1/* Copyright (C) 2003-2019 Free Software Foundation, Inc.
2 This file is part of the GNU C Library.
3
4 The GNU C Library is free software; you can redistribute it and/or
5 modify it under the terms of the GNU Lesser General Public
6 License as published by the Free Software Foundation; either
7 version 2.1 of the License, or (at your option) any later version.
8
9 The GNU C Library is distributed in the hope that it will be useful,
10 but WITHOUT ANY WARRANTY; without even the implied warranty of
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 Lesser General Public License for more details.
13
14 You should have received a copy of the GNU Lesser General Public
15 License along with the GNU C Library; if not, see
16 <http://www.gnu.org/licenses/>. */
17
18#include <errno.h>
19#include <fcntl.h>
20#include <sysdep.h>
21
22/* Advice the system about the expected behaviour of the application with
23 respect to the file associated with FD. */
24
25#ifndef __OFF_T_MATCHES_OFF64_T
26
27/* Default implementation will use __NR_fadvise64 with expected argument
28 positions (for instance i386 and powerpc32 that uses __ALIGNMENT_ARG).
29
30 Second option will be used by arm which define __NR_arm_fadvise64_64
31 (redefined to __NR_fadvise64_64 in kernel-features.h) that behaves as
32 __NR_fadvise64_64 (without the aligment argument required for the ABI).
33
34 Third option will be used by mips o32. Mips will use a 7 argument
35 syscall with __NR_fadvise64.
36
37 s390 implements fadvice64_64 using a specific struct with arguments
38 packed inside. This is the only implementation handled in arch-specific
39 code. */
40
41int
42posix_fadvise (int fd, off_t offset, off_t len, int advise)
43{
44 INTERNAL_SYSCALL_DECL (err);
45# if defined (__NR_fadvise64) && !defined (__ASSUME_FADVISE64_AS_64_64)
46 int ret = INTERNAL_SYSCALL_CALL (fadvise64, err, fd,
47 __ALIGNMENT_ARG SYSCALL_LL (offset),
48 len, advise);
49# else
50# ifdef __ASSUME_FADVISE64_64_6ARG
51 int ret = INTERNAL_SYSCALL_CALL (fadvise64_64, err, fd, advise,
52 SYSCALL_LL (offset), SYSCALL_LL (len));
53# else
54
55# ifndef __NR_fadvise64_64
56# define __NR_fadvise64_64 __NR_fadvise64
57# endif
58
59 int ret = INTERNAL_SYSCALL_CALL (fadvise64_64, err, fd,
60 __ALIGNMENT_ARG SYSCALL_LL (offset),
61 SYSCALL_LL (len), advise);
62# endif
63# endif
64 if (INTERNAL_SYSCALL_ERROR_P (ret, err))
65 return INTERNAL_SYSCALL_ERRNO (ret, err);
66 return 0;
67}
68#endif /* __OFF_T_MATCHES_OFF64_T */
69