[InstCombine] Signed saturation patterns
[llvm-complete.git] / test / CodeGen / AArch64 / aarch64-combine-fmul-fsub.mir
blobc69967d941542d9d702342b7d1c566bf5caf4653
1 # RUN: llc -run-pass=machine-combiner -o - -mtriple=aarch64-unknown-linux -mcpu=cortex-a57 -enable-unsafe-fp-math -machine-combiner-verify-pattern-order=true %s | FileCheck --check-prefixes=UNPROFITABLE,ALL %s
2 # RUN: llc -run-pass=machine-combiner -o - -mtriple=aarch64-unknown-linux -mcpu=falkor -enable-unsafe-fp-math %s -machine-combiner-verify-pattern-order=true | FileCheck --check-prefixes=PROFITABLE,ALL %s
3 # RUN: llc -run-pass=machine-combiner -o - -mtriple=aarch64-unknown-linux -mcpu=exynos-m1 -enable-unsafe-fp-math -machine-combiner-verify-pattern-order=true %s | FileCheck --check-prefixes=PROFITABLE,ALL %s
4 # RUN: llc -run-pass=machine-combiner -o - -mtriple=aarch64-unknown-linux -mcpu=thunderx2t99 -enable-unsafe-fp-math -machine-combiner-verify-pattern-order=true %s | FileCheck --check-prefixes=PROFITABLE,ALL %s
6 name:            f1_2s
7 registers:
8   - { id: 0, class: fpr64 }
9   - { id: 1, class: fpr64 }
10   - { id: 2, class: fpr64 }
11   - { id: 3, class: fpr64 }
12   - { id: 4, class: fpr64 }
13 body:             |
14   bb.0.entry:
15     %2:fpr64 = COPY $d2
16     %1:fpr64 = COPY $d1
17     %0:fpr64 = COPY $d0
18     %3:fpr64 = FMULv2f32 %0, %1
19     %4:fpr64 = FSUBv2f32 killed %3, %2
20     $d0 = COPY %4
21     RET_ReallyLR implicit $d0
23 ...
24 # UNPROFITABLE-LABEL: name: f1_2s
25 # UNPROFITABLE: %3:fpr64 = FMULv2f32 %0, %1
26 # UNPROFITABLE-NEXT: FSUBv2f32 killed %3, %2
28 # PROFITABLE-LABEL: name: f1_2s
29 # PROFITABLE: [[R1:%[0-9]+]]:fpr64 = FNEGv2f32 %2
30 # PROFITABLE-NEXT: FMLAv2f32 killed [[R1]], %0, %1
31 ---
32 name:            f1_4s
33 registers:
34   - { id: 0, class: fpr128 }
35   - { id: 1, class: fpr128 }
36   - { id: 2, class: fpr128 }
37   - { id: 3, class: fpr128 }
38   - { id: 4, class: fpr128 }
39 body:             |
40   bb.0.entry:
41     %2:fpr128 = COPY $q2
42     %1:fpr128 = COPY $q1
43     %0:fpr128 = COPY $q0
44     %3:fpr128 = FMULv4f32 %0, %1
45     %4:fpr128 = FSUBv4f32 killed %3, %2
46     $q0 = COPY %4
47     RET_ReallyLR implicit $q0
49 ...
50 # UNPROFITABLE-LABEL: name: f1_4s
51 # UNPROFITABLE: %3:fpr128 = FMULv4f32 %0, %1
52 # UNPROFITABLE-NEXT: FSUBv4f32 killed %3, %2
54 # PROFITABLE-LABEL: name: f1_4s
55 # PROFITABLE: [[R1:%[0-9]+]]:fpr128 = FNEGv4f32 %2
56 # PROFITABLE-NEXT: FMLAv4f32 killed [[R1]], %0, %1
57 ---
58 name:            f1_2d
59 registers:
60   - { id: 0, class: fpr128 }
61   - { id: 1, class: fpr128 }
62   - { id: 2, class: fpr128 }
63   - { id: 3, class: fpr128 }
64   - { id: 4, class: fpr128 }
65 body:             |
66   bb.0.entry:
67     %2:fpr128 = COPY $q2
68     %1:fpr128 = COPY $q1
69     %0:fpr128 = COPY $q0
70     %3:fpr128 = FMULv2f64 %0, %1
71     %4:fpr128 = FSUBv2f64 killed %3, %2
72     $q0 = COPY %4
73     RET_ReallyLR implicit $q0
75 ...
76 # UNPROFITABLE-LABEL: name: f1_2d
77 # UNPROFITABLE: %3:fpr128 = FMULv2f64 %0, %1
78 # UNPROFITABLE-NEXT: FSUBv2f64 killed %3, %2
80 # PROFITABLE-LABEL: name: f1_2d
81 # PROFITABLE: [[R1:%[0-9]+]]:fpr128 = FNEGv2f64 %2
82 # PROFITABLE-NEXT: FMLAv2f64 killed [[R1]], %0, %1
83 ---
84 name:            f1_both_fmul_2s
85 registers:
86   - { id: 0, class: fpr64 }
87   - { id: 1, class: fpr64 }
88   - { id: 2, class: fpr64 }
89   - { id: 3, class: fpr64 }
90   - { id: 4, class: fpr64 }
91   - { id: 5, class: fpr64 }
92   - { id: 6, class: fpr64 }
93 body:             |
94   bb.0.entry:
95     %3:fpr64 = COPY $q3
96     %2:fpr64 = COPY $q2
97     %1:fpr64 = COPY $q1
98     %0:fpr64 = COPY $q0
99     %4:fpr64 = FMULv2f32 %0, %1
100     %5:fpr64 = FMULv2f32 %2, %3
101     %6:fpr64 = FSUBv2f32 killed %4, %5
102     $q0 = COPY %6
103     RET_ReallyLR implicit $q0
106 # ALL-LABEL: name: f1_both_fmul_2s
107 # ALL: %4:fpr64 = FMULv2f32 %0, %1
108 # ALL-NEXT: FMLSv2f32 killed %4, %2, %3
110 name:            f1_both_fmul_4s
111 registers:
112   - { id: 0, class: fpr128 }
113   - { id: 1, class: fpr128 }
114   - { id: 2, class: fpr128 }
115   - { id: 3, class: fpr128 }
116   - { id: 4, class: fpr128 }
117   - { id: 5, class: fpr128 }
118   - { id: 6, class: fpr128 }
119 body:             |
120   bb.0.entry:
121     %3:fpr128 = COPY $q3
122     %2:fpr128 = COPY $q2
123     %1:fpr128 = COPY $q1
124     %0:fpr128 = COPY $q0
125     %4:fpr128 = FMULv4f32 %0, %1
126     %5:fpr128 = FMULv4f32 %2, %3
127     %6:fpr128 = FSUBv4f32 killed %4, %5
128     $q0 = COPY %6
129     RET_ReallyLR implicit $q0
132 # ALL-LABEL: name: f1_both_fmul_4s
133 # ALL: %4:fpr128 = FMULv4f32 %0, %1
134 # ALL-NEXT: FMLSv4f32 killed %4, %2, %3
136 name:            f1_both_fmul_2d
137 registers:
138   - { id: 0, class: fpr128 }
139   - { id: 1, class: fpr128 }
140   - { id: 2, class: fpr128 }
141   - { id: 3, class: fpr128 }
142   - { id: 4, class: fpr128 }
143   - { id: 5, class: fpr128 }
144   - { id: 6, class: fpr128 }
145 body:             |
146   bb.0.entry:
147     %3:fpr128 = COPY $q3
148     %2:fpr128 = COPY $q2
149     %1:fpr128 = COPY $q1
150     %0:fpr128 = COPY $q0
151     %4:fpr128 = FMULv2f64 %0, %1
152     %5:fpr128 = FMULv2f64 %2, %3
153     %6:fpr128 = FSUBv2f64 killed %4, %5
154     $q0 = COPY %6
155     RET_ReallyLR implicit $q0
158 # ALL-LABEL: name: f1_both_fmul_2d
159 # ALL: %4:fpr128 = FMULv2f64 %0, %1
160 # ALL-NEXT: FMLSv2f64 killed %4, %2, %3