Index: lib/fuzzer/scripts/collect_data_flow.py =================================================================== --- lib/fuzzer/scripts/collect_data_flow.py +++ lib/fuzzer/scripts/collect_data_flow.py @@ -63,13 +63,26 @@ r = q.pop() print("******* Trying: ", r) tmpfile = os.path.join(tmpdir, str(r[0]) + "-" + str(r[1])) - ret = subprocess.call([exe, str(r[0]), str(r[1]), inp, tmpfile]) + + proc = subprocess.Popen([exe, str(r[0]), str(r[1]), inp, tmpfile], + stdout=subprocess.PIPE, stderr=subprocess.PIPE) + output, err = proc.communicate() + if b'FATAL: DataFlowSanitizer: out of labels' in err: + print('The input is too long, skipping.') + break + + ret = proc.returncode if ret and r[1] - r[0] >= 2: q.append([r[0], (r[1] + r[0]) / 2]) q.append([(r[1] + r[0]) / 2, r[1]]) else: outputs.append(tmpfile) print("******* Success: ", r) + + if len(outputs) == 0: + print('No traces to merge. Exiting.') + sys.exit(1) + f = sys.stdout if len(argv) >= 4: f = open(argv[3], "w")