Line 2: |
Line 2: |
| | | |
| = caps:sc = | | = caps:sc = |
− | This is "nn::capsrv::sf::IScreenShotControlService". | + | This is "nn::capsrv::sf::IScreenShotControlService". This is available with [2.0.0+]. |
| | | |
| {| 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. |
| |- | | |- |
− | | 1 || | + | | 1009 || [5.0.0+] ? || Takes a total of 0x10-bytes of input, no output. |
| |- | | |- |
− | | 2 || | + | | 1010 || [5.0.0+] ? || Takes a total of 0x10-bytes of input, no output. |
| |- | | |- |
− | | 1001 || | + | | 1011 || || Takes a total of 8-bytes of input, no output. |
| |- | | |- |
− | | 1002 || | + | | 1012 || || Takes a total of 8-bytes of input, no output. |
| |- | | |- |
− | | 1003 || | + | | 1101 || [4.0.0+] ? || |
| |- | | |- |
− | | 1011 || | + | | 1106 || [4.0.0+] ? || |
| |- | | |- |
− | | 1012 || | + | | 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 == |
| + | 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. |
| + | |
| + | '''buffer_index''' and '''buffer_count''' correspond to buffers with size 0x384000(1280*720*4). |
| + | |
| + | Value 0 is usable for the input u32. |
| + | |
| + | This takes a screenshot, the output buffer contains the RGBA8 image. |
| + | |
| + | Stubbed with [5.0.0+], where it now returns error 0x7FECE. |
| + | |
| + | == Cmd2 == |
| + | 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 = |
− | This is "nn::capsrv::sf::IScreenShotService". | + | This is "nn::capsrv::sf::IScreenShotService". This is available with [2.0.0+]. |
| | | |
| {| class="wikitable" border="1" | | {| class="wikitable" border="1" |
Line 40: |
Line 107: |
| | 202 || | | | 202 || |
| |- | | |- |
− | | 203 || | + | | 203 || [3.0.0+] |
| |- | | |- |
− | | 204 || | + | | 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 64: |
Line 135: |
| ! Cmd || Name | | ! Cmd || Name |
| |- | | |- |
− | | 0 || | + | | 0 || Initialize |
| |- | | |- |
− | | 1 || | + | | 1 || Finalize |
| |- | | |- |
| | 2 || | | | 2 || |
| |- | | |- |
− | | 3 || | + | | 3 || PerformOneTouchPlay |
| |- | | |- |
| | 4 || | | | 4 || |
Line 76: |
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 117: |
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 = non-user-service? Returns an error when using value 1 with vi:u(same error listed below for IApplicationDisplayService for unavailable commands). | + | 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 248: |
Line 339: |
| | | |
| == SetDisplayEnabled == | | == SetDisplayEnabled == |
− | Takes an input u32 boolean, and an u64(DisplayId?). | + | Takes an input u32 boolean, and an u64 DisplayId. |
| | | |
| == GetDisplayResolution == | | == GetDisplayResolution == |
Line 276: |
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 281: |
Line 374: |
| | | |
| == GetIndirectLayerImageRequiredMemoryInfo == | | == GetIndirectLayerImageRequiredMemoryInfo == |
− | Takes two input u64s: with and height. Returns two output u64s. First u64 is the buffer size to use with the ImageMap cmds. | + | 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 302: |
Line 395: |
| | 1203 || GetDisplayLogicalResolution | | | 1203 || GetDisplayLogicalResolution |
| |- | | |- |
− | | 1204 || SetDisplayMagnification | + | | 1204 || [3.0.0+] SetDisplayMagnification |
| |- | | |- |
| | 2201 || SetLayerPosition | | | 2201 || SetLayerPosition |
Line 316: |
Line 409: |
| | 2209 || SetLayerAlpha | | | 2209 || SetLayerAlpha |
| |- | | |- |
− | | 2312 || CreateStrayLayer | + | | 2312 || [1.0.0-6.2.0] CreateStrayLayer |
| |- | | |- |
| | 2400 || OpenIndirectLayer | | | 2400 || OpenIndirectLayer |
Line 394: |
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 417: |
Line 512: |
| |- | | |- |
| | 2302 || GetDisplayHotplugEvent | | | 2302 || GetDisplayHotplugEvent |
| + | |- |
| + | | 2303 || [5.1.0+] GetDisplayModeChangedEvent |
| |- | | |- |
| | 2402 || GetDisplayHotplugState | | | 2402 || GetDisplayHotplugState |
Line 453: |
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 520: |
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 528: |
Line 633: |
| | 0x0 || 0x40 || [[#DisplayName]] | | | 0x0 || 0x40 || [[#DisplayName]] |
| |- | | |- |
− | | 0x40 || 0x8? || Normally 0x1 for the "Default" Display? | + | | 0x40 || 0x1 || Whether or not the display has a constrained number of layers. |
| |- | | |- |
− | | 0x48 || 0x8? || Normally 0x1 for the "Default" Display? | + | | 0x41 || 0x7 || Padding/Reserved |
| |- | | |- |
− | | 0x50 || 0x8? || Width | + | | 0x48 || 0x8 || If this display has a constrained number of layers (0x40 is set), indicates the maximum number of layers. |
| |- | | |- |
− | | 0x58 || 0x8? || Height | + | | 0x50 || 0x8 || Width in pixels |
| + | |- |
| + | | 0x58 || 0x8 || Height in pixels |
| |} | | |} |
| | | |
Line 544: |
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 = |