Changeset View
Changeset View
Standalone View
Standalone View
sys/powerpc/aim/mmu_oea.c
Show First 20 Lines • Show All 1,269 Lines • ▼ Show 20 Lines | |||||
retry: | retry: | ||||
pvo = moea_pvo_find_va(pmap, va & ~ADDR_POFF, NULL); | pvo = moea_pvo_find_va(pmap, va & ~ADDR_POFF, NULL); | ||||
if (pvo != NULL && (pvo->pvo_pte.pte.pte_hi & PTE_VALID) && | if (pvo != NULL && (pvo->pvo_pte.pte.pte_hi & PTE_VALID) && | ||||
((pvo->pvo_pte.pte.pte_lo & PTE_PP) == PTE_RW || | ((pvo->pvo_pte.pte.pte_lo & PTE_PP) == PTE_RW || | ||||
(prot & VM_PROT_WRITE) == 0)) { | (prot & VM_PROT_WRITE) == 0)) { | ||||
if (vm_page_pa_tryrelock(pmap, pvo->pvo_pte.pte.pte_lo & PTE_RPGN, &pa)) | if (vm_page_pa_tryrelock(pmap, pvo->pvo_pte.pte.pte_lo & PTE_RPGN, &pa)) | ||||
goto retry; | goto retry; | ||||
m = PHYS_TO_VM_PAGE(pvo->pvo_pte.pte.pte_lo & PTE_RPGN); | m = PHYS_TO_VM_PAGE(pvo->pvo_pte.pte.pte_lo & PTE_RPGN); | ||||
vm_page_hold(m); | vm_page_wire(m); | ||||
} | } | ||||
PA_UNLOCK_COND(pa); | PA_UNLOCK_COND(pa); | ||||
PMAP_UNLOCK(pmap); | PMAP_UNLOCK(pmap); | ||||
return (m); | return (m); | ||||
} | } | ||||
void | void | ||||
moea_init(mmu_t mmu) | moea_init(mmu_t mmu) | ||||
▲ Show 20 Lines • Show All 1,494 Lines • Show Last 20 Lines |