STM32 ADC筆記單次轉換已測試通過
(2012-05-20 08:45:28)下面分別爲庫函數和直接操作寄存器的兩個範便,我都已測試通過
使用此程序前必要對GPIO設好爲模擬輸入方式
=====================================庫函數版=========================================
void AD_CONFIG_SINGLE(void )
{
//先配置IO口:
ADC_InitTypeDef adcInitStruct;
// //PB1 作爲模擬通道輸入引腳
RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1 , ENABLE); //使能ADC和GPIOC時鐘
//配置ADC:
//將ADC配置成非掃描方式(就是每次處理時不會掃描本組內的所有端口),因爲採用規則組時只有一個寄存器保存adc結果;單次模式。
adcInitStruct.ADC_Mode = ADC_Mode_Independent;
adcInitStruct.ADC_ScanConvMode = DISABLE;
adcInitStruct.ADC_ContinuousConvMode = DISABLE;
adcInitStruct.ADC_ExternalTrigConv = ADC_ExternalTrigConv_None;
adcInitStruct.ADC_DataAlign = ADC_DataAlign_Right;
adcInitStruct.ADC_NbrOfChannel = 1;
ADC_Init(ADC1, &adcInitStruct);
ADC_Cmd(ADC1, ENABLE);
ADC_TempSensorVrefintCmd(ENABLE);
ADC_ResetCalibration(ADC1);
while((ADC_GetResetCalibrationStatus(ADC1)));// && (timeOut--));
ADC_StartCalibration(ADC1);
while((ADC_GetCalibrationStatus(ADC1)));// && (timeOut--));
}
//每次掃描時調用函數:
u16 AD_sysGetAdcResult(void)
{
u16 ad;
ADC_RegularChannelConfig(ADC1, ADC_Channel_10, 1, ADC_SampleTime_55Cycles5);
ADC_ClearFlag(ADC1, ADC_FLAG_EOC);
ADC_SoftwareStartConvCmd(ADC1, ENABLE);
while(ADC_GetFlagStatus(ADC1,ADC_FLAG_EOC)==0);
ad = ADC_GetConversionValue(ADC1);
//ADC_TempSensorVrefintCmd(DISABLE);
//ADC_SoftwareStartConvCmd(ADC1, DISABLE);
//ADC_Cmd(ADC1, DISABLE);
return ad;
}
=====================================寄存器版=========================================
void AD_CONFIG_SINGLE(void)
{
//先初始化 IO 口
//RCC->APB2ENR|=1<<2; //使能 PORTA 口時鐘
//GPIOA->CRL&=0XFFFF0000;//PA0 1 2 3 anolog 輸入
//通道 10/11 設置
RCC->APB2ENR|=1<<9; //ADC1 時鐘使能
RCC->APB2RSTR|=1<<9; //ADC1 復位
RCC->APB2RSTR&=~(1<<9);//復位結束
RCC->CFGR&=~(3<<14); //分頻因子清零
//SYSCLK/DIV2=12M ADC 時鐘設置爲 12M,ADC 最大時鐘不能超過 14M!
//否則將導致 ADC 準確度下降!
RCC->CFGR|=2<<14;
ADC1->CR1&=0XF0FFFF; //工作模式清零
ADC1->CR1|=0<<16; //獨立工作模式
ADC1->CR1&=~(1<<8); //非掃描模式
ADC1->CR2&=~(1<<1); //單次轉換模式