您的位置: OpenADSP社区论坛 -> Blackfin专区 -> 技术讨论区 -> [求助]BF518基于描述符的DMA传输问题
本帖共有1145个阅读者
发表帖子 发表投票 回复主题
[求助]BF518基于描述符的DMA传输问题
xuliqiang(论坛新手)
xuliqiang
头衔:社区公民
帮派:无帮无派
帖数:3
金钱:127
积分:5
注册时间:2011/11/13
楼主信息 | 留言 | Email | 主页 | 编辑 | 管理 | 离线
[求助]BF518基于描述符的DMA传输问题
最近在用BF518这款DSP做网络传输,其中用到基于描述符的DMA传输,输出采用DMA2通道。
//以太网帧头格式
ADI_ETHER_FRAME_BUFFER dma12={
                                16,                                                                
                                {0xff,0xff,0xff,0xff,0xff,0xff},
                                {0x00,0x24,0x8c,0xf8,0x05,0xb4},
                                {0x0800}
                                     };
//DMA描述符                                                        
DMA_DESCRIPTOR dma2={NULL,&dma12,0x758b,16};

*pDMA2_NEXT_DESC_PTR=&dma2;
*pDMA2_X_COUNT=16;
*pDMA2_X_MODIFY=4;
register_handler(ik_ivg11, EMAC_TX_ISR);
*pSIC_IMASK0 |= 0x40000000;
*pSIC_IAR3 &= 0xf0f0ffff;
*pSIC_IAR3 |=(4<<24);
*pIMASK |=(1<<11);
*pDMA2_CONFIG=0x758b;
*pEMAC_OPMODE |=0x10000;

我是这样编程的,可是查询DMA2_IRQ_STATUS寄存器的最后一位,始终是1,没有改变过,并且我的产生中断函数
EX_INTERRUPT_HANDLER(EMAC_TX_ISR)
{
        printf("TX is completed\n");
}也没有执行,请问这是怎么回事?

这家伙很懒,什么也没有留下!
等级:论坛新手 参考IP地址:*.*.*.*
2012/4/25 22:16:43
xuliqiang(论坛新手)
xuliqiang
头衔:社区公民
帮派:无帮无派
帖数:3
金钱:127
积分:5
注册时间:2011/11/13
1信息 | 留言 | Email | 主页 | 编辑 | 管理 | 离线
还是自己回答吧,是要先使能EMAC,再使能DMA2传输,即*pDMA2_CONFIG=0x758b;
*pEMAC_OPMODE |=0x10000;这两句需要把位置换一下就OK了


这家伙很懒,什么也没有留下!
等级:论坛新手 参考IP地址:*.*.*.*
2012/4/26 20:53:06
Powered by OpenADSP Copyright © 2010 www.Openadsp.com. All rights reserved.154000 Call, 1 Queries, Processed in 0.015015 second(s),