1
; RUN: opt < %s -slsr -nary-reassociate -S | FileCheck %s
2
; RUN: llc < %s -march=nvptx64 -mcpu=sm_20 | FileCheck %s --check-prefix=PTX
4
target datalayout = "e-i64:64-v16:16-v32:32-n16:32:64"
7
; foo((a + b * 2) + c);
8
; foo((a + b * 3) + c);
16
define void @nary_reassociate_after_slsr(i32 %a, i32 %b, i32 %c) {
17
; CHECK-LABEL: @nary_reassociate_after_slsr(
18
; PTX-LABEL: .visible .func nary_reassociate_after_slsr(
19
; PTX: ld.param.u32 [[b:%r[0-9]+]], [nary_reassociate_after_slsr_param_1];
21
%abc = add i32 %ab, %c
22
call void @foo(i32 %abc)
23
; CHECK: call void @foo(i32 %abc)
24
; PTX: st.param.b32 [param0+0], [[abc:%r[0-9]+]];
27
%ab2 = add i32 %a, %b2
28
%ab2c = add i32 %ab2, %c
29
; CHECK-NEXT: %ab2c = add i32 %abc, %b
30
; PTX: add.s32 [[ab2c:%r[0-9]+]], [[abc]], [[b]]
31
call void @foo(i32 %ab2c)
32
; CHECK-NEXT: call void @foo(i32 %ab2c)
33
; PTX: st.param.b32 [param0+0], [[ab2c]];
36
%ab3 = add i32 %a, %b3
37
%ab3c = add i32 %ab3, %c
38
; CHECK-NEXT: %ab3c = add i32 %ab2c, %b
39
; PTX: add.s32 [[ab3c:%r[0-9]+]], [[ab2c]], [[b]]
40
call void @foo(i32 %ab3c)
41
; CHECK-NEXT: call void @foo(i32 %ab3c)
42
; PTX: st.param.b32 [param0+0], [[ab3c]];
47
declare void @foo(i32)