1*9880d681SAndroid Build Coastguard Worker; RUN: llvm-as < %s | llvm-dis | FileCheck %s 2*9880d681SAndroid Build Coastguard Worker 3*9880d681SAndroid Build Coastguard Worker@X = external global i8 4*9880d681SAndroid Build Coastguard Worker@Y = external global i8 5*9880d681SAndroid Build Coastguard Worker@Z = external global i8 6*9880d681SAndroid Build Coastguard Worker 7*9880d681SAndroid Build Coastguard Worker@A = global i1 add (i1 icmp ult (i8* @X, i8* @Y), i1 icmp ult (i8* @X, i8* @Z)) 8*9880d681SAndroid Build Coastguard Worker; CHECK: @A = global i1 xor (i1 icmp ult (i8* @X, i8* @Y), i1 icmp ult (i8* @X, i8* @Z)) 9*9880d681SAndroid Build Coastguard Worker@B = global i1 sub (i1 icmp ult (i8* @X, i8* @Y), i1 icmp ult (i8* @X, i8* @Z)), align 2 10*9880d681SAndroid Build Coastguard Worker; CHECK: @B = global i1 xor (i1 icmp ult (i8* @X, i8* @Y), i1 icmp ult (i8* @X, i8* @Z)) 11*9880d681SAndroid Build Coastguard Worker@C = global i1 mul (i1 icmp ult (i8* @X, i8* @Y), i1 icmp ult (i8* @X, i8* @Z)) 12*9880d681SAndroid Build Coastguard Worker; CHECK: @C = global i1 and (i1 icmp ult (i8* @X, i8* @Y), i1 icmp ult (i8* @X, i8* @Z)) 13*9880d681SAndroid Build Coastguard Worker 14*9880d681SAndroid Build Coastguard Worker@D = global i1 sdiv (i1 icmp ult (i8* @X, i8* @Y), i1 icmp ult (i8* @X, i8* @Z)) 15*9880d681SAndroid Build Coastguard Worker; CHECK: @D = global i1 icmp ult (i8* @X, i8* @Y) 16*9880d681SAndroid Build Coastguard Worker@E = global i1 udiv (i1 icmp ult (i8* @X, i8* @Y), i1 icmp ult (i8* @X, i8* @Z)) 17*9880d681SAndroid Build Coastguard Worker; CHECK: @E = global i1 icmp ult (i8* @X, i8* @Y) 18*9880d681SAndroid Build Coastguard Worker@F = global i1 srem (i1 icmp ult (i8* @X, i8* @Y), i1 icmp ult (i8* @X, i8* @Z)) 19*9880d681SAndroid Build Coastguard Worker; CHECK: @F = global i1 false 20*9880d681SAndroid Build Coastguard Worker@G = global i1 urem (i1 icmp ult (i8* @X, i8* @Y), i1 icmp ult (i8* @X, i8* @Z)) 21*9880d681SAndroid Build Coastguard Worker; CHECK: @G = global i1 false 22*9880d681SAndroid Build Coastguard Worker 23*9880d681SAndroid Build Coastguard Worker@H = global i1 icmp ule (i32* bitcast (i8* @X to i32*), i32* bitcast (i8* @Y to i32*)) 24*9880d681SAndroid Build Coastguard Worker; CHECK: @H = global i1 icmp ule (i8* @X, i8* @Y) 25*9880d681SAndroid Build Coastguard Worker 26*9880d681SAndroid Build Coastguard Worker@I = global i1 xor (i1 icmp ult (i8* @X, i8* @Y), i1 false) 27*9880d681SAndroid Build Coastguard Worker; CHECK: @I = global i1 icmp ult (i8* @X, i8* @Y) 28*9880d681SAndroid Build Coastguard Worker@J = global i1 xor (i1 icmp ult (i8* @X, i8* @Y), i1 true) 29*9880d681SAndroid Build Coastguard Worker; CHECK: @J = global i1 icmp uge (i8* @X, i8* @Y) 30*9880d681SAndroid Build Coastguard Worker 31*9880d681SAndroid Build Coastguard Worker@K = global i1 icmp eq (i1 icmp ult (i8* @X, i8* @Y), i1 false) 32*9880d681SAndroid Build Coastguard Worker; CHECK: @K = global i1 icmp uge (i8* @X, i8* @Y) 33*9880d681SAndroid Build Coastguard Worker@L = global i1 icmp eq (i1 icmp ult (i8* @X, i8* @Y), i1 true) 34*9880d681SAndroid Build Coastguard Worker; CHECK: @L = global i1 icmp ult (i8* @X, i8* @Y) 35*9880d681SAndroid Build Coastguard Worker@M = global i1 icmp ne (i1 icmp ult (i8* @X, i8* @Y), i1 true) 36*9880d681SAndroid Build Coastguard Worker; CHECK: @M = global i1 icmp uge (i8* @X, i8* @Y) 37*9880d681SAndroid Build Coastguard Worker@N = global i1 icmp ne (i1 icmp ult (i8* @X, i8* @Y), i1 false) 38*9880d681SAndroid Build Coastguard Worker; CHECK: @N = global i1 icmp ult (i8* @X, i8* @Y) 39*9880d681SAndroid Build Coastguard Worker 40*9880d681SAndroid Build Coastguard Worker@O = global i1 icmp eq (i32 zext (i1 icmp ult (i8* @X, i8* @Y) to i32), i32 0) 41*9880d681SAndroid Build Coastguard Worker; CHECK: @O = global i1 icmp uge (i8* @X, i8* @Y) 42*9880d681SAndroid Build Coastguard Worker 43*9880d681SAndroid Build Coastguard Worker 44*9880d681SAndroid Build Coastguard Worker 45*9880d681SAndroid Build Coastguard Worker; PR5176 46*9880d681SAndroid Build Coastguard Worker 47*9880d681SAndroid Build Coastguard Worker; CHECK: @T1 = global i1 true 48*9880d681SAndroid Build Coastguard Worker@T1 = global i1 icmp eq (i64 and (i64 trunc (i256 lshr (i256 or (i256 and (i256 and (i256 shl (i256 zext (i64 ptrtoint (i1* @B to i64) to i256), i256 64), i256 -6277101735386680763495507056286727952638980837032266301441), i256 6277101735386680763835789423207666416102355444464034512895), i256 shl (i256 zext (i64 ptrtoint (i1* @A to i64) to i256), i256 192)), i256 64) to i64), i64 1), i64 0) 49*9880d681SAndroid Build Coastguard Worker 50*9880d681SAndroid Build Coastguard Worker; CHECK: @T2 = global i1* @B 51*9880d681SAndroid Build Coastguard Worker@T2 = global i1* inttoptr (i64 add (i64 trunc (i256 lshr (i256 or (i256 and (i256 and (i256 shl (i256 zext (i64 ptrtoint (i1* @A to i64) to i256), i256 64), i256 -6277101735386680763495507056286727952638980837032266301441), i256 6277101735386680763835789423207666416102355444464034512895), i256 shl (i256 zext (i64 ptrtoint (i1* @B to i64) to i256), i256 192)), i256 192) to i64), i64 trunc (i256 lshr (i256 or (i256 and (i256 and (i256 shl (i256 zext (i64 ptrtoint (i1* @A to i64) to i256), i256 64), i256 -6277101735386680763495507056286727952638980837032266301441), i256 6277101735386680763835789423207666416102355444464034512895), i256 shl (i256 zext (i64 ptrtoint (i1* @B to i64) to i256), i256 192)), i256 128) to i64)) to i1*) 52*9880d681SAndroid Build Coastguard Worker 53*9880d681SAndroid Build Coastguard Worker; CHECK: @T3 = global i64 add (i64 ptrtoint (i1* @B to i64), i64 -1) 54*9880d681SAndroid Build Coastguard Worker@T3 = global i64 add (i64 trunc (i256 lshr (i256 or (i256 and (i256 and (i256 shl (i256 zext (i64 ptrtoint (i1* @B to i64) to i256), i256 64), i256 -6277101735386680763495507056286727952638980837032266301441), i256 6277101735386680763835789423207666416102355444464034512895), i256 shl (i256 zext (i64 ptrtoint (i1* @A to i64) to i256), i256 192)), i256 64) to i64), i64 -1) 55*9880d681SAndroid Build Coastguard Worker 56*9880d681SAndroid Build Coastguard Worker; CHECK: @T4 = global i1* @B 57*9880d681SAndroid Build Coastguard Worker@T4 = global i1* inttoptr (i64 trunc (i256 lshr (i256 or (i256 and (i256 and (i256 shl (i256 zext (i64 ptrtoint (i1* @B to i64) to i256), i256 64), i256 -6277101735386680763495507056286727952638980837032266301441), i256 6277101735386680763835789423207666416102355444464034512895), i256 shl (i256 zext (i64 ptrtoint (i1* @A to i64) to i256), i256 192)), i256 64) to i64) to i1*) 58*9880d681SAndroid Build Coastguard Worker 59*9880d681SAndroid Build Coastguard Worker; CHECK: @T5 = global i1* @A 60*9880d681SAndroid Build Coastguard Worker@T5 = global i1* inttoptr (i64 add (i64 trunc (i256 lshr (i256 or (i256 and (i256 and (i256 shl (i256 zext (i64 ptrtoint (i1* @B to i64) to i256), i256 64), i256 -6277101735386680763495507056286727952638980837032266301441), i256 6277101735386680763835789423207666416102355444464034512895), i256 shl (i256 zext (i64 ptrtoint (i1* @A to i64) to i256), i256 192)), i256 192) to i64), i64 trunc (i256 lshr (i256 or (i256 and (i256 and (i256 shl (i256 zext (i64 ptrtoint (i1* @B to i64) to i256), i256 64), i256 -6277101735386680763495507056286727952638980837032266301441), i256 6277101735386680763835789423207666416102355444464034512895), i256 shl (i256 zext (i64 ptrtoint (i1* @A to i64) to i256), i256 192)), i256 128) to i64)) to i1*) 61*9880d681SAndroid Build Coastguard Worker 62*9880d681SAndroid Build Coastguard Worker 63*9880d681SAndroid Build Coastguard Worker 64*9880d681SAndroid Build Coastguard Worker; PR6096 65*9880d681SAndroid Build Coastguard Worker 66*9880d681SAndroid Build Coastguard Worker; No check line. This used to crash llvm-as. 67*9880d681SAndroid Build Coastguard Worker@T6 = global <2 x i1> fcmp ole (<2 x float> fdiv (<2 x float> undef, <2 x float> <float 1.000000e+00, float 1.000000e+00>), <2 x float> zeroinitializer) 68*9880d681SAndroid Build Coastguard Worker 69*9880d681SAndroid Build Coastguard Worker 70*9880d681SAndroid Build Coastguard Worker; PR9011 71*9880d681SAndroid Build Coastguard Worker 72*9880d681SAndroid Build Coastguard Worker@pr9011_1 = constant <4 x i32> zext (<4 x i8> zeroinitializer to <4 x i32>) 73*9880d681SAndroid Build Coastguard Worker; CHECK: pr9011_1 = constant <4 x i32> zeroinitializer 74*9880d681SAndroid Build Coastguard Worker@pr9011_2 = constant <4 x i32> sext (<4 x i8> zeroinitializer to <4 x i32>) 75*9880d681SAndroid Build Coastguard Worker; CHECK: pr9011_2 = constant <4 x i32> zeroinitializer 76*9880d681SAndroid Build Coastguard Worker@pr9011_3 = constant <4 x i32> bitcast (<16 x i8> zeroinitializer to <4 x i32>) 77*9880d681SAndroid Build Coastguard Worker; CHECK: pr9011_3 = constant <4 x i32> zeroinitializer 78*9880d681SAndroid Build Coastguard Worker@pr9011_4 = constant <4 x float> uitofp (<4 x i8> zeroinitializer to <4 x float>) 79*9880d681SAndroid Build Coastguard Worker; CHECK: pr9011_4 = constant <4 x float> zeroinitializer 80*9880d681SAndroid Build Coastguard Worker@pr9011_5 = constant <4 x float> sitofp (<4 x i8> zeroinitializer to <4 x float>) 81*9880d681SAndroid Build Coastguard Worker; CHECK: pr9011_5 = constant <4 x float> zeroinitializer 82*9880d681SAndroid Build Coastguard Worker@pr9011_6 = constant <4 x i32> fptosi (<4 x float> zeroinitializer to <4 x i32>) 83*9880d681SAndroid Build Coastguard Worker; CHECK: pr9011_6 = constant <4 x i32> zeroinitializer 84*9880d681SAndroid Build Coastguard Worker@pr9011_7 = constant <4 x i32> fptoui (<4 x float> zeroinitializer to <4 x i32>) 85*9880d681SAndroid Build Coastguard Worker; CHECK: pr9011_7 = constant <4 x i32> zeroinitializer 86*9880d681SAndroid Build Coastguard Worker@pr9011_8 = constant <4 x float> fptrunc (<4 x double> zeroinitializer to <4 x float>) 87*9880d681SAndroid Build Coastguard Worker; CHECK: pr9011_8 = constant <4 x float> zeroinitializer 88*9880d681SAndroid Build Coastguard Worker@pr9011_9 = constant <4 x double> fpext (<4 x float> zeroinitializer to <4 x double>) 89*9880d681SAndroid Build Coastguard Worker; CHECK: pr9011_9 = constant <4 x double> zeroinitializer 90*9880d681SAndroid Build Coastguard Worker 91*9880d681SAndroid Build Coastguard Worker@pr9011_10 = constant <4 x double> bitcast (i256 0 to <4 x double>) 92*9880d681SAndroid Build Coastguard Worker; CHECK: pr9011_10 = constant <4 x double> zeroinitializer 93*9880d681SAndroid Build Coastguard Worker@pr9011_11 = constant <4 x float> bitcast (i128 0 to <4 x float>) 94*9880d681SAndroid Build Coastguard Worker; CHECK: pr9011_11 = constant <4 x float> zeroinitializer 95*9880d681SAndroid Build Coastguard Worker@pr9011_12 = constant <4 x i32> bitcast (i128 0 to <4 x i32>) 96*9880d681SAndroid Build Coastguard Worker; CHECK: pr9011_12 = constant <4 x i32> zeroinitializer 97*9880d681SAndroid Build Coastguard Worker@pr9011_13 = constant i256 bitcast (<4 x double> zeroinitializer to i256) 98*9880d681SAndroid Build Coastguard Worker; CHECK: pr9011_13 = constant i256 0 99*9880d681SAndroid Build Coastguard Worker@pr9011_14 = constant i128 bitcast (<4 x float> zeroinitializer to i128) 100*9880d681SAndroid Build Coastguard Worker; CHECK: pr9011_14 = constant i128 0 101*9880d681SAndroid Build Coastguard Worker@pr9011_15 = constant i128 bitcast (<4 x i32> zeroinitializer to i128) 102*9880d681SAndroid Build Coastguard Worker; CHECK: pr9011_15 = constant i128 0 103*9880d681SAndroid Build Coastguard Worker 104*9880d681SAndroid Build Coastguard Worker@select = internal constant 105*9880d681SAndroid Build Coastguard Worker i32 select (i1 icmp ult (i32 ptrtoint (i8* @X to i32), 106*9880d681SAndroid Build Coastguard Worker i32 ptrtoint (i8* @Y to i32)), 107*9880d681SAndroid Build Coastguard Worker i32 select (i1 icmp ult (i32 ptrtoint (i8* @X to i32), 108*9880d681SAndroid Build Coastguard Worker i32 ptrtoint (i8* @Y to i32)), 109*9880d681SAndroid Build Coastguard Worker i32 10, i32 20), 110*9880d681SAndroid Build Coastguard Worker i32 30) 111*9880d681SAndroid Build Coastguard Worker; CHECK: select = internal constant i32 select {{.*}} i32 10, i32 30 112