Fuzz introspector
For issues and ideas: https://github.com/ossf/fuzz-introspector/issues

Project functions overview

The following table shows data about each function in the project. The functions included in this table correspond to all functions that exist in the executables of the fuzzers. As such, there may be functions that are from third-party libraries.

For further technical details on the meaning of columns in the below table, please see the Glossary .

Func name Functions filename Args Function call depth Reached by Fuzzers Runtime reached by Fuzzers Combined reached by Fuzzers Fuzzers runtime hit Func lines hit % I Count BB Count Cyclomatic complexity Functions reached Reached by functions Accumulated cyclomatic complexity Undiscovered complexity

Fuzzer details

Fuzzer: debug_aranges

Call tree

The calltree shows the control flow of the fuzzer. This is overlaid with coverage information to display how much of the potential code a fuzzer can reach is in fact covered at runtime. In the following there is a link to a detailed calltree visualisation as well as a bitmap showing a high-level view of the calltree. For further information about these topics please see the glossary for full calltree and calltree overview

Call tree overview bitmap:

The distribution of callsites in terms of coloring is
Color Runtime hitcount Callsite count Percentage
red 0 36 87.8%
gold [1:9] 0 0.0%
yellow [10:29] 0 0.0%
greenyellow [30:49] 0 0.0%
lawngreen 50+ 5 12.1%
All colors 41 100

Fuzz blockers

The following nodes represent call sites where fuzz blockers occur.

Amount of callsites blocked Calltree index Parent function Callsite Largest blocked function
24 4 DebugAddr::headers call site: 00004 ArrayVec::try_push
10 30 DebugAddr::headers call site: 00030 ArrayVec::clone
1 0 EP call site: 00000
1 2 DebugAranges::new call site: 00002

Runtime coverage analysis

Covered functions
49
Functions that are reachable but not covered
2
Reachable functions
8
Percentage of reachable functions covered
75.0%
NB: The sum of covered functions and functions that are reachable but not covered need not be equal to Reachable functions . This is because the reachability analysis is an approximation and thus at runtime some functions may be covered that are not included in the reachability analysis. This is a limitation of our static analysis capabilities.
Warning: The number of covered functions are larger than the number of reachable functions. This means that there are more functions covered at runtime than are extracted using static analysis. This is likely a result of the static analysis component failing to extract the right call graph or the coverage runtime being compiled with sanitizers in code that the static analysis has not analysed. This can happen if lto/gold is not used in all places that coverage instrumentation is used.
Function name source code lines source lines hit percentage hit

Files reached

filename functions hit
fuzz/fuzz_targets/debug_aranges.rs 6
src/write/op.rs 2
src/read/addr.rs 6
src/read/util.rs 14
src/write/endian_vec.rs 1
src/write/unit.rs 1
src/read/reader.rs 1
src/common.rs 1

Fuzzer: debug_abbrev

Call tree

The calltree shows the control flow of the fuzzer. This is overlaid with coverage information to display how much of the potential code a fuzzer can reach is in fact covered at runtime. In the following there is a link to a detailed calltree visualisation as well as a bitmap showing a high-level view of the calltree. For further information about these topics please see the glossary for full calltree and calltree overview

Call tree overview bitmap:

The distribution of callsites in terms of coloring is
Color Runtime hitcount Callsite count Percentage
red 0 831 95.8%
gold [1:9] 6 0.69%
yellow [10:29] 0 0.0%
greenyellow [30:49] 0 0.0%
lawngreen 50+ 30 3.46%
All colors 867 100

Fuzz blockers

The following nodes represent call sites where fuzz blockers occur.

Amount of callsites blocked Calltree index Parent function Callsite Largest blocked function
641 205 Reader::read_uleb128 call site: 00205 EntriesRaw::read_attributes
39 165 Abbreviations::insert call site: 00165 EntriesRaw::read_entry
27 33 DebugAbbrev::abbreviations call site: 00033 SubRange::read_slice
27 91 Reader::read_uleb128_u16 call site: 00091 Abbreviation::parse_attributes
23 9 DebugAbbrev::abbreviations call site: 00009 ArrayVec::try_push
23 131 Reader::read_sleb128 call site: 00131 Abbreviations::insert
17 73 Reader::read_uleb128 call site: 00073 Reader::read_u8
10 120 AttributeSpecification::new call site: 00120 AttributeSpecification::parse
8 0 EP call site: 00000 DebugAbbrev::abbreviations
7 65 Abbreviations::empty call site: 00065 Abbreviation::parse
5 861 Abbreviations::insert call site: 00861 Expression::set_target
2 161 Abbreviations::insert call site: 00161 ArrayVec::try_push

Runtime coverage analysis

Covered functions
32
Functions that are reachable but not covered
3
Reachable functions
8
Percentage of reachable functions covered
62.5%
NB: The sum of covered functions and functions that are reachable but not covered need not be equal to Reachable functions . This is because the reachability analysis is an approximation and thus at runtime some functions may be covered that are not included in the reachability analysis. This is a limitation of our static analysis capabilities.
Warning: The number of covered functions are larger than the number of reachable functions. This means that there are more functions covered at runtime than are extracted using static analysis. This is likely a result of the static analysis component failing to extract the right call graph or the coverage runtime being compiled with sanitizers in code that the static analysis has not analysed. This can happen if lto/gold is not used in all places that coverage instrumentation is used.
Function name source code lines source lines hit percentage hit

Files reached

filename functions hit
fuzz/fuzz_targets/debug_abbrev.rs 6
src/write/endian_vec.rs 6
src/write/op.rs 16
src/common.rs 1
src/read/abbrev.rs 18
src/read/util.rs 15
src/write/unit.rs 1
src/leb128.rs 10
src/read/reader.rs 15
src/read/endian_reader.rs 26
src/write/abbrev.rs 1
src/read/loclists.rs 3
src/read/addr.rs 19
src/write/line.rs 3
src/endianity.rs 27
src/read/op.rs 2
src/read/unit.rs 68
src/read/cfi.rs 1
src/write/relocate.rs 24
src/write/writer.rs 25
crates/examples/src/bin/simple_write.rs 1
src/constants.rs 1

Fuzzer: debug_names

Call tree

The calltree shows the control flow of the fuzzer. This is overlaid with coverage information to display how much of the potential code a fuzzer can reach is in fact covered at runtime. In the following there is a link to a detailed calltree visualisation as well as a bitmap showing a high-level view of the calltree. For further information about these topics please see the glossary for full calltree and calltree overview

Call tree overview bitmap:

The distribution of callsites in terms of coloring is
Color Runtime hitcount Callsite count Percentage
red 0 114 71.6%
gold [1:9] 0 0.0%
yellow [10:29] 0 0.0%
greenyellow [30:49] 0 0.0%
lawngreen 50+ 45 28.3%
All colors 159 100

Fuzz blockers

The following nodes represent call sites where fuzz blockers occur.

Amount of callsites blocked Calltree index Parent function Callsite Largest blocked function
41 0 EP call site: 00000 NameIndex::find_by_bucket
33 42 NameIndex::find_by_bucket call site: 00042 read::skip
14 80 Endianity::read_u32 call site: 00080 NameIndex::name_entries
12 128 Reader::read_word call site: 00128 read::skip
9 95 NameIndex::name_entries call site: 00095 Reader::read_offset
1 78 Endianity::read_u32 call site: 00078
1 113 Endianity::read_u32 call site: 00113
1 116 Reader::read_word call site: 00116
1 125 Endianity::read_u64 call site: 00125
1 149 NameIndex::compile_unit call site: 00149 NameIndex::local_type_unit

Runtime coverage analysis

Covered functions
71
Functions that are reachable but not covered
2
Reachable functions
15
Percentage of reachable functions covered
86.67%
NB: The sum of covered functions and functions that are reachable but not covered need not be equal to Reachable functions . This is because the reachability analysis is an approximation and thus at runtime some functions may be covered that are not included in the reachability analysis. This is a limitation of our static analysis capabilities.
Warning: The number of covered functions are larger than the number of reachable functions. This means that there are more functions covered at runtime than are extracted using static analysis. This is likely a result of the static analysis component failing to extract the right call graph or the coverage runtime being compiled with sanitizers in code that the static analysis has not analysed. This can happen if lto/gold is not used in all places that coverage instrumentation is used.
Function name source code lines source lines hit percentage hit

Files reached

filename functions hit
fuzz/fuzz_targets/debug_names.rs 11
src/write/op.rs 14
src/common.rs 1
src/read/addr.rs 6
src/read/util.rs 14
src/write/endian_vec.rs 1
src/write/unit.rs 1
src/read/reader.rs 8
src/read/names.rs 9
src/leb128.rs 3
src/read/endian_reader.rs 14
src/write/abbrev.rs 1
src/read/loclists.rs 3
src/endianity.rs 12
src/read/cfi.rs 1

Fuzzer: eh_frame_hdr

Call tree

The calltree shows the control flow of the fuzzer. This is overlaid with coverage information to display how much of the potential code a fuzzer can reach is in fact covered at runtime. In the following there is a link to a detailed calltree visualisation as well as a bitmap showing a high-level view of the calltree. For further information about these topics please see the glossary for full calltree and calltree overview

Call tree overview bitmap:

The distribution of callsites in terms of coloring is
Color Runtime hitcount Callsite count Percentage
red 0 104 73.7%
gold [1:9] 0 0.0%
yellow [10:29] 0 0.0%
greenyellow [30:49] 4 2.83%
lawngreen 50+ 33 23.4%
All colors 141 100

Fuzz blockers

The following nodes represent call sites where fuzz blockers occur.

Amount of callsites blocked Calltree index Parent function Callsite Largest blocked function
40 70 AddrHeader::parse call site: 00070 read::skip
24 19 Reader::read_u32 call site: 00019 SubRange::read_slice
6 0 EP call site: 00000
6 120 AddrHeader::parse call site: 00120 Reader::read_u8
5 51 Endianity::read_u32 call site: 00051 Reader::read_u64
4 65 Endianity::read_u64 call site: 00065
4 127 AddrHeader::parse call site: 00127 Reader::read_u8_array
3 116 Endianity::read_u16 call site: 00116
2 135 AddrHeader::parse call site: 00135 Reader::read_u8
2 138 AddrHeader::parse call site: 00138
1 7 BaseAddresses::set_eh_frame call site: 00007
1 10 BaseAddresses::set_eh_frame_hdr call site: 00010

Runtime coverage analysis

Covered functions
57
Functions that are reachable but not covered
2
Reachable functions
10
Percentage of reachable functions covered
80.0%
NB: The sum of covered functions and functions that are reachable but not covered need not be equal to Reachable functions . This is because the reachability analysis is an approximation and thus at runtime some functions may be covered that are not included in the reachability analysis. This is a limitation of our static analysis capabilities.
Warning: The number of covered functions are larger than the number of reachable functions. This means that there are more functions covered at runtime than are extracted using static analysis. This is likely a result of the static analysis component failing to extract the right call graph or the coverage runtime being compiled with sanitizers in code that the static analysis has not analysed. This can happen if lto/gold is not used in all places that coverage instrumentation is used.
Function name source code lines source lines hit percentage hit

Files reached

filename functions hit
fuzz/fuzz_targets/eh_frame_hdr.rs 8
src/write/op.rs 3
src/common.rs 1
src/read/cfi.rs 1
src/read/addr.rs 14
src/read/reader.rs 11
src/endianity.rs 14
src/read/endian_reader.rs 18
src/leb128.rs 3
src/write/abbrev.rs 1
src/write/endian_vec.rs 1
src/read/loclists.rs 3
src/read/util.rs 14
src/write/unit.rs 1

Fuzzer: debug_line

Call tree

The calltree shows the control flow of the fuzzer. This is overlaid with coverage information to display how much of the potential code a fuzzer can reach is in fact covered at runtime. In the following there is a link to a detailed calltree visualisation as well as a bitmap showing a high-level view of the calltree. For further information about these topics please see the glossary for full calltree and calltree overview

Call tree overview bitmap:

The distribution of callsites in terms of coloring is
Color Runtime hitcount Callsite count Percentage
red 0 1218 87.0%
gold [1:9] 4 0.28%
yellow [10:29] 0 0.0%
greenyellow [30:49] 0 0.0%
lawngreen 50+ 178 12.7%
All colors 1400 100

Fuzz blockers

The following nodes represent call sites where fuzz blockers occur.

Amount of callsites blocked Calltree index Parent function Callsite Largest blocked function
458 272 Reader::read_null_terminated_slice call site: 00272 Writer::write_eh_pointer_data
155 846 Reader::read_uleb128_u16 call site: 00846 EntriesRaw::read_entry
126 1069 Reader::read_address call site: 01069 Expression::write
109 16 Dwarf::new call site: 00016 EntriesRaw::read_entry
65 126 Reader::read_uleb128 call site: 00126 EntriesRaw::read_attributes
62 783 Endianity::read_u64 call site: 00783 DebugAbbrev::abbreviations
33 1353 LineRow::apply_line_advance call site: 01353 DebugAranges::header
25 1026 Reader::read_offset call site: 01026 tests::test_line_program
23 749 Reader::read_null_terminated_slice call site: 00749 Reader::read_offset
19 1006 Reader::read_null_terminated_slice call site: 01006 Reader::read_offset
17 1233 Reader::read_address_size call site: 01233 read::skip
15 0 EP call site: 00000 tests::test_line_program

Runtime coverage analysis

Covered functions
90
Functions that are reachable but not covered
2
Reachable functions
8
Percentage of reachable functions covered
75.0%
NB: The sum of covered functions and functions that are reachable but not covered need not be equal to Reachable functions . This is because the reachability analysis is an approximation and thus at runtime some functions may be covered that are not included in the reachability analysis. This is a limitation of our static analysis capabilities.
Warning: The number of covered functions are larger than the number of reachable functions. This means that there are more functions covered at runtime than are extracted using static analysis. This is likely a result of the static analysis component failing to extract the right call graph or the coverage runtime being compiled with sanitizers in code that the static analysis has not analysed. This can happen if lto/gold is not used in all places that coverage instrumentation is used.
Function name source code lines source lines hit percentage hit

Files reached

filename functions hit
fuzz/fuzz_targets/debug_line.rs 6
src/write/op.rs 34
src/common.rs 2
src/write/line.rs 47
src/read/unit.rs 71
src/read/reader.rs 27
src/write/endian_vec.rs 6
src/read/endian_reader.rs 26
src/read/util.rs 15
src/write/unit.rs 1
src/leb128.rs 10
src/write/abbrev.rs 1
src/read/loclists.rs 3
src/read/op.rs 3
src/read/cfi.rs 1
src/endianity.rs 28
src/write/relocate.rs 26
src/write/writer.rs 25
crates/examples/src/bin/simple_write.rs 1
src/constants.rs 4
src/read/abbrev.rs 18
src/read/addr.rs 67
src/read/dwarf.rs 32
src/read/str.rs 15
src/read/lists.rs 1
src/read/names.rs 2
src/write/section.rs 1
benches/bench.rs 5
src/read/line.rs 21
src/read/aranges.rs 4

Fuzzer: debug_info

Call tree

The calltree shows the control flow of the fuzzer. This is overlaid with coverage information to display how much of the potential code a fuzzer can reach is in fact covered at runtime. In the following there is a link to a detailed calltree visualisation as well as a bitmap showing a high-level view of the calltree. For further information about these topics please see the glossary for full calltree and calltree overview

Call tree overview bitmap:

The distribution of callsites in terms of coloring is
Color Runtime hitcount Callsite count Percentage
red 0 759 84.5%
gold [1:9] 0 0.0%
yellow [10:29] 0 0.0%
greenyellow [30:49] 0 0.0%
lawngreen 50+ 139 15.4%
All colors 898 100

Fuzz blockers

The following nodes represent call sites where fuzz blockers occur.

Amount of callsites blocked Calltree index Parent function Callsite Largest blocked function
456 329 Reader::read_null_terminated_slice call site: 00329 Writer::write_eh_pointer_data
27 44 DebugAbbrev::abbreviations call site: 00044 SubRange::read_slice
27 101 Reader::read_uleb128_u16 call site: 00101 Abbreviation::parse_attributes
24 9 DebugInfo::units call site: 00009 ArrayVec::try_push
23 141 Reader::read_sleb128 call site: 00141 Abbreviations::insert
23 804 Reader::read_null_terminated_slice call site: 00804 Reader::read_offset
20 237 EntriesRaw::read_attributes call site: 00237 read::skip
18 190 UnitHeader::header_size call site: 00190 EntriesRaw::read_entry
16 84 Reader::read_uleb128 call site: 00084 Reader::read_u8
15 272 Endianity::read_u32 call site: 00272 Reader::read_u8
11 292 Endianity::read_u64 call site: 00292 Reader::read_offset
10 130 AttributeSpecification::new call site: 00130 AttributeSpecification::parse

Runtime coverage analysis

Covered functions
126
Functions that are reachable but not covered
4
Reachable functions
27
Percentage of reachable functions covered
85.19%
NB: The sum of covered functions and functions that are reachable but not covered need not be equal to Reachable functions . This is because the reachability analysis is an approximation and thus at runtime some functions may be covered that are not included in the reachability analysis. This is a limitation of our static analysis capabilities.
Warning: The number of covered functions are larger than the number of reachable functions. This means that there are more functions covered at runtime than are extracted using static analysis. This is likely a result of the static analysis component failing to extract the right call graph or the coverage runtime being compiled with sanitizers in code that the static analysis has not analysed. This can happen if lto/gold is not used in all places that coverage instrumentation is used.
Function name source code lines source lines hit percentage hit

Files reached

filename functions hit
fuzz/fuzz_targets/debug_info.rs 8
src/write/op.rs 18
src/common.rs 1
src/read/unit.rs 72
src/read/util.rs 15
src/write/endian_vec.rs 6
src/write/unit.rs 1
src/read/reader.rs 15
src/read/addr.rs 24
src/read/abbrev.rs 20
src/leb128.rs 10
src/read/endian_reader.rs 26
src/write/abbrev.rs 1
src/read/loclists.rs 3
src/write/line.rs 3
src/endianity.rs 27
src/read/op.rs 2
src/read/cfi.rs 1
src/write/relocate.rs 24
src/write/writer.rs 25
crates/examples/src/bin/simple_write.rs 1
src/constants.rs 1

Fuzzer: eh_frame

Call tree

The calltree shows the control flow of the fuzzer. This is overlaid with coverage information to display how much of the potential code a fuzzer can reach is in fact covered at runtime. In the following there is a link to a detailed calltree visualisation as well as a bitmap showing a high-level view of the calltree. For further information about these topics please see the glossary for full calltree and calltree overview

Call tree overview bitmap:

The distribution of callsites in terms of coloring is
Color Runtime hitcount Callsite count Percentage
red 0 972 91.9%
gold [1:9] 0 0.0%
yellow [10:29] 0 0.0%
greenyellow [30:49] 0 0.0%
lawngreen 50+ 85 8.04%
All colors 1057 100

Fuzz blockers

The following nodes represent call sites where fuzz blockers occur.

Amount of callsites blocked Calltree index Parent function Callsite Largest blocked function
209 507 constants::DwEhPe::format call site: 00507 Writer::write_udata
148 274 ArrayVec::try_push call site: 00274 Writer::write_udata
87 782 Endianity::read_u16 call site: 00782 DebugAranges::header
83 423 constants::DwEhPe::application call site: 00423 Writer::write_eh_pointer_data
79 871 u64::wrapping_add_sized call site: 00871 EntriesRaw::read_entry
72 134 Endianity::read_u16 call site: 00134 LineInstructions::next_instruction
29 994 Reader::read_null_terminated_slice call site: 00994 Reader::read_offset
28 1028 Endianity::read_u64 call site: 01028 DebugAranges::header
23 62 Reader::read_u32 call site: 00062 SubRange::read_slice
22 207 Reader::read_uleb128 call site: 00207 Reader::read_address
19 110 Reader::read_initial_length call site: 00110 read::skip
19 250 Reader::read_null_terminated_slice call site: 00250 Writer::write_udata

Runtime coverage analysis

Covered functions
167
Functions that are reachable but not covered
4
Reachable functions
18
Percentage of reachable functions covered
77.78%
NB: The sum of covered functions and functions that are reachable but not covered need not be equal to Reachable functions . This is because the reachability analysis is an approximation and thus at runtime some functions may be covered that are not included in the reachability analysis. This is a limitation of our static analysis capabilities.
Warning: The number of covered functions are larger than the number of reachable functions. This means that there are more functions covered at runtime than are extracted using static analysis. This is likely a result of the static analysis component failing to extract the right call graph or the coverage runtime being compiled with sanitizers in code that the static analysis has not analysed. This can happen if lto/gold is not used in all places that coverage instrumentation is used.
Function name source code lines source lines hit percentage hit

Files reached

filename functions hit
fuzz/fuzz_targets/eh_frame.rs 14
src/write/op.rs 15
src/common.rs 1
src/read/op.rs 7
src/read/util.rs 15
src/write/endian_vec.rs 6
src/write/unit.rs 1
src/read/cfi.rs 2
src/read/addr.rs 50
src/read/reader.rs 26
src/endianity.rs 24
src/read/endian_reader.rs 26
src/leb128.rs 10
src/write/abbrev.rs 1
src/read/loclists.rs 3
src/read/line.rs 21
src/read/aranges.rs 4
src/write/line.rs 6
src/write/relocate.rs 24
src/write/writer.rs 25
crates/examples/src/bin/simple_write.rs 1
src/constants.rs 1
src/read/unit.rs 68

Fuzz engine guidance

This sections provides heuristics that can be used as input to a fuzz engine when running a given fuzz target. The current focus is on providing input that is usable by libFuzzer.

fuzz/fuzz_targets/debug_aranges.rs

Dictionary

Use this with the libFuzzer -dict=DICT.file flag


Fuzzer function priority

Use one of these functions as input to libfuzzer with flag: -focus_function name

-focus_function=['DebugAddr::headers', 'DebugAranges::new']

fuzz/fuzz_targets/debug_abbrev.rs

Dictionary

Use this with the libFuzzer -dict=DICT.file flag


Fuzzer function priority

Use one of these functions as input to libfuzzer with flag: -focus_function name

-focus_function=['Reader::read_uleb128', 'Abbreviations::insert', 'DebugAbbrev::abbreviations', 'Reader::read_uleb128_u16', 'Reader::read_sleb128', 'AttributeSpecification::new', 'Abbreviations::empty']

fuzz/fuzz_targets/debug_names.rs

Dictionary

Use this with the libFuzzer -dict=DICT.file flag


Fuzzer function priority

Use one of these functions as input to libfuzzer with flag: -focus_function name

-focus_function=['NameIndex::find_by_bucket', 'Endianity::read_u32', 'Reader::read_word', 'NameIndex::name_entries', 'Endianity::read_u64', 'NameIndex::compile_unit']

fuzz/fuzz_targets/eh_frame_hdr.rs

Dictionary

Use this with the libFuzzer -dict=DICT.file flag


Fuzzer function priority

Use one of these functions as input to libfuzzer with flag: -focus_function name

-focus_function=['AddrHeader::parse', 'Reader::read_u32', 'Endianity::read_u32', 'Endianity::read_u64', 'Endianity::read_u16']

fuzz/fuzz_targets/debug_line.rs

Dictionary

Use this with the libFuzzer -dict=DICT.file flag


Fuzzer function priority

Use one of these functions as input to libfuzzer with flag: -focus_function name

-focus_function=['Reader::read_null_terminated_slice', 'Reader::read_uleb128_u16', 'Reader::read_address', 'Dwarf::new', 'Reader::read_uleb128', 'Endianity::read_u64', 'LineRow::apply_line_advance', 'Reader::read_offset']

fuzz/fuzz_targets/debug_info.rs

Dictionary

Use this with the libFuzzer -dict=DICT.file flag


Fuzzer function priority

Use one of these functions as input to libfuzzer with flag: -focus_function name

-focus_function=['Reader::read_null_terminated_slice', 'DebugAbbrev::abbreviations', 'Reader::read_uleb128_u16', 'DebugInfo::units', 'Reader::read_sleb128', 'EntriesRaw::read_attributes', 'UnitHeader::header_size', 'Reader::read_uleb128', 'Endianity::read_u32']

fuzz/fuzz_targets/eh_frame.rs

Dictionary

Use this with the libFuzzer -dict=DICT.file flag


Fuzzer function priority

Use one of these functions as input to libfuzzer with flag: -focus_function name

-focus_function=['constants::DwEhPe::format', 'ArrayVec::try_push', 'Endianity::read_u16', 'constants::DwEhPe::application', 'u64::wrapping_add_sized', 'Reader::read_null_terminated_slice', 'Endianity::read_u64', 'Reader::read_u32', 'Reader::read_uleb128']

Files and Directories in report

This section shows which files and directories are considered in this report. The main reason for showing this is fuzz introspector may include more code in the reasoning than is desired. This section helps identify if too many files/directories are included, e.g. third party code, which may be irrelevant for the threat model. In the event too much is included, fuzz introspector supports a configuration file that can exclude data from the report. See the following link for more information on how to create a config file: link

Files in report

Source file Reached by Covered by
/src/gimli/src/write/mod.rs [] []
/src/gimli/src/write/relocate.rs ['debug_abbrev', 'debug_line', 'debug_info', 'eh_frame'] ['debug_line', 'debug_info', 'eh_frame']
/src/gimli/src/test_util.rs [] []
/src/gimli/src/read/op.rs ['debug_abbrev', 'debug_line', 'debug_info', 'eh_frame'] ['debug_abbrev', 'debug_line', 'debug_info', 'eh_frame']
/src/gimli/src/read/relocate.rs [] []
/src/gimli/src/read/index.rs [] []
/src/gimli/crates/examples/src/bin/convert.rs [] []
/src/gimli/src/read/macros.rs [] []
/src/gimli/src/read/names.rs ['debug_names', 'debug_line'] ['debug_names', 'debug_line']
/src/gimli/src/read/endian_reader.rs ['debug_abbrev', 'debug_names', 'eh_frame_hdr', 'debug_line', 'debug_info', 'eh_frame'] ['debug_abbrev', 'debug_names', 'eh_frame_hdr', 'debug_line', 'debug_info', 'eh_frame']
/src/gimli/src/read/str.rs ['debug_line'] ['debug_line']
/src/gimli/crates/examples/src/bin/simple_convert.rs [] []
/src/gimli/crates/examples/src/bin/simple_write.rs ['debug_abbrev', 'debug_line', 'debug_info', 'eh_frame'] ['debug_abbrev', 'debug_line', 'debug_info', 'eh_frame']
/src/gimli/crates/examples/src/bin/dwarfdump.rs [] []
/src/gimli/fuzz/fuzz_targets/debug_info.rs ['debug_info'] []
/src/gimli/src/read/lookup.rs [] []
/src/gimli/src/leb128.rs ['debug_abbrev', 'debug_names', 'eh_frame_hdr', 'debug_line', 'debug_info', 'eh_frame'] ['debug_abbrev', 'debug_names', 'eh_frame_hdr', 'debug_line', 'debug_info', 'eh_frame']
/src/gimli/fuzz/fuzz_targets/debug_aranges.rs ['debug_aranges'] []
/src/gimli/src/write/abbrev.rs ['debug_abbrev', 'debug_names', 'eh_frame_hdr', 'debug_line', 'debug_info', 'eh_frame'] []
/src/gimli/src/write/section.rs ['debug_line'] ['debug_line']
/src/gimli/src/read/loclists.rs ['debug_abbrev', 'debug_names', 'eh_frame_hdr', 'debug_line', 'debug_info', 'eh_frame'] ['debug_abbrev', 'debug_names', 'eh_frame_hdr', 'debug_line', 'debug_info', 'eh_frame']
/src/gimli/fuzz/fuzz_targets/debug_names.rs ['debug_names'] []
/src/gimli/fuzz/fuzz_targets/eh_frame.rs ['eh_frame'] []
/src/gimli/src/write/cfi.rs [] []
/src/gimli/src/arch.rs [] []
/src/gimli/src/case_fold.rs [] []
/src/gimli/src/read/abbrev.rs ['debug_abbrev', 'debug_line', 'debug_info'] ['debug_abbrev', 'debug_line', 'debug_info']
/src/gimli/crates/examples/src/bin/simple.rs [] []
/src/gimli/src/write/range.rs [] []
/src/gimli/src/write/op.rs ['debug_aranges', 'debug_abbrev', 'debug_names', 'eh_frame_hdr', 'debug_line', 'debug_info', 'eh_frame'] ['debug_aranges', 'debug_abbrev', 'debug_names', 'eh_frame_hdr', 'debug_line', 'debug_info', 'eh_frame']
/src/gimli/src/read/value.rs [] []
/src/gimli/src/read/dwarf.rs ['debug_line'] ['debug_line']
/src/gimli/src/write/unit.rs ['debug_aranges', 'debug_abbrev', 'debug_names', 'eh_frame_hdr', 'debug_line', 'debug_info', 'eh_frame'] ['debug_aranges', 'debug_abbrev', 'debug_names', 'eh_frame_hdr', 'debug_line', 'debug_info', 'eh_frame']
/src/gimli/tests/convert_self.rs [] []
/src/gimli/src/write/loc.rs [] []
/src/gimli/src/read/line.rs ['debug_line', 'eh_frame'] ['debug_line', 'eh_frame']
/src/gimli/crates/examples/src/bin/dwarf-validate.rs [] []
/src/gimli/src/common.rs ['debug_aranges', 'debug_abbrev', 'debug_names', 'eh_frame_hdr', 'debug_line', 'debug_info', 'eh_frame'] ['debug_aranges', 'debug_abbrev', 'debug_names', 'eh_frame_hdr', 'debug_line', 'debug_info', 'eh_frame']
/src/gimli/src/write/writer.rs ['debug_abbrev', 'debug_line', 'debug_info', 'eh_frame'] []
/src/gimli/fuzz/fuzz_targets/debug_line.rs ['debug_line'] []
/src/gimli/src/read/util.rs ['debug_aranges', 'debug_abbrev', 'debug_names', 'eh_frame_hdr', 'debug_line', 'debug_info', 'eh_frame'] ['debug_aranges', 'debug_abbrev', 'debug_names', 'eh_frame_hdr', 'debug_line', 'debug_info', 'eh_frame']
/src/gimli/src/write/dwarf.rs [] []
/src/gimli/fuzz/fuzz_targets/debug_abbrev.rs ['debug_abbrev'] []
/src/gimli/src/read/reader.rs ['debug_aranges', 'debug_abbrev', 'debug_names', 'eh_frame_hdr', 'debug_line', 'debug_info', 'eh_frame'] ['debug_aranges', 'debug_abbrev', 'debug_names', 'eh_frame_hdr', 'debug_line', 'debug_info', 'eh_frame']
/src/gimli/src/read/addr.rs ['debug_aranges', 'debug_abbrev', 'debug_names', 'eh_frame_hdr', 'debug_line', 'debug_info', 'eh_frame'] ['debug_aranges', 'debug_abbrev', 'debug_names', 'eh_frame_hdr', 'debug_line', 'debug_info', 'eh_frame']
/src/gimli/src/write/line.rs ['debug_abbrev', 'debug_line', 'debug_info', 'eh_frame'] ['debug_abbrev', 'debug_line', 'debug_info', 'eh_frame']
/src/gimli/src/read/endian_slice.rs [] []
/src/gimli/tests/parse_self.rs [] []
/src/gimli/src/write/str.rs [] []
/src/gimli/src/read/pubtypes.rs [] []
/src/gimli/src/read/aranges.rs ['debug_line', 'eh_frame'] ['debug_line', 'eh_frame']
/src/gimli/src/read/pubnames.rs [] []
/src/gimli/src/write/endian_vec.rs ['debug_aranges', 'debug_abbrev', 'debug_names', 'eh_frame_hdr', 'debug_line', 'debug_info', 'eh_frame'] ['debug_aranges', 'debug_abbrev', 'debug_names', 'eh_frame_hdr', 'debug_line', 'debug_info', 'eh_frame']
/src/gimli/src/read/rnglists.rs [] []
/src/gimli/src/constants.rs ['debug_abbrev', 'debug_line', 'debug_info', 'eh_frame'] ['debug_info', 'eh_frame']
/src/gimli/src/read/lists.rs ['debug_line'] ['debug_line']
/src/gimli/src/read/cfi.rs ['debug_abbrev', 'debug_names', 'eh_frame_hdr', 'debug_line', 'debug_info', 'eh_frame'] ['debug_abbrev', 'debug_names', 'eh_frame_hdr', 'debug_line', 'debug_info', 'eh_frame']
/src/gimli/fuzz/fuzz_targets/eh_frame_hdr.rs ['eh_frame_hdr'] []
/src/gimli/benches/bench.rs ['debug_line'] []
/src/gimli/src/endianity.rs ['debug_abbrev', 'debug_names', 'eh_frame_hdr', 'debug_line', 'debug_info', 'eh_frame'] ['debug_names', 'eh_frame_hdr', 'debug_line', 'debug_info', 'eh_frame']
/src/gimli/src/read/mod.rs [] []
/src/gimli/src/read/unit.rs ['debug_abbrev', 'debug_line', 'debug_info', 'eh_frame'] ['debug_abbrev', 'debug_line', 'debug_info', 'eh_frame']

Directories in report

Directory
/src/gimli/tests/
/src/gimli/benches/
/src/gimli/src/
/src/gimli/src/read/
/src/gimli/crates/examples/src/bin/
/src/gimli/src/write/
/src/gimli/fuzz/fuzz_targets/