X-Git-Url: https://git.saurik.com/apple/xnu.git/blobdiff_plain/2d21ac55c334faf3a56e5634905ed6987fc787d4..13f56ec4e58bf8687e2a68032c093c0213dd519b:/libsyscall/custom/custom.s?ds=inline diff --git a/libsyscall/custom/custom.s b/libsyscall/custom/custom.s index c18fabc0e..b9d46ba13 100644 --- a/libsyscall/custom/custom.s +++ b/libsyscall/custom/custom.s @@ -30,35 +30,7 @@ #include "SYS.h" -#if defined(__ppc__) || defined(__ppc64__) - -/* We use mode-independent "g" opcodes such as "srgi", and/or - * mode-independent macros such as MI_GET_ADDRESS. These expand - * into word operations when targeting __ppc__, and into doubleword - * operations when targeting __ppc64__. - */ -#include - - .globl _errno - -MI_ENTRY_POINT(cerror) - MI_PUSH_STACK_FRAME - MI_GET_ADDRESS(r12,_errno) - stw r3,0(r12) /* save syscall return code in global */ - MI_CALL_EXTERNAL(_cthread_set_errno_self) - li r3,-1 /* then bug return value */ - li r4,-1 /* in case we're returning a long-long in 32-bit mode, etc */ - MI_POP_STACK_FRAME_AND_RETURN - - - .globl _processor_facilities_used - .align 2 -_processor_facilities_used: - li r0,0x7FF3 - sc - blr - -#elif defined(__i386__) +#if defined(__i386__) .globl _errno @@ -75,9 +47,7 @@ LABEL(cerror) movl $-1,%edx /* in case a 64-bit value is returned */ ret - .private_extern __sysenter_trap - ALIGN -__sysenter_trap: +LABEL(__sysenter_trap) popl %edx movl %esp, %ecx sysenter @@ -87,8 +57,9 @@ __sysenter_trap: .globl _errno LABEL(cerror) - REG_TO_EXTERN(%rax, _errno) - mov %rsp,%rdx + PICIFY(_errno) /* address -> %r11 */ + movl %eax,(%r11) + mov %rsp,%rdx andq $-16,%rsp subq $16,%rsp // Preserve the original stack @@ -101,20 +72,6 @@ LABEL(cerror) movq $-1,%rdx /* in case a 128-bit value is returned */ ret -#elif defined(__arm__) - - .globl _errno - -MI_ENTRY_POINT(cerror) - stmfd sp!, {r7, lr} - mov r7, sp - MI_GET_ADDRESS(r3,_errno) - str r0, [r3] - MI_CALL_EXTERNAL(_cthread_set_errno_self) - mov r0, #-1 - mov r1, #-1 - ldmfd sp!, {r7, pc} - #else #error Unsupported architecture #endif