

| fld f2,0(00)    | 1 ~ 4 | 2~5   | 6  | 7  |  |  |
|-----------------|-------|-------|----|----|--|--|
| fdiv.d f8,f0,f2 | 8     | 9~19  | 20 | 21 |  |  |
| fmul.d f2,f6,f2 | 22    | 23~27 | 28 | 29 |  |  |
| fld f4,0(01)    | 23    | 24~27 | 28 | 29 |  |  |
| fadd.d f4,f0,f4 | 30    | 31~33 | 34 | 35 |  |  |
| fadd.d f0,f8,f2 | 31    | 32~34 | 33 | 36 |  |  |
| fsd f10,0(00)   | 37    | 38~39 | 40 | 41 |  |  |
| fsd f4,0(01)    | 38    | 39~40 | 41 | 42 |  |  |
| addi G0,G0,8    | 42    | 43    | 48 | 49 |  |  |
| addi A1,A1,8    | 43    | 44    | 45 | 46 |  |  |
| sub X10,X4,G0   | 46    | 47    | 48 | 49 |  |  |
| bnez X10,Loop   | 50    | 51~52 | 53 | 54 |  |  |

3.1 59 49 个周期  
下面的情况:

| fld f2,0(00)    | 1 | 2~5   | 6  | 7  |  |  |
|-----------------|---|-------|----|----|--|--|
| fdiv.d f8,f0,f2 | 1 | 8~18  | 19 | 20 |  |  |
| fmul.d f2,f6,f2 | 2 | 8~12  | 13 | 14 |  |  |
| fld f4,0(01)    | 2 | 3~6   | 7  | 8  |  |  |
| fadd.d f4,f0,f4 | 3 | 9~11  | 12 | 13 |  |  |
| fadd.d f0,f8,f2 | 3 | 21~23 | 24 | 25 |  |  |
| fsd f10,0(00)   | 4 | 26~27 | 28 | 29 |  |  |
| fsd f4,0(01)    | 4 | 14~15 | 16 | 17 |  |  |
| addi G0,G0,8    | 8 | 30    | 31 | 32 |  |  |
| addi A1,A1,8    | 9 | 18    | 19 | 20 |  |  |
| sub X10,X4,G0   | 6 | 33    | 34 | 35 |  |  |
| bnez X10,Loop   | 6 | 29~31 | 32 | 33 |  |  |

8 个周期.

| (3)                     |
|-------------------------|
| fld f2,0(00)            |
| fld f4,0(01)            |
| fadd.d f4,f0,f4         |
| fdiv.d f8,f0,f2         |
| fmul.d f2,f6,f2         |
| fadd.d f4,f8,f2         |
| fsd f10,0(00)           |
| fsd f4,0(01)            |
| addi G0,G0,8            |
| addi A1,A1,8            |
| sub X10,X4,G0           |
| bnez X10,Loop           |
| 不会做. 不清楚两段流水线之间如何进行信息传递 |

16. fild T12, 0(a0)  
fa fmil T10 T0, T2  
fmu fdn T16, T4, T10  
fld T12, 0(a1)  
f fadd T14, T0, T12  
f fsub T24, T16, T14  
f fsd T24, 0(a1)

并存储到新的寄存器中，从而避免数据冲突。  
可以直接使用这些新的寄存器，从而避免数据冲突。  
隐式重命名值一次，从而实现了变量的唯一定义。在执行一条指令时，该指令的操作数可以直接使用其唯一的定义，从而避免数据冲突。

11. 差别：显式重命名是通过在流水线中添加额外寄存器来实现的，这些寄存器有缓存功能，前一个周期中每个变量的重命名值。每个指令的结果都被写入到新的寄存器中，而不再写入到原来的寄存器中。随后的指令将使用这些新寄存器。需要修改处理器的硬件结构，并增加额外延迟，才能有效解决数据冲突。

隐式重命名是通过在编译器中进行优化实现的，编译器在识别数据冲突时，将冲突的变量重新命名为不同的寄存器或内存位置，并在代码中使用这些新的寄存器或内存位置。这种方法不需要修改处理器的硬件结构，因此不会增加额外的延迟，但需对编译器进行优化。

优点：显式重命名优点是它能够有效地解决数据冲突，并能够保证程序的正确性。也可以提高处理器并行性，因为每个指令都可以在新的寄存器中执行，而不必等待前一条指令的结果。然而，显式重命名会增加寄存器硬件开销和延迟，从而降低处理器效率。

缺点：隐式重命名优点是不需要额外硬件开销和延迟，可以提高处理器效率，但会导致代码变得更加难以理解和调试，并可能导致错误代码生成，从而影响程序正确性。

实现方式：显式重命名：Register Renaming Table：将一个 RRT 表格加入到 CPU 中，用于存储每个变量的重命名值。在执行一条指令时，该指令操作数会被重命名，从而避免数据冲突。

并存储到新的寄存器中，同时该指令结果也会被存储到新寄存器中。这样，后续指令可以直接使用这些新的寄存器，从而避免了数据冲突。

隐式重命名：Static Single Assignment (SSA)：通过在编译期间将每个变量赋值一次，从而实现了变量的唯一定义。在执行一条指令时，该指令的操作数可以直接使用其唯一的定义，从而避免数据冲突。