xref: /aosp_15_r20/external/llvm/test/CodeGen/ARM/cse-flags.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: llc -asm-verbose=false < %s | FileCheck %s
2*9880d681SAndroid Build Coastguard Worker; PR26063
3*9880d681SAndroid Build Coastguard Worker
4*9880d681SAndroid Build Coastguard Workertarget datalayout = "e-m:e-p:32:32-i64:64-v128:64:128-a:0:32-n32-S64"
5*9880d681SAndroid Build Coastguard Workertarget triple = "armv7--linux-gnueabihf"
6*9880d681SAndroid Build Coastguard Worker
7*9880d681SAndroid Build Coastguard Worker; CHECK: .LBB0_1:
8*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: bl      f{{$}}
9*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: ldrb    r[[T0:[0-9]+]], [r{{[0-9]+}}, #1]!{{$}}
10*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: cmp     r{{[0-9]+}}, #1{{$}}
11*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: cmpne   r[[T0]], #0{{$}}
12*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: bne     .LBB0_1{{$}}
13*9880d681SAndroid Build Coastguard Workerdefine i8* @h(i8* readonly %a, i32 %b, i32 %c) {
14*9880d681SAndroid Build Coastguard Workerentry:
15*9880d681SAndroid Build Coastguard Worker  %0 = load i8, i8* %a, align 1
16*9880d681SAndroid Build Coastguard Worker  %tobool4 = icmp ne i8 %0, 0
17*9880d681SAndroid Build Coastguard Worker  %cmp5 = icmp ne i32 %b, 1
18*9880d681SAndroid Build Coastguard Worker  %1 = and i1 %cmp5, %tobool4
19*9880d681SAndroid Build Coastguard Worker  br i1 %1, label %while.body.preheader, label %while.end
20*9880d681SAndroid Build Coastguard Worker
21*9880d681SAndroid Build Coastguard Workerwhile.body.preheader:                             ; preds = %entry
22*9880d681SAndroid Build Coastguard Worker  br label %while.body
23*9880d681SAndroid Build Coastguard Worker
24*9880d681SAndroid Build Coastguard Workerwhile.body:                                       ; preds = %while.body.preheader, %while.body
25*9880d681SAndroid Build Coastguard Worker  %a.addr.06 = phi i8* [ %incdec.ptr, %while.body ], [ %a, %while.body.preheader ]
26*9880d681SAndroid Build Coastguard Worker  %call = tail call i32 bitcast (i32 (...)* @f to i32 ()*)()
27*9880d681SAndroid Build Coastguard Worker  %incdec.ptr = getelementptr inbounds i8, i8* %a.addr.06, i32 1
28*9880d681SAndroid Build Coastguard Worker  %2 = load i8, i8* %incdec.ptr, align 1
29*9880d681SAndroid Build Coastguard Worker  %tobool = icmp ne i8 %2, 0
30*9880d681SAndroid Build Coastguard Worker  %cmp = icmp ne i32 %call, 1
31*9880d681SAndroid Build Coastguard Worker  %3 = and i1 %cmp, %tobool
32*9880d681SAndroid Build Coastguard Worker  br i1 %3, label %while.body, label %while.end.loopexit
33*9880d681SAndroid Build Coastguard Worker
34*9880d681SAndroid Build Coastguard Workerwhile.end.loopexit:                               ; preds = %while.body
35*9880d681SAndroid Build Coastguard Worker  %incdec.ptr.lcssa = phi i8* [ %incdec.ptr, %while.body ]
36*9880d681SAndroid Build Coastguard Worker  br label %while.end
37*9880d681SAndroid Build Coastguard Worker
38*9880d681SAndroid Build Coastguard Workerwhile.end:                                        ; preds = %while.end.loopexit, %entry
39*9880d681SAndroid Build Coastguard Worker  %a.addr.0.lcssa = phi i8* [ %a, %entry ], [ %incdec.ptr.lcssa, %while.end.loopexit ]
40*9880d681SAndroid Build Coastguard Worker  ret i8* %a.addr.0.lcssa
41*9880d681SAndroid Build Coastguard Worker}
42*9880d681SAndroid Build Coastguard Worker
43*9880d681SAndroid Build Coastguard Workerdeclare i32 @f(...)
44