__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>
|
2015-05-05 Florian Weimer <fweimer@redhat.com>
|
||||||
|
|
||||||
* sysdeps/unix/sysv/linux/i386/Makefile
|
* sysdeps/unix/sysv/linux/i386/Makefile
|
||||||
|
@ -16,42 +16,22 @@
|
|||||||
<http://www.gnu.org/licenses/>. */
|
<http://www.gnu.org/licenses/>. */
|
||||||
|
|
||||||
#include <fcntl.h>
|
#include <fcntl.h>
|
||||||
#include <kernel-features.h>
|
|
||||||
#include <sysdep.h>
|
#include <sysdep.h>
|
||||||
|
|
||||||
#define posix_fallocate static internal_fallocate
|
#define posix_fallocate static internal_fallocate
|
||||||
#include <sysdeps/posix/posix_fallocate.c>
|
#include <sysdeps/posix/posix_fallocate.c>
|
||||||
#undef posix_fallocate
|
#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. */
|
/* Reserve storage for the data of the file associated with FD. */
|
||||||
int
|
int
|
||||||
posix_fallocate (int fd, __off_t offset, __off_t len)
|
posix_fallocate (int fd, __off_t offset, __off_t len)
|
||||||
{
|
{
|
||||||
#ifdef __NR_fallocate
|
INTERNAL_SYSCALL_DECL (err);
|
||||||
# ifndef __ASSUME_FALLOCATE
|
int res = INTERNAL_SYSCALL (fallocate, err, 4, fd, 0, offset, len);
|
||||||
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
|
|
||||||
|
|
||||||
|
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);
|
return internal_fallocate (fd, offset, len);
|
||||||
}
|
}
|
||||||
|
@ -16,7 +16,6 @@
|
|||||||
<http://www.gnu.org/licenses/>. */
|
<http://www.gnu.org/licenses/>. */
|
||||||
|
|
||||||
#include <fcntl.h>
|
#include <fcntl.h>
|
||||||
#include <kernel-features.h>
|
|
||||||
#include <sysdep.h>
|
#include <sysdep.h>
|
||||||
|
|
||||||
extern int __posix_fallocate64_l64 (int fd, __off64_t offset, __off64_t len);
|
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>
|
#include <sysdeps/posix/posix_fallocate64.c>
|
||||||
#undef __posix_fallocate64_l64
|
#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. */
|
/* Reserve storage for the data of the file associated with FD. */
|
||||||
int
|
int
|
||||||
__posix_fallocate64_l64 (int fd, __off64_t offset, __off64_t len)
|
__posix_fallocate64_l64 (int fd, __off64_t offset, __off64_t len)
|
||||||
{
|
{
|
||||||
#ifdef __NR_fallocate
|
INTERNAL_SYSCALL_DECL (err);
|
||||||
# ifndef __ASSUME_FALLOCATE
|
int res = INTERNAL_SYSCALL (fallocate, err, 4, fd, 0, offset, len);
|
||||||
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
|
|
||||||
|
|
||||||
|
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);
|
return internal_fallocate64 (fd, offset, len);
|
||||||
}
|
}
|
||||||
|
@ -16,44 +16,24 @@
|
|||||||
<http://www.gnu.org/licenses/>. */
|
<http://www.gnu.org/licenses/>. */
|
||||||
|
|
||||||
#include <fcntl.h>
|
#include <fcntl.h>
|
||||||
#include <kernel-features.h>
|
|
||||||
#include <sysdep.h>
|
#include <sysdep.h>
|
||||||
|
|
||||||
#define posix_fallocate static internal_fallocate
|
#define posix_fallocate static internal_fallocate
|
||||||
#include <sysdeps/posix/posix_fallocate.c>
|
#include <sysdeps/posix/posix_fallocate.c>
|
||||||
#undef posix_fallocate
|
#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. */
|
/* Reserve storage for the data of the file associated with FD. */
|
||||||
int
|
int
|
||||||
posix_fallocate (int fd, __off_t offset, __off_t len)
|
posix_fallocate (int fd, __off_t offset, __off_t len)
|
||||||
{
|
{
|
||||||
#ifdef __NR_fallocate
|
INTERNAL_SYSCALL_DECL (err);
|
||||||
# ifndef __ASSUME_FALLOCATE
|
int res = INTERNAL_SYSCALL (fallocate, err, 6, fd, 0,
|
||||||
if (__glibc_likely (__have_fallocate >= 0))
|
__LONG_LONG_PAIR (offset >> 31, offset),
|
||||||
# endif
|
__LONG_LONG_PAIR (len >> 31, len));
|
||||||
{
|
|
||||||
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
|
|
||||||
|
|
||||||
|
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);
|
return internal_fallocate (fd, offset, len);
|
||||||
}
|
}
|
||||||
|
@ -16,7 +16,6 @@
|
|||||||
<http://www.gnu.org/licenses/>. */
|
<http://www.gnu.org/licenses/>. */
|
||||||
|
|
||||||
#include <fcntl.h>
|
#include <fcntl.h>
|
||||||
#include <kernel-features.h>
|
|
||||||
#include <sysdep.h>
|
#include <sysdep.h>
|
||||||
|
|
||||||
extern int __posix_fallocate64_l64 (int fd, __off64_t offset, __off64_t len);
|
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>
|
#include <sysdeps/posix/posix_fallocate64.c>
|
||||||
#undef __posix_fallocate64_l64
|
#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. */
|
/* Reserve storage for the data of the file associated with FD. */
|
||||||
int
|
int
|
||||||
__posix_fallocate64_l64 (int fd, __off64_t offset, __off64_t len)
|
__posix_fallocate64_l64 (int fd, __off64_t offset, __off64_t len)
|
||||||
{
|
{
|
||||||
#ifdef __NR_fallocate
|
INTERNAL_SYSCALL_DECL (err);
|
||||||
# ifndef __ASSUME_FALLOCATE
|
int res = INTERNAL_SYSCALL (fallocate, err, 6, fd, 0,
|
||||||
if (__glibc_likely (__have_fallocate >= 0))
|
__LONG_LONG_PAIR ((long int) (offset >> 32),
|
||||||
# endif
|
(long int) offset),
|
||||||
{
|
__LONG_LONG_PAIR ((long int) (len >> 32),
|
||||||
INTERNAL_SYSCALL_DECL (err);
|
(long int) len));
|
||||||
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
|
|
||||||
|
|
||||||
|
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);
|
return internal_fallocate64 (fd, offset, len);
|
||||||
}
|
}
|
||||||
|
@ -23,6 +23,8 @@
|
|||||||
#include <sysdeps/posix/posix_fallocate.c>
|
#include <sysdeps/posix/posix_fallocate.c>
|
||||||
#undef posix_fallocate
|
#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
|
#if !defined __ASSUME_FALLOCATE && defined __NR_fallocate
|
||||||
static int __have_fallocate;
|
static int __have_fallocate;
|
||||||
#endif
|
#endif
|
||||||
|
Loading…
x
Reference in New Issue
Block a user