mirror of
https://sourceware.org/git/glibc.git
synced 2024-12-27 21:20:18 +00:00
e3b0580d0d
The accept4, recvmmsg and sendmmsg functions had macros __ASSUME_*_SYSCALL_WITH_SOCKETCALL. Before we could assume kernels with the relevant functionality, these macros represented the conditions under which, on a socketcall architecture, glibc could just call the syscall unconditionally and not have to deal with socketcall at all for those functions, because if the syscall didn't work for them the socketcall call wouldn't either. Now we can assume kernels with the relevant functionality, the only question is whether we can assume the syscall is present; if not, we are on a socketcall architecture and just use socketcall instead. Thus, this patch removes the macros that are no longer necessary, and simplifies the code for accept4, recvmmsg and sendmmsg to use the same logic as the other C implementations of socket functions that may use a syscall or socketcall depending on kernel support. Tested for x86_64 and x86. * sysdeps/unix/sysv/linux/accept4.c (accept4): Use syscall if [__ASSUME_ACCEPT4_SYSCALL], otherwise socketcall. * sysdeps/unix/sysv/linux/recvmmsg.c (recvmmsg): Use syscall if [__ASSUME_RECVMMSG_SYSCALL], otherwise socketcall. * sysdeps/unix/sysv/linux/sendmmsg.c (__sendmmsg): Use syscall if [__ASSUME_SENDMMSG_SYSCALL], otherwise socketcall. * sysdeps/unix/sysv/linux/kernel-features.h (__ASSUME_ACCEPT4_SYSCALL): Move to general list of macros for socket syscalls. (__ASSUME_RECVMMSG_SYSCALL): Likewise. (__ASSUME_SENDMMSG_SYSCALL): Likewise. * sysdeps/unix/sysv/linux/i386/kernel-features.h (__ASSUME_RECVMMSG_SYSCALL_WITH_SOCKETCALL): Remove. (__ASSUME_SENDMMSG_SYSCALL_WITH_SOCKETCALL): Likewise. * sysdeps/unix/sysv/linux/microblaze/kernel-features.h (__ASSUME_RECVMMSG_SYSCALL_WITH_SOCKETCALL): Remove. * sysdeps/unix/sysv/linux/powerpc/kernel-features.h (__ASSUME_SENDMMSG_SYSCALL_WITH_SOCKETCALL): Likewise. * sysdeps/unix/sysv/linux/sh/kernel-features.h (__ASSUME_SENDMMSG_SYSCALL_WITH_SOCKETCALL): Likewise. * sysdeps/unix/sysv/linux/sparc/kernel-features.h (__ASSUME_ACCEPT4_SYSCALL_WITH_SOCKETCALL): Likewise. (__ASSUME_RECVMMSG_SYSCALL_WITH_SOCKETCALL): Likewise. (__ASSUME_SENDMMSG_SYSCALL_WITH_SOCKETCALL): Likewise. |
||
---|---|---|
.. | ||
i686 | ||
i786 | ||
____longjmp_chk.S | ||
_exit.S | ||
alphasort64.c | ||
arch-fork.h | ||
brk.c | ||
c++-types.data | ||
clone.S | ||
configure | ||
configure.ac | ||
dl-librecon.h | ||
dl-procinfo.h | ||
dl-sysdep.h | ||
fcntl.c | ||
fxstat.c | ||
fxstatat.c | ||
get_clockfreq.c | ||
getcontext.S | ||
getdents64.c | ||
getmsg.c | ||
gettimeofday.c | ||
glob64.c | ||
Implies | ||
init-first.c | ||
kernel-features.h | ||
ld.abilist | ||
ldconfig.h | ||
libanl.abilist | ||
libBrokenLocale.abilist | ||
libc-do-syscall.S | ||
libc-lowlevellock.S | ||
libc.abilist | ||
libcrypt.abilist | ||
libdl.abilist | ||
libm.abilist | ||
libnsl.abilist | ||
libpthread.abilist | ||
libresolv.abilist | ||
librt.abilist | ||
libthread_db.abilist | ||
libutil.abilist | ||
lll_timedlock_wait.c | ||
lll_timedwait_tid.c | ||
localplt.data | ||
lockf64.c | ||
lowlevellock.h | ||
lowlevellock.S | ||
lxstat.c | ||
makecontext.S | ||
Makefile | ||
olddirent.h | ||
profil-counter.h | ||
putmsg.c | ||
readdir64_r.c | ||
readdir64.c | ||
readelflib.c | ||
register-dump.h | ||
scandir64.c | ||
setcontext.S | ||
shlib-versions | ||
sigaction.c | ||
sigcontextinfo.h | ||
smp.h | ||
swapcontext.S | ||
syscall.S | ||
syscalls.list | ||
sysdep-cancel.h | ||
sysdep.c | ||
sysdep.h | ||
time.c | ||
ucontext_i.sym | ||
Versions | ||
versionsort64.c | ||
vfork.S | ||
xstat.c |