关于ADC+DMA实时数据的寄存器版本

2019-07-21 02:22发布

我要实现PA2和PA3的ADC采集,然后实时存到一个数组。现在是只能有开机的更新的一次数据,之后就不更新了。下面是我的配置,请大家看看有什么问题:

MYDMA_Config(DMA1_Channel1,(u32)&(ADC1->DR),(u32)AD,2);


void MYDMA_Config(DMA_Channel_TypeDef*DMA_CHx,u32 cpar,u32 cmar,u16 cndtr)
{
        RCC->AHBENR|=1<<0;                        //开启DMA1时钟
        delay_ms(5);                                //等待DMA时钟稳定
        DMA_CHx->CPAR=cpar;                  //DMA1 外设地址
        DMA_CHx->CMAR=(u32)cmar;         //DMA1,存储器地址
        DMA1_MEM_LEN=cndtr;              //保存DMA传输数据量
        DMA_CHx->CNDTR=cndtr;            //DMA1,传输数据量
        DMA_CHx->CCR=0X00000000;        //复位
        DMA_CHx->CCR&=0<<4;                  //从外设读
        DMA_CHx->CCR|=1<<5;                  //循环模式
        DMA_CHx->CCR&=0<<6;                 //外设地址非增量模式
        DMA_CHx->CCR|=1<<7;                  //存储器增量模式
        DMA_CHx->CCR|=1<<8;                  //外设数据宽度为16位
        DMA_CHx->CCR|=1<<10;                 //存储器数据宽度16位
        DMA_CHx->CCR|=1<<12;                 //中等优先级
        DMA_CHx->CCR&=0<<14;                 //非存储器到存储器模式
        DMA_CHx->CCR|=1<<0;          //开启DMA传输       
}



void  Adc_Init(void)
{   
        //先初始化IO口
        RCC->APB2ENR|=1<<2;    //使能PORTA口时钟
        GPIOA->CRL&=0XFFFFF0FF;//PA2 anolog输入
        GPIOA->CRL&=0XFFFF0FFF;//PA3 anolog输入
        //通道2/3设置                         
        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);    //连续转换模式
        ADC1->CR2&=~(7<<17);          
        ADC1->CR2|=7<<17;           //软件控制转换  
        ADC1->CR2|=1<<20;      //使用外部触发(SWSTART)!!!        必须使用一个事件来触发
        ADC1->CR2&=~(1<<11);   //右对齐         
        ADC1->SQR1&=~(0XF<<20);
        ADC1->SQR1|=1<<20;     //2个转换在规则序列中
        ADC1->SQR3&=~(0X1F<<0); //通道2在规则序列中1
        ADC1->SQR3|=2<<0;
        ADC1->SQR3&=~(0X1F<<5); //通道3在规则序列中2
        ADC1->SQR3|=3<<5;        
        //设置通道2的采样时间
        ADC1->SMPR2&=~(7<<6);  //通道2采样时间清空          
        ADC1->SMPR2|=7<<6;     //通道2  239.5周期,提高采样时间可以提高精确度
        //设置通道3的采样时间
        ADC1->SMPR2&=~(7<<9);  //通道3采样时间清空          
        ADC1->SMPR2|=7<<9;     //通道3  239.5周期,提高采样时间可以提高精确度
        ADC1->CR2|=1<<8;           //开启DMA模式
        ADC1->CR2|=1<<0;           //开启AD转换器         
        ADC1->CR2|=1<<3;       //使能复位校准  
        while(ADC1->CR2&1<<3); //等待校准结束                          
    //该位由软件设置并由硬件清除。在校准寄存器被初始化后该位将被清除。                  
        ADC1->CR2|=1<<2;        //开启AD校准       
        while(ADC1->CR2&1<<2);  //等待校准结束
        //该位由软件设置以开始校准,并在校准结束时由硬件清除
        ADC1->CR2 |= 0x00500000;  
}

友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。