|
@@ -1479,11 +1479,9 @@ unsigned long mmap_region(struct file *file, unsigned long addr,
|
|
|
{
|
|
|
struct mm_struct *mm = current->mm;
|
|
|
struct vm_area_struct *vma, *prev;
|
|
|
- int correct_wcount = 0;
|
|
|
int error;
|
|
|
struct rb_node **rb_link, *rb_parent;
|
|
|
unsigned long charged = 0;
|
|
|
- struct inode *inode = file ? file_inode(file) : NULL;
|
|
|
|
|
|
/* Check against address space limit. */
|
|
|
if (!may_expand_vm(mm, len >> PAGE_SHIFT)) {
|
|
@@ -1552,7 +1550,6 @@ munmap_back:
|
|
|
error = deny_write_access(file);
|
|
|
if (error)
|
|
|
goto free_vma;
|
|
|
- correct_wcount = 1;
|
|
|
}
|
|
|
vma->vm_file = get_file(file);
|
|
|
error = file->f_op->mmap(file, vma);
|
|
@@ -1593,11 +1590,10 @@ munmap_back:
|
|
|
}
|
|
|
|
|
|
vma_link(mm, vma, prev, rb_link, rb_parent);
|
|
|
- file = vma->vm_file;
|
|
|
-
|
|
|
/* Once vma denies write, undo our temporary denial count */
|
|
|
- if (correct_wcount)
|
|
|
- atomic_inc(&inode->i_writecount);
|
|
|
+ if (vm_flags & VM_DENYWRITE)
|
|
|
+ allow_write_access(file);
|
|
|
+ file = vma->vm_file;
|
|
|
out:
|
|
|
perf_event_mmap(vma);
|
|
|
|
|
@@ -1616,8 +1612,8 @@ out:
|
|
|
return addr;
|
|
|
|
|
|
unmap_and_free_vma:
|
|
|
- if (correct_wcount)
|
|
|
- atomic_inc(&inode->i_writecount);
|
|
|
+ if (vm_flags & VM_DENYWRITE)
|
|
|
+ allow_write_access(file);
|
|
|
vma->vm_file = NULL;
|
|
|
fput(file);
|
|
|
|