123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146 |
- #include <sys/syscall.h>
- #ifdef __STDC__
- #ifdef __ELF__
- #define SYSCALL_WEAK_ALIAS(alias,orig) \
- .weak alias; \
- alias=__libc_##orig
- #if 1
- #ifdef PTHREAD_KERNEL
- #define SYSCALL__(name,args) PSEUDO (__machdep_sys_##name, name, args) \
- .weak machdep_sys_##name; \
- machdep_sys_##name = __machdep_sys_##name; \
- .type __machdep_sys_##name,@function; \
- .type machdep_sys_##name,@function; \
- .L__machdep_sys_##name##end: .size __machdep_sys_##name,.L__machdep_sys_##name##end - __machdep_sys_##name
- #define SYSCALL(name,args) PSEUDO (__machdep_sys_##name, name, args) \
- .weak machdep_sys_##name; \
- machdep_sys_##name = __machdep_sys_##name; \
- .type __machdep_sys_##name,@function; \
- .type machdep_sys_##name,@function; \
- .L__machdep_sys_##name##end: .size __machdep_sys_##name,.L__machdep_sys_##name##end - __machdep_sys_##name
- #else
- #define SYSCALL__(name,args) PSEUDO (__libc_##name, name, args) \
- .weak __##name; \
- .weak name; \
- __##name = __libc_##name; \
- name = __libc_##name; \
- .type __libc_##name,@function; \
- .type name,@function; \
- .type __##name,@function; \
- .L__libc_##name##end: .size __libc_##name,.L__libc_##name##end - __libc_##name
- #define SYSCALL(name,args) PSEUDO (__libc_##name, name, args) \
- .weak name; \
- name = __libc_##name; \
- .type __libc_##name,@function; \
- .type name,@function; \
- .L__libc_##name##end: .size __libc_##name,.L__libc_##name##end - __libc_##name
- #endif
- #else
- #define SYSCALL__(name,args) PSEUDO (__libc_##name, name, args) \
- .weak name; \
- __##name = __libc_##name; \
- name = __libc_##name; \
- .type __libc_##name,@function; \
- .type name,@function; \
- .type __##name,@function; \
- .L__libc_##name##end: .size __libc_##name,.L__libc_##name##end - __libc_##name
- #define SYSCALL(name,args) PSEUDO (__libc_##name, name, args) \
- name = __libc_##name; \
- .type __libc_##name,@function; \
- .type name,@function; \
- .L__libc_##name##end: .size __libc_##name,.L__libc_##name##end - __libc_##name
- #endif
- #else
- #define SYSCALL_WEAK_ALIAS(alias,orig)
- #define SYSCALL__(name,args) PSEUDO (__##name, name, args)
- #define SYSCALL(name,args) PSEUDO (name, name, args)
- #endif
- #else
- #define SYSCALL__(name,args) PSEUDO (__name, name, args)
- #define SYSCALL(name,args) PSEUDO (name, name, args)
- #endif
- #if !defined(HAVE_GNU_LD) && !defined (__ELF__)
- #define ___errno _errno
- #endif
- #define HAVE_SYSCALLS
- #define ENTRY(name)
- .global name;
- .align 4;
- #define END(name)
- .size name,.-name;
- #define PSEUDO(name, syscall_name, args) \
- .text; \
- ENTRY(name); \
- ta 0x10; \
- bcc,a 9000f; \
- nop; \
- 9000:;
- #define PSEUDO_END(name) \
- .size name,.-name;
|