From 59a4e01d92da432e9736b24c085089cd31963833 Mon Sep 17 00:00:00 2001
From: zhangbo <zhangbo@qq.com>
Date: 星期三, 21 五月 2025 15:19:22 +0800
Subject: [PATCH] 修改了串口读取的bug,现在是通过飞线控制的 PCA蓝牙IRQ拉低,修改灯的闪灯逻辑,

---
 keil/include/drivers/Usart.c |   60 +++++++++++++++++++++++++++++++++++++++++++++++++-----------
 1 files changed, 49 insertions(+), 11 deletions(-)

diff --git a/keil/include/drivers/Usart.c b/keil/include/drivers/Usart.c
index 6d4af12..179e553 100644
--- a/keil/include/drivers/Usart.c
+++ b/keil/include/drivers/Usart.c
@@ -11,8 +11,10 @@
 volatile int8_t m_EUART_TxFrm_Head = 0;					//数据发送帧队列头指针
 volatile int8_t m_EUART_TxFrm_FreeFrmLen = 0;			//数据发送帧队列剩余帧数
 //DMA数据接收缓存
-uint8_t m_EUART_DMA_RXBuf[EUART_RX_BUF_SIZE];			//DMA数据接收缓存
+uint8_t m_EUART_DMA_RXBuf[EUART_RX_BUF_SIZE];			//DMA数据接收缓存   m_EUART_DMA_RXBuf_1
+uint8_t m_EUART_DMA_RXBuf_1[USART_RX_BUF_SIZE];	
 volatile int32_t m_EUART_DMA_RXPtr = 0;					//当前数据地址
+volatile int32_t m_EUART_DMA_RXPtr_1 = 0;	
 //int16_t DMA_rxtemp = 0,DMA_rxtemp2 = 0;															//当前数据地址缓存
 //uint16_t datadelaycount = 0;													//剩余1位数据延时等待处理
 //标志变量
@@ -22,6 +24,7 @@
 volatile uint8_t m_bEUARTTxEn = 0;						//使能发送
 
 void (*Usart1ParseDataCallback)(uint8_t);
+void (*Usart0ParseDataCallback)(uint8_t);
 void Usart1InitVariables(void)
 {
     m_EUART_TxFrm_FreeFrmLen = EUART_TX_FRM_SIZE-1;
@@ -35,11 +38,12 @@
 //uint16_t t1,t2,t3,t4;
 
 uint16_t t3;
-uint32_t cndtr=0;
+
 void UART_CheckReceive(void)
 {
+	  uint32_t cndtr=0;
     int32_t DMACnt = 0;
-    int32_t MaxDataLen = EUART_RX_BUF_SIZE;
+    int32_t MaxDataLen = USART_RX_BUF_SIZE;
     cndtr=get_uart1_dma_cndtr();
     //缺少check保护
     //如果正在往发送队列中添加数据,退出
@@ -54,24 +58,58 @@
         m_bEUARTCheckingRec = 0;
         return;
     }
-    DMACnt = EUART_RX_BUF_SIZE - cndtr;
-    while( m_EUART_DMA_RXPtr != DMACnt && MaxDataLen > 0)
+    DMACnt = USART_RX_BUF_SIZE - cndtr;
+    while( m_EUART_DMA_RXPtr_1 != DMACnt && MaxDataLen > 0)
     {
-        Usart1ParseDataCallback(m_EUART_DMA_RXBuf[m_EUART_DMA_RXPtr]);
+        Usart0ParseDataCallback(m_EUART_DMA_RXBuf_1[m_EUART_DMA_RXPtr_1]);
         //waitusart_timer = tag_frequency*USART_KEEPWAKE_TIME;
-        m_EUART_DMA_RXPtr++;
-        if( m_EUART_DMA_RXPtr >= EUART_RX_BUF_SIZE )
+        m_EUART_DMA_RXPtr_1++;
+        if( m_EUART_DMA_RXPtr_1 >= USART_RX_BUF_SIZE )
         {
-            m_EUART_DMA_RXPtr = 0;
+            m_EUART_DMA_RXPtr_1 = 0;
         }
-        DMACnt = EUART_RX_BUF_SIZE - cndtr;
+        DMACnt = USART_RX_BUF_SIZE - cndtr;
         MaxDataLen--;
     }
     m_bEUARTCheckingRec = 0;
 
 }
 
-
+void UART0_CheckReceive(void)
+{
+         uint32_t cndtr=0; 
+				 int32_t DMACnt = 0;
+				 int32_t MaxDataLen = EUART_RX_BUF_SIZE;        
+				 cndtr=get_uart0_dma_cndtr();
+                //缺少check保护
+        //如果正在往发送队列中添加数据,退出
+        if(m_bEUARTPushingFrms)
+                return;
+        //判断是否正在Check
+        if(m_bEUARTCheckingRec)
+                return;
+        m_bEUARTCheckingRec = 1;
+        if(cndtr== 0)
+        {
+                m_bEUARTCheckingRec = 0;
+                return;
+        }
+        DMACnt = EUART_RX_BUF_SIZE - cndtr;
+        while( m_EUART_DMA_RXPtr != DMACnt && MaxDataLen > 0)
+        {
+                Usart1ParseDataCallback(m_EUART_DMA_RXBuf[m_EUART_DMA_RXPtr]);
+                //waitusart_timer = tag_frequency*USART_KEEPWAKE_TIME;
+                m_EUART_DMA_RXPtr++;
+                if( m_EUART_DMA_RXPtr >= EUART_RX_BUF_SIZE )
+                {
+                        m_EUART_DMA_RXPtr = 0;
+                }
+                DMACnt = EUART_RX_BUF_SIZE - cndtr;
+                MaxDataLen--;
+        }
+        m_bEUARTCheckingRec = 0;        
+        
+}
 
 #ifndef EXUART_USE_TXDMA
 //查询方式发送数据

--
Gitblit v1.9.3