Patrick Georgi | ac95903 | 2020-05-05 22:49:26 +0200 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0-only */ |
Julius Werner | 90f025b2 | 2018-04-24 16:39:20 -0700 | [diff] [blame] | 2 | |
| 3 | #include <console/uart.h> |
| 4 | #include <gpio.h> |
Julius Werner | 90f025b2 | 2018-04-24 16:39:20 -0700 | [diff] [blame] | 5 | |
| 6 | #define UART_TX_PIN GPIO(4) |
| 7 | |
| 8 | static void set_tx(int line_state) |
| 9 | { |
| 10 | gpio_set(UART_TX_PIN, line_state); |
| 11 | } |
| 12 | |
Felix Held | e3a1247 | 2020-09-11 15:47:09 +0200 | [diff] [blame] | 13 | void uart_init(unsigned int idx) |
Julius Werner | 90f025b2 | 2018-04-24 16:39:20 -0700 | [diff] [blame] | 14 | { |
| 15 | gpio_output(UART_TX_PIN, 1); |
| 16 | } |
| 17 | |
Felix Held | e3a1247 | 2020-09-11 15:47:09 +0200 | [diff] [blame] | 18 | void uart_tx_byte(unsigned int idx, unsigned char data) |
Julius Werner | 90f025b2 | 2018-04-24 16:39:20 -0700 | [diff] [blame] | 19 | { |
| 20 | uart_bitbang_tx_byte(data, set_tx); |
| 21 | } |
| 22 | |
Felix Held | e3a1247 | 2020-09-11 15:47:09 +0200 | [diff] [blame] | 23 | void uart_tx_flush(unsigned int idx) |
Julius Werner | 90f025b2 | 2018-04-24 16:39:20 -0700 | [diff] [blame] | 24 | { |
| 25 | /* unnecessary, PIO Tx means transaction is over when tx_byte returns */ |
| 26 | } |
| 27 | |
Felix Held | e3a1247 | 2020-09-11 15:47:09 +0200 | [diff] [blame] | 28 | unsigned char uart_rx_byte(unsigned int idx) |
Julius Werner | 90f025b2 | 2018-04-24 16:39:20 -0700 | [diff] [blame] | 29 | { |
| 30 | return 0; /* not implemented */ |
| 31 | } |