CuVoodoo STM32F1 firmware template
busvoodoo_uart_generic.h
Go to the documentation of this file.
1 /* This program is free software: you can redistribute it and/or modify
2  * it under the terms of the GNU General Public License as published by
3  * the Free Software Foundation, either version 3 of the License, or
4  * (at your option) any later version.
5  *
6  * This program is distributed in the hope that it will be useful,
7  * but WITHOUT ANY WARRANTY; without even the implied warranty of
8  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
9  * GNU General Public License for more details.
10  *
11  * You should have received a copy of the GNU General Public License
12  * along with this program. If not, see <http://www.gnu.org/licenses/>.
13  *
14  */
24  uint32_t usart;
25  uint32_t usart_rcc;
26  uint32_t usart_rst;
27  bool multidrive;
28  uint32_t tx_port;
29  uint32_t tx_pin;
30  uint32_t tx_rcc;
31  void (*tx_pre)(void);
32  void (*tx_post)(void);
33  uint32_t rx_port;
34  uint32_t rx_pin;
35  uint32_t rx_rcc;
36  void (*rx_pre)(void);
37  void (*rx_post)(void);
38  bool hwflowctl;
39  uint32_t rts_port;
40  uint32_t rts_pin;
41  uint32_t rts_rcc;
42  uint32_t cts_port;
43  uint32_t cts_pin;
44  uint32_t cts_rcc;
45 };
46 
58 bool busvoodoo_uart_generic_setup(char** prefix, const char* line);
64 #define busvoodoo_uart_generic_commands_nb 5
65 
command menu entry
Definition: menu.h:31
void(* tx_post)(void)
method to be called after transmitting data
bool busvoodoo_uart_generic_setup(char **prefix, const char *line)
setup generic UART mode
bool busvoodoo_uart_generic_configure(const struct busvoodoo_uart_generic_specific_t *conf)
provide the generic USART with mode specific information
uint32_t rx_pin
GPIO pin address of receive pin.
uint32_t rts_port
GPIO port address of request to send pin.
void(* rx_pre)(void)
method to be called before receiving data
uint32_t usart
USART peripheral base address.
uint32_t rx_rcc
GPIO RCC address of receive pin.
bool multidrive
if multiple drive modes are supported (push-pull, open-drain with internal resistors, open-drain with external resistors), or just push-pull
uint32_t rx_port
GPIO port address of receive pin.
uint32_t tx_pin
GPIO pin address of transmit pin.
void(* rx_post)(void)
method to be called after receiving data
uint32_t tx_rcc
GPIO RCC address of transmit pin.
UART specific methods that will be called by the generic methods.
void(* tx_pre)(void)
method to be called before transmitting data
uint32_t rts_rcc
GPIO RCC address of request to send pin.
uint32_t cts_port
GPIO port address of clear to send pin.
#define busvoodoo_uart_generic_commands_nb
number of commands supported by the generic UART mode
uint32_t usart_rst
USART RST address.
uint32_t rts_pin
GPIO pin address of request to send pin.
uint32_t usart_rcc
USART RCC address.
uint32_t cts_rcc
GPIO RCC address of clear to send pin.
void busvoodoo_uart_generic_exit(void)
exit genetic UART mode
bool hwflowctl
if RTC/CTS hardware flow control is supported
uint32_t tx_port
GPIO port address of transmit pin.
uint32_t cts_pin
GPIO pin address of clear to send pin.
const struct menu_command_t busvoodoo_uart_generic_commands[busvoodoo_uart_generic_commands_nb]
commands supported by the generic UART mode