zxz19890318 发表于 2010-8-9 16:39:42

请教,关于sdram与flash之间的DMA传输

本帖最后由 fpgaw 于 2011-6-29 17:50 编辑

昨天做了sdram到on-chip的DMA实验,实验是成功的。可今天做sdram到flash的DMA实验就是成功不了。还请前辈们赐教:



设置的时候应该把sdram定为发送端口,把flash定为接收端口。可是flash是片外存储器,只能靠三态桥连接,所以接收端口接到三态桥,然后通过三态桥和flash连接,也不知道这样行不行,或者是不是在软件编程的时候要通过一定的指令将接收端口和flash连接起来。



上图是做好的硬件,管脚绑定没问题,因为是按着以前成功的例子绑的管脚。

下面是Nios程序,这是在网上抄过来稍微修改了一下,用这个程序做sdram到on-chip的实验是成功的,我认为只要两个存储器的地址联系上了程序应该大同小异。


/**********实现sdram到flash的数据传输******************/

#include <stdio.h>
#include <stdlib.h>
#include <sys/alt_dma.h>
#include "system.h"
static volatile int rx_done = 0;
alt_u8 i;
int rc;
alt_dma_txchan txchan;
alt_dma_rxchan rxchan;

void* tx_data = (void*) 0x02002000; /* 源地址,0x02002000是sdram的某一起始地址 */
void* rx_buffer = (void*) 0x04402000; /* 目标地址,0x04010000为flash的某一起始地址*/

//DMA传输结束回调函数

static void done_t(void* handle, void* data)//done_t()是DMA完成后被调用的回调函数

{
   rx_done++;
}

int main (int argc, char* argv[], char* envp[])

{
    alt_u8 *p=tx_data;
    alt_u8 *q=rx_buffer;
   
    printf("Welcome!\n");
    for(i=0;i<128;i++)
    {
         *p++=i;   
    }
   
    printf ("1\n");
   
/* 打开发送通道 */

if (!(txchan = alt_dma_txchan_open("/dev/DMA")))
{
    printf ("Failed to open transmit channel\n");
    exit (1);
}

/* 打开接收通道 */

if (!(rxchan = alt_dma_rxchan_open("/dev/DMA")))
{
    printf ("Failed to open receive channel\n");
    exit (1);
}

/* 开始发送数据 */

if ((rc = alt_dma_txchan_send (txchan,//选用transport通道
                                 tx_data,//a pointer to the start of the data to send.
                                 128,       //the length of the data to send in bytes.
                                 NULL,
                                 NULL)) < 0)

{
    printf ("Failed to post transmit request, reason = %i\n", rc);
    exit (1);
}

/* 开始接收数据*/

if ((rc = alt_dma_rxchan_prepare (rxchan,   //选中recieve通道
                                    rx_buffer,//目标地址
                                    128,    //the maximum length of the data to receive
                                    done_t,//done_t()是DMA完成后被调用的回调函数
                                    NULL)) < 0)

{
    printf ("Failed to post read request, reason = %i\n", rc);
    exit (1);
}

/* 等待传输结束 ,即等待rx_done的值变为1,等待回调函数的执行*/
   printf ("2\n");

while (!rx_done);
printf ("Transfer successful!\n");
   printf ("3\n");

    p=tx_data;
    q=rx_buffer;
      
      for(i=0;i<128;i++)
    {
         printf(" flash%x=%x\n", *q++);   
         printf(" sdram%x=%x\n", *p++);
    }
return 0;

}


我用printf语句检查,程序执行到while (!rx_done);就卡死了。说明回调函数没执行,rx_done没置1。我用debug调试程序也是确实到while (!rx_done);它走不下去了。不知道是什么原因,还请前辈不吝赐教,感激不尽。
页: [1]
查看完整版本: 请教,关于sdram与flash之间的DMA传输