forked from llvm/llvm-project
-
Notifications
You must be signed in to change notification settings - Fork 338
/
Copy pathcounted-to-counted-assignments-O2.c
73 lines (67 loc) · 2.63 KB
/
counted-to-counted-assignments-O2.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
// NOTE: Assertions have been autogenerated by utils/update_cc_test_checks.py UTC_ARGS: --replace-value-regex "!annotation ![0-9]+" "!tbaa ![0-9]+" "!tbaa\.struct ![0-9]+" "!nosanitize ![0-9]+" "!srcloc ![0-9]+" --prefix-filecheck-ir-name TMP_
// RUN: %clang_cc1 -O2 -fbounds-safety -triple x86_64 -emit-llvm %s -o - | FileCheck %s
#include <ptrcheck.h>
struct S {
int *__counted_by(len) ptr;
int *__counted_by(len - 1) ptr2;
int len;
};
// CHECK-LABEL: @TestPtrFail(
// CHECK-NEXT: entry:
// CHECK-NEXT: tail call void @llvm.ubsantrap(i8 25) #[[ATTR5:[0-9]+]], {{!annotation ![0-9]+}}
// CHECK-NEXT: unreachable, {{!annotation ![0-9]+}}
//
void TestPtrFail() {
int arr[10];
struct S s = {arr, &arr[1], 10};
s.ptr = s.ptr2; // trap! bounds_of(s.ptr2) == 9 < 10
s.ptr2 = arr;
s.len = 10;
}
// CHECK-LABEL: @TestPtrOK(
// CHECK-NEXT: entry:
// CHECK-NEXT: ret void
//
void TestPtrOK() {
int arr[10];
struct S s = {arr, &arr[1], 10};
s.ptr = s.ptr2; // ok: bounds_of(s.ptr2) == 9 <= 9
s.ptr2 += 1; // bounds_of(s.ptr2 + 1) == 8 <= 8
s.len = 9;
}
// CHECK-LABEL: @TestPtrLBFail(
// CHECK-NEXT: entry:
// CHECK-NEXT: [[ARR:%.*]] = alloca [10 x i32], align 16
// CHECK-NEXT: call void @llvm.lifetime.start.p0(i64 40, ptr nonnull [[ARR]]) #[[ATTR6:[0-9]+]]
// CHECK-NEXT: [[ADD_PTR:%.*]] = getelementptr inbounds nuw i8, ptr [[ARR]], i64 40
// CHECK-NEXT: [[BOUND_PTR_ARITH18:%.*]] = getelementptr i8, ptr [[ARR]], i64 -8
// CHECK-NEXT: [[CMP_NOT:%.*]] = icmp ugt ptr [[BOUND_PTR_ARITH18]], [[ADD_PTR]], {{!annotation ![0-9]+}}
// CHECK-NEXT: [[CMP42_NOT:%.*]] = icmp ugt ptr [[ARR]], [[BOUND_PTR_ARITH18]], {{!annotation ![0-9]+}}
// CHECK-NEXT: [[OR_COND:%.*]] = or i1 [[CMP_NOT]], [[CMP42_NOT]], {{!annotation ![0-9]+}}
// CHECK-NEXT: br i1 [[OR_COND]], label [[TRAP:%.*]], label [[CONT57:%.*]], {{!annotation ![0-9]+}}
// CHECK: trap:
// CHECK-NEXT: call void @llvm.ubsantrap(i8 25) #[[ATTR5]], {{!annotation ![0-9]+}}
// CHECK-NEXT: unreachable, {{!annotation ![0-9]+}}
// CHECK: cont56:
// CHECK-NEXT: call void @llvm.lifetime.end.p0(i64 40, ptr nonnull [[ARR]]) #[[ATTR6]]
// CHECK-NEXT: ret void
//
void TestPtrLBFail() {
int arr[10];
struct S s = {arr, &arr[1], 10};
s.ptr = s.ptr - 2; // trap! ptr < lb
s.ptr2 = arr;
s.len = 10;
}
// CHECK-LABEL: @TestPtrUBFail(
// CHECK-NEXT: entry:
// CHECK-NEXT: tail call void @llvm.ubsantrap(i8 25) #[[ATTR5]], {{!annotation ![0-9]+}}
// CHECK-NEXT: unreachable, {{!annotation ![0-9]+}}
//
void TestPtrUBFail() {
int arr[10];
struct S s = {arr, &arr[1], 10};
s.ptr = s.ptr;
s.ptr2 = s.ptr2 + 10; // trap! ptr2 oob
s.len = 1;
}