diff options
author | Ulrich Drepper <drepper@redhat.com> | 2000-06-13 07:33:12 +0000 |
---|---|---|
committer | Ulrich Drepper <drepper@redhat.com> | 2000-06-13 07:33:12 +0000 |
commit | ab95290c787fb6e22bf03f23059b97559e1ad7d7 (patch) | |
tree | 892cff92b6d49d7c99a6d99c077882642fe6eda7 /sysdeps/unix/make-syscalls.sh | |
parent | a5c88158b6170149fa1b98e1704ed9dcab457314 (diff) | |
download | glibc-ab95290c787fb6e22bf03f23059b97559e1ad7d7.tar.gz glibc-ab95290c787fb6e22bf03f23059b97559e1ad7d7.tar.xz glibc-ab95290c787fb6e22bf03f23059b97559e1ad7d7.zip |
Update.
2000-06-13 Ulrich Drepper <drepper@redhat.com> * misc/sys/cdefs.h: Define __bounded and __unbounded if __BOUNDED_POINTERS__ is not defined. 2000-06-07 Greg McGary <greg@mcgary.org> * sysdeps/generic/bp-sym.h: New file. * sysdeps/generic/bp-start.h: New file. * sysdeps/i386/elf/start.S: Designate BP symbols. * sysdeps/generic/libc-start.c: Wrap bounds around argv & envp and each of their string members. 2000-06-07 Greg McGary <greg@mcgary.org> * sysdeps/unix/make-syscalls.sh: Add comments to output that aid debugging & comprehension. Map simple syscall signatures to number of args. Generate BP syscall thunk definitions. * sysdeps/generic/bp-thunks.h: New file. * sysdeps/unix/syscalls.list: Replace arg-count with simple return+arg signature. * sysdeps/unix/common/syscalls.list: Likewise. * sysdeps/unix/inet/syscalls.list: Likewise. * sysdeps/unix/mman/syscalls.list: Likewise. * sysdeps/unix/sysv/syscalls.list: Likewise. * sysdeps/unix/sysv/linux/syscalls.list: Likewise. * sysdeps/unix/sysv/linux/i386/syscalls.list: Likewise. 2000-06-07 Greg McGary <greg@mcgary.org> * Makeconfig (CPPFLAGS-.ob): pass -fbounded-pointers for all files *.[cS]. (CFLAGS-.ob): Don't optimize sibling calls. (bppfx): New variable. * Makerules (elide-bp-thunks): New variable. (elide-routines.*): Elide BP-* files for all but *.ob. (sources): Include bp-thunks. * iconv/gconv_simple.c: Remove unnecessary prototype. * iconv/gconv_trans.c: Pretty print.
Diffstat (limited to 'sysdeps/unix/make-syscalls.sh')
-rw-r--r-- | sysdeps/unix/make-syscalls.sh | 111 |
1 files changed, 75 insertions, 36 deletions
diff --git a/sysdeps/unix/make-syscalls.sh b/sysdeps/unix/make-syscalls.sh index 7aa4b3ea0d..387df6799e 100644 --- a/sysdeps/unix/make-syscalls.sh +++ b/sysdeps/unix/make-syscalls.sh @@ -5,47 +5,68 @@ thisdir=$1; shift -# Get the list of system calls for this directory. -calls=`sed 's/#.*$// -/^[ ]*$/d' $thisdir/syscalls.list` - +echo '' +echo \#### DIRECTORY = $thisdir # Check each sysdep dir with higher priority than this one, # and remove from $calls all the functions found in other dirs. -for dir in $sysdirs; do +# Punt when we reach the directory defining these syscalls. +sysdirs=`for dir in $sysdirs; do + test $dir = $thisdir && break; echo $dir; done` +echo \#### SYSDIRS = $sysdirs - # Punt when we reach the directory defining these syscalls. - test $dir = $thisdir && break +# Get the list of system calls for this directory. +calls=`sed 's/#.*$// +/^[ ]*$/d' $thisdir/syscalls.list` +calls=`echo "$calls" | +while read file caller rest; do # Remove each syscall that is implemented by a file in $dir. # If a syscall specified a "caller", then only compile that syscall # if the caller function is also implemented in this directory. - calls=`echo "$calls" | while read file caller rest; do - test -f $dir/$file.c && continue - test -f $dir/$file.S && continue - test -f $dir/$file.s && continue - if test x$caller != x-; then - test -f $dir/$caller.c && continue - test -f $dir/$caller.S && continue - test -f $dir/$caller.s && continue - fi - echo $file $caller $rest - done` - -done + srcfile=-; + for dir in $sysdirs; do + { test -f $dir/$file.c && srcfile=$dir/$file.c; } || + { test -f $dir/$file.S && srcfile=$dir/$file.S; } || + { test -f $dir/$file.s && srcfile=$dir/$file.s; } || + { test x$caller != x- && + { { test -f $dir/$caller.c && srcfile=$dir/$caller.c; } || + { test -f $dir/$caller.S && srcfile=$dir/$caller.S; } || + { test -f $dir/$caller.s && srcfile=$dir/$caller.s; }; }; } && break; + done; + echo $file $srcfile $caller $rest; +done` # Any calls left? test -n "$calls" || exit 0 -files= - # Emit rules to compile the syscalls remaining in $calls. -echo "$calls" | while read file caller syscall nargs strong weak; do +echo "$calls" | while read file srcfile caller syscall args strong weak; do + +# Figure out if $syscall is defined with a number in syscall.h. +callnum=- +eval `{ echo "#include <sysdep.h>"; + echo "callnum=SYS_ify ($syscall)"; } | + $asm_CPP - |grep "^callnum=" |grep -v $syscall` + + # Derive the number of arguments from the argument signature + case $args in + [0-9]) nargs=$args;; + ?:) nargs=0;; + ?:?) nargs=1;; + ?:??) nargs=2;; + ?:???) nargs=3;; + ?:????) nargs=4;; + ?:?????) nargs=5;; + ?:??????) nargs=6;; + esac - # Figure out if $syscall is defined with a number in syscall.h. - $asm_CPP - << EOF | grep "^@@@ .*$syscall" >/dev/null && continue -#include <sysdep.h> -@@@ SYS_ify ($syscall) -EOF + # Make sure only the first syscall rule is used, if multiple dirs + # define the same syscall. + echo "#### CALL=$file NUMBER=$callnum ARGS=$args SOURCE=$srcfile" + case x$srcfile$callnum in + x*-) ;; ### Do nothing for undefined callnum + x-*) + echo "ifeq (,\$(filter $file,\$(unix-syscalls)))" case $weak in *@*) @@ -53,11 +74,6 @@ EOF echo "ifneq (,\$(filter .os,\$(object-suffixes)))" ;; esac - - # Make sure only the first syscall rule is used, if multiple dirs - # define the same syscall. - echo "ifeq (,\$(filter $file,\$(unix-syscalls)))" - # Accumulate the list of syscall files for this directory. echo "unix-syscalls += $file" test x$caller = x- || echo "unix-extra-syscalls += $file" @@ -75,7 +91,7 @@ shared-only-routines += $file \$(foreach o,\$(object-suffixes),\$(objpfx)$file\$o): \\" ;; esac - echo "\$(common-objpfx)s-proto.d + echo " \$(common-objpfx)s-proto.d (echo '#include <sysdep.h>'; \\ echo 'PSEUDO ($strong, $syscall, $nargs)'; \\ echo ' ret'; \\ @@ -124,8 +140,6 @@ shared-only-routines += $file # And finally, pipe this all into the compiler. echo ' ) | $(COMPILE.S) -x assembler-with-cpp -o $@ -' - echo endif - case $weak in *@*) # The versioned symbols are only in the shared library. @@ -133,4 +147,29 @@ shared-only-routines += $file ;; esac + echo endif + ;; + esac + + case x$callnum,$srcfile,$args in + x[0-9]*,-,*[sp]* | x*,*.[sS],*[sp]*) + echo "ifeq (,\$(filter $file,\$(bp-thunks)))" + echo "bp-thunks += $file"; + echo "\ +\$(objpfx)\$(bppfx)$file.ob: \$(common-objpfx)s-proto.d + (echo '#include <bp-thunks.h>'; \\ + echo 'BP_THUNK_`echo $args |tr : _` ($strong)'; \\" + + for name in $weak; do + case $name in + *@*) ;; + *) echo " echo 'BP_ALIAS ($strong, $name)'; \\" ;; + esac + done + + echo ' ) | $(COMPILE.c) -x c -o $@ -' + echo endif + ;; + esac + done |