File: test_shadow.c

package info (click to toggle)
swiftlang 6.0.3-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 2,519,992 kB
  • sloc: cpp: 9,107,863; ansic: 2,040,022; asm: 1,135,751; python: 296,500; objc: 82,456; f90: 60,502; lisp: 34,951; pascal: 19,946; sh: 18,133; perl: 7,482; ml: 4,937; javascript: 4,117; makefile: 3,840; awk: 3,535; xml: 914; fortran: 619; cs: 573; ruby: 573
file content (41 lines) | stat: -rw-r--r-- 1,217 bytes parent folder | download | duplicates (17)
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
// RUN: %clang_hwasan %s -o %t && %run %t

#include <assert.h>
#include <sanitizer/hwasan_interface.h>
#include <stdio.h>
#include <stdlib.h>

int main() {
  __hwasan_enable_allocator_tagging();
  for (int sz = 0; sz < 64; ++sz) {
    fprintf(stderr, "sz: %d\n", sz);
    char *x = (char *)malloc(sz);
    do {
      // Empty range is always OK.
      for (int b = -16; b < sz + 32; ++b)
        assert(__hwasan_test_shadow(x + b, 0) == -1);

      int real_sz = sz ? sz : 1;
      // Unlucky case when we cant distinguish between tag and short granule size.
      if (__hwasan_tag_pointer(x, real_sz % 16) == x)
        break;

      // Underflow - the first byte is bad.
      for (int b = -16; b < 0; ++b)
        assert(__hwasan_test_shadow(x + b, real_sz) == 0);

      // Inbound ranges.
      for (int b = 0; b < real_sz; ++b)
        for (int e = b; e <= real_sz; ++e)
          assert(__hwasan_test_shadow(x + b, e - b) == -1);

      // Overflow - the first byte after the buffer is bad.
      for (int b = 0; b <= real_sz; ++b)
        for (int e = real_sz + 1; e <= real_sz + 64; ++e)
          assert(__hwasan_test_shadow(x + b, e - b) == (real_sz - b));

    } while (0);
    free(x);
  }
  return 0;
}