Coverage Report

Created: 2025-10-10 06:41

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/h5_read_fuzzer.c
Line
Count
Source
1
/* Copyright 2023 Google LLC
2
Licensed under the Apache License, Version 2.0 (the "License");
3
you may not use this file except in compliance with the License.
4
You may obtain a copy of the License at
5
      http://www.apache.org/licenses/LICENSE-2.0
6
Unless required by applicable law or agreed to in writing, software
7
distributed under the License is distributed on an "AS IS" BASIS,
8
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
9
See the License for the specific language governing permissions and
10
limitations under the License.
11
*/
12
13
#include "hdf5.h"
14
15
#include <unistd.h>
16
17
extern int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size)
18
10
{
19
    // Some old logic with regards to skipping first byte. Leaving it here
20
    // to avoid affecting the clusterfuzz-generated corpus.
21
10
    if (size == 0) {
22
0
        return 0;
23
0
    }
24
10
    uint8_t decider = data[0];
25
10
    size -= 1;
26
10
    data += 1;
27
28
10
    char filename[256];
29
10
    sprintf(filename, "/tmp/libfuzzer.%d", getpid());
30
31
10
    FILE *fp = fopen(filename, "wb");
32
10
    if (!fp) {
33
0
        return 0;
34
0
    }
35
10
    fwrite(data, size, 1, fp);
36
10
    fclose(fp);
37
38
10
    hid_t fuzz_h5_id = H5Fopen(filename, H5F_ACC_RDWR, H5P_DEFAULT);
39
10
    if (fuzz_h5_id != H5I_INVALID_HID) {
40
0
        H5Fclose(fuzz_h5_id);
41
0
    }
42
43
10
    return 0;
44
10
}