null-deref-ps.c revision 584def7364f51e35bfcaf5c3c64673096533adda
1// RUN: clang -checker-simple -verify %s
2
3#include<stdint.h>
4
5void f1(int *p) {
6  if (p) *p = 1;
7  else *p = 0; // expected-warning{{ereference}}
8}
9
10struct foo_struct {
11  int x;
12};
13
14int f2(struct foo_struct* p) {
15
16  if (p)
17    p->x = 1;
18
19  return p->x++; // expected-warning{{Dereference of null pointer.}}
20}
21
22int f3(char* x) {
23
24  int i = 2;
25
26  if (x)
27    return x[i - 1];
28
29  return x[i+1]; // expected-warning{{Dereference of null pointer.}}
30}
31
32int f3_b(char* x) {
33
34  int i = 2;
35
36  if (x)
37    return x[i - 1];
38
39  return x[i+1]++; // expected-warning{{Dereference of null pointer.}}
40}
41
42int f4(int *p) {
43
44  uintptr_t x = p;
45
46  if (x)
47    return 1;
48
49  int *q = (int*) x;
50  return *q; // expected-warning{{Dereference of null pointer.}}
51}
52
53int f5() {
54
55  char *s = "hello world";
56  return s[0]; // no-warning
57}
58
59int bar(int* p) __attribute__((nonnull));
60
61int f6(int *p) {
62  return !p ? bar(p) : *p; // expected-warning {{Null pointer passed as an argument to a 'nonnull' parameter}}
63}
64
65
66