首页/指令库/VNSRL-WI
VNSRL.WI

RISC-V VNSRL.WI 指令详解

指令手册I-type

逻辑窄化右移,将 2*SEW 源元素写成 SEW 结果。

指令语法

vnsrl.wi vd, vs2, uimm, vm
操作数说明
目标寄存器 rd:存放运算结果的通用寄存器。
源寄存器 rs1:第一个操作数所在的寄存器。
立即数 imm:12 位有符号立即数,符号扩展后与 rs1 进行运算。
V向量整数运算移位/窄化

指令行为说明

VNSRL.WI 对 2*SEW 宽源元素执行逻辑右移,取低 SEW 位作为目标元素。移位量来自 立即数。

快速理解与检索要点

VNSRL.WI 用于把宽整数结果通过逻辑右移缩回 SEW 宽度。

源元素宽度为 2*SEW,目标元素宽度为 SEW。
逻辑右移从高位补零。
该指令不使用 vxrm 舍入,也不设置 vxsat 饱和标志。

常见使用场景

定点缩放

结合 «vnsrl.wi v8, v12, 4, v0.t» 等实际代码理解该场景。

精度降级

结合 «vnsrl.wi v8, v12, 4, v0.t» 等实际代码理解该场景。

使用前检查清单

语法检查
  • 确认当前指令格式为 I-type。
  • 确认操作数排列顺序与示例一致。
语义检查
  • 确认目标寄存器用途和调用约定兼容。
  • 确认该指令不是伪指令展开后的底层形式。

容易混淆 / 常见误区

移位量0+rs1=x0=窄化类型转换(伪指令vncvt.x.x.w)

常见问题

VNSRL.WI 会舍入吗?

不会。它是窄化右移;需要定点舍入和饱和时使用 VNCLIP/VNCLIPU。