diff --git a/nx/include/switch/svc.h b/nx/include/switch/svc.h index e217cca6..8900f2e0 100644 --- a/nx/include/switch/svc.h +++ b/nx/include/switch/svc.h @@ -25,4 +25,6 @@ Result svcSendSyncRequest(Handle session); Result svcBreak(u32 BreakReason, u64 inval1, u64 inval2); Result svcAcceptSession(Handle *session_handle, Handle port_handle); Result svcReplyAndReceive(s32* index, const Handle* handles, s32 handleCount, Handle replyTarget, u64 timeout); +Result svcQueryPhysicalAddress(u64* out, u64 virtaddr);//3 output u64s are written to out. +Result svcQueryIoMapping(u64* virtaddr, u64 physaddr, u64 size); Result svcManageNamedPort(Handle* portServer, const char* name, s32 maxSessions); diff --git a/nx/source/svc.s b/nx/source/svc.s index 6fbc93e3..75cc03f0 100644 --- a/nx/source/svc.s +++ b/nx/source/svc.s @@ -58,6 +58,24 @@ SVC_BEGIN svcReplyAndReceive ret SVC_END +SVC_BEGIN svcQueryPhysicalAddress + str x0, [sp, #-16]! + svc 0x54 + ldr x2, [sp], #16 + str x1, [x2] + str x2, [x2, #8] + str x3, [x2, #16] + ret +SVC_END + +SVC_BEGIN svcQueryIoMapping + str x0, [sp, #-16]! + svc 0x55 + ldr x2, [sp], #16 + str x1, [x2] + ret +SVC_END + SVC_BEGIN svcManageNamedPort str x0, [sp, #-16]! svc 0x71