[sanitizer] Improve FreeBSD ASLR detection
[llvm-project.git] / llvm / test / Transforms / GVN / constexpr-vector-constainsundef-crash-inseltpoison.ll
blob6750b858e03fbdcc00d304ed5eb186f89f6b8571
1 ; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
2 ; RUN: opt -gvn -S %s | FileCheck %s
4 ; Reduced test case from
5 ; https://bugs.chromium.org/p/oss-fuzz/issues/detail?id=24278
7 ; Make sure we do not crash when dealing with a vector constant expression.
8 define <4 x i64*> @test(i64* %ptr) {
9 ; CHECK-LABEL: @test(
10 ; CHECK-NEXT:  entry:
11 ; CHECK-NEXT:    [[L3:%.*]] = load i64, i64* [[PTR:%.*]], align 4
12 ; CHECK-NEXT:    [[I6:%.*]] = insertelement <4 x i64*> getelementptr (i64, i64* null, <4 x i64> <i64 poison, i64 poison, i64 poison, i64 -128>), i64* undef, i64 [[L3]]
13 ; CHECK-NEXT:    ret <4 x i64*> [[I6]]
15 entry:
16   %B9 = sdiv i16 -32768, 256
17   %L3 = load i64, i64* %ptr, align 4
18   %B3 = sub i16 0, %B9
19   %0 = insertelement <4 x i16> poison, i16 %B3, i32 3
20   %1 = sub <4 x i16> zeroinitializer, %0
21   %2 = sext <4 x i16> %1 to <4 x i32>
22   %3 = getelementptr inbounds i64, i64* null, <4 x i32> %2
23   %I6 = insertelement <4 x i64*> %3, i64* undef, i64 %L3
24   ret <4 x i64*> %I6