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

 找回密码
 注册

手机号码,快捷登录

手机号码,快捷登录

搜全文
查看: 2639|回复: 0

[求助] 一个关于用dma方式传数据到pc的问题

[复制链接]
发表于 2016-10-31 16:27:23 | 显示全部楼层 |阅读模式

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

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

×
本人最近在做一个pci-e卡的项目,负责写pci-e卡的fpga程序和pci-e卡的windows驱动程序,但在fpga中把数据帧(memory write tlp)通过pci-e硬核写到pc分配给pci-e卡的内核内存时,在驱动程序中通过WdfMemoryCopyFromBuffer把pc分配给pci-e卡的内核内存复制到readfile传进来的outputbuffer时,发现无论如何outputbuffer中数据都是全1。现在在想在fpga中把数据通过pci-e硬核写到pc上,是不是一定要通过dma的方法。看了微软的名叫PLX9x5x的windows驱动程序例程后,有多地方不明白。首先,PLX9x5x的windows驱动程序例程创建了一个代表缓冲区的commonbuffer对象,用WdfCommonBufferGetAlignedLogicalAddress得到缓冲区的物理地址,把这个物理地址地址发给dma设备后,但dma设备为什么能根据这个地址写数据到commonbuffer缓冲区(这个commonbuffer缓冲区没有在系统初始化的时候和pci-e设备上的内存建立映射关系,这样的缓冲区跟我在内核里手动创建的缓冲区有什么不同呢),为什么不能用dma的方式使dma设备写数据到系统初始化时pc分配给pci-e卡的内核内存上呢?同时,为什么PLX9x5x的windows驱动程序在dma设备写数据到commonbuffer缓冲区后,在中断回调例程和dpc回调例程中没有把commonbuffer缓冲区的数据复制到readfile传进来的outputbuffer中就TransactionRelease和RequestComplete了?
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

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


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

GMT+8, 2025-10-12 22:02 , Processed in 0.011025 second(s), 3 queries , Gzip On, Redis On.

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