summaryrefslogtreecommitdiffstats
path: root/c/src/lib/libbsp/powerpc/gen83xx/console/console-config.c
diff options
context:
space:
mode:
authorSebastian Huber <sebastian.huber@embedded-brains.de>2010-11-12 14:16:57 +0000
committerSebastian Huber <sebastian.huber@embedded-brains.de>2010-11-12 14:16:57 +0000
commit8a54204379574c12af94a9491a91cf59a5857e22 (patch)
tree8000c0ad4c8734fc33326e0d37abd5c12f10d80f /c/src/lib/libbsp/powerpc/gen83xx/console/console-config.c
parent2010-11-12 Sebastian Huber <sebastian.huber@embedded-brains.de> (diff)
downloadrtems-8a54204379574c12af94a9491a91cf59a5857e22.tar.bz2
2010-11-12 Sebastian Huber <sebastian.huber@embedded-brains.de>
* console/console.h, console/console.c, console/config.c, console/ns16550cfg.c: Removed files. * console/console-config.c: New file. * Makefile.am: Reflect changes above. * configure.ac: New BSP options. * include/bsp.h: Use new BSP options. * network/network.c: Avoid memory leak. * startup/bspstart.c: Initialize console port table. * spi/spi_init.c: Update for SD card API changes.
Diffstat (limited to 'c/src/lib/libbsp/powerpc/gen83xx/console/console-config.c')
-rw-r--r--c/src/lib/libbsp/powerpc/gen83xx/console/console-config.c118
1 files changed, 118 insertions, 0 deletions
diff --git a/c/src/lib/libbsp/powerpc/gen83xx/console/console-config.c b/c/src/lib/libbsp/powerpc/gen83xx/console/console-config.c
new file mode 100644
index 0000000000..99317e5a45
--- /dev/null
+++ b/c/src/lib/libbsp/powerpc/gen83xx/console/console-config.c
@@ -0,0 +1,118 @@
+/**
+ * @file
+ *
+ * @brief Console configuration.
+ */
+
+/*
+ * Copyright (c) 2008, 2010 embedded brains GmbH. All rights reserved.
+ *
+ * embedded brains GmbH
+ * Obere Lagerstr. 30
+ * 82178 Puchheim
+ * Germany
+ * <rtems@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.com/license/LICENSE.
+ */
+
+#include <rtems/bspIo.h>
+
+#include <libchip/serial.h>
+#include <libchip/ns16550.h>
+
+#include <mpc83xx/mpc83xx.h>
+
+#include <bspopts.h>
+#include <bsp/irq.h>
+
+#ifdef BSP_USE_UART2
+ #define PORT_COUNT 2
+#else
+ #define PORT_COUNT 1
+#endif
+
+#ifdef BSP_USE_UART_INTERRUPTS
+ #define DEVICE_FNS &ns16550_fns
+#else
+ #define DEVICE_FNS &ns16550_fns_polled
+#endif
+
+static uint8_t gen83xx_console_get_register(uint32_t addr, uint8_t i)
+{
+ volatile uint8_t *reg = (volatile uint8_t *) addr;
+
+ return reg [i];
+}
+
+static void gen83xx_console_set_register(uint32_t addr, uint8_t i, uint8_t val)
+{
+ volatile uint8_t *reg = (volatile uint8_t *) addr;
+
+ reg [i] = val;
+}
+
+unsigned long Console_Port_Count = PORT_COUNT;
+
+rtems_device_minor_number Console_Port_Minor = 0;
+
+console_data Console_Port_Data [PORT_COUNT];
+
+console_tbl Console_Port_Tbl [PORT_COUNT] = {
+ {
+ .sDeviceName = "/dev/ttyS0",
+ .deviceType = SERIAL_NS16550,
+ .pDeviceFns = DEVICE_FNS,
+ .deviceProbe = NULL,
+ .pDeviceFlow = NULL,
+ .ulMargin = 16,
+ .ulHysteresis = 8,
+ .pDeviceParams = (void *) BSP_CONSOLE_BAUD,
+ .ulCtrlPort1 = (uint32_t) &mpc83xx.duart [0],
+ .ulCtrlPort2 = 0,
+ .ulDataPort = (uint32_t) &mpc83xx.duart [0],
+ .getRegister = gen83xx_console_get_register,
+ .setRegister = gen83xx_console_set_register,
+ .getData = NULL,
+ .setData = NULL,
+ .ulClock = 0,
+ .ulIntVector = BSP_IPIC_IRQ_UART1
+ }
+#ifdef BSP_USE_UART2
+ , {
+ .sDeviceName = "/dev/ttyS1",
+ .deviceType = SERIAL_NS16550,
+ .pDeviceFns = DEVICE_FNS,
+ .deviceProbe = NULL,
+ .pDeviceFlow = NULL,
+ .ulMargin = 16,
+ .ulHysteresis = 8,
+ .pDeviceParams = (void *) BSP_CONSOLE_BAUD,
+ .ulCtrlPort1 = (uint32_t) &mpc83xx.duart [1],
+ .ulCtrlPort2 = 0,
+ .ulDataPort = (uint32_t) &mpc83xx.duart [1],
+ .getRegister = gen83xx_console_get_register,
+ .setRegister = gen83xx_console_set_register,
+ .getData = NULL,
+ .setData = NULL,
+ .ulClock = 0,
+ .ulIntVector = BSP_IPIC_IRQ_UART2
+ }
+#endif
+};
+
+static void gen83xx_output_char(char c)
+{
+ const console_fns *console = Console_Port_Tbl [Console_Port_Minor].pDeviceFns;
+
+ if (c == '\n') {
+ console->deviceWritePolled((int) Console_Port_Minor, '\r');
+ }
+ console->deviceWritePolled((int) Console_Port_Minor, c);
+}
+
+BSP_output_char_function_type BSP_output_char = gen83xx_output_char;
+
+BSP_polling_getchar_function_type BSP_poll_char = NULL;