blob: aa807f44ed3b3dc1965f32d16036e132fd968f83 (
plain)
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
|
// RUN: %clang_asan -Wno-alloc-size -fsanitize-recover=address %s -o %t && %env_asan_opts=halt_on_error=0 %run %t 2>&1 | FileCheck %s
#include <stdio.h>
#include <stdlib.h>
int main(int argc, char **argv) {
{
char *p1 = (char *)calloc(1, 0);
printf("p1 is %p\n", p1);
printf("Content of p1 is: %d\n", *p1);
// CHECK: ERROR: AddressSanitizer: heap-buffer-overflow
// CHECK: {{#0 0x.* in main .*zero_alloc.cpp:}}[[@LINE-2]]
free(p1);
}
{
char *p2 = (char *)calloc(0, 1);
printf("p2 is %p\n", p2);
printf("Content of p2 is: %d\n", *p2);
// CHECK: ERROR: AddressSanitizer: heap-buffer-overflow
// CHECK: {{#0 0x.* in main .*zero_alloc.cpp:}}[[@LINE-2]]
free(p2);
}
{
char *p3 = (char *)malloc(0);
printf("p3 is %p\n", p3);
printf("Content of p2 is: %d\n", *p3);
// CHECK: ERROR: AddressSanitizer: heap-buffer-overflow
// CHECK: {{#0 0x.* in main .*zero_alloc.cpp:}}[[@LINE-2]]
free(p3);
}
return 0;
}
|