您的位置: OpenADSP社区论坛 -> Blackfin专区 -> 技术讨论区 -> [求助] 二维MDMA配置
本帖共有626个阅读者
发表帖子 发表投票 回复主题
[求助] 二维MDMA配置
mathslee(论坛新手)
mathslee
头衔:社区公民
帮派:无帮无派
帖数:35
金钱:421
积分:43
注册时间:2013/9/23
楼主信息 | 留言 | Email | 主页 | 编辑 | 管理 | 离线
[求助] 二维MDMA配置
最近在学习bf609dma,想用二维搬移一副图像 width=720×2,height=480, 数据大小是1BYTE的,下面是我配置的,但是搬移的不对,请高手帮忙,谢谢.....


#define MEM_SIZE_32 0x200
#define COPY_2D                 0x04000000

void DMA_Copy(uint8_t src[], uint8_t dst[])
{
/* configure destination registers */
*pREG_DMA22_CFG = BITM_DMA_CFG_WNR | MEM_SIZE_32| COPY_2D;
*pREG_DMA22_ADDRSTART = dst;
*pREG_DMA22_XCNT = 720*2;
*pREG_DMA22_XMOD = 4;
*pREG_DMA22_YCNT = 480;
*pREG_DMA22_YMOD = 1;

/* configure source registers */
*pREG_DMA21_CFG = MEM_SIZE_32|COPY_2D ;
*pREG_DMA21_ADDRSTART = src;
*pREG_DMA21_XCNT = 720*2;
*pREG_DMA21_XMOD = 4;
*pREG_DMA21_YCNT = 480;
*pREG_DMA21_YMOD = 1;

/* enable DMA */
*pREG_DMA21_CFG |= 0x1;
*pREG_DMA22_CFG |= 0x1;

/* wait here if DMA_DONE is a 0x0 because the DMA
   is still going */
while( (*pREG_DMA22_STAT & BITM_DMA_STAT_IRQDONE) == 0x0 )
{};

/* turn off DMA */
*pREG_DMA22_CFG = 0x0;
*pREG_DMA21_CFG = 0x0;

/* clear the DMA_DONE bit */
*pREG_DMA22_STAT = 0x1;
}



这家伙很懒,什么也没有留下!
等级:论坛新手 参考IP地址:*.*.*.*
2013/11/11 11:39:06
尊贵身份标志
andy(论坛版主)
andy
头衔:社区公民
帮派:无帮无派
帖数:2287
金钱:11132
积分:2263
注册时间:2011/6/8
1信息 | 留言 | Email | 主页 | 编辑 | 管理 | 离线
609没用过,但从经验上看,MEMDMA需要原地址和目的地址,你配置的DMA是按照内存到接口的模式配置的,肯定不正确,这里有一个533上的MDMA代码,你参考下吧。

这家伙很懒,什么也没有留下!
等级:论坛版主 参考IP地址:*.*.*.*
2013/11/11 21:18:34
mathslee(论坛新手)
mathslee
头衔:社区公民
帮派:无帮无派
帖数:35
金钱:421
积分:43
注册时间:2013/9/23
2信息 | 留言 | Email | 主页 | 编辑 | 管理 | 离线
谢谢andy...

这家伙很懒,什么也没有留下!
等级:论坛新手 参考IP地址:*.*.*.*
2013/11/12 10:57:42
Powered by OpenADSP Copyright © 2010 www.Openadsp.com. All rights reserved.153966 Call, 1 Queries, Processed in 0.015625 second(s),