SVC: Difference between revisions
IsBorrowed is also set to true when it's the source of a MapMemory. |
CreateDeviceAddressSpace 32-bit regs |
||
(16 intermediate revisions by the same user not shown) | |||
Line 19: | Line 19: | ||
| 0x7 || [[#svcExitProcess]] || None || | | 0x7 || [[#svcExitProcess]] || None || | ||
|- | |- | ||
| 0x8 || [[#svcCreateThread]] || X1=entry, X2=thread_context, X3=stacktop, W4=prio, W5=processor_id | | 0x8 || [[#svcCreateThread]] || X1=entry, X2=thread_context, X3=stacktop, W4=prio, W5=processor_id | ||
R0=prio, R1=entry, R2=thread_context, R3=stacktop, R4=processor_id | |||
|| W0=result, W1=handle | |||
|- | |- | ||
| 0x9 || [[#svcStartThread]] || W0=thread_handle || W0=result | | 0x9 || [[#svcStartThread]] || W0=thread_handle || W0=result | ||
Line 73: | Line 75: | ||
|- | |- | ||
| 0x1E || [[#svcGetSystemTick]] || None || X0={value of cntpct_el0} | | 0x1E || [[#svcGetSystemTick]] || None || X0={value of cntpct_el0} | ||
R0=cntpct_el0_lower32, R1=cntpct_el0_upper32 | |||
|- | |- | ||
| 0x1F || svcConnectToNamedPort || X1=port_name_str || W0=result, W1=handle | | 0x1F || svcConnectToNamedPort || X1=port_name_str || W0=result, W1=handle | ||
Line 85: | Line 88: | ||
|- | |- | ||
| 0x24 || svcGetProcessId || W1=thread_or_process_or_debug_handle || W0=result, X1=pid | | 0x24 || svcGetProcessId || W1=thread_or_process_or_debug_handle || W0=result, X1=pid | ||
R0=result, R1=pid_lower32, R2=pid_upper32 | |||
|- | |- | ||
| 0x25 || svcGetThreadId || W1=thread_handle || W0=result, X1=out | | 0x25 || svcGetThreadId || W1=thread_handle || W0=result, X1=out | ||
R0=result, R1=out_lower32, R2=out_upper32 | |||
|- | |- | ||
| 0x26 || [[#svcBreak]] || X0=break_reason,X1,X2=info || W0=result = 0 | | 0x26 || [[#svcBreak]] || X0=break_reason,X1,X2=info || W0=result = 0 | ||
Line 107: | Line 112: | ||
| 0x2D || [3.0.0+] svcUnmapPhysicalMemory || X0=addr, X1=size || W0=result | | 0x2D || [3.0.0+] svcUnmapPhysicalMemory || X0=addr, X1=size || W0=result | ||
|- | |- | ||
| 0x2E || [5.0.0+] svcGetFutureThreadInfo || X3=timeout || W0=result, bunch of crap | | 0x2E || [5.0.0+] svcGetFutureThreadInfo || X3=timeout | ||
R0=timeout_lower32, R1=timeout_upper32 | |||
|| W0=result, bunch of crap | |||
|- | |- | ||
| 0x2F || svcGetLastThreadInfo || None || W0=result, W1,W2,W3,W4=unk, W5=truncated_u64, W6=bool | | 0x2F || svcGetLastThreadInfo || None || W0=result, W1,W2,W3,W4=unk, W5=truncated_u64, W6=bool | ||
|- | |- | ||
| 0x30 || svcGetResourceLimitLimitValue || W1=reslimit_handle, W2=[[#LimitableResource]] || W0=result, X1=value | | 0x30 || svcGetResourceLimitLimitValue || W1=reslimit_handle, W2=[[#LimitableResource]] || W0=result, X1=value | ||
R0=result, R1=value_lower32, R2=value_upper32 | |||
|- | |- | ||
| 0x31 || svcGetResourceLimitCurrentValue || W1=reslimit_handle, W2=[[#LimitableResource]] || W0=result, X1=value | | 0x31 || svcGetResourceLimitCurrentValue || W1=reslimit_handle, W2=[[#LimitableResource]] || W0=result, X1=value | ||
R0=result, R1=value_lower32, R2=value_upper32 | |||
|- | |- | ||
| 0x32 || svcSetThreadActivity || W0=thread_handle, W1=bool || W0=result | | 0x32 || svcSetThreadActivity || W0=thread_handle, W1=bool || W0=result | ||
Line 119: | Line 128: | ||
| 0x33 || svcGetThreadContext3 || X0=[[#ThreadContext]]*, W1=thread_handle || W0=result | | 0x33 || svcGetThreadContext3 || X0=[[#ThreadContext]]*, W1=thread_handle || W0=result | ||
|- | |- | ||
| 0x34 || [4.0.0+] svcWaitForAddress || X0=ptr, W1=[[#ArbitrationType]], X2=value X3=timeout || | | 0x34 || [4.0.0+] svcWaitForAddress || X0=ptr, W1=[[#ArbitrationType]], X2=value, X3=timeout | ||
R0=ptr, R1=[[#ArbitrationType]], R2=value, R3=timeout_lower32, R4=timeout_upper32 | |||
|| | |||
|- | |- | ||
| 0x35 || [4.0.0+] svcSignalToAddress || X0=ptr, W1=[[#SignalType]], X2=value W3=num_to_signal || | | 0x35 || [4.0.0+] svcSignalToAddress || X0=ptr, W1=[[#SignalType]], X2=value, W3=num_to_signal || | ||
|- | |- | ||
| 0x36 || [8.0.0+] svcSynchronizePreemptionState || None || W0=result | | 0x36 || [8.0.0+] svcSynchronizePreemptionState || None || W0=result | ||
Line 129: | Line 140: | ||
| 0x3D || [4.0.0+] svcDumpInfoNew || || | | 0x3D || [4.0.0+] svcDumpInfoNew || || | ||
|- style="border-top: double" | |- style="border-top: double" | ||
| 0x40 || svcCreateSession || W2=is_light, X3= | | 0x40 || svcCreateSession || W2=is_light, X3=name_ptr || W0=result, W1=server_handle, W2=client_handle | ||
|- | |- | ||
| 0x41 || [[#svcAcceptSession]] || W1=port_handle || W0=result, W1=session_handle | | 0x41 || [[#svcAcceptSession]] || W1=port_handle || W0=result, W1=session_handle | ||
Line 135: | Line 146: | ||
| 0x42 || svcReplyAndReceiveLight || W0=light_session_handle || W0=result, W1,W2,W3,W4,W5,W6,W7=out | | 0x42 || svcReplyAndReceiveLight || W0=light_session_handle || W0=result, W1,W2,W3,W4,W5,W6,W7=out | ||
|- | |- | ||
| 0x43 || [[#svcReplyAndReceive]] || X1=ptr_handles, W2=num_handles, X3=replytarget_handle(0=none), X4=timeout || W0=result, W1=handle_idx | | 0x43 || [[#svcReplyAndReceive]] || X1=ptr_handles, W2=num_handles, X3=replytarget_handle(0=none), X4=timeout | ||
R0=timeout_lower32, R1=ptr_handles, R2=num_handles, R3=replytarget_handle(0=none), R4=timeout_upper32 | |||
|| W0=result, W1=handle_idx | |||
|- | |- | ||
| 0x44 || svcReplyAndReceiveWithUserBuffer|| X1=buf, X2=sz, X3=ptr_handles, W4=num_handles, X5=replytarget_handle(0=none), X6=timeout || W0=result, W1=handle_idx | | 0x44 || svcReplyAndReceiveWithUserBuffer|| X1=buf, X2=sz, X3=ptr_handles, W4=num_handles, X5=replytarget_handle(0=none), X6=timeout | ||
R0=num_handles, R1=buf, R2=sz, R3=ptr_handles, R4=replytarget_handle(0=none), R5=timeout_lower32, R6=timeout_upper32 | |||
|| W0=result, W1=handle_idx | |||
|- | |- | ||
| 0x45 || svcCreateEvent || None || W0=result, W1=wevent_handle, W2=revent_handle | | 0x45 || svcCreateEvent || None || W0=result, W1=wevent_handle, W2=revent_handle | ||
Line 149: | Line 164: | ||
| 0x4B || [4.0.0+] [[#svcCreateCodeMemory]] || X1=addr, X2=size || W0=result, W1=code_memory_handle | | 0x4B || [4.0.0+] [[#svcCreateCodeMemory]] || X1=addr, X2=size || W0=result, W1=code_memory_handle | ||
|- | |- | ||
| 0x4C || [4.0.0+] [[#svcControlCodeMemory]] || W0=code_memory_handle, W1=[[#CodeMemoryOperation]], X2=dstaddr, X3=size, W4=perm || W0=result | | 0x4C || [4.0.0+] [[#svcControlCodeMemory]] || W0=code_memory_handle, W1=[[#CodeMemoryOperation]], X2=dstaddr, X3=size, W4=perm | ||
R0=code_memory_handle, R1=[[#CodeMemoryOperation]], R2=dstaddr_lower32, R3=dstaddr_upper32, R4=size_lower32, R5=size_upper32, R6=perm | |||
|| W0=result | |||
|- | |- | ||
| 0x4D || svcSleepSystem || None || None | | 0x4D || svcSleepSystem || None || None | ||
|- | |- | ||
| 0x4E || [[#svcReadWriteRegister]] || X1=reg_addr, W2=rw_mask, W3=in_val || W0=result, W1=out_val | | 0x4E || [[#svcReadWriteRegister]] || X1=reg_addr, W2=rw_mask, W3=in_val | ||
R0=rw_mask, R1=in_val, R2=reg_addr_lower32, R3=reg_addr_upper32 | |||
|| W0=result, W1=out_val | |||
|- | |- | ||
| 0x4F || svcSetProcessActivity || W0=process_handle, W1=bool || W0=result | | 0x4F || svcSetProcessActivity || W0=process_handle, W1=bool || W0=result | ||
Line 167: | Line 186: | ||
| 0x54 || [[#svcQueryPhysicalAddress]] || X1=addr || W0=result, X1=physaddr, X2=kerneladdr, X3=size | | 0x54 || [[#svcQueryPhysicalAddress]] || X1=addr || W0=result, X1=physaddr, X2=kerneladdr, X3=size | ||
|- | |- | ||
| 0x55 || [[#svcQueryIoMapping]] || X1=physaddr, X2=size || W0=result, X1=virtaddr | | 0x55 || [[#svcQueryIoMapping]] || X1=physaddr, X2=size | ||
R0=size, R2=physaddr_lower32, R3=physaddr_upper32 | |||
|| W0=result, X1=virtaddr | |||
|- | |- | ||
| 0x56 || [[#svcCreateDeviceAddressSpace]] || X1=dev_as_start_addr, X2=dev_as_end_addr || W0=result, W1=dev_as_handle | | 0x56 || [[#svcCreateDeviceAddressSpace]] || X1=dev_as_start_addr, X2=dev_as_end_addr | ||
R0=dev_as_end_addr_lower32, R1=dev_as_end_addr_upper32, R2=dev_as_start_addr_lower32, R3=dev_as_start_addr_upper32 | |||
|| W0=result, W1=dev_as_handle | |||
|- | |- | ||
| 0x57 || [[#svcAttachDeviceAddressSpace]] || W0=device, X1=dev_as_handle || W0=result | | 0x57 || [[#svcAttachDeviceAddressSpace]] || W0=device, X1=dev_as_handle || W0=result | ||
Line 433: | Line 456: | ||
{| class="wikitable" border="1" | {| class="wikitable" border="1" | ||
|- | |- | ||
! | ! Argument64 || Argument32 || Type || Name | ||
|- | |- | ||
| (In) X1 || void(*)(void*) || Entry | | (In) X1 || R1 || void(*)(void*) || Entry | ||
|- | |- | ||
| (In) X2 || void* || ThreadContext | | (In) X2 || R2 || void* || ThreadContext | ||
|- | |- | ||
| (In) X3 || void* || StackTop | | (In) X3 || R3 || void* || StackTop | ||
|- | |- | ||
| (In) W4 || u32 || Priority | | (In) W4 || R0 || u32 || Priority | ||
|- | |- | ||
| (In) W5 || u32 || ProcessorId | | (In) W5 || R4 || u32 || ProcessorId | ||
|- | |- | ||
| (Out) W0 || [[#Result]] || Ret | | (Out) W0 || R0 || [[#Result]] || Ret | ||
|- | |- | ||
| (Out) W1 || Handle<Thread> || Handle | | (Out) W1 || R1 || Handle<Thread> || Handle | ||
|} | |} | ||
</div> | </div> | ||
Line 490: | Line 513: | ||
{| class="wikitable" border="1" | {| class="wikitable" border="1" | ||
|- | |- | ||
! | ! Argument64 || Argument32 || Type || Name | ||
|- | |- | ||
| (In) R1 || | | (In) X0 || R0, R1 || s64 || Nanoseconds | ||
|- | |- | ||
|} | |} | ||
Line 567: | Line 579: | ||
{| class="wikitable" border="1" | {| class="wikitable" border="1" | ||
|- | |- | ||
! | ! Argument64 || Argument32 || Type || Name | ||
|- | |- | ||
| (In) W2 || Handle<Thread> || Handle | | (In) W2 || R2 || Handle<Thread> || Handle | ||
|- | |- | ||
| (Out) W0 || [[#Result]] || Ret | | (Out) W0 || R0 || [[#Result]] || Ret | ||
|- | |- | ||
| (Out) W1 || u32 || Out0 | | (Out) W1 || R1 || u32 || Out0 | ||
|- | |- | ||
| (Out) X2 || | | (Out) X2 || R2, R3 || u64 || Out1 | ||
|} | |} | ||
</div> | </div> | ||
Line 602: | Line 598: | ||
{| class="wikitable" border="1" | {| class="wikitable" border="1" | ||
|- | |- | ||
! | ! Argument64 || Argument32 || Type || Name | ||
|- | |- | ||
| (In) W0 || Handle<Thread> || Handle | | (In) W0 || R0 || Handle<Thread> || Handle | ||
|- | |- | ||
| (In) W1 || u32 || In0 | | (In) W1 || R1 || u32 || In0 | ||
|- | |- | ||
| (In) X2 || u64 || In1 | | (In) X2 || R2, R3 || u64 || In1 | ||
|- | |- | ||
| (Out) W0 || | | (Out) W0 || R0 || [[#Result]] || Ret | ||
|} | |} | ||
</div> | </div> | ||
'''Description:''' Set affinity mask of provided thread handle. | '''Description:''' Set affinity mask of provided thread handle. | ||
Line 701: | Line 682: | ||
{| class="wikitable" border="1" | {| class="wikitable" border="1" | ||
|- | |- | ||
! | ! Argument64 || Argument32 || Type || Name | ||
|- | |- | ||
| (In) | | (In) X1 || R1 || Handle* || HandlesPtr | ||
|- | |- | ||
| (In) | | (In) W2 || R2 || u64 || HandlesNum | ||
|- | |- | ||
| (In) | | (In) X3 || R0, R3 || u64 || Timeout | ||
|- | |- | ||
| ( | | (Out) W0 || R0 || [[#Result]] || Ret | ||
|- | |- | ||
| (Out) | | (Out) W1 || R1 || u64 || HandleIndex | ||
| | |||
|} | |} | ||
</div> | </div> | ||
Line 799: | Line 762: | ||
{| class="wikitable" border="1" | {| class="wikitable" border="1" | ||
|- | |- | ||
! | ! Argument64 || Argument32 || Type || Name | ||
|- | |- | ||
| (Out) X0 || u64 || Ticks | | (Out) X0 || R0, R1 || u64 || Ticks | ||
|} | |} | ||
</div> | </div> | ||
Line 1,003: | Line 966: | ||
{| class="wikitable" border="1" | {| class="wikitable" border="1" | ||
|- | |- | ||
! | ! Argument64 || Argument32 || Type || Name | ||
|- | |- | ||
| (In) W1 || *Handle<Port or ServerSession> || Handles | | (In) W1 || R1 || *Handle<Port or ServerSession> || Handles | ||
|- | |- | ||
| (In) W2 || u32 || NumHandles | | (In) W2 || R2 || u32 || NumHandles | ||
|- | |- | ||
| (In) W3 || Handle<ServerSession> || ReplyTarget | | (In) W3 || R3 || Handle<ServerSession> || ReplyTarget | ||
|- | |- | ||
| (In) X4 || u64 (nanoseconds) || Timeout | | (In) X4 || R0, R4 || u64 (nanoseconds) || Timeout | ||
|- | |- | ||
| (Out) W0 || [[#Result]] || Result | | (Out) W0 || R0 || [[#Result]] || Result | ||
|- | |- | ||
| (Out) W1 || u32 || HandleIndex | | (Out) W1 || R1 || u32 || HandleIndex | ||
|} | |} | ||
</div> | </div> | ||
Line 1,061: | Line 1,024: | ||
{| class="wikitable" border="1" | {| class="wikitable" border="1" | ||
|- | |- | ||
! | ! Argument64 || Argument32 || Type || Name | ||
|- | |- | ||
| (In) X1 || u64 || RegAddr | | (In) X1 || R2, R3 || u64 || RegAddr | ||
|- | |- | ||
| (In) W2 || u64 || RwMask | | (In) W2 || R0 || u64 || RwMask | ||
|- | |- | ||
| (In) W3 || u64 || InValue | | (In) W3 || R1 || u64 || InValue | ||
|- | |- | ||
| (Out) W0 || [[#Result]] || Ret | | (Out) W0 || R0 || [[#Result]] || Ret | ||
|- | |- | ||
| (Out) W1|| u64 || OutValue | | (Out) W1 || R1 || u64 || OutValue | ||
|} | |} | ||
</div> | </div> | ||
Line 1,226: | Line 1,189: | ||
{| class="wikitable" border="1" | {| class="wikitable" border="1" | ||
|- | |- | ||
! | ! Argument64 || Argument32 || Type || Name | ||
|- | |- | ||
| (In) X1 || u64 || PhysAddr | | (In) X1 || R2, R3 || u64 || PhysAddr | ||
|- | |- | ||
| (In) X2 || u64 || Size | | (In) X2 || R0 || u64 || Size | ||
|- | |- | ||
| (Out) W0 || [[#Result]] || Ret | | (Out) W0 || R0 || [[#Result]] || Ret | ||
|- | |- | ||
| (Out) X1 || void* || VirtAddr | | (Out) X1 || R1 || void* || VirtAddr | ||
|} | |} | ||
</div> | </div> | ||
Line 1,245: | Line 1,208: | ||
{| class="wikitable" border="1" | {| class="wikitable" border="1" | ||
|- | |- | ||
! | ! Argument64 || Argument32 || Type || Name | ||
|- | |- | ||
| (In) X1 || u64 || StartAddr | | (In) X1 || R2, R3 || u64 || StartAddr | ||
|- | |- | ||
| (In) X2 || u64 || EndAddr | | (In) X2 || R0, R1 || u64 || EndAddr | ||
|- | |- | ||
| (Out) W0 || [[#Result]] || Ret | | (Out) W0 || R0 || [[#Result]] || Ret | ||
|- | |- | ||
| (Out) W1 || Handle<DeviceAddressSpace> || AddressSpaceHandle | | (Out) W1 || R1 || Handle<DeviceAddressSpace> || AddressSpaceHandle | ||
|} | |} | ||
</div> | </div> |