ChibiOS
20.3.4
|
Generic SIO Driver. More...
Generic SIO Driver.
This driver abstracts a generic serial communication channel, usually an UART, this driver is similar to Serial and UART drivers but follows a different concept:
HAL_USE_SIO
option must be enabled in halconf.h
.The driver implements a state machine internally, not all the driver functionalities can be used in any moment, any transition not explicitly shown in the following diagram has to be considered an error and shall be captured by an assertion (if enabled).
Macros | |
#define | sioGetFlagsX(siop) sio_lld_get_flags(siop) |
Returns the current set of flags and clears it. More... | |
#define | sioRXIsEmptyX(siop) sio_lld_rx_is_empty(siop) |
Determines the state of the RX FIFO. More... | |
#define | sioTXIsFullX(siop) sio_lld_tx_is_full(siop) |
Determines the state of the TX FIFO. More... | |
#define | sioRXGetX(siop) sio_lld_rx_get(siop) |
Returns one frame from the RX FIFO. More... | |
#define | sioTXPutX(siop, data) sio_lld_tx_put(siop, data) |
Pushes one frame into the TX FIFO. More... | |
#define | sioReadX(siop, buffer, size) sio_lld_read(siop, buffer, size) |
Reads data from the RX FIFO. More... | |
#define | sioWriteX(siop, buffer, size) sio_lld_write(siop, buffer, size) |
Writes data into the TX FIFO. More... | |
#define | sioControlX(siop, operation, arg) sio_lld_control(siop, operation, arg) |
Control operation on a serial port. More... | |
#define | sio_lld_rx_is_empty(siop) true |
Determines the state of the RX FIFO. More... | |
#define | sio_lld_tx_is_full(siop) true |
Determines the state of the TX FIFO. More... | |
#define | sio_lld_rx_get(siop) |
Returns one frame from the RX FIFO. More... | |
#define | sio_lld_tx_put(siop, data) |
Pushes one frame into the TX FIFO. More... | |
SIO status flags | |
#define | SIO_NO_ERROR 0 |
No pending conditions. More... | |
#define | SIO_PARITY_ERROR 4 |
Parity error happened. More... | |
#define | SIO_FRAMING_ERROR 8 |
Framing error happened. More... | |
#define | SIO_OVERRUN_ERROR 16 |
Overflow happened. More... | |
#define | SIO_NOISE_ERROR 32 |
Noise on the line. More... | |
#define | SIO_BREAK_DETECTED 64 |
Break detected. More... | |
PLATFORM configuration options | |
#define | PLATFORM_SIO_USE_SIO1 FALSE |
SIO driver enable switch. More... | |
Typedefs | |
typedef struct hal_sio_driver | SIODriver |
Type of structure representing a SIO driver. More... | |
typedef struct hal_sio_config | SIOConfig |
Type of structure representing a SIO configuration. More... | |
typedef uint32_t | sioflags_t |
SIO driver condition flags type. More... | |
typedef void(* | siocb_t) (SIODriver *siop) |
Generic SIO notification callback type. More... | |
typedef void(* | sioecb_t) (SIODriver *siop, sioflags_t e) |
Receive error SIO notification callback type. More... | |
Data Structures | |
struct | hal_sio_config |
Driver configuration structure. More... | |
struct | hal_sio_driver |
Structure representing a SIO driver. More... | |
Functions | |
void | sioInit (void) |
SIO Driver initialization. More... | |
void | sioObjectInit (SIODriver *siop) |
Initializes the standard part of a SIODriver structure. More... | |
void | sioStart (SIODriver *siop, const SIOConfig *config) |
Configures and activates the SIO peripheral. More... | |
void | sioStop (SIODriver *siop) |
Deactivates the SIO peripheral. More... | |
void | sio_lld_init (void) |
Low level SIO driver initialization. More... | |
void | sio_lld_start (SIODriver *siop) |
Configures and activates the SIO peripheral. More... | |
void | sio_lld_stop (SIODriver *siop) |
Deactivates the SIO peripheral. More... | |
msg_t | sio_lld_control (SIODriver *siop, unsigned int operation, void *arg) |
Control operation on a serial port. More... | |
Enumerations | |
enum | siostate_t { SIO_UNINIT = 0, SIO_STOP = 1, SIO_READY = 2 } |
Driver state machine possible states. More... | |
Variables | |
SIODriver | SIOD1 |
SIO1 driver identifier. More... | |
#define sioGetFlagsX | ( | siop | ) | sio_lld_get_flags(siop) |
#define sioRXIsEmptyX | ( | siop | ) | sio_lld_rx_is_empty(siop) |
Determines the state of the RX FIFO.
[in] | siop | pointer to the SIODriver object |
false | if RX FIFO is not empty |
true | if RX FIFO is empty |
#define sioTXIsFullX | ( | siop | ) | sio_lld_tx_is_full(siop) |
Determines the state of the TX FIFO.
[in] | siop | pointer to the SIODriver object |
false | if TX FIFO is not full |
true | if TX FIFO is full |
#define sioRXGetX | ( | siop | ) | sio_lld_rx_get(siop) |
Returns one frame from the RX FIFO.
[in] | siop | pointer to the SIODriver object |
#define sioTXPutX | ( | siop, | |
data | |||
) | sio_lld_tx_put(siop, data) |
Pushes one frame into the TX FIFO.
[in] | siop | pointer to the SIODriver object |
[in] | data | frame to be written |
#define sioReadX | ( | siop, | |
buffer, | |||
size | |||
) | sio_lld_read(siop, buffer, size) |
Reads data from the RX FIFO.
This function is non-blocking, data is read if present and the effective amount is returned.
rxne_cb
callback handler.[in] | siop | pointer to the SIODriver object |
[in] | buffer | buffer for the received data |
[in] | size | maximum number of frames to read |
#define sioWriteX | ( | siop, | |
buffer, | |||
size | |||
) | sio_lld_write(siop, buffer, size) |
Writes data into the TX FIFO.
This function is non-blocking, data is written if there is space in the FIFO and the effective amount is returned.
txnf_cb
callback handler.[in] | siop | pointer to the SIODriver object |
[out] | buffer | buffer containing the data to be transmitted |
[in] | size | maximum number of frames to read |
#define sioControlX | ( | siop, | |
operation, | |||
arg | |||
) | sio_lld_control(siop, operation, arg) |
Control operation on a serial port.
[in] | siop | pointer to the SIODriver object |
[in] | operation | control operation code |
[in,out] | arg | operation argument |
MSG_OK | in case of success. |
MSG_TIMEOUT | in case of operation timeout. |
MSG_RESET | in case of operation reset. |
#define PLATFORM_SIO_USE_SIO1 FALSE |
SIO driver enable switch.
If set to TRUE
the support for SIO1 is included.
FALSE
. Definition at line 48 of file hal_sio_lld.h.
#define sio_lld_rx_is_empty | ( | siop | ) | true |
Determines the state of the RX FIFO.
[in] | siop | pointer to the SIODriver object |
false | if RX FIFO is not empty |
true | if RX FIFO is empty |
Definition at line 144 of file hal_sio_lld.h.
#define sio_lld_tx_is_full | ( | siop | ) | true |
Determines the state of the TX FIFO.
[in] | siop | pointer to the SIODriver object |
false | if TX FIFO is not full |
true | if TX FIFO is full |
Definition at line 156 of file hal_sio_lld.h.
#define sio_lld_rx_get | ( | siop | ) |
Returns one frame from the RX FIFO.
[in] | siop | pointer to the SIODriver object |
Definition at line 167 of file hal_sio_lld.h.
#define sio_lld_tx_put | ( | siop, | |
data | |||
) |
Pushes one frame into the TX FIFO.
[in] | siop | pointer to the SIODriver object |
[in] | data | frame to be written |
Definition at line 178 of file hal_sio_lld.h.
typedef struct hal_sio_driver SIODriver |
typedef struct hal_sio_config SIOConfig |
typedef uint32_t sioflags_t |
SIO driver condition flags type.
Definition at line 63 of file hal_sio_lld.h.
typedef void(* siocb_t) (SIODriver *siop) |
Generic SIO notification callback type.
[in] | siop | pointer to the SIODriver object |
Definition at line 70 of file hal_sio_lld.h.
typedef void(* sioecb_t) (SIODriver *siop, sioflags_t e) |
Receive error SIO notification callback type.
[in] | siop | pointer to the SIODriver object triggering the callback |
[in] | e | receive error mask |
Definition at line 79 of file hal_sio_lld.h.
enum siostate_t |
void sioInit | ( | void | ) |
SIO Driver initialization.
halInit()
, there is no need to explicitly initialize the driver.Definition at line 56 of file hal_sio.c.
References sio_lld_init().
void sioObjectInit | ( | SIODriver * | siop | ) |
Initializes the standard part of a SIODriver
structure.
[out] | siop | pointer to the SIODriver object |
Definition at line 68 of file hal_sio.c.
References hal_sio_driver::config, SIO_STOP, and hal_sio_driver::state.
Referenced by sio_lld_init().
Configures and activates the SIO peripheral.
[in] | siop | pointer to the SIODriver object |
[in] | config | pointer to the SIOConfig object |
Definition at line 87 of file hal_sio.c.
References hal_sio_driver::config, osalDbgAssert, osalDbgCheck, osalSysLock(), osalSysUnlock(), sio_lld_start(), SIO_READY, SIO_STOP, and hal_sio_driver::state.
void sioStop | ( | SIODriver * | siop | ) |
Deactivates the SIO peripheral.
[in] | siop | pointer to the SIODriver object |
Definition at line 108 of file hal_sio.c.
References hal_sio_driver::config, osalDbgAssert, osalDbgCheck, osalSysLock(), osalSysUnlock(), sio_lld_stop(), SIO_READY, SIO_STOP, and hal_sio_driver::state.
void sio_lld_init | ( | void | ) |
Low level SIO driver initialization.
Definition at line 65 of file hal_sio_lld.c.
References SIOD1, and sioObjectInit().
Referenced by sioInit().
void sio_lld_start | ( | SIODriver * | siop | ) |
Configures and activates the SIO peripheral.
[in] | siop | pointer to the SIODriver object |
Definition at line 80 of file hal_sio_lld.c.
References SIO_STOP, SIOD1, and hal_sio_driver::state.
Referenced by sioStart().
void sio_lld_stop | ( | SIODriver * | siop | ) |
Deactivates the SIO peripheral.
[in] | siop | pointer to the SIODriver object |
Definition at line 101 of file hal_sio_lld.c.
References SIO_READY, SIOD1, and hal_sio_driver::state.
Referenced by sioStop().
Control operation on a serial port.
[in] | siop | pointer to the SIODriver object |
[in] | operation | control operation code |
[in,out] | arg | operation argument |
MSG_OK | in case of success. |
MSG_TIMEOUT | in case of operation timeout. |
MSG_RESET | in case of operation reset. |
Definition at line 129 of file hal_sio_lld.c.
References MSG_OK.
SIODriver SIOD1 |
SIO1 driver identifier.
Definition at line 41 of file hal_sio_lld.c.
Referenced by sio_lld_init(), sio_lld_start(), and sio_lld_stop().