File: test_malloc_less_than_bound.c

package info (click to toggle)
cbmc 6.6.0-4
  • links: PTS
  • area: main
  • in suites: forky, sid, trixie
  • size: 153,852 kB
  • sloc: cpp: 386,459; ansic: 114,466; java: 28,405; python: 6,003; yacc: 4,552; makefile: 4,041; lex: 2,487; xml: 2,388; sh: 2,050; perl: 557; pascal: 184; javascript: 163; ada: 36
file content (21 lines) | stat: -rw-r--r-- 543 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
#include <assert.h>
#include <stdlib.h>

// Similar to our test in `test.c` of this folder, with the difference being
// that the malloc size is less than the bound checked, which implies that the
// check for the pointer being outside the object bounds is expected to fail.

// clang-format off
int main() {
  char *a = malloc(4);

  assert(*a == *a);

  // BUG: no errors even with `--pointer-check` enabled -- now fixed.
  assert(
    __CPROVER_forall {
      int i ; (0 <= i && i < 10) ==> *(a+i) == *(a+i)
    }
  );
}
// clang-format on