Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/arch/arm/arm Allow for 8KB page size. Add ARM_MMU_EXTEN...
details: https://anonhg.NetBSD.org/src/rev/b49b0e80adb7
branches: trunk
changeset: 328270:b49b0e80adb7
user: matt <matt%NetBSD.org@localhost>
date: Sun Mar 30 01:15:03 2014 +0000
description:
Allow for 8KB page size. Add ARM_MMU_EXTENDED support.
Add missing END()
diffstat:
sys/arch/arm/arm/cpufunc_asm_arm10.S | 17 ++++++++++++++-
sys/arch/arm/arm/cpufunc_asm_arm11.S | 32 ++++++++++++++++++++++++++----
sys/arch/arm/arm/cpufunc_asm_arm11x6.S | 24 +++++++---------------
sys/arch/arm/arm/cpufunc_asm_arm3.S | 3 +-
sys/arch/arm/arm/cpufunc_asm_arm67.S | 3 +-
sys/arch/arm/arm/cpufunc_asm_arm7tdmi.S | 28 +++++++++++++++++---------
sys/arch/arm/arm/cpufunc_asm_arm8.S | 18 ++++++++++++++++-
sys/arch/arm/arm/cpufunc_asm_arm9.S | 25 +++++++++++++++++++----
sys/arch/arm/arm/cpufunc_asm_armv4.S | 9 ++++++-
sys/arch/arm/arm/cpufunc_asm_armv5.S | 5 +--
sys/arch/arm/arm/cpufunc_asm_armv5_ec.S | 5 +--
sys/arch/arm/arm/cpufunc_asm_fa526.S | 27 ++++++++++++++++++++++++-
sys/arch/arm/arm/cpufunc_asm_ixp12x0.S | 4 ++-
sys/arch/arm/arm/cpufunc_asm_pj4b.S | 34 ++++++++++++++++++++++----------
sys/arch/arm/arm/cpufunc_asm_sa1.S | 24 ++++++++++++++++++++++-
sys/arch/arm/arm/cpufunc_asm_sa11x0.S | 3 +-
sys/arch/arm/arm/cpufunc_asm_sheeva.S | 3 +-
sys/arch/arm/arm/cpufunc_asm_xscale.S | 8 ++++++-
18 files changed, 204 insertions(+), 68 deletions(-)
diffs (truncated from 1014 to 300 lines):
diff -r 9b7937301b55 -r b49b0e80adb7 sys/arch/arm/arm/cpufunc_asm_arm10.S
--- a/sys/arch/arm/arm/cpufunc_asm_arm10.S Sun Mar 30 01:12:18 2014 +0000
+++ b/sys/arch/arm/arm/cpufunc_asm_arm10.S Sun Mar 30 01:15:03 2014 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: cpufunc_asm_arm10.S,v 1.10 2013/08/18 06:28:18 matt Exp $ */
+/* $NetBSD: cpufunc_asm_arm10.S,v 1.11 2014/03/30 01:15:03 matt Exp $ */
/*
* Copyright (c) 2002 ARM Limited
@@ -33,6 +33,7 @@
#include <machine/asm.h>
#include <arm/locore.h>
+#include "assym.h"
/*
* TLB functions
@@ -40,12 +41,23 @@
ENTRY(arm10_tlb_flushID_SE)
mcr p15, 0, r0, c8, c6, 1 /* flush D tlb single entry */
mcr p15, 0, r0, c8, c5, 1 /* flush I tlb single entry */
+#if PAGE_SIZE == 2 * L2_S_SIZE
+ add r0, r0, #L2_S_SIZE
+ mcr p15, 0, r0, c8, c6, 1 /* flush D tlb single entry */
+ mcr p15, 0, r0, c8, c5, 1 /* flush I tlb single entry */
+#endif
RET
+END(arm10_tlb_flushID_SE)
ENTRY(arm10_tlb_flushI_SE)
mcr p15, 0, r0, c8, c5, 1 /* flush I tlb single entry */
+#if PAGE_SIZE == 2 * L2_S_SIZE
+ add r0, r0, #L2_S_SIZE
+ mcr p15, 0, r0, c8, c5, 1 /* flush I tlb single entry */
+#endif
RET
-
+END(arm10_tlb_flushI_SE)
+
/*
* Context switch.
@@ -67,3 +79,4 @@
nop
nop
RET
+END(arm10_context_switch)
diff -r 9b7937301b55 -r b49b0e80adb7 sys/arch/arm/arm/cpufunc_asm_arm11.S
--- a/sys/arch/arm/arm/cpufunc_asm_arm11.S Sun Mar 30 01:12:18 2014 +0000
+++ b/sys/arch/arm/arm/cpufunc_asm_arm11.S Sun Mar 30 01:15:03 2014 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: cpufunc_asm_arm11.S,v 1.11 2014/02/20 17:27:46 matt Exp $ */
+/* $NetBSD: cpufunc_asm_arm11.S,v 1.12 2014/03/30 01:15:03 matt Exp $ */
/*
* Copyright (c) 2002, 2005 ARM Limited
@@ -49,15 +49,17 @@
#error arm11 does not have a VIVT cache.
#endif
- mcr p15, 0, r0, c2, c0, 0 /* load new TTB */
-
cmp r1, #0
+ mcr p15, 0, r0, c2, c0, 0 /* TTBR0 set */
+#ifdef ARM_MMU_EXTENDED
+ mcreq p15, 0, r0, c2, c0, 1 /* TTBR1 set */
+#else
mcrne p15, 0, r0, c8, c7, 0 /* invalidate I+D TLBs */
mcrne p15, 0, r0, c7, c10, 4 /* drain write buffer */
+#endif
RET
END(arm11_setttb)
-
/*
* Context switch.
*
@@ -69,9 +71,16 @@
* We can assume that the caches will only contain kernel addresses
* at this point. So no need to flush them again.
*/
+#ifdef ARM_MMU_EXTENDED
+ cmp r1, #0
+#endif
mcr p15, 0, r0, c7, c10, 4 /* drain the write buffer */
- mcr p15, 0, r0, c2, c0, 0 /* set the new TTB */
+ mcr p15, 0, r0, c2, c0, 0 /* TTBR0 set */
+#ifdef ARM_MMU_EXTENDED
+ mcreq p15, 0, r0, c2, c0, 1 /* TTBR1 set is asid 0 */
+#else
mcr p15, 0, r0, c8, c7, 0 /* and flush the I+D tlbs */
+#endif
/* Paranoia -- make sure the pipeline is empty. */
nop
@@ -96,6 +105,11 @@
orr r0, r0, r1 /* insert ASID into MVA */
#endif
mcr p15, 0, r0, c8, c5, 1 /* flush I tlb single entry */
+#if PAGE_SIZE == 2 * L2_S_SIZE
+ add r0, r0, #L2_S_SIZE
+ mcr p15, 0, r0, c8, c5, 1 /* flush I tlb single entry */
+#endif
+
mov r0, #0
mcr p15, 0, r0, c7, c10, 4 /* drain write buffer */
RET
@@ -113,6 +127,10 @@
orr r0, r0, r1 /* insert ASID into MVA */
#endif
mcr p15, 0, r0, c8, c6, 1 /* flush D tlb single entry */
+#if PAGE_SIZE == 2 * L2_S_SIZE
+ add r0, r0, #L2_S_SIZE
+ mcr p15, 0, r0, c8, c6, 1 /* flush D tlb single entry */
+#endif
mov r0, #0
mcr p15, 0, r0, c7, c10, 4 /* drain write buffer */
RET
@@ -130,6 +148,10 @@
orr r0, r0, r1 /* insert ASID into MVA */
#endif
mcr p15, 0, r0, c8, c7, 1 /* flush I+D tlb single entry */
+#if PAGE_SIZE == 2 * L2_S_SIZE
+ add r0, r0, #L2_S_SIZE
+ mcr p15, 0, r0, c8, c7, 1 /* flush I+D tlb single entry */
+#endif
mov r0, #0
mcr p15, 0, r0, c7, c10, 4 /* drain write buffer */
RET
diff -r 9b7937301b55 -r b49b0e80adb7 sys/arch/arm/arm/cpufunc_asm_arm11x6.S
--- a/sys/arch/arm/arm/cpufunc_asm_arm11x6.S Sun Mar 30 01:12:18 2014 +0000
+++ b/sys/arch/arm/arm/cpufunc_asm_arm11x6.S Sun Mar 30 01:15:03 2014 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: cpufunc_asm_arm11x6.S,v 1.3 2013/08/18 06:28:18 matt Exp $ */
+/* $NetBSD: cpufunc_asm_arm11x6.S,v 1.4 2014/03/30 01:15:03 matt Exp $ */
/*
* Copyright (c) 2007 Microsoft
@@ -63,7 +63,7 @@
#include <machine/asm.h>
#include <arm/locore.h>
-RCSID("$NetBSD: cpufunc_asm_arm11x6.S,v 1.3 2013/08/18 06:28:18 matt Exp $")
+RCSID("$NetBSD: cpufunc_asm_arm11x6.S,v 1.4 2014/03/30 01:15:03 matt Exp $")
#if 0
#define Invalidate_I_cache(Rtmp1, Rtmp2) \
@@ -114,37 +114,27 @@
mcr p15, 0, reg, c7, c10, 4;/* Data Synchronization Barrier */
#endif
-ENTRY(arm11x6_setttb)
-#ifdef PMAP_CACHE_VIVT
- Flush_D_cache(r2)
- Invalidate_I_cache(r2, r3)
-#else
- mov r2, #0
-#endif
- mcr p15, 0, r0, c2, c0, 0 /* load new TTB */
-
- cmp r1, #0
- mcrne p15, 0, r2, c8, c7, 0 /* invalidate I+D TLBs */
- mcrne p15, 0, r2, c7, c10, 4 /* drain write buffer */
- RET
-
ENTRY_NP(arm11x6_idcache_wbinv_all)
Flush_D_cache(r0)
Invalidate_I_cache(r0, r1)
RET
+END(arm11x6_idcache_wbinv_all)
ENTRY_NP(arm11x6_dcache_wbinv_all)
Flush_D_cache(r0)
RET
+END(arm11x6_dcache_wbinv_all)
ENTRY_NP(arm11x6_icache_sync_all)
Flush_D_cache(r0)
Invalidate_I_cache(r0, r1)
RET
+END(arm11x6_icache_sync_all)
ENTRY_NP(arm11x6_flush_prefetchbuf)
mcr p15, 0, r0, c7, c5, 4 /* Flush Prefetch Buffer */
RET
+END(arm11x6_flush_prefetchbuf)
ENTRY_NP(arm11x6_icache_sync_range)
add r1, r1, r0
@@ -171,6 +161,7 @@
mcrr p15, 0, r1, r0, c12 /* clean and invalidate D cache range */ /* XXXNH */
mcr p15, 0, r0, c7, c10, 4 /* drain the write buffer */
RET
+END(arm11x6_icache_sync_range)
ENTRY_NP(arm11x6_idcache_wbinv_range)
add r1, r1, r0
@@ -197,6 +188,7 @@
mcrr p15, 0, r1, r0, c14 /* clean and invalidate D cache range */
mcr p15, 0, r0, c7, c10, 4 /* drain the write buffer */
RET
+END(arm11x6_idcache_wbinv_range)
/*
* Preload the cache before issuing the WFI by conditionally disabling the
diff -r 9b7937301b55 -r b49b0e80adb7 sys/arch/arm/arm/cpufunc_asm_arm3.S
--- a/sys/arch/arm/arm/cpufunc_asm_arm3.S Sun Mar 30 01:12:18 2014 +0000
+++ b/sys/arch/arm/arm/cpufunc_asm_arm3.S Sun Mar 30 01:15:03 2014 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: cpufunc_asm_arm3.S,v 1.3 2013/08/18 06:28:18 matt Exp $ */
+/* $NetBSD: cpufunc_asm_arm3.S,v 1.4 2014/03/30 01:15:03 matt Exp $ */
/*
* Copyright (c) 1997,1998 Mark Brinicombe.
@@ -35,6 +35,7 @@
* ARM3 assembly functions for CPU / MMU / TLB specific operations
*/
+#include "assym.h"
#include <machine/asm.h>
#include <arm/locore.h>
diff -r 9b7937301b55 -r b49b0e80adb7 sys/arch/arm/arm/cpufunc_asm_arm67.S
--- a/sys/arch/arm/arm/cpufunc_asm_arm67.S Sun Mar 30 01:12:18 2014 +0000
+++ b/sys/arch/arm/arm/cpufunc_asm_arm67.S Sun Mar 30 01:15:03 2014 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: cpufunc_asm_arm67.S,v 1.6 2013/08/18 06:28:18 matt Exp $ */
+/* $NetBSD: cpufunc_asm_arm67.S,v 1.7 2014/03/30 01:15:03 matt Exp $ */
/*
* Copyright (c) 1997,1998 Mark Brinicombe.
@@ -35,6 +35,7 @@
* ARM6/ARM7 assembly functions for CPU / MMU / TLB specific operations
*/
+#include "assym.h"
#include <machine/asm.h>
#include <arm/locore.h>
diff -r 9b7937301b55 -r b49b0e80adb7 sys/arch/arm/arm/cpufunc_asm_arm7tdmi.S
--- a/sys/arch/arm/arm/cpufunc_asm_arm7tdmi.S Sun Mar 30 01:12:18 2014 +0000
+++ b/sys/arch/arm/arm/cpufunc_asm_arm7tdmi.S Sun Mar 30 01:15:03 2014 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: cpufunc_asm_arm7tdmi.S,v 1.6 2013/08/18 06:28:18 matt Exp $ */
+/* $NetBSD: cpufunc_asm_arm7tdmi.S,v 1.7 2014/03/30 01:15:03 matt Exp $ */
/*
* Copyright (c) 2001 John Fremlin
@@ -34,6 +34,7 @@
* ARM7TDMI assembly functions for CPU / MMU / TLB specific operations
*/
+#include "assym.h"
#include <machine/asm.h>
#include <arm/locore.h>
@@ -43,6 +44,13 @@
* We need to clean and flush the cache as it uses virtual
* addresses that are about to change.
*/
+
+/*
+ * Context switch.
+ *
+ * These are the CPU-specific parts of the context switcher cpu_switch()
+ * These functions actually perform the TTB reload.
+ */
ENTRY(arm7tdmi_setttb)
mov r3, lr /* ditto with lr */
mov r2, r1 /* store the flush flag in a safe place */
@@ -64,6 +72,8 @@
bl _C_LABEL(arm7tdmi_cache_flushID)
mov pc, r3
+END(arm7tdmi_setttb)
+STRONG_ALIAS(arm7tdmi_context_switch, arm7tdmi_setttb)
/*
* TLB functions
@@ -72,10 +82,16 @@
mov r0, #0
mcr p15, 0, r0, c8, c7, 0
mov pc, lr
+END(arm7tdmi_tlb_flushID)
ENTRY(arm7tdmi_tlb_flushID_SE)
mcr p15, 0, r0, c8, c7, 1
+#if PAGE_SIZE == 2 * L2_S_SIZE
+ add r0, r0, #L2_S_SIZE
+ mcr p15, 0, r0, c8, c7, 1
+#endif
mov pc, lr
+END(arm7tdmi_tlb_flushID_SE)
/*
* Cache functions
@@ -90,12 +106,4 @@
mov r0, r0
mov pc, lr
Home |
Main Index |
Thread Index |
Old Index