zhangbo
4 天以前 0817c03a55b444ff4958723476f807486439e107
keil/include/drivers/Usart.c
@@ -2,6 +2,7 @@
#include <string.h>
#include <stdio.h>
#include "mk_uart.h"
#include "UART.h"
//#include "modbus.h"
//#include "Rcc_Nvic_Systick.h"
@@ -57,7 +58,23 @@
    DMACnt = EUART_RX_BUF_SIZE - cndtr;
    while( m_EUART_DMA_RXPtr != DMACnt && MaxDataLen > 0)
    {
        // 弃用此部分逻辑
        // Usart1ParseDataCallback(m_EUART_DMA_RXBuf[m_EUART_DMA_RXPtr]);
        // 使用UART.c方法接入数据,以便使用STM32的逻辑
//        Uart_SetChar(UART_ID_DBG_GPS, m_EUART_DMA_RXBuf[m_EUART_DMA_RXPtr]);
//        DBG_Poll();
//        //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--;
        Usart1ParseDataCallback(m_EUART_DMA_RXBuf[m_EUART_DMA_RXPtr]);
//        Usart1ParseDataHandler(m_EUART_DMA_RXBuf);
//        DBG_Poll();
        //waitusart_timer = tag_frequency*USART_KEEPWAKE_TIME;
        m_EUART_DMA_RXPtr++;
        if( m_EUART_DMA_RXPtr >= EUART_RX_BUF_SIZE )
@@ -68,9 +85,33 @@
        MaxDataLen--;
    }
    m_bEUARTCheckingRec = 0;
}
void INTERNET_CheckReceive(void)
{
    int32_t DMACnt = 0;
    int32_t MaxDataLen = EUART_RX_BUF_SIZE;
    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