mirror of
https://sourceware.org/git/glibc.git
synced 2024-12-03 18:31:04 +00:00
456b3c08b6
Now that Hurd implementis both close_range and closefrom (f2c996597d
),
we can make close_range() a base ABI, and make the default closefrom()
implementation on top of close_range().
The generic closefrom() implementation based on __getdtablesize() is
moved to generic close_range(). On Linux it will be overriden by
the auto-generation syscall while on Hurd it will be a system specific
implementation.
The closefrom() now calls close_range() and __closefrom_fallback().
Since on Hurd close_range() does not fail, __closefrom_fallback() is an
empty static inline function set by__ASSUME_CLOSE_RANGE.
The __ASSUME_CLOSE_RANGE also allows optimize Linux
__closefrom_fallback() implementation when --enable-kernel=5.9 or
higher is used.
Finally the Linux specific tst-close_range.c is moved to io and
enabled as default. The Linuxism and CLOSE_RANGE_UNSHARE are
guarded so it can be built for Hurd (I have not actually test it).
Checked on x86_64-linux-gnu, i686-linux-gnu, and with a i686-gnu
build.
51 lines
2.0 KiB
C
51 lines
2.0 KiB
C
/* System-specific extensions of <unistd.h>, Linux version.
|
|
Copyright (C) 2019-2021 Free Software Foundation, Inc.
|
|
This file is part of the GNU C Library.
|
|
|
|
The GNU C Library is free software; you can redistribute it and/or
|
|
modify it under the terms of the GNU Lesser General Public
|
|
License as published by the Free Software Foundation; either
|
|
version 2.1 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
|
|
Lesser General Public License for more details.
|
|
|
|
You should have received a copy of the GNU Lesser General Public
|
|
License along with the GNU C Library; if not, see
|
|
<https://www.gnu.org/licenses/>. */
|
|
|
|
#ifndef _UNISTD_H
|
|
# error "Never include <bits/unistd_ext.h> directly; use <unistd.h> instead."
|
|
#endif
|
|
|
|
#ifdef __USE_GNU
|
|
|
|
/* Return the kernel thread ID (TID) of the current thread. The
|
|
returned value is not subject to caching. Most Linux system calls
|
|
accept a TID in place of a PID. Using the TID to change properties
|
|
of a thread that has been created using pthread_create can lead to
|
|
undefined behavior (comparable to manipulating file descriptors
|
|
directly that have not been created explicitly). Note that a TID
|
|
uniquely identifies a thread only while this thread is running; a
|
|
TID can be reused once a thread has exited, even if the thread is
|
|
not detached and has not been joined. */
|
|
extern __pid_t gettid (void) __THROW;
|
|
|
|
#ifdef __has_include
|
|
# if __has_include ("linux/close_range.h")
|
|
# include "linux/close_range.h"
|
|
# endif
|
|
#endif
|
|
/* Unshare the file descriptor table before closing file descriptors. */
|
|
#ifndef CLOSE_RANGE_UNSHARE
|
|
# define CLOSE_RANGE_UNSHARE (1U << 1)
|
|
#endif
|
|
/* Set the FD_CLOEXEC bit instead of closing the file descriptor. */
|
|
#ifndef CLOSE_RANGE_CLOEXEC
|
|
# define CLOSE_RANGE_CLOEXEC (1U << 2)
|
|
#endif
|
|
|
|
#endif /* __USE_GNU */
|