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

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

3天内不再提示

简谈PCIe的软件配置方式

FPGA学习交流 2019-07-29 09:26 次阅读

大家好,又到了每日学习的时间了,今天我们来聊一聊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的配置空间。

1.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。

2.png

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

3.png

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

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

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

PCIE配置空间register

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

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

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

    关注

    1624

    文章

    21603

    浏览量

    601070
收藏 人收藏

    评论

    相关推荐

    FPGA的片内资源

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

    关于dm8168的PRCM使能pcie寄存器区域,需要PRCM配置打开pcie,为什么配置之后还是不能访问pcie的寄存器?

    本帖最后由 一只耳朵怪 于 2018-5-25 15:02 编辑 系统:dm8168作为ep,启动方式为spi现在想仿真器访问8168的pcie寄存器区域,需要PRCM配置打开pcie
    发表于 05-25 08:39

    关于PCIE中BAR配置的问题。

    \drv\exampleProjects\PCIE_exampleProject 里面的例子 这个工程可以成功跑起来,并且在PC端通过用WinDriver可以看到设备,但是目前有一个关于例程中BAR配置
    发表于 06-19 00:50

    PCIE MSI中断的配置

    小弟学习K1_STK(从官网下的最新的例程keystone软件开发包)里面的PCIE(例程),这个是例程里面RC端和EP端用的是MSI中断。PCIE
    发表于 06-21 03:49

    PCIe总线的复位方式是什么?

    PCIe总线规定了两个复位方式:conventional Reset和FLR(FunctionLevel Reset),而Conventional Reset由进一步分为两大类:Fundamental Reset和Non-Fundamental Reset。
    发表于 10-16 08:19

    pcie

    pcie虚拟化技术中,一端pcie的虚拟通道又睡指定,是通过软件配置
    发表于 11-11 10:34

    PCIe软件配置方式

    发表于 07-06 14:58

    太阳能电池的原理

    太阳能电池的原理       当太阳光照射到太阳电池上时,电池吸收光能,产生光生电子—空穴对。在电池的内
    发表于 11-13 15:42 550次阅读

    电容传感器与测控技术

    电容传感器与测控技术        传感器作为太阳能热水器电子控制系统中的感觉器官,承载系统的信息源
    发表于 11-23 14:32 887次阅读

    PCB设计软件对比

    大家好,又到了每日学习的时间了,今天咱们来聊一聊PCB设计软件。 一、原理图软件 原理图设计软件:会ORCAD就可以了,支持的Netlist超多,基本是业界标准。 二、PCB Layout
    的头像 发表于 06-20 10:41 5040次阅读

    PCIe软件配置方式

           大家好,又到了每日学习的时间了,今天我们来聊一聊PCIe软件配置方式。       关于PCIe
    的头像 发表于 07-27 19:16 3622次阅读
    <b class='flag-5'>简</b><b class='flag-5'>谈</b><b class='flag-5'>PCIe</b>的<b class='flag-5'>软件</b><b class='flag-5'>配置</b><b class='flag-5'>方式</b>

    PCIe总线的两种复位方式

    传统的复位方式分为Cold、Warm和Hot Reset。PCIe设备可以根据当前的设备的运行状态选择合适的复位方式PCIe总线提供多种复位方式
    的头像 发表于 12-30 09:37 2.3w次阅读

    二维码(QRcode)的C语言生成,在单片机平台的实现

    二维码(QRcode)的C语言生成,在单片机平台的实现
    发表于 11-13 20:21 18次下载
    <b class='flag-5'>简</b><b class='flag-5'>谈</b>二维码(QRcode)的C语言生成,在单片机平台的实现

    FPGA和USB3.0通信-FX3硬件设计

    FPGA和USB3.0通信-FX3硬件设计本次演示用的是USB3.0芯片-CYPRESS CYUSB3014(下称 FX3),该芯片是标准的USB3.0 PHY,可以大大简化使用USB...
    发表于 12-01 20:06 24次下载
    FPGA和USB3.0通信-FX3硬件设计<b class='flag-5'>简</b><b class='flag-5'>谈</b>

    图解PCIE原理(从软件角度)

    1 PCIE基本概念1.1 PCIE拓扑架构图1.2 PCIE Switch内部结构图1.3 PCIE协议结构图2 PCIE枚举原理2.1
    发表于 12-17 18:29 28次下载
    图解<b class='flag-5'>PCIE</b>原理(从<b class='flag-5'>软件</b>角度)