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

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 MD5_init(t_hash_state**) call site: 00000 /src/pycryptodome/src/MD5.c:207
0 0 None 0 0 MD5_init(t_hash_state**) call site: 00000 /src/pycryptodome/src/MD5.c:212
0 0 None 0 0 MD5_update(t_hash_state*,unsignedcharconst*,unsignedlong) call site: 00000 /src/pycryptodome/src/MD5.c:254
0 0 None 0 0 MD5_digest(t_hash_stateconst*,unsignedchar*) call site: 00000 /src/pycryptodome/src/MD5.c:309
0 0 None 0 0 md5_finalize(t_hash_state*,unsignedchar*) call site: 00000 /src/pycryptodome/src/MD5.c:270

Fuzzer calltree

0 LLVMFuzzerTestOneInput [function] [call site] 00000
1 MD5_init(t_hash_state**) [function] [call site] 00001
2 calloc [call site] 00002
1 MD5_update(t_hash_state*, unsigned char const*, unsigned long) [function] [call site] 00003
2 __assert_fail [call site] 00004
2 md5_compress(t_hash_state*) [function] [call site] 00005
3 load_u8to32_little(unsigned char const*) [function] [call site] 00006
4 u8to32_little(unsigned int*, unsigned char const*) [function] [call site] 00007
2 add_bits(t_hash_state*, unsigned int) [function] [call site] 00008
1 MD5_digest(t_hash_state const*, unsigned char*) [function] [call site] 00009
2 md5_finalize(t_hash_state*, unsigned char*) [function] [call site] 00010
3 __assert_fail [call site] 00011
3 add_bits(t_hash_state*, unsigned int) [function] [call site] 00012
3 md5_compress(t_hash_state*) [function] [call site] 00013
3 u64to8_little(unsigned char*, unsigned long const*) [function] [call site] 00014
3 md5_compress(t_hash_state*) [function] [call site] 00015
3 u32to8_little(unsigned char*, unsigned int const*) [function] [call site] 00016
1 MD5_destroy(t_hash_state*) [function] [call site] 00017