Add input support to DEBUG_LL infrastructure and implement it for i.MX

Signed-off-by: Andrey Smirnov <andrew.smir...@gmail.com>
---
 arch/arm/Kconfig                          |  1 +
 arch/arm/mach-imx/include/mach/debug_ll.h | 26 ++++++++++++++++++++++++++
 common/Kconfig                            | 11 +++++++++++
 include/debug_ll.h                        | 30 ++++++++++++++++++++++++++++++
 4 files changed, 68 insertions(+)

diff --git a/arch/arm/Kconfig b/arch/arm/Kconfig
index 50f3095..47d792b 100644
--- a/arch/arm/Kconfig
+++ b/arch/arm/Kconfig
@@ -103,6 +103,7 @@ config ARCH_IMX
        select CLKDEV_LOOKUP
        select WATCHDOG_IMX_RESET_SOURCE
        select HAS_DEBUG_LL
+       select HAS_DEBUG_LL_INPUT

 config ARCH_MVEBU
        bool "Marvell EBU platforms"
diff --git a/arch/arm/mach-imx/include/mach/debug_ll.h 
b/arch/arm/mach-imx/include/mach/debug_ll.h
index 8eb59f6..3f5a102 100644
--- a/arch/arm/mach-imx/include/mach/debug_ll.h
+++ b/arch/arm/mach-imx/include/mach/debug_ll.h
@@ -114,6 +114,32 @@ static inline void PUTC_LL(int c)

        writel(c, base + URTX0);
 }
+
+#ifdef CONFIG_DEBUG_LL_INPUT
+static inline bool TSTC_LL(void)
+{
+       void __iomem *base = IOMEM(IMX_UART_BASE(IMX_DEBUG_SOC,
+                                                CONFIG_DEBUG_IMX_UART_PORT));
+
+       return readl(base + USR2) & USR2_RDR;
+}
+
+static inline int GETC_LL(void)
+{
+       void __iomem *base = IOMEM(IMX_UART_BASE(IMX_DEBUG_SOC,
+                                                CONFIG_DEBUG_IMX_UART_PORT));
+
+       if (!base)
+               return -EINVAL;
+
+       if (!(readl(base + UCR1) & UCR1_UARTEN))
+               return -EINVAL;
+
+       while (!TSTC_LL());
+
+       return 0xff & readl(base + URXD0);
+}
+#endif
 #else

 static inline void imx_uart_setup_ll(void __iomem *uartbase,
diff --git a/common/Kconfig b/common/Kconfig
index 1c5d14c..4032dcd 100644
--- a/common/Kconfig
+++ b/common/Kconfig
@@ -774,6 +774,15 @@ config DEBUG_LL
          This requires SoC specific support. Most SoCs require the debug UART 
to be
          initialized by a debugger or first stage bootloader.

+config DEBUG_LL_INPUT
+        bool
+       depends on DEBUG_LL
+       depends on HAS_DEBUG_LL_INPUT
+       prompt "enable data reception on low level debug port"
+       help
+         Enable this option if you want to be able to receive data using low
+         level debug port as well as sending data over it.
+
 choice
        prompt "Kernel low-level debugging port"
        depends on DEBUG_LL
@@ -930,3 +939,5 @@ endmenu

 config HAS_DEBUG_LL
        bool
+config HAS_DEBUG_LL_INPUT
+        bool
diff --git a/include/debug_ll.h b/include/debug_ll.h
index b0eb7cd..4272830 100644
--- a/include/debug_ll.h
+++ b/include/debug_ll.h
@@ -38,6 +38,27 @@ static inline void putc_ll(char value)
        PUTC_LL(value);
 }

+#if defined (CONFIG_DEBUG_LL_INPUT)
+static inline int tstc_ll(void)
+{
+       return TSTC_LL();
+}
+
+static inline int getc_ll(void)
+{
+       return GETC_LL();
+}
+#else
+static inline int tstc_ll(void)
+{
+       return 0;
+}
+static inline int getc_ll(void)
+{
+       return -ENOTSUPP;
+}
+#endif
+
 static inline void puthex_ll(unsigned long value)
 {
        int i; unsigned char ch;
@@ -71,6 +92,15 @@ static inline void putc_ll(char value)
 {
 }

+static inline int tstc_ll(void)
+{
+       return 0;
+}
+static inline int getc_ll(void)
+{
+       return -ENOTSUPP;
+}
+
 static inline void puthex_ll(unsigned long value)
 {
 }
--
2.1.4

_______________________________________________
barebox mailing list
barebox@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/barebox

Reply via email to