高级计算机体系结构--期末教材复习

  • Chap2 性能评测和并行编程
    • 性能评测
    • 并行编程
      • 为什么需要三次 `barrier`
      • 改进方法
  • Chap3 互连网络
    • 交换和路由
      • 二维网格中 XY 路由
    • 死锁、活锁及饿死
      • 死锁避免的方法:虚通道、转弯模型
      • 二维网格中最小 西向优先、北向最后和负向优先算法
      • 转弯模型:超立方体的部分自适应路由算法(P立方路由)
    • 互连网络
      • Omega 网络
        • 地址映射
        • 阻塞条件
        • 自路由标记
      • 蝶形 MIN 网络
      • 立方体 MIN 网络
    • XY 多播路由模式
  • Chap4 对称多处理机系统
    • SMP 的特点
    • 扩展 SMP
    • 高速缓存一致性
      • 总线侦听
      • 侦听协议
        • MSI
        • MESI
        • Dragon
    • 顺序一致性
  • Chap6 机群系统

Chap2 性能评测和并行编程

性能评测

作业题会用到,考试没考过。

C P I = 执行整个程序所需的时钟周期数 程序中指令总数 CPI = \frac{执行整个程序所需的时钟周期数}{程序中指令总数} CPI=程序中指令总数执行整个程序所需的时钟周期数,即:

C P I = ∑ i = 1 n ( C P I i × I i ) I N CPI = \frac{\sum_{i=1}^n(CPI_i \times I_i)}{I_N} CPI=INi=1n(CPIi×Ii)

时钟频率 R C R_C RC M I P S MIPS MIPS (每秒百万条指令)为:

M I P S = R C C P I × 1 0 6 MIPS = \frac{R_C}{CPI \times 10^6} MIPS=CPI×106RC

C P U 执行时间 = 总时钟周期数 × 时钟周期 = 总时钟周期数 时钟频率 CPU 执行时间 = 总时钟周期数 \times 时钟周期 = \frac{总时钟周期数}{时钟频率} CPU执行时间=总时钟周期数×时钟周期=时钟频率总时钟周期数,即:

T C P U = T C R C T_{CPU} = \frac{T_C}{R_C} TCPU=RCTC

并行编程

共享地址空间方法中,常见的同步原语有:

  • 锁(提供互斥):临界区中一次只能有一个线程
  • 障碍(提供同步):等待线程到达此点。障碍是表达依赖关系的一种保守方式。障碍将计算分为多个阶段,障碍之前所有线程的所有计算在障碍开始后任何线程中的任何计算之前完成。换句话说,假设障碍之后的所有计算都依赖于障碍之前的所有计算。
int n;
bool done = false;
float diff = 0.0;
LOCK myLock;
BARRIER myBarrier;

//allocate grid
float* A = allocate(n+2, n+2);

void solve(float* A){
    float myDiff;
    int myMin = 1+(threadId*n/NUM_PROCESSORS);
    int myMax = myMin + (n/NUM_PROCESSORS);

    while(!done){
        float myDiff = 0.f;
        diff = 0.f;
        barrier(myBarrier,NUM_PROCESSORS);
        for(j=myMin to myMax){
            for(i = red cells in this row){
                float prev = A[i,j];
                A[i,j] = 0.2f * (A[i-1,j]+A[i,j-1]+A[i,j]+A[i+1,j]+A[i,j+1]);
                myDiff += abs(A[i,j]-prev);
            }
            lock(myLock);
            diff += myDiff;
            unlock(myLock);
            barrier(myBarrier,NUM_PROCESSORS);
            if(diff/(n*n) < TOLERANCE) // check
                done = true;
            barrier(myBarrier,NUM_PROCESSORS);
        }
    }
}

为什么需要三次 barrier

本示例使用了多个处理器来加速计算过程,代码中的 barrier 函数调用是同步点,每个 barrier 都是必要的,它们确保了在关键的计算步骤之间所有线程的同步,防止数据冲突和不一致的结果。

  • 第一次 barrier 用于等待所有线程都完成初始化,确保 diff 变量在 for 循环计算之前为 0.f
  • 第二次 barrier 用于等待所有线程都更新全局变量 diff ,每一轮迭代中,diff 是所有线程的 myDiff 变量之和。
  • 第三次 barrier 用于等待所有线程检查是否满足了收敛条件,确保每个线程对 done 变量的操作相同。

此外,lock 的使用是为了保护共享资源 diff,确保在任何时刻只有一个线程可以更新这个变量

改进方法

  • 在连续的循环迭代中使用不同的 diff 变量来删除依赖关系;
  • 权衡占用空间以消除依赖关系(一种常见的并行计算技巧)。

这种技巧是指在并行编程中,通过牺牲一些内存占用来减少或消除数据之间的依赖关系,从而提高并行性和性能。这通常涉及到复制或重复存储一些数据,以便每个线程或处理器都可以独立地访问和操作它们,而无需等待其他线程或处理器的输入或结果。

int n; // grid size
bool done = false;
LOCK myLock;
BARRIER myBarrier;
float diff[3]; // global diff, but now 3 copies

float *A = allocate(n+2, n+2);

void solve(float* A) {
 float myDiff; // thread local variable
 int index = 0; // thread local variable
 
 diff[0] = 0.0f;
 barrier(myBarrier, NUM_PROCESSORS); // one-time only: just for init
 
 while (!done) {
	 myDiff = 0.0f;
	 // 这里不再需要 barrier 确保全局 diff 初始化为 0.f
	 
	 //
	 // perform computation (accumulate locally into myDiff)
	 //
	 lock(myLock);
	 diff[index] += myDiff; // atomically update global diff
	 unlock(myLock);
	 diff[(index+1) % 3] = 0.0f;
	 barrier(myBarrier, NUM_PROCESSORS);  
	 // 这个barrier既等待全局diff[index]的值,又初始化全局diff[(index+1)%3]的值为0.f
	 
	 if (diff[index]/(n*n) < TOLERANCE)  
		 break;
	 // 这里不再需要barrier确保各线程对全局done进行相同操作,直接break
	 index = (index + 1) % 3;
 }
}

Chap3 互连网络

交换和路由

二维网格中 XY 路由

如果发送方节点的坐标为 ( X 1 , Y 1 ) (X_1,Y_1) (X1,Y1),接收方节点的坐标为 ( X 2 , Y 2 ) (X_2,Y_2) (X2,Y2),那么消息会首先沿着 X X X 轴移动到达 X X X 坐标为 X 2 X_2 X2 的位置,然后再沿着 Y Y Y 轴移动到达 Y Y Y 坐标为 Y 2 Y_2 Y2 的位置。

以左下角的节点为 ( 0 , 0 ) (0,0) (0,0) 坐标,建立 XY 轴。

算法:二维网格中 XY 路由
输入:当前节点的坐标(Xcurrent,Ycurrent)和目标节点的坐标(Xdest,Ydest)
输出:选择的输出通道Channel
过程:
  Xoffest := Xdest - Xcurrent;
  Yoffset := Ydest - Ycurrent;
  
  if Xoffset < 0 then
    Channel := X- ;
  endif
  
  if Xoffret > 0 then
    Channel:= X+;
  endif
  
  if Xoffset = 0 and Yoffset < 0 then
    Channel := Y-;
  endif
  
  if Xoffset = 0 and Yoffset > 0 then
     Channel := Y+;
  endif
  
  it Xoffset = 0 and Yoffset = 0 then
    Channel := Internal;  //Internal是连接本地节点的通道
  endif

死锁、活锁及饿死

关键原因都是因为资源有限。

  • 死锁是指两个或多个进程(或报文)因为互相等待对方释放资源而无法继续执行的状态。包含在死锁配置内的所有报文将永远被阻塞。

  • 活锁指的是系统中的进程(或报文)一直在重试某个操作,但是却无法取得进展,因此系统不能正常工作。

  • 如果网络流量紧张,某个报文由于所请求的资源总是分配给其他请求同一资源的报文,该报文也会被阻塞,这种情况称为饿死。

死锁避免的方法:虚通道、转弯模型

虚通道:将一条物理通道分成多条逻辑通道(虚通道)复用,交换机内的缓冲也相应分成多份。目的是减少死锁。如,单向二维环绕网的维序路由。

转弯模型:禁止最小数量的转弯,防止环的出现,从而避免发生死锁。如二维网格中最小 西向优先、北向最后和负向优先算法

二维网格中最小 西向优先、北向最后和负向优先算法

在二维网格中,通道的方向通常是根据坐标轴来定义的,其中 X- 代表西向,Y+代表北向

三种合法转弯选路方法:

  • 西向优先:不允许转向 X- 方向;

  • 北向最后:不允许来自 Y+ 方向的转弯;

  • 负向优先:禁止从负方向转向正方向。

总结:策略优先,XY 路由次之。

例如,西向优先,那么优先考虑 Xoffset < 0,再考虑 Xoffset > 0,最后是 Xoffset = 0,这三种情况分别对应 Yoffset < 0Yoffset > 0Yoffset = 0

  1. 最小西向优先算法:如果需要向西路由,先向西路由一个包,然后自适应地向南、向北、向东路由。
算法:二维网格中最小西向优先算法
输入:当前节点的坐标(Xcurrent,Ycurrent)和目标节点的坐标(Xdest,Ydest)
输出:选择的输出通道Channel
过程:
   Xoffest := Xdest - Xcurrent;
   Yoffset := Ydest - Ycurrernt;
   
   If Xoffset < 0 then 
     Channel := X-;
   endif
   
   If Xoffset › 0 and Yoffset < 0 then
     Channel := Select (X+, Y-) ;  // Select 选择函数,从通道中选择一个空闲的通道
   endif
   
   If Xoffset > 0 and Yoffset > 0 then
     Channel := Select ( X+, Y+);
   endif
   
   if Xoffset > 0 and Yoffset = 0 then
     Channel := X+;
   endif
   
   if Xoffset = 0 and Yoffset < 0 then
     Channel := Y-;
   endif
   
   If Xoffset = 0 and Yoffset > 0 then
     Channel := Y+;
   endif
   
   If Xoffset = 0 and Yoffset = 0 then 
     Channel := Internal;  //Internal是连接本地节点的通道
   endif
  1. 北最后算法的思想是在选择输出通道时,尽可能避免向北方向移动,除非没有其他选项。这种算法适用于那些希望最小化北向移动的场景,例如在某些网络拓扑中,北向通道可能比其他方向更拥挤或者成本更高。

在伪代码中,首先检查东西方向(X轴)的偏移量,如果目标在当前节点的西边(Xoffset < 0),则优先选择西向通道(X-)。如果目标在东边(Xoffset > 0),则选择东向通道(X+)。只有当目标正好在当前节点的正北方或正南方时(Xoffset = 0),我们才考虑北向或南向的移动。如果目标在南边(Yoffset < 0),则选择南向通道(Y-),如果在北边(Yoffset > 0),则最后考虑北向通道(Y+)。如果当前节点就是目标节点(Xoffset = 0 and Yoffset = 0),则选择内部通道(Internal)。

算法:二维网格中最小北向最后算法
输入:当前节点的坐标(Xcurrent,Ycurrent)和目标节点的坐标(Xdest,Ydest)
输出:选择的输出通道Channel
过程:
   Xoffest := Xdest - Xcurrent;
   Yoffset := Ydest - Ycurrernt;
   
   If Xoffset < 0 and Yoffset >= 0 then 
     Channel := X-;
   endif
   
   If Xoffset < 0 and Yoffset < 0 then
     Channel := Select (X-, Y-);
   endif
   
   If Xoffset › 0 and Yoffset >= 0 then
     Channel := X+;
   endif
   
   if Xoffset > 0 and Yoffset < 0 then
     Channel := Select (X+, Y-);
   endif
   
   If Xoffset = 0 and Yoffset > 0 then
     Channel := Y+;
   endif
   
   if Xoffset = 0 and Yoffset < 0 then
     Channel := Y-;
   endif
   
   If Xoffset = 0 and Yoffset = 0 then 
     Channel := Internal;  //Internal是连接本地节点的通道
   endif
  1. 最小负向优先算法:基本思想是,一正一负先走负,正正负负随便选。
算法:二维网格中最小负向优先算法
输入:当前节点的坐标(Xcurrent,Ycurrent)和目标节点的坐标(Xdest,Ydest)
输出:选择的输出通道Channel
过程:
Xoffset := Xdest – Xcurrent;
Yoffset := Ydest – Ycurrent;

If Xoffser < 0 and Yoffset < 0
  channel := select(X-, Y-); // 选择函数,从通道中选择一个空闲的通道
Endif

If Xoffset < 0 and Yoffset >= 0
  channel := X-;
Endif

if Xoffset >= 0 and Yoffset < 0
  channel := Y-;
Endif

if Xoffset > 0 and Yoffset > 0
  channel := select(X+, Y+);
Endif

if Xoffset > 0 and Yoffset = 0
  channel := X+;
Endif

if Xoffset = 0 and Yoffset > 0
  channel = Y+;
Endif

if Xoffset = 0 and Yoffset = 0
  channel := internal;
Endif

转弯模型:超立方体的部分自适应路由算法(P立方路由)

二元 n n n 立方体的源 s = s n − 1 s n − 2 … s 0 s=s_{n-1}s_{n-2}…s_0 s=sn1sn2s0 目的 d = d n − 1 d n − 2 … d 0 d=d_{n-1}d_{n-2}…d_0 d=dn1dn2d0

集合 E E E 由所有 s s s d d d 有差别的维数组成, E E E 分为两个不相交的子集 E 0 E_0 E0 E 1 E_1 E1,对于 E E E 中的所有 i i i,如果 s i = 0 s_i=0 si=0 d i = 1 d_i=1 di=1,则 i ∈ E 0 i ∈ E_0 iE0,否则 i ∈ E 1 i∈E_1 iE1

P立方路由的基本概念就是将路由选择分成两个阶段:

  • 第一个阶段报文在 E 0 E_0 E0 中以任意维序路由
  • 第二个阶段在 E 1 E_1 E1 中以任意维序路由

互连网络

在这里插入图片描述

Omega 网络

OMEGA 网络采用完美洗牌互连算法,它通过循环逻辑左移位来进行数据的路由。

地址映射

考虑从 s n − 1 s n − 2 … s 1 s 0 s_{n-1}s_{n-2}…s_1s_0 sn1sn2s1s0 d n − 1 d n − 2 … d 1 d 0 d_{n-1}d_{n-2}…d_1d_0 dn1dn2d1d0 建立一条电路,

经过第 0 级链路后: s n − 1 s n − 2 … s 1 s 0 s_{n-1}s_{n-2}…s_1s_0 sn1sn2s1s0 s n − 2 s n − 3 … s 1 s 0 s n − 1 s_{n-2}s_{n-3}…s_1s_0s_{n-1} sn2sn3s1s0sn1

s n − 2 s n − 3 … s 1 s 0 s n − 1 s_{n-2}s_{n-3}…s_1s_0s_{n-1} sn2sn3s1s0sn1 作为第 0 级开关输入地址,

经过第 0 级开关后: s n − 2 s n − 3 … s 1 s 0 s n − 1 s_{n-2}s_{n-3}…s_1s_0s_{n-1} sn2sn3s1s0sn1 s n − 2 s n − 3 … s 1 s 0 s n − 1 ′ s_{n-2}s_{n-3}…s_1s_0 s_{n-1}^{'} sn2sn3s1s0sn1

经过第 1 级链路后: s n − 2 s n − 3 … s 1 s 0 s n − 1 ′ s_{n-2}s_{n-3}…s_1s_0s_{n-1}^{'} sn2sn3s1s0sn1 s n − 3 s n − 4 … s 1 s 0 s n − 1 ′ s n − 2 s_{n-3}s_{n-4}…s_1s_0s_{n-1}^{'}s_{n-2} sn3sn4s1s0sn1sn2

s n − 3 s n − 4 … s 1 s 0 s n − 1 ′ s n − 2 s_{n-3}s_{n-4}…s_1s_0s_{n-1}^{'}s_{n-2} sn3sn4s1s0sn1sn2 作为第 1 级开关输入地址,

经过第 1 级开关后: s n − 3 s n − 4 … s 1 s 0 s n − 1 ′ s n − 2 s_{n-3}s_{n-4}…s_1s_0s_{n-1}^{'}s_{n-2} sn3sn4s1s0sn1sn2 s n − 3 s n − 4 … s 1 s 0 s n − 1 ′ s n − 2 ′ s_{n-3}s_{n-4}…s_1s_0s_{n-1}^{'}s_{n-2}^{'} sn3sn4s1s0sn1sn2

类似的有第 i i i 级开关的输出为: s n − i − 2 s n − i − 3 … s 0 s n − 1 ’ s n − 2 ’ … s n − i − 1 ’ s_{n-i-2}s_{n-i-3}…s_0s_{n-1}^{’}s_{n-2}^{’}…s_{n-i-1}^{’} sni2sni3s0sn1sn2sni1

从而第 n − 1 n-1 n1 级开关的输出为: s n − 1 ’ s n − 2 ’ … s 1 ’ s 0 ’ s_{n-1}^{’}s_{n-2}^{’}…s_1^{’}s_0^{’} sn1sn2s1s0

最后一级连接为恒等排列,所以 s n − 1 ’ s n − 2 ’ … s 1 ’ s 0 ’ = d n − 1 d n − 2 … d 1 d 0 s_{n-1}^{’}s_{n-2}^{’}…s_1^{’}s_0^{’} = d_{n-1}d_{n-2}…d_1d_0 sn1sn2s1s0=dn1dn2d1d0

从而有 s i ’ = d i s_i^{’}=d_i si=di

所以第 i i i 级开关的输出为: s n − i − 2 s n − i − 3 … s 0 d n − 1 d n − 2 … d n − i − 1 s_{n-i-2}s_{n-i-3}…s_0d_{n-1}d_{n-2}…d_{n-i-1} sni2sni3s0dn1dn2dni1

阻塞条件

对于任意两个输入/输出对 ( S , D ) (S,D) (S,D) ( R , T ) (R,T) (R,T),可以建立无冲突的两条路径的充要条件是:

对于任意的 i i i 都有:

s n − i − 2 s n − i − 3 … s 0 d n − 1 d n − 2 … d n − i − 1 s_{n-i-2}s_{n-i-3}…s_0d_{n-1}d_{n-2}…d_{n-i-1} sni2sni3s0dn1dn2dni1 不等于 r n − i − 2 r n − i − 3 … r 0 t n − 1 t n − 2 … t n − i − 1 r_{n-i-2}r_{n-i-3}…r_0t_{n-1}t_{n-2}…t_{n-i-1} rni2rni3r0tn1tn2tni1

将两个输入/输出对的地址级联在一起,将一个大小为 n n n 的窗口在两个输入/输出对上滑动,并对两个窗口中的内容进行比较。如果它们在任意点相等,那么两条路径在网络的某一级存在冲突。

如 (0110,1100) (1010,1111)有冲突。

自路由标记

Delta 网络的自路由特性:可以根据目的地址做出路由决策,不必考虑源地址。

自路由使用路由标志 T = t n − 1 . . t 1 t 0 T=t_{n-1}..t_1t_0 T=tn1..t1t0 执行, t i t_i ti 控制 G i G_i Gi 级开关。

每一级路由标志都考虑哪一位是最低有效位,该位最终映射到的目标地址的相应位为哪一位,从而 t i t_i ti 等于目标地址中该位的值。

在 OMEGA 网络中,在第 i i i 级开关最低有效位为第 n − i − 1 n-i-1 ni1 位,并且最终映射到的目标地址中的对应位为第 n − i − 1 n-i-1 ni1 位,所以 t i = d n − i − 1 , 0 ≤ i ≤ n − 1 t_i=d_{n-i-1},0 \leq i \leq n-1 ti=dni1,0in1

蝶形 MIN 网络

蝶式网络的特点包括:

  1. 分阶段结构:网络分为多个阶段,每个阶段由一组交换节点组成。
  2. 固定连接模式:每个阶段的节点按照固定的模式连接到下一个阶段的节点。
  3. 重排能力:网络能够在不同的输入和输出之间建立连接,即使在多个数据包同时传输时也能避免冲突。
  4. 递归结构:蝶式网络可以看作是由更小的蝶式网络递归构成,这使得它可以很容易地扩展到更大的规模。

如果两对输入/输出路径经过同一中间链路或共享任意一个中间级的同一个输出,那么这两对输入输出路径就产生冲突。

自路由标记

在蝶形 MIN 中, t i = d i + 1 , ( 0 ≤ i ≤ n − 2 ) , t n − 1 = d 0 t_i=d_{i+1},(0 \leq i \leq n-2),t_{n-1}=d_0 ti=di+1,(0in2),tn1=d0

阻塞条件

如果要对于任意两个输入/输出对 ( S , D ) (S,D) (S,D) ( R , T ) (R,T) (R,T) 建立无冲突的两条路径,其充要条件为:

对于任意的 i i i 都有:

s n − 1 s n − 2 … s i + 1 d i d i − 1 d i − 2 … d 2 d 1 d i + 1 s_{n-1}s_{n-2}…s_{i+1}d_id_{i-1}d_{i-2}…d_2d_1d_{i+1} sn1sn2si+1didi1di2d2d1di+1 不等于 r n − 1 r n − 2 … r i + 1 t i t i − 1 t i − 2 … t 2 t 1 t i + 1 r_{n-1}r_{n-2}…r_{i+1}t_it_{i-1}t_{i-2}…t_2t_1t_{i+1} rn1rn2ri+1titi1ti2t2t1ti+1

立方体 MIN 网络

立方体网络的自路由标记推导:

C i C_i Ci 为第 n − i n-i ni个蝶形排列( i = 1 , 2 , … , n i=1,2,…,n i=1,2,,n ), C 0 C_0 C0 为完全混洗

考虑从 S n − 1 S n − 2 … S 1 S 0 S_{n−1}S_{n−2}…S_1S_0 Sn1Sn2S1S0 d n − 1 d n − 2 … d 1 d 0 d_{n−1}d_{n−2}…d_1d_0 dn1dn2d1d0 建立一条链路
经过第 0 级链路: S n − 1 S n − 2 … S 1 S 0 → S n − 2 S n − 3 … S 1 S 0 S n − 1 S_{n−1}S_{n−2}…S_1S_0\rightarrow S_{n−2}S_{n−3}…S_1S_0S _{n−1} Sn1Sn2S1S0Sn2Sn3S1S0Sn1
S n − 2 S n − 3 … S 1 S 0 S n − 1 S_{n−2}S_{n−3}…S_1S_0S_{n−1} Sn2Sn3S1S0Sn1 作为第 0 级开关的输入,
S n − 2 S n − 3 … S 1 S 0 S n − 1 → S n − 2 S n − 3 … S 1 S 0 S n − 1 ′ S_{n-2}S_{n-3}\ldots S_1S_0S_{n-1} \rightarrow S_{n-2}S_{n-3}\ldots S_1S_0S_{n-1}' Sn2Sn3S1S0Sn1Sn2Sn3S1S0Sn1 S n − 2 S n − 3 … S 1 S 0 S n − 1 ′ S_{n-2}S_{n-3}\ldots S_1S_0S_{n-1}' Sn2Sn3S1S0Sn1 作为第 1 级链路的输入: S n − 2 S n − 3 … S 1 S 0 S n − 1 ′ → S n − 1 ′ S n − 3 … S 1 S 0 S n − 2 S_{n-2}S_{n-3}\ldots S_1S_0S_{n-1}' \rightarrow S_{n-1}'S_{n-3}\ldots S_1S_0S_{n-2} Sn2Sn3S1S0Sn1Sn1Sn3S1S0Sn2
经过第1级开关: S n − 1 ′ S n − 3 … S 1 S 0 S n − 2 → S n − 1 ′ S n − 3 … S 1 S 0 S n − 2 ′ S_{n-1}'S_{n-3}\ldots S_1S_0S_{n-2} \rightarrow S_{n-1}'S_{n-3}\ldots S_1S_0S_{n-2}' Sn1Sn3S1S0Sn2Sn1Sn3S1S0Sn2
经过第2级链路: S n − 1 ′ S n − 3 … S 1 S 0 S n − 2 ′ → S n − 1 ′ S n − 2 ′ … S 1 S 0 S n − 3 S_{n-1}'S_{n-3}\ldots S_1S_0S_{n-2}' \rightarrow S_{n-1}'S_{n-2}'\ldots S_1S_0S_{n-3} Sn1Sn3S1S0Sn2Sn1Sn2S1S0Sn3
经过第2级开关: S n − 1 ′ S n − 2 ′ … S 1 S 0 S n − 3 → S n − 1 ′ S n − 2 ′ … S 1 S 0 S n − 3 ′ S_{n-1}'S_{n-2}'\ldots S_1S_0S_{n-3} \rightarrow S_{n-1}'S_{n-2}'\ldots S_1S_0S_{n-3}' Sn1Sn2S1S0Sn3Sn1Sn2S1S0Sn3
类似的第 i i i 级开关: S n − 1 ′ S n − 2 ′ … S n − i ′ S n − i − 2 … S 1 S 0 S n − i − 1 → S n − 1 ′ S n − 2 ′ … S n − i ′ S n − i − 2 … S 1 S 0 S n − i − 1 ′ S_{n-1}'S_{n-2}'\ldots S_{n-i}'S_{n-i-2}\ldots S_1S_0S_{n-i-1} \rightarrow S_{n-1}'S_{n-2}'\ldots S_{n-i}'S_{n-i-2}\ldots S_1S_0S_{n-i-1}' Sn1Sn2SniSni2S1S0Sni1Sn1Sn2SniSni2S1S0Sni1
从而第n-1级开关输出为 S n − 1 ′ S n − 2 ′ … S 1 ′ S 0 ′ S_{n-1}'S_{n-2}'\ldots S_1'S_0' Sn1Sn2S1S0
最后1级连伟恒等排列: S n − 1 ′ S n − 2 ′ … S 1 ′ S 0 ′ = d n − 1 d n − 2 … d 1 d 0 S_{n-1}'S_{n-2}'\ldots S_1'S_0' = d_{n-1}d_{n-2}\ldots d_1d_0 Sn1Sn2S1S0=dn1dn2d1d0
所以 S i ′ = d i S_i' = d_i Si=di
所以第i级开关输出为 d n − 1 d n − 2 … d n − i S n − i − 2 … S 1 S 0 d n − i − 1 ′ d_{n-1}d_{n-2}\ldots d_{n-i} S_{n-i-2}\ldots S_1S_0d_{n-i-1}' dn1dn2dniSni2S1S0dni1
在立方网络中,第 i i i 级开关最低有效位为 n − i − 1 n-i-1 ni1,并最终映射到目标地址的 n − i − 1 n-i-1 ni1 位,所以 t i = d n − i − 1 ( 0 ≤ i ≤ n − 1 ) t_i = d_{n-i-1}(0≤i≤n−1) ti=dni1(0in1)

XY 多播路由模式

思路:每送完一个节点,将该节点从目的节点中去除。先沿着 X 轴从最左往最右送,到达每一个当前最左 X 后再沿着 Y 轴先上再下送。

目的节点集 D ′ D^{'} D,本地址 ( x , y ) (x,y) (x,y)

  1. x > m i n { x i ∣ ( x i , y i ) ∈ D ′ } x > min \{ x_i|(x_i,y_i)∈D^{'} \} x>min{xi(xi,yi)D} 则把消息和列表送到节点 ( x − 1 , y ) (x-1,y) (x1,y);若 x < m a x { x i ∣ ( x i , y i ) ∈ D ’ } x<max\{x_i|(x_i,y_i)∈D^{’}\} x<max{xi(xi,yi)D} 则把消息和列表送到节点 ( x + 1 , y ) (x+1,y) (x+1,y)
  2. x ∈ { x i ∣ ( x i , y i ) ∈ D ′ } x∈\{x_i|(x_i,y_i)∈D^{'}\} x{xi(xi,yi)D},判断 y y y 的大小,若 y > m i n { y i ∣ ( x i , y i ) ∈ D ′ } y>min\{y_i|(x_i,y_i)∈D^{'}\} y>min{yi(xi,yi)D} 则把消息和列表送到 ( x , y − 1 ) (x,y-1) (x,y1),若 y < m a x { y i ∣ ( x i , y i ) ∈ D ′ } y<max\{y_i|(x_i,y_i)∈D^{'}\} y<max{yi(xi,yi)D},则把消息和列表送到 ( x , y + 1 ) (x,y+1) (x,y+1)
  3. ( x , y ) ∈ D ′ (x,y)∈D^{'} (x,y)D D ′ ← D ′ − ( x , y ) D^{'} \leftarrow D^{'}-(x,y) DD(x,y),并把消息送到本地节点。

Chap4 对称多处理机系统

在这里插入图片描述

SMP 的特点

在这里插入图片描述

  • 对称性
  • 单一物理地址空间
  • 高速缓存及其一致性
  • 低通信延迟

扩展 SMP

前三种是对称的,第四种不是。

在这里插入图片描述

除了共享高速缓存,在所有结构中,每个处理器至少有一层高速缓存是私有的。

这就形成了高速缓存一致性问题。

同一个内存块的拷贝可能同时出现在多个处理器的高速缓存中,多个处理器对这些拷贝的存取,可能使这些拷贝的内容不一致。

  • 造成高速缓存一致性问题的主要原因
    • 由共享可写数据所造成的不一致

      在这里插入图片描述

    • 由绕过高速缓存的 I/O 所造成的不一致

    • 由进程迁移所造成的不一致

高速缓存一致性

在这里插入图片描述

按照高速缓存的写策略的不同,有写直达 WT(Wrtite Through)和 写回 WB(Write Back)两种高速缓存。

  • WT:一旦高速缓存中的一个字被修改,则在主存中立即修改。
  • WB:当被修改的字从高速缓存中被替换或消除时,才真正修改主存。

总线侦听

基于总线的 SMP 通过共享总线连接微处理器(包括高速缓存)和共享存储器,因此利用总线的特性来实现高速缓存一致性。

总线连接多个设备,其上的每个设备都能侦听到总线上出现的事务。

在这里插入图片描述

思想:

  • 当一个处理器 P n P_n Pn 向内存发出一个内存读/写请求时,该处理器本地的高速缓存控制器检查自身的状态,并采取相应的动作。比如,读命中,则本地高速缓存直接响应;读缺失,则向总线发出存取内存的事务请求。
  • 所有其他的高速缓存控制器 P 1 、 ⋯ 、 P n − 1 P_1、\cdots 、P_{n-1} P1Pn1 都侦听总线上出现的事务,一旦事务与自己相关(自己的高速缓存有该事务请求内存块的一个拷贝),就执行相应的动作来保证高速缓存一致性。

总线序程序序共同保证了高速缓存一致性。

单处理机中,当采用写直达且写不分配的高速缓存时,只需无效 I(Invalid)和有效 V(Valid)两个状态。

  • 开始时,所有的块都是无效的。
  • 当处理器发生一个读缺失时,高速缓存控制器产生一个总线事务从内存中读入该块,并将该块置为有效
  • 当处理器执行写操作时,高速缓存控制器产生一个总线事务去更新内存,如果所写的块在高速缓存中,且处于有效状态的话,则也更新高速缓存中块的内容,但不改变该块的状态
  • 当高速缓存中的一个块被替换出去时,将该块置为无效

在这里插入图片描述

  • V, PrRd/-:Valid,所以读命中。不触发总线事件,仍然 Valid。
  • V, PrWr/BusWr:Valid,写命中。写直达,故既要写该数据块拷贝,又要写 Mem。需要总线 Invalid 其他数据块拷贝(Cache),即其他相应块会经历 V, BusWr/- -> I。
  • V, BusWr/-:Valid,响应其他拷贝块发起的 BusWr,要 Invalid 自己相应的拷贝块变为 I。
  • I, PrRd/BusRd:Invalid,所以读不命中。触发 BusRd,从 Mem 中读进最新的到该块,变为 Valid。
  • I, PrWr/BusWr:要修改自己的 Cache 时,发现被 Invalid 了。但是,没关系,自己现在更新了,是最新的,故要通过 Bus Invalid 掉其他 Cache,再写到 Mem。

多处理机系统中,一个内存块在每个处理器的高速缓存中都有一个状态,所有的这些状态都按照状态转换图来转换。

侦听协议

两种设计选择:

  • 是写直达,还是写回;
  • 是写无效 WI(Write-Invalidate),还是写更新 WU(Write-Update)。

写直达,主存总与高速缓存中最新值一致,每次写操作都需要更新主存,从而需要额外的总线周期

写回,主存的更新在发生替换时才进行,只需占有较少的总线周期,但存在短暂不一致。

【总结】写回方式中尽量延迟写直达中对主存的更新,而且可以快速实现写命中,故在存储器总线结构上采用写回高速缓存更经济。

在这里插入图片描述

写无效,本地高速缓存中数据被更新后,使所有其他高速缓存中的相应数据拷贝无效,那么处理器发出的对内存块的写操作就不会引起总线上的任何通信。

写更新,广播修改后的数据,以更新所有的高速缓存中的相应数据拷贝,那么当拥有该块拷贝的处理器接下来存取这个新数据时,存取延迟就很小。

【总结】由于一个总线事务就能更新所有拥有该块的高速缓存中内容,所以如果该块有多个共享者,就能极大地节约总线带宽。

MSI

MSI 协议比较简单,它定义了三个状态:

  1. Modified:表示数据已经修改,和内存里不一致
  2. Shared:数据和内存一致,可以有一到多个缓存同时处在 Shared 状态
  3. Invalid:不在缓存中

在这里插入图片描述

Read hit 的时候,状态不变。

Read miss 的时候,检查其他缓存的状态,

  • 如果都是 Invalid,就从内存里读取,然后进入 Shared 状态。
  • 如果有 Shared,就从其他缓存处读取。
  • 如果有 Dirty,那就要把其他缓存的数据写入内存和本地缓存,然后进入 Shared 状态。

Write hit 的时候,

  • 如果现在是 Shared 状态,则要让其他的 Shared 缓存进入 Invalid 状态,然后更新数据,进入 Modified 状态。
  • 如果是 Modified 状态,那就修改数据,状态保持不变。

Write miss 的时候,

  • 如果有其他缓存处于 Modified/Shared 状态,那就从其他缓存处读取数据,并让其他缓存进入 Invalid 状态,然后修改本地数据,进入 Modified 状态。
  • 如果所有缓存都是 Invalid 状态,那就从内存读入,然后修改缓存数据,进入 Modified 状态。

在这里插入图片描述

MESI

MESI 协议定义了四种状态:

  1. Modified:数据与内存不一致,并且只有一个缓存有数据
  2. Exclusive:数据与内存一致,并且只有一个缓存有数据
  3. Shared:数据与内存一致,可以有多个缓存同时有数据
  4. Invalid:不在缓存中

在这里插入图片描述

Read hit 的时候,状态不变。

Read miss 的时候,首先会检查其他缓存的状态,

  • 如果有数据,就从其他缓存读取数据,并且都进入 Shared 状态;
  • 如果其他缓存处于 Modified 状态,还需要把数据写入内存;
  • 如果其他缓存都没有数据,就从内存里读取,然后进入 Exclusive 状态。

Write hit 的时候,进入 Modified 状态,同时让其他缓存进入 Invalid 状态。

Write miss 的时候,检查其他缓存的状态,

  • 如果有数据,就从其他缓存读取,否则从内存读取。
  • 然后,其他缓存都进入 Invalid 状态,本地缓存更新数据,进入 Modified 状态。

注意,Shared 状态不一定表示只有一个缓存有数据:比如本来有两个缓存都是 Shared 状态,然后其中一个因为缓存替换变成了 Invalid,那么另一个是不会受到通知变成 Exclusive 的。Exclusive 的设置是为了减少一些总线请求,比如当数据只有一个核心访问的时候,只有第一次 Read miss 会发送总线请求,之后一直在 Exclusive/Modified 状态中,不需要发送总线请求。

Dragon

Dragon 协议是一个基于更新的协议,意味着写入缓存的时候,会把更新的数据同步到拥有这个缓存行的其他缓存块。

基于更新的协议(例如 Dragon 协议)在写入缓存块之后由其他处理器进行多次读取时会高效执行,因为更新的缓存块很容易在与所有处理器关联的缓存中使用。

它定义了四个状态:

  1. Exclusive clean(E):独占,并且数据和内存一致
  2. Shared clean(Sc):数据同时存在多个缓存中,并且自己不是最后一个写入该缓存数据的
  3. Shared modified(Sm):数据同时存在多个缓存中,并且自己是最后一个写入该缓存数据的
  4. Modify(M):独占,并且数据和内存不一致

可以看到,EM 都是独占的,如果出现了多个缓存有同一个缓存行,那就是若干个 Sc 和一个 Sm

在这里插入图片描述

Read miss 的时候,在总线上检查是否有缓存已经有这个缓存行的数据,

  • 如果没有,则从内存读取并转到 Exclusive clean 状态;
  • 如果已经在其他缓存中,则从其他缓存读取,将其他缓存转移到 Shared clean/Shared modified 状态,然后该缓存转移到 Shared clean 状态。

Write miss 的时候,同样检查其他缓存的状态,

  • 如果是第一个访问的,就从内存读取,更新数据,然后转到 Modify 状态;
  • 如果不是第一个访问的,就进入 Shared modified 状态,并且让原来 Shared modified 的缓存进入 Shared clean 状态。

Write hit 的时候,

  • 如果状态是 Shared modified,这时候需要通知其他缓存更新数据;
  • 如果状态是 Shared clean,则要通知其他缓存更新数据的同时,让原来 Shared modified 的缓存进入 Shared clean 状态;
  • 如果状态是 Exclusive clean,则进入 Modify 状态。

在这里,Shared modified 的缓存负责在换出的时候,写入数据到内存中。

顺序一致性

顺序一致性是对所有的读/写操作的一致性要求;

高速缓存一致性是对同一个内存位置的读/写操作的一致性要求。

在这里插入图片描述

Chap6 机群系统

在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

原生JavaScript实现录屏功能

1. 前言 使用JavaScript实现浏览器中打开系统录屏功能 示例图: 2. 源码 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8" /><meta http-equiv"X-UA-Compatible" content"IEedge" /><…

深度学习——卷积神经网络(convolutional neural network)CNN详解(一)——概述. 步骤清晰0基础可看

在CNN的学习过程中我会提供相应的手算例子帮助理解训练过程。 其他关于神经网络的学习链接如下&#xff1a; 一、了解卷积神经网络 卷积神经网络的作用 总的来说&#xff0c;卷积神经网络的第一个主要作用是对图像进行特征提取&#xff0c;所谓特征提取&#xff0c;就是明白…

7.6第三天作业

一、在数据库中创建一个表student&#xff0c;用于存储学生信息 CREATE TABLE student( id INT PRIMARY KEY, name VARCHAR(20) NOT NULL, grade FLOAT ); &#xff08;1.&#xff09;先创建一个数据库 &#xff08;2.&#xff09;创建student表 查看是否创建成功 1、向studen…

QT c++函数模板与类模板的使用

QT c类模板的使用 #pragma once#include <QtWidgets/QMainWindow> #include "ui_QtWidgetsApplication5.h"class QtWidgetsApplication5 : public QMainWindow {Q_OBJECTpublic:QtWidgetsApplication5(QWidget *parent nullptr);~QtWidgetsApplication5();te…

代码随想录算法训练营第13天|二叉树的递归遍历、二叉树的迭代遍历、二叉树的统一迭代法、102.二叉树的层序遍历

打卡Day13 1.理论基础2.二叉树的递归遍历3.二叉树的迭代遍历3.二叉树的统一迭代法4.102.二叉树的层序遍历扩展107. 二叉树的层序遍历 II199.二叉树的右视图637.二叉树的层平均值429.N叉树的层序遍历515.在每个树行中找最大值116.填充每个节点的下一个右侧节点指针117. 填充每个…

嵌入式C语言面试相关知识——关键字(不定期更新)

嵌入式C语言面试相关知识——关键字 一、博客声明二、C语言关键字1、sizeof关键字2、static关键字3、const关键字4、volatile关键字5、extern关键字 一、博客声明 又是一年一度的秋招&#xff0c;怎么能只刷笔试题目呢&#xff0c;面试题目也得看&#xff0c;想当好厂的牛马其实…

数据可视化之智慧城市的脉动与洞察

在数字化转型的浪潮中,城市作为社会经济发展的核心单元,正经历着前所未有的变革。城市数据可视化大屏看板作为这一变革中的重要工具,不仅极大地提升了城市管理效率,还为公众提供了直观、全面的城市运行状态视图,成为智慧城市建设不可或缺的一部分。本文将深入探讨以“城市…

一文理解 Treelite,Treelite 为决策树集成模型的部署和推理提供了高效、灵活的解决方案

&#x1f349; CSDN 叶庭云&#xff1a;https://yetingyun.blog.csdn.net/ 一、什么是 Treelite&#xff1f; Treelite 是一个专门用于将决策树集成模型高效部署到生产环境中的机器学习模型编译器&#xff0c;特别适合处理大批量数据的推理任务&#xff0c;能够显著提升推理性能…

Java之网络面试经典题(一)

目录 ​编辑 一.Session和cookie Cookie Session 二.HTTP和HTTPS的区别 三.浅谈HTTPS为什么是安全的&#xff1f; 四.TCP和UDP 五.GET和Post的区别 六.forward 和 redirect 的区别&#xff1f; 本专栏全是博主自己收集的面试题&#xff0c;仅可参考&#xff0c;不能相…

嵌入式Linux系统编程 — 7.2 进程的环境变量

目录 1 什么是进程的环境变量 2 环境变量的作用 3 应用程序中获取环境变量 3.1 environ全局变量 3.2 获取指定环境变量 getenv 4 添加/删除/修改环境变量 4.1 putenv()函数添加环境变量 4.2 setenv()函数 4.3 unsetenv()函数 1 什么是进程的环境变量 每一个进程都有一…

Android - Json/Gson

Json数据解析 json对象&#xff1a;花括号开头和结尾&#xff0c;中间是键值对形式————”属性”:属性值”” json数组&#xff1a;中括号里放置 json 数组&#xff0c;里面是多个json对象或者数字等 JSONObject 利用 JSONObject 解析 1.创建 JSONObject 对象&#xff0c;传…

快手大模型首次集体亮相,用AI重塑内容与商业生态

7月6日&#xff0c;在2024世界人工智能大会期间&#xff0c;快手举办了以“新AI新应用新生态”为主题的大模型论坛&#xff0c;会上&#xff0c;快手大模型首次集体亮相&#xff0c;视频生成大模型可灵、图像生成大模型可图等产品的多项新功能正式发布。 继图生视频、视频续写…

Appium启动APP时报错Security exception: Permission Denial

报错内容Security exception: Permission Denial: starting Intent 直接通过am命令尝试也是同样的报错 查阅资料了解到&#xff1a;android:exported | App quality | Android Developers exported属性默认false&#xff0c;所以android:exported"false"修改为t…

QT学习积累——如何提高Qt遍历list的效率

目录 引出Qt遍历list提高效率显示函数的调用使用&与不使用&除法的一个坑 总结自定义信号和槽1.自定义信号2.自定义槽3.建立连接4.进行触发 自定义信号重载带参数的按钮触发信号触发信号拓展 lambda表达式返回值mutable修饰案例 引出 QT学习积累——如何提高Qt遍历list…

Springboot学习之用EasyExcel4导入导出数据(基于MyBatisPlus)

一、POM依赖 <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><m…

Kotlin中的数据类型

人不走空 &#x1f308;个人主页&#xff1a;人不走空 &#x1f496;系列专栏&#xff1a;算法专题 ⏰诗词歌赋&#xff1a;斯是陋室&#xff0c;惟吾德馨 目录 &#x1f308;个人主页&#xff1a;人不走空 &#x1f496;系列专栏&#xff1a;算法专题 ⏰诗词歌…

使用WinSCP工具连接Windows电脑与Ubuntu虚拟机实现文件共享传输

一。环境配置 1.首先你的Windows电脑上安装了VMware虚拟机&#xff0c;虚拟机装有Ubuntu系统&#xff1b; 2.在你的windows电脑安装了WinSCP工具&#xff1b; 3.打开WinSCP工具默认是这样 二。设置WinSCP连接 打开WinSCP&#xff0c;点击新标签页&#xff0c;进入到如下图的…

Ubuntu20.04配置TurtleBot3 Waffle Pi远程控制

这里写目录标题 0. 机器人配置1. Ubuntu20.04配置TurtleBot3 Waffle Pi远程控制1.1 TurtleBot3 Waffle Pi端配置1.2 PC端配置1.2.1 安装turtlebot3的环境配置1.2.2 创建项目并安装Turtlebot31.2.3 配置环境变量 1.3 PC端与TurtleBot3进行通信1.3.1 PC端与机器人端互PING和SSH连…

用C#调用Windows API向指定窗口发送按键消息详解与示例

文章目录 1. 按键消息的定义及功能2. 引入所需的命名空间3. 定义Windows API函数4. 定义发送消息的方法5. 获取窗口句柄6. 调用API发送按键消息7. 使用示例注意事项总结 在C#中调用Windows API向指定窗口发送按键消息是一种常见的操作&#xff0c;这通常用于自动化脚本、游戏辅…

加密货币大利好!9月降息概率突破70%!美国可能大幅降息或多次降息?

根据最新消息&#xff0c;美国9月降息的概率已经突破70%&#xff0c;这对加密货币市场来说是个利好消息。与此同时&#xff0c;美国经济表现疲软&#xff0c;可能会陷入衰退&#xff0c;联邦储备系统(Fed)接下来会不会果断采取大幅降息措施备受关注。 美国劳工统计局7月5日公布…