Display services: Difference between revisions
Document unknown fields within DisplayInfo. These indicate if a display has a limited number of layers (and if so, how many layers are allowed). |
|||
(32 intermediate revisions by 5 users not shown) | |||
Line 6: | Line 6: | ||
{| class="wikitable" border="1" | {| class="wikitable" border="1" | ||
|- | |- | ||
! Cmd || Name | ! Cmd || Name || Notes | ||
|- | |||
| 1 || || | |||
|- | |||
| 2 || || | |||
|- | |||
| 3 || [5.0.0+] ? || Takes a total of 8-bytes of input, no output. | |||
|- | |||
| 5 || [5.0.0+] ? || Takes a total of 0x10-bytes of input, no output. | |||
|- | |||
| 210 || [6.0.0+] ? || Takes a total of 0x50-bytes of input, a type-0x15 input buffer, and a type-0x45 input buffer, returns a total of 0x20-bytes of output. | |||
|- | |||
| [2.0.0-4.1.0] 1001 || || Takes a total of 0x10-bytes of input, no output. | |||
|- | |||
| [2.0.0-4.1.0] 1002 || || Takes a total of 0x18-bytes of input, no output. | |||
|- | |||
| [3.0.0-4.1.0] 1003 || || Takes a total of 0x58-bytes of input, no output. | |||
|- | |||
| 1004 || [5.0.0+] ? || Takes a total of 0x60-bytes of input, no output. [6.0.0+]: In addition, this also takes a type-0x15 input buffer. | |||
|- | |- | ||
| | | 1009 || [5.0.0+] ? || Takes a total of 0x10-bytes of input, no output. | ||
|- | |- | ||
| | | 1010 || [5.0.0+] ? || Takes a total of 0x10-bytes of input, no output. | ||
|- | |- | ||
| | | 1011 || || Takes a total of 8-bytes of input, no output. | ||
|- | |- | ||
| | | 1012 || || Takes a total of 8-bytes of input, no output. | ||
|- | |- | ||
| | | 1101 || [4.0.0+] ? || | ||
|- | |- | ||
| | | 1106 || [4.0.0+] ? || | ||
|- | |- | ||
| | | 1107 || [4.0.0+] ? || | ||
|- | |- | ||
| 1201 || | | 1201 || [3.0.0+] ? || Takes a total of 0x10-bytes of input, returns a total of 0x18-bytes of output. | ||
|- | |- | ||
| 1202 || | | 1202 || [3.0.0+] ? || No input/output. | ||
|- | |- | ||
| 1203 || | | 1203 || [3.0.0+] ? || Takes a total of 8-bytes of input and a type-0x6 output buffer, returns a total of 8-bytes of output. | ||
|} | |} | ||
* cmd210: User-processes use hard-coded size 0x88 for the type-0x15 buffer. | |||
* cmd1106/1107: User-processes use hard-coded sizes 0x400 and 0x404 for the first/second type-0x15 buffers. | |||
* cmd1201/1202/1203: These are only usable when the previously loaded value from [[Settings_services|set:sys GetDebugModeFlag]] is set. | |||
The only caps:sc commands used by [[GRC_services|GRC]] are: 1101, 1106, and 1107. | |||
[8.0.0+] Cmd210 and cmd1004 now takes an additional type-0x15 input buffer. | |||
== Cmd1 == | == Cmd1 == | ||
Takes a type-0x46 output buffer, an input u32, two input u64s '''width'''/'''height''', an input s64 '''buffer_count''', and an input s64 '''buffer_index'''. | Takes a type-0x46 output buffer, an input u32 '''layer_stack''', two input u64s '''width'''/'''height''', an input s64 '''buffer_count''', and an input s64 '''buffer_index'''. | ||
'''width'''/'''height''' must match 1280/720. '''buffer_index''' must be < '''buffer_count'''. '''buffer_index''' and '''buffer_count''' must not be negative. | '''width'''/'''height''' must match 1280/720. '''buffer_index''' must be < '''buffer_count'''. '''buffer_index''' and '''buffer_count''' must not be negative. | ||
Line 39: | Line 65: | ||
This takes a screenshot, the output buffer contains the RGBA8 image. | This takes a screenshot, the output buffer contains the RGBA8 image. | ||
Stubbed with [5.0.0+], where it now returns error 0x7FECE. | |||
== Cmd2 == | == Cmd2 == | ||
Calls the same internal func as cmd1, where the last param is an additional cmd input u64 instead of hard-coded value 0x5f5e100. | Calls the same internal func as cmd1, where the last param is an additional cmd input u64 instead of hard-coded value 0x5f5e100. | ||
Stubbed with [5.0.0+], where it now returns error 0x7FECE. | |||
== Cmd1101 == | |||
Takes two input u64s '''width'''/'''height''', a 0x18-byte input struct, and two type-0x46 output buffers. | |||
For the input struct, [[GRC_services|GRC]] uses the output from [[Capture_services|caps:c]] cmd2101. | |||
'''width'''/'''height''' must be 1280x720. The first buffer address must be 0x400-byte aligned. The size of the first buffer must be at least '''width'''*'''height''', and must be aligned to 0x20000-bytes. | |||
The requirements for the second buffer address/size are the same as the first buffer, except the minimum size is ('''width'''*'''height''')/2. | |||
== Cmd1106 == | |||
Takes a 0x40-byte input struct, two input u64s '''width'''/'''height''', a 0x18-byte input struct, two type-0x15 input buffers, a type-0x6 output buffer, and two type-0x46 output buffers, returns 3 output u64s. | |||
'''width'''/'''height''' have same requirements as [[#Cmd1101]]. The size of the type-0x6 buffer must be at least 0x7D000. The requirements for the type-0x46 buffers are the same as [[#Cmd1101]]. | |||
[5.0.0+] Now takes a total of 0x68-bytes of input instead of 0x30. | |||
== Cmd1107 == | |||
Takes a 0x40-byte input struct, two input u64s '''width'''/'''height''', a 0x18-byte input struct, two type-0x15 input buffers, a type-0x6 output buffer, and a type-0x45 input buffer, returns 3 output u64s. | |||
'''width'''/'''height''' have same requirements as [[#Cmd1101]]. The size of the type-0x6 buffer must be at least 0x7D000. The size of the type-0x45 buffer must be at least 0x384000. | |||
[5.0.0+] Now takes a total of 0x68-bytes of input instead of 0x30. | |||
= caps:ss = | = caps:ss = | ||
Line 54: | Line 107: | ||
| 202 || | | 202 || | ||
|- | |- | ||
| 203 || | | 203 || [3.0.0+] | ||
|- | |||
| 204 || [3.0.0+] | |||
|- | |- | ||
| | | 208 || [5.0.0+] | ||
|} | |} | ||
= caps:su = | = caps:su = | ||
This is "nn::capsrv::sf::IScreenShotApplicationService". | This is "nn::capsrv::sf::IScreenShotApplicationService". | ||
This was added with [3.0.0+]. This was moved to [[Applet_Manager_services|AM]] with [6.0.0+]. | |||
{| class="wikitable" border="1" | {| class="wikitable" border="1" | ||
Line 69: | Line 126: | ||
|- | |- | ||
| 203 || SaveScreenShotEx0 | | 203 || SaveScreenShotEx0 | ||
|} | |} | ||
Line 80: | Line 135: | ||
! Cmd || Name | ! Cmd || Name | ||
|- | |- | ||
| 0 || | | 0 || Initialize | ||
|- | |- | ||
| 1 || | | 1 || Finalize | ||
|- | |- | ||
| 2 || | | 2 || | ||
|- | |- | ||
| 3 || | | 3 || PerformOneTouchPlay | ||
|- | |- | ||
| 4 || | | 4 || | ||
Line 92: | Line 147: | ||
| 5 || | | 5 || | ||
|- | |- | ||
| 6 || | | 6 || [2.0.0+] | ||
|- | |||
| 100 || [4.0.0+] GetHdcpServiceObject | |||
|} | |||
GetHdcpServiceObject: No input, returns a [[#CecManagerSubinterface100]]. | |||
= CecManagerSubinterface100 = | |||
Added with [4.0.0+]. | |||
{| class="wikitable" border="1" | |||
|- | |||
! Cmd || Name | |||
|- | |||
| 0 || | |||
|- | |||
| 1 || | |||
|- | |||
| 2 || | |||
|- | |||
| 3 || | |||
|} | |} | ||
Line 133: | Line 208: | ||
== GetDisplayService == | == GetDisplayService == | ||
Returns an [[#IApplicationDisplayService]]. Takes an input u32, user-processes use 0 or 1, with 0 for regular-applications normally. 0 = user-service(vi:u), 1 = | Returns an [[#IApplicationDisplayService]]. Takes an input u32, user-processes use 0 or 1, with 0 for regular-applications normally. 0 = user-service(vi:u), 1 = system/manager service (vi:s/vi:m). Returns an error when using value 1 with vi:u(same error listed below for IApplicationDisplayService for unavailable commands), however passing 1 to vi:s/vi:m results in the IApplicationDisplayService having greater privileges. | ||
= vi:s = | = vi:s = | ||
Line 292: | Line 367: | ||
== GetIndirectLayerImageMap == | == GetIndirectLayerImageMap == | ||
Takes a PID-descriptor, an type-0x46 buffer, and four u64s: width(s32), height(s32), <output from [[AM_services|AM]] GetIndirectLayerConsumerHandle>, and [[AM_services|AppletResourceUserId]]. Returns two output u64s. | Takes a PID-descriptor, an type-0x46 buffer, and four u64s: width(s32), height(s32), <output from [[AM_services|AM]] GetIndirectLayerConsumerHandle>, and [[AM_services|AppletResourceUserId]]. Returns two output u64s. | ||
Calls the same func as [[#GetIndirectLayerImageCropMap]] internally, with the input floats set to 0.0f, then 1.0f for the rest. | |||
== GetIndirectLayerImageCropMap == | == GetIndirectLayerImageCropMap == | ||
Line 297: | Line 374: | ||
== GetIndirectLayerImageRequiredMemoryInfo == | == GetIndirectLayerImageRequiredMemoryInfo == | ||
Takes two input u64s: | Takes two input u64s: width and height. Returns two output u64s. First u64 is the buffer size to use with the ImageMap cmds, second u64 is the buffer address alignment for those cmds. | ||
== GetDisplayVsyncEvent == | == GetDisplayVsyncEvent == | ||
Line 318: | Line 395: | ||
| 1203 || GetDisplayLogicalResolution | | 1203 || GetDisplayLogicalResolution | ||
|- | |- | ||
| 1204 || SetDisplayMagnification | | 1204 || [3.0.0+] SetDisplayMagnification | ||
|- | |- | ||
| 2201 || SetLayerPosition | | 2201 || SetLayerPosition | ||
Line 332: | Line 409: | ||
| 2209 || SetLayerAlpha | | 2209 || SetLayerAlpha | ||
|- | |- | ||
| 2312 || CreateStrayLayer | | 2312 || [1.0.0-6.2.0] CreateStrayLayer | ||
|- | |- | ||
| 2400 || OpenIndirectLayer | | 2400 || OpenIndirectLayer | ||
Line 410: | Line 487: | ||
| 201 || [4.0.0+] FreeProcessHeapBlock | | 201 || [4.0.0+] FreeProcessHeapBlock | ||
|- | |- | ||
| 1102 || GetDisplayResolution | | 1102 || [3.0.0+] GetDisplayResolution | ||
|- | |- | ||
| 2010 || CreateManagedLayer | | 2010 || CreateManagedLayer | ||
|- | |- | ||
| 2011 || DestroyManagedLayer | | 2011 || DestroyManagedLayer | ||
|- | |||
| 2012 || [7.0.0+] CreateStrayLayer | |||
|- | |- | ||
| 2050 || CreateIndirectLayer | | 2050 || CreateIndirectLayer | ||
Line 433: | Line 512: | ||
|- | |- | ||
| 2302 || GetDisplayHotplugEvent | | 2302 || GetDisplayHotplugEvent | ||
|- | |||
| 2303 || [5.1.0+] GetDisplayModeChangedEvent | |||
|- | |- | ||
| 2402 || GetDisplayHotplugState | | 2402 || GetDisplayHotplugState | ||
Line 469: | Line 550: | ||
|- | |- | ||
| 6010 || [5.0.0+] GetLayerPresentationAllFencesExpiredEvent | | 6010 || [5.0.0+] GetLayerPresentationAllFencesExpiredEvent | ||
|- | |||
| 6011 || [7.0.0+] EnableLayerAutoClearTransitionBuffer | |||
|- | |||
| 6012 || [7.0.0+] DisableLayerAutoClearTransitionBuffer | |||
|- | |- | ||
| 7000 || SetContentVisibility | | 7000 || SetContentVisibility | ||
|- | |- | ||
| 8000 || SetConductorLayer | | 8000 || SetConductorLayer | ||
|- | |||
| 8001 || [8.0.0+] SetTimestampTracking | |||
|- | |- | ||
| 8100 || SetIndirectProducerFlipOffset | | 8100 || SetIndirectProducerFlipOffset | ||
Line 536: | Line 623: | ||
| 8298 || [5.0.0+] ExpandStartupLogoOnSharedFrameBuffer | | 8298 || [5.0.0+] ExpandStartupLogoOnSharedFrameBuffer | ||
|} | |} | ||
[5.0.0+] SetDetachedSharedFrameBufferImage now takes an additional 0x10-bytes of input. CopyDetachedSharedFrameBufferImage now takes an additional 0x18-bytes of input. SetDetachedSharedFrameBufferSubImage now takes an additional 0x10-bytes of input, and the buffer type was changed from 0x5 to 0x45. | |||
= DisplayInfo = | = DisplayInfo = | ||
Line 562: | Line 651: | ||
This is a 0x40-byte block: a NUL-terminated string. | This is a 0x40-byte block: a NUL-terminated string. | ||
Can be "Default", "External", "Edid", "Internal" or "Null". | Can be "Default", "External", "[https://en.wikipedia.org/wiki/Extended_Display_Identification_Data Edid]", "Internal" or "Null". | ||
= Parcel = | = Parcel = |