diff options
| author | Sage Weil <sage@inktank.com> | 2013-08-15 11:11:45 -0700 | 
|---|---|---|
| committer | Sage Weil <sage@inktank.com> | 2013-08-15 11:11:45 -0700 | 
| commit | ee3e542fec6e69bc9fb668698889a37d93950ddf (patch) | |
| tree | e74ee766a4764769ef1d3d45d266b4dea64101d3 /arch/arm/include/debug | |
| parent | fe2a801b50c0bb8039d627e5ae1fec249d10ff39 (diff) | |
| parent | f1d6e17f540af37bb1891480143669ba7636c4cf (diff) | |
Merge remote-tracking branch 'linus/master' into testing
Diffstat (limited to 'arch/arm/include/debug')
| -rw-r--r-- | arch/arm/include/debug/imx-uart.h | 10 | ||||
| -rw-r--r-- | arch/arm/include/debug/keystone.S | 43 | ||||
| -rw-r--r-- | arch/arm/include/debug/mvebu.S | 5 | ||||
| -rw-r--r-- | arch/arm/include/debug/nspire.S | 28 | ||||
| -rw-r--r-- | arch/arm/include/debug/rockchip.S | 42 | ||||
| -rw-r--r-- | arch/arm/include/debug/sti.S | 61 | ||||
| -rw-r--r-- | arch/arm/include/debug/u300.S | 18 | ||||
| -rw-r--r-- | arch/arm/include/debug/vexpress.S | 10 | 
8 files changed, 217 insertions, 0 deletions
| diff --git a/arch/arm/include/debug/imx-uart.h b/arch/arm/include/debug/imx-uart.h index 91d38e38a0b..29da84e183f 100644 --- a/arch/arm/include/debug/imx-uart.h +++ b/arch/arm/include/debug/imx-uart.h @@ -65,6 +65,14 @@  #define IMX6Q_UART_BASE_ADDR(n)	IMX6Q_UART##n##_BASE_ADDR  #define IMX6Q_UART_BASE(n)	IMX6Q_UART_BASE_ADDR(n) +#define IMX6SL_UART1_BASE_ADDR	0x02020000 +#define IMX6SL_UART2_BASE_ADDR	0x02024000 +#define IMX6SL_UART3_BASE_ADDR	0x02034000 +#define IMX6SL_UART4_BASE_ADDR	0x02038000 +#define IMX6SL_UART5_BASE_ADDR	0x02018000 +#define IMX6SL_UART_BASE_ADDR(n) IMX6SL_UART##n##_BASE_ADDR +#define IMX6SL_UART_BASE(n)	IMX6SL_UART_BASE_ADDR(n) +  #define IMX_DEBUG_UART_BASE(soc) soc##_UART_BASE(CONFIG_DEBUG_IMX_UART_PORT)  #ifdef CONFIG_DEBUG_IMX1_UART @@ -83,6 +91,8 @@  #define UART_PADDR	IMX_DEBUG_UART_BASE(IMX53)  #elif defined(CONFIG_DEBUG_IMX6Q_UART)  #define UART_PADDR	IMX_DEBUG_UART_BASE(IMX6Q) +#elif defined(CONFIG_DEBUG_IMX6SL_UART) +#define UART_PADDR	IMX_DEBUG_UART_BASE(IMX6SL)  #endif  #endif /* __DEBUG_IMX_UART_H */ diff --git a/arch/arm/include/debug/keystone.S b/arch/arm/include/debug/keystone.S new file mode 100644 index 00000000000..9aef9ba3f4f --- /dev/null +++ b/arch/arm/include/debug/keystone.S @@ -0,0 +1,43 @@ +/* + * Early serial debug output macro for Keystone SOCs + * + * Copyright 2013 Texas Instruments, Inc. + *	Santosh Shilimkar <santosh.shilimkar@ti.com> + * + * Based on RMKs low level debug code. + *  Copyright (C) 1994-1999 Russell King + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License version 2 as + * published by the Free Software Foundation. + */ + +#include <linux/serial_reg.h> + +#define UART_SHIFT 2 +#if defined(CONFIG_DEBUG_KEYSTONE_UART0) +#define UART_PHYS		0x02530c00 +#define UART_VIRT		0xfeb30c00 +#elif defined(CONFIG_DEBUG_KEYSTONE_UART1) +#define UART_PHYS		0x02531000 +#define UART_VIRT		0xfeb31000 +#endif + +	.macro	addruart, rp, rv, tmp +	ldr	\rv, =UART_VIRT			@ physical base address +	ldr	\rp, =UART_PHYS			@ virtual base address +	.endm + +	.macro	senduart,rd,rx +	str	\rd, [\rx, #UART_TX << UART_SHIFT] +	.endm + +	.macro	busyuart,rd,rx +1002:	ldr	\rd, [\rx, #UART_LSR << UART_SHIFT] +	and	\rd, \rd, #UART_LSR_TEMT | UART_LSR_THRE +	teq	\rd, #UART_LSR_TEMT | UART_LSR_THRE +	bne	1002b +	.endm + +	.macro	waituart,rd,rx +	.endm diff --git a/arch/arm/include/debug/mvebu.S b/arch/arm/include/debug/mvebu.S index df191afa3be..6517311a1c9 100644 --- a/arch/arm/include/debug/mvebu.S +++ b/arch/arm/include/debug/mvebu.S @@ -11,7 +11,12 @@   * published by the Free Software Foundation.  */ +#ifdef CONFIG_DEBUG_MVEBU_UART_ALTERNATE +#define ARMADA_370_XP_REGS_PHYS_BASE	0xf1000000 +#else  #define ARMADA_370_XP_REGS_PHYS_BASE	0xd0000000 +#endif +  #define ARMADA_370_XP_REGS_VIRT_BASE	0xfec00000  	.macro	addruart, rp, rv, tmp diff --git a/arch/arm/include/debug/nspire.S b/arch/arm/include/debug/nspire.S new file mode 100644 index 00000000000..886fd276fcb --- /dev/null +++ b/arch/arm/include/debug/nspire.S @@ -0,0 +1,28 @@ +/* + *	linux/arch/arm/include/debug/nspire.S + * + *	Copyright (C) 2013 Daniel Tang <tangrs@tangrs.id.au> + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License version 2, as + * published by the Free Software Foundation. + * + */ + +#define NSPIRE_EARLY_UART_PHYS_BASE	   0x90020000 +#define NSPIRE_EARLY_UART_VIRT_BASE	   0xfee20000 + +.macro	addruart, rp, rv, tmp +	ldr \rp, =(NSPIRE_EARLY_UART_PHYS_BASE)		@ physical base address +	ldr \rv, =(NSPIRE_EARLY_UART_VIRT_BASE)		@ virtual base address +.endm + + +#ifdef CONFIG_DEBUG_NSPIRE_CX_UART +#include <asm/hardware/debug-pl01x.S> +#endif + +#ifdef CONFIG_DEBUG_NSPIRE_CLASSIC_UART +#define UART_SHIFT 2 +#include <asm/hardware/debug-8250.S> +#endif diff --git a/arch/arm/include/debug/rockchip.S b/arch/arm/include/debug/rockchip.S new file mode 100644 index 00000000000..cfd883e6958 --- /dev/null +++ b/arch/arm/include/debug/rockchip.S @@ -0,0 +1,42 @@ +/* + * Early serial output macro for Rockchip SoCs + * + * Copyright (C) 2012 Maxime Ripard + * + * Maxime Ripard <maxime.ripard@free-electrons.com> + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License version 2 as + * published by the Free Software Foundation. +*/ + +#if defined(CONFIG_DEBUG_RK29_UART0) +#define ROCKCHIP_UART_DEBUG_PHYS_BASE 0x20060000 +#define ROCKCHIP_UART_DEBUG_VIRT_BASE 0xfed60000 +#elif defined(CONFIG_DEBUG_RK29_UART1) +#define ROCKCHIP_UART_DEBUG_PHYS_BASE 0x20064000 +#define ROCKCHIP_UART_DEBUG_VIRT_BASE 0xfed64000 +#elif defined(CONFIG_DEBUG_RK29_UART2) +#define ROCKCHIP_UART_DEBUG_PHYS_BASE 0x20068000 +#define ROCKCHIP_UART_DEBUG_VIRT_BASE 0xfed68000 +#elif defined(CONFIG_DEBUG_RK3X_UART0) +#define ROCKCHIP_UART_DEBUG_PHYS_BASE 0x10124000 +#define ROCKCHIP_UART_DEBUG_VIRT_BASE 0xfeb24000 +#elif defined(CONFIG_DEBUG_RK3X_UART1) +#define ROCKCHIP_UART_DEBUG_PHYS_BASE 0x10126000 +#define ROCKCHIP_UART_DEBUG_VIRT_BASE 0xfeb26000 +#elif defined(CONFIG_DEBUG_RK3X_UART2) +#define ROCKCHIP_UART_DEBUG_PHYS_BASE 0x20064000 +#define ROCKCHIP_UART_DEBUG_VIRT_BASE 0xfed64000 +#elif defined(CONFIG_DEBUG_RK3X_UART3) +#define ROCKCHIP_UART_DEBUG_PHYS_BASE 0x20068000 +#define ROCKCHIP_UART_DEBUG_VIRT_BASE 0xfed68000 +#endif + +	.macro	addruart, rp, rv, tmp +	ldr	\rp, =ROCKCHIP_UART_DEBUG_PHYS_BASE +	ldr	\rv, =ROCKCHIP_UART_DEBUG_VIRT_BASE +	.endm + +#define UART_SHIFT	2 +#include <asm/hardware/debug-8250.S> diff --git a/arch/arm/include/debug/sti.S b/arch/arm/include/debug/sti.S new file mode 100644 index 00000000000..e3aa58ff177 --- /dev/null +++ b/arch/arm/include/debug/sti.S @@ -0,0 +1,61 @@ +/* + * arch/arm/include/debug/sti.S + * + * Debugging macro include header + * Copyright (C) 2013 STMicroelectronics (R&D) Limited. + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License version 2 as + * published by the Free Software Foundation. + */ + +#define STIH41X_COMMS_BASE              0xfed00000 +#define STIH41X_ASC2_BASE               (STIH41X_COMMS_BASE+0x32000) + +#define STIH41X_SBC_LPM_BASE            0xfe400000 +#define STIH41X_SBC_COMMS_BASE          (STIH41X_SBC_LPM_BASE + 0x100000) +#define STIH41X_SBC_ASC1_BASE           (STIH41X_SBC_COMMS_BASE + 0x31000) + + +#define VIRT_ADDRESS(x)		(x - 0x1000000) + +#if IS_ENABLED(CONFIG_STIH41X_DEBUG_ASC2) +#define DEBUG_LL_UART_BASE	STIH41X_ASC2_BASE +#endif + +#if IS_ENABLED(CONFIG_STIH41X_DEBUG_SBC_ASC1) +#define DEBUG_LL_UART_BASE	STIH41X_SBC_ASC1_BASE +#endif + +#ifndef DEBUG_LL_UART_BASE +#error "DEBUG UART is not Configured" +#endif + +#define ASC_TX_BUF_OFF  0x04 +#define ASC_CTRL_OFF    0x0c +#define ASC_STA_OFF     0x14 + +#define ASC_STA_TX_FULL         (1<<9) +#define ASC_STA_TX_EMPTY        (1<<1) + + +		.macro	addruart, rp, rv, tmp +		ldr	\rp,      =DEBUG_LL_UART_BASE	@ physical base +		ldr	\rv,      =VIRT_ADDRESS(DEBUG_LL_UART_BASE) @ virt base +		.endm + +                .macro  senduart,rd,rx +                strb    \rd, [\rx, #ASC_TX_BUF_OFF] +                .endm + +                .macro  waituart,rd,rx +1001:           ldr     \rd, [\rx, #ASC_STA_OFF] +                tst     \rd, #ASC_STA_TX_FULL +                bne     1001b +                .endm + +                .macro  busyuart,rd,rx +1001:           ldr     \rd, [\rx, #ASC_STA_OFF] +                tst     \rd, #ASC_STA_TX_EMPTY +                beq     1001b +                .endm diff --git a/arch/arm/include/debug/u300.S b/arch/arm/include/debug/u300.S new file mode 100644 index 00000000000..6f04f08a203 --- /dev/null +++ b/arch/arm/include/debug/u300.S @@ -0,0 +1,18 @@ +/* + * Copyright (C) 2006-2013 ST-Ericsson AB + * License terms: GNU General Public License (GPL) version 2 + * Debugging macro include header. + * Author: Linus Walleij <linus.walleij@stericsson.com> + */ +#define U300_SLOW_PER_PHYS_BASE		0xc0010000 +#define U300_SLOW_PER_VIRT_BASE		0xff000000 + +	.macro	addruart, rp, rv, tmp +	/* If we move the address using MMU, use this. */ +	ldr	\rp,	  = U300_SLOW_PER_PHYS_BASE @ MMU off, physical address +	ldr	\rv,	  = U300_SLOW_PER_VIRT_BASE @ MMU on, virtual address +	orr	\rp, \rp, #0x00003000 +	orr	\rv, \rv, #0x00003000 +	.endm + +#include <asm/hardware/debug-pl01x.S> diff --git a/arch/arm/include/debug/vexpress.S b/arch/arm/include/debug/vexpress.S index dc8e882a625..acafb229e2b 100644 --- a/arch/arm/include/debug/vexpress.S +++ b/arch/arm/include/debug/vexpress.S @@ -16,6 +16,8 @@  #define DEBUG_LL_PHYS_BASE_RS1		0x1c000000  #define DEBUG_LL_UART_OFFSET_RS1	0x00090000 +#define DEBUG_LL_UART_PHYS_CRX		0xb0090000 +  #define DEBUG_LL_VIRT_BASE		0xf8000000  #if defined(CONFIG_DEBUG_VEXPRESS_UART0_DETECT) @@ -67,6 +69,14 @@  #include <asm/hardware/debug-pl01x.S> +#elif defined(CONFIG_DEBUG_VEXPRESS_UART0_CRX) + +		.macro	addruart,rp,tmp,tmp2 +		ldr	\rp, =DEBUG_LL_UART_PHYS_CRX +		.endm + +#include <asm/hardware/debug-pl01x.S> +  #else /* CONFIG_DEBUG_LL_UART_NONE */  		.macro	addruart, rp, rv, tmp | 
