2005-04-17 02:20:36 +04:00
/* $Id: mman.h,v 1.2 2000/03/15 02:44:26 davem Exp $ */
# ifndef __SPARC64_MMAN_H__
# define __SPARC64_MMAN_H__
2006-02-16 02:17:39 +03:00
# include <asm-generic/mman.h>
2005-04-17 02:20:36 +04:00
2006-02-16 02:17:39 +03:00
/* SunOS'ified... */
2005-04-17 02:20:36 +04:00
# define MAP_RENAME MAP_ANONYMOUS /* In SunOS terminology */
# define MAP_NORESERVE 0x40 /* don't reserve swap pages */
# define MAP_INHERIT 0x80 /* SunOS doesn't do this, but... */
# define MAP_LOCKED 0x100 /* lock the mapping */
# define _MAP_NEW 0x80000000 /* Binary compatibility is fun... */
# define MAP_GROWSDOWN 0x0200 /* stack-like segment */
# define MAP_DENYWRITE 0x0800 /* ETXTBSY */
# define MAP_EXECUTABLE 0x1000 /* mark it as an executable */
# define MCL_CURRENT 0x2000 /* lock all currently mapped pages */
# define MCL_FUTURE 0x4000 /* lock all additions to address space */
# define MAP_POPULATE 0x8000 /* populate (prefault) pagetables */
# define MAP_NONBLOCK 0x10000 /* do not block on IO */
/* XXX Need to add flags to SunOS's mctl, mlockall, and madvise system
* XXX calls .
*/
/* SunOS sys_mctl() stuff... */
# define MC_SYNC 1 /* Sync pages in memory with storage (usu. a file) */
# define MC_LOCK 2 /* Lock pages into core ram, do not allow swapping of them */
# define MC_UNLOCK 3 /* Unlock pages locked via previous mctl() with MC_LOCK arg */
# define MC_LOCKAS 5 /* Lock an entire address space of the calling process */
# define MC_UNLOCKAS 6 /* Unlock entire address space of calling process */
# define MADV_FREE 0x5 /* (Solaris) contents can be freed */
2006-09-07 14:17:04 +04:00
# ifdef __KERNEL__
# ifndef __ASSEMBLY__
# define arch_mmap_check sparc64_mmap_check
int sparc64_mmap_check ( unsigned long addr , unsigned long len ,
unsigned long flags ) ;
# endif
# endif
2005-04-17 02:20:36 +04:00
# endif /* __SPARC64_MMAN_H__ */