[rtsan] Add fork/execve interceptors (#117198)
[llvm-project.git] / llvm / test / Transforms / WholeProgramDevirt / virtual-const-prop-multiple-assumes.ll
blobbd900217ba58808b2a70eb52e544cfe056c6d24e
1 ; RUN: opt -S -passes=wholeprogramdevirt -whole-program-visibility %s | FileCheck %s
3 target datalayout = "e-p:64:64"
4 target triple = "x86_64-unknown-linux-gnu"
6 @vt2 = constant [3 x ptr] [
7 ptr @vf1i1,
8 ptr @vf0i1,
9 ptr @vf2i32
10 ], !type !0
12 define i1 @vf0i1(ptr %this) readnone {
13   ret i1 0
16 define i1 @vf1i1(ptr %this) readnone {
17   ret i1 1
20 define i32 @vf2i32(ptr %this) readnone {
21   ret i32 2
24 ; CHECK: define i1 @call1(
25 define i1 @call1(ptr %obj) {
26   %vtable = load ptr, ptr %obj
27   %p = call i1 @llvm.type.test(ptr %vtable, metadata !"typeid")
28   call void @llvm.assume(i1 %p)
29   %p2 = call i1 @llvm.type.test(ptr %vtable, metadata !"typeid")
30   call void @llvm.assume(i1 %p2)
31   %fptr = load ptr, ptr %vtable
32   %result = call i1 %fptr(ptr %obj)
33   ret i1 %result
36 declare i1 @llvm.type.test(ptr, metadata)
37 declare void @llvm.assume(i1)
39 !0 = !{i32 0, !"typeid"}