xref: /aosp_15_r20/bionic/libc/include/sys/mman.h (revision 8d67ca893c1523eb926b9080dbe4e2ffd2a27ba1)
1*8d67ca89SAndroid Build Coastguard Worker /*
2*8d67ca89SAndroid Build Coastguard Worker  * Copyright (C) 2008 The Android Open Source Project
3*8d67ca89SAndroid Build Coastguard Worker  * All rights reserved.
4*8d67ca89SAndroid Build Coastguard Worker  *
5*8d67ca89SAndroid Build Coastguard Worker  * Redistribution and use in source and binary forms, with or without
6*8d67ca89SAndroid Build Coastguard Worker  * modification, are permitted provided that the following conditions
7*8d67ca89SAndroid Build Coastguard Worker  * are met:
8*8d67ca89SAndroid Build Coastguard Worker  *  * Redistributions of source code must retain the above copyright
9*8d67ca89SAndroid Build Coastguard Worker  *    notice, this list of conditions and the following disclaimer.
10*8d67ca89SAndroid Build Coastguard Worker  *  * Redistributions in binary form must reproduce the above copyright
11*8d67ca89SAndroid Build Coastguard Worker  *    notice, this list of conditions and the following disclaimer in
12*8d67ca89SAndroid Build Coastguard Worker  *    the documentation and/or other materials provided with the
13*8d67ca89SAndroid Build Coastguard Worker  *    distribution.
14*8d67ca89SAndroid Build Coastguard Worker  *
15*8d67ca89SAndroid Build Coastguard Worker  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
16*8d67ca89SAndroid Build Coastguard Worker  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
17*8d67ca89SAndroid Build Coastguard Worker  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
18*8d67ca89SAndroid Build Coastguard Worker  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
19*8d67ca89SAndroid Build Coastguard Worker  * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
20*8d67ca89SAndroid Build Coastguard Worker  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
21*8d67ca89SAndroid Build Coastguard Worker  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
22*8d67ca89SAndroid Build Coastguard Worker  * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
23*8d67ca89SAndroid Build Coastguard Worker  * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
24*8d67ca89SAndroid Build Coastguard Worker  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
25*8d67ca89SAndroid Build Coastguard Worker  * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
26*8d67ca89SAndroid Build Coastguard Worker  * SUCH DAMAGE.
27*8d67ca89SAndroid Build Coastguard Worker  */
28*8d67ca89SAndroid Build Coastguard Worker 
29*8d67ca89SAndroid Build Coastguard Worker #pragma once
30*8d67ca89SAndroid Build Coastguard Worker 
31*8d67ca89SAndroid Build Coastguard Worker #include <sys/cdefs.h>
32*8d67ca89SAndroid Build Coastguard Worker #include <sys/types.h>
33*8d67ca89SAndroid Build Coastguard Worker #include <linux/memfd.h>
34*8d67ca89SAndroid Build Coastguard Worker #include <linux/mman.h>
35*8d67ca89SAndroid Build Coastguard Worker #include <linux/uio.h>
36*8d67ca89SAndroid Build Coastguard Worker 
37*8d67ca89SAndroid Build Coastguard Worker __BEGIN_DECLS
38*8d67ca89SAndroid Build Coastguard Worker 
39*8d67ca89SAndroid Build Coastguard Worker /** Alternative spelling of the `MAP_ANONYMOUS` flag for mmap(). */
40*8d67ca89SAndroid Build Coastguard Worker #define MAP_ANON MAP_ANONYMOUS
41*8d67ca89SAndroid Build Coastguard Worker 
42*8d67ca89SAndroid Build Coastguard Worker /** Return value for mmap(). */
43*8d67ca89SAndroid Build Coastguard Worker #define MAP_FAILED __BIONIC_CAST(reinterpret_cast, void*, -1)
44*8d67ca89SAndroid Build Coastguard Worker 
45*8d67ca89SAndroid Build Coastguard Worker /**
46*8d67ca89SAndroid Build Coastguard Worker  * [mmap(2)](https://man7.org/linux/man-pages/man2/mmap.2.html)
47*8d67ca89SAndroid Build Coastguard Worker  * creates a memory mapping for the given range.
48*8d67ca89SAndroid Build Coastguard Worker  *
49*8d67ca89SAndroid Build Coastguard Worker  * Returns the address of the mapping on success,
50*8d67ca89SAndroid Build Coastguard Worker  * and returns `MAP_FAILED` and sets `errno` on failure.
51*8d67ca89SAndroid Build Coastguard Worker  */
52*8d67ca89SAndroid Build Coastguard Worker #if defined(__USE_FILE_OFFSET64)
53*8d67ca89SAndroid Build Coastguard Worker void* _Nonnull mmap(void* _Nullable __addr, size_t __size, int __prot, int __flags, int __fd, off_t __offset) __RENAME(mmap64);
54*8d67ca89SAndroid Build Coastguard Worker #else
55*8d67ca89SAndroid Build Coastguard Worker void* _Nonnull mmap(void* _Nullable __addr, size_t __size, int __prot, int __flags, int __fd, off_t __offset);
56*8d67ca89SAndroid Build Coastguard Worker #endif
57*8d67ca89SAndroid Build Coastguard Worker 
58*8d67ca89SAndroid Build Coastguard Worker /**
59*8d67ca89SAndroid Build Coastguard Worker  * mmap64() is a variant of mmap() that takes a 64-bit offset even on LP32.
60*8d67ca89SAndroid Build Coastguard Worker  *
61*8d67ca89SAndroid Build Coastguard Worker  * See https://android.googlesource.com/platform/bionic/+/main/docs/32-bit-abi.md
62*8d67ca89SAndroid Build Coastguard Worker  */
63*8d67ca89SAndroid Build Coastguard Worker void* _Nonnull mmap64(void* _Nullable __addr, size_t __size, int __prot, int __flags, int __fd, off64_t __offset);
64*8d67ca89SAndroid Build Coastguard Worker 
65*8d67ca89SAndroid Build Coastguard Worker /**
66*8d67ca89SAndroid Build Coastguard Worker  * [munmap(2)](https://man7.org/linux/man-pages/man2/munmap.2.html)
67*8d67ca89SAndroid Build Coastguard Worker  * deletes a memory mapping for the given range.
68*8d67ca89SAndroid Build Coastguard Worker  *
69*8d67ca89SAndroid Build Coastguard Worker  * Returns 0 on success, and returns -1 and sets `errno` on failure.
70*8d67ca89SAndroid Build Coastguard Worker  */
71*8d67ca89SAndroid Build Coastguard Worker int munmap(void* _Nonnull __addr, size_t __size);
72*8d67ca89SAndroid Build Coastguard Worker 
73*8d67ca89SAndroid Build Coastguard Worker /**
74*8d67ca89SAndroid Build Coastguard Worker  * [msync(2)](https://man7.org/linux/man-pages/man2/msync.2.html)
75*8d67ca89SAndroid Build Coastguard Worker  * flushes changes to a memory-mapped file to disk.
76*8d67ca89SAndroid Build Coastguard Worker  *
77*8d67ca89SAndroid Build Coastguard Worker  * Returns 0 on success, and returns -1 and sets `errno` on failure.
78*8d67ca89SAndroid Build Coastguard Worker  */
79*8d67ca89SAndroid Build Coastguard Worker int msync(void* _Nonnull __addr, size_t __size, int __flags);
80*8d67ca89SAndroid Build Coastguard Worker 
81*8d67ca89SAndroid Build Coastguard Worker /**
82*8d67ca89SAndroid Build Coastguard Worker  * [mprotect(2)](https://man7.org/linux/man-pages/man2/mprotect.2.html)
83*8d67ca89SAndroid Build Coastguard Worker  * sets the protection on a memory region.
84*8d67ca89SAndroid Build Coastguard Worker  *
85*8d67ca89SAndroid Build Coastguard Worker  * Returns 0 on success, and returns -1 and sets `errno` on failure.
86*8d67ca89SAndroid Build Coastguard Worker  */
87*8d67ca89SAndroid Build Coastguard Worker int mprotect(void* _Nonnull __addr, size_t __size, int __prot);
88*8d67ca89SAndroid Build Coastguard Worker 
89*8d67ca89SAndroid Build Coastguard Worker /** Flag for mremap(). */
90*8d67ca89SAndroid Build Coastguard Worker #define MREMAP_MAYMOVE  1
91*8d67ca89SAndroid Build Coastguard Worker 
92*8d67ca89SAndroid Build Coastguard Worker /** Flag for mremap(). */
93*8d67ca89SAndroid Build Coastguard Worker #define MREMAP_FIXED    2
94*8d67ca89SAndroid Build Coastguard Worker 
95*8d67ca89SAndroid Build Coastguard Worker /**
96*8d67ca89SAndroid Build Coastguard Worker  * [mremap(2)](https://man7.org/linux/man-pages/man2/mremap.2.html)
97*8d67ca89SAndroid Build Coastguard Worker  * expands or shrinks an existing memory mapping.
98*8d67ca89SAndroid Build Coastguard Worker  *
99*8d67ca89SAndroid Build Coastguard Worker  * Returns the address of the mapping on success,
100*8d67ca89SAndroid Build Coastguard Worker  * and returns `MAP_FAILED` and sets `errno` on failure.
101*8d67ca89SAndroid Build Coastguard Worker  */
102*8d67ca89SAndroid Build Coastguard Worker void* _Nonnull mremap(void* _Nonnull __old_addr, size_t __old_size, size_t __new_size, int __flags, ...);
103*8d67ca89SAndroid Build Coastguard Worker 
104*8d67ca89SAndroid Build Coastguard Worker /**
105*8d67ca89SAndroid Build Coastguard Worker  * [mlockall(2)](https://man7.org/linux/man-pages/man2/mlockall.2.html)
106*8d67ca89SAndroid Build Coastguard Worker  * locks pages (preventing swapping).
107*8d67ca89SAndroid Build Coastguard Worker  *
108*8d67ca89SAndroid Build Coastguard Worker  * Returns 0 on success, and returns -1 and sets `errno` on failure.
109*8d67ca89SAndroid Build Coastguard Worker  */
110*8d67ca89SAndroid Build Coastguard Worker int mlockall(int __flags);
111*8d67ca89SAndroid Build Coastguard Worker 
112*8d67ca89SAndroid Build Coastguard Worker /**
113*8d67ca89SAndroid Build Coastguard Worker  * [munlockall(2)](https://man7.org/linux/man-pages/man2/munlockall.2.html)
114*8d67ca89SAndroid Build Coastguard Worker  * unlocks pages (allowing swapping).
115*8d67ca89SAndroid Build Coastguard Worker  *
116*8d67ca89SAndroid Build Coastguard Worker  * Returns 0 on success, and returns -1 and sets `errno` on failure.
117*8d67ca89SAndroid Build Coastguard Worker  */
118*8d67ca89SAndroid Build Coastguard Worker int munlockall(void);
119*8d67ca89SAndroid Build Coastguard Worker 
120*8d67ca89SAndroid Build Coastguard Worker /**
121*8d67ca89SAndroid Build Coastguard Worker  * [mlock(2)](https://man7.org/linux/man-pages/man2/mlock.2.html)
122*8d67ca89SAndroid Build Coastguard Worker  * locks pages (preventing swapping).
123*8d67ca89SAndroid Build Coastguard Worker  *
124*8d67ca89SAndroid Build Coastguard Worker  * Returns 0 on success, and returns -1 and sets `errno` on failure.
125*8d67ca89SAndroid Build Coastguard Worker  */
126*8d67ca89SAndroid Build Coastguard Worker int mlock(const void* _Nonnull __addr, size_t __size);
127*8d67ca89SAndroid Build Coastguard Worker 
128*8d67ca89SAndroid Build Coastguard Worker /**
129*8d67ca89SAndroid Build Coastguard Worker  * [mlock2(2)](https://man7.org/linux/man-pages/man2/mlock.2.html)
130*8d67ca89SAndroid Build Coastguard Worker  * locks pages (preventing swapping), with optional flags.
131*8d67ca89SAndroid Build Coastguard Worker  *
132*8d67ca89SAndroid Build Coastguard Worker  * Available since API level 30.
133*8d67ca89SAndroid Build Coastguard Worker  *
134*8d67ca89SAndroid Build Coastguard Worker  * Returns 0 on success, and returns -1 and sets `errno` on failure.
135*8d67ca89SAndroid Build Coastguard Worker  */
136*8d67ca89SAndroid Build Coastguard Worker 
137*8d67ca89SAndroid Build Coastguard Worker #if __BIONIC_AVAILABILITY_GUARD(30)
138*8d67ca89SAndroid Build Coastguard Worker int mlock2(const void* _Nonnull __addr, size_t __size, int __flags) __INTRODUCED_IN(30);
139*8d67ca89SAndroid Build Coastguard Worker #endif /* __BIONIC_AVAILABILITY_GUARD(30) */
140*8d67ca89SAndroid Build Coastguard Worker 
141*8d67ca89SAndroid Build Coastguard Worker 
142*8d67ca89SAndroid Build Coastguard Worker /**
143*8d67ca89SAndroid Build Coastguard Worker  * [munlock(2)](https://man7.org/linux/man-pages/man2/munlock.2.html)
144*8d67ca89SAndroid Build Coastguard Worker  * unlocks pages (allowing swapping).
145*8d67ca89SAndroid Build Coastguard Worker  *
146*8d67ca89SAndroid Build Coastguard Worker  * Returns 0 on success, and returns -1 and sets `errno` on failure.
147*8d67ca89SAndroid Build Coastguard Worker  */
148*8d67ca89SAndroid Build Coastguard Worker int munlock(const void* _Nonnull __addr, size_t __size);
149*8d67ca89SAndroid Build Coastguard Worker 
150*8d67ca89SAndroid Build Coastguard Worker /**
151*8d67ca89SAndroid Build Coastguard Worker  * [mincore(2)](https://man7.org/linux/man-pages/man2/mincore.2.html)
152*8d67ca89SAndroid Build Coastguard Worker  * tests whether pages are resident in memory.
153*8d67ca89SAndroid Build Coastguard Worker  *
154*8d67ca89SAndroid Build Coastguard Worker  * Returns 0 on success, and returns -1 and sets `errno` on failure.
155*8d67ca89SAndroid Build Coastguard Worker  */
156*8d67ca89SAndroid Build Coastguard Worker int mincore(void* _Nonnull __addr, size_t __size, unsigned char* _Nonnull __vector);
157*8d67ca89SAndroid Build Coastguard Worker 
158*8d67ca89SAndroid Build Coastguard Worker /**
159*8d67ca89SAndroid Build Coastguard Worker  * [madvise(2)](https://man7.org/linux/man-pages/man2/madvise.2.html)
160*8d67ca89SAndroid Build Coastguard Worker  * gives the kernel advice about future usage patterns.
161*8d67ca89SAndroid Build Coastguard Worker  *
162*8d67ca89SAndroid Build Coastguard Worker  * Returns 0 on success, and returns -1 and sets `errno` on failure.
163*8d67ca89SAndroid Build Coastguard Worker  */
164*8d67ca89SAndroid Build Coastguard Worker int madvise(void* _Nonnull __addr, size_t __size, int __advice);
165*8d67ca89SAndroid Build Coastguard Worker 
166*8d67ca89SAndroid Build Coastguard Worker /**
167*8d67ca89SAndroid Build Coastguard Worker  * [process_madvise(2)](https://man7.org/linux/man-pages/man2/process_madvise.2.html)
168*8d67ca89SAndroid Build Coastguard Worker  * works just like madvise(2) but applies to the process specified by the given
169*8d67ca89SAndroid Build Coastguard Worker  * PID file descriptor.
170*8d67ca89SAndroid Build Coastguard Worker  *
171*8d67ca89SAndroid Build Coastguard Worker  * Available since API level 31. Its sibling process_mrelease() does not have a
172*8d67ca89SAndroid Build Coastguard Worker  * libc wrapper and should be called using syscall() instead. Given the lack of
173*8d67ca89SAndroid Build Coastguard Worker  * widespread applicability of this system call and the absence of wrappers in
174*8d67ca89SAndroid Build Coastguard Worker  * other libcs, it was probably a mistake to have added this wrapper to bionic.
175*8d67ca89SAndroid Build Coastguard Worker  *
176*8d67ca89SAndroid Build Coastguard Worker  * Returns the number of bytes advised on success, and returns -1 and sets `errno` on failure.
177*8d67ca89SAndroid Build Coastguard Worker  */
178*8d67ca89SAndroid Build Coastguard Worker 
179*8d67ca89SAndroid Build Coastguard Worker #if __BIONIC_AVAILABILITY_GUARD(31)
180*8d67ca89SAndroid Build Coastguard Worker ssize_t process_madvise(int __pid_fd, const struct iovec* _Nonnull __iov, size_t __count, int __advice, unsigned __flags) __INTRODUCED_IN(31);
181*8d67ca89SAndroid Build Coastguard Worker #endif /* __BIONIC_AVAILABILITY_GUARD(31) */
182*8d67ca89SAndroid Build Coastguard Worker 
183*8d67ca89SAndroid Build Coastguard Worker 
184*8d67ca89SAndroid Build Coastguard Worker #if defined(__USE_GNU)
185*8d67ca89SAndroid Build Coastguard Worker 
186*8d67ca89SAndroid Build Coastguard Worker /**
187*8d67ca89SAndroid Build Coastguard Worker  * [memfd_create(2)](https://man7.org/linux/man-pages/man2/memfd_create.2.html)
188*8d67ca89SAndroid Build Coastguard Worker  * creates an anonymous file.
189*8d67ca89SAndroid Build Coastguard Worker  *
190*8d67ca89SAndroid Build Coastguard Worker  * Available since API level 30.
191*8d67ca89SAndroid Build Coastguard Worker  *
192*8d67ca89SAndroid Build Coastguard Worker  * Returns an fd on success, and returns -1 and sets `errno` on failure.
193*8d67ca89SAndroid Build Coastguard Worker  */
194*8d67ca89SAndroid Build Coastguard Worker 
195*8d67ca89SAndroid Build Coastguard Worker #if __BIONIC_AVAILABILITY_GUARD(30)
196*8d67ca89SAndroid Build Coastguard Worker int memfd_create(const char* _Nonnull __name, unsigned __flags) __INTRODUCED_IN(30);
197*8d67ca89SAndroid Build Coastguard Worker #endif /* __BIONIC_AVAILABILITY_GUARD(30) */
198*8d67ca89SAndroid Build Coastguard Worker 
199*8d67ca89SAndroid Build Coastguard Worker 
200*8d67ca89SAndroid Build Coastguard Worker #endif
201*8d67ca89SAndroid Build Coastguard Worker 
202*8d67ca89SAndroid Build Coastguard Worker #if __ANDROID_API__ >= 23
203*8d67ca89SAndroid Build Coastguard Worker 
204*8d67ca89SAndroid Build Coastguard Worker /*
205*8d67ca89SAndroid Build Coastguard Worker  * Some third-party code uses the existence of POSIX_MADV_NORMAL to detect the
206*8d67ca89SAndroid Build Coastguard Worker  * availability of posix_madvise. This is not correct, since having up-to-date
207*8d67ca89SAndroid Build Coastguard Worker  * UAPI headers says nothing about the C library, but for the time being we
208*8d67ca89SAndroid Build Coastguard Worker  * don't want to harm adoption of the unified headers.
209*8d67ca89SAndroid Build Coastguard Worker  *
210*8d67ca89SAndroid Build Coastguard Worker  * https://github.com/android-ndk/ndk/issues/395
211*8d67ca89SAndroid Build Coastguard Worker  */
212*8d67ca89SAndroid Build Coastguard Worker 
213*8d67ca89SAndroid Build Coastguard Worker /** Flag for posix_madvise(). */
214*8d67ca89SAndroid Build Coastguard Worker #define POSIX_MADV_NORMAL     MADV_NORMAL
215*8d67ca89SAndroid Build Coastguard Worker /** Flag for posix_madvise(). */
216*8d67ca89SAndroid Build Coastguard Worker #define POSIX_MADV_RANDOM     MADV_RANDOM
217*8d67ca89SAndroid Build Coastguard Worker /** Flag for posix_madvise(). */
218*8d67ca89SAndroid Build Coastguard Worker #define POSIX_MADV_SEQUENTIAL MADV_SEQUENTIAL
219*8d67ca89SAndroid Build Coastguard Worker /** Flag for posix_madvise(). */
220*8d67ca89SAndroid Build Coastguard Worker #define POSIX_MADV_WILLNEED   MADV_WILLNEED
221*8d67ca89SAndroid Build Coastguard Worker /** Flag for posix_madvise(). */
222*8d67ca89SAndroid Build Coastguard Worker #define POSIX_MADV_DONTNEED   MADV_DONTNEED
223*8d67ca89SAndroid Build Coastguard Worker 
224*8d67ca89SAndroid Build Coastguard Worker #endif
225*8d67ca89SAndroid Build Coastguard Worker 
226*8d67ca89SAndroid Build Coastguard Worker /**
227*8d67ca89SAndroid Build Coastguard Worker  * [posix_madvise(3)](https://man7.org/linux/man-pages/man3/posix_madvise.3.html)
228*8d67ca89SAndroid Build Coastguard Worker  * gives the kernel advice about future usage patterns.
229*8d67ca89SAndroid Build Coastguard Worker  *
230*8d67ca89SAndroid Build Coastguard Worker  * Available since API level 23.
231*8d67ca89SAndroid Build Coastguard Worker  * See also madvise() which is available at all API levels.
232*8d67ca89SAndroid Build Coastguard Worker  *
233*8d67ca89SAndroid Build Coastguard Worker  * Returns 0 on success, and returns a positive error number on failure.
234*8d67ca89SAndroid Build Coastguard Worker  */
235*8d67ca89SAndroid Build Coastguard Worker 
236*8d67ca89SAndroid Build Coastguard Worker #if __BIONIC_AVAILABILITY_GUARD(23)
237*8d67ca89SAndroid Build Coastguard Worker int posix_madvise(void* _Nonnull __addr, size_t __size, int __advice) __INTRODUCED_IN(23);
238*8d67ca89SAndroid Build Coastguard Worker #endif /* __BIONIC_AVAILABILITY_GUARD(23) */
239*8d67ca89SAndroid Build Coastguard Worker 
240*8d67ca89SAndroid Build Coastguard Worker 
241*8d67ca89SAndroid Build Coastguard Worker /**
242*8d67ca89SAndroid Build Coastguard Worker  * [mseal(2)](https://man7.org/linux/man-pages/man2/mseal.2.html)
243*8d67ca89SAndroid Build Coastguard Worker  * seals the given range to prevent modifications such as mprotect() calls.
244*8d67ca89SAndroid Build Coastguard Worker  *
245*8d67ca89SAndroid Build Coastguard Worker  * Available since API level 36.
246*8d67ca89SAndroid Build Coastguard Worker  * Requires a Linux 6.10 or newer kernel.
247*8d67ca89SAndroid Build Coastguard Worker  * Always fails for 32-bit processes.
248*8d67ca89SAndroid Build Coastguard Worker  *
249*8d67ca89SAndroid Build Coastguard Worker  * Returns 0 on success, and returns -1 and sets `errno` on failure.
250*8d67ca89SAndroid Build Coastguard Worker  */
251*8d67ca89SAndroid Build Coastguard Worker 
252*8d67ca89SAndroid Build Coastguard Worker #if __BIONIC_AVAILABILITY_GUARD(36)
253*8d67ca89SAndroid Build Coastguard Worker int mseal(void* _Nonnull __addr, size_t __size, unsigned long __flags) __INTRODUCED_IN(36);
254*8d67ca89SAndroid Build Coastguard Worker #endif /* __BIONIC_AVAILABILITY_GUARD(36) */
255*8d67ca89SAndroid Build Coastguard Worker 
256*8d67ca89SAndroid Build Coastguard Worker 
257*8d67ca89SAndroid Build Coastguard Worker __END_DECLS
258