diff options
author | Oleg Nesterov <oleg@redhat.com> | 2015-09-09 18:39:29 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2015-09-10 16:29:01 -0400 |
commit | 1fcfd8db7f82fa1f533a6f0e4155614ff4144d56 (patch) | |
tree | 958b38ccd3bdd3bc97de154bf7bf322ff09637db /mm | |
parent | 7cbea8dc0127a95226c7722a738ac6534950ef67 (diff) |
mm, mpx: add "vm_flags_t vm_flags" arg to do_mmap_pgoff()
Add the additional "vm_flags_t vm_flags" argument to do_mmap_pgoff(),
rename it to do_mmap(), and re-introduce do_mmap_pgoff() as a simple
wrapper on top of do_mmap(). Perhaps we should update the callers of
do_mmap_pgoff() and kill it later.
This way mpx_mmap() can simply call do_mmap(vm_flags => VM_MPX) and do not
play with vm internals.
After this change mmap_region() has a single user outside of mmap.c,
arch/tile/mm/elf.c:arch_setup_additional_pages(). It would be nice to
change arch/tile/ and unexport mmap_region().
[kirill@shutemov.name: fix build]
[akpm@linux-foundation.org: coding-style fixes]
Signed-off-by: Oleg Nesterov <oleg@redhat.com>
Acked-by: Dave Hansen <dave.hansen@linux.intel.com>
Tested-by: Dave Hansen <dave.hansen@linux.intel.com>
Signed-off-by: Kirill A. Shutemov <kirill.shutemov@linux.intel.com>
Cc: "H. Peter Anvin" <hpa@zytor.com>
Cc: Andy Lutomirski <luto@amacapital.net>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: Minchan Kim <minchan@kernel.org>
Cc: Thomas Gleixner <tglx@linutronix.de>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'mm')
-rw-r--r-- | mm/mmap.c | 10 | ||||
-rw-r--r-- | mm/nommu.c | 19 |
2 files changed, 14 insertions, 15 deletions
@@ -1260,14 +1260,12 @@ static inline int mlock_future_check(struct mm_struct *mm, | |||
1260 | /* | 1260 | /* |
1261 | * The caller must hold down_write(¤t->mm->mmap_sem). | 1261 | * The caller must hold down_write(¤t->mm->mmap_sem). |
1262 | */ | 1262 | */ |
1263 | 1263 | unsigned long do_mmap(struct file *file, unsigned long addr, | |
1264 | unsigned long do_mmap_pgoff(struct file *file, unsigned long addr, | ||
1265 | unsigned long len, unsigned long prot, | 1264 | unsigned long len, unsigned long prot, |
1266 | unsigned long flags, unsigned long pgoff, | 1265 | unsigned long flags, vm_flags_t vm_flags, |
1267 | unsigned long *populate) | 1266 | unsigned long pgoff, unsigned long *populate) |
1268 | { | 1267 | { |
1269 | struct mm_struct *mm = current->mm; | 1268 | struct mm_struct *mm = current->mm; |
1270 | vm_flags_t vm_flags; | ||
1271 | 1269 | ||
1272 | *populate = 0; | 1270 | *populate = 0; |
1273 | 1271 | ||
@@ -1311,7 +1309,7 @@ unsigned long do_mmap_pgoff(struct file *file, unsigned long addr, | |||
1311 | * to. we assume access permissions have been handled by the open | 1309 | * to. we assume access permissions have been handled by the open |
1312 | * of the memory object, so we don't do any here. | 1310 | * of the memory object, so we don't do any here. |
1313 | */ | 1311 | */ |
1314 | vm_flags = calc_vm_prot_bits(prot) | calc_vm_flag_bits(flags) | | 1312 | vm_flags |= calc_vm_prot_bits(prot) | calc_vm_flag_bits(flags) | |
1315 | mm->def_flags | VM_MAYREAD | VM_MAYWRITE | VM_MAYEXEC; | 1313 | mm->def_flags | VM_MAYREAD | VM_MAYWRITE | VM_MAYEXEC; |
1316 | 1314 | ||
1317 | if (flags & MAP_LOCKED) | 1315 | if (flags & MAP_LOCKED) |
diff --git a/mm/nommu.c b/mm/nommu.c index 1cc0709fcaa5..ab14a2014dea 100644 --- a/mm/nommu.c +++ b/mm/nommu.c | |||
@@ -1233,18 +1233,19 @@ enomem: | |||
1233 | /* | 1233 | /* |
1234 | * handle mapping creation for uClinux | 1234 | * handle mapping creation for uClinux |
1235 | */ | 1235 | */ |
1236 | unsigned long do_mmap_pgoff(struct file *file, | 1236 | unsigned long do_mmap(struct file *file, |
1237 | unsigned long addr, | 1237 | unsigned long addr, |
1238 | unsigned long len, | 1238 | unsigned long len, |
1239 | unsigned long prot, | 1239 | unsigned long prot, |
1240 | unsigned long flags, | 1240 | unsigned long flags, |
1241 | unsigned long pgoff, | 1241 | vm_flags_t vm_flags, |
1242 | unsigned long *populate) | 1242 | unsigned long pgoff, |
1243 | unsigned long *populate) | ||
1243 | { | 1244 | { |
1244 | struct vm_area_struct *vma; | 1245 | struct vm_area_struct *vma; |
1245 | struct vm_region *region; | 1246 | struct vm_region *region; |
1246 | struct rb_node *rb; | 1247 | struct rb_node *rb; |
1247 | unsigned long capabilities, vm_flags, result; | 1248 | unsigned long capabilities, result; |
1248 | int ret; | 1249 | int ret; |
1249 | 1250 | ||
1250 | *populate = 0; | 1251 | *populate = 0; |
@@ -1262,7 +1263,7 @@ unsigned long do_mmap_pgoff(struct file *file, | |||
1262 | 1263 | ||
1263 | /* we've determined that we can make the mapping, now translate what we | 1264 | /* we've determined that we can make the mapping, now translate what we |
1264 | * now know into VMA flags */ | 1265 | * now know into VMA flags */ |
1265 | vm_flags = determine_vm_flags(file, prot, flags, capabilities); | 1266 | vm_flags |= determine_vm_flags(file, prot, flags, capabilities); |
1266 | 1267 | ||
1267 | /* we're going to need to record the mapping */ | 1268 | /* we're going to need to record the mapping */ |
1268 | region = kmem_cache_zalloc(vm_region_jar, GFP_KERNEL); | 1269 | region = kmem_cache_zalloc(vm_region_jar, GFP_KERNEL); |