File: fsanitize_fuzzer.d

package info (click to toggle)
ldc 1%3A1.30.0-1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 59,248 kB
  • sloc: cpp: 61,598; ansic: 14,545; sh: 1,014; makefile: 972; asm: 510; objc: 135; exp: 48; python: 12
file content (28 lines) | stat: -rw-r--r-- 845 bytes parent folder | download | duplicates (2)
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
// Test basic Fuzz sanitizer functionality

// RUN: %ldc -c -output-ll -O3 -fsanitize=fuzzer -of=%t.ll %s && FileCheck %s < %t.ll
// RUN: %ldc -c -output-ll -fsanitize=fuzzer,address -of=%t.asan.ll %s && FileCheck %s --check-prefix=CHECK --check-prefix=wASAN < %t.asan.ll

// CHECK-LABEL: define{{.*}} @{{.*}}FuzzMe
bool FuzzMe(const ubyte* data, size_t dataSize)
{
    // CHECK: call {{.*}}_sanitizer_cov_trace_{{(const_)?}}cmp

    return dataSize >= 3 &&
           data[0] == 'F' &&
           data[1] == 'U' &&
           data[2] == 'Z' &&
           data[3] == 'Z'; // :‑<
}

// CHECK-LABEL: define{{.*}} @{{.*}}allocInt
void allocInt() {
    // wASAN: call {{.*}}_asan_stack_malloc
    int[10] a;
}

// CHECK-LABEL: define{{.*}} @{{.*}}foo
void foo(int function() a) {
    // CHECK: call void @__sanitizer_cov_trace_pc_indir
    a();
}