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

Fuzzers overview

Fuzzer Fuzzer filename Functions Reached Functions unreached Fuzzer depth Files reached Basic blocks reached Cyclomatic complexity Details
fuzzerDistances apps/fuzzers/fuzzerDistances.c 8 233 2 2 15 17 fuzzerDistances.c
fuzzerCompact apps/fuzzers/fuzzerCompact.c 20 221 4 5 255 105 fuzzerCompact.c
fuzzerInternalCoordIjk apps/fuzzers/fuzzerInternalCoordIjk.c 9 24 3 3 125 55 fuzzerInternalCoordIjk.c
fuzzerEdgeLength apps/fuzzers/fuzzerEdgeLength.c 56 185 8 9 517 234 fuzzerEdgeLength.c
fuzzerIndexIO apps/fuzzers/fuzzerIndexIO.c 5 236 2 2 18 13 fuzzerIndexIO.c
fuzzerDirectedEdge apps/fuzzers/fuzzerDirectedEdge.c 79 162 7 11 884 391 fuzzerDirectedEdge.c
fuzzerCellToLatLng apps/fuzzers/fuzzerCellToLatLng.c 47 194 5 7 399 188 fuzzerCellToLatLng.c
fuzzerInternalAlgos apps/fuzzers/fuzzerInternalAlgos.c 73 168 6 10 719 316 fuzzerInternalAlgos.c
fuzzerGridDisk apps/fuzzers/fuzzerGridDisk.c 28 213 6 7 408 180 fuzzerGridDisk.c
fuzzerPolygonToCells apps/fuzzers/fuzzerPolygonToCells.c 97 146 9 13 1127 493 fuzzerPolygonToCells.c
fuzzerPolygonToCellsExperimentalNoHoles apps/fuzzers/fuzzerPolygonToCellsExperimentalNoHoles.c 116 140 9 14 1246 551 fuzzerPolygonToCellsExperimentalNoHoles.c
fuzzerHierarchy apps/fuzzers/fuzzerHierarchy.c 19 222 4 5 133 65 fuzzerHierarchy.c
fuzzerCellProperties apps/fuzzers/fuzzerCellProperties.c 41 200 6 5 313 160 fuzzerCellProperties.c
fuzzerPolygonToCellsNoHoles apps/fuzzers/fuzzerPolygonToCellsNoHoles.c 96 146 9 13 1111 486 fuzzerPolygonToCellsNoHoles.c
fuzzerCellToChildPos apps/fuzzers/fuzzerCellToChildPos.c 12 229 4 4 172 65 fuzzerCellToChildPos.c
fuzzerResolutions apps/fuzzers/fuzzerResolutions.c 10 231 2 5 78 33 fuzzerResolutions.c
fuzzerCellArea apps/fuzzers/fuzzerCellArea.c 54 187 6 7 439 208 fuzzerCellArea.c
fuzzerLatLngToCell apps/fuzzers/fuzzerLatLngToCell.c 40 201 6 7 280 151 fuzzerLatLngToCell.c
fuzzerLocalIj apps/fuzzers/fuzzerLocalIj.c 46 204 6 6 623 261 fuzzerLocalIj.c
fuzzerVertexes apps/fuzzers/fuzzerVertexes.c 67 174 7 9 754 331 fuzzerVertexes.c
fuzzerPolygonToCellsExperimental apps/fuzzers/fuzzerPolygonToCellsExperimental.c 117 140 9 14 1262 558 fuzzerPolygonToCellsExperimental.c
fuzzerCellsToLinkedMultiPolygon apps/fuzzers/fuzzerCellsToLinkedMultiPolygon.c 79 162 7 12 823 350 fuzzerCellsToLinkedMultiPolygon.c

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: fuzzerDistances

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 0 0.0%
gold [1:9] 0 0.0%
yellow [10:29] 4 36.3%
greenyellow [30:49] 1 9.09%
lawngreen 50+ 6 54.5%
All colors 11 100

Runtime coverage analysis

Covered functions
4
Functions that are reachable but not covered
4
Reachable functions
8
Percentage of reachable functions covered
50.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.
Function name source code lines source lines hit percentage hit

Files reached

filename functions hit
apps/fuzzers/fuzzerDistances.c 1
h3lib/lib/latLng.c 3

Fuzzer: fuzzerCompact

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 0 0.0%
gold [1:9] 0 0.0%
yellow [10:29] 0 0.0%
greenyellow [30:49] 0 0.0%
lawngreen 50+ 35 100.%
All colors 35 100

Fuzz blockers

The followings are the branches where fuzzer fails to bypass.

Unique non-covered Complexity Unique Reachable Complexities Unique Reachable Functions All non-covered Complexity All Reachable Complexity Function Name Function Callsite Blocked Branch
0 0 None 4 34 compactCells call site: 00002 /src/h3/src/h3lib/lib/h3Index.c:479
0 0 None 2 32 compactCells call site: 00003 /src/h3/src/h3lib/lib/h3Index.c:484
0 0 None 2 32 compactCells call site: 00009 /src/h3/src/h3lib/lib/h3Index.c:581
0 0 None 0 0 cellToParent call site: 00004 /src/h3/src/h3lib/lib/h3Index.c:327
0 0 None 0 0 compactCells call site: 00002 /src/h3/src/h3lib/lib/h3Index.c:467

Runtime coverage analysis

Covered functions
18
Functions that are reachable but not covered
2
Reachable functions
20
Percentage of reachable functions covered
90.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.
Function name source code lines source lines hit percentage hit

Files reached

filename functions hit
apps/fuzzers/fuzzerCompact.c 1
h3lib/lib/h3Index.c 9
h3lib/lib/baseCells.c 1
h3lib/lib/mathExtensions.c 1
h3lib/lib/iterators.c 6

Fuzzer: fuzzerInternalCoordIjk

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 0 0.0%
gold [1:9] 0 0.0%
yellow [10:29] 0 0.0%
greenyellow [30:49] 0 0.0%
lawngreen 50+ 28 100.%
All colors 28 100

Fuzz blockers

The followings are the branches where fuzzer fails to bypass.

Unique non-covered Complexity Unique Reachable Complexities Unique Reachable Functions All non-covered Complexity All Reachable Complexity Function Name Function Callsite Blocked Branch
0 0 None 0 0 _ijkNormalize call site: 00014 /src/h3/src/h3lib/lib/coordijk.c:273

Runtime coverage analysis

Covered functions
7
Functions that are reachable but not covered
2
Reachable functions
9
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.
Function name source code lines source lines hit percentage hit

Files reached

filename functions hit
apps/fuzzers/fuzzerInternalCoordIjk.c 1
h3lib/lib/coordijk.c 4
h3lib/include/mathExtensions.h 2

Fuzzer: fuzzerEdgeLength

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 2 1.21%
gold [1:9] 1 0.60%
yellow [10:29] 8 4.84%
greenyellow [30:49] 8 4.84%
lawngreen 50+ 146 88.4%
All colors 165 100

Fuzz blockers

The followings are the branches where fuzzer fails to bypass.

Unique non-covered Complexity Unique Reachable Complexities Unique Reachable Functions All non-covered Complexity All Reachable Complexity Function Name Function Callsite Blocked Branch
0 0 None 0 36 _hex2dToGeo call site: 00115 /src/h3/src/h3lib/lib/faceijk.c:465
0 0 None 0 3 _geoAzDistanceRads call site: 00119 /src/h3/src/h3lib/lib/latLng.c:239
0 0 None 0 0 _ijkNormalize call site: 00024 /src/h3/src/h3lib/lib/coordijk.c:273
0 0 None 0 0 _hex2dToGeo call site: 00110 /src/h3/src/h3lib/lib/faceijk.c:442
0 0 None 0 0 _geoAzDistanceRads call site: 00118 /src/h3/src/h3lib/lib/latLng.c:229
0 0 None 0 0 _geoAzDistanceRads call site: 00125 /src/h3/src/h3lib/lib/latLng.c:262
0 0 None 0 0 _geoAzDistanceRads call site: 00125 /src/h3/src/h3lib/lib/latLng.c:266

Runtime coverage analysis

Covered functions
48
Functions that are reachable but not covered
8
Reachable functions
56
Percentage of reachable functions covered
85.71%
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.
Function name source code lines source lines hit percentage hit

Files reached

filename functions hit
apps/fuzzers/fuzzerEdgeLength.c 1
h3lib/lib/latLng.c 7
h3lib/lib/directedEdge.c 2
h3lib/lib/vertex.c 2
h3lib/lib/h3Index.c 7
h3lib/lib/baseCells.c 4
h3lib/lib/coordijk.c 15
h3lib/lib/faceijk.c 7
h3lib/lib/vec2d.c 3

Fuzzer: fuzzerIndexIO

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 0 0.0%
gold [1:9] 0 0.0%
yellow [10:29] 4 80.0%
greenyellow [30:49] 0 0.0%
lawngreen 50+ 1 20.0%
All colors 5 100

Fuzz blockers

The followings are the branches where fuzzer fails to bypass.

Unique non-covered Complexity Unique Reachable Complexities Unique Reachable Functions All non-covered Complexity All Reachable Complexity Function Name Function Callsite Blocked Branch
0 0 None 0 0 h3ToString call site: 00001 /src/h3/src/h3lib/lib/h3Index.c:114

Runtime coverage analysis

Covered functions
3
Functions that are reachable but not covered
2
Reachable functions
5
Percentage of reachable functions covered
60.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.
Function name source code lines source lines hit percentage hit

Files reached

filename functions hit
apps/fuzzers/fuzzerIndexIO.c 1
h3lib/lib/h3Index.c 2

Fuzzer: fuzzerDirectedEdge

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 6 2.75%
gold [1:9] 16 7.33%
yellow [10:29] 15 6.88%
greenyellow [30:49] 3 1.37%
lawngreen 50+ 178 81.6%
All colors 218 100

Fuzz blockers

The followings are the branches where fuzzer fails to bypass.

Unique non-covered Complexity Unique Reachable Complexities Unique Reachable Functions All non-covered Complexity All Reachable Complexity Function Name Function Callsite Blocked Branch
7 7 1 :

['getNumCells']

7 7 maxGridDiskSize call site: 00038 /src/h3/src/h3lib/lib/algos.c:172
0 0 None 0 175 gridDiskDistancesUnsafe call site: 00009 /src/h3/src/h3lib/lib/algos.c:677
0 0 None 0 166 gridDiskDistancesUnsafe call site: 00036 /src/h3/src/h3lib/lib/algos.c:722
0 0 None 0 85 gridDiskDistances call site: 00038 /src/h3/src/h3lib/lib/algos.c:236
0 0 None 0 85 gridDiskDistances call site: 00041 /src/h3/src/h3lib/lib/algos.c:238
0 0 None 0 36 _hex2dToGeo call site: 00178 /src/h3/src/h3lib/lib/faceijk.c:465
0 0 None 0 3 _geoAzDistanceRads call site: 00182 /src/h3/src/h3lib/lib/latLng.c:239
0 0 None 0 0 maxGridDiskSize call site: 00038 /src/h3/src/h3lib/lib/algos.c:169
0 0 None 0 0 gridDiskDistances call site: 00038 /src/h3/src/h3lib/lib/algos.c:229
0 0 None 0 0 _gridDiskDistancesInternal call site: 00044 /src/h3/src/h3lib/lib/algos.c:305
0 0 None 0 0 gridDiskDistancesUnsafe call site: 00009 /src/h3/src/h3lib/lib/algos.c:670
0 0 None 0 0 _ijkNormalize call site: 00087 /src/h3/src/h3lib/lib/coordijk.c:273

Runtime coverage analysis

Covered functions
68
Functions that are reachable but not covered
11
Reachable functions
79
Percentage of reachable functions covered
86.08%
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.
Function name source code lines source lines hit percentage hit

Files reached

filename functions hit
apps/fuzzers/fuzzerDirectedEdge.c 1
h3lib/lib/directedEdge.c 8
h3lib/lib/h3Index.c 16
h3lib/lib/baseCells.c 5
h3lib/lib/algos.c 7
h3lib/lib/coordijk.c 16
h3lib/lib/latLng.c 4
h3lib/lib/mathExtensions.c 1
h3lib/lib/vertex.c 2
h3lib/lib/faceijk.c 7
h3lib/lib/vec2d.c 3

Fuzzer: fuzzerCellToLatLng

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 1 0.68%
gold [1:9] 8 5.51%
yellow [10:29] 14 9.65%
greenyellow [30:49] 3 2.06%
lawngreen 50+ 119 82.0%
All colors 145 100

Fuzz blockers

The followings are the branches where fuzzer fails to bypass.

Unique non-covered Complexity Unique Reachable Complexities Unique Reachable Functions All non-covered Complexity All Reachable Complexity Function Name Function Callsite Blocked Branch
0 0 None 0 3 _geoAzDistanceRads call site: 00071 /src/h3/src/h3lib/lib/latLng.c:239
0 0 None 0 0 _isBaseCellPentagon call site: 00004 /src/h3/src/h3lib/lib/baseCells.c:825
0 0 None 0 0 _ijkNormalize call site: 00017 /src/h3/src/h3lib/lib/coordijk.c:273
0 0 None 0 0 _geoAzDistanceRads call site: 00070 /src/h3/src/h3lib/lib/latLng.c:229
0 0 None 0 0 _geoAzDistanceRads call site: 00077 /src/h3/src/h3lib/lib/latLng.c:262
0 0 None 0 0 _geoAzDistanceRads call site: 00077 /src/h3/src/h3lib/lib/latLng.c:266

Runtime coverage analysis

Covered functions
39
Functions that are reachable but not covered
8
Reachable functions
47
Percentage of reachable functions covered
82.98%
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.
Function name source code lines source lines hit percentage hit

Files reached

filename functions hit
apps/fuzzers/fuzzerCellToLatLng.c 1
h3lib/lib/h3Index.c 8
h3lib/lib/baseCells.c 1
h3lib/lib/coordijk.c 15
h3lib/lib/faceijk.c 8
h3lib/lib/vec2d.c 3
h3lib/lib/latLng.c 3

Fuzzer: fuzzerInternalAlgos

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 4 1.95%
gold [1:9] 0 0.0%
yellow [10:29] 1 0.48%
greenyellow [30:49] 5 2.43%
lawngreen 50+ 195 95.1%
All colors 205 100

Fuzz blockers

The followings are the branches where fuzzer fails to bypass.

Unique non-covered Complexity Unique Reachable Complexities Unique Reachable Functions All non-covered Complexity All Reachable Complexity Function Name Function Callsite Blocked Branch
0 0 None 0 36 _hex2dToGeo call site: 00131 /src/h3/src/h3lib/lib/faceijk.c:465
0 0 None 0 7 h3SetToVertexGraph call site: 00030 /src/h3/src/h3lib/lib/algos.c:1183
0 0 None 0 3 _geoAzDistanceRads call site: 00135 /src/h3/src/h3lib/lib/latLng.c:239
0 0 None 0 3 destroyLinkedMultiPolygon call site: 00203 /src/h3/src/h3lib/lib/linkedGeo.c:124
0 0 None 0 0 _ijkNormalize call site: 00050 /src/h3/src/h3lib/lib/coordijk.c:273
0 0 None 0 0 _hex2dToGeo call site: 00126 /src/h3/src/h3lib/lib/faceijk.c:442
0 0 None 0 0 _geoAzDistanceRads call site: 00134 /src/h3/src/h3lib/lib/latLng.c:229
0 0 None 0 0 _geoAzDistanceRads call site: 00141 /src/h3/src/h3lib/lib/latLng.c:262
0 0 None 0 0 _geoAzDistanceRads call site: 00141 /src/h3/src/h3lib/lib/latLng.c:266
0 0 None 0 0 initVertexGraph call site: 00031 /src/h3/src/h3lib/lib/vertexGraph.c:38
0 0 None 0 0 removeVertexNode call site: 00174 /src/h3/src/h3lib/lib/vertexGraph.c:155

Runtime coverage analysis

Covered functions
62
Functions that are reachable but not covered
11
Reachable functions
73
Percentage of reachable functions covered
84.93%
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.
Function name source code lines source lines hit percentage hit

Files reached

filename functions hit
apps/fuzzers/fuzzerInternalAlgos.c 1
h3lib/lib/algos.c 4
h3lib/lib/coordijk.c 16
h3lib/lib/h3Index.c 9
h3lib/lib/baseCells.c 3
h3lib/lib/vertexGraph.c 9
h3lib/lib/faceijk.c 7
h3lib/lib/vec2d.c 3
h3lib/lib/latLng.c 5
h3lib/lib/linkedGeo.c 5

Fuzzer: fuzzerGridDisk

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 1 1.29%
gold [1:9] 0 0.0%
yellow [10:29] 0 0.0%
greenyellow [30:49] 2 2.59%
lawngreen 50+ 74 96.1%
All colors 77 100

Fuzz blockers

The followings are the branches where fuzzer fails to bypass.

Unique non-covered Complexity Unique Reachable Complexities Unique Reachable Functions All non-covered Complexity All Reachable Complexity Function Name Function Callsite Blocked Branch
0 0 None 2 87 _gridRingInternal call site: 00070 /src/h3/src/h3lib/lib/algos.c:406
0 0 None 0 85 gridDiskDistances call site: 00039 /src/h3/src/h3lib/lib/algos.c:238
0 0 None 0 85 _gridRingInternal call site: 00071 /src/h3/src/h3lib/lib/algos.c:410
0 0 None 0 0 gridDiskDistances call site: 00038 /src/h3/src/h3lib/lib/algos.c:229
0 0 None 0 0 gridDiskDistancesSafe call site: 00053 /src/h3/src/h3lib/lib/algos.c:331
0 0 None 0 0 _gridRingInternal call site: 00068 /src/h3/src/h3lib/lib/algos.c:394
0 0 None 0 0 _gridRingInternal call site: 00069 /src/h3/src/h3lib/lib/algos.c:401
0 0 None 0 0 h3NeighborRotations call site: 00011 /src/h3/src/h3lib/lib/algos.c:453
0 0 None 0 0 gridDiskDistancesUnsafe call site: 00007 /src/h3/src/h3lib/lib/algos.c:670
0 0 None 0 0 gridDisksUnsafe call site: 00075 /src/h3/src/h3lib/lib/algos.c:764
0 0 None 0 0 gridRingUnsafe call site: 00059 /src/h3/src/h3lib/lib/algos.c:790
0 0 None 0 0 getNumCells call site: 00002 /src/h3/src/h3lib/lib/latLng.c:349

Runtime coverage analysis

Covered functions
26
Functions that are reachable but not covered
2
Reachable functions
28
Percentage of reachable functions covered
92.86%
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.
Function name source code lines source lines hit percentage hit

Files reached

filename functions hit
apps/fuzzers/fuzzerGridDisk.c 1
h3lib/lib/algos.c 12
h3lib/lib/latLng.c 1
h3lib/lib/mathExtensions.c 1
h3lib/lib/h3Index.c 6
h3lib/lib/baseCells.c 3
h3lib/lib/coordijk.c 2

Fuzzer: fuzzerPolygonToCells

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 25 8.89%
gold [1:9] 0 0.0%
yellow [10:29] 0 0.0%
greenyellow [30:49] 0 0.0%
lawngreen 50+ 256 91.1%
All colors 281 100

Fuzz blockers

The followings are the branches where fuzzer fails to bypass.

Unique non-covered Complexity Unique Reachable Complexities Unique Reachable Functions All non-covered Complexity All Reachable Complexity Function Name Function Callsite Blocked Branch
107 107 1 :

['_faceIjkToCellBoundary']

107 107 cellToBoundary call site: 00099 /src/h3/src/h3lib/lib/h3Index.c:1083
7 7 1 :

['getNumCells']

7 7 maxGridDiskSize call site: 00265 /src/h3/src/h3lib/lib/algos.c:172
0 0 None 4 1170 polygonToCells call site: 00167 /src/h3/src/h3lib/lib/algos.c:1017
0 0 None 2 924 polygonToCells call site: 00172 /src/h3/src/h3lib/lib/algos.c:1032
0 0 None 0 922 polygonToCells call site: 00173 /src/h3/src/h3lib/lib/algos.c:1037
0 0 None 0 175 gridDiskDistancesUnsafe call site: 00241 /src/h3/src/h3lib/lib/algos.c:677
0 0 None 0 166 gridDiskDistancesUnsafe call site: 00263 /src/h3/src/h3lib/lib/algos.c:722
0 0 None 0 85 gridDiskDistances call site: 00265 /src/h3/src/h3lib/lib/algos.c:236
0 0 None 0 85 gridDiskDistances call site: 00268 /src/h3/src/h3lib/lib/algos.c:238
0 0 None 0 3 _geoAzDistanceRads call site: 00083 /src/h3/src/h3lib/lib/latLng.c:239
0 0 None 0 0 pointInsideGeoLoop call site: 00278 /src/h3/src/h3lib/include/polygonAlgos.h:105
0 0 None 0 0 pointInsideGeoLoop call site: 00278 /src/h3/src/h3lib/include/polygonAlgos.h:120

Runtime coverage analysis

Covered functions
81
Functions that are reachable but not covered
16
Reachable functions
97
Percentage of reachable functions covered
83.51%
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.
Function name source code lines source lines hit percentage hit

Files reached

filename functions hit
apps/fuzzers/fuzzerPolygonToCells.c 3
h3lib/lib/algos.c 9
h3lib/lib/polygon.c 3
h3lib/include/polygonAlgos.h 2
h3lib/lib/bbox.c 5
h3lib/lib/h3Index.c 14
h3lib/lib/baseCells.c 5
h3lib/lib/coordijk.c 20
h3lib/lib/faceijk.c 11
h3lib/lib/vec2d.c 3
h3lib/lib/latLng.c 7
h3lib/lib/vec3d.c 3
h3lib/lib/mathExtensions.c 1

Fuzzer: fuzzerPolygonToCellsExperimentalNoHoles

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 15 4.60%
gold [1:9] 0 0.0%
yellow [10:29] 1 0.30%
greenyellow [30:49] 0 0.0%
lawngreen 50+ 310 95.0%
All colors 326 100

Fuzz blockers

The followings are the branches where fuzzer fails to bypass.

Unique non-covered Complexity Unique Reachable Complexities Unique Reachable Functions All non-covered Complexity All Reachable Complexity Function Name Function Callsite Blocked Branch
0 0 None 0 147 latLngToCell call site: 00120 /src/h3/src/h3lib/lib/h3Index.c:952
0 0 None 0 16 _iterInitPolygonCompact call site: 00010 /src/h3/src/h3lib/lib/polyfill.c:351
0 0 None 0 5 iterStepPolygonCompact call site: 00028 /src/h3/src/h3lib/lib/polyfill.c:441
0 0 None 0 5 iterStepPolygonCompact call site: 00181 /src/h3/src/h3lib/lib/polyfill.c:487
0 0 None 0 5 iterStepPolygonCompact call site: 00272 /src/h3/src/h3lib/lib/polyfill.c:525
0 0 None 0 5 iterStepPolygonCompact call site: 00284 /src/h3/src/h3lib/lib/polyfill.c:553
0 0 None 0 5 iterStepPolygonCompact call site: 00290 /src/h3/src/h3lib/lib/polyfill.c:575
0 0 None 0 5 _iterInitPolygonCompact call site: 00008 /src/h3/src/h3lib/lib/polyfill.c:343
0 0 None 0 3 _geoAzDistanceRads call site: 00098 /src/h3/src/h3lib/lib/latLng.c:239
0 0 None 0 0 pointInsideGeoLoop call site: 00117 /src/h3/src/h3lib/include/polygonAlgos.h:105
0 0 None 0 0 pointInsideGeoLoop call site: 00117 /src/h3/src/h3lib/include/polygonAlgos.h:120
0 0 None 0 0 _isBaseCellPentagon call site: 00025 /src/h3/src/h3lib/lib/baseCells.c:825

Runtime coverage analysis

Covered functions
105
Functions that are reachable but not covered
11
Reachable functions
116
Percentage of reachable functions covered
90.52%
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.
Function name source code lines source lines hit percentage hit

Files reached

filename functions hit
apps/fuzzers/fuzzerPolygonToCellsExperimentalNoHoles.c 2
h3lib/lib/polyfill.c 14
h3lib/lib/h3Index.c 17
h3lib/lib/polygon.c 7
h3lib/include/polygonAlgos.h 2
h3lib/lib/bbox.c 9
h3lib/lib/latLng.c 6
h3lib/lib/baseCells.c 4
h3lib/lib/coordijk.c 20
h3lib/lib/faceijk.c 11
h3lib/lib/vec2d.c 3
h3lib/lib/vec3d.c 3
h3lib/lib/mathExtensions.c 1
h3lib/lib/iterators.c 6

Fuzzer: fuzzerHierarchy

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 0 0.0%
gold [1:9] 1 3.57%
yellow [10:29] 2 7.14%
greenyellow [30:49] 0 0.0%
lawngreen 50+ 25 89.2%
All colors 28 100

Runtime coverage analysis

Covered functions
18
Functions that are reachable but not covered
1
Reachable functions
19
Percentage of reachable functions covered
94.74%
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.
Function name source code lines source lines hit percentage hit

Files reached

filename functions hit
apps/fuzzers/fuzzerHierarchy.c 1
h3lib/lib/h3Index.c 9
h3lib/lib/baseCells.c 1
h3lib/lib/mathExtensions.c 1
h3lib/lib/iterators.c 6

Fuzzer: fuzzerCellProperties

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 0 0.0%
gold [1:9] 2 1.80%
yellow [10:29] 7 6.30%
greenyellow [30:49] 10 9.00%
lawngreen 50+ 92 82.8%
All colors 111 100

Fuzz blockers

The followings are the branches where fuzzer fails to bypass.

Unique non-covered Complexity Unique Reachable Complexities Unique Reachable Functions All non-covered Complexity All Reachable Complexity Function Name Function Callsite Blocked Branch
0 0 None 0 50 _faceIjkPentToVerts call site: 00079 /src/h3/src/h3lib/lib/faceijk.c:635
0 0 None 0 0 _ijkNormalize call site: 00036 /src/h3/src/h3lib/lib/coordijk.c:273

Runtime coverage analysis

Covered functions
38
Functions that are reachable but not covered
3
Reachable functions
41
Percentage of reachable functions covered
92.68%
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.
Function name source code lines source lines hit percentage hit

Files reached

filename functions hit
apps/fuzzers/fuzzerCellProperties.c 1
h3lib/lib/h3Index.c 18
h3lib/lib/baseCells.c 1
h3lib/lib/coordijk.c 14
h3lib/lib/faceijk.c 4

Fuzzer: fuzzerPolygonToCellsNoHoles

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 28 10.1%
gold [1:9] 0 0.0%
yellow [10:29] 0 0.0%
greenyellow [30:49] 0 0.0%
lawngreen 50+ 249 89.8%
All colors 277 100

Fuzz blockers

The followings are the branches where fuzzer fails to bypass.

Unique non-covered Complexity Unique Reachable Complexities Unique Reachable Functions All non-covered Complexity All Reachable Complexity Function Name Function Callsite Blocked Branch
107 107 1 :

['_faceIjkToCellBoundary']

107 107 cellToBoundary call site: 00096 /src/h3/src/h3lib/lib/h3Index.c:1083
7 7 1 :

['getNumCells']

7 7 maxGridDiskSize call site: 00262 /src/h3/src/h3lib/lib/algos.c:172
0 0 None 4 1170 polygonToCells call site: 00164 /src/h3/src/h3lib/lib/algos.c:1017
0 0 None 2 924 polygonToCells call site: 00169 /src/h3/src/h3lib/lib/algos.c:1032
0 0 None 0 922 polygonToCells call site: 00170 /src/h3/src/h3lib/lib/algos.c:1037
0 0 None 0 175 gridDiskDistancesUnsafe call site: 00238 /src/h3/src/h3lib/lib/algos.c:677
0 0 None 0 166 gridDiskDistancesUnsafe call site: 00260 /src/h3/src/h3lib/lib/algos.c:722
0 0 None 0 85 gridDiskDistances call site: 00262 /src/h3/src/h3lib/lib/algos.c:236
0 0 None 0 85 gridDiskDistances call site: 00265 /src/h3/src/h3lib/lib/algos.c:238
0 0 None 0 3 _geoAzDistanceRads call site: 00080 /src/h3/src/h3lib/lib/latLng.c:239
0 0 None 0 0 pointInsideGeoLoop call site: 00275 /src/h3/src/h3lib/include/polygonAlgos.h:105
0 0 None 0 0 pointInsideGeoLoop call site: 00275 /src/h3/src/h3lib/include/polygonAlgos.h:120

Runtime coverage analysis

Covered functions
80
Functions that are reachable but not covered
16
Reachable functions
96
Percentage of reachable functions covered
83.33%
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.
Function name source code lines source lines hit percentage hit

Files reached

filename functions hit
apps/fuzzers/fuzzerPolygonToCellsNoHoles.c 2
h3lib/lib/algos.c 9
h3lib/lib/polygon.c 3
h3lib/include/polygonAlgos.h 2
h3lib/lib/bbox.c 5
h3lib/lib/h3Index.c 14
h3lib/lib/baseCells.c 5
h3lib/lib/coordijk.c 20
h3lib/lib/faceijk.c 11
h3lib/lib/vec2d.c 3
h3lib/lib/latLng.c 7
h3lib/lib/vec3d.c 3
h3lib/lib/mathExtensions.c 1

Fuzzer: fuzzerCellToChildPos

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 0 0.0%
gold [1:9] 0 0.0%
yellow [10:29] 0 0.0%
greenyellow [30:49] 0 0.0%
lawngreen 50+ 24 100.%
All colors 24 100

Fuzz blockers

The followings are the branches where fuzzer fails to bypass.

Unique non-covered Complexity Unique Reachable Complexities Unique Reachable Functions All non-covered Complexity All Reachable Complexity Function Name Function Callsite Blocked Branch
0 0 None 0 0 _hasChildAtRes call site: 00013 /src/h3/src/h3lib/lib/h3Index.c:354

Runtime coverage analysis

Covered functions
11
Functions that are reachable but not covered
1
Reachable functions
12
Percentage of reachable functions covered
91.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.
Function name source code lines source lines hit percentage hit

Files reached

filename functions hit
apps/fuzzers/fuzzerCellToChildPos.c 1
h3lib/lib/h3Index.c 8
h3lib/lib/baseCells.c 1
h3lib/lib/mathExtensions.c 1

Fuzzer: fuzzerResolutions

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 0 0.0%
gold [1:9] 0 0.0%
yellow [10:29] 1 10.0%
greenyellow [30:49] 0 0.0%
lawngreen 50+ 9 90.0%
All colors 10 100

Fuzz blockers

The followings are the branches where fuzzer fails to bypass.

Unique non-covered Complexity Unique Reachable Complexities Unique Reachable Functions All non-covered Complexity All Reachable Complexity Function Name Function Callsite Blocked Branch
0 0 None 0 0 _isBaseCellPentagon call site: 00008 /src/h3/src/h3lib/lib/baseCells.c:825

Runtime coverage analysis

Covered functions
10
Functions that are reachable but not covered
0
Reachable functions
10
Percentage of reachable functions covered
100.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.
Function name source code lines source lines hit percentage hit

Files reached

filename functions hit
apps/fuzzers/fuzzerResolutions.c 1
h3lib/lib/latLng.c 5
h3lib/lib/mathExtensions.c 1
h3lib/lib/h3Index.c 2
h3lib/lib/baseCells.c 1

Fuzzer: fuzzerCellArea

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 1 0.60%
gold [1:9] 1 0.60%
yellow [10:29] 6 3.65%
greenyellow [30:49] 8 4.87%
lawngreen 50+ 148 90.2%
All colors 164 100

Fuzz blockers

The followings are the branches where fuzzer fails to bypass.

Unique non-covered Complexity Unique Reachable Complexities Unique Reachable Functions All non-covered Complexity All Reachable Complexity Function Name Function Callsite Blocked Branch
0 0 None 0 3 _geoAzDistanceRads call site: 00072 /src/h3/src/h3lib/lib/latLng.c:239
0 0 None 0 0 _isBaseCellPentagon call site: 00005 /src/h3/src/h3lib/lib/baseCells.c:825
0 0 None 0 0 _ijkNormalize call site: 00018 /src/h3/src/h3lib/lib/coordijk.c:273
0 0 None 0 0 cellToBoundary call site: 00087 /src/h3/src/h3lib/lib/h3Index.c:1080
0 0 None 0 0 _geoAzDistanceRads call site: 00071 /src/h3/src/h3lib/lib/latLng.c:229
0 0 None 0 0 _geoAzDistanceRads call site: 00078 /src/h3/src/h3lib/lib/latLng.c:262
0 0 None 0 0 _geoAzDistanceRads call site: 00078 /src/h3/src/h3lib/lib/latLng.c:266

Runtime coverage analysis

Covered functions
45
Functions that are reachable but not covered
9
Reachable functions
54
Percentage of reachable functions covered
83.33%
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.
Function name source code lines source lines hit percentage hit

Files reached

filename functions hit
apps/fuzzers/fuzzerCellArea.c 1
h3lib/lib/latLng.c 9
h3lib/lib/h3Index.c 8
h3lib/lib/baseCells.c 1
h3lib/lib/coordijk.c 15
h3lib/lib/faceijk.c 8
h3lib/lib/vec2d.c 3

Fuzzer: fuzzerLatLngToCell

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 0 0.0%
gold [1:9] 1 1.31%
yellow [10:29] 2 2.63%
greenyellow [30:49] 2 2.63%
lawngreen 50+ 71 93.4%
All colors 76 100

Fuzz blockers

The followings are the branches where fuzzer fails to bypass.

Unique non-covered Complexity Unique Reachable Complexities Unique Reachable Functions All non-covered Complexity All Reachable Complexity Function Name Function Callsite Blocked Branch
0 0 None 0 0 _isBaseCellPentagon call site: 00063 /src/h3/src/h3lib/lib/baseCells.c:825
0 0 None 0 0 _geoToHex2d call site: 00013 /src/h3/src/h3lib/lib/faceijk.c:398
0 0 None 0 0 _faceIjkToH3 call site: 00031 /src/h3/src/h3lib/lib/h3Index.c:859
0 0 None 0 0 _faceIjkToH3 call site: 00058 /src/h3/src/h3lib/lib/h3Index.c:903

Runtime coverage analysis

Covered functions
33
Functions that are reachable but not covered
7
Reachable functions
40
Percentage of reachable functions covered
82.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.
Function name source code lines source lines hit percentage hit

Files reached

filename functions hit
apps/fuzzers/fuzzerLatLngToCell.c 1
h3lib/lib/h3Index.c 7
h3lib/lib/faceijk.c 3
h3lib/lib/vec3d.c 3
h3lib/lib/latLng.c 2
h3lib/lib/coordijk.c 13
h3lib/lib/baseCells.c 4

Fuzzer: fuzzerLocalIj

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 0 0.0%
gold [1:9] 0 0.0%
yellow [10:29] 0 0.0%
greenyellow [30:49] 0 0.0%
lawngreen 50+ 159 100.%
All colors 159 100

Fuzz blockers

The followings are the branches where fuzzer fails to bypass.

Unique non-covered Complexity Unique Reachable Complexities Unique Reachable Functions All non-covered Complexity All Reachable Complexity Function Name Function Callsite Blocked Branch
0 0 None 0 0 _isBaseCellPentagon call site: 00010 /src/h3/src/h3lib/lib/baseCells.c:825
0 0 None 0 0 gridPathCells call site: 00071 /src/h3/src/h3lib/lib/localij.c:681

Runtime coverage analysis

Covered functions
43
Functions that are reachable but not covered
3
Reachable functions
46
Percentage of reachable functions covered
93.48%
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.
Function name source code lines source lines hit percentage hit

Files reached

filename functions hit
apps/fuzzers/fuzzerLocalIj.c 2
h3lib/lib/localij.c 8
h3lib/lib/baseCells.c 4
h3lib/lib/h3Index.c 7
h3lib/lib/coordijk.c 20
h3lib/include/mathExtensions.h 2

Fuzzer: fuzzerVertexes

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 20 9.95%
gold [1:9] 11 5.47%
yellow [10:29] 1 0.49%
greenyellow [30:49] 3 1.49%
lawngreen 50+ 166 82.5%
All colors 201 100

Fuzz blockers

The followings are the branches where fuzzer fails to bypass.

Unique non-covered Complexity Unique Reachable Complexities Unique Reachable Functions All non-covered Complexity All Reachable Complexity Function Name Function Callsite Blocked Branch
0 0 None 0 36 _hex2dToGeo call site: 00153 /src/h3/src/h3lib/lib/faceijk.c:465
0 0 None 0 3 _geoAzDistanceRads call site: 00157 /src/h3/src/h3lib/lib/latLng.c:239
0 0 None 0 0 h3NeighborRotations call site: 00073 /src/h3/src/h3lib/lib/algos.c:453
0 0 None 0 0 h3NeighborRotations call site: 00085 /src/h3/src/h3lib/lib/algos.c:545
0 0 None 0 0 _ijkNormalize call site: 00023 /src/h3/src/h3lib/lib/coordijk.c:273
0 0 None 0 0 _hex2dToGeo call site: 00148 /src/h3/src/h3lib/lib/faceijk.c:442
0 0 None 0 0 _geoAzDistanceRads call site: 00156 /src/h3/src/h3lib/lib/latLng.c:229
0 0 None 0 0 _geoAzDistanceRads call site: 00163 /src/h3/src/h3lib/lib/latLng.c:262
0 0 None 0 0 _geoAzDistanceRads call site: 00163 /src/h3/src/h3lib/lib/latLng.c:266
0 0 None 0 0 vertexNumForDirection call site: 00105 /src/h3/src/h3lib/lib/vertex.c:138
0 0 None 0 0 directionForVertexNum call site: 00006 /src/h3/src/h3lib/lib/vertex.c:174

Runtime coverage analysis

Covered functions
57
Functions that are reachable but not covered
10
Reachable functions
67
Percentage of reachable functions covered
85.07%
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.
Function name source code lines source lines hit percentage hit

Files reached

filename functions hit
apps/fuzzers/fuzzerVertexes.c 1
h3lib/lib/vertex.c 7
h3lib/lib/h3Index.c 15
h3lib/lib/baseCells.c 5
h3lib/lib/coordijk.c 16
h3lib/lib/faceijk.c 7
h3lib/lib/algos.c 2
h3lib/lib/vec2d.c 3
h3lib/lib/latLng.c 3

Fuzzer: fuzzerPolygonToCellsExperimental

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 11 3.33%
gold [1:9] 0 0.0%
yellow [10:29] 0 0.0%
greenyellow [30:49] 2 0.60%
lawngreen 50+ 317 96.0%
All colors 330 100

Fuzz blockers

The followings are the branches where fuzzer fails to bypass.

Unique non-covered Complexity Unique Reachable Complexities Unique Reachable Functions All non-covered Complexity All Reachable Complexity Function Name Function Callsite Blocked Branch
0 12 1 :

['_h3Rotate60ccw']

0 33 _faceIjkToH3 call site: 00172 /src/h3/src/h3lib/lib/h3Index.c:920
0 0 None 0 147 latLngToCell call site: 00123 /src/h3/src/h3lib/lib/h3Index.c:952
0 0 None 0 16 _iterInitPolygonCompact call site: 00013 /src/h3/src/h3lib/lib/polyfill.c:351
0 0 None 0 5 iterStepPolygonCompact call site: 00031 /src/h3/src/h3lib/lib/polyfill.c:441
0 0 None 0 5 iterStepPolygonCompact call site: 00184 /src/h3/src/h3lib/lib/polyfill.c:487
0 0 None 0 5 iterStepPolygonCompact call site: 00275 /src/h3/src/h3lib/lib/polyfill.c:525
0 0 None 0 5 iterStepPolygonCompact call site: 00287 /src/h3/src/h3lib/lib/polyfill.c:553
0 0 None 0 5 iterStepPolygonCompact call site: 00293 /src/h3/src/h3lib/lib/polyfill.c:575
0 0 None 0 5 _iterInitPolygonCompact call site: 00011 /src/h3/src/h3lib/lib/polyfill.c:343
0 0 None 0 3 _geoAzDistanceRads call site: 00101 /src/h3/src/h3lib/lib/latLng.c:239
0 0 None 0 0 pointInsideGeoLoop call site: 00120 /src/h3/src/h3lib/include/polygonAlgos.h:105
0 0 None 0 0 pointInsideGeoLoop call site: 00120 /src/h3/src/h3lib/include/polygonAlgos.h:120

Runtime coverage analysis

Covered functions
106
Functions that are reachable but not covered
11
Reachable functions
117
Percentage of reachable functions covered
90.6%
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.
Function name source code lines source lines hit percentage hit

Files reached

filename functions hit
apps/fuzzers/fuzzerPolygonToCellsExperimental.c 3
h3lib/lib/polyfill.c 14
h3lib/lib/h3Index.c 17
h3lib/lib/polygon.c 7
h3lib/include/polygonAlgos.h 2
h3lib/lib/bbox.c 9
h3lib/lib/latLng.c 6
h3lib/lib/baseCells.c 4
h3lib/lib/coordijk.c 20
h3lib/lib/faceijk.c 11
h3lib/lib/vec2d.c 3
h3lib/lib/vec3d.c 3
h3lib/lib/mathExtensions.c 1
h3lib/lib/iterators.c 6

Fuzzer: fuzzerCellsToLinkedMultiPolygon

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 2 0.97%
gold [1:9] 1 0.48%
yellow [10:29] 0 0.0%
greenyellow [30:49] 0 0.0%
lawngreen 50+ 203 98.5%
All colors 206 100

Fuzz blockers

The followings are the branches where fuzzer fails to bypass.

Unique non-covered Complexity Unique Reachable Complexities Unique Reachable Functions All non-covered Complexity All Reachable Complexity Function Name Function Callsite Blocked Branch
0 0 None 0 36 _hex2dToGeo call site: 00106 /src/h3/src/h3lib/lib/faceijk.c:465
0 0 None 0 3 _geoAzDistanceRads call site: 00110 /src/h3/src/h3lib/lib/latLng.c:239
0 0 None 0 0 _isBaseCellPentagon call site: 00010 /src/h3/src/h3lib/lib/baseCells.c:825
0 0 None 0 0 _ijkNormalize call site: 00023 /src/h3/src/h3lib/lib/coordijk.c:273
0 0 None 0 0 _hex2dToGeo call site: 00101 /src/h3/src/h3lib/lib/faceijk.c:442
0 0 None 0 0 _geoAzDistanceRads call site: 00109 /src/h3/src/h3lib/lib/latLng.c:229
0 0 None 0 0 _geoAzDistanceRads call site: 00116 /src/h3/src/h3lib/lib/latLng.c:262
0 0 None 0 0 _geoAzDistanceRads call site: 00116 /src/h3/src/h3lib/lib/latLng.c:266
0 0 None 0 0 normalizeMultiPolygon call site: 00178 /src/h3/src/h3lib/lib/linkedGeo.c:296
0 0 None 0 0 removeVertexNode call site: 00149 /src/h3/src/h3lib/lib/vertexGraph.c:155

Runtime coverage analysis

Covered functions
68
Functions that are reachable but not covered
11
Reachable functions
79
Percentage of reachable functions covered
86.08%
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.
Function name source code lines source lines hit percentage hit

Files reached

filename functions hit
apps/fuzzers/fuzzerCellsToLinkedMultiPolygon.c 1
h3lib/lib/algos.c 3
h3lib/lib/vertexGraph.c 9
h3lib/lib/h3Index.c 7
h3lib/lib/baseCells.c 1
h3lib/lib/coordijk.c 15
h3lib/lib/faceijk.c 7
h3lib/lib/vec2d.c 3
h3lib/lib/latLng.c 5
h3lib/lib/linkedGeo.c 11
h3lib/include/polygonAlgos.h 4
h3lib/lib/bbox.c 2

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.

apps/fuzzers/fuzzerDistances.c

Dictionary

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


apps/fuzzers/fuzzerCompact.c

Dictionary

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


apps/fuzzers/fuzzerInternalCoordIjk.c

Dictionary

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


apps/fuzzers/fuzzerEdgeLength.c

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=['_hex2dToGeo', '_geoAzDistanceRads']

apps/fuzzers/fuzzerIndexIO.c

Dictionary

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


apps/fuzzers/fuzzerDirectedEdge.c

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=['gridDiskDistances', '_h3Rotate60cw', '_gridDiskDistancesInternal', '_hex2dToGeo', '_geoAzDistanceRads']

apps/fuzzers/fuzzerCellToLatLng.c

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=['_geoAzDistanceRads']

apps/fuzzers/fuzzerInternalAlgos.c

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=['_h3Rotate60cw', 'LLVMFuzzerTestOneInput', '_hex2dToGeo', '_geoAzDistanceRads']

apps/fuzzers/fuzzerGridDisk.c

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=['_h3Rotate60cw']

apps/fuzzers/fuzzerPolygonToCells.c

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=['_faceIjkPentToCellBoundary', 'gridDiskDistances', '_geoAzDistanceRads', 'h3NeighborRotations', '_gridDiskDistancesInternal']

apps/fuzzers/fuzzerPolygonToCellsExperimentalNoHoles.c

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=['cellBoundaryCrossesGeoLoop', '_iterInitPolygonCompact', 'bboxesFromGeoPolygon', '_geoAzDistanceRads', 'pointInsideGeoLoop', 'iterStepPolygonCompact', '_faceIjkToCellBoundary']

apps/fuzzers/fuzzerHierarchy.c

Dictionary

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


apps/fuzzers/fuzzerCellProperties.c

Dictionary

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


apps/fuzzers/fuzzerPolygonToCellsNoHoles.c

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=['_faceIjkPentToCellBoundary', 'gridDiskDistances', '_geoAzDistanceRads', 'bboxesFromGeoPolygon', 'latLngToCell', 'h3NeighborRotations', '_gridDiskDistancesInternal', 'pointInsideGeoLoop']

apps/fuzzers/fuzzerCellToChildPos.c

Dictionary

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


apps/fuzzers/fuzzerResolutions.c

Dictionary

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


apps/fuzzers/fuzzerCellArea.c

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=['_geoAzDistanceRads']

apps/fuzzers/fuzzerLatLngToCell.c

Dictionary

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


apps/fuzzers/fuzzerLocalIj.c

Dictionary

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


apps/fuzzers/fuzzerVertexes.c

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=['_faceIjkPentToCellBoundary', '_faceIjkToCellBoundary', 'cellToVertex', 'h3NeighborRotations', '_hex2dToGeo', '_geoAzDistanceRads']

apps/fuzzers/fuzzerPolygonToCellsExperimental.c

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=['_iterInitPolygonCompact', '_geoAzDistanceRads', '_faceIjkToH3', 'iterStepPolygonCompact', '_faceIjkToCellBoundary']

apps/fuzzers/fuzzerCellsToLinkedMultiPolygon.c

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=['_hex2dToGeo', '_geoAzDistanceRads']

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/h3/src/h3lib/lib/coordijk.c ['fuzzerInternalCoordIjk', 'fuzzerEdgeLength', 'fuzzerDirectedEdge', 'fuzzerCellToLatLng', 'fuzzerInternalAlgos', 'fuzzerGridDisk', 'fuzzerPolygonToCells', 'fuzzerPolygonToCellsExperimentalNoHoles', 'fuzzerCellProperties', 'fuzzerPolygonToCellsNoHoles', 'fuzzerCellArea', 'fuzzerLatLngToCell', 'fuzzerLocalIj', 'fuzzerVertexes', 'fuzzerPolygonToCellsExperimental', 'fuzzerCellsToLinkedMultiPolygon'] ['fuzzerInternalCoordIjk', 'fuzzerEdgeLength', 'fuzzerDirectedEdge', 'fuzzerCellToLatLng', 'fuzzerInternalAlgos', 'fuzzerGridDisk', 'fuzzerPolygonToCells', 'fuzzerPolygonToCellsExperimentalNoHoles', 'fuzzerCellProperties', 'fuzzerPolygonToCellsNoHoles', 'fuzzerCellArea', 'fuzzerLatLngToCell', 'fuzzerLocalIj', 'fuzzerVertexes', 'fuzzerPolygonToCellsExperimental', 'fuzzerCellsToLinkedMultiPolygon']
/src/h3/src/h3lib/lib/algos.c ['fuzzerDirectedEdge', 'fuzzerInternalAlgos', 'fuzzerGridDisk', 'fuzzerPolygonToCells', 'fuzzerPolygonToCellsNoHoles', 'fuzzerVertexes', 'fuzzerCellsToLinkedMultiPolygon'] ['fuzzerDirectedEdge', 'fuzzerInternalAlgos', 'fuzzerGridDisk', 'fuzzerPolygonToCells', 'fuzzerPolygonToCellsNoHoles', 'fuzzerVertexes', 'fuzzerCellsToLinkedMultiPolygon']
/src/h3/src/apps/fuzzers/fuzzerGridDisk.c ['fuzzerGridDisk'] ['fuzzerGridDisk']
/src/h3/src/h3lib/lib/linkedGeo.c ['fuzzerInternalAlgos', 'fuzzerCellsToLinkedMultiPolygon'] ['fuzzerInternalAlgos', 'fuzzerCellsToLinkedMultiPolygon']
/src/h3/src/apps/fuzzers/fuzzerInternalAlgos.c ['fuzzerInternalAlgos'] ['fuzzerInternalAlgos']
/src/h3/src/h3lib/lib/directedEdge.c ['fuzzerEdgeLength', 'fuzzerDirectedEdge'] ['fuzzerEdgeLength', 'fuzzerDirectedEdge']
/src/h3/src/h3lib/include/polygonAlgos.h ['fuzzerPolygonToCells', 'fuzzerPolygonToCellsExperimentalNoHoles', 'fuzzerPolygonToCellsNoHoles', 'fuzzerPolygonToCellsExperimental', 'fuzzerCellsToLinkedMultiPolygon'] ['fuzzerPolygonToCells', 'fuzzerPolygonToCellsExperimentalNoHoles', 'fuzzerPolygonToCellsNoHoles', 'fuzzerPolygonToCellsExperimental', 'fuzzerCellsToLinkedMultiPolygon']
/src/h3/src/apps/fuzzers/fuzzerCompact.c ['fuzzerCompact'] ['fuzzerCompact']
/src/h3/src/apps/fuzzers/fuzzerHierarchy.c ['fuzzerHierarchy'] ['fuzzerHierarchy']
/src/h3/src/h3lib/lib/faceijk.c ['fuzzerEdgeLength', 'fuzzerDirectedEdge', 'fuzzerCellToLatLng', 'fuzzerInternalAlgos', 'fuzzerPolygonToCells', 'fuzzerPolygonToCellsExperimentalNoHoles', 'fuzzerCellProperties', 'fuzzerPolygonToCellsNoHoles', 'fuzzerCellArea', 'fuzzerLatLngToCell', 'fuzzerVertexes', 'fuzzerPolygonToCellsExperimental', 'fuzzerCellsToLinkedMultiPolygon'] ['fuzzerEdgeLength', 'fuzzerDirectedEdge', 'fuzzerCellToLatLng', 'fuzzerInternalAlgos', 'fuzzerPolygonToCells', 'fuzzerPolygonToCellsExperimentalNoHoles', 'fuzzerCellProperties', 'fuzzerPolygonToCellsNoHoles', 'fuzzerCellArea', 'fuzzerLatLngToCell', 'fuzzerVertexes', 'fuzzerPolygonToCellsExperimental', 'fuzzerCellsToLinkedMultiPolygon']
/src/h3/src/h3lib/lib/baseCells.c ['fuzzerCompact', 'fuzzerEdgeLength', 'fuzzerDirectedEdge', 'fuzzerCellToLatLng', 'fuzzerInternalAlgos', 'fuzzerGridDisk', 'fuzzerPolygonToCells', 'fuzzerPolygonToCellsExperimentalNoHoles', 'fuzzerHierarchy', 'fuzzerCellProperties', 'fuzzerPolygonToCellsNoHoles', 'fuzzerCellToChildPos', 'fuzzerResolutions', 'fuzzerCellArea', 'fuzzerLatLngToCell', 'fuzzerLocalIj', 'fuzzerVertexes', 'fuzzerPolygonToCellsExperimental', 'fuzzerCellsToLinkedMultiPolygon'] ['fuzzerCompact', 'fuzzerEdgeLength', 'fuzzerDirectedEdge', 'fuzzerCellToLatLng', 'fuzzerInternalAlgos', 'fuzzerGridDisk', 'fuzzerPolygonToCells', 'fuzzerPolygonToCellsExperimentalNoHoles', 'fuzzerHierarchy', 'fuzzerCellProperties', 'fuzzerPolygonToCellsNoHoles', 'fuzzerCellToChildPos', 'fuzzerResolutions', 'fuzzerCellArea', 'fuzzerLatLngToCell', 'fuzzerLocalIj', 'fuzzerVertexes', 'fuzzerPolygonToCellsExperimental', 'fuzzerCellsToLinkedMultiPolygon']
/src/h3/src/h3lib/lib/iterators.c ['fuzzerCompact', 'fuzzerPolygonToCellsExperimentalNoHoles', 'fuzzerHierarchy', 'fuzzerPolygonToCellsExperimental'] ['fuzzerCompact', 'fuzzerPolygonToCellsExperimentalNoHoles', 'fuzzerHierarchy', 'fuzzerPolygonToCellsExperimental']
/src/h3/src/apps/fuzzers/fuzzerCellToLatLng.c ['fuzzerCellToLatLng'] ['fuzzerCellToLatLng']
/src/h3/src/apps/fuzzers/fuzzerPolygonToCellsExperimentalNoHoles.c ['fuzzerPolygonToCellsExperimentalNoHoles'] ['fuzzerPolygonToCellsExperimentalNoHoles']
/src/h3/src/apps/fuzzers/fuzzerVertexes.c ['fuzzerVertexes'] ['fuzzerVertexes']
/src/h3/src/apps/fuzzers/fuzzerPolygonToCellsExperimental.c ['fuzzerPolygonToCellsExperimental'] ['fuzzerPolygonToCellsExperimental']
/src/h3/src/apps/fuzzers/fuzzerLatLngToCell.c ['fuzzerLatLngToCell'] ['fuzzerLatLngToCell']
/src/h3/src/apps/fuzzers/fuzzerCellProperties.c ['fuzzerCellProperties'] ['fuzzerCellProperties']
/src/h3/src/apps/fuzzers/fuzzerDistances.c ['fuzzerDistances'] ['fuzzerDistances']
/src/h3/src/apps/fuzzers/fuzzerCellsToLinkedMultiPolygon.c ['fuzzerCellsToLinkedMultiPolygon'] ['fuzzerCellsToLinkedMultiPolygon']
/src/h3/src/apps/fuzzers/fuzzerInternalCoordIjk.c ['fuzzerInternalCoordIjk'] ['fuzzerInternalCoordIjk']
/src/h3/src/apps/fuzzers/fuzzerDirectedEdge.c ['fuzzerDirectedEdge'] ['fuzzerDirectedEdge']
/src/h3/src/h3lib/lib/vertex.c ['fuzzerEdgeLength', 'fuzzerDirectedEdge', 'fuzzerVertexes'] ['fuzzerEdgeLength', 'fuzzerDirectedEdge', 'fuzzerVertexes']
/src/h3/src/h3lib/lib/polyfill.c ['fuzzerPolygonToCellsExperimentalNoHoles', 'fuzzerPolygonToCellsExperimental'] ['fuzzerPolygonToCellsExperimentalNoHoles', 'fuzzerPolygonToCellsExperimental']
/src/h3/src/apps/fuzzers/fuzzerPolygonToCells.c ['fuzzerPolygonToCells'] ['fuzzerPolygonToCells']
/src/h3/src/h3lib/lib/localij.c ['fuzzerLocalIj'] ['fuzzerLocalIj']
/src/h3/src/h3lib/lib/latLng.c ['fuzzerDistances', 'fuzzerEdgeLength', 'fuzzerDirectedEdge', 'fuzzerCellToLatLng', 'fuzzerInternalAlgos', 'fuzzerGridDisk', 'fuzzerPolygonToCells', 'fuzzerPolygonToCellsExperimentalNoHoles', 'fuzzerPolygonToCellsNoHoles', 'fuzzerResolutions', 'fuzzerCellArea', 'fuzzerLatLngToCell', 'fuzzerVertexes', 'fuzzerPolygonToCellsExperimental', 'fuzzerCellsToLinkedMultiPolygon'] ['fuzzerDistances', 'fuzzerEdgeLength', 'fuzzerDirectedEdge', 'fuzzerCellToLatLng', 'fuzzerInternalAlgos', 'fuzzerGridDisk', 'fuzzerPolygonToCells', 'fuzzerPolygonToCellsExperimentalNoHoles', 'fuzzerPolygonToCellsNoHoles', 'fuzzerResolutions', 'fuzzerCellArea', 'fuzzerLatLngToCell', 'fuzzerVertexes', 'fuzzerPolygonToCellsExperimental', 'fuzzerCellsToLinkedMultiPolygon']
/src/h3/src/apps/fuzzers/fuzzerResolutions.c ['fuzzerResolutions'] ['fuzzerResolutions']
/src/h3/src/h3lib/include/mathExtensions.h ['fuzzerInternalCoordIjk', 'fuzzerLocalIj'] ['fuzzerInternalCoordIjk', 'fuzzerLocalIj']
/src/h3/src/apps/fuzzers/fuzzerEdgeLength.c ['fuzzerEdgeLength'] ['fuzzerEdgeLength']
/src/h3/src/h3lib/lib/h3Index.c ['fuzzerCompact', 'fuzzerEdgeLength', 'fuzzerIndexIO', 'fuzzerDirectedEdge', 'fuzzerCellToLatLng', 'fuzzerInternalAlgos', 'fuzzerGridDisk', 'fuzzerPolygonToCells', 'fuzzerPolygonToCellsExperimentalNoHoles', 'fuzzerHierarchy', 'fuzzerCellProperties', 'fuzzerPolygonToCellsNoHoles', 'fuzzerCellToChildPos', 'fuzzerResolutions', 'fuzzerCellArea', 'fuzzerLatLngToCell', 'fuzzerLocalIj', 'fuzzerVertexes', 'fuzzerPolygonToCellsExperimental', 'fuzzerCellsToLinkedMultiPolygon'] ['fuzzerCompact', 'fuzzerEdgeLength', 'fuzzerIndexIO', 'fuzzerDirectedEdge', 'fuzzerCellToLatLng', 'fuzzerInternalAlgos', 'fuzzerGridDisk', 'fuzzerPolygonToCells', 'fuzzerPolygonToCellsExperimentalNoHoles', 'fuzzerHierarchy', 'fuzzerCellProperties', 'fuzzerPolygonToCellsNoHoles', 'fuzzerCellToChildPos', 'fuzzerResolutions', 'fuzzerCellArea', 'fuzzerLatLngToCell', 'fuzzerLocalIj', 'fuzzerVertexes', 'fuzzerPolygonToCellsExperimental', 'fuzzerCellsToLinkedMultiPolygon']
/src/h3/src/h3lib/lib/polygon.c ['fuzzerPolygonToCells', 'fuzzerPolygonToCellsExperimentalNoHoles', 'fuzzerPolygonToCellsNoHoles', 'fuzzerPolygonToCellsExperimental'] ['fuzzerPolygonToCells', 'fuzzerPolygonToCellsExperimentalNoHoles', 'fuzzerPolygonToCellsNoHoles', 'fuzzerPolygonToCellsExperimental']
/src/h3/src/h3lib/lib/vec3d.c ['fuzzerPolygonToCells', 'fuzzerPolygonToCellsExperimentalNoHoles', 'fuzzerPolygonToCellsNoHoles', 'fuzzerLatLngToCell', 'fuzzerPolygonToCellsExperimental'] ['fuzzerPolygonToCells', 'fuzzerPolygonToCellsExperimentalNoHoles', 'fuzzerPolygonToCellsNoHoles', 'fuzzerLatLngToCell', 'fuzzerPolygonToCellsExperimental']
/src/h3/src/apps/fuzzers/fuzzerLocalIj.c ['fuzzerLocalIj'] ['fuzzerLocalIj']
/src/h3/src/h3lib/lib/bbox.c ['fuzzerPolygonToCells', 'fuzzerPolygonToCellsExperimentalNoHoles', 'fuzzerPolygonToCellsNoHoles', 'fuzzerPolygonToCellsExperimental', 'fuzzerCellsToLinkedMultiPolygon'] ['fuzzerPolygonToCells', 'fuzzerPolygonToCellsExperimentalNoHoles', 'fuzzerPolygonToCellsNoHoles', 'fuzzerPolygonToCellsExperimental', 'fuzzerCellsToLinkedMultiPolygon']
/src/h3/src/apps/fuzzers/fuzzerCellArea.c ['fuzzerCellArea'] ['fuzzerCellArea']
/src/h3/src/apps/fuzzers/fuzzerPolygonToCellsNoHoles.c ['fuzzerPolygonToCellsNoHoles'] ['fuzzerPolygonToCellsNoHoles']
/src/h3/src/h3lib/lib/vec2d.c ['fuzzerEdgeLength', 'fuzzerDirectedEdge', 'fuzzerCellToLatLng', 'fuzzerInternalAlgos', 'fuzzerPolygonToCells', 'fuzzerPolygonToCellsExperimentalNoHoles', 'fuzzerPolygonToCellsNoHoles', 'fuzzerCellArea', 'fuzzerVertexes', 'fuzzerPolygonToCellsExperimental', 'fuzzerCellsToLinkedMultiPolygon'] ['fuzzerEdgeLength', 'fuzzerDirectedEdge', 'fuzzerCellToLatLng', 'fuzzerInternalAlgos', 'fuzzerPolygonToCells', 'fuzzerPolygonToCellsExperimentalNoHoles', 'fuzzerPolygonToCellsNoHoles', 'fuzzerCellArea', 'fuzzerVertexes', 'fuzzerPolygonToCellsExperimental', 'fuzzerCellsToLinkedMultiPolygon']
/src/h3/src/h3lib/lib/vertexGraph.c ['fuzzerInternalAlgos', 'fuzzerCellsToLinkedMultiPolygon'] ['fuzzerInternalAlgos', 'fuzzerCellsToLinkedMultiPolygon']
/src/h3/src/h3lib/lib/mathExtensions.c ['fuzzerCompact', 'fuzzerDirectedEdge', 'fuzzerGridDisk', 'fuzzerPolygonToCells', 'fuzzerPolygonToCellsExperimentalNoHoles', 'fuzzerHierarchy', 'fuzzerPolygonToCellsNoHoles', 'fuzzerCellToChildPos', 'fuzzerResolutions', 'fuzzerPolygonToCellsExperimental'] ['fuzzerCompact', 'fuzzerGridDisk', 'fuzzerPolygonToCellsExperimentalNoHoles', 'fuzzerHierarchy', 'fuzzerCellToChildPos', 'fuzzerResolutions', 'fuzzerPolygonToCellsExperimental']
/src/h3/src/apps/fuzzers/fuzzerIndexIO.c ['fuzzerIndexIO'] ['fuzzerIndexIO']
/src/h3/src/apps/fuzzers/fuzzerCellToChildPos.c ['fuzzerCellToChildPos'] ['fuzzerCellToChildPos']

Directories in report

Directory
/src/h3/src/h3lib/include/
/src/h3/src/apps/fuzzers/
/src/h3/src/h3lib/lib/

Metadata section

This sections shows the raw data that is used to produce this report. This is mainly used for further processing and developer debugging.

Fuzzer Calltree file Program data file Coverage file
fuzzerDistances fuzzerLogFile-0-xIEC5uAts9.data fuzzerLogFile-0-xIEC5uAts9.data.yaml fuzzerDistances.covreport
fuzzerCompact fuzzerLogFile-0-4KvNmkCL8W.data fuzzerLogFile-0-4KvNmkCL8W.data.yaml fuzzerCompact.covreport
fuzzerInternalCoordIjk fuzzerLogFile-0-R5qx91V42k.data fuzzerLogFile-0-R5qx91V42k.data.yaml fuzzerInternalCoordIjk.covreport
fuzzerEdgeLength fuzzerLogFile-0-lHmvfekVUu.data fuzzerLogFile-0-lHmvfekVUu.data.yaml fuzzerEdgeLength.covreport
fuzzerIndexIO fuzzerLogFile-0-aqC6XCCvpO.data fuzzerLogFile-0-aqC6XCCvpO.data.yaml fuzzerIndexIO.covreport
fuzzerDirectedEdge fuzzerLogFile-0-7qZGQNNPuL.data fuzzerLogFile-0-7qZGQNNPuL.data.yaml fuzzerDirectedEdge.covreport
fuzzerCellToLatLng fuzzerLogFile-0-gHrfub9jlA.data fuzzerLogFile-0-gHrfub9jlA.data.yaml fuzzerCellToLatLng.covreport
fuzzerInternalAlgos fuzzerLogFile-0-ITprsT7uEa.data fuzzerLogFile-0-ITprsT7uEa.data.yaml fuzzerInternalAlgos.covreport
fuzzerGridDisk fuzzerLogFile-0-IJ2AJbIBi8.data fuzzerLogFile-0-IJ2AJbIBi8.data.yaml fuzzerGridDisk.covreport
fuzzerPolygonToCells fuzzerLogFile-0-zS0GAAoIB5.data fuzzerLogFile-0-zS0GAAoIB5.data.yaml fuzzerPolygonToCells.covreport
fuzzerPolygonToCellsExperimentalNoHoles fuzzerLogFile-0-eFQ2h4u4PB.data fuzzerLogFile-0-eFQ2h4u4PB.data.yaml fuzzerPolygonToCellsExperimentalNoHoles.covreport
fuzzerHierarchy fuzzerLogFile-0-poQKJi1aOf.data fuzzerLogFile-0-poQKJi1aOf.data.yaml fuzzerHierarchy.covreport
fuzzerCellProperties fuzzerLogFile-0-3XtWVEa88Q.data fuzzerLogFile-0-3XtWVEa88Q.data.yaml fuzzerCellProperties.covreport
fuzzerPolygonToCellsNoHoles fuzzerLogFile-0-SjDcPw6DeF.data fuzzerLogFile-0-SjDcPw6DeF.data.yaml fuzzerPolygonToCellsNoHoles.covreport
fuzzerCellToChildPos fuzzerLogFile-0-e2YIo8ma4o.data fuzzerLogFile-0-e2YIo8ma4o.data.yaml fuzzerCellToChildPos.covreport
fuzzerResolutions fuzzerLogFile-0-7y5fIprshG.data fuzzerLogFile-0-7y5fIprshG.data.yaml fuzzerResolutions.covreport
fuzzerCellArea fuzzerLogFile-0-5wx9eAjGjm.data fuzzerLogFile-0-5wx9eAjGjm.data.yaml fuzzerCellArea.covreport
fuzzerLatLngToCell fuzzerLogFile-0-HrUbjQzai4.data fuzzerLogFile-0-HrUbjQzai4.data.yaml fuzzerLatLngToCell.covreport
fuzzerLocalIj fuzzerLogFile-0-46aOyCGKWA.data fuzzerLogFile-0-46aOyCGKWA.data.yaml fuzzerLocalIj.covreport
fuzzerVertexes fuzzerLogFile-0-IKSKePIQI6.data fuzzerLogFile-0-IKSKePIQI6.data.yaml fuzzerVertexes.covreport
fuzzerPolygonToCellsExperimental fuzzerLogFile-0-efHVtPnElf.data fuzzerLogFile-0-efHVtPnElf.data.yaml fuzzerPolygonToCellsExperimental.covreport
fuzzerCellsToLinkedMultiPolygon fuzzerLogFile-0-wJtKPWVTY9.data fuzzerLogFile-0-wJtKPWVTY9.data.yaml fuzzerCellsToLinkedMultiPolygon.covreport