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