

## 嵌入式第四周作业

A: 扩展了并发操作中的原语指令

1. 简要分析CISC和RISC架构各自的优劣势. F: 扩展了IEEE标准单精度浮点数运算指令,

解: 1) CISC 复杂指令计算机, 单个指令完成 增加了32个32位浮点寄存器.

优势: 代码量大且功能复杂, 指令长度灵活, 如x86 R: 扩展了四精度浮点数运算指令.

指令集帮助CISC架构.

V: 扩展了向量操作指令.

优点: 对编译器和程序存储空间要求较低. C: 压缩指令扩展, 将某些指令进行压缩,

缺点: 硬件设计复杂, 测试验证难度较高. 提高代码密度;

2) RISC, 精简指令集计算机, 单个指令完成 例 4. D: 双精度扩展, 扩展双精度浮点寄存器,

少且功能单一, 指令长度相对固定, 如RISC-V, 计算指令、L/S指令.

MIPS及ARM(移动常见).

$I + C + M + F + A + D$  缩写为 "G".

优点: 硬件设计较为简单, 适合利用流水线

提升性能.

4. RV32I中的add指令和RV64I中的addw指令

缺点: 对编译器设计的要求较高, 程序的 均为32位整型加法指令, 但具有不同的指令  
代码密度较低. 操作数(opcode), 但和RV64I中的add指令  
具有相同的指令操作数. 是为了保障

指令集的简洁性和一致性, 同时提高编

2. RISC-V基本指令集是什么? 列举5个常见的 码和执行效率.

RISC-V标准扩展指令集并简要说明它们的作用和应用范围.

基本指令集:

RV32I: 使用32位寄存器的基本32位整数指令

因为在RV64I中, addw和addiw指令的目标寄存器 中存放的32位计算结果不需要进行额外的

RV32E: 只使用16位寄存器的基本32位指令,

符号扩展就可以进行后续的64位计算.

适用于低端的嵌入式应用.

因为RV64I指令集采用了扩展指令, 使得所有的32位操作都能够自动进行符号扩展.

RV64I: 使用64位寄存器的基本64位整数指令.

并存储在64位寄存器中. 不论是 addw还是

addiw, 其结果存放目标寄存器时已进行了

符号扩展.

2) 标准扩展指令集:

M: 扩展了整数乘法和除法指令.

小补充：在32位中，add指令的操作数为32位，  
b. 解： $a_2 = -3$

在RV64中，addw的操作数为64位，其中低32位表示操作数。

ADD：有符号加法指令；ADDW：低32位有符号加法指令；ADDI：有符号立即数加法指令。结果为正数。

ADD2W：低32位有符号立即数加法指令。

5. 什么是RV的標準指令集中存在的HINT指令空间？它有什么用？

解：这是一组用于给处理器提供信息的指令。HINT指令不是本机的指令，但可以提高处理器的性能和能效。由一个16位的opcod（操作码）和一个4位的func3（功能码）字段组成。

作用：向处理器提示信息，以便优化处理器的性能和能效。这些提示信息可以包括：

① 告诉处理器何时可以进行指令重排列。

② 提醒处理器当处理器等待某事件发生时，

可以进行其他任务，以避免浪费其计算资源。

③ 告诉处理器何时可以休眠，以减少功耗。

④ 告诉其如何更好地利用计算资源。

另：是一组用于提供提示和建议的指令。

告诉CPU如何最优化执行代码。

DIV指令执行有符号除法操作，被除数和除数的符号必须相同，如果被除数和除数中有一个

为负数，结果为负数；如果都为正数，结果为正数。

2) a3. 为 |

当两数正负号一样时，结果为正；

当有一个负数时，结果与被除数符号保持一致。

1). 写出以下指令的使用的寻址模式。

解：1) jal ra, 0x88

JAL指令使用的是PC相对地址模式，

偏移量为0x88。

2) jalr x0, ra, 0x3

JALR指令使用的是基址加偏移量模式。

即ra寄存器的值加上偏移量0。

3) addi a0, a1, 4

ADDI指令使用的是立即数模式，即

a1寄存器的值加上立即数4。

4) mul a0, a1, a2

MUL使用的是寄存器模式，即a0寄存器和a2寄存器的值相乘。

5) ld a4, 1b(sp)

LD是基址加偏移量模式，即栈指针寄存器sp的值加上偏移量1b。