微波EDA网,见证研发工程师的成长!
首页 > 研发问答 > 嵌入式设计讨论 > FPGA,CPLD和ASIC > 一个关于用dma方式传数据到pc的问题

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

时间:10-02 整理:3721RD 点击:
本人最近在做一个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了?

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top