patch-2.4.3 linux/mm/mremap.c
Next file: linux/mm/page_alloc.c
Previous file: linux/mm/mprotect.c
Back to the patch index
Back to the overall index
- Lines: 51
- Date:
Mon Mar 19 17:17:43 2001
- Orig file:
v2.4.2/linux/mm/mremap.c
- Orig date:
Fri Dec 29 14:07:24 2000
diff -u --recursive --new-file v2.4.2/linux/mm/mremap.c linux/mm/mremap.c
@@ -51,9 +51,9 @@
pmd_t * pmd;
pte_t * pte = NULL;
- pmd = pmd_alloc(pgd_offset(mm, addr), addr);
+ pmd = pmd_alloc(mm, pgd_offset(mm, addr), addr);
if (pmd)
- pte = pte_alloc(pmd, addr);
+ pte = pte_alloc(mm, pmd, addr);
return pte;
}
@@ -62,7 +62,6 @@
int error = 0;
pte_t pte;
- spin_lock(&mm->page_table_lock);
if (!pte_none(*src)) {
pte = ptep_get_and_clear(src);
if (!dst) {
@@ -72,7 +71,6 @@
}
set_pte(dst, pte);
}
- spin_unlock(&mm->page_table_lock);
return error;
}
@@ -81,9 +79,11 @@
int error = 0;
pte_t * src;
+ spin_lock(&mm->page_table_lock);
src = get_one_pte(mm, old_addr);
if (src)
error = copy_one_pte(mm, src, alloc_one_pte(mm, new_addr));
+ spin_unlock(&mm->page_table_lock);
return error;
}
@@ -292,8 +292,8 @@
{
unsigned long ret;
- down(¤t->mm->mmap_sem);
+ down_write(¤t->mm->mmap_sem);
ret = do_mremap(addr, old_len, new_len, flags, new_addr);
- up(¤t->mm->mmap_sem);
+ up_write(¤t->mm->mmap_sem);
return ret;
}
FUNET's LINUX-ADM group, linux-adm@nic.funet.fi
TCL-scripts by Sam Shen (who was at: slshen@lbl.gov)