aboutsummaryrefslogtreecommitdiffstats
path: root/test/Transforms/StraightLineStrengthReduce/slsr-add.ll
blob: 4c79be0577e326edc6492d37c6076d08457c58d3 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
; RUN: opt < %s -slsr -gvn -dce -S | FileCheck %s

target datalayout = "e-i64:64-v16:16-v32:32-n16:32:64"

define void @shl(i32 %b, i32 %s) {
; CHECK-LABEL: @shl(
  %1 = add i32 %b, %s
; [[BASIS:%[a-zA-Z0-9]+]] = add i32 %b, %s
  call void @foo(i32 %1)
  %s2 = shl i32 %s, 1
  %2 = add i32 %b, %s2
; add i32 [[BASIS]], %s
  call void @foo(i32 %2)
  ret void
}

define void @stride_is_2s(i32 %b, i32 %s) {
; CHECK-LABEL: @stride_is_2s(
  %s2 = shl i32 %s, 1
; CHECK: %s2 = shl i32 %s, 1
  %1 = add i32 %b, %s2
; CHECK: [[t1:%[a-zA-Z0-9]+]] = add i32 %b, %s2
  call void @foo(i32 %1)
  %s4 = shl i32 %s, 2
  %2 = add i32 %b, %s4
; CHECK: [[t2:%[a-zA-Z0-9]+]] = add i32 [[t1]], %s2
  call void @foo(i32 %2)
  %s6 = mul i32 %s, 6
  %3 = add i32 %b, %s6
; CHECK: add i32 [[t2]], %s2
  call void @foo(i32 %3)
  ret void
}

define void @stride_is_3s(i32 %b, i32 %s) {
; CHECK-LABEL: @stride_is_3s(
  %1 = add i32 %s, %b
; CHECK: [[t1:%[a-zA-Z0-9]+]] = add i32 %s, %b
  call void @foo(i32 %1)
  %s4 = shl i32 %s, 2
  %2 = add i32 %s4, %b
; CHECK: [[bump:%[a-zA-Z0-9]+]] = mul i32 %s, 3
; CHECK: [[t2:%[a-zA-Z0-9]+]] = add i32 [[t1]], [[bump]]
  call void @foo(i32 %2)
  %s7 = mul i32 %s, 7
  %3 = add i32 %s7, %b
; CHECK: add i32 [[t2]], [[bump]]
  call void @foo(i32 %3)
  ret void
}

; foo(b + 6 * s);
; foo(b + 4 * s);
; foo(b + 2 * s);
;   =>
; t1 = b + 6 * s;
; foo(t1);
; s2 = 2 * s;
; t2 = t1 - s2;
; foo(t2);
; t3 = t2 - s2;
; foo(t3);
define void @stride_is_minus_2s(i32 %b, i32 %s) {
; CHECK-LABEL: @stride_is_minus_2s(
  %s6 = mul i32 %s, 6
  %1 = add i32 %b, %s6
; CHECK: [[t1:%[a-zA-Z0-9]+]] = add i32 %b, %s6
; CHECK: call void @foo(i32 [[t1]])
  call void @foo(i32 %1)
  %s4 = shl i32 %s, 2
  %2 = add i32 %b, %s4
; CHECK: [[bump:%[a-zA-Z0-9]+]] = shl i32 %s, 1
; CHECK: [[t2:%[a-zA-Z0-9]+]] = sub i32 [[t1]], [[bump]]
  call void @foo(i32 %2)
; CHECK: call void @foo(i32 [[t2]])
  %s2 = shl i32 %s, 1
  %3 = add i32 %b, %s2
; CHECK: [[t3:%[a-zA-Z0-9]+]] = sub i32 [[t2]], [[bump]]
  call void @foo(i32 %3)
; CHECK: call void @foo(i32 [[t3]])
  ret void
}

; t = b + (s << 3);
; foo(t);
; foo(b + s);
;
; do not rewrite b + s to t - 7 * s because the latter is more complicated.
define void @simple_enough(i32 %b, i32 %s) {
; CHECK-LABEL: @simple_enough(
  %s8 = shl i32 %s, 3
  %1 = add i32 %b, %s8
  call void @foo(i32 %1)
  %2 = add i32 %b, %s
; CHECK: [[t:%[a-zA-Z0-9]+]] = add i32 %b, %s{{$}}
  call void @foo(i32 %2)
; CHECK: call void @foo(i32 [[t]])
  ret void
}

declare void @foo(i32)