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: tests/jq_fuzz_parse.c

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 project has no code coverage. Will not display blockers as blockers depend on code coverage.

Fuzzer: tests/jq_fuzz_parse_stream.c

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 project has no code coverage. Will not display blockers as blockers depend on code coverage.

Fuzzer: tests/jq_fuzz_load_file.c

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 project has no code coverage. Will not display blockers as blockers depend on code coverage.

Fuzzer: tests/jq_fuzz_execute.cpp

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 project has no code coverage. Will not display blockers as blockers depend on code coverage.

Fuzzer: tests/jq_fuzz_parse_extended.c

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 project has no code coverage. Will not display blockers as blockers depend on code coverage.

Fuzzer: tests/jq_fuzz_fixed.cpp

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 project has no code coverage. Will not display blockers as blockers depend on code coverage.

Fuzzer: tests/jq_fuzz_compile.c

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 project has no code coverage. Will not display blockers as blockers depend on code coverage.

Analyses and suggestions

Optimal target analysis

Remaining optimal interesting functions

The following table shows a list of functions that are optimal targets. Optimal targets are identified by finding the functions that in combination, yield a high code coverage.

Func name Functions filename Arg count Args Function depth hitcount instr count bb count cyclomatic complexity Reachable functions Incoming references total cyclomatic complexity Unreached complexity
decFloatNextToward /src/jq/vendor/decNumber/decBasic.c 4 ['decFloat*', 'decFloat*', 'decFloat*', 'decContext*'] 6 0 34 7 9 70 0 600 353
decDivide /src/jq/vendor/decNumber/decBasic.c 5 ['decFloat*', 'decFloat*', 'decFloat*', 'decContext*', 'uInt'] 6 0 321 67 107 62 4 552 138
delpaths_sorted /src/jq/src/jv_aux.c 3 ['jv', 'jv', 'int'] 11 0 36 7 12 178 3 677 81
jq_testsuite /src/jq/src/jq_test.c 4 ['jv', 'int', 'int', 'char*[]'] 29 0 24 5 5 554 0 2057 78
decNumberExp /src/jq/vendor/decNumber/decNumber.c 3 ['decNumber*', 'decNumber*', 'decContext*'] 7 0 21 8 9 47 0 379 71
f_format /src/jq/src/builtin.c 3 ['jq_state*', 'jv', 'jv'] 16 0 202 43 56 161 0 319 61
decToIntegral /src/jq/vendor/decNumber/decBasic.c 5 ['decFloat*', 'decFloat*', 'decContext*', 'enum rounding', 'Flag'] 5 0 20 5 4 28 2 137 57
decQuantizeOp /src/jq/vendor/decNumber/decNumber.c 6 ['decNumber*', 'decNumber*', 'decNumber*', 'decContext*', 'Flag', 'uInt*'] 5 0 84 24 36 36 0 352 55
decFloatNextMinus /src/jq/vendor/decNumber/decBasic.c 3 ['decFloat*', 'decFloat*', 'decContext*'] 6 0 18 3 3 57 0 382 54
stream_token /src/jq/src/jv_parse.c 2 ['struct jv_parser*', 'char'] 8 0 148 46 49 92 0 164 49

Implementing fuzzers that target the above functions will improve reachability such that it becomes:

Functions statically reachable by fuzzers
50.0%
533 / 1075
Cyclomatic complexity statically reachable by fuzzers
65.0%
2964 / 4562

All functions overview

If you implement fuzzers for these functions, the status of all functions in the project will be:

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

Fuzz driver synthesis

New fuzzers

The below fuzzers are templates and suggestions for how to target the set of optimal functions above

decBasic.c

Target file: /src/jq/vendor/decNumber/decBasic.c
Target functions: decFloatNextToward, decDivide, decToIntegral, decFloatNextMinus
#include "ada_fuzz_header.h"

int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) {
  af_safe_gb_init(data, size);

  /* target decFloatNextToward */
  UNKNOWN_TYPE unknown_0;
  UNKNOWN_TYPE unknown_1;
  UNKNOWN_TYPE unknown_2;
  UNKNOWN_TYPE unknown_3;
  decFloatNextToward(unknown_0, unknown_1, unknown_2, unknown_3);

  /* target decDivide */
  UNKNOWN_TYPE unknown_4;
  UNKNOWN_TYPE unknown_5;
  UNKNOWN_TYPE unknown_6;
  UNKNOWN_TYPE unknown_7;
  UNKNOWN_TYPE unknown_8;
  decDivide(unknown_4, unknown_5, unknown_6, unknown_7, unknown_8);

  /* target decToIntegral */
  UNKNOWN_TYPE unknown_22;
  UNKNOWN_TYPE unknown_23;
  UNKNOWN_TYPE unknown_24;
  UNKNOWN_TYPE unknown_25;
  UNKNOWN_TYPE unknown_26;
  decToIntegral(unknown_22, unknown_23, unknown_24, unknown_25, unknown_26);

  /* target decFloatNextMinus */
  UNKNOWN_TYPE unknown_33;
  UNKNOWN_TYPE unknown_34;
  UNKNOWN_TYPE unknown_35;
  decFloatNextMinus(unknown_33, unknown_34, unknown_35);

  af_safe_gb_cleanup();
}

jv_aux.c

Target file: /src/jq/src/jv_aux.c
Target functions: delpaths_sorted
#include "ada_fuzz_header.h"

int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) {
  af_safe_gb_init(data, size);

  /* target delpaths_sorted */
  UNKNOWN_TYPE unknown_9;
  UNKNOWN_TYPE unknown_10;
  int new_var11 = ada_safe_get_int();
  delpaths_sorted(unknown_9, unknown_10, new_var11);

  af_safe_gb_cleanup();
}

jq_test.c

Target file: /src/jq/src/jq_test.c
Target functions: jq_testsuite
#include "ada_fuzz_header.h"

int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) {
  af_safe_gb_init(data, size);

  /* target jq_testsuite */
  UNKNOWN_TYPE unknown_12;
  int new_var13 = ada_safe_get_int();
  int new_var14 = ada_safe_get_int();
  UNKNOWN_TYPE unknown_15;
  jq_testsuite(unknown_12, new_var13, new_var14, unknown_15);

  af_safe_gb_cleanup();
}

decNumber.c

Target file: /src/jq/vendor/decNumber/decNumber.c
Target functions: decNumberExp, decQuantizeOp
#include "ada_fuzz_header.h"

int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) {
  af_safe_gb_init(data, size);

  /* target decNumberExp */
  UNKNOWN_TYPE unknown_16;
  UNKNOWN_TYPE unknown_17;
  UNKNOWN_TYPE unknown_18;
  decNumberExp(unknown_16, unknown_17, unknown_18);

  /* target decQuantizeOp */
  UNKNOWN_TYPE unknown_27;
  UNKNOWN_TYPE unknown_28;
  UNKNOWN_TYPE unknown_29;
  UNKNOWN_TYPE unknown_30;
  UNKNOWN_TYPE unknown_31;
  UNKNOWN_TYPE unknown_32;
  decQuantizeOp(unknown_27, unknown_28, unknown_29, unknown_30, unknown_31, unknown_32);

  af_safe_gb_cleanup();
}

builtin.c

Target file: /src/jq/src/builtin.c
Target functions: f_format
#include "ada_fuzz_header.h"

int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) {
  af_safe_gb_init(data, size);

  /* target f_format */
  UNKNOWN_TYPE unknown_19;
  UNKNOWN_TYPE unknown_20;
  UNKNOWN_TYPE unknown_21;
  f_format(unknown_19, unknown_20, unknown_21);

  af_safe_gb_cleanup();
}

jv_parse.c

Target file: /src/jq/src/jv_parse.c
Target functions: stream_token
#include "ada_fuzz_header.h"

int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) {
  af_safe_gb_init(data, size);

  /* target stream_token */
  structjv_parser* new_var36 = calloc(sizeof(structjv_parser), 1);
  UNKNOWN_TYPE unknown_37;
  stream_token(new_var36, unknown_37);

  af_safe_gb_cleanup();
}

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/jq/src/jv_print.c ['tests/jq_fuzz_execute.cpp', 'tests/jq_fuzz_parse_extended.c', 'tests/jq_fuzz_fixed.cpp', 'tests/jq_fuzz_compile.c'] []
/src/jq/vendor/decNumber/decNumberLocal.h [] []
/src/jq/src/jv.h ['tests/jq_fuzz_parse.c', 'tests/jq_fuzz_parse_stream.c', 'tests/jq_fuzz_load_file.c', 'tests/jq_fuzz_execute.cpp', 'tests/jq_fuzz_parse_extended.c', 'tests/jq_fuzz_fixed.cpp', 'tests/jq_fuzz_compile.c'] []
/src/jq/src/util.c ['tests/jq_fuzz_execute.cpp', 'tests/jq_fuzz_fixed.cpp', 'tests/jq_fuzz_compile.c'] []
/src/jq/src/jq_test.c [] []
/src/jq/src/bytecode.c ['tests/jq_fuzz_execute.cpp', 'tests/jq_fuzz_fixed.cpp', 'tests/jq_fuzz_compile.c'] []
/src/jq/tests/jq_fuzz_compile.c ['tests/jq_fuzz_compile.c'] []
/src/jq/vendor/decNumber/decimal64.c [] []
/src/jq/src/compile.c ['tests/jq_fuzz_execute.cpp', 'tests/jq_fuzz_fixed.cpp', 'tests/jq_fuzz_compile.c'] []
/src/jq/src/jv_aux.c ['tests/jq_fuzz_execute.cpp', 'tests/jq_fuzz_fixed.cpp', 'tests/jq_fuzz_compile.c'] []
/src/jq/tests/jq_fuzz_parse_stream.c ['tests/jq_fuzz_parse_stream.c'] []
/src/jq/vendor/decNumber/decContext.c ['tests/jq_fuzz_parse.c', 'tests/jq_fuzz_parse_stream.c', 'tests/jq_fuzz_load_file.c', 'tests/jq_fuzz_execute.cpp', 'tests/jq_fuzz_parse_extended.c', 'tests/jq_fuzz_fixed.cpp', 'tests/jq_fuzz_compile.c'] []
/src/jq/src/inject_errors.c ['tests/jq_fuzz_load_file.c', 'tests/jq_fuzz_execute.cpp', 'tests/jq_fuzz_fixed.cpp', 'tests/jq_fuzz_compile.c'] []
/src/jq/vendor/decNumber/decBasic.c ['tests/jq_fuzz_execute.cpp', 'tests/jq_fuzz_fixed.cpp', 'tests/jq_fuzz_compile.c'] []
/src/jq/vendor/decNumber/decimal128.c [] []
/src/jq/src/jv.c ['tests/jq_fuzz_parse.c', 'tests/jq_fuzz_parse_stream.c', 'tests/jq_fuzz_load_file.c', 'tests/jq_fuzz_execute.cpp', 'tests/jq_fuzz_parse_extended.c', 'tests/jq_fuzz_fixed.cpp', 'tests/jq_fuzz_compile.c'] []
/src/jq/src/linker.c ['tests/jq_fuzz_execute.cpp', 'tests/jq_fuzz_fixed.cpp', 'tests/jq_fuzz_compile.c'] []
/src/jq/src/locfile.c ['tests/jq_fuzz_execute.cpp', 'tests/jq_fuzz_fixed.cpp', 'tests/jq_fuzz_compile.c'] []
/src/jq/src/parser.c ['tests/jq_fuzz_execute.cpp', 'tests/jq_fuzz_fixed.cpp', 'tests/jq_fuzz_compile.c'] []
/src/jq/src/jv_dtoa_tsd.c ['tests/jq_fuzz_execute.cpp', 'tests/jq_fuzz_fixed.cpp', 'tests/jq_fuzz_compile.c'] []
/src/jq/tests/jq_fuzz_parse_extended.c ['tests/jq_fuzz_parse_extended.c'] []
/src/jq/tests/jq_fuzz_load_file.c ['tests/jq_fuzz_load_file.c'] []
/src/jq/src/builtin.c ['tests/jq_fuzz_execute.cpp', 'tests/jq_fuzz_fixed.cpp', 'tests/jq_fuzz_compile.c'] []
/src/jq/src/main.c ['tests/jq_fuzz_execute.cpp', 'tests/jq_fuzz_fixed.cpp', 'tests/jq_fuzz_compile.c'] []
/src/jq/vendor/decNumber/decPacked.c [] []
/src/jq/tests/jq_fuzz_fixed.cpp ['tests/jq_fuzz_fixed.cpp'] []
/src/jq/src/jv_thread.h ['tests/jq_fuzz_execute.cpp', 'tests/jq_fuzz_fixed.cpp', 'tests/jq_fuzz_compile.c'] []
/src/jq/src/lexer.c [] []
/src/jq/src/execute.c ['tests/jq_fuzz_execute.cpp', 'tests/jq_fuzz_fixed.cpp', 'tests/jq_fuzz_compile.c'] []
/src/jq/src/jv_alloc.c ['tests/jq_fuzz_parse.c', 'tests/jq_fuzz_parse_stream.c', 'tests/jq_fuzz_load_file.c', 'tests/jq_fuzz_execute.cpp', 'tests/jq_fuzz_parse_extended.c', 'tests/jq_fuzz_fixed.cpp', 'tests/jq_fuzz_compile.c'] []
/src/jq/vendor/decNumber/decNumber.c ['tests/jq_fuzz_parse.c', 'tests/jq_fuzz_parse_stream.c', 'tests/jq_fuzz_load_file.c', 'tests/jq_fuzz_execute.cpp', 'tests/jq_fuzz_parse_extended.c', 'tests/jq_fuzz_fixed.cpp', 'tests/jq_fuzz_compile.c'] []
/src/jq/vendor/decNumber/example4.c [] []
/src/jq/src/compile.h [] []
/src/jq/src/util.h ['tests/jq_fuzz_execute.cpp', 'tests/jq_fuzz_fixed.cpp', 'tests/jq_fuzz_compile.c'] []
/src/jq/vendor/decNumber/example1.c [] []
/src/jq/src/jv_file.c ['tests/jq_fuzz_load_file.c', 'tests/jq_fuzz_execute.cpp', 'tests/jq_fuzz_fixed.cpp', 'tests/jq_fuzz_compile.c'] []
/src/jq/vendor/decNumber/decSingle.h [] []
/src/jq/tests/jq_fuzz_execute.cpp ['tests/jq_fuzz_execute.cpp'] []
/src/jq/vendor/decNumber/decQuad.h [] []
/src/jq/tests/jq_fuzz_parse.c ['tests/jq_fuzz_parse.c'] []
/src/jq/vendor/decNumber/decimal32.c [] []
/src/jq/src/jv_unicode.c ['tests/jq_fuzz_parse.c', 'tests/jq_fuzz_parse_stream.c', 'tests/jq_fuzz_load_file.c', 'tests/jq_fuzz_execute.cpp', 'tests/jq_fuzz_parse_extended.c', 'tests/jq_fuzz_fixed.cpp', 'tests/jq_fuzz_compile.c'] []
/src/jq/vendor/decNumber/decCommon.c ['tests/jq_fuzz_parse.c', 'tests/jq_fuzz_parse_stream.c', 'tests/jq_fuzz_load_file.c', 'tests/jq_fuzz_execute.cpp', 'tests/jq_fuzz_parse_extended.c', 'tests/jq_fuzz_fixed.cpp', 'tests/jq_fuzz_compile.c'] []
/src/jq/vendor/decNumber/decNumber.h [] []
/src/jq/src/exec_stack.h ['tests/jq_fuzz_execute.cpp', 'tests/jq_fuzz_fixed.cpp', 'tests/jq_fuzz_compile.c'] []
/src/jq/src/jv_dtoa.c ['tests/jq_fuzz_parse.c', 'tests/jq_fuzz_parse_stream.c', 'tests/jq_fuzz_load_file.c', 'tests/jq_fuzz_execute.cpp', 'tests/jq_fuzz_parse_extended.c', 'tests/jq_fuzz_fixed.cpp', 'tests/jq_fuzz_compile.c'] []
/src/jq/vendor/decNumber/decDouble.h [] []
/src/jq/src/jv_parse.c ['tests/jq_fuzz_parse.c', 'tests/jq_fuzz_parse_stream.c', 'tests/jq_fuzz_load_file.c', 'tests/jq_fuzz_execute.cpp', 'tests/jq_fuzz_parse_extended.c', 'tests/jq_fuzz_fixed.cpp', 'tests/jq_fuzz_compile.c'] []

Directories in report

Directory
/src/jq/tests/
/src/jq/src/
/src/jq/vendor/decNumber/

Sink analyser for CWEs

This section contains multiple tables, each table contains a list of sink functions/methods found in the project for one of the CWE supported by the sink analyser, together with information like which fuzzers statically reach the sink functions/methods and possible call path to that sink functions/methods if it is not statically reached by any fuzzers. Column 1 is the function/method name of the sink functions/methods found in the project. Column 2 lists all fuzzers (or no fuzzers at all) that have covered that particular function method statically. Column 3 shows a list of possible call paths to reach the specific function/method call if none of the fuzzers cover the target function/method calls. Lastly, column 4 shows possible fuzzer blockers that prevent an existing fuzzer from reaching the target sink functions/methods dynamically.

Sink functions/methods found for CWE787

Target sink Reached by fuzzer Function call path Possible branch blockers
fwrite ['/src/jq/tests/jq_fuzz_compile.c', '/src/jq/tests/jq_fuzz_load_file.c', '/src/jq/tests/jq_fuzz_fixed.cpp', '/src/jq/tests/jq_fuzz_execute.cpp'] N/A
Blocker function Arguments type Return type Constants touched
jq_testsuite
in /src/jq/src/jq_test.c:19
['jv', 'int', 'int', 'char*[]'] int []
test_pthread_run
in /src/jq/src/jq_test.c:348
['void*'] void []
f_modulemeta
in /src/jq/src/builtin.c:1383
['jq_state*', 'jv'] jv []
process
in /src/jq/src/main.c:175
['jq_state*', 'jv', 'int', 'int', 'int'] int []
f_negate
in /src/jq/src/builtin.c:246
['jq_state*', 'jv'] jv []
f_json_parse
in /src/jq/src/builtin.c:435
['jq_state*', 'jv'] jv []
f_tonumber
in /src/jq/src/builtin.c:444
['jq_state*', 'jv'] jv []
f_toboolean
in /src/jq/src/builtin.c:469
['jq_state*', 'jv'] jv []
f_length
in /src/jq/src/builtin.c:486
['jq_state*', 'jv'] jv []
f_utf8bytelength
in /src/jq/src/builtin.c:513
['jq_state*', 'jv'] jv []
f_format
in /src/jq/src/builtin.c:569
['jq_state*', 'jv', 'jv'] jv []
f_keys
in /src/jq/src/builtin.c:800
['jq_state*', 'jv'] jv []
f_keys_unsorted
in /src/jq/src/builtin.c:808
['jq_state*', 'jv'] jv []
f_sort
in /src/jq/src/builtin.c:816
['jq_state*', 'jv'] jv []
f_bsearch
in /src/jq/src/builtin.c:840
['jq_state*', 'jv', 'jv'] jv []
f_unique
in /src/jq/src/builtin.c:878
['jq_state*', 'jv'] jv []
f_halt_error
in /src/jq/src/builtin.c:1253
['jq_state*', 'jv', 'jv'] jv []
f_string_implode
in /src/jq/src/builtin.c:1347
['jq_state*', 'jv'] jv []
f_contains
in /src/jq/src/builtin.c:423
['jq_state*', 'jv', 'jv'] jv []
f_sort_by_impl
in /src/jq/src/builtin.c:824
['jq_state*', 'jv', 'jv'] jv []
f_group_by_impl
in /src/jq/src/builtin.c:868
['jq_state*', 'jv', 'jv'] jv []
f_unique_by_impl
in /src/jq/src/builtin.c:886
['jq_state*', 'jv', 'jv'] jv []
f_min
in /src/jq/src/builtin.c:1157
['jq_state*', 'jv'] jv []
f_max
in /src/jq/src/builtin.c:1161
['jq_state*', 'jv'] jv []
f_min_by_impl
in /src/jq/src/builtin.c:1165
['jq_state*', 'jv', 'jv'] jv []
f_max_by_impl
in /src/jq/src/builtin.c:1169
['jq_state*', 'jv', 'jv'] jv []
stderr_cb
in /src/jq/src/main.c:259
['void*', 'jv'] void []
default_err_cb
in /src/jq/src/execute.c:1041
['void*', 'jv'] void []
test_err_cb
in /src/jq/src/jq_test.c:68
['void*', 'jv'] void []
f_dump
in /src/jq/src/builtin.c:431
['jq_state*', 'jv'] jv []
malloc ['/src/jq/tests/jq_fuzz_parse.c', '/src/jq/tests/jq_fuzz_parse_extended.c', '/src/jq/tests/jq_fuzz_compile.c', '/src/jq/tests/jq_fuzz_load_file.c', '/src/jq/tests/jq_fuzz_parse_stream.c', '/src/jq/tests/jq_fuzz_fixed.cpp', '/src/jq/tests/jq_fuzz_execute.cpp'] N/A
Blocker function Arguments type Return type Constants touched
jq_testsuite
in /src/jq/src/jq_test.c:19
['jv', 'int', 'int', 'char*[]'] int []
test_pthread_run
in /src/jq/src/jq_test.c:348
['void*'] void []
f_modulemeta
in /src/jq/src/builtin.c:1383
['jq_state*', 'jv'] jv []
process
in /src/jq/src/main.c:175
['jq_state*', 'jv', 'int', 'int', 'int'] int []
f_negate
in /src/jq/src/builtin.c:246
['jq_state*', 'jv'] jv []
f_json_parse
in /src/jq/src/builtin.c:435
['jq_state*', 'jv'] jv []
f_tonumber
in /src/jq/src/builtin.c:444
['jq_state*', 'jv'] jv []
f_toboolean
in /src/jq/src/builtin.c:469
['jq_state*', 'jv'] jv []
f_length
in /src/jq/src/builtin.c:486
['jq_state*', 'jv'] jv []
f_utf8bytelength
in /src/jq/src/builtin.c:513
['jq_state*', 'jv'] jv []
f_format
in /src/jq/src/builtin.c:569
['jq_state*', 'jv', 'jv'] jv []
f_keys
in /src/jq/src/builtin.c:800
['jq_state*', 'jv'] jv []
f_keys_unsorted
in /src/jq/src/builtin.c:808
['jq_state*', 'jv'] jv []
f_sort
in /src/jq/src/builtin.c:816
['jq_state*', 'jv'] jv []
f_bsearch
in /src/jq/src/builtin.c:840
['jq_state*', 'jv', 'jv'] jv []
f_unique
in /src/jq/src/builtin.c:878
['jq_state*', 'jv'] jv []
f_halt_error
in /src/jq/src/builtin.c:1253
['jq_state*', 'jv', 'jv'] jv []
f_string_implode
in /src/jq/src/builtin.c:1347
['jq_state*', 'jv'] jv []
f_contains
in /src/jq/src/builtin.c:423
['jq_state*', 'jv', 'jv'] jv []
f_sort_by_impl
in /src/jq/src/builtin.c:824
['jq_state*', 'jv', 'jv'] jv []
f_group_by_impl
in /src/jq/src/builtin.c:868
['jq_state*', 'jv', 'jv'] jv []
f_unique_by_impl
in /src/jq/src/builtin.c:886
['jq_state*', 'jv', 'jv'] jv []
f_min
in /src/jq/src/builtin.c:1157
['jq_state*', 'jv'] jv []
f_max
in /src/jq/src/builtin.c:1161
['jq_state*', 'jv'] jv []
f_min_by_impl
in /src/jq/src/builtin.c:1165
['jq_state*', 'jv', 'jv'] jv []
f_max_by_impl
in /src/jq/src/builtin.c:1169
['jq_state*', 'jv', 'jv'] jv []
stderr_cb
in /src/jq/src/main.c:259
['void*', 'jv'] void []
default_err_cb
in /src/jq/src/execute.c:1041
['void*', 'jv'] void []
test_err_cb
in /src/jq/src/jq_test.c:68
['void*', 'jv'] void []
f_dump
in /src/jq/src/builtin.c:431
['jq_state*', 'jv'] jv []
stream_token
in /src/jq/src/jv_parse.c:241
['struct jv_parser*', 'char'] pfunc []
f_delpaths
in /src/jq/src/builtin.c:1380
['jq_state*', 'jv', 'jv'] jv []
f_setpath
in /src/jq/src/builtin.c:1375
['jq_state*', 'jv', 'jv', 'jv'] jv []
f_getpath
in /src/jq/src/builtin.c:1377
['jq_state*', 'jv', 'jv'] jv []
f_has
in /src/jq/src/builtin.c:1381
['jq_state*', 'jv', 'jv'] jv []
f_isinfinite
in /src/jq/src/builtin.c:1180
['jq_state*', 'jv'] jv []
f_isnan
in /src/jq/src/builtin.c:1191
['jq_state*', 'jv'] jv []
f_isnormal
in /src/jq/src/builtin.c:1202
['jq_state*', 'jv'] jv []
f_mktime
in /src/jq/src/builtin.c:1664
['jq_state*', 'jv'] jv []
jv_is_integer
in /src/jq/src/jv.c:715
['jv'] int []
sort_cmp
in /src/jq/src/jv_aux.c:669
['void*', 'void*'] int []
jv_string_implode
in /src/jq/src/jv.c:1416
['jv'] jv []
f_current_filename
in /src/jq/src/builtin.c:1857
['jq_state*', 'jv'] jv []
f_current_line
in /src/jq/src/builtin.c:1866
['jq_state*', 'jv'] jv []
jq_util_input_next_input_cb
in /src/jq/src/util.c:348
['jq_state*', 'void*'] jv []
jv_parse_custom_flags
in /src/jq/src/jv_parse.c:911
['char*', 'int'] jv []
f_string_explode
in /src/jq/src/builtin.c:1284
['jq_state*', 'jv'] jv []
f_string_trim
in /src/jq/src/builtin.c:1343
['jq_state*', 'jv'] jv []
f_string_ltrim
in /src/jq/src/builtin.c:1344
['jq_state*', 'jv'] jv []
f_string_rtrim
in /src/jq/src/builtin.c:1345
['jq_state*', 'jv'] jv []
f_startswith
in /src/jq/src/builtin.c:255
['jq_state*', 'jv', 'jv'] jv []
f_endswith
in /src/jq/src/builtin.c:271
['jq_state*', 'jv', 'jv'] jv []
f_string_split
in /src/jq/src/builtin.c:1277
['jq_state*', 'jv', 'jv'] jv []
f_strptime
in /src/jq/src/builtin.c:1556
['jq_state*', 'jv', 'jv'] jv []
f_match
in /src/jq/src/builtin.c:1115
['jq_state*', 'jv', 'jv', 'jv', 'jv'] jv []
f_error
in /src/jq/src/builtin.c:1223
['jq_state*', 'jv'] jv []
f_input
in /src/jq/src/builtin.c:1390
['jq_state*', 'jv'] jv []
f_gmtime
in /src/jq/src/builtin.c:1709
['jq_state*', 'jv'] jv []
f_localtime
in /src/jq/src/builtin.c:1746
['jq_state*', 'jv'] jv []
f_strftime
in /src/jq/src/builtin.c:1800
['jq_state*', 'jv', 'jv'] jv []
f_strflocaltime
in /src/jq/src/builtin.c:1835
['jq_state*', 'jv', 'jv'] jv []
f_match_name_iter
in /src/jq/src/builtin.c:897
['UChar*', 'UChar*', 'int', 'int*', 'regex_t*', 'void*'] int []
parse_token
in /src/jq/src/jv_parse.c:156
['struct jv_parser*', 'char'] pfunc []
f_string_indexes
in /src/jq/src/builtin.c:1291
['jq_state*', 'jv', 'jv'] jv []
jv_object_foreach
in /src/jq/src/jv.c:1898
[] void []
f_env
in /src/jq/src/builtin.c:1232
['jq_state*', 'jv'] jv []
f_get_search_list
in /src/jq/src/builtin.c:1262
['jq_state*', 'jv'] jv []
jq_util_input_set_parser
in /src/jq/src/util.c:216
['jq_util_input_state*', 'jv_parser*', 'int'] void []
jq_util_input_free
in /src/jq/src/util.c:228
['jq_util_input_state**'] void []
debug_cb
in /src/jq/src/main.c:253
['void*', 'jv'] void []
f_get_jq_origin
in /src/jq/src/builtin.c:1272
['jq_state*', 'jv'] jv []
f_get_prog_origin
in /src/jq/src/builtin.c:1267
['jq_state*', 'jv'] jv []
f_type
in /src/jq/src/builtin.c:1174
['jq_state*', 'jv'] jv []
yy_scan_string
in /src/jq/src/lexer.c:2218
['char*', 'yyscan_t'] YY_BUFFER_STATE []
yypush_buffer_state
in /src/jq/src/lexer.c:2080
['YY_BUFFER_STATE', 'yyscan_t'] void []
enter
in /src/jq/src/lexer.c:2688
['int', 'int', 'yyscan_t'] int []
yylex_init
in /src/jq/src/lexer.c:2507
['yyscan_t*'] int []
yylex_init_extra
in /src/jq/src/lexer.c:2534
['YY_EXTRA_TYPE', 'yyscan_t*'] int []
tsd_dec_ctx_get
in /src/jq/src/jv.c:508
['pthread_key_t*'] decContext []
main
in /src/jq/vendor/decNumber/example1.c:15
['int', 'char*[]'] int []
decimal128FromString
in /src/jq/vendor/decNumber/decimal128.c:451
['decimal128*', 'char*', 'decContext*'] decimal128 []
decimal64FromString
in /src/jq/vendor/decNumber/decimal64.c:439
['decimal64*', 'char*', 'decContext*'] decimal64 []
decimal32FromString
in /src/jq/vendor/decNumber/decimal32.c:378
['decimal32*', 'char*', 'decContext*'] decimal32 []
decNumberCompareTotalMag
in /src/jq/vendor/decNumber/decNumber.c:917
['decNumber*', 'decNumber*', 'decNumber*', 'decContext*'] decNumber []
decNumberFMA
in /src/jq/vendor/decNumber/decNumber.c:1094
['decNumber*', 'decNumber*', 'decNumber*', 'decNumber*', 'decContext*'] decNumber []
decNumberLog10
in /src/jq/vendor/decNumber/decNumber.c:1386
['decNumber*', 'decNumber*', 'decContext*'] decNumber []
decNumberExp
in /src/jq/vendor/decNumber/decNumber.c:1038
['decNumber*', 'decNumber*', 'decContext*'] decNumber []
decNumberCompareSignal
in /src/jq/vendor/decNumber/decNumber.c:875
['decNumber*', 'decNumber*', 'decNumber*', 'decContext*'] decNumber []
decNumberCompareTotal
in /src/jq/vendor/decNumber/decNumber.c:896
['decNumber*', 'decNumber*', 'decNumber*', 'decContext*'] decNumber []
decNumberMax
in /src/jq/vendor/decNumber/decNumber.c:1534
['decNumber*', 'decNumber*', 'decNumber*', 'decContext*'] decNumber []
decNumberMaxMag
in /src/jq/vendor/decNumber/decNumber.c:1557
['decNumber*', 'decNumber*', 'decNumber*', 'decContext*'] decNumber []
decNumberMin
in /src/jq/vendor/decNumber/decNumber.c:1580
['decNumber*', 'decNumber*', 'decNumber*', 'decContext*'] decNumber []
decNumberMinMag
in /src/jq/vendor/decNumber/decNumber.c:1603
['decNumber*', 'decNumber*', 'decNumber*', 'decContext*'] decNumber []
decFloatNextToward
in /src/jq/vendor/decNumber/decBasic.c:2781
['decFloat*', 'decFloat*', 'decFloat*', 'decContext*'] decFloat []
decFloatFromWider
in /src/jq/vendor/decNumber/decCommon.c:1018
['decFloat*', 'decFloatWider*', 'decContext*'] decFloat []
decFloatScaleB
in /src/jq/vendor/decNumber/decBasic.c:3353
['decFloat*', 'decFloat*', 'decFloat*', 'decContext*'] decFloat []
decFloatDivide
in /src/jq/vendor/decNumber/decBasic.c:1963
['decFloat*', 'decFloat*', 'decFloat*', 'decContext*'] decFloat []
decFloatDivideInteger
in /src/jq/vendor/decNumber/decBasic.c:1979
['decFloat*', 'decFloat*', 'decFloat*', 'decContext*'] decFloat []
decFloatRemainder
in /src/jq/vendor/decNumber/decBasic.c:3226
['decFloat*', 'decFloat*', 'decFloat*', 'decContext*'] decFloat []
decFloatRemainderNear
in /src/jq/vendor/decNumber/decBasic.c:3243
['decFloat*', 'decFloat*', 'decFloat*', 'decContext*'] decFloat []
decFloatNextMinus
in /src/jq/vendor/decNumber/decBasic.c:2692
['decFloat*', 'decFloat*', 'decContext*'] decFloat []
decFloatNextPlus
in /src/jq/vendor/decNumber/decBasic.c:2735
['decFloat*', 'decFloat*', 'decContext*'] decFloat []
decFloatSubtract
in /src/jq/vendor/decNumber/decBasic.c:3457
['decFloat*', 'decFloat*', 'decFloat*', 'decContext*'] decFloat []
decFloatMultiply
in /src/jq/vendor/decNumber/decBasic.c:2659
['decFloat*', 'decFloat*', 'decFloat*', 'decContext*'] decFloat []
decFloatReduce
in /src/jq/vendor/decNumber/decBasic.c:3189
['decFloat*', 'decFloat*', 'decContext*'] decFloat []
decFloatRotate
in /src/jq/vendor/decNumber/decBasic.c:3268
['decFloat*', 'decFloat*', 'decFloat*', 'decContext*'] decFloat []
decFloatShift
in /src/jq/vendor/decNumber/decBasic.c:3398
['decFloat*', 'decFloat*', 'decFloat*', 'decContext*'] decFloat []
decQuantizeOp
in /src/jq/vendor/decNumber/decNumber.c:5831
['decNumber*', 'decNumber*', 'decNumber*', 'decContext*', 'Flag', 'uInt*'] decNumber []
decNumberNextToward
in /src/jq/vendor/decNumber/decNumber.c:1734
['decNumber*', 'decNumber*', 'decNumber*', 'decContext*'] decNumber []
decNumberLn
in /src/jq/vendor/decNumber/decNumber.c:1258
['decNumber*', 'decNumber*', 'decContext*'] decNumber []
decMalloc
in /src/jq/vendor/decNumber/decNumber.c:8093
['size_t'] void []

Sink functions/methods found for CWE416

Target sink Reached by fuzzer Function call path Possible branch blockers
free ['/src/jq/tests/jq_fuzz_parse.c', '/src/jq/tests/jq_fuzz_parse_extended.c', '/src/jq/tests/jq_fuzz_compile.c', '/src/jq/tests/jq_fuzz_load_file.c', '/src/jq/tests/jq_fuzz_parse_stream.c', '/src/jq/tests/jq_fuzz_fixed.cpp', '/src/jq/tests/jq_fuzz_execute.cpp'] N/A
Blocker function Arguments type Return type Constants touched
tsd_fini
in /src/jq/src/jv_alloc.c:54
[] void []
tsd_fini_thread
in /src/jq/src/jv_alloc.c:66
['void*'] void []
jq_set_colors
in /src/jq/src/jv_print.c:39
['char*'] int []
jq_testsuite
in /src/jq/src/jq_test.c:19
['jv', 'int', 'int', 'char*[]'] int []
test_pthread_run
in /src/jq/src/jq_test.c:348
['void*'] void []
f_modulemeta
in /src/jq/src/builtin.c:1383
['jq_state*', 'jv'] jv []
switch
in /src/jq/src/parser.c:1997
[] YY_IGNORE_MAYBE_UNINITIALIZED_BEGIN []
jq_util_input_free
in /src/jq/src/util.c:228
['jq_util_input_state**'] void []
DllMain
in /src/jq/src/jv.c:304
['HINSTANCE', 'DWORD', 'LPVOID'] BOOL []
process
in /src/jq/src/main.c:175
['jq_state*', 'jv', 'int', 'int', 'int'] int []
f_negate
in /src/jq/src/builtin.c:246
['jq_state*', 'jv'] jv []
f_json_parse
in /src/jq/src/builtin.c:435
['jq_state*', 'jv'] jv []
f_tonumber
in /src/jq/src/builtin.c:444
['jq_state*', 'jv'] jv []
f_toboolean
in /src/jq/src/builtin.c:469
['jq_state*', 'jv'] jv []
f_length
in /src/jq/src/builtin.c:486
['jq_state*', 'jv'] jv []
f_utf8bytelength
in /src/jq/src/builtin.c:513
['jq_state*', 'jv'] jv []
f_format
in /src/jq/src/builtin.c:569
['jq_state*', 'jv', 'jv'] jv []
f_keys
in /src/jq/src/builtin.c:800
['jq_state*', 'jv'] jv []
f_keys_unsorted
in /src/jq/src/builtin.c:808
['jq_state*', 'jv'] jv []
f_sort
in /src/jq/src/builtin.c:816
['jq_state*', 'jv'] jv []
f_bsearch
in /src/jq/src/builtin.c:840
['jq_state*', 'jv', 'jv'] jv []
f_unique
in /src/jq/src/builtin.c:878
['jq_state*', 'jv'] jv []
f_halt_error
in /src/jq/src/builtin.c:1253
['jq_state*', 'jv', 'jv'] jv []
f_string_implode
in /src/jq/src/builtin.c:1347
['jq_state*', 'jv'] jv []
f_contains
in /src/jq/src/builtin.c:423
['jq_state*', 'jv', 'jv'] jv []
f_sort_by_impl
in /src/jq/src/builtin.c:824
['jq_state*', 'jv', 'jv'] jv []
f_group_by_impl
in /src/jq/src/builtin.c:868
['jq_state*', 'jv', 'jv'] jv []
f_unique_by_impl
in /src/jq/src/builtin.c:886
['jq_state*', 'jv', 'jv'] jv []
f_min
in /src/jq/src/builtin.c:1157
['jq_state*', 'jv'] jv []
f_max
in /src/jq/src/builtin.c:1161
['jq_state*', 'jv'] jv []
f_min_by_impl
in /src/jq/src/builtin.c:1165
['jq_state*', 'jv', 'jv'] jv []
f_max_by_impl
in /src/jq/src/builtin.c:1169
['jq_state*', 'jv', 'jv'] jv []
stderr_cb
in /src/jq/src/main.c:259
['void*', 'jv'] void []
default_err_cb
in /src/jq/src/execute.c:1041
['void*', 'jv'] void []
test_err_cb
in /src/jq/src/jq_test.c:68
['void*', 'jv'] void []
f_dump
in /src/jq/src/builtin.c:431
['jq_state*', 'jv'] jv []
stream_token
in /src/jq/src/jv_parse.c:241
['struct jv_parser*', 'char'] pfunc []
f_delpaths
in /src/jq/src/builtin.c:1380
['jq_state*', 'jv', 'jv'] jv []
f_setpath
in /src/jq/src/builtin.c:1375
['jq_state*', 'jv', 'jv', 'jv'] jv []
f_getpath
in /src/jq/src/builtin.c:1377
['jq_state*', 'jv', 'jv'] jv []
f_has
in /src/jq/src/builtin.c:1381
['jq_state*', 'jv', 'jv'] jv []
f_isinfinite
in /src/jq/src/builtin.c:1180
['jq_state*', 'jv'] jv []
f_isnan
in /src/jq/src/builtin.c:1191
['jq_state*', 'jv'] jv []
f_isnormal
in /src/jq/src/builtin.c:1202
['jq_state*', 'jv'] jv []
f_mktime
in /src/jq/src/builtin.c:1664
['jq_state*', 'jv'] jv []
jv_is_integer
in /src/jq/src/jv.c:715
['jv'] int []
sort_cmp
in /src/jq/src/jv_aux.c:669
['void*', 'void*'] int []
jv_string_implode
in /src/jq/src/jv.c:1416
['jv'] jv []
jv_parse_custom_flags
in /src/jq/src/jv_parse.c:911
['char*', 'int'] jv []
jq_set_attrs
in /src/jq/src/execute.c:1269
['jq_state*', 'jv'] void []
jq_util_input_next_input_cb
in /src/jq/src/util.c:348
['jq_state*', 'void*'] jv []
parse_token
in /src/jq/src/jv_parse.c:156
['struct jv_parser*', 'char'] pfunc []
jv_object_foreach
in /src/jq/src/jv.c:1898
[] void []
f_string_explode
in /src/jq/src/builtin.c:1284
['jq_state*', 'jv'] jv []
f_string_trim
in /src/jq/src/builtin.c:1343
['jq_state*', 'jv'] jv []
f_string_ltrim
in /src/jq/src/builtin.c:1344
['jq_state*', 'jv'] jv []
f_string_rtrim
in /src/jq/src/builtin.c:1345
['jq_state*', 'jv'] jv []
f_startswith
in /src/jq/src/builtin.c:255
['jq_state*', 'jv', 'jv'] jv []
f_endswith
in /src/jq/src/builtin.c:271
['jq_state*', 'jv', 'jv'] jv []
f_string_split
in /src/jq/src/builtin.c:1277
['jq_state*', 'jv', 'jv'] jv []
f_strptime
in /src/jq/src/builtin.c:1556
['jq_state*', 'jv', 'jv'] jv []
f_match_name_iter
in /src/jq/src/builtin.c:897
['UChar*', 'UChar*', 'int', 'int*', 'regex_t*', 'void*'] int []
f_match
in /src/jq/src/builtin.c:1115
['jq_state*', 'jv', 'jv', 'jv', 'jv'] jv []
f_type
in /src/jq/src/builtin.c:1174
['jq_state*', 'jv'] jv []
f_infinite
in /src/jq/src/builtin.c:1213
['jq_state*', 'jv'] jv []
f_nan
in /src/jq/src/builtin.c:1218
['jq_state*', 'jv'] jv []
f_env
in /src/jq/src/builtin.c:1232
['jq_state*', 'jv'] jv []
f_halt
in /src/jq/src/builtin.c:1247
['jq_state*', 'jv'] jv []
f_get_search_list
in /src/jq/src/builtin.c:1262
['jq_state*', 'jv'] jv []
f_get_prog_origin
in /src/jq/src/builtin.c:1267
['jq_state*', 'jv'] jv []
f_get_jq_origin
in /src/jq/src/builtin.c:1272
['jq_state*', 'jv'] jv []
f_input
in /src/jq/src/builtin.c:1390
['jq_state*', 'jv'] jv []
f_gmtime
in /src/jq/src/builtin.c:1709
['jq_state*', 'jv'] jv []
f_localtime
in /src/jq/src/builtin.c:1746
['jq_state*', 'jv'] jv []
f_strftime
in /src/jq/src/builtin.c:1800
['jq_state*', 'jv', 'jv'] jv []
f_strflocaltime
in /src/jq/src/builtin.c:1835
['jq_state*', 'jv', 'jv'] jv []
f_now
in /src/jq/src/builtin.c:1851
['jq_state*', 'jv'] jv []
f_current_filename
in /src/jq/src/builtin.c:1857
['jq_state*', 'jv'] jv []
f_current_line
in /src/jq/src/builtin.c:1866
['jq_state*', 'jv'] jv []
f_have_decnum
in /src/jq/src/builtin.c:1871
['jq_state*', 'jv'] jv []
f_string_indexes
in /src/jq/src/builtin.c:1291
['jq_state*', 'jv', 'jv'] jv []
yylex_destroy
in /src/jq/src/lexer.c:2595
['yyscan_t'] int []
s2b
in /src/jq/src/jv_dtoa.c:642
['struct dtoa_context*', 'char*', 'int', 'int', 'ULong', 'int'] Bigint []
pow5mult
in /src/jq/src/jv_dtoa.c:869
['struct dtoa_context*', 'Bigint*', 'int'] Bigint []
lshift
in /src/jq/src/jv_dtoa.c:904
['struct dtoa_context*', 'Bigint*', 'int'] Bigint []
increment
in /src/jq/src/jv_dtoa.c:1526
['struct dtoa_context*', 'Bigint*'] Bigint []
tsd_init
in /src/jq/src/jv_alloc.c:70
[] void []
main
in /src/jq/vendor/decNumber/example1.c:15
['int', 'char*[]'] int []
decimal128FromString
in /src/jq/vendor/decNumber/decimal128.c:451
['decimal128*', 'char*', 'decContext*'] decimal128 []
decimal64FromString
in /src/jq/vendor/decNumber/decimal64.c:439
['decimal64*', 'char*', 'decContext*'] decimal64 []
decimal32FromString
in /src/jq/vendor/decNumber/decimal32.c:378
['decimal32*', 'char*', 'decContext*'] decimal32 []
decNumberCompareTotalMag
in /src/jq/vendor/decNumber/decNumber.c:917
['decNumber*', 'decNumber*', 'decNumber*', 'decContext*'] decNumber []
decNumberExp
in /src/jq/vendor/decNumber/decNumber.c:1038
['decNumber*', 'decNumber*', 'decContext*'] decNumber []
decNumberFMA
in /src/jq/vendor/decNumber/decNumber.c:1094
['decNumber*', 'decNumber*', 'decNumber*', 'decNumber*', 'decContext*'] decNumber []
decNumberLn
in /src/jq/vendor/decNumber/decNumber.c:1258
['decNumber*', 'decNumber*', 'decContext*'] decNumber []
decNumberLog10
in /src/jq/vendor/decNumber/decNumber.c:1386
['decNumber*', 'decNumber*', 'decContext*'] decNumber []
decQuantizeOp
in /src/jq/vendor/decNumber/decNumber.c:5831
['decNumber*', 'decNumber*', 'decNumber*', 'decContext*', 'Flag', 'uInt*'] decNumber []
decNumberCompareSignal
in /src/jq/vendor/decNumber/decNumber.c:875
['decNumber*', 'decNumber*', 'decNumber*', 'decContext*'] decNumber []
decNumberCompareTotal
in /src/jq/vendor/decNumber/decNumber.c:896
['decNumber*', 'decNumber*', 'decNumber*', 'decContext*'] decNumber []
decNumberMax
in /src/jq/vendor/decNumber/decNumber.c:1534
['decNumber*', 'decNumber*', 'decNumber*', 'decContext*'] decNumber []
decNumberMaxMag
in /src/jq/vendor/decNumber/decNumber.c:1557
['decNumber*', 'decNumber*', 'decNumber*', 'decContext*'] decNumber []
decNumberMin
in /src/jq/vendor/decNumber/decNumber.c:1580
['decNumber*', 'decNumber*', 'decNumber*', 'decContext*'] decNumber []
decNumberMinMag
in /src/jq/vendor/decNumber/decNumber.c:1603
['decNumber*', 'decNumber*', 'decNumber*', 'decContext*'] decNumber []
decFloatNextToward
in /src/jq/vendor/decNumber/decBasic.c:2781
['decFloat*', 'decFloat*', 'decFloat*', 'decContext*'] decFloat []
decFloatFromWider
in /src/jq/vendor/decNumber/decCommon.c:1018
['decFloat*', 'decFloatWider*', 'decContext*'] decFloat []
decFloatScaleB
in /src/jq/vendor/decNumber/decBasic.c:3353
['decFloat*', 'decFloat*', 'decFloat*', 'decContext*'] decFloat []
decFloatDivide
in /src/jq/vendor/decNumber/decBasic.c:1963
['decFloat*', 'decFloat*', 'decFloat*', 'decContext*'] decFloat []
decFloatDivideInteger
in /src/jq/vendor/decNumber/decBasic.c:1979
['decFloat*', 'decFloat*', 'decFloat*', 'decContext*'] decFloat []
decFloatRemainder
in /src/jq/vendor/decNumber/decBasic.c:3226
['decFloat*', 'decFloat*', 'decFloat*', 'decContext*'] decFloat []
decFloatRemainderNear
in /src/jq/vendor/decNumber/decBasic.c:3243
['decFloat*', 'decFloat*', 'decFloat*', 'decContext*'] decFloat []
decFloatNextMinus
in /src/jq/vendor/decNumber/decBasic.c:2692
['decFloat*', 'decFloat*', 'decContext*'] decFloat []
decFloatNextPlus
in /src/jq/vendor/decNumber/decBasic.c:2735
['decFloat*', 'decFloat*', 'decContext*'] decFloat []
decFloatSubtract
in /src/jq/vendor/decNumber/decBasic.c:3457
['decFloat*', 'decFloat*', 'decFloat*', 'decContext*'] decFloat []
decFloatMultiply
in /src/jq/vendor/decNumber/decBasic.c:2659
['decFloat*', 'decFloat*', 'decFloat*', 'decContext*'] decFloat []
decFloatReduce
in /src/jq/vendor/decNumber/decBasic.c:3189
['decFloat*', 'decFloat*', 'decContext*'] decFloat []
decFloatRotate
in /src/jq/vendor/decNumber/decBasic.c:3268
['decFloat*', 'decFloat*', 'decFloat*', 'decContext*'] decFloat []
decFloatShift
in /src/jq/vendor/decNumber/decBasic.c:3398
['decFloat*', 'decFloat*', 'decFloat*', 'decContext*'] decFloat []
decNumberNextToward
in /src/jq/vendor/decNumber/decNumber.c:1734
['decNumber*', 'decNumber*', 'decNumber*', 'decContext*'] decNumber []
decFree
in /src/jq/vendor/decNumber/decNumber.c:8122
['void*'] void []

Sink functions/methods found for CWE20

Target sink Reached by fuzzer Function call path Possible branch blockers
fread ['/src/jq/tests/jq_fuzz_compile.c', '/src/jq/tests/jq_fuzz_load_file.c', '/src/jq/tests/jq_fuzz_fixed.cpp', '/src/jq/tests/jq_fuzz_execute.cpp'] N/A
Blocker function Arguments type Return type Constants touched
jq_testsuite
in /src/jq/src/jq_test.c:19
['jv', 'int', 'int', 'char*[]'] int []
test_pthread_run
in /src/jq/src/jq_test.c:348
['void*'] void []
f_modulemeta
in /src/jq/src/builtin.c:1383
['jq_state*', 'jv'] jv []
fgets [] Path 1
Path 2
N/A

Sink functions/methods found for CWE22

Target sink Reached by fuzzer Function call path Possible branch blockers
fopen ['/src/jq/tests/jq_fuzz_load_file.c'] N/A
Blocker function Arguments type Return type Constants touched
jq_util_input_next_input_cb
in /src/jq/src/util.c:348
['jq_state*', 'void*'] jv []
jq_testsuite
in /src/jq/src/jq_test.c:19
['jv', 'int', 'int', 'char*[]'] int []