NV services: Difference between revisions

From Nintendo Switch Brew
Jump to navigation Jump to search
No edit summary
 
(76 intermediate revisions by 6 users not shown)
Line 1: Line 1:
The Switch uses a customized NVIDIA driver.
= nvdrv, nvdrv:a, nvdrv:s, nvdrv:t =
= nvdrv, nvdrv:a, nvdrv:s, nvdrv:t =
This is "nns::nvdrv::INvDrvServices".
This is "nns::nvdrv::INvDrvServices".
Main NVIDIA driver service.


Each service is used by:
Each service is used by:
* "nvdrv": Applications.
* "nvdrv": Applications.
** [[#Permissions|Permission]] mask is [3.0.0+] 0xA82B ([1.0.0-2.3.0] 0x2B).
** [[#NvDrvPermission|Permission]] mask is [11.0.0+] 0xA83B ([1.0.0-2.3.0] 0x2B, [3.0.0+] 0xA82B).
* "nvdrv:a": Applets.
* "nvdrv:a": Applets.
** [[#Permissions|Permission]] mask is [3.0.0+] 0x10A9 ([1.0.0-2.3.0] 0xA9).
** [[#NvDrvPermission|Permission]] mask is [3.0.0+] 0x10A9 ([1.0.0-2.3.0] 0xA9).
* "nvdrv:s": Sysmodules.
* "nvdrv:s": Sysmodules.
** [[#Permissions|Permission]] mask is [3.0.0+] 0x439E ([1.0.0-2.3.0] 0x39E).
** [[#NvDrvPermission|Permission]] mask is [3.0.0+] 0x439E ([1.0.0-2.3.0] 0x39E).
* "nvdrv:t": Factory.
* "nvdrv:t": Factory.
** [[#Permissions|Permission]] mask is 0xFFFFFFFF.
** [[#NvDrvPermission|Permission]] mask is 0xFFFFFFFF.


{| class="wikitable" border="1"
{| class="wikitable" border="1"
Line 20: Line 16:
! Cmd || Name
! Cmd || Name
|-
|-
| 0 || [[#Open]]
| 0 || [[#Open|Open]]
|-
|-
| 1 || [[#Ioctl]]
| 1 || [[#Ioctl|Ioctl]]
|-
|-
| 2 || [[#Close]]
| 2 || [[#Close|Close]]
|-
|-
| 3 || [[#Initialize]]
| 3 || [[#Initialize|Initialize]]
|-
|-
| 4 || [[#QueryEvent]]
| 4 || [[#QueryEvent|QueryEvent]]
|-
|-
| 5 || [[#MapSharedMem]]
| 5 || [[#MapSharedMem|MapSharedMem]]
|-
|-
| 6 || [[#GetStatus]]
| 6 || [[#GetStatus|GetStatus]]
|-
|-
| 7 || [[#SetAruidWithoutCheck]]
| 7 || [[#SetAruidWithoutCheck|SetAruidWithoutCheck]]
|-
|-
| 8 || [[#SetAruid]]
| 8 || [[#SetAruid|SetAruid]]
|-
|-
| 9 || [[#DumpStatus]]
| 9 || [[#DumpStatus|DumpStatus]]
|-
|-
| 10 || [3.0.0+] [[#InitializeDevtools]]
| 10 || [3.0.0+] [[#InitializeDevtools|InitializeDevtools]]
|-
|-
| 11 || [3.0.0+] [[#Ioctl2]]
| 11 || [3.0.0+] [[#Ioctl2|Ioctl2]]
|-
|-
| 12 || [3.0.0+] [[#Ioctl3]]
| 12 || [3.0.0+] [[#Ioctl3|Ioctl3]]
|-
|-
| 13 || [3.0.0+] [[#SetGraphicsFirmwareMemoryMarginEnabled]]
| 13 || [3.0.0+] [[#SetGraphicsFirmwareMemoryMarginEnabled|SetGraphicsFirmwareMemoryMarginEnabled]]
|}
|}


== Open ==
== Open ==
Takes a type-0x5 input buffer for the device-path. Returns the output 32bit '''fd''' and the u32 '''error_code'''.
Takes a type-0x5 input buffer '''Path'''. Returns two output u32s '''FdOut''' and '''Err'''.


== Ioctl ==
== Ioctl ==
Takes a 32bit '''fd''', an u32 '''ioctl_cmd''', a type-0x21 input buffer, and a type-0x22 output buffer. Returns an output u32 ('''error_code''').
Takes two input u32s '''Fd''' and '''Iocode''', a type-0x21 input buffer and a type-0x22 output buffer. Returns an output u32 '''Err'''.


The addr/size for send/recv buffers are only set when the associated direction bit is set in the ioctl cmd (addr/size = 0 otherwise).
The addr/size for send/recv buffers are only set when the associated direction bit is set in the ioctl cmd (addr/size = 0 otherwise).


== Close ==
== Close ==
Takes a 32bit '''fd'''. Returns an output u32 ('''error_code''').
Takes an input u32 '''Fd'''. Returns an output u32 '''Err'''.


== Initialize ==
== Initialize ==
Takes two copy-handles ('''current_process''' and '''transfer_memory''') and an input u32 ('''transfer_memory_size'''). Returns an output u32 ('''error_code''').
Takes an input Process handle, an input TransferMemory handle and an input u32 '''Size'''. Returns an output u32 '''Err'''.


Webkit applet creates the transfer-memory with perm = 0 and size 0x300000.
Webkit applet creates the TransferMemory with perm == 0 and size == 0x300000.


== QueryEvent ==
== QueryEvent ==
Takes two input u32s ('''fd''' and '''event_id'''), with the second word immediately after the first one. Returns an output u32 ('''error_code''') and a copy-handle ('''event_handle''').
Takes two input u32s '''Fd''' and '''EvtId'''. Returns an output u32 '''Err''' and an output Event handle.
 
QueryEvent is only supported by:
* '''/dev/nvcec-ctrl'''
** EvtId=0
** EvtId=1
** EvtId=2
** EvtId=3
** EvtId=4
** EvtId=5
** EvtId=6
** EvtId=7
** EvtId=8
** EvtId=9
 
* '''/dev/nvhdcp_up-ctrl'''
** EvtId=0: DphdcpStateEvent
 
* '''/dev/nvdisp-ctrl'''
** EvtId=0: HpdInEvent
** EvtId=1: HpdOutEvent
** EvtId=2: VblankHead0Event
 
* '''/dev/nvhost-gpu'''
** EvtId=1: BptIntEvent
** EvtId=2: BptPauseEvent
** EvtId=3: ErrorNotifierEvent
 
* '''/dev/nvhost-ctrl'''
** EvtId=(EventSlot | ((SyncptId & 0xFFF) << 16) | (IsValid << 28)): New format used by [[#NVHOST_IOCTL_CTRL_SYNCPT_WAIT_EVENT|NVHOST_IOCTL_CTRL_SYNCPT_WAIT_EVENT]]/[[#NVHOST_IOCTL_CTRL_SYNCPT_WAIT_EVENT_EX|NVHOST_IOCTL_CTRL_SYNCPT_WAIT_EVENT_EX]].
** EvtId=(EventSlot | (SyncptId << 4)): Old format used by [[#NVHOST_IOCTL_CTRL_SYNCPT_WAITEX|NVHOST_IOCTL_CTRL_SYNCPT_WAITEX]].


QueryEvent is only supported on (and implemented differently on):
* '''/dev/nvhost-ctrl-gpu'''
* /dev/nvhost-gpu
** EvtId=1: ErrorEvent
** 1: SmException_BptIntReport
** EvtId=2: SemaphoreEvent
** 2: SmException_BptPauseReport
 
** 3: ErrorNotifierEvent
* '''/dev/nvhost-dbg-gpu'''
* /dev/nvhost-ctrl: Used to get events for SyncPts.
** EvtId=Any: DbgEvents
** If bit31-28 is 1, then lower 16-bits contain event_slot, bit27-16 contain syncpt_number.
 
** If bit31-28 is 0, then lower 4-bits contain event_slot, bit31-4 contains syncpt_number.
* '''/dev/nvsched-ctrl'''
* /dev/nvhost-ctrl-gpu
** EvtId=0: ApplicationAddedEvent
** 1: Returns error_event_handle.
** EvtId=1: ApplicationUpdatedEvent
** 2: Returns unknown event.
** EvtId=2: ApplicationMaxDebtUpdatedEvent
* /dev/nvhost-dbg-gpu
** EvtId=3: ApplicationRemovedEvent
** Ignores event_id.
** EvtId=4: ApplicationDetachedEvent
** EvtId=5: RunlistAddedEvent
** EvtId=6: RunlistUpdatedEvent
** EvtId=7: RunlistMaxDebtUpdatedEvent
** EvtId=8: RunlistLinkedEvent
** EvtId=9: RunlistUnlinkedEvent
** EvtId=10: RunlistRemovedEvent
** EvtId=11: ConductorSwapintervalUpdatedEvent
** EvtId=12: ChannelAcquiredEvent
** EvtId=13: ChannelReleasedEvent


== MapSharedMem ==
== MapSharedMem ==
Takes a copy-handle ('''transfer_memory''') and two input u32s ('''fd''' and '''nvmap_handle'''). Returns an output u32 ('''error_code''').
Takes an input TransferMemory handle and two input u32s '''Fd''' and '''HMem'''. Returns an output u32 '''Err'''.
 
'''HMem''' is a [[#/dev/nvmap|/dev/nvmap]] memory handle.


== GetStatus ==
== GetStatus ==
Takes no input. Returns 0x10-bytes and an output u32 ('''error_code''').
Takes no input. Returns an output [[#NvDrvStatus]] and an output u32 '''Err'''.


== SetAruidWithoutCheck ==
== SetAruidWithoutCheck ==
Takes an input u64 which must [[IPC_Marshalling|match]] the user-process PID ([[Applet_Manager_services#AppletResourceUserId|AppletResourceUserId]]). Returns an output u32 ('''error_code''').
Takes an input u64 '''Aruid'''. Returns an output u32 '''Err'''.
 
'''Aruid''' must [[IPC_Marshalling|match]] the current [[Applet_Manager_services#AppletResourceUserId|AppletResourceUserId]].


== SetAruid ==
== SetAruid ==
Takes a PID-descriptor and an u64 which must [[IPC_Marshalling|match]] the user-process PID ([[Applet_Manager_services#AppletResourceUserId|AppletResourceUserId]]). Returns an output u32 ('''error_code''').
Takes a PID-descriptor and an input [[Applet_Manager_services#AppletResourceUserId|AppletResourceUserId]]. Returns an output u32 '''Err'''.


== DumpStatus ==
== DumpStatus ==
No input or output.
No input/output.


== InitializeDevtools ==
== InitializeDevtools ==
Takes a copy-handle ('''transfer_memory''') and an input u32 ('''transfer_memory_size'''). Returns an output u32 ('''error_code''').
Takes an input TransferMemory handle and an input u32 '''Size'''. Returns an output u32 '''Err'''.


== Ioctl2 ==
== Ioctl2 ==
Takes a type-0x21 buffer, a type-0x22 buffer, a type-0x21 buffer, and two input u32s. Returns an output u32 ('''error_code''').
Takes two input u32s '''Fd''' and '''Iocode''', two type-0x21 input buffers and a type-0x22 output buffer. Returns an output u32 '''Err'''.


== Ioctl3 ==
== Ioctl3 ==
Takes a type-0x21 buffer, a type-0x22 buffer, another type-0x22 buffer, and two input u32s. Returns an output u32 (error_code).
Takes two input u32s '''Fd''' and '''Iocode''', a type-0x21 input buffer and two type-0x22 output buffers. Returns an output u32 '''Err'''.
Cmdhdr_word1 is 0x100B instead of 0xC0B.


== SetGraphicsFirmwareMemoryMarginEnabled ==
== SetGraphicsFirmwareMemoryMarginEnabled ==
Unofficial name.
Takes an input u64. No output.
Takes an input u64. No output.


This sets a boolean value based on the input u64 and the value of the "nv!nv_graphics_firmware_memory_margin" system configuration, but only for "nvdrv" (the other services default to false).
This sets a boolean value based on the input u64 and the value of the "nv!nv_graphics_firmware_memory_margin" system configuration, but only for "nvdrv" (the other services default to false).


Official user-processes starting with 3.0.0 now use this at the end of nvdrv service init with value 0x1.
[3.0.0+] Official user-processes now use this at the end of nvdrv service init with value 0x1.


= Permissions =
= nvmemp =
Each nvdrv service is initialized with a bitfield that controls access to nodes and other operations.
This is "nv::MemoryProfiler::IMemoryProfiler".
 
/dev/nvhost-ctrl sends the ioctl NVHOST_IOCTL_CTRL_GET_CONFIG to check the config "nv!NV_MEMORY_PROFILER". If config_str returns "1", the application attempts to use nvmemp.


{| class="wikitable" border="1"
{| class="wikitable" border="1"
!  Bits
!  Name
!  Description
|-
|-
| 0
! Cmd || Name
| NvDrvPermission_Gpu
| Can access [[#Channels|/dev/nvhost-gpu]], [[#/dev/nvhost-ctrl-gpu|/dev/nvhost-ctrl-gpu]] and [[#/dev/nvhost-as-gpu|/dev/nvhost-as-gpu]].
|-
|-
| 1
| 0 || [[#Open_2|Open]]
| NvDrvPermission_GpuDebug
| Can access [[#/dev/nvhost-dbg-gpu|/dev/nvhost-dbg-gpu]] and [[#/dev/nvhost-prof-gpu|/dev/nvhost-prof-gpu]].
|-
|-
| 2
| 1 || [[#GetPid|GetPid]]
| NvDrvPermission_GpuSchedule
|}
| Can access [[#/dev/nvsched-ctrl|/dev/nvsched-ctrl]].
 
== Open ==
Takes an input TransferMemory handle and an input u32 '''Size'''. No output.
 
== GetPid ==
No input. Returns an output u32 '''Pid'''.
 
= nvdrvdbg =
This is "nns::nvdrv::INvDrvDebugFSServices".
 
{| class="wikitable" border="1"
|-
|-
| 3
! Cmd || Name
| NvDrvPermission_VIC
| Can access [[#Channels|/dev/nvhost-vic]].
|-
|-
| 4
| 0 || [[#DebugFSOpen|DebugFSOpen]]
| NvDrvPermission_VideoEncoder
| Can access [[#Channels|/dev/nvhost-msenc]].
|-
|-
| 5
| 1 || [[#DebugFSClose|DebugFSClose]]
| NvDrvPermission_VideoDecoder
| Can access [[#Channels|/dev/nvhost-nvdec]].
|-
|-
| 6
| 2 || [[#GetDebugFSKeys|GetDebugFSKeys]]
| NvDrvPermission_TSEC
| Can access [[#Channels|/dev/nvhost-tsec]].
|-
|-
| 7
| 3 || [[#GetDebugFSValue|GetDebugFSValue]]
| NvDrvPermission_JPEG
| Can access [[#Channels|/dev/nvhost-nvjpg]].
|-
|-
| 8
| 4 || [[#SetDebugFSValue|SetDebugFSValue]]
| NvDrvPermission_Display
|}
| Can access [[#Channels|/dev/nvhost-display]], [[#/dev/nvcec-ctrl|/dev/nvcec-ctrl]], [[#/dev/nvhdcp_up-ctrl|/dev/nvhdcp_up-ctrl]], [[#/dev/nvdisp-ctrl|/dev/nvdisp-ctrl]], [[#/dev/nvdisp-disp0, /dev/nvdisp-disp1|/dev/nvdisp-disp0]], [[#/dev/nvdisp-disp0, /dev/nvdisp-disp1|/dev/nvdisp-disp1]], [[#/dev/nvdcutil-disp0, /dev/nvdcutil-disp1|/dev/nvdcutil-disp0]] and [[#/dev/nvdcutil-disp0, /dev/nvdcutil-disp1|/dev/nvdcutil-disp1]].
 
|-
== DebugFSOpen ==
| 9
Takes an input Process handle. Returns an output u32 '''Handle'''.
| NvDrvPermission_ImportMemory
 
| Can duplicate [[#/dev/nvmap|nvmap]] handles from other processes with [[#NVMAP_IOC_FROM_ID|NVMAP_IOC_FROM_ID]].
== DebugFSClose ==
|-
Takes an input u32 '''Handle'''. No output.
| 10
 
| NvDrvPermission_NoCheckedAruid
== GetDebugFSKeys ==
| Can use [[#SetAruidWithoutCheck|SetAruidWithoutCheck]].
Takes an input u32 '''Handle''' and a type-0x6 output buffer '''OutValueBuf'''. Returns an output u32 '''Err'''.
 
== GetDebugFSValue ==
Takes an input u32 '''Handle''', a type-0x5 input buffer '''InKeyBuf''' and a type-0x6 output buffer '''OutValueBuf'''. Returns an output u32 '''Err'''.
 
== SetDebugFSValue ==
Takes an input u32 '''Handle''' and two type-0x5 input buffers '''InKeyBuf''' and '''InValueBuf'''. Returns an output u32 '''Err'''.
 
= nvgem:c =
This is "nv::gemcontrol::INvGemControl".
 
{| class="wikitable" border="1"
|-
! Cmd || Name
|-
| 0 || [[#Initialize_2|Initialize]]
|-
| 1 || [[#GetEventHandle|GetEventHandle]]
|-
| 2 || [[#ControlNotification|ControlNotification]]
|-
|-
| 11
| 3 || [[#SetNotificationPerm|SetNotificationPerm]]
|
| Can use [[#SetGraphicsFirmwareMemoryMarginEnabled|SetGraphicsFirmwareMemoryMarginEnabled]].
|-
|-
| 12
| 4 || [[#SetCoreDumpPerm|SetCoreDumpPerm]]
|
| Can duplicate exported [[#/dev/nvmap|nvmap]] handles from other processes with [[#NVMAP_IOC_FROM_ID|NVMAP_IOC_FROM_ID]].
|-
|-
| 13
| 5 || [1.0.0-4.1.0] [[#GetAruid|GetAruid]]
|
|  
|-
|-
| 14
| 6 || [[#Reset|Reset]]
|
| Can use [[#NVMAP_IOC_EXPORT_FOR_ARUID|NVMAP_IOC_EXPORT_FOR_ARUID]] and [[#NVMAP_IOC_REMOVE_EXPORT_FOR_ARUID|NVMAP_IOC_REMOVE_EXPORT_FOR_ARUID]].
|-
|-
| 15
| 7 || [3.0.0+] [[#GetAruid2|GetAruid2]]
|
|  
|}
|}


Nodes [[#/dev/nvmap|/dev/nvmap]], [[#/dev/nvhost-ctrl|/dev/nvhost-ctrl]] and [[#/dev/nverpt-ctrl|/dev/nverpt-ctrl]] are always accessible.
== Initialize ==
No input. Returns an output u32 '''Err'''.


= Ioctls =
== GetEventHandle ==
The ioctl number is generated with the following primitive (see Linux kernel):
No input. Returns an output Event handle and an output u32 '''Err'''.
 
== ControlNotification ==
Takes an input bool '''Enable'''. Returns an output u32 '''Err'''.
 
== SetNotificationPerm ==
Takes an input u64 '''Aruid''' and an input bool '''Enable'''. Returns an output u32 '''Err'''.
 
== SetCoreDumpPerm ==
Takes an input u64 '''Aruid''' and an input bool '''Enable'''. Returns an output u32 '''Err'''.
 
== GetAruid ==
No input. Returns an output u64 '''Aruid''' and an output u32 '''Err'''.
 
== Reset ==
No input. Returns an output u32 '''Err'''.
 
== GetAruid2 ==
Unofficial name.


#define _IOC(inout, group, num, len) \
No input. Returns an output u64 '''Aruid''', an output bool '''IsCoreDumpEnabled''' and an output u32 '''Err'''.
    (inout | ((len & IOCPARM_MASK) << 16) | ((group) << 8) | (num))


The following table contains known ioctls.
= nvgem:cd =
This is "nv::gemcoredump::INvGemCoreDump".


== /dev/nvhost-ctrl ==
{| class="wikitable" border="1"
{| class="wikitable" border="1"
! Value || Direction || Size || Description
|-
|-
| 0xC0080014 || Inout || 8 || [[#NVHOST_IOCTL_CTRL_SYNCPT_READ]]
! Cmd || Name
|-
|-
| 0x40040015 || In || 4 || [[#NVHOST_IOCTL_CTRL_SYNCPT_INCR]]
| 0 || [[#Initialize_3|Initialize]]
|-
|-
| 0xC00C0016 || Inout || 12 || [[#NVHOST_IOCTL_CTRL_SYNCPT_WAIT]]
| 1 || [[#GetAruid_2|GetAruid]]
|-
|-
| 0x40080017 || In || 8 || [[#NVHOST_IOCTL_CTRL_MODULE_MUTEX]]
| 2 || [1.0.0-8.1.0] [[#ReadNextBlock|ReadNextBlock]]
|-
|-
| 0xC0180018 || Inout || 24 || [[#NVHOST_IOCTL_CTRL_MODULE_REGRDWR]]
| 3 || [8.0.0+] [[#GetNextBlockSize|GetNextBlockSize]]
|-
|-
| 0xC0100019 || Inout || 16 || [[#NVHOST_IOCTL_CTRL_SYNCPT_WAITEX]]
| 4 || [8.0.0+] [[#ReadNextBlock2|ReadNextBlock2]]
|-
| 0xC008001A || Inout || 8 || [[#NVHOST_IOCTL_CTRL_SYNCPT_READ_MAX]]
|-
| 0xC183001B || Inout || 387 || [[#NVHOST_IOCTL_CTRL_GET_CONFIG]]
|-
| 0xC004001C || Inout || 4 || [[#NVHOST_IOCTL_CTRL_SYNCPT_CLEAR_EVENT_WAIT]]
|-
| 0xC010001D || Inout || 16 || [[#NVHOST_IOCTL_CTRL_SYNCPT_EVENT_WAIT]]
|-
| 0xC010001E || Inout || 16 || [[#NVHOST_IOCTL_CTRL_SYNCPT_EVENT_WAIT_ASYNC]]
|-
| 0xC004001F || Inout || 4 || [[#NVHOST_IOCTL_CTRL_SYNCPT_REGISTER_EVENT]]
|-
| 0xC0040020 || Inout || 4 || [[#NVHOST_IOCTL_CTRL_SYNCPT_UNREGISTER_EVENT]]
|-
| 0x40080021 || In || 8 || [[#NVHOST_IOCTL_CTRL_SYNCPT_FREE_EVENTS]]
|-
| 0xC0040022 || Inout || 4 || [[#NVHOST_IOCTL_CTRL_GET_MAX_EVENT_FIFO_CHANNEL]]
|}
|}


=== NVHOST_IOCTL_CTRL_SYNCPT_READ ===
== Initialize ==
Identical to Linux driver.
No input. Returns an output u32 '''Err'''.
 
== GetAruid ==
No input. Returns an output u64 '''Aruid''' and an output u32 '''Err'''.


  struct {
== ReadNextBlock ==
    __in  u32 id;
Takes a type-0x6 output buffer. Returns an output u32 '''Err'''.
    __out u32 value;
  };


=== NVHOST_IOCTL_CTRL_SYNCPT_INCR ===
== GetNextBlockSize ==
Identical to Linux driver.
Unofficial name.


  struct {
No input. Returns an output u64 '''Size''' and an output u32 '''Err'''.
    __in u32 id;
  };


=== NVHOST_IOCTL_CTRL_SYNCPT_WAIT ===
== ReadNextBlock2 ==
Identical to Linux driver.
Unofficial name.


  struct {
Takes a type-0x6 output buffer and two input u64s '''Size''' and '''Offset'''. Returns an output u64 '''OutSize''' and an output u32 '''Err'''.
    __in u32 id;
    __in u32 thresh;
    __in s32 timeout;
  };


=== NVHOST_IOCTL_CTRL_MODULE_MUTEX ===
= nvdbg:d =
Identical to Linux driver.
This is "nns::nvdrv::INvDrvDebugSvcServices". This was added with [10.0.0+].


  struct {
This service has no commands.
    __in u32 id;
    __in u32 lock;        // (0==unlock; 1==lock)
  };


=== NVHOST_IOCTL_CTRL_MODULE_REGRDWR ===
= (S2) INvDrv2User =
Identical to Linux driver. Uses 32-bit version and doesn't work.
This is "nn::nvdrv::INvDrv2User".


  struct {
{| class="wikitable" border="1"
    __in u32 id;
|-
    __in u32 num_offsets;
! Cmd || Name
    __in u32 block_size;
|-
    __in u32 offsets;
| 0 || Open
    __in u32 values;
|-
    __in u32 write;
| 1 || Ioctl
  };
|-
| 2 || Close
|-
| 4 || QueryEvent
|-
| 9 || DumpStatus
|-
| 10 || InitializeDevtools
|-
| 11 || Ioctl2
|-
| 12 || Ioctl3
|-
| 13 || [[#SetConfiguration|SetConfiguration]]
|}


=== NVHOST_IOCTL_CTRL_SYNCPT_WAITEX ===
== SetConfiguration ==
Identical to Linux driver.
Unofficial name.


  struct {
Takes an input u64 '''Configuration'''. No output.
    __in  u32 id;
    __in  u32 thresh;
    __in  s32 timeout;
    __out u32 value;
  };


=== NVHOST_IOCTL_CTRL_SYNCPT_READ_MAX ===
Bit 0 in '''Configuration''' represents the old '''GraphicsFirmwareMemoryMarginEnabled''' option.
Identical to Linux driver.


  struct {
= Ioctls =
    __in  u32 id;
The ioctl number is generated with the following primitive (see Linux kernel):
    __out u32 value;
  };


=== NVHOST_IOCTL_CTRL_GET_CONFIG ===
#define _IOC(inout, group, num, len) \
Returns configured settings. Not available in production mode.
    (inout | ((len & IOCPARM_MASK) << 16) | ((group) << 8) | (num))


  struct {
The following table contains all known ioctls.
    __in char domain_str[0x41];      // "nv"
    __in char param_str[0x41];
    __out char config_str[0x101];
  };


=== NVHOST_IOCTL_CTRL_SYNCPT_CLEAR_EVENT_WAIT ===
== /dev/nvhost-ctrl ==
Clears the wait signal of an event. Exclusive to the Switch.
{| class="wikitable" border="1"
 
! Value || Direction || Size || Description
  struct {
|-
    __in u32 event_slot;        // ranges from 0x00 to 0x3F
| 0xC0080014 || Inout || 8 || [[#NVHOST_IOCTL_CTRL_SYNCPT_READ|NVHOST_IOCTL_CTRL_SYNCPT_READ]]
  };
|-
 
| 0x40040015 || In || 4 || [[#NVHOST_IOCTL_CTRL_SYNCPT_INCR|NVHOST_IOCTL_CTRL_SYNCPT_INCR]]
=== NVHOST_IOCTL_CTRL_SYNCPT_EVENT_WAIT ===
|-
Waits on an event. If waiting fails, returns error code 0x05 (Timeout) and sets '''value''' to (('''syncpt_id''' << 0x10) | 0x10000000).
| 0xC00C0016 || Inout || 12 || [[#NVHOST_IOCTL_CTRL_SYNCPT_WAIT|NVHOST_IOCTL_CTRL_SYNCPT_WAIT]]
 
|-
Depending on '''threshold''', an '''event_slot''' may be returned for using with other event ioctls.
| 0x40080017 || In || 8 || [[#NVHOST_IOCTL_CTRL_MODULE_MUTEX|NVHOST_IOCTL_CTRL_MODULE_MUTEX]]
 
|-
  struct {
| 0xC0180018 || Inout || 24 || [[#NVHOST_IOCTL_CTRL_MODULE_REGRDWR|NVHOST_IOCTL_CTRL_MODULE_REGRDWR]]
    __in    u32 syncpt_id;
|-
    __in    u32 threshold;
| 0xC0100019 || Inout || 16 || [[#NVHOST_IOCTL_CTRL_SYNCPT_WAITEX|NVHOST_IOCTL_CTRL_SYNCPT_WAITEX]]
    __in    s32 timeout;
    __inout u32 value;          // in=event_slot (ignored); out=syncpt_value or event_slot
  };
 
=== NVHOST_IOCTL_CTRL_SYNCPT_EVENT_WAIT_ASYNC ===
Waits on an event (async version). If waiting fails, returns error code 0x0B (BadValue).
 
Depending on '''threshold''', an '''event_slot''' may be returned for using with other event ioctls.
 
  struct {
    __in    u32 syncpt_id;
    __in    u32 threshold;
    __in    u32 timeout;
    __inout u32 value;          // in=event_slot (ignored); out=syncpt_value or event_slot
  };
 
=== NVHOST_IOCTL_CTRL_SYNCPT_REGISTER_EVENT ===
Registers an event. Exclusive to the Switch.
 
  struct {
    __in u32 event_slot;        // ranges from 0x00 to 0x3F
  };
 
=== NVHOST_IOCTL_CTRL_SYNCPT_UNREGISTER_EVENT ===
Unregisters an event. Exclusive to the Switch.
 
  struct {
    __in u32 event_slot;        // ranges from 0x00 to 0x3F
  };
 
=== NVHOST_IOCTL_CTRL_SYNCPT_FREE_EVENTS ===
Frees events. Exclusive to the Switch.
 
  struct {
    __in u64 events;            // 64-bit bitfield where each bit represents one event
  };
 
=== NVHOST_IOCTL_CTRL_GET_MAX_EVENT_FIFO_CHANNEL ===
If event FIFO is enabled, returns the maximum channel number. Exclusive to the Switch.
 
  struct {
    __out u32 max_channel;      // 0x00 (FIFO disabled) or 0x60 (FIFO enabled)
  };
 
== /dev/nvmap ==
{| class="wikitable" border="1"
! Value || Direction || Size || Description
|-
|-
| 0xC0080101 || Inout || 8 || [[#NVMAP_IOC_CREATE]]
| 0xC008001A || Inout || 8 || [[#NVHOST_IOCTL_CTRL_SYNCPT_READ_MAX|NVHOST_IOCTL_CTRL_SYNCPT_READ_MAX]]
|-
|-
| 0x00000102 || - || 0 || [[#NVMAP_IOC_CLAIM]]
| 0xC183001B || Inout || 387 || [[#NVHOST_IOCTL_CTRL_GET_CONFIG|NVHOST_IOCTL_CTRL_GET_CONFIG]]
|-
|-
| 0xC0080103 || Inout || 8 || [[#NVMAP_IOC_FROM_ID]]
| 0xC004001C || Inout || 4 || [[#NVHOST_IOCTL_CTRL_SYNCPT_CLEAR_EVENT_WAIT|NVHOST_IOCTL_CTRL_SYNCPT_CLEAR_EVENT_WAIT]]
|-
|-
| 0xC0200104 || Inout || 32 || [[#NVMAP_IOC_ALLOC]]
| 0xC010001D || Inout || 16 || [[#NVHOST_IOCTL_CTRL_SYNCPT_WAIT_EVENT|NVHOST_IOCTL_CTRL_SYNCPT_WAIT_EVENT]]
|-
|-
| 0xC0180105 || Inout || 24 || [[#NVMAP_IOC_FREE]]
| 0xC010001E || Inout || 16 || [[#NVHOST_IOCTL_CTRL_SYNCPT_WAIT_EVENT_EX|NVHOST_IOCTL_CTRL_SYNCPT_WAIT_EVENT_EX]]
|-
|-
| 0xC0280106 || Inout || 40 || [[#NVMAP_IOC_MMAP]]
| 0xC004001F || Inout || 4 || [[#NVHOST_IOCTL_CTRL_SYNCPT_ALLOC_EVENT|NVHOST_IOCTL_CTRL_SYNCPT_ALLOC_EVENT]]
|-
|-
| 0xC0280107 || Inout || 40 || [[#NVMAP_IOC_WRITE]]
| 0xC0040020 || Inout || 4 || [[#NVHOST_IOCTL_CTRL_SYNCPT_FREE_EVENT|NVHOST_IOCTL_CTRL_SYNCPT_FREE_EVENT]]
|-
|-
| 0xC0280108 || Inout || 40 || [[#NVMAP_IOC_READ]]
| 0x40080021 || In || 8 || [[#NVHOST_IOCTL_CTRL_SYNCPT_FREE_EVENT_BATCH|NVHOST_IOCTL_CTRL_SYNCPT_FREE_EVENT_BATCH]]
|-
|-
| 0xC00C0109 || Inout || 12 || [[#NVMAP_IOC_PARAM]]
| 0xC0040022 || Inout || 4 || [[#NVHOST_IOCTL_CTRL_SYNCPT_GET_SHIFT|NVHOST_IOCTL_CTRL_SYNCPT_GET_SHIFT]]
|-
|-
| 0xC010010A || Inout || 16 || [[#NVMAP_IOC_PIN_MULT]]
| 0xC0080027 || Inout || 8 || [S2] NVHOST_IOCTL_CTRL_ALLOC_SYNCPT
|-
|-
| 0xC010010B || Inout || 16 || [[#NVMAP_IOC_UNPIN_MULT]]
| 0x40040028 || In || 4 || [S2] NVHOST_IOCTL_CTRL_FREE_SYNCPT
|-
|-
| 0xC008010C || Inout || 8 || [[#NVMAP_IOC_CACHE]]
| 0xC010002A || Inout || 16 || [S2] NVHOST_IOCTL_CTRL_GET_CHARACTERISTICS
|-
|-
| 0xC004010D || Inout || 4 || [[#NVMAP_IOC_GET_IVC_ID]]
| 0xC008002B || Inout || 8 || [S2] NVHOST_IOCTL_CTRL_CHECK_MODULE_SUPPORT
|-
|}
| 0xC008010E || Inout || 8 || [[#NVMAP_IOC_GET_ID]]
 
|-
=== NVHOST_IOCTL_CTRL_SYNCPT_READ ===
| 0xC004010F || Inout || 4 || [[#NVMAP_IOC_FROM_IVC_ID]]
Identical to Linux driver.
|-
| 0x40040110 || In || 4 || [[#NVMAP_IOC_SET_ALLOCATION_TAG_LABEL]]
|-
| 0x00000111 || - || 0 || [[#NVMAP_IOC_RESERVE]]
|-
| 0x40100112 || In || 16 || [[#NVMAP_IOC_EXPORT_FOR_ARUID]]
|-
| 0x40100113 || In || 16 || [[#NVMAP_IOC_IS_OWNED_BY_ARUID]]
|-
| 0x40100114 || In || 16 || [[#NVMAP_IOC_REMOVE_EXPORT_FOR_ARUID]]
|}
 
=== NVMAP_IOC_CREATE ===
Creates an nvmap object. Identical to Linux driver.


   struct {
   struct {
     __in  u32 size;
     __in  u32 id;
     __out u32 handle;
     __out u32 value;
   };
   };


=== NVMAP_IOC_CLAIM ===
=== NVHOST_IOCTL_CTRL_SYNCPT_INCR ===
Returns [[#Errors|NotSupported]].
Identical to Linux driver.
 
=== NVMAP_IOC_FROM_ID ===
Get handle to an existing nvmap object. Identical to Linux driver.


   struct {
   struct {
     __in u32 id;
     __in u32 id;
    __out u32 handle;
   };
   };


=== NVMAP_IOC_ALLOC ===
=== NVHOST_IOCTL_CTRL_SYNCPT_WAIT ===
Allocate memory for the nvmap object. Nintendo extended this one with 16 bytes, and changed it from in to inout.
Identical to Linux driver.


   struct {
   struct {
     __in u32 handle;
     __in u32 id;
     __in u32 heapmask;
     __in u32 thresh;
     __in u32 flags;    // (0=read-only, 1=read-write)
     __in s32 timeout;
    __in u32 align;
    __in u8  kind;
    u8      pad[7];
    __inout u64 addr;
   };
   };


=== NVMAP_IOC_FREE ===
=== NVHOST_IOCTL_CTRL_MODULE_MUTEX ===
This one is completely custom. Partly because the Linux driver passed the handle as the ioctl "arg-ptr", and HIPC can't handle that voodoo.
Identical to Linux driver.


   struct {
   struct {
     __in u32 handle;
     __in u32 id;
     u32       pad;
     __in u32 lock;       // 0=unlock, 1=lock
    __out u64 address;
    __out u32 size;
    __out u32 flags;    // 1=NOT_FREED_YET
   };
   };


=== NVMAP_IOC_MMAP ===
=== NVHOST_IOCTL_CTRL_MODULE_REGRDWR ===
Returns [[#Errors|NotSupported]].
Identical to Linux driver. Uses 32-bit version and doesn't work.
 
=== NVMAP_IOC_WRITE ===
Returns [[#Errors|NotSupported]].
 
=== NVMAP_IOC_READ ===
Returns [[#Errors|NotSupported]].
 
=== NVMAP_IOC_PARAM ===
Returns info about a nvmap object. Identical to Linux driver, but extended with further params.


   struct {
   struct {
     __in u32 handle;
     __in u32 id;
     __in u32 param; // 1=SIZE, 2=ALIGNMENT, 3=BASE (returns error), 4=HEAP (always 0x40000000), 5=KIND, 6=COMPR (unused)
     __in u32 num_offsets;
     __out u32 result;
     __in u32 block_size;
    __in u32 offsets;
    __in u32 values;
    __in u32 write;
   };
   };


=== NVMAP_IOC_PIN_MULT ===
=== NVHOST_IOCTL_CTRL_SYNCPT_WAITEX ===
Returns [[#Errors|NotSupported]].
Identical to Linux driver.


=== NVMAP_IOC_UNPIN_MULT ===
  struct {
Returns [[#Errors|NotSupported]].
    __in  u32 id;
    __in  u32 thresh;
    __in  s32 timeout;
    __out u32 value;
  };


=== NVMAP_IOC_CACHE ===
=== NVHOST_IOCTL_CTRL_SYNCPT_READ_MAX ===
Returns [[#Errors|NotSupported]].
Identical to Linux driver.


=== NVMAP_IOC_GET_IVC_ID ===
  struct {
Returns [[#Errors|NotSupported]].
    __in  u32 id;
    __out u32 value;
  };


=== NVMAP_IOC_GET_ID ===
=== NVHOST_IOCTL_CTRL_GET_CONFIG ===
Returns an id for a nvmap object. Identical to Linux driver.
Returns configured settings. Not available in production mode.


   struct {
   struct {
     __out u32 id; //~0 indicates error
     __in char name[0x41];       // "nv"
     __in u32 handle;
     __in char key[0x41];
    __out char value[0x101];
   };
   };


=== NVMAP_IOC_FROM_IVC_ID ===
=== NVHOST_IOCTL_CTRL_SYNCPT_CLEAR_EVENT_WAIT ===
Returns [[#Errors|NotSupported]].
Clears the wait signal of a syncpt event.


=== NVMAP_IOC_SET_ALLOCATION_TAG_LABEL ===
  struct {
Returns [[#Errors|NotSupported]].
    __in u32 event_slot;      // 0x00 to 0x3F
  };


=== NVMAP_IOC_RESERVE ===
=== NVHOST_IOCTL_CTRL_SYNCPT_WAIT_EVENT ===
Returns [[#Errors|NotSupported]].
Waits on a syncpt using events. If waiting fails, returns error code 0x05 (Timeout) and sets '''value''' to ('''event_slot''' | (('''syncpt_id''' & 0xFFF) << 16) | ('''is_valid''' << 28)).
 
=== NVMAP_IOC_EXPORT_FOR_ARUID ===
Binds a nvmap object to an [[Applet_Manager_services#AppletResourceUserId|AppletResourceUserId]].


   struct {
   struct {
     __in  u64 aruid;
     __in  u32 id;
     __in  u32 handle;
     __in  u32 thresh;
     u8        pad[4];
     __in  s32 timeout;
    __out u32 value;
   };
   };


=== NVMAP_IOC_IS_OWNED_BY_ARUID ===
=== NVHOST_IOCTL_CTRL_SYNCPT_WAIT_EVENT_EX ===
Checks if a nvmap object is bound to an [[Applet_Manager_services#AppletResourceUserId|AppletResourceUserId]].
Waits on a syncpt using a specific event. If waiting fails, returns error code 0x05 (Timeout) and sets '''value''' to ('''event_slot''' | ('''syncpt_id''' << 4)).


   struct {
   struct {
     __in u64 aruid;
     __in   u32 id;
     __in u32 handle;
    __in    u32 thresh;
     u8        pad[4];
    __in    s32 timeout;
    __inout u32 value;          // in=event_slot; out=syncpt_value
  };
 
=== NVHOST_IOCTL_CTRL_SYNCPT_ALLOC_EVENT ===
Allocates a new syncpt event.
 
  struct {
    __in u32 event_slot;        // 0x00 to 0x3F
  };
 
=== NVHOST_IOCTL_CTRL_SYNCPT_FREE_EVENT ===
Frees an existing syncpt event.
 
  struct {
     __in u32 event_slot;        // 0x00 to 0x3F
  };
 
=== NVHOST_IOCTL_CTRL_SYNCPT_FREE_EVENT_BATCH ===
Frees multiple syncpt events.
 
  struct {
     __in u64 event_slot_mask;   // 64-bit bitfield where each bit represents one event
   };
   };


=== NVMAP_IOC_REMOVE_EXPORT_FOR_ARUID ===
=== NVHOST_IOCTL_CTRL_SYNCPT_GET_SHIFT ===
Unbinds a nvmap object from an [[Applet_Manager_services#AppletResourceUserId|AppletResourceUserId]].
Unofficial name.
 
Returns the syncpt shift value.


   struct {
   struct {
     __in  u64 aruid;
     __out u32 syncpt_shift;     // 0x00 (FIFO disabled) or 0x60 (FIFO enabled)
    __in  u32 handle;
    u8        pad[4];
   };
   };


== /dev/nvdisp-ctrl ==
== /dev/nvmap ==
{| class="wikitable" border="1"
{| class="wikitable" border="1"
! Value || Direction || Size || Description
! Value || Direction || Size || Description
|-
|-
| 0x80040212 || Out || 4 || NVDISP_CTRL_NUM_OUTPUTS
| 0xC0080101 || Inout || 8 || [[#NVMAP_IOC_CREATE|NVMAP_IOC_CREATE]]
|-
| 0x00000102 || - || 0 || [[#NVMAP_IOC_CLAIM|NVMAP_IOC_CLAIM]]
|-
| 0xC0080103 || Inout || 8 || [[#NVMAP_IOC_FROM_ID|NVMAP_IOC_FROM_ID]]
|-
|-
| 0xC0140213 || Inout || 20 || NVDISP_CTRL_GET_DISPLAY_PROPERTIES
| 0xC0200104 || Inout || 32 || [[#NVMAP_IOC_ALLOC|NVMAP_IOC_ALLOC]]
|-
|-
| 0xC1100214 || Inout || 272 || NVDISP_CTRL_QUERY_EDID
| 0xC0180105 || Inout || 24 || [[#NVMAP_IOC_FREE|NVMAP_IOC_FREE]]
|-
|-
| 0xC0080216</br>([1.0.0-3.0.0] 0xC0040216) || Inout || 8</br>([1.0.0-3.0.0] 4) || NVDISP_CTRL_GET_EXT_HPD_IN_OUT_EVENTS</br>([1.0.0-3.0.0] NVDISP_CTRL_GET_EXT_HPD_IN_EVENT)
| 0xC0280106 || Inout || 40 || [[#NVMAP_IOC_MMAP|NVMAP_IOC_MMAP]]
|-
|-
| ([1.0.0-3.0.0] 0xC0040217) || ([1.0.0-3.0.0] Inout) || ([1.0.0-3.0.0] 4) || ([1.0.0-3.0.0] NVDISP_CTRL_GET_EXT_HPD_OUT_EVENT)
| 0xC0280107 || Inout || 40 || [[#NVMAP_IOC_WRITE|NVMAP_IOC_WRITE]]
|-
|-
| 0xC0100218 || Inout || 16 || NVDISP_CTRL_GET_VBLANK_HEAD0_EVENT
| 0xC0280108 || Inout || 40 || [[#NVMAP_IOC_READ|NVMAP_IOC_READ]]
|-
|-
| 0xC0100219 || Inout || 16 || NVDISP_CTRL_GET_VBLANK_HEAD1_EVENT
| 0xC00C0109 || Inout || 12 || [[#NVMAP_IOC_PARAM|NVMAP_IOC_PARAM]]
|-
|-
| 0xC0040220 || Inout || 4 || NVDISP_CTRL_SUSPEND
| 0xC010010A || Inout || 16 || [[#NVMAP_IOC_PIN_MULT|NVMAP_IOC_PIN_MULT]]
|-
|-
| 0x80010224 || Out || 1 || [11.0.0+]
| 0xC010010B || Inout || 16 || [[#NVMAP_IOC_UNPIN_MULT|NVMAP_IOC_UNPIN_MULT]]
|}
 
== /dev/nvdisp-disp0, /dev/nvdisp-disp1 ==
{| class="wikitable" border="1"
! Value || Direction || Size || Description
|-
|-
| 0x40040201 || In || 4 || NVDISP_GET_WINDOW
| 0xC008010C || Inout || 8 || [[#NVMAP_IOC_CACHE|NVMAP_IOC_CACHE]]
|-
|-
| 0x40040202 || In || 4 || NVDISP_PUT_WINDOW
| 0xC004010D || Inout || 4 || [[#NVMAP_IOC_GET_IVC_ID|NVMAP_IOC_GET_IVC_ID]]
|-
|-
| 0xC4C80203 || In || 1224 || NVDISP_FLIP
| 0xC008010E || Inout || 8 || [[#NVMAP_IOC_GET_ID|NVMAP_IOC_GET_ID]]
|-
|-
| 0x80380204 || Out || 56 || NVDISP_GET_MODE
| 0xC004010F || Inout || 4 || [[#NVMAP_IOC_FROM_IVC_ID|NVMAP_IOC_FROM_IVC_ID]]
|-
|-
| 0x40380205 || Out || 56 || NVDISP_SET_MODE
| 0x40040110 || In || 4 || [[#NVMAP_IOC_SET_ALLOCATION_TAG_LABEL|NVMAP_IOC_SET_ALLOCATION_TAG_LABEL]]
|-
|-
| 0x430C0206 || In || 780 || NVDISP_SET_LUT
| 0x00000111 || - || 0 || [[#NVMAP_IOC_RESERVE|NVMAP_IOC_RESERVE]]
|-
|-
| 0x40010207 || In || 1 || NVDISP_CONFIG_CRC
| 0x40100112 || In || 16 || [[#NVMAP_IOC_EXPORT_FOR_ARUID|NVMAP_IOC_EXPORT_FOR_ARUID]]
|-
|-
| 0x80040208 || Out || 4 || NVDISP_GET_CRC
| 0x40100113 || In || 16 || [[#NVMAP_IOC_IS_OWNED_BY_ARUID|NVMAP_IOC_IS_OWNED_BY_ARUID]]
|-
|-
| 0x80040209 || Out || 4 || NVDISP_GET_HEAD_STATUS
| 0x40100114 || In || 16 || [[#NVMAP_IOC_REMOVE_EXPORT_FOR_ARUID|NVMAP_IOC_REMOVE_EXPORT_FOR_ARUID]]
|-
|}
| 0xC038020A || Inout || 56 || NVDISP_VALIDATE_MODE
 
|-
=== NVMAP_IOC_CREATE ===
| 0x4018020B || In || 24 || NVDISP_SET_CSC
Creates an nvmap object. Identical to Linux driver.
|-
 
| 0xC004020C || Inout || 4 || NVDISP_GET_VBLANK_SYNCPT
  struct {
|-
    __in  u32 size;
| 0x8040020D || Out || 64 || NVDISP_GET_UNDERFLOWS
    __out u32 handle;
|-
  };
| 0xC99A020E || Inout || 2458 || NVDISP_SET_CMU
 
|-
=== NVMAP_IOC_CLAIM ===
| 0xC004020F || Inout || 4 || NVDISP_DPMS
Returns [[#Errors|NotSupported]].
|-
 
| 0x80600210 || Out || 96 || NVDISP_GET_AVI_INFOFRAME
=== NVMAP_IOC_FROM_ID ===
|-
Get handle to an existing nvmap object. Identical to Linux driver.
| 0x40600211 || In || 96 || NVDISP_SET_AVI_INFOFRAME
|-
| 0xEBFC0215 || Inout || 11260 || NVDISP_GET_MODE_DB
|-
| 0xC003021A || Inout || 3 || NVDISP_PANEL_GET_VENDOR_ID
|-
| 0x803C021B || Out || 60 || NVDISP_GET_MODE2
|-
| 0x403C021C || In || 60 || NVDISP_SET_MODE2
|-
| 0xC03C021D || Inout || 60 || NVDISP_VALIDATE_MODE2
|-
| 0xEF20021E || Inout || 12064 || NVDISP_GET_MODE_DB2
|-
| 0xC004021F || Inout || 4 || NVDISP_GET_WINMASK
|-
| 0x80080221 || Out || 8 || [10.0.0+] NVDISP_GET_BACKLIGHT_RANGE
|-
| 0x40040222 || In || 4 || [10.0.0+] NVDISP_SET_BACKLIGHT
|-
| 0x40040223 || In || 4 || [11.0.0+] NVDISP_SEND_PANEL_MSG
|-
| 0x401C0225 || In || 28 || [11.0.0+] NVDISP_SEND_PANEL_MSG_EX
|-
| 0xC01C0226 || Inout || 28 || [11.0.0+] NVDISP_GET_PANEL_DATA
|}


== /dev/nvcec-ctrl ==
  struct {
{| class="wikitable" border="1"
    __in  u32 id;
! Value || Direction || Size || Description
    __out u32 handle;
|-
  };
| 0x40010301 || In || 1 || NVCEC_CTRL_ENABLE
 
|-
=== NVMAP_IOC_ALLOC ===
| 0x804C0302 || Out || 76 || NVCEC_CTRL_GET_PADDR
Allocate memory for the nvmap object. Nintendo extended this one with 16 bytes, and changed it from in to inout.
|-
| 0x40040303 || In || 4 || NVCEC_CTRL_SET_LADDR
|-
| 0xC04C0304 || Inout || 76 || NVCEC_CTRL_WRITE
|-
| 0xC04C0305 || Inout || 76 || NVCEC_CTRL_READ
|-
| 0x804C0306 || Out || 76 || NVCEC_CTRL_GET_CONNECTION_STATUS
|-
| 0x804C0307 || Out || 76 || NVCEC_CTRL_GET_WRITE_STATUS
|}


== /dev/nvhdcp_up-ctrl ==
  struct {
{| class="wikitable" border="1"
    __in u32 handle;
! Value || Direction || Size || Description
    __in u32 heapmask;
|-
    __in u32 flags;    // (0=read-only, 1=read-write)
| 0xC4880401 || Inout || 1160 || NVHDCP_READ_STATUS
    __inout u32 align;
|-
    __in u8  kind;
| 0xC4880402 || Inout || 1160 || NVHDCP_READ_M
    __in u8  pad[7];
|-
    __in u64 addr;
| 0x40010403 || In || 1 || NVHDCP_ENABLE
  };
|-
 
| 0xC0080404 || Inout || 8 || NVHDCP_CTRL_STATE_TRANSIT_EVENT_DATA
=== NVMAP_IOC_FREE ===
|-
This one is completely custom. Partly because the Linux driver passed the handle as the ioctl "arg-ptr", and HIPC can't handle that voodoo.
| 0xC0010405 || Inout || 1 || NVHDCP_CTRL_STATE_CB
 
|}
  struct {
    __in  u32 handle;
    __in  u32 pad;
    __out u64 address;  // 0 if the handle wasn't yet freed
    __out u32 size;
    __out u32 flags;    // 1=WAS_UNCACHED (if flags bit 1 was set when NVMAP_IOC_ALLOC was called)
  };


== /dev/nvdcutil-disp0, /dev/nvdcutil-disp1 ==
=== NVMAP_IOC_MMAP ===
{| class="wikitable" border="1"
Returns [[#Errors|NotSupported]].
! Value || Direction || Size || Description
 
|-
=== NVMAP_IOC_WRITE ===
| 0x40010501 || In || 1 || NVDCUTIL_ENABLE_CRC
Returns [[#Errors|NotSupported]].
|-
| 0x40010502 || In || 1 || NVDCUTIL_VIRTUAL_EDID_ENABLE
|-
| 0x42040503 || In || 1056 || NVDCUTIL_VIRTUAL_EDID_SET_DATA
|-
| 0x803C0504 || Out || 60 || NVDCUTIL_GET_MODE
|-
| 0x40010505 || In || 1 || NVDCUTIL_BEGIN_TELEMETRY_TEST
|-
| 0x400C0506 || In || 12 || NVDCUTIL_DSI_PACKET_TEST_SHORT_WRITE
|-
| 0x40F80507 || In || 248 || NVDCUTIL_DSI_PACKET_TEST_LONG_WRITE
|-
| 0xC0F40508 || Inout || 244 || NVDCUTIL_DSI_PACKET_TEST_READ
|-
| 0x40010509 || In || 1 || [10.0.0+] NVDCUTIL_DP_ELEC_TEST_MODE_ENABLE
|-
| 0xC020050A || Inout || 32 || [10.0.0+] NVDCUTIL_DP_ELEC_TEST_SETTINGS
|-
| 0x8070050B || Out || 112 || [11.0.0+] NVDCUTIL_DP_CONF_READ
|}


== /dev/nvsched-ctrl ==
=== NVMAP_IOC_READ ===
This is a customized scheduler device.
Returns [[#Errors|NotSupported]].


The way this device is exposed and configured is exclusive to the Switch, since other sources don't have an actual interface for the scheduler.
=== NVMAP_IOC_PARAM ===
Returns info about a nvmap object. Identical to Linux driver, but extended with further params.


{| class="wikitable" border="1"
  struct {
! Value || Direction || Size || Description
    __in  u32 handle;
|-
    __in  u32 param;  // 1=SIZE, 2=ALIGNMENT, 3=BASE (returns error), 4=HEAP (always 0x40000000), 5=KIND, 6=COMPR (unused)
| 0x00000601 || - || 0 || [[#NVSCHED_CTRL_ENABLE]]
    __out u32 result;
|-
  };
| 0x00000602 || - || 0 || [[#NVSCHED_CTRL_DISABLE]]
|-
| 0x40180603 || In || 24 || [[#NVSCHED_CTRL_ADD_APPLICATION]]
|-
| 0x40180604 || In || 24 || [[#NVSCHED_CTRL_UPDATE_APPLICATION]]
|-
| 0x40080605 || In || 8 || [[#NVSCHED_CTRL_REMOVE_APPLICATION]]
|-
| 0x80080606 || Out || 8 || [[#NVSCHED_CTRL_GET_ID]]
|-
| 0x80080607 || Out || 8 || [[#NVSCHED_CTRL_ADD_RUNLIST]]
|-
| 0x40180608 || In || 24 || [[#NVSCHED_CTRL_UPDATE_RUNLIST]]
|-
| 0x40100609 || In || 16 || [[#NVSCHED_CTRL_LINK_RUNLIST]]
|-
| 0x4010060A || In || 16 || [[#NVSCHED_CTRL_UNLINK_RUNLIST]]
|-
| 0x4008060B || In || 8 || [[#NVSCHED_CTRL_REMOVE_RUNLIST]]
|-
| 0x8001060C || Out || 1 || [[#NVSCHED_CTRL_HAS_OVERRUN_EVENT]]
|-
| 0x8020060D</br>([1.0.0-3.0.0] 0x8010060D) || Out || 32</br>([1.0.0-3.0.0] 16) || [[#NVSCHED_CTRL_GET_NEXT_OVERRUN_EVENT]]
|-
| 0x400C060E || In || 12 || [[#NVSCHED_CTRL_PUT_CONDUCTOR_FLIP_FENCE]]
|-
| 0x4008060F || In || 8 || [[#NVSCHED_CTRL_DETACH_APPLICATION]]
|-
| 0x40100610 || In || 16 || NVSCHED_CTRL_SET_APPLICATION_MAX_DEBT
|-
| 0x40100611 || In || 16 || NVSCHED_CTRL_SET_RUNLIST_MAX_DEBT
|-
| 0x40010612 || In || 1 || NVSCHED_CTRL_OVERRUN_EVENTS_ENABLE
|}


=== NVSCHED_CTRL_ENABLE ===
=== NVMAP_IOC_PIN_MULT ===
Enables the scheduler.
Returns [[#Errors|NotSupported]].


=== NVSCHED_CTRL_DISABLE ===
=== NVMAP_IOC_UNPIN_MULT ===
Disables the scheduler.
Returns [[#Errors|NotSupported]].


=== NVSCHED_CTRL_ADD_APPLICATION ===
=== NVMAP_IOC_CACHE ===
Adds a new application to the scheduler.
Returns [[#Errors|NotSupported]].


  struct {
=== NVMAP_IOC_GET_IVC_ID ===
    __in u64 application_id;
Returns [[#Errors|NotSupported]].
    __in u64 priority;
    __in u64 timeslice;
  };


=== NVSCHED_CTRL_UPDATE_APPLICATION ===
=== NVMAP_IOC_GET_ID ===
Updates the application parameters in the scheduler.
Returns an id for a nvmap object. Identical to Linux driver.


   struct {
   struct {
     __in u64 application_id;
     __out u32 id; //~0 indicates error
    __in u64 priority;
     __in u32 handle;
     __in u64 timeslice;
   };
   };


=== NVSCHED_CTRL_REMOVE_APPLICATION ===
=== NVMAP_IOC_FROM_IVC_ID ===
Removes the application from the scheduler.
Returns [[#Errors|NotSupported]].


  struct {
=== NVMAP_IOC_SET_ALLOCATION_TAG_LABEL ===
    __in u64 application_id;
Returns [[#Errors|NotSupported]].
  };
 
=== NVMAP_IOC_RESERVE ===
Returns [[#Errors|NotSupported]].


=== NVSCHED_CTRL_GET_ID ===
=== NVMAP_IOC_EXPORT_FOR_ARUID ===
Returns the ID of the last scheduled object.
Binds a nvmap object to an [[Applet_Manager_services#AppletResourceUserId|AppletResourceUserId]].


   struct {
   struct {
     __out u64 id;
     __in  u64 aruid;
    __in  u32 handle;
    __in  u8 pad[4];
   };
   };


=== NVSCHED_CTRL_ADD_RUNLIST ===
=== NVMAP_IOC_IS_OWNED_BY_ARUID ===
Creates a new runlist and returns it's ID.
Checks if a nvmap object is bound to an [[Applet_Manager_services#AppletResourceUserId|AppletResourceUserId]].


   struct {
   struct {
     __out u64 runlist_id;
     __in  u64 aruid;
    __in  u32 handle;
    __in  u8 pad[4];
   };
   };


=== NVSCHED_CTRL_UPDATE_RUNLIST ===
=== NVMAP_IOC_REMOVE_EXPORT_FOR_ARUID ===
Updates the runlist parameters in the scheduler.
Unbinds a nvmap object from an [[Applet_Manager_services#AppletResourceUserId|AppletResourceUserId]].


   struct {
   struct {
     __in u64 runlist_id;
     __in u64 aruid;
     __in u64 priority;
     __in u32 handle;
     __in u64 timeslice;
     __in u8 pad[4];
   };
   };


=== NVSCHED_CTRL_LINK_RUNLIST ===
== /dev/nvdisp-ctrl ==
Links a runlist to a given application in the scheduler.
{| class="wikitable" border="1"
! Value || Direction || Size || Description
|-
| 0x80040212 || Out || 4 || [[#NVDISP_CTRL_NUM_OUTPUTS|NVDISP_CTRL_NUM_OUTPUTS]]
|-
| 0xC0140213 || Inout || 20 || NVDISP_CTRL_GET_DISPLAY_PROPERTIES
|-
| 0xC2100214</br>([1.0.0-11.0.1] 0xC1100214) || Inout || 528</br>([1.0.0-11.0.1] 272) || NVDISP_CTRL_QUERY_EDID
|-
| 0xC0080216</br>([1.0.0-3.0.0] 0xC0040216) || Inout || 8</br>([1.0.0-3.0.0] 4) || NVDISP_CTRL_GET_EXT_HPD_IN_OUT_EVENTS</br>([1.0.0-3.0.0] NVDISP_CTRL_GET_EXT_HPD_IN_EVENT)
|-
| 0xC0040217 || Inout || 4 || [1.0.0-3.0.0] NVDISP_CTRL_GET_EXT_HPD_OUT_EVENT
|-
| 0xC0100218 || Inout || 16 || NVDISP_CTRL_GET_VBLANK_HEAD0_EVENT
|-
| 0xC0100219 || Inout || 16 || NVDISP_CTRL_GET_VBLANK_HEAD1_EVENT
|-
| 0xC0040220 || Inout || 4 || NVDISP_CTRL_SUSPEND
|-
| 0x80010224 || Out || 1 || [11.0.0+] [[#NVDISP_CTRL_IS_DISPLAY_OLED|NVDISP_CTRL_IS_DISPLAY_OLED]]
|}
 
=== NVDISP_CTRL_NUM_OUTPUTS ===
Returns the number of display outputs available.


   struct {
   struct {
     __in u64 runlist_id;
     __out u32 num_outputs;
    __in u64 application_id;
   };
   };


=== NVSCHED_CTRL_UNLINK_RUNLIST ===
=== NVDISP_CTRL_IS_DISPLAY_OLED ===
Unlinks a runlist from a given application in the scheduler.
Unofficial name.
 
This sets a boolean value based on the values of the system configuration.
 
Returns true if "nvservices!internal_display_vddpn_control" is set to false and "nvservices!external_display_full_dp_lanes" is set to true.


   struct {
   struct {
     __in u64 runlist_id;
     __out u8 is_display_oled;
    __in u64 application_id;
   };
   };


=== NVSCHED_CTRL_REMOVE_RUNLIST ===
== /dev/nvdisp-disp0, /dev/nvdisp-disp1 ==
Removes the runlist from the scheduler.
{| class="wikitable" border="1"
 
! Value || Direction || Size || Description
  struct {
|-
    __in u64 runlist_id;
| 0x40040201 || In || 4 || NVDISP_GET_WINDOW
  };
|-
 
| 0x40040202 || In || 4 || NVDISP_PUT_WINDOW
=== NVSCHED_CTRL_HAS_OVERRUN_EVENT ===
|-
Returns a boolean to tell if the scheduler has an overrun event or not.
| 0xC4C80203 || In || 1224 || NVDISP_FLIP
 
|-
  struct {
| 0x80380204 || Out || 56 || [[#NVDISP_GET_MODE|NVDISP_GET_MODE]]
    __out u8 has_overrun;
|-
  };
| 0x40380205 || In || 56 || [[#NVDISP_SET_MODE|NVDISP_SET_MODE]]
 
|-
=== NVSCHED_CTRL_GET_NEXT_OVERRUN_EVENT ===
| 0x430C0206 || In || 780 || NVDISP_SET_LUT
Returns the overrun event's data from the scheduler.
|-
 
| 0x40010207 || In || 1 || NVDISP_CONFIG_CRC
   struct {
|-
     __out u64 runlist_id;
| 0x80040208 || Out || 4 || NVDISP_GET_CRC
     __out u64 debt;
|-
     __out u64 unk0;           // 3.0.0+ only
| 0x80040209 || Out || 4 || NVDISP_GET_HEAD_STATUS
     __out u64 unk1;           // 3.0.0+ only
|-
  };
| 0xC038020A || Inout || 56 || [[#NVDISP_VALIDATE_MODE|NVDISP_VALIDATE_MODE]]
 
|-
=== NVSCHED_CTRL_PUT_CONDUCTOR_FLIP_FENCE ===
| 0x4018020B || In || 24 || NVDISP_SET_CSC
Installs a fence swap event?
|-
 
| 0xC004020C || Inout || 4 || NVDISP_GET_VBLANK_SYNCPT
  struct {
|-
     __in u32 fence_id;
| 0x8040020D || Out || 64 || NVDISP_GET_UNDERFLOWS
     __in u32 fence_thresh;
|-
     __in u32 swap_interval;
| 0xC99A020E || Inout || 2458 || NVDISP_SET_CMU
|-
| 0xC004020F || Inout || 4 || NVDISP_DPMS
|-
| 0x80600210 || Out || 96 || [[#NVDISP_GET_AVI_INFOFRAME|NVDISP_GET_AVI_INFOFRAME]]
|-
| 0x40600211 || In || 96 || [[#NVDISP_SET_AVI_INFOFRAME|NVDISP_SET_AVI_INFOFRAME]]
|-
| 0xEBFC0215 || Inout || 11260 || [[#NVDISP_GET_MODE_DB|NVDISP_GET_MODE_DB]]
|-
| 0xC003021A || Inout || 3 || [[#NVDISP_PANEL_GET_VENDOR_ID|NVDISP_PANEL_GET_VENDOR_ID]]
|-
| 0x803C021B || Out || 60 || [[#NVDISP_GET_MODE2|NVDISP_GET_MODE2]]
|-
| 0x403C021C || In || 60 || [[#NVDISP_SET_MODE2|NVDISP_SET_MODE2]]
|-
| 0xC03C021D || Inout || 60 || [[#NVDISP_VALIDATE_MODE2|NVDISP_VALIDATE_MODE2]]
|-
| 0xEF20021E || Inout || 12064 || [[#NVDISP_GET_MODE_DB2|NVDISP_GET_MODE_DB2]]
|-
| 0xC004021F || Inout || 4 || NVDISP_GET_WINMASK
|-
| 0x80080221 || Out || 8 || [10.0.0+] [[#NVDISP_GET_BACKLIGHT_RANGE|NVDISP_GET_BACKLIGHT_RANGE]]
|-
| 0x40040222 || In || 4 || [10.0.0+] [[#NVDISP_SET_BACKLIGHT_RANGE_MAX|NVDISP_SET_BACKLIGHT_RANGE_MAX]]
|-
| 0x40040223 || In || 4 || [11.0.0+] [[#NVDISP_SET_BACKLIGHT_RANGE_MIN|NVDISP_SET_BACKLIGHT_RANGE_MIN]]
|-
| 0x401C0225 || In || 28 || [11.0.0+] [[#NVDISP_SEND_PANEL_MSG|NVDISP_SEND_PANEL_MSG]]
|-
| 0xC01C0226 || Inout || 28 || [11.0.0+] [[#NVDISP_GET_PANEL_DATA|NVDISP_GET_PANEL_DATA]]
|}
 
=== NVDISP_GET_MODE ===
Almost identical to Linux driver.
 
   struct {
     __out u32 hActive;
     __out u32 vActive;
     __out u32 hSyncWidth;
    __out u32 vSyncWidth;
     __out u32 hFrontPorch;
    __out u32 vFrontPorch;
    __out u32 hBackPorch;
    __out u32 vBackPorch;
    __out u32 hRefToSync;
    __out u32 vRefToSync;
    __out u32 pclkKHz;
     __out u32 bitsPerPixel;     // Always 0
     __out u32 vmode;             // Always 0
     __out u32 sync;
   };
   };


=== NVSCHED_CTRL_DETACH_APPLICATION ===
=== NVDISP_SET_MODE ===
Places the given application in detached state.
Almost identical to Linux driver.


   struct {
   struct {
     __in u64 application_id;
     __in u32 hActive;
    __in u32 vActive;
    __in u32 hSyncWidth;
    __in u32 vSyncWidth;
    __in u32 hFrontPorch;
    __in u32 vFrontPorch;
    __in u32 hBackPorch;
    __in u32 vBackPorch;
    __in u32 hRefToSync;
    __in u32 vRefToSync;
    __in u32 pclkKHz;
    __in u32 bitsPerPixel;
    __in u32 vmode;
    __in u32 sync;
   };
   };


== /dev/nverpt-ctrl ==
=== NVDISP_VALIDATE_MODE ===
Added in firmware version 3.0.0.
Almost identical to Linux driver.


{| class="wikitable" border="1"
  struct {
! Value || Direction || Size || Description
    __inout u32 hActive;
|-
    __inout u32 vActive;
| 0xC1280701 || Inout || 296 || [[#NVERPT_TELEMETRY_SUBMIT_DATA]]
    __inout u32 hSyncWidth;
|-
    __inout u32 vSyncWidth;
| 0xCF580702 || Inout || 3928 || [[#NVERPT_TELEMETRY_SUBMIT_DISPLAY_DATA]]
    __inout u32 hFrontPorch;
|}
    __inout u32 vFrontPorch;
    __inout u32 hBackPorch;
    __inout u32 vBackPorch;
    __inout u32 hRefToSync;
    __inout u32 vRefToSync;
    __inout u32 pclkKHz;
    __inout u32 bitsPerPixel;
    __inout u32 vmode;
    __inout u32 sync;
  };


=== NVERPT_TELEMETRY_SUBMIT_DATA ===
=== NVDISP_GET_AVI_INFOFRAME ===
Sends test data for creating a new [[Error_Report_services|Error Report]].
Unpacked standard AVI infoframe struct (HDMI v1.4b/2.0)


   struct {
   struct {
     __in u64 TestU64;
     __out u32 csum;
     __in u32 TestU32;
    __out u32 scan;
     __in u8  padding0[4];
    __out u32 bar_valid;
     __in s64 TestI64;
    __out u32 act_fmt_valid;
     __in s32 TestI32;
     __out u32 rgb_ycc;
     __in u8  TestString[32];
     __out u32 act_format;
     __in u8  TestU8Array[8];
     __out u32 aspect_ratio;
     __in u32 TestU8Array_size;
     __out u32 colorimetry;
     __in u32 TestU32Array[8];
     __out u32 scaling;
     __in u32 TestU32Array_size;
     __out u32 rgb_quant;
     __in u64 TestU64Array[8];
     __out u32 ext_colorimetry;
     __in u32 TestU64Array_size;
     __out u32 it_content;
     __in s32 TestI32Array[8];
     __out u32 video_format;
     __in u32 TestI32Array_size;
     __out u32 pix_rep;
     __in s64 TestI64Array[8];
     __out u32 it_content_type;
     __in u32 TestI64Array_size;
     __out u32 ycc_quant;
     __in u16 TestU16;
     __out u32 top_bar_end_line_lsb;
     __in u8  TestU8;
     __out u32 top_bar_end_line_msb;
     __in s16 TestI16;
     __out u32 bot_bar_start_line_lsb;
     __in s8  TestI8;
     __out u32 bot_bar_start_line_msb;
     __in u8  padding1[5];
     __out u32 left_bar_end_pixel_lsb;
     __out u32 left_bar_end_pixel_msb;
     __out u32 right_bar_start_pixel_lsb;
     __out u32 right_bar_start_pixel_msb;
   };
   };


=== NVERPT_TELEMETRY_SUBMIT_DISPLAY_DATA ===
=== NVDISP_SET_AVI_INFOFRAME ===
Sends display data for creating a new [[Error_Report_services|Error Report]].
Unpacked standard AVI infoframe struct (HDMI v1.4b/2.0)


   struct {
   struct {
     __in u32 CodecType;
     __in u32 csum;
     __in u32 DecodeBuffers;
     __in u32 scan;
     __in u32 FrameWidth;
     __in u32 bar_valid;
     __in u32 FrameHeight;
     __in u32 act_fmt_valid;
     __in u8  ColorPrimaries;
     __in u32 rgb_ycc;
     __in u8  TransferCharacteristics;
     __in u32 act_format;
     __in u8  MatrixCoefficients;
     __in u32 aspect_ratio;
     __in u8  padding;
     __in u32 colorimetry;
     __in u32 DisplayWidth;
     __in u32 scaling;
     __in u32 DisplayHeight;
     __in u32 rgb_quant;
     __in u32 DARWidth;
     __in u32 ext_colorimetry;
     __in u32 DARHeight;
     __in u32 it_content;
     __in u32 ColorFormat;
     __in u32 video_format;
     __in u32 ColorSpace[8];
     __in u32 pix_rep;
     __in u32 ColorSpace_size;
     __in u32 it_content_type;
     __in u32 SurfaceLayout[8];
     __in u32 ycc_quant;
     __in u32 SurfaceLayout_size;
     __in u32 top_bar_end_line_lsb;
     __in u8  ErrorString[64];       // must be "Error detected = 0x1000000"
     __in u32 top_bar_end_line_msb;
     __in u32 VideoDecState;
     __in u32 bot_bar_start_line_lsb;
     __in u8  VideoLog[3712];
     __in u32 bot_bar_start_line_msb;
     __in u32 VideoLog_size;
    __in u32 left_bar_end_pixel_lsb;
    __in u32 left_bar_end_pixel_msb;
    __in u32 right_bar_start_pixel_lsb;
     __in u32 right_bar_start_pixel_msb;
   };
   };


== /dev/nvhost-as-gpu ==
=== NVDISP_GET_MODE_DB ===
Each fd opened to this device creates an address space. An address space is then later bound with a channel.
Almost identical to Linux driver.


Once a nvgpu channel has been bound to an address space it cannot be unbound. There is no support for allowing an nvgpu channel to change from one address space to another (or from one to none).
  struct mode {
                                                                                                                             
    u32 hActive;
{| class="wikitable" border="1"
    u32 vActive;
! Value || Direction || Size || Description
    u32 hSyncWidth;
|-
    u32 vSyncWidth;
| 0x40044101 || In || 4 || [[#NVGPU_AS_IOCTL_BIND_CHANNEL]]
    u32 hFrontPorch;
|-
    u32 vFrontPorch;
| 0xC0184102 || Inout || 24 || [[#NVGPU_AS_IOCTL_ALLOC_SPACE]]
    u32 hBackPorch;
|-
    u32 vBackPorch;
| 0xC0104103 || Inout || 16 || [[#NVGPU_AS_IOCTL_FREE_SPACE]]
    u32 hRefToSync;
|-
    u32 vRefToSync;
| 0xC0184104 || Inout || 24 || [[#NVGPU_AS_IOCTL_MAP_BUFFER]]
    u32 pclkKHz;
|-
    u32 bitsPerPixel;
| 0xC0084105 || Inout || 8 || [[#NVGPU_AS_IOCTL_UNMAP_BUFFER]]
    u32 vmode;
|-
    u32 sync;
| 0xC0284106 || Inout || 40 || [[#NVGPU_AS_IOCTL_MAP_BUFFER_EX]]
  };
|-
| 0x40104107 || In || 16 || [[#NVGPU_AS_IOCTL_ALLOC_AS]]
  struct {
|-
    __out struct mode modes[201];
| 0xC0404108 || Inout || 64 || [[#NVGPU_AS_IOCTL_GET_VA_REGIONS]]
    __out u32 num_modes;
|-
  };
| 0x40284109 || In || 40 || [[#NVGPU_AS_IOCTL_ALLOC_AS_EX]]
|-
| 0xC038410A || Inout || 56 || [[#NVGPU_AS_IOCTL_MODIFY]]
|-
| 0xC0??4114 || Inout || Variable || [[#NVGPU_AS_IOCTL_REMAP]]
|}


=== NVGPU_AS_IOCTL_BIND_CHANNEL ===
=== NVDISP_PANEL_GET_VENDOR_ID ===
Identical to Linux driver.
Returns display panel's informations.


   struct {
   struct {
     __in u32 channel_fd;
     __out u8 vendor; //0x10 - JDI, 0x20 - InnoLux, 0x30 - AUO, 0x40 - Sharp, 0x50 - Samsung
    __out u8 model;
    __out u8 board; //0xF - 6.2", 0x10 - 5.5", 0x20 - 7.0". JDI panels have nonstandard values
   };
   };


=== NVGPU_AS_IOCTL_ALLOC_SPACE ===
=== NVDISP_GET_MODE2 ===
Reserves pages in the device address space.


   struct {
   struct {
     __in u32 pages;
     __out u32 unk0;              //Always 0
     __in u32 page_size;
    __out u32 hActive;
     __in u32 flags;
    __out u32 vActive;
     u32      padding;
    __out u32 hSyncWidth;
     union {
     __out u32 vSyncWidth;
      __out u64 offset;
     __out u32 hFrontPorch;
      __in  u64 align;
     __out u32 vFrontPorch;
     };
    __out u32 hBackPorch;
    __out u32 vBackPorch;
    __out u32 pclkKHz;
    __out u32 bitsPerPixel;     // Always 0
    __out u32 vmode;             // Always 0
     __out u32 sync;
    __out u32 unk1;
     __out u32 reserved;
   };
   };


=== NVGPU_AS_IOCTL_FREE_SPACE ===
=== NVDISP_SET_MODE2 ===
Frees pages from the device address space.


   struct {
   struct {
     __in u64 offset;
     __in u32 unk0;
     __in u32 pages;
    __in u32 hActive;
     __in u32 page_size;
    __in u32 vActive;
    __in u32 hSyncWidth;
    __in u32 vSyncWidth;
    __in u32 hFrontPorch;
    __in u32 vFrontPorch;
    __in u32 hBackPorch;
    __in u32 vBackPorch;
    __in u32 pclkKHz;
    __in u32 bitsPerPixel;
    __in u32 vmode;
    __in u32 sync;
     __in u32 unk1;
     __in u32 reserved;
   };
   };


=== NVGPU_AS_IOCTL_MAP_BUFFER ===
=== NVDISP_VALIDATE_MODE2 ===
Maps a memory region in the device address space. Identical to Linux driver pretty much.
 
  struct {
    __inout u32 unk0;
    __inout u32 hActive;
    __inout u32 vActive;
    __inout u32 hSyncWidth;
    __inout u32 vSyncWidth;
    __inout u32 hFrontPorch;
    __inout u32 vFrontPorch;
    __inout u32 hBackPorch;
    __inout u32 vBackPorch;
    __inout u32 pclkKHz;
    __inout u32 bitsPerPixel;
    __inout u32 vmode;
    __inout u32 sync;
    __inout u32 unk1;
    __inout u32 reserved;
  };


On success, the mapped memory region is granted the [[SVC#MemoryAttribute|DeviceShared]] attribute.
=== NVDISP_GET_MODE_DB2 ===


  struct mode2 {
    u32 unk0;
    u32 hActive;
    u32 vActive;
    u32 hSyncWidth;
    u32 vSyncWidth;
    u32 hFrontPorch;
    u32 vFrontPorch;
    u32 hBackPorch;
    u32 vBackPorch;
    u32 pclkKHz;
    u32 bitsPerPixel;
    u32 vmode;
    u32 sync;
    u32 unk1;
    u32 reserved;
  };
   struct {
   struct {
     __in    u32 flags;       // bit0: fixed_offset, bit2: cacheable
     __out struct mode2 modes[201];
     u32         reserved;
     __out u32 num_modes;
    __in    u32 dmabuf_fd;    // nvmap handle
    __inout u32 page_size;    // 0 means don't care
    union {
      __out u64 offset;
      __in  u64 align;
    };
   };
   };


=== NVGPU_AS_IOCTL_MAP_BUFFER_EX ===
=== NVDISP_GET_BACKLIGHT_RANGE ===
Maps a memory region in the device address space with extra params.
Unofficial name.


Unaligned size will cause a [[#Panic]].
Returns the minimum and maximum values for the intensity of the display's backlight.
 
On success, the mapped memory region is granted the [[SVC#MemoryAttribute|DeviceShared]] attribute.


   struct {
   struct {
     __in      u32 flags;         // bit0: fixed_offset, bit2: cacheable
     __out u32 min;
     __in      u32 kind;          // -1 is default
     __out u32 max;
    __in      u32 dmabuf_fd;      // nvmap handle
    __inout  u32 page_size;      // 0 means don't care
    __in      u64 buffer_offset;
    __in      u64 mapping_size;
    __inout  u64 offset;
   };
   };


=== NVGPU_AS_IOCTL_UNMAP_BUFFER ===
=== NVDISP_SET_BACKLIGHT_RANGE_MAX ===
Unmaps a memory region from the device address space.
Unofficial name.


struct {
Sets the maximum value for the intensity of the display's backlight.
    __in u64 offset;
  };
 
=== NVGPU_AS_IOCTL_ALLOC_AS ===
Nintendo's custom implementation for allocating an address space.


   struct {
   struct {
     __in u32 big_page_size;   // depends on GPU's available_big_page_sizes; 0=default
     __in u32 max;
    __in s32 as_fd;          // ignored; passes 0
    __in u64 reserved;        // ignored; passes 0
   };
   };


=== NVGPU_AS_IOCTL_GET_VA_REGIONS ===
=== NVDISP_SET_BACKLIGHT_RANGE_MIN ===
Nintendo's custom implementation to get rid of pointer in struct.
Unofficial name.
 
Sets the minimum value for the intensity of the display's backlight.


  struct va_region {
    u64 offset;
    u32 page_size;
    u32 reserved;
    u64 pages;
  };
 
   struct {
   struct {
     u64          buf_addr;    // (contained output user ptr on linux, ignored)
     __in u32 min;
    __inout u32   buf_size;    // forced to 2*sizeof(struct va_region)
    u32          reserved;
    __out struct  va_region regions[2];
   };
   };


=== NVGPU_AS_IOCTL_ALLOC_AS_EX ===
=== NVDISP_SEND_PANEL_MSG ===
Nintendo's custom implementation for allocating an address space with extra params.
Unofficial name.
 
Sends raw data to the display panel over DPAUX.


   struct {
   struct {
     __in u32 big_page_size;   // depends on GPU's available_big_page_sizes; 0=default
     __in u32 cmd;         // DPAUX AUXCTL command (1=unk, 2=I2CWR, 4=MOTWR, 7=AUXWR)
     __in s32 as_fd;           // ignored; passes 0
     __in u32 addr;         // DPAUX AUXADDR
     __in u32 flags;           // passes 0
     __in u32 size;         // message size
     __in u32 reserved;       // ignored; passes 0
     __in u32 msg[4];       // raw AUXDATA message
    __in u64 va_range_start;
    __in u64 va_range_end;
    __in u64 va_range_split;
   };
   };


=== NVGPU_AS_IOCTL_MODIFY ===
=== NVDISP_GET_PANEL_DATA ===
Modifies a memory region in the device address space.
Unofficial name.


    struct {
Receives raw data from the display panel over DPAUX.
     __in     u32 flags;          // bit0: fixed_offset, bit2: cacheable
 
     __in     u32 kind;           // -1 is default
  struct {
     __in     u32 dmabuf_fd;     // nvmap handle
     __in u32 cmd;          // DPAUX AUXCTL command (3=I2CRD, 5=MOTRD, 6=AUXRD)
     __inout  u32 page_size;      // 0 means don't care
     __in u32 addr;         // DPAUX AUXADDR
    __in      u64 buffer_offset;
     __in u32 size;         // message size
    __in      u64 mapping_size;
     __out u32 msg[4];      // raw AUXDATA message
    __inout  u64 offset;
    __in      u64 unk0;
    __in      u32 unk1;
    u32          reserved;
   };
   };


=== NVGPU_AS_IOCTL_REMAP ===
== /dev/nvcec-ctrl ==
Nintendo's custom implementation of address space remapping.
 
  struct remap_op {
    __in u16 flags;                  // 0 or 4
    __in u16 kind;         
    __in u32 mem_handle;
    __in u32 mem_offset_in_pages;
    __in u32 virt_offset_in_pages;    // (alloc_space_offset >> 0x10)
    __in u32 num_pages;              // alloc_space_pages
  };
struct {
    __in struct remap_op entries[];
};
 
== /dev/nvhost-dbg-gpu ==
Returns [[#Errors|NotSupported]] on Open unless nn::settings::detail::GetDebugModeFlag is set.
 
{| class="wikitable" border="1"
{| class="wikitable" border="1"
! Value || Direction || Size || Description
! Value || Direction || Size || Description
|-
|-
| 0x40084401 || In || 8 || NVGPU_DBG_GPU_IOCTL_BIND_CHANNEL
| 0x40010301 || In || 1 || NVCEC_CTRL_ENABLE
|-
|-
| 0xC0??4402 || Inout || Variable || NVGPU_DBG_GPU_IOCTL_REG_OPS
| 0x804C0302 || Out || 76 || NVCEC_CTRL_GET_PADDR
|-
|-
| 0x40084403 || In || 8 || NVGPU_DBG_GPU_IOCTL_EVENTS_CTRL
| 0x40040303 || In || 4 || NVCEC_CTRL_SET_LADDR
|-
|-
| 0x40044404 || In || 4 || NVGPU_DBG_GPU_IOCTL_POWERGATE
| 0xC04C0304 || Inout || 76 || NVCEC_CTRL_WRITE
|-
|-
| 0x40044405 || In || 4 || NVGPU_DBG_GPU_IOCTL_SMPC_CTXSW_MODE
| 0xC04C0305 || Inout || 76 || NVCEC_CTRL_READ
|-
|-
| 0x40044406 || In || 4 || NVGPU_DBG_GPU_IOCTL_SUSPEND_RESUME_ALL_SMS
| 0x804C0306 || Out || 76 || NVCEC_CTRL_GET_CONNECTION_STATUS
|-
|-
| 0xC0184407 || Inout || 24 || NVGPU_DBG_GPU_IOCTL_PERFBUF_MAP
| 0x804C0307 || Out || 76 || NVCEC_CTRL_GET_WRITE_STATUS
|}
 
== /dev/nvhdcp_up-ctrl ==
{| class="wikitable" border="1"
! Value || Direction || Size || Description
|-
|-
| 0x40084408 || In || 8 || NVGPU_DBG_GPU_IOCTL_PERFBUF_UNMAP
| 0xC4880401 || Inout || 1160 || NVHDCP_READ_STATUS
|-
|-
| 0x40084409 || In || 8 || NVGPU_DBG_GPU_IOCTL_PC_SAMPLING
| 0xC4880402 || Inout || 1160 || NVHDCP_READ_M
|-
|-
| 0x4008440A || In || 8 || NVGPU_DBG_GPU_IOCTL_TIMEOUT
| 0x40010403 || In || 1 || NVHDCP_ENABLE
|-
|-
| 0x8008440B || Out || 8 || NVGPU_DBG_GPU_IOCTL_GET_TIMEOUT
| 0xC0080404 || Inout || 8 || NVHDCP_CTRL_STATE_TRANSIT_EVENT_DATA
|-
|-
| 0x8004440C || Out || 4 || NVGPU_DBG_GPU_IOCTL_GET_GR_CONTEXT_SIZE
| 0xC0010405 || Inout || 1 || NVHDCP_CTRL_STATE_CB
|}
 
== /dev/nvdcutil-disp0, /dev/nvdcutil-disp1 ==
{| class="wikitable" border="1"
! Value || Direction || Size || Description
|-
|-
| 0x0000440D || None || 0 || [[#NVGPU_DBG_GPU_IOCTL_GET_GR_CONTEXT]]
| 0x40010501 || In || 1 || NVDCUTIL_ENABLE_CRC
|-
|-
| 0xC018440E || Inout || 24 || NVGPU_DBG_GPU_IOCTL_ACCESS_FB_MEMORY
| 0x40010502 || In || 1 || [[#NVDCUTIL_VIRTUAL_EDID_ENABLE|NVDCUTIL_VIRTUAL_EDID_ENABLE]]
|-
|-
| 0xC018440F || Inout || 24 || NVGPU_DBG_GPU_IOCTL_GET_GPU_VA_RANGE_NUM_PDES
| 0x42040503 || In || 516 || [[#NVDCUTIL_VIRTUAL_EDID_SET_DATA|NVDCUTIL_VIRTUAL_EDID_SET_DATA]]
|-
|-
| 0xC0104410 || Inout || 16 || [[#NVGPU_DBG_GPU_IOCTL_GET_GPU_VA_RANGE_PDES]]
| 0x803C0504 || Out || 60 || NVDCUTIL_GET_MODE
|-
|-
| 0xC0184411 || Inout || 24 || NVGPU_DBG_GPU_IOCTL_GET_GPU_VA_RANGE_NUM_PTES
| 0x40010505 || In || 1 || NVDCUTIL_BEGIN_TELEMETRY_TEST
|-
|-
| 0xC0104412 || Inout || 16 || [[#NVGPU_DBG_GPU_IOCTL_GET_GPU_VA_RANGE_PTES]]
| 0x400C0506 || In || 12 || NVDCUTIL_DSI_PACKET_TEST_SHORT_WRITE
|-
|-
| 0xC0684413 || Inout || 104 || NVGPU_DBG_GPU_IOCTL_GET_COMPTAG_INFO
| 0x40F80507 || In || 248 || NVDCUTIL_DSI_PACKET_TEST_LONG_WRITE
|-
|-
| 0xC0184414 || Inout || 24 || [[#NVGPU_DBG_GPU_IOCTL_READ_COMPTAGS]]
| 0xC0F40508 || Inout || 244 || NVDCUTIL_DSI_PACKET_TEST_READ
|-
|-
| 0xC0184415 || Inout || 24 || [[#NVGPU_DBG_GPU_IOCTL_WRITE_COMPTAGS]]
| 0x40010509 || In || 1 || [10.0.0+] NVDCUTIL_DP_ELECTRIC_TEST_EN
|-
|-
| 0xC0104416 || Inout || 16 || NVGPU_DBG_GPU_IOCTL_RESERVE_COMPTAGS
| 0xC020050A || Inout || 32 || [10.0.0+] NVDCUTIL_DP_ELECTRIC_TEST_SETTINGS
|-
|-
| 0xC0104417 || Inout || 16 || NVGPU_DBG_GPU_IOCTL_FREE_RESERVED_COMPTAGS
| 0x8070050B || Out || 112 || [11.0.0+] NVDCUTIL_DP_CONF_READ
|-
| 0xC0104418 || Inout || 16 || NVGPU_DBG_GPU_IOCTL_RESERVE_PA
|-
| 0xC0104419 || Inout || 16 || NVGPU_DBG_GPU_IOCTL_FREE_RESERVED_PA
|-
| 0xC018441A || Inout || 24 || NVGPU_DBG_GPU_IOCTL_LAZY_ALLOC_RESERVED_PA
|-
| 0xC020441B || Inout || 32 || [11.0.0+]
|-
| 0xC020441E || Inout || 32 || [11.0.0+]
|}
|}


=== NVGPU_DBG_GPU_IOCTL_GET_GR_CONTEXT ===
=== NVDCUTIL_VIRTUAL_EDID_ENABLE ===
Uses [[#Ioctl3|Ioctl3]].
Enables virtual EDID.


=== NVGPU_DBG_GPU_IOCTL_GET_GPU_VA_RANGE_PDES ===
  struct {
Uses [[#Ioctl3|Ioctl3]].
    __in u8 enable;
  };


=== NVGPU_DBG_GPU_IOCTL_GET_GPU_VA_RANGE_PTES ===
=== NVDCUTIL_VIRTUAL_EDID_SET_DATA ===
Uses [[#Ioctl3|Ioctl3]].
Sets virtual EDID data.


=== NVGPU_DBG_GPU_IOCTL_READ_COMPTAGS ===
  struct {
Uses [[#Ioctl3|Ioctl3]].
    __in u8 edid[512];
    __in u32 edid_size;
  };


=== NVGPU_DBG_GPU_IOCTL_WRITE_COMPTAGS ===
== /dev/nvsched-ctrl ==
Uses [[#Ioctl2|Ioctl2]].
This is a customized scheduler device.


== /dev/nvhost-prof-gpu ==
The way this device is exposed and configured is exclusive to the Switch, since other sources don't have an actual interface for the scheduler.
Returns [[#Errors|NotSupported]] on Open unless nn::settings::detail::GetDebugModeFlag is set.
 
This device is identical to [[#/dev/nvhost-dbg-gpu|/dev/nvhost-dbg-gpu]].


== /dev/nvhost-ctrl-gpu ==
This device is for global (context independent) operations on the gpu. 
                                                                                                                                             
{| class="wikitable" border="1"
{| class="wikitable" border="1"
! Value || Direction || Size || Description
! Value || Direction || Size || Description
|-
|-
| 0x80044701 || Out || 4 || [[#NVGPU_GPU_IOCTL_ZCULL_GET_CTX_SIZE]]
| 0x00000601 || - || 0 || [[#NVSCHED_CTRL_ENABLE|NVSCHED_CTRL_ENABLE]]
|-
|-
| 0x80284702 || Out || 40 || [[#NVGPU_GPU_IOCTL_ZCULL_GET_INFO]]
| 0x00000602 || - || 0 || [[#NVSCHED_CTRL_DISABLE|NVSCHED_CTRL_DISABLE]]
|-
|-
| 0x402C4703 || In || 44 || [[#NVGPU_GPU_IOCTL_ZBC_SET_TABLE]]
| 0x40180603 || In || 24 || [[#NVSCHED_CTRL_ADD_APPLICATION|NVSCHED_CTRL_ADD_APPLICATION]]
|-
|-
| 0xC0344704 || Inout || 52 || [[#NVGPU_GPU_IOCTL_ZBC_QUERY_TABLE]]
| 0x40180604 || In || 24 || [[#NVSCHED_CTRL_UPDATE_APPLICATION|NVSCHED_CTRL_UPDATE_APPLICATION]]
|-
|-
| 0xC0B04705 || Inout || 176 || [[#NVGPU_GPU_IOCTL_GET_CHARACTERISTICS]]
| 0x40080605 || In || 8 || [[#NVSCHED_CTRL_REMOVE_APPLICATION|NVSCHED_CTRL_REMOVE_APPLICATION]]
|-
|-
| 0xC0184706 || Inout || 24 || [[#NVGPU_GPU_IOCTL_GET_TPC_MASKS]]
| 0x80080606 || Out || 8 || [[#NVSCHED_CTRL_GET_ID|NVSCHED_CTRL_GET_ID]]
|-
|-
| 0x40084707 || In || 8 || [[#NVGPU_GPU_IOCTL_FLUSH_L2]]
| 0x80080607 || Out || 8 || [[#NVSCHED_CTRL_ADD_RUNLIST|NVSCHED_CTRL_ADD_RUNLIST]]
|-
|-
| 0x4008470D || In || 8 || [[#NVGPU_GPU_IOCTL_INVAL_ICACHE]]
| 0x40180608 || In || 24 || [[#NVSCHED_CTRL_UPDATE_RUNLIST|NVSCHED_CTRL_UPDATE_RUNLIST]]
|-
|-
| 0x4008470E || In || 8 || [[#NVGPU_GPU_IOCTL_SET_MMU_DEBUG_MODE]]
| 0x40100609 || In || 16 || [[#NVSCHED_CTRL_LINK_RUNLIST|NVSCHED_CTRL_LINK_RUNLIST]]
|-
|-
| 0x4010470F || In || 16 || [[#NVGPU_GPU_IOCTL_SET_SM_DEBUG_MODE]]
| 0x4010060A || In || 16 || [[#NVSCHED_CTRL_UNLINK_RUNLIST|NVSCHED_CTRL_UNLINK_RUNLIST]]
|-
|-
| 0xC0304710</br>([1.0.0-6.1.0] 0xC0084710) || Inout || 48</br>([1.0.0-6.1.0] 8) || [[#NVGPU_GPU_IOCTL_WAIT_FOR_PAUSE]]
| 0x4008060B || In || 8 || [[#NVSCHED_CTRL_REMOVE_RUNLIST|NVSCHED_CTRL_REMOVE_RUNLIST]]
|-
|-
| 0x80084711 || Out || 8 || [[#NVGPU_GPU_IOCTL_GET_TPC_EXCEPTION_EN_STATUS]]
| 0x8001060C || Out || 1 || [[#NVSCHED_CTRL_HAS_OVERRUN_EVENT|NVSCHED_CTRL_HAS_OVERRUN_EVENT]]
|-
|-
| 0x80084712 || Out || 8 || [[#NVGPU_GPU_IOCTL_NUM_VSMS]]
| 0x8020060D</br>([1.0.0-3.0.0] 0x8010060D) || Out || 32</br>([1.0.0-3.0.0] 16) || [[#NVSCHED_CTRL_GET_NEXT_OVERRUN_EVENT|NVSCHED_CTRL_GET_NEXT_OVERRUN_EVENT]]
|-
|-
| 0xC0044713 || Inout || 4 || [[#NVGPU_GPU_IOCTL_VSMS_MAPPING]]
| 0x400C060E || In || 12 || [[#NVSCHED_CTRL_PUT_CONDUCTOR_FLIP_FENCE|NVSCHED_CTRL_PUT_CONDUCTOR_FLIP_FENCE]]
|-
|-
| 0x80084714 || Out || 8 || [[#NVGPU_GPU_IOCTL_ZBC_GET_ACTIVE_SLOT_MASK]]
| 0x4008060F || In || 8 || [[#NVSCHED_CTRL_DETACH_APPLICATION|NVSCHED_CTRL_DETACH_APPLICATION]]
|-
|-
| 0x80044715 || Out || 4 || [[#NVGPU_GPU_IOCTL_PMU_GET_GPU_LOAD]]
| 0x40100610 || In || 16 || NVSCHED_CTRL_SET_APPLICATION_MAX_DEBT
|-
|-
| 0x40084716 || In || 8 || [[#NVGPU_GPU_IOCTL_SET_CG_CONTROLS]]
| 0x40100611 || In || 16 || NVSCHED_CTRL_SET_RUNLIST_MAX_DEBT
|-
|-
| 0xC0084717 || Inout || 8 || [[#NVGPU_GPU_IOCTL_GET_CG_CONTROLS]]
| 0x40010612 || In || 1 || NVSCHED_CTRL_OVERRUN_EVENTS_ENABLE
|-
| 0x40084718 || In || 8 || [[#NVGPU_GPU_IOCTL_SET_PG_CONTROLS]]
|-
| 0xC0084719 || Inout || 8 || [[#NVGPU_GPU_IOCTL_GET_PG_CONTROLS]]
|-
| 0x8018471A || Out || 24 || [[#NVGPU_GPU_IOCTL_PMU_GET_ELPG_RESIDENCY_GATING]]
|-
| 0xC008471B || Inout || 8 || [[#NVGPU_GPU_IOCTL_GET_ERROR_CHANNEL_USER_DATA]]
|-
| 0xC010471C || Inout || 16 || [[#NVGPU_GPU_IOCTL_GET_GPU_TIME]]
|-
| 0xC108471D || Inout || 264 || [[#NVGPU_GPU_IOCTL_GET_CPU_TIME_CORRELATION_INFO]]
|}
|}


=== NVGPU_GPU_IOCTL_ZCULL_GET_CTX_SIZE ===
=== NVSCHED_CTRL_ENABLE ===
Returns the GPU's ZCULL context size. Identical to Linux driver.
Enables the scheduler.


struct {
=== NVSCHED_CTRL_DISABLE ===
    __out u32 size;
Disables the scheduler.
  };


=== NVGPU_GPU_IOCTL_ZCULL_GET_INFO ===
=== NVSCHED_CTRL_ADD_APPLICATION ===
Returns GPU's ZCULL information. Identical to Linux driver.
Adds a new application to the scheduler.


struct {
  struct {
     __out u32 width_align_pixels;
     __in u64 application_id;
     __out u32 height_align_pixels;
     __in u64 priority;
     __out u32 pixel_squares_by_aliquots;
     __in u64 timeslice;
    __out u32 aliquot_total;
    __out u32 region_byte_multiplier;
    __out u32 region_header_size;
    __out u32 subregion_header_size;
    __out u32 subregion_width_align_pixels;
    __out u32 subregion_height_align_pixels;
    __out u32 subregion_count;
   };
   };


=== NVGPU_GPU_IOCTL_ZBC_SET_TABLE ===
=== NVSCHED_CTRL_UPDATE_APPLICATION ===
Sets the active ZBC table. Identical to Linux driver.
Updates the application parameters in the scheduler.


struct {
  struct {
     __in u32 color_ds[4];
     __in u64 application_id;
     __in u32 color_l2[4];
     __in u64 priority;
     __in u32 depth;
     __in u64 timeslice;
    __in u32 format;
    __in u32 type;        // 1=color, 2=depth
   };
   };


=== NVGPU_GPU_IOCTL_ZBC_QUERY_TABLE ===
=== NVSCHED_CTRL_REMOVE_APPLICATION ===
Queries the active ZBC table. Identical to Linux driver.
Removes the application from the scheduler.


struct {
  struct {
     __out u32 color_ds[4];
     __in u64 application_id;
    __out u32 color_l2[4];
    __out u32 depth;
    __out u32 ref_cnt;
    __out u32 format;
    __out u32 type;
    __inout u32 index_size;
   };
   };


=== NVGPU_GPU_IOCTL_GET_CHARACTERISTICS ===
=== NVSCHED_CTRL_GET_ID ===
Returns the GPU characteristics. Modified to return inline data instead of using a pointer.
Returns the ID of the last scheduled object.


[3.0.0+] Uses either [[#Ioctl|Ioctl]] or [[#Ioctl3|Ioctl3]].
  struct gpu_characteristics {
    u32 arch;                      // 0x120 (NVGPU_GPU_ARCH_GM200)
    u32 impl;                      // 0xB (NVGPU_GPU_IMPL_GM20B) or 0xE (NVGPU_GPU_IMPL_GM20B_B)
    u32 rev;                        // 0xA1 (Revision A1)
    u32 num_gpc;                    // 0x1
    u64 l2_cache_size;              // 0x40000
    u64 on_board_video_memory_size; // 0x0 (not used)
    u32 num_tpc_per_gpc;            // 0x2
    u32 bus_type;                  // 0x20 (NVGPU_GPU_BUS_TYPE_AXI)
    u32 big_page_size;              // 0x20000
    u32 compression_page_size;      // 0x20000
    u32 pde_coverage_bit_count;    // 0x1B
    u32 available_big_page_sizes;  // 0x30000
    u32 gpc_mask;                  // 0x1
    u32 sm_arch_sm_version;        // 0x503 (Maxwell Generation 5.0.3)
    u32 sm_arch_spa_version;        // 0x503 (Maxwell Generation 5.0.3)
    u32 sm_arch_warp_count;        // 0x80
    u32 gpu_va_bit_count;          // 0x28
    u32 reserved;                  // NULL
    u64 flags;                      // 0x55 (HAS_SYNCPOINTS | SUPPORT_SPARSE_ALLOCS | SUPPORT_CYCLE_STATS | SUPPORT_CYCLE_STATS_SNAPSHOT)
    u32 twod_class;                // 0x902D (FERMI_TWOD_A)
    u32 threed_class;              // 0xB197 (MAXWELL_B)
    u32 compute_class;              // 0xB1C0 (MAXWELL_COMPUTE_B)
    u32 gpfifo_class;              // 0xB06F (MAXWELL_CHANNEL_GPFIFO_A)
    u32 inline_to_memory_class;    // 0xA140 (KEPLER_INLINE_TO_MEMORY_B)
    u32 dma_copy_class;            // 0xB0B5 (MAXWELL_DMA_COPY_A)
    u32 max_fbps_count;            // 0x1
    u32 fbp_en_mask;                // 0x0 (disabled)
    u32 max_ltc_per_fbp;            // 0x2
    u32 max_lts_per_ltc;            // 0x1
    u32 max_tex_per_tpc;            // 0x0 (not supported)
    u32 max_gpc_count;              // 0x1
    u32 rop_l2_en_mask_0;          // 0x21D70 (fuse_status_opt_rop_l2_fbp_r)
    u32 rop_l2_en_mask_1;          // 0x0
    u64 chipname;                  // 0x6230326D67 ("gm20b")
    u64 gr_compbit_store_base_hw;  // 0x0 (not supported)
  };
   struct {
   struct {
     __inout u64 gpu_characteristics_buf_size;  // must not be NULL, but gets overwritten with 0xA0=max_size
     __out u64 id;
    __in    u64 gpu_characteristics_buf_addr;  // ignored, but must not be NULL
    __out struct gpu_characteristics gc;
   };
   };


=== NVGPU_GPU_IOCTL_GET_TPC_MASKS ===
=== NVSCHED_CTRL_ADD_RUNLIST ===
Returns the TPC mask value for each GPC. Modified to return inline data instead of using a pointer.
Creates a new runlist and returns it's ID.
 
[3.0.0+] Uses either [[#Ioctl|Ioctl]] or [[#Ioctl3|Ioctl3]].


   struct {
   struct {
    __in u32 mask_buf_size;      // ignored, but must not be NULL
     __out u64 runlist_id;
    __in u32 reserved[3];
     __out u64 mask_buf;           // receives one 32-bit TPC mask per GPC (GPC 0 and GPC 1)
   };
   };


=== NVGPU_GPU_IOCTL_FLUSH_L2 ===
=== NVSCHED_CTRL_UPDATE_RUNLIST ===
Flushes the GPU L2 cache.
Updates the runlist parameters in the scheduler.


   struct {
   struct {
     __in u32 flush;         // l2_flush | l2_invalidate << 1 | fb_flush << 2
     __in u64 runlist_id;
     __in u32 reserved;
     __in u64 priority;
    __in u64 timeslice;
   };
   };


=== NVGPU_GPU_IOCTL_INVAL_ICACHE ===
=== NVSCHED_CTRL_LINK_RUNLIST ===
Invalidates the GPU instruction cache. Identical to Linux driver.
Links a runlist to a given application in the scheduler.


   struct {
   struct {
     __in s32 channel_fd;
     __in u64 runlist_id;
     __in u32 reserved;
     __in u64 application_id;
   };
   };


=== NVGPU_GPU_IOCTL_SET_MMU_DEBUG_MODE ===
=== NVSCHED_CTRL_UNLINK_RUNLIST ===
Sets the GPU MMU debug mode. Identical to Linux driver.
Unlinks a runlist from a given application in the scheduler.


   struct {
   struct {
     __in u32 state;
     __in u64 runlist_id;
     __in u32 reserved;
     __in u64 application_id;
   };
   };


=== NVGPU_GPU_IOCTL_SET_SM_DEBUG_MODE ===
=== NVSCHED_CTRL_REMOVE_RUNLIST ===
Sets the GPU SM debug mode. Identical to Linux driver.
Removes the runlist from the scheduler.


   struct {
   struct {
    __in s32 channel_fd;
     __in u64 runlist_id;
    __in u32 enable;
     __in u64 sms;
   };
   };


=== NVGPU_GPU_IOCTL_WAIT_FOR_PAUSE ===
=== NVSCHED_CTRL_HAS_OVERRUN_EVENT ===
Waits until all valid warps on the GPU SM are paused and returns their current state.
Returns a boolean to tell if the scheduler has an overrun event or not.


   struct {
   struct {
     __in u64 pwarpstate;
     __out u8 has_overrun;
   };
   };


[6.1.0+] This command was modified to return inline data instead of using a pointer.
=== NVSCHED_CTRL_GET_NEXT_OVERRUN_EVENT ===
Returns the overrun event's data from the scheduler.


   struct {
   struct {
     __out u64 sm0_valid_warps;
     __out u64 runlist_id;
     __out u64 sm0_trapped_warps;
     __out u64 debt;
     __out u64 sm0_paused_warps;
     __out u64 unk0;           // 3.0.0+ only
     __out u64 sm1_valid_warps;
     __out u64 unk1;           // 3.0.0+ only
    __out u64 sm1_trapped_warps;
    __out u64 sm1_paused_warps;
   };
   };


=== NVGPU_GPU_IOCTL_GET_TPC_EXCEPTION_EN_STATUS ===
=== NVSCHED_CTRL_PUT_CONDUCTOR_FLIP_FENCE ===
Returns a mask value describing all active TPC exceptions. Identical to Linux driver.
Installs a fence swap event?


   struct {
   struct {
     __out u64 tpc_exception_en_sm_mask;
     __in u32 fence_id;
    __in u32 fence_value;
    __in u32 swap_interval;
   };
   };


=== NVGPU_GPU_IOCTL_NUM_VSMS ===
=== NVSCHED_CTRL_DETACH_APPLICATION ===
Returns the number of GPU SM units present. Identical to Linux driver.
Places the given application in detached state.


   struct {
   struct {
     __out u32 num_vsms;
     __in u64 application_id;
    __out u32 reserved;
   };
   };


=== NVGPU_GPU_IOCTL_VSMS_MAPPING ===
== /dev/nverpt-ctrl ==
Returns mapping information on each GPU SM unit. Modified to return inline data instead of using a pointer.
Added in firmware version 3.0.0.


  struct {
{| class="wikitable" border="1"
    __out u8 sm0_gpc_index;
! Value || Direction || Size || Description
    __out u8 sm0_tpc_index;
|-
    __out u8 sm1_gpc_index;
| 0xC1280701 || Inout || 296 || [[#NVERPT_TELEMETRY_SUBMIT_DATA|NVERPT_TELEMETRY_SUBMIT_DATA]]
    __out u8 sm1_tpc_index;
|-
  };
| 0xCF580702 || Inout || 3928 || [[#NVERPT_TELEMETRY_SUBMIT_DISPLAY_DATA|NVERPT_TELEMETRY_SUBMIT_DISPLAY_DATA]]
|}


=== NVGPU_GPU_IOCTL_ZBC_GET_ACTIVE_SLOT_MASK ===
=== NVERPT_TELEMETRY_SUBMIT_DATA ===
Returns the mask value for a ZBC slot.
Unofficial name.
 
Sends test data for creating a new [[Error_Report_services|Error Report]].


   struct {
   struct {
     __out u32 slot;       // always 0x07
     __in u64 TestU64;
     __out u32 mask;
    __in u32 TestU32;
    __in u8  padding0[4];
    __in s64 TestI64;
    __in s32 TestI32;
    __in u8  TestString[32];
    __in u8  TestU8Array[8];
    __in u32 TestU8Array_size;
    __in u32 TestU32Array[8];
    __in u32 TestU32Array_size;
    __in u64 TestU64Array[8];
    __in u32 TestU64Array_size;
    __in s32 TestI32Array[8];
    __in u32 TestI32Array_size;
    __in s64 TestI64Array[8];
     __in u32 TestI64Array_size;
    __in u16 TestU16;
    __in u8  TestU8;
    __in s16 TestI16;
    __in s8  TestI8;
    __in u8  padding1[5];
   };
   };


=== NVGPU_GPU_IOCTL_PMU_GET_GPU_LOAD ===
=== NVERPT_TELEMETRY_SUBMIT_DISPLAY_DATA ===
Returns the GPU load value from the PMU.
Unofficial name.
 
Sends display data for creating a new [[Error_Report_services|Error Report]].


   struct {
   struct {
     __out u32 pmu_gpu_load;
     __in u32 CodecType;
    __in u32 DecodeBuffers;
    __in u32 FrameWidth;
    __in u32 FrameHeight;
    __in u8  ColorPrimaries;
    __in u8  TransferCharacteristics;
    __in u8  MatrixCoefficients;
    __in u8  padding;
    __in u32 DisplayWidth;
    __in u32 DisplayHeight;
    __in u32 DARWidth;
    __in u32 DARHeight;
    __in u32 ColorFormat;
    __in u32 ColorSpace[8];
    __in u32 ColorSpace_size;
    __in u32 SurfaceLayout[8];
    __in u32 SurfaceLayout_size;
    __in u8  ErrorString[64];      // must be "Error detected = 0x1000000"
    __in u32 VideoDecState;
    __in u8  VideoLog[3712];
    __in u32 VideoLog_size;
   };
   };


=== NVGPU_GPU_IOCTL_SET_CG_CONTROLS ===
== /dev/nvhost-as-gpu ==
Sets the clock gate control value.
Each fd opened to this device creates an address space. An address space is then later bound with a channel.


  struct {
Once a nvgpu channel has been bound to an address space it cannot be unbound. There is no support for allowing an nvgpu channel to change from one address space to another (or from one to none).
    __in u32 cg_mask;
                                                                                                                             
    __in u32 cg_value;
{| class="wikitable" border="1"
  };
! Value || Direction || Size || Description
|-
| 0x40044101 || In || 4 || [[#NVGPU_AS_IOCTL_BIND_CHANNEL|NVGPU_AS_IOCTL_BIND_CHANNEL]]
|-
| 0xC0184102 || Inout || 24 || [[#NVGPU_AS_IOCTL_ALLOC_SPACE|NVGPU_AS_IOCTL_ALLOC_SPACE]]
|-
| 0xC0104103 || Inout || 16 || [[#NVGPU_AS_IOCTL_FREE_SPACE|NVGPU_AS_IOCTL_FREE_SPACE]]
|-
| 0xC0184104 || Inout || 24 || [[#NVGPU_AS_IOCTL_MAP_BUFFER|NVGPU_AS_IOCTL_MAP_BUFFER]]
|-
| 0xC0084105 || Inout || 8 || [[#NVGPU_AS_IOCTL_UNMAP_BUFFER|NVGPU_AS_IOCTL_UNMAP_BUFFER]]
|-
| 0xC0284106 || Inout || 40 || [[#NVGPU_AS_IOCTL_MAP_BUFFER_EX|NVGPU_AS_IOCTL_MAP_BUFFER_EX]]
|-
| 0x40104107 || In || 16 || [[#NVGPU_AS_IOCTL_ALLOC_AS|NVGPU_AS_IOCTL_ALLOC_AS]]
|-
| 0xC0404108 || Inout || 64 || [[#NVGPU_AS_IOCTL_GET_VA_REGIONS|NVGPU_AS_IOCTL_GET_VA_REGIONS]]
|-
| 0x40284109 || In || 40 || [[#NVGPU_AS_IOCTL_ALLOC_AS_EX|NVGPU_AS_IOCTL_ALLOC_AS_EX]]
|-
| 0xC038410A || Inout || 56 || [[#NVGPU_AS_IOCTL_MAP_BUFFER_EX2|NVGPU_AS_IOCTL_MAP_BUFFER_EX2]]
|-
| 0x8010410B || Out || 16 || [S2] [[#NVGPU_AS_IOCTL_GET_SYNC_RO_MAP|NVGPU_AS_IOCTL_GET_SYNC_RO_MAP]]
|-
| 0xC020410C || Inout || 32 || [S2] [[#NVGPU_AS_IOCTL_MAPPING_MODIFY|NVGPU_AS_IOCTL_MAPPING_MODIFY]]
|-
| 0xC???410D || Inout || Variable || [S2] [[#NVGPU_AS_IOCTL_REMAP_2|NVGPU_AS_IOCTL_REMAP]]
|-
| 0xC0??4114 || Inout || Variable || [[#NVGPU_AS_IOCTL_REMAP|NVGPU_AS_IOCTL_REMAP]]
|}


=== NVGPU_GPU_IOCTL_GET_CG_CONTROLS ===
=== NVGPU_AS_IOCTL_BIND_CHANNEL ===
Returns the clock gate control value.
Identical to Linux driver.


   struct {
   struct {
     __in u32 cg_mask;
     __in u32 channel_fd;
    __out u32 cg_value;
   };
   };


=== NVGPU_GPU_IOCTL_SET_PG_CONTROLS ===
=== NVGPU_AS_IOCTL_ALLOC_SPACE ===
Sets the power gate control value.
Reserves pages in the device address space.


   struct {
   struct {
     __in u32 pg_mask;
     __in u32 pages;
     __in u32 pg_value;
     __in u32 page_size;
    __in u32 flags;
    __in u32 padding;
    union {
      __out u64 offset;
      __in  u64 align;
    };
   };
   };


=== NVGPU_GPU_IOCTL_GET_PG_CONTROLS ===
=== NVGPU_AS_IOCTL_FREE_SPACE ===
Returns the power gate control value.
Frees pages from the device address space.


   struct {
   struct {
     __in u32 pg_mask;
    __in u64 offset;
     __out u32 pg_value;
     __in u32 pages;
     __in u32 page_size;
   };
   };


=== NVGPU_GPU_IOCTL_PMU_GET_ELPG_RESIDENCY_GATING ===
=== NVGPU_AS_IOCTL_MAP_BUFFER ===
Returns the GPU PMU ELPG residency gating values.
Maps a memory region in the device address space.
 
Unaligned size will cause a [[#Panic]].
 
On success, the mapped memory region is granted the [[SVC#MemoryAttribute|DeviceShared]] attribute.


   struct {
   struct {
     __out u64 pg_ingating_time_us;
     __in    u32 flags;        // bit0: fixed_offset, bit2: cacheable
    __out u64 pg_ungating_time_us;
    __inout u32 reserved0;
     __out u64 pg_gating_cnt;
    __in    u32 mem_id;      // nvmap handle
    __inout u32 reserved1;
    union {
      __out u64 offset;
      __in  u64 align;
     };
   };
   };


=== NVGPU_GPU_IOCTL_GET_ERROR_CHANNEL_USER_DATA ===
=== NVGPU_AS_IOCTL_MAP_BUFFER_EX ===
Returns user specific data from the error channel, if one exists.
Maps a memory region in the device address space with extra params.
 
Unaligned size will cause a [[#Panic]].
 
On success, the mapped memory region is granted the [[SVC#MemoryAttribute|DeviceShared]] attribute.


   struct {
   struct {
     __out u64 data;
     __in      u32 flags;          // bit0: fixed_offset, bit2: cacheable
    __inout  u32 kind;          // -1 is default
    __in      u32 mem_id;        // nvmap handle
    __inout  u32 reserved;
    __in      u64 buffer_offset;
    __in      u64 mapping_size;
    union {
      __out   u64 offset;
      __in    u64 align;
    };
   };
   };


=== NVGPU_GPU_IOCTL_GET_GPU_TIME ===
=== NVGPU_AS_IOCTL_UNMAP_BUFFER ===
Returns the timestamp from the GPU's nanosecond timer (PTIMER). Identical to Linux driver.
Unmaps a memory region from the device address space.


   struct {
   struct {
     __out u64 gpu_timestamp;      // raw GPU counter (PTIMER) value
     __in u64 offset;
    __out u64 reserved;
   };
   };


=== NVGPU_GPU_IOCTL_GET_CPU_TIME_CORRELATION_INFO ===
=== NVGPU_AS_IOCTL_ALLOC_AS ===
Returns CPU/GPU timestamp pairs for correlation analysis. Identical to Linux driver.
Nintendo's custom implementation for allocating an address space.


struct time_correlation_sample {
  struct {
  u64 cpu_timestamp;                                 // from CPU's CNTPCT_EL0 register
    __in u32 big_page_size;   // depends on GPU's available_big_page_sizes; 0=default
  u64 gpu_timestamp;                                  // from GPU's PTIMER registers
    __in s32 as_fd;           // ignored; passes 0
};
    __in u64 reserved;       // ignored; passes 0
  };
struct {
  __out struct time_correlation_sample samples[16];   // timestamp pairs
  __in u32    count;                                 // number of pairs to read
  __in u32    source_id;                             // cpu clock source id (must be 1)
};


== Channels ==
=== NVGPU_AS_IOCTL_GET_VA_REGIONS ===
Channels are a concept for  NVIDIA hardware blocks that share a common interface.
Nintendo's custom implementation to get rid of pointer in struct.


{| class="wikitable" border="1"
Uses [[#Ioctl3|Ioctl3]].
! Path || Name
|-
| /dev/nvhost-gpu || GPU
|-
| /dev/nvhost-msenc || Video Encoder
|-
| /dev/nvhost-nvdec || Video Decoder
|-
| /dev/nvhost-nvjpg || JPEG Decoder
|-
| /dev/nvhost-vic || Video Image Compositor
|-
| /dev/nvhost-display || Display
|}


== Channel Ioctls ==
  struct va_region {
{| class="wikitable" border="1"
    u64 offset;
! Value || Size || Description
    u32 page_size;
|-
    u32 reserved;
| 0xC0??0001 || Variable || [[#NVHOST_IOCTL_CHANNEL_SUBMIT]]
    u64 pages;
|-
  };
| 0xC0080002 || 8 || [[#NVHOST_IOCTL_CHANNEL_GET_SYNCPOINT]]
 
|-
  struct {
| 0xC0080003 || 8 || [[#NVHOST_IOCTL_CHANNEL_GET_WAITBASE]]
    __inout u64  buf_addr;    // (contained output user ptr on linux, ignored)
|-
    __inout u32  buf_size;    // forced to 2*sizeof(struct va_region)
| 0xC0080004 || 8 || [[#NVHOST_IOCTL_CHANNEL_GET_MODMUTEX]]
    __inout u32  reserved;
|-
    __out struct  va_region regions[2];
| 0x40040007 || 4 || [[#NVHOST_IOCTL_CHANNEL_SET_SUBMIT_TIMEOUT]]
  };
|-
 
| 0x40080008 || 8 || [[#NVHOST_IOCTL_CHANNEL_SET_CLK_RATE]]
=== NVGPU_AS_IOCTL_ALLOC_AS_EX ===
|-
Nintendo's custom implementation for allocating an address space with extra params.
| 0xC0??0009 || Variable || [[#NVHOST_IOCTL_CHANNEL_MAP_CMD_BUFFER]]
 
|-
  struct {
| 0xC0??000A || Variable || [[#NVHOST_IOCTL_CHANNEL_UNMAP_CMD_BUFFER]]
    __in u32 big_page_size;  // depends on GPU's available_big_page_sizes; 0=default
|-
    __in s32 as_fd;          // ignored; passes 0
| 0x00000013 || 0 || [[#NVHOST_IOCTL_CHANNEL_SET_TIMEOUT_EX]]
    __in u32 flags;          // passes 0
|-
    __in u32 reserved;        // ignored; passes 0
| 0xC0080023</br>([1.0.0-7.0.1] 0xC0080014) || 8 || [[#NVHOST_IOCTL_CHANNEL_GET_CLK_RATE]]
    __in u64 va_range_start;
|-
    __in u64 va_range_end;
| 0xC0??0024 || Variable || [[#NVHOST_IOCTL_CHANNEL_SUBMIT_EX]]
    __in u64 va_range_split;
|-
  };
| 0xC0??0025 || Variable || [[#NVHOST_IOCTL_CHANNEL_MAP_CMD_BUFFER_EX]]
 
|-
=== NVGPU_AS_IOCTL_MAP_BUFFER_EX2 ===
| 0xC0??0026 || Variable || [[#NVHOST_IOCTL_CHANNEL_UNMAP_CMD_BUFFER_EX]]
Maps a memory region in the device address space with extra params.
|- style="border-top: double"
 
| 0x40044801 || 4 || [[#NVGPU_IOCTL_CHANNEL_SET_NVMAP_FD]]
Unaligned size will cause a [[#Panic]].
|-
 
| 0x40044803 || 4 || [[#NVGPU_IOCTL_CHANNEL_SET_TIMEOUT]]
On success, the mapped memory region is granted the [[SVC#MemoryAttribute|DeviceShared]] attribute.
|-
 
| 0x40084805 || 8 || [[#NVGPU_IOCTL_CHANNEL_ALLOC_GPFIFO]]
  struct {
|-
    __in      u32 flags;          // bit0: fixed_offset, bit2: cacheable
| 0x40184806 || 24 || [[#NVGPU_IOCTL_CHANNEL_WAIT]]
    __inout  u32 kind;          // -1 is default
|-
    __in      u32 mem_id;        // nvmap handle
| 0xC0044807 || 4 || [[#NVGPU_IOCTL_CHANNEL_CYCLE_STATS]]
    __inout  u32 reserved0;
|-
    __in      u64 buffer_offset;
| 0xC0??4808 || Variable || [[#NVGPU_IOCTL_CHANNEL_SUBMIT_GPFIFO]]
    __in      u64 mapping_size;
|-
    union {
| 0xC0104809 || 16 || [[#NVGPU_IOCTL_CHANNEL_ALLOC_OBJ_CTX]]
      __out  u64 offset;
|-
      __in    u64 align;
| 0x4008480A || 8 || [[#NVHOST_IOCTL_CHANNEL_FREE_OBJ_CTX]]
    };
|-
    __in      u64 vma_addr;
| 0xC010480B || 16 || [[#NVGPU_IOCTL_CHANNEL_ZCULL_BIND]]
    __in      u32 pages;
|-
    __inout  u32 reserved1;
| 0xC018480C || 24 || [[#NVGPU_IOCTL_CHANNEL_SET_ERROR_NOTIFIER]]
  };
|-
| 0x4004480D || 4 || [[#NVGPU_IOCTL_CHANNEL_SET_PRIORITY]]
|-
| 0x0000480E || 0 || [[#NVGPU_IOCTL_CHANNEL_ENABLE]]
|-
| 0x0000480F || 0 || [[#NVGPU_IOCTL_CHANNEL_DISABLE]]
|-
| 0x00004810 || 0 || [[#NVGPU_IOCTL_CHANNEL_PREEMPT]]
|-
| 0x00004811 || 0 || [[#NVGPU_IOCTL_CHANNEL_FORCE_RESET]]
|-
| 0x40084812 || 8 || [[#NVGPU_IOCTL_CHANNEL_EVENT_ID_CONTROL]]
|-
| 0xC0104813 || 16 || [[#NVGPU_IOCTL_CHANNEL_CYCLE_STATS_SNAPSHOT]]
|-
| 0x80804816 || 128 || [[#NVGPU_IOCTL_CHANNEL_GET_ERROR_INFO]]
|-
| 0xC0104817 || 16 || [[#NVGPU_IOCTL_CHANNEL_GET_ERROR_NOTIFICATION]]
|-
| 0x40204818 || 32 || [[#NVGPU_IOCTL_CHANNEL_ALLOC_GPFIFO_EX]]
|-
| 0xC0??4819 || Variable || [[#NVGPU_IOCTL_CHANNEL_SUBMIT_GPFIFO_RETRY]]
|-
| 0xC020481A || 32 || [[#NVGPU_IOCTL_CHANNEL_ALLOC_GPFIFO_EX2]]
|-
| 0xC018481B || 24 || [[#NVGPU_IOCTL_CHANNEL_SUBMIT_GPFIFO_EX]]
|-
| 0xC018481C || 24 || [[#NVGPU_IOCTL_CHANNEL_SUBMIT_GPFIFO_RETRY_EX]]
|-
| 0xC004481D || 4 || [[#NVGPU_IOCTL_CHANNEL_SET_TIMESLICE]]
|- style="border-top: double"
| 0x40084714 || 8 || [[#NVGPU_IOCTL_CHANNEL_SET_USER_DATA]]
|-
| 0x80084715 || 8 || [[#NVGPU_IOCTL_CHANNEL_GET_USER_DATA]]
|}


=== NVHOST_IOCTL_CHANNEL_SUBMIT ===
=== NVGPU_AS_IOCTL_GET_SYNC_RO_MAP ===
Submits data to the channel.
Returns the GPU virtual address to the read-only syncpoint-semaphore shim.


   struct cmdbuf {
   struct {
     u32 mem;
     __out    u64 base_gpuva;
     u32 offset;
    __out     u32 sync_size;
     u32 words;
    __out     u32 num_syncpoints;
   };
   };
 
 
   struct reloc {
=== NVGPU_AS_IOCTL_MAPPING_MODIFY ===
     u32 cmdbuf_mem;
Changes the kind of an existing mapped buffer region.
     u32 cmdbuf_offset;
 
     u32 target;
   struct {
     u32 target_offset;
     __in      s16 compr_kind;
    __in      s16 incompr_kind;
     __in      u64 buffer_offset;
     __in      u64 buffer_size;
     __in      u64 map_address;
   };
   };
 
 
   struct reloc_shift {
=== NVGPU_AS_IOCTL_REMAP ===
     u32 shift;
Nintendo's custom implementation of address space remapping for sparse pages.
 
   struct remap_op {
    u16 flags;                      // bit2: cacheable
    u16 kind;         
    u32 mem_handle;
    u32 mem_offset_in_pages;
    u32 virt_offset_in_pages;      // (alloc_space_offset >> 0x10)
     u32 num_pages;                 // alloc_space_pages
   };
   };
 
   struct syncpt_incr {
   struct {
     u32 syncpt_id;
     __in struct remap_op entries[];
    u32 syncpt_incrs;
   };
   };
 
 
  struct fence {
=== NVGPU_AS_IOCTL_REMAP ===
    u32 id;
Switch 2 variation of [[#NVGPU_AS_IOCTL_REMAP|NVGPU_AS_IOCTL_REMAP]].
    u32 thresh;
 
  };
   struct remap_op {
 
     u32 flags;
   struct {
     s16 compr_kind;  
     __in    u32 num_cmdbufs;
     s16 incompr_kind;      
     __in    u32 num_relocs;
     u32 mem_handle;
     __in    u32 num_syncpt_incrs;
     u32 reserved;
     __in    u32 num_fences;
     u64 mem_offset_in_pages;
     __in    struct cmdbuf cmdbufs[];               // depends on num_cmdbufs
     u64 virt_offset_in_pages;
     __in    struct reloc relocs[];                // depends on num_relocs
     u64 num_pages;
    __in    struct reloc_shift reloc_shifts[];     // depends on num_relocs
     __in    struct syncpt_incr syncpt_incrs[];     // depends on num_syncpt_incrs
     __out  struct fence fences[];                 // depends on num_fences
   };
   };
 
=== NVHOST_IOCTL_CHANNEL_GET_SYNCPOINT ===
Returns the current syncpoint value for a given module. Identical to Linux driver.
 
   struct {
   struct {
     __in   u32 module_id;
     __in struct remap_op entries[];
    __out  u32 syncpt_value;
   };
   };


=== NVHOST_IOCTL_CHANNEL_GET_WAITBASE ===
== /dev/nvhost-dbg-gpu ==
Returns the current waitbase value for a given module. Always returns 0.
Returns [[#Errors|NotSupported]] on Open unless nn::settings::detail::GetDebugModeFlag is set.


  struct {
{| class="wikitable" border="1"
    __in    u32 module_id;
! Value || Direction || Size || Description
    __out  u32 waitbase_value;
|-
  };
| 0x40084401 || In || 8 || NVGPU_DBG_GPU_IOCTL_BIND_CHANNEL
 
|-
=== NVHOST_IOCTL_CHANNEL_GET_MODMUTEX ===
| 0xC0??4402 || Inout || Variable || NVGPU_DBG_GPU_IOCTL_REG_OPS
Stubbed. Does a debug print and returns 0.
|-
 
| 0x40084403 || In || 8 || NVGPU_DBG_GPU_IOCTL_EVENTS_CTRL
=== NVHOST_IOCTL_CHANNEL_SET_SUBMIT_TIMEOUT ===
|-
Sets the submit timeout value for the channel. Identical to Linux driver.
| 0x40044404 || In || 4 || NVGPU_DBG_GPU_IOCTL_POWERGATE
 
|-
  struct {
| 0x40044405 || In || 4 || NVGPU_DBG_GPU_IOCTL_SMPC_CTXSW_MODE
    __in    u32 timeout;
|-
  };
| 0x40044406 || In || 4 || NVGPU_DBG_GPU_IOCTL_SUSPEND_RESUME_ALL_SMS
 
|-
=== NVHOST_IOCTL_CHANNEL_SET_CLK_RATE ===
| 0xC0184407 || Inout || 24 || NVGPU_DBG_GPU_IOCTL_PERFBUF_MAP
Sets the clock rate value for a given module. Identical to Linux driver.
|-
 
| 0x40084408 || In || 8 || NVGPU_DBG_GPU_IOCTL_PERFBUF_UNMAP
  struct {
|-
    __in    u32 clk_rate;
| 0x40084409 || In || 8 || NVGPU_DBG_GPU_IOCTL_PC_SAMPLING
    __in    u32 module_id;
|-
  };
| 0x4008440A || In || 8 || NVGPU_DBG_GPU_IOCTL_TIMEOUT
 
|-
=== NVHOST_IOCTL_CHANNEL_MAP_CMD_BUFFER ===
| 0x8008440B || Out || 8 || NVGPU_DBG_GPU_IOCTL_GET_TIMEOUT
Uses '''nvmap_pin''' internally to pin a given number of nvmap handles to an appropriate device physical address.
|-
 
| 0x8004440C || Out || 4 || NVGPU_DBG_GPU_IOCTL_GET_GR_CONTEXT_SIZE
  struct handle {
|-
    u32 handle_id_in;                // nvmap handle to map
| 0x0000440D || None || 0 || [[#NVGPU_DBG_GPU_IOCTL_GET_GR_CONTEXT|NVGPU_DBG_GPU_IOCTL_GET_GR_CONTEXT]]
    u32 phys_addr_out;                // returned device physical address mapped to the handle
|-
  };
| 0xC018440E || Inout || 24 || NVGPU_DBG_GPU_IOCTL_ACCESS_FB_MEMORY
|-
  struct {
| 0xC018440F || Inout || 24 || NVGPU_DBG_GPU_IOCTL_GET_GPU_VA_RANGE_NUM_PDES
    __in    u32 num_handles;          // number of nvmap handles to map
|-
    __in    u32 reserved;            // ignored
| 0xC0104410 || Inout || 16 || [[#NVGPU_DBG_GPU_IOCTL_GET_GPU_VA_RANGE_PDES|NVGPU_DBG_GPU_IOCTL_GET_GPU_VA_RANGE_PDES]]
    __in    u8  is_compr;            // memory to map is compressed
|-
    __in    u8  padding[3];          // ignored
| 0xC0184411 || Inout || 24 || NVGPU_DBG_GPU_IOCTL_GET_GPU_VA_RANGE_NUM_PTES
    __inout struct handle handles[];  // depends on num_handles
|-
  };
| 0xC0104412 || Inout || 16 || [[#NVGPU_DBG_GPU_IOCTL_GET_GPU_VA_RANGE_PTES|NVGPU_DBG_GPU_IOCTL_GET_GPU_VA_RANGE_PTES]]
 
|-
=== NVHOST_IOCTL_CHANNEL_UNMAP_CMD_BUFFER ===
| 0xC0684413</br>[S2] 0xC0304413 || Inout || 104</br>48 || NVGPU_DBG_GPU_IOCTL_GET_COMPTAG_INFO
Uses '''nvmap_unpin''' internally to unpin a given number of nvmap handles from their device physical address.
|-
 
| 0xC0184414</br>[S2] 0xC0084414 || Inout || 24</br>8 || [[#NVGPU_DBG_GPU_IOCTL_READ_COMPTAGS|NVGPU_DBG_GPU_IOCTL_READ_COMPTAGS]]
  struct handle {
|-
    u32 handle_id_in;                // nvmap handle to unmap
| 0xC0184415</br>[S2] 0xC0084415 || Inout || 24</br>8 || [[#NVGPU_DBG_GPU_IOCTL_WRITE_COMPTAGS|NVGPU_DBG_GPU_IOCTL_WRITE_COMPTAGS]]
    u32 reserved;                    // ignored
|-
  };
| 0xC0104416 || Inout || 16 || NVGPU_DBG_GPU_IOCTL_RESERVE_COMPTAGS
|-
  struct {
| 0xC0104417 || Inout || 16 || NVGPU_DBG_GPU_IOCTL_FREE_RESERVED_COMPTAGS
    __in    u32 num_handles;          // number of nvmap handles to unmap
|-
    __in    u32 reserved;            // ignored
| 0xC0104418 || Inout || 16 || NVGPU_DBG_GPU_IOCTL_RESERVE_PA
    __in    u8  is_compr;            // memory to unmap is compressed
|-
    __in    u8  padding[3];          // ignored
| 0xC0104419 || Inout || 16 || NVGPU_DBG_GPU_IOCTL_FREE_RESERVED_PA
    __inout struct handle handles[];  // depends on num_handles
|-
  };
| 0xC018441A || Inout || 24 || NVGPU_DBG_GPU_IOCTL_LAZY_ALLOC_RESERVED_PA
|-
| 0xC020441B || Inout || 32 || [11.0.0+] NVGPU_DBG_GPU_IOCTL_LAZY_ALLOC_RESERVED_PA_EX
|-
| 0xC084441C || Inout || 132 || [11.0.0+] NVGPU_DBG_GPU_IOCTL_GET_SETTINGS
|-
| 0xC018441D || Inout || 24 || [11.0.0+] NVGPU_DBG_GPU_IOCTL_GET_SERIAL_NUMBER
|-
| 0xC020441E || Inout || 32 || [11.0.0+] NVGPU_DBG_GPU_IOCTL_GET_GPU_VA_RANGE_PAGES
|-
| 0x4008441F || In || 8 || [S2]
|-
| 0x00004420 || None || 0 || [S2]
|-
| 0xC0184421 || Inout || 24 || [S2]
|-
| 0x40084422 || In || 8 || [S2] NVGPU_DBG_GPU_IOCTL_SET_CTX_MMU_DEBUG_MODE
|-
| 0xC0084423 || Inout || 8 || [S2] NVGPU_DBG_GPU_IOCTL_HWPM_CTXSW_MODE
|-
| 0x40084424 || In || 8 || [S2] NVGPU_DBG_GPU_IOCTL_SET_SM_EXCEPTION_TYPE_MASK
|-
| 0xC0104425 || Inout || 16 || [S2] NVGPU_DBG_GPU_IOCTL_SUSPEND_RESUME_CONTEXTS
|-
| 0xC0184426 || Inout || 24 || [S2] NVGPU_DBG_GPU_IOCTL_READ_SINGLE_SM_ERROR_STATE
|-
| 0x40084427 || In || 8 || [S2] NVGPU_DBG_GPU_IOCTL_CLEAR_SINGLE_SM_ERROR_STATE
|-
| 0x40044428 || In || 4 || [S2] NVGPU_DBG_GPU_IOCTL_SET_SCHED_EXIT_WAIT_FOR_ERRBAR
|-
| 0xC0184429 || Inout || 24 || [S2]
|-
| 0x4010442A || In || 16 || [S2]  
|-
| 0x4010442B || In || 16 || [S2]  
|}


=== NVHOST_IOCTL_CHANNEL_SET_TIMEOUT_EX ===
=== NVGPU_DBG_GPU_IOCTL_GET_GR_CONTEXT ===
Sets the global timeout value for the channel. Identical to Linux driver.
Uses [[#Ioctl3|Ioctl3]].


  struct {
=== NVGPU_DBG_GPU_IOCTL_GET_GPU_VA_RANGE_PDES ===
    __in    u32 timeout;
Uses [[#Ioctl3|Ioctl3]].
    __in    u32 flags;
  };


=== NVHOST_IOCTL_CHANNEL_GET_CLK_RATE ===
=== NVGPU_DBG_GPU_IOCTL_GET_GPU_VA_RANGE_PTES ===
Returns the clock rate value for a given module. Identical to Linux driver.
Uses [[#Ioctl3|Ioctl3]].


  struct {
=== NVGPU_DBG_GPU_IOCTL_READ_COMPTAGS ===
    __out  u32 clk_rate;
Uses [[#Ioctl3|Ioctl3]].
    __in    u32 module_id;
  };


=== NVHOST_IOCTL_CHANNEL_SUBMIT_EX ===
=== NVGPU_DBG_GPU_IOCTL_WRITE_COMPTAGS ===
Same as [[#NVHOST_IOCTL_CHANNEL_SUBMIT|NVHOST_IOCTL_CHANNEL_SUBMIT]].
Uses [[#Ioctl2|Ioctl2]].


=== NVHOST_IOCTL_CHANNEL_MAP_CMD_BUFFER_EX ===
== /dev/nvhost-prof-gpu ==
Same as [[#NVHOST_IOCTL_CHANNEL_MAP_CMD_BUFFER|NVHOST_IOCTL_CHANNEL_MAP_CMD_BUFFER]], but calls '''nvmap_unpin''' internally in case of error.
Returns [[#Errors|NotSupported]] on Open unless nn::settings::detail::GetDebugModeFlag is set.


=== NVHOST_IOCTL_CHANNEL_UNMAP_CMD_BUFFER_EX ===
This device is identical to [[#/dev/nvhost-dbg-gpu|/dev/nvhost-dbg-gpu]].
Same as [[#NVHOST_IOCTL_CHANNEL_UNMAP_CMD_BUFFER|NVHOST_IOCTL_CHANNEL_UNMAP_CMD_BUFFER]].


=== NVGPU_IOCTL_CHANNEL_SET_NVMAP_FD ===
== /dev/nvhost-ctrl-gpu ==
Binds a nvmap object to this channel. Identical to Linux driver.
This device is for global (context independent) operations on the gpu. 
 
                                                                                                                                             
  struct {
{| class="wikitable" border="1"
    __in u32 nvmap_fd;
! Value || Direction || Size || Description
  };
|-
 
| 0x80044701 || Out || 4 || [[#NVGPU_GPU_IOCTL_ZCULL_GET_CTX_SIZE|NVGPU_GPU_IOCTL_ZCULL_GET_CTX_SIZE]]
=== NVGPU_IOCTL_CHANNEL_SET_TIMEOUT ===
|-
Sets the timeout value for the GPU channel. Identical to Linux driver.
| 0x80284702 || Out || 40 || [[#NVGPU_GPU_IOCTL_ZCULL_GET_INFO|NVGPU_GPU_IOCTL_ZCULL_GET_INFO]]
 
|-
  struct {
| 0x402C4703 || In || 44 || [[#NVGPU_GPU_IOCTL_ZBC_SET_TABLE|NVGPU_GPU_IOCTL_ZBC_SET_TABLE]]
    __in u32 timeout;
|-
  };
| 0xC0344704 || Inout || 52 || [[#NVGPU_GPU_IOCTL_ZBC_QUERY_TABLE|NVGPU_GPU_IOCTL_ZBC_QUERY_TABLE]]
 
|-
=== NVGPU_IOCTL_CHANNEL_ALLOC_GPFIFO ===
| 0xC0B04705</br>[S2] 0xC0E04705 || Inout || 176</br>[S2] 224|| [[#NVGPU_GPU_IOCTL_GET_CHARACTERISTICS|NVGPU_GPU_IOCTL_GET_CHARACTERISTICS]]
Allocates gpfifo entries. Identical to Linux driver.
|-
| 0xC0184706 || Inout || 24 || [[#NVGPU_GPU_IOCTL_GET_TPC_MASKS|NVGPU_GPU_IOCTL_GET_TPC_MASKS]]
|-
| 0x40084707 || In || 8 || [[#NVGPU_GPU_IOCTL_FLUSH_L2|NVGPU_GPU_IOCTL_FLUSH_L2]]
|-
| 0x4008470D || In || 8 || [[#NVGPU_GPU_IOCTL_INVAL_ICACHE|NVGPU_GPU_IOCTL_INVAL_ICACHE]]
|-
| 0x4008470E || In || 8 || [[#NVGPU_GPU_IOCTL_SET_MMU_DEBUG_MODE|NVGPU_GPU_IOCTL_SET_MMU_DEBUG_MODE]]
|-
| 0x4010470F || In || 16 || [[#NVGPU_GPU_IOCTL_SET_SM_DEBUG_MODE|NVGPU_GPU_IOCTL_SET_SM_DEBUG_MODE]]
|-
| 0xC0304710</br>([1.0.0-6.1.0] 0xC0084710)</br>[S2] 0xC0084710 || Inout || 48</br>([1.0.0-6.1.0] 8)</br>[S2] 8 || [[#NVGPU_GPU_IOCTL_WAIT_FOR_PAUSE|NVGPU_GPU_IOCTL_WAIT_FOR_PAUSE]]
|-
| 0x80084711 || Out || 8 || [[#NVGPU_GPU_IOCTL_GET_TPC_EXCEPTION_EN_STATUS|NVGPU_GPU_IOCTL_GET_TPC_EXCEPTION_EN_STATUS]]
|-
| 0x80084712 || Out || 8 || [[#NVGPU_GPU_IOCTL_NUM_VSMS|NVGPU_GPU_IOCTL_NUM_VSMS]]
|-
| 0xC0044713</br>[S2] 0xC0084713 || Inout || 4</br>[S2] 8 || [[#NVGPU_GPU_IOCTL_VSMS_MAPPING|NVGPU_GPU_IOCTL_VSMS_MAPPING]]
|-
| 0x80084714 || Out || 8 || [[#NVGPU_GPU_IOCTL_ZBC_GET_ACTIVE_SLOT_MASK|NVGPU_GPU_IOCTL_ZBC_GET_ACTIVE_SLOT_MASK]]
|-
| 0x80044715 || Out || 4 || [[#NVGPU_GPU_IOCTL_PMU_GET_GPU_LOAD|NVGPU_GPU_IOCTL_PMU_GET_GPU_LOAD]]
|-
| 0x40084716 || In || 8 || [[#NVGPU_GPU_IOCTL_SET_CG_CONTROLS|NVGPU_GPU_IOCTL_SET_CG_CONTROLS]]
|-
| 0xC0084717 || Inout || 8 || [[#NVGPU_GPU_IOCTL_GET_CG_CONTROLS|NVGPU_GPU_IOCTL_GET_CG_CONTROLS]]
|-
| 0x40084718 || In || 8 || [[#NVGPU_GPU_IOCTL_SET_PG_CONTROLS|NVGPU_GPU_IOCTL_SET_PG_CONTROLS]]
|-
| 0xC0084719 || Inout || 8 || [[#NVGPU_GPU_IOCTL_GET_PG_CONTROLS|NVGPU_GPU_IOCTL_GET_PG_CONTROLS]]
|-
| 0x8018471A || Out || 24 || [[#NVGPU_GPU_IOCTL_PMU_GET_ELPG_RESIDENCY_GATING|NVGPU_GPU_IOCTL_PMU_GET_ELPG_RESIDENCY_GATING]]
|-
| 0xC008471B || Inout || 8 || [[#NVGPU_GPU_IOCTL_GET_ERROR_CHANNEL_USER_DATA|NVGPU_GPU_IOCTL_GET_ERROR_CHANNEL_USER_DATA]]
|-
| 0xC010471C || Inout || 16 || [[#NVGPU_GPU_IOCTL_GET_GPU_TIME|NVGPU_GPU_IOCTL_GET_GPU_TIME]]
|-
| 0xC108471D || Inout || 264 || [[#NVGPU_GPU_IOCTL_GET_CPU_TIME_CORRELATION_INFO|NVGPU_GPU_IOCTL_GET_CPU_TIME_CORRELATION_INFO]]
|-
| 0xC010471E || Inout || 16 || [S2] [[#NVGPU_GPU_IOCTL_SET_DETERMINISTIC_OPTS|NVGPU_GPU_IOCTL_SET_DETERMINISTIC_OPTS]]
|-
| 0xC010471F || Inout || 16 || [S2] [[#NVGPU_GPU_IOCTL_GET_ENGINE_INFO|NVGPU_GPU_IOCTL_GET_ENGINE_INFO]]
|}
 
=== NVGPU_GPU_IOCTL_ZCULL_GET_CTX_SIZE ===
Returns the GPU's ZCULL context size. Identical to Linux driver.


   struct {
   struct {
     __in u32 num_entries;
     __out u32 size;
    __in u32 flags;
   };
   };


=== NVGPU_IOCTL_CHANNEL_WAIT ===
=== NVGPU_GPU_IOCTL_ZCULL_GET_INFO ===
Waits on channel. Identical to Linux driver.
Returns GPU's ZCULL information. Identical to Linux driver.


   struct {
   struct {
     __in u32 type;           // wait type (0=notifier, 1=semaphore)
     __out u32 width_align_pixels;
     __in u32 timeout;         // wait timeout value
     __out u32 height_align_pixels;
     __in u32 dmabuf_fd;       // nvmap handle
     __out u32 pixel_squares_by_aliquots;
     __in u32 offset;         // nvmap memory offset
     __out u32 aliquot_total;
     __in u32 payload;         // payload data (semaphore only)
     __out u32 region_byte_multiplier;
     __in u32 padding;         // ignored
     __out u32 region_header_size;
    __out u32 subregion_header_size;
    __out u32 subregion_width_align_pixels;
    __out u32 subregion_height_align_pixels;
    __out u32 subregion_count;
   };
   };


=== NVGPU_IOCTL_CHANNEL_CYCLE_STATS ===
=== NVGPU_GPU_IOCTL_ZBC_SET_TABLE ===
Maps memory for the cycle stats buffer. Identical to Linux driver.
Sets the active ZBC table. Identical to Linux driver.


   struct {
   struct {
     __in u32 dmabuf_fd;   // nvmap handle
     __in u32 color_ds[4];
    __in u32 color_l2[4];
    __in u32 depth;
    __in u32 format;
    __in u32 type;        // 1=color, 2=depth
   };
   };


=== NVGPU_IOCTL_CHANNEL_SUBMIT_GPFIFO ===
=== NVGPU_GPU_IOCTL_ZBC_QUERY_TABLE ===
Submits a gpfifo object. Modified to take inline entry objects instead of a pointer.
Queries the active ZBC table. Identical to Linux driver.


  struct fence {
    u32 id;
    u32 thresh;
  };
 
  struct gpfifo_entry {
    u64 entry;                              // gpu_iova | (unk_2bits << 40) | (size << 42) | (unk_flag << 63)
  };
 
   struct {
   struct {
     __in    u64 gpfifo;                     // (ignored) pointer to gpfifo fence structs
     __out u32 color_ds[4];
     __in    u32 num_entries;                 // number of fence objects being submitted
    __out u32 color_l2[4];
     __in    u32 flags;
     __out u32 depth;
     __inout struct fence fence_out;         // returned new fence object for others to wait on
     __out u32 ref_cnt;
     __in    struct gpfifo_entry entries[];   // depends on num_entries
     __out u32 format;
    __out u32 type;
     __inout u32 index_size;
   };
   };


=== NVGPU_IOCTL_CHANNEL_ALLOC_OBJ_CTX ===
=== NVGPU_GPU_IOCTL_GET_CHARACTERISTICS ===
Allocates a graphics context object. Modified to ignore object's ID.
Returns the GPU characteristics. Modified to return inline data instead of using a pointer.


You can only have one object context allocated at a time. You must have bound an address space before using this.
[3.0.0+] Uses either [[#Ioctl|Ioctl]] or [[#Ioctl3|Ioctl3]].


   struct {
   struct gpu_characteristics {
     __in  u32 class_num;   // 0x902D=2d, 0xB197=3d, 0xB1C0=compute, 0xA140=kepler, 0xB0B5=DMA, 0xB06F=channel_gpfifo
     u32 arch;                         // 0x120 (NVGPU_GPU_ARCH_GM200)
     __in  u32 flags;       // bit0: LOCKBOOST_ZERO
    u32 impl;                        // 0xB (NVGPU_GPU_IMPL_GM20B) or 0xE (NVGPU_GPU_IMPL_GM20B_B)
     __out u64 obj_id;       // (ignored) used for FREE_OBJ_CTX ioctl, which is not supported
    u32 rev;                          // 0xA1 (Revision A1)
    u32 num_gpc;                      // 0x1
    u64 l2_cache_size;                // 0x40000
    u64 on_board_video_memory_size;  // 0x0 (not used)
    u32 num_tpc_per_gpc;              // 0x2
    u32 bus_type;                    // 0x20 (NVGPU_GPU_BUS_TYPE_AXI)
    u32 big_page_size;                // 0x20000
    u32 compression_page_size;        // 0x20000
    u32 pde_coverage_bit_count;      // 0x1B
    u32 available_big_page_sizes;    // 0x30000
    u32 gpc_mask;                    // 0x1
    u32 sm_arch_sm_version;          // 0x503 (Maxwell Generation 5.0.3)
    u32 sm_arch_spa_version;          // 0x503 (Maxwell Generation 5.0.3)
    u32 sm_arch_warp_count;          // 0x80
    u32 gpu_va_bit_count;            // 0x28
    u32 reserved;                    // 0x0
    u64 flags;                        // 0x55 (HAS_SYNCPOINTS | SUPPORT_SPARSE_ALLOCS | SUPPORT_CYCLE_STATS | SUPPORT_CYCLE_STATS_SNAPSHOT)
    u32 twod_class;                  // 0x902D (FERMI_TWOD_A)
    u32 threed_class;                // 0xB197 (MAXWELL_B)
    u32 compute_class;                // 0xB1C0 (MAXWELL_COMPUTE_B)
    u32 gpfifo_class;                // 0xB06F (MAXWELL_CHANNEL_GPFIFO_A)
    u32 inline_to_memory_class;      // 0xA140 (KEPLER_INLINE_TO_MEMORY_B)
    u32 dma_copy_class;              // 0xB0B5 (MAXWELL_DMA_COPY_A)
    u32 max_fbps_count;              // 0x1
    u32 fbp_en_mask;                  // 0x0 (disabled)
    u32 max_ltc_per_fbp;              // 0x2
    u32 max_lts_per_ltc;              // 0x1
    u32 max_tex_per_tpc;              // 0x0 (not supported)
    u32 max_gpc_count;                // 0x1
    u32 rop_l2_en_mask_0;            // 0x21D70 (fuse_status_opt_rop_l2_fbp_r)
     u32 rop_l2_en_mask_1;             // 0x0
     u64 chipname;                     // 0x6230326D67 ("gm20b")
    u64 gr_compbit_store_base_hw;    // 0x0 (not supported)
   };
   };
 
=== NVHOST_IOCTL_CHANNEL_FREE_OBJ_CTX ===
Frees a graphics context object. Not supported.
 
   struct {
   struct {
     __in u64 obj_id;       // ignored
    __inout u64 gpu_characteristics_buf_size;  // must not be NULL, but gets overwritten with 0xA0=max_size
     __in   u64 gpu_characteristics_buf_addr;   // ignored, but must not be NULL
    __out struct gpu_characteristics gc;
   };
   };


=== NVGPU_IOCTL_CHANNEL_ZCULL_BIND ===
[S2] Uses [[#Ioctl3|Ioctl3]].
Binds a ZCULL context to the channel. Identical to Linux driver.


struct {
  struct gpu_characteristics {
     __in u64 gpu_va;
     u32 arch;                        // 0x170
     __in u32 mode;         // 0=global, 1=no_ctxsw, 2=separate_buffer, 3=part_of_regular_buf
    u32 impl;                        // 0xE
     __in u32 reserved;
    u32 rev;                          // 0xA1 (Revision A1)
    u32 num_gpc;                      // 0x1
    u64 l2_cache_size;                // 0x100000
    u64 on_board_video_memory_size;  // 0x0 (not used)
    u32 num_tpc_per_gpc;              // 0x6
    u32 bus_type;                    // 0x20 (NVGPU_GPU_BUS_TYPE_AXI)
    u32 big_page_size;                // 0x0
    u32 compression_page_size;        // 0x10000
    u32 pde_coverage_bit_count;      // 0x15
    u32 available_big_page_sizes;    // 0x0
    u32 gpc_mask;                    // 0x1
    u32 sm_arch_sm_version;          // 0x808
    u32 sm_arch_spa_version;          // 0x806
    u32 sm_arch_warp_count;          // 0x60
    u32 gpu_va_bit_count;            // 0x28
    u32 reserved;                    // 0x0
    u64 flags;                        // 0x935FAF1EDC0155
    u32 twod_class;                  // 0x902D (FERMI_TWOD_A)
    u32 threed_class;                // 0xC797 (AMPERE_B)
    u32 compute_class;                // 0xC7C0 (AMPERE_COMPUTE_B)
    u32 gpfifo_class;                // 0xC76F (AMPERE_CHANNEL_GPFIFO_B)
    u32 inline_to_memory_class;      // 0xA140 (KEPLER_INLINE_TO_MEMORY_B)
    u32 dma_copy_class;              // 0xC7B5 (AMPERE_DMA_COPY_B)
    s16 gpu_ioctl_nr_last;            // 0x1F
    s16 tsg_ioctl_nr_last;            // 0xF
    s16 dbg_gpu_ioctl_nr_last;        // 0x2B
    s16 ioctl_channel_nr_last;        // 0x21
    s16 as_ioctl_nr_last;            // 0xD
    s16 unk0_ioctl_nr_last;          // 0xFFFF
    s16 unk1_ioctl_nr_last;          // 0xFFFF
    s16 unk2_ioctl_nr_last;          // 0xFFFF
    u32 max_fbps_count;              // 0x0
    u32 fbp_en_mask;                  // 0x1
    u32 emc_en_mask;                  // 0x1
    u32 max_ltc_per_fbp;              // 0x1
    u32 max_lts_per_ltc;              // 0x4
    u32 max_tex_per_tpc;              // 0x0
    u32 max_gpc_count;                // 0x1
    u32 rop_l2_en_mask_DEPRECATED_0;  // 0x0
    u32 rop_l2_en_mask_DEPRECATED_1;  // 0x0
    u64 chipname;                    // 0x6761313066 ("ga10f")
    u32 unk0;                        // 0x0
    u32 unk1;                        // 0x2
    u32 unk2;                         // 0x40
    u32 unk3;                        // 0x3
    u32 unk4;                        // 0x7
    u32 unk5;                        // 0x1
    u32 unk6;                        // 0x1
    u32 unk7;                        // 0x0
    u32 unk8;                        // 0x0
  };
 
  struct in_buf {
     __in u64 gpu_characteristics_buf_size;   // must not be NULL, but gets overwritten with 0xD0=max_size
     __in u8 reserved[0xD8];
  };
 
  struct out_buf {
    __out u8 reserved[0xE0];
  };
 
  struct out_buf2 {
    __out struct gpu_characteristics gc;
   };
   };


=== NVGPU_IOCTL_CHANNEL_SET_ERROR_NOTIFIER ===
=== NVGPU_GPU_IOCTL_GET_TPC_MASKS ===
Initializes the error notifier for this channel. Unlike for the Linux kernel, the Switch driver cannot write to an arbitrary userspace buffer. Thus new ioctls have been introduced to fetch the error information rather than using a shared memory buffer.
Returns the TPC mask value for each GPC. Modified to return inline data instead of using a pointer.
 
[3.0.0+] Uses either [[#Ioctl|Ioctl]] or [[#Ioctl3|Ioctl3]].


   struct {
   struct {
     __in u64 offset;   // ignored
     __in u32 mask_buf_size;       // ignored, but must not be NULL
     __in u64 size;     // ignored
     __inout u32 reserved[3];
     __in u32 mem;     // must be non-zero to initialize, zero to de-initialize
     __out u64 mask_buf;           // receives one 32-bit TPC mask per GPC (GPC 0 and GPC 1)
    __in u32 reserved; // ignored
   };
   };


=== NVGPU_IOCTL_CHANNEL_SET_PRIORITY ===
=== NVGPU_GPU_IOCTL_FLUSH_L2 ===
Changes channel's priority. Identical to Linux driver.
Flushes the GPU L2 cache.


   struct {
   struct {
     __in u32 priority;   // 0x32 is low, 0x64 is medium and 0x96 is high
     __in u32 flush;         // l2_flush | l2_invalidate << 1 | fb_flush << 2
    __in u32 reserved;
   };
   };


=== NVGPU_IOCTL_CHANNEL_ENABLE ===
=== NVGPU_GPU_IOCTL_INVAL_ICACHE ===
Enables the current channel. Identical to Linux driver.
Invalidates the GPU instruction cache. Identical to Linux driver.


=== NVGPU_IOCTL_CHANNEL_DISABLE ===
  struct {
Disables the current channel. Identical to Linux driver.
    __in s32 channel_fd;
    __in u32 reserved;
  };


=== NVGPU_IOCTL_CHANNEL_PREEMPT ===
=== NVGPU_GPU_IOCTL_SET_MMU_DEBUG_MODE ===
Clears the FIFO pipe for this channel. Identical to Linux driver.
Sets the GPU MMU debug mode. Identical to Linux driver.
 
=== NVGPU_IOCTL_CHANNEL_FORCE_RESET ===
Forces the channel to reset. Identical to Linux driver.
 
=== NVGPU_IOCTL_CHANNEL_EVENT_ID_CONTROL ===
Controls event notifications.


   struct {
   struct {
     __in u32 cmd;   // 0=disable, 1=enable, 2=clear
     __in u32 state;
     __in u32 id;     // same id's as for [[#QueryEvent]]
     __in u32 reserved;
   };
   };


=== NVGPU_IOCTL_CHANNEL_CYCLE_STATS_SNAPSHOT ===
=== NVGPU_GPU_IOCTL_SET_SM_DEBUG_MODE ===
Controls the cycle stats snapshot buffer. Identical to Linux driver.
Sets the GPU SM debug mode. Identical to Linux driver.


   struct {
   struct {
     __in   u32 cmd;         // command to handle (0=flush, 1=attach, 2=detach)
     __in s32 channel_fd;
     __in   u32 dmabuf_fd;   // nvmap handle
     __in u32 enable;
    __inout u32 extra;      // extra payload data/result
     __in u64 sms;
     __in   u32 padding;     // ignored
   };
   };


=== NVGPU_IOCTL_CHANNEL_GET_ERROR_INFO ===
=== NVGPU_GPU_IOCTL_WAIT_FOR_PAUSE ===
Returns information on the current error notification caught by the error notifier. Exclusive to the Switch.
Waits until all valid warps on the GPU SM are paused and returns their current state.


   struct {
   struct {
     __out u32 error_info[32];   // first word is an error code (0=no_error, 1=gr_error, 2=gr_error, 3=invalid, 4=invalid)
     __in u64 pwarpstate;
   };
   };


=== NVGPU_IOCTL_CHANNEL_GET_ERROR_NOTIFICATION ===
[6.1.0+] This command was modified to return inline data instead of using a pointer.
Returns the current error notification caught by the error notifier. Exclusive to the Switch.


   struct {
   struct {
     __out u64 timestamp;   // fetched straight from armGetSystemTick
     __out u64 sm0_valid_warps;
     __out u32 info32;       // error code
     __out u64 sm0_trapped_warps;
     __out u16 info16;       // additional error info
     __out u64 sm0_paused_warps;
     __out u16 status;       // always 0xFFFF
     __out u64 sm1_valid_warps;
    __out u64 sm1_trapped_warps;
    __out u64 sm1_paused_warps;
   };
   };


=== NVGPU_IOCTL_CHANNEL_ALLOC_GPFIFO_EX ===
=== NVGPU_GPU_IOCTL_GET_TPC_EXCEPTION_EN_STATUS ===
Allocates gpfifo entries with additional parameters. Exclusive to the Switch.
Returns a mask value describing all active TPC exceptions. Identical to Linux driver.


struct fence {
  struct {
     u32 id;
     __out u64 tpc_exception_en_sm_mask;
    u32 thresh;
   };
};
struct {
  __in    u32 num_entries;
  __in    u32 num_jobs;
  __in    u32 flags;
  __out   struct fence fence_out;          // returned new fence object for others to wait on
  __in    u32 reserved[3];                // ignored
};


=== NVGPU_IOCTL_CHANNEL_SUBMIT_GPFIFO_RETRY ===
=== NVGPU_GPU_IOCTL_NUM_VSMS ===
Same as [[#NVGPU_IOCTL_CHANNEL_SUBMIT_GPFIFO|NVGPU_IOCTL_CHANNEL_SUBMIT_GPFIFO]].
Returns the number of GPU SM units present. Identical to Linux driver.


=== NVGPU_IOCTL_CHANNEL_ALLOC_GPFIFO_EX2 ===
  struct {
Same as [[#NVGPU_IOCTL_CHANNEL_ALLOC_GPFIFO_EX|NVGPU_IOCTL_CHANNEL_ALLOC_GPFIFO_EX]].
    __out u32 num_vsms;
    __out u32 reserved;
  };


=== NVGPU_IOCTL_CHANNEL_SUBMIT_GPFIFO_EX ===
=== NVGPU_GPU_IOCTL_VSMS_MAPPING ===
Same as [[#NVGPU_IOCTL_CHANNEL_SUBMIT_GPFIFO|NVGPU_IOCTL_CHANNEL_SUBMIT_GPFIFO]], but uses [[#Ioctl2|Ioctl2]].
Returns mapping information on each GPU SM unit. Modified to return inline data instead of using a pointer.
 
=== NVGPU_IOCTL_CHANNEL_SUBMIT_GPFIFO_RETRY_EX ===
Same as [[#NVGPU_IOCTL_CHANNEL_SUBMIT_GPFIFO_RETRY|NVGPU_IOCTL_CHANNEL_SUBMIT_GPFIFO_RETRY]], but uses [[#Ioctl2|Ioctl2]].
 
=== NVGPU_IOCTL_CHANNEL_SET_TIMESLICE ===
Changes channel's timeslice. Identical to Linux driver.


   struct {
   struct {
     __in u32 timeslice;
     __out u8 sm0_gpc_index;
    __out u8 sm0_tpc_index;
    __out u8 sm1_gpc_index;
    __out u8 sm1_tpc_index;
   };
   };


=== NVGPU_IOCTL_CHANNEL_SET_USER_DATA ===
=== NVGPU_GPU_IOCTL_ZBC_GET_ACTIVE_SLOT_MASK ===
Sets user specific data.
Returns the mask value for a ZBC slot.


   struct {
   struct {
     __in u64 data;
     __out u32 slot;      // always 0x07
    __out u32 mask;
   };
   };


=== NVGPU_IOCTL_CHANNEL_GET_USER_DATA ===
=== NVGPU_GPU_IOCTL_PMU_GET_GPU_LOAD ===
Returns user specific data.
Returns the GPU load value from the PMU.


   struct {
   struct {
     __out u64 data;
     __out u32 pmu_gpu_load;
   };
   };


= nvmemp =
=== NVGPU_GPU_IOCTL_SET_CG_CONTROLS ===
This is "nv::MemoryProfiler::IMemoryProfiler".
Sets the clock gate control value.
 
  struct {
    __in u32 cg_mask;
    __in u32 cg_value;
  };


/dev/nvhost-ctrl sends the ioctl NVHOST_IOCTL_CTRL_GET_CONFIG to check the config "nv!NV_MEMORY_PROFILER". If config_str returns "1", the application attempts to use nvmemp.
=== NVGPU_GPU_IOCTL_GET_CG_CONTROLS ===
Returns the clock gate control value.


{| class="wikitable" border="1"
  struct {
|-
    __in u32 cg_mask;
! Cmd || Name
    __out u32 cg_value;
|-
  };
| 0 || Open
|-
| 1 || GetPid
|}


= nvdrvdbg =
=== NVGPU_GPU_IOCTL_SET_PG_CONTROLS ===
This is "nns::nvdrv::INvDrvDebugFSServices".
Sets the power gate control value.


{| class="wikitable" border="1"
  struct {
|-
    __in u32 pg_mask;
! Cmd || Name
    __in u32 pg_value;
|-
  };
| 0 || [[#OpenDebugFS]]
|-
| 1 || [[#CloseDebugFS]]
|-
| 2 || [[#GetDebugFSKeys]]
|-
| 3 || GetDebugFSValue
|-
| 4 || SetDebugFSValue
|}


== OpenDebugFS ==
=== NVGPU_GPU_IOCTL_GET_PG_CONTROLS ===
Takes a process handle. Returns a u32 '''fd'''.
Returns the power gate control value.


== CloseDebugFS ==
  struct {
Takes a u32 '''fd''' and closes it.
    __in u32 pg_mask;
    __out u32 pg_value;
  };


== GetDebugFSKeys ==
=== NVGPU_GPU_IOCTL_PMU_GET_ELPG_RESIDENCY_GATING ===
Takes a u32 '''fd''' and reads debug contents into a type-6 buffer.
Returns the GPU PMU ELPG residency gating values.
 
  struct {
    __out u64 pg_ingating_time_us;
    __out u64 pg_ungating_time_us;
    __out u64 pg_gating_cnt;
  };


= nvgem:c =
=== NVGPU_GPU_IOCTL_GET_ERROR_CHANNEL_USER_DATA ===
This is "nv::gemcontrol::INvGemControl".
Returns user specific data from the error channel, if one exists.


{| class="wikitable" border="1"
  struct {
|-
    __out u64 data;
! Cmd || Name
  };
|-
 
| 0 || Initialize
=== NVGPU_GPU_IOCTL_GET_GPU_TIME ===
|-
Returns the timestamp from the GPU's nanosecond timer (PTIMER). Identical to Linux driver.
| 1 || GetEventHandle
|-
| 2 || ControlNotification
|-
| 3 || SetNotificationPerm
|-
| 4 || SetCoreDumpPerm
|-
| 5 || [1.0.0-4.1.0] GetAruid
|-
| 6 || Reset
|-
| 7 || [3.0.0+]
|}


= nvgem:cd =
  struct {
This is "nv::gemcoredump::INvGemCoreDump".
    __out u64 gpu_timestamp;      // raw GPU counter (PTIMER) value
    __out u64 reserved;
  };


{| class="wikitable" border="1"
=== NVGPU_GPU_IOCTL_GET_CPU_TIME_CORRELATION_INFO ===
|-
Returns CPU/GPU timestamp pairs for correlation analysis. Identical to Linux driver.
! Cmd || Name
 
|-
  struct time_correlation_sample {
| 0 || Initialize
    u64 cpu_timestamp;                                  // from CPU's CNTPCT_EL0 register
|-
    u64 gpu_timestamp;                                  // from GPU's PTIMER registers
| 1 || GetAruid
  };
|-
| 2 || [1.0.0-8.1.0] ReadNextBlock
  struct {
|-
    __out struct time_correlation_sample samples[16];  // timestamp pairs
| 3 || [8.0.0+]
    __in u32    count;                                // number of pairs to read
|-
    __in u32    source_id;                            // cpu clock source id (must be 1)
| 4 || [8.0.0+]
  };
|}
 
 
=== NVGPU_GPU_IOCTL_SET_DETERMINISTIC_OPTS ===
= nvdbg:d =
Adjusts options of deterministic channels in channel batches.
This is "nns::nvdrv::INvDrvDebugSvcServices". This was added with [10.0.0+].
 
 
Uses [[#Ioctl2|Ioctl2]].
This service has no commands.
 
 
  struct deterministic_opts {
= Errors =
    __inout u32 num_channels;
Most nvidia driver commands return an error code apart from the normal return code.
    __in u32 flags;
    __in u64 channels;                          // ignored
  };
 
  struct in_buf {
    __in struct deterministic_opts opts;
  };
 
  struct in_buf2 {
    __in u32 channels[num_channels];
  };
 
  struct out_buf {
    __out struct deterministic_opts opts;
  };
 
=== NVGPU_GPU_IOCTL_GET_ENGINE_INFO ===
Returns information on graphics engines.
 
Uses [[#Ioctl3|Ioctl3]].
 
  struct engine_info {
    __inout u32 engine_info_buf_size;
    __in u32 reserved;
    __in u64 engine_info_buf_addr;                    // ignored
  };
 
  struct engine_info_item {
    __out u32 engine_id;
    __out u32 engine_instance;
    __out s32 runlist_id;
    __out u32 reserved;
  };
 
  struct in_buf {
    __in struct engine_info info;
  };
 
  struct out_buf {
    __out struct engine_info info;   
  };
 
  struct out_buf2 {
    __out struct engine_info_item items[engine_info_buf_size];
  };
 
== (S2) /dev/nvhost-prof-dev-gpu ==                                                                                                         
{| class="wikitable" border="1"
! Value || Direction || Size || Description
|-
| 0x40085001 || In || 8 || NVGPU_PROFILER_IOCTL_BIND_CONTEXT
|-
| 0x40105002 || In || 16 || NVGPU_PROFILER_IOCTL_RESERVE_PM_RESOURCE
|-
| 0x40085003 || In || 8 || NVGPU_PROFILER_IOCTL_RELEASE_PM_RESOURCE
|-
| 0xC0305004 || Inout || 48 || NVGPU_PROFILER_IOCTL_ALLOC_PMA_STREAM
|-
| 0x00005005 || None || 0 || NVGPU_PROFILER_IOCTL_FREE_PMA_STREAM
|-
| 0x00005006 || None || 0 || NVGPU_PROFILER_IOCTL_BIND_PM_RESOURCES
|-
| 0x00005007 || None || 0 || NVGPU_PROFILER_IOCTL_UNBIND_PM_RESOURCES
|-
| 0xC0285008 || Inout || 40 || NVGPU_PROFILER_IOCTL_PMA_STREAM_UPDATE_GET_PUT
|-
| 0xC0205009 || Inout || 32 || NVGPU_PROFILER_IOCTL_EXEC_REG_OPS
|-
| 0x0000500A || None || 0 || NVGPU_PROFILER_IOCTL_UNBIND_CONTEXT
|-
| 0x4010500B || In || 16 || NVGPU_PROFILER_IOCTL_VAB_RESERVE
|-
| 0x0000500C || None || 0 || NVGPU_PROFILER_IOCTL_VAB_RELEASE
|-
| 0x4010500D || In || 16 || NVGPU_PROFILER_IOCTL_VAB_FLUSH_STATE
|}
 
== (S2) /dev/nvhost-tsg-gpu ==                                                                                   
{| class="wikitable" border="1"
! Value || Direction || Size || Description
|-
| 0xC0045401 || Inout || 4 || [[#NVGPU_TSG_IOCTL_BIND_CHANNEL|NVGPU_TSG_IOCTL_BIND_CHANNEL]]
|-
| 0xC0045402 || Inout || 4 || [[#NVGPU_TSG_IOCTL_UNBIND_CHANNEL|NVGPU_TSG_IOCTL_UNBIND_CHANNEL]]
|-
| 0x00005403 || None || 0 || [[#NVGPU_TSG_IOCTL_ENABLE|NVGPU_TSG_IOCTL_ENABLE]]
|-
| 0x00005404 || None || 0 || [[#NVGPU_TSG_IOCTL_DISABLE|NVGPU_TSG_IOCTL_DISABLE]]
|-
| 0x00005405 || None || 0 || [[#NVGPU_TSG_IOCTL_PREEMPT|NVGPU_TSG_IOCTL_PREEMPT]]
|-
| 0xC0085407 || Inout || 8 || [[#NVGPU_TSG_IOCTL_SET_RUNLIST_INTERLEAVE|NVGPU_TSG_IOCTL_SET_RUNLIST_INTERLEAVE]]
|-
| 0xC0045408 || Inout || 4 || [[#NVGPU_TSG_IOCTL_SET_TIMESLICE|NVGPU_TSG_IOCTL_SET_TIMESLICE]]
|-
| 0xC0105409 || Inout || 16 || [[#NVGPU_TSG_IOCTL_EVENT_ID_CTRL|NVGPU_TSG_IOCTL_EVENT_ID_CTRL]]
|-
| 0x8004540A || Out || 4 || [[#NVGPU_TSG_IOCTL_GET_TIMESLICE|NVGPU_TSG_IOCTL_GET_TIMESLICE]]
|-
| 0xC018540B || Inout || 24 || [[#NVGPU_TSG_IOCTL_BIND_CHANNEL_EX|NVGPU_TSG_IOCTL_BIND_CHANNEL_EX]]
|-
| 0xC018540C || Inout || 24 || [[#NVGPU_TSG_IOCTL_READ_SINGLE_SM_ERROR_STATE|NVGPU_TSG_IOCTL_READ_SINGLE_SM_ERROR_STATE]]
|-
| 0xC008540D || Inout || 8 || [[#NVGPU_TSG_IOCTL_SET_L2_SECTOR_PROMOTION|NVGPU_TSG_IOCTL_SET_L2_SECTOR_PROMOTION]]
|}
 
=== NVGPU_TSG_IOCTL_BIND_CHANNEL ===
Binds a channel to the TSG.
 
  struct {
    __in s32 channel_fd;
  };
 
=== NVGPU_TSG_IOCTL_UNBIND_CHANNEL ===
Unbinds a channel from the TSG.
 
  struct {
    __in s32 channel_fd;
  };
 
=== NVGPU_TSG_IOCTL_ENABLE ===
Enables the TSG in runlist.
 
=== NVGPU_TSG_IOCTL_DISABLE ===
Disables the TSG in runlist.
 
=== NVGPU_TSG_IOCTL_PREEMPT ===
Preempts the TSG.
 
=== NVGPU_TSG_IOCTL_SET_RUNLIST_INTERLEAVE ===
Configures interleaving channels in a runlist.
 
  struct {
    __in u32 level;
    __in u32 reserved;
  };
 
=== NVGPU_TSG_IOCTL_SET_TIMESLICE ===
Sets how long a channel occupies an engine uninterrupted.
 
  struct {
    __in u32 timeslice_us;
  };
 
=== NVGPU_TSG_IOCTL_EVENT_ID_CTRL ===
Controls event notifications.
 
  struct {
    __in u32 cmd;
    __in u32 event_id;
    __out s32 event_fd;
    __in u32 padding;
  };
 
=== NVGPU_TSG_IOCTL_GET_TIMESLICE ===
Gets how long a channel occupies an engine uninterrupted.
 
  struct {
    __out u32 timeslice_us;
  };
 
=== NVGPU_TSG_IOCTL_BIND_CHANNEL_EX ===
Binds a channel to the TSG of the node receiving the command.
 
  struct {
    __in s32 channel_fd;
    __in u32 subcontext_id;
    __in u32 reserved[4];
  };
 
=== NVGPU_TSG_IOCTL_READ_SINGLE_SM_ERROR_STATE ===
Reads the error state of a single SM.
 
Uses [[#Ioctl3|Ioctl3]].
 
  struct single_sm_error_state {
    __in u32 sm_id;
    __inout u32 reserved;
    __inout u64 record_mem;
    __in u64 record_size;
  };
 
  struct in_buf {
    __in struct single_sm_error_state state;
  };
 
  struct out_buf {
    __out struct single_sm_error_state state;
  };
 
  struct out_buf2 {
    __out u8 state[];
  };
 
=== NVGPU_TSG_IOCTL_SET_L2_SECTOR_PROMOTION ===
Configures L2 sector promotion.
 
  struct {
    __in u32 promotion_flag;
    __in u32 reserved;
  };
 
= Channels =
Channels are a concept for NVIDIA hardware blocks that share a common interface.
 
{| class="wikitable" border="1"
! Path || Name
|-
| /dev/nvhost-gpu || GPU
|-
| /dev/nvhost-msenc || Video Encoder
|-
| /dev/nvhost-nvdec || Video Decoder
|-
| /dev/nvhost-nvjpg || JPEG Decoder
|-
| /dev/nvhost-vic || Video Image Compositor
|-
| /dev/nvhost-display || Display
|-
| /dev/nvhost-tsec || TSEC
|}
 
== Ioctls ==
{| class="wikitable" border="1"
! Value || Direction || Size || Description
|-
| 0xC0??0001 || Inout || Variable || [[#NVHOST_IOCTL_CHANNEL_SUBMIT|NVHOST_IOCTL_CHANNEL_SUBMIT]]
|-
| 0xC0080002 || Inout || 8 || [[#NVHOST_IOCTL_CHANNEL_GET_SYNCPOINT|NVHOST_IOCTL_CHANNEL_GET_SYNCPOINT]]
|-
| 0xC0080003 || Inout || 8 || [[#NVHOST_IOCTL_CHANNEL_GET_WAITBASE|NVHOST_IOCTL_CHANNEL_GET_WAITBASE]]
|-
| 0xC0080004 || Inout || 8 || [[#NVHOST_IOCTL_CHANNEL_GET_MODMUTEX|NVHOST_IOCTL_CHANNEL_GET_MODMUTEX]]
|-
| 0x40040007 || In || 4 || [[#NVHOST_IOCTL_CHANNEL_SET_SUBMIT_TIMEOUT|NVHOST_IOCTL_CHANNEL_SET_SUBMIT_TIMEOUT]]
|-
| 0x40080008 || In || 8 || [[#NVHOST_IOCTL_CHANNEL_SET_CLK_RATE|NVHOST_IOCTL_CHANNEL_SET_CLK_RATE]]
|-
| 0xC0??0009 || Inout || Variable || [[#NVHOST_IOCTL_CHANNEL_MAP_CMD_BUFFER|NVHOST_IOCTL_CHANNEL_MAP_CMD_BUFFER]]
|-
| 0xC0??000A || Inout || Variable || [[#NVHOST_IOCTL_CHANNEL_UNMAP_CMD_BUFFER|NVHOST_IOCTL_CHANNEL_UNMAP_CMD_BUFFER]]
|-
| 0x00000013 || None || 0 || [[#NVHOST_IOCTL_CHANNEL_SET_TIMEOUT_EX|NVHOST_IOCTL_CHANNEL_SET_TIMEOUT_EX]]
|-
| 0xC0080023</br>([1.0.0-7.0.1] 0xC0080014) || Inout || 8 || [[#NVHOST_IOCTL_CHANNEL_GET_CLK_RATE|NVHOST_IOCTL_CHANNEL_GET_CLK_RATE]]
|-
| 0xC0??0024 || Inout || Variable || [[#NVHOST_IOCTL_CHANNEL_SUBMIT_EX|NVHOST_IOCTL_CHANNEL_SUBMIT_EX]]
|-
| 0xC0??0025 || Inout || Variable || [[#NVHOST_IOCTL_CHANNEL_MAP_CMD_BUFFER_EX|NVHOST_IOCTL_CHANNEL_MAP_CMD_BUFFER_EX]]
|-
| 0xC0??0026 || Inout || Variable || [[#NVHOST_IOCTL_CHANNEL_UNMAP_CMD_BUFFER_EX|NVHOST_IOCTL_CHANNEL_UNMAP_CMD_BUFFER_EX]]
|- style="border-top: double"
| 0x40044801 || In || 4 || [[#NVGPU_IOCTL_CHANNEL_SET_NVMAP_FD|NVGPU_IOCTL_CHANNEL_SET_NVMAP_FD]]
|-
| 0x40044803 || In || 4 || [[#NVGPU_IOCTL_CHANNEL_SET_TIMEOUT|NVGPU_IOCTL_CHANNEL_SET_TIMEOUT]]
|-
| 0x40084805 || In || 8 || [[#NVGPU_IOCTL_CHANNEL_ALLOC_GPFIFO|NVGPU_IOCTL_CHANNEL_ALLOC_GPFIFO]]
|-
| 0x40184806 || In || 24 || [[#NVGPU_IOCTL_CHANNEL_WAIT|NVGPU_IOCTL_CHANNEL_WAIT]]
|-
| 0xC0044807 || Inout || 4 || [[#NVGPU_IOCTL_CHANNEL_CYCLE_STATS|NVGPU_IOCTL_CHANNEL_CYCLE_STATS]]
|-
| 0xC0??4808 || Inout || Variable || [[#NVGPU_IOCTL_CHANNEL_SUBMIT_GPFIFO|NVGPU_IOCTL_CHANNEL_SUBMIT_GPFIFO]]
|-
| 0xC0104809 || Inout || 16 || [[#NVGPU_IOCTL_CHANNEL_ALLOC_OBJ_CTX|NVGPU_IOCTL_CHANNEL_ALLOC_OBJ_CTX]]
|-
| 0x4008480A || In || 8 || [[#NVHOST_IOCTL_CHANNEL_FREE_OBJ_CTX|NVHOST_IOCTL_CHANNEL_FREE_OBJ_CTX]]
|-
| 0xC010480B || Inout || 16 || [[#NVGPU_IOCTL_CHANNEL_ZCULL_BIND|NVGPU_IOCTL_CHANNEL_ZCULL_BIND]]
|-
| 0xC018480C || Inout || 24 || [[#NVGPU_IOCTL_CHANNEL_SET_ERROR_NOTIFIER|NVGPU_IOCTL_CHANNEL_SET_ERROR_NOTIFIER]]
|-
| 0x4004480D || In || 4 || [[#NVGPU_IOCTL_CHANNEL_SET_PRIORITY|NVGPU_IOCTL_CHANNEL_SET_PRIORITY]]
|-
| 0x0000480E || None || 0 || [[#NVGPU_IOCTL_CHANNEL_ENABLE|NVGPU_IOCTL_CHANNEL_ENABLE]]
|-
| 0x0000480F || None || 0 || [[#NVGPU_IOCTL_CHANNEL_DISABLE|NVGPU_IOCTL_CHANNEL_DISABLE]]
|-
| 0x00004810 || None || 0 || [[#NVGPU_IOCTL_CHANNEL_PREEMPT|NVGPU_IOCTL_CHANNEL_PREEMPT]]
|-
| 0x00004811 || None ||  0 || [[#NVGPU_IOCTL_CHANNEL_FORCE_RESET|NVGPU_IOCTL_CHANNEL_FORCE_RESET]]
|-
| 0x40084812</br>[S2] 0x40104812 || In || 8</br>[S2] 16 || [[#NVGPU_IOCTL_CHANNEL_EVENT_ID_CONTROL|NVGPU_IOCTL_CHANNEL_EVENT_ID_CONTROL]]
|-
| 0xC0104813 || Inout || 16 || [[#NVGPU_IOCTL_CHANNEL_CYCLE_STATS_SNAPSHOT|NVGPU_IOCTL_CHANNEL_CYCLE_STATS_SNAPSHOT]]
|-
| 0x40084714 || In || 8 || [[#NVGPU_IOCTL_CHANNEL_SET_USER_DATA|NVGPU_IOCTL_CHANNEL_SET_USER_DATA]]
|-
| 0x80084715 || Out || 8 || [[#NVGPU_IOCTL_CHANNEL_GET_USER_DATA|NVGPU_IOCTL_CHANNEL_GET_USER_DATA]]
|-
| 0x80804816 || Out || 128 || [[#NVGPU_IOCTL_CHANNEL_GET_ERROR_INFO|NVGPU_IOCTL_CHANNEL_GET_ERROR_INFO]]
|-
| 0xC0104817 || Inout || 16 || [[#NVGPU_IOCTL_CHANNEL_GET_ERROR_NOTIFICATION|NVGPU_IOCTL_CHANNEL_GET_ERROR_NOTIFICATION]]
|-
| 0x40204818 || In || 32 || [[#NVGPU_IOCTL_CHANNEL_ALLOC_GPFIFO_EX|NVGPU_IOCTL_CHANNEL_ALLOC_GPFIFO_EX]]
|-
| 0xC0??4819 || Inout || Variable || [[#NVGPU_IOCTL_CHANNEL_SUBMIT_GPFIFO_RETRY|NVGPU_IOCTL_CHANNEL_SUBMIT_GPFIFO_RETRY]]
|-
| 0xC020481A || Inout || 32 || [[#NVGPU_IOCTL_CHANNEL_ALLOC_GPFIFO_EX2|NVGPU_IOCTL_CHANNEL_ALLOC_GPFIFO_EX2]]
|-
| 0xC018481B || Inout || 24 || [[#NVGPU_IOCTL_CHANNEL_SUBMIT_GPFIFO2|NVGPU_IOCTL_CHANNEL_SUBMIT_GPFIFO2]]
|-
| 0xC018481C || Inout || 24 || [[#NVGPU_IOCTL_CHANNEL_SUBMIT_GPFIFO2_RETRY|NVGPU_IOCTL_CHANNEL_SUBMIT_GPFIFO2_RETRY]]
|-
| 0xC004481D || Inout || 4 || [[#NVGPU_IOCTL_CHANNEL_SET_TIMESLICE|NVGPU_IOCTL_CHANNEL_SET_TIMESLICE]]
|-
| 0xC010481E || Inout || 16 || [S2] [[#NVGPU_IOCTL_CHANNEL_GET_USER_SYNCPOINT|NVGPU_IOCTL_CHANNEL_GET_USER_SYNCPOINT]]
|-
| 0xC008481F || Inout || 8 || [S2] [[#NVGPU_IOCTL_CHANNEL_SET_PREEMPTION_MODE|NVGPU_IOCTL_CHANNEL_SET_PREEMPTION_MODE]]
|-
| 0x40044820 || In || 4 || [S2] [[#NVGPU_IOCTL_CHANNEL_OPEN|NVGPU_IOCTL_CHANNEL_OPEN]]
|-
| 0xC0504821 || Inout || 80 || [S2] [[#NVGPU_IOCTL_CHANNEL_SETUP_BIND|NVGPU_IOCTL_CHANNEL_SETUP_BIND]]
|}
 
=== NVHOST_IOCTL_CHANNEL_SUBMIT ===
Submits data to the channel.
 
  struct cmdbuf {
    u32 mem;
    u32 offset;
    u32 words;
  };
 
  struct reloc {
    u32 cmdbuf_mem;
    u32 cmdbuf_offset;
    u32 target;
    u32 target_offset;
  };
 
  struct reloc_shift {
    u32 shift;
  };
 
  struct syncpt_incr {
    u32 syncpt_id;
    u32 syncpt_incrs;
    u32 reserved[3];
  };
 
  struct {
    __in    u32 num_cmdbufs;
    __in    u32 num_relocs;
    __in    u32 num_syncpt_incrs;
    __in    u32 num_fences;
    __in    struct cmdbuf cmdbufs[];              // depends on num_cmdbufs
    __in    struct reloc relocs[];                // depends on num_relocs
    __in    struct reloc_shift reloc_shifts[];    // depends on num_relocs
    __in    struct syncpt_incr syncpt_incrs[];    // depends on num_syncpt_incrs
    __out  u32 fence_thresholds[];                // depends on num_fences
  };
 
=== NVHOST_IOCTL_CHANNEL_GET_SYNCPOINT ===
Returns the current syncpoint value for a given module. Identical to Linux driver.
 
  struct {
    __in    u32 module_id;
    __out  u32 syncpt_value;
  };
 
=== NVHOST_IOCTL_CHANNEL_GET_WAITBASE ===
Returns the current waitbase value for a given module. Always returns 0.
 
  struct {
    __in    u32 module_id;
    __out  u32 waitbase_value;
  };
 
=== NVHOST_IOCTL_CHANNEL_GET_MODMUTEX ===
Stubbed. Does a debug print and returns 0.
 
=== NVHOST_IOCTL_CHANNEL_SET_SUBMIT_TIMEOUT ===
Sets the submit timeout value for the channel. Identical to Linux driver.
 
  struct {
    __in    u32 timeout;
  };
 
=== NVHOST_IOCTL_CHANNEL_SET_CLK_RATE ===
Sets the clock rate value for a given module. Identical to Linux driver.
 
  struct {
    __in    u32 clk_rate;
    __in    u32 module_id;
  };
 
=== NVHOST_IOCTL_CHANNEL_MAP_CMD_BUFFER ===
Uses '''nvmap_pin''' internally to pin a given number of nvmap handles to an appropriate device physical address.
 
  struct handle {
    u32 handle_id_in;                // nvmap handle to map
    u32 phys_addr_out;                // returned device physical address mapped to the handle
  };
 
  struct {
    __in    u32 num_handles;          // number of nvmap handles to map
    __in    u32 reserved;            // ignored
    __in    u8  is_compr;            // memory to map is compressed
    __in    u8  padding[3];          // ignored
    __inout struct handle handles[];  // depends on num_handles
  };
 
=== NVHOST_IOCTL_CHANNEL_UNMAP_CMD_BUFFER ===
Uses '''nvmap_unpin''' internally to unpin a given number of nvmap handles from their device physical address.
 
  struct handle {
    u32 handle_id_in;                // nvmap handle to unmap
    u32 reserved;                    // ignored
  };
 
  struct {
    __in    u32 num_handles;          // number of nvmap handles to unmap
    __in    u32 reserved;            // ignored
    __in    u8  is_compr;            // memory to unmap is compressed
    __in    u8  padding[3];          // ignored
    __inout struct handle handles[];  // depends on num_handles
  };
 
=== NVHOST_IOCTL_CHANNEL_SET_TIMEOUT_EX ===
Sets the global timeout value for the channel. Identical to Linux driver.
 
  struct {
    __in    u32 timeout;
    __in    u32 flags;
  };
 
=== NVHOST_IOCTL_CHANNEL_GET_CLK_RATE ===
Returns the clock rate value for a given module. Identical to Linux driver.
 
  struct {
    __out  u32 clk_rate;
    __in    u32 module_id;
  };
 
=== NVHOST_IOCTL_CHANNEL_SUBMIT_EX ===
Same as [[#NVHOST_IOCTL_CHANNEL_SUBMIT|NVHOST_IOCTL_CHANNEL_SUBMIT]].
 
=== NVHOST_IOCTL_CHANNEL_MAP_CMD_BUFFER_EX ===
Same as [[#NVHOST_IOCTL_CHANNEL_MAP_CMD_BUFFER|NVHOST_IOCTL_CHANNEL_MAP_CMD_BUFFER]], but calls '''nvmap_unpin''' internally in case of error.
 
=== NVHOST_IOCTL_CHANNEL_UNMAP_CMD_BUFFER_EX ===
Same as [[#NVHOST_IOCTL_CHANNEL_UNMAP_CMD_BUFFER|NVHOST_IOCTL_CHANNEL_UNMAP_CMD_BUFFER]].
 
=== NVGPU_IOCTL_CHANNEL_SET_NVMAP_FD ===
Binds a nvmap object to this channel. Identical to Linux driver.
 
  struct {
    __in u32 nvmap_fd;
  };
 
=== NVGPU_IOCTL_CHANNEL_SET_TIMEOUT ===
Sets the timeout value for the GPU channel. Identical to Linux driver.
 
  struct {
    __in u32 timeout;
  };
 
=== NVGPU_IOCTL_CHANNEL_ALLOC_GPFIFO ===
Allocates gpfifo entries. Identical to Linux driver.
 
  struct {
    __in u32 num_entries;
    __in u32 flags;          // bit0: vpr_enabled
  };
 
=== NVGPU_IOCTL_CHANNEL_WAIT ===
Waits on channel. Identical to Linux driver.
 
  struct {
    __in u32 type;            // wait type (0=notifier, 1=semaphore)
    __in u32 timeout;        // wait timeout value
    __in u32 dmabuf_fd;      // nvmap handle
    __in u32 offset;          // nvmap memory offset
    __in u32 payload;        // payload data (semaphore only)
    __in u32 padding;        // ignored
  };
 
=== NVGPU_IOCTL_CHANNEL_CYCLE_STATS ===
Maps memory for the cycle stats buffer. Identical to Linux driver.
 
  struct {
    __in u32 dmabuf_fd;  // nvmap handle
  };
 
=== NVGPU_IOCTL_CHANNEL_SUBMIT_GPFIFO ===
Submits a gpfifo object. Modified to take inline entry objects instead of a pointer.
 
  struct fence {
    u32 id;
    u32 value;
  };
 
  struct gpfifo_entry {
    u32 entry0;                              // gpu_iova_lo
    u32 entry1;                              // gpu_iova_hi | (allow_flush << 8) | (is_push_buf << 9) | (size << 10) | (sync << 31)
  };
 
  struct {
    __in    u64 gpfifo;                      // (ignored) pointer to gpfifo fence structs
    __in    u32 num_entries;                // number of fence objects being submitted
    union {
      __out u32 detailed_error;
      __in  u32 flags;                      // bit0: fence_wait, bit1: fence_get, bit2: hw_format, bit3: sync_fence, bit4: suppress_wfi, bit5: skip_buffer_refcounting
    };
    __inout struct fence fence_out;          // returned new fence object for others to wait on
    __in    struct gpfifo_entry entries[];  // depends on num_entries
  };
 
=== NVGPU_IOCTL_CHANNEL_ALLOC_OBJ_CTX ===
Allocates a graphics context object. Modified to ignore object's ID.
 
You can only have one object context allocated at a time. You must have bound an address space before using this.
 
  struct {
    __in  u32 class_num;    // 0x902D=2d, 0xB197=3d, 0xB1C0=compute, 0xA140=kepler, 0xB0B5=DMA, 0xB06F=channel_gpfifo
    __in  u32 flags;        // bit0: LOCKBOOST_ZERO
    __out u64 obj_id;      // (ignored) used for FREE_OBJ_CTX ioctl, which is not supported
  };
 
=== NVHOST_IOCTL_CHANNEL_FREE_OBJ_CTX ===
Frees a graphics context object. Not supported.
 
  struct {
    __in u64 obj_id;      // ignored
  };
 
=== NVGPU_IOCTL_CHANNEL_ZCULL_BIND ===
Binds a ZCULL context to the channel. Identical to Linux driver.
 
  struct {
    __in u64 gpu_va;
    __in u32 mode;        // 0=global, 1=no_ctxsw, 2=separate_buffer, 3=part_of_regular_buf
    __in u32 reserved;
  };
 
=== NVGPU_IOCTL_CHANNEL_SET_ERROR_NOTIFIER ===
Initializes the error notifier for this channel. Unlike for the Linux kernel, the Switch driver cannot write to an arbitrary userspace buffer. Thus new ioctls have been introduced to fetch the error information rather than using a shared memory buffer.
 
  struct {
    __in u64 offset;  // ignored
    __in u64 size;    // ignored
    __in u32 mem;      // must be non-zero to initialize, zero to de-initialize
    __in u32 reserved; // ignored
  };
 
=== NVGPU_IOCTL_CHANNEL_SET_PRIORITY ===
Changes channel's priority. Identical to Linux driver.
 
  struct {
    __in u32 priority;    // 0x32 is low, 0x64 is medium and 0x96 is high
  };
 
=== NVGPU_IOCTL_CHANNEL_ENABLE ===
Enables the current channel. Identical to Linux driver.
 
=== NVGPU_IOCTL_CHANNEL_DISABLE ===
Disables the current channel. Identical to Linux driver.
 
=== NVGPU_IOCTL_CHANNEL_PREEMPT ===
Clears the FIFO pipe for this channel. Identical to Linux driver.
 
=== NVGPU_IOCTL_CHANNEL_FORCE_RESET ===
Forces the channel to reset. Identical to Linux driver.
 
=== NVGPU_IOCTL_CHANNEL_EVENT_ID_CONTROL ===
Controls event notifications.
 
  struct {
    __in u32 cmd;    // 0=disable, 1=enable, 2=clear
    __in u32 id;    // same id's as for [[#QueryEvent]]
  };
 
=== NVGPU_IOCTL_CHANNEL_CYCLE_STATS_SNAPSHOT ===
Controls the cycle stats snapshot buffer. Identical to Linux driver.
 
  struct {
    __in    u32 cmd;        // command to handle (0=flush, 1=attach, 2=detach)
    __in    u32 dmabuf_fd;  // nvmap handle
    __inout u32 extra;      // extra payload data/result
    __in    u32 padding;    // ignored
  };
 
=== NVGPU_IOCTL_CHANNEL_GET_ERROR_INFO ===
Returns information on the current error notification caught by the error notifier. Exclusive to the Switch.
 
  struct {
    __out u32 type;    // Error type (0=no_error, 1=mmu_error, 2=gr_error, 3=pbdma_error, 4=timeout)
    __out u32 info[31]; // Infor depends on the error type
  };
 
==== GR Error Code Format ====
When <code>type == 2</code> (GR Error), the returned data is formatted as follows:
  struct {
    __out u32 type;      // 2=gr_error
    __out u32 intr_value; // Interrupt bits
    __out u32 addr;      // Register address (in bytes)
    __out u32 data_hi;    // Data high 32 bits
    __out u32 data_lo;    // Data low 32 bits
    __out u32 class_num;  // GPU class number (e.g., 0xb197 for MAXWELL_B)
  };
 
GR Error Interrupt Bits:
{| class="wikitable"
! Bits
! Description
|-
| 0
| GR_INTR_NOTIFY
|-
| 1
| GR_INTR_SEMAPHORE
|-
| 2
|
|-
| 3
|
|-
| 4
| GR_INTR_ILLEGAL_METHOD
|-
| 5
| GR_INTR_ILLEGAL_CLASS
|-
| 6
| GR_INTR_ILLEGAL_NOTIFY
|-
| 7
|
|-
| 8
| GR_INTR_FIRMWARE_METHOD
|-
| 9–18
|
|-
| 19
| GR_INTR_FECS_ERROR
|-
| 20
| GR_INTR_CLASS_ERROR
|-
| 21
| GR_INTR_EXCEPTION
|-
| 22–31
|  
|}
 
=== NVGPU_IOCTL_CHANNEL_GET_ERROR_NOTIFICATION ===
Returns the current error notification caught by the error notifier. Exclusive to the Switch.
 
  struct {
    __out u64 timestamp;    // fetched straight from armGetSystemTick
    __out u32 info32;      // error code
    __out u16 info16;      // additional error info
    __out u16 status;      // always 0xFFFF
  };
 
=== NVGPU_IOCTL_CHANNEL_ALLOC_GPFIFO_EX ===
Allocates gpfifo entries with additional parameters. Exclusive to the Switch.
 
  struct fence {
    u32 id;
    u32 value;
  };
  struct {
    __in    u32 num_entries;
    __in    u32 num_jobs;
    __in    u32 flags;                      // bit0: vpr_enabled
    __out  struct fence fence_out;          // returned new fence object for others to wait on
    __in    u32 reserved[3];                // ignored
  };
 
=== NVGPU_IOCTL_CHANNEL_SUBMIT_GPFIFO_RETRY ===
Same as [[#NVGPU_IOCTL_CHANNEL_SUBMIT_GPFIFO|NVGPU_IOCTL_CHANNEL_SUBMIT_GPFIFO]].
 
=== NVGPU_IOCTL_CHANNEL_ALLOC_GPFIFO_EX2 ===
Same as [[#NVGPU_IOCTL_CHANNEL_ALLOC_GPFIFO_EX|NVGPU_IOCTL_CHANNEL_ALLOC_GPFIFO_EX]].
 
=== NVGPU_IOCTL_CHANNEL_SUBMIT_GPFIFO2 ===
Same as [[#NVGPU_IOCTL_CHANNEL_SUBMIT_GPFIFO|NVGPU_IOCTL_CHANNEL_SUBMIT_GPFIFO]], but uses [[#Ioctl2|Ioctl2]].
 
=== NVGPU_IOCTL_CHANNEL_SUBMIT_GPFIFO2_RETRY ===
Same as [[#NVGPU_IOCTL_CHANNEL_SUBMIT_GPFIFO_RETRY|NVGPU_IOCTL_CHANNEL_SUBMIT_GPFIFO_RETRY]], but uses [[#Ioctl2|Ioctl2]].
 
=== NVGPU_IOCTL_CHANNEL_SET_TIMESLICE ===
Changes channel's timeslice. Identical to Linux driver.
 
  struct {
    __in u32 timeslice;
  };
 
=== NVGPU_IOCTL_CHANNEL_SET_USER_DATA ===
Sets user specific data.
 
  struct {
    __in u64 data;
  };
 
=== NVGPU_IOCTL_CHANNEL_GET_USER_DATA ===
Returns user specific data.
 
  struct {
    __out u64 data;
  };
 
=== NVGPU_IOCTL_CHANNEL_GET_USER_SYNCPOINT ===
Returns information on the user syncpoint.
 
  struct {
    __out u64 gpu_va;
    __out u64 syncpoint_id;
    __out u64 syncpoint_max;
  };
 
=== NVGPU_IOCTL_CHANNEL_SET_PREEMPTION_MODE ===
Sets the channel preemption modes.
 
  struct {
    __in u32 graphics_preempt_mode;
    __in u32 compute_preempt_mode;
  };
 
=== NVGPU_IOCTL_CHANNEL_OPEN ===
Opens the channel for a given runlist.
 
  struct {
    __in s32 runlist_id;
  };
 
=== NVGPU_IOCTL_CHANNEL_SETUP_BIND ===
Allocates or assigns the control buffers for the channel.
 
  struct {
    __in u32 num_gpfifo_entries;
    __in u32 num_inflight_jobs;
    __in u32 flags;
    __in s32 userd_dmabuf_fd;
    __in s32 gpfifo_dmabuf_fd;
    __out u32 work_submit_token;
    __in u64 userd_dmabuf_offset;
    __in u64 gpfifo_dmabuf_offset;
    __out u64 gpfifo_gpu_va;
    __out u64 userd_gpu_va;
    __out u64 usermode_mmio_gpu_va;
    __out u32 hw_channel_id;
    __in u32 reserved[3];
  };
 
= NvDrvPermission =
This is "nns::nvdrv::NvDrvPermission".
 
{| class="wikitable" border="1"
!  Bits
!  Name
!  Description
|-
| 0
| Gpu
| Can access [[#Channels|/dev/nvhost-gpu]], [[#/dev/nvhost-ctrl-gpu|/dev/nvhost-ctrl-gpu]] and [[#/dev/nvhost-as-gpu|/dev/nvhost-as-gpu]].
|-
| 1
| GpuDebug
| Can access [[#/dev/nvhost-dbg-gpu|/dev/nvhost-dbg-gpu]] and [[#/dev/nvhost-prof-gpu|/dev/nvhost-prof-gpu]].
|-
| 2
| GpuSchedule
| Can access [[#/dev/nvsched-ctrl|/dev/nvsched-ctrl]].
|-
| 3
| VIC
| Can access [[#Channels|/dev/nvhost-vic]].
|-
| 4
| VideoEncoder
| Can access [[#Channels|/dev/nvhost-msenc]].
|-
| 5
| VideoDecoder
| Can access [[#Channels|/dev/nvhost-nvdec]].
|-
| 6
| TSEC
| Can access [[#Channels|/dev/nvhost-tsec]].
|-
| 7
| JPEG
| Can access [[#Channels|/dev/nvhost-nvjpg]].
|-
| 8
| Display
| Can access [[#Channels|/dev/nvhost-display]], [[#/dev/nvcec-ctrl|/dev/nvcec-ctrl]], [[#/dev/nvhdcp_up-ctrl|/dev/nvhdcp_up-ctrl]], [[#/dev/nvdisp-ctrl|/dev/nvdisp-ctrl]], [[#/dev/nvdisp-disp0, /dev/nvdisp-disp1|/dev/nvdisp-disp0]], [[#/dev/nvdisp-disp0, /dev/nvdisp-disp1|/dev/nvdisp-disp1]], [[#/dev/nvdcutil-disp0, /dev/nvdcutil-disp1|/dev/nvdcutil-disp0]] and [[#/dev/nvdcutil-disp0, /dev/nvdcutil-disp1|/dev/nvdcutil-disp1]].
|-
| 9
| ImportMemory
| Can duplicate [[#/dev/nvmap|nvmap]] handles from other processes with [[#NVMAP_IOC_FROM_ID|NVMAP_IOC_FROM_ID]].
|-
| 10
| NoCheckedAruid
| Can use [[#SetAruidWithoutCheck|SetAruidWithoutCheck]].
|-
| 11
|
| Can use [[#SetGraphicsFirmwareMemoryMarginEnabled|SetGraphicsFirmwareMemoryMarginEnabled]].  
|-
| 12
|
| Can duplicate exported [[#/dev/nvmap|nvmap]] handles from other processes with [[#NVMAP_IOC_FROM_ID|NVMAP_IOC_FROM_ID]].
|-
| 13
|
| Can use the GPU virtual address range 0xC0000 to 0x580000 instead of 0x0 to 0xC0000.
|-
| 14
|
| Can use [[#NVMAP_IOC_EXPORT_FOR_ARUID|NVMAP_IOC_EXPORT_FOR_ARUID]] and [[#NVMAP_IOC_REMOVE_EXPORT_FOR_ARUID|NVMAP_IOC_REMOVE_EXPORT_FOR_ARUID]].
|-
| 15
|
| Can use the virtual address ranges 0x0 to 0x100000000 (GPU) and 0x0 to 0xE0000000 (non-GPU) instead of 0x100000000 to 0x11FA50000 (GPU) and 0xE0000000 to 0xFFFE0000 (non-GPU).
|}
 
= NvError =
This is "nns::nvdrv::NvError".
 
{| class="wikitable" border="1"
|-
! Value || Name
|-
| 0x0 || Success
|-
| 0x1 || NotImplemented
|-
| 0x2 || NotSupported
|-
| 0x3 || NotInitialized
|-
| 0x4 || BadParameter
|-
| 0x5 || Timeout
|-
| 0x6 || InsufficientMemory
|-
| 0x7 || ReadOnlyAttribute
|-
| 0x8 || InvalidState
|-
| 0x9 || InvalidAddress
|-
| 0xA || InvalidSize
|-
| 0xB || BadValue
|-
| 0xD || AlreadyAllocated
|-
| 0xE || Busy
|-
| 0xF || ResourceError
|-
| 0x10 || CountMismatch
|-
| 0x11 || OverFlow
|-
| 0x1000 || InsufficientTransferMemory
|-
| 0x10000 || InsufficientVideoMemory
|-
| 0x10001 || BadSurfaceColorScheme
|-
| 0x10002 || InvalidSurface
|-
| 0x10003 || SurfaceNotSupported
|-
| 0x20000 || DispInitFailed
|-
| 0x20001 || DispAlreadyAttached
|-
| 0x20002 || DispTooManyDisplays
|-
| 0x20003 || DispNoDisplaysAttached
|-
| 0x20004 || DispModeNotSupported
|-
| 0x20005 || DispNotFound
|-
| 0x20006 || DispAttachDissallowed
|-
| 0x20007 || DispTypeNotSupported
|-
| 0x20008 || DispAuthenticationFailed
|-
| 0x20009 || DispNotAttached
|-
| 0x2000A || DispSamePwrState
|-
| 0x2000B || DispEdidFailure
|-
| 0x2000C || DispDsiReadAckError
|-
| 0x2000D || DispDsiReadInvalidResp
|-
| 0x30000 || FileWriteFailed
|-
| 0x30001 || FileReadFailed
|-
| 0x30002 || EndOfFile
|-
| 0x30003 || FileOperationFailed
|-
| 0x30004 || DirOperationFailed
|-
| 0x30005 || EndOfDirList
|-
| 0x30006 || ConfigVarNotFound
|-
| 0x30007 || InvalidConfigVar
|-
| 0x30008 || LibraryNotFound
|-
| 0x30009 || SymbolNotFound
|-
| 0x3000A || MemoryMapFailed
|-
| 0x3000F || IoctlFailed                       
|-
| 0x30010 || AccessDenied
|-
| 0x30011 || DeviceNotFound
|-
| 0x30012 || KernelDriverNotFound
|-
| 0x30013 || FileNotFound
|-
| 0x30014 || PathAlreadyExists
|-
| 0xA000E || ModuleNotPresent
|}
 
= NvDrvStatus =
This is "nns::nvdrv::NvDrvStatus".


{| class="wikitable" border="1"
{| class="wikitable" border="1"
|-
|-
! Value || Name
! Offset
! Size
! Description
|-
|-
| 0x0 || NvError_Success
| 0x0
| 0x4
| FreeSize
|-
|-
| 0x1 || NvError_NotImplemented
| 0x4
| 0x4
| AllocatableSize
|-
|-
| 0x2 || NvError_NotSupported
| 0x8
| 0x4
| MinimumFreeSize
|-
|-
| 0x3 || NvError_NotInitialized
| 0xC
| 0x4
| MinimumAllocatableSize
|-
|-
| 0x4 || NvError_BadParameter
| 0x10
|-
| 0x10
| 0x5 || NvError_Timeout
| Reserved
|-
|}
| 0x6 || NvError_InsufficientMemory
 
|-
= Notes =
| 0x7 || NvError_ReadOnlyAttribute
In some cases, a panic may occur. NV forces a crash by doing:
|-
(void *)0 = 0xCAFE;
| 0x8 || NvError_InvalidState
End result is that the system hangs with a white-screen.
|-
 
| 0x9 || NvError_InvalidAddress
When the gpfifo data in the gpu_va buffers specified by the submitted gpfifo entries is invalid(?), eventually the user-process will be force-terminated after using the submit-gpfifo ioctl. It's unknown how exactly this is done.
|-
| 0xA || NvError_InvalidSize
|-
| 0xB || NvError_BadValue
|-
| 0xD || NvError_AlreadyAllocated
|-
| 0xE || NvError_Busy
|-
| 0xF || NvError_ResourceError
|-
| 0x10 || NvError_CountMismatch
|-
| 0x11 || NvError_OverFlow
|-
| 0x1000 || NvError_InsufficientTransferMemory
|-
| 0x10000 || NvError_InsufficientVideoMemory
|-
| 0x10001 || NvError_BadSurfaceColorScheme
|-
| 0x10002 || NvError_InvalidSurface
|-
| 0x10003 || NvError_SurfaceNotSupported
|-
| 0x20000 || NvError_DispInitFailed
|-
| 0x20001 || NvError_DispAlreadyAttached
|-
| 0x20002 || NvError_DispTooManyDisplays
|-
| 0x20003 || NvError_DispNoDisplaysAttached
|-
| 0x20004 || NvError_DispModeNotSupported
|-
| 0x20005 || NvError_DispNotFound
|-
| 0x20006 || NvError_DispAttachDissallowed
|-
| 0x20007 || NvError_DispTypeNotSupported
|-
| 0x20008 || NvError_DispAuthenticationFailed
|-
| 0x20009 || NvError_DispNotAttached
|-
| 0x2000A || NvError_DispSamePwrState
|-
| 0x2000B || NvError_DispEdidFailure
|-
| 0x2000C || NvError_DispDsiReadAckError
|-
| 0x2000D || NvError_DispDsiReadInvalidResp
|-
| 0x30000 || NvError_FileWriteFailed
|-
| 0x30001 || NvError_FileReadFailed
|-
| 0x30002 || NvError_EndOfFile
|-
| 0x30003 || NvError_FileOperationFailed
|-
| 0x30004 || NvError_DirOperationFailed
|-
| 0x30005 || NvError_EndOfDirList
|-
| 0x30006 || NvError_ConfigVarNotFound
|-
| 0x30007 || NvError_InvalidConfigVar
|-
| 0x30008 || NvError_LibraryNotFound
|-
| 0x30009 || NvError_SymbolNotFound
|-
| 0x3000A || NvError_MemoryMapFailed
|-
| 0x3000F || NvError_IoctlFailed                       
|-
| 0x30010 || NvError_AccessDenied
|-
| 0x30011 || NvError_DeviceNotFound
|-
| 0x30012 || NvError_KernelDriverNotFound
|-
| 0x30013 || NvError_FileNotFound
|-
| 0x30014 || NvError_PathAlreadyExists
|-
| 0xA000E || NvError_ModuleNotPresent
|}


= Panic =
GPU rendering (GPFIFO) is only used by applets/Applications. All sysmodules doing any gfx-display uses software rendering. During system-boot, GPU GPFIFO is not used until the applets are launched.
In some cases, a panic may occur. NV forces a crash by doing:
(void *)0 = 0xCAFE;
End result is that the system hangs with a white-screen.
 
== Gpfifo Panic ==
When the gpfifo data in the gpu_va buffers specified by the submitted gpfifo entries is invalid(?), eventually the user-process will be force-terminated after using the submit-gpfifo ioctl. It's unknown how exactly this is done.


[[Category:Services]]
[[Category:Services]]

Latest revision as of 02:40, 18 October 2025

nvdrv, nvdrv:a, nvdrv:s, nvdrv:t

This is "nns::nvdrv::INvDrvServices".

Each service is used by:

  • "nvdrv": Applications.
    • Permission mask is [11.0.0+] 0xA83B ([1.0.0-2.3.0] 0x2B, [3.0.0+] 0xA82B).
  • "nvdrv:a": Applets.
    • Permission mask is [3.0.0+] 0x10A9 ([1.0.0-2.3.0] 0xA9).
  • "nvdrv:s": Sysmodules.
    • Permission mask is [3.0.0+] 0x439E ([1.0.0-2.3.0] 0x39E).
  • "nvdrv:t": Factory.
Cmd Name
0 Open
1 Ioctl
2 Close
3 Initialize
4 QueryEvent
5 MapSharedMem
6 GetStatus
7 SetAruidWithoutCheck
8 SetAruid
9 DumpStatus
10 [3.0.0+] InitializeDevtools
11 [3.0.0+] Ioctl2
12 [3.0.0+] Ioctl3
13 [3.0.0+] SetGraphicsFirmwareMemoryMarginEnabled

Open

Takes a type-0x5 input buffer Path. Returns two output u32s FdOut and Err.

Ioctl

Takes two input u32s Fd and Iocode, a type-0x21 input buffer and a type-0x22 output buffer. Returns an output u32 Err.

The addr/size for send/recv buffers are only set when the associated direction bit is set in the ioctl cmd (addr/size = 0 otherwise).

Close

Takes an input u32 Fd. Returns an output u32 Err.

Initialize

Takes an input Process handle, an input TransferMemory handle and an input u32 Size. Returns an output u32 Err.

Webkit applet creates the TransferMemory with perm == 0 and size == 0x300000.

QueryEvent

Takes two input u32s Fd and EvtId. Returns an output u32 Err and an output Event handle.

QueryEvent is only supported by:

  • /dev/nvcec-ctrl
    • EvtId=0
    • EvtId=1
    • EvtId=2
    • EvtId=3
    • EvtId=4
    • EvtId=5
    • EvtId=6
    • EvtId=7
    • EvtId=8
    • EvtId=9
  • /dev/nvhdcp_up-ctrl
    • EvtId=0: DphdcpStateEvent
  • /dev/nvdisp-ctrl
    • EvtId=0: HpdInEvent
    • EvtId=1: HpdOutEvent
    • EvtId=2: VblankHead0Event
  • /dev/nvhost-gpu
    • EvtId=1: BptIntEvent
    • EvtId=2: BptPauseEvent
    • EvtId=3: ErrorNotifierEvent
  • /dev/nvhost-ctrl-gpu
    • EvtId=1: ErrorEvent
    • EvtId=2: SemaphoreEvent
  • /dev/nvhost-dbg-gpu
    • EvtId=Any: DbgEvents
  • /dev/nvsched-ctrl
    • EvtId=0: ApplicationAddedEvent
    • EvtId=1: ApplicationUpdatedEvent
    • EvtId=2: ApplicationMaxDebtUpdatedEvent
    • EvtId=3: ApplicationRemovedEvent
    • EvtId=4: ApplicationDetachedEvent
    • EvtId=5: RunlistAddedEvent
    • EvtId=6: RunlistUpdatedEvent
    • EvtId=7: RunlistMaxDebtUpdatedEvent
    • EvtId=8: RunlistLinkedEvent
    • EvtId=9: RunlistUnlinkedEvent
    • EvtId=10: RunlistRemovedEvent
    • EvtId=11: ConductorSwapintervalUpdatedEvent
    • EvtId=12: ChannelAcquiredEvent
    • EvtId=13: ChannelReleasedEvent

MapSharedMem

Takes an input TransferMemory handle and two input u32s Fd and HMem. Returns an output u32 Err.

HMem is a /dev/nvmap memory handle.

GetStatus

Takes no input. Returns an output #NvDrvStatus and an output u32 Err.

SetAruidWithoutCheck

Takes an input u64 Aruid. Returns an output u32 Err.

Aruid must match the current AppletResourceUserId.

SetAruid

Takes a PID-descriptor and an input AppletResourceUserId. Returns an output u32 Err.

DumpStatus

No input/output.

InitializeDevtools

Takes an input TransferMemory handle and an input u32 Size. Returns an output u32 Err.

Ioctl2

Takes two input u32s Fd and Iocode, two type-0x21 input buffers and a type-0x22 output buffer. Returns an output u32 Err.

Ioctl3

Takes two input u32s Fd and Iocode, a type-0x21 input buffer and two type-0x22 output buffers. Returns an output u32 Err.

SetGraphicsFirmwareMemoryMarginEnabled

Unofficial name.

Takes an input u64. No output.

This sets a boolean value based on the input u64 and the value of the "nv!nv_graphics_firmware_memory_margin" system configuration, but only for "nvdrv" (the other services default to false).

[3.0.0+] Official user-processes now use this at the end of nvdrv service init with value 0x1.

nvmemp

This is "nv::MemoryProfiler::IMemoryProfiler".

/dev/nvhost-ctrl sends the ioctl NVHOST_IOCTL_CTRL_GET_CONFIG to check the config "nv!NV_MEMORY_PROFILER". If config_str returns "1", the application attempts to use nvmemp.

Cmd Name
0 Open
1 GetPid

Open

Takes an input TransferMemory handle and an input u32 Size. No output.

GetPid

No input. Returns an output u32 Pid.

nvdrvdbg

This is "nns::nvdrv::INvDrvDebugFSServices".

Cmd Name
0 DebugFSOpen
1 DebugFSClose
2 GetDebugFSKeys
3 GetDebugFSValue
4 SetDebugFSValue

DebugFSOpen

Takes an input Process handle. Returns an output u32 Handle.

DebugFSClose

Takes an input u32 Handle. No output.

GetDebugFSKeys

Takes an input u32 Handle and a type-0x6 output buffer OutValueBuf. Returns an output u32 Err.

GetDebugFSValue

Takes an input u32 Handle, a type-0x5 input buffer InKeyBuf and a type-0x6 output buffer OutValueBuf. Returns an output u32 Err.

SetDebugFSValue

Takes an input u32 Handle and two type-0x5 input buffers InKeyBuf and InValueBuf. Returns an output u32 Err.

nvgem:c

This is "nv::gemcontrol::INvGemControl".

Cmd Name
0 Initialize
1 GetEventHandle
2 ControlNotification
3 SetNotificationPerm
4 SetCoreDumpPerm
5 [1.0.0-4.1.0] GetAruid
6 Reset
7 [3.0.0+] GetAruid2

Initialize

No input. Returns an output u32 Err.

GetEventHandle

No input. Returns an output Event handle and an output u32 Err.

ControlNotification

Takes an input bool Enable. Returns an output u32 Err.

SetNotificationPerm

Takes an input u64 Aruid and an input bool Enable. Returns an output u32 Err.

SetCoreDumpPerm

Takes an input u64 Aruid and an input bool Enable. Returns an output u32 Err.

GetAruid

No input. Returns an output u64 Aruid and an output u32 Err.

Reset

No input. Returns an output u32 Err.

GetAruid2

Unofficial name.

No input. Returns an output u64 Aruid, an output bool IsCoreDumpEnabled and an output u32 Err.

nvgem:cd

This is "nv::gemcoredump::INvGemCoreDump".

Cmd Name
0 Initialize
1 GetAruid
2 [1.0.0-8.1.0] ReadNextBlock
3 [8.0.0+] GetNextBlockSize
4 [8.0.0+] ReadNextBlock2

Initialize

No input. Returns an output u32 Err.

GetAruid

No input. Returns an output u64 Aruid and an output u32 Err.

ReadNextBlock

Takes a type-0x6 output buffer. Returns an output u32 Err.

GetNextBlockSize

Unofficial name.

No input. Returns an output u64 Size and an output u32 Err.

ReadNextBlock2

Unofficial name.

Takes a type-0x6 output buffer and two input u64s Size and Offset. Returns an output u64 OutSize and an output u32 Err.

nvdbg:d

This is "nns::nvdrv::INvDrvDebugSvcServices". This was added with [10.0.0+].

This service has no commands.

(S2) INvDrv2User

This is "nn::nvdrv::INvDrv2User".

Cmd Name
0 Open
1 Ioctl
2 Close
4 QueryEvent
9 DumpStatus
10 InitializeDevtools
11 Ioctl2
12 Ioctl3
13 SetConfiguration

SetConfiguration

Unofficial name.

Takes an input u64 Configuration. No output.

Bit 0 in Configuration represents the old GraphicsFirmwareMemoryMarginEnabled option.

Ioctls

The ioctl number is generated with the following primitive (see Linux kernel):

#define _IOC(inout, group, num, len) \
   (inout | ((len & IOCPARM_MASK) << 16) | ((group) << 8) | (num))

The following table contains all known ioctls.

/dev/nvhost-ctrl

Value Direction Size Description
0xC0080014 Inout 8 NVHOST_IOCTL_CTRL_SYNCPT_READ
0x40040015 In 4 NVHOST_IOCTL_CTRL_SYNCPT_INCR
0xC00C0016 Inout 12 NVHOST_IOCTL_CTRL_SYNCPT_WAIT
0x40080017 In 8 NVHOST_IOCTL_CTRL_MODULE_MUTEX
0xC0180018 Inout 24 NVHOST_IOCTL_CTRL_MODULE_REGRDWR
0xC0100019 Inout 16 NVHOST_IOCTL_CTRL_SYNCPT_WAITEX
0xC008001A Inout 8 NVHOST_IOCTL_CTRL_SYNCPT_READ_MAX
0xC183001B Inout 387 NVHOST_IOCTL_CTRL_GET_CONFIG
0xC004001C Inout 4 NVHOST_IOCTL_CTRL_SYNCPT_CLEAR_EVENT_WAIT
0xC010001D Inout 16 NVHOST_IOCTL_CTRL_SYNCPT_WAIT_EVENT
0xC010001E Inout 16 NVHOST_IOCTL_CTRL_SYNCPT_WAIT_EVENT_EX
0xC004001F Inout 4 NVHOST_IOCTL_CTRL_SYNCPT_ALLOC_EVENT
0xC0040020 Inout 4 NVHOST_IOCTL_CTRL_SYNCPT_FREE_EVENT
0x40080021 In 8 NVHOST_IOCTL_CTRL_SYNCPT_FREE_EVENT_BATCH
0xC0040022 Inout 4 NVHOST_IOCTL_CTRL_SYNCPT_GET_SHIFT
0xC0080027 Inout 8 [S2] NVHOST_IOCTL_CTRL_ALLOC_SYNCPT
0x40040028 In 4 [S2] NVHOST_IOCTL_CTRL_FREE_SYNCPT
0xC010002A Inout 16 [S2] NVHOST_IOCTL_CTRL_GET_CHARACTERISTICS
0xC008002B Inout 8 [S2] NVHOST_IOCTL_CTRL_CHECK_MODULE_SUPPORT

NVHOST_IOCTL_CTRL_SYNCPT_READ

Identical to Linux driver.

 struct {
   __in  u32 id;
   __out u32 value;
 };

NVHOST_IOCTL_CTRL_SYNCPT_INCR

Identical to Linux driver.

 struct {
   __in u32 id;
 };

NVHOST_IOCTL_CTRL_SYNCPT_WAIT

Identical to Linux driver.

 struct {
   __in u32 id;
   __in u32 thresh;
   __in s32 timeout;
 };

NVHOST_IOCTL_CTRL_MODULE_MUTEX

Identical to Linux driver.

 struct {
   __in u32 id;
   __in u32 lock;        // 0=unlock, 1=lock
 };

NVHOST_IOCTL_CTRL_MODULE_REGRDWR

Identical to Linux driver. Uses 32-bit version and doesn't work.

 struct {
   __in u32 id;
   __in u32 num_offsets;
   __in u32 block_size;
   __in u32 offsets;
   __in u32 values;
   __in u32 write;
 };

NVHOST_IOCTL_CTRL_SYNCPT_WAITEX

Identical to Linux driver.

 struct {
   __in  u32 id;
   __in  u32 thresh;
   __in  s32 timeout;
   __out u32 value;
 };

NVHOST_IOCTL_CTRL_SYNCPT_READ_MAX

Identical to Linux driver.

 struct {
   __in  u32 id;
   __out u32 value;
 };

NVHOST_IOCTL_CTRL_GET_CONFIG

Returns configured settings. Not available in production mode.

 struct {
   __in char name[0x41];       // "nv"
   __in char key[0x41];
   __out char value[0x101];
 };

NVHOST_IOCTL_CTRL_SYNCPT_CLEAR_EVENT_WAIT

Clears the wait signal of a syncpt event.

 struct {
   __in u32 event_slot;       // 0x00 to 0x3F
 };

NVHOST_IOCTL_CTRL_SYNCPT_WAIT_EVENT

Waits on a syncpt using events. If waiting fails, returns error code 0x05 (Timeout) and sets value to (event_slot | ((syncpt_id & 0xFFF) << 16) | (is_valid << 28)).

 struct {
   __in  u32 id;
   __in  u32 thresh;
   __in  s32 timeout;
   __out u32 value;
 };

NVHOST_IOCTL_CTRL_SYNCPT_WAIT_EVENT_EX

Waits on a syncpt using a specific event. If waiting fails, returns error code 0x05 (Timeout) and sets value to (event_slot | (syncpt_id << 4)).

 struct {
   __in    u32 id;
   __in    u32 thresh;
   __in    s32 timeout;
   __inout u32 value;           // in=event_slot; out=syncpt_value
 };

NVHOST_IOCTL_CTRL_SYNCPT_ALLOC_EVENT

Allocates a new syncpt event.

 struct {
   __in u32 event_slot;         // 0x00 to 0x3F
 };

NVHOST_IOCTL_CTRL_SYNCPT_FREE_EVENT

Frees an existing syncpt event.

 struct {
   __in u32 event_slot;         // 0x00 to 0x3F
 };

NVHOST_IOCTL_CTRL_SYNCPT_FREE_EVENT_BATCH

Frees multiple syncpt events.

 struct {
   __in u64 event_slot_mask;    // 64-bit bitfield where each bit represents one event
 };

NVHOST_IOCTL_CTRL_SYNCPT_GET_SHIFT

Unofficial name.

Returns the syncpt shift value.

 struct {
   __out u32 syncpt_shift;      // 0x00 (FIFO disabled) or 0x60 (FIFO enabled)
 };

/dev/nvmap

Value Direction Size Description
0xC0080101 Inout 8 NVMAP_IOC_CREATE
0x00000102 - 0 NVMAP_IOC_CLAIM
0xC0080103 Inout 8 NVMAP_IOC_FROM_ID
0xC0200104 Inout 32 NVMAP_IOC_ALLOC
0xC0180105 Inout 24 NVMAP_IOC_FREE
0xC0280106 Inout 40 NVMAP_IOC_MMAP
0xC0280107 Inout 40 NVMAP_IOC_WRITE
0xC0280108 Inout 40 NVMAP_IOC_READ
0xC00C0109 Inout 12 NVMAP_IOC_PARAM
0xC010010A Inout 16 NVMAP_IOC_PIN_MULT
0xC010010B Inout 16 NVMAP_IOC_UNPIN_MULT
0xC008010C Inout 8 NVMAP_IOC_CACHE
0xC004010D Inout 4 NVMAP_IOC_GET_IVC_ID
0xC008010E Inout 8 NVMAP_IOC_GET_ID
0xC004010F Inout 4 NVMAP_IOC_FROM_IVC_ID
0x40040110 In 4 NVMAP_IOC_SET_ALLOCATION_TAG_LABEL
0x00000111 - 0 NVMAP_IOC_RESERVE
0x40100112 In 16 NVMAP_IOC_EXPORT_FOR_ARUID
0x40100113 In 16 NVMAP_IOC_IS_OWNED_BY_ARUID
0x40100114 In 16 NVMAP_IOC_REMOVE_EXPORT_FOR_ARUID

NVMAP_IOC_CREATE

Creates an nvmap object. Identical to Linux driver.

 struct {
   __in  u32 size;
   __out u32 handle;
 };

NVMAP_IOC_CLAIM

Returns NotSupported.

NVMAP_IOC_FROM_ID

Get handle to an existing nvmap object. Identical to Linux driver.

 struct {
   __in  u32 id;
   __out u32 handle;
 };

NVMAP_IOC_ALLOC

Allocate memory for the nvmap object. Nintendo extended this one with 16 bytes, and changed it from in to inout.

 struct {
   __in u32 handle;
   __in u32 heapmask;
   __in u32 flags;    // (0=read-only, 1=read-write)
   __inout u32 align;
   __in u8  kind;
   __in u8  pad[7];
   __in u64 addr;
 };

NVMAP_IOC_FREE

This one is completely custom. Partly because the Linux driver passed the handle as the ioctl "arg-ptr", and HIPC can't handle that voodoo.

 struct {
   __in  u32 handle;
   __in  u32 pad;
   __out u64 address;  // 0 if the handle wasn't yet freed
   __out u32 size;
   __out u32 flags;    // 1=WAS_UNCACHED (if flags bit 1 was set when NVMAP_IOC_ALLOC was called)
 };

NVMAP_IOC_MMAP

Returns NotSupported.

NVMAP_IOC_WRITE

Returns NotSupported.

NVMAP_IOC_READ

Returns NotSupported.

NVMAP_IOC_PARAM

Returns info about a nvmap object. Identical to Linux driver, but extended with further params.

 struct {
   __in  u32 handle;
   __in  u32 param;  // 1=SIZE, 2=ALIGNMENT, 3=BASE (returns error), 4=HEAP (always 0x40000000), 5=KIND, 6=COMPR (unused)
   __out u32 result;
 };

NVMAP_IOC_PIN_MULT

Returns NotSupported.

NVMAP_IOC_UNPIN_MULT

Returns NotSupported.

NVMAP_IOC_CACHE

Returns NotSupported.

NVMAP_IOC_GET_IVC_ID

Returns NotSupported.

NVMAP_IOC_GET_ID

Returns an id for a nvmap object. Identical to Linux driver.

 struct {
   __out u32 id; //~0 indicates error
   __in  u32 handle;
 };

NVMAP_IOC_FROM_IVC_ID

Returns NotSupported.

NVMAP_IOC_SET_ALLOCATION_TAG_LABEL

Returns NotSupported.

NVMAP_IOC_RESERVE

Returns NotSupported.

NVMAP_IOC_EXPORT_FOR_ARUID

Binds a nvmap object to an AppletResourceUserId.

 struct {
   __in  u64 aruid;
   __in  u32 handle;
   __in  u8 pad[4];
 };

NVMAP_IOC_IS_OWNED_BY_ARUID

Checks if a nvmap object is bound to an AppletResourceUserId.

 struct {
   __in  u64 aruid;
   __in  u32 handle;
   __in  u8 pad[4];
 };

NVMAP_IOC_REMOVE_EXPORT_FOR_ARUID

Unbinds a nvmap object from an AppletResourceUserId.

 struct {
   __in  u64 aruid;
   __in  u32 handle;
   __in  u8 pad[4];
 };

/dev/nvdisp-ctrl

Value Direction Size Description
0x80040212 Out 4 NVDISP_CTRL_NUM_OUTPUTS
0xC0140213 Inout 20 NVDISP_CTRL_GET_DISPLAY_PROPERTIES
0xC2100214
([1.0.0-11.0.1] 0xC1100214)
Inout 528
([1.0.0-11.0.1] 272)
NVDISP_CTRL_QUERY_EDID
0xC0080216
([1.0.0-3.0.0] 0xC0040216)
Inout 8
([1.0.0-3.0.0] 4)
NVDISP_CTRL_GET_EXT_HPD_IN_OUT_EVENTS
([1.0.0-3.0.0] NVDISP_CTRL_GET_EXT_HPD_IN_EVENT)
0xC0040217 Inout 4 [1.0.0-3.0.0] NVDISP_CTRL_GET_EXT_HPD_OUT_EVENT
0xC0100218 Inout 16 NVDISP_CTRL_GET_VBLANK_HEAD0_EVENT
0xC0100219 Inout 16 NVDISP_CTRL_GET_VBLANK_HEAD1_EVENT
0xC0040220 Inout 4 NVDISP_CTRL_SUSPEND
0x80010224 Out 1 [11.0.0+] NVDISP_CTRL_IS_DISPLAY_OLED

NVDISP_CTRL_NUM_OUTPUTS

Returns the number of display outputs available.

 struct {
   __out u32 num_outputs;
 };

NVDISP_CTRL_IS_DISPLAY_OLED

Unofficial name.

This sets a boolean value based on the values of the system configuration.

Returns true if "nvservices!internal_display_vddpn_control" is set to false and "nvservices!external_display_full_dp_lanes" is set to true.

 struct {
   __out u8 is_display_oled;
 };

/dev/nvdisp-disp0, /dev/nvdisp-disp1

Value Direction Size Description
0x40040201 In 4 NVDISP_GET_WINDOW
0x40040202 In 4 NVDISP_PUT_WINDOW
0xC4C80203 In 1224 NVDISP_FLIP
0x80380204 Out 56 NVDISP_GET_MODE
0x40380205 In 56 NVDISP_SET_MODE
0x430C0206 In 780 NVDISP_SET_LUT
0x40010207 In 1 NVDISP_CONFIG_CRC
0x80040208 Out 4 NVDISP_GET_CRC
0x80040209 Out 4 NVDISP_GET_HEAD_STATUS
0xC038020A Inout 56 NVDISP_VALIDATE_MODE
0x4018020B In 24 NVDISP_SET_CSC
0xC004020C Inout 4 NVDISP_GET_VBLANK_SYNCPT
0x8040020D Out 64 NVDISP_GET_UNDERFLOWS
0xC99A020E Inout 2458 NVDISP_SET_CMU
0xC004020F Inout 4 NVDISP_DPMS
0x80600210 Out 96 NVDISP_GET_AVI_INFOFRAME
0x40600211 In 96 NVDISP_SET_AVI_INFOFRAME
0xEBFC0215 Inout 11260 NVDISP_GET_MODE_DB
0xC003021A Inout 3 NVDISP_PANEL_GET_VENDOR_ID
0x803C021B Out 60 NVDISP_GET_MODE2
0x403C021C In 60 NVDISP_SET_MODE2
0xC03C021D Inout 60 NVDISP_VALIDATE_MODE2
0xEF20021E Inout 12064 NVDISP_GET_MODE_DB2
0xC004021F Inout 4 NVDISP_GET_WINMASK
0x80080221 Out 8 [10.0.0+] NVDISP_GET_BACKLIGHT_RANGE
0x40040222 In 4 [10.0.0+] NVDISP_SET_BACKLIGHT_RANGE_MAX
0x40040223 In 4 [11.0.0+] NVDISP_SET_BACKLIGHT_RANGE_MIN
0x401C0225 In 28 [11.0.0+] NVDISP_SEND_PANEL_MSG
0xC01C0226 Inout 28 [11.0.0+] NVDISP_GET_PANEL_DATA

NVDISP_GET_MODE

Almost identical to Linux driver.

 struct {
   __out u32 hActive;
   __out u32 vActive;
   __out u32 hSyncWidth;
   __out u32 vSyncWidth;
   __out u32 hFrontPorch;
   __out u32 vFrontPorch;
   __out u32 hBackPorch;
   __out u32 vBackPorch;
   __out u32 hRefToSync;
   __out u32 vRefToSync;
   __out u32 pclkKHz;
   __out u32 bitsPerPixel;      // Always 0
   __out u32 vmode;             // Always 0
   __out u32 sync;
 };

NVDISP_SET_MODE

Almost identical to Linux driver.

 struct {
   __in u32 hActive;
   __in u32 vActive;
   __in u32 hSyncWidth;
   __in u32 vSyncWidth;
   __in u32 hFrontPorch;
   __in u32 vFrontPorch;
   __in u32 hBackPorch;
   __in u32 vBackPorch;
   __in u32 hRefToSync;
   __in u32 vRefToSync;
   __in u32 pclkKHz;
   __in u32 bitsPerPixel;
   __in u32 vmode;
   __in u32 sync;
 };

NVDISP_VALIDATE_MODE

Almost identical to Linux driver.

 struct {
   __inout u32 hActive;
   __inout u32 vActive;
   __inout u32 hSyncWidth;
   __inout u32 vSyncWidth;
   __inout u32 hFrontPorch;
   __inout u32 vFrontPorch;
   __inout u32 hBackPorch;
   __inout u32 vBackPorch;
   __inout u32 hRefToSync;
   __inout u32 vRefToSync;
   __inout u32 pclkKHz;
   __inout u32 bitsPerPixel;
   __inout u32 vmode;
   __inout u32 sync;
 };

NVDISP_GET_AVI_INFOFRAME

Unpacked standard AVI infoframe struct (HDMI v1.4b/2.0)

 struct {
   __out u32 csum;
   __out u32 scan;
   __out u32 bar_valid;
   __out u32 act_fmt_valid;
   __out u32 rgb_ycc;
   __out u32 act_format;
   __out u32 aspect_ratio;
   __out u32 colorimetry;
   __out u32 scaling;
   __out u32 rgb_quant;
   __out u32 ext_colorimetry;
   __out u32 it_content;
   __out u32 video_format;
   __out u32 pix_rep;
   __out u32 it_content_type;
   __out u32 ycc_quant;
   __out u32 top_bar_end_line_lsb;
   __out u32 top_bar_end_line_msb;
   __out u32 bot_bar_start_line_lsb;
   __out u32 bot_bar_start_line_msb;
   __out u32 left_bar_end_pixel_lsb;
   __out u32 left_bar_end_pixel_msb;
   __out u32 right_bar_start_pixel_lsb;
   __out u32 right_bar_start_pixel_msb;
 };

NVDISP_SET_AVI_INFOFRAME

Unpacked standard AVI infoframe struct (HDMI v1.4b/2.0)

 struct {
   __in u32 csum;
   __in u32 scan;
   __in u32 bar_valid;
   __in u32 act_fmt_valid;
   __in u32 rgb_ycc;
   __in u32 act_format;
   __in u32 aspect_ratio;
   __in u32 colorimetry;
   __in u32 scaling;
   __in u32 rgb_quant;
   __in u32 ext_colorimetry;
   __in u32 it_content;
   __in u32 video_format;
   __in u32 pix_rep;
   __in u32 it_content_type;
   __in u32 ycc_quant;
   __in u32 top_bar_end_line_lsb;
   __in u32 top_bar_end_line_msb;
   __in u32 bot_bar_start_line_lsb;
   __in u32 bot_bar_start_line_msb;
   __in u32 left_bar_end_pixel_lsb;
   __in u32 left_bar_end_pixel_msb;
   __in u32 right_bar_start_pixel_lsb;
   __in u32 right_bar_start_pixel_msb;
 };

NVDISP_GET_MODE_DB

Almost identical to Linux driver.

 struct mode {
   u32 hActive;
   u32 vActive;
   u32 hSyncWidth;
   u32 vSyncWidth;
   u32 hFrontPorch;
   u32 vFrontPorch;
   u32 hBackPorch;
   u32 vBackPorch;
   u32 hRefToSync;
   u32 vRefToSync;
   u32 pclkKHz;
   u32 bitsPerPixel;
   u32 vmode;
   u32 sync;
 };

 struct {
   __out struct mode modes[201];
   __out u32 num_modes;
 };

NVDISP_PANEL_GET_VENDOR_ID

Returns display panel's informations.

 struct {
   __out u8 vendor; //0x10 - JDI, 0x20 - InnoLux, 0x30 - AUO, 0x40 - Sharp, 0x50 - Samsung
   __out u8 model;
   __out u8 board; //0xF - 6.2", 0x10 - 5.5", 0x20 - 7.0". JDI panels have nonstandard values
 };

NVDISP_GET_MODE2

 struct {
   __out u32 unk0;              //Always 0
   __out u32 hActive;
   __out u32 vActive;
   __out u32 hSyncWidth;
   __out u32 vSyncWidth;
   __out u32 hFrontPorch;
   __out u32 vFrontPorch;
   __out u32 hBackPorch;
   __out u32 vBackPorch;
   __out u32 pclkKHz;
   __out u32 bitsPerPixel;      // Always 0
   __out u32 vmode;             // Always 0
   __out u32 sync;
   __out u32 unk1;
   __out u32 reserved;
 };

NVDISP_SET_MODE2

 struct {
   __in u32 unk0;
   __in u32 hActive;
   __in u32 vActive;
   __in u32 hSyncWidth;
   __in u32 vSyncWidth;
   __in u32 hFrontPorch;
   __in u32 vFrontPorch;
   __in u32 hBackPorch;
   __in u32 vBackPorch;
   __in u32 pclkKHz;
   __in u32 bitsPerPixel;
   __in u32 vmode;
   __in u32 sync;
   __in u32 unk1;
   __in u32 reserved;
 };

NVDISP_VALIDATE_MODE2

 struct {
   __inout u32 unk0;
   __inout u32 hActive;
   __inout u32 vActive;
   __inout u32 hSyncWidth;
   __inout u32 vSyncWidth;
   __inout u32 hFrontPorch;
   __inout u32 vFrontPorch;
   __inout u32 hBackPorch;
   __inout u32 vBackPorch;
   __inout u32 pclkKHz;
   __inout u32 bitsPerPixel;
   __inout u32 vmode;
   __inout u32 sync;
   __inout u32 unk1;
   __inout u32 reserved;
 };

NVDISP_GET_MODE_DB2

 struct mode2 {
   u32 unk0;
   u32 hActive;
   u32 vActive;
   u32 hSyncWidth;
   u32 vSyncWidth;
   u32 hFrontPorch;
   u32 vFrontPorch;
   u32 hBackPorch;
   u32 vBackPorch;
   u32 pclkKHz;
   u32 bitsPerPixel;
   u32 vmode;
   u32 sync;
   u32 unk1;
   u32 reserved;
 };

 struct {
   __out struct mode2 modes[201];
   __out u32 num_modes;
 };

NVDISP_GET_BACKLIGHT_RANGE

Unofficial name.

Returns the minimum and maximum values for the intensity of the display's backlight.

 struct {
   __out u32 min;
   __out u32 max;
 };

NVDISP_SET_BACKLIGHT_RANGE_MAX

Unofficial name.

Sets the maximum value for the intensity of the display's backlight.

 struct {
   __in u32 max;
 };

NVDISP_SET_BACKLIGHT_RANGE_MIN

Unofficial name.

Sets the minimum value for the intensity of the display's backlight.

 struct {
   __in u32 min;
 };

NVDISP_SEND_PANEL_MSG

Unofficial name.

Sends raw data to the display panel over DPAUX.

 struct {
   __in u32 cmd;          // DPAUX AUXCTL command (1=unk, 2=I2CWR, 4=MOTWR, 7=AUXWR)
   __in u32 addr;         // DPAUX AUXADDR
   __in u32 size;         // message size
   __in u32 msg[4];       // raw AUXDATA message
 };

NVDISP_GET_PANEL_DATA

Unofficial name.

Receives raw data from the display panel over DPAUX.

 struct {
   __in u32 cmd;          // DPAUX AUXCTL command (3=I2CRD, 5=MOTRD, 6=AUXRD)
   __in u32 addr;         // DPAUX AUXADDR
   __in u32 size;         // message size
   __out u32 msg[4];      // raw AUXDATA message
 };

/dev/nvcec-ctrl

Value Direction Size Description
0x40010301 In 1 NVCEC_CTRL_ENABLE
0x804C0302 Out 76 NVCEC_CTRL_GET_PADDR
0x40040303 In 4 NVCEC_CTRL_SET_LADDR
0xC04C0304 Inout 76 NVCEC_CTRL_WRITE
0xC04C0305 Inout 76 NVCEC_CTRL_READ
0x804C0306 Out 76 NVCEC_CTRL_GET_CONNECTION_STATUS
0x804C0307 Out 76 NVCEC_CTRL_GET_WRITE_STATUS

/dev/nvhdcp_up-ctrl

Value Direction Size Description
0xC4880401 Inout 1160 NVHDCP_READ_STATUS
0xC4880402 Inout 1160 NVHDCP_READ_M
0x40010403 In 1 NVHDCP_ENABLE
0xC0080404 Inout 8 NVHDCP_CTRL_STATE_TRANSIT_EVENT_DATA
0xC0010405 Inout 1 NVHDCP_CTRL_STATE_CB

/dev/nvdcutil-disp0, /dev/nvdcutil-disp1

Value Direction Size Description
0x40010501 In 1 NVDCUTIL_ENABLE_CRC
0x40010502 In 1 NVDCUTIL_VIRTUAL_EDID_ENABLE
0x42040503 In 516 NVDCUTIL_VIRTUAL_EDID_SET_DATA
0x803C0504 Out 60 NVDCUTIL_GET_MODE
0x40010505 In 1 NVDCUTIL_BEGIN_TELEMETRY_TEST
0x400C0506 In 12 NVDCUTIL_DSI_PACKET_TEST_SHORT_WRITE
0x40F80507 In 248 NVDCUTIL_DSI_PACKET_TEST_LONG_WRITE
0xC0F40508 Inout 244 NVDCUTIL_DSI_PACKET_TEST_READ
0x40010509 In 1 [10.0.0+] NVDCUTIL_DP_ELECTRIC_TEST_EN
0xC020050A Inout 32 [10.0.0+] NVDCUTIL_DP_ELECTRIC_TEST_SETTINGS
0x8070050B Out 112 [11.0.0+] NVDCUTIL_DP_CONF_READ

NVDCUTIL_VIRTUAL_EDID_ENABLE

Enables virtual EDID.

 struct {
   __in u8 enable;
 };

NVDCUTIL_VIRTUAL_EDID_SET_DATA

Sets virtual EDID data.

 struct {
   __in u8 edid[512];
   __in u32 edid_size;
 };

/dev/nvsched-ctrl

This is a customized scheduler device.

The way this device is exposed and configured is exclusive to the Switch, since other sources don't have an actual interface for the scheduler.

Value Direction Size Description
0x00000601 - 0 NVSCHED_CTRL_ENABLE
0x00000602 - 0 NVSCHED_CTRL_DISABLE
0x40180603 In 24 NVSCHED_CTRL_ADD_APPLICATION
0x40180604 In 24 NVSCHED_CTRL_UPDATE_APPLICATION
0x40080605 In 8 NVSCHED_CTRL_REMOVE_APPLICATION
0x80080606 Out 8 NVSCHED_CTRL_GET_ID
0x80080607 Out 8 NVSCHED_CTRL_ADD_RUNLIST
0x40180608 In 24 NVSCHED_CTRL_UPDATE_RUNLIST
0x40100609 In 16 NVSCHED_CTRL_LINK_RUNLIST
0x4010060A In 16 NVSCHED_CTRL_UNLINK_RUNLIST
0x4008060B In 8 NVSCHED_CTRL_REMOVE_RUNLIST
0x8001060C Out 1 NVSCHED_CTRL_HAS_OVERRUN_EVENT
0x8020060D
([1.0.0-3.0.0] 0x8010060D)
Out 32
([1.0.0-3.0.0] 16)
NVSCHED_CTRL_GET_NEXT_OVERRUN_EVENT
0x400C060E In 12 NVSCHED_CTRL_PUT_CONDUCTOR_FLIP_FENCE
0x4008060F In 8 NVSCHED_CTRL_DETACH_APPLICATION
0x40100610 In 16 NVSCHED_CTRL_SET_APPLICATION_MAX_DEBT
0x40100611 In 16 NVSCHED_CTRL_SET_RUNLIST_MAX_DEBT
0x40010612 In 1 NVSCHED_CTRL_OVERRUN_EVENTS_ENABLE

NVSCHED_CTRL_ENABLE

Enables the scheduler.

NVSCHED_CTRL_DISABLE

Disables the scheduler.

NVSCHED_CTRL_ADD_APPLICATION

Adds a new application to the scheduler.

 struct {
   __in u64 application_id;
   __in u64 priority;
   __in u64 timeslice;
 };

NVSCHED_CTRL_UPDATE_APPLICATION

Updates the application parameters in the scheduler.

 struct {
   __in u64 application_id;
   __in u64 priority;
   __in u64 timeslice;
 };

NVSCHED_CTRL_REMOVE_APPLICATION

Removes the application from the scheduler.

 struct {
   __in u64 application_id;
 };

NVSCHED_CTRL_GET_ID

Returns the ID of the last scheduled object.

 struct {
   __out u64 id;
 };

NVSCHED_CTRL_ADD_RUNLIST

Creates a new runlist and returns it's ID.

 struct {
   __out u64 runlist_id;
 };

NVSCHED_CTRL_UPDATE_RUNLIST

Updates the runlist parameters in the scheduler.

 struct {
   __in u64 runlist_id;
   __in u64 priority;
   __in u64 timeslice;
 };

NVSCHED_CTRL_LINK_RUNLIST

Links a runlist to a given application in the scheduler.

 struct {
   __in u64 runlist_id;
   __in u64 application_id;
 };

NVSCHED_CTRL_UNLINK_RUNLIST

Unlinks a runlist from a given application in the scheduler.

 struct {
   __in u64 runlist_id;
   __in u64 application_id;
 };

NVSCHED_CTRL_REMOVE_RUNLIST

Removes the runlist from the scheduler.

 struct {
   __in u64 runlist_id;
 };

NVSCHED_CTRL_HAS_OVERRUN_EVENT

Returns a boolean to tell if the scheduler has an overrun event or not.

 struct {
   __out u8 has_overrun;
 };

NVSCHED_CTRL_GET_NEXT_OVERRUN_EVENT

Returns the overrun event's data from the scheduler.

 struct {
   __out u64 runlist_id;
   __out u64 debt;
   __out u64 unk0;           // 3.0.0+ only
   __out u64 unk1;           // 3.0.0+ only
 };

NVSCHED_CTRL_PUT_CONDUCTOR_FLIP_FENCE

Installs a fence swap event?

 struct {
   __in u32 fence_id;
   __in u32 fence_value;
   __in u32 swap_interval;
 };

NVSCHED_CTRL_DETACH_APPLICATION

Places the given application in detached state.

 struct {
   __in u64 application_id;
 };

/dev/nverpt-ctrl

Added in firmware version 3.0.0.

Value Direction Size Description
0xC1280701 Inout 296 NVERPT_TELEMETRY_SUBMIT_DATA
0xCF580702 Inout 3928 NVERPT_TELEMETRY_SUBMIT_DISPLAY_DATA

NVERPT_TELEMETRY_SUBMIT_DATA

Unofficial name.

Sends test data for creating a new Error Report.

 struct {
   __in u64 TestU64;
   __in u32 TestU32;
   __in u8  padding0[4];
   __in s64 TestI64;
   __in s32 TestI32;
   __in u8  TestString[32];
   __in u8  TestU8Array[8];
   __in u32 TestU8Array_size;
   __in u32 TestU32Array[8];
   __in u32 TestU32Array_size;
   __in u64 TestU64Array[8];
   __in u32 TestU64Array_size;
   __in s32 TestI32Array[8];
   __in u32 TestI32Array_size;
   __in s64 TestI64Array[8];
   __in u32 TestI64Array_size;
   __in u16 TestU16;
   __in u8  TestU8;
   __in s16 TestI16;
   __in s8  TestI8;
   __in u8  padding1[5];
 };

NVERPT_TELEMETRY_SUBMIT_DISPLAY_DATA

Unofficial name.

Sends display data for creating a new Error Report.

 struct {
   __in u32 CodecType;
   __in u32 DecodeBuffers;
   __in u32 FrameWidth;
   __in u32 FrameHeight;
   __in u8  ColorPrimaries;
   __in u8  TransferCharacteristics;
   __in u8  MatrixCoefficients;
   __in u8  padding;
   __in u32 DisplayWidth;
   __in u32 DisplayHeight;
   __in u32 DARWidth;
   __in u32 DARHeight;
   __in u32 ColorFormat;
   __in u32 ColorSpace[8];
   __in u32 ColorSpace_size;
   __in u32 SurfaceLayout[8];
   __in u32 SurfaceLayout_size;
   __in u8  ErrorString[64];       // must be "Error detected = 0x1000000"
   __in u32 VideoDecState;
   __in u8  VideoLog[3712];
   __in u32 VideoLog_size;
 };

/dev/nvhost-as-gpu

Each fd opened to this device creates an address space. An address space is then later bound with a channel.

Once a nvgpu channel has been bound to an address space it cannot be unbound. There is no support for allowing an nvgpu channel to change from one address space to another (or from one to none).

Value Direction Size Description
0x40044101 In 4 NVGPU_AS_IOCTL_BIND_CHANNEL
0xC0184102 Inout 24 NVGPU_AS_IOCTL_ALLOC_SPACE
0xC0104103 Inout 16 NVGPU_AS_IOCTL_FREE_SPACE
0xC0184104 Inout 24 NVGPU_AS_IOCTL_MAP_BUFFER
0xC0084105 Inout 8 NVGPU_AS_IOCTL_UNMAP_BUFFER
0xC0284106 Inout 40 NVGPU_AS_IOCTL_MAP_BUFFER_EX
0x40104107 In 16 NVGPU_AS_IOCTL_ALLOC_AS
0xC0404108 Inout 64 NVGPU_AS_IOCTL_GET_VA_REGIONS
0x40284109 In 40 NVGPU_AS_IOCTL_ALLOC_AS_EX
0xC038410A Inout 56 NVGPU_AS_IOCTL_MAP_BUFFER_EX2
0x8010410B Out 16 [S2] NVGPU_AS_IOCTL_GET_SYNC_RO_MAP
0xC020410C Inout 32 [S2] NVGPU_AS_IOCTL_MAPPING_MODIFY
0xC???410D Inout Variable [S2] NVGPU_AS_IOCTL_REMAP
0xC0??4114 Inout Variable NVGPU_AS_IOCTL_REMAP

NVGPU_AS_IOCTL_BIND_CHANNEL

Identical to Linux driver.

 struct {
   __in u32 channel_fd;
 };

NVGPU_AS_IOCTL_ALLOC_SPACE

Reserves pages in the device address space.

 struct {
   __in u32 pages;
   __in u32 page_size;
   __in u32 flags;
   __in u32 padding;
   union {
     __out u64 offset;
     __in  u64 align;
   };
 };

NVGPU_AS_IOCTL_FREE_SPACE

Frees pages from the device address space.

 struct {
   __in u64 offset;
   __in u32 pages;
   __in u32 page_size;
 };

NVGPU_AS_IOCTL_MAP_BUFFER

Maps a memory region in the device address space.

Unaligned size will cause a #Panic.

On success, the mapped memory region is granted the DeviceShared attribute.

 struct {
   __in    u32 flags;        // bit0: fixed_offset, bit2: cacheable
   __inout u32 reserved0;
   __in    u32 mem_id;       // nvmap handle
   __inout u32 reserved1;
   union {
     __out u64 offset;
     __in  u64 align;
   };
 };

NVGPU_AS_IOCTL_MAP_BUFFER_EX

Maps a memory region in the device address space with extra params.

Unaligned size will cause a #Panic.

On success, the mapped memory region is granted the DeviceShared attribute.

 struct {
   __in      u32 flags;          // bit0: fixed_offset, bit2: cacheable
   __inout   u32 kind;           // -1 is default
   __in      u32 mem_id;         // nvmap handle
   __inout   u32 reserved;
   __in      u64 buffer_offset;
   __in      u64 mapping_size;
   union {
     __out   u64 offset;
     __in    u64 align;
   };
 };

NVGPU_AS_IOCTL_UNMAP_BUFFER

Unmaps a memory region from the device address space.

 struct {
   __in u64 offset;
 };

NVGPU_AS_IOCTL_ALLOC_AS

Nintendo's custom implementation for allocating an address space.

 struct {
   __in u32 big_page_size;   // depends on GPU's available_big_page_sizes; 0=default
   __in s32 as_fd;           // ignored; passes 0
   __in u64 reserved;        // ignored; passes 0
 };

NVGPU_AS_IOCTL_GET_VA_REGIONS

Nintendo's custom implementation to get rid of pointer in struct.

Uses Ioctl3.

 struct va_region {
   u64 offset;
   u32 page_size;
   u32 reserved;
   u64 pages;
 };
 
 struct {
   __inout u64   buf_addr;    // (contained output user ptr on linux, ignored)
   __inout u32   buf_size;    // forced to 2*sizeof(struct va_region)
   __inout u32   reserved;
   __out struct  va_region regions[2];
 };

NVGPU_AS_IOCTL_ALLOC_AS_EX

Nintendo's custom implementation for allocating an address space with extra params.

 struct {
   __in u32 big_page_size;   // depends on GPU's available_big_page_sizes; 0=default
   __in s32 as_fd;           // ignored; passes 0
   __in u32 flags;           // passes 0
   __in u32 reserved;        // ignored; passes 0
   __in u64 va_range_start;
   __in u64 va_range_end;
   __in u64 va_range_split;
 };

NVGPU_AS_IOCTL_MAP_BUFFER_EX2

Maps a memory region in the device address space with extra params.

Unaligned size will cause a #Panic.

On success, the mapped memory region is granted the DeviceShared attribute.

 struct {
   __in      u32 flags;          // bit0: fixed_offset, bit2: cacheable
   __inout   u32 kind;           // -1 is default
   __in      u32 mem_id;         // nvmap handle
   __inout   u32 reserved0;
   __in      u64 buffer_offset;
   __in      u64 mapping_size;
   union {
     __out   u64 offset;
     __in    u64 align;
   };
   __in      u64 vma_addr;
   __in      u32 pages;
   __inout   u32 reserved1;
 };

NVGPU_AS_IOCTL_GET_SYNC_RO_MAP

Returns the GPU virtual address to the read-only syncpoint-semaphore shim.

 struct {
   __out     u64 base_gpuva;
   __out     u32 sync_size;
   __out     u32 num_syncpoints;
 };

NVGPU_AS_IOCTL_MAPPING_MODIFY

Changes the kind of an existing mapped buffer region.

 struct {
   __in      s16 compr_kind;
   __in      s16 incompr_kind;
   __in      u64 buffer_offset;
   __in      u64 buffer_size;
   __in      u64 map_address;
 };

NVGPU_AS_IOCTL_REMAP

Nintendo's custom implementation of address space remapping for sparse pages.

 struct remap_op {
   u16 flags;                      // bit2: cacheable
   u16 kind;           
   u32 mem_handle;
   u32 mem_offset_in_pages;
   u32 virt_offset_in_pages;       // (alloc_space_offset >> 0x10)
   u32 num_pages;                  // alloc_space_pages
 };

 struct {
   __in struct remap_op entries[];
 };

NVGPU_AS_IOCTL_REMAP

Switch 2 variation of NVGPU_AS_IOCTL_REMAP.

 struct remap_op {
   u32 flags;
   s16 compr_kind;   
   s16 incompr_kind;        
   u32 mem_handle;
   u32 reserved;
   u64 mem_offset_in_pages;
   u64 virt_offset_in_pages;
   u64 num_pages;
 };

 struct {
   __in struct remap_op entries[];
 };

/dev/nvhost-dbg-gpu

Returns NotSupported on Open unless nn::settings::detail::GetDebugModeFlag is set.

Value Direction Size Description
0x40084401 In 8 NVGPU_DBG_GPU_IOCTL_BIND_CHANNEL
0xC0??4402 Inout Variable NVGPU_DBG_GPU_IOCTL_REG_OPS
0x40084403 In 8 NVGPU_DBG_GPU_IOCTL_EVENTS_CTRL
0x40044404 In 4 NVGPU_DBG_GPU_IOCTL_POWERGATE
0x40044405 In 4 NVGPU_DBG_GPU_IOCTL_SMPC_CTXSW_MODE
0x40044406 In 4 NVGPU_DBG_GPU_IOCTL_SUSPEND_RESUME_ALL_SMS
0xC0184407 Inout 24 NVGPU_DBG_GPU_IOCTL_PERFBUF_MAP
0x40084408 In 8 NVGPU_DBG_GPU_IOCTL_PERFBUF_UNMAP
0x40084409 In 8 NVGPU_DBG_GPU_IOCTL_PC_SAMPLING
0x4008440A In 8 NVGPU_DBG_GPU_IOCTL_TIMEOUT
0x8008440B Out 8 NVGPU_DBG_GPU_IOCTL_GET_TIMEOUT
0x8004440C Out 4 NVGPU_DBG_GPU_IOCTL_GET_GR_CONTEXT_SIZE
0x0000440D None 0 NVGPU_DBG_GPU_IOCTL_GET_GR_CONTEXT
0xC018440E Inout 24 NVGPU_DBG_GPU_IOCTL_ACCESS_FB_MEMORY
0xC018440F Inout 24 NVGPU_DBG_GPU_IOCTL_GET_GPU_VA_RANGE_NUM_PDES
0xC0104410 Inout 16 NVGPU_DBG_GPU_IOCTL_GET_GPU_VA_RANGE_PDES
0xC0184411 Inout 24 NVGPU_DBG_GPU_IOCTL_GET_GPU_VA_RANGE_NUM_PTES
0xC0104412 Inout 16 NVGPU_DBG_GPU_IOCTL_GET_GPU_VA_RANGE_PTES
0xC0684413
[S2] 0xC0304413
Inout 104
48
NVGPU_DBG_GPU_IOCTL_GET_COMPTAG_INFO
0xC0184414
[S2] 0xC0084414
Inout 24
8
NVGPU_DBG_GPU_IOCTL_READ_COMPTAGS
0xC0184415
[S2] 0xC0084415
Inout 24
8
NVGPU_DBG_GPU_IOCTL_WRITE_COMPTAGS
0xC0104416 Inout 16 NVGPU_DBG_GPU_IOCTL_RESERVE_COMPTAGS
0xC0104417 Inout 16 NVGPU_DBG_GPU_IOCTL_FREE_RESERVED_COMPTAGS
0xC0104418 Inout 16 NVGPU_DBG_GPU_IOCTL_RESERVE_PA
0xC0104419 Inout 16 NVGPU_DBG_GPU_IOCTL_FREE_RESERVED_PA
0xC018441A Inout 24 NVGPU_DBG_GPU_IOCTL_LAZY_ALLOC_RESERVED_PA
0xC020441B Inout 32 [11.0.0+] NVGPU_DBG_GPU_IOCTL_LAZY_ALLOC_RESERVED_PA_EX
0xC084441C Inout 132 [11.0.0+] NVGPU_DBG_GPU_IOCTL_GET_SETTINGS
0xC018441D Inout 24 [11.0.0+] NVGPU_DBG_GPU_IOCTL_GET_SERIAL_NUMBER
0xC020441E Inout 32 [11.0.0+] NVGPU_DBG_GPU_IOCTL_GET_GPU_VA_RANGE_PAGES
0x4008441F In 8 [S2]
0x00004420 None 0 [S2]
0xC0184421 Inout 24 [S2]
0x40084422 In 8 [S2] NVGPU_DBG_GPU_IOCTL_SET_CTX_MMU_DEBUG_MODE
0xC0084423 Inout 8 [S2] NVGPU_DBG_GPU_IOCTL_HWPM_CTXSW_MODE
0x40084424 In 8 [S2] NVGPU_DBG_GPU_IOCTL_SET_SM_EXCEPTION_TYPE_MASK
0xC0104425 Inout 16 [S2] NVGPU_DBG_GPU_IOCTL_SUSPEND_RESUME_CONTEXTS
0xC0184426 Inout 24 [S2] NVGPU_DBG_GPU_IOCTL_READ_SINGLE_SM_ERROR_STATE
0x40084427 In 8 [S2] NVGPU_DBG_GPU_IOCTL_CLEAR_SINGLE_SM_ERROR_STATE
0x40044428 In 4 [S2] NVGPU_DBG_GPU_IOCTL_SET_SCHED_EXIT_WAIT_FOR_ERRBAR
0xC0184429 Inout 24 [S2]
0x4010442A In 16 [S2]
0x4010442B In 16 [S2]

NVGPU_DBG_GPU_IOCTL_GET_GR_CONTEXT

Uses Ioctl3.

NVGPU_DBG_GPU_IOCTL_GET_GPU_VA_RANGE_PDES

Uses Ioctl3.

NVGPU_DBG_GPU_IOCTL_GET_GPU_VA_RANGE_PTES

Uses Ioctl3.

NVGPU_DBG_GPU_IOCTL_READ_COMPTAGS

Uses Ioctl3.

NVGPU_DBG_GPU_IOCTL_WRITE_COMPTAGS

Uses Ioctl2.

/dev/nvhost-prof-gpu

Returns NotSupported on Open unless nn::settings::detail::GetDebugModeFlag is set.

This device is identical to /dev/nvhost-dbg-gpu.

/dev/nvhost-ctrl-gpu

This device is for global (context independent) operations on the gpu.

Value Direction Size Description
0x80044701 Out 4 NVGPU_GPU_IOCTL_ZCULL_GET_CTX_SIZE
0x80284702 Out 40 NVGPU_GPU_IOCTL_ZCULL_GET_INFO
0x402C4703 In 44 NVGPU_GPU_IOCTL_ZBC_SET_TABLE
0xC0344704 Inout 52 NVGPU_GPU_IOCTL_ZBC_QUERY_TABLE
0xC0B04705
[S2] 0xC0E04705
Inout 176
[S2] 224
NVGPU_GPU_IOCTL_GET_CHARACTERISTICS
0xC0184706 Inout 24 NVGPU_GPU_IOCTL_GET_TPC_MASKS
0x40084707 In 8 NVGPU_GPU_IOCTL_FLUSH_L2
0x4008470D In 8 NVGPU_GPU_IOCTL_INVAL_ICACHE
0x4008470E In 8 NVGPU_GPU_IOCTL_SET_MMU_DEBUG_MODE
0x4010470F In 16 NVGPU_GPU_IOCTL_SET_SM_DEBUG_MODE
0xC0304710
([1.0.0-6.1.0] 0xC0084710)
[S2] 0xC0084710
Inout 48
([1.0.0-6.1.0] 8)
[S2] 8
NVGPU_GPU_IOCTL_WAIT_FOR_PAUSE
0x80084711 Out 8 NVGPU_GPU_IOCTL_GET_TPC_EXCEPTION_EN_STATUS
0x80084712 Out 8 NVGPU_GPU_IOCTL_NUM_VSMS
0xC0044713
[S2] 0xC0084713
Inout 4
[S2] 8
NVGPU_GPU_IOCTL_VSMS_MAPPING
0x80084714 Out 8 NVGPU_GPU_IOCTL_ZBC_GET_ACTIVE_SLOT_MASK
0x80044715 Out 4 NVGPU_GPU_IOCTL_PMU_GET_GPU_LOAD
0x40084716 In 8 NVGPU_GPU_IOCTL_SET_CG_CONTROLS
0xC0084717 Inout 8 NVGPU_GPU_IOCTL_GET_CG_CONTROLS
0x40084718 In 8 NVGPU_GPU_IOCTL_SET_PG_CONTROLS
0xC0084719 Inout 8 NVGPU_GPU_IOCTL_GET_PG_CONTROLS
0x8018471A Out 24 NVGPU_GPU_IOCTL_PMU_GET_ELPG_RESIDENCY_GATING
0xC008471B Inout 8 NVGPU_GPU_IOCTL_GET_ERROR_CHANNEL_USER_DATA
0xC010471C Inout 16 NVGPU_GPU_IOCTL_GET_GPU_TIME
0xC108471D Inout 264 NVGPU_GPU_IOCTL_GET_CPU_TIME_CORRELATION_INFO
0xC010471E Inout 16 [S2] NVGPU_GPU_IOCTL_SET_DETERMINISTIC_OPTS
0xC010471F Inout 16 [S2] NVGPU_GPU_IOCTL_GET_ENGINE_INFO

NVGPU_GPU_IOCTL_ZCULL_GET_CTX_SIZE

Returns the GPU's ZCULL context size. Identical to Linux driver.

 struct {
   __out u32 size;
 };

NVGPU_GPU_IOCTL_ZCULL_GET_INFO

Returns GPU's ZCULL information. Identical to Linux driver.

 struct {
   __out u32 width_align_pixels;
   __out u32 height_align_pixels;
   __out u32 pixel_squares_by_aliquots;
   __out u32 aliquot_total;
   __out u32 region_byte_multiplier;
   __out u32 region_header_size;
   __out u32 subregion_header_size;
   __out u32 subregion_width_align_pixels;
   __out u32 subregion_height_align_pixels;
   __out u32 subregion_count;
 };

NVGPU_GPU_IOCTL_ZBC_SET_TABLE

Sets the active ZBC table. Identical to Linux driver.

 struct {
   __in u32 color_ds[4];
   __in u32 color_l2[4];
   __in u32 depth;
   __in u32 format;
   __in u32 type;         // 1=color, 2=depth
 };

NVGPU_GPU_IOCTL_ZBC_QUERY_TABLE

Queries the active ZBC table. Identical to Linux driver.

 struct {
   __out u32 color_ds[4];
   __out u32 color_l2[4];
   __out u32 depth;
   __out u32 ref_cnt;
   __out u32 format;
   __out u32 type;
   __inout u32 index_size;
 };

NVGPU_GPU_IOCTL_GET_CHARACTERISTICS

Returns the GPU characteristics. Modified to return inline data instead of using a pointer.

[3.0.0+] Uses either Ioctl or Ioctl3.

 struct gpu_characteristics {
   u32 arch;                         // 0x120 (NVGPU_GPU_ARCH_GM200)
   u32 impl;                         // 0xB (NVGPU_GPU_IMPL_GM20B) or 0xE (NVGPU_GPU_IMPL_GM20B_B)
   u32 rev;                          // 0xA1 (Revision A1)
   u32 num_gpc;                      // 0x1
   u64 l2_cache_size;                // 0x40000
   u64 on_board_video_memory_size;   // 0x0 (not used)
   u32 num_tpc_per_gpc;              // 0x2
   u32 bus_type;                     // 0x20 (NVGPU_GPU_BUS_TYPE_AXI)
   u32 big_page_size;                // 0x20000
   u32 compression_page_size;        // 0x20000
   u32 pde_coverage_bit_count;       // 0x1B
   u32 available_big_page_sizes;     // 0x30000
   u32 gpc_mask;                     // 0x1
   u32 sm_arch_sm_version;           // 0x503 (Maxwell Generation 5.0.3)
   u32 sm_arch_spa_version;          // 0x503 (Maxwell Generation 5.0.3)
   u32 sm_arch_warp_count;           // 0x80
   u32 gpu_va_bit_count;             // 0x28
   u32 reserved;                     // 0x0
   u64 flags;                        // 0x55 (HAS_SYNCPOINTS | SUPPORT_SPARSE_ALLOCS | SUPPORT_CYCLE_STATS | SUPPORT_CYCLE_STATS_SNAPSHOT)
   u32 twod_class;                   // 0x902D (FERMI_TWOD_A)
   u32 threed_class;                 // 0xB197 (MAXWELL_B)
   u32 compute_class;                // 0xB1C0 (MAXWELL_COMPUTE_B)
   u32 gpfifo_class;                 // 0xB06F (MAXWELL_CHANNEL_GPFIFO_A)
   u32 inline_to_memory_class;       // 0xA140 (KEPLER_INLINE_TO_MEMORY_B)
   u32 dma_copy_class;               // 0xB0B5 (MAXWELL_DMA_COPY_A)
   u32 max_fbps_count;               // 0x1
   u32 fbp_en_mask;                  // 0x0 (disabled)
   u32 max_ltc_per_fbp;              // 0x2
   u32 max_lts_per_ltc;              // 0x1
   u32 max_tex_per_tpc;              // 0x0 (not supported)
   u32 max_gpc_count;                // 0x1
   u32 rop_l2_en_mask_0;             // 0x21D70 (fuse_status_opt_rop_l2_fbp_r)
   u32 rop_l2_en_mask_1;             // 0x0
   u64 chipname;                     // 0x6230326D67 ("gm20b")
   u64 gr_compbit_store_base_hw;     // 0x0 (not supported)
 };

 struct {
   __inout u64 gpu_characteristics_buf_size;   // must not be NULL, but gets overwritten with 0xA0=max_size
   __in    u64 gpu_characteristics_buf_addr;   // ignored, but must not be NULL
   __out struct gpu_characteristics gc;
 };

[S2] Uses Ioctl3.

 struct gpu_characteristics {
   u32 arch;                         // 0x170
   u32 impl;                         // 0xE
   u32 rev;                          // 0xA1 (Revision A1)
   u32 num_gpc;                      // 0x1
   u64 l2_cache_size;                // 0x100000
   u64 on_board_video_memory_size;   // 0x0 (not used)
   u32 num_tpc_per_gpc;              // 0x6
   u32 bus_type;                     // 0x20 (NVGPU_GPU_BUS_TYPE_AXI)
   u32 big_page_size;                // 0x0
   u32 compression_page_size;        // 0x10000
   u32 pde_coverage_bit_count;       // 0x15
   u32 available_big_page_sizes;     // 0x0
   u32 gpc_mask;                     // 0x1
   u32 sm_arch_sm_version;           // 0x808
   u32 sm_arch_spa_version;          // 0x806
   u32 sm_arch_warp_count;           // 0x60
   u32 gpu_va_bit_count;             // 0x28
   u32 reserved;                     // 0x0
   u64 flags;                        // 0x935FAF1EDC0155
   u32 twod_class;                   // 0x902D (FERMI_TWOD_A)
   u32 threed_class;                 // 0xC797 (AMPERE_B)
   u32 compute_class;                // 0xC7C0 (AMPERE_COMPUTE_B)
   u32 gpfifo_class;                 // 0xC76F (AMPERE_CHANNEL_GPFIFO_B)
   u32 inline_to_memory_class;       // 0xA140 (KEPLER_INLINE_TO_MEMORY_B)
   u32 dma_copy_class;               // 0xC7B5 (AMPERE_DMA_COPY_B)
   s16 gpu_ioctl_nr_last;            // 0x1F
   s16 tsg_ioctl_nr_last;            // 0xF
   s16 dbg_gpu_ioctl_nr_last;        // 0x2B
   s16 ioctl_channel_nr_last;        // 0x21
   s16 as_ioctl_nr_last;             // 0xD
   s16 unk0_ioctl_nr_last;           // 0xFFFF
   s16 unk1_ioctl_nr_last;           // 0xFFFF
   s16 unk2_ioctl_nr_last;           // 0xFFFF
   u32 max_fbps_count;               // 0x0
   u32 fbp_en_mask;                  // 0x1
   u32 emc_en_mask;                  // 0x1
   u32 max_ltc_per_fbp;              // 0x1
   u32 max_lts_per_ltc;              // 0x4
   u32 max_tex_per_tpc;              // 0x0
   u32 max_gpc_count;                // 0x1
   u32 rop_l2_en_mask_DEPRECATED_0;  // 0x0
   u32 rop_l2_en_mask_DEPRECATED_1;  // 0x0
   u64 chipname;                     // 0x6761313066 ("ga10f")
   u32 unk0;                         // 0x0
   u32 unk1;                         // 0x2
   u32 unk2;                         // 0x40
   u32 unk3;                         // 0x3
   u32 unk4;                         // 0x7
   u32 unk5;                         // 0x1
   u32 unk6;                         // 0x1
   u32 unk7;                         // 0x0
   u32 unk8;                         // 0x0
 };
 
 struct in_buf {
   __in u64 gpu_characteristics_buf_size;   // must not be NULL, but gets overwritten with 0xD0=max_size
   __in u8 reserved[0xD8];
 };
 
 struct out_buf {
   __out u8 reserved[0xE0];
 };
 
 struct out_buf2 {
   __out struct gpu_characteristics gc;
 };

NVGPU_GPU_IOCTL_GET_TPC_MASKS

Returns the TPC mask value for each GPC. Modified to return inline data instead of using a pointer.

[3.0.0+] Uses either Ioctl or Ioctl3.

 struct {
   __in u32 mask_buf_size;       // ignored, but must not be NULL
   __inout u32 reserved[3];
   __out u64 mask_buf;           // receives one 32-bit TPC mask per GPC (GPC 0 and GPC 1)
 };

NVGPU_GPU_IOCTL_FLUSH_L2

Flushes the GPU L2 cache.

 struct {
   __in u32 flush;          // l2_flush | l2_invalidate << 1 | fb_flush << 2
   __in u32 reserved;
 };

NVGPU_GPU_IOCTL_INVAL_ICACHE

Invalidates the GPU instruction cache. Identical to Linux driver.

 struct {
   __in s32 channel_fd;
   __in u32 reserved;
 };

NVGPU_GPU_IOCTL_SET_MMU_DEBUG_MODE

Sets the GPU MMU debug mode. Identical to Linux driver.

 struct {
   __in u32 state;
   __in u32 reserved;
 };

NVGPU_GPU_IOCTL_SET_SM_DEBUG_MODE

Sets the GPU SM debug mode. Identical to Linux driver.

 struct {
   __in s32 channel_fd;
   __in u32 enable;
   __in u64 sms;
 };

NVGPU_GPU_IOCTL_WAIT_FOR_PAUSE

Waits until all valid warps on the GPU SM are paused and returns their current state.

 struct {
   __in u64 pwarpstate;
 };

[6.1.0+] This command was modified to return inline data instead of using a pointer.

 struct {
   __out u64 sm0_valid_warps;
   __out u64 sm0_trapped_warps;
   __out u64 sm0_paused_warps;
   __out u64 sm1_valid_warps;
   __out u64 sm1_trapped_warps;
   __out u64 sm1_paused_warps;
 };

NVGPU_GPU_IOCTL_GET_TPC_EXCEPTION_EN_STATUS

Returns a mask value describing all active TPC exceptions. Identical to Linux driver.

 struct {
   __out u64 tpc_exception_en_sm_mask;
 };

NVGPU_GPU_IOCTL_NUM_VSMS

Returns the number of GPU SM units present. Identical to Linux driver.

 struct {
   __out u32 num_vsms;
   __out u32 reserved;
 };

NVGPU_GPU_IOCTL_VSMS_MAPPING

Returns mapping information on each GPU SM unit. Modified to return inline data instead of using a pointer.

 struct {
   __out u8 sm0_gpc_index;
   __out u8 sm0_tpc_index;
   __out u8 sm1_gpc_index;
   __out u8 sm1_tpc_index;
 };

NVGPU_GPU_IOCTL_ZBC_GET_ACTIVE_SLOT_MASK

Returns the mask value for a ZBC slot.

 struct {
   __out u32 slot;       // always 0x07
   __out u32 mask;
 };

NVGPU_GPU_IOCTL_PMU_GET_GPU_LOAD

Returns the GPU load value from the PMU.

 struct {
   __out u32 pmu_gpu_load;
 };

NVGPU_GPU_IOCTL_SET_CG_CONTROLS

Sets the clock gate control value.

 struct {
   __in u32 cg_mask;
   __in u32 cg_value;
 };

NVGPU_GPU_IOCTL_GET_CG_CONTROLS

Returns the clock gate control value.

 struct {
   __in u32 cg_mask;
   __out u32 cg_value;
 };

NVGPU_GPU_IOCTL_SET_PG_CONTROLS

Sets the power gate control value.

 struct {
   __in u32 pg_mask;
   __in u32 pg_value;
 };

NVGPU_GPU_IOCTL_GET_PG_CONTROLS

Returns the power gate control value.

 struct {
   __in u32 pg_mask;
   __out u32 pg_value;
 };

NVGPU_GPU_IOCTL_PMU_GET_ELPG_RESIDENCY_GATING

Returns the GPU PMU ELPG residency gating values.

 struct {
   __out u64 pg_ingating_time_us;
   __out u64 pg_ungating_time_us;
   __out u64 pg_gating_cnt;
 };

NVGPU_GPU_IOCTL_GET_ERROR_CHANNEL_USER_DATA

Returns user specific data from the error channel, if one exists.

 struct {
   __out u64 data;
 };

NVGPU_GPU_IOCTL_GET_GPU_TIME

Returns the timestamp from the GPU's nanosecond timer (PTIMER). Identical to Linux driver.

 struct {
   __out u64 gpu_timestamp;      // raw GPU counter (PTIMER) value
   __out u64 reserved;
 };

NVGPU_GPU_IOCTL_GET_CPU_TIME_CORRELATION_INFO

Returns CPU/GPU timestamp pairs for correlation analysis. Identical to Linux driver.

 struct time_correlation_sample {
   u64 cpu_timestamp;                                  // from CPU's CNTPCT_EL0 register
   u64 gpu_timestamp;                                  // from GPU's PTIMER registers
 };

 struct {
   __out struct time_correlation_sample samples[16];   // timestamp pairs
   __in u32     count;                                 // number of pairs to read
   __in u32     source_id;                             // cpu clock source id (must be 1)
 };

NVGPU_GPU_IOCTL_SET_DETERMINISTIC_OPTS

Adjusts options of deterministic channels in channel batches.

Uses Ioctl2.

 struct deterministic_opts {
   __inout u32 num_channels;
   __in u32 flags;
   __in u64 channels;                           // ignored
 };
 
 struct in_buf {
   __in struct deterministic_opts opts;
 };
 
 struct in_buf2 {
   __in u32 channels[num_channels];
 };
 
 struct out_buf {
   __out struct deterministic_opts opts;
 };

NVGPU_GPU_IOCTL_GET_ENGINE_INFO

Returns information on graphics engines.

Uses Ioctl3.

 struct engine_info {
   __inout u32 engine_info_buf_size;
   __in u32 reserved;
   __in u64 engine_info_buf_addr;                    // ignored
 };
 
 struct engine_info_item {
   __out u32 engine_id;
   __out u32 engine_instance;
   __out s32 runlist_id;
   __out u32 reserved;
 };
 
 struct in_buf {
   __in struct engine_info info;
 };
 
 struct out_buf {
   __out struct engine_info info;    
 };
 
 struct out_buf2 {
   __out struct engine_info_item items[engine_info_buf_size];
 };

(S2) /dev/nvhost-prof-dev-gpu

Value Direction Size Description
0x40085001 In 8 NVGPU_PROFILER_IOCTL_BIND_CONTEXT
0x40105002 In 16 NVGPU_PROFILER_IOCTL_RESERVE_PM_RESOURCE
0x40085003 In 8 NVGPU_PROFILER_IOCTL_RELEASE_PM_RESOURCE
0xC0305004 Inout 48 NVGPU_PROFILER_IOCTL_ALLOC_PMA_STREAM
0x00005005 None 0 NVGPU_PROFILER_IOCTL_FREE_PMA_STREAM
0x00005006 None 0 NVGPU_PROFILER_IOCTL_BIND_PM_RESOURCES
0x00005007 None 0 NVGPU_PROFILER_IOCTL_UNBIND_PM_RESOURCES
0xC0285008 Inout 40 NVGPU_PROFILER_IOCTL_PMA_STREAM_UPDATE_GET_PUT
0xC0205009 Inout 32 NVGPU_PROFILER_IOCTL_EXEC_REG_OPS
0x0000500A None 0 NVGPU_PROFILER_IOCTL_UNBIND_CONTEXT
0x4010500B In 16 NVGPU_PROFILER_IOCTL_VAB_RESERVE
0x0000500C None 0 NVGPU_PROFILER_IOCTL_VAB_RELEASE
0x4010500D In 16 NVGPU_PROFILER_IOCTL_VAB_FLUSH_STATE

(S2) /dev/nvhost-tsg-gpu

Value Direction Size Description
0xC0045401 Inout 4 NVGPU_TSG_IOCTL_BIND_CHANNEL
0xC0045402 Inout 4 NVGPU_TSG_IOCTL_UNBIND_CHANNEL
0x00005403 None 0 NVGPU_TSG_IOCTL_ENABLE
0x00005404 None 0 NVGPU_TSG_IOCTL_DISABLE
0x00005405 None 0 NVGPU_TSG_IOCTL_PREEMPT
0xC0085407 Inout 8 NVGPU_TSG_IOCTL_SET_RUNLIST_INTERLEAVE
0xC0045408 Inout 4 NVGPU_TSG_IOCTL_SET_TIMESLICE
0xC0105409 Inout 16 NVGPU_TSG_IOCTL_EVENT_ID_CTRL
0x8004540A Out 4 NVGPU_TSG_IOCTL_GET_TIMESLICE
0xC018540B Inout 24 NVGPU_TSG_IOCTL_BIND_CHANNEL_EX
0xC018540C Inout 24 NVGPU_TSG_IOCTL_READ_SINGLE_SM_ERROR_STATE
0xC008540D Inout 8 NVGPU_TSG_IOCTL_SET_L2_SECTOR_PROMOTION

NVGPU_TSG_IOCTL_BIND_CHANNEL

Binds a channel to the TSG.

 struct {
   __in s32 channel_fd;
 };

NVGPU_TSG_IOCTL_UNBIND_CHANNEL

Unbinds a channel from the TSG.

 struct {
   __in s32 channel_fd;
 };

NVGPU_TSG_IOCTL_ENABLE

Enables the TSG in runlist.

NVGPU_TSG_IOCTL_DISABLE

Disables the TSG in runlist.

NVGPU_TSG_IOCTL_PREEMPT

Preempts the TSG.

NVGPU_TSG_IOCTL_SET_RUNLIST_INTERLEAVE

Configures interleaving channels in a runlist.

 struct {
   __in u32 level;
   __in u32 reserved;
 };

NVGPU_TSG_IOCTL_SET_TIMESLICE

Sets how long a channel occupies an engine uninterrupted.

 struct {
   __in u32 timeslice_us;
 };

NVGPU_TSG_IOCTL_EVENT_ID_CTRL

Controls event notifications.

 struct {
   __in u32 cmd;
   __in u32 event_id;
   __out s32 event_fd;
   __in u32 padding;
 };

NVGPU_TSG_IOCTL_GET_TIMESLICE

Gets how long a channel occupies an engine uninterrupted.

 struct {
   __out u32 timeslice_us;
 };

NVGPU_TSG_IOCTL_BIND_CHANNEL_EX

Binds a channel to the TSG of the node receiving the command.

 struct {
   __in s32 channel_fd;
   __in u32 subcontext_id;
   __in u32 reserved[4];
 };

NVGPU_TSG_IOCTL_READ_SINGLE_SM_ERROR_STATE

Reads the error state of a single SM.

Uses Ioctl3.

 struct single_sm_error_state {
   __in u32 sm_id;
   __inout u32 reserved;
   __inout u64 record_mem;
   __in u64 record_size;
 };
 
 struct in_buf {
   __in struct single_sm_error_state state;
 };
 
 struct out_buf {
   __out struct single_sm_error_state state;
 };
 
 struct out_buf2 {
   __out u8 state[];
 };

NVGPU_TSG_IOCTL_SET_L2_SECTOR_PROMOTION

Configures L2 sector promotion.

 struct {
   __in u32 promotion_flag;
   __in u32 reserved;
 };

Channels

Channels are a concept for NVIDIA hardware blocks that share a common interface.

Path Name
/dev/nvhost-gpu GPU
/dev/nvhost-msenc Video Encoder
/dev/nvhost-nvdec Video Decoder
/dev/nvhost-nvjpg JPEG Decoder
/dev/nvhost-vic Video Image Compositor
/dev/nvhost-display Display
/dev/nvhost-tsec TSEC

Ioctls

Value Direction Size Description
0xC0??0001 Inout Variable NVHOST_IOCTL_CHANNEL_SUBMIT
0xC0080002 Inout 8 NVHOST_IOCTL_CHANNEL_GET_SYNCPOINT
0xC0080003 Inout 8 NVHOST_IOCTL_CHANNEL_GET_WAITBASE
0xC0080004 Inout 8 NVHOST_IOCTL_CHANNEL_GET_MODMUTEX
0x40040007 In 4 NVHOST_IOCTL_CHANNEL_SET_SUBMIT_TIMEOUT
0x40080008 In 8 NVHOST_IOCTL_CHANNEL_SET_CLK_RATE
0xC0??0009 Inout Variable NVHOST_IOCTL_CHANNEL_MAP_CMD_BUFFER
0xC0??000A Inout Variable NVHOST_IOCTL_CHANNEL_UNMAP_CMD_BUFFER
0x00000013 None 0 NVHOST_IOCTL_CHANNEL_SET_TIMEOUT_EX
0xC0080023
([1.0.0-7.0.1] 0xC0080014)
Inout 8 NVHOST_IOCTL_CHANNEL_GET_CLK_RATE
0xC0??0024 Inout Variable NVHOST_IOCTL_CHANNEL_SUBMIT_EX
0xC0??0025 Inout Variable NVHOST_IOCTL_CHANNEL_MAP_CMD_BUFFER_EX
0xC0??0026 Inout Variable NVHOST_IOCTL_CHANNEL_UNMAP_CMD_BUFFER_EX
0x40044801 In 4 NVGPU_IOCTL_CHANNEL_SET_NVMAP_FD
0x40044803 In 4 NVGPU_IOCTL_CHANNEL_SET_TIMEOUT
0x40084805 In 8 NVGPU_IOCTL_CHANNEL_ALLOC_GPFIFO
0x40184806 In 24 NVGPU_IOCTL_CHANNEL_WAIT
0xC0044807 Inout 4 NVGPU_IOCTL_CHANNEL_CYCLE_STATS
0xC0??4808 Inout Variable NVGPU_IOCTL_CHANNEL_SUBMIT_GPFIFO
0xC0104809 Inout 16 NVGPU_IOCTL_CHANNEL_ALLOC_OBJ_CTX
0x4008480A In 8 NVHOST_IOCTL_CHANNEL_FREE_OBJ_CTX
0xC010480B Inout 16 NVGPU_IOCTL_CHANNEL_ZCULL_BIND
0xC018480C Inout 24 NVGPU_IOCTL_CHANNEL_SET_ERROR_NOTIFIER
0x4004480D In 4 NVGPU_IOCTL_CHANNEL_SET_PRIORITY
0x0000480E None 0 NVGPU_IOCTL_CHANNEL_ENABLE
0x0000480F None 0 NVGPU_IOCTL_CHANNEL_DISABLE
0x00004810 None 0 NVGPU_IOCTL_CHANNEL_PREEMPT
0x00004811 None 0 NVGPU_IOCTL_CHANNEL_FORCE_RESET
0x40084812
[S2] 0x40104812
In 8
[S2] 16
NVGPU_IOCTL_CHANNEL_EVENT_ID_CONTROL
0xC0104813 Inout 16 NVGPU_IOCTL_CHANNEL_CYCLE_STATS_SNAPSHOT
0x40084714 In 8 NVGPU_IOCTL_CHANNEL_SET_USER_DATA
0x80084715 Out 8 NVGPU_IOCTL_CHANNEL_GET_USER_DATA
0x80804816 Out 128 NVGPU_IOCTL_CHANNEL_GET_ERROR_INFO
0xC0104817 Inout 16 NVGPU_IOCTL_CHANNEL_GET_ERROR_NOTIFICATION
0x40204818 In 32 NVGPU_IOCTL_CHANNEL_ALLOC_GPFIFO_EX
0xC0??4819 Inout Variable NVGPU_IOCTL_CHANNEL_SUBMIT_GPFIFO_RETRY
0xC020481A Inout 32 NVGPU_IOCTL_CHANNEL_ALLOC_GPFIFO_EX2
0xC018481B Inout 24 NVGPU_IOCTL_CHANNEL_SUBMIT_GPFIFO2
0xC018481C Inout 24 NVGPU_IOCTL_CHANNEL_SUBMIT_GPFIFO2_RETRY
0xC004481D Inout 4 NVGPU_IOCTL_CHANNEL_SET_TIMESLICE
0xC010481E Inout 16 [S2] NVGPU_IOCTL_CHANNEL_GET_USER_SYNCPOINT
0xC008481F Inout 8 [S2] NVGPU_IOCTL_CHANNEL_SET_PREEMPTION_MODE
0x40044820 In 4 [S2] NVGPU_IOCTL_CHANNEL_OPEN
0xC0504821 Inout 80 [S2] NVGPU_IOCTL_CHANNEL_SETUP_BIND

NVHOST_IOCTL_CHANNEL_SUBMIT

Submits data to the channel.

 struct cmdbuf {
   u32 mem;
   u32 offset;
   u32 words;
 };
 
 struct reloc {
   u32 cmdbuf_mem;
   u32 cmdbuf_offset;
   u32 target;
   u32 target_offset;
 };
 
 struct reloc_shift {
   u32 shift;
 };
 
 struct syncpt_incr {
   u32 syncpt_id;
   u32 syncpt_incrs;
   u32 reserved[3];
 };
 
 struct {
   __in    u32 num_cmdbufs;
   __in    u32 num_relocs;
   __in    u32 num_syncpt_incrs;
   __in    u32 num_fences;
   __in    struct cmdbuf cmdbufs[];               // depends on num_cmdbufs
   __in    struct reloc relocs[];                 // depends on num_relocs
   __in    struct reloc_shift reloc_shifts[];     // depends on num_relocs
   __in    struct syncpt_incr syncpt_incrs[];     // depends on num_syncpt_incrs
   __out   u32 fence_thresholds[];                // depends on num_fences
 };

NVHOST_IOCTL_CHANNEL_GET_SYNCPOINT

Returns the current syncpoint value for a given module. Identical to Linux driver.

 struct {
   __in    u32 module_id;
   __out   u32 syncpt_value;
 };

NVHOST_IOCTL_CHANNEL_GET_WAITBASE

Returns the current waitbase value for a given module. Always returns 0.

 struct {
   __in    u32 module_id;
   __out   u32 waitbase_value;
 };

NVHOST_IOCTL_CHANNEL_GET_MODMUTEX

Stubbed. Does a debug print and returns 0.

NVHOST_IOCTL_CHANNEL_SET_SUBMIT_TIMEOUT

Sets the submit timeout value for the channel. Identical to Linux driver.

 struct {
   __in    u32 timeout;
 };

NVHOST_IOCTL_CHANNEL_SET_CLK_RATE

Sets the clock rate value for a given module. Identical to Linux driver.

 struct {
   __in    u32 clk_rate;
   __in    u32 module_id;
 };

NVHOST_IOCTL_CHANNEL_MAP_CMD_BUFFER

Uses nvmap_pin internally to pin a given number of nvmap handles to an appropriate device physical address.

 struct handle {
   u32 handle_id_in;                 // nvmap handle to map
   u32 phys_addr_out;                // returned device physical address mapped to the handle
 };
 
 struct {
   __in    u32 num_handles;          // number of nvmap handles to map
   __in    u32 reserved;             // ignored
   __in    u8  is_compr;             // memory to map is compressed
   __in    u8  padding[3];           // ignored
   __inout struct handle handles[];  // depends on num_handles
 };

NVHOST_IOCTL_CHANNEL_UNMAP_CMD_BUFFER

Uses nvmap_unpin internally to unpin a given number of nvmap handles from their device physical address.

 struct handle {
   u32 handle_id_in;                 // nvmap handle to unmap
   u32 reserved;                     // ignored
 };
 
 struct {
   __in    u32 num_handles;          // number of nvmap handles to unmap
   __in    u32 reserved;             // ignored
   __in    u8  is_compr;             // memory to unmap is compressed
   __in    u8  padding[3];           // ignored
   __inout struct handle handles[];  // depends on num_handles
 };

NVHOST_IOCTL_CHANNEL_SET_TIMEOUT_EX

Sets the global timeout value for the channel. Identical to Linux driver.

 struct {
   __in    u32 timeout;
   __in    u32 flags;
 };

NVHOST_IOCTL_CHANNEL_GET_CLK_RATE

Returns the clock rate value for a given module. Identical to Linux driver.

 struct {
   __out   u32 clk_rate;
   __in    u32 module_id;
 };

NVHOST_IOCTL_CHANNEL_SUBMIT_EX

Same as NVHOST_IOCTL_CHANNEL_SUBMIT.

NVHOST_IOCTL_CHANNEL_MAP_CMD_BUFFER_EX

Same as NVHOST_IOCTL_CHANNEL_MAP_CMD_BUFFER, but calls nvmap_unpin internally in case of error.

NVHOST_IOCTL_CHANNEL_UNMAP_CMD_BUFFER_EX

Same as NVHOST_IOCTL_CHANNEL_UNMAP_CMD_BUFFER.

NVGPU_IOCTL_CHANNEL_SET_NVMAP_FD

Binds a nvmap object to this channel. Identical to Linux driver.

 struct {
   __in u32 nvmap_fd;
 };

NVGPU_IOCTL_CHANNEL_SET_TIMEOUT

Sets the timeout value for the GPU channel. Identical to Linux driver.

 struct {
   __in u32 timeout;
 };

NVGPU_IOCTL_CHANNEL_ALLOC_GPFIFO

Allocates gpfifo entries. Identical to Linux driver.

 struct {
   __in u32 num_entries;
   __in u32 flags;           // bit0: vpr_enabled
 };

NVGPU_IOCTL_CHANNEL_WAIT

Waits on channel. Identical to Linux driver.

 struct {
   __in u32 type;            // wait type (0=notifier, 1=semaphore)
   __in u32 timeout;         // wait timeout value
   __in u32 dmabuf_fd;       // nvmap handle
   __in u32 offset;          // nvmap memory offset
   __in u32 payload;         // payload data (semaphore only)
   __in u32 padding;         // ignored
 };

NVGPU_IOCTL_CHANNEL_CYCLE_STATS

Maps memory for the cycle stats buffer. Identical to Linux driver.

 struct {
   __in u32 dmabuf_fd;   // nvmap handle
 };

NVGPU_IOCTL_CHANNEL_SUBMIT_GPFIFO

Submits a gpfifo object. Modified to take inline entry objects instead of a pointer.

 struct fence {
   u32 id;
   u32 value;
 };
 
 struct gpfifo_entry {
   u32 entry0;                              // gpu_iova_lo
   u32 entry1;                              // gpu_iova_hi | (allow_flush << 8) | (is_push_buf << 9) | (size << 10) | (sync << 31)
 };
 
 struct {
   __in    u64 gpfifo;                      // (ignored) pointer to gpfifo fence structs
   __in    u32 num_entries;                 // number of fence objects being submitted
   union {
     __out u32 detailed_error;
     __in  u32 flags;                       // bit0: fence_wait, bit1: fence_get, bit2: hw_format, bit3: sync_fence, bit4: suppress_wfi, bit5: skip_buffer_refcounting
   };
   __inout struct fence fence_out;          // returned new fence object for others to wait on
   __in    struct gpfifo_entry entries[];   // depends on num_entries
 };

NVGPU_IOCTL_CHANNEL_ALLOC_OBJ_CTX

Allocates a graphics context object. Modified to ignore object's ID.

You can only have one object context allocated at a time. You must have bound an address space before using this.

 struct {
   __in  u32 class_num;    // 0x902D=2d, 0xB197=3d, 0xB1C0=compute, 0xA140=kepler, 0xB0B5=DMA, 0xB06F=channel_gpfifo
   __in  u32 flags;        // bit0: LOCKBOOST_ZERO
   __out u64 obj_id;       // (ignored) used for FREE_OBJ_CTX ioctl, which is not supported
 };

NVHOST_IOCTL_CHANNEL_FREE_OBJ_CTX

Frees a graphics context object. Not supported.

 struct {
   __in u64 obj_id;       // ignored
 };

NVGPU_IOCTL_CHANNEL_ZCULL_BIND

Binds a ZCULL context to the channel. Identical to Linux driver.

 struct {
   __in u64 gpu_va;
   __in u32 mode;         // 0=global, 1=no_ctxsw, 2=separate_buffer, 3=part_of_regular_buf
   __in u32 reserved;
 };

NVGPU_IOCTL_CHANNEL_SET_ERROR_NOTIFIER

Initializes the error notifier for this channel. Unlike for the Linux kernel, the Switch driver cannot write to an arbitrary userspace buffer. Thus new ioctls have been introduced to fetch the error information rather than using a shared memory buffer.

 struct {
   __in u64 offset;   // ignored
   __in u64 size;     // ignored
   __in u32 mem;      // must be non-zero to initialize, zero to de-initialize
   __in u32 reserved; // ignored
 };

NVGPU_IOCTL_CHANNEL_SET_PRIORITY

Changes channel's priority. Identical to Linux driver.

 struct {
   __in u32 priority;    // 0x32 is low, 0x64 is medium and 0x96 is high
 };

NVGPU_IOCTL_CHANNEL_ENABLE

Enables the current channel. Identical to Linux driver.

NVGPU_IOCTL_CHANNEL_DISABLE

Disables the current channel. Identical to Linux driver.

NVGPU_IOCTL_CHANNEL_PREEMPT

Clears the FIFO pipe for this channel. Identical to Linux driver.

NVGPU_IOCTL_CHANNEL_FORCE_RESET

Forces the channel to reset. Identical to Linux driver.

NVGPU_IOCTL_CHANNEL_EVENT_ID_CONTROL

Controls event notifications.

 struct {
   __in u32 cmd;    // 0=disable, 1=enable, 2=clear
   __in u32 id;     // same id's as for #QueryEvent
 };

NVGPU_IOCTL_CHANNEL_CYCLE_STATS_SNAPSHOT

Controls the cycle stats snapshot buffer. Identical to Linux driver.

 struct {
   __in    u32 cmd;         // command to handle (0=flush, 1=attach, 2=detach)
   __in    u32 dmabuf_fd;   // nvmap handle
   __inout u32 extra;       // extra payload data/result
   __in    u32 padding;     // ignored
 };

NVGPU_IOCTL_CHANNEL_GET_ERROR_INFO

Returns information on the current error notification caught by the error notifier. Exclusive to the Switch.

 struct {
   __out u32 type;     // Error type (0=no_error, 1=mmu_error, 2=gr_error, 3=pbdma_error, 4=timeout)
   __out u32 info[31]; // Infor depends on the error type
 }; 

GR Error Code Format

When type == 2 (GR Error), the returned data is formatted as follows:

 struct {
   __out u32 type;       // 2=gr_error
   __out u32 intr_value; // Interrupt bits
   __out u32 addr;       // Register address (in bytes)
   __out u32 data_hi;    // Data high 32 bits
   __out u32 data_lo;    // Data low 32 bits
   __out u32 class_num;  // GPU class number (e.g., 0xb197 for MAXWELL_B)
 }; 

GR Error Interrupt Bits:

Bits Description
0 GR_INTR_NOTIFY
1 GR_INTR_SEMAPHORE
2
3
4 GR_INTR_ILLEGAL_METHOD
5 GR_INTR_ILLEGAL_CLASS
6 GR_INTR_ILLEGAL_NOTIFY
7
8 GR_INTR_FIRMWARE_METHOD
9–18
19 GR_INTR_FECS_ERROR
20 GR_INTR_CLASS_ERROR
21 GR_INTR_EXCEPTION
22–31

NVGPU_IOCTL_CHANNEL_GET_ERROR_NOTIFICATION

Returns the current error notification caught by the error notifier. Exclusive to the Switch.

 struct {
   __out u64 timestamp;    // fetched straight from armGetSystemTick
   __out u32 info32;       // error code
   __out u16 info16;       // additional error info
   __out u16 status;       // always 0xFFFF
 };

NVGPU_IOCTL_CHANNEL_ALLOC_GPFIFO_EX

Allocates gpfifo entries with additional parameters. Exclusive to the Switch.

 struct fence {
   u32 id;
   u32 value;
 };

 struct {
   __in    u32 num_entries;
   __in    u32 num_jobs;
   __in    u32 flags;                       // bit0: vpr_enabled
   __out   struct fence fence_out;          // returned new fence object for others to wait on
   __in    u32 reserved[3];                 // ignored
 };

NVGPU_IOCTL_CHANNEL_SUBMIT_GPFIFO_RETRY

Same as NVGPU_IOCTL_CHANNEL_SUBMIT_GPFIFO.

NVGPU_IOCTL_CHANNEL_ALLOC_GPFIFO_EX2

Same as NVGPU_IOCTL_CHANNEL_ALLOC_GPFIFO_EX.

NVGPU_IOCTL_CHANNEL_SUBMIT_GPFIFO2

Same as NVGPU_IOCTL_CHANNEL_SUBMIT_GPFIFO, but uses Ioctl2.

NVGPU_IOCTL_CHANNEL_SUBMIT_GPFIFO2_RETRY

Same as NVGPU_IOCTL_CHANNEL_SUBMIT_GPFIFO_RETRY, but uses Ioctl2.

NVGPU_IOCTL_CHANNEL_SET_TIMESLICE

Changes channel's timeslice. Identical to Linux driver.

 struct {
   __in u32 timeslice;
 };

NVGPU_IOCTL_CHANNEL_SET_USER_DATA

Sets user specific data.

 struct {
   __in u64 data;
 };

NVGPU_IOCTL_CHANNEL_GET_USER_DATA

Returns user specific data.

 struct {
   __out u64 data;
 };

NVGPU_IOCTL_CHANNEL_GET_USER_SYNCPOINT

Returns information on the user syncpoint.

 struct {
   __out u64 gpu_va;
   __out u64 syncpoint_id;
   __out u64 syncpoint_max;
 };

NVGPU_IOCTL_CHANNEL_SET_PREEMPTION_MODE

Sets the channel preemption modes.

 struct {
   __in u32 graphics_preempt_mode;
   __in u32 compute_preempt_mode;
 };

NVGPU_IOCTL_CHANNEL_OPEN

Opens the channel for a given runlist.

 struct {
   __in s32 runlist_id;
 };

NVGPU_IOCTL_CHANNEL_SETUP_BIND

Allocates or assigns the control buffers for the channel.

 struct {
   __in u32 num_gpfifo_entries;
   __in u32 num_inflight_jobs;
   __in u32 flags;
   __in s32 userd_dmabuf_fd;
   __in s32 gpfifo_dmabuf_fd;
   __out u32 work_submit_token;
   __in u64 userd_dmabuf_offset;
   __in u64 gpfifo_dmabuf_offset;
   __out u64 gpfifo_gpu_va;
   __out u64 userd_gpu_va;
   __out u64 usermode_mmio_gpu_va;
   __out u32 hw_channel_id;
   __in u32 reserved[3];
 };

NvDrvPermission

This is "nns::nvdrv::NvDrvPermission".

Bits Name Description
0 Gpu Can access /dev/nvhost-gpu, /dev/nvhost-ctrl-gpu and /dev/nvhost-as-gpu.
1 GpuDebug Can access /dev/nvhost-dbg-gpu and /dev/nvhost-prof-gpu.
2 GpuSchedule Can access /dev/nvsched-ctrl.
3 VIC Can access /dev/nvhost-vic.
4 VideoEncoder Can access /dev/nvhost-msenc.
5 VideoDecoder Can access /dev/nvhost-nvdec.
6 TSEC Can access /dev/nvhost-tsec.
7 JPEG Can access /dev/nvhost-nvjpg.
8 Display Can access /dev/nvhost-display, /dev/nvcec-ctrl, /dev/nvhdcp_up-ctrl, /dev/nvdisp-ctrl, /dev/nvdisp-disp0, /dev/nvdisp-disp1, /dev/nvdcutil-disp0 and /dev/nvdcutil-disp1.
9 ImportMemory Can duplicate nvmap handles from other processes with NVMAP_IOC_FROM_ID.
10 NoCheckedAruid Can use SetAruidWithoutCheck.
11 Can use SetGraphicsFirmwareMemoryMarginEnabled.
12 Can duplicate exported nvmap handles from other processes with NVMAP_IOC_FROM_ID.
13 Can use the GPU virtual address range 0xC0000 to 0x580000 instead of 0x0 to 0xC0000.
14 Can use NVMAP_IOC_EXPORT_FOR_ARUID and NVMAP_IOC_REMOVE_EXPORT_FOR_ARUID.
15 Can use the virtual address ranges 0x0 to 0x100000000 (GPU) and 0x0 to 0xE0000000 (non-GPU) instead of 0x100000000 to 0x11FA50000 (GPU) and 0xE0000000 to 0xFFFE0000 (non-GPU).

NvError

This is "nns::nvdrv::NvError".

Value Name
0x0 Success
0x1 NotImplemented
0x2 NotSupported
0x3 NotInitialized
0x4 BadParameter
0x5 Timeout
0x6 InsufficientMemory
0x7 ReadOnlyAttribute
0x8 InvalidState
0x9 InvalidAddress
0xA InvalidSize
0xB BadValue
0xD AlreadyAllocated
0xE Busy
0xF ResourceError
0x10 CountMismatch
0x11 OverFlow
0x1000 InsufficientTransferMemory
0x10000 InsufficientVideoMemory
0x10001 BadSurfaceColorScheme
0x10002 InvalidSurface
0x10003 SurfaceNotSupported
0x20000 DispInitFailed
0x20001 DispAlreadyAttached
0x20002 DispTooManyDisplays
0x20003 DispNoDisplaysAttached
0x20004 DispModeNotSupported
0x20005 DispNotFound
0x20006 DispAttachDissallowed
0x20007 DispTypeNotSupported
0x20008 DispAuthenticationFailed
0x20009 DispNotAttached
0x2000A DispSamePwrState
0x2000B DispEdidFailure
0x2000C DispDsiReadAckError
0x2000D DispDsiReadInvalidResp
0x30000 FileWriteFailed
0x30001 FileReadFailed
0x30002 EndOfFile
0x30003 FileOperationFailed
0x30004 DirOperationFailed
0x30005 EndOfDirList
0x30006 ConfigVarNotFound
0x30007 InvalidConfigVar
0x30008 LibraryNotFound
0x30009 SymbolNotFound
0x3000A MemoryMapFailed
0x3000F IoctlFailed
0x30010 AccessDenied
0x30011 DeviceNotFound
0x30012 KernelDriverNotFound
0x30013 FileNotFound
0x30014 PathAlreadyExists
0xA000E ModuleNotPresent

NvDrvStatus

This is "nns::nvdrv::NvDrvStatus".

Offset Size Description
0x0 0x4 FreeSize
0x4 0x4 AllocatableSize
0x8 0x4 MinimumFreeSize
0xC 0x4 MinimumAllocatableSize
0x10 0x10 Reserved

Notes

In some cases, a panic may occur. NV forces a crash by doing:

(void *)0 = 0xCAFE;

End result is that the system hangs with a white-screen.

When the gpfifo data in the gpu_va buffers specified by the submitted gpfifo entries is invalid(?), eventually the user-process will be force-terminated after using the submit-gpfifo ioctl. It's unknown how exactly this is done.

GPU rendering (GPFIFO) is only used by applets/Applications. All sysmodules doing any gfx-display uses software rendering. During system-boot, GPU GPFIFO is not used until the applets are launched.