aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorStefan Agner <stefan@agner.ch>2014-03-05 17:07:48 -0500
committerShawn Guo <shawn.guo@freescale.com>2014-04-30 01:40:27 -0400
commitcfdb7d564c03a06e00f76a5e9b3929f802c1040b (patch)
tree9c7d46bcf05b660e4c0cda1fc10174147f5884a4
parent477fbf1db8cb7b33ada578efb6dd8ce2f00de7f8 (diff)
ARM: vf610: add UART choice for low-level debug
Add choice for low-level debug UART. Similar to i.MX6, there is a numeric configuration, valid choices are 0 to 3. Note that the kernel assumes that the boot loader initialized clock properly. Signed-off-by: Stefan Agner <stefan@agner.ch> Signed-off-by: Shawn Guo <shawn.guo@linaro.org>
-rw-r--r--arch/arm/Kconfig.debug9
-rw-r--r--arch/arm/include/debug/vf.S15
2 files changed, 22 insertions, 2 deletions
diff --git a/arch/arm/Kconfig.debug b/arch/arm/Kconfig.debug
index eab8ecbe69c1..00c69503da22 100644
--- a/arch/arm/Kconfig.debug
+++ b/arch/arm/Kconfig.debug
@@ -942,6 +942,15 @@ config DEBUG_IMX_UART_PORT
942 Choose UART port on which kernel low-level debug messages 942 Choose UART port on which kernel low-level debug messages
943 should be output. 943 should be output.
944 944
945config DEBUG_VF_UART_PORT
946 int "Vybrid Debug UART Port Selection" if DEBUG_VF_UART
947 default 1
948 range 0 3
949 depends on SOC_VF610
950 help
951 Choose UART port on which kernel low-level debug messages
952 should be output.
953
945config DEBUG_TEGRA_UART 954config DEBUG_TEGRA_UART
946 bool 955 bool
947 depends on ARCH_TEGRA 956 depends on ARCH_TEGRA
diff --git a/arch/arm/include/debug/vf.S b/arch/arm/include/debug/vf.S
index ba12cc44b2cb..b88933849a17 100644
--- a/arch/arm/include/debug/vf.S
+++ b/arch/arm/include/debug/vf.S
@@ -7,9 +7,20 @@
7 * 7 *
8 */ 8 */
9 9
10#define VF_UART0_BASE_ADDR 0x40027000
11#define VF_UART1_BASE_ADDR 0x40028000
12#define VF_UART2_BASE_ADDR 0x40029000
13#define VF_UART3_BASE_ADDR 0x4002a000
14#define VF_UART_BASE_ADDR(n) VF_UART##n##_BASE_ADDR
15#define VF_UART_BASE(n) VF_UART_BASE_ADDR(n)
16#define VF_UART_PHYSICAL_BASE VF_UART_BASE(CONFIG_DEBUG_VF_UART_PORT)
17
18#define VF_UART_VIRTUAL_BASE 0xfe000000
19
10 .macro addruart, rp, rv, tmp 20 .macro addruart, rp, rv, tmp
11 ldr \rp, =0x40028000 @ physical 21 ldr \rp, =VF_UART_PHYSICAL_BASE @ physical
12 ldr \rv, =0xfe028000 @ virtual 22 and \rv, \rp, #0xffffff @ offset within 16MB section
23 add \rv, \rv, #VF_UART_VIRTUAL_BASE
13 .endm 24 .endm
14 25
15 .macro senduart, rd, rx 26 .macro senduart, rd, rx