1/* $Id: mman.h,v 1.1.1.1 2007/08/03 18:53:36 Exp $ */
2#ifndef __SPARC64_MMAN_H__
3#define __SPARC64_MMAN_H__
4
5#include <asm-generic/mman.h>
6
7/* SunOS'ified... */
8
9#define MAP_RENAME      MAP_ANONYMOUS   /* In SunOS terminology */
10#define MAP_NORESERVE   0x40            /* don't reserve swap pages */
11#define MAP_INHERIT     0x80            /* SunOS doesn't do this, but... */
12#define MAP_LOCKED      0x100           /* lock the mapping */
13#define _MAP_NEW        0x80000000      /* Binary compatibility is fun... */
14
15#define MAP_GROWSDOWN	0x0200		/* stack-like segment */
16#define MAP_DENYWRITE	0x0800		/* ETXTBSY */
17#define MAP_EXECUTABLE	0x1000		/* mark it as an executable */
18
19#define MCL_CURRENT     0x2000          /* lock all currently mapped pages */
20#define MCL_FUTURE      0x4000          /* lock all additions to address space */
21
22#define MAP_POPULATE	0x8000		/* populate (prefault) pagetables */
23#define MAP_NONBLOCK	0x10000		/* do not block on IO */
24
25
26/* SunOS sys_mctl() stuff... */
27#define MC_SYNC         1  /* Sync pages in memory with storage (usu. a file) */
28#define MC_LOCK         2  /* Lock pages into core ram, do not allow swapping of them */
29#define MC_UNLOCK       3  /* Unlock pages locked via previous mctl() with MC_LOCK arg */
30#define MC_LOCKAS       5  /* Lock an entire address space of the calling process */
31#define MC_UNLOCKAS     6  /* Unlock entire address space of calling process */
32
33#define MADV_FREE	0x5		/* (Solaris) contents can be freed */
34
35#ifdef __KERNEL__
36#ifndef __ASSEMBLY__
37#define arch_mmap_check	sparc64_mmap_check
38int sparc64_mmap_check(unsigned long addr, unsigned long len,
39		unsigned long flags);
40#endif
41#endif
42
43#endif /* __SPARC64_MMAN_H__ */
44