基于Nios II的DMA传输总结.docVIP

  1. 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
基于Nios II的DMA传输总结.doc

最近练了一段时间的DMA传输,现做如下的总结,分享自己获得心得以及遇到的一些问题。 ??? 在系统运行时,当需要传输大量数据时,可以采用DMA的方式进行传输,以解脱出CPU来处理其他命令。 Nios II中的DMA传输有以下三种形式: 1、 存储器到存储器 这种情况下需要同时打开发送通道和接收通道,而且源地址和目标地址都是自增的。 tx = alt_dma_txchan_open(/dev/dma_0);//打开发送通道 dma_res = alt_dma_txchan_send(tx, tx_buf, 32, NULL, NULL); // tx_buf是源地址 rx = alt_dma_rxchan_open(/dev/dma_0);//打开接收通道 dma_res = alt_dma_rxchan_prepare(rx, rx_buf, 32, dma_done, NULL); // rx_buf是目标地址,dma_done()是DMA完成后被调用的回调函数。 2、 存储器到外设 这种情况下只要打开发送通道,而且源地址是自增的,目标地址是固定的。 tx = alt_dma_txchan_open(/dev/dma_0); // 打开发送通道 alt_dma_txchan_ioctl(tx, ALT_DMA_TX_ONLY_ON, (void *)dst_addr); // dst_addr是目标地址 dma_res = alt_dma_txchan_send(tx, tx_buf, 32, dma_done, NULL); // tx_buf是源地址 3、 外设到存储器 这种情况下只要打开接收通道,而且源地址是固定的,目标地址是自增的。 rx = alt_dma_rxchan_open(/dev/dma_0); // 打开接收通道 alt_dma_rxchan_ioctl(rx, ALT_DMA_RX_ONLY_ON, (void *)source_addr); // source_addr是源地址 dma_res = alt_dma_rxchan_prepare(rx, rx_buf, 32, dma_done, NULL); // rx_buf是目标地址 其中通过alt_dma_txchan_ioctl,alt_dma_rxchan_ioctl还可以设置每次发送和接收的字节数。 下面给出两个实例,说明DMA传输的过程。 1、 存储器到存储器 下面程序为SDRAM到onchip-memory的数据传输。 硬件连接图示: 程序如下: #include stdio.h #include stdlib.h #include sys/alt_dma.h #include system.h static volatile int rx_done = 0; int rc; alt_dma_txchan txchan; alt_dma_rxchan rxchan; static char buff[256]; void* tx_data = (void*) buff; /* 源地址 */ void* rx_buffer = (void*) 0 /* 目标地址,从上图看到0onchip-memory的地址*/ //DMA传输结束回调函数 static void done_t(void* handle, void* data) { ??? ??? rx_done++; ??? } int main (int argc, char* argv[], char* envp[]) { /* 打开发送通道 */ if ((txchan = alt_dma_txchan_open(/dev/dma)) == NULL) { ??? printf (Failed to open transmit channel\n); ??? exit (1); } /* 打开接收通道 */ if ((rxchan = alt_dma_rxchan_open(/dev/dma)) == NULL) { ??? printf (Failed to open receive channel\n); ??? exit (1); } /* 开始发送数据 */ if ((rc = alt_dma_txchan_send (txchan, ???????????????????????????????? tx_data, ???????????????????????????????? 128, ???????????????????????????????? NULL, ????????????????????????????

文档评论(0)

克拉钻 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档