Lines Matching full:uart
3 * ARC On-Chip(fpga) UART Driver
17 * -New Serial Core based ARC UART driver
37 * ARC UART Hardware Specs
42 * UART Register set (this is not a Standards Compliant IP)
54 /* Bits for UART Status Reg (R/W) */
67 /* Uart bit fiddling helpers: lowest level */
75 /* Uart bit fiddling helpers: API level */
76 #define UART_SET_DATA(uart, val) UART_REG_SET(uart, R_DATA, val) argument
77 #define UART_GET_DATA(uart) UART_REG_GET(uart, R_DATA) argument
79 #define UART_SET_BAUDH(uart, val) UART_REG_SET(uart, R_BAUDH, val) argument
80 #define UART_SET_BAUDL(uart, val) UART_REG_SET(uart, R_BAUDL, val) argument
82 #define UART_CLR_STATUS(uart, val) UART_REG_CLR(uart, R_STS, val) argument
83 #define UART_GET_STATUS(uart) UART_REG_GET(uart, R_STS) argument
85 #define UART_ALL_IRQ_DISABLE(uart) UART_REG_CLR(uart, R_STS, RXIENB|TXIENB) argument
86 #define UART_RX_IRQ_DISABLE(uart) UART_REG_CLR(uart, R_STS, RXIENB) argument
87 #define UART_TX_IRQ_DISABLE(uart) UART_REG_CLR(uart, R_STS, TXIENB) argument
89 #define UART_ALL_IRQ_ENABLE(uart) UART_REG_OR(uart, R_STS, RXIENB|TXIENB) argument
90 #define UART_RX_IRQ_ENABLE(uart) UART_REG_OR(uart, R_STS, RXIENB) argument
91 #define UART_TX_IRQ_ENABLE(uart) UART_REG_OR(uart, R_STS, TXIENB) argument
108 #define DRIVER_NAME "arc-uart"
202 * UART has 4 deep RX-FIFO. Driver's recongnition of this fact in arc_serial_rx_chars()
247 * to keep things simple as well as efficient, it writes to UART in polled
259 * -writes-data-to-uart
280 * notifications from the UART Controller. in arc_serial_isr()
328 /* ARC UART doesn't support sending Break signal */ in arc_serial_break_ctl()
333 /* Before we hook up the ISR, Disable all UART Interrupts */ in arc_serial_startup()
336 if (request_irq(port->irq, arc_serial_isr, 0, "arc uart rx-tx", port)) { in arc_serial_startup()
337 dev_warn(port->dev, "Unable to attach ARC UART intr\n"); in arc_serial_startup()
356 struct arc_uart_port *uart = to_arc_port(port); in arc_serial_set_termios() local
364 * Formula for ARC UART is: hw-val = ((CLK/(BAUD*4)) -1) in arc_serial_set_termios()
369 hw_val = port->uartclk / (uart->baud * 4) - 1; in arc_serial_set_termios()
383 * UART doesn't support Parity/Hardware Flow Control; in arc_serial_set_termios()
494 * The uart port backing the console (e.g. ttyARC1) might not have been in arc_serial_console_setup()
570 OF_EARLYCON_DECLARE(arc_uart, "snps,arc-uart", arc_early_console_setup);
577 struct arc_uart_port *uart; in arc_serial_probe() local
595 uart = &arc_uart_ports[dev_id]; in arc_serial_probe()
596 port = &uart->port; in arc_serial_probe()
608 uart->baud = val; in arc_serial_probe()
612 /* No point of dev_err since UART itself is hosed here */ in arc_serial_probe()
642 { .compatible = "snps,arc-uart" },