1; RUN: llc < %s 2; PR3117 3target datalayout = "e-p:32:32:32-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:32:64-f32:32:32-f64:32:64-v64:64:64-v128:128:128-a0:0:64-f80:32:32" 4target triple = "i386-pc-linux-gnu" 5@g_118 = external global i8 ; <i8*> [#uses=1] 6@g_7 = external global i32 ; <i32*> [#uses=1] 7 8define i32 @func_73(i32 %p_74) nounwind { 9entry: 10 %0 = load i32* @g_7, align 4 ; <i32> [#uses=1] 11 %1 = or i8 0, 118 ; <i8> [#uses=1] 12 %2 = zext i8 %1 to i64 ; <i64> [#uses=1] 13 %3 = icmp ne i32 %0, 0 ; <i1> [#uses=1] 14 %4 = zext i1 %3 to i64 ; <i64> [#uses=1] 15 %5 = or i64 %4, -758998846 ; <i64> [#uses=3] 16 %6 = icmp sle i64 %2, %5 ; <i1> [#uses=1] 17 %7 = zext i1 %6 to i8 ; <i8> [#uses=1] 18 %8 = or i8 %7, 118 ; <i8> [#uses=1] 19 %9 = zext i8 %8 to i64 ; <i64> [#uses=1] 20 %10 = icmp sle i64 %9, 0 ; <i1> [#uses=1] 21 %11 = zext i1 %10 to i8 ; <i8> [#uses=1] 22 %12 = or i8 %11, 118 ; <i8> [#uses=1] 23 %13 = zext i8 %12 to i64 ; <i64> [#uses=1] 24 %14 = icmp sle i64 %13, %5 ; <i1> [#uses=1] 25 %15 = zext i1 %14 to i8 ; <i8> [#uses=1] 26 %16 = or i8 %15, 118 ; <i8> [#uses=1] 27 %17 = zext i8 %16 to i64 ; <i64> [#uses=1] 28 %18 = icmp sle i64 %17, 0 ; <i1> [#uses=1] 29 %19 = zext i1 %18 to i8 ; <i8> [#uses=1] 30 %20 = or i8 %19, 118 ; <i8> [#uses=1] 31 %21 = zext i8 %20 to i64 ; <i64> [#uses=1] 32 %22 = icmp sle i64 %21, %5 ; <i1> [#uses=1] 33 %23 = zext i1 %22 to i8 ; <i8> [#uses=1] 34 %24 = or i8 %23, 118 ; <i8> [#uses=1] 35 store i8 %24, i8* @g_118, align 1 36 ret i32 undef 37} 38