summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorjhibbits <jhibbits@FreeBSD.org>2014-03-02 15:53:39 +0000
committerjhibbits <jhibbits@FreeBSD.org>2014-03-02 15:53:39 +0000
commita95a014852d6390c812b8cb5677bacdce3c6bc82 (patch)
tree8a0e08fd823de275b1eaf29c5abec0d550c468f2
parentba86c492432dadd23ec1d08ac0d1a14b9b0a904b (diff)
downloadFreeBSD-src-a95a014852d6390c812b8cb5677bacdce3c6bc82.zip
FreeBSD-src-a95a014852d6390c812b8cb5677bacdce3c6bc82.tar.gz
MFC r261258
Use a loop of dcbz, instead of calling bzero() to zero a page. This matches what is done in mmu_oea64.c.
-rw-r--r--sys/powerpc/aim/mmu_oea.c10
1 files changed, 4 insertions, 6 deletions
diff --git a/sys/powerpc/aim/mmu_oea.c b/sys/powerpc/aim/mmu_oea.c
index ac3e9fe..5451bc3 100644
--- a/sys/powerpc/aim/mmu_oea.c
+++ b/sys/powerpc/aim/mmu_oea.c
@@ -1084,10 +1084,10 @@ moea_copy_pages(mmu_t mmu, vm_page_t *ma, vm_offset_t a_offset,
void
moea_zero_page(mmu_t mmu, vm_page_t m)
{
- vm_offset_t pa = VM_PAGE_TO_PHYS(m);
- void *va = (void *)pa;
+ vm_offset_t off, pa = VM_PAGE_TO_PHYS(m);
- bzero(va, PAGE_SIZE);
+ for (off = 0; off < PAGE_SIZE; off += cacheline_size)
+ __asm __volatile("dcbz 0,%0" :: "r"(pa + off));
}
void
@@ -1102,10 +1102,8 @@ moea_zero_page_area(mmu_t mmu, vm_page_t m, int off, int size)
void
moea_zero_page_idle(mmu_t mmu, vm_page_t m)
{
- vm_offset_t pa = VM_PAGE_TO_PHYS(m);
- void *va = (void *)pa;
- bzero(va, PAGE_SIZE);
+ moea_zero_page(mmu, m);
}
/*
OpenPOWER on IntegriCloud