From 2190d7a3f4afb341a5ca15fffd242c17194bbbe9 Mon Sep 17 00:00:00 2001 From: Huibin Hong Date: Mon, 21 Nov 2016 18:03:31 +0800 Subject: [PATCH] rk_fiq_debugger: map signal irq for fiq mode Change-Id: I220067fa3b6efaf4a1e88208a596822fc7120376 Signed-off-by: Huibin Hong --- drivers/soc/rockchip/rk_fiq_debugger.c | 27 ++++++++++++++++++-------- 1 file changed, 19 insertions(+), 8 deletions(-) diff --git a/drivers/soc/rockchip/rk_fiq_debugger.c b/drivers/soc/rockchip/rk_fiq_debugger.c index d9d798f0d3c1..7db9a8442e9f 100755 --- a/drivers/soc/rockchip/rk_fiq_debugger.c +++ b/drivers/soc/rockchip/rk_fiq_debugger.c @@ -40,7 +40,7 @@ #include #ifdef CONFIG_FIQ_DEBUGGER_EL3_TO_EL1 -#include "linux/rockchip/psci.h" +#include #endif #define UART_USR 0x1f /* In: UART Status Register */ @@ -62,6 +62,13 @@ struct rk_fiq_debugger { #endif }; +static int rk_fiq_debugger_id; +static int serial_id; + +#ifdef CONFIG_FIQ_DEBUGGER_EL3_TO_EL1 +static bool tf_fiq_sup; +#endif + static inline void rk_fiq_write(struct rk_fiq_debugger *t, unsigned int val, unsigned int off) { @@ -299,13 +306,11 @@ static int fiq_debugger_uart_dev_resume(struct platform_device *pdev) struct rk_fiq_debugger *t; t = container_of(dev_get_platdata(&pdev->dev), typeof(*t), pdata); - psci_fiq_debugger_uart_irq_tf_init(t->irq, fiq_debugger_uart_irq_tf); + psci_fiq_debugger_uart_irq_tf_init(serial_id, fiq_debugger_uart_irq_tf); return 0; } #endif -static int rk_fiq_debugger_id; - void rk_serial_debug_init(void __iomem *base, int irq, int signal_irq, int wakeup_irq, unsigned int baudrate) { @@ -316,7 +321,6 @@ void rk_serial_debug_init(void __iomem *base, int irq, int signal_irq, #ifdef CONFIG_FIQ_DEBUGGER_EL3_TO_EL1 /* tf means trust firmware*/ int tf_ver = 0; - bool tf_fiq_sup = false; #endif if (!base) { @@ -340,7 +344,7 @@ void rk_serial_debug_init(void __iomem *base, int irq, int signal_irq, t->pdata.uart_flush = debug_flush; #endif t->pdata.fiq_enable = fiq_enable; - t->pdata.force_irq = NULL; //force_irq; + t->pdata.force_irq = NULL; t->debug_port_base = base; res = kzalloc(sizeof(struct resource) * 3, GFP_KERNEL); @@ -367,7 +371,8 @@ void rk_serial_debug_init(void __iomem *base, int irq, int signal_irq, t->pdata.switch_cpu = rk_fiq_debugger_switch_cpu; t->pdata.enable_debug = rk_fiq_debugger_enable_debug; t->pdata.uart_dev_resume = fiq_debugger_uart_dev_resume; - psci_fiq_debugger_uart_irq_tf_init(irq, + psci_fiq_debugger_set_print_port(serial_id, 0); + psci_fiq_debugger_uart_irq_tf_init(serial_id, fiq_debugger_uart_irq_tf); } else { t->pdata.switch_cpu = NULL; @@ -445,7 +450,7 @@ static int __init rk_fiq_debugger_init(void) { void __iomem *base; struct device_node *np; - unsigned int id, serial_id, ok = 0; + unsigned int id, ok = 0; unsigned int irq, signal_irq = 0, wake_irq = 0; unsigned int baudrate = 0, irq_mode = 0; struct clk *clk; @@ -480,6 +485,12 @@ static int __init rk_fiq_debugger_init(void) { if (of_property_read_u32(np, "rockchip,baudrate", &baudrate)) baudrate = -1; + if (signal_irq > 0) { + signal_irq = irq_of_parse_and_map(np, 0); + if (!signal_irq) + return -EINVAL; + } + np = NULL; do { -- 2.34.1