Add getThreadLocalStorage(), major cleanup in svc.h/svc.s
This commit is contained in:
parent
0f93112ecb
commit
377e753b7d
@ -2,8 +2,7 @@
|
||||
svc.h _ Syscall wrappers.
|
||||
*/
|
||||
|
||||
#ifndef SVC_H
|
||||
#define SVC_H
|
||||
#pragma once
|
||||
|
||||
typedef enum {
|
||||
MEMOP_FREE =1, // Free heap
|
||||
@ -42,8 +41,17 @@ typedef enum {
|
||||
ARBITER_KERNEL4 =4,
|
||||
} ArbitrationType;
|
||||
|
||||
static inline void* getThreadLocalStorage(void)
|
||||
{
|
||||
void* ret;
|
||||
asm volatile("mrc p15, 0, %[data], c13, c0, 3" : [data] "=r" (ret));
|
||||
return ret;
|
||||
}
|
||||
|
||||
u32* getThreadCommandBuffer(void);
|
||||
static inline u32* getThreadCommandBuffer(void)
|
||||
{
|
||||
return (u32*)((u8*)getThreadLocalStorage() + 0x80);
|
||||
}
|
||||
|
||||
s32 svcControlMemory(u32* addr_out, u32 addr0, u32 addr1, u32 size, MemOp op, MemPerm perm);
|
||||
s32 svcQueryMemory(MemInfo* info, PageInfo* out, u32 addr);
|
||||
@ -51,6 +59,7 @@ void __attribute__((noreturn)) svcExitProcess();
|
||||
s32 svcCreateThread(Handle* thread, ThreadFunc entrypoint, u32 arg, u32* stack_top, s32 thread_priority, s32 processor_id);
|
||||
void __attribute__((noreturn)) svcExitThread();
|
||||
void svcSleepThread(s64 ns);
|
||||
s32 svcSetThreadPriority(Handle thread, s32 prio);
|
||||
s32 svcCreateMutex(Handle* mutex, bool initially_locked);
|
||||
s32 svcReleaseMutex(Handle handle);
|
||||
s32 svcCreateEvent(Handle* event, u8 reset_type);
|
||||
@ -76,6 +85,3 @@ s32 svcConnectToPort(volatile Handle* out, const char* portName);
|
||||
s32 svcSendSyncRequest(Handle session);
|
||||
s32 svcGetProcessId(u32 *out, Handle handle);
|
||||
s32 svcOutputDebugString(const char* str, int length);
|
||||
s32 svcSetThreadPriority(Handle thread, s32 prio);
|
||||
|
||||
#endif
|
||||
|
@ -1,72 +1,69 @@
|
||||
.arm
|
||||
.align 4
|
||||
|
||||
/* THIS DOES NOT BELONG HERE */
|
||||
.global getThreadCommandBuffer
|
||||
.type getThreadCommandBuffer, %function
|
||||
getThreadCommandBuffer:
|
||||
mrc p15, 0, r0, c13, c0, 3
|
||||
add r0, #0x80
|
||||
bx lr
|
||||
|
||||
|
||||
.global svcControlMemory
|
||||
.type svcControlMemory, %function
|
||||
svcControlMemory:
|
||||
stmfd sp!, {r0, r4}
|
||||
ldr r0, [sp, #0x8]
|
||||
ldr r4, [sp, #0x8+0x4]
|
||||
svc 0x01
|
||||
ldr r2, [sp], #4
|
||||
str r1, [r2]
|
||||
ldr r4, [sp], #4
|
||||
bx lr
|
||||
push {r0, r4}
|
||||
ldr r0, [sp, #0x8]
|
||||
ldr r4, [sp, #0x8+0x4]
|
||||
svc 0x01
|
||||
ldr r2, [sp], #4
|
||||
str r1, [r2]
|
||||
ldr r4, [sp], #4
|
||||
bx lr
|
||||
|
||||
.global svcQueryMemory
|
||||
.type svcQueryMemory, %function
|
||||
svcQueryMemory:
|
||||
stmfd sp!, {r0,r1,r4-r6}
|
||||
svc 2
|
||||
ldr r6, [sp]
|
||||
str r1, [r6]
|
||||
str r2, [r6,#4]
|
||||
str r3, [r6,#8]
|
||||
str r4, [r6,#0xc]
|
||||
ldr r6, [sp,#4]
|
||||
str r5, [r6]
|
||||
add sp, sp, #8
|
||||
ldmfd sp!, {r4-r6}
|
||||
bx lr
|
||||
push {r0, r1, r4-r6}
|
||||
svc 0x02
|
||||
ldr r6, [sp]
|
||||
str r1, [r6]
|
||||
str r2, [r6, #4]
|
||||
str r3, [r6, #8]
|
||||
str r4, [r6, #0xc]
|
||||
ldr r6, [sp, #4]
|
||||
str r5, [r6]
|
||||
add sp, sp, #8
|
||||
pop {r4-r6}
|
||||
bx lr
|
||||
|
||||
.global svcExitProcess
|
||||
.type svcExitProcess, %function
|
||||
svcExitProcess:
|
||||
svc 0x03
|
||||
bx lr
|
||||
bx lr
|
||||
|
||||
.global svcCreateThread
|
||||
.type svcCreateThread, %function
|
||||
svcCreateThread:
|
||||
stmfd sp!, {r0, r4}
|
||||
ldr r0, [sp, #0x8]
|
||||
ldr r4, [sp, #0x8+0x4]
|
||||
svc 0x08
|
||||
ldr r2, [sp], #4
|
||||
str r1, [r2]
|
||||
ldr r4, [sp], #4
|
||||
bx lr
|
||||
push {r0, r4}
|
||||
ldr r0, [sp, #0x8]
|
||||
ldr r4, [sp, #0x8+0x4]
|
||||
svc 0x08
|
||||
ldr r2, [sp], #4
|
||||
str r1, [r2]
|
||||
ldr r4, [sp], #4
|
||||
bx lr
|
||||
|
||||
.global svcExitThread
|
||||
.type svcExitThread, %function
|
||||
svcExitThread:
|
||||
svc 0x09
|
||||
bx lr
|
||||
bx lr
|
||||
|
||||
.global svcSleepThread
|
||||
.type svcSleepThread, %function
|
||||
svcSleepThread:
|
||||
svc 0x0A
|
||||
bx lr
|
||||
bx lr
|
||||
|
||||
.global svcSetThreadPriority
|
||||
.type svcSetThreadPriority, %function
|
||||
svcSetThreadPriority:
|
||||
svc 0x0C
|
||||
bx lr
|
||||
|
||||
.global svcCreateMutex
|
||||
.type svcCreateMutex, %function
|
||||
@ -75,61 +72,61 @@ svcCreateMutex:
|
||||
svc 0x13
|
||||
ldr r3, [sp], #4
|
||||
str r1, [r3]
|
||||
bx lr
|
||||
bx lr
|
||||
|
||||
.global svcReleaseMutex
|
||||
.type svcReleaseMutex, %function
|
||||
svcReleaseMutex:
|
||||
svc 0x14
|
||||
bx lr
|
||||
bx lr
|
||||
|
||||
.global svcCreateEvent
|
||||
.type svcCreateEvent, %function
|
||||
svcCreateEvent:
|
||||
str r0, [sp,#-4]!
|
||||
str r0, [sp, #-4]!
|
||||
svc 0x17
|
||||
ldr r2, [sp], #4
|
||||
str r1, [r2]
|
||||
bx lr
|
||||
bx lr
|
||||
|
||||
.global svcSignalEvent
|
||||
.type svcSignalEvent, %function
|
||||
svcSignalEvent:
|
||||
svc 0x18
|
||||
bx lr
|
||||
bx lr
|
||||
|
||||
.global svcClearEvent
|
||||
.type svcClearEvent, %function
|
||||
svcClearEvent:
|
||||
svc 0x19
|
||||
bx lr
|
||||
bx lr
|
||||
|
||||
.global svcCreateTimer
|
||||
.type svcCreateTimer, %function
|
||||
svcCreateTimer:
|
||||
str r0, [sp,#-4]!
|
||||
str r0, [sp, #-4]!
|
||||
svc 0x1A
|
||||
ldr r2, [sp], #4
|
||||
str r1, [r2]
|
||||
bx lr
|
||||
bx lr
|
||||
|
||||
.global svcSetTimer
|
||||
.type svcSetTimer, %function
|
||||
svcSetTimer:
|
||||
svc 0x1B
|
||||
bx lr
|
||||
bx lr
|
||||
|
||||
.global svcCancelTimer
|
||||
.type svcCancelTimer, %function
|
||||
svcCancelTimer:
|
||||
svc 0x1C
|
||||
bx lr
|
||||
bx lr
|
||||
|
||||
.global svcClearTimer
|
||||
.type svcClearTimer, %function
|
||||
svcClearTimer:
|
||||
svc 0x1D
|
||||
bx lr
|
||||
bx lr
|
||||
|
||||
.global svcCreateMemoryBlock
|
||||
.type svcCreateMemoryBlock, %function
|
||||
@ -139,49 +136,49 @@ svcCreateMemoryBlock:
|
||||
svc 0x1E
|
||||
ldr r2, [sp], #4
|
||||
str r1, [r2]
|
||||
bx lr
|
||||
bx lr
|
||||
|
||||
.global svcMapMemoryBlock
|
||||
.type svcMapMemoryBlock, %function
|
||||
svcMapMemoryBlock:
|
||||
svc 0x1F
|
||||
bx lr
|
||||
bx lr
|
||||
|
||||
.global svcUnmapMemoryBlock
|
||||
.type svcUnmapMemoryBlock, %function
|
||||
svcUnmapMemoryBlock:
|
||||
svc 0x20
|
||||
bx lr
|
||||
bx lr
|
||||
|
||||
.global svcCreateAddressArbiter
|
||||
.type svcCreateAddressArbiter, %function
|
||||
svcCreateAddressArbiter:
|
||||
svc 0x21
|
||||
bx lr
|
||||
bx lr
|
||||
|
||||
.global svcArbitrateAddress
|
||||
.type svcArbitrateAddress, %function
|
||||
svcArbitrateAddress:
|
||||
push {r4,r5}
|
||||
push {r4, r5}
|
||||
add sp, #8
|
||||
ldr r5, [sp]
|
||||
ldr r4, [sp, #4]
|
||||
sub sp, #8
|
||||
svc 0x22
|
||||
pop {r4,r5}
|
||||
bx lr
|
||||
pop {r4, r5}
|
||||
bx lr
|
||||
|
||||
.global svcCloseHandle
|
||||
.type svcCloseHandle, %function
|
||||
svcCloseHandle:
|
||||
svc 0x23
|
||||
bx lr
|
||||
bx lr
|
||||
|
||||
.global svcWaitSynchronization
|
||||
.type svcWaitSynchronization, %function
|
||||
svcWaitSynchronization:
|
||||
svc 0x24
|
||||
bx lr
|
||||
bx lr
|
||||
|
||||
.global svcWaitSynchronizationN
|
||||
.type svcWaitSynchronizationN, %function
|
||||
@ -195,16 +192,16 @@ svcWaitSynchronizationN:
|
||||
str r1, [r5]
|
||||
ldr r4, [sp], #4
|
||||
ldr r5, [sp], #4
|
||||
bx lr
|
||||
bx lr
|
||||
|
||||
.global svcDuplicateHandle
|
||||
.type svcDuplicateHandle, %function
|
||||
svcDuplicateHandle:
|
||||
str r0, [sp,#-0x4]!
|
||||
str r0, [sp, #-0x4]!
|
||||
svc 0x27
|
||||
ldr r3, [sp], #4
|
||||
str r1, [r3]
|
||||
bx lr
|
||||
bx lr
|
||||
|
||||
.global svcGetSystemTick
|
||||
.type svcGetSystemTick, %function
|
||||
@ -215,34 +212,34 @@ svcGetSystemTick:
|
||||
.global svcGetSystemInfo
|
||||
.type svcGetSystemInfo, %function
|
||||
svcGetSystemInfo:
|
||||
stmfd sp!, {r0, r4}
|
||||
svc 0x2A
|
||||
ldr r4, [sp], #4
|
||||
str r1, [r4]
|
||||
str r2, [r4, #4]
|
||||
str r3, [r4, #8]
|
||||
ldr r4, [sp], #4
|
||||
bx lr
|
||||
push {r0, r4}
|
||||
svc 0x2A
|
||||
ldr r4, [sp], #4
|
||||
str r1, [r4]
|
||||
str r2, [r4, #4]
|
||||
str r3, [r4, #8]
|
||||
ldr r4, [sp], #4
|
||||
bx lr
|
||||
|
||||
.global svcGetProcessInfo
|
||||
.type svcGetProcessInfo, %function
|
||||
svcGetProcessInfo:
|
||||
stmfd sp!, {r0, r4}
|
||||
svc 0x2B
|
||||
ldr r4, [sp], #4
|
||||
str r1, [r4]
|
||||
str r2, [r4, #4]
|
||||
ldr r4, [sp], #4
|
||||
bx lr
|
||||
push {r0,r4}
|
||||
svc 0x2B
|
||||
ldr r4, [sp], #4
|
||||
str r1, [r4]
|
||||
str r2, [r4, #4]
|
||||
ldr r4, [sp], #4
|
||||
bx lr
|
||||
|
||||
.global svcConnectToPort
|
||||
.type svcConnectToPort, %function
|
||||
svcConnectToPort:
|
||||
str r0, [sp,#-0x4]!
|
||||
str r0, [sp, #-0x4]!
|
||||
svc 0x2D
|
||||
ldr r3, [sp], #4
|
||||
str r1, [r3]
|
||||
bx lr
|
||||
bx lr
|
||||
|
||||
.global svcSendSyncRequest
|
||||
.type svcSendSyncRequest, %function
|
||||
@ -253,23 +250,17 @@ svcSendSyncRequest:
|
||||
.global svcGetProcessId
|
||||
.type svcGetProcessId, %function
|
||||
svcGetProcessId:
|
||||
str r0, [sp,#-0x4]!
|
||||
str r0, [sp, #-0x4]!
|
||||
svc 0x35
|
||||
ldr r3, [sp], #4
|
||||
str r1, [r3]
|
||||
bx lr
|
||||
|
||||
.global svcSetThreadPriority
|
||||
.type svcSetThreadPriority, %function
|
||||
svcSetThreadPriority:
|
||||
svc 0x0C
|
||||
bx lr
|
||||
bx lr
|
||||
|
||||
.global svcOutputDebugString
|
||||
.type svcOutputDebugString, %function
|
||||
svcOutputDebugString:
|
||||
str r0, [sp,#-0x4]!
|
||||
str r0, [sp, #-0x4]!
|
||||
svc 0x3D
|
||||
ldr r2, [sp], #4
|
||||
str r1, [r2]
|
||||
bx lr
|
||||
bx lr
|
||||
|
Loading…
Reference in New Issue
Block a user