20 #ifndef MBED_SERIAL_API_H    21 #define MBED_SERIAL_API_H    25 #include "hal/buffer.h"    26 #include "hal/dma_api.h"    30 #define SERIAL_EVENT_TX_SHIFT (2)    31 #define SERIAL_EVENT_RX_SHIFT (8)    33 #define SERIAL_EVENT_TX_MASK (0x00FC)    34 #define SERIAL_EVENT_RX_MASK (0x3F00)    36 #define SERIAL_EVENT_ERROR (1 << 1)    43 #define SERIAL_EVENT_TX_COMPLETE (1 << (SERIAL_EVENT_TX_SHIFT + 0))    44 #define SERIAL_EVENT_TX_ALL      (SERIAL_EVENT_TX_COMPLETE)    52 #define SERIAL_EVENT_RX_COMPLETE        (1 << (SERIAL_EVENT_RX_SHIFT + 0))    53 #define SERIAL_EVENT_RX_OVERRUN_ERROR   (1 << (SERIAL_EVENT_RX_SHIFT + 1))    54 #define SERIAL_EVENT_RX_FRAMING_ERROR   (1 << (SERIAL_EVENT_RX_SHIFT + 2))    55 #define SERIAL_EVENT_RX_PARITY_ERROR    (1 << (SERIAL_EVENT_RX_SHIFT + 3))    56 #define SERIAL_EVENT_RX_OVERFLOW        (1 << (SERIAL_EVENT_RX_SHIFT + 4))    57 #define SERIAL_EVENT_RX_CHARACTER_MATCH (1 << (SERIAL_EVENT_RX_SHIFT + 5))    58 #define SERIAL_EVENT_RX_ALL             (SERIAL_EVENT_RX_OVERFLOW | SERIAL_EVENT_RX_PARITY_ERROR | \    59                                          SERIAL_EVENT_RX_FRAMING_ERROR | SERIAL_EVENT_RX_OVERRUN_ERROR | \    60                                          SERIAL_EVENT_RX_COMPLETE | SERIAL_EVENT_RX_CHARACTER_MATCH)    63 #define SERIAL_RESERVED_CHAR_MATCH (255)    85 typedef void (*uart_irq_handler)(uint32_t id, SerialIrq event);
    87 #if DEVICE_SERIAL_ASYNCH    91     struct serial_s serial;  
   260 #if DEVICE_SERIAL_ASYNCH   281 int serial_tx_asynch(
serial_t *obj, 
const void *tx, 
size_t tx_length, uint8_t tx_width, uint32_t handler, uint32_t event, DMAUsage hint);
   296 void serial_rx_asynch(
serial_t *obj, 
void *rx, 
size_t rx_length, uint8_t rx_width, uint32_t handler, uint32_t event, uint8_t char_match, DMAUsage hint);
 const PinMap * serial_tx_pinmap(void)
Get the pins that support Serial TX. 
void serial_baud(serial_t *obj, int baudrate)
Configure the baud rate. 
Generic buffer structure. 
void serial_tx_abort_asynch(serial_t *obj)
Abort the ongoing TX transaction. 
void serial_break_clear(serial_t *obj)
Clear the break. 
void serial_rx_asynch(serial_t *obj, void *rx, size_t rx_length, uint8_t rx_width, uint32_t handler, uint32_t event, uint8_t char_match, DMAUsage hint)
Begin asynchronous RX transfer (enable interrupt for data collecting) The used buffer is specified in...
int serial_writable(serial_t *obj)
Check if the serial peripheral is writable. 
int serial_getc(serial_t *obj)
Get character. 
const PinMap * serial_cts_pinmap(void)
Get the pins that support Serial CTS. 
int serial_irq_handler_asynch(serial_t *obj)
The asynchronous TX and RX handler. 
uint8_t char_match
Character to be matched. 
void serial_format(serial_t *obj, int data_bits, SerialParity parity, int stop_bits)
Configure the format. 
void serial_free(serial_t *obj)
Release the serial peripheral, not currently invoked. 
void serial_rx_abort_asynch(serial_t *obj)
Abort the ongoing RX transaction. 
void serial_init(serial_t *obj, PinName tx, PinName rx)
Initialize the serial peripheral. 
void serial_irq_handler(serial_t *obj, uart_irq_handler handler, uint32_t id)
The serial interrupt handler registration. 
const PinMap * serial_rts_pinmap(void)
Get the pins that support Serial RTS. 
void serial_irq_set(serial_t *obj, SerialIrq irq, uint32_t enable)
Configure serial interrupt. 
const PinMap * serial_rx_pinmap(void)
Get the pins that support Serial RX. 
void serial_set_flow_control(serial_t *obj, FlowControl type, PinName rxflow, PinName txflow)
Configure the serial for the flow control. 
Asynch serial HAL structure. 
uint8_t serial_rx_active(serial_t *obj)
Attempts to determine if the serial peripheral is already in use for RX. 
uint8_t char_found
State of the matched character. 
int serial_tx_asynch(serial_t *obj, const void *tx, size_t tx_length, uint8_t tx_width, uint32_t handler, uint32_t event, DMAUsage hint)
Begin asynchronous TX transfer. 
void serial_clear(serial_t *obj)
Clear the serial peripheral. 
void serial_break_set(serial_t *obj)
Set the break. 
void serial_pinout_tx(PinName tx)
Configure the TX pin for UART function. 
uint8_t serial_tx_active(serial_t *obj)
Attempts to determine if the serial peripheral is already in use for TX. 
void serial_putc(serial_t *obj, int c)
Send a character. 
int serial_readable(serial_t *obj)
Check if the serial peripheral is readable.