PCI控制器扫描PCI总线过程解析

1、PCI的三种地址空间介绍

地址空间描述命令说明
I/O空间供给设备驱动程序使用I/O操作命令对设备对应的I/O地址空间进行访问,此类访问不可预取
存储空间供给设备驱动程序使用memory操作命令对设备的Memory空间进行访问,其中Memory操作命令又可分为Prefechable(可预取)和Non-prefechable(不可预取)两种类型
配置空间提供Linux内核中的PCIe初始化代码使用配置访问命令对设备的配置空间进行读写访问,用来初始化设备,给设备分配资源

I/O空间和存储空间的区别:操作I/O地址空间,数据是未知的,操作存储空间,结果是已知的。如果是存储空间,写进去是1那读出来应该也是1;但是I/O地址,状态可能是由I/O外部决定的,去读I/O端口,这个端口是1还是0,由外部决定;

2、两种配置命令(Type 0和 Type 1)

(1)PCI总线协议中,设备分为PCI普通设备和PCI桥。PCI普通设备就是终端设备,比如网卡;PCI桥是转发消息的作用,可以构建多级的PCI总线拓扑;
(2)参考博客:《PCI设备和PCI桥的配置空间(header_type0、header_type1)和配置命令(type0、type1)详解》;

3、PCI主桥如何遍历挂载的PCI设备

3.1、header type 0中重要的字段

在这里插入图片描述

字段含义
Primary Bus Number上一级PCI总线号
Secondary Bus NumberPCI桥自己分配到的总线号
SubordinateBus NumberPCI总线域中的下级PCI总线号中最大的总线号

3.2、PCI根桥扫描过程

在这里插入图片描述

(1)HOST主桥依次使能挂载在PCI总线上设备的IDSEL引脚,扫描每个PCI插槽,尝试读取PCI设备的配置空间;
(2)通过读取PCI设备的配置空间Header Type字段,判断是PCI桥设备还是非PCI桥设备;
(3)通过type 0配置直接挂载的PCI设备,type 1配置通过PCI桥间接挂载的PCI设备;
(4)HOST主桥如果识别到PCI设备也是桥设备,会给PCI桥分配PCI总线号,并等到PCI桥设备去扫描更下一级PCI总线段的PCI设备;如果扫描到的是PCI普通设备,则直接通过type 0进行配置;
(5)当HOST主桥将所以PCI设备扫描完成并分配了相应资源,以后在PCI总线上就可以通过PCI地址来访问各个设备;

3.3、PCI根桥配置PCI设备举例分析

在这里插入图片描述
在这里插入图片描述

假设:HOST主桥要访问PCI总线3、设备号31、功能0、寄存器0xE
(1)HOST根桥在AD线上发送上面的type 1配置命令;
(2)PCI设备01是普通设备,忽略掉type 1类型的命令;PCI桥4会比较type 1命令的总线号3,不在自己以及后级总线的处理范围内,不转发;PCI桥1,比较type 1的总线号满足"1< 3 <= 3",将type 1命令转发到PCI总线1上;
(3)PCI总线1::PCI设备11忽略掉type 1类型命令,PCI桥2比较type 1的总线号满足"2<3 <= 3",将type 1命令转发到PCI总线2上;
(4)PCI总线3:PCI设备21忽略掉type 1类型命令,PCI桥3比较type 1的总线号满足"3<=3 <= 3",是自己能够处理的配置命令;
(5)PCI桥3将type 1配置命令,转换成type 0配置命令,并根据Device Number去选择对应PCI设备的IDSEL引脚,配置相应的设备;

4、如何区分当前设备是否是多功能设备?

在256字节的配置空间中,有个Header Type register,如果bit 7是0代表是单功能设备,如果bit 7是1代表多功能设备;

5、如何识别PCI/PCIE设备需要申请多大的地址空间?

参考博客:
《如何识别PCI/PCIE设备需要申请多大的地址空间?》;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://xiahunao.cn/news/1618398.html

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

从PC传输文件到ipad

首先从PC上进入iTunes。剩下步骤如图所示。

【iPhone和iPad设备管理和文件传输工具】iMazing 2.9.9 for Mac

文章来源于&#xff1a;风云社区 iMazing 2.9.9 for Mac iMazing- 管理你的iPhone。获取可信赖的软件来传输和保存您的音乐&#xff0c;消息&#xff0c;文件和数据。安全备份任何iPhone&#xff0c;iPad或iPod touch。iMazing功能强大且用户友好&#xff0c;是Mac和PC的最佳…

ipad如何投屏到xbmc_询问操作技巧:在iPad上设置文件传输拖放区,XBMC,并使用控制台模拟器享受复古游戏...

ipad如何投屏到xbmc Once a week we round up some of the reader questions we’ve answered and share them with everyone; this week we’re taking a look at setting up file transfer drop zones, installing XBMC on the iPad, and setting up a console emulator. 每周…

iOS系统与Windows电脑如何做到无线传输文件?

iOS系统与Windows电脑传输文件&#xff0c;大多数人可能会选择使用微信或QQ的 “文件传输助手”&#xff0c;今天我教大家一种一分钟设置&#xff0c;便可永久传输的简单方法。快点赞收藏起来吧&#xff01;&#xff01; &#xff08;此处用iPad 第8代 2020为例子&#xff09;…

Nginx详解 第三部分:Nginx高级配置(附配置实例)

Part 3 一、网页的状态页二、Nginx第三方模块2.1 echo 模块 三、变量3.1 内置变量3.1.1 常用内置变量3.1.2 举个例子 3.2 自定义变量 四、自定义访问日志 (优化)4.1 自定义访问日志的格式4.2 自定义json 格式日志 五、Nginx压缩功能&#xff08;重要&#xff09;六、HTTPS 功能…

Java“牵手”天猫商品历史价格信息API接口数据,天猫API接口申请指南

天猫平台商品历史价格接口是开放平台提供的一种API接口&#xff0c;通过调用API接口&#xff0c;开发者可以获取天猫商品的标题、价格、库存、月销量、总销量、库存、详情描述、图片、最低价、当前价格、价格信息等详细信息 。 获取商品历史价格接口API是一种用于获取电商平台…

美国慌了,满世界找稀土替代却找不到,最终还是得求中国

中国先后对稀土、镓、锗等稀有金属材料的出口采取限制措施&#xff0c;美国一开始并不慌&#xff0c;毕竟全球还有美国自己、澳大利亚、蒙古等国家拥有稀土矿藏&#xff0c;因此美国以为可以迅速找到替代&#xff0c;然而如今却发现事情并不简单。 中国占有的稀土矿藏确实不算最…

家用计算机音效部件图示,唱吧新版自定义音效设置方法(附上最佳音效设置参数图)...

新版唱吧发布后&#xff0c;觉得唱吧设计的音效越来越专业 真的很爱这个版本 愿研发GG们继续研发更多更牛的音效&#xff01;我们这些唱粉也跟着一起进步。 除了界面大改版之外&#xff0c;录音功能也有大的改进喔&#xff01; 一眼望去&#xff0c;以前的音效又增加了若干固定…

Java的异常与错误

对比 Exception 和 Error&#xff0c;另外&#xff0c;运行时异常与一般异常有什么区别&#xff1f; Exception 和 Error 都是继承了 Throwable 类&#xff0c;在 Java 中只有 Throwable 类型的实例才可以被抛出&#xff08;throw&#xff09;或者捕获&#xff08;catch&#x…

渗透测试工具ZAP入门教程(1)-安装和快速开始

介绍 ZAP Zed Attack Proxy&#xff08;ZAP&#xff09;是一个免费的开源渗透测试工具&#xff0c;在 软件安全项目 &#xff08;SSP&#xff09;。ZAP 专为测试 Web 应用程序而设计&#xff0c;既灵活又可扩展。 ZAP的核心是所谓的“中间人代理”。它位于测试人员的浏览器和…

叁腾科技更新招股书:营收、净利双降,创始人鲁永祥有股权被冻结

日前&#xff0c;上海叁腾科技有限公司&#xff08;Sentage Holdings Inc.&#xff0c;下称“叁腾科技”&#xff09;向美国证券交易委员会&#xff08;SEC&#xff09;递交了更新后的招股书。招股书显示&#xff0c;叁腾科技拟在纳斯达克上市。 根据招股书&#xff0c;叁腾科…

任意系统升Windows10(microsoft官网)

打开https://www.microsoft.com/zh-cn/software-download/windows10 点击“立即下载工具” 下载好后点击“保留” 单击“MediaCreationTool20H2.exe”

竞逐新能源汽车续航,背靠广汽的巨湾技研能否打好“技术牌”?

续航、安全性能包括充电速度一直都是新能源汽车行业发展掣肘。 2020年以来&#xff0c;国内外主力电动乘用车续航普遍突破600公里&#xff0c;消费者续航焦虑逐步化解&#xff0c;但随之而来的是&#xff0c;需求侧对充电便捷性的考量&#xff0c;能否像传统车加油一样实现快速…

GD32E230C8T6_OTA升级

GD32E230C8T6_OTA升级 运行环境简介程序的起始地址进行分区总体流程图Bootloader 程序Bootloader 编译设置APP 分区部分APP 编译设置重点步骤 运行环境 1.Windows10 2. Keil5(MDK5) Version 5.27.0.0 3. MCU GD32E230C8T6 简介 本例程主要分析在线升级(OTA)的实现过程, 主要…

个人配置电脑清单 (windows+黑苹果)

自配第一套,3A游戏入门套 AMD锐龙 R5 3500X盒装微星B450 迫击炮 Max主板套装 1218元 酷兽DDR4 8G 3200MHz内存条 2条 301元 耕升1660 super 6g 炫光 1487元 爱国者极光风扇 4个 110元 航嘉 金牌500W WD500K电源 265元 先马&#xff08;SAMA&#xff09;鲁班1 机箱 179元 …

耕升 GeForce RTX 4070 星极皓月 OC给玩家带来DLSS3+2K光追百帧游戏体验

在2023年4月12日晚上21:00,耕升 GeForce RTX 4070 系列全系显卡正式解禁。作为NVIDIA 核心AIC合作伙伴之一的耕升&#xff0c;也紧跟步伐推出全新耕升 GeForce RTX 4070 星极皓月 OC 和 耕升 GeForce RTX 4070 星极幻姬 OC。其建议零售价为人民币5199元。耕升 GeForce RTX 4070…

耕升 GeForce RTX 4060 Ti 系列,为玩家带来DLSS3+1080P光追游戏体验!

NVIDIA 于2023年5月18日&#xff0c;正式发布GeForce RTX 4060 Ti系列&#xff0c;作为核心AIC厂商的一员&#xff0c;耕升此次也为玩家带来了多款耕升 GeForce RTX 40系列全新家族成员。其中囊括耕升 GeForce RTX 4060 Ti 追风 EX3和耕升 GeForce RTX 4060 Ti 追风&#xff0c…

shell脚本耕升(一)

文章目录 文件描述符自定义文件描述符数组和关联数组定义关联数组 别名获取终端信息获取&#xff0c;设置日期与延时延时 调试脚本函数与参数递归函数导出函数 读取命令序列输出不按回车键的方式读取字符“n”字段分隔符与迭代器for循环命令使用cat 查看script&#xff0c;scri…

高精度地图定位在高速公路自动驾驶系统中的应用

近年来随着汽车保有量不断增加&#xff0c;随之而来的是: ( 1) 严重的交通拥堵&#xff0c;通行效率低下&#xff0c;用在通行上的时间不断增加; ( 2) 交通事故频发&#xff0c;交通事故导致的伤亡人数和费用不断增加&#xff0c;而且绝大多数事故是由人为因素导致的; ( 3) 大气…

Kubernetes对象深入学习之五:TypeMeta无效之谜

欢迎访问我的GitHub 这里分类和汇总了欣宸的全部原创(含配套源码)&#xff1a;https://github.com/zq2599/blog_demos 本篇概览 本文是《Kubernetes对象深入学习之五》系列的第五篇&#xff0c;从前文的分析也能看出&#xff0c;代表对象类型的schema.ObjectKind&#xff0c;于…