0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

简谈PCIe的软件配置方式

FPGA学习交流 2018-07-27 19:16 次阅读

大家好,又到了每日学习的时间了,今天我们来聊一聊PCIe的软件配置方式。

关于PCIe的软件配置和初始化

PCIe设计出来考虑了和pci兼容问题。所以PCIe的软件配置方式可以沿用PCI的配置方式。当然,由于特殊性,也有自身独特的配置方式。所以PCIe模块的访问方式有如下两种:
1、 PCI 兼容的配置方式。
2、 PCI Express enhanced 配置机制。

PCI兼容方式是在PCI章节已经提过,PCIe与其完全兼容。这里主要描述PCIE高级配置机制。

PCIe的配置空间

PCIe的配置空间是兼容PCI的,但是在PCI的基础上增加了不少register。从256增加到4Kbytes的大小。如下图所示,PCIe的配置空间。

134606xdnsfah77dfs5f6l.png



其中,PCIe的配置空可以分成PCI兼容部分和扩展部分。PCI兼容部分在前面256byte区域,完全可以使用PCI配置机制来访问。而扩展部分的register,使用PCI配置方式无法实现,则可以通过PCIe 高级配置方式完成。

PCIe高级配置机制

PCIe enhanced configuration mechanism的主要原理是将pcie的所有4K bytes 映射到memory地址上,这样,通过访问memory的方式即可读写PCIE的配置空间。当然,通过此方式读memory时候,最好考虑到4字节对齐的问题,否则有可能出错。

在正常的访问过程中,可以访问这一部分的memory来配置pcie,而这部分memory在哪里呢?芯片组中会定义一个base address,而base address开始的256MB的空间内则是总线上所有PCIe设备的配置空间对应的register。

134606orlmsr5trsrxzrsq.png


上图是PCIE总线高级配置结构图,很明显可以看出是PCIE配置空间映射的memory空间为[XbaseAddress +0 àXbaseAddress +FFFFFFFh]。那么实际的地址线如何对应呢?如下图所示:

134607rx76keoxqbji84xu.png


在程序中的表达和操作是这样的:

1、计算出PCIe设备配置空间中寄存器的地址:Register address = PCIe_Base + (BusNO * 1MB) + (DeviceNO * 32KB) + (FuncNO* 4KB) + (Reg).

2、使用memory 读写周期完成register的读写。

PCIE配置空间register

详细的register解读,请阅读PCIe spec或者参考一份X86架构的芯片组datasheet。

今天就聊到这里,各位,加油。


声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
收藏 人收藏

    评论

    相关推荐

    Xilinx Zynq-7000嵌入式系统设计与实现

    今天给大侠带来Xilinx Zynq-7000嵌入式系统设计与实现,话不多说,上货。 Xilinx的ZYNQ系列FPGA是二种看上去对立面的思想的融合,ARM处理器的串行执行+FPGA
    发表于 04-10 16:00

    8路SDI/HDMI/MIPI/PCIe-DMA音视频采集,V4L2驱动应用介绍

    、个数、大小)软件配置11.8个视频显示队列参数(队列元素的地址、个数、大小)软件配置12.支持超带宽视频采集和超带宽视频显示13.支持MSI中断,16个DMA中断和16个User
    发表于 03-13 13:59

    PCIe可以添加哪些定位手段?PCIe需要的debug设计

    如图所示,PCIe IP作为endpoint与RC对接,用户实现了应用逻辑,与PCIe IP进行交互,交互信号中data格式为TLP报文格式,且交互信号包含相应的控制信号,例如PCIe配置
    的头像 发表于 02-26 18:19 915次阅读

    FPGA的片内资源

    FPGA的片内资源
    发表于 01-08 22:12

    AD采集卡设计原理图:630-基于PCIe的高速模拟AD采集卡

    =94%] [tr][td] 三、应用软件 2路AD采集PCIe传输(453 + 536) 软件实现FPGA逻辑 AD采集,PCIe XDMA传输,寄存器
    发表于 12-11 11:36

    体验紫光PCIE之使用WinDriver驱动紫光PCIE

    不同系列的PCIE IP并不通用,不同的系列都需要安装不同的PCIE IP包。 (3)参数配置PCIE 的gen1是2.5GT/s,gen2是5GT/s,芯片集成的是gen2的硬核,
    发表于 11-17 14:35

    STM32使用GPIO配置的5种方式

    STM32使用GPIO配置的5种方式 STM32是常见的一种微控制器,其GPIO模块可以实现对外部设备的控制和数据传输,包括数字I/O口、模拟输入口和输出口等。在STM32中,GPIO模块的配置可以
    的头像 发表于 10-26 17:42 769次阅读

    PCIe相关问题解答

    CPU 发起的,访问PCIe设备配置空间的数据流。这种数据流主要是BIOS/Linux PCIe driver 对设备进行初始化、资源分配时,读写配置空间的。包括
    的头像 发表于 09-15 09:39 972次阅读
    <b class='flag-5'>PCIe</b>相关问题解答

    访问PCI/PCIe设备的流程

    访问 PCI/PCIe 设备的流程 PCI/PCIe 设备的配置信息 PCI/PCIe 设备上有配置空间(
    的头像 发表于 07-30 09:44 1047次阅读

    9FGV1005 PhiClock PCIe Timing Commander 软件 用户指南

    9FGV1005 PhiClock PCIe Timing Commander 软件 用户指南
    发表于 07-07 19:27 0次下载
    9FGV1005 PhiClock <b class='flag-5'>PCIe</b> Timing Commander <b class='flag-5'>软件</b> 用户指南

    什么是PCIe

    PCIe是一种高速串行计算机扩展总线标准,自2003年推出以来,已经成为服务器(Server)和PC上的重要接口。今天为大家简单介绍一下PCIe的发展历史以及它的工作原理。 一、PCIe的由来
    的头像 发表于 07-04 18:15 1.1w次阅读

    如何读写PCIe

    我是一名PCIe新手,想了解以下问题: 1、如何测试PCIe? 2、如何读写PCIe(两块开发板通过PCIe线互连,分别配置为RC和EP)?
    发表于 06-12 06:05

    PCIe系统复位方式

    PCIe Spec中,Reset总共分为两类:Conventional Reset和Function Level Reset.
    的头像 发表于 06-05 17:30 2711次阅读
    <b class='flag-5'>PCIe</b>系统复位<b class='flag-5'>方式</b>

    如何将LS1046a PCIE主机配置为gen1?

    如何将LS1046a PCIE主机配置为gen1
    发表于 05-18 08:44

    ls1028 pcie配置,是否需要启用任何与pcie相关的电源设置?

    你好 作为我们在 ls1028 上努力的一部分 我们通过 pcie 将自定义 fpga 连接到 M.2 连接器(通道 C/2 - j16) 相关uboot日志: U-Boot
    发表于 05-09 12:00