Garys 发表于 2023-6-5 15:42

针对HC32L110的使用ADC进行电压数据采集,uart数据收发异常

就是使用这个hc32l110的ADC模块来进行电压数据采集,然后把数据通过uart在串口上打印。但是不知道为什么我写的代码在获取电压数据,打印出来一直为0,电路是没什么问题的。
#include "ddl.h"
#include "uart.h"
#include "bt.h"
#include "lpm.h"
#include "gpio.h"
#include "adc.h"



#define   T1_PORT               (3)
#define   T1_PIN                  (3)


staticuint16_t u16ScanResult;
uint8_t u8Rx**=0;
uint8_t Check**=0;
uint8_t u8RxData={0x11,0x22,0X33};

void AdcContIrqCallback(void)
{   
    Adc_GetScanResult(0,&u16ScanResult);

    M0P_ADC->CR0_f.STATERST = 1u;

    M0P_BT1->ICLR_f.TFC = 0;
}

void RxIntCallback(void)
{
                u8RxData=M0P_UART1->SBUF;
          u8Rx** = 1;
}



void ErrIntCallback(void)
{

}

void AdcRegIrqCallback(void)
{   

}

void AdcHhtIrqCallback(void)
{   

}

void AdcLltIrqCallback(void)
{   

}

int32_t main(void)
{
       
           uint16_t timer=0;
    uint32_t pclk=0;
          uint16_t                  u16ArrData2;
    uint16_t                  u16InitCntData2;
                stc_adc_cfg_t             stcAdcCfg                                ;
    stc_adc_scan_cfg_t      stcAdcScanCfg                ;
    stc_adc_irq_t             stcAdcIrq                                ;
    stc_adc_irq_calbakfn_pt_t stcAdcIrqCalbaks;
    stc_bt_config_t         stcBtConfig                        ;
                stc_uart_config_t                           stcConfig                                ;       
    stc_uart_irq_cb_t                                 stcUartIrqCb                ;
    stc_uart_multimode_t                         stcMulti                                ;
    stc_uart_baud_config_t          stcBaud                                        ;
          


    DDL_ZERO_STRUCT(stcAdcCfg);
    DDL_ZERO_STRUCT(stcAdcScanCfg);
    DDL_ZERO_STRUCT(stcAdcIrq);
    DDL_ZERO_STRUCT(stcAdcIrqCalbaks);
       
          DDL_ZERO_STRUCT(stcUartIrqCb);
    DDL_ZERO_STRUCT(stcMulti);
    DDL_ZERO_STRUCT(stcBaud);
    DDL_ZERO_STRUCT(stcBtConfig);
       
    Clk_SwitchTo(ClkRCL);
    Clk_SetRCHFreq(ClkFreq24Mhz);
    Clk_SwitchTo(ClkRCH);            


    Gpio_SetAnalog(2, 4, TRUE);
               
                Adc_Enable();
    M0P_BGR->CR_f.BGR_EN = 0x1u;   
    M0P_BGR->CR_f.TS_EN = 0x0u;   
    delay100us(1);

    stcAdcCfg.enAdcOpMode                           = AdcScanMode;            
    stcAdcCfg.enAdcClkSel                           = AdcClkSysTDiv1;         
    stcAdcCfg.enAdcSampTimeSel          = AdcSampTime8Clk;   
    stcAdcCfg.enAdcRefVolSel                  = RefVolSelAVDD;         
    stcAdcCfg.bAdcInBufEn                           = FALSE;                  
    stcAdcCfg.enAdcTrig0Sel                   = AdcTrigTimer2;         
    stcAdcCfg.enAdcTrig1Sel                   = AdcTrigDisable;
    Adc_Init(&stcAdcCfg);         
                                                                                                                                  
    stcAdcIrq.bAdcIrq               = TRUE;                           
    stcAdcIrq.bAdcRegCmp            = FALSE;
    stcAdcIrq.bAdcHhtCmp            = FALSE;
    stcAdcIrq.bAdcLltCmp            = FALSE;
    stcAdcIrqCalbaks.pfnAdcContIrq= AdcContIrqCallback;
    stcAdcIrqCalbaks.pfnAdcRegIrq   = AdcRegIrqCallback;
    stcAdcIrqCalbaks.pfnAdcHhtIrq   = AdcHhtIrqCallback;
    stcAdcIrqCalbaks.pfnAdcLltIrq   = AdcLltIrqCallback;
    Adc_ConfigIrq(&stcAdcIrq, &stcAdcIrqCalbaks);      
    Adc_EnableIrq();                                    
    Adc_CmpCfg(&stcAdcIrq);                           

    stcAdcScanCfg.u8AdcScanModeCh         =ADC_SCAN_CH1_EN;
               
                stcAdcScanCfg.u8AdcSampCnt = 0x1;                  
    Adc_ConfigScanMode(&stcAdcCfg, &stcAdcScanCfg);

    Gpio_InitIO(T1_PORT,T1_PIN,GpioDirIn);
    Gpio_InitIO(0,3,GpioDirOut);
    Gpio_SetIO(0,3,1);

    Gpio_InitIOExt(3,5,GpioDirOut,TRUE,FALSE,FALSE,FALSE);   
    Gpio_InitIOExt(3,6,GpioDirOut,TRUE,FALSE,FALSE,FALSE);


    Gpio_SetFunc_UART1TX_P35();
    Gpio_SetFunc_UART1RX_P36();
               
                Clk_SetPeripheralGate(ClkPeripheralBt,TRUE);
    Clk_SetPeripheralGate(ClkPeripheralUart1,TRUE);
                if (Ok != Clk_SetPeripheralGate(ClkPeripheralAdcBgr, TRUE))
    {
      return Error;
    }

    stcUartIrqCb.pfnRxIrqCb      = RxIntCallback;
    stcUartIrqCb.pfnTxIrqCb      = NULL;
    stcUartIrqCb.pfnRxErrIrqCb   = ErrIntCallback;
    stcConfig.pstcIrqCb                                       = &stcUartIrqCb;
    stcConfig.bTouchNvic                                        = TRUE;


    stcConfig.enRunMode = UartMode3;


    stcMulti.enMulti_mode = UartNormal;

    stcConfig.pstcMultiMode = &stcMulti;

    stcBaud.bDbaud = 0u;
    stcBaud.u32Baud = 2400U;
    stcBaud.u8Mode = UartMode3;
    pclk = Clk_GetPClkFreq();
    timer=Uart_SetBaudRate(UARTCH1,pclk,&stcBaud);

    stcBtConfig.enMD    = BtMode2;
                stcBtConfig.enCT    = BtTimer;
        Bt_ClearIntFlag(TIM1);
        Bt_EnableIrq(TIM1);

    Bt_Init(TIM1, &stcBtConfig);
    Bt_ARRSet(TIM1,timer);
    Bt_Cnt16Set(TIM1,timer);

    Uart_Init(UARTCH1, &stcConfig);
    Uart_EnableIrq(UARTCH1,UartRxIrq);
    Uart_ClrStatus(UARTCH1,UartRxFull);
    Uart_EnableFunc(UARTCH1,UartRx);
               
                stcBtConfig.enGateP = BtPositive;
    stcBtConfig.enGate= BtGateDisable;   
    stcBtConfig.enPRS   = BtPCLKDiv256;   
    stcBtConfig.enTog   = BtTogDisable;   
    stcBtConfig.enCT    = BtTimer;
    stcBtConfig.enMD    = BtMode2;

    Bt_Init(TIM2, &stcBtConfig);

    Bt_ClearIntFlag(TIM2);
    Bt_EnableIrq(TIM2);

    u16ArrData2 = 0x10000 - 9375;      
    u16InitCntData2 = 0x10000 - 9375;
    Bt_ARRSet(TIM2, u16ArrData2);
    Bt_Cnt16Set(TIM2, u16InitCntData2);
    Bt_Run(TIM2);
                Bt_Run(TIM1);
       
    while(1)
        {
                Adc_Start();
          Check** = 0;
                u8RxData = (u16ScanResult >> 8 );
                u8RxData = (u16ScanResult & 0xFF);
                if(u8Rx**)
                {
                        u8Rx** = 0;
                       
                        if(Uart_CheckEvenOrOdd(UARTCH1,Even,u8RxData)!=Ok)
                        {
                                Check** = 1;
                        }
                        else
                        {
                               
                                Uart_SetTb8(UARTCH1,Even,u8RxData);
                          Uart_SendData(UARTCH1,u8RxData);                               
                          Uart_SetTb8(UARTCH1,Even,u8RxData);
                          Uart_SendData(UARTCH1,u8RxData);
                                Uart_SetTb8(UARTCH1,Even,u8RxData);
                          Uart_SendData(UARTCH1,u8RxData);
                        }
                }
        }

}



liuyuxiier 发表于 2023-6-5 16:21

代码太长啦,建议把问题分割一下,缩小一下问题范围,所谓授人以鱼不如授人以渔,
你这里涉及两个主要功能,一个是ADC采集,一个是串口发送。
先排查ADC是否能正常采集到电压。使用仿真器,观察ADC结果寄存器有没有数据。
如果ADC结果寄存器没有数据,那就检查ADC的配置,比如端口配置,ADC时钟,ADC通道配置,模式配置,触发配置等等。
如果ADC结果寄存器有数据,那就检查USART配置,可以先给一组固定的数据看看能够正常打印。
如果能正常打印,就重点检查ADC结果寄存器的读取与数据转换。

以上步骤可以把问题缩小到一定的范围,你再精准的把问题提出来,大家也会有针对性的帮你解决问题了。祝好运。

wubangmi 发表于 2023-6-6 09:32

u8RxData = (u16ScanResult >> 8 );
u8RxData = (u16ScanResult & 0xFF);
你认真考虑下上面这两条语句放在while死循环里直接运行会产生什么效果?
可能几个微秒就执行一次。u8RxData[]这个数组极大部分时间都是等于0.

xch 发表于 2023-6-6 11:07

ADC 和 UART 得分开测试。要不然都是临时工的责任。

xch 发表于 2023-6-6 16:21

本帖最后由 xch 于 2023-6-6 16:29 编辑

ADC 模拟信号输入引脚是哪个?

对应的初始化代码是哪段?
P24?


wubangmi 发表于 2023-6-6 17:08

本帖最后由 wubangmi 于 2023-6-6 17:18 编辑

楼主这个整合能力还有待提高,还要多研究相对应的用户手册。

tpgf 发表于 2023-7-6 11:56

能在程序里边看到采集到的数据是不是正确的呢

paotangsan 发表于 2023-7-6 13:13

能确定一下就是获取的电压数据是不是正确的呢

wakayi 发表于 2023-7-6 13:53

不用ad采集的话直接让串口发送固定数据 观察一下现象

heimaojingzhang 发表于 2023-7-6 18:59

楼主看一下发送数据缓冲里边的数据是什么

keaibukelian 发表于 2023-7-6 19:29

用示波器看一下实际发送的数据是不是正确

renzheshengui 发表于 2023-7-6 19:56

楼主可以先不发送 看一下采集的数据是不是正确的
页: [1]
查看完整版本: 针对HC32L110的使用ADC进行电压数据采集,uart数据收发异常