linux 定时采样 adc,ADC采样放在定时器里的问题。

小弟我最近在搞电设,用到ADC采样处理。用定时器触发ADC+DMA都会使用。就是开始在调试的时候,我用ADC1的两个采样而不用DMA可以使用(论坛都说要DMA,不过我不用DMA还是有的了),然后直接把ADC的采样函数u16 Get_Adc(u8 ch) 直接放在定时器中断里就用不了了(如Io_adc= Get_Adc(ADC_Channel_12);)。一直不知道什么原因,不过放在主函数里还是可以使用的,硬仿的时候貌似是某个flag没变,然后导致这个函数Get_Adc(u8 ch) 里的一个while语句出不了。

void  Adc_Init(void)

{

ADC_InitTypeDef ADC_InitStructure;

GPIO_InitTypeDef GPIO_InitStructure;

RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC|RCC_APB2Periph_ADC1, ENABLE );          //使能ADC1通道时钟

//PA1 作为模拟通道输入引脚

GPIO_InitStructure.GPIO_Pin = GPIO_Pin_2|GPIO_Pin_3;

GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN;                //模拟输入引脚

GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;

GPIO_Init(GPIOC, &GPIO_InitStructure);

RCC_ADCCLKConfig(RCC_PCLK2_Div6);   //设置ADC分频因子6 72M/6=12,ADC最大时间不能超过14M

ADC_DeInit(ADC1);  //复位ADC1,将外设 ADC1 的全部寄存器重设为缺省值

ADC_InitStructure.ADC_Mode = ADC_Mode_Independent;        //ADC工作模式:ADC1和ADC2工作在独立模式

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数据右对齐

ADC_InitStructure.ADC_NbrOfChannel = 1;        //顺序进行规则转换的ADC通道的数目

ADC_Init(ADC1, &ADC_InitStructure);        //根据ADC_InitStruct中指定的参数初始化外设ADCx的寄存器

ADC_Cmd(ADC1, ENABLE);        //使能指定的ADC1

ADC_ResetCalibration(ADC1);        //使能复位校准

while(ADC_GetResetCalibrationStatus(ADC1));        //等待复位校准结束

ADC_StartCalibration(ADC1);         //开启AD校准

while(ADC_GetCalibrationStatus(ADC1));         //等待校准结束

}

//获得ADC值

//ch:通道值 0~3

u16 Get_Adc(u8 ch)

{

//设置指定ADC的规则组通道,一个序列,采样时间

ADC_RegularChannelConfig(ADC1, ch, 1, ADC_SampleTime_13Cycles5);        //ADC1,ADC通道,采样时间为239.5周期

ADC_SoftwareStartConvCmd(ADC1, ENABLE);                //使能指定的ADC1的软件转换启动功能

while(!ADC_GetFlagStatus(ADC1, ADC_FLAG_EOC ));//等待转换结束

return ADC_GetConversionValue(ADC1);        //返回最近一次ADC1规则组的转换结果

}

void Get_all_Adc(void) //取值

{

int i,j,temp;

for(i=0;i

{

Io_adc[i] = Get_Adc(ADC_Channel_12);    //PC2

Uo_adc[i] = Get_Adc(ADC_Channel_13);    //PC3

}

}

//*****************************定时器中断******************************************//

void TIM3_IRQHandler(void)   //TIM3中断

{

if(TIM_GetITStatus(TIM3, TIM_IT_Update) != RESET) //检查指定的TIM中断发生与否:TIM 中断源

{

TIM_ClearITPendingBit(TIM3, TIM_IT_Update  );  //清除TIMx的中断待处理位:TIM 中断源

Get_all_Adc();

}

}

我来回答

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值