初级会员

- 积分
- 74
- 金钱
- 74
- 注册时间
- 2011-7-26
- 在线时间
- 8 小时
|

楼主 |
发表于 2012-8-20 13:42:24
|
显示全部楼层
上代码,大家帮我看看是不是哪里配错了
void ADC_Scan_Init(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; //72M---6分频就是12M
ADC1->CR1&=0XF0FFFF; //工作模式清零//独立工作模式,2个ADC单独工作
ADC1->CR1|=0<<16; //独立工作模式
//ADC1->CR1&=~(1<<8); //非扫描模式
ADC1->CR1|=1<<8; //扫描模式
//ADC1->CR2&=~(1<<1); //单次转换模式
ADC1->CR2|=1<<1; //连续转换----注意这里就已经设置了扫描模式和连续转换
ADC1->CR2&=~(7<<17);
ADC1->CR2|=7<<17; //软件控制转换
ADC1->CR2|=1<<20; //使用用外部触发(SWSTART)!!! 必须使用一个事件来触发
//我们这里是软件事件
ADC1->CR2&=~(1<<11); //右对齐
ADC1->SQR1&=~(0XF<<20); //ADC规则寄存器1
ADC1->SQR1|=3<<20; //1个转换在规则序列中 也就是只转换规则序列1
BIT(ADC1->SQR1,20) = 1;
BIT(ADC1->SQR1,21) = 1;
//规则通道里面有4个要转换
ADC1->SQR3 =0X00018820;//规则通道里面有CH0-1-2-3通道
//设置通道0~3的采样时间 //12M下239.5周期大概接近20us
ADC1->SMPR2&=0XFFFFF000;//通道0,1,2,3采样时间清空
ADC1->SMPR2|=7<<9; //通道3 239.5周期,提高采样时间可以提高精确度
ADC1->SMPR2|=7<<6; //通道2 239.5周期,提高采样时间可以提高精确度
ADC1->SMPR2|=7<<3; //通道1 239.5周期,提高采样时间可以提高精确度
ADC1->SMPR2|=7<<0; //通道0 239.5周期,提高采样时间可以提高精确度
ADC1->CR2|=1<<0; //开启AD转换器
ADC1->CR2|=1<<3; //使能复位校准
while(ADC1->CR2&1<<3); //等待校准结束
//该位由软件设置并由硬件清除。在校准寄存器被初始化后该位将被清除。
ADC1->CR2|=1<<2; //开启AD校准
while(ADC1->CR2&1<<2); //等待校准结束
BIT(ADC1->CR1,5) = 1; //开启ADC中断
MY_NVIC_Init(2,2,ADC1_2_IRQChannel,4);//抢占2,子优先级3,组2
ADC1->CR2|=1<<22; //启动规则转换通道
}
u16 adc_table[4]={0,0,0,0};
void Get_Adc_Scan(void)//用中断的话,该函数不用
{
while(!(ADC1->SR&1<<1));//等待转换结束
adc_table[0]= ADC1->DR;
//BIT(ADC1->SR,1) = 0;
while(!(ADC1->SR&1<<1));
adc_table[1]= ADC1->DR;
// BIT(ADC1->SR,1) = 0;
while(!(ADC1->SR&1<<1));
adc_table[2]= ADC1->DR;
// BIT(ADC1->SR,1) = 0;
while(!(ADC1->SR&1<<1));
adc_table[3]= ADC1->DR;
//BIT(ADC1->SR,1) = 0;
// BIT(ADC1->CR2,22) = 0;
//return ADC1->DR; //返回adc值
}
u8 state_adc = 0;
void ADC_IRQHandler(void)
{
ADC1->CR2|=1<<22;
switch(state_adc)
{
case 0: adc_table[0]= ADC1->DR;state_adc++;break;
case 1: adc_table[1]= ADC1->DR;state_adc++;break;
case 2: adc_table[2]= ADC1->DR;state_adc++;break;
case 3: adc_table[3]= ADC1->DR;state_adc=0;break;
} //启动规则转换通道
} |
|