123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146 |
- /* Copyright (C) 1991, 1992 Free Software Foundation, Inc.
- This file is part of the GNU C Library.
- The GNU C Library is free software; you can redistribute it and/or
- modify it under the terms of the GNU Library General Public License as
- published by the Free Software Foundation; either version 2 of the
- License, or (at your option) any later version.
- The GNU C Library is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- Library General Public License for more details.
- You should have received a copy of the GNU Library General Public
- License along with the GNU C Library; see the file COPYING.LIB. If
- not, write to the Free Software Foundation, Inc., 675 Mass Ave,
- Cambridge, MA 02139, USA. */
- #include <sys/syscall.h>
- /* Not that using a `PASTE' macro loses. */
- #ifdef __STDC__
- #ifdef __ELF__
- #define SYSCALL_WEAK_ALIAS(alias,orig) \
- .weak alias; \
- alias=__libc_##orig
- /*
- #ifdef _POSIX_THREADS
- */
- #if 1
- #ifdef PTHREAD_KERNEL
- /* Use the regular ELF conventions about underscores, and provide the
- weak symbol, as required */
- #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 /* PTHREAD_KERNEL */
- /* Use the regular ELF conventions about underscores, and provide the
- weak symbol, as required */
- #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 /* PTHREAD_KERNEL */
- #else /* _POSIX_THREADS */
- /* Use the regular ELF conventions about underscores, and provide the
- weak symbol, as required */
- #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 /* _POSIX_THREADS */
- #else /* __ELF__ */
- #define SYSCALL_WEAK_ALIAS(alias,orig)
- /* Regular a.out definition */
- #define SYSCALL__(name,args) PSEUDO (__##name, name, args)
- #define SYSCALL(name,args) PSEUDO (name, name, args)
- #endif /* __ELF__ */
- #else /* __STDC__ */
- #define SYSCALL__(name,args) PSEUDO (__/**/name, name, args)
- #define SYSCALL(name,args) PSEUDO (name, name, args)
- #endif /* __STDC__ */
- /* Machine-dependent sysdep.h files are expected to define the macro
- PSEUDO (function_name, syscall_name) to emit assembly code to define the
- C-callable function FUNCTION_NAME to do system call SYSCALL_NAME.
- r0 and r1 are the system call outputs. movl should be defined as
- an instruction such that "movl r1, r0" works. ret should be defined
- as the return instruction. */
- #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;
|