aboutsummaryrefslogtreecommitdiff
path: root/riscv/insns/kmar64.h
blob: a4d332b0d8034911b3f4212b7d69b14719aeb91f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
require_vector_vs;
P_64_PROFILE_BASE()
P_64_PROFILE_PARAM(true, false)

bool sat = false;
sreg_t mres0 = (sreg_t)P_SW(rs1, 0) * P_SW(rs2, 0);
sreg_t mres1 = (sreg_t)P_SW(rs1, 1) * P_SW(rs2, 1);

if (xlen == 32) {
  rd = (sat_add<int64_t, uint64_t>(rd, mres0, sat));
} else {
  rd = (sat_add<int64_t, uint64_t>(rd, mres0, mres1, sat));
}
P_SET_OV(sat);
P_64_PROFILE_END()