source: svn/trunk/newcon3bcm2_21bu/toolchain/mipsel-linux-uclibc/include/bits/mman.h @ 2

Last change on this file since 2 was 2, checked in by jglee, 11 years ago

first commit

  • Property svn:executable set to *
File size: 3.2 KB
Line 
1/* Definitions for POSIX memory map interface.  Linux/MIPS version.
2   Copyright (C) 1997, 2000 Free Software Foundation, Inc.
3   This file is part of the GNU C Library.
4
5   The GNU C Library is free software; you can redistribute it and/or
6   modify it under the terms of the GNU Lesser General Public
7   License as published by the Free Software Foundation; either
8   version 2.1 of the License, or (at your option) any later version.
9
10   The GNU C Library is distributed in the hope that it will be useful,
11   but WITHOUT ANY WARRANTY; without even the implied warranty of
12   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
13   Lesser General Public License for more details.
14
15   You should have received a copy of the GNU Lesser General Public
16   License along with the GNU C Library; if not, write to the Free
17   Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
18   02111-1307 USA.  */
19
20#ifndef _SYS_MMAN_H
21# error "Never use <bits/mman.h> directly; include <sys/mman.h> instead."
22#endif
23
24/* The following definitions basically come from the kernel headers.
25   But the kernel header is not namespace clean.  */
26
27
28/* Protections are chosen from these bits, OR'd together.  The
29   implementation does not necessarily support PROT_EXEC or PROT_WRITE
30   without PROT_READ.  The only guarantees are that no writing will be
31   allowed without PROT_WRITE and no access will be allowed for PROT_NONE. */
32
33#define PROT_READ       0x1             /* Page can be read.  */
34#define PROT_WRITE      0x2             /* Page can be written.  */
35#define PROT_EXEC       0x4             /* Page can be executed.  */
36#define PROT_NONE       0x0             /* Page can not be accessed.  */
37
38/* Sharing types (must choose one and only one of these).  */
39#define MAP_SHARED      0x01            /* Share changes.  */
40#define MAP_PRIVATE     0x02            /* Changes are private.  */
41#ifdef __USE_MISC
42# define MAP_TYPE       0x0f            /* Mask for type of mapping.  */
43#endif
44
45/* Other flags.  */
46#define MAP_FIXED       0x10            /* Interpret addr exactly.  */
47#ifdef __USE_MISC
48# define MAP_FILE       0x00
49# define MAP_ANONYMOUS  0x0800          /* Don't use a file.  */
50# define MAP_ANON       MAP_ANONYMOUS
51# define MAP_RENAME     MAP_ANONYMOUS
52#endif
53
54/* These are Linux-specific.  */
55#ifdef __USE_MISC
56# define MAP_NORESERVE  0x0400          /* don't check for reservations */
57# define MAP_ANONYMOUS  0x0800          /* don't use a file */
58# define MAP_GROWSDOWN  0x1000          /* stack-like segment */
59# define MAP_DENYWRITE  0x2000          /* ETXTBSY */
60# define MAP_EXECUTABLE 0x4000          /* mark it as an executable */
61# define MAP_LOCKED     0x8000          /* pages are locked */
62#endif
63
64/* Flags to `msync'.  */
65#define MS_ASYNC        1               /* Sync memory asynchronously.  */
66#define MS_INVALIDATE   2               /* Invalidate the caches.  */
67#define MS_SYNC         4               /* Synchronous memory sync.  */
68
69/* Flags for `mlockall'.  */
70#define MCL_CURRENT     1               /* Lock all currently mapped pages.  */
71#define MCL_FUTURE      2               /* Lock all additions to address
72                                           space.  */
73
74/* Advice to `madvise'.  */
75#ifdef __USE_BSD
76#define MADV_NORMAL     0               /* default page-in behavior */
77#define MADV_RANDOM     1               /* page-in minimum required */
78#define MADV_SEQUENTIAL 2               /* read-ahead aggressively */
79#define MADV_WILLNEED   3               /* pre-fault pages */
80#define MADV_DONTNEED   4               /* discard these pages */
81#endif
82
83/* Flags for `mremap'.  */
84#ifdef __USE_GNU
85# define MREMAP_MAYMOVE 1
86#endif
Note: See TracBrowser for help on using the repository browser.