集成电路技术分享

 找回密码
 我要注册

QQ登录

只需一步,快速开始

搜索
查看: 1757|回复: 0

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

[复制链接]
zxz19890318 发表于 2010-8-9 16:39:42 | 显示全部楼层 |阅读模式
本帖最后由 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
您需要登录后才可以回帖 登录 | 我要注册

本版积分规则

关闭

站长推荐上一条 /1 下一条

QQ|小黑屋|手机版|Archiver|fpga论坛|fpga设计论坛 ( 京ICP备20003123号-1 )

GMT+8, 2024-12-25 02:35 , Processed in 0.059426 second(s), 23 queries .

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表