summaryrefslogtreecommitdiffstats
path: root/bsps/arm/include
diff options
context:
space:
mode:
authorSebastian Huber <sebastian.huber@embedded-brains.de>2020-12-21 08:08:00 +0100
committerSebastian Huber <sebastian.huber@embedded-brains.de>2020-12-23 09:19:28 +0100
commitb32fd22732ea9344bd7573c767573a3ce148c3f7 (patch)
treeb0dd44ab8840a56370913bdecdc5775a7b836d8e /bsps/arm/include
parentbsps/arm: Remove optional start hook arguments (diff)
downloadrtems-b32fd22732ea9344bd7573c767573a3ce148c3f7.tar.bz2
bsps/arm: Add arm-data-cache-loop-set-way.h
This makes it possible to reuse this loop. Update #4202.
Diffstat (limited to 'bsps/arm/include')
-rw-r--r--bsps/arm/include/dev/cache/arm-data-cache-loop-set-way.h96
1 files changed, 96 insertions, 0 deletions
diff --git a/bsps/arm/include/dev/cache/arm-data-cache-loop-set-way.h b/bsps/arm/include/dev/cache/arm-data-cache-loop-set-way.h
new file mode 100644
index 0000000000..f5dc792aa2
--- /dev/null
+++ b/bsps/arm/include/dev/cache/arm-data-cache-loop-set-way.h
@@ -0,0 +1,96 @@
+/*
+ * SPDX-License-Identifier: BSD-2-Clause
+ *
+ * Copyright (C) 2018 embedded brains GmbH
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
+ * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
+ * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+ * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
+ * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
+ * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
+ * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
+ * POSSIBILITY OF SUCH DAMAGE.
+ */
+
+.macro ARM_DATA_CACHE_LOOP_SET_WAY CRM
+
+ /* Get cache levels (LoC) from CLIDR */
+ mrc p15, 1, r1, c0, c0, 1
+ mov r2, r1, lsr #24
+ ands r2, r2, #0x7
+ beq 5f
+
+ /* Start with level 0 */
+ mov r3, #0
+
+ /* Flush level specified by r3 */
+1:
+
+ /* Check cache type and skip this level if there is no data cache */
+ add r4, r3, r3, lsl #1
+ lsr r5, r1, r4
+ and r5, r5, #0x7
+ cmp r5, #2
+ blt 4f
+
+ /* Read CCSIDR */
+ lsl r4, r3, #1
+ mcr p15, 2, r4, c0, c0, 0
+ isb
+ mrc p15, 1, r5, c0, c0, 0
+
+ /* Get cache line power */
+ and r6, r5, #0x7
+ add r6, r6, #4
+
+ /* Get ways minus one */
+ mov r7, #0x3ff
+ ands r7, r7, r5, lsr #3
+
+ /* Get way shift */
+ clz r8, r7
+
+ /* Get sets minus one */
+ mov r9, #0x7fff
+ ands r9, r9, r5, lsr #13
+
+ /* Loop over ways */
+2:
+ mov r10, r9
+
+ /* Loop over sets */
+3:
+ orr r11, r4, r7, lsl r8
+ orr r11, r11, r10, lsl r6
+
+ /* Cache operation by set and way */
+ mcr p15, 0, r11, c7, \CRM, 2
+
+ subs r10, r10, #1
+ bge 3b
+ subs r7, r7, #1
+ bge 2b
+
+ /* Next level */
+4:
+ add r3, r3, #1
+ cmp r2, r3
+ bgt 1b
+
+ /* Done */
+5:
+
+.endm