MiaoUI/HARDWARE/uart/bsp_usart.c

221 lines
6.1 KiB
C
Raw Normal View History

2023-06-30 04:50:02 +00:00
#include "bsp_usart.h"
/**
* @brief NVIC
* @param
* @retval
2023-06-30 04:50:02 +00:00
*/
static void NVIC_Configuration(void)
{
NVIC_InitTypeDef NVIC_InitStructure;
/* 嵌套向量中断控制器组选择 */
2023-06-30 04:50:02 +00:00
NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);
/* 配置USART为中断源 */
2023-06-30 04:50:02 +00:00
NVIC_InitStructure.NVIC_IRQChannel = DEBUG_USART_IRQ;
/* 抢断优先级*/
NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;
/* 子优先级 */
NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0;
/* 使能中断 */
2023-06-30 04:50:02 +00:00
NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
/* 初始化配置NVIC */
2023-06-30 04:50:02 +00:00
NVIC_Init(&NVIC_InitStructure);
}
/**
* @brief USART GPIO ,
* @param
* @retval
2023-06-30 04:50:02 +00:00
*/
void USART_Config(void)
{
GPIO_InitTypeDef GPIO_InitStructure;
USART_InitTypeDef USART_InitStructure;
// 打开串口GPIO的时钟
2023-06-30 04:50:02 +00:00
DEBUG_USART_GPIO_APBxClkCmd(DEBUG_USART_GPIO_CLK, ENABLE);
// 打开串口外设的时钟
2023-06-30 04:50:02 +00:00
DEBUG_USART_APBxClkCmd(DEBUG_USART_CLK, ENABLE);
// 将USART Tx的GPIO配置为推挽复用模式
2023-06-30 04:50:02 +00:00
GPIO_InitStructure.GPIO_Pin = DEBUG_USART_TX_GPIO_PIN;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_Init(DEBUG_USART_TX_GPIO_PORT, &GPIO_InitStructure);
// 将USART Rx的GPIO配置为浮空输入模式
2023-06-30 04:50:02 +00:00
GPIO_InitStructure.GPIO_Pin = DEBUG_USART_RX_GPIO_PIN;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;
GPIO_Init(DEBUG_USART_RX_GPIO_PORT, &GPIO_InitStructure);
// 配置串口的工作参数
// 配置波特率
2023-06-30 04:50:02 +00:00
USART_InitStructure.USART_BaudRate = DEBUG_USART_BAUDRATE;
// 配置 针数据字长
2023-06-30 04:50:02 +00:00
USART_InitStructure.USART_WordLength = USART_WordLength_8b;
// 配置停止位
2023-06-30 04:50:02 +00:00
USART_InitStructure.USART_StopBits = USART_StopBits_1;
// 配置校验位
2023-06-30 04:50:02 +00:00
USART_InitStructure.USART_Parity = USART_Parity_No ;
// 配置硬件流控制
2023-06-30 04:50:02 +00:00
USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;
// 配置工作模式,收发一起
2023-06-30 04:50:02 +00:00
USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;
// 完成串口的初始化配置
2023-06-30 04:50:02 +00:00
USART_Init(DEBUG_USARTx, &USART_InitStructure);
// 串口中断优先级配置
2023-06-30 04:50:02 +00:00
NVIC_Configuration();
// 使能串口接收中断
2023-06-30 04:50:02 +00:00
USART_ITConfig(DEBUG_USARTx, USART_IT_RXNE, ENABLE);
// 使能串口
2023-06-30 04:50:02 +00:00
USART_Cmd(DEBUG_USARTx, ENABLE);
}
/***************** 发送一个字节 **********************/
2023-06-30 04:50:02 +00:00
void Usart_SendByte( USART_TypeDef * pUSARTx, uint8_t ch)
{
/* 发送一个字节数据到USART */
2023-06-30 04:50:02 +00:00
USART_SendData(pUSARTx,ch);
/* 等待发送数据寄存器为空 */
2023-06-30 04:50:02 +00:00
while (USART_GetFlagStatus(pUSARTx, USART_FLAG_TXE) == RESET);
}
/****************** 发送8位的数组 ************************/
2023-06-30 04:50:02 +00:00
void Usart_SendArray( USART_TypeDef * pUSARTx, uint8_t *array, uint16_t num)
{
uint8_t i;
for(i=0; i<num; i++)
{
/* 发送一个字节数据到USART */
2023-06-30 04:50:02 +00:00
Usart_SendByte(pUSARTx,array[i]);
}
/* 等待发送完成 */
2023-06-30 04:50:02 +00:00
while(USART_GetFlagStatus(pUSARTx,USART_FLAG_TC)==RESET);
}
/***************** 发送字符串 **********************/
2023-06-30 04:50:02 +00:00
void Usart_SendString( USART_TypeDef * pUSARTx, char *str)
{
unsigned int k=0;
do
{
Usart_SendByte( pUSARTx, *(str + k) );
k++;
} while(*(str + k)!='\0');
/* 等待发送完成 */
2023-06-30 04:50:02 +00:00
while(USART_GetFlagStatus(pUSARTx,USART_FLAG_TC)==RESET)
{}
}
/***************** 发送一个16位数 **********************/
2023-06-30 04:50:02 +00:00
void Usart_SendHalfWord( USART_TypeDef * pUSARTx, uint16_t ch)
{
uint8_t temp_h, temp_l;
/* 取出高八位 */
2023-06-30 04:50:02 +00:00
temp_h = (ch&0XFF00)>>8;
/* 取出低八位 */
2023-06-30 04:50:02 +00:00
temp_l = ch&0XFF;
/* 发送高八位 */
2023-06-30 04:50:02 +00:00
USART_SendData(pUSARTx,temp_h);
while (USART_GetFlagStatus(pUSARTx, USART_FLAG_TXE) == RESET);
/* 发送低八位 */
2023-06-30 04:50:02 +00:00
USART_SendData(pUSARTx,temp_l);
while (USART_GetFlagStatus(pUSARTx, USART_FLAG_TXE) == RESET);
}
///重定向c库函数printf到串口重定向后可使用printf函数
2023-06-30 04:50:02 +00:00
int fputc(int ch, FILE *f)
{
/* 发送一个字节数据到串口 */
2023-06-30 04:50:02 +00:00
USART_SendData(DEBUG_USARTx, (uint8_t) ch);
/* 等待发送完毕 */
2023-06-30 04:50:02 +00:00
while (USART_GetFlagStatus(DEBUG_USARTx, USART_FLAG_TXE) == RESET);
return (ch);
}
///重定向c库函数scanf到串口重写向后可使用scanf、getchar等函数
2023-06-30 04:50:02 +00:00
int fgetc(FILE *f)
{
/* 等待串口输入数据 */
2023-06-30 04:50:02 +00:00
while (USART_GetFlagStatus(DEBUG_USARTx, USART_FLAG_RXNE) == RESET);
return (int)USART_ReceiveData(DEBUG_USARTx);
}
uint8_t RX_Packet[1024];
volatile int RX_Packet_Length = 0, Time_Length = 0;
uint8_t Usart_GetTime[25],GetTime_State=0;
bool packetReceived = false; // 添加一个变量用于标识是否接收到完整的数据包
void USART1_IRQHandler(void)
{
static uint8_t state = 0;
if (USART_GetITStatus(USART1, USART_IT_RXNE) == SET)
{
uint8_t RxData = USART_ReceiveData(USART1);
switch (state)
{
case 0:
if (RxData == 0xFF)
{
RX_Packet_Length = 0;
state = 1;
}
if (RxData == 0x01)
{
Time_Length = 0;
state = 3;
}
break;
case 1:
RX_Packet[RX_Packet_Length] = RxData;
RX_Packet_Length++;
if (RX_Packet_Length >= 1024) // 数据字节数
{
state = 2;
}
break;
case 2:
if (RxData == 0xFE) // 数据包尾
{
state = 0;
packetReceived = true; // 设置标志位表示接收到完整的数据包
}
break;
case 3:
Time_Length++;
Usart_GetTime[Time_Length] = RxData;
if (Time_Length >= 25)
{
state = 4;
}
break;
case 4:
if (RxData == 0x02)
{
state = 0;
GetTime_State = 1;
}
break;
default:
break;
}
USART_ClearITPendingBit(USART1, USART_IT_RXNE);
}
}