risc-v指令集手册(非特权架构)- ‘M’整数乘除法标准扩展V2.0(已批准)

本章介绍了标准的整数乘法和除法指令扩展,命名为“ M”,其中包含将两个整数寄存器中保存的值相乘或相除的指令。

我们将整数乘法和除法从基本指令集中分离出来,以简化低端实现,或者针对不经常使用整数乘法和除法或者在附加加速器中处理得更好的应用。

9.1 乘法运算

在这里插入图片描述
MUL实现rs1与rs2之间的XLEN位与XLEN位乘法,并将结果的低XLEN位放在目标寄存器中。MULH、MULHU和MULHSU执行相同的乘法,但返回完整的2×XLEN位乘积的高XLEN位,分别对应于有符号×有符号、无符号×无符号和有符号rs1×无符号rs2乘法。如果同时需要同一乘积的高位和低位,则建议的代码序列为:MULH[[S]U] rdh,rs1,rs2; MUL rdl,rs1,rs2(源寄存器指示符必须是相同的顺序,并且rdh不能与rs1或rs2相同)。然后微体系结构可以将它们融合为一个乘法运算,而不是执行两个单独的乘法。

MULHSU用于多字有符号乘法中,将被乘数的最高有效字(包含符号位)与乘数的较低有效字(无符号)相乘。(?)

MULW是RV64指令,它将源寄存器中的低32位相乘,然后将结果的低32位以符号位扩展后放入目标寄存器。

在RV64中,可以使用MUL来获取64位乘积的高32位,但是带符号的自变量必须是正确的32位带符号的值,而无符号的自变量其高32位必须为零。如果不知道参数是符号扩展还是零扩展,则可以选择将两个参数都左移32位,然后使用MULH[[S]U]。

9.2 除法运算

在这里插入图片描述
DIV和DIVU分别实现一个rs1除以rs2的XLEN位与XLEN位有符号和无符号除法,并向零舍入。REM和REMU提供了相应除法运算的余数部分。对于REM,结果的符号与被除数的符号相同。

对于有符号和无符号除法,原则都是被除数=除数×商+余数。

如果同一除法的商和余数都需要的话,则建议的代码序列为:DIV[U] rdq,rs1,rs2; REM[U] rdr,rs1,rs2(rdq不能与rs1或rs2相同)。然后微体系结构可以将它们融合为一个除法运算,而不是执行两个单独的除法运算。
DIVW和DIVUW是RV64指令,它们将rs1的低32位除以rs2的低32位,分别将它们视为有符号和无符号整数,然后将32位商数放在rd中,并以符号位扩展为64位。REMW和REMUW是RV64指令,分别提供相应的有符号和无符号余数运算。REMW和REMUW总是将32位结果以符号位扩展为64位(包括除以零)。
表9.1总结了除以零和除法溢出的语义。除以零的商所有位均为1,除以零的余数等于被除数。仅当最小的负整数除以-1时,才发生有符号除法溢出。带溢出的有符号除法的商等于被除数,余数为零。无符号除法溢出不会发生。(?)
表格9.1 零除和除法溢出的语义。L是操作的宽度,以位为单位:对于DIV[U]和REM[U]为XLEN,对于DIV[U]W和REM[U]W为32。

我们考虑过在整数除以零的情况下引发异常,这些异常在大多数执行环境中都会导致陷阱。然而,这将是标准ISA中唯一的算术陷阱(浮点异常设置标志并写入默认值,但不会导致陷阱),并且在这种情况下,需要语言实现者与执行环境的陷阱处理程序进行交互。此外,在语言标准规定“除以零”异常必须立即导致控制流更改的情况下,只需向每个除法运算添加一条分支指令,并且该分支指令可以插入除法之后,并且通常预测为不发生,这几乎不会增加运行时开销。
为无符号和有符号除以零返回所有位置位的值,以简化除法器电路。所有位均为1的值既是无符号除法返回的自然值,表示最大的无符号数,也是简单无符号除法器实现的自然结果。有符号除法通常使用无符号除法电路来实现,并且指定相同的溢出结果简化了硬件。

9.3 Zmmul扩展,V1.0,已批准

Zmmul扩展实现了M扩展的乘法子集。它添加了9.1节定义的所有乘法指令:MUL、MULH、MULHU、MULHSU以及(仅用于RV64)MULW。指令编码和M扩展指令是一致的。

Zmmul扩展支持需要乘法运算而不需要除法的低成本实现。对于许多微控制器应用来说,除法操作过于罕见,无法证明除法器硬件成本的合理性。相比之下,乘法运算更加频繁,使得乘法器硬件的成本更加合理。简单的FPGA软内核特别受益于消除除法但保留乘法的变动,因为许多FPGA提供硬核乘法器,但要求在软逻辑中实现除法器。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: RISC-V是一种开放的指令集架构,它是根据精简指令集计算机(RISC)的原则设计的。RISC-V指令集中文版是对RISC-V指令集进行中文翻译的版本。这个翻译版本的目的是为了方便中文用户理解和使用RISC-V指令集RISC-V指令集中文版包括了一系列指令,用于执行不同的计算和操作。这些指令可以分为几个类别,包括算术指令、逻辑指令、存储访问指令、控制转移指令等。 算术指令主要用于实现加法、减法、乘法和除法等算术运算。逻辑指令主要用于实现逻辑运算,如与、或和等。存储访问指令用于访问存储器中的数据,包括读取和写入操作。控制转移指令用于控制程序的执行流程,如跳转、函数调用等。 RISC-V指令集中文版的设计遵循了精简指令集计算机的原则,它采用了固定长度的指令格式,每条指令都有相同数量的位数。这种设计简化了指令的解码和执行过程,提高了指令的执行效率。 通过使用RISC-V指令集中文版,开发者可以更容易地编写和调试程序。同时,由于RISC-V是开放的指令集架构,任何人都可以自由使用和扩展它,这为开发者提供了更大的灵活性和创造性。 总之,RISC-V指令集中文版是一种开放的、简洁而功能强大的指令集架构,它为中文用户提供了一种更加便捷和灵活的编程方式。 ### 回答2: RISC-V是一种开源的指令集架构,其设计目标是简洁、清晰和可扩展RISC-V指令集的中文版描述了指令的功能和操作方式,以便于中文用户理解和使用。 RISC-V指令集中包括了基本的指令扩展指令。基本指令包括了加载、存储、算术、逻辑、控制等常用的操作。例如,LOAD指令可以从内存中加载数据到寄存器中,STORE指令可以将寄存器的数据存储到内存中。算术指令比如ADD、SUB、MUL等可以执行加法、减法、乘法等运算。逻辑指令如AND、OR、XOR可以进行与、或、异或等逻辑运算。控制指令如BRANCH、JUMP可以用于条件判断和跳转。这些基本指令可以满足大部分应用的需求。 扩展指令则可根据应用需求进行定制。例如,浮点指令扩展可以添加浮点数运算指令,向量指令扩展可以添加向量运算指令。这些扩展指令能够满足不同应用领域的需求,提高了RISC-V指令集的通用性和灵活性。 RISC-V指令集中的指令使用类似于汇编语言的格式进行描述。每个指令由操作码和操作数组成。操作码表示指令的功能,操作数则是用于指定操作的寄存器或者内存地址。指令可以通过相应的汇编器进行编译,生成机器码后可以在RISC-V架构的处理器上执行。 总的来说,RISC-V指令集中文版提供了详细的指令描述和例子,使得中文用户可以理解和使用这个开源指令集,并且可以根据需要进行扩展,以满足不同应用场景的需求。 ### 回答3: RISC-V指令集是一种开源的、精简的指令集架构。其设计思想是为了简化处理器架构,提供更高的性能和灵活性。 RISC-V指令集的设计原则是简化和统一。它采用了固定大小的指令格式,指令长度为32位,其中包含指令操作码、操作数和地址等。这种设计能够提高指令的解码效率,并且使得指令的执行速度更快。 RISC-V指令集提供了丰富的指令集扩展方式,可以根据特定应用的需求进行扩展。这样的设计使得RISC-V成为了一种高度可定制化的指令集架构,适用于多种不同的应用领域。 另外,RISC-V指令集还提供了多种特权级别的支持。在特权级别方面,RISC-V定义了四个特权级别:用户模式、监管模式、机器模式和超级模式。这样的设计使得RISC-V可以适应不同的操作环境和安全需求。 最后,RISC-V指令集是一种开源的指令集架构,这意味着任何人都可以使用、修改和贡献代码。这种开源的特性促进了RISC-V的发展和创新,使得更多的人参与到指令集架构的设计和优化中。 总而言之,RISC-V指令集是一种开源的、精简的指令集架构,它具有简洁统一、可扩展性强、支持多种特权级别等特点。这些特性使得RISC-V成为了一种广泛应用的指令集架构,并在众多领域受到了广泛的关注和应用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值