blob: 548b44db6d2728824935e57018e96988be6f0721 [file] [log] [blame]
Chris Lattnerfa4e8532010-02-03 00:48:53 +00001; RUN: llc < %s -march=x86 -relocation-model=static -disable-fp-elim -post-RA-scheduler=false -asm-verbose=0 | FileCheck %s
Evan Chengc33577b2008-07-12 01:56:02 +00002; PR2536
3
Jakob Stoklund Olesendec66802010-02-11 23:55:29 +00004; CHECK: andl $65534, %
Evan Chengb9bbb572009-09-21 21:12:25 +00005; CHECK-NEXT: movl %
Chris Lattner9e2f6412009-08-30 21:45:23 +00006; CHECK-NEXT: movl $17
7
Evan Chengc33577b2008-07-12 01:56:02 +00008@g_5 = external global i16 ; <i16*> [#uses=2]
9@g_107 = external global i16 ; <i16*> [#uses=1]
10@g_229 = external global i32 ; <i32*> [#uses=1]
11@g_227 = external global i16 ; <i16*> [#uses=1]
12
13define i32 @func_54(i32 %p_55, i16 zeroext %p_56) nounwind {
14entry:
15 load i16* @g_5, align 2 ; <i16>:0 [#uses=1]
16 zext i16 %0 to i32 ; <i32>:1 [#uses=1]
17 %.mask = and i32 %1, 65534 ; <i32> [#uses=1]
18 icmp eq i32 %.mask, 0 ; <i1>:2 [#uses=1]
19 load i32* @g_229, align 4 ; <i32>:3 [#uses=1]
20 load i16* @g_227, align 2 ; <i16>:4 [#uses=1]
21 icmp eq i16 %4, 0 ; <i1>:5 [#uses=1]
22 load i16* @g_5, align 2 ; <i16>:6 [#uses=1]
23 br label %bb
24
25bb: ; preds = %bb7.preheader, %entry
26 %indvar4 = phi i32 [ 0, %entry ], [ %indvar.next5, %bb7.preheader ] ; <i32> [#uses=1]
27 %p_56_addr.1.reg2mem.0 = phi i16 [ %p_56, %entry ], [ %p_56_addr.0, %bb7.preheader ] ; <i16> [#uses=2]
28 br i1 %2, label %bb7.preheader, label %bb5
29
30bb5: ; preds = %bb
31 store i16 %6, i16* @g_107, align 2
32 br label %bb7.preheader
33
34bb7.preheader: ; preds = %bb5, %bb
35 icmp eq i16 %p_56_addr.1.reg2mem.0, 0 ; <i1>:7 [#uses=1]
Evan Cheng475031e2009-03-12 16:10:08 +000036 %.0 = select i1 %7, i32 1, i32 %3 ; <i32> [#uses=1]
Evan Chengc33577b2008-07-12 01:56:02 +000037 urem i32 1, %.0 ; <i32>:8 [#uses=1]
38 icmp eq i32 %8, 0 ; <i1>:9 [#uses=1]
39 %.not = xor i1 %9, true ; <i1> [#uses=1]
40 %.not1 = xor i1 %5, true ; <i1> [#uses=1]
41 %brmerge = or i1 %.not, %.not1 ; <i1> [#uses=1]
Evan Cheng475031e2009-03-12 16:10:08 +000042 %iftmp.6.0 = select i1 %brmerge, i32 3, i32 0 ; <i32> [#uses=1]
Evan Chengc33577b2008-07-12 01:56:02 +000043 mul i32 %iftmp.6.0, %3 ; <i32>:10 [#uses=1]
44 icmp eq i32 %10, 0 ; <i1>:11 [#uses=1]
45 %p_56_addr.0 = select i1 %11, i16 %p_56_addr.1.reg2mem.0, i16 1 ; <i16> [#uses=1]
46 %indvar.next5 = add i32 %indvar4, 1 ; <i32> [#uses=2]
47 %exitcond6 = icmp eq i32 %indvar.next5, 17 ; <i1> [#uses=1]
48 br i1 %exitcond6, label %bb25, label %bb
49
50bb25: ; preds = %bb7.preheader
51 ret i32 1
52}