[rtems commit] bsp/realview-pbx-a9: Fix printk() support

Sebastian Huber sebh at rtems.org
Wed Nov 7 12:00:06 UTC 2018


Module:    rtems
Branch:    master
Commit:    2faea99ac26573623ff09759131cc5607ecb5bae
Changeset: http://git.rtems.org/rtems/commit/?id=2faea99ac26573623ff09759131cc5607ecb5bae

Author:    Sebastian Huber <sebastian.huber at embedded-brains.de>
Date:      Wed Nov  7 11:08:50 2018 +0100

bsp/realview-pbx-a9: Fix printk() support

Avoid dependencies on the Termios support in case only printk() is used
by the application.

---

 bsps/arm/realview-pbx-a9/console/console-config.c | 37 ++---------------
 bsps/arm/realview-pbx-a9/console/console-polled.c | 48 +++++++++++++++++++++++
 bsps/arm/realview-pbx-a9/include/bsp/console.h    | 32 +++++++++++++++
 c/src/lib/libbsp/arm/realview-pbx-a9/Makefile.am  |  1 +
 4 files changed, 85 insertions(+), 33 deletions(-)

diff --git a/bsps/arm/realview-pbx-a9/console/console-config.c b/bsps/arm/realview-pbx-a9/console/console-config.c
index 66dcfa6..6375a4d 100644
--- a/bsps/arm/realview-pbx-a9/console/console-config.c
+++ b/bsps/arm/realview-pbx-a9/console/console-config.c
@@ -16,17 +16,10 @@
 #include <rtems/bspIo.h>
 
 #include <bsp.h>
-#include <bsp/irq.h>
-#include <bsp/arm-pl011.h>
 #include <bsp/arm-pl050.h>
+#include <bsp/console.h>
 #include <bsp/console-termios.h>
-
-static arm_pl011_context pl011_context = {
-  .base = RTEMS_TERMIOS_DEVICE_CONTEXT_INITIALIZER("PL011"),
-  .regs = (volatile pl011 *) 0x10009000,
-  .irq = RVPBXA9_IRQ_UART_0,
-  .initial_baud = 115200
-};
+#include <bsp/irq.h>
 
 static arm_pl050_context pl050_context = {
   .base = RTEMS_TERMIOS_DEVICE_CONTEXT_INITIALIZER("PL050"),
@@ -35,34 +28,12 @@ static arm_pl050_context pl050_context = {
   .initial_baud = 115200
 };
 
-static void output_char(char c)
-{
-  arm_pl011_write_polled(&pl011_context.base, c);
-}
-
-static bool pl011_probe(rtems_termios_device_context *base)
-{
-  BSP_output_char = output_char;
-
-  return arm_pl011_probe(base);
-}
-
-static void output_char_init(char c)
-{
-  pl011_probe(&pl011_context.base);
-  output_char(c);
-}
-
-BSP_output_char_function_type BSP_output_char = output_char_init;
-
-BSP_polling_getchar_function_type BSP_poll_char = NULL;
-
 const console_device console_device_table[] = {
   {
     .device_file = "/dev/ttyS0",
-    .probe = pl011_probe,
+    .probe = rvpbx_pl011_probe,
     .handler = &arm_pl011_fns,
-    .context = &pl011_context.base
+    .context = &rvpbx_pl011_context.base
   }, {
     .device_file = SERIAL_MOUSE_DEVICE_PS2,
     .probe = console_device_probe_default,
diff --git a/bsps/arm/realview-pbx-a9/console/console-polled.c b/bsps/arm/realview-pbx-a9/console/console-polled.c
new file mode 100644
index 0000000..53d5288
--- /dev/null
+++ b/bsps/arm/realview-pbx-a9/console/console-polled.c
@@ -0,0 +1,48 @@
+/*
+ * Copyright (c) 2013, 2018 embedded brains GmbH.  All rights reserved.
+ *
+ *  embedded brains GmbH
+ *  Dornierstr. 4
+ *  82178 Puchheim
+ *  Germany
+ *  <info at embedded-brains.de>
+ *
+ * The license and distribution terms for this file may be
+ * found in the file LICENSE in this distribution or at
+ * http://www.rtems.org/license/LICENSE.
+ */
+
+#include <bsp/console.h>
+#include <bsp.h>
+#include <bsp/irq.h>
+
+#include <rtems/bspIo.h>
+
+arm_pl011_context rvpbx_pl011_context = {
+  .base = RTEMS_TERMIOS_DEVICE_CONTEXT_INITIALIZER("PL011"),
+  .regs = (volatile pl011 *) 0x10009000,
+  .irq = RVPBXA9_IRQ_UART_0,
+  .initial_baud = 115200
+};
+
+static void output_char(char c)
+{
+  arm_pl011_write_polled(&rvpbx_pl011_context.base, c);
+}
+
+bool rvpbx_pl011_probe(rtems_termios_device_context *base)
+{
+  BSP_output_char = output_char;
+
+  return arm_pl011_probe(base);
+}
+
+static void output_char_init(char c)
+{
+  rvpbx_pl011_probe(&rvpbx_pl011_context.base);
+  output_char(c);
+}
+
+BSP_output_char_function_type BSP_output_char = output_char_init;
+
+BSP_polling_getchar_function_type BSP_poll_char = NULL;
diff --git a/bsps/arm/realview-pbx-a9/include/bsp/console.h b/bsps/arm/realview-pbx-a9/include/bsp/console.h
new file mode 100644
index 0000000..da2e409
--- /dev/null
+++ b/bsps/arm/realview-pbx-a9/include/bsp/console.h
@@ -0,0 +1,32 @@
+/*
+ * Copyright (c) 2018 embedded brains GmbH.  All rights reserved.
+ *
+ *  embedded brains GmbH
+ *  Dornierstr. 4
+ *  82178 Puchheim
+ *  Germany
+ *  <info at embedded-brains.de>
+ *
+ * The license and distribution terms for this file may be
+ * found in the file LICENSE in this distribution or at
+ * http://www.rtems.org/license/LICENSE.
+ */
+
+#ifndef LIBBSP_ARM_REALVIEW_PBX_A9_BSP_CONSOLE_H
+#define LIBBSP_ARM_REALVIEW_PBX_A9_BSP_CONSOLE_H
+
+#include <bsp/arm-pl011.h>
+
+#ifdef __cplusplus
+extern "C" {
+#endif /* __cplusplus */
+
+extern arm_pl011_context rvpbx_pl011_context;
+
+bool rvpbx_pl011_probe(rtems_termios_device_context *base);
+
+#ifdef __cplusplus
+}
+#endif /* __cplusplus */
+
+#endif /* LIBBSP_ARM_REALVIEW_PBX_A9_BSP_CONSOLE_H */
diff --git a/c/src/lib/libbsp/arm/realview-pbx-a9/Makefile.am b/c/src/lib/libbsp/arm/realview-pbx-a9/Makefile.am
index 4512d75..b6f2c02 100644
--- a/c/src/lib/libbsp/arm/realview-pbx-a9/Makefile.am
+++ b/c/src/lib/libbsp/arm/realview-pbx-a9/Makefile.am
@@ -65,6 +65,7 @@ librtemsbsp_a_SOURCES += ../../../../../../bsps/shared/dev/serial/getserialmouse
 librtemsbsp_a_SOURCES += ../../../../../../bsps/arm/shared/serial/arm-pl011.c
 librtemsbsp_a_SOURCES += ../../../../../../bsps/arm/shared/serial/arm-pl050.c
 librtemsbsp_a_SOURCES += ../../../../../../bsps/arm/realview-pbx-a9/console/console-config.c
+librtemsbsp_a_SOURCES += ../../../../../../bsps/arm/realview-pbx-a9/console/console-polled.c
 
 # Clock
 librtemsbsp_a_SOURCES += ../../../../../../bsps/arm/shared/clock/clock-a9mpcore.c



More information about the vc mailing list