Skip to content

UART

A universal asynchronous receiver-transmitter (UART) is a peripheral device for asynchronous serial communication.

MiraOS supports independent operation of multiple UARTs.

Defines

Name Value Description
MIRA_IODEF_UART0 { miraint_uart_read, miraint_uart_write, 0 }
MIRA_IODEF_UART1 { miraint_uart_read, miraint_uart_write, 1 }
MIRA_IODEF_UART2 { miraint_uart_read, miraint_uart_write, 2 }
MIRA_IODEF_UART(_ID) { miraint_uart_read, miraint_uart_write, (_ID) }

Types

Name Type Description
mira_uart_input_callback_t int(*)(uint8_t c, void *storage)

Enums

mira_uart_parity_t

Name Value Description
MIRA_UART_PARITY_NONE
MIRA_UART_PARITY_EVEN
MIRA_UART_PARITY_ODD

Structs

mira_uart_config_t

Type Name Description
int32_t baudrate
mira_gpio_pin_t tx_pin Pin to use as TXD
mira_gpio_pin_t rx_pin Pin to use as RXD
mira_uart_parity_t parity

Functions

mira_uart_init

mira_status_t mira_uart_init(
    uint8_t                    uart_id,
    const mira_uart_config_t*  config);

Initialize a UART module.

The custom config is passed as a parameter (NULL for platform default).

Note: this might start a higher resolution clock in the CPU, which can significantly increase the power consumption until CPU is restarted. Only UART 0 is supported.

Parameters

Parameter Description
uart_id The index of the UART peripheral.
config Pointer to a configuration to setup.

Return

See the enum definition.

Value Description
MIRA_SUCCESS UART was successfully initialized.
MIRA_UART_ERROR_INIT UART could not initialize.
MIRA_ERROR_NOT_SUPPORTED Invalid UART id.

mira_uart_set_input_callback

mira_status_t mira_uart_set_input_callback(
    uint8_t                     uart_id,
    mira_uart_input_callback_t  cb,
    void*                       storage);

Set a callback to be called on uart byte input.

Parameters

Parameter Description
uart_id The index of the UART peripheral.
cb The callback to call.
storage Storage pointer which is used to store optional information to be used by the callback function. E.g. it could be used as an identifier or to pass on a configuration struct.

Return

See the enum definition.

Value Description
MIRA_SUCCESS The callback was successfully set.