mirror of
				https://sourceware.org/git/glibc.git
				synced 2025-10-26 00:57:39 +03:00 
			
		
		
		
	* sysdeps/generic/bp-checks.h: New file.
* sysdeps/generic/bp-thunks.h: Replace generic thunk definitions with list of #include files. * sysdeps/unix/make-syscalls.sh: Handle new arg signature keyletters a, b, B, f, n, N, P, v, V. Fixup some indentation. Don't generate BP thunk if `V' appears in signature. Generate thunks with complete bounds checks. * sysdeps/unix/syscalls.list: Refine signatures using new keyletters. * sysdeps/unix/inet/syscalls.list: Likewise. * sysdeps/unix/mman/syscalls.list: Likewise. * sysdeps/unix/sysv/linux/syscalls.list: Likewise. * sysdeps/unix/sysv/linux/ia64/syscalls.list: Likewise. * sysdeps/unix/sysv/linux/mips/syscalls.list: Likewise. * sysdeps/unix/sysv/linux/powerpc/syscalls.list: Likewise. 2000-07-05 Greg McGary <greg@mcgary.org> * sysdeps/generic/bp-checks.h: New file. * sysdeps/generic/bp-thunks.h: Replace generic thunk definitions with list of #include files. * sysdeps/unix/make-syscalls.sh: Handle new arg signature keyletters a, b, B, f, n, N, P, v, V. Fixup some indentation. Don't generate BP thunk if `V' appears in signature. Generate thunks with complete bounds checks. * sysdeps/unix/syscalls.list: Refine signatures using new keyletters. * sysdeps/unix/inet/syscalls.list: Likewise. * sysdeps/unix/mman/syscalls.list: Likewise. * sysdeps/unix/sysv/linux/syscalls.list: Likewise. * sysdeps/unix/sysv/linux/ia64/syscalls.list: Likewise. * sysdeps/unix/sysv/linux/mips/syscalls.list: Likewise. * sysdeps/unix/sysv/linux/powerpc/syscalls.list: Likewise.
This commit is contained in:
		
							
								
								
									
										17
									
								
								ChangeLog
									
									
									
									
									
								
							
							
						
						
									
										17
									
								
								ChangeLog
									
									
									
									
									
								
							| @@ -1,3 +1,20 @@ | |||||||
|  | 2000-07-05  Greg McGary  <greg@mcgary.org> | ||||||
|  |  | ||||||
|  | 	* sysdeps/generic/bp-checks.h: New file. | ||||||
|  | 	* sysdeps/generic/bp-thunks.h: Replace generic thunk definitions | ||||||
|  | 	with list of #include files. | ||||||
|  | 	* sysdeps/unix/make-syscalls.sh: Handle new arg signature | ||||||
|  | 	keyletters a, b, B, f, n, N, P, v, V.  Fixup some indentation. | ||||||
|  | 	Don't generate BP thunk if `V' appears in signature. | ||||||
|  | 	Generate thunks with complete bounds checks. | ||||||
|  | 	* sysdeps/unix/syscalls.list: Refine signatures using new keyletters. | ||||||
|  | 	* sysdeps/unix/inet/syscalls.list: Likewise. | ||||||
|  | 	* sysdeps/unix/mman/syscalls.list: Likewise. | ||||||
|  | 	* sysdeps/unix/sysv/linux/syscalls.list: Likewise. | ||||||
|  | 	* sysdeps/unix/sysv/linux/ia64/syscalls.list: Likewise. | ||||||
|  | 	* sysdeps/unix/sysv/linux/mips/syscalls.list: Likewise. | ||||||
|  | 	* sysdeps/unix/sysv/linux/powerpc/syscalls.list: Likewise. | ||||||
|  |  | ||||||
| 2000-07-05  Ulrich Drepper  <drepper@redhat.com> | 2000-07-05  Ulrich Drepper  <drepper@redhat.com> | ||||||
|  |  | ||||||
| 	* sysdeps/unix/sysv/linux/getsysstats.c (get_proc_path): Cache | 	* sysdeps/unix/sysv/linux/getsysstats.c (get_proc_path): Cache | ||||||
|   | |||||||
							
								
								
									
										98
									
								
								sysdeps/generic/bp-checks.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										98
									
								
								sysdeps/generic/bp-checks.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,98 @@ | |||||||
|  | /* Bounded-pointer checking macros for C. | ||||||
|  |    Copyright (C) 2000 Free Software Foundation, Inc. | ||||||
|  |    Contributed by Greg McGary <greg@mcgary.org> | ||||||
|  |  | ||||||
|  |    This file is part of the GNU C Library.  Its master source is NOT part of | ||||||
|  |    the C library, however.  The master source lives in the GNU MP 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., 59 Temple Place - Suite 330, | ||||||
|  |    Boston, MA 02111-1307, USA.  */ | ||||||
|  |  | ||||||
|  | #ifndef _bp_checks_h_ | ||||||
|  | # define _bp_checks_h_ 1 | ||||||
|  |  | ||||||
|  | # if !__ASSEMBLER__ | ||||||
|  |  | ||||||
|  | #  if __BOUNDED_POINTERS__ | ||||||
|  |  | ||||||
|  | /* GKM FIXME: when gcc is ready, add real bounds checks */ | ||||||
|  | #   define BOUNDS_VIOLATED (__builtin_trap (), 0) | ||||||
|  | extern int __ubp_memchr (const char *__unbounded, int, unsigned); | ||||||
|  |  | ||||||
|  | /* Verify that pointer's value >= low.  Return pointer value.  */ | ||||||
|  | #   define CHECK_BOUNDS_LOW(ARG)				\ | ||||||
|  |   (((__ptrvalue (ARG) < __ptrlow (ARG)) && BOUNDS_VIOLATED),	\ | ||||||
|  |    __ptrvalue (ARG)) | ||||||
|  |  | ||||||
|  | /* Verify that pointer's value < high.  Return pointer value.  */ | ||||||
|  | #   define CHECK_BOUNDS_HIGH(ARG)				\ | ||||||
|  |   (((__ptrvalue (ARG) > __ptrhigh (ARG)) && BOUNDS_VIOLATED),	\ | ||||||
|  |    __ptrvalue (ARG)) | ||||||
|  |  | ||||||
|  | /* Check bounds of a pointer seated to a single object.  */ | ||||||
|  | #   define CHECK_1(ARG) CHECK_N ((ARG), 1) | ||||||
|  |  | ||||||
|  | /* Same as CHECK_1, but tolerate ARG == NULL.  */ | ||||||
|  | #   define CHECK_1opt(ARG) CHECK_Nopt ((ARG), 1) | ||||||
|  |  | ||||||
|  | /* Check bounds of a pointer seated to an array of N objects.  */ | ||||||
|  | #   define CHECK_N(ARG, N)				\ | ||||||
|  |   (((__ptrvalue (ARG) < __ptrlow (ARG)			\ | ||||||
|  |      || __ptrvalue (ARG) + (N) > __ptrhigh (ARG))	\ | ||||||
|  |     && BOUNDS_VIOLATED), __ptrvalue (ARG)) | ||||||
|  |  | ||||||
|  | /* Same as CHECK_N, but tolerate ARG == NULL.  */ | ||||||
|  | #   define CHECK_Nopt(ARG, N)				\ | ||||||
|  |   (((__ptrvalue (ARG)					\ | ||||||
|  |      && (__ptrvalue (ARG) < __ptrlow (ARG)		\ | ||||||
|  | 	 || __ptrvalue (ARG) + (N) > __ptrhigh (ARG)))	\ | ||||||
|  |     && BOUNDS_VIOLATED), __ptrvalue (ARG)) | ||||||
|  |  | ||||||
|  | /* Check for NUL-terminator within string's bounds.  */ | ||||||
|  | #   define CHECK_STRING(ARG)					\ | ||||||
|  |   (((__ptrvalue (ARG) < __ptrlow (ARG)				\ | ||||||
|  |      || !__ubp_memchr (__ptrvalue (ARG), '\0',			\ | ||||||
|  | 		       (__ptrhigh (ARG) - __ptrvalue (ARG))))	\ | ||||||
|  |      && BOUNDS_VIOLATED),					\ | ||||||
|  |    __ptrvalue (ARG)) | ||||||
|  |  | ||||||
|  | #  else /* !__BOUNDED_POINTERS__ */ | ||||||
|  |  | ||||||
|  | /* Do nothing if not compiling with -fbounded-pointers.  */ | ||||||
|  |  | ||||||
|  | #   define BOUNDS_VIOLATED | ||||||
|  | #   define CHECK_BOUNDS_LOW(ARG) (ARG) | ||||||
|  | #   define CHECK_BOUNDS_HIGH(ARG) (ARG) | ||||||
|  | #   define CHECK_1(ARG) (ARG) | ||||||
|  | #   define CHECK_1opt(ARG) (ARG) | ||||||
|  | #   define CHECK_N(ARG, N) (ARG) | ||||||
|  | #   define CHECK_Nopt(ARG, N) (ARG) | ||||||
|  | #   define CHECK_STRING(ARG) (ARG) | ||||||
|  |  | ||||||
|  | #  endif /* !__BOUNDED_POINTERS__ */ | ||||||
|  |  | ||||||
|  | #  if defined (_IOC_SIZESHIFT) && defined (_IOC_SIZEBITS) | ||||||
|  |  | ||||||
|  | /* Extract the size of the ioctl parameter argument and check its bounds.  */ | ||||||
|  | #   define CHECK_IOCTL(ARG, CMD) \ | ||||||
|  |   CHECK_N ((ARG), (((CMD) >> _IOC_SIZESHIFT) & ((1 << _IOC_SIZEBITS) - 1))) | ||||||
|  |  | ||||||
|  | #  else | ||||||
|  | #   define CHECK_IOCTL(ARG, CMD) __ptrvalue (ARG) | ||||||
|  | #  endif | ||||||
|  |  | ||||||
|  | # endif /* !__ASSEMBLER__ */ | ||||||
|  |  | ||||||
|  | #endif /* _bp_checks_h_ */ | ||||||
| @@ -1,4 +1,4 @@ | |||||||
| /* Bounded-pointer thunk definitions. | /* Bounded-pointer syscall thunk support. | ||||||
|    Copyright (C) 2000 Free Software Foundation, Inc. |    Copyright (C) 2000 Free Software Foundation, Inc. | ||||||
|    Contributed by Greg McGary <greg@mcgary.org> |    Contributed by Greg McGary <greg@mcgary.org> | ||||||
|  |  | ||||||
| @@ -23,203 +23,39 @@ | |||||||
| #ifndef _bpthunks_h_ | #ifndef _bpthunks_h_ | ||||||
| #define _bpthunks_h_ | #define _bpthunks_h_ | ||||||
|  |  | ||||||
|  | /* This header is included by the syscall BP thunks defined in | ||||||
|  |    sysd-syscalls, as created by sysdeps/unix/make-syscalls.sh.  It | ||||||
|  |    includes all headers that contain prototype declarations for system | ||||||
|  |    call functions.  */ | ||||||
|  |  | ||||||
| #include <libc-symbols.h> | #include <libc-symbols.h> | ||||||
|  | #include <bp-sym.h> | ||||||
| #define BP_ALIAS(STRONG, ALIAS) weak_alias (__BP_##STRONG, __BP_##ALIAS) | #include <bp-checks.h> | ||||||
|  | #include <stddef.h> | ||||||
| #define PV(P) __ptrvalue (P) | #include <unistd.h> | ||||||
| #define SV(S) __ptrvalue (S) | #include <sched.h> | ||||||
| #define PB(P) __ptrlow (P) | #include <signal.h> | ||||||
| #define PE(P) __ptrhigh (P) | #include <fcntl.h> | ||||||
| #define voidp void *__bounded | #include <utime.h> | ||||||
| #define charp char *__bounded | #include <sys/types.h> | ||||||
|  | #include <sys/ioctl.h> | ||||||
| /* GKM FIXME: Add code to check bounds.  Right now, they only strip bounds, */ | #include <sys/klog.h> | ||||||
|  | #include <sys/mman.h> | ||||||
| #define BP_THUNK_i_iiip(NAME) __unbounded { \ | #include <sys/mount.h> | ||||||
|   extern int NAME (int, int, int, void *); \ | #include <sys/quota.h> | ||||||
|   int __BP_##NAME (int i0, int i1, int i2, voidp p3) \ | #include <sys/resource.h> | ||||||
|     { return NAME (i0, i1, i2, PV (p3)); } } | #include <sys/select.h> | ||||||
|  | #include <sys/sendfile.h> | ||||||
| #define BP_THUNK_i_iiipi(NAME) __unbounded { \ | #include <sys/socket.h> | ||||||
|   extern int NAME (int, int, int, void *, int); \ | #include <sys/stat.h> | ||||||
|   int __BP_##NAME (int i0, int i1, int i2, voidp p3, int i4) \ | #include <sys/statfs.h> | ||||||
|     { return NAME (i0, i1, i2, PV (p3), i4); } } | #include <sys/swap.h> | ||||||
|  | #include <sys/sysinfo.h> | ||||||
| #define BP_THUNK_i_iiipp(NAME) __unbounded { \ | #include <sys/time.h> | ||||||
|   extern int NAME (int, int, int, void *, void *); \ | #include <sys/times.h> | ||||||
|   int __BP_##NAME (int i0, int i1, int i2, voidp p3, voidp p4) \ | #include <sys/timex.h> | ||||||
|     { return NAME (i0, i1, i2, PV (p3), PV (p4)); } } | #include <sys/utsname.h> | ||||||
|  | #include <sys/vm86.h> | ||||||
| #define BP_THUNK_i_iip(NAME) __unbounded { \ | #include <sys/wait.h> | ||||||
|   extern int NAME (int, int, void *); \ |  | ||||||
|   int __BP_##NAME (int i0, int i1, voidp p2) \ |  | ||||||
|     { return NAME (i0, i1, PV (p2)); } } |  | ||||||
|  |  | ||||||
| #define BP_THUNK_i_iipi(NAME) __unbounded { \ |  | ||||||
|   extern int NAME (int, int, void *, int); \ |  | ||||||
|   int __BP_##NAME (int i0, int i1, voidp p2, int i3) \ |  | ||||||
|     { return NAME (i0, i1, PV (p2), i3); } } |  | ||||||
|  |  | ||||||
| #define BP_THUNK_i_iipp(NAME) __unbounded { \ |  | ||||||
|   extern int NAME (int, int, void *, void *); \ |  | ||||||
|   int __BP_##NAME (int i0, int i1, voidp p2, voidp p3) \ |  | ||||||
|     { return NAME (i0, i1, PV (p2), PV (p3)); } } |  | ||||||
|  |  | ||||||
| #define BP_THUNK_i_ip(NAME) __unbounded { \ |  | ||||||
|   extern int NAME (int, void *); \ |  | ||||||
|   int __BP_##NAME (int i0, voidp p1) \ |  | ||||||
|     { return NAME (i0, PV (p1)); } } |  | ||||||
|  |  | ||||||
| #define BP_THUNK_i_ipi(NAME) __unbounded { \ |  | ||||||
|   extern int NAME (int, void *, int); \ |  | ||||||
|   int __BP_##NAME (int i0, voidp p1, int i2) \ |  | ||||||
|     { return NAME (i0, PV (p1), i2); } } |  | ||||||
|  |  | ||||||
| #define BP_THUNK_i_ipii(NAME) __unbounded { \ |  | ||||||
|   extern int NAME (int, void *, int, int); \ |  | ||||||
|   int __BP_##NAME (int i0, voidp p1, int i2, int i3) \ |  | ||||||
|     { return NAME (i0, PV (p1), i2, i3); } } |  | ||||||
|  |  | ||||||
| #define BP_THUNK_i_ipiii(NAME) __unbounded { \ |  | ||||||
|   extern int NAME (int, void *, int, int, int); \ |  | ||||||
|   int __BP_##NAME (int i0, voidp p1, int i2, int i3, int i4) \ |  | ||||||
|     { return NAME (i0, PV (p1), i2, i3, i4); } } |  | ||||||
|  |  | ||||||
| #define BP_THUNK_i_ipiipi(NAME) __unbounded { \ |  | ||||||
|   extern int NAME (int, void *, int, int, void *, int); \ |  | ||||||
|   int __BP_##NAME (int i0, voidp p1, int i2, int i3, voidp p4, int i5) \ |  | ||||||
|     { return NAME (i0, PV (p1), i2, i3, PV (p4), i5); } } |  | ||||||
|  |  | ||||||
| #define BP_THUNK_i_ipiipp(NAME) __unbounded { \ |  | ||||||
|   extern int NAME (int, void *, int, int, void *, void *); \ |  | ||||||
|   int __BP_##NAME (int i0, voidp p1, int i2, int i3, voidp p4, voidp p5) \ |  | ||||||
|     { return NAME (i0, PV (p1), i2, i3, PV (p4), PV (p5)); } } |  | ||||||
|  |  | ||||||
| #define BP_THUNK_i_ipip(NAME) __unbounded { \ |  | ||||||
|   extern int NAME (int, void *, int, void *); \ |  | ||||||
|   int __BP_##NAME (int i0, voidp p1, int i2, voidp p3) \ |  | ||||||
|     { return NAME (i0, PV (p1), i2, PV (p3)); } } |  | ||||||
|  |  | ||||||
| #define BP_THUNK_i_ipp(NAME) __unbounded { \ |  | ||||||
|   extern int NAME (int, void *, void *); \ |  | ||||||
|   int __BP_##NAME (int i0, voidp p1, voidp p2) \ |  | ||||||
|     { return NAME (i0, PV (p1), PV (p2)); } } |  | ||||||
|  |  | ||||||
| #define BP_THUNK_i_ippi(NAME) __unbounded { \ |  | ||||||
|   extern int NAME (int, void *, void *, int); \ |  | ||||||
|   int __BP_##NAME (int i0, voidp p1, voidp p2, int i3) \ |  | ||||||
|     { return NAME (i0, PV (p1), PV (p2), i3); } } |  | ||||||
|  |  | ||||||
| #define BP_THUNK_i_ipppp(NAME) __unbounded { \ |  | ||||||
|   extern int NAME (int, void *, void *, void *, void *); \ |  | ||||||
|   int __BP_##NAME (int i0, voidp p1, voidp p2, voidp p3, voidp p4) \ |  | ||||||
|     { return NAME (i0, PV (p1), PV (p2), PV (p3), PV (p4)); } } |  | ||||||
|  |  | ||||||
| #define BP_THUNK_i_isi(NAME) __unbounded { \ |  | ||||||
|   extern int NAME (int, char *, int); \ |  | ||||||
|   int __BP_##NAME (int i0, charp s1, int i2) \ |  | ||||||
|     { return NAME (i0, SV (s1), i2); } } |  | ||||||
|  |  | ||||||
| #define BP_THUNK_i_isip(NAME) __unbounded { \ |  | ||||||
|   extern int NAME (int, char *, int, void *); \ |  | ||||||
|   int __BP_##NAME (int i0, charp s1, int i2, voidp p3) \ |  | ||||||
|     { return NAME (i0, SV (s1), i2, PV (p3)); } } |  | ||||||
|  |  | ||||||
| #define BP_THUNK_i_p(NAME) __unbounded { \ |  | ||||||
|   extern int NAME (void *); \ |  | ||||||
|   int __BP_##NAME (voidp p0) \ |  | ||||||
|     { return NAME (PV (p0)); } } |  | ||||||
|  |  | ||||||
| #define BP_THUNK_i_pi(NAME) __unbounded { \ |  | ||||||
|   extern int NAME (void *, int); \ |  | ||||||
|   int __BP_##NAME (voidp p0, int i1) \ |  | ||||||
|     { return NAME (PV (p0), i1); } } |  | ||||||
|  |  | ||||||
| #define BP_THUNK_i_pii(NAME) __unbounded { \ |  | ||||||
|   extern int NAME (void *, int, int); \ |  | ||||||
|   int __BP_##NAME (voidp p0, int i1, int i2) \ |  | ||||||
|     { return NAME (PV (p0), i1, i2); } } |  | ||||||
|  |  | ||||||
| #define BP_THUNK_i_piii(NAME) __unbounded { \ |  | ||||||
|   extern int NAME (void *, int, int, int); \ |  | ||||||
|   int __BP_##NAME (voidp p0, int i1, int i2, int i3) \ |  | ||||||
|     { return NAME (PV (p0), i1, i2, i3); } } |  | ||||||
|  |  | ||||||
| #define BP_THUNK_i_pp(NAME) __unbounded { \ |  | ||||||
|   extern int NAME (void *, void *); \ |  | ||||||
|   int __BP_##NAME (voidp p0, voidp p1) \ |  | ||||||
|     { return NAME (PV (p0), PV (p1)); } } |  | ||||||
|  |  | ||||||
| #define BP_THUNK_i_pppi(NAME) __unbounded { \ |  | ||||||
|   extern int NAME (void *, void *, void *, int); \ |  | ||||||
|   int __BP_##NAME (voidp p0, voidp p1, voidp p2, int i3) \ |  | ||||||
|     { return NAME (PV (p0), PV (p1), PV (p2), i3); } } |  | ||||||
|  |  | ||||||
| #define BP_THUNK_i_s(NAME) __unbounded { \ |  | ||||||
|   extern int NAME (char *); \ |  | ||||||
|   int __BP_##NAME (charp s0) \ |  | ||||||
|     { return NAME (SV (s0)); } } |  | ||||||
|  |  | ||||||
| #define BP_THUNK_i_si(NAME) __unbounded { \ |  | ||||||
|   extern int NAME (char *, int); \ |  | ||||||
|   int __BP_##NAME (charp s0, int i1) \ |  | ||||||
|     { return NAME (SV (s0), i1); } } |  | ||||||
|  |  | ||||||
| #define BP_THUNK_i_sii(NAME) __unbounded { \ |  | ||||||
|   extern int NAME (char *, int, int); \ |  | ||||||
|   int __BP_##NAME (charp s0, int i1, int i2) \ |  | ||||||
|     { return NAME (SV (s0), i1, i2); } } |  | ||||||
|  |  | ||||||
| #define BP_THUNK_i_sipip(NAME) __unbounded { \ |  | ||||||
|   extern int NAME (char *, int, void *, int, void *); \ |  | ||||||
|   int __BP_##NAME (charp s0, int i1, voidp p2, int i3, voidp p4) \ |  | ||||||
|     { return NAME (SV (s0), i1, PV (p2), i3, PV (p4)); } } |  | ||||||
|  |  | ||||||
| #define BP_THUNK_i_sp(NAME) __unbounded { \ |  | ||||||
|   extern int NAME (char *, void *); \ |  | ||||||
|   int __BP_##NAME (charp s0, voidp p1) \ |  | ||||||
|     { return NAME (SV (s0), PV (p1)); } } |  | ||||||
|  |  | ||||||
| #define BP_THUNK_i_spi(NAME) __unbounded { \ |  | ||||||
|   extern int NAME (char *, void *, int); \ |  | ||||||
|   int __BP_##NAME (charp s0, voidp p1, int i2) \ |  | ||||||
|     { return NAME (SV (s0), PV (p1), i2); } } |  | ||||||
|  |  | ||||||
| #define BP_THUNK_i_spp(NAME) __unbounded { \ |  | ||||||
|   extern int NAME (char *, void *, void *); \ |  | ||||||
|   int __BP_##NAME (charp s0, voidp p1, voidp p2) \ |  | ||||||
|     { return NAME (SV (s0), PV (p1), PV (p2)); } } |  | ||||||
|  |  | ||||||
| #define BP_THUNK_i_ss(NAME) __unbounded { \ |  | ||||||
|   extern int NAME (char *, char *); \ |  | ||||||
|   int __BP_##NAME (charp s0, charp s1) \ |  | ||||||
|     { return NAME (SV (s0), s1); } } |  | ||||||
|  |  | ||||||
| #define BP_THUNK_i_sssip(NAME) __unbounded { \ |  | ||||||
|   extern int NAME (char *, char *, char *, int, void *); \ |  | ||||||
|   int __BP_##NAME (charp s0, charp s1, charp s2, int i3, voidp p4) \ |  | ||||||
|     { return NAME (SV (s0), SV (s1), SV (s2), i3, PV (p4)); } } |  | ||||||
|  |  | ||||||
| /* sstk */ |  | ||||||
| #define BP_THUNK_p_i(NAME) __unbounded { \ |  | ||||||
|   extern void *NAME (int); \ |  | ||||||
|   voidp __BP_##NAME (int i0) \ |  | ||||||
|     { charp m; PV (m) = PB (m) = NAME (i0); \ |  | ||||||
|       PE (m) = PV (m) + i0; return m; } } |  | ||||||
|  |  | ||||||
| /* mremap */ |  | ||||||
| #define BP_THUNK_p_piii(NAME) __unbounded { \ |  | ||||||
|   extern void *NAME (void *, int, int, int); \ |  | ||||||
|   voidp __BP_##NAME (voidp p0, int i1, int i2, int i3) \ |  | ||||||
|     { charp m; PV (m) = PB (m) = NAME (PV (p0), i1, i2, i3); \ |  | ||||||
|       PE (m) = PV (m) + i2; return m; } } |  | ||||||
|  |  | ||||||
| /* mmap */ |  | ||||||
| #define BP_THUNK_p_piiiii(NAME) __unbounded { \ |  | ||||||
|   extern void *NAME (void *, int, int, int, int, int); \ |  | ||||||
|   voidp __BP_##NAME (voidp p0, int i1, int i2, int i3, int i4, int i5) \ |  | ||||||
|     { charp m; PV (m) = PB (m) = NAME (PV (p0), i1, i2, i3, i4, i5); \ |  | ||||||
|       PE (m) = PV (m) + i1; return m; } } |  | ||||||
|  |  | ||||||
| #endif /* _bpthunks_h_ */ | #endif /* _bpthunks_h_ */ | ||||||
|   | |||||||
| @@ -1,23 +1,23 @@ | |||||||
| # File name	Caller	Syscall name	# args	Strong name	Weak names | # File name	Caller	Syscall name	# args	Strong name	Weak names | ||||||
|  |  | ||||||
| accept		-	accept		i:ipp	__libc_accept	accept | accept		-	accept		i:ibN	__libc_accept	accept | ||||||
| bind		-	bind		i:ipi	bind | bind		-	bind		i:ipi	bind | ||||||
| connect		-	connect		i:ipi	__libc_connect	__connect connect | connect		-	connect		i:ipi	__libc_connect	__connect connect | ||||||
| gethostid	-	gethostid	i:	gethostid | gethostid	-	gethostid	i:	gethostid | ||||||
| gethostname	-	gethostname	i:si	__gethostname	gethostname | gethostname	-	gethostname	i:bn	__gethostname	gethostname | ||||||
| getpeername	-	getpeername	i:ipp	getpeername | getpeername	-	getpeername	i:ibN	getpeername | ||||||
| getsockname	-	getsockname	i:ipp	getsockname | getsockname	-	getsockname	i:ibN	getsockname | ||||||
| getsockopt	-	getsockopt	i:iiipp	getsockopt | getsockopt	-	getsockopt	i:iiiBN	getsockopt | ||||||
| listen		-	listen		i:ii	listen | listen		-	listen		i:ii	listen | ||||||
| recv		-	recv		i:ipii	__libc_recv	recv | recv		-	recv		i:ibni	__libc_recv	recv | ||||||
| recvfrom	-	recvfrom	i:ipiipp	__libc_recvfrom	recvfrom | recvfrom	-	recvfrom	i:ibnibN	__libc_recvfrom	recvfrom | ||||||
| recvmsg		-	recvmsg		i:ipi	__libc_recvmsg	recvmsg | recvmsg		-	recvmsg		i:ipi	__libc_recvmsg	recvmsg | ||||||
| send		-	send		i:ipii	__libc_send	__send send | send		-	send		i:ibni	__libc_send	__send send | ||||||
| sendmsg		-	sendmsg		i:ipi	__libc_sendmsg	sendmsg | sendmsg		-	sendmsg		i:ipi	__libc_sendmsg	sendmsg | ||||||
| sendto		-	sendto		i:ipiipi	__libc_sendto	sendto | sendto		-	sendto		i:ibnibn	__libc_sendto	sendto | ||||||
| sethostid	-	sethostid	i:i	sethostid | sethostid	-	sethostid	i:i	sethostid | ||||||
| sethostname	-	sethostname	i:pi	sethostname | sethostname	-	sethostname	i:pi	sethostname | ||||||
| setsockopt	-	setsockopt	i:iiipi	setsockopt | setsockopt	-	setsockopt	i:iiibn	setsockopt | ||||||
| shutdown	-	shutdown	i:ii	shutdown | shutdown	-	shutdown	i:ii	shutdown | ||||||
| socket		-	socket		i:iii	socket | socket		-	socket		i:iii	socket | ||||||
| socketpair	-	socketpair	i:iiip	socketpair | socketpair	-	socketpair	i:iiif	socketpair | ||||||
|   | |||||||
| @@ -3,6 +3,37 @@ | |||||||
| # Usage: make-syscalls.sh ../sysdeps/unix/common | # Usage: make-syscalls.sh ../sysdeps/unix/common | ||||||
| # Expects $sysdirs in environment. | # Expects $sysdirs in environment. | ||||||
|  |  | ||||||
|  | ############################################################################## | ||||||
|  |  | ||||||
|  | # Syscall Signature Key Letters for BP Thunks: | ||||||
|  | # | ||||||
|  | # a: unchecked address (e.g., 1st arg to mmap) | ||||||
|  | # b: non-NULL buffer (e.g., 2nd arg to read) | ||||||
|  | # B: optionally-NULL buffer (e.g., 4th arg to getsockopt) | ||||||
|  | # f: buffer of 2 ints (e.g., 4th arg to socketpair) | ||||||
|  | # i: scalar (any signedness & size: int, long, long long, enum, whatever) | ||||||
|  | # n: scalar buffer length (e.g., 3rd arg to read) | ||||||
|  | # N: pointer to value/return scalar buffer length (e.g., 6th arg to recvfrom) | ||||||
|  | # p: pointer to typed object (e.g., any non-void* arg) | ||||||
|  | # P: pointer return value (e.g., return value from mmap) | ||||||
|  | # s: string (e.g., 1st arg to open) | ||||||
|  | # v: vararg scalar (e.g., optional 3rd arg to open) | ||||||
|  | # V: vararg pointer (e.g., 3rd arg to fcntl & ioctl) | ||||||
|  |  | ||||||
|  | ptrlet='[abBfNpPs]' | ||||||
|  | argdig='[1-9]' | ||||||
|  | fixarg='[^vV]'$argdig	# fixed args (declare extern) | ||||||
|  | strarg=s$argdig		# string arg (check with CHECK_STRING) | ||||||
|  | twoarg=f$argdig		# fd pair arg (check with CHECK_N (..., 2) | ||||||
|  | objarg=p$argdig		# object arg (check with CHECK_1) | ||||||
|  | ptrarg=$ptrlet$argdig	# pointer arg (toss bounds) | ||||||
|  | rtnarg='P'$argdig	# pointer return value (add bounds) | ||||||
|  | bufarg='[bB]'$argdig	# buffer arg (check with CHECK_N) | ||||||
|  | intarg='[inv]'$argdig	# scalar arg | ||||||
|  | borarg='[iv]'$argdig	# boring arg (just pass it through) | ||||||
|  |  | ||||||
|  | ############################################################################## | ||||||
|  |  | ||||||
| thisdir=$1; shift | thisdir=$1; shift | ||||||
|  |  | ||||||
| echo '' | echo '' | ||||||
| @@ -40,11 +71,12 @@ done` | |||||||
| test -n "$calls" || exit 0 | test -n "$calls" || exit 0 | ||||||
|  |  | ||||||
| # Emit rules to compile the syscalls remaining in $calls. | # Emit rules to compile the syscalls remaining in $calls. | ||||||
| echo "$calls" | while read file srcfile caller syscall args 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. |   # Figure out if $syscall is defined with a number in syscall.h. | ||||||
| callnum=- |   callnum=- | ||||||
| eval `{ echo "#include <sysdep.h>"; |   eval `{ echo "#include <sysdep.h>"; | ||||||
| 	echo "callnum=SYS_ify ($syscall)"; } | | 	echo "callnum=SYS_ify ($syscall)"; } | | ||||||
| 	  $asm_CPP - |sed -n -e "/^callnum=.*$syscall/d" \ | 	  $asm_CPP - |sed -n -e "/^callnum=.*$syscall/d" \ | ||||||
| 			     -e "/^\(callnum=\)[ 	]*\(.*\)/s//\1'\2'/p"` | 			     -e "/^\(callnum=\)[ 	]*\(.*\)/s//\1'\2'/p"` | ||||||
| @@ -66,7 +98,9 @@ eval `{ echo "#include <sysdep.h>"; | |||||||
|  |  | ||||||
|   # Make sure only the first syscall rule is used, if multiple dirs |   # Make sure only the first syscall rule is used, if multiple dirs | ||||||
|   # define the same syscall. |   # define the same syscall. | ||||||
|  |   echo '' | ||||||
|   echo "#### CALL=$file NUMBER=$callnum ARGS=$args SOURCE=$srcfile" |   echo "#### CALL=$file NUMBER=$callnum ARGS=$args SOURCE=$srcfile" | ||||||
|  |  | ||||||
|  case x$srcfile"$callnum" in |  case x$srcfile"$callnum" in | ||||||
|  x*-) ;; ### Do nothing for undefined callnum |  x*-) ;; ### Do nothing for undefined callnum | ||||||
|  x-*) |  x-*) | ||||||
| @@ -156,23 +190,102 @@ shared-only-routines += $file | |||||||
|  esac |  esac | ||||||
|  |  | ||||||
|   case x"$callnum",$srcfile,$args in |   case x"$callnum",$srcfile,$args in | ||||||
|   x-,-,*) ;; |   x-,-,* | x*,*.[sS],*V*) ;; | ||||||
|   x*,-,*[sp]* | x*,*.[sS],*[sp]*) |   x*,-,*$ptrlet* | x*,*.[sS],*$ptrlet*) | ||||||
|     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 |     # find the name without leading underscores | ||||||
|       case $name in |     set `echo $strong $weak |tr -s ' \t' '\12' |sed '/^_/d'` | ||||||
| 	*@*) ;; |     callname=$1 | ||||||
| 	*) echo "	 echo 'BP_ALIAS ($strong, $name)'; \\" ;; |  | ||||||
|  |     # convert signature string to individual numbered arg names | ||||||
|  |     # e.g., i:ipbN -> i0 i1 p2 b3 N4 | ||||||
|  |     set `echo $args | | ||||||
|  | 	sed -e 's/^\(.\):\(.*\)/\2 \10/' \ | ||||||
|  | 	    -e 's/^\([^ ]\)\(.*\)/\2 \11/' \ | ||||||
|  | 	    -e 's/^\([^ ]\)\(.*\)/\2 \12/' \ | ||||||
|  | 	    -e 's/^\([^ ]\)\(.*\)/\2 \13/' \ | ||||||
|  | 	    -e 's/^\([^ ]\)\(.*\)/\2 \14/' \ | ||||||
|  | 	    -e 's/^\([^ ]\)\(.*\)/\2 \15/' \ | ||||||
|  | 	    -e 's/^\([^ ]\)\(.*\)/\2 \16/' \ | ||||||
|  | 	    -e 's/^\([^ ]\)\(.*\)/\2 \17/' \ | ||||||
|  | 	    -e 's/^\([^ ]\)\(.*\)/\2 \18/' \ | ||||||
|  | 	    -e 's/^\([^ ]\)\(.*\)/\2 \19/'` | ||||||
|  |     rtn=$1; shift | ||||||
|  |     args=$* | ||||||
|  |     arglist=`echo $* |sed 's/ /, /g'` | ||||||
|  |  | ||||||
|  |     # The best way to understand what's going on here is to examine | ||||||
|  |     # the output in BUILDDIR/sysd-syscalls. | ||||||
|  |  | ||||||
|  |     # generate makefile envelope & rule head | ||||||
|  |     echo "ifeq (,\$(filter $file,\$(bp-thunks)))" | ||||||
|  |     echo "bp-thunks += $file" | ||||||
|  |     echo "\$(objpfx)\$(bppfx)$file.ob: \$(common-objpfx)s-proto.d" | ||||||
|  |  | ||||||
|  |     # generate macro head & thunk prologue | ||||||
|  |     echo "\ | ||||||
|  | 	(echo '#define $callname($arglist) r0, $rtn; \\'; \\ | ||||||
|  | 	 echo '`echo $args | \ | ||||||
|  | 		    sed -e 's/\('$fixarg'\)/extern \1, \1v;/g' \ | ||||||
|  | 			-e 's/\(v'$argdig'\)/extern int \1v;/g'` \\'; \\ | ||||||
|  | 	 echo '__typeof (r0) BP_SYM ($strong) (`echo $args | \ | ||||||
|  | 		    sed -e 's/ /, /g' \ | ||||||
|  | 			-e 's/\('$ptrarg'\)/__typeof (\1v) *__bounded \1a/g' \ | ||||||
|  | 			-e 's/\('$intarg'\)/__typeof (\1v) \1a/g'`) { \\'; \\ | ||||||
|  | 	 echo '  extern __typeof (r0) ($callname) (`echo $args | \ | ||||||
|  | 		    sed -e 's/ /, /g' \ | ||||||
|  | 			-e 's/\('$ptrarg'\)/__typeof (\1v) *__unbounded/g' \ | ||||||
|  | 			-e 's/\('$intarg'\)/__typeof (\1v)/g'`); \\'; \\" | ||||||
|  |  | ||||||
|  |     # generate thunk bounds checks | ||||||
|  |     for arg; do | ||||||
|  |       next=$2; shift | ||||||
|  |       case $arg in | ||||||
|  |       B$argdig) echo "	 echo '  __ptrvalue (${arg}a) && \\'; \\" ;; | ||||||
|  |       esac | ||||||
|  |       case $arg in | ||||||
|  |       n$argdig) len=$arg ;; ### save for possible use with return value. | ||||||
|  |       $strarg) echo "	 echo '  CHECK_STRING (${arg}a); \\'; \\" ;; | ||||||
|  |       $objarg) echo "	 echo '  CHECK_1 (${arg}a); \\'; \\" ;; | ||||||
|  |       $twoarg) echo "	 echo '  CHECK_N (${arg}a, 2); \\'; \\" ;; | ||||||
|  |       $bufarg) | ||||||
|  | 	case $next in | ||||||
|  | 	n$argdig) echo "	 echo '  CHECK_N (${arg}a, ${next}a); \\'; \\" ;; | ||||||
|  | 	N$argdig) echo "	 echo '  CHECK_N (${arg}a, *CHECK_1 (${next}a)); \\'; \\" ;; | ||||||
|  | 	*) echo "### BP Thunk Error: Expected length after buffer ###" ;; | ||||||
|  | 	esac ;; | ||||||
|       esac |       esac | ||||||
|     done |     done | ||||||
|  |  | ||||||
|     echo '	) | $(COMPILE.c) -x c -o $@ -' |     # generate thunk epilogue | ||||||
|  |     funcall="($callname) (`echo $args | \ | ||||||
|  | 		    sed -e 's/ /, /g' \ | ||||||
|  | 			-e 's/\('$ptrarg'\)/__ptrvalue (\1a)/g' \ | ||||||
|  | 			-e 's/\('$intarg'\)/\1a/g'`)" | ||||||
|  |     case $rtn in | ||||||
|  |     P*) echo "	 echo '{ __typeof ($rtn) *__bounded rtn; \\'; \\ | ||||||
|  | 	 echo '  __ptrlow (rtn) = __ptrvalue (rtn) = $funcall; \\'; \\ | ||||||
|  | 	 echo '  __ptrhigh (rtn) = __ptrlow (rtn) + ${len}a; return rtn; } \\'; \\" ;; | ||||||
|  |     *) echo "	 echo '  return $funcall; \\'; \\" ;; | ||||||
|  |     esac | ||||||
|  |     echo "	 echo '} \\'; \\" | ||||||
|  |  | ||||||
|  |     # generate thunk aliases | ||||||
|  |     for name in $weak; do | ||||||
|  |       case $name in | ||||||
|  | 	*@*) ;; | ||||||
|  | 	*) echo "	 echo 'weak_alias (BP_SYM ($strong), BP_SYM ($name)) \\'; \\" ;; | ||||||
|  |       esac | ||||||
|  |     done | ||||||
|  |     # wrap up | ||||||
|  |     echo "\ | ||||||
|  | 	 echo ''; \\ | ||||||
|  | 	 echo '#include <bp-thunks.h>'; \\ | ||||||
|  | 	) | \$(COMPILE.c) -x c -o \$@ -" | ||||||
|  | ### Use this for debugging intermediate output: | ||||||
|  | ### echo '	) >$(@:.ob=.c) | ||||||
|  | ###	$(subst -c,-E,$(COMPILE.c)) -o $(@:.ob=.ib) $(@:.ob=.c) | ||||||
|  | ###	$(COMPILE.c) -x cpp-output -o $@ $(@:.ob=.ib)' | ||||||
|     echo endif |     echo endif | ||||||
|     ;; |     ;; | ||||||
|   esac |   esac | ||||||
|   | |||||||
| @@ -5,7 +5,7 @@ | |||||||
| # File name	Caller	Syscall name	# args	Strong name	Weak names | # File name	Caller	Syscall name	# args	Strong name	Weak names | ||||||
|  |  | ||||||
| madvise		-	madvise		i:pii	madvise | madvise		-	madvise		i:pii	madvise | ||||||
| mmap		-	mmap		p:piiiii	__mmap		mmap | mmap		-	mmap		P:aniiii __mmap		mmap | ||||||
| mprotect	-	mprotect	i:pii	__mprotect	mprotect | mprotect	-	mprotect	i:aii	__mprotect	mprotect | ||||||
| msync		-	msync		i:pii	__libc_msync	msync | msync		-	msync		i:aii	__libc_msync	msync | ||||||
| munmap		-	munmap		i:pi	__munmap	munmap | munmap		-	munmap		i:ai	__munmap	munmap | ||||||
|   | |||||||
| @@ -10,7 +10,7 @@ close		-	close		i:i	__libc_close	__close close | |||||||
| dup		-	dup		i:i	__dup		dup | dup		-	dup		i:i	__dup		dup | ||||||
| dup2		-	dup2		i:ii	__dup2		dup2 | dup2		-	dup2		i:ii	__dup2		dup2 | ||||||
| fchdir		-	fchdir		i:i	__fchdir	fchdir | fchdir		-	fchdir		i:i	__fchdir	fchdir | ||||||
| fcntl		-	fcntl		i:iip	__libc_fcntl	__fcntl fcntl | fcntl		-	fcntl		i:iiV	__libc_fcntl	__fcntl fcntl | ||||||
| fstatfs		-	fstatfs		i:ip	__fstatfs	fstatfs | fstatfs		-	fstatfs		i:ip	__fstatfs	fstatfs | ||||||
| fsync		-	fsync		i:i	__libc_fsync	fsync | fsync		-	fsync		i:i	__libc_fsync	fsync | ||||||
| getdomain	-	getdomainname	i:si	getdomainname | getdomain	-	getdomainname	i:si	getdomainname | ||||||
| @@ -21,15 +21,15 @@ getpid		-	getpid		i:	__getpid	getpid | |||||||
| getpriority	-	getpriority	i:ii	getpriority | getpriority	-	getpriority	i:ii	getpriority | ||||||
| getrlimit	-	getrlimit	i:ip	__getrlimit	getrlimit | getrlimit	-	getrlimit	i:ip	__getrlimit	getrlimit | ||||||
| getuid		-	getuid		i:	__getuid	getuid | getuid		-	getuid		i:	__getuid	getuid | ||||||
| ioctl		-	ioctl		i:iip	__ioctl		ioctl | ioctl		-	ioctl		i:iiV	__ioctl		ioctl | ||||||
| kill		-	kill		i:ii	__kill		kill | kill		-	kill		i:ii	__kill		kill | ||||||
| link		-	link		i:ss	__link		link | link		-	link		i:ss	__link		link | ||||||
| lseek		-	lseek		i:iii	__libc_lseek	__lseek lseek | lseek		-	lseek		i:iii	__libc_lseek	__lseek lseek | ||||||
| mkdir		-	mkdir		i:si	__mkdir		mkdir | mkdir		-	mkdir		i:si	__mkdir		mkdir | ||||||
| open		-	open		i:sii	__libc_open	__open open | open		-	open		i:siv	__libc_open	__open open | ||||||
| profil		-	profil		i:piii	profil | profil		-	profil		i:piii	profil | ||||||
| ptrace		-	ptrace		i:iiii	ptrace | ptrace		-	ptrace		i:iiii	ptrace | ||||||
| read		-	read		i:ipi	__libc_read	__read read | read		-	read		i:ibn	__libc_read	__read read | ||||||
| readlink	-	readlink	i:spi	__readlink	readlink | readlink	-	readlink	i:spi	__readlink	readlink | ||||||
| readv		-	readv		i:ipi	__readv		readv | readv		-	readv		i:ipi	__readv		readv | ||||||
| reboot		-	reboot		i:i	reboot | reboot		-	reboot		i:i	reboot | ||||||
| @@ -61,5 +61,5 @@ umask		-	umask		i:i	__umask		umask | |||||||
| uname		-	uname		i:p	uname | uname		-	uname		i:p	uname | ||||||
| unlink		-	unlink		i:s	__unlink	unlink | unlink		-	unlink		i:s	__unlink	unlink | ||||||
| utimes		-	utimes		i:sp	__utimes	utimes | utimes		-	utimes		i:sp	__utimes	utimes | ||||||
| write		-	write		i:ipi	__libc_write	__write write | write		-	write		i:ibn	__libc_write	__write write | ||||||
| writev		-	writev		i:ipi	__writev	writev | writev		-	writev		i:ipi	__writev	writev | ||||||
|   | |||||||
| @@ -8,15 +8,15 @@ pread		-	pread		4	__syscall_pread	__syscall_pread64 __pread pread __pread64 prea | |||||||
| pwrite		-	pwrite		4	__syscall_pwrite	__syscall_pwrite64 __pwrite pwrite __pwrite64 pwrite64 | pwrite		-	pwrite		4	__syscall_pwrite	__syscall_pwrite64 __pwrite pwrite __pwrite64 pwrite64 | ||||||
| fstatfs		-	fstatfs		i:ip	__fstatfs	fstatfs fstatfs64 __fstatfs64 | fstatfs		-	fstatfs		i:ip	__fstatfs	fstatfs fstatfs64 __fstatfs64 | ||||||
| statfs		-	statfs		i:sp	__statfs	statfs statfs64 | statfs		-	statfs		i:sp	__statfs	statfs statfs64 | ||||||
| mmap		-	mmap		6	__mmap		mmap __mmap64 mmap64 | mmap		-	mmap		P:aniiii __mmap		mmap __mmap64 mmap64 | ||||||
| getpeername	-	getpeername	i:ipp	__getpeername	getpeername | getpeername	-	getpeername	i:ipp	__getpeername	getpeername | ||||||
| getpriority	-	getpriority	i:ii	__getpriority	getpriority | getpriority	-	getpriority	i:ii	__getpriority	getpriority | ||||||
|  |  | ||||||
| # semaphore and shm system calls | # semaphore and shm system calls | ||||||
| msgctl		-	msgctl		i:iip	__msgctl	msgctl | msgctl		-	msgctl		i:iip	__msgctl	msgctl | ||||||
| msgget		-	msgget		i:ii	__msgget	msgget | msgget		-	msgget		i:ii	__msgget	msgget | ||||||
| msgrcv		-	msgrcv		i:ipiii	__msgrcv	msgrcv | msgrcv		-	msgrcv		i:ibnii	__msgrcv	msgrcv | ||||||
| msgsnd		-	msgsnd		i:ipii	__msgsnd	msgsnd | msgsnd		-	msgsnd		i:ibni	__msgsnd	msgsnd | ||||||
| shmat		-	shmat		i:ipi	__shmat		shmat | shmat		-	shmat		i:ipi	__shmat		shmat | ||||||
| shmctl		-	shmctl		i:iip	__shmctl	shmctl | shmctl		-	shmctl		i:iip	__shmctl	shmctl | ||||||
| shmdt		-	shmdt		i:s	__shmdt		shmdt | shmdt		-	shmdt		i:s	__shmdt		shmdt | ||||||
| @@ -31,18 +31,18 @@ bind		-	bind		i:ipi	__bind		bind | |||||||
| connect		-	connect		i:ipi	__libc_connect	__connect connect | connect		-	connect		i:ipi	__libc_connect	__connect connect | ||||||
| getpeername	-	getpeername	i:ipp	__getpeername	getpeername | getpeername	-	getpeername	i:ipp	__getpeername	getpeername | ||||||
| getsockname	-	getsockname	i:ipp	__getsockname	getsockname | getsockname	-	getsockname	i:ipp	__getsockname	getsockname | ||||||
| getsockopt	-	getsockopt	i:iiipp	__getsockopt	getsockopt | getsockopt	-	getsockopt	i:iiiBN	__getsockopt	getsockopt | ||||||
| listen		-	listen		i:ii	__listen	listen | listen		-	listen		i:ii	__listen	listen | ||||||
| recv		-	recv		i:ipii	__libc_recv	__recv recv | recv		-	recv		i:ibni	__libc_recv	__recv recv | ||||||
| recvfrom	-	recvfrom	i:ipiipp	__libc_recvfrom	__recvfrom recvfrom | recvfrom	-	recvfrom	i:ibnibN	__libc_recvfrom	__recvfrom recvfrom | ||||||
| recvmsg		-	recvmsg		i:ipi	__libc_recvmsg	recvmsg | recvmsg		-	recvmsg		i:ipi	__libc_recvmsg	recvmsg | ||||||
| send		-	send		i:ipii	__libc_send	__send send | send		-	send		i:ibni	__libc_send	__send send | ||||||
| sendmsg		-	sendmsg		i:ipi	__libc_sendmsg	sendmsg | sendmsg		-	sendmsg		i:ipi	__libc_sendmsg	sendmsg | ||||||
| sendto		-	sendto		i:ipiipi	__libc_sendto	__sendto sendto | sendto		-	sendto		i:ibnibn	__libc_sendto	__sendto sendto | ||||||
| setsockopt	-	setsockopt	i:iiipi	__setsockopt	setsockopt | setsockopt	-	setsockopt	i:iiibn	__setsockopt	setsockopt | ||||||
| shutdown	-	shutdown	i:ii	__shutdown	shutdown | shutdown	-	shutdown	i:ii	__shutdown	shutdown | ||||||
| socket		-	socket		i:iii	__socket	socket | socket		-	socket		i:iii	__socket	socket | ||||||
| socketpair	-	socketpair	i:iiip	__socketpair	socketpair | socketpair	-	socketpair	i:iiif	__socketpair	socketpair | ||||||
|  |  | ||||||
| # DIG-compliant access to PCI configuration space: | # DIG-compliant access to PCI configuration space: | ||||||
| pciconfig_read	EXTRA	pciconfig_read	5	pciconfig_read | pciconfig_read	EXTRA	pciconfig_read	5	pciconfig_read | ||||||
|   | |||||||
| @@ -21,18 +21,18 @@ bind		-	bind		i:ipi	__bind		bind | |||||||
| connect		-	connect		i:ipi	__libc_connect	__connect connect | connect		-	connect		i:ipi	__libc_connect	__connect connect | ||||||
| getpeername	-	getpeername	i:ipp	__getpeername	getpeername | getpeername	-	getpeername	i:ipp	__getpeername	getpeername | ||||||
| getsockname	-	getsockname	i:ipp	__getsockname	getsockname | getsockname	-	getsockname	i:ipp	__getsockname	getsockname | ||||||
| getsockopt	-	getsockopt	i:iiipp	__getsockopt	getsockopt | getsockopt	-	getsockopt	i:iiiBN	__getsockopt	getsockopt | ||||||
| listen		-	listen		i:ii	__listen	listen | listen		-	listen		i:ii	__listen	listen | ||||||
| recv		-	recv		i:ipii	__libc_recv	__recv recv | recv		-	recv		i:ibni	__libc_recv	__recv recv | ||||||
| recvfrom	-	recvfrom	i:ipiipp __libc_recvfrom __recvfrom recvfrom | recvfrom	-	recvfrom	i:ibnibN __libc_recvfrom __recvfrom recvfrom | ||||||
| recvmsg		-	recvmsg		i:ipi	__libc_recvmsg	__recvmsg recvmsg | recvmsg		-	recvmsg		i:ipi	__libc_recvmsg	__recvmsg recvmsg | ||||||
| send		-	send		i:ipii	__libc_send	__send send | send		-	send		i:ibni	__libc_send	__send send | ||||||
| sendmsg		-	sendmsg		i:ipi	__libc_sendmsg	__sendmsg sendmsg | sendmsg		-	sendmsg		i:ipi	__libc_sendmsg	__sendmsg sendmsg | ||||||
| sendto		-	sendto		i:ipiipi __libc_sendto	__sendto sendto | sendto		-	sendto		i:ibnibn __libc_sendto	__sendto sendto | ||||||
| setsockopt	-	setsockopt	i:iiipi	__setsockopt	setsockopt | setsockopt	-	setsockopt	i:iiibn	__setsockopt	setsockopt | ||||||
| shutdown	-	shutdown	i:ii	__shutdown	shutdown | shutdown	-	shutdown	i:ii	__shutdown	shutdown | ||||||
| socket		-	socket		i:iii	__socket	socket | socket		-	socket		i:iii	__socket	socket | ||||||
| socketpair	-	socketpair	i:iiip	__socketpair	socketpair | socketpair	-	socketpair	i:iiif	__socketpair	socketpair | ||||||
|  |  | ||||||
| # | # | ||||||
| # These are defined locally because the caller is also defined in this dir. | # These are defined locally because the caller is also defined in this dir. | ||||||
| @@ -61,10 +61,10 @@ getresuid	-	getresuid	i:ppp	getresuid | |||||||
| s_ipc		msgget	ipc		i:iiiip	__syscall_ipc | s_ipc		msgget	ipc		i:iiiip	__syscall_ipc | ||||||
| s_lstat64	lxstat64 lstat64	i:sp	__syscall_lstat64 | s_lstat64	lxstat64 lstat64	i:sp	__syscall_lstat64 | ||||||
| s_poll		poll	poll		i:pii	__syscall_poll | s_poll		poll	poll		i:pii	__syscall_poll | ||||||
| s_pread64	pread64	pread		i:ipiiii __syscall_pread | s_pread64	pread64	pread		i:ibniii __syscall_pread | ||||||
| s_putpmsg	putpmsg	putpmsg		i:ippii	__syscall_putpmsg | s_putpmsg	putpmsg	putpmsg		i:ippii	__syscall_putpmsg | ||||||
| s_ptrace	ptrace	ptrace		i:iipp	__syscall_ptrace | s_ptrace	ptrace	ptrace		i:iipp	__syscall_ptrace | ||||||
| s_pwrite64	pwrite64 pwrite		i:ipiiii __syscall_pwrite | s_pwrite64	pwrite64 pwrite		i:ibniii __syscall_pwrite | ||||||
| s_reboot	reboot	reboot		i:iii	__syscall_reboot | s_reboot	reboot	reboot		i:iii	__syscall_reboot | ||||||
| s_setrlimit	setrlimit setrlimit	i:ip	__syscall_setrlimit | s_setrlimit	setrlimit setrlimit	i:ip	__syscall_setrlimit | ||||||
| s_sigpending	sigpending sigpending	i:p	__syscall_sigpending | s_sigpending	sigpending sigpending	i:p	__syscall_sigpending | ||||||
|   | |||||||
| @@ -22,12 +22,12 @@ getresgid	-	getresgid	i:ppp	getresgid | |||||||
| getresuid	-	getresuid	i:ppp	getresuid | getresuid	-	getresuid	i:ppp	getresuid | ||||||
| s_getrlimit	getrlimit getrlimit	i:ip	__syscall_getrlimit | s_getrlimit	getrlimit getrlimit	i:ip	__syscall_getrlimit | ||||||
| s_lstat64	lxstat64 lstat64	i:sp	__syscall_lstat64 | s_lstat64	lxstat64 lstat64	i:sp	__syscall_lstat64 | ||||||
| s_mmap2		mmap64	mmap2		p:piiiii __syscall_mmap2 | s_mmap2		mmap64	mmap2		P:aniiii __syscall_mmap2 | ||||||
| s_poll		poll	poll		i:pii	__syscall_poll | s_poll		poll	poll		i:pii	__syscall_poll | ||||||
| s_pread64	pread64	pread		i:ipiii	__syscall_pread | s_pread64	pread64	pread		i:ibnii	__syscall_pread | ||||||
| s_ptrace	ptrace	ptrace		i:iipp	__syscall_ptrace | s_ptrace	ptrace	ptrace		i:iipp	__syscall_ptrace | ||||||
| s_putpmsg	putpmsg	putpmsg		i:ippii	__syscall_putpmsg | s_putpmsg	putpmsg	putpmsg		i:ippii	__syscall_putpmsg | ||||||
| s_pwrite64	pwrite64 pwrite		i:ipiii	__syscall_pwrite | s_pwrite64	pwrite64 pwrite		i:ibnii	__syscall_pwrite | ||||||
| s_reboot	reboot	reboot		i:iii	__syscall_reboot | s_reboot	reboot	reboot		i:iii	__syscall_reboot | ||||||
| s_setrlimit	setrlimit setrlimit	i:ip	__syscall_setrlimit | s_setrlimit	setrlimit setrlimit	i:ip	__syscall_setrlimit | ||||||
| s_sigaction	sigaction sigaction	i:ipp	__syscall_sigaction | s_sigaction	sigaction sigaction	i:ipp	__syscall_sigaction | ||||||
|   | |||||||
| @@ -23,18 +23,18 @@ klogctl		EXTRA	syslog		i:isi	klogctl | |||||||
| lchown		-	lchown		i:sii	__lchown	lchown | lchown		-	lchown		i:sii	__lchown	lchown | ||||||
| madvise		-	madvise		i:pii	posix_madvise	madvise | madvise		-	madvise		i:pii	posix_madvise	madvise | ||||||
| mincore		-	mincore		i:iip	mincore | mincore		-	mincore		i:iip	mincore | ||||||
| mlock		EXTRA	mlock		i:pi	__mlock	mlock | mlock		EXTRA	mlock		i:bn	__mlock	mlock | ||||||
| mlockall	EXTRA	mlockall	i:i	__mlockall	mlockall | mlockall	EXTRA	mlockall	i:i	__mlockall	mlockall | ||||||
| mmap		-	mmap		p:piiiii	__mmap		mmap | mmap		-	mmap		P:aniiii	__mmap		mmap | ||||||
| mount		EXTRA	mount		i:sssip	__mount	mount | mount		EXTRA	mount		i:sssip	__mount	mount | ||||||
| mremap		EXTRA	mremap		p:piii	__mremap	mremap | mremap		EXTRA	mremap		P:aini	__mremap	mremap | ||||||
| munlock		EXTRA	munlock		i:pi	__munlock	munlock | munlock		EXTRA	munlock		i:ai	__munlock	munlock | ||||||
| munlockall	EXTRA	munlockall	i:	__munlockall	munlockall | munlockall	EXTRA	munlockall	i:	__munlockall	munlockall | ||||||
| nanosleep	-	nanosleep	i:pp	__libc_nanosleep	__nanosleep nanosleep | nanosleep	-	nanosleep	i:pp	__libc_nanosleep	__nanosleep nanosleep | ||||||
| nfsservctl	EXTRA	nfsservctl	i:ipp	nfsservctl | nfsservctl	EXTRA	nfsservctl	i:ipp	nfsservctl | ||||||
| pause		-	pause		i:	__libc_pause	pause | pause		-	pause		i:	__libc_pause	pause | ||||||
| personality	init-first personality	i:i	__personality	personality | personality	init-first personality	i:i	__personality	personality | ||||||
| pipe		-	pipe		i:p	__pipe		pipe | pipe		-	pipe		i:f	__pipe		pipe | ||||||
| prctl		EXTRA	prctl		i:iiiii	prctl | prctl		EXTRA	prctl		i:iiiii	prctl | ||||||
| query_module	EXTRA	query_module	i:sipip	query_module | query_module	EXTRA	query_module	i:sipip	query_module | ||||||
| quotactl	EXTRA	quotactl	i:isip	quotactl | quotactl	EXTRA	quotactl	i:isip	quotactl | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user