阅读:1251回复:0
Amcc5933的DMA传输及相关问题求助
请各位大虾告诉我,DMA传输之间的设置最短需要多长时间?最好以amcc5933为例。
我自己的一个实验如下: 只进行板子到系统内核内存的dma传输(数据不传到应用程序的缓冲区),两次DMA之间也需要有35微秒左右的处理时间(fifo持续满了35微秒),而fifo不到8微秒就满了,可这35微秒大概是必需的时间吧?(因为先开一块物理连续的内存块,dma设置时直接把其地址指针写入mwar,所以这个处理只包括“假”完成irp包、写四个dma相关寄存器和中断后写intcsr确认中断这几个必要动作) 但是不应该啊,用一个商业板子及其驱动作相同的试验,fifo从来就没有满过!! 急需各位大虾指点如何DMA传输才可以保证数据流连续,fifo不满。是不是需要什么别的技术?在win2k ddk的帮助里没找到别的方法啊。 听说过双缓冲DMA传输,不清楚怎么回事,谁告诉我吧? 谢谢! |
|
|