【沁恒微CH32V307评估板试用体验】以太网传输ADC采集值 - RISC-V MCU技术社区 - 电子技术william hill官网 - 广受欢迎的专业电子william hill官网 - 威廉希尔官方网站
分享 收藏 返回

[文章]

【沁恒微CH32V307评估板试用体验】以太网传输ADC采集值

本来打算使用以太网主动向上位机传输值的,但是目前在程序里没有发现,自己暂时也只是看了下历程,这里就改变下传输方式吧,使用上位机发送,下位机再传输数值。
本次历程在TCPClient上修改过来。主要增加了ADC,ADC的配置先看下。
  1. s16 Calibrattion_Val = 0;

  2. void ADC_Function_Init(void)

  3. {

  4.     ADC_InitTypeDef ADC_InitStructure={0};

  5.     GPIO_InitTypeDef GPIO_InitStructure={0};



  6.     RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE );

  7.     RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1, ENABLE );

  8.     RCC_ADCCLKConfig(RCC_PCLK2_Div8);



  9.     GPIO_InitStructure.GPIO_Pin = GPIO_Pin_2;

  10.     GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN;

  11.     GPIO_Init(GPIOA, &GPIO_InitStructure);



  12.     GPIO_InitStructure.GPIO_Pin = GPIO_Pin_3;

  13.     GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN;

  14.     GPIO_Init(GPIOA, &GPIO_InitStructure);



  15.     ADC_DeInit(ADC1);

  16.     ADC_InitStructure.ADC_Mode = ADC_Mode_Independent;

  17.     ADC_InitStructure.ADC_ScanConvMode = DISABLE;

  18.     ADC_InitStructure.ADC_ContinuousConvMode = DISABLE;

  19.     ADC_InitStructure.ADC_ExternalTrigConv = ADC_ExternalTrigConv_None;

  20.     ADC_InitStructure.ADC_DataAlign = ADC_DataAlign_Right;

  21.     ADC_InitStructure.ADC_NbrOfChannel = 1;

  22.     ADC_Init(ADC1, &ADC_InitStructure);



  23.     ADC_RegularChannelConfig(ADC1, ADC_Channel_2, 1, ADC_SampleTime_239Cycles5 );

  24.     ADC_RegularChannelConfig(ADC1, ADC_Channel_3, 1, ADC_SampleTime_239Cycles5 );

  25.     ADC_AutoInjectedConvCmd(ADC1, ENABLE);

  26.     ADC_Cmd(ADC1, ENABLE);



  27.     ADC_BufferCmd(ADC1, DISABLE);   //disable buffer

  28.     ADC_ResetCalibration(ADC1);

  29.     while(ADC_GetResetCalibrationStatus(ADC1));

  30.     ADC_StartCalibration(ADC1);

  31.     while(ADC_GetCalibrationStatus(ADC1));

  32.     Calibrattion_Val = Get_CalibrationValue(ADC1);



  33.     ADC_BufferCmd(ADC1, ENABLE);   //enable buffer

  34. }

这个配置和以前的32基本配置无差别。就是初始化ADC管脚,ADC时钟打开,然后配置转换通道,我这里就采集一路,所以是最后配置的PA3,第三路的ADC。规则转换,只需要在main函数中增加转换的方式即可。
图片1.png
这里我使用累加的方法,不至于采集过快,导致TCP传输出现问题。
图片2.png
之后修改下以太网配置参数,主要是端口和目标IP,主机上得用TCPSever。
图片3.png
其这里是配置了以太网的接收中断,在主循环中一直判断中断的到来,然后读取中断,如果有数据接收到,就可以进入我们的函数。我修改了传输我们ADC值。
  1. len = WCHNET_SocketRecvLen(socketid,NULL);                                /* 获取socket缓冲区数据长度  */

  2.        printf("WCHNET_SocketRecvLen %d  socketid %drn",len,socketid);

  3.        WCHNET_SocketRecv(socketid,MyBuf,&len);                                   /* 将接收缓冲区的数据读到MyBuf中*/



  4.        sprintf(adc_value,"adc_value:%drn",adc_val);

  5. //       i = WCHNET_SocketSend(socketid,MyBuf,&len);                               /* 演示回传数据,这种处理方式会出现数据丢失*/

  6.        i = WCHNET_SocketSend(socketid,adc_value,20);

  7.        printf("Actual sending len: %d ret: %xrn",len,i);                       /* 实际发送的长度,发送函数返回值 */

也使用Sprintf拼接了下字符串,后续我们可以通过这种方式写个上位机,但是能主动发送才是最好的方式。下面就是效果:
图片4.png
我接PA3到GND和VCC上获取的值,可以看到还是十分稳定的。

搜索
复制

更多回帖

×
发帖