summaryrefslogtreecommitdiffstats
path: root/sys/powerpc
diff options
context:
space:
mode:
authoralc <alc@FreeBSD.org>2003-10-03 22:46:53 +0000
committeralc <alc@FreeBSD.org>2003-10-03 22:46:53 +0000
commitb1691aebe4218b5dedfc2dac5620bc1e02226f72 (patch)
tree10ac1c9d9b930d5a0606d41e87f29b5d53946de0 /sys/powerpc
parent678d7d93783f9161ce47727c8e23987c819d7ab6 (diff)
downloadFreeBSD-src-b1691aebe4218b5dedfc2dac5620bc1e02226f72.zip
FreeBSD-src-b1691aebe4218b5dedfc2dac5620bc1e02226f72.tar.gz
Migrate pmap_prefault() into the machine-independent virtual memory layer.
A small helper function pmap_is_prefaultable() is added. This function encapsulate the few lines of pmap_prefault() that actually vary from machine to machine. Note: pmap_is_prefaultable() and pmap_mincore() have much in common. Going forward, it's worth considering their merger.
Diffstat (limited to 'sys/powerpc')
-rw-r--r--sys/powerpc/aim/mmu_oea.c21
-rw-r--r--sys/powerpc/powerpc/mmu_oea.c21
-rw-r--r--sys/powerpc/powerpc/pmap.c21
3 files changed, 39 insertions, 24 deletions
diff --git a/sys/powerpc/aim/mmu_oea.c b/sys/powerpc/aim/mmu_oea.c
index 1c789f7..30ce2f8 100644
--- a/sys/powerpc/aim/mmu_oea.c
+++ b/sys/powerpc/aim/mmu_oea.c
@@ -1117,6 +1117,19 @@ pmap_is_modified(vm_page_t m)
return (pmap_query_bit(m, PTE_CHG));
}
+/*
+ * pmap_is_prefaultable:
+ *
+ * Return whether or not the specified virtual address is elgible
+ * for prefault.
+ */
+boolean_t
+pmap_is_prefaultable(pmap_t pmap, vm_offset_t addr)
+{
+
+ return (FALSE);
+}
+
void
pmap_clear_reference(vm_page_t m)
{
@@ -1424,14 +1437,6 @@ pmap_pinit2(pmap_t pmap)
/* XXX: Remove this stub when no longer called */
}
-void
-pmap_prefault(pmap_t pm, vm_offset_t va, vm_map_entry_t entry)
-{
- KASSERT(pm == &curproc->p_vmspace->vm_pmap || pm == kernel_pmap,
- ("pmap_prefault: non current pmap"));
- /* XXX */
-}
-
/*
* Set the physical protection on the specified range of this map as requested.
*/
diff --git a/sys/powerpc/powerpc/mmu_oea.c b/sys/powerpc/powerpc/mmu_oea.c
index 1c789f7..30ce2f8 100644
--- a/sys/powerpc/powerpc/mmu_oea.c
+++ b/sys/powerpc/powerpc/mmu_oea.c
@@ -1117,6 +1117,19 @@ pmap_is_modified(vm_page_t m)
return (pmap_query_bit(m, PTE_CHG));
}
+/*
+ * pmap_is_prefaultable:
+ *
+ * Return whether or not the specified virtual address is elgible
+ * for prefault.
+ */
+boolean_t
+pmap_is_prefaultable(pmap_t pmap, vm_offset_t addr)
+{
+
+ return (FALSE);
+}
+
void
pmap_clear_reference(vm_page_t m)
{
@@ -1424,14 +1437,6 @@ pmap_pinit2(pmap_t pmap)
/* XXX: Remove this stub when no longer called */
}
-void
-pmap_prefault(pmap_t pm, vm_offset_t va, vm_map_entry_t entry)
-{
- KASSERT(pm == &curproc->p_vmspace->vm_pmap || pm == kernel_pmap,
- ("pmap_prefault: non current pmap"));
- /* XXX */
-}
-
/*
* Set the physical protection on the specified range of this map as requested.
*/
diff --git a/sys/powerpc/powerpc/pmap.c b/sys/powerpc/powerpc/pmap.c
index 1c789f7..30ce2f8 100644
--- a/sys/powerpc/powerpc/pmap.c
+++ b/sys/powerpc/powerpc/pmap.c
@@ -1117,6 +1117,19 @@ pmap_is_modified(vm_page_t m)
return (pmap_query_bit(m, PTE_CHG));
}
+/*
+ * pmap_is_prefaultable:
+ *
+ * Return whether or not the specified virtual address is elgible
+ * for prefault.
+ */
+boolean_t
+pmap_is_prefaultable(pmap_t pmap, vm_offset_t addr)
+{
+
+ return (FALSE);
+}
+
void
pmap_clear_reference(vm_page_t m)
{
@@ -1424,14 +1437,6 @@ pmap_pinit2(pmap_t pmap)
/* XXX: Remove this stub when no longer called */
}
-void
-pmap_prefault(pmap_t pm, vm_offset_t va, vm_map_entry_t entry)
-{
- KASSERT(pm == &curproc->p_vmspace->vm_pmap || pm == kernel_pmap,
- ("pmap_prefault: non current pmap"));
- /* XXX */
-}
-
/*
* Set the physical protection on the specified range of this map as requested.
*/
OpenPOWER on IntegriCloud