[asan] experimental tracing for indirect calls, llvm part.
[oota-llvm.git] / test / Instrumentation / AddressSanitizer / coverage.ll
1 ; RUN: opt < %s -asan -asan-module -asan-coverage=0 -S | FileCheck %s --check-prefix=CHECK0
2 ; RUN: opt < %s -asan -asan-module -asan-coverage=1 -S | FileCheck %s --check-prefix=CHECK1
3 ; RUN: opt < %s -asan -asan-module -asan-coverage=2 -S | FileCheck %s --check-prefix=CHECK2
4 ; RUN: opt < %s -asan -asan-module -asan-coverage=2 -asan-coverage-block-threshold=10 -S | FileCheck %s --check-prefix=CHECK2
5 ; RUN: opt < %s -asan -asan-module -asan-coverage=2 -asan-coverage-block-threshold=1  -S | FileCheck %s --check-prefix=CHECK1
6 ; RUN: opt < %s -asan -asan-module -asan-coverage=3 -asan-coverage-block-threshold=10 -S | FileCheck %s --check-prefix=CHECK3
7 ; RUN: opt < %s -asan -asan-module -asan-coverage=4 -S | FileCheck %s --check-prefix=CHECK4
8
9 ; RUN: opt < %s -asan -asan-module -asan-coverage=0 -asan-globals=0 -S | \
10 ; RUN:     FileCheck %s --check-prefix=CHECK0
11 ; RUN: opt < %s -asan -asan-module -asan-coverage=1 -asan-globals=0 -S | \
12 ; RUN:     FileCheck %s --check-prefix=CHECK1
13 ; RUN: opt < %s -asan -asan-module -asan-coverage=2 -asan-globals=0 -S | \
14 ; RUN:     FileCheck %s --check-prefix=CHECK2
15 ; RUN: opt < %s -asan -asan-module -asan-coverage=2 -asan-coverage-block-threshold=10 \
16 ; RUN:     -asan-globals=0 -S | FileCheck %s --check-prefix=CHECK2
17 ; RUN: opt < %s -asan -asan-module -asan-coverage=2 -asan-coverage-block-threshold=1 \
18 ; RUN:     -asan-globals=0 -S | FileCheck %s --check-prefix=CHECK1
19
20 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"
21 target triple = "x86_64-unknown-linux-gnu"
22 define void @foo(i32* %a) sanitize_address {
23 entry:
24   %tobool = icmp eq i32* %a, null
25   br i1 %tobool, label %if.end, label %if.then
26
27   if.then:                                          ; preds = %entry
28   store i32 0, i32* %a, align 4
29   br label %if.end
30
31   if.end:                                           ; preds = %entry, %if.then
32   ret void
33 }
34
35 ; CHECK0-NOT: call void @__sanitizer_cov(
36 ; CHECK0-NOT: call void @__sanitizer_cov_module_init(
37
38 ; CHECK1-LABEL: define void @foo
39 ; CHECK1: %0 = load atomic i8* @__asan_gen_cov_foo monotonic, align 1
40 ; CHECK1: %1 = icmp eq i8 0, %0
41 ; CHECK1: br i1 %1, label %2, label %3
42 ; CHECK1: call void @__sanitizer_cov
43 ; CHECK1-NOT: call void @__sanitizer_cov
44 ; CHECK1: store atomic i8 1, i8* @__asan_gen_cov_foo monotonic, align 1
45
46 ; CHECK1-LABEL: define internal void @asan.module_ctor
47 ; CHECK1-NOT: ret
48 ; CHECK1: call void @__sanitizer_cov_module_init(i64 2)
49 ; CHECK1: ret
50
51
52 ; CHECK2-LABEL: define void @foo
53 ; CHECK2: call void @__sanitizer_cov
54 ; CHECK2: call void @__sanitizer_cov
55 ; CHECK2: call void @__sanitizer_cov
56 ; CHECK2-NOT: call void @__sanitizer_cov
57 ; CHECK2: ret void
58
59 ; CHECK2-LABEL: define internal void @asan.module_ctor
60 ; CHECK2-NOT: ret
61 ; CHECK2: call void @__sanitizer_cov_module_init(i64 4)
62 ; CHECK2: ret
63
64 ; CHECK3-LABEL: define void @foo
65 ; CHECK3: call void @__sanitizer_cov
66 ; CHECK3: call void @__sanitizer_cov
67 ; CHECK3: call void @__sanitizer_cov
68 ; CHECK3: call void @__sanitizer_cov
69 ; CHECK3-NOT: call void @__sanitizer_cov
70 ; CHECK3: ret void
71
72
73 %struct.StructWithVptr = type { i32 (...)** }
74
75 define void @CallViaVptr(%struct.StructWithVptr* %foo) uwtable sanitize_address {
76 entry:
77   %0 = bitcast %struct.StructWithVptr* %foo to void (%struct.StructWithVptr*)***
78   %vtable = load void (%struct.StructWithVptr*)*** %0, align 8
79   %1 = load void (%struct.StructWithVptr*)** %vtable, align 8
80   tail call void %1(%struct.StructWithVptr* %foo)
81   ret void
82 }
83
84 ; CHECK4-LABEL: define void @CallViaVptr
85 ; CHECK4: call void @__sanitizer_cov_indir_call16
86 ; CHECK4: ret void