1*673dc3d4SNico Weber // RUN: %clangxx_asan -O %s -o %t
2*673dc3d4SNico Weber // RUN: not %run %t crash 2>&1 | FileCheck --check-prefix=CHECK-CRASH %s
3*673dc3d4SNico Weber // RUN: not %run %t bad-bounds 2>&1 | FileCheck --check-prefix=CHECK-BAD-BOUNDS %s
4*673dc3d4SNico Weber // RUN: not %run %t bad-alignment 2>&1 | FileCheck --check-prefix=CHECK-BAD-ALIGNMENT %s
5*673dc3d4SNico Weber // RUN: %env_asan_opts=detect_container_overflow=0 %run %t crash
6*673dc3d4SNico Weber //
7*673dc3d4SNico Weber // Test crash due to __sanitizer_annotate_contiguous_container.
8*673dc3d4SNico Weber
9*673dc3d4SNico Weber #include <assert.h>
10*673dc3d4SNico Weber #include <string.h>
11*673dc3d4SNico Weber
12*673dc3d4SNico Weber extern "C" {
13*673dc3d4SNico Weber void __sanitizer_annotate_contiguous_container(const void *beg, const void *end,
14*673dc3d4SNico Weber const void *old_mid,
15*673dc3d4SNico Weber const void *new_mid);
16*673dc3d4SNico Weber } // extern "C"
17*673dc3d4SNico Weber
18*673dc3d4SNico Weber static volatile int one = 1;
19*673dc3d4SNico Weber
TestCrash()20*673dc3d4SNico Weber int TestCrash() {
21*673dc3d4SNico Weber long t[100];
22*673dc3d4SNico Weber t[60] = 0;
23*673dc3d4SNico Weber __sanitizer_annotate_contiguous_container(&t[0], &t[0] + 100, &t[0] + 100,
24*673dc3d4SNico Weber &t[0] + 50);
25*673dc3d4SNico Weber // CHECK-CRASH: AddressSanitizer: container-overflow
26*673dc3d4SNico Weber // CHECK-CRASH: if you don't care about these errors you may set ASAN_OPTIONS=detect_container_overflow=0
27*673dc3d4SNico Weber return (int)t[60 * one]; // Touches the poisoned memory.
28*673dc3d4SNico Weber }
29*673dc3d4SNico Weber
BadBounds()30*673dc3d4SNico Weber void BadBounds() {
31*673dc3d4SNico Weber long t[100];
32*673dc3d4SNico Weber // CHECK-BAD-BOUNDS: ERROR: AddressSanitizer: bad parameters to __sanitizer_annotate_contiguous_container
33*673dc3d4SNico Weber __sanitizer_annotate_contiguous_container(&t[0], &t[0] + 100, &t[0] + 101,
34*673dc3d4SNico Weber &t[0] + 50);
35*673dc3d4SNico Weber }
36*673dc3d4SNico Weber
BadAlignment()37*673dc3d4SNico Weber void BadAlignment() {
38*673dc3d4SNico Weber int t[100];
39*673dc3d4SNico Weber // CHECK-BAD-ALIGNMENT: ERROR: AddressSanitizer: bad parameters to __sanitizer_annotate_contiguous_container
40*673dc3d4SNico Weber // CHECK-BAD-ALIGNMENT: ERROR: beg is not aligned by {{[0-9]+}}
41*673dc3d4SNico Weber __sanitizer_annotate_contiguous_container(&t[1], &t[0] + 100, &t[1] + 10,
42*673dc3d4SNico Weber &t[0] + 50);
43*673dc3d4SNico Weber }
44*673dc3d4SNico Weber
main(int argc,char ** argv)45*673dc3d4SNico Weber int main(int argc, char **argv) {
46*673dc3d4SNico Weber assert(argc == 2);
47*673dc3d4SNico Weber if (!strcmp(argv[1], "crash"))
48*673dc3d4SNico Weber return TestCrash();
49*673dc3d4SNico Weber else if (!strcmp(argv[1], "bad-bounds"))
50*673dc3d4SNico Weber BadBounds();
51*673dc3d4SNico Weber else if (!strcmp(argv[1], "bad-alignment"))
52*673dc3d4SNico Weber BadAlignment();
53*673dc3d4SNico Weber }
54