| The Android Open Source Project | 1dc9e47 | 2009-03-03 19:28:35 -0800 | [diff] [blame] | 1 | /* | 
 | 2 |  * Copyright (C) 2008 The Android Open Source Project | 
 | 3 |  * All rights reserved. | 
 | 4 |  * | 
 | 5 |  * Redistribution and use in source and binary forms, with or without | 
 | 6 |  * modification, are permitted provided that the following conditions | 
 | 7 |  * are met: | 
 | 8 |  *  * Redistributions of source code must retain the above copyright | 
 | 9 |  *    notice, this list of conditions and the following disclaimer. | 
 | 10 |  *  * Redistributions in binary form must reproduce the above copyright | 
 | 11 |  *    notice, this list of conditions and the following disclaimer in | 
 | 12 |  *    the documentation and/or other materials provided with the | 
 | 13 |  *    distribution. | 
 | 14 |  * | 
 | 15 |  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | 
 | 16 |  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | 
 | 17 |  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS | 
 | 18 |  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE | 
 | 19 |  * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, | 
 | 20 |  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, | 
 | 21 |  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS | 
 | 22 |  * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED | 
 | 23 |  * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | 
 | 24 |  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT | 
 | 25 |  * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF | 
 | 26 |  * SUCH DAMAGE. | 
 | 27 |  */ | 
| Elliott Hughes | e989399 | 2013-10-17 11:45:22 -0700 | [diff] [blame] | 28 |  | 
| Elliott Hughes | b361e68 | 2019-11-01 16:47:46 -0700 | [diff] [blame] | 29 | #pragma once | 
| The Android Open Source Project | 1dc9e47 | 2009-03-03 19:28:35 -0800 | [diff] [blame] | 30 | #define _FCNTL_H | 
 | 31 |  | 
| Elliott Hughes | b361e68 | 2019-11-01 16:47:46 -0700 | [diff] [blame] | 32 | /** | 
 | 33 |  * @file fcntl.h | 
 | 34 |  * @brief File control operations. | 
 | 35 |  */ | 
 | 36 |  | 
| The Android Open Source Project | 1dc9e47 | 2009-03-03 19:28:35 -0800 | [diff] [blame] | 37 | #include <sys/cdefs.h> | 
 | 38 | #include <sys/types.h> | 
| Elliott Hughes | 01e505a | 2014-01-07 17:47:20 -0800 | [diff] [blame] | 39 | #include <linux/fadvise.h> | 
| Nick Desaulniers | 09d900d | 2016-07-19 15:20:24 -0700 | [diff] [blame] | 40 | #include <linux/falloc.h> | 
| The Android Open Source Project | 1dc9e47 | 2009-03-03 19:28:35 -0800 | [diff] [blame] | 41 | #include <linux/fcntl.h> | 
| Elliott Hughes | 64d8382 | 2014-12-29 11:14:38 -0800 | [diff] [blame] | 42 | #include <linux/stat.h> | 
| Elliott Hughes | 3f525d4 | 2014-06-24 16:32:01 -0700 | [diff] [blame] | 43 | #include <linux/uio.h> | 
| The Android Open Source Project | 1dc9e47 | 2009-03-03 19:28:35 -0800 | [diff] [blame] | 44 |  | 
| Josh Gao | ee8d169 | 2016-04-07 14:16:30 -0700 | [diff] [blame] | 45 | #include <bits/fcntl.h> | 
| Elliott Hughes | fd936ae | 2016-08-12 10:16:34 -0700 | [diff] [blame] | 46 | #include <bits/seek_constants.h> | 
| Josh Gao | ee8d169 | 2016-04-07 14:16:30 -0700 | [diff] [blame] | 47 |  | 
| Elliott Hughes | 5704c42 | 2016-01-25 18:06:24 -0800 | [diff] [blame] | 48 | #if defined(__USE_GNU) || defined(__USE_BSD) | 
 | 49 | #include <bits/lockf.h> | 
 | 50 | #endif | 
 | 51 |  | 
| The Android Open Source Project | 1dc9e47 | 2009-03-03 19:28:35 -0800 | [diff] [blame] | 52 | __BEGIN_DECLS | 
 | 53 |  | 
| Elliott Hughes | 09e77f3 | 2020-01-29 19:20:45 -0800 | [diff] [blame] | 54 | #if defined(__LP64__) | 
 | 55 |  | 
| Christopher Ferris | ba8d4f4 | 2014-09-03 19:56:49 -0700 | [diff] [blame] | 56 | /* LP64 kernels don't have F_*64 defines because their flock is 64-bit. */ | 
| Elliott Hughes | 09e77f3 | 2020-01-29 19:20:45 -0800 | [diff] [blame] | 57 |  | 
| Elliott Hughes | b361e68 | 2019-11-01 16:47:46 -0700 | [diff] [blame] | 58 | /** Flag for flock(). */ | 
| Serban Constantinescu | 48501af | 2014-03-14 13:16:25 +0000 | [diff] [blame] | 59 | #define F_GETLK64  F_GETLK | 
| Elliott Hughes | b361e68 | 2019-11-01 16:47:46 -0700 | [diff] [blame] | 60 | /** Flag for flock(). */ | 
| Serban Constantinescu | 48501af | 2014-03-14 13:16:25 +0000 | [diff] [blame] | 61 | #define F_SETLK64  F_SETLK | 
| Elliott Hughes | b361e68 | 2019-11-01 16:47:46 -0700 | [diff] [blame] | 62 | /** Flag for flock(). */ | 
| Serban Constantinescu | 48501af | 2014-03-14 13:16:25 +0000 | [diff] [blame] | 63 | #define F_SETLKW64 F_SETLKW | 
| Elliott Hughes | 09e77f3 | 2020-01-29 19:20:45 -0800 | [diff] [blame] | 64 |  | 
 | 65 | #elif defined(__USE_FILE_OFFSET64) | 
 | 66 |  | 
 | 67 | /* For _FILE_OFFSET_BITS=64, redirect the constants to the off64_t variants. */ | 
 | 68 |  | 
 | 69 | #undef F_GETLK | 
 | 70 | #undef F_SETLK | 
 | 71 | #undef F_SETLKW | 
 | 72 |  | 
 | 73 | /** Flag for flock(). */ | 
 | 74 | #define F_GETLK F_GETLK64 | 
 | 75 | /** Flag for flock(). */ | 
 | 76 | #define F_SETLK F_SETLK64 | 
 | 77 | /** Flag for flock(). */ | 
 | 78 | #define F_SETLKW F_SETLKW64 | 
 | 79 |  | 
| Serban Constantinescu | 48501af | 2014-03-14 13:16:25 +0000 | [diff] [blame] | 80 | #endif | 
 | 81 |  | 
| Elliott Hughes | b361e68 | 2019-11-01 16:47:46 -0700 | [diff] [blame] | 82 | /** Flag for open(). */ | 
| Elliott Hughes | 3f525d4 | 2014-06-24 16:32:01 -0700 | [diff] [blame] | 83 | #define O_ASYNC FASYNC | 
| Elliott Hughes | b361e68 | 2019-11-01 16:47:46 -0700 | [diff] [blame] | 84 | /** Flag for open(). */ | 
| Elliott Hughes | 31165ed | 2014-09-23 17:34:29 -0700 | [diff] [blame] | 85 | #define O_RSYNC O_SYNC | 
| Elliott Hughes | 3f525d4 | 2014-06-24 16:32:01 -0700 | [diff] [blame] | 86 |  | 
| Elliott Hughes | b361e68 | 2019-11-01 16:47:46 -0700 | [diff] [blame] | 87 | /** Flag for splice(). */ | 
| Elliott Hughes | 3f525d4 | 2014-06-24 16:32:01 -0700 | [diff] [blame] | 88 | #define SPLICE_F_MOVE 1 | 
| Elliott Hughes | b361e68 | 2019-11-01 16:47:46 -0700 | [diff] [blame] | 89 | /** Flag for splice(). */ | 
| Elliott Hughes | 3f525d4 | 2014-06-24 16:32:01 -0700 | [diff] [blame] | 90 | #define SPLICE_F_NONBLOCK 2 | 
| Elliott Hughes | b361e68 | 2019-11-01 16:47:46 -0700 | [diff] [blame] | 91 | /** Flag for splice(). */ | 
| Elliott Hughes | 3f525d4 | 2014-06-24 16:32:01 -0700 | [diff] [blame] | 92 | #define SPLICE_F_MORE 4 | 
| Elliott Hughes | b361e68 | 2019-11-01 16:47:46 -0700 | [diff] [blame] | 93 | /** Flag for splice(). */ | 
| Elliott Hughes | 3f525d4 | 2014-06-24 16:32:01 -0700 | [diff] [blame] | 94 | #define SPLICE_F_GIFT 8 | 
| The Android Open Source Project | 1dc9e47 | 2009-03-03 19:28:35 -0800 | [diff] [blame] | 95 |  | 
| Elliott Hughes | b361e68 | 2019-11-01 16:47:46 -0700 | [diff] [blame] | 96 | /** Flag for sync_file_range(). */ | 
| Elliott Hughes | 3434727 | 2014-02-26 11:10:32 -0800 | [diff] [blame] | 97 | #define SYNC_FILE_RANGE_WAIT_BEFORE 1 | 
| Elliott Hughes | b361e68 | 2019-11-01 16:47:46 -0700 | [diff] [blame] | 98 | /** Flag for sync_file_range(). */ | 
| Elliott Hughes | 3434727 | 2014-02-26 11:10:32 -0800 | [diff] [blame] | 99 | #define SYNC_FILE_RANGE_WRITE 2 | 
| Elliott Hughes | b361e68 | 2019-11-01 16:47:46 -0700 | [diff] [blame] | 100 | /** Flag for sync_file_range(). */ | 
| Elliott Hughes | 3434727 | 2014-02-26 11:10:32 -0800 | [diff] [blame] | 101 | #define SYNC_FILE_RANGE_WAIT_AFTER 4 | 
 | 102 |  | 
| Elliott Hughes | b361e68 | 2019-11-01 16:47:46 -0700 | [diff] [blame] | 103 | /** | 
| Elliott Hughes | bbd39aa | 2024-08-13 20:59:16 +0000 | [diff] [blame] | 104 |  * [creat(2)](https://man7.org/linux/man-pages/man2/creat.2.html) | 
| Elliott Hughes | b361e68 | 2019-11-01 16:47:46 -0700 | [diff] [blame] | 105 |  * creates a file. | 
 | 106 |  * | 
 | 107 |  * Returns a new file descriptor on success and returns -1 and sets `errno` on | 
 | 108 |  * failure. | 
 | 109 |  */ | 
| zijunzhao | 4aa1ea0 | 2023-01-30 19:48:44 +0000 | [diff] [blame] | 110 | int creat(const char* _Nonnull __path, mode_t __mode); | 
| Elliott Hughes | b361e68 | 2019-11-01 16:47:46 -0700 | [diff] [blame] | 111 | /** See creat(). */ | 
| Elliott Hughes | 655e430 | 2023-06-16 12:39:33 -0700 | [diff] [blame] | 112 | int creat64(const char* _Nonnull __path, mode_t __mode); | 
| Elliott Hughes | b361e68 | 2019-11-01 16:47:46 -0700 | [diff] [blame] | 113 |  | 
 | 114 | /** | 
| Elliott Hughes | bbd39aa | 2024-08-13 20:59:16 +0000 | [diff] [blame] | 115 |  * [openat(2)](https://man7.org/linux/man-pages/man2/openat.2.html) | 
| Elliott Hughes | b361e68 | 2019-11-01 16:47:46 -0700 | [diff] [blame] | 116 |  * opens (and possibly creates) a file. | 
 | 117 |  * | 
 | 118 |  * Returns a new file descriptor on success and returns -1 and sets `errno` on | 
 | 119 |  * failure. | 
 | 120 |  */ | 
| zijunzhao | 4aa1ea0 | 2023-01-30 19:48:44 +0000 | [diff] [blame] | 121 | int openat(int __dir_fd, const char* _Nonnull __path, int __flags, ...); | 
| Elliott Hughes | b361e68 | 2019-11-01 16:47:46 -0700 | [diff] [blame] | 122 | /** See openat(). */ | 
| Elliott Hughes | 655e430 | 2023-06-16 12:39:33 -0700 | [diff] [blame] | 123 | int openat64(int __dir_fd, const char* _Nonnull __path, int __flags, ...); | 
| Elliott Hughes | b361e68 | 2019-11-01 16:47:46 -0700 | [diff] [blame] | 124 |  | 
 | 125 | /** | 
| Elliott Hughes | bbd39aa | 2024-08-13 20:59:16 +0000 | [diff] [blame] | 126 |  * [open(2)](https://man7.org/linux/man-pages/man2/open.2.html) | 
| Elliott Hughes | b361e68 | 2019-11-01 16:47:46 -0700 | [diff] [blame] | 127 |  * opens (and possibly creates) a file. | 
 | 128 |  * | 
 | 129 |  * Returns a new file descriptor on success and returns -1 and sets `errno` on | 
 | 130 |  * failure. | 
 | 131 |  */ | 
| zijunzhao | 4aa1ea0 | 2023-01-30 19:48:44 +0000 | [diff] [blame] | 132 | int open(const char* _Nonnull __path, int __flags, ...); | 
| Elliott Hughes | b361e68 | 2019-11-01 16:47:46 -0700 | [diff] [blame] | 133 | /** See open(). */ | 
| Elliott Hughes | 655e430 | 2023-06-16 12:39:33 -0700 | [diff] [blame] | 134 | int open64(const char* _Nonnull __path, int __flags, ...); | 
| Elliott Hughes | b361e68 | 2019-11-01 16:47:46 -0700 | [diff] [blame] | 135 |  | 
 | 136 | /** | 
| Elliott Hughes | bbd39aa | 2024-08-13 20:59:16 +0000 | [diff] [blame] | 137 |  * [splice(2)](https://man7.org/linux/man-pages/man2/splice.2.html) | 
| Elliott Hughes | b361e68 | 2019-11-01 16:47:46 -0700 | [diff] [blame] | 138 |  * splices data to/from a pipe. | 
 | 139 |  * | 
 | 140 |  * Valid flags are `SPLICE_F_MOVE`, `SPLICE_F_NONBLOCK`, `SPLICE_F_MORE`, and | 
 | 141 |  * `SPLICE_F_GIFT`. | 
 | 142 |  * | 
 | 143 |  * Returns the number of bytes spliced on success and returns -1 and sets | 
 | 144 |  * `errno` on failure. | 
| Elliott Hughes | b361e68 | 2019-11-01 16:47:46 -0700 | [diff] [blame] | 145 |  */ | 
| Elliott Hughes | 655e430 | 2023-06-16 12:39:33 -0700 | [diff] [blame] | 146 | ssize_t splice(int __in_fd, off64_t* __BIONIC_COMPLICATED_NULLNESS __in_offset, int __out_fd, off64_t* __BIONIC_COMPLICATED_NULLNESS __out_offset, size_t __length, unsigned int __flags); | 
| Elliott Hughes | b361e68 | 2019-11-01 16:47:46 -0700 | [diff] [blame] | 147 |  | 
 | 148 | /** | 
| Elliott Hughes | bbd39aa | 2024-08-13 20:59:16 +0000 | [diff] [blame] | 149 |  * [tee(2)](https://man7.org/linux/man-pages/man2/tee.2.html) | 
| Elliott Hughes | b361e68 | 2019-11-01 16:47:46 -0700 | [diff] [blame] | 150 |  * duplicates data from one pipe to another. | 
 | 151 |  * | 
 | 152 |  * Valid flags are `SPLICE_F_MOVE`, `SPLICE_F_NONBLOCK`, `SPLICE_F_MORE`, and | 
 | 153 |  * `SPLICE_F_GIFT`. | 
 | 154 |  * | 
 | 155 |  * Returns the number of bytes duplicated on success and returns -1 and sets | 
 | 156 |  * `errno` on failure. | 
| Elliott Hughes | b361e68 | 2019-11-01 16:47:46 -0700 | [diff] [blame] | 157 |  */ | 
| Elliott Hughes | 655e430 | 2023-06-16 12:39:33 -0700 | [diff] [blame] | 158 | ssize_t tee(int __in_fd, int __out_fd, size_t __length, unsigned int __flags); | 
| Elliott Hughes | b361e68 | 2019-11-01 16:47:46 -0700 | [diff] [blame] | 159 |  | 
 | 160 | /** | 
| Elliott Hughes | bbd39aa | 2024-08-13 20:59:16 +0000 | [diff] [blame] | 161 |  * [vmsplice(2)](https://man7.org/linux/man-pages/man2/vmsplice.2.html) | 
| Elliott Hughes | b361e68 | 2019-11-01 16:47:46 -0700 | [diff] [blame] | 162 |  * splices data to/from a pipe. | 
 | 163 |  * | 
 | 164 |  * Valid flags are `SPLICE_F_MOVE`, `SPLICE_F_NONBLOCK`, `SPLICE_F_MORE`, and | 
 | 165 |  * `SPLICE_F_GIFT`. | 
 | 166 |  * | 
 | 167 |  * Returns the number of bytes spliced on success and returns -1 and sets | 
 | 168 |  * `errno` on failure. | 
| Elliott Hughes | b361e68 | 2019-11-01 16:47:46 -0700 | [diff] [blame] | 169 |  */ | 
| Elliott Hughes | 655e430 | 2023-06-16 12:39:33 -0700 | [diff] [blame] | 170 | ssize_t vmsplice(int __fd, const struct iovec* _Nonnull __iov, size_t __count, unsigned int __flags); | 
| The Android Open Source Project | 1dc9e47 | 2009-03-03 19:28:35 -0800 | [diff] [blame] | 171 |  | 
| Elliott Hughes | b361e68 | 2019-11-01 16:47:46 -0700 | [diff] [blame] | 172 | /** | 
| Elliott Hughes | bbd39aa | 2024-08-13 20:59:16 +0000 | [diff] [blame] | 173 |  * [fallocate(2)](https://man7.org/linux/man-pages/man2/fallocate.2.html) | 
| Elliott Hughes | b361e68 | 2019-11-01 16:47:46 -0700 | [diff] [blame] | 174 |  * is a Linux-specific extension of posix_fallocate(). | 
 | 175 |  * | 
 | 176 |  * Valid flags are `FALLOC_FL_KEEP_SIZE`, `FALLOC_FL_PUNCH_HOLE`, | 
 | 177 |  * `FALLOC_FL_NO_HIDE_STALE`, `FALLOC_FL_COLLAPSE_RANGE`, | 
 | 178 |  * `FALLOC_FL_ZERO_RANGE`, `FALLOC_FL_INSERT_RANGE`, and | 
 | 179 |  * `FALLOC_FL_UNSHARE_RANGE`. | 
 | 180 |  * | 
 | 181 |  * Returns 0 on success and returns -1 and sets `errno` on failure. | 
| Elliott Hughes | b361e68 | 2019-11-01 16:47:46 -0700 | [diff] [blame] | 182 |  */ | 
| Elliott Hughes | 655e430 | 2023-06-16 12:39:33 -0700 | [diff] [blame] | 183 | int fallocate(int __fd, int __mode, off_t __offset, off_t __length) __RENAME_IF_FILE_OFFSET64(fallocate64); | 
| Elliott Hughes | b361e68 | 2019-11-01 16:47:46 -0700 | [diff] [blame] | 184 | /** See fallocate(). */ | 
| Elliott Hughes | 655e430 | 2023-06-16 12:39:33 -0700 | [diff] [blame] | 185 | int fallocate64(int __fd, int __mode, off64_t __offset, off64_t __length); | 
| Elliott Hughes | b361e68 | 2019-11-01 16:47:46 -0700 | [diff] [blame] | 186 |  | 
 | 187 | /** | 
| Elliott Hughes | bbd39aa | 2024-08-13 20:59:16 +0000 | [diff] [blame] | 188 |  * [posix_fadvise(2)](https://man7.org/linux/man-pages/man2/posix_fadvise.2.html) | 
| Elliott Hughes | b361e68 | 2019-11-01 16:47:46 -0700 | [diff] [blame] | 189 |  * declares an expected access pattern for file data. | 
 | 190 |  * | 
 | 191 |  * Valid flags are `POSIX_FADV_NORMAL`, `POSIX_FADV_RANDOM`, | 
 | 192 |  * `POSIX_FADV_SEQUENTIAL`, `POSIX_FADV_WILLNEED`, `POSIX_FADV_DONTNEED`, | 
 | 193 |  * and `POSIX_FADV_NOREUSE`. | 
 | 194 |  * | 
 | 195 |  * Returns 0 on success and returns an error number on failure. | 
| Elliott Hughes | b361e68 | 2019-11-01 16:47:46 -0700 | [diff] [blame] | 196 |  */ | 
| Elliott Hughes | 655e430 | 2023-06-16 12:39:33 -0700 | [diff] [blame] | 197 | int posix_fadvise(int __fd, off_t __offset, off_t __length, int __advice) __RENAME_IF_FILE_OFFSET64(posix_fadvise64); | 
| Elliott Hughes | b361e68 | 2019-11-01 16:47:46 -0700 | [diff] [blame] | 198 | /** See posix_fadvise(). */ | 
| Elliott Hughes | 655e430 | 2023-06-16 12:39:33 -0700 | [diff] [blame] | 199 | int posix_fadvise64(int __fd, off64_t __offset, off64_t __length, int __advice); | 
| Elliott Hughes | b361e68 | 2019-11-01 16:47:46 -0700 | [diff] [blame] | 200 |  | 
 | 201 | /** | 
| Elliott Hughes | bbd39aa | 2024-08-13 20:59:16 +0000 | [diff] [blame] | 202 |  * [posix_fallocate(2)](https://man7.org/linux/man-pages/man2/posix_fallocate.2.html) | 
| Elliott Hughes | b361e68 | 2019-11-01 16:47:46 -0700 | [diff] [blame] | 203 |  * allocates file space. | 
 | 204 |  * | 
 | 205 |  * Returns 0 on success and returns an error number on failure. | 
| Elliott Hughes | b361e68 | 2019-11-01 16:47:46 -0700 | [diff] [blame] | 206 |  */ | 
| Elliott Hughes | 655e430 | 2023-06-16 12:39:33 -0700 | [diff] [blame] | 207 | int posix_fallocate(int __fd, off_t __offset, off_t __length) __RENAME_IF_FILE_OFFSET64(posix_fallocate64); | 
| Elliott Hughes | b361e68 | 2019-11-01 16:47:46 -0700 | [diff] [blame] | 208 | /** See posix_fallocate(). */ | 
| Elliott Hughes | 655e430 | 2023-06-16 12:39:33 -0700 | [diff] [blame] | 209 | int posix_fallocate64(int __fd, off64_t __offset, off64_t __length); | 
| Elliott Hughes | 68dc20d | 2015-02-06 22:28:49 -0800 | [diff] [blame] | 210 |  | 
| Elliott Hughes | 55147ad | 2016-04-05 11:06:02 -0700 | [diff] [blame] | 211 | #if defined(__USE_GNU) | 
| Elliott Hughes | b361e68 | 2019-11-01 16:47:46 -0700 | [diff] [blame] | 212 |  | 
 | 213 | /** | 
| Elliott Hughes | bbd39aa | 2024-08-13 20:59:16 +0000 | [diff] [blame] | 214 |  * [readahead(2)](https://man7.org/linux/man-pages/man2/readahead.2.html) | 
| Elliott Hughes | b361e68 | 2019-11-01 16:47:46 -0700 | [diff] [blame] | 215 |  * initiates readahead for the given file. | 
 | 216 |  * | 
 | 217 |  * Returns 0 on success and returns -1 and sets `errno` on failure. | 
 | 218 |  */ | 
 | 219 | ssize_t readahead(int __fd, off64_t __offset, size_t __length); | 
 | 220 |  | 
 | 221 | /** | 
| Elliott Hughes | bbd39aa | 2024-08-13 20:59:16 +0000 | [diff] [blame] | 222 |  * [sync_file_range(2)](https://man7.org/linux/man-pages/man2/sync_file_range.2.html) | 
| Elliott Hughes | b361e68 | 2019-11-01 16:47:46 -0700 | [diff] [blame] | 223 |  * syncs part of a file with disk. | 
 | 224 |  * | 
 | 225 |  * Valid flags are `SYNC_FILE_RANGE_WAIT_BEFORE`, `SYNC_FILE_RANGE_WRITE`, and | 
 | 226 |  * `SYNC_FILE_RANGE_WAIT_AFTER`. | 
 | 227 |  * | 
 | 228 |  * Returns 0 on success and returns -1 and sets `errno` on failure. | 
 | 229 |  */ | 
| Dan Albert | 02ce401 | 2024-10-25 19:13:49 +0000 | [diff] [blame] | 230 |  | 
 | 231 | #if __BIONIC_AVAILABILITY_GUARD(26) | 
| Elliott Hughes | ff26a16 | 2017-08-17 22:34:21 +0000 | [diff] [blame] | 232 | int sync_file_range(int __fd, off64_t __offset, off64_t __length, unsigned int __flags) __INTRODUCED_IN(26); | 
| Dan Albert | 02ce401 | 2024-10-25 19:13:49 +0000 | [diff] [blame] | 233 | #endif /* __BIONIC_AVAILABILITY_GUARD(26) */ | 
 | 234 |  | 
| Elliott Hughes | b361e68 | 2019-11-01 16:47:46 -0700 | [diff] [blame] | 235 |  | 
| Elliott Hughes | 55147ad | 2016-04-05 11:06:02 -0700 | [diff] [blame] | 236 | #endif | 
 | 237 |  | 
| George Burgess IV | b97049c | 2017-07-24 15:05:05 -0700 | [diff] [blame] | 238 | #if defined(__BIONIC_INCLUDE_FORTIFY_HEADERS) | 
 | 239 | #include <bits/fortify/fcntl.h> | 
 | 240 | #endif | 
| Nick Kralevich | 8118f62 | 2012-06-26 15:08:06 -0700 | [diff] [blame] | 241 |  | 
| The Android Open Source Project | 1dc9e47 | 2009-03-03 19:28:35 -0800 | [diff] [blame] | 242 | __END_DECLS |