DMA的理解

2019-07-20 13:08发布

有几个问题希望大家帮忙解答!
比如我定义一个外部的SRAM空间 sram_buf[100];
用双缓冲的话,比如定义buf1[50],buf2[50]

1. 那么DMA_BufferSize定义成多大比较好?

2. 还有就是,buf1的数据存储进sram_buf里,占了前面50个,buf2会自动从第51个开始往里面写数据吗?

3. 下面代码里的*pbuf该怎么理解,DMA2_Stream1->CR&(1<<19)这一句的意义

[mw_shl_code=c,true]void jpeg_dcmi_rx_callback(void)
{
        u16 i;
        u32 *pbuf;
        pbuf=jpeg_data_buf+jpeg_data_len;//偏移到有效数据末尾
        if(DMA2_Stream1->CR&(1<<19))//buf0已满,正常处理buf1
        {
                for(i=0;i<jpeg_dma_bufsize;i++)pbuf=jpeg_buf0;//读取buf0里面的数据
                jpeg_data_len+=jpeg_dma_bufsize;//偏移
        }else //buf1已满,正常处理buf0
        {
                for(i=0;i<jpeg_dma_bufsize;i++)pbuf=jpeg_buf1;//读取buf1里面的数据
                jpeg_data_len+=jpeg_dma_bufsize;//偏移
        }        
}[/mw_shl_code]
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。