aboutsummaryrefslogtreecommitdiff
path: root/riscv/insns/uclip8.h
blob: b8a95c0758367260340d4f420268212293fcca4c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
require_vector_vs;
P_I_LOOP(8, 3, {
  int64_t uint_max = imm3u ? UINT64_MAX >> (64 - imm3u) : 0;
  pd = ps1;

  if (ps1 > uint_max) {
    pd = uint_max;
    P_SET_OV(1);
  } else if (ps1 < 0) {
    pd = 0;
    P_SET_OV(1);
  }
})