1*9880d681SAndroid Build Coastguard Worker; RUN: opt < %s -basicaa -gvn -tsan -S | FileCheck %s 2*9880d681SAndroid Build Coastguard Worker; TSAN conflicts with load widening. Make sure the load widening is off with -tsan. 3*9880d681SAndroid Build Coastguard Worker 4*9880d681SAndroid Build Coastguard Worker; 32-bit little endian target. 5*9880d681SAndroid Build Coastguard Workertarget 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:128:128-n8:16:32" 6*9880d681SAndroid Build Coastguard Worker 7*9880d681SAndroid Build Coastguard Worker%struct_of_8_bytes_4_aligned = type { i32, i8, i8, i8, i8} 8*9880d681SAndroid Build Coastguard Worker 9*9880d681SAndroid Build Coastguard Worker@f = global %struct_of_8_bytes_4_aligned zeroinitializer, align 4 10*9880d681SAndroid Build Coastguard Worker 11*9880d681SAndroid Build Coastguard Worker; Accessing bytes 4 and 6, not ok to widen to i32 if sanitize_thread is set. 12*9880d681SAndroid Build Coastguard Worker 13*9880d681SAndroid Build Coastguard Workerdefine i32 @test_widening_bad(i8* %P) nounwind ssp noredzone sanitize_thread { 14*9880d681SAndroid Build Coastguard Workerentry: 15*9880d681SAndroid Build Coastguard Worker %tmp = load i8, i8* getelementptr inbounds (%struct_of_8_bytes_4_aligned, %struct_of_8_bytes_4_aligned* @f, i64 0, i32 1), align 4 16*9880d681SAndroid Build Coastguard Worker %conv = zext i8 %tmp to i32 17*9880d681SAndroid Build Coastguard Worker %tmp1 = load i8, i8* getelementptr inbounds (%struct_of_8_bytes_4_aligned, %struct_of_8_bytes_4_aligned* @f, i64 0, i32 3), align 1 18*9880d681SAndroid Build Coastguard Worker %conv2 = zext i8 %tmp1 to i32 19*9880d681SAndroid Build Coastguard Worker %add = add nsw i32 %conv, %conv2 20*9880d681SAndroid Build Coastguard Worker ret i32 %add 21*9880d681SAndroid Build Coastguard Worker; CHECK: @test_widening_bad 22*9880d681SAndroid Build Coastguard Worker; CHECK: call void @__tsan_read1 23*9880d681SAndroid Build Coastguard Worker; CHECK: call void @__tsan_read1 24*9880d681SAndroid Build Coastguard Worker; CHECK-NOT: call void @__tsan_read4 25*9880d681SAndroid Build Coastguard Worker; CHECK: ret i32 26*9880d681SAndroid Build Coastguard Worker} 27