llvm-project/llvm/test/Transforms/EarlyCSE/getmatchingvalue-crash.ll

145 lines
4.6 KiB
LLVM

; RUN: opt -basic-aa -aa -memoryssa -early-cse-memssa -verify -S < %s | FileCheck %s
; Check that this doesn't crash. The crash only happens with expensive checks,
; but there doesn't seem to be a REQUIRES for that.
; CHECK: invoke void @f1
target datalayout = "e-m:e-p270:32:32-p271:32:32-p272:64:64-i64:64-f80:128-n8:16:32:64-S128"
target triple = "x86_64-unknown-linux-gnu"
%s.0 = type { %s.1 }
%s.1 = type { %s.2* }
%s.2 = type { %s.3, %s.6, %s.16 }
%s.3 = type { %s.4, %s.5 }
%s.4 = type { i32 (...)**, i64 }
%s.5 = type { i32 (...)** }
%s.6 = type <{ %s.7, %s.10, i8*, i32, [4 x i8] }>
%s.7 = type { i32 (...)**, %s.8, i8*, i8*, i8*, i8*, i8*, i8* }
%s.8 = type { %s.9* }
%s.9 = type opaque
%s.10 = type { %s.11 }
%s.11 = type { %s.12 }
%s.12 = type { %s.13 }
%s.13 = type { %s.14 }
%s.14 = type { %s.15 }
%s.15 = type { i64, i64, i8* }
%s.16 = type <{ %s.17, %s.18*, i32 }>
%s.17 = type { i32 (...)**, i32, i64, i64, i32, i32, i8*, i8*, void (i32, %s.17*, i32)**, i32*, i64, i64, i64*, i64, i64, i8**, i64, i64 }
%s.18 = type { i32 (...)**, %s.16 }
%s.19 = type { i8, %s.20 }
%s.20 = type { %s.21 }
%s.21 = type { %s.22*, %s.24, %s.26 }
%s.22 = type { %s.23* }
%s.23 = type <{ %s.22, %s.23*, %s.22*, i8, [7 x i8] }>
%s.24 = type { %s.25 }
%s.25 = type { %s.22 }
%s.26 = type { %s.27 }
%s.27 = type { i64 }
@g0 = external constant [1 x i8], align 1
declare i32 @f0(...)
; Function Attrs: uwtable
declare void @f1(%s.0* nocapture) align 2
declare void @f2(%s.10*, %s.2*)
declare void @f3(%s.10*, i8*, i32)
define i8* @f4(%s.19* %a0, i8* %a1, i32 %a2, i8* %a3) align 2 personality i8* bitcast (i32 (...)* @f0 to i8*) {
b0:
%v0 = alloca %s.0, align 8
br label %b1
b1: ; preds = %b0
invoke void @f5(%s.10* nonnull sret(%s.10) align 8 undef, i8* nonnull undef)
to label %b6 unwind label %b3
b2: ; preds = %b2
%v1 = invoke nonnull align 8 dereferenceable(24) %s.10* @f6(%s.10* undef, i64 undef, i64 1)
to label %b2 unwind label %b4
b3: ; preds = %b1
%v2 = landingpad { i8*, i32 }
cleanup
br label %b5
b4: ; preds = %b2
%v3 = landingpad { i8*, i32 }
cleanup
br label %b5
b5: ; preds = %b4, %b3
resume { i8*, i32 } undef
b6: ; preds = %b1
invoke void @f1(%s.0* nonnull %v0)
to label %b8 unwind label %b7
b7: ; preds = %b6
%v4 = landingpad { i8*, i32 }
cleanup
br label %b20
b8: ; preds = %b6
invoke void @f2(%s.10* sret(%s.10) align 8 undef, %s.2* undef)
to label %b10 unwind label %b14
b9: ; No predecessors!
br label %b16
b10: ; preds = %b8
%v6 = invoke i32 @f7(%s.10* nonnull undef, i64 0, i64 -1, i8* getelementptr inbounds ([1 x i8], [1 x i8]* @g0, i64 0, i64 0), i64 undef)
to label %b12 unwind label %b11
b11: ; preds = %b10
%v7 = landingpad { i8*, i32 }
catch i8* null
unreachable
b12: ; preds = %b10
invoke void @f3(%s.10* nonnull sret(%s.10) align 8 undef, i8* %a1, i32 %a2)
to label %b13 unwind label %b15
b13: ; preds = %b12
unreachable
b14: ; preds = %b8
%v8 = landingpad { i8*, i32 }
cleanup
br label %b16
b15: ; preds = %b12
%v9 = landingpad { i8*, i32 }
cleanup
br label %b16
b16: ; preds = %b15, %b14, %b9
%v10 = getelementptr inbounds %s.0, %s.0* %v0, i64 0, i32 0
%v11 = getelementptr inbounds %s.1, %s.1* %v10, i64 0, i32 0
br label %b17
b17: ; preds = %b16
%v12 = load %s.2*, %s.2** %v11, align 8
br label %b18
b18: ; preds = %b17
call void undef(%s.2* nonnull %v12)
br label %b19
b19: ; preds = %b18
store %s.2* null, %s.2** %v11, align 8
br label %b20
b20: ; preds = %b19, %b7
resume { i8*, i32 } undef
}
declare hidden void @f5(%s.10*, i8*)
declare %s.10* @f6(%s.10*, i64, i64)
declare i32 @f7(%s.10*, i64, i64, i8*, i64)