1# RUN: llc -run-pass=peephole-opt %s -o - | FileCheck %s
2
3# Here we check that the peephole cmp rewrite is not triggered, because
4# there is store instruction between the tMUL and tCMP, i.e. there are
5# no constants to reorder.
6
7--- |
8  ; ModuleID = 'cmp2-peephole-thumb.ll'
9  source_filename = "<stdin>"
10  target datalayout = "e-m:e-p:32:32-i64:64-v128:64:128-a:0:32-n32-S64"
11  target triple = "thumb-none--eabi"
12
13  define i32 @g(i32 %a, i32 %b) {
14  entry:
15    %retval = alloca i32, align 4
16    %mul = alloca i32, align 4
17    %mul1 = mul nsw i32 %a, %b
18    store i32 %mul1, i32* %mul, align 4
19    %0 = load i32, i32* %mul, align 4
20    %cmp = icmp sle i32 %0, 0
21    br i1 %cmp, label %if.then, label %if.end
22
23  if.then:                                          ; preds = %entry
24    store i32 42, i32* %retval, align 4
25    br label %return
26
27  if.end:                                           ; preds = %entry
28    store i32 1, i32* %retval, align 4
29    br label %return
30
31  return:                                           ; preds = %if.end, %if.then
32    %1 = load i32, i32* %retval, align 4
33    ret i32 %1
34  }
35
36...
37---
38name:            g
39# CHECK-LABEL: name: g
40alignment:       2
41exposesReturnsTwice: false
42legalized:       false
43regBankSelected: false
44selected:        false
45tracksRegLiveness: true
46registers:
47  - { id: 0, class: tgpr }
48  - { id: 1, class: tgpr }
49  - { id: 2, class: tgpr }
50  - { id: 3, class: tgpr }
51  - { id: 4, class: tgpr }
52  - { id: 5, class: tgpr }
53liveins:
54  - { reg: '$r0', virtual-reg: '%0' }
55  - { reg: '$r1', virtual-reg: '%1' }
56frameInfo:
57  isFrameAddressTaken: false
58  isReturnAddressTaken: false
59  hasStackMap:     false
60  hasPatchPoint:   false
61  stackSize:       0
62  offsetAdjustment: 0
63  maxAlignment:    4
64  adjustsStack:    false
65  hasCalls:        false
66  maxCallFrameSize: 0
67  hasOpaqueSPAdjustment: false
68  hasVAStart:      false
69  hasMustTailInVarArgFunc: false
70stack:
71  - { id: 0, name: retval, offset: 0, size: 4, alignment: 4, local-offset: -4 }
72  - { id: 1, name: mul, offset: 0, size: 4, alignment: 4, local-offset: -8 }
73
74# CHECK: tMUL
75# CHECK-NEXT: tSTRspi
76# CHECK-NEXT: tCMPi8
77body:             |
78  bb.0.entry:
79    liveins: $r0, $r1
80
81    %1 = COPY $r1
82    %0 = COPY $r0
83    %2, $cpsr = tMUL %0, %1, 14, $noreg
84    tSTRspi %2, %stack.1.mul, 0, 14, $noreg :: (store 4 into %ir.mul)
85    tCMPi8 %2, 0, 14, $noreg, implicit-def $cpsr
86    tBcc %bb.2.if.end, 12, $cpsr
87    tB %bb.1.if.then, 14, $noreg
88
89  bb.1.if.then:
90    %4, $cpsr = tMOVi8 42, 14, $noreg
91    tSTRspi killed %4, %stack.0.retval, 0, 14, $noreg :: (store 4 into %ir.retval)
92    tB %bb.3.return, 14, $noreg
93
94  bb.2.if.end:
95    %3, $cpsr = tMOVi8 1, 14, $noreg
96    tSTRspi killed %3, %stack.0.retval, 0, 14, $noreg :: (store 4 into %ir.retval)
97
98  bb.3.return:
99    %5 = tLDRspi %stack.0.retval, 0, 14, $noreg :: (dereferenceable load 4 from %ir.retval)
100    $r0 = COPY %5
101    tBX_RET 14, $noreg, implicit $r0
102
103...
104