blob: fe4ea7f5a64db5722044dd937df91bd8b9e401e3 [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>
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080035
36__BEGIN_DECLS
37
Elliott Hughes3d24d2b2019-08-05 13:53:01 -070038/** Alternative spelling of the `MAP_ANONYMOUS` flag for mmap(). */
39#define MAP_ANON MAP_ANONYMOUS
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080040
Elliott Hughes3d24d2b2019-08-05 13:53:01 -070041/** Return value for mmap(). */
Elliott Hughes5470c182016-07-22 11:36:17 -070042#define MAP_FAILED __BIONIC_CAST(reinterpret_cast, void*, -1)
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080043
Elliott Hughes3d24d2b2019-08-05 13:53:01 -070044/**
45 * [mmap(2)](http://man7.org/linux/man-pages/man2/mmap.2.html)
46 * creates a memory mapping for the given range.
Elliott Hughesa3481742017-11-28 14:47:17 -080047 *
Elliott Hughes3d24d2b2019-08-05 13:53:01 -070048 * Returns the address of the mapping on success,
49 * and returns `MAP_FAILED` and sets `errno` on failure.
Dan Alberta613d0d2017-10-05 16:39:33 -070050 */
Elliott Hughesa3481742017-11-28 14:47:17 -080051#if defined(__USE_FILE_OFFSET64)
Elliott Hughes0d1a8a52018-07-24 19:36:51 +000052void* mmap(void* __addr, size_t __size, int __prot, int __flags, int __fd, off_t __offset) __RENAME(mmap64);
Elliott Hughes68dc20d2015-02-06 22:28:49 -080053#else
Elliott Hughesff26a162017-08-17 22:34:21 +000054void* mmap(void* __addr, size_t __size, int __prot, int __flags, int __fd, off_t __offset);
Elliott Hughesa3481742017-11-28 14:47:17 -080055#endif
Elliott Hughes2eab77e2017-06-01 14:08:58 -070056
Elliott Hughes95c6cd72019-12-20 13:26:14 -080057#if __ANDROID_API__ >= 21
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 *
63 * mmap64 wasn't really around until L, but we added an inline for it since it
64 * allows a lot more code to compile with _FILE_OFFSET_BITS=64.
65 */
Elliott Hughesff26a162017-08-17 22:34:21 +000066void* mmap64(void* __addr, size_t __size, int __prot, int __flags, int __fd, off64_t __offset) __INTRODUCED_IN(21);
Dan Alberta613d0d2017-10-05 16:39:33 -070067#endif
Elliott Hughes68dc20d2015-02-06 22:28:49 -080068
Elliott Hughes3d24d2b2019-08-05 13:53:01 -070069/**
70 * [munmap(2)](http://man7.org/linux/man-pages/man2/munmap.2.html)
71 * deletes a memory mapping for the given range.
72 *
73 * Returns 0 on success, and returns -1 and sets `errno` on failure.
74 */
Elliott Hughesff26a162017-08-17 22:34:21 +000075int munmap(void* __addr, size_t __size);
Elliott Hughes3d24d2b2019-08-05 13:53:01 -070076
77/**
78 * [msync(2)](http://man7.org/linux/man-pages/man2/msync.2.html)
79 * flushes changes to a memory-mapped file to disk.
80 *
81 * Returns 0 on success, and returns -1 and sets `errno` on failure.
82 */
Elliott Hughesff26a162017-08-17 22:34:21 +000083int msync(void* __addr, size_t __size, int __flags);
Elliott Hughes3d24d2b2019-08-05 13:53:01 -070084
85/**
86 * [mprotect(2)](http://man7.org/linux/man-pages/man2/mprotect.2.html)
87 * sets the protection on a memory region.
88 *
89 * Returns 0 on success, and returns -1 and sets `errno` on failure.
90 */
Elliott Hughesff26a162017-08-17 22:34:21 +000091int mprotect(void* __addr, size_t __size, int __prot);
Elliott Hughes3d24d2b2019-08-05 13:53:01 -070092
93/** Flag for mremap(). */
94#define MREMAP_MAYMOVE 1
95
96/** Flag for mremap(). */
97#define MREMAP_FIXED 2
98
99/**
100 * [mremap(2)](http://man7.org/linux/man-pages/man2/mremap.2.html)
101 * expands or shrinks an existing memory mapping.
102 *
103 * Returns the address of the mapping on success,
104 * and returns `MAP_FAILED` and sets `errno` on failure.
105 */
Elliott Hughesff26a162017-08-17 22:34:21 +0000106void* mremap(void* __old_addr, size_t __old_size, size_t __new_size, int __flags, ...);
The Android Open Source Project1dc9e472009-03-03 19:28:35 -0800107
Elliott Hughes3d24d2b2019-08-05 13:53:01 -0700108/**
109 * [mlockall(2)](http://man7.org/linux/man-pages/man2/mlockall.2.html)
110 * locks pages (preventing swapping).
111 *
112 * 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 *
120 * Returns 0 on success, and returns -1 and sets `errno` on failure.
121 */
Elliott Hughes5470c182016-07-22 11:36:17 -0700122int munlockall(void) __INTRODUCED_IN(17);
Elliott Hughes2eab77e2017-06-01 14:08:58 -0700123
Elliott Hughes3d24d2b2019-08-05 13:53:01 -0700124/**
125 * [mlock(2)](http://man7.org/linux/man-pages/man2/mlock.2.html)
126 * locks pages (preventing swapping).
127 *
128 * Returns 0 on success, and returns -1 and sets `errno` on failure.
129 */
Elliott Hughesff26a162017-08-17 22:34:21 +0000130int mlock(const void* __addr, size_t __size);
Elliott Hughes3d24d2b2019-08-05 13:53:01 -0700131
132/**
133 * [mlock2(2)](http://man7.org/linux/man-pages/man2/mlock.2.html)
134 * locks pages (preventing swapping), with optional flags.
135 *
136 * Returns 0 on success, and returns -1 and sets `errno` on failure.
137 */
138int mlock2(const void* __addr, size_t __size, int __flags) __INTRODUCED_IN(30);
139
140/**
141 * [munlock(2)](http://man7.org/linux/man-pages/man2/munlock.2.html)
142 * unlocks pages (allowing swapping).
143 *
144 * Returns 0 on success, and returns -1 and sets `errno` on failure.
145 */
Elliott Hughesff26a162017-08-17 22:34:21 +0000146int munlock(const void* __addr, size_t __size);
The Android Open Source Project1dc9e472009-03-03 19:28:35 -0800147
Elliott Hughes3d24d2b2019-08-05 13:53:01 -0700148/**
149 * [mincore(2)](http://man7.org/linux/man-pages/man2/mincore.2.html)
150 * tests whether pages are resident in memory.
151 *
152 * Returns 0 on success, and returns -1 and sets `errno` on failure.
153 */
Elliott Hughesff26a162017-08-17 22:34:21 +0000154int mincore(void* __addr, size_t __size, unsigned char* __vector);
The Android Open Source Project1dc9e472009-03-03 19:28:35 -0800155
Elliott Hughes3d24d2b2019-08-05 13:53:01 -0700156/**
157 * [madvise(2)](http://man7.org/linux/man-pages/man2/madvise.2.html)
158 * gives the kernel advice about future usage patterns.
159 *
160 * Returns 0 on success, and returns -1 and sets `errno` on failure.
161 */
Elliott Hughesff26a162017-08-17 22:34:21 +0000162int madvise(void* __addr, size_t __size, int __advice);
Elliott Hughes2eab77e2017-06-01 14:08:58 -0700163
Elliott Hughes3d24d2b2019-08-05 13:53:01 -0700164#if defined(__USE_GNU)
165
166/**
167 * [memfd_create(2)](http://man7.org/linux/man-pages/man2/memfd_create.2.html)
168 * creates an anonymous file.
169 *
170 * Returns an fd on success, and returns -1 and sets `errno` on failure.
171 */
172int memfd_create(const char* __name, unsigned __flags) __INTRODUCED_IN(30);
173
174#endif
175
Elliott Hughes95c6cd72019-12-20 13:26:14 -0800176#if __ANDROID_API__ >= 23
Elliott Hughes3d24d2b2019-08-05 13:53:01 -0700177
Elliott Hughes2eab77e2017-06-01 14:08:58 -0700178/*
179 * Some third-party code uses the existence of POSIX_MADV_NORMAL to detect the
180 * availability of posix_madvise. This is not correct, since having up-to-date
181 * UAPI headers says nothing about the C library, but for the time being we
Elliott Hughes00fedf52017-07-05 15:23:50 -0700182 * don't want to harm adoption of the unified headers.
Elliott Hughes2eab77e2017-06-01 14:08:58 -0700183 *
184 * https://github.com/android-ndk/ndk/issues/395
185 */
Elliott Hughes3d24d2b2019-08-05 13:53:01 -0700186
187/** Flag for posix_madvise(). */
Elliott Hughes2eab77e2017-06-01 14:08:58 -0700188#define POSIX_MADV_NORMAL MADV_NORMAL
Elliott Hughes3d24d2b2019-08-05 13:53:01 -0700189/** Flag for posix_madvise(). */
Elliott Hughes2eab77e2017-06-01 14:08:58 -0700190#define POSIX_MADV_RANDOM MADV_RANDOM
Elliott Hughes3d24d2b2019-08-05 13:53:01 -0700191/** Flag for posix_madvise(). */
Elliott Hughes2eab77e2017-06-01 14:08:58 -0700192#define POSIX_MADV_SEQUENTIAL MADV_SEQUENTIAL
Elliott Hughes3d24d2b2019-08-05 13:53:01 -0700193/** Flag for posix_madvise(). */
Elliott Hughes2eab77e2017-06-01 14:08:58 -0700194#define POSIX_MADV_WILLNEED MADV_WILLNEED
Elliott Hughes3d24d2b2019-08-05 13:53:01 -0700195/** Flag for posix_madvise(). */
Elliott Hughes2eab77e2017-06-01 14:08:58 -0700196#define POSIX_MADV_DONTNEED MADV_DONTNEED
Elliott Hughes3d24d2b2019-08-05 13:53:01 -0700197
Elliott Hughes2eab77e2017-06-01 14:08:58 -0700198#endif
Elliott Hughes3d24d2b2019-08-05 13:53:01 -0700199
200/**
201 * [posix_madvise(3)](http://man7.org/linux/man-pages/man3/posix_madvise.3.html)
202 * gives the kernel advice about future usage patterns.
203 *
204 * Returns 0 on success, and returns a positive error number on failure.
205 *
206 * See also madvise() which has been available much longer.
207 */
Elliott Hughesff26a162017-08-17 22:34:21 +0000208int posix_madvise(void* __addr, size_t __size, int __advice) __INTRODUCED_IN(23);
Yabin Cui5afae642014-11-25 20:17:27 -0800209
The Android Open Source Project1dc9e472009-03-03 19:28:35 -0800210__END_DECLS
211
Dan Alberta613d0d2017-10-05 16:39:33 -0700212#include <android/legacy_sys_mman_inlines.h>