Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/arch/aarch64/aarch64 even if the line size of Icache and...
details: https://anonhg.NetBSD.org/src/rev/a5fd31a61680
branches: trunk
changeset: 972644:a5fd31a61680
user: ryo <ryo%NetBSD.org@localhost>
date: Mon Jun 01 08:59:00 2020 +0000
description:
even if the line size of Icache and Dcache is different, it was fixed to work correctly.
- MAX(IcacheShift,DcacheShift) is wrong and should be MIN(IcacheShift,DcacheShift).
Dcache and Icache are now done in independent loops instead of in the same loop.
- simplify the handling of cache_handle_range() macro arguments.
- cache_handle_range macro doesn't include "ret" anymore.
diffstat:
sys/arch/aarch64/aarch64/cpufunc_asm_armv8.S | 64 +++++++++++++++------------
1 files changed, 35 insertions(+), 29 deletions(-)
diffs (122 lines):
diff -r 2c5a7894131b -r a5fd31a61680 sys/arch/aarch64/aarch64/cpufunc_asm_armv8.S
--- a/sys/arch/aarch64/aarch64/cpufunc_asm_armv8.S Mon Jun 01 08:33:40 2020 +0000
+++ b/sys/arch/aarch64/aarch64/cpufunc_asm_armv8.S Mon Jun 01 08:59:00 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: cpufunc_asm_armv8.S,v 1.4 2019/09/12 06:12:56 ryo Exp $ */
+/* $NetBSD: cpufunc_asm_armv8.S,v 1.5 2020/06/01 08:59:00 ryo Exp $ */
/*-
* Copyright (c) 2014 Robin Randhawa
@@ -41,43 +41,44 @@
/*
* Macro to handle the cache. This takes the start address in x0, length
- * in x1. It will corrupt x0, x1, x2, and x3.
+ * in x1. It will corrupt x2-x5.
*/
-.macro cache_handle_range dcop = 0, ic = 0, icop = 0
-.if \ic == 0
+.macro cache_handle_range dcop = 0, icop = 0
mrs x3, ctr_el0
- ubfx x3, x3, #16, #4 /* x3 = D cache shift */
- mov x2, #4 /* size of word */
- lsl x3, x2, x3 /* x3 = D cache line size */
-.else
- mrs x3, ctr_el0
+ mov x4, #4 /* size of word */
+.if \dcop != 0
ubfx x2, x3, #16, #4 /* x2 = D cache shift */
+ lsl x2, x4, x2 /* x2 = D cache line size */
+.endif
+.if \icop != 0
and x3, x3, #15 /* x3 = I cache shift */
- cmp x3, x2
- bcs 1f
- mov x3, x2
-1: /* x3 = MAX(IcacheShift,DcacheShift) */
- mov x2, #4 /* size of word */
- lsl x3, x2, x3 /* x3 = cache line size */
+ lsl x3, x4, x3 /* x3 = I cache line size */
.endif
- sub x4, x3, #1 /* Get the address mask */
- and x2, x0, x4 /* Get the low bits of the address */
- add x1, x1, x2 /* Add these to the size */
- bic x0, x0, x4 /* Clear the low bit of the address */
+.if \dcop != 0
+ sub x4, x2, #1 /* Get the address mask */
+ and x4, x0, x4 /* Get the low bits of the address */
+ add x5, x1, x4 /* Add these to the size */
+ bic x4, x0, x4 /* Clear the low bit of the address */
1:
- dc \dcop, x0
- dsb ish
-.if \ic != 0
- ic \icop, x0
+ dc \dcop, x4
+ add x4, x4, x2 /* Move to the next line */
+ subs x5, x5, x2 /* Reduce the size */
+ b.hi 1b /* Check if we are done */
dsb ish
.endif
- add x0, x0, x3 /* Move to the next line */
- subs x1, x1, x3 /* Reduce the size */
+.if \icop != 0
+ sub x4, x3, #1 /* Get the address mask */
+ and x4, x0, x4 /* Get the low bits of the address */
+ add x5, x1, x4 /* Add these to the size */
+ bic x4, x0, x4 /* Clear the low bit of the address */
+1:
+ ic \icop, x4
+ add x4, x4, x3 /* Move to the next line */
+ subs x5, x5, x3 /* Reduce the size */
b.hi 1b /* Check if we are done */
-.if \ic != 0
+ dsb ish
isb
.endif
- ret
.endm
@@ -95,6 +96,7 @@
*/
ENTRY(aarch64_dcache_wb_range)
cache_handle_range dcop = cvac
+ ret
END(aarch64_dcache_wb_range)
/*
@@ -102,6 +104,7 @@
*/
ENTRY(aarch64_dcache_wbinv_range)
cache_handle_range dcop = civac
+ ret
END(aarch64_dcache_wbinv_range)
/*
@@ -112,20 +115,23 @@
*/
ENTRY(aarch64_dcache_inv_range)
cache_handle_range dcop = ivac
+ ret
END(aarch64_dcache_inv_range)
/*
* void aarch64_idcache_wbinv_range(vaddr_t, vsize_t)
*/
ENTRY(aarch64_idcache_wbinv_range)
- cache_handle_range dcop = civac, ic = 1, icop = ivau
+ cache_handle_range dcop = civac, icop = ivau
+ ret
END(aarch64_idcache_wbinv_range)
/*
* void aarch64_icache_sync_range(vaddr_t, vsize_t)
*/
ENTRY(aarch64_icache_sync_range)
- cache_handle_range dcop = cvau, ic = 1, icop = ivau
+ cache_handle_range dcop = cvau, icop = ivau
+ ret
END(aarch64_icache_sync_range)
/*
Home |
Main Index |
Thread Index |
Old Index