File: invalid-ptr-checker.c

package info (click to toggle)
llvm-toolchain-19 1%3A19.1.7-3
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 1,998,520 kB
  • sloc: cpp: 6,951,680; ansic: 1,486,157; asm: 913,598; python: 232,024; f90: 80,126; objc: 75,281; lisp: 37,276; pascal: 16,990; sh: 10,009; ml: 5,058; perl: 4,724; awk: 3,523; makefile: 3,167; javascript: 2,504; xml: 892; fortran: 664; cs: 573
file content (63 lines) | stat: -rw-r--r-- 2,443 bytes parent folder | download | duplicates (8)
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
// RUN: %clang_analyze_cc1                                                      \
// RUN:  -analyzer-checker=security.cert.env.InvalidPtr                         \
// RUN:  -analyzer-config security.cert.env.InvalidPtr:InvalidatingGetEnv=false \
// RUN:  -analyzer-output=text -verify -Wno-unused %s
//
// RUN: %clang_analyze_cc1                                                      \
// RUN:  -analyzer-checker=security.cert.env.InvalidPtr                         \
// RUN:  -analyzer-config                                                       \
// RUN: security.cert.env.InvalidPtr:InvalidatingGetEnv=true                    \
// RUN: -analyzer-output=text -verify=expected,pedantic -Wno-unused %s

#include "Inputs/system-header-simulator.h"

char *getenv(const char *name);
int setenv(const char *name, const char *value, int overwrite);
int strcmp(const char *, const char *);

int custom_env_handler(const char **envp);

void getenv_after_getenv(void) {
  char *v1 = getenv("V1");
  // pedantic-note@-1{{previous function call was here}}

  char *v2 = getenv("V2");
  // pedantic-note@-1{{'getenv' call may invalidate the result of the previous 'getenv'}}

  strcmp(v1, v2);
  // pedantic-warning@-1{{use of invalidated pointer 'v1' in a function call}}
  // pedantic-note@-2{{use of invalidated pointer 'v1' in a function call}}
}

void setenv_after_getenv(void) {
  char *v1 = getenv("VAR1");

  setenv("VAR2", "...", 1);
  // expected-note@-1{{'setenv' call may invalidate the environment returned by 'getenv'}}

  strcmp(v1, "");
  // expected-warning@-1{{use of invalidated pointer 'v1' in a function call}}
  // expected-note@-2{{use of invalidated pointer 'v1' in a function call}}
}

int main(int argc, const char *argv[], const char *envp[]) {
  setenv("VAR", "...", 0);
  // expected-note@-1 2 {{'setenv' call may invalidate the environment parameter of 'main'}}

  *envp;
  // expected-warning@-1 2 {{dereferencing an invalid pointer}}
  // expected-note@-2 2 {{dereferencing an invalid pointer}}
}

void multiple_invalidation_no_duplicate_notes(void) {
  char *v1 = getenv("VAR1");

  setenv("VAR2", "...", 1); // no note here

  setenv("VAR3", "...", 1);
  // expected-note@-1{{'setenv' call may invalidate the environment returned by 'getenv'}}

  strcmp(v1, "");
  // expected-warning@-1{{use of invalidated pointer 'v1' in a function call}}
  // expected-note@-2{{use of invalidated pointer 'v1' in a function call}}
}