VMACC.VX

RISC-V VMACC.VX Instruction Details

Instruction ManualR-type

Add the integer product of vs1/scalar and vs2 to the old vd.

Instruction Syntax

vmacc.vx vd, vs2, rs1, 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 IntegerMultiply-Accumulate

Instruction Behavior

VMACC.VX is a destructive RISC-V V integer multiply-add instruction. It computes vd[i] = vd[i] + vs2[i] * the second operand. Multiplication and addition produce the low SEW-width result and do not set integer exception flags.

Quick Understanding & Search Notes

VMACC.VX writes only active elements; integer overflow keeps the low SEW bits and does not trap.

Vector-scalar .vx forms use x[rs1], while vector-vector .vv forms use vs1.
Results are written at SEW width; high-half multiply explicitly returns the high SEW bits of the 2*SEW product.
vm=0 uses v0 as the execution mask and vm=1 is unmasked; inactive and tail elements follow the current vma/vta policy.

Common Usage Scenarios

Vectorized Loops

Understand this scenario with real code like «vsetvli t0, a0, e32, m1, ta, ma vmacc.vx v8, v4, a1».

Matrix/Tensor

Understand this scenario with real code like «vsetvli t0, a0, e32, m1, ta, ma vmacc.vx v8, v4, a1».

Convolution

Understand this scenario with real code like «vsetvli t0, a0, e32, m1, ta, ma vmacc.vx v8, v4, a1».

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

Destructive: vd is both accumulator input and output
Only low SEW bits of product retained; use vwmacc for widening
vmacc overwrites addend(vd); vmadd overwrites multiplicand(vs1)

FAQ

How does VMACC.VX handle masking?

With vm=0, v0 selects active elements; with vm=1, all body elements participate. Inactive and tail elements follow the current policies.