diff options
author | Dave Kleikamp <shaggy@linux.vnet.ibm.com> | 2008-07-07 10:28:51 -0400 |
---|---|---|
committer | Benjamin Herrenschmidt <benh@kernel.crashing.org> | 2008-07-09 02:30:45 -0400 |
commit | b845f313d78e4e259ec449909e3bbadf77b53a6d (patch) | |
tree | 03239e77dbc43f627ce112963736c8b4c53117e6 /mm | |
parent | e5093ff05d36c64e8f36a9ddb26358256dc133ea (diff) |
mm: Allow architectures to define additional protection bits
This patch allows architectures to define functions to deal with
additional protections bits for mmap() and mprotect().
arch_calc_vm_prot_bits() maps additonal protection bits to vm_flags
arch_vm_get_page_prot() maps additional vm_flags to the vma's vm_page_prot
arch_validate_prot() checks for valid values of the protection bits
Note: vm_get_page_prot() is now pretty ugly, but the generated code
should be identical for architectures that don't define additional
protection bits.
Signed-off-by: Dave Kleikamp <shaggy@linux.vnet.ibm.com>
Acked-by: Andrew Morton <akpm@linux-foundation.org>
Acked-by: Hugh Dickins <hugh@veritas.com>
Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Diffstat (limited to 'mm')
-rw-r--r-- | mm/mmap.c | 5 | ||||
-rw-r--r-- | mm/mprotect.c | 2 |
2 files changed, 4 insertions, 3 deletions
@@ -72,8 +72,9 @@ pgprot_t protection_map[16] = { | |||
72 | 72 | ||
73 | pgprot_t vm_get_page_prot(unsigned long vm_flags) | 73 | pgprot_t vm_get_page_prot(unsigned long vm_flags) |
74 | { | 74 | { |
75 | return protection_map[vm_flags & | 75 | return __pgprot(pgprot_val(protection_map[vm_flags & |
76 | (VM_READ|VM_WRITE|VM_EXEC|VM_SHARED)]; | 76 | (VM_READ|VM_WRITE|VM_EXEC|VM_SHARED)]) | |
77 | pgprot_val(arch_vm_get_page_prot(vm_flags))); | ||
77 | } | 78 | } |
78 | EXPORT_SYMBOL(vm_get_page_prot); | 79 | EXPORT_SYMBOL(vm_get_page_prot); |
79 | 80 | ||
diff --git a/mm/mprotect.c b/mm/mprotect.c index a5bf31c27375..ecfaa5844b5f 100644 --- a/mm/mprotect.c +++ b/mm/mprotect.c | |||
@@ -239,7 +239,7 @@ sys_mprotect(unsigned long start, size_t len, unsigned long prot) | |||
239 | end = start + len; | 239 | end = start + len; |
240 | if (end <= start) | 240 | if (end <= start) |
241 | return -ENOMEM; | 241 | return -ENOMEM; |
242 | if (prot & ~(PROT_READ | PROT_WRITE | PROT_EXEC | PROT_SEM)) | 242 | if (!arch_validate_prot(prot)) |
243 | return -EINVAL; | 243 | return -EINVAL; |
244 | 244 | ||
245 | reqprot = prot; | 245 | reqprot = prot; |