Coverage Report

Created: 2025-11-24 06:45

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/load_from_memory_fuzzer.cc
Line
Count
Source
1
#include <cstddef>
2
#include <cstdint>
3
#include <cstdlib>
4
#include <vector>
5
#include <FreeImage.h>
6
7
namespace {
8
9
// Returns true if the format should be attempted to loaded from memory.
10
29.7k
bool SafeToLoadFromMemory(FREE_IMAGE_FORMAT fif) {
11
  // For now, just load if it is a BMP. Future heuristics may need to be based
12
  // on the expected size in different formats for memory regions to avoid OOMs.
13
29.7k
  return fif == FIF_BMP;
14
29.7k
}
15
16
}  // namespace
17
18
29.7k
extern "C" int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size) {
19
29.7k
  static bool initialized = false;
20
29.7k
  if (!initialized) {
21
29.7k
    FreeImage_Initialise();
22
29.7k
  }
23
24
29.7k
  if (size > 100 * 1000) {
25
1
    return 0;
26
1
  }
27
28
29.7k
  std::vector<uint8_t> fuzzer_data_vector(data, data + size);
29
29.7k
  FIMEMORY* fiMem = FreeImage_OpenMemory(
30
29.7k
      reinterpret_cast<unsigned char*>(fuzzer_data_vector.data()),
31
29.7k
      fuzzer_data_vector.size());
32
33
29.7k
  FREE_IMAGE_FORMAT fif = FreeImage_GetFileTypeFromMemory(fiMem, 0);
34
29.7k
  if (SafeToLoadFromMemory(fif)) {
35
102
    FIBITMAP* fiBitmap = FreeImage_LoadFromMemory(fif, fiMem);
36
102
    FreeImage_Unload(fiBitmap);
37
102
  }
38
29.7k
  FreeImage_CloseMemory(fiMem);
39
40
29.7k
  return 0;
41
29.7k
}