VWSUB.WV

RISC-V VWSUB.WV Instruction Details

Instruction ManualR-type

VWSUB.WV performs signed widening subtraction.

Instruction Syntax

vwsub.wv vd, vs2, vs1, vm
Operand Breakdown
Destination rd: register receiving the operation result.
Source rs1: register holding the first operand.
Source rs2: register holding the second operand.
VVector Operations

Instruction Behavior

vwsub.wv is a V extension signed widening subtraction instruction. The first source vs2 is already 2*SEW wide; the other SEW source is widened before subtraction. The result is written to 2*SEW-wide vd.

Quick Understanding & Search Notes

vwsub.wv is a V extension vector instruction. Active elements are controlled by vl, vtype, vstart, and the optional v0.t mask; it subtracts a widened source operand from 2*SEW-wide vs2.

Official syntax is `vwsub.wv vd, vs2, vs1, vm`; without a mask operand it is unmasked, while `, v0.t` updates only selected active elements.
Tail elements and masked-off elements follow the current vtype tail/mask policy; the mnemonic alone does not imply zeroing.
The .w suffix means a wide source participates; this is not ordinary narrow vector subtraction.

Common Usage Scenarios

Bit Operations & Masks

Understand this scenario with real code like «vwsub.wv v8, v12, v4, v0.t».

Data Storing

Understand this scenario with real code like «vwsub.wv v8, v12, v4, v0.t».

Vector Operations

Understand this scenario with real code like «vwsub.wv v8, v12, v4, v0.t».

Pre-Use Checklist

Syntax Check
  • Confirm the current instruction format is R-type.
  • Confirm the operand order matches the example.
Semantic Check
  • Ensure the destination register usage is compatible with the calling convention.
  • Confirm this is not the lower-level form of a pseudo-instruction expansion.

Pitfalls / Common Confusions

In .w forms, vs2 is the wide source operand; do not read it as two narrow sources.
The result is a 2*SEW integer subtraction; it does not use vxrm and does not set vxsat.
The destination group is wider and must satisfy V extension EMUL and overlap constraints.

FAQ

What determines the element count for vwsub.wv?

The current vl and vtype determine it, with vstart, LMUL, SEW, mask state, and tail policy also affecting execution.

Does vwsub.wv always process the whole vector register?

No. V instructions operate on active elements; register grouping and inactive-element behavior are controlled by vtype and policy bits.