1*9880d681SAndroid Build Coastguard Worker; RUN: opt -S < %s -instcombine | FileCheck %s 2*9880d681SAndroid Build Coastguard Worker 3*9880d681SAndroid Build Coastguard Workertarget datalayout = "e-p1:16:16-p2:32:32-p3:64:64" 4*9880d681SAndroid Build Coastguard Worker 5*9880d681SAndroid Build Coastguard Worker@G1 = global i32 42, align 1 6*9880d681SAndroid Build Coastguard Worker@G2 = global i32 42 7*9880d681SAndroid Build Coastguard Worker@G3 = global [4 x i8] zeroinitializer, align 1 8*9880d681SAndroid Build Coastguard Worker 9*9880d681SAndroid Build Coastguard Worker@A1 = alias i32, bitcast (i8* getelementptr inbounds ([4 x i8], [4 x i8]* @G3, i32 0, i32 2) to i32*) 10*9880d681SAndroid Build Coastguard Worker@A2 = alias i32, inttoptr (i64 and (i64 ptrtoint (i8* getelementptr inbounds ([4 x i8], [4 x i8]* @G3, i32 0, i32 3) to i64), i64 -4) to i32*) 11*9880d681SAndroid Build Coastguard Worker 12*9880d681SAndroid Build Coastguard Workerdefine i64 @f1() { 13*9880d681SAndroid Build Coastguard Worker; This cannot be constant folded because G1 is underaligned. 14*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @f1( 15*9880d681SAndroid Build Coastguard Worker; CHECK: ret i64 and 16*9880d681SAndroid Build Coastguard Worker ret i64 and (i64 ptrtoint (i32* @G1 to i64), i64 1) 17*9880d681SAndroid Build Coastguard Worker} 18*9880d681SAndroid Build Coastguard Worker 19*9880d681SAndroid Build Coastguard Workerdefine i64 @f2() { 20*9880d681SAndroid Build Coastguard Worker; The preferred alignment for G2 allows this one to foled to zero. 21*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @f2( 22*9880d681SAndroid Build Coastguard Worker; CHECK: ret i64 0 23*9880d681SAndroid Build Coastguard Worker ret i64 and (i64 ptrtoint (i32* @G2 to i64), i64 1) 24*9880d681SAndroid Build Coastguard Worker} 25*9880d681SAndroid Build Coastguard Worker 26*9880d681SAndroid Build Coastguard Workerdefine i64 @g1() { 27*9880d681SAndroid Build Coastguard Worker; This cannot be constant folded because A1 aliases G3 which is underalaigned. 28*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @g1( 29*9880d681SAndroid Build Coastguard Worker; CHECK: ret i64 and 30*9880d681SAndroid Build Coastguard Worker ret i64 and (i64 ptrtoint (i32* @A1 to i64), i64 1) 31*9880d681SAndroid Build Coastguard Worker} 32*9880d681SAndroid Build Coastguard Worker 33*9880d681SAndroid Build Coastguard Workerdefine i64 @g2() { 34*9880d681SAndroid Build Coastguard Worker; While A2 also aliases G3 which is underaligned, the math of A2 forces a 35*9880d681SAndroid Build Coastguard Worker; certain alignment allowing this to fold to zero. 36*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @g2( 37*9880d681SAndroid Build Coastguard Worker; CHECK: ret i64 0 38*9880d681SAndroid Build Coastguard Worker ret i64 and (i64 ptrtoint (i32* @A2 to i64), i64 1) 39*9880d681SAndroid Build Coastguard Worker} 40*9880d681SAndroid Build Coastguard Worker 41