blob: dd08ffc058bc0f6f827aaa246142c4872da93ca2 [file] [log] [blame]
George Burgess IVb97049c2017-07-24 15:05:05 -07001/*
2 * Copyright (C) 2017 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 */
28#ifndef _UNISTD_H_
29#error "Never include this file directly; instead, include <unistd.h>"
30#endif
31
32char* __getcwd_chk(char*, size_t, size_t) __INTRODUCED_IN(24);
33
34ssize_t __pread_chk(int, void*, size_t, off_t, size_t) __INTRODUCED_IN(23);
35ssize_t __pread_real(int, void*, size_t, off_t) __RENAME(pread);
36
37ssize_t __pread64_chk(int, void*, size_t, off64_t, size_t) __INTRODUCED_IN(23);
38ssize_t __pread64_real(int, void*, size_t, off64_t) __RENAME(pread64) __INTRODUCED_IN(12);
39
40ssize_t __pwrite_chk(int, const void*, size_t, off_t, size_t) __INTRODUCED_IN(24);
41ssize_t __pwrite_real(int, const void*, size_t, off_t) __RENAME(pwrite);
42
43ssize_t __pwrite64_chk(int, const void*, size_t, off64_t, size_t) __INTRODUCED_IN(24);
44ssize_t __pwrite64_real(int, const void*, size_t, off64_t) __RENAME(pwrite64)
45 __INTRODUCED_IN(12);
46
47ssize_t __read_chk(int, void*, size_t, size_t) __INTRODUCED_IN(21);
48ssize_t __write_chk(int, const void*, size_t, size_t) __INTRODUCED_IN(24);
49ssize_t __readlink_chk(const char*, char*, size_t, size_t) __INTRODUCED_IN(23);
50ssize_t __readlinkat_chk(int dirfd, const char*, char*, size_t, size_t) __INTRODUCED_IN(23);
51
52#if defined(__BIONIC_FORTIFY)
53
54#if defined(__USE_FILE_OFFSET64)
55#define __PREAD_PREFIX(x) __pread64_ ## x
56#define __PWRITE_PREFIX(x) __pwrite64_ ## x
57#else
58#define __PREAD_PREFIX(x) __pread_ ## x
59#define __PWRITE_PREFIX(x) __pwrite_ ## x
60#endif
61
George Burgess IV16c17392017-07-31 21:30:47 -070062#define __error_if_overflows_ssizet(what, fn) \
63 __clang_error_if((what) > SSIZE_MAX, "in call to '" #fn "', '" #what "' must be <= SSIZE_MAX")
George Burgess IVb97049c2017-07-24 15:05:05 -070064
George Burgess IV16c17392017-07-31 21:30:47 -070065#define __error_if_overflows_objectsize(what, objsize, fn) \
George Burgess IV5273dc52019-05-09 13:46:57 -070066 __clang_error_if(__bos_unevaluated_lt((objsize), (what)), \
George Burgess IV16c17392017-07-31 21:30:47 -070067 "in call to '" #fn "', '" #what "' bytes overflows the given object")
George Burgess IVb97049c2017-07-24 15:05:05 -070068
George Burgess IVda8d30f2019-09-18 17:09:43 -070069#define __bos_trivially_ge_no_overflow(bos_val, index) \
George Burgess IV74519e72019-06-06 17:54:00 -070070 ((__bos_dynamic_check_impl_and((bos_val), >=, (index), (bos_val) <= SSIZE_MAX) && \
71 __builtin_constant_p(index) && (index) <= SSIZE_MAX))
George Burgess IVd9865e72019-05-13 17:20:04 -070072
George Burgess IVb97049c2017-07-24 15:05:05 -070073__BIONIC_FORTIFY_INLINE
George Burgess IV16c17392017-07-31 21:30:47 -070074char* getcwd(char* const __pass_object_size buf, size_t size)
75 __overloadable
76 __error_if_overflows_objectsize(size, __bos(buf), getcwd) {
George Burgess IVda8d30f2019-09-18 17:09:43 -070077#if __ANDROID_API__ >= __ANDROID_API_N__
George Burgess IVb97049c2017-07-24 15:05:05 -070078 size_t bos = __bos(buf);
79
George Burgess IVda8d30f2019-09-18 17:09:43 -070080 if (!__bos_trivially_not_lt(bos, size)) {
81 return __getcwd_chk(buf, size, bos);
George Burgess IVb97049c2017-07-24 15:05:05 -070082 }
George Burgess IVb97049c2017-07-24 15:05:05 -070083#endif /* __ANDROID_API__ >= __ANDROID_API_N__ */
George Burgess IVda8d30f2019-09-18 17:09:43 -070084 return __call_bypassing_fortify(getcwd)(buf, size);
85}
George Burgess IVb97049c2017-07-24 15:05:05 -070086
George Burgess IVda8d30f2019-09-18 17:09:43 -070087#if !defined(__USE_FILE_OFFSET64)
George Burgess IVb97049c2017-07-24 15:05:05 -070088__BIONIC_FORTIFY_INLINE
George Burgess IV16c17392017-07-31 21:30:47 -070089ssize_t pread(int fd, void* const __pass_object_size0 buf, size_t count, off_t offset)
90 __overloadable
91 __error_if_overflows_ssizet(count, pread)
92 __error_if_overflows_objectsize(count, __bos0(buf), pread) {
George Burgess IVda8d30f2019-09-18 17:09:43 -070093#if __ANDROID_API__ >= __ANDROID_API_M__
George Burgess IVb97049c2017-07-24 15:05:05 -070094 size_t bos = __bos0(buf);
95
George Burgess IVda8d30f2019-09-18 17:09:43 -070096 if (!__bos_trivially_ge_no_overflow(bos, count)) {
97 return __PREAD_PREFIX(chk)(fd, buf, count, offset, bos);
George Burgess IVb97049c2017-07-24 15:05:05 -070098 }
George Burgess IVda8d30f2019-09-18 17:09:43 -070099#endif /* __ANDROID_API__ >= __ANDROID_API_M__ */
100 return __PREAD_PREFIX(real)(fd, buf, count, offset);
George Burgess IVb97049c2017-07-24 15:05:05 -0700101}
George Burgess IVda8d30f2019-09-18 17:09:43 -0700102#endif /* !defined(__USE_FILE_OFFSET64) */
George Burgess IVb97049c2017-07-24 15:05:05 -0700103
George Burgess IVb97049c2017-07-24 15:05:05 -0700104__BIONIC_FORTIFY_INLINE
George Burgess IV16c17392017-07-31 21:30:47 -0700105ssize_t pread64(int fd, void* const __pass_object_size0 buf, size_t count, off64_t offset)
106 __overloadable
107 __error_if_overflows_ssizet(count, pread64)
108 __error_if_overflows_objectsize(count, __bos0(buf), pread64) {
George Burgess IVda8d30f2019-09-18 17:09:43 -0700109#if __ANDROID_API__ >= __ANDROID_API_M__
George Burgess IVb97049c2017-07-24 15:05:05 -0700110 size_t bos = __bos0(buf);
111
George Burgess IVda8d30f2019-09-18 17:09:43 -0700112 if (!__bos_trivially_ge_no_overflow(bos, count)) {
113 return __pread64_chk(fd, buf, count, offset, bos);
George Burgess IVb97049c2017-07-24 15:05:05 -0700114 }
George Burgess IVb97049c2017-07-24 15:05:05 -0700115#endif /* __ANDROID_API__ >= __ANDROID_API_M__ */
George Burgess IVda8d30f2019-09-18 17:09:43 -0700116 return __pread64_real(fd, buf, count, offset);
117}
George Burgess IVb97049c2017-07-24 15:05:05 -0700118
George Burgess IVda8d30f2019-09-18 17:09:43 -0700119#if !defined(__USE_FILE_OFFSET64)
George Burgess IVb97049c2017-07-24 15:05:05 -0700120__BIONIC_FORTIFY_INLINE
George Burgess IV16c17392017-07-31 21:30:47 -0700121ssize_t pwrite(int fd, const void* const __pass_object_size0 buf, size_t count, off_t offset)
122 __overloadable
123 __error_if_overflows_ssizet(count, pwrite)
124 __error_if_overflows_objectsize(count, __bos0(buf), pwrite) {
George Burgess IVda8d30f2019-09-18 17:09:43 -0700125#if __ANDROID_API__ >= __ANDROID_API_N__
George Burgess IVb97049c2017-07-24 15:05:05 -0700126 size_t bos = __bos0(buf);
127
George Burgess IVda8d30f2019-09-18 17:09:43 -0700128 if (!__bos_trivially_ge_no_overflow(bos, count)) {
129 return __PWRITE_PREFIX(chk)(fd, buf, count, offset, bos);
George Burgess IVb97049c2017-07-24 15:05:05 -0700130 }
George Burgess IVda8d30f2019-09-18 17:09:43 -0700131#endif /* __ANDROID_API__ >= __ANDROID_API_N__ */
132 return __PWRITE_PREFIX(real)(fd, buf, count, offset);
George Burgess IVb97049c2017-07-24 15:05:05 -0700133}
George Burgess IVda8d30f2019-09-18 17:09:43 -0700134#endif /* !defined(__USE_FILE_OFFSET64) */
George Burgess IVb97049c2017-07-24 15:05:05 -0700135
George Burgess IVb97049c2017-07-24 15:05:05 -0700136__BIONIC_FORTIFY_INLINE
George Burgess IV16c17392017-07-31 21:30:47 -0700137ssize_t pwrite64(int fd, const void* const __pass_object_size0 buf, size_t count, off64_t offset)
138 __overloadable
139 __error_if_overflows_ssizet(count, pwrite64)
140 __error_if_overflows_objectsize(count, __bos0(buf), pwrite64) {
George Burgess IVda8d30f2019-09-18 17:09:43 -0700141#if __ANDROID_API__ >= __ANDROID_API_N__
George Burgess IVb97049c2017-07-24 15:05:05 -0700142 size_t bos = __bos0(buf);
143
George Burgess IVda8d30f2019-09-18 17:09:43 -0700144 if (!__bos_trivially_ge_no_overflow(bos, count)) {
145 return __pwrite64_chk(fd, buf, count, offset, bos);
George Burgess IVb97049c2017-07-24 15:05:05 -0700146 }
George Burgess IVb97049c2017-07-24 15:05:05 -0700147#endif /* __ANDROID_API__ >= __ANDROID_API_N__ */
George Burgess IVda8d30f2019-09-18 17:09:43 -0700148 return __pwrite64_real(fd, buf, count, offset);
149}
George Burgess IVb97049c2017-07-24 15:05:05 -0700150
George Burgess IVb97049c2017-07-24 15:05:05 -0700151__BIONIC_FORTIFY_INLINE
152ssize_t read(int fd, void* const __pass_object_size0 buf, size_t count)
George Burgess IV16c17392017-07-31 21:30:47 -0700153 __overloadable
154 __error_if_overflows_ssizet(count, read)
155 __error_if_overflows_objectsize(count, __bos0(buf), read) {
George Burgess IVda8d30f2019-09-18 17:09:43 -0700156#if __ANDROID_API__ >= __ANDROID_API_L__
George Burgess IVb97049c2017-07-24 15:05:05 -0700157 size_t bos = __bos0(buf);
158
George Burgess IVda8d30f2019-09-18 17:09:43 -0700159 if (!__bos_trivially_ge_no_overflow(bos, count)) {
160 return __read_chk(fd, buf, count, bos);
George Burgess IVb97049c2017-07-24 15:05:05 -0700161 }
George Burgess IVb97049c2017-07-24 15:05:05 -0700162#endif /* __ANDROID_API__ >= __ANDROID_API_L__ */
George Burgess IVda8d30f2019-09-18 17:09:43 -0700163 return __call_bypassing_fortify(read)(fd, buf, count);
164}
George Burgess IVb97049c2017-07-24 15:05:05 -0700165
George Burgess IVb97049c2017-07-24 15:05:05 -0700166__BIONIC_FORTIFY_INLINE
167ssize_t write(int fd, const void* const __pass_object_size0 buf, size_t count)
George Burgess IV16c17392017-07-31 21:30:47 -0700168 __overloadable
169 __error_if_overflows_ssizet(count, write)
170 __error_if_overflows_objectsize(count, __bos0(buf), write) {
George Burgess IVda8d30f2019-09-18 17:09:43 -0700171#if __ANDROID_API__ >= __ANDROID_API_N__
George Burgess IVb97049c2017-07-24 15:05:05 -0700172 size_t bos = __bos0(buf);
173
George Burgess IVda8d30f2019-09-18 17:09:43 -0700174 if (!__bos_trivially_ge_no_overflow(bos, count)) {
175 return __write_chk(fd, buf, count, bos);
George Burgess IVb97049c2017-07-24 15:05:05 -0700176 }
George Burgess IVb97049c2017-07-24 15:05:05 -0700177#endif /* __ANDROID_API__ >= __ANDROID_API_N__ */
George Burgess IVda8d30f2019-09-18 17:09:43 -0700178 return __call_bypassing_fortify(write)(fd, buf, count);
179}
George Burgess IVb97049c2017-07-24 15:05:05 -0700180
George Burgess IVb97049c2017-07-24 15:05:05 -0700181__BIONIC_FORTIFY_INLINE
George Burgess IV16c17392017-07-31 21:30:47 -0700182ssize_t readlink(const char* path, char* const __pass_object_size buf, size_t size)
183 __overloadable
184 __error_if_overflows_ssizet(size, readlink)
185 __error_if_overflows_objectsize(size, __bos(buf), readlink) {
George Burgess IVda8d30f2019-09-18 17:09:43 -0700186#if __ANDROID_API__ >= __ANDROID_API_M__
George Burgess IVb97049c2017-07-24 15:05:05 -0700187 size_t bos = __bos(buf);
188
George Burgess IVda8d30f2019-09-18 17:09:43 -0700189 if (!__bos_trivially_ge_no_overflow(bos, size)) {
190 return __readlink_chk(path, buf, size, bos);
George Burgess IVb97049c2017-07-24 15:05:05 -0700191 }
George Burgess IVda8d30f2019-09-18 17:09:43 -0700192#endif /* __ANDROID_API__ >= __ANDROID_API_M__ */
193 return __call_bypassing_fortify(readlink)(path, buf, size);
George Burgess IVb97049c2017-07-24 15:05:05 -0700194}
195
George Burgess IVda8d30f2019-09-18 17:09:43 -0700196#if __ANDROID_API__ >= __ANDROID_API_L__
George Burgess IVb97049c2017-07-24 15:05:05 -0700197__BIONIC_FORTIFY_INLINE
George Burgess IV16c17392017-07-31 21:30:47 -0700198ssize_t readlinkat(int dirfd, const char* path, char* const __pass_object_size buf, size_t size)
199 __overloadable
200 __error_if_overflows_ssizet(size, readlinkat)
201 __error_if_overflows_objectsize(size, __bos(buf), readlinkat) {
George Burgess IVda8d30f2019-09-18 17:09:43 -0700202#if __ANDROID_API__ >= __ANDROID_API_M__
George Burgess IVb97049c2017-07-24 15:05:05 -0700203 size_t bos = __bos(buf);
204
George Burgess IVda8d30f2019-09-18 17:09:43 -0700205 if (!__bos_trivially_ge_no_overflow(bos, size)) {
206 return __readlinkat_chk(dirfd, path, buf, size, bos);
George Burgess IVb97049c2017-07-24 15:05:05 -0700207 }
George Burgess IVb97049c2017-07-24 15:05:05 -0700208#endif /* __ANDROID_API__ >= __ANDROID_API_M__ */
George Burgess IVda8d30f2019-09-18 17:09:43 -0700209 return __call_bypassing_fortify(readlinkat)(dirfd, path, buf, size);
210}
211#endif /* __ANDROID_API__ >= __ANDROID_API_L__ */
George Burgess IVb97049c2017-07-24 15:05:05 -0700212
George Burgess IVda8d30f2019-09-18 17:09:43 -0700213#undef __bos_trivially_ge_no_overflow
George Burgess IVb97049c2017-07-24 15:05:05 -0700214#undef __enable_if_no_overflow_ssizet
215#undef __error_if_overflows_objectsize
216#undef __error_if_overflows_ssizet
George Burgess IVb97049c2017-07-24 15:05:05 -0700217#undef __PREAD_PREFIX
218#undef __PWRITE_PREFIX
219#endif /* defined(__BIONIC_FORTIFY) */