diff options
| author | Max Moroz <mmoroz@chromium.org> | 2019-04-04 21:20:36 +0000 | 
|---|---|---|
| committer | Max Moroz <mmoroz@chromium.org> | 2019-04-04 21:20:36 +0000 | 
| commit | c815210013f27cfac07d6b53b47e8ac53e86afa3 (patch) | |
| tree | c611b67658237ef871cf05ff30fafe3e6206d0fc /compiler-rt/lib/fuzzer/scripts/collect_data_flow.py | |
| parent | 955b5a633138370cb5877f853f22ea86545adc36 (diff) | |
| download | bcm5719-llvm-c815210013f27cfac07d6b53b47e8ac53e86afa3.tar.gz bcm5719-llvm-c815210013f27cfac07d6b53b47e8ac53e86afa3.zip | |
[libFuzzer] Make DataFlow scripts Python3 compatible.
Summary:
Python2 will hit end of life soon: https://pythonclock.org/
This change also makes the integration with OSS-Fuzz a bit simpler:
https://github.com/google/oss-fuzz/issues/1632
Reviewers: morehouse, kcc
Reviewed By: morehouse
Subscribers: delcypher, #sanitizers, llvm-commits
Tags: #llvm, #sanitizers
Differential Revision: https://reviews.llvm.org/D60282
llvm-svn: 357726
Diffstat (limited to 'compiler-rt/lib/fuzzer/scripts/collect_data_flow.py')
| -rwxr-xr-x | compiler-rt/lib/fuzzer/scripts/collect_data_flow.py | 12 | 
1 files changed, 7 insertions, 5 deletions
| diff --git a/compiler-rt/lib/fuzzer/scripts/collect_data_flow.py b/compiler-rt/lib/fuzzer/scripts/collect_data_flow.py index 5be8ae6aa37..e8b56a71910 100755 --- a/compiler-rt/lib/fuzzer/scripts/collect_data_flow.py +++ b/compiler-rt/lib/fuzzer/scripts/collect_data_flow.py @@ -1,4 +1,4 @@ -#!/usr/bin/env python +#!/usr/bin/env python3  #===- lib/fuzzer/scripts/collect_data_flow.py ------------------------------===#  #  # Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. @@ -39,7 +39,9 @@ def collect_dataflow_for_corpus(self, exe, corpus_dir, output_dir):    for root, dirs, files in os.walk(corpus_dir):      for f in files:        path = os.path.join(root, f) -      sha1 = hashlib.sha1(open(path).read()).hexdigest() +      with open(path, 'rb') as fh: +        data = fh.read() +      sha1 = hashlib.sha1(data).hexdigest()        output = os.path.join(output_dir, sha1)        subprocess.call([self, exe, path, output])    functions_txt = open(os.path.join(output_dir, "functions.txt"), "w") @@ -55,11 +57,11 @@ def main(argv):    q = [[0, size]]    tmpdir = tempfile.mkdtemp(prefix="libfuzzer-tmp-")    atexit.register(cleanup, tmpdir) -  print "tmpdir: ", tmpdir +  print("tmpdir: ", tmpdir)    outputs = []    while len(q):      r = q.pop() -    print "******* Trying:  ", r +    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])      if ret and r[1] - r[0] >= 2: @@ -67,7 +69,7 @@ def main(argv):        q.append([(r[1] + r[0]) / 2, r[1]])      else:        outputs.append(tmpfile) -      print "******* Success: ", r +      print("******* Success: ", r)    f = sys.stdout    if len(argv) >= 4:      f = open(argv[3], "w") | 

