Coverage Report

Created: 2026-01-10 06:44

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/libarchive_fuzzer.cc
Line
Count
Source
1
// Copyright 2016 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
////////////////////////////////////////////////////////////////////////////////
16
#include <stddef.h>
17
#include <stdint.h>
18
#include <vector>
19
20
#include "archive.h"
21
#include "archive_entry.h"
22
23
6.24k
extern "C" int LLVMFuzzerTestOneInput(const uint8_t *buf, size_t len) {
24
6.24k
  struct archive *a = archive_read_new();
25
26
6.24k
  archive_read_support_filter_all(a);
27
6.24k
  archive_read_support_format_all(a);
28
6.24k
  archive_read_support_format_empty(a);
29
6.24k
  archive_read_support_format_raw(a);
30
6.24k
  archive_read_support_format_gnutar(a);
31
32
6.24k
  if (ARCHIVE_OK != archive_read_set_options(a, "zip:ignorecrc32,tar:read_concatenated_archives,tar:mac-ext")) {
33
0
    return 0;
34
0
  }
35
36
6.24k
  archive_read_add_passphrase(a, "secret");
37
38
6.24k
  if (ARCHIVE_OK != archive_read_open_memory(a, buf, len)) {
39
129
    archive_read_free(a);
40
129
    return 0;
41
129
  }
42
43
624k
  while(1) {
44
624k
    std::vector<uint8_t> data_buffer(getpagesize(), 0);
45
624k
    struct archive_entry *entry;
46
624k
    int ret = archive_read_next_header(a, &entry);
47
624k
    if (ret == ARCHIVE_EOF || ret == ARCHIVE_FATAL)
48
4.76k
      break;
49
619k
    if (ret == ARCHIVE_RETRY)
50
489k
      continue;
51
52
130k
    (void)archive_entry_pathname(entry);
53
130k
    (void)archive_entry_pathname_utf8(entry);
54
130k
    (void)archive_entry_pathname_w(entry);
55
56
130k
    (void)archive_entry_atime(entry);
57
130k
    (void)archive_entry_birthtime(entry);
58
130k
    (void)archive_entry_ctime(entry);
59
130k
    (void)archive_entry_dev(entry);
60
130k
    (void)archive_entry_digest(entry, ARCHIVE_ENTRY_DIGEST_SHA1);
61
130k
    (void)archive_entry_filetype(entry);
62
130k
    (void)archive_entry_gid(entry);
63
130k
    (void)archive_entry_is_data_encrypted(entry);
64
130k
    (void)archive_entry_is_encrypted(entry);
65
130k
    (void)archive_entry_is_metadata_encrypted(entry);
66
130k
    (void)archive_entry_mode(entry);
67
130k
    (void)archive_entry_mtime(entry);
68
130k
    (void)archive_entry_size(entry);
69
130k
    (void)archive_entry_uid(entry);
70
71
130k
    ssize_t r;
72
334M
    while ((r = archive_read_data(a, data_buffer.data(),
73
334M
            data_buffer.size())) > 0)
74
334M
      ;
75
130k
    if (r == ARCHIVE_FATAL)
76
1.35k
      break;
77
130k
  }
78
79
6.11k
  archive_read_has_encrypted_entries(a);
80
6.11k
  archive_read_format_capabilities(a);
81
6.11k
  archive_file_count(a);
82
6.11k
  archive_seek_data(a, 0, SEEK_SET);
83
84
6.11k
  archive_read_free(a);
85
6.11k
  return 0;
86
6.24k
}