OpenEdv-开源电子网

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

ADC-DMA同步规则模式 寄存器版代码共享

[复制链接]

65

主题

440

帖子

0

精华

高级会员

Rank: 4

积分
782
金钱
782
注册时间
2012-8-29
在线时间
17 小时
发表于 2013-11-22 10:41:48 | 显示全部楼层 |阅读模式
DMA部分代码与http://www.openedv.com/posts/list/0/24372.htm?privmsg=1#140711 一样

void  ADC1_Init(void)
{    
//先初始化IO口
  RCC->APB2ENR|=1<<2;    //使能PORTA口时钟 
GPIOA->CRL&=0XFFFF000F;//PA1 PA2 PA3 anolog输入 3路ADC  
RCC->APB2ENR|=1<<9;    //ADC1时钟使能  
RCC->APB2RSTR|=1<<9;   //ADC1复位
RCC->APB2RSTR&=~(1<<9);//复位结束    
RCC->CFGR&=~(3<<14);   //分频因子清零
RCC->CFGR|=2<<14;   //SYSCLK/DIV2=12M ADC时钟设置为12M,ADC最大时钟不能超过14M!
  //否则将导致ADC准确度下降!        

ADC1->CR1=0;    //全部清零,需要哪个功能自己配置
ADC1->CR1|=(1<<8);    //扫描模式  
ADC1->CR1&=~(1<<16);      //16-19同步规则工作模式   
ADC1->CR1|=(1<<17);       // 
ADC1->CR1|=(1<<18);       //在ADC2 ADC3中为保留位
ADC1->CR1&=~(1<<19);      //

ADC1->CR2=0;    //全部清零,需要哪个功能自己配置
ADC1->CR2&=~(1<<1);     //单次转换模式
ADC1->CR2|=1<<8; //DMA模式
ADC1->CR2&=~(1<<11);   //右对齐   
ADC1->CR2|=7<<17;   //软件控制转换——SWSTART  同步规则时,同时给ADC1ADC2触发信号 
ADC1->CR2|=1<<20;      //使用用外部触发 必须使用一个事件来触发 (这个是必要的吗?Y)

ADC1->SMPR2&=~(7<<0);  //通道0采样时间清空  
  ADC1->SMPR2|=7<<0;     //通道0  239.5周期,提高采样时间可以提高精确度  

ADC1->SQR1|=1<<21;   //规则序列中三个转换
ADC1->SQR3|=1<<0;   //第一个转换通道1
ADC1->SQR3|=1<<5;   //第二个转换通道1
ADC1->SQR3|=1<<10;   //第三个转换通道1
  
//设置通道1的采样时间
ADC1->CR2|=1<<0;   //开启AD转换器  
ADC1->CR2|=1<<3;       //使能复位校准  
while(ADC1->CR2&1<<3); //等待校准结束  
    //该位由软件设置并由硬件清除。在校准寄存器被初始化后该位将被清除。  
ADC1->CR2|=1<<2;        //开启AD校准   
while(ADC1->CR2&1<<2);  //等待校准结束
//该位由软件设置以开始校准,并在校准结束时由硬件清除  
}  

void  ADC2_Init(void)
{    
//先初始化IO口
  RCC->APB2ENR|=1<<2;    //使能PORTA口时钟 
GPIOA->CRL&=0XFFFF000F;//PA1 PA2 PA3 anolog输入 3路ADC  
RCC->APB2ENR|=1<<10;    //ADC2时钟使能  
RCC->APB2RSTR|=1<<10;   //ADC2复位
RCC->APB2RSTR&=~(1<<10);//复位结束    
RCC->CFGR&=~(3<<14);   //分频因子清零
RCC->CFGR|=2<<14;   //SYSCLK/DIV2=12M ADC时钟设置为12M,ADC最大时钟不能超过14M!
  //否则将导致ADC准确度下降!        

ADC2->CR1=0;    //全部清零,需要哪个功能自己配置
ADC2->CR1|=(1<<8);    //扫描模式  
// ADC2->CR1&=~(1<<16);      //16-19在ADC2 ADC3中为保留位

ADC2->CR2=0;    //全部清零,需要哪个功能自己配置
ADC2->CR2&=~(1<<1);     //单次转换模式
ADC2->CR2|=1<<8; //DMA模式
ADC2->CR2&=~(1<<11);   //右对齐   
ADC2->CR2|=7<<17;   //软件控制转换——SWSTART 
ADC2->CR2|=1<<20;      //使用用外部触发 必须使用一个事件来触发 (这个是必要的吗?Y)

ADC2->SMPR2&=~(7<<0);  //通道0采样时间清空  
  ADC2->SMPR2|=7<<0;     //通道0  239.5周期,提高采样时间可以提高精确度  

ADC2->SQR1|=1<<21;   //规则序列中三个转换
ADC2->SQR3|=3<<0;   //第一个转换通道3
ADC2->SQR3|=3<<5;   //第二个转换通道3
ADC2->SQR3|=3<<10;   //第三个转换通道3
  
//设置通道1的采样时间
ADC2->CR2|=1<<0;   //开启AD转换器  
ADC2->CR2|=1<<3;       //使能复位校准  
while(ADC2->CR2&1<<3); //等待校准结束  
    //该位由软件设置并由硬件清除。在校准寄存器被初始化后该位将被清除。  
ADC2->CR2|=1<<2;        //开启AD校准   
while(ADC2->CR2&1<<2);  //等待校准结束
//该位由软件设置以开始校准,并在校准结束时由硬件清除  
}


DMA_ADC1_EN(3,(u32)data_ADC); ADC1->CR2|=1<<22; //启动规则转换通道
这两句
可以开启ADC1和ADC2同时转换,转换之后通过DMA将结果存入数组。DMA部分初始化把之前的16位数据改为32位数据,原因:ADC_DR寄存器前16位存ADC1数据后16位存ADC1数据。   


这个帖子与前一个帖子基本可以解决大家ADC+DMA应用方面的问题,代码注释很详细。


人生永远追逐着幻光,但谁把幻光看作幻光,谁便沉入无边的苦海
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

38

主题

2061

帖子

6

精华

论坛大神

Rank: 7Rank: 7Rank: 7

积分
3273
金钱
3273
注册时间
2012-1-16
在线时间
37 小时
发表于 2013-11-22 15:03:11 | 显示全部楼层
回复【楼主位】sun_shine:
---------------------------------
谢谢分享
站在巨人的肩膀上不断的前进。。。
回复 支持 反对

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2013-11-22 22:59:16 | 显示全部楼层
谢谢分享
回复 支持 反对

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-7-9 07:32

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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