Risc-V定义了可选的RV32M,它定义了整数乘法除法指令。

总共8条指令。

Category Fmt RV32I base machine code(bin) comment
mul 整数乘法 R mul rd, rs1, rs2 0000001[24-20,rs2][19-15,rs1]000[11-7,rd]0110011 rd=rs1*rs2,
将结果的低32位写入rd,对于有符号数和无符号数相乘,结果低32位是相同的,所以只有一条指令,取低32位
整数乘法 R mulh rd, rs1, rs3 0000001[24-20,rs2][19-15,rs1]001[11-7,rd]0110011 rd=rs1*rs2, rs1,rs2被当作有符号数,结果高32位写入rd
整数乘法 R mulhu rd, rs1, rs4 0000001[24-20,rs2][19-15,rs1]010[11-7,rd]0110011 rd=rs1*rs2, rs1,rs2被当作无符号数,结果高32位写入rd
整数乘法 R mulhsu rd, rs1, rs5 0000001[24-20,rs2][19-15,rs1]011[11-7,rd]0110011 rd=rs1*rs2,
rs1当作有符号数,rs2被当作无符号数,结果高32位写入rd
div 整数除法 R div rd, rs1, rs2 0000001[24-20,rs2][19-15,rs1]100[11-7,rd]0110011 rd=rs1/rs2,rs1,rs2都被当作有符号数,将除法的商写回寄存器rd中。
整数除法 R divu rd, rs1, rs3 0000001[24-20,rs2][19-15,rs1]101[11-7,rd]0110011 rd=rs1/rs2,rs1,rs2都被当作无符号数,将除法的商写回寄存器rd中。
整数除法 R rem rd, rs1, rs4 0000001[24-20,rs2][19-15,rs1]110[11-7,rd]0110011 rd=rs1/rs2,rs1,rs2都被当作有符号数,将除法的余数写回寄存器rd中。
整数除法 R remu rd, rs1, rs5 0000001[24-20,rs2][19-15,rs1]111[11-7,rd]0110011 rd=rs1/rs2,rs1,rs2都被当作无符号数,将除法的余数写回寄存器rd中。

如果希望得到两个32位整数相乘;的完整的64位结果,Risc-V推荐使用下面的指令:

mulh[s|u] rdh,rs1, rs2;

mul rdl rs1,rs2

其中要求:两条指令的源操作数索引号和顺序必须完全相同。第一条指令的rdh索引必须不能与rs1,rs2索引号相同。处理器实现的微架构可以把两条指令融合成一条指令执行,从而提高性能。

如果希望同时得到两个32位数相除的商和余数,Risc-V推荐用以下指令:

div[u] rdq, rs1, rs2;

rem[u] rdr,rs1,rs2;

其中要求:两条指令的源操作数索引号和顺序必须完全相同。第一条指令的rdh索引必须不能与rs1,rs2索引号相同。处理器实现的微架构可以把两条指令融合成一条指令执行,从而提高性能。

Risv-V中除以0,并不会产生异常,仍会产生一个特殊的结果。

RV32M指令集的更多相关文章

  1. Risc-V指令集

    https://riscv.org/specifications/ Risc-V文档包括:用户层指令集文档和特权架构文档,下面这两个文件的官网链接. User-Level ISA Specificat ...

  2. SSE指令集学习:Compiler Intrinsic

    大多数的函数是在库中,Intrinsic Function却内嵌在编译器中(built in to the compiler). 1. Intrinsic Function Intrinsic Fun ...

  3. ARM-汇编指令集(总结)

    ARM汇编指令集 指令.伪指令 (汇编)指令:   是机器码的助记符,经过汇编器编译后,由CPU执行. (汇编)伪指令:用来指导指令执行,是汇编器的产物,最终不会生成机器码. 有两种不同风格的ARM指 ...

  4. iOS------苹果设备处理器指令集(iPhone初代到iPhone5s)

    (via 雅香小筑) Arm处理器,因为其低功耗和小尺寸而闻名,几乎所有的手机处理器都基于arm,其在嵌入式系统中的应用非常广泛,它的性能在同等功耗产品中也很出色. Armv6.armv7.armv7 ...

  5. SSE指令集优化学习:双线性插值

    对SSE的学习总算迈出了第一步,用2天时间对双线性插值的代码进行了优化,现将实现的过程梳理以下,算是对这段学习的一个总结. 1. 什么是SSE 说到SSE,首先要弄清楚的一个概念是SIMD(单指令多数 ...

  6. RISC指令集的五个周期

    RISC指令集的五个周期 RISC(reduced instruction set computer,精简指令集计算机)简称为精简指令集.RISC把执行指令的精力主要放在了经常使用的指令上面.本文主要 ...

  7. x86指令集同频性能提升

    x86近5000条指令,迄今为止最复杂的指令集.这里不研究CISC & RISC,也不考虑process制程变化,主要是看最近几代IA架构对于同频率下性能的提升. x86指令集nasm文档 h ...

  8. CPU指令集

    cpu作为一台电脑中的核心,它的作用是无法替代的.而cpu本身只是在块硅晶片上所集成的超大规模的集成电路,集成的晶体管数量可达到上亿个,是由非常先进复杂的制造工艺制造出来的,拥有相当高的科技含量. C ...

  9. 在UWP应用中加入Cortana语音指令集

    本文介绍小娜语音指令集的使用场景,如何将UWP应用接入小娜的语音指令集,使用户直接通过小娜启动应用并使用应用中 一些轻量级的功能.文中以必应词典作为实例讲解必应词典UWP版本是如何接入小娜语音功能的. ...

随机推荐

  1. WIN10下使用Anaconda配置opencv、tensorflow、pygame并在pycharm中运用

    昨天想运行一段机器学习的代码,在win10系统下配置了一天的python环境,真的是头疼,准备写篇博客来帮助后面需要配置环境的兄弟. 1.下载Anaconda 根据昨天的经历,发现Anaconda真的 ...

  2. 整理低版本ie兼容问题的解决方案

    CSS hack \9    所有的IE10及之前 *     IE7以及IE7以下版本的 _     IE6以及IE6以下版本的      !important  提升样式优先级权重 1.ie6,7 ...

  3. 解决Mac java.net Local host name unknown error的方法

    解决这个问题的方法: scutil --set HostName "localhost"  解决Mac java.net Local host name unknown error ...

  4. 【BZOJ-3672】购票 树分治 + 斜率优化DP

    3672: [Noi2014]购票 Time Limit: 30 Sec  Memory Limit: 512 MBSubmit: 1177  Solved: 562[Submit][Status][ ...

  5. Educational Codeforces Round 14 B. s-palindrome 水题

    B. s-palindrome 题目连接: http://www.codeforces.com/contest/691/problem/B Description Let's call a strin ...

  6. ROS知识(20)----SLAM资源集合

    1.各种最新开源的SLAM a.OpenSLAM.这里收集了各种最新的开源SLAM资料,包含了比如: ORB_SLAM, ORB_SLAM2, hector_slam,ethzasl_ptam,g2o ...

  7. 39、ABTestingGateway

    2015 年度新增开源软件排名 TOP 100 - 开源中国社区   http://www.oschina.net/news/69808/2015-annual-ranking-top-100-new ...

  8. PL/SQL Developer中调试oracle的存储过程

    作者:iamlaosong 唉,真土,曾经用Toad.一直用dbms_output.put_line调试存储过程,仅仅认为不方便,用上PL/SQL Developer后,习惯性的还是用这种方法.人都是 ...

  9. 【Oracle】-【LRU和DBWR】-LRU算法与DBWR中的应用

    Oracle体系结构中经常看到LRU算法,Least Recently Used,也有叫“最近最少使用页面置换算法”,简单讲,Oracle会将内存中最近不用的数据库移出内存以腾出空间来加载另外的数据. ...

  10. Creating popup windows in XBAP applications

    A colleague at DevelopMentor recently asked me about creating popup windows in XAML browser applicat ...