1; RUN: llc < %s -march=nvptx -mcpu=sm_20 | FileCheck %s
2
3; CHECK: shift_parts_left_128
4define void @shift_parts_left_128(i128* %val, i128* %amtptr) {
5; CHECK: shl.b64
6; CHECK: mov.u32
7; CHECK: sub.s32
8; CHECK: shr.u64
9; CHECK: or.b64
10; CHECK: add.s32
11; CHECK: shl.b64
12; CHECK: setp.gt.s32
13; CHECK: selp.b64
14; CHECK: shl.b64
15  %amt = load i128, i128* %amtptr
16  %a = load i128, i128* %val
17  %val0 = shl i128 %a, %amt
18  store i128 %val0, i128* %val
19  ret void
20}
21
22; CHECK: shift_parts_right_128
23define void @shift_parts_right_128(i128* %val, i128* %amtptr) {
24; CHECK: shr.u64
25; CHECK: sub.s32
26; CHECK: shl.b64
27; CHECK: or.b64
28; CHECK: add.s32
29; CHECK: shr.s64
30; CHECK: setp.gt.s32
31; CHECK: selp.b64
32; CHECK: shr.s64
33  %amt = load i128, i128* %amtptr
34  %a = load i128, i128* %val
35  %val0 = ashr i128 %a, %amt
36  store i128 %val0, i128* %val
37  ret void
38}
39