INCB, INCD, INCH, INCW (scalar)

Increment scalar by multiple of predicate constraint element count

Determines the number of active elements implied by the named predicate constraint, multiplies that by an immediate in the range 1 to 16 inclusive, and then uses the result to increment the scalar destination.

The named predicate constraint limits the number of active elements in a single predicate to:

  • A fixed number (VL1 to VL256)
  • The largest power of two (POW2)
  • The largest multiple of three or four (MUL3 or MUL4)
  • All available, implicitly a multiple of two (ALL).
  • Unspecified or out of range constraint encodings generate an empty predicate or zero element count rather than Undefined Instruction exception.

    Encoding: Byte

    Variants: FEAT_SVE || FEAT_SME (FEAT_SVE || FEAT_SME)

    313029282726252423222120191817161514131211109876543210
    000001000011111000
    sizeimm4DpatternRdn

    INCB <Xdn>{, <pattern>{, MUL #<imm>}}

    Decoding algorithm

    if !IsFeatureImplemented(FEAT_SVE) && !IsFeatureImplemented(FEAT_SME) then
        EndOfDecode(Decode_UNDEF);
    constant integer esize = 8;
    constant integer dn = UInt(Rdn);
    constant bits(5) pat = pattern;
    constant integer imm = UInt(imm4) + 1;

    Encoding: Doubleword

    Variants: FEAT_SVE || FEAT_SME (FEAT_SVE || FEAT_SME)

    313029282726252423222120191817161514131211109876543210
    000001001111111000
    sizeimm4DpatternRdn

    INCD <Xdn>{, <pattern>{, MUL #<imm>}}

    Decoding algorithm

    if !IsFeatureImplemented(FEAT_SVE) && !IsFeatureImplemented(FEAT_SME) then
        EndOfDecode(Decode_UNDEF);
    constant integer esize = 64;
    constant integer dn = UInt(Rdn);
    constant bits(5) pat = pattern;
    constant integer imm = UInt(imm4) + 1;

    Encoding: Halfword

    Variants: FEAT_SVE || FEAT_SME (FEAT_SVE || FEAT_SME)

    313029282726252423222120191817161514131211109876543210
    000001000111111000
    sizeimm4DpatternRdn

    INCH <Xdn>{, <pattern>{, MUL #<imm>}}

    Decoding algorithm

    if !IsFeatureImplemented(FEAT_SVE) && !IsFeatureImplemented(FEAT_SME) then
        EndOfDecode(Decode_UNDEF);
    constant integer esize = 16;
    constant integer dn = UInt(Rdn);
    constant bits(5) pat = pattern;
    constant integer imm = UInt(imm4) + 1;

    Encoding: Word

    Variants: FEAT_SVE || FEAT_SME (FEAT_SVE || FEAT_SME)

    313029282726252423222120191817161514131211109876543210
    000001001011111000
    sizeimm4DpatternRdn

    INCW <Xdn>{, <pattern>{, MUL #<imm>}}

    Decoding algorithm

    if !IsFeatureImplemented(FEAT_SVE) && !IsFeatureImplemented(FEAT_SME) then
        EndOfDecode(Decode_UNDEF);
    constant integer esize = 32;
    constant integer dn = UInt(Rdn);
    constant bits(5) pat = pattern;
    constant integer imm = UInt(imm4) + 1;

    Operation

    CheckSVEEnabled();
    constant integer count = DecodePredCount(pat, esize);
    constant integer VL = CurrentVL;
    constant bits(64) operand1 = X[dn, 64];
    X[dn, 64] = operand1 + (count * imm);

    Explanations

    <Xdn>: Is the 64-bit name of the source and destination general-purpose register, encoded in the "Rdn" field.
    <pattern>: <imm>: Is the immediate multiplier, in the range 1 to 16, defaulting to 1, encoded in the "imm4" field.

    Operational Notes

    If PSTATE.DIT is 1: