blob: cbe6a7579e168acd082b1a2f313d3b55d4392048 [file] [log] [blame]
The Android Open Source Project1dc9e472009-03-03 19:28:35 -08001/*
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 Hughesff26a162017-08-17 22:34:21 +000028
Elliott Hughes3d24d2b2019-08-05 13:53:01 -070029#pragma once
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080030
31#include <sys/cdefs.h>
32#include <sys/types.h>
Elliott Hughes3d24d2b2019-08-05 13:53:01 -070033#include <linux/memfd.h>
Christopher Ferris24f97eb2019-05-20 12:58:13 -070034#include <linux/mman.h>
Edgar Arriaga128ef8e2020-12-23 14:59:56 -080035#include <linux/uio.h>
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080036
37__BEGIN_DECLS
38
Elliott Hughes3d24d2b2019-08-05 13:53:01 -070039/** Alternative spelling of the `MAP_ANONYMOUS` flag for mmap(). */
40#define MAP_ANON MAP_ANONYMOUS
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080041
Elliott Hughes3d24d2b2019-08-05 13:53:01 -070042/** Return value for mmap(). */
Elliott Hughes5470c182016-07-22 11:36:17 -070043#define MAP_FAILED __BIONIC_CAST(reinterpret_cast, void*, -1)
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080044
Elliott Hughes3d24d2b2019-08-05 13:53:01 -070045/**
46 * [mmap(2)](http://man7.org/linux/man-pages/man2/mmap.2.html)
47 * creates a memory mapping for the given range.
Elliott Hughesa3481742017-11-28 14:47:17 -080048 *
Elliott Hughes3d24d2b2019-08-05 13:53:01 -070049 * Returns the address of the mapping on success,
50 * and returns `MAP_FAILED` and sets `errno` on failure.
Dan Alberta613d0d2017-10-05 16:39:33 -070051 */
Elliott Hughesa3481742017-11-28 14:47:17 -080052#if defined(__USE_FILE_OFFSET64)
zijunzhao25725712023-05-04 23:29:00 +000053void* _Nonnull mmap(void* _Nullable __addr, size_t __size, int __prot, int __flags, int __fd, off_t __offset) __RENAME(mmap64);
Elliott Hughes68dc20d2015-02-06 22:28:49 -080054#else
zijunzhao25725712023-05-04 23:29:00 +000055void* _Nonnull mmap(void* _Nullable __addr, size_t __size, int __prot, int __flags, int __fd, off_t __offset);
Elliott Hughesa3481742017-11-28 14:47:17 -080056#endif
Elliott Hughes2eab77e2017-06-01 14:08:58 -070057
Elliott Hughes3d24d2b2019-08-05 13:53:01 -070058/**
59 * mmap64() is a variant of mmap() that takes a 64-bit offset even on LP32.
60 *
61 * See https://android.googlesource.com/platform/bionic/+/master/docs/32-bit-abi.md
62 *
Elliott Hughes19ed2042023-02-24 00:41:30 +000063 * Available since API level 21.
Elliott Hughes3d24d2b2019-08-05 13:53:01 -070064 */
zijunzhao25725712023-05-04 23:29:00 +000065void* _Nonnull mmap64(void* _Nullable __addr, size_t __size, int __prot, int __flags, int __fd, off64_t __offset) __INTRODUCED_IN(21);
Elliott Hughes68dc20d2015-02-06 22:28:49 -080066
Elliott Hughes3d24d2b2019-08-05 13:53:01 -070067/**
68 * [munmap(2)](http://man7.org/linux/man-pages/man2/munmap.2.html)
69 * deletes a memory mapping for the given range.
70 *
71 * Returns 0 on success, and returns -1 and sets `errno` on failure.
72 */
zijunzhao25725712023-05-04 23:29:00 +000073int munmap(void* _Nonnull __addr, size_t __size);
Elliott Hughes3d24d2b2019-08-05 13:53:01 -070074
75/**
76 * [msync(2)](http://man7.org/linux/man-pages/man2/msync.2.html)
77 * flushes changes to a memory-mapped file to disk.
78 *
79 * Returns 0 on success, and returns -1 and sets `errno` on failure.
80 */
zijunzhao25725712023-05-04 23:29:00 +000081int msync(void* _Nonnull __addr, size_t __size, int __flags);
Elliott Hughes3d24d2b2019-08-05 13:53:01 -070082
83/**
84 * [mprotect(2)](http://man7.org/linux/man-pages/man2/mprotect.2.html)
85 * sets the protection on a memory region.
86 *
87 * Returns 0 on success, and returns -1 and sets `errno` on failure.
88 */
zijunzhao25725712023-05-04 23:29:00 +000089int mprotect(void* _Nonnull __addr, size_t __size, int __prot);
Elliott Hughes3d24d2b2019-08-05 13:53:01 -070090
91/** Flag for mremap(). */
92#define MREMAP_MAYMOVE 1
93
94/** Flag for mremap(). */
95#define MREMAP_FIXED 2
96
97/**
98 * [mremap(2)](http://man7.org/linux/man-pages/man2/mremap.2.html)
99 * expands or shrinks an existing memory mapping.
100 *
101 * Returns the address of the mapping on success,
102 * and returns `MAP_FAILED` and sets `errno` on failure.
103 */
zijunzhao25725712023-05-04 23:29:00 +0000104void* _Nonnull mremap(void* _Nonnull __old_addr, size_t __old_size, size_t __new_size, int __flags, ...);
The Android Open Source Project1dc9e472009-03-03 19:28:35 -0800105
Elliott Hughes3d24d2b2019-08-05 13:53:01 -0700106/**
107 * [mlockall(2)](http://man7.org/linux/man-pages/man2/mlockall.2.html)
108 * locks pages (preventing swapping).
109 *
Elliott Hughesd4fd67c2022-11-30 19:53:33 +0000110 * Available since API level 17.
111 *
Elliott Hughes3d24d2b2019-08-05 13:53:01 -0700112 * Returns 0 on success, and returns -1 and sets `errno` on failure.
113 */
Elliott Hughesff26a162017-08-17 22:34:21 +0000114int mlockall(int __flags) __INTRODUCED_IN(17);
Elliott Hughes3d24d2b2019-08-05 13:53:01 -0700115
116/**
117 * [munlockall(2)](http://man7.org/linux/man-pages/man2/munlockall.2.html)
118 * unlocks pages (allowing swapping).
119 *
Elliott Hughesd4fd67c2022-11-30 19:53:33 +0000120 * Available since API level 17.
121 *
Elliott Hughes3d24d2b2019-08-05 13:53:01 -0700122 * Returns 0 on success, and returns -1 and sets `errno` on failure.
123 */
Elliott Hughes5470c182016-07-22 11:36:17 -0700124int munlockall(void) __INTRODUCED_IN(17);
Elliott Hughes2eab77e2017-06-01 14:08:58 -0700125
Elliott Hughes3d24d2b2019-08-05 13:53:01 -0700126/**
127 * [mlock(2)](http://man7.org/linux/man-pages/man2/mlock.2.html)
128 * locks pages (preventing swapping).
129 *
130 * Returns 0 on success, and returns -1 and sets `errno` on failure.
131 */
zijunzhao25725712023-05-04 23:29:00 +0000132int mlock(const void* _Nonnull __addr, size_t __size);
Elliott Hughes3d24d2b2019-08-05 13:53:01 -0700133
134/**
135 * [mlock2(2)](http://man7.org/linux/man-pages/man2/mlock.2.html)
136 * locks pages (preventing swapping), with optional flags.
137 *
Elliott Hughesd4fd67c2022-11-30 19:53:33 +0000138 * Available since API level 30.
139 *
Elliott Hughes3d24d2b2019-08-05 13:53:01 -0700140 * Returns 0 on success, and returns -1 and sets `errno` on failure.
141 */
zijunzhao25725712023-05-04 23:29:00 +0000142int mlock2(const void* _Nonnull __addr, size_t __size, int __flags) __INTRODUCED_IN(30);
Elliott Hughes3d24d2b2019-08-05 13:53:01 -0700143
144/**
145 * [munlock(2)](http://man7.org/linux/man-pages/man2/munlock.2.html)
146 * unlocks pages (allowing swapping).
147 *
148 * Returns 0 on success, and returns -1 and sets `errno` on failure.
149 */
zijunzhao25725712023-05-04 23:29:00 +0000150int munlock(const void* _Nonnull __addr, size_t __size);
The Android Open Source Project1dc9e472009-03-03 19:28:35 -0800151
Elliott Hughes3d24d2b2019-08-05 13:53:01 -0700152/**
153 * [mincore(2)](http://man7.org/linux/man-pages/man2/mincore.2.html)
154 * tests whether pages are resident in memory.
155 *
156 * Returns 0 on success, and returns -1 and sets `errno` on failure.
157 */
zijunzhao25725712023-05-04 23:29:00 +0000158int mincore(void* _Nonnull __addr, size_t __size, unsigned char* _Nonnull __vector);
The Android Open Source Project1dc9e472009-03-03 19:28:35 -0800159
Elliott Hughes3d24d2b2019-08-05 13:53:01 -0700160/**
161 * [madvise(2)](http://man7.org/linux/man-pages/man2/madvise.2.html)
162 * gives the kernel advice about future usage patterns.
163 *
164 * Returns 0 on success, and returns -1 and sets `errno` on failure.
165 */
zijunzhao25725712023-05-04 23:29:00 +0000166int madvise(void* _Nonnull __addr, size_t __size, int __advice);
Elliott Hughes2eab77e2017-06-01 14:08:58 -0700167
Edgar Arriaga128ef8e2020-12-23 14:59:56 -0800168/**
169 * [process_madvise(2)](http://man7.org/linux/man-pages/man2/process_madvise.2.html)
170 * works just like madvise(2) but applies to the process specified by the given
171 * PID file descriptor.
172 *
Elliott Hughesee41a352022-09-27 19:27:10 +0000173 * Available since API level 31. Its sibling process_mrelease() does not have a
174 * libc wrapper and should be called using syscall() instead. Given the lack of
175 * widespread applicability of this system call and the absence of wrappers in
176 * other libcs, it was probably a mistake to have added this wrapper to bionic.
Elliott Hughesd4fd67c2022-11-30 19:53:33 +0000177 *
178 * Returns the number of bytes advised on success, and returns -1 and sets `errno` on failure.
Edgar Arriaga128ef8e2020-12-23 14:59:56 -0800179 */
zijunzhao25725712023-05-04 23:29:00 +0000180ssize_t process_madvise(int __pid_fd, const struct iovec* _Nonnull __iov, size_t __count, int __advice, unsigned __flags) __INTRODUCED_IN(31);
Edgar Arriaga128ef8e2020-12-23 14:59:56 -0800181
Elliott Hughes3d24d2b2019-08-05 13:53:01 -0700182#if defined(__USE_GNU)
183
184/**
185 * [memfd_create(2)](http://man7.org/linux/man-pages/man2/memfd_create.2.html)
186 * creates an anonymous file.
187 *
Elliott Hughesd4fd67c2022-11-30 19:53:33 +0000188 * Available since API level 30.
189 *
Elliott Hughes3d24d2b2019-08-05 13:53:01 -0700190 * Returns an fd on success, and returns -1 and sets `errno` on failure.
191 */
zijunzhao25725712023-05-04 23:29:00 +0000192int memfd_create(const char* _Nonnull __name, unsigned __flags) __INTRODUCED_IN(30);
Elliott Hughes3d24d2b2019-08-05 13:53:01 -0700193
194#endif
195
Elliott Hughes95c6cd72019-12-20 13:26:14 -0800196#if __ANDROID_API__ >= 23
Elliott Hughes3d24d2b2019-08-05 13:53:01 -0700197
Elliott Hughes2eab77e2017-06-01 14:08:58 -0700198/*
199 * Some third-party code uses the existence of POSIX_MADV_NORMAL to detect the
200 * availability of posix_madvise. This is not correct, since having up-to-date
201 * UAPI headers says nothing about the C library, but for the time being we
Elliott Hughes00fedf52017-07-05 15:23:50 -0700202 * don't want to harm adoption of the unified headers.
Elliott Hughes2eab77e2017-06-01 14:08:58 -0700203 *
204 * https://github.com/android-ndk/ndk/issues/395
205 */
Elliott Hughes3d24d2b2019-08-05 13:53:01 -0700206
207/** Flag for posix_madvise(). */
Elliott Hughes2eab77e2017-06-01 14:08:58 -0700208#define POSIX_MADV_NORMAL MADV_NORMAL
Elliott Hughes3d24d2b2019-08-05 13:53:01 -0700209/** Flag for posix_madvise(). */
Elliott Hughes2eab77e2017-06-01 14:08:58 -0700210#define POSIX_MADV_RANDOM MADV_RANDOM
Elliott Hughes3d24d2b2019-08-05 13:53:01 -0700211/** Flag for posix_madvise(). */
Elliott Hughes2eab77e2017-06-01 14:08:58 -0700212#define POSIX_MADV_SEQUENTIAL MADV_SEQUENTIAL
Elliott Hughes3d24d2b2019-08-05 13:53:01 -0700213/** Flag for posix_madvise(). */
Elliott Hughes2eab77e2017-06-01 14:08:58 -0700214#define POSIX_MADV_WILLNEED MADV_WILLNEED
Elliott Hughes3d24d2b2019-08-05 13:53:01 -0700215/** Flag for posix_madvise(). */
Elliott Hughes2eab77e2017-06-01 14:08:58 -0700216#define POSIX_MADV_DONTNEED MADV_DONTNEED
Elliott Hughes3d24d2b2019-08-05 13:53:01 -0700217
Elliott Hughes2eab77e2017-06-01 14:08:58 -0700218#endif
Elliott Hughes3d24d2b2019-08-05 13:53:01 -0700219
220/**
221 * [posix_madvise(3)](http://man7.org/linux/man-pages/man3/posix_madvise.3.html)
222 * gives the kernel advice about future usage patterns.
223 *
Elliott Hughesd4fd67c2022-11-30 19:53:33 +0000224 * Available since API level 23.
225 * See also madvise() which is available at all API levels.
Elliott Hughes3d24d2b2019-08-05 13:53:01 -0700226 *
Elliott Hughesd4fd67c2022-11-30 19:53:33 +0000227 * Returns 0 on success, and returns a positive error number on failure.
Elliott Hughes3d24d2b2019-08-05 13:53:01 -0700228 */
zijunzhao25725712023-05-04 23:29:00 +0000229int posix_madvise(void* _Nonnull __addr, size_t __size, int __advice) __INTRODUCED_IN(23);
Yabin Cui5afae642014-11-25 20:17:27 -0800230
The Android Open Source Project1dc9e472009-03-03 19:28:35 -0800231__END_DECLS