summaryrefslogtreecommitdiff
path: root/sys
diff options
context:
space:
mode:
Diffstat (limited to 'sys')
-rw-r--r--sys/arch/powerpc/powerpc/pmap.c34
1 files changed, 17 insertions, 17 deletions
diff --git a/sys/arch/powerpc/powerpc/pmap.c b/sys/arch/powerpc/powerpc/pmap.c
index 2e61469ae1b..91de55a35eb 100644
--- a/sys/arch/powerpc/powerpc/pmap.c
+++ b/sys/arch/powerpc/powerpc/pmap.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: pmap.c,v 1.93 2005/10/09 14:01:11 drahn Exp $ */
+/* $OpenBSD: pmap.c,v 1.94 2005/11/13 03:56:26 brad Exp $ */
/*
* Copyright (c) 2001, 2002 Dale Rahn.
@@ -255,7 +255,7 @@ pmap_vp_remove(pmap_t pm, vaddr_t va)
* This code should track allocations of vp table allocations
* so they can be freed efficiently.
*
- * Should this be called under splimp?
+ * Should this be called under splvm?
*/
void
pmap_vp_enter(pmap_t pm, vaddr_t va, struct pte_desc *pted)
@@ -268,7 +268,7 @@ pmap_vp_enter(pmap_t pm, vaddr_t va, struct pte_desc *pted)
vp1 = pm->pm_vp[VP_SR(va)];
if (vp1 == NULL) {
- s = splimp();
+ s = splvm();
vp1 = pool_get(&pmap_vp_pool, PR_NOWAIT);
splx(s);
bzero(vp1, sizeof (struct pmapvp));
@@ -277,7 +277,7 @@ pmap_vp_enter(pmap_t pm, vaddr_t va, struct pte_desc *pted)
vp2 = vp1->vp[VP_IDX1(va)];
if (vp2 == NULL) {
- s = splimp();
+ s = splvm();
vp2 = pool_get(&pmap_vp_pool, PR_NOWAIT);
splx(s);
bzero(vp2, sizeof (struct pmapvp));
@@ -474,7 +474,7 @@ pmap_enter(pm, va, pa, prot, flags)
/* MP - Acquire lock for this pmap */
- s = splimp();
+ s = splvm();
pted = pmap_vp_lookup(pm, va);
if (pted && PTED_VALID(pted)) {
pmap_remove_pg(pm, va);
@@ -638,7 +638,7 @@ pmap_remove_pg(pmap_t pm, vaddr_t va)
* so that we know the mapping information is either valid,
* or that the mapping is not present in the hash table.
*/
- s = splimp();
+ s = splvm();
if (pm == pmap_kernel()) {
pted = pmap_vp_lookup(pm, va);
if (pted == NULL || !PTED_VALID(pted)) {
@@ -699,7 +699,7 @@ _pmap_kenter_pa(vaddr_t va, paddr_t pa, vm_prot_t prot, int flags, int cache)
pm = pmap_kernel();
/* MP - lock pmap. */
- s = splimp();
+ s = splvm();
pted = pmap_vp_lookup(pm, va);
if (pted && PTED_VALID(pted))
@@ -786,7 +786,7 @@ pmap_kremove_pg(vaddr_t va)
if (!PTED_VALID(pted))
return; /* not mapped */
- s = splimp();
+ s = splvm();
pm->pm_stats.resident_count--;
@@ -1019,7 +1019,7 @@ pteclrbits(paddr_t pa, u_int bit, u_int clear)
* then reread the attribute cache.
*/
/* need lock for this pv */
- s = splimp();
+ s = splvm();
LIST_FOREACH(pted, pvh, pted_pv_list) {
vaddr_t va = pted->pted_va & PAGE_MASK;
@@ -1189,7 +1189,7 @@ again:
tbloff = try % (8 * sizeof usedsr[0]);
if ((usedsr[tblidx] & (1 << tbloff)) == 0) {
/* pmap create lock? */
- s = splimp();
+ s = splvm();
if ((usedsr[tblidx] & (1 << tbloff)) == 1) {
/* entry was stolen out from under us, retry */
splx(s); /* pmap create unlock */
@@ -1217,7 +1217,7 @@ pmap_create()
pmap_t pmap;
int s;
- s = splimp();
+ s = splvm();
pmap = pool_get(&pmap_pmap_pool, PR_WAITOK);
splx(s);
pmap_pinit(pmap);
@@ -1255,7 +1255,7 @@ pmap_destroy(pmap_t pm)
* reference count is zero, free pmap resources and free pmap.
*/
pmap_release(pm);
- s = splimp();
+ s = splvm();
pool_put(&pmap_pmap_pool, pm);
splx(s);
}
@@ -1276,7 +1276,7 @@ pmap_release(pmap_t pm)
tbloff = i % (8 * sizeof usedsr[0]);
/* LOCK? */
- s = splimp();
+ s = splvm();
usedsr[tblidx] &= ~(1 << tbloff);
splx(s);
}
@@ -1299,12 +1299,12 @@ pmap_vp_destroy(pmap_t pm)
if (vp2 == NULL)
continue;
- s = splimp();
+ s = splvm();
pool_put(&pmap_vp_pool, vp2);
splx(s);
}
pm->pm_vp[i] = NULL;
- s = splimp();
+ s = splvm();
pool_put(&pmap_vp_pool, vp1);
splx(s);
}
@@ -2013,7 +2013,7 @@ pmap_page_protect(struct vm_page *pg, vm_prot_t prot)
struct pted_pv_head *pvh;
/* need to lock for this pv */
- s = splimp();
+ s = splvm();
pvh = pmap_find_pvh(pa);
/* nothing to do if not a managed page */
@@ -2045,7 +2045,7 @@ pmap_protect(pmap_t pm, vaddr_t sva, vaddr_t eva, vm_prot_t prot)
{
int s;
if (prot & VM_PROT_READ) {
- s = splimp();
+ s = splvm();
if (ppc_proc_is_64b) {
while (sva < eva) {
pmap_page_ro64(pm, sva);