mirror of
https://github.com/openwrt/openwrt.git
synced 2024-12-23 07:22:33 +00:00
113 lines
4.2 KiB
Diff
113 lines
4.2 KiB
Diff
|
From ddc092180bd24b34afdd6fd7cd48b77b55a5bd5e Mon Sep 17 00:00:00 2001
|
||
|
From: Kurt Mahan <kmahan@freescale.com>
|
||
|
Date: Tue, 24 Jun 2008 23:21:07 -0600
|
||
|
Subject: [PATCH] Cleanup ACR mappings and document.
|
||
|
|
||
|
LTIBName: mcfv4e-acr-cleanup
|
||
|
Signed-off-by: Kurt Mahan <kmahan@freescale.com>
|
||
|
---
|
||
|
arch/m68k/coldfire/head.S | 81 +++++++++++++++++++++++++-------------------
|
||
|
1 files changed, 46 insertions(+), 35 deletions(-)
|
||
|
|
||
|
--- a/arch/m68k/coldfire/head.S
|
||
|
+++ b/arch/m68k/coldfire/head.S
|
||
|
@@ -53,52 +53,63 @@
|
||
|
#define __FINIT .previous
|
||
|
#endif
|
||
|
|
||
|
-/* JKM -- REVISE DOCS FOR M547x_8x and PHYS MAPPING */
|
||
|
+#if CONFIG_SDRAM_BASE != PAGE_OFFSET
|
||
|
/*
|
||
|
- * Setup ACR mappings to provide the following memory map:
|
||
|
- * Data
|
||
|
- * 0xA0000000 -> 0xAFFFFFFF [0] NO CACHE / PRECISE / SUPER ONLY
|
||
|
- * 0xF0000000 -> 0xFFFFFFFF [1] NO CACHE / PRECISE / SUPER ONLY
|
||
|
- * Code
|
||
|
- * None currently (mapped via TLBs)
|
||
|
+ * Kernel mapped to virtual ram address.
|
||
|
+ *
|
||
|
+ * M5445x:
|
||
|
+ * Data[0]: 0xF0000000 -> 0xFFFFFFFF System regs
|
||
|
+ * Data[1]: 0xA0000000 -> 0xAFFFFFFF PCI
|
||
|
+ * Code[0]: Not Mapped
|
||
|
+ * Code[1]: Not Mapped
|
||
|
+ *
|
||
|
+ * M547x/M548x
|
||
|
+ * Data[0]: 0xF0000000 -> 0xFFFFFFFF System regs
|
||
|
+ * Data[1]: Not Mapped
|
||
|
+ * Code[0]: Not Mapped
|
||
|
+ * Code[1]: Not Mapped
|
||
|
*/
|
||
|
-
|
||
|
-#if CONFIG_SDRAM_BASE != PAGE_OFFSET
|
||
|
#if defined(CONFIG_M5445X)
|
||
|
-#if 0
|
||
|
-#define ACR0_DEFAULT #0xA00FA048 /* ACR0 default value */
|
||
|
-#endif
|
||
|
-#define ACR0_DEFAULT #0x400FA028 /* ACR0 default value */
|
||
|
-#define ACR1_DEFAULT #0xF00FA040 /* ACR1 default value */
|
||
|
-#if 0
|
||
|
-#define ACR2_DEFAULT #0x00000000 /* ACR2 default value */
|
||
|
-#endif
|
||
|
-#define ACR2_DEFAULT #0x400FA028 /* ACR2 default value */
|
||
|
-#define ACR3_DEFAULT #0x00000000 /* ACR3 default value */
|
||
|
-/* ACR mapping for FPGA (maps 0) */
|
||
|
-#define ACR0_FPGA #0x000FA048 /* ACR0 enable FPGA */
|
||
|
+#define ACR0_DEFAULT #0xF00FA048 /* System regs */
|
||
|
+#define ACR1_DEFAULT #0xA00FA048 /* PCI */
|
||
|
+#define ACR2_DEFAULT #0x00000000 /* Not Mapped */
|
||
|
+#define ACR3_DEFAULT #0x00000000 /* Not Mapped */
|
||
|
#elif defined(CONFIG_M547X_8X)
|
||
|
-#define ACR0_DEFAULT #0xE000C040 /* ACR0 default value */
|
||
|
-#define ACR1_DEFAULT #0x00000000 /* ACR1 default value */
|
||
|
-#define ACR2_DEFAULT #0x00000000 /* ACR2 default value */
|
||
|
-#define ACR3_DEFAULT #0x00000000 /* ACR3 default value */
|
||
|
+#define ACR0_DEFAULT #0xF00FA048 /* System Regs */
|
||
|
+#define ACR1_DEFAULT #0x00000000 /* Not Mapped */
|
||
|
+#define ACR2_DEFAULT #0x00000000 /* Not Mapped */
|
||
|
+#define ACR3_DEFAULT #0x00000000 /* Not Mapped */
|
||
|
#endif
|
||
|
|
||
|
-#else
|
||
|
+#else /* CONFIG_SDRAM_BASE = PAGE_OFFSET */
|
||
|
+/*
|
||
|
+ * Kernel mapped to physical ram address.
|
||
|
+ *
|
||
|
+ * M5445x:
|
||
|
+ * Data[0]: 0xF0000000 -> 0xFFFFFFFF System regs
|
||
|
+ * Data[1]: 0x40000000 -> 0x4FFFFFFF SDRAM - uncached
|
||
|
+ * Code[0]: Not Mapped
|
||
|
+ * Code[1]: 0x40000000 -> 0x4FFFFFFF SDRAM - cached
|
||
|
+ *
|
||
|
+ * M547x/M548x
|
||
|
+ * Data[0]: 0xF0000000 -> 0xFFFFFFFF System regs
|
||
|
+ * Data[1]: 0x00000000 -> 0x0FFFFFFF SDRAM - uncached
|
||
|
+ * Code[0]: Not Mapped
|
||
|
+ * Code[1]: 0x00000000 -> 0x0FFFFFFF SDRAM - cached
|
||
|
+ */
|
||
|
#if defined(CONFIG_M5445X)
|
||
|
-#define ACR0_DEFAULT #0xF00FC040 /* ACR0 default value */
|
||
|
-#define ACR1_DEFAULT #0x400FA008 /* ACR1 default value */
|
||
|
-#define ACR2_DEFAULT #0x00000000 /* ACR2 default value */
|
||
|
-#define ACR3_DEFAULT #0x400FA008 /* ACR3 default value */
|
||
|
+#define ACR0_DEFAULT #0xF00FA048 /* System Regs */
|
||
|
+#define ACR1_DEFAULT #0x400FA048 /* SDRAM uncached */
|
||
|
+#define ACR2_DEFAULT #0x00000000 /* Not mapped */
|
||
|
+#define ACR3_DEFAULT #0x400FA008 /* SDRAM cached */
|
||
|
#elif defined(CONFIG_M547X_8X)
|
||
|
-#define ACR0_DEFAULT #0xF00FC040 /* ACR0 default value */
|
||
|
-#define ACR1_DEFAULT #0x000FA008 /* ACR1 default value */
|
||
|
-#define ACR2_DEFAULT #0x00000000 /* ACR2 default value */
|
||
|
-#define ACR3_DEFAULT #0x000FA008 /* ACR3 default value */
|
||
|
+#define ACR0_DEFAULT #0xF00FA048 /* System Regs */
|
||
|
+#define ACR1_DEFAULT #0x000FA048 /* SDRAM uncached */
|
||
|
+#define ACR2_DEFAULT #0x00000000 /* Not mapped */
|
||
|
+#define ACR3_DEFAULT #0x000FA008 /* SDRAM cached */
|
||
|
#endif
|
||
|
#endif
|
||
|
|
||
|
-
|
||
|
/* Several macros to make the writing of subroutines easier:
|
||
|
* - func_start marks the beginning of the routine which setups the frame
|
||
|
* register and saves the registers, it also defines another macro
|