File indexing completed on 2025-05-11 08:23:39
0001
0002
0003
0004
0005
0006
0007
0008
0009
0010
0011
0012
0013
0014
0015
0016
0017
0018
0019
0020
0021
0022
0023
0024
0025
0026
0027
0028
0029
0030
0031
0032
0033 #include <rtems/console.h>
0034 #include <rtems/bspIo.h>
0035 #include <rtems/termiostypes.h>
0036
0037 #include <bsp/irq.h>
0038 #include <dev/serial/zynq-uart.h>
0039 #include <dev/serial/zynq-uart-regs.h>
0040
0041 #include <bspopts.h>
0042
0043 static zynq_uart_context zynqmp_uart_instances[2] = {
0044 {
0045 .base = RTEMS_TERMIOS_DEVICE_CONTEXT_INITIALIZER( "Zynq UART 0" ),
0046 .regs = (volatile zynq_uart *) ZYNQ_UART_0_BASE_ADDR,
0047 .irq = ZYNQMP_IRQ_UART_0
0048 }, {
0049 .base = RTEMS_TERMIOS_DEVICE_CONTEXT_INITIALIZER( "Zynq UART 1" ),
0050 .regs = (volatile zynq_uart *) ZYNQ_UART_1_BASE_ADDR,
0051 .irq = ZYNQMP_IRQ_UART_1
0052 }
0053 };
0054
0055 rtems_status_code console_initialize(
0056 rtems_device_major_number major,
0057 rtems_device_minor_number minor,
0058 void *arg
0059 )
0060 {
0061 size_t i;
0062
0063 rtems_termios_initialize();
0064
0065 for (i = 0; i < RTEMS_ARRAY_SIZE(zynqmp_uart_instances); ++i) {
0066 zynq_uart_context *ctx = &zynqmp_uart_instances[i];
0067 char uart[] = "/dev/ttySX";
0068
0069 uart[sizeof(uart) - 2] = (char) ('0' + i);
0070 rtems_termios_device_install(
0071 &uart[0],
0072 &zynq_uart_handler,
0073 NULL,
0074 &ctx->base
0075 );
0076
0077 if (ctx->regs == (zynq_uart *) ZYNQ_UART_KERNEL_IO_BASE_ADDR) {
0078 link(&uart[0], CONSOLE_DEVICE_NAME);
0079 }
0080 }
0081
0082 return RTEMS_SUCCESSFUL;
0083 }
0084
0085 void zynqmp_debug_console_flush(void)
0086 {
0087 zynq_uart_reset_tx_flush((zynq_uart *) ZYNQ_UART_KERNEL_IO_BASE_ADDR);
0088 }