When setup vm_page_prot, some code use 0x7 instead of (VM_READ|VM_WRITE|VM_EXEC). It does works well, but it will be better if we use the VM_READ/WRITE/EXEC MACRO :-) This patch uses (VM_READ|VM_WRITE|VM_EXEC) to replace 0x7 in vm_page_prot setup. Signed-Off-By: Coly Li <[email protected]> diff --git a/arch/ia64/mm/init.c b/arch/ia64/mm/init.c index c14abef..864a9f3 100644 --- a/arch/ia64/mm/init.c +++ b/arch/ia64/mm/init.c @@ -130,7 +130,8 @@ ia64_init_addr_space (void) vma->vm_mm = current->mm; vma->vm_start = current->thread.rbs_bot & PAGE_MASK; vma->vm_end = vma->vm_start + PAGE_SIZE; - vma->vm_page_prot = protection_map[VM_DATA_DEFAULT_FLAGS & 0x7]; + vma->vm_page_prot = protection_map[VM_DATA_DEFAULT_FLAGS & + (VM_READ|VM_WRITE|VM_EXEC)]; vma->vm_flags = VM_DATA_DEFAULT_FLAGS|VM_GROWSUP|VM_ACCOUNT; down_write(¤t->mm->mmap_sem); if (insert_vm_struct(current->mm, vma)) { diff --git a/fs/exec.c b/fs/exec.c index c21a8cc..cca277f 100644 --- a/fs/exec.c +++ b/fs/exec.c @@ -261,7 +261,8 @@ static int __bprm_mm_init(struct linux_binprm *bprm) vma->vm_start = vma->vm_end - PAGE_SIZE; vma->vm_flags = VM_STACK_FLAGS; - vma->vm_page_prot = protection_map[vma->vm_flags & 0x7]; + vma->vm_page_prot = protection_map[vma->vm_flags & + (VM_READ|VM_WRITE|VM_EXEC)]; err = insert_vm_struct(mm, vma); if (err) { up_write(&mm->mmap_sem); diff --git a/mm/mmap.c b/mm/mmap.c index 0d40e66..18d33f2 100644 --- a/mm/mmap.c +++ b/mm/mmap.c @@ -2210,7 +2210,8 @@ int install_special_mapping(struct mm_struct *mm, vma->vm_end = addr + len; vma->vm_flags = vm_flags | mm->def_flags; - vma->vm_page_prot = protection_map[vma->vm_flags & 7]; + vma->vm_page_prot = protection_map[vma->vm_flags & + (VM_READ|VM_WRITE|VM_EXEC)]; vma->vm_ops = &special_mapping_vmops; vma->vm_private_data = pages;
Attachment:
signature.asc
Description: PGP signature
Attachment:
signature.asc
Description: OpenPGP digital signature
- Follow-Ups:
- Re: [PATCH] use VM_READ/WRITE/EXEC to set vm_page_prot
- From: Hugh Dickins <[email protected]>
- Re: [PATCH] use VM_READ/WRITE/EXEC to set vm_page_prot
- Prev by Date: Re: [ANNOUNCE] GIT 1.5.3
- Next by Date: Linux, 2.6.23-rc5, powersaving degradation, (time spend in C0 goes up after a while)
- Previous by thread: GPL weasels and the atheros stink
- Next by thread: Re: [PATCH] use VM_READ/WRITE/EXEC to set vm_page_prot
- Index(es):