有几个问题希望大家帮忙解答!
比如我定义一个外部的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]
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
2,如果是buf到SRAM,那么会。
3,就是一个指针,用来操作数据和地址。至于判断语句,自己看参考手册,找寄存器描述。
一周热门 更多>