diff options
| author | Bernhard Reutner-Fischer <rep.dot.nop@gmail.com> | 2011-10-30 21:57:39 +0100 | 
|---|---|---|
| committer | Bernhard Reutner-Fischer <rep.dot.nop@gmail.com> | 2011-11-02 16:49:04 +0100 | 
| commit | 04df27ce9847a2ce7d1104732cc497d4e6f02d89 (patch) | |
| tree | 8bb6f2b37f4f99c9fc8ea07b2e3a67f4e9495c59 /libc | |
| parent | 3c331f45196eaea2548aea095cebf1a8dcfac087 (diff) | |
stubs: handle linux-specific
Signed-off-by: Bernhard Reutner-Fischer <rep.dot.nop@gmail.com>
Diffstat (limited to 'libc')
| -rw-r--r-- | libc/sysdeps/linux/common/Makefile.in | 47 | ||||
| -rw-r--r-- | libc/sysdeps/linux/common/stubs.c | 156 | 
2 files changed, 184 insertions, 19 deletions
| diff --git a/libc/sysdeps/linux/common/Makefile.in b/libc/sysdeps/linux/common/Makefile.in index 63f3f6f07..570bb93e7 100644 --- a/libc/sysdeps/linux/common/Makefile.in +++ b/libc/sysdeps/linux/common/Makefile.in @@ -18,14 +18,45 @@ CSRC-$(findstring y,$(UCLIBC_HAS_SSP)$(UCLIBC_HAS_FORTIFY)) += ssp.c  CSRC-$(UCLIBC_LINUX_MODULE_24) += create_module.c query_module.c \  	get_kernel_syms.c  # we need these internally: fstatfs.c statfs.c -CSRC-$(UCLIBC_LINUX_SPECIFIC) += capget.c capset.c inotify.c ioperm.c iopl.c \ -	modify_ldt.c pipe2.c personality.c ppoll.c prctl.c \ -	readahead.c reboot.c \ -	remap_file_pages.c sched_getaffinity.c sched_setaffinity.c \ -	sendfile64.c sendfile.c setfsgid.c setfsuid.c setresuid.c \ -	splice.c vmsplice.c tee.c signalfd.c swapoff.c swapon.c \ -	sync_file_range.c sysctl.c sysinfo.c eventfd.c timerfd.c uselib.c \ -	vhangup.c +CSRC-$(UCLIBC_LINUX_SPECIFIC) += \ +	bdflush.c \ +	capget.c \ +	capset.c \ +	eventfd.c \ +	inotify.c \ +	ioperm.c \ +	iopl.c \ +	modify_ldt.c \ +	personality.c \ +	pipe2.c \ +	ppoll.c \ +	prctl.c \ +	readahead.c \ +	reboot.c \ +	remap_file_pages.c \ +	sched_getaffinity.c \ +	sched_setaffinity.c \ +	sendfile.c \ +	setfsgid.c \ +	setfsuid.c \ +	setresgid.c \ +	setresuid.c \ +	signalfd.c \ +	splice.c \ +	swapoff.c \ +	swapon.c \ +	sync_file_range.c \ +	sysctl.c \ +	sysinfo.c \ +	tee.c \ +	timerfd.c \ +	umount2.c \ +	umount.c \ +	uselib.c \ +	vhangup.c \ +	vmsplice.c +CSRC-$(if $(findstring yy,$(UCLIBC_LINUX_SPECIFIC)$(UCLIBC_HAS_LFS)),y) += \ +	sendfile64.c  # NPTL needs these internally: madvise.c  CSRC-$(findstring y,$(UCLIBC_LINUX_SPECIFIC)$(UCLIBC_HAS_THREADS_NATIVE)) += madvise.c  ifeq ($(UCLIBC_HAS_THREADS_NATIVE),y) diff --git a/libc/sysdeps/linux/common/stubs.c b/libc/sysdeps/linux/common/stubs.c index fc2d98d5a..2f170ead9 100644 --- a/libc/sysdeps/linux/common/stubs.c +++ b/libc/sysdeps/linux/common/stubs.c @@ -7,6 +7,7 @@   */  #include <errno.h> +#include <bits/wordsize.h>  #include <sys/syscall.h>  #ifdef __UCLIBC_HAS_STUBS__ @@ -46,6 +47,7 @@ static int enosys_stub(void)  # undef __NR_modify_ldt  # undef __NR_personality  # undef __NR_pipe2 +# undef __NR_pivot_root  # undef __NR_ppoll  # undef __NR_prctl  # undef __NR_readahead @@ -99,7 +101,19 @@ make_stub(accept)  make_stub(accept4)  #endif -#ifndef __NR_bdflush +#if !defined __NR_arch_prctl && defined __UCLIBC_LINUX_SPECIFIC__ +make_stub(arch_prctl) +#endif + +#if !defined __NR_capget && defined __UCLIBC_LINUX_SPECIFIC__ +make_stub(capget) +#endif + +#if !defined __NR_capset && defined __UCLIBC_LINUX_SPECIFIC__ +make_stub(capset) +#endif + +#if !defined __NR_bdflush && defined __UCLIBC_LINUX_SPECIFIC__  make_stub(bdflush)  #endif @@ -163,6 +177,10 @@ make_stub(fremovexattr)  make_stub(fsetxattr)  #endif +#if !defined __NR_fstatfs && defined __UCLIBC_LINUX_SPECIFIC__ +make_stub(fstatfs) +#endif +  #ifndef __NR_get_kernel_syms  make_stub(get_kernel_syms)  #endif @@ -191,6 +209,30 @@ make_stub(getxattr)  make_stub(init_module)  #endif +#if !defined __NR_inotify_init && defined __UCLIBC_LINUX_SPECIFIC__ +make_stub(inotify_init) +#endif + +#if !defined __NR_inotify_init1 && defined __UCLIBC_LINUX_SPECIFIC__ +make_stub(inotify_init1) +#endif + +#if !defined __NR_inotify_add_watch && defined __UCLIBC_LINUX_SPECIFIC__ +make_stub(inotify_add_watch) +#endif + +#if !defined __NR_inotify_rm_watch && defined __UCLIBC_LINUX_SPECIFIC__ +make_stub(inotify_rm_watch) +#endif + +#if !defined __NR_ioperm && defined __UCLIBC_LINUX_SPECIFIC__ +make_stub(ioperm) +#endif + +#if !defined __NR_iopl && defined __UCLIBC_LINUX_SPECIFIC__ +make_stub(iopl) +#endif +  #ifndef __NR_lgetxattr  make_stub(lgetxattr)  #endif @@ -215,19 +257,47 @@ make_stub(lremovexattr)  make_stub(lsetxattr)  #endif -#ifndef __NR_pipe2 +#if !defined __NR_madvise && defined __UCLIBC_LINUX_SPECIFIC__ +make_stub(madvise) +#endif + +#if !defined __NR_modify_ldt && defined __UCLIBC_LINUX_SPECIFIC__ +make_stub(modify_ldt) +#endif + +#if !defined __NR_personality && defined __UCLIBC_LINUX_SPECIFIC__ +make_stub(personality) +#endif + +#if !defined __NR_pipe2 && defined __UCLIBC_LINUX_SPECIFIC__  make_stub(pipe2)  #endif -#ifndef __NR_pivot_root +#if !defined __NR_pivot_root && defined __UCLIBC_LINUX_SPECIFIC__  make_stub(pivot_root)  #endif +#if !defined __NR_ppoll && defined __UCLIBC_LINUX_SPECIFIC__ +make_stub(ppoll) +#endif + +#if !defined __NR_prctl && defined __UCLIBC_LINUX_SPECIFIC__ +make_stub(prctl) +#endif + +#if !defined __NR_readahead && defined __UCLIBC_LINUX_SPECIFIC__ +make_stub(readahead) +#endif + +#if !defined __NR_reboot && defined __UCLIBC_LINUX_SPECIFIC__ +make_stub(reboot) +#endif +  #ifndef __NR_query_module  make_stub(query_module)  #endif -#if !defined __NR_recv && !defined __NR_socketcall && && !defined __NR_recvfrom && defined __UCLIBC_HAS_SOCKET__ +#if !defined __NR_recv && !defined __NR_socketcall && !defined __NR_recvfrom && defined __UCLIBC_HAS_SOCKET__  make_stub(recv)  #endif @@ -239,15 +309,19 @@ make_stub(recvfrom)  make_stub(recvmsg)  #endif +#if !defined __NR_remap_file_pages && defined __UCLIBC_LINUX_SPECIFIC__ +make_stub(remap_file_pages) +#endif +  #ifndef __NR_removexattr  make_stub(removexattr)  #endif -#ifndef __NR_sched_getaffinity +#if !defined __NR_sched_getaffinity && defined __UCLIBC_LINUX_SPECIFIC__  make_stub(sched_getaffinity)  #endif -#ifndef __NR_sched_setaffinity +#if !defined __NR_sched_setaffinity && defined __UCLIBC_LINUX_SPECIFIC__  make_stub(sched_setaffinity)  #endif @@ -255,6 +329,14 @@ make_stub(sched_setaffinity)  make_stub(send)  #endif +#if !defined __NR_sendfile && defined __UCLIBC_LINUX_SPECIFIC__ +make_stub(sendfile) +#endif + +#if !defined __NR_sendfile64 && !defined __NR_sendfile && defined __UCLIBC_LINUX_SPECIFIC__ && defined __UCLIBC_HAS_LFS__ +make_stub(sendfile64) +#endif +  #if !defined __NR_sendmsg && !defined __NR_socketcall && defined __UCLIBC_HAS_SOCKET__  make_stub(sendmsg)  #endif @@ -263,6 +345,22 @@ make_stub(sendmsg)  make_stub(sendto)  #endif +#if ((__WORDSIZE == 32 && (!defined __NR_setfsgid32 && !defined __NR_setfsgid)) || (__WORDSIZE == 64 && !defined __NR_setfsgid)) && defined __UCLIBC_LINUX_SPECIFIC__ +make_stub(setfsgid) +#endif + +#if ((__WORDSIZE == 32 && (!defined __NR_setfsuid32 && !defined __NR_setfsuid)) || (__WORDSIZE == 64 && !defined __NR_setfsuid)) && defined __UCLIBC_LINUX_SPECIFIC__ +make_stub(setfsuid) +#endif + +#if !defined __NR_setresgid32 && !defined __NR_setresgid && defined __UCLIBC_LINUX_SPECIFIC__ +make_stub(setresgid) +#endif + +#if !defined __NR_setresuid32 && !defined __NR_setresuid && defined __UCLIBC_LINUX_SPECIFIC__ +make_stub(setresuid) +#endif +  #if !defined __NR_setsockopt && !defined __NR_socketcall && defined __UCLIBC_HAS_SOCKET__  make_stub(setsockopt)  #endif @@ -275,7 +373,7 @@ make_stub(setxattr)  make_stub(shutdown)  #endif -#if !defined(__NR_signalfd4) && !defined(__NR_signalfd) +#if !defined __NR_signalfd4 && !defined __NR_signalfd && defined __UCLIBC_LINUX_SPECIFIC__  make_stub(signalfd)  #endif @@ -296,19 +394,51 @@ make_stub(sigtimedwait)  make_stub(sigwaitinfo)  #endif -#ifndef __NR_splice +#if !defined __NR_splice && defined __UCLIBC_LINUX_SPECIFIC__  make_stub(splice)  #endif -#ifndef __NR_sync_file_range +#if !defined __NR_swapoff && defined __UCLIBC_LINUX_SPECIFIC__ +make_stub(swapoff) +#endif + +#if !defined __NR_swapon && defined __UCLIBC_LINUX_SPECIFIC__ +make_stub(swapon) +#endif + +#if !defined __NR_sync_file_range && defined __UCLIBC_LINUX_SPECIFIC__  make_stub(sync_file_range)  #endif -#if !defined(__NR_umount) && !defined(__NR_umount2) +#if !defined __NR__sysctl && defined __UCLIBC_LINUX_SPECIFIC__ +make_stub(_sysctl) +#endif + +#if !defined __NR_sysinfo && defined __UCLIBC_LINUX_SPECIFIC__ +make_stub(sysinfo) +#endif + +#if !defined __NR_tee && defined __UCLIBC_LINUX_SPECIFIC__ +make_stub(tee) +#endif + +#if !defined __NR_timerfd_create && defined __UCLIBC_LINUX_SPECIFIC__ +make_stub(timerfd_create) +#endif + +#if !defined __NR_timerfd_settime && defined __UCLIBC_LINUX_SPECIFIC__ +make_stub(timerfd_settime) +#endif + +#if !defined __NR_timerfd_gettime && defined __UCLIBC_LINUX_SPECIFIC__ +make_stub(timerfd_gettime) +#endif + +#if !defined __NR_umount && !defined __NR_umount2 && defined __UCLIBC_LINUX_SPECIFIC__  make_stub(umount)  #endif -#ifndef __NR_umount2 +#if !defined __NR_umount2 && defined __UCLIBC_LINUX_SPECIFIC__  make_stub(umount2)  #endif @@ -320,6 +450,10 @@ make_stub(lutimes)  # endif  #endif +#if !defined __NR_vhangup && defined __UCLIBC_LINUX_SPECIFIC__ +make_stub(vhangup) +#endif +  #ifndef __NR_vmsplice  make_stub(vmsplice)  #endif | 
