summaryrefslogtreecommitdiffstats
path: root/sys/powerpc/aim
diff options
context:
space:
mode:
authornwhitehorn <nwhitehorn@FreeBSD.org>2012-03-15 22:50:48 +0000
committernwhitehorn <nwhitehorn@FreeBSD.org>2012-03-15 22:50:48 +0000
commit9a147d4aa9b88d194fb4b58c42c7ec7c140b44a8 (patch)
tree211bce45d1709de159b689df259cec4f5ebf0894 /sys/powerpc/aim
parent3b858f15a9ba8059e55c7e2b2d560cdb37dff77f (diff)
downloadFreeBSD-src-9a147d4aa9b88d194fb4b58c42c7ec7c140b44a8.zip
FreeBSD-src-9a147d4aa9b88d194fb4b58c42c7ec7c140b44a8.tar.gz
Implement pmap_remove_pages(). This will be added later to the 32-bit MMU
module. Suggested by: alc
Diffstat (limited to 'sys/powerpc/aim')
-rw-r--r--sys/powerpc/aim/mmu_oea64.c18
1 files changed, 18 insertions, 0 deletions
diff --git a/sys/powerpc/aim/mmu_oea64.c b/sys/powerpc/aim/mmu_oea64.c
index c66e26b..36ff645 100644
--- a/sys/powerpc/aim/mmu_oea64.c
+++ b/sys/powerpc/aim/mmu_oea64.c
@@ -308,6 +308,7 @@ void moea64_qenter(mmu_t, vm_offset_t, vm_page_t *, int);
void moea64_qremove(mmu_t, vm_offset_t, int);
void moea64_release(mmu_t, pmap_t);
void moea64_remove(mmu_t, pmap_t, vm_offset_t, vm_offset_t);
+void moea64_remove_pages(mmu_t, pmap_t);
void moea64_remove_all(mmu_t, vm_page_t);
void moea64_remove_write(mmu_t, vm_page_t);
void moea64_zero_page(mmu_t, vm_page_t);
@@ -350,6 +351,7 @@ static mmu_method_t moea64_methods[] = {
MMUMETHOD(mmu_qremove, moea64_qremove),
MMUMETHOD(mmu_release, moea64_release),
MMUMETHOD(mmu_remove, moea64_remove),
+ MMUMETHOD(mmu_remove_pages, moea64_remove_pages),
MMUMETHOD(mmu_remove_all, moea64_remove_all),
MMUMETHOD(mmu_remove_write, moea64_remove_write),
MMUMETHOD(mmu_sync_icache, moea64_sync_icache),
@@ -2046,6 +2048,22 @@ moea64_release(mmu_t mmu, pmap_t pmap)
}
/*
+ * Remove all pages mapped by the specified pmap
+ */
+void
+moea64_remove_pages(mmu_t mmu, pmap_t pm)
+{
+ struct pvo_entry *pvo, *tpvo;
+
+ vm_page_lock_queues();
+ PMAP_LOCK(pm);
+ LIST_FOREACH_SAFE(pvo, &pm->pmap_pvo, pvo_plink, tpvo)
+ moea64_pvo_remove(mmu, pvo);
+ vm_page_unlock_queues();
+ PMAP_UNLOCK(pm);
+}
+
+/*
* Remove the given range of addresses from the specified map.
*/
void
OpenPOWER on IntegriCloud