[Clang][CodeGen]`vtable`, `typeinfo` et al. are globals
[llvm-project.git] / llvm / test / Instrumentation / AddressSanitizer / ubsan.ll
blob62bbc985cb1b557bae6427753c7f88585b1938ec
1 ; ASan shouldn't instrument code added by UBSan.
3 ; RUN: opt < %s -passes=asan -S | FileCheck %s
4 ; RUN: opt < %s -passes=asan -asan-detect-invalid-pointer-cmp -S \
5 ; RUN:     | FileCheck %s --check-prefixes=NOCMP
7 target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128-n8:16:32:64"
8 target triple = "x86_64-unknown-linux-gnu"
10 %struct.A = type { ptr }
11 declare void @__ubsan_handle_dynamic_type_cache_miss(ptr, i64, i64) uwtable
12 declare void @__ubsan_handle_pointer_overflow(ptr, i64, i64) uwtable
13 @__ubsan_vptr_type_cache = external global [128 x i64]
14 @.src = private unnamed_addr constant [19 x i8] c"tmp/ubsan/vptr.cpp\00", align 1
15 @0 = private unnamed_addr constant { i16, i16, [4 x i8] } { i16 -1, i16 0, [4 x i8] c"'A'\00" }
16 @_ZTI1A = external constant ptr
17 @1 = private unnamed_addr global { { ptr, i32, i32 }, ptr, ptr, i8 } { { ptr, i32, i32 } { ptr @.src, i32 2, i32 18 }, ptr @0, ptr @_ZTI1A, i8 4 }
18 @2 = private unnamed_addr global { { ptr, i32, i32 } } { { ptr, i32, i32 } { ptr @.src, i32 24, i32 25 } }
20 define void @_Z3BarP1A(ptr %a) uwtable sanitize_address {
21 ; CHECK-LABEL: define void @_Z3BarP1A
22 entry:
23   %vtable = load ptr, ptr %a, align 8
24 ; CHECK: __asan_report_load8
25   %0 = load ptr, ptr %vtable, align 8
26 ; CHECK: __asan_report_load8
27   %1 = ptrtoint ptr %vtable to i64
28   %2 = xor i64 %1, -303164226014115343, !nosanitize !0
29   %3 = mul i64 %2, -7070675565921424023, !nosanitize !0
30   %4 = lshr i64 %3, 47, !nosanitize !0
31   %5 = xor i64 %3, %1, !nosanitize !0
32   %6 = xor i64 %5, %4, !nosanitize !0
33   %7 = mul i64 %6, -7070675565921424023, !nosanitize !0
34   %8 = lshr i64 %7, 47, !nosanitize !0
35   %9 = xor i64 %8, %7, !nosanitize !0
36   %10 = mul i64 %9, -7070675565921424023, !nosanitize !0
37   %11 = and i64 %10, 127, !nosanitize !0
38   %12 = getelementptr inbounds [128 x i64], ptr @__ubsan_vptr_type_cache, i64 0, i64 %11, !nosanitize !0
39 ; CHECK-NOT: __asan_report_load8
40   %13 = load i64, ptr %12, align 8, !nosanitize !0
41   %14 = icmp eq i64 %13, %10, !nosanitize !0
42   br i1 %14, label %cont, label %handler.dynamic_type_cache_miss, !nosanitize !0
44 handler.dynamic_type_cache_miss:                  ; preds = %entry
45   %15 = ptrtoint ptr %a to i64, !nosanitize !0
46   tail call void @__ubsan_handle_dynamic_type_cache_miss(ptr @1, i64 %15, i64 %10) #2, !nosanitize !0
47   br label %cont, !nosanitize !0
49 cont:                                             ; preds = %handler.dynamic_type_cache_miss, %entry
50   tail call void %0(ptr %a)
51 ; CHECK: ret void
52   ret void
55 define void @_Z3foov() uwtable sanitize_address {
56 ; NOCMP-LABEL: define void @_Z3foov
57 entry:
58   %bar = alloca [10 x i8], align 1
59   %arrayidx = getelementptr inbounds [10 x i8], ptr %bar, i64 0, i64 4
60   %0 = ptrtoint ptr %bar to i64, !nosanitize !0
61 ; NOCMP-NOT: call void @__sanitizer_ptr_cmp
62   %1 = icmp ult ptr %bar, inttoptr (i64 -4 to ptr), !nosanitize !0
63   br i1 %1, label %cont, label %handler.pointer_overflow, !nosanitize !0
65 handler.pointer_overflow:                         ; preds = %entry
66   %2 = add i64 %0, 4, !nosanitize !0
67   call void @__ubsan_handle_pointer_overflow(ptr @2, i64 %0, i64 %2), !nosanitize !0
68   br label %cont, !nosanitize !0
70 cont:                                             ; preds = %handler.pointer_overflow, %entry
71   store i8 0, ptr %arrayidx, align 1
72 ; NOCMP: ret void
73   ret void
76 !0 = !{}