本帖最后由 underwood_w 于 2016-8-7 11:34 编辑
本意是用TIM2_CH2触发ADC1_CH0进行单次转换,显示在LCD,ADC和TIM2程序如下:ADC配置:
void Adc_Init(void)
{
GPIO_InitTypeDef GPIO_InitStruct;
ADC_CommonInitTypeDef ADC_CommonInitStruct;
ADC_InitTypeDef ADC_InitStruct;
RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1,ENABLE);
RCC_AHB1PeriphResetCmd(RCC_AHB1Periph_GPIOA,ENABLE);
GPIO_InitStruct.GPIO_Mode=GPIO_Mode_AN;
GPIO_InitStruct.GPIO_OType=GPIO_OType_PP;
GPIO_InitStruct.GPIO_Pin=GPIO_Pin_0;
GPIO_InitStruct.GPIO_PuPd = GPIO_PuPd_NOPULL ;
GPIO_Init(GPIOA,&GPIO_InitStruct);
RCC_APB2PeriphResetCmd(RCC_APB2Periph_ADC1,ENABLE);
RCC_APB2PeriphResetCmd(RCC_APB2Periph_ADC1,DISABLE);
ADC_DeInit();
ADC_CommonInitStruct.ADC_DMAAccessMode=ADC_DMAAccessMode_Disabled;
ADC_CommonInitStruct.ADC_Mode=ADC_Mode_Independent;
ADC_CommonInitStruct.ADC_Prescaler=ADC_Prescaler_Div4;
ADC_CommonInitStruct.ADC_TwoSamplingDelay=ADC_TwoSamplingDelay_5Cycles;
ADC_CommonInit(&ADC_CommonInitStruct);
//ADC13õê¼»ˉ
ADC_InitStruct.ADC_ContinuousConvMode=DISABLE;
ADC_InitStruct.ADC_DataAlign=ADC_DataAlign_Right;
ADC_InitStruct.ADC_ExternalTrigConv=ADC_ExternalTrigConv_T2_CC2;
ADC_InitStruct.ADC_ExternalTrigConvEdge=ADC_ExternalTrigConvEdge_Falling;//配置为下降沿触发
ADC_InitStruct.ADC_NbrOfConversion=1;
ADC_InitStruct.ADC_Resolution=ADC_Resolution_12b;
ADC_InitStruct.ADC_ScanConvMode=DISABLE;
ADC_Init(ADC1,&ADC_InitStruct);
//ê1ÄüADC1
ADC_Cmd(ADC1, ENABLE);
}
u16 Get_Adc(u8 ch)
Get_Adc(u8 ch)
{
ADC_RegularChannelConfig(ADC1, ch, 1, ADC_SampleTime_480Cycles );
//TIM_GenerateEvent(TIM2,TIM_EventSource_CC2);
while(!ADC_GetFlagStatus(ADC1, ADC_FLAG_EOC ));
return ADC_GetConversionValue(ADC1);
}
定时器2配置:
void My_TIM2_Init(u16 presca,u16 period)
{
GPIO_InitTypeDef GPIO_InitStruct;
TIM_TimeBaseInitTypeDef TIM_TimeBaseInitStruct;
TIM_OCInitTypeDef TIM_OCInitStruct;
RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2,ENABLE);
RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOB,ENABLE);
GPIO_InitStruct.GPIO_Mode=GPIO_Mode_AF;
GPIO_InitStruct.GPIO_OType=GPIO_OType_PP;
GPIO_InitStruct.GPIO_Pin=GPIO_Pin_3;
GPIO_InitStruct.GPIO_PuPd=GPIO_PuPd_UP;
GPIO_InitStruct.GPIO_Speed=GPIO_Speed_50MHz; //50MHZ
GPIO_Init(GPIOB,&GPIO_InitStruct);
GPIO_PinAFConfig(GPIOB,GPIO_PinSource3,GPIO_AF_TIM2);
TIM_InternalClockConfig(TIM2);
TIM_TimeBaseInitStruct.TIM_ClockDivision=TIM_CKD_DIV4;
TIM_TimeBaseInitStruct.TIM_CounterMode=TIM_CounterMode_Down;
TIM_TimeBaseInitStruct.TIM_Period=period;
TIM_TimeBaseInitStruct.TIM_Prescaler=presca;
TIM_TimeBaseInitStruct.TIM_RepetitionCounter=period;
TIM_TimeBaseInit(TIM2,&TIM_TimeBaseInitStruct);
TIM_OCInitStruct.TIM_OCMode=TIM_OCMode_PWM1;
TIM_OCInitStruct.TIM_OutputState=TIM_OutputState_Enable;
TIM_OCInitStruct.TIM_OCPolarity=TIM_OCPolarity_Low;
TIM_OC2Init(TIM2,&TIM_OCInitStruct);
TIM_OC2PreloadConfig(TIM2,TIM_OCPreload_Enable);
TIM_SetCompare2(TIM2,period/2);
TIM_ARRPreloadConfig(TIM2,ENABLE);
TIM_Cmd(TIM2,ENABLE);
}
ADC没有转换,结果始终是0。但是定时器确定有PWM输出(PB
3)引脚的电平如下:
图0
我比较疑惑下图所说ADC由TIM_CH2触发的意思是什么?
1.由TIM2_CH2的引脚(PB3)的边沿触发。
2.由TIM_CH2事件触发。
如果是第1种理解,那么配置TIM_CH2的PWM输出,在计数值和设置值匹配时PWM输出改变出现需要的边沿,从而触发ADC转换。但是为什么下图1表51说的是片上定时器的内部信号“TIM2_CH2事件”触发(TIM2_CH2事件触发是指TIM2_CH2比较通道计数值和设置值匹配会产生一个事件?)。
如果是第2种理解,即当
TIM2_CH2比较通道计数值和设置值匹配时产生一个事件,这个事件引起某个标志位改变,然后触发ADC转换。但是为什么下图2ADC配置位还要配置触发边沿极性?而且在定时器TIM2_CH2的框图并没有发现比较匹配时会产生事件(只可能中断),如下图3所示。TIM2手册也没有说比较匹配时会产生事件。
图1
图2
图3
我又试着直接在
Get_Adc(u8 ch) 调用TIM_GenerateEvent(TIM2,TIM_EventSource_CC2);手动产生一个TIM_CC2事件,但是ADC还是没有转换。
因此我很纠结图1图2所指的定时器触发ADC转换到底是什么样的机制?麻烦清楚的朋友解释一下,谢谢!
多谢指正。改正后可以用了,谢谢
一周热门 更多>