本来打算使用以太网主动向上位机传输值的,但是目前在程序里没有发现,自己暂时也只是看了下历程,这里就改变下传输方式吧,使用上位机发送,下位机再传输数值。 本次历程在TCPClient上修改过来。主要增加了ADC,ADC的配置先看下。 - s16 Calibrattion_Val = 0;
- void ADC_Function_Init(void)
- {
- ADC_InitTypeDef ADC_InitStructure={0};
- GPIO_InitTypeDef GPIO_InitStructure={0};
-
- RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE );
- RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1, ENABLE );
- RCC_ADCCLKConfig(RCC_PCLK2_Div8);
-
- GPIO_InitStructure.GPIO_Pin = GPIO_Pin_2;
- GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN;
- GPIO_Init(GPIOA, &GPIO_InitStructure);
-
- GPIO_InitStructure.GPIO_Pin = GPIO_Pin_3;
- GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN;
- GPIO_Init(GPIOA, &GPIO_InitStructure);
-
- ADC_DeInit(ADC1);
- ADC_InitStructure.ADC_Mode = ADC_Mode_Independent;
- ADC_InitStructure.ADC_ScanConvMode = DISABLE;
- ADC_InitStructure.ADC_ContinuousConvMode = DISABLE;
- ADC_InitStructure.ADC_ExternalTrigConv = ADC_ExternalTrigConv_None;
- ADC_InitStructure.ADC_DataAlign = ADC_DataAlign_Right;
- ADC_InitStructure.ADC_NbrOfChannel = 1;
- ADC_Init(ADC1, &ADC_InitStructure);
-
- ADC_RegularChannelConfig(ADC1, ADC_Channel_2, 1, ADC_SampleTime_239Cycles5 );
- ADC_RegularChannelConfig(ADC1, ADC_Channel_3, 1, ADC_SampleTime_239Cycles5 );
- ADC_AutoInjectedConvCmd(ADC1, ENABLE);
- ADC_Cmd(ADC1, ENABLE);
-
- ADC_BufferCmd(ADC1, DISABLE); //disable buffer
- ADC_ResetCalibration(ADC1);
- while(ADC_GetResetCalibrationStatus(ADC1));
- ADC_StartCalibration(ADC1);
- while(ADC_GetCalibrationStatus(ADC1));
- Calibrattion_Val = Get_CalibrationValue(ADC1);
-
- ADC_BufferCmd(ADC1, ENABLE); //enable buffer
- }
复制代码
这个配置和以前的32基本配置无差别。就是初始化ADC管脚,ADC时钟打开,然后配置转换通道,我这里就采集一路,所以是最后配置的PA3,第三路的ADC。规则转换,只需要在main函数中增加转换的方式即可。 这里我使用累加的方法,不至于采集过快,导致TCP传输出现问题。 之后修改下以太网配置参数,主要是端口和目标IP,主机上得用TCPSever。 其这里是配置了以太网的接收中断,在主循环中一直判断中断的到来,然后读取中断,如果有数据接收到,就可以进入我们的函数。我修改了传输我们ADC值。 - len = WCHNET_SocketRecvLen(socketid,NULL); /* 获取socket缓冲区数据长度 */
- printf("WCHNET_SocketRecvLen %d socketid %drn",len,socketid);
- WCHNET_SocketRecv(socketid,MyBuf,&len); /* 将接收缓冲区的数据读到MyBuf中*/
-
- sprintf(adc_value,"adc_value:%drn",adc_val);
- // i = WCHNET_SocketSend(socketid,MyBuf,&len); /* 演示回传数据,这种处理方式会出现数据丢失*/
- i = WCHNET_SocketSend(socketid,adc_value,20);
- printf("Actual sending len: %d ret: %xrn",len,i); /* 实际发送的长度,发送函数返回值 */
复制代码
也使用Sprintf拼接了下字符串,后续我们可以通过这种方式写个上位机,但是能主动发送才是最好的方式。下面就是效果: 我接PA3到GND和VCC上获取的值,可以看到还是十分稳定的。
搜索
复制
|