mirror of
https://sourceware.org/git/glibc.git
synced 2024-11-10 23:30:07 +00:00
__ASSUME_FALLOCATE is always true on 32-bit architectures
This means we can clean up the generic code a bit. The 64-bit variant still needs to support !__ASSUME_FALLOCATE for alpha.
This commit is contained in:
parent
4bd40bcf44
commit
d0ccd0d977
13
ChangeLog
13
ChangeLog
@ -1,3 +1,16 @@
|
||||
2015-05-05 Florian Weimer <fweimer@redhat.com>
|
||||
|
||||
* sysdeps/unix/sysv/linux/posix_fallocate.c (posix_fallocate):
|
||||
Assume __ASSUME_FALLOCATE is always true.
|
||||
* sysdeps/unix/sysv/linux/posix_fallocate64.c
|
||||
(__posix_fallocate64_l64): Likweise.
|
||||
* sysdeps/unix/sysv/linux/mips/mips64/n32/posix_fallocate.c
|
||||
(posix_fallocate): Likewise.
|
||||
* sysdeps/unix/sysv/linux/mips/mips64/n32/posix_fallocate64.c
|
||||
(__posix_fallocate64_l64): Likewise.
|
||||
* sysdeps/unix/sysv/linux/wordsize-64/posix_fallocate.c
|
||||
[!__ASSUME_FALLOCATE]: Add comment.
|
||||
|
||||
2015-05-05 Florian Weimer <fweimer@redhat.com>
|
||||
|
||||
* sysdeps/unix/sysv/linux/i386/Makefile
|
||||
|
@ -16,42 +16,22 @@
|
||||
<http://www.gnu.org/licenses/>. */
|
||||
|
||||
#include <fcntl.h>
|
||||
#include <kernel-features.h>
|
||||
#include <sysdep.h>
|
||||
|
||||
#define posix_fallocate static internal_fallocate
|
||||
#include <sysdeps/posix/posix_fallocate.c>
|
||||
#undef posix_fallocate
|
||||
|
||||
#if !defined __ASSUME_FALLOCATE && defined __NR_fallocate
|
||||
int __have_fallocate attribute_hidden;
|
||||
#endif
|
||||
|
||||
|
||||
/* Reserve storage for the data of the file associated with FD. */
|
||||
int
|
||||
posix_fallocate (int fd, __off_t offset, __off_t len)
|
||||
{
|
||||
#ifdef __NR_fallocate
|
||||
# ifndef __ASSUME_FALLOCATE
|
||||
if (__builtin_expect (__have_fallocate >= 0, 1))
|
||||
# endif
|
||||
{
|
||||
INTERNAL_SYSCALL_DECL (err);
|
||||
int res = INTERNAL_SYSCALL (fallocate, err, 4, fd, 0, offset, len);
|
||||
|
||||
if (! INTERNAL_SYSCALL_ERROR_P (res, err))
|
||||
return 0;
|
||||
|
||||
# ifndef __ASSUME_FALLOCATE
|
||||
if (__builtin_expect (INTERNAL_SYSCALL_ERRNO (res, err) == ENOSYS, 0))
|
||||
__have_fallocate = -1;
|
||||
else
|
||||
# endif
|
||||
if (INTERNAL_SYSCALL_ERRNO (res, err) != EOPNOTSUPP)
|
||||
return INTERNAL_SYSCALL_ERRNO (res, err);
|
||||
}
|
||||
#endif
|
||||
INTERNAL_SYSCALL_DECL (err);
|
||||
int res = INTERNAL_SYSCALL (fallocate, err, 4, fd, 0, offset, len);
|
||||
|
||||
if (! INTERNAL_SYSCALL_ERROR_P (res, err))
|
||||
return 0;
|
||||
if (INTERNAL_SYSCALL_ERRNO (res, err) != EOPNOTSUPP)
|
||||
return INTERNAL_SYSCALL_ERRNO (res, err);
|
||||
return internal_fallocate (fd, offset, len);
|
||||
}
|
||||
|
@ -16,7 +16,6 @@
|
||||
<http://www.gnu.org/licenses/>. */
|
||||
|
||||
#include <fcntl.h>
|
||||
#include <kernel-features.h>
|
||||
#include <sysdep.h>
|
||||
|
||||
extern int __posix_fallocate64_l64 (int fd, __off64_t offset, __off64_t len);
|
||||
@ -24,36 +23,16 @@ extern int __posix_fallocate64_l64 (int fd, __off64_t offset, __off64_t len);
|
||||
#include <sysdeps/posix/posix_fallocate64.c>
|
||||
#undef __posix_fallocate64_l64
|
||||
|
||||
#if !defined __ASSUME_FALLOCATE && defined __NR_fallocate
|
||||
/* Defined in posix_fallocate.c. */
|
||||
extern int __have_fallocate attribute_hidden;
|
||||
#endif
|
||||
|
||||
|
||||
/* Reserve storage for the data of the file associated with FD. */
|
||||
int
|
||||
__posix_fallocate64_l64 (int fd, __off64_t offset, __off64_t len)
|
||||
{
|
||||
#ifdef __NR_fallocate
|
||||
# ifndef __ASSUME_FALLOCATE
|
||||
if (__builtin_expect (__have_fallocate >= 0, 1))
|
||||
# endif
|
||||
{
|
||||
INTERNAL_SYSCALL_DECL (err);
|
||||
int res = INTERNAL_SYSCALL (fallocate, err, 4, fd, 0, offset, len);
|
||||
|
||||
if (! INTERNAL_SYSCALL_ERROR_P (res, err))
|
||||
return 0;
|
||||
|
||||
# ifndef __ASSUME_FALLOCATE
|
||||
if (__builtin_expect (INTERNAL_SYSCALL_ERRNO (res, err) == ENOSYS, 0))
|
||||
__have_fallocate = -1;
|
||||
else
|
||||
# endif
|
||||
if (INTERNAL_SYSCALL_ERRNO (res, err) != EOPNOTSUPP)
|
||||
return INTERNAL_SYSCALL_ERRNO (res, err);
|
||||
}
|
||||
#endif
|
||||
INTERNAL_SYSCALL_DECL (err);
|
||||
int res = INTERNAL_SYSCALL (fallocate, err, 4, fd, 0, offset, len);
|
||||
|
||||
if (! INTERNAL_SYSCALL_ERROR_P (res, err))
|
||||
return 0;
|
||||
if (INTERNAL_SYSCALL_ERRNO (res, err) != EOPNOTSUPP)
|
||||
return INTERNAL_SYSCALL_ERRNO (res, err);
|
||||
return internal_fallocate64 (fd, offset, len);
|
||||
}
|
||||
|
@ -16,44 +16,24 @@
|
||||
<http://www.gnu.org/licenses/>. */
|
||||
|
||||
#include <fcntl.h>
|
||||
#include <kernel-features.h>
|
||||
#include <sysdep.h>
|
||||
|
||||
#define posix_fallocate static internal_fallocate
|
||||
#include <sysdeps/posix/posix_fallocate.c>
|
||||
#undef posix_fallocate
|
||||
|
||||
#if !defined __ASSUME_FALLOCATE && defined __NR_fallocate
|
||||
int __have_fallocate attribute_hidden;
|
||||
#endif
|
||||
|
||||
|
||||
/* Reserve storage for the data of the file associated with FD. */
|
||||
int
|
||||
posix_fallocate (int fd, __off_t offset, __off_t len)
|
||||
{
|
||||
#ifdef __NR_fallocate
|
||||
# ifndef __ASSUME_FALLOCATE
|
||||
if (__glibc_likely (__have_fallocate >= 0))
|
||||
# endif
|
||||
{
|
||||
INTERNAL_SYSCALL_DECL (err);
|
||||
int res = INTERNAL_SYSCALL (fallocate, err, 6, fd, 0,
|
||||
__LONG_LONG_PAIR (offset >> 31, offset),
|
||||
__LONG_LONG_PAIR (len >> 31, len));
|
||||
|
||||
if (! INTERNAL_SYSCALL_ERROR_P (res, err))
|
||||
return 0;
|
||||
|
||||
# ifndef __ASSUME_FALLOCATE
|
||||
if (__glibc_unlikely (INTERNAL_SYSCALL_ERRNO (res, err) == ENOSYS))
|
||||
__have_fallocate = -1;
|
||||
else
|
||||
# endif
|
||||
if (INTERNAL_SYSCALL_ERRNO (res, err) != EOPNOTSUPP)
|
||||
return INTERNAL_SYSCALL_ERRNO (res, err);
|
||||
}
|
||||
#endif
|
||||
INTERNAL_SYSCALL_DECL (err);
|
||||
int res = INTERNAL_SYSCALL (fallocate, err, 6, fd, 0,
|
||||
__LONG_LONG_PAIR (offset >> 31, offset),
|
||||
__LONG_LONG_PAIR (len >> 31, len));
|
||||
|
||||
if (! INTERNAL_SYSCALL_ERROR_P (res, err))
|
||||
return 0;
|
||||
if (INTERNAL_SYSCALL_ERRNO (res, err) != EOPNOTSUPP)
|
||||
return INTERNAL_SYSCALL_ERRNO (res, err);
|
||||
return internal_fallocate (fd, offset, len);
|
||||
}
|
||||
|
@ -16,7 +16,6 @@
|
||||
<http://www.gnu.org/licenses/>. */
|
||||
|
||||
#include <fcntl.h>
|
||||
#include <kernel-features.h>
|
||||
#include <sysdep.h>
|
||||
|
||||
extern int __posix_fallocate64_l64 (int fd, __off64_t offset, __off64_t len);
|
||||
@ -24,40 +23,20 @@ extern int __posix_fallocate64_l64 (int fd, __off64_t offset, __off64_t len);
|
||||
#include <sysdeps/posix/posix_fallocate64.c>
|
||||
#undef __posix_fallocate64_l64
|
||||
|
||||
#if !defined __ASSUME_FALLOCATE && defined __NR_fallocate
|
||||
/* Defined in posix_fallocate.c. */
|
||||
extern int __have_fallocate attribute_hidden;
|
||||
#endif
|
||||
|
||||
|
||||
/* Reserve storage for the data of the file associated with FD. */
|
||||
int
|
||||
__posix_fallocate64_l64 (int fd, __off64_t offset, __off64_t len)
|
||||
{
|
||||
#ifdef __NR_fallocate
|
||||
# ifndef __ASSUME_FALLOCATE
|
||||
if (__glibc_likely (__have_fallocate >= 0))
|
||||
# endif
|
||||
{
|
||||
INTERNAL_SYSCALL_DECL (err);
|
||||
int res = INTERNAL_SYSCALL (fallocate, err, 6, fd, 0,
|
||||
__LONG_LONG_PAIR ((long int) (offset >> 32),
|
||||
(long int) offset),
|
||||
__LONG_LONG_PAIR ((long int) (len >> 32),
|
||||
(long int) len));
|
||||
|
||||
if (! INTERNAL_SYSCALL_ERROR_P (res, err))
|
||||
return 0;
|
||||
|
||||
# ifndef __ASSUME_FALLOCATE
|
||||
if (__glibc_unlikely (INTERNAL_SYSCALL_ERRNO (res, err) == ENOSYS))
|
||||
__have_fallocate = -1;
|
||||
else
|
||||
# endif
|
||||
if (INTERNAL_SYSCALL_ERRNO (res, err) != EOPNOTSUPP)
|
||||
return INTERNAL_SYSCALL_ERRNO (res, err);
|
||||
}
|
||||
#endif
|
||||
INTERNAL_SYSCALL_DECL (err);
|
||||
int res = INTERNAL_SYSCALL (fallocate, err, 6, fd, 0,
|
||||
__LONG_LONG_PAIR ((long int) (offset >> 32),
|
||||
(long int) offset),
|
||||
__LONG_LONG_PAIR ((long int) (len >> 32),
|
||||
(long int) len));
|
||||
|
||||
if (! INTERNAL_SYSCALL_ERROR_P (res, err))
|
||||
return 0;
|
||||
if (INTERNAL_SYSCALL_ERRNO (res, err) != EOPNOTSUPP)
|
||||
return INTERNAL_SYSCALL_ERRNO (res, err);
|
||||
return internal_fallocate64 (fd, offset, len);
|
||||
}
|
||||
|
@ -23,6 +23,8 @@
|
||||
#include <sysdeps/posix/posix_fallocate.c>
|
||||
#undef posix_fallocate
|
||||
|
||||
/* The alpha architecture introduced the fallocate system call in
|
||||
2.6.33-rc1, so we still need the fallback code. */
|
||||
#if !defined __ASSUME_FALLOCATE && defined __NR_fallocate
|
||||
static int __have_fallocate;
|
||||
#endif
|
||||
|
Loading…
Reference in New Issue
Block a user