《PCI EXPRESS体系结构导读》---(5)PCI总线Device号的分配

PCI设备的IDSEL信号与PCI总线的AD[31:0]的信号连接关系决定了该设备的PCI总线设备号。每一个PCI设备都使用了独立的IDSEL信号,该信号与PCI总线的AD[31:0]相连。

在此我们简要回可顾PCI的配置读写事务使用的时序。PCI总线事务由一个地址周期加若干个数据周期组成。在进行配置读写请求总线事务时,C/BE#信号线的值在地址周期中为0x1010或者为0x1011,表示当前总线事务为配置读 或者配置写请求 。此时出现在AD[31:0]总线上的值不是 目标设备的PCI总线地址而是目标设备的ID号,这与PCI总线进行IO或者存储器请求时不同,因为PCI总线使用ID号而不是PCI总线地址对配置空间进行访问。

在配置读写总线事务的地址周期中,AD[10:0]信号已经被Function Number和Register Number使用,因此PCI设备的IDSEL只能与AD[31:11]信号连接。

认真的读者一定可以发现在CONFIG_ADDRESS寄存器中DeviceNumber字段一共有5位可以表示32个设备,而AD[31:11]只有21位,显然在这两者之间无法建立一一对应的映射关系。因此在一条PCI总线上如果有21个以上的PCI设备,那么总是有几个设备无法与AD[31:11]信号线连接,从而PCI总线无法访问这些设备。因为PCI总线在配置请求的地址周期中,只能使用第31~11这些AD信号,所以在一条总线上最多也只能挂接21 个PCI设备。这21个设备可能是从0到20,也可能是从11到31排列。从而系统软件在遍历PCI总线时,还是需要从0到31遍历整条PCI总线。

在实际的应用中,一条PCI总线能够挂接21个设备已经足够了,实际上由于PCI总线的负载能力有限,即便在总线频率为33MHz的情况下,在一条PCI总线中最多也只能挂接 10个负载,一条PCI总线所能挂接的负载详见表1-1。AD信号线与PCI设备IDSEL线的连接关系如图2-14所示。

PCI总线推荐了一种Device Number字段与AD[31:16]之间的映射关系。其中PCI设备0与Device Number字段的0b00000对应:PCI设备1与Device Number字段的0b00001对应,并以此类推,PCI设备15与DeviceNumber字段的0b01111对应。

在这种映射关系之下,一条PCI总线中,与信号线AD16相连的PCI设备的设备号为0:与信号线AD17相连的PCI设备的设备号为1;以此类推,与信号线AD31相连的PCI设备的设备号为15。在Type00h配置请求中,设备号并没有像FunctionNumber和RegisterNum ber那样以编码的形式出现在AD总线上,而是与AD信号一一对应,如图2-12所示。

这里有一个原则需要读者注意,就是对PCI设备的配置寄存器进行访问时,一定要有确定BusNumber、DeviceNumber、FunctionNumber和RegisterNumber,这"四元组"缺-不可。在TypeO0h配置请求中,DeviceNumber由AD[31:11]信号线与PCI设备IDSEL信号的连接关系确定;Function Number保存在AD[10:8]字段中;而RegisterNumber保存在 AD[7:0]字段中;在Type01h配置请求中,也有完整的四元组信息。

相关推荐
克里斯蒂亚诺更新21 小时前
vue展示node express调用python解析tdms
服务器·python·express
小天源6 天前
Oracle Database 11g Express Edition (XE) 11.2.0.2 在离线银河麒麟 V10 上的部署手册
数据库·oracle·express·麒麟v10·oracle11g·oracle-xe-11g
C++实习生10 天前
Visual Studio Express 2015 for Windows Desktop 中文学习版
windows·express·visual studio
C++实习生11 天前
Visual C++ 2005 Express 中文版
express·c++20
张彦峰ZYF11 天前
QLExpress 字符串能力解析:机制、用法与工程实践
字符串·express·qlexpress规则表达力
biyezuopinvip11 天前
基于uni-app和Express的问答对战小程序的设计与实现(论文)
小程序·uni-app·毕业设计·论文·express·毕业论文·问答对战小程序的设计与实现
天意pt11 天前
Idempotency 幂等性 - 点赞和投票功能
前端·javascript·express
水冗水孚18 天前
告别黑盒!手写Windows版简易NodeMON,学习文件监听代码修改与进程服务重启知识
node.js·express
天意pt18 天前
Blog-SSR 系统操作手册(v1.0.0)
前端·vue.js·redis·mysql·docker·node.js·express