mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 b0f205c2a3
			
		
	
	
		b0f205c2a3
		
	
	
	
	
		
			
			The previous patch introduced a flag that specified pages in a VMA should be placed on the unevictable LRU, but they should not be made present when the area is created. This patch adds the ability to set this state via the new mlock system calls. We add MLOCK_ONFAULT for mlock2 and MCL_ONFAULT for mlockall. MLOCK_ONFAULT will set the VM_LOCKONFAULT modifier for VM_LOCKED. MCL_ONFAULT should be used as a modifier to the two other mlockall flags. When used with MCL_CURRENT, all current mappings will be marked with VM_LOCKED | VM_LOCKONFAULT. When used with MCL_FUTURE, the mm->def_flags will be marked with VM_LOCKED | VM_LOCKONFAULT. When used with both MCL_CURRENT and MCL_FUTURE, all current mappings and mm->def_flags will be marked with VM_LOCKED | VM_LOCKONFAULT. Prior to this patch, mlockall() will unconditionally clear the mm->def_flags any time it is called without MCL_FUTURE. This behavior is maintained after adding MCL_ONFAULT. If a call to mlockall(MCL_FUTURE) is followed by mlockall(MCL_CURRENT), the mm->def_flags will be cleared and new VMAs will be unlocked. This remains true with or without MCL_ONFAULT in either mlockall() invocation. munlock() will unconditionally clear both vma flags. munlockall() unconditionally clears for VMA flags on all VMAs and in the mm->def_flags field. Signed-off-by: Eric B Munson <emunson@akamai.com> Acked-by: Michal Hocko <mhocko@suse.com> Acked-by: Vlastimil Babka <vbabka@suse.cz> Cc: Jonathan Corbet <corbet@lwn.net> Cc: Catalin Marinas <catalin.marinas@arm.com> Cc: Geert Uytterhoeven <geert@linux-m68k.org> Cc: Guenter Roeck <linux@roeck-us.net> Cc: Heiko Carstens <heiko.carstens@de.ibm.com> Cc: Kirill A. Shutemov <kirill.shutemov@linux.intel.com> Cc: Michael Kerrisk <mtk.manpages@gmail.com> Cc: Ralf Baechle <ralf@linux-mips.org> Cc: Shuah Khan <shuahkh@osg.samsung.com> Cc: Stephen Rothwell <sfr@canb.auug.org.au> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
		
			
				
	
	
		
			29 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			29 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #ifndef _UAPI__SPARC_MMAN_H__
 | |
| #define _UAPI__SPARC_MMAN_H__
 | |
| 
 | |
| #include <asm-generic/mman-common.h>
 | |
| 
 | |
| /* SunOS'ified... */
 | |
| 
 | |
| #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 MCL_ONFAULT	0x8000		/* lock all pages that are faulted in */
 | |
| 
 | |
| #define MAP_POPULATE	0x8000		/* populate (prefault) pagetables */
 | |
| #define MAP_NONBLOCK	0x10000		/* do not block on IO */
 | |
| #define MAP_STACK	0x20000		/* give out an address that is best suited for process/thread stacks */
 | |
| #define MAP_HUGETLB	0x40000		/* create a huge page mapping */
 | |
| 
 | |
| 
 | |
| #endif /* _UAPI__SPARC_MMAN_H__ */
 |