diff options
| author | Stefan Agner <stefan@agner.ch> | 2014-03-05 17:07:48 -0500 |
|---|---|---|
| committer | Shawn Guo <shawn.guo@freescale.com> | 2014-04-30 01:40:27 -0400 |
| commit | cfdb7d564c03a06e00f76a5e9b3929f802c1040b (patch) | |
| tree | 9c7d46bcf05b660e4c0cda1fc10174147f5884a4 | |
| parent | 477fbf1db8cb7b33ada578efb6dd8ce2f00de7f8 (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.debug | 9 | ||||
| -rw-r--r-- | arch/arm/include/debug/vf.S | 15 |
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 | ||
| 945 | config 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 | |||
| 945 | config DEBUG_TEGRA_UART | 954 | config 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 |
