添加485获取特定命令或者命令加参数的形式
This commit is contained in:
parent
699a8218f7
commit
f5a936e022
@ -5,7 +5,12 @@
|
||||
#ifndef RS485_H
|
||||
#define RS485_H
|
||||
|
||||
#include "gd32e23x_it.h"
|
||||
#include <stdbool.h>
|
||||
#include <string.h>
|
||||
|
||||
#define RX_BUFFER_SIZE 64
|
||||
|
||||
void process_command(char *cmd);
|
||||
|
||||
#endif //RS485_H
|
||||
|
32
src/RS485.c
32
src/RS485.c
@ -11,19 +11,25 @@
|
||||
#define MAX_CMD_SIZE 16
|
||||
#define BUFSIZE 8
|
||||
|
||||
static char cmdbuffer[BUFSIZE][MAX_CMD_SIZE];
|
||||
static char *strchr_pointer = NULL;
|
||||
extern uint16_t g_distance_uint16;
|
||||
extern uint16_t g_temperature_uint16;
|
||||
|
||||
static int bufindr = 0;
|
||||
static int bufindw = 0;
|
||||
static int buflen = 0;
|
||||
|
||||
bool code_seen(char code)
|
||||
{
|
||||
strchr_pointer = strchr(cmdbuffer[bufindr], code);
|
||||
return (strchr_pointer != NULL); //Return True if a character was found
|
||||
void process_command(char *cmd) {
|
||||
if (strncmp(cmd, "M1", 2) == 0) {
|
||||
printf("M1 -=-=- OK!\r\n");
|
||||
printf("Distance: %d\r\n", g_distance_uint16);
|
||||
} else if (strncmp(cmd, "M2", 2) == 0) {
|
||||
printf("M2 -=-=- OK!\r\n");
|
||||
printf("Temperature: %d\r\n", g_temperature_uint16);
|
||||
// } 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");
|
||||
}
|
||||
float code_value(void)
|
||||
{
|
||||
return (strtod(&cmdbuffer[bufindr][strchr_pointer - cmdbuffer[bufindr] + 1], NULL));
|
||||
}
|
@ -37,9 +37,13 @@ OF SUCH DAMAGE.
|
||||
#include "main.h"
|
||||
#include "systick.h"
|
||||
#include "ultrasonic_driver.h"
|
||||
#include "rs485.h"
|
||||
|
||||
__IO uint32_t g_capture_value;
|
||||
|
||||
char rx_buffer[RX_BUFFER_SIZE];
|
||||
uint8_t rx_index = 0;
|
||||
|
||||
/*!
|
||||
\brief this function handles NMI exception
|
||||
\param[in] none
|
||||
@ -62,6 +66,7 @@ void NMI_Handler(void)
|
||||
void HardFault_Handler(void)
|
||||
{
|
||||
/* if Hard Fault exception occurs, go to infinite loop */
|
||||
// log_error("HardFault_Handler");
|
||||
while(1) {
|
||||
}
|
||||
}
|
||||
@ -157,3 +162,23 @@ void EXTI0_1_IRQHandler(void) {
|
||||
exti_interrupt_disable(EXTI_0);
|
||||
}
|
||||
}
|
||||
|
||||
void USART0_IRQHandler(void) {
|
||||
if(RESET != usart_interrupt_flag_get(USART0, USART_INT_FLAG_RBNE))
|
||||
{
|
||||
usart_interrupt_flag_clear(USART0, USART_INT_FLAG_RBNE);
|
||||
uint8_t received_data = (uint8_t)usart_data_receive(USART0);
|
||||
|
||||
// 将接收到的数据存储到缓冲区
|
||||
if(rx_index < RX_BUFFER_SIZE - 1) {
|
||||
rx_buffer[rx_index++] = received_data;
|
||||
}
|
||||
|
||||
// 检查是否接收到换行符,表示指令结束
|
||||
if(received_data == '\n') {
|
||||
rx_buffer[rx_index] = '\0'; // 添加字符串结束符
|
||||
process_command(rx_buffer); // 处理指令
|
||||
rx_index = 0; // 重置缓冲区索引
|
||||
}
|
||||
}
|
||||
}
|
@ -57,6 +57,9 @@ void usart_config(void)
|
||||
usart_transmit_config(USART0_PHY, USART_TRANSMIT_ENABLE);
|
||||
|
||||
usart_enable(USART0_PHY);
|
||||
|
||||
nvic_irq_enable(USART0_IRQn, 0);
|
||||
usart_interrupt_enable(USART0_PHY, USART_INT_RBNE);
|
||||
}
|
||||
|
||||
void UltraSonic_GPIO_Config(void)
|
||||
|
Loading…
x
Reference in New Issue
Block a user