接前一篇文章:《PCI Express体系结构导读》随记 —— 第I篇 第1章 PCI总线的基本知识(10)
1.3 PCI总线的存储器读写总线事务
1.3.2 Posted和Non-Posted传送方式
PCI总线规定了两类数据传送方式,分别是Posted和Non-Posted数据传送方式。其中,使用Posted数据传送方式的总线事务也被称为Posted总线事务;而使用Non-Posted数据传送方式的总线事务也被称为Non-Posted总线事务。
Posted总线事务指是PCI主设备向PCI目标设备进行数据传递时,当数据到达PCI桥后,即由PCI桥接管来自上游总线的总线事务,并将其转发到下游总线。采用这种数据传送方式,在数据还没有到达最终的目的地之前,PCI总线就可以结束当前总线事务,从而在一定程度上解决了PCI总线的拥塞问题。
而Non-Posted总线事务是指PCI主设备向PCI目标设备进行数据传递时,数据必须到达最终目的地之后,才能结束当前总线事务的一种数据传递方式。
很显然,采用Posted传送方式,当这个Posted总线事务通过某条PCI总线后,就可以释放PCI总线的资源;而采用Non-Posted传送方式,PCI总线在没有结束当前总线事务时必须等待。这种等待严重阻塞了当前PCI总线上的其它数据传送,因此PCI总线使用Delayed总线事务处理Non-Posted数据请求,使用Delayed总线事务可以相对缓解PCI总线的拥塞。
PCI总线规定,只有存储器写请求(包括存储器写并无效请求)可以采用Posted总线事务,下文将Posted存储器写请求简称为PMW(Posted Memory Write)。而存储器读请求、I/O读写请求、配置读写请求只能采用Non-Posted总线事务。
下面以图1-1中的处理器系统中的PCI设备11向存储器进行DMA写操作为例,说明Posted传送方式的实现过程。
PCI设备11进行DMA写操作时使用存储器写总线事务。
1)当PCI设备11获得PCI总线x1的使用权后,将发送存储器写总线事务到PCI总线x1;
2)当PCI桥x1发现这个总线事务的地址不再该桥管理的地址范围内时,其将首先接收这个总线事务,并结束PCI总线x1的总线事务;
3)此时PCI总线x1使用的资源已被释放,PCI设备11和PCI设备12可以使用PCI总线x1进行通信;
4)PCI桥x1获得PCI总线x0的使用权后,将转发这个存储器写总线事务到PCI总线x0;
5)之后HOST主桥x将接收这个存储器写总线事务,并最终将数据写入主存储器。
有以上过程可以发现,Posted数据请求在通过PCI总线之后,将逐级释放总线资源,因此PCI总线的利用率较高。而使用Non-Posted方式进行数据传送的处理过程与此不同,Non-Posted数据请求在通过PCI总线时,并不会及时释放总线资源,从而在某种程度上影响了PCI总线的使用效率和传送带宽。
更多内容请看下回。