关于stm32f407的三重DMA模式
请问大侠,这边手册说的生成3个DMA请求不知道是哪个DMA通道生成的。ADC1 、ADC2 、ADC3不是在DMA2模块中不是都有对应的相应的数据流和通道。
1、是否是ADC1、ADC2、ADC3只要一个ADC设置相应的DMA通道,并启动。如,设置ADC1相对应的DMA通道,并启动。当ADC1装换完成时,ADC1对应的DMA通道是不是就会发出3个DMA请求?
2、是否是ADC1、ADC2、ADC3每个ADC都要设置相应的DMA通道,并启动。如,要设置ADC1、ADC2、ADC3相对应的通道,并启动。当ADC1转换完成时,就生成一个ADC1相对应的DMA请求,当ADC2转换完成时,就生成一个ADC2相对应的DMA请求,当ADC3转换完成时,就生成一个ADC3相对应的DMA请求?
不知道是上面的哪种情况,还是都不是?
希望有用
DMA传输有三个步骤:
1. 从外设数据寄存器或者内存中取出数据,外设数据寄存器地址和内存地址分别由DMA_SxPAR寄存器和DMA_SxM0AR寄存器给出
2. 将取出的数据进行存储
3. DMA_SxNDTR寄存器的自减,DMA_SxNDTR寄存器里的值表示还需要传输的数据个数
通道选择:
每个数据流的通道可以通过DMA_SxCR寄存器中的CHSEL 设置。通道和数据流的映射祥参数据手册
是情况二,每个ADC通道转换结束都会产生一个DMA请求,产生DMA请求的同时会判断DMA位是否为01,是01则一次性完成三个DMA数据传输到SRAM,如果不是会继续按照既定设置ADC采样。 奔跑小蜗牛 发表于 2014-12-18 15:03
是情况二,每个ADC通道转换结束都会产生一个DMA请求,产生DMA请求的同时会判断DMA位是否为01,是01则 ...
没听明白,能否说的详细点。一次性完成三个DMA数据传输到SRAM,这三个DMA请求是不是让一个同一个DMA通道传输三次。还是怎么?
[*]/***DMA设置***/
[*]void ADC_DMA_Config(void)
[*]{
[*]RCC->AHB1ENR |= (1<<22); //使能DMA2时钟
[*]ADC3->CR2 &= ~(1<<8);//ADC3 dma发送模式除能
[*]DMA2_Stream0->CR &= 0xFFFFFFFE; //除能DMA2_Stream0
[*]while(DMA2_Stream0->CR & 0x00000001);//确保DMA可以被设置
[*]DMA2->LIFCR |= 0x0000003D;//传送前清空DMA2_Stream0所有中断标志
[*]DMA2_Stream0->PAR = (uint32_t)&ADC->CDR;//设置外设地址
[*]DMA2_Stream0->M0AR = (uint32_t)ADCConvertedVault; //设置内存地址
[*]DMA2_Stream0->CR |= 0x0002800;//16位数据
[*]DMA2_Stream0->NDTR = 10000; //设置dma传输数据的数量
[*]/*
[*] 设置dma2通道0,即ADC1
[*] 优先级Medium
[*] 传输方向外设到内存
[*] 内存递增模式
[*] 循环模式
[*] 传输完成中断
[*]*/
[*]DMA2_Stream0->CR |= ( 0x00000000 | 0x00010000 | 0x0 | (1<<10) | (1<<8) | (1<<4) );
[*]
[*]NVIC->IP = 0xB0;
[*]NVIC->ISER |= (1<<(56-32));
[*]
[*]DMA2_Stream0->CR |= 1; //DMA2数据流0使能
[*]}
[*]这是三重ADC转换时DMA设置的函数,不过是寄存器写的, DMA2_Stream0->PAR = (uint32_t)&ADC->CDR;//设置外设地址,DMA2数据流0外设地址指向了ADC->CDR寄存器地址
楼主问题是否解决了呢?谢谢楼上几位朋友回答 谢谢大家的知道,问题已经解决 沐紫 发表于 2014-12-22 13:41
楼主问题是否解决了呢?谢谢楼上几位朋友回答
管理员大虾,我在写程序的时候,用的双重规则同时模式,发现一旦adc转换设定为定时器触发,软件触发便触发不了adc转换。是程序问题还是单片机自身限制。查阅芯片手册没有发现关于这个的说明。谢谢
页:
[1]