generated from hulk/gd32e23x_template
54 lines
1.9 KiB
C
54 lines
1.9 KiB
C
//
|
|
// Created by dell on 24-12-3.
|
|
//
|
|
|
|
#include "RS485.h"
|
|
|
|
extern uint32_t g_temperature_uint32;
|
|
|
|
void RS485_config(void) {
|
|
rcu_periph_clock_enable(RS485_GPIO_RCU);
|
|
rcu_periph_clock_enable(RS485_RCU);
|
|
|
|
gpio_af_set(RS485_GPIO_PORT, GPIO_AF_1, GPIO_PIN_2 | GPIO_PIN_3);
|
|
|
|
/* configure USART Tx&Rx as alternate function push-pull */
|
|
gpio_mode_set(RS485_GPIO_PORT, GPIO_MODE_AF, GPIO_PUPD_PULLUP, RS485_TX_PIN | RS485_RX_PIN);
|
|
gpio_output_options_set(RS485_GPIO_PORT, GPIO_OTYPE_PP, GPIO_OSPEED_10MHZ, RS485_TX_PIN | RS485_RX_PIN);
|
|
|
|
/* configure RS485 EN Pin */
|
|
gpio_mode_set(RS485_GPIO_PORT, GPIO_MODE_OUTPUT, GPIO_PUPD_NONE, RS485_EN_PIN);
|
|
gpio_output_options_set(RS485_GPIO_PORT, GPIO_OTYPE_PP, GPIO_OSPEED_50MHZ, RS485_EN_PIN);
|
|
gpio_bit_write(RS485_GPIO_PORT, RS485_EN_PIN, SET);
|
|
|
|
/* USART configure */
|
|
usart_deinit(RS485_PHY);
|
|
usart_baudrate_set(RS485_PHY, RS485_BAUDRATE);
|
|
usart_receive_config(RS485_PHY, USART_RECEIVE_ENABLE);
|
|
usart_transmit_config(RS485_PHY, USART_TRANSMIT_ENABLE);
|
|
|
|
usart_enable(RS485_PHY);
|
|
|
|
nvic_irq_enable(USART0_IRQn, 0);
|
|
usart_interrupt_enable(RS485_PHY, USART_INT_RBNE);
|
|
}
|
|
|
|
void process_command(char *cmd) {
|
|
if (strncmp(cmd, "M1", 2) == 0) {
|
|
printf("M1 -=-=- OK!\r\n");
|
|
} else if (strncmp(cmd, "M2", 2) == 0) {
|
|
// printf("M2 -=-=- OK!\r\n");
|
|
printf("Temperature: %lu\r\n", g_temperature_uint32);
|
|
// } else if (strncmp(cmd, "M3", 2) == 0) {
|
|
// char *param_str = cmd + 2; // Skip "M3"
|
|
// int param = atoi(param_str + 1); // Skip "S" and convert to integer
|
|
// if (param >= 0 && param <= 100) {
|
|
// printf("M3 with parameter %d -=-=- OK!\r\n", param);
|
|
// } else {
|
|
// printf("Invalid parameter for M3 command!\r\n");
|
|
// }
|
|
} else {
|
|
printf("Invalid Command!\r\n");
|
|
}
|
|
}
|