UART MUX 2 click
UART MUX 2 Click is a compact add-on board that enables pseudo-multidrop RS232 transmission. This board features the MAX399, a precise CMOS analog multiplexer that allows four remote RS-232 transceivers to share a single UART from Maxim Integrated. It offers fast switching speeds with a transition time of less than 250ns and low on-resistance less than 100Ω while retains CMOS-logic input compatibility and fast switching. Channel selection is performed through a set of specific GPIO pins and possesses additional functionality such as the manual ON/OFF feature.
click Product page
Click library
- Author : Nenad Filipovic
- Date : Jan 2021.
- Type : UART type
Software Support
We provide a library for the UartMux2 Click as well as a demo application (example), developed using MikroElektronika compilers. The demo can run on all the main MikroElektronika development boards.
Package can be downloaded/installed directly from NECTO Studio Package Manager(recommended way), downloaded from our LibStock™ or found on mikroE github account.
Library Description
This library contains API for UartMux2 Click driver.
Standard key functions :
uartmux2_cfg_setup
Config Object Initialization function.
void uartmux2_cfg_setup(uartmux2_cfg_t *cfg)
UART MUX 2 configuration object setup function.
UART MUX 2 Click configuration object.
Definition uartmux2.h:210
uartmux2_init
Initialization function.
err_t uartmux2_init(uartmux2_t *ctx, uartmux2_cfg_t *cfg)
UART MUX 2 initialization function.
UART MUX 2 Click context object.
Definition uartmux2.h:182
uartmux2_default_cfg
Click Default Configuration function.
void uartmux2_default_cfg(uartmux2_t *ctx)
UART MUX 2 default configuration function.
Example key functions :
uartmux2_set_operation_mode
UART MUX 2 set operation mode function.
err_t uartmux2_set_operation_mode(uartmux2_t *ctx, uint8_t op_mode)
UART MUX 2 set operation mode function.
uartmux2_set_channel
UART MUX 2 set channel function.
err_t uartmux2_set_channel(uartmux2_t *ctx, uint8_t mux_ch)
UART MUX 2 set channel function.
uartmux2_send_data
UART MUX 2 data writing function.
err_t uartmux2_send_data(uartmux2_t *ctx, char *tx_data)
UART MUX 2 data writing function.
Example Description
This library contains API for UART MUX 2 Click driver. This example transmits/receives and processes data from UART MUX 2 clicks. The library initializes and defines the UART bus drivers to transmit or receive data.
The demo application is composed of two sections :
Application Init
Initializes driver and set UART channel module.
log_cfg_t log_cfg;
LOG_MAP_USB_UART( log_cfg );
log_init( &logger, &log_cfg );
log_printf( &logger, "\r\n Application Init \r\n" );
if ( init_flag == UART_ERROR ) {
log_error( &logger, " Application Init Error. " );
log_info( &logger, " Please, run program again... " );
for ( ; ; );
}
app_buf_len = 0;
app_buf_cnt = 0;
log_printf( &logger, "\r\n Application Task \r\n" );
log_printf( &logger, "------------------\r\n" );
Delay_ms ( 500 );
#ifdef TRANSMITTER
log_printf( &logger, " Send data: \r\n" );
log_printf( &logger, " mikroE \r\n" );
log_printf( &logger, "------------------\r\n" );
log_printf( &logger, " Transmit data \r\n" );
Delay_ms ( 1000 );
#endif
#ifdef RECIEVER
log_printf( &logger, " Receive data \r\n" );
log_printf( &logger, " UART%u \r\n", ( uint16_t ) uart_ch );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
#endif
log_printf( &logger, "------------------\r\n" );
}
#define UARTMUX2_CHANNEL_0
UART MUX 2 select channel.
Definition uartmux2.h:143
#define UARTMUX2_MAP_MIKROBUS(cfg, mikrobus)
MikroBUS pin mapping.
Definition uartmux2.h:165
void application_init(void)
Definition main.c:68
Application Task
Transmitter/Receiver task depend on uncommented code. Receiver logging each received byte to the UART for data logging, while transmitted send messages every 2 seconds.
#ifdef TRANSMITTER
Delay_ms ( 100 );
log_printf( &logger, " UART%u : ", ( uint16_t ) uart_ch );
for ( uint8_t cnt = 0; cnt < 9; cnt ++ ) {
Delay_ms ( 100 );
}
Delay_ms ( 1000 );
Delay_ms ( 1000 );
}
log_printf( &logger, "------------------\r\n" );
Delay_ms ( 100 );
#endif
#ifdef RECIEVER
uartmux2_process( );
if ( app_buf_len > 0 ) {
log_printf( &logger, "%s", app_buf );
uartmux2_clear_app_buf( );
}
#endif
}
#define UARTMUX2_CHANNEL_3
Definition uartmux2.h:146
unsigned char demo_message[9]
Definition main.c:46
void application_task(void)
Definition main.c:128
The full application code, and ready to use projects can be installed directly from NECTO Studio Package Manager(recommended way), downloaded from our LibStock™ or found on mikroE github account.
Other mikroE Libraries used in the example:
- MikroSDK.Board
- MikroSDK.Log
- Click.UartMux2
Additional notes and informations
Depending on the development board you are using, you may need USB UART click, USB UART 2 Click or RS232 Click to connect to your PC, for development systems with no UART to USB interface available on the board. UART terminal is available in all Mikroelektronika compilers.