pcie总线与cpci总线_DSP6678与FPGA实现PCIE调试

本文详述了以DSP作为Root Complex (RC),FPGA作为Endpoint (EP) 进行PCIe总线调试的过程,重点解析了outbound和inbound机制、EP端的BUS_MS和MEM_SP配置、BAR的配置以及地址转换。调试过程中,DSP的PCIE_DATA 0x60000000~0x6FFFFFFF地址段触发outbound机制,配置EP端的BAR0以实现数据传输。通过配置inbound和outbound寄存器,实现了数据在DSP和FPGA之间的有效通信。
摘要由CSDN通过智能技术生成

本人调试是将DSP作为RC端,FPGA作为EP端,且下文是对DSP代码的讲解。本人调试参考代码是D:ipdk_C6678_1_1_2_6packagesidrvexampleProjectsPCIE_exampleProject。本文所指的PCIE手册为TI公司C6678的pcie技术手册,全名为 KeyStone Architecture Peripheral Component Interconnect Express (PCIe).pdf

(1)outbound和inbound的理解:

哪一端发起请求哪一端就是outbound。一端是outbound,另一端就是inbound。

对于outbound来说,可以发出写请求和读请求。当作为RC端的DSP对0X60000000发起写请求时,RC发出outbound的写请求,将数据传送给作为EP端的FPGA。当作为RC端的DSP对0X60000000发起读请求时,RC发出outbound的读请求,作为EP端的FPGA先收到读请求然后将数据发给RC端的DSP。

错误理解:简单地将数据出去理解为outbound,数据进去理解为inbound。

DSP存在PCIE_DATA 0x60000000~0x6FFFFFFF这段地址。在这段地址中写数据会触发outbound写机制,在这段地址中读数据会触发outbound读机制。0x60000000该地址在outbound转换机制中为DSP内部总线地址。

(2)对EP端(远程配置空间)BUS_MS和MEM_SP的配置

RC端对EP发出outbound写时,RC端的DSP必须把作为EP端FPGA的BUS_MS和MEM_SP置为1,否则EP端无法收到数据。BUS_MS为设置总线控制权,MEM_SP为设置存储器访问权限,具体可见pcie手册3-63页

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值