fuzzing_include_am.py 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155
  1. FUZZERS = """
  2. consensus
  3. descriptor
  4. diff
  5. diff-apply
  6. extrainfo
  7. hsdescv2
  8. hsdescv3
  9. http
  10. iptsv2
  11. microdesc
  12. vrs
  13. """
  14. PREAMBLE = r"""
  15. FUZZING_CPPFLAGS = \
  16. $(src_test_AM_CPPFLAGS) $(TEST_CPPFLAGS)
  17. FUZZING_CFLAGS = \
  18. $(AM_CFLAGS) $(TEST_CFLAGS)
  19. FUZZING_LDFLAG = \
  20. @TOR_LDFLAGS_zlib@ @TOR_LDFLAGS_openssl@ @TOR_LDFLAGS_libevent@
  21. FUZZING_LIBS = \
  22. src/or/libtor-testing.a \
  23. src/common/libor-crypto-testing.a \
  24. $(LIBKECCAK_TINY) \
  25. $(LIBDONNA) \
  26. src/common/libor-testing.a \
  27. src/common/libor-ctime-testing.a \
  28. src/common/libor-event-testing.a \
  29. src/trunnel/libor-trunnel-testing.a \
  30. @TOR_ZLIB_LIBS@ @TOR_LIB_MATH@ \
  31. @TOR_LIBEVENT_LIBS@ \
  32. @TOR_OPENSSL_LIBS@ @TOR_LIB_WS32@ @TOR_LIB_GDI@ @CURVE25519_LIBS@ \
  33. @TOR_SYSTEMD_LIBS@
  34. oss-fuzz-prereqs: \
  35. src/or/libtor-testing.a \
  36. src/common/libor-crypto-testing.a \
  37. $(LIBKECCAK_TINY) \
  38. $(LIBDONNA) \
  39. src/common/libor-testing.a \
  40. src/common/libor-ctime-testing.a \
  41. src/common/libor-event-testing.a \
  42. src/trunnel/libor-trunnel-testing.a
  43. noinst_HEADERS += \
  44. src/test/fuzz/fuzzing.h
  45. LIBFUZZER = /home/nickm/build/libfuzz/libFuzzer.a
  46. LIBFUZZER_CPPFLAGS = $(FUZZING_CPPFLAGS) -DLLVM_FUZZ
  47. LIBFUZZER_CFLAGS = $(FUZZING_CFLAGS)
  48. LIBFUZZER_LDFLAG = $(FUZZING_LDFLAG)
  49. LIBFUZZER_LIBS = $(FUZZING_LIBS) $(LIBFUZZER) -lstdc++
  50. LIBOSS_FUZZ_CPPFLAGS = $(FUZZING_CPPFLAGS) -DLLVM_FUZZ
  51. LIBOSS_FUZZ_CFLAGS = $(FUZZING_CFLAGS)
  52. """
  53. POSTAMBLE = r"""
  54. noinst_PROGRAMS += $(FUZZERS) $(LIBFUZZER_FUZZERS)
  55. noinst_LIBRARIES += $(OSS_FUZZ_FUZZERS)
  56. oss-fuzz-fuzzers: oss-fuzz-prereqs $(OSS_FUZZ_FUZZERS)
  57. fuzzers: $(FUZZERS) $(LIBFUZZER_FUZZERS)
  58. test-fuzz-corpora: $(FUZZERS)
  59. $(top_srcdir)/src/test/fuzz_static_testcases.sh
  60. """
  61. ########### No user serviceable parts will follow.
  62. PREAMBLE = PREAMBLE.strip()
  63. POSTAMBLE = POSTAMBLE.strip() # If I use it, it's a word!
  64. FUZZERS = FUZZERS.split()
  65. FUZZERS.sort()
  66. WARNING = """
  67. # This file was generated by fuzzing_include_am.py; do not hand-edit unless
  68. # you enjoy having your changes erased.
  69. """.strip()
  70. print(WARNING)
  71. print(PREAMBLE)
  72. print("\n# ===== AFL fuzzers")
  73. def get_id_name(s):
  74. return s.replace("-", "_")
  75. for fuzzer in FUZZERS:
  76. idname = get_id_name(fuzzer)
  77. print("""\
  78. src_test_fuzz_fuzz_{name}_SOURCES = \\
  79. src/test/fuzz/fuzzing_common.c \\
  80. src/test/fuzz/fuzz_{name}.c
  81. src_test_fuzz_fuzz_{name}_CPPFLAGS = $(FUZZING_CPPFLAGS)
  82. src_test_fuzz_fuzz_{name}_CFLAGS = $(FUZZING_CFLAGS)
  83. src_test_fuzz_fuzz_{name}_LDFLAGS = $(FUZZING_LDFLAG)
  84. src_test_fuzz_fuzz_{name}_LDADD = $(FUZZING_LIBS)
  85. """.format(name=idname))
  86. print("FUZZERS = \\")
  87. print(" \\\n".join("\tsrc/test/fuzz/fuzz-{name}".format(name=fuzzer)
  88. for fuzzer in FUZZERS))
  89. print("\n# ===== libfuzzer")
  90. print("\nif LIBFUZZER_ENABLED")
  91. for fuzzer in FUZZERS:
  92. idname = get_id_name(fuzzer)
  93. print("""\
  94. src_test_fuzz_lf_fuzz_{name}_SOURCES = \\
  95. $(src_test_fuzz_fuzz_{name}_SOURCES)
  96. src_test_fuzz_lf_fuzz_{name}_CPPFLAGS = $(LIBFUZZER_CPPFLAGS)
  97. src_test_fuzz_lf_fuzz_{name}_CFLAGS = $(LIBFUZZER_CFLAGS)
  98. src_test_fuzz_lf_fuzz_{name}_LDFLAGS = $(LIBFUZZER_LDFLAG)
  99. src_test_fuzz_lf_fuzz_{name}_LDADD = $(LIBFUZZER_LIBS)
  100. """.format(name=idname))
  101. print("LIBFUZZER_FUZZERS = \\")
  102. print(" \\\n".join("\tsrc/test/fuzz/lf-fuzz-{name}".format(name=fuzzer)
  103. for fuzzer in FUZZERS))
  104. print("""
  105. else
  106. LIBFUZZER_FUZZERS =
  107. endif""")
  108. print("\n# ===== oss-fuzz\n")
  109. print("if OSS_FUZZ_ENABLED")
  110. for fuzzer in FUZZERS:
  111. idname = get_id_name(fuzzer)
  112. print("""\
  113. src_test_fuzz_liboss_fuzz_{name}_a_SOURCES = \\
  114. $(src_test_fuzz_fuzz_{name}_SOURCES)
  115. src_test_fuzz_liboss_fuzz_{name}_a_CPPFLAGS = $(LIBOSS_FUZZ_CPPFLAGS)
  116. src_test_fuzz_liboss_fuzz_{name}_a_CFLAGS = $(LIBOSS_FUZZ_CFLAGS)
  117. """.format(name=idname))
  118. print("OSS_FUZZ_FUZZERS = \\")
  119. print(" \\\n".join("\tsrc/test/fuzz/liboss-fuzz-{name}.a".format(name=fuzzer)
  120. for fuzzer in FUZZERS))
  121. print("""
  122. else
  123. OSS_FUZZ_FUZZERS =
  124. endif""")
  125. print("")
  126. print(POSTAMBLE)