|
本帖最后由 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);它走不下去了。不知道是什么原因,还请前辈不吝赐教,感激不尽。 |
本帖子中包含更多资源
您需要 登录 才可以下载或查看,没有账号?我要注册
x
|