如何将外部 ddr 地址映射为 DMAable 地址以进行 DMA 传输

问题描述

在我的用例中存在以下硬件设置:

  1. 2GB DDR(1) 运行 linux(S1)
  2. 1GB 的外部 DDR(2),与另一个硬件 (S2) 共享

即 外部 DDR => DDR 与两个处理器共享。将其视为 SocFPGA,其中 DDR 在 Soc 和 FPGA 硬件之间共享。

我的 Linux 驱动程序需要使用 DMA 将数据从外部 DDR(2) 传输到 linux DDR(1) 地址。然后数据将用于DDR(1)中的计算。

目前完成的事情:

  1. 使用devm_request_mem_region()获取外部DDR(2)的物理地址
  2. IO 将 DDR(2) 物理地址重新映射到内核虚拟地址

将虚拟地址设置为可 DMA 的缓冲区并获取用于 DMA 传输的 DMA 句柄的下一步是什么?

我可以使用 dma_map_single() API 将虚拟地址转换为可使用 DMA 的缓冲区地址吗?

问题简述: 如何在 Linux 中将外部 DDR(2) 映射为 DMA 的读取地址?哪个 DMA API 可以帮助我做到这一点?

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...