mirror of
https://sourceware.org/git/glibc.git
synced 2025-08-01 10:06:57 +03:00
Remove __ASSUME_O_CLOEXEC / O_CLOEXEC conditionals in sysdeps/unix/sysv/linux/.
This patch removes conditionals on __ASSUME_O_CLOEXEC, and on O_CLOEXEC being defined, in sysdeps/unix/sysv/linux/, now that O_CLOEXEC support can be unconditionally assumed. The patch is conservative in what it changes and further followup cleanups may be possible. It may be possible to remove dl-opendir.c, but the patch does not do so, just removing a redundant undefine and redefine of __ASSUME_O_CLOEXEC. Also, __ASSUME_O_CLOEXEC is defined unconditionally for Hurd as well as Linux. Thus, if we decide that O_CLOEXEC support is a required feature of any glibc port, we could remove __ASSUME_O_CLOEXEC and all conditionals on it throughout glibc, rather than just cleaning up sysdeps/unix/sysv/linux/. Tested x86_64 that the disassembly of installed shared libraries is unchanged by this patch. * sysdeps/unix/sysv/linux/dl-opendir.c (__ASSUME_O_CLOEXEC): Do not undefine and redefine. * sysdeps/unix/sysv/linux/getsysstats.c (__get_nprocs) [O_CLOEXEC]: Make code unconditional. (__get_nprocs) [!O_CLOEXEC]: Remove conditional code. * sysdeps/unix/sysv/linux/shm_open.c: Do not include <kernel-features.h>. [O_CLOEXEC && !__ASSUME_O_CLOEXEC] (have_o_cloexec): Remove conditional variable definition. (shm_open) [O_CLOEXEC]: Make code unconditional. (shm_open) [!O_CLOEXEC || !__ASSUME_O_CLOEXEC]: Remove conditional code.
This commit is contained in:
13
ChangeLog
13
ChangeLog
@ -1,5 +1,18 @@
|
|||||||
2014-06-25 Joseph Myers <joseph@codesourcery.com>
|
2014-06-25 Joseph Myers <joseph@codesourcery.com>
|
||||||
|
|
||||||
|
* sysdeps/unix/sysv/linux/dl-opendir.c (__ASSUME_O_CLOEXEC): Do
|
||||||
|
not undefine and redefine.
|
||||||
|
* sysdeps/unix/sysv/linux/getsysstats.c (__get_nprocs)
|
||||||
|
[O_CLOEXEC]: Make code unconditional.
|
||||||
|
(__get_nprocs) [!O_CLOEXEC]: Remove conditional code.
|
||||||
|
* sysdeps/unix/sysv/linux/shm_open.c: Do not include
|
||||||
|
<kernel-features.h>.
|
||||||
|
[O_CLOEXEC && !__ASSUME_O_CLOEXEC] (have_o_cloexec): Remove
|
||||||
|
conditional variable definition.
|
||||||
|
(shm_open) [O_CLOEXEC]: Make code unconditional.
|
||||||
|
(shm_open) [!O_CLOEXEC || !__ASSUME_O_CLOEXEC]: Remove conditional
|
||||||
|
code.
|
||||||
|
|
||||||
* configure.ac (USE_REGPARMS): Don't define here.
|
* configure.ac (USE_REGPARMS): Don't define here.
|
||||||
* configure: Regenerated.
|
* configure: Regenerated.
|
||||||
* sysdeps/i386/configure.ac (USE_REGPARMS): Define here.
|
* sysdeps/i386/configure.ac (USE_REGPARMS): Define here.
|
||||||
|
@ -1,6 +1 @@
|
|||||||
/* In this implementation we do not really care whether the opened
|
|
||||||
file descriptor has the CLOEXEC bit set. The only call happens
|
|
||||||
long before there is a call to fork or exec. */
|
|
||||||
#undef __ASSUME_O_CLOEXEC
|
|
||||||
#define __ASSUME_O_CLOEXEC 1
|
|
||||||
#include <opendir.c>
|
#include <opendir.c>
|
||||||
|
@ -142,11 +142,7 @@ __get_nprocs (void)
|
|||||||
char *cp = buffer_end;
|
char *cp = buffer_end;
|
||||||
char *re = buffer_end;
|
char *re = buffer_end;
|
||||||
|
|
||||||
#ifdef O_CLOEXEC
|
|
||||||
const int flags = O_RDONLY | O_CLOEXEC;
|
const int flags = O_RDONLY | O_CLOEXEC;
|
||||||
#else
|
|
||||||
const int flags = O_RDONLY;
|
|
||||||
#endif
|
|
||||||
int fd = open_not_cancel_2 ("/sys/devices/system/cpu/online", flags);
|
int fd = open_not_cancel_2 ("/sys/devices/system/cpu/online", flags);
|
||||||
char *l;
|
char *l;
|
||||||
int result = 0;
|
int result = 0;
|
||||||
|
@ -28,8 +28,6 @@
|
|||||||
#include <bits/libc-lock.h>
|
#include <bits/libc-lock.h>
|
||||||
#include "linux_fsinfo.h"
|
#include "linux_fsinfo.h"
|
||||||
|
|
||||||
#include <kernel-features.h>
|
|
||||||
|
|
||||||
|
|
||||||
/* Mount point of the shared memory filesystem. */
|
/* Mount point of the shared memory filesystem. */
|
||||||
static struct
|
static struct
|
||||||
@ -45,11 +43,6 @@ static const char defaultdir[] = "/dev/shm/";
|
|||||||
__libc_once_define (static, once);
|
__libc_once_define (static, once);
|
||||||
|
|
||||||
|
|
||||||
#if defined O_CLOEXEC && !defined __ASSUME_O_CLOEXEC
|
|
||||||
static bool have_o_cloexec;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
/* Determine where the shmfs is mounted (if at all). */
|
/* Determine where the shmfs is mounted (if at all). */
|
||||||
static void
|
static void
|
||||||
where_is_shmfs (void)
|
where_is_shmfs (void)
|
||||||
@ -164,51 +157,13 @@ shm_open (const char *name, int oflag, mode_t mode)
|
|||||||
__mempcpy (__mempcpy (fname, mountpoint.dir, mountpoint.dirlen),
|
__mempcpy (__mempcpy (fname, mountpoint.dir, mountpoint.dirlen),
|
||||||
name, namelen + 1);
|
name, namelen + 1);
|
||||||
|
|
||||||
#ifdef O_CLOEXEC
|
|
||||||
oflag |= O_CLOEXEC;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* And get the file descriptor.
|
/* And get the file descriptor.
|
||||||
XXX Maybe we should test each descriptor whether it really is for a
|
XXX Maybe we should test each descriptor whether it really is for a
|
||||||
file on the shmfs. If this is what should be done the whole function
|
file on the shmfs. If this is what should be done the whole function
|
||||||
should be revamped since we can determine whether shmfs is available
|
should be revamped since we can determine whether shmfs is available
|
||||||
while trying to open the file, all in one turn. */
|
while trying to open the file, all in one turn. */
|
||||||
fd = open (fname, oflag | O_NOFOLLOW, mode);
|
fd = open (fname, oflag | O_CLOEXEC | O_NOFOLLOW, mode);
|
||||||
if (fd != -1)
|
if (fd == -1 && __glibc_unlikely (errno == EISDIR))
|
||||||
{
|
|
||||||
#if !defined O_CLOEXEC || !defined __ASSUME_O_CLOEXEC
|
|
||||||
# ifdef O_CLOEXEC
|
|
||||||
if (have_o_cloexec <= 0)
|
|
||||||
# endif
|
|
||||||
{
|
|
||||||
/* We got a descriptor. Now set the FD_CLOEXEC bit. */
|
|
||||||
int flags = fcntl (fd, F_GETFD, 0);
|
|
||||||
|
|
||||||
if (__builtin_expect (flags, 0) >= 0)
|
|
||||||
{
|
|
||||||
# ifdef O_CLOEXEC
|
|
||||||
if (have_o_cloexec == 0)
|
|
||||||
have_o_cloexec = (flags & FD_CLOEXEC) == 0 ? -1 : 1;
|
|
||||||
if (have_o_cloexec < 0)
|
|
||||||
# endif
|
|
||||||
{
|
|
||||||
flags |= FD_CLOEXEC;
|
|
||||||
flags = fcntl (fd, F_SETFD, flags);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (flags == -1)
|
|
||||||
{
|
|
||||||
/* Something went wrong. We cannot return the descriptor. */
|
|
||||||
int save_errno = errno;
|
|
||||||
close (fd);
|
|
||||||
fd = -1;
|
|
||||||
__set_errno (save_errno);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
else if (__glibc_unlikely (errno == EISDIR))
|
|
||||||
/* It might be better to fold this error with EINVAL since
|
/* It might be better to fold this error with EINVAL since
|
||||||
directory names are just another example for unsuitable shared
|
directory names are just another example for unsuitable shared
|
||||||
object names and the standard does not mention EISDIR. */
|
object names and the standard does not mention EISDIR. */
|
||||||
|
Reference in New Issue
Block a user