aboutsummaryrefslogtreecommitdiffstats
path: root/tools
diff options
context:
space:
mode:
authorJakub Zawadzki <darkjames-ws@darkjames.pl>2017-04-24 22:20:44 +0200
committerJakub Zawadzki <darkjames-ws@darkjames.pl>2017-04-24 20:50:53 +0000
commit13fbdfc1ba9e38a45336f2d06e35083ba7da3d16 (patch)
treebc4d2d8a2f71a6b073f2bfe34d43083a8ced8b92 /tools
parent6cbea5c01c636b1e4b2737e325addeb5ca32a11c (diff)
fuzzshark: try to fix oss-build, remove oss-fuzzshark.c in old location.
Step #3: /src/wireshark/tools/oss-fuzzshark.c:190:2: warning: implicit declaration of function 'wtap_init' is invalid in C99 [-Wimplicit-function-declaration] (https://oss-fuzz-build-logs.storage.googleapis.com/log-472514ce-1a41-4f14-8798-d45084212a65.txt) Change-Id: I47715bdf55c20124a80da51d3c8812db1d8d94cf Reviewed-on: https://code.wireshark.org/review/21317 Reviewed-by: Jakub Zawadzki <darkjames-ws@darkjames.pl> Petri-Dish: Jakub Zawadzki <darkjames-ws@darkjames.pl> Tested-by: Petri Dish Buildbot <buildbot-no-reply@wireshark.org>
Diffstat (limited to 'tools')
-rw-r--r--tools/oss-fuzzshark.c330
-rw-r--r--tools/oss-fuzzshark/fuzzshark.c2
2 files changed, 2 insertions, 330 deletions
diff --git a/tools/oss-fuzzshark.c b/tools/oss-fuzzshark.c
deleted file mode 100644
index f4fab346e5..0000000000
--- a/tools/oss-fuzzshark.c
+++ /dev/null
@@ -1,330 +0,0 @@
-/* oss-fuzzshark.c
- *
- * Fuzzer variant of Wireshark for oss-fuzz
- *
- * Wireshark - Network traffic analyzer
- * By Gerald Combs <gerald@wireshark.org>
- * Copyright 1998 Gerald Combs
- *
- * This program is free software; you can redistribute it and/or
- * modify it under the terms of the GNU General Public License
- * as published by the Free Software Foundation; either version 2
- * of the License, or (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
- */
-
-#include <config.h>
-
-#include <stdlib.h>
-#include <stdio.h>
-#include <string.h>
-#include <limits.h>
-
-#include <glib.h>
-
-#include <epan/epan-int.h>
-#include <epan/epan.h>
-
-#include <wsutil/cmdarg_err.h>
-#include <wsutil/crash_info.h>
-#include <wsutil/filesystem.h>
-#include <wsutil/privileges.h>
-#include <wsutil/report_message.h>
-#include <ws_version_info.h>
-
-#include <epan/timestamp.h>
-#include <epan/prefs.h>
-#include <epan/column.h>
-#include <epan/print.h>
-#include <epan/epan_dissect.h>
-
-#ifdef HAVE_PLUGINS
-#include <wsutil/plugins.h>
-#endif
-
-#define EPAN_INIT_FAIL 2
-
-static column_info fuzz_cinfo;
-static epan_t *fuzz_epan;
-static epan_dissect_t *fuzz_edt;
-
-/*
- * General errors and warnings are reported with an console message
- * in oss-fuzzshark.
- */
-static void
-failure_warning_message(const char *msg_format, va_list ap)
-{
- fprintf(stderr, "oss-fuzzshark: ");
- vfprintf(stderr, msg_format, ap);
- fprintf(stderr, "\n");
-}
-
-/*
- * Open/create errors are reported with an console message in oss-fuzzshark.
- */
-static void
-open_failure_message(const char *filename, int err, gboolean for_writing)
-{
- fprintf(stderr, "oss-fuzzshark: ");
- fprintf(stderr, file_open_error_message(err, for_writing), filename);
- fprintf(stderr, "\n");
-}
-
-/*
- * Read errors are reported with an console message in oss-fuzzshark.
- */
-static void
-read_failure_message(const char *filename, int err)
-{
- cmdarg_err("An error occurred while reading from the file \"%s\": %s.", filename, g_strerror(err));
-}
-
-/*
- * Write errors are reported with an console message in oss-fuzzshark.
- */
-static void
-write_failure_message(const char *filename, int err)
-{
- cmdarg_err("An error occurred while writing to the file \"%s\": %s.", filename, g_strerror(err));
-}
-
-/*
- * Report additional information for an error in command-line arguments.
- */
-static void
-failure_message_cont(const char *msg_format, va_list ap)
-{
- vfprintf(stderr, msg_format, ap);
- fprintf(stderr, "\n");
-}
-
-static const nstime_t *
-fuzzshark_get_frame_ts(void *data _U_, guint32 frame_num _U_)
-{
- static nstime_t empty;
-
- return &empty;
-}
-
-static epan_t *
-fuzzshark_epan_new(void)
-{
- epan_t *epan = epan_new();
-
- epan->get_frame_ts = fuzzshark_get_frame_ts;
- epan->get_interface_name = NULL;
- epan->get_interface_description = NULL;
- epan->get_user_comment = NULL;
-
- return epan;
-}
-
-static int
-fuzz_init(int argc _U_, char **argv)
-{
- GString *comp_info_str;
- GString *runtime_info_str;
- char *init_progfile_dir_error;
-
- char *err_msg = NULL;
- e_prefs *prefs_p;
- int ret = EXIT_SUCCESS;
-
-#if defined(FUZZ_DISSECTOR_TARGET)
- dissector_handle_t fuzz_handle = NULL;
-#endif
-
- cmdarg_err_init(failure_warning_message, failure_message_cont);
-
- /*
- * Get credential information for later use, and drop privileges
- * before doing anything else.
- * Let the user know if anything happened.
- */
- init_process_policies();
-#if 0 /* disable setresgid(), it fails with -EINVAL https://github.com/google/oss-fuzz/pull/532#issuecomment-294515463 */
- relinquish_special_privs_perm();
-#endif
-
- /*
- * Attempt to get the pathname of the executable file.
- */
- init_progfile_dir_error = init_progfile_dir(argv[0], fuzz_init);
- if (init_progfile_dir_error != NULL)
- fprintf(stderr, "fuzzshark: Can't get pathname of oss-fuzzshark program: %s.\n", init_progfile_dir_error);
-
- /* Get the compile-time version information string */
- comp_info_str = get_compiled_version_info(NULL, epan_get_compiled_version_info);
-
- /* Get the run-time version information string */
- runtime_info_str = get_runtime_version_info(epan_get_runtime_version_info);
-
- /* Add it to the information to be reported on a crash. */
- ws_add_crash_info("OSS Fuzzshark (Wireshark) %s\n"
- "\n"
- "%s"
- "\n"
- "%s",
- get_ws_vcs_version_info(),
- comp_info_str->str,
- runtime_info_str->str);
- g_string_free(comp_info_str, TRUE);
- g_string_free(runtime_info_str, TRUE);
-
- init_report_message(failure_warning_message, failure_warning_message,
- open_failure_message, read_failure_message, write_failure_message);
-
- timestamp_set_type(TS_RELATIVE);
- timestamp_set_precision(TS_PREC_AUTO);
- timestamp_set_seconds_type(TS_SECONDS_DEFAULT);
-
- wtap_init();
-
-#ifdef HAVE_PLUGINS
- /* Register all the plugin types we have. */
- epan_register_plugin_types(); /* Types known to libwireshark */
-
- /* Scan for plugins. This does *not* call their registration routines; that's done later. */
- scan_plugins(REPORT_LOAD_FAILURE);
-
- /* Register all libwiretap plugin modules. */
- register_all_wiretap_modules();
-#endif
-
- /* Register all dissectors; we must do this before checking for the
- "-G" flag, as the "-G" flag dumps information registered by the
- dissectors, and we must do it before we read the preferences, in
- case any dissectors register preferences. */
- if (!epan_init(register_all_protocols, register_all_protocol_handoffs, NULL, NULL))
- {
- ret = EPAN_INIT_FAIL;
- goto clean_exit;
- }
-
- /* Load libwireshark settings from the current profile. */
- prefs_p = epan_load_settings();
-
- if (!color_filters_init(&err_msg, NULL))
- {
- fprintf(stderr, "color_filters_init() failed %s\n", err_msg);
- g_free(err_msg);
- }
-
- /* Notify all registered modules that have had any of their preferences
- changed either from one of the preferences file or from the command
- line that their preferences have changed. */
- prefs_apply_all();
-
- /* Build the column format array */
- build_column_format_array(&fuzz_cinfo, prefs_p->num_cols, TRUE);
-
-#if defined(FUZZ_DISSECTOR_TABLE) && defined(FUZZ_DISSECTOR_TARGET)
-# define FUZZ_EPAN 1
- fprintf(stderr, "oss-fuzz configured for dissector: %s in table: %s\n", FUZZ_DISSECTOR_TARGET, FUZZ_DISSECTOR_TABLE);
-
- /* search for handle, cannot use dissector_table_get_dissector_handle() cause it's using short-name, and I already used filter name in samples ;/ */
- {
- GSList *handle_list = dissector_table_get_dissector_handles(find_dissector_table(FUZZ_DISSECTOR_TABLE));
- while (handle_list)
- {
- dissector_handle_t handle = (dissector_handle_t) handle_list->data;
- const char *handle_filter_name = proto_get_protocol_filter_name(dissector_handle_get_protocol_index(handle));
-
- if (!strcmp(handle_filter_name, FUZZ_DISSECTOR_TARGET))
- fuzz_handle = handle;
- handle_list = handle_list->next;
- }
- }
-
-#elif defined(FUZZ_DISSECTOR_TARGET)
-# define FUZZ_EPAN 2
- fprintf(stderr, "oss-fuzz configured for dissector: %s\n", FUZZ_DISSECTOR_TARGET);
- fuzz_handle = find_dissector(FUZZ_DISSECTOR_TARGET);
-#endif
-
-#ifdef FUZZ_EPAN
- g_assert(fuzz_handle != NULL);
- register_postdissector(fuzz_handle);
-#endif
-
- fuzz_epan = fuzzshark_epan_new();
- fuzz_edt = epan_dissect_new(fuzz_epan, TRUE, FALSE);
-
- return 0;
-clean_exit:
- wtap_cleanup();
- free_progdirs();
-#ifdef HAVE_PLUGINS
- plugins_cleanup();
-#endif
- return ret;
-}
-
-#ifdef FUZZ_EPAN
-int
-LLVMFuzzerTestOneInput(guint8 *buf, size_t real_len)
-{
- static guint32 framenum = 0;
- epan_dissect_t *edt = fuzz_edt;
-
- guint32 len = (guint32) real_len;
-
- struct wtap_pkthdr whdr;
- frame_data fdlocal;
-
- memset(&whdr, 0, sizeof(whdr));
-
- whdr.rec_type = REC_TYPE_PACKET;
- whdr.caplen = len;
- whdr.len = len;
-
- /* whdr.pkt_encap = WTAP_ENCAP_ETHERNET; */
- whdr.pkt_encap = G_MAXINT16;
- whdr.presence_flags = WTAP_HAS_TS | WTAP_HAS_CAP_LEN; /* most common flags... */
-
- frame_data_init(&fdlocal, ++framenum, &whdr, /* offset */ 0, /* cum_bytes */ 0);
- /* frame_data_set_before_dissect() not needed */
- epan_dissect_run(edt, WTAP_FILE_TYPE_SUBTYPE_UNKNOWN, &whdr, tvb_new_real_data(buf, len, len), &fdlocal, NULL /* &fuzz_cinfo */);
- frame_data_destroy(&fdlocal);
-
- epan_dissect_reset(edt);
- return 0;
-}
-
-#else
-# error "Missing fuzz target."
-#endif
-
-int
-LLVMFuzzerInitialize(int *argc, char ***argv)
-{
- int ret;
-
- ret = fuzz_init(*argc, *argv);
- if (ret != 0)
- exit(ret);
-
- return 0;
-}
-
-/*
- * Editor modelines - http://www.wireshark.org/tools/modelines.html
- *
- * Local variables:
- * c-basic-offset: 8
- * tab-width: 8
- * indent-tabs-mode: t
- * End:
- *
- * vi: set shiftwidth=8 tabstop=8 noexpandtab:
- * :indentSize=8:tabSize=8:noTabs=false:
- */
diff --git a/tools/oss-fuzzshark/fuzzshark.c b/tools/oss-fuzzshark/fuzzshark.c
index 6c77e28b1d..ccab8a06ee 100644
--- a/tools/oss-fuzzshark/fuzzshark.c
+++ b/tools/oss-fuzzshark/fuzzshark.c
@@ -40,6 +40,8 @@
#include <wsutil/report_message.h>
#include <ws_version_info.h>
+#include <wiretap/wtap.h>
+
#include <epan/timestamp.h>
#include <epan/prefs.h>
#include <epan/column.h>