Coverage Report

Created: 2026-05-16 06:52

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/spirv-tools/test/fuzzers/spvtools_val_fuzzer.cpp
Line
Count
Source
1
// Copyright (c) 2018 Google Inc.
2
//
3
// Licensed under the Apache License, Version 2.0 (the "License");
4
// you may not use this file except in compliance with the License.
5
// You may obtain a copy of the License at
6
//
7
//     http://www.apache.org/licenses/LICENSE-2.0
8
//
9
// Unless required by applicable law or agreed to in writing, software
10
// distributed under the License is distributed on an "AS IS" BASIS,
11
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
// See the License for the specific language governing permissions and
13
// limitations under the License.
14
15
#include <cstdint>
16
#include <vector>
17
18
#include "spirv-tools/libspirv.hpp"
19
#include "test/fuzzers/random_generator.h"
20
21
18.9k
extern "C" int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size) {
22
18.9k
  if (size < 1) {
23
0
    return 0;
24
0
  }
25
26
18.9k
  spvtools::fuzzers::RandomGenerator random_gen(data, size);
27
18.9k
  spvtools::SpirvTools tools(random_gen.GetTargetEnv());
28
18.9k
  tools.SetMessageConsumer([](spv_message_level_t, const char*,
29
20.1k
                              const spv_position_t&, const char*) {});
30
31
18.9k
  std::vector<uint32_t> input;
32
18.9k
  input.resize(size >> 2);
33
34
18.9k
  size_t count = 0;
35
10.6M
  for (size_t i = 0; (i + 3) < size; i += 4) {
36
10.6M
    input[count++] = data[i] | (data[i + 1] << 8) | (data[i + 2] << 16) |
37
10.6M
                     (data[i + 3]) << 24;
38
10.6M
  }
39
40
18.9k
  tools.Validate(input);
41
18.9k
  return 0;
42
18.9k
}