3.3 与Cache相关的PCI总线事务

简介: <div class="bct fc05 fc11 nbw-blog ztag"> <p style="TEXT-INDENT: 21pt;"><span lang="EN-US" xmllang="EN-US">PCI</span><span style="FONT-FAMILY: 宋体; mso-ascii-font-family: 'Times new roman'; mso-hans

PCI总线规范定义了一系列与Cache相关的总线事务,以提高PCI设备与主存储器进行数据交换的效率,即DMA读写的效率。当PCI设备使用DMA方式向存储器进行读写操作时,一定需要经过HOST主桥,而HOST主桥通过FSB总线[1]向存储器控制器进行读写操作时,需要进行Cache共享一致性操作。

PCI设备与主存储器进行的Cache共享一致性增加了HOST主桥的设计复杂度。在高性能处理器中Cache状态机的转换模型十分复杂。而HOST主桥是FSB上的一个设备,需要按照FSB规定的协议处理这个Cache一致性,而多级Cache的一致性和状态转换模型一直是高性能处理器设计中的难点。

不同的HOST主桥处理PCI设备进行的DMA操作时,使用的Cache一致性的方法并不相同。因为Cache一致性操作不仅与HOST主桥的设计相关,而且主要与处理器和Cache Memory系统设计密切相关。

PowerPCx86处理器可以对PCI设备所访问的存储器进行设置,其设置方法并不相同。其中PowerPC处理器,如MPC8548处理器,可以使用Inbound寄存器的RTT字段和WTT字段,设置在PCI设备进行DMA操作时,是否需要进行Cache一致性操作,是否可以将数据直接写入Cache中。RTT字段和WTT字段的详细说明见第2.2.3节。

x86处理器可以使用MTRR(Memory Type Range Registers)设置物理存储器区间的属性,是否为可Cache空间。下文分别讨论在PowerPCx86处理器中,PCI设备进行DMA写操作时,如何进行Cache一致性操作。

但是与PowerPC处理器相比,x86处理器在处理PCI设备的Cache一致性上略有不足,特别是网络设备与存储器系统进行数据交换的效率。因为x86处理器所重点优化的是PCIe设备,目前x86处理器使用的IOAT(I/O Acceleration Technology)技术,极大增强了PCIe设备与主存储器进行数据通信的效率,但是这种技术仍然不能与一些Data Plane处理器,如XLP832P4080处理器优化I/O访问的技术相提并论。毕竟x86处理器所适用的领域依然是PC、服务器等计算和控制领域,并不是Data Plane处理器领域。

相关文章
|
6月前
|
芯片
 总线(Bus)
 总线(Bus)
|
8月前
|
安全 搜索推荐 Linux
D-Bus深度解析:系统总线与会话总线的区别与应用
D-Bus深度解析:系统总线与会话总线的区别与应用
241 2
|
缓存
总线窥探(Bus Snooping)
总线窥探(Bus Snooping)
211 0
|
数据安全/隐私保护
MOTOROLA MVME2432 支持总线控制和直接存储器存取
MOTOROLA MVME2432 支持总线控制和直接存储器存取
117 0
MOTOROLA  MVME2432 支持总线控制和直接存储器存取
RK3399平台开发系列讲解(PCI/PCI-E)5.53、PCIE RC侧 地址映射
RK3399平台开发系列讲解(PCI/PCI-E)5.53、PCIE RC侧 地址映射
227 0
RK3399平台开发系列讲解(PCI/PCI-E)5.53、PCIE RC侧 地址映射
|
存储 芯片 异构计算
FPGA-利用SPI总线进行flash操作
FPGA-利用SPI总线进行flash操作
434 0
FPGA-利用SPI总线进行flash操作
|
前端开发 芯片
PCI-X总线
<p><span style="">PCI-X接口是并连的</span><a target="_blank" href="http://baike.baidu.com/view/2815.htm" style="">PCI总线</a><span style="">(Peripheral Components Interconnect)的更新版本,仍采用传统的</span><a target
989 0
HI3531由DMA 发起PCIe 事务
<p>Hi3531 PCIe 控制器内含DMA 控制器,DMA 控制器包含有两个DMA 通道(一个<br> DMA 读通道和一个DMA 写通道)。PCIe 控制器内包含的DMA 控制器用于大数据量<br> 的存储器读写事务,以提高数据传输的速率。<br> DMA 控制器可以实现如下的存储器读写事务:<br> DMA 控制寄存器<br> 软件可通过DMA 控制寄存器来配置DMA 传
2164 0
PCI设备内存操作函数总结
<p>1.  <strong>ExAllocatePool</strong>()</p> <p>函数说明:</p> <p align="left"><strong>ExAllocatePool</strong> allocates pool memory of the specified type and returns a pointer to the allocated</p>
1593 0
1.3 PCI总线的存储器读写总线事务
<div class="bct fc05 fc11 nbw-blog ztag"><div> <p style="TEXT-INDENT: 21pt;"><span style="FONT-FAMILY: 宋体;">总线的基本任务是实现数据传送,将一组数据从一个设备传送到另一个设备,当然总线也可以将一个设备的数据广播到多个设备。在处理器系统中,这些数据传送都要依赖一定的规则,</span><
2347 0

热门文章

最新文章