Hardware UART API. More...
Macros | |
#define | UART_NUM(uart) |
Returns the UART number for a UART instance. More... | |
#define | UART_INSTANCE(num) |
Returns the UART instance with the given UART number. More... | |
#define | UART_DREQ_NUM(uart, is_tx) |
Returns the dreq_num_t used for pacing DMA transfers to or from this UART instance. If is_tx is true, then it is for transfers to the UART else for transfers from the UART. More... | |
#define | UART_CLOCK_NUM(uart) |
Returns clock_num_t of the clock for the given UART instance. More... | |
#define | UART_FUNCSEL_NUM(uart, gpio) |
Returns gpio_function_t needed to select the UART function for the given UART instance on the given GPIO number. More... | |
#define | UART_IRQ_NUM(uart) |
Returns the irq_num_t for processor interrupts from the given UART instance. More... | |
#define | UART_RESET_NUM(uart) |
Returns the reset_num_t used to reset a given UART instance. More... | |
Enumerations | |
enum | uart_parity_t { UART_PARITY_NONE , UART_PARITY_EVEN , UART_PARITY_ODD } |
UART Parity enumeration. | |
Functions | |
static uint | uart_get_index (uart_inst_t *uart) |
Convert UART instance to hardware instance number. More... | |
static uart_inst_t * | uart_get_instance (uint num) |
Get the UART instance from an instance number. More... | |
static uart_hw_t * | uart_get_hw (uart_inst_t *uart) |
Get the real hardware UART instance from a UART instance. More... | |
uint | uart_init (uart_inst_t *uart, uint baudrate) |
Initialise a UART. More... | |
void | uart_deinit (uart_inst_t *uart) |
DeInitialise a UART. More... | |
uint | uart_set_baudrate (uart_inst_t *uart, uint baudrate) |
Set UART baud rate. More... | |
static void | uart_set_hw_flow (uart_inst_t *uart, bool cts, bool rts) |
Set UART flow control CTS/RTS. More... | |
void | uart_set_format (uart_inst_t *uart, uint data_bits, uint stop_bits, uart_parity_t parity) |
Set UART data format. More... | |
static void | uart_set_irqs_enabled (uart_inst_t *uart, bool rx_has_data, bool tx_needs_data) |
Enable/Disable UART interrupt outputs. More... | |
static bool | uart_is_enabled (uart_inst_t *uart) |
Test if specific UART is enabled. More... | |
void | uart_set_fifo_enabled (uart_inst_t *uart, bool enabled) |
Enable/Disable the FIFOs on specified UART. More... | |
static bool | uart_is_writable (uart_inst_t *uart) |
Determine if space is available in the TX FIFO. More... | |
static void | uart_tx_wait_blocking (uart_inst_t *uart) |
Wait for the UART TX fifo to be drained. More... | |
static bool | uart_is_readable (uart_inst_t *uart) |
Determine whether data is waiting in the RX FIFO. More... | |
static void | uart_write_blocking (uart_inst_t *uart, const uint8_t *src, size_t len) |
Write to the UART for transmission. More... | |
static void | uart_read_blocking (uart_inst_t *uart, uint8_t *dst, size_t len) |
Read from the UART. More... | |
static void | uart_putc_raw (uart_inst_t *uart, char c) |
Write single character to UART for transmission. More... | |
static void | uart_putc (uart_inst_t *uart, char c) |
Write single character to UART for transmission, with optional CR/LF conversions. More... | |
static void | uart_puts (uart_inst_t *uart, const char *s) |
Write string to UART for transmission, doing any CR/LF conversions. More... | |
static char | uart_getc (uart_inst_t *uart) |
Read a single character from the UART. More... | |
void | uart_set_break (uart_inst_t *uart, bool en) |
Assert a break condition on the UART transmission. More... | |
void | uart_set_translate_crlf (uart_inst_t *uart, bool translate) |
Set CR/LF conversion on UART. More... | |
static void | uart_default_tx_wait_blocking (void) |
Wait for the default UART's TX FIFO to be drained. | |
bool | uart_is_readable_within_us (uart_inst_t *uart, uint32_t us) |
Wait for up to a certain number of microseconds for the RX FIFO to be non empty. More... | |
static uint | uart_get_dreq_num (uart_inst_t *uart, bool is_tx) |
Return the dreq_num_t to use for pacing transfers to/from a particular UART instance. More... | |
static uint | uart_get_reset_num (uart_inst_t *uart) |
Return the reset_num_t to use for pacing transfers to/from a particular UART instance. More... | |
#define | uart0 ((uart_inst_t *)uart0_hw) |
Identifier for UART instance 0. More... | |
#define | uart1 ((uart_inst_t *)uart1_hw) |
Identifier for UART instance 1. | |
Hardware UART API.
RP-series microcontrollers have 2 identical instances of a UART peripheral, based on the ARM PL011. Each UART can be connected to a number of GPIO pins as defined in the GPIO muxing.
Only the TX, RX, RTS, and CTS signals are connected, meaning that the modem mode and IrDA mode of the PL011 are not supported.
#define uart0 ((uart_inst_t *)uart0_hw) |
Identifier for UART instance 0.
The UART identifiers for use in UART functions.
e.g. uart_init(uart1, 48000)
#define UART_CLOCK_NUM | ( | uart | ) |
Returns clock_num_t of the clock for the given UART instance.
Note this macro is intended to resolve at compile time, and does no parameter checking
#define UART_DREQ_NUM | ( | uart, | |
is_tx | |||
) |
Returns the dreq_num_t used for pacing DMA transfers to or from this UART instance. If is_tx is true, then it is for transfers to the UART else for transfers from the UART.
Note this macro is intended to resolve at compile time, and does no parameter checking
#define UART_FUNCSEL_NUM | ( | uart, | |
gpio | |||
) |
Returns gpio_function_t needed to select the UART function for the given UART instance on the given GPIO number.
Note this macro is intended to resolve at compile time, and does no parameter checking
#define UART_INSTANCE | ( | num | ) |
Returns the UART instance with the given UART number.
Note this macro is intended to resolve at compile time, and does no parameter checking
#define UART_IRQ_NUM | ( | uart | ) |
Returns the irq_num_t for processor interrupts from the given UART instance.
Note this macro is intended to resolve at compile time, and does no parameter checking
#define UART_NUM | ( | uart | ) |
Returns the UART number for a UART instance.
Note this macro is intended to resolve at compile time, and does no parameter checking
#define UART_RESET_NUM | ( | uart | ) |
Returns the reset_num_t used to reset a given UART instance.
Note this macro is intended to resolve at compile time, and does no parameter checking
void uart_deinit | ( | uart_inst_t * | uart | ) |
|
inlinestatic |
Return the dreq_num_t to use for pacing transfers to/from a particular UART instance.
|
inlinestatic |
Get the real hardware UART instance from a UART instance.
This extra level of abstraction was added to facilitate adding PIO UARTs in the future. It currently does nothing, and costs nothing.
uart | UART instance |
|
inlinestatic |
Convert UART instance to hardware instance number.
uart | UART instance |
|
inlinestatic |
Get the UART instance from an instance number.
uart | UART instance |
|
inlinestatic |
Return the reset_num_t to use for pacing transfers to/from a particular UART instance.
|
inlinestatic |
uint uart_init | ( | uart_inst_t * | uart, |
uint | baudrate | ||
) |
Initialise a UART.
Put the UART into a known state, and enable it. Must be called before other functions.
This function always enables the FIFOs, and configures the UART for the following default line format:
|
inlinestatic |
|
inlinestatic |
bool uart_is_readable_within_us | ( | uart_inst_t * | uart, |
uint32_t | us | ||
) |
|
inlinestatic |
|
inlinestatic |
|
inlinestatic |
|
inlinestatic |
|
inlinestatic |
uint uart_set_baudrate | ( | uart_inst_t * | uart, |
uint | baudrate | ||
) |
Set UART baud rate.
Set baud rate as close as possible to requested, and return actual rate selected.
The UART is paused for around two character periods whilst the settings are changed. Data received during this time may be dropped by the UART.
Any characters still in the transmit buffer will be sent using the new updated baud rate. uart_tx_wait_blocking() can be called before this function to ensure all characters at the old baud rate have been sent before the rate is changed.
This function should not be called from an interrupt context, and the UART interrupt should be disabled before calling this function.
void uart_set_break | ( | uart_inst_t * | uart, |
bool | en | ||
) |
void uart_set_fifo_enabled | ( | uart_inst_t * | uart, |
bool | enabled | ||
) |
Enable/Disable the FIFOs on specified UART.
The UART is paused for around two character periods whilst the settings are changed. Data received during this time may be dropped by the UART.
Any characters still in the transmit FIFO will be lost if the FIFO is disabled. uart_tx_wait_blocking() can be called before this function to avoid this.
This function should not be called from an interrupt context, and the UART interrupt should be disabled when calling this function.
void uart_set_format | ( | uart_inst_t * | uart, |
uint | data_bits, | ||
uint | stop_bits, | ||
uart_parity_t | parity | ||
) |
Set UART data format.
Configure the data format (bits etc) for the UART.
The UART is paused for around two character periods whilst the settings are changed. Data received during this time may be dropped by the UART.
Any characters still in the transmit buffer will be sent using the new updated data format. uart_tx_wait_blocking() can be called before this function to ensure all characters needing the old format have been sent before the format is changed.
This function should not be called from an interrupt context, and the UART interrupt should be disabled before calling this function.
|
inlinestatic |
|
inlinestatic |
Enable/Disable UART interrupt outputs.
Enable/Disable the UART's interrupt outputs. An interrupt handler should be installed prior to calling this function.
void uart_set_translate_crlf | ( | uart_inst_t * | uart, |
bool | translate | ||
) |
|
inlinestatic |
|
inlinestatic |
Write to the UART for transmission.
This function will block until all the data has been sent to the UART transmit buffer hardware. Note: Serial data transmission will continue until the Tx FIFO and the transmit shift register (not programmer-accessible) are empty. To ensure the UART FIFO has been emptied, you can use uart_tx_wait_blocking()