在线咨询
eetop公众号 创芯大讲堂 创芯人才网
切换到宽版

EETOP 创芯网论坛 (原名:电子顶级开发网)

手机号码,快捷登录

手机号码,快捷登录

找回密码

  登录   注册  

快捷导航
搜帖子
芯片精品文章合集(500篇!)    创芯人才网--重磅上线啦!
查看: 2867|回复: 1

[原创] DriverStudio中关于DMA的类-Xilinx Pcie驱动开发

[复制链接]
发表于 2012-11-29 13:17:18 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?注册

x
本帖最后由 recorner 于 2012-11-29 13:45 编辑

最近用DS写PCIe的驱动,用到DMA控制传输,关于DMA的三个类KDmaAdapter,KDmaTransfer和KCommonBuffer应该怎么用呢?

初始化KDmaAdapter:




  1. DEVICE_DESCRIPTION dd;

  2. RtlZeroMemory(&dd, sizeof(dd));
  3. dd.Version = DEVICE_DESCRIPTION_VERSION;
  4. dd.Master = TRUE;
  5. dd.ScatterGather = FALSE;
  6. dd.Dma32BitAddresses= TRUE;
  7. dd.Dma64BitAddresses= FALSE;
  8. dd.InterfaceType = PCIBus;
  9. dd.MaximumLength = MAX_DMA_LENGTH;



复制代码

1. 初始化KDmaAdapter时设置了DMA单个传输的最大长度为1M:




  1. dd.MaximumLength = MAX_DMA_LENGTH; // 1M



复制代码
再为KDmaTransfer分配非分页内存




  1. m_DmaTransfer = new(NonPagedPool) KDmaTransfer(this, &m_Dma);



复制代码
这是只是分配了一个非分页内存也就是4KB大小是么?因为我只能读写的4KB的数据,我不知道为什么。。。为什么DMA可传输数据量不是KDmaAdapter里设置的DMA单个传输的最大长度为1M呢?怎样才能写入大于4KB的数据呢?

2. 不支持Scatter/Gather的话,需不需要用到KCommonBuffer呢?在什么情况下用KCommonBuffer呢?

3. scatter /gather是硬件本身支持与否决定的,还是如下代码,在DS中的设置的呢?




  1. dd.ScatterGather = FALSE; //不支持



复制代码

4. 支持与不支持scatter /gather,哪个更好些呢?

5. 怎样连续多次DMA传输呢?

驱动菜鸟,希望得到各位大侠指点!!!
发表于 2012-12-1 00:23:23 | 显示全部楼层
回复 1# recorner


        真好!!!!!!!!
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

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

小黑屋| 关于我们| 联系我们| 在线咨询| 隐私声明| EETOP 创芯网
( 京ICP备:10050787号 京公网安备:11010502037710 )

GMT+8, 2024-4-27 04:30 , Processed in 0.024280 second(s), 8 queries , Gzip On, Redis On.

eetop公众号 创芯大讲堂 创芯人才网
快速回复 返回顶部 返回列表