Coverage Report

Created: 2024-04-25 06:10

/src/uWebSockets/fuzzing/helpers.h
Line
Count
Source
1
#ifndef HELPERS_H
2
#define HELPERS_H
3
4
/* Common helpers for fuzzing */
5
6
#include <functional>
7
#include <string_view>
8
#include <cstring>
9
10
/* We use this to pad the fuzz */
11
2.86k
static inline const uint8_t *makePadded(const uint8_t *data, size_t size) {
12
2.86k
    static int paddedLength = 512 * 1024;
13
2.86k
    static char *padded = new char[128 + paddedLength + 128];
14
15
    /* Increase landing area if required */
16
2.86k
    if (paddedLength < size) {
17
16
        delete [] padded;
18
16
        paddedLength = size;
19
16
        padded = new char [128 + paddedLength + 128];
20
16
    }
21
22
2.86k
    memcpy(padded + 128, data, size);
23
24
2.86k
    return (uint8_t *) padded + 128;
25
2.86k
}
26
27
/* Splits the fuzz data in one or many chunks */
28
2.86k
static inline void makeChunked(const uint8_t *data, size_t size, std::function<void(const uint8_t *data, size_t size)> cb) {
29
    /* First byte determines chunk size; 0 is all that remains, 1-255 is small chunk */
30
94.8k
    for (int i = 0; i < size; ) {
31
91.9k
        unsigned int chunkSize = data[i++];
32
91.9k
        if (!chunkSize) {
33
1.25k
            chunkSize = size - i;
34
90.7k
        } else {
35
90.7k
            chunkSize = std::min<int>(chunkSize, size - i);
36
90.7k
        }
37
38
91.9k
        cb(data + i, chunkSize);
39
91.9k
        i += chunkSize;
40
91.9k
    }
41
2.86k
}
42
43
/* Reads all bytes to trigger invalid reads */
44
50.4k
static inline void readBytes(std::string_view s) {
45
50.4k
    volatile int sum = 0;
46
211k
    for (int i = 0; i < s.size(); i++) {
47
161k
        sum += s[i];
48
161k
    }
49
50.4k
}
50
51
#endif