|
@@ -1729,19 +1729,17 @@ unsigned long mmap_region(struct file *file, unsigned long addr,
|
|
* specific mapper. the address has already been validated, but
|
|
* specific mapper. the address has already been validated, but
|
|
* not unmapped, but the maps are removed from the list.
|
|
* not unmapped, but the maps are removed from the list.
|
|
*/
|
|
*/
|
|
- vma = vm_area_alloc();
|
|
|
|
|
|
+ vma = vm_area_alloc(mm);
|
|
if (!vma) {
|
|
if (!vma) {
|
|
error = -ENOMEM;
|
|
error = -ENOMEM;
|
|
goto unacct_error;
|
|
goto unacct_error;
|
|
}
|
|
}
|
|
|
|
|
|
- vma->vm_mm = mm;
|
|
|
|
vma->vm_start = addr;
|
|
vma->vm_start = addr;
|
|
vma->vm_end = addr + len;
|
|
vma->vm_end = addr + len;
|
|
vma->vm_flags = vm_flags;
|
|
vma->vm_flags = vm_flags;
|
|
vma->vm_page_prot = vm_get_page_prot(vm_flags);
|
|
vma->vm_page_prot = vm_get_page_prot(vm_flags);
|
|
vma->vm_pgoff = pgoff;
|
|
vma->vm_pgoff = pgoff;
|
|
- INIT_LIST_HEAD(&vma->anon_vma_chain);
|
|
|
|
|
|
|
|
if (file) {
|
|
if (file) {
|
|
if (vm_flags & VM_DENYWRITE) {
|
|
if (vm_flags & VM_DENYWRITE) {
|
|
@@ -2979,14 +2977,12 @@ static int do_brk_flags(unsigned long addr, unsigned long len, unsigned long fla
|
|
/*
|
|
/*
|
|
* create a vma struct for an anonymous mapping
|
|
* create a vma struct for an anonymous mapping
|
|
*/
|
|
*/
|
|
- vma = vm_area_alloc();
|
|
|
|
|
|
+ vma = vm_area_alloc(mm);
|
|
if (!vma) {
|
|
if (!vma) {
|
|
vm_unacct_memory(len >> PAGE_SHIFT);
|
|
vm_unacct_memory(len >> PAGE_SHIFT);
|
|
return -ENOMEM;
|
|
return -ENOMEM;
|
|
}
|
|
}
|
|
|
|
|
|
- INIT_LIST_HEAD(&vma->anon_vma_chain);
|
|
|
|
- vma->vm_mm = mm;
|
|
|
|
vma->vm_start = addr;
|
|
vma->vm_start = addr;
|
|
vma->vm_end = addr + len;
|
|
vma->vm_end = addr + len;
|
|
vma->vm_pgoff = pgoff;
|
|
vma->vm_pgoff = pgoff;
|
|
@@ -3343,12 +3339,10 @@ static struct vm_area_struct *__install_special_mapping(
|
|
int ret;
|
|
int ret;
|
|
struct vm_area_struct *vma;
|
|
struct vm_area_struct *vma;
|
|
|
|
|
|
- vma = vm_area_alloc();
|
|
|
|
|
|
+ vma = vm_area_alloc(mm);
|
|
if (unlikely(vma == NULL))
|
|
if (unlikely(vma == NULL))
|
|
return ERR_PTR(-ENOMEM);
|
|
return ERR_PTR(-ENOMEM);
|
|
|
|
|
|
- INIT_LIST_HEAD(&vma->anon_vma_chain);
|
|
|
|
- vma->vm_mm = mm;
|
|
|
|
vma->vm_start = addr;
|
|
vma->vm_start = addr;
|
|
vma->vm_end = addr + len;
|
|
vma->vm_end = addr + len;
|
|
|
|
|