[DAGCombiner] Add target hook function to decide folding (mul (add x, c1), c2)
[llvm-project.git] / llvm / test / MC / Mips / mips64shift.ll
blobd36ef37b947e39bec866db76a3212976115c3898
1 ; RUN: llc -march=mips64el -filetype=obj -mcpu=mips64r2 -disable-mips-delay-filler %s -o - \
2 ; RUN:   | llvm-objdump -d - | FileCheck %s
4 ; RUN: llc -march=mips64el -filetype=obj -mcpu=mips64r2 %s -o - \
5 ; RUN:   | llvm-objdump -d - | FileCheck %s
7 define i64 @f3(i64 %a0) nounwind readnone {
8 entry:
9 ; CHECK: dsll ${{[0-9]+}}, ${{[0-9]+}}, 10
10   %shl = shl i64 %a0, 10
11   ret i64 %shl
14 define i64 @f4(i64 %a0) nounwind readnone {
15 entry:
16 ; CHECK: dsra ${{[0-9]+}}, ${{[0-9]+}}, 10
17   %shr = ashr i64 %a0, 10
18   ret i64 %shr
21 define i64 @f5(i64 %a0) nounwind readnone {
22 entry:
23 ; CHECK: dsrl ${{[0-9]+}}, ${{[0-9]+}}, 10
24   %shr = lshr i64 %a0, 10
25   ret i64 %shr
28 define i64 @f6(i64 %a0) nounwind readnone {
29 entry:
30 ; CHECK: dsll32 ${{[0-9]+}}, ${{[0-9]+}}, 8
31   %shl = shl i64 %a0, 40
32   ret i64 %shl
35 define i64 @f7(i64 %a0) nounwind readnone {
36 entry:
37 ; CHECK: dsra32 ${{[0-9]+}}, ${{[0-9]+}}, 8
38   %shr = ashr i64 %a0, 40
39   ret i64 %shr
42 define i64 @f8(i64 %a0) nounwind readnone {
43 entry:
44 ; CHECK: dsrl32 ${{[0-9]+}}, ${{[0-9]+}}, 8
45   %shr = lshr i64 %a0, 40
46   ret i64 %shr