消息请求规则
主要涉及以下几种消息:
•INTx中断信令
•电源管理
•错误信令
•锁定事务支持
•槽位功率限制支持
•供应商定义消息
•延迟容错性报告(LTR)消息
•优化缓冲区刷新/填充(OBFF)消息
•设备就绪状态(DRS)消息
•功能就绪状态(FRS)消息
•精确时间测量(PTM)消息
以下规则适用于所有消息请求。接下来是特定于每种消息类型的其他规则。
•除了常见的报头字段,所有的消息请求还包括以下字段 (见图):
◦Requester ID[15:0]和标Tag9:0],形成Transaction ID。
◦Message Code[7:0]-指定具体的消息体现在请求。
•所有消息请求使用Msg或MsgD类型字段编码。
•消息码字段必须完全解码(消息别名是不允许的)。
•Attr[2]字段不保留,除非特别指定为保留。
•除特别说明外,Attr[1:0]字段为保留字段。
•LN不适用于Message Requests,该位为Reserved。
•除特别说明外,TH不适用于Message Requests,该位为Reserved。
•AT[1:0]必须是00b。不要求或不鼓励接收方检查此选项。
•除特别说明外,第8到15字节为预留。
•消息请求是Posted,不需要完成。
•消息请求遵循与内存写请求相同的排序规则。
•消息路由是使用Type字段的r[2:0]子字段确定的;
INTx中断信令-规则
消息信号中断(MSI或MSI- x)是PCI Express中首选的中断信号机制。然而,在某些系统中,可能存在不支持MSI或MSI- x机制的函数。在不能使用MSI或MSI-X机制的情况下,INTx虚拟线中断信令机制用于支持遗留端点和PCI Express/PCI(-X)桥。SW必须支持这种机制。以下规则适用于INTx中断信令机制:
•INTx机制使用8个不同的消息(见表)。
•Assert_INTx/Deassert_INTx消息不包括数据负载(TLP类型是Msg)。
•Length字段保留。
•对于Assert_INTx/Deassert_INTx消息,请求者ID中的Function Number字段必须为0。注意,对于非ARI和ARI请求者id,功能编号字段的大小是不同的。
•Assert_INTx/Deassert_INTx消息仅由上游端口发出。
◦接收方可以选择检查是否违反此规则。如果实现此检查的Receiver确定Assert_INTx/Deassert_INTx违反了此规则,则必须将该TLP作为Malformed TLP处理。
•Assert_INTx和Deassert_INTx中断消息必须使用默认的流量类指示器(TC0)。
(缩写:RC =根复杂Sw =交换机(仅用于“链路”路由)Ep =端点Br = PCI Express(主要)到PCI/PCI- x(次要)桥r =支持作为接收器t =支持作为发射器)
Assert_INTx/Deassert_INTx消息对为每个指定为A, B, C和D的遗留PCI中断构成了四条“虚拟线”。以下规则描述了这些虚拟线的操作:
•每个链路两端的组件必须使用Assert/Deassert消息来跟踪四个虚拟线的逻辑状态,以表示每个相应虚拟线的活动和非活动转换(分别)。
◦Assert_INTx代表INTx (x = A, B, C, D)虚拟线的激活转换
◦Deassert_INTx代表INTx (x = A, B, C, D)虚拟线的非激活转换
•当INTx虚拟线的局部逻辑状态改变上游端口,端口必须沟通这一状态变化到下游端口的另一边相同的链接使用适当的Assert_INTx或Deassert_INTx消息。
注意:重复的Assert_INTx/Deassert_INTx消息没有效果,但不是错误。
•当命令寄存器的中断禁用位被设置时,INTx中断信令被禁用。
◦当中断禁用位设置时,任何INTx虚拟线都必须通过传输适当的Deassert_INTx消息来解除断言。
•虚拟和实际PCI到PCI网桥必须根据网桥从侧设备的Device Number映射网桥从侧跟踪的虚线,如表2-19所示。
•Switch必须为每个下游端口独立跟踪四根虚拟线的状态,并在其上游端口上呈现一组“合并”的虚拟线。
•如果Switch下游端口变为DL_Down状态,与该端口关联的INTx虚线必须解除断言,并且Switch上游端口虚线状态相应更新。
◦如果这导致任何上游INTx虚拟线的撤销,适当的Deassert_INTx消息(s)必须由上游端口发送。
•RC必须为每个下游端口独立地跟踪四个INTx虚拟线的状态,并将这些虚拟信号映射到系统中断资源。
◦此映射的细节是系统实现特定的。
•如果根Complex的下行端口变为DL_Down状态,与该端口关联的INTx虚拟线必须解除断言,并且任何关联的系统中断资源请求必须被丢弃