PCI/PCIE总线的宏观理解

1、pcie总线协议实现的效果

(1)像访问内存一样去访问外设;

(2)当建立好CPU地址空间到PCI/PCIE地址空间的映射关系后,程序访问CPU地址空间就可以达到访问PCI/PCIE地址空间的效果;

2、芯片地址空间

(1)32位的CPU寻址范围是4G,64位的CPU寻址范围是2的64次方,地址空间是有限的,也属于一种资源;

(2)属于CPU地址空间的地址,CPU可以直接访问。比如上面截取的地址空间都属于CPU地址空间,所以CPU可以直接通过读写地址的方式去访问数据;

(3)但是有的地址空间是和CPU地址空间独立的,比如32位的CPU寻址范围是4G,外接了4G的eMMC,那CPU地址空间的0x100地址和eMMC地址空间的0x100地址是独立的。CPU想要访问eMMC地址空间的0x100地址,需要把0x100这个地址传给eMMC控制器,由eMMC控制器去访问eMMC的0x100地址处数据;

3、PCI/PCIE设备工作的流程

(1)根设备扫描连接在PCI/PCIE总线上的每个设备,识别每个设备是普通PCI/PCIE设备还是桥;

(2)如果是普通设备则读取ID、配置信息,为设备分配资源;

(3)如果是桥设备,则还需要分配总线号,桥再去扫描下一级总线上挂载的设备;

(4)当所以设备都扫描完毕后,每个设备都分配了地址空间,以后在总线上就用地址来访问设备;

4、CPU地址和PCI/PCIE地址的转换

(1)PCI/PCIE地址 = CPU地址 + 偏移量;

(2)偏移量是在芯片的PCI/PCIE控制器驱动里指定的;

5、类比

(1)PCI/PCIE地址空间和CPU地址空间的转换,类似于虚拟地址和物理地址的转换;

(2)虚拟地址和物理地址有对应关系,但是对于虚拟地址之上编程的程序员是不用感知这个转换的,只有维护MMU的程序员才会关注;

(3)PCI/PCIE地址空间和CPU地址空间的转换,是CPU的PCI/CPIE控制器驱动进行的,如果不是维护该驱动的程序员,对此也不用太关心;

6、参考资料

以上笔记源自韦东山老师的视频课程,以及个人理解。

相关推荐
apple_ttt8 小时前
从零开始讲PCIe(6)——PCI-X概述
fpga开发·fpga·pcie
apple_ttt10 小时前
从零开始讲PCIe(5)——66MHZ的PCI总线与其限制
fpga开发·fpga·pcie
9527华安2 天前
FPGA实现PCIE图片采集转HDMI输出,基于XDMA中断架构,提供3套工程源码和技术支持
fpga开发·pcie·xdma·hdmi
芯片业者柏承双22 天前
也谈PCIe带宽问题
pcie
9527华安1 个月前
FPGA实现多功能SDI视频采集卡,基于GTX+RIFFA架构,提供2套工程源码和技术支持
fpga开发·架构·pcie·sdi·gtx·riffa
9527华安1 个月前
FPGA实现SDI视频缩放转PCIE传输,基于GTX+RIFFA架构,提供4套工程源码和技术支持
fpga开发·pcie·图像缩放·sdi·gtx·riffa
9527华安1 个月前
FPGA实现SDI视频缩放转PCIE传输,基于GS2971+RIFFA架构,提供6套工程源码和技术支持
fpga开发·pcie·图像缩放·sdi·gs2971·riffa
SEP50102 个月前
Linux PCI和PCIe总线
pcie·pci
木泽八3 个月前
【PCIe】P2P DMA
dma·p2p·pcie
yao000374 个月前
PCIe学习——重点提纲
pcie