OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 4051|回复: 1

发现个奇怪的问题,AD转换,双通道数据正常,当增加成三通道的时候数据就乱了,这是怎么回事?

[复制链接]

9

主题

15

帖子

0

精华

初级会员

Rank: 2

积分
70
金钱
70
注册时间
2015-4-9
在线时间
3 小时
发表于 2015-5-11 10:14:01 | 显示全部楼层 |阅读模式
5金钱
[mw_shl_code=c,true]void Con_Trsf_AD_DMA() { GPIO_InitTypeDef GPIO_InitStructure; ADC_InitTypeDef ADC_InitStructure; DMA_InitTypeDef DMA_InitStructure; GPIO_InitStructure.GPIO_Pin = trsf_Pin; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN; GPIO_Init(trsf_GPIO, &GPIO_InitStructure); GPIO_InitStructure.GPIO_Pin = CO2_Pin; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN; GPIO_Init(CO2_GPIO, &GPIO_InitStructure); GPIO_InitStructure.GPIO_Pin = vol_Pin; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN; GPIO_Init(vol_GPIO, &GPIO_InitStructure); /* Enable DMA1 clock */ RCC_AHBPeriphClockCmd(RCC_AHBPeriph_DMA1, ENABLE); /* Enable ADC1 and GPIOC clock */ RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1, ENABLE); DMA_DeInit(DMA1_Channel1); DMA_InitStructure.DMA_PeripheralBaseAddr = ADC1_DR_Address; DMA_InitStructure.DMA_MemoryBaseAddr = (uint32_t)&ADCConvertedValue; DMA_InitStructure.DMA_DIR = DMA_DIR_PeripheralSRC; DMA_InitStructure.DMA_BufferSize = 5000; DMA_InitStructure.DMA_PeripheralInc = DMA_PeripheralInc_Disable; DMA_InitStructure.DMA_MemoryInc = DMA_MemoryInc_Enable; DMA_InitStructure.DMA_PeripheralDataSize = DMA_PeripheralDataSize_HalfWord; DMA_InitStructure.DMA_MemoryDataSize = DMA_MemoryDataSize_HalfWord; DMA_InitStructure.DMA_Mode = DMA_Mode_Circular; DMA_InitStructure.DMA_Priority = DMA_Priority_High; DMA_InitStructure.DMA_M2M = DMA_M2M_Disable; DMA_Init(DMA1_Channel1, &DMA_InitStructure); /* Enable DMA1 channel1 */ DMA_Cmd(DMA1_Channel1, ENABLE); /* ADC1 configuration ------------------------------------------------------*/ ADC_InitStructure.ADC_Mode = ADC_Mode_Independent; ADC_InitStructure.ADC_ScanConvMode = ENABLE; ADC_InitStructure.ADC_ContinuousConvMode = ENABLE; ADC_InitStructure.ADC_ExternalTrigConv = ADC_ExternalTrigConv_None; ADC_InitStructure.ADC_DataAlign = ADC_DataAlign_Right; ADC_InitStructure.ADC_NbrOfChannel = 2; ADC_Init(ADC1, &ADC_InitStructure); /* ADC1 regular channel1 configuration */ ADC_RegularChannelConfig(ADC1, CO2_Channelx, 1, ADC_SampleTime_239Cycles5); //ADC_RegularChannelConfig(ADC1, ADC_Channelx, 2, ADC_SampleTime_239Cycles5); ADC_RegularChannelConfig(ADC1, vol_Channel, 2, ADC_SampleTime_239Cycles5); //ADC_RegularChannelConfig(ADC1, ADC_Channelx, 3, ADC_SampleTime_239Cycles5); /* Enable ADC1 DMA */ ADC_DMACmd(ADC1, ENABLE); /* Enable ADC1 */ ADC_Cmd(ADC1, ENABLE); /* Enable ADC1 reset calibration register */ ADC_ResetCalibration(ADC1); /* Check the end of ADC1 reset calibration register */ while(ADC_GetResetCalibrationStatus(ADC1)); /* Start ADC1 calibration */ ADC_StartCalibration(ADC1); /* Check the end of ADC1 calibration */ while(ADC_GetCalibrationStatus(ADC1)); ADC_SoftwareStartConvCmd(ADC1, ENABLE); }[/mw_shl_code]
这是配置。
下面是读取函数
[mw_shl_code=c,true]void quick(uint16_t *a,int16_t i,int16_t j) //?ì?????ò { int16_t m,n,temp; uint16_t k; m=i; n=j; k=a[(i+j)/2]; /*??????????*/ do { while(a[m]<k&&m<j) m++; /* ??×ó??????±?k?ó??????*/ while(a[n]>k&&n>i) n--; /* ??????×ó??±?k????????*/ if(m<=n) { /*?????????ú×????????ò????*/ temp=a[m]; a[m]=a[n]; a[n]=temp; m++; n--; } }while(m<=n); if(m<j) quick(a,m,j); /*???????é*/ if(n>i) quick(a,i,n); } uint16_t readSF() //?????ò,??????×??ó×?????,×??ó???ù { uint8_t ji=0; ADC_TR_ave=0; for(ji=0;ji<20;ji++) { ADC_Tmp[ji]=ADCConvertedValue[ji*3+1]; } quick(ADC_Tmp,0,19); //0~35±ê??,??36?? for(ji=2;ji<18;ji++) { ADC_TR_ave+=ADC_Tmp[ji]; } ADC_TR_ave>>=4; if(ADC_TR_ave>4000) { trSF=1002; } else { trSF=(float)(ADC_TR_ave*(3.3/4096))*100; //AD*0.8/2 } if(trSF>999) trSF=999; return trSF; } uint16_t readCO2() { uint8_t ji=0; ADC_CO2_ave=0; for(ji=0;ji<20;ji++) { CO2_Tmp[ji]=ADCConvertedValue[ji*2]; } quick(CO2_Tmp,0,19); //0~35±ê??,??36?? for(ji=2;ji<18;ji++) { ADC_CO2_ave+=CO2_Tmp[ji]; } ADC_CO2_ave>>=4; CO2=(float)(ADC_CO2_ave*(3.3/4096))*100; //AD*0.8/2 return CO2; } uint16_t readVOL() { uint8_t ji=0; ADC_VOL_ave=0; for(ji=0;ji<20;ji++) { ADC4_Tmp[ji]=ADCConvertedValue[ji*2+1]; } quick(ADC4_Tmp,0,19); //0~35±ê??,??36?? for(ji=2;ji<18;ji++) { ADC_VOL_ave+=ADC4_Tmp[ji]; } ADC_VOL_ave>>=4; Vol=(uint16_t)(ADC_VOL_ave*330/4096); //AD*0.8/2 return Vol; }[/mw_shl_code]
然后再主函数里面分别读取三个ad转换值
用的是10\11\15三个通道,其中其中任意两个组合成双通道都可以正常采集,三个一起就采集数据就异常了

正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2015-5-12 00:26:10 | 显示全部楼层
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-6-22 14:48

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表