1
0
mirror of https://github.com/irssi/irssi.git synced 2024-12-04 14:46:39 -05:00

Merge pull request #610 from josephbisch/fe-fuzz

Add frontend for fuzzing
This commit is contained in:
Alexander Færøy 2017-01-13 00:16:30 +01:00 committed by GitHub
commit 7732bbed5e
6 changed files with 273 additions and 1 deletions

4
.gitignore vendored
View File

@ -32,6 +32,7 @@ docs/help/[a-z]*
docs/help/in/Makefile.am docs/help/in/Makefile.am
src/fe-text/irssi src/fe-text/irssi
src/fe-fuzz/irssi-fuzz
src/fe-common/irc/irc-modules.c src/fe-common/irc/irc-modules.c
src/irc/irc.c src/irc/irc.c
@ -46,6 +47,9 @@ src/perl/ui/*.c
src/perl/*/MYMETA.* src/perl/*/MYMETA.*
src/perl/*/Makefile.old src/perl/*/Makefile.old
src/fe-fuzz/crash-*
src/fe-fuzz/oom-*
*.a *.a
*.bs *.bs
*.la *.la

View File

@ -52,6 +52,19 @@ AC_ARG_WITH(bot,
fi, fi,
want_irssibot=no) want_irssibot=no)
AC_ARG_WITH(fuzzer,
[ --with-fuzzer Build irssi-fuzzer],
if test x$withval = xno; then
want_irssifuzzer=no
else
want_irssifuzzer=yes
fi,
want_irssifuzzer=no)
AC_ARG_WITH(fuzzer-lib,
[ --with-fuzzer-lib Specify path to fuzzer library],
fuzzerlibpath="$withval")
AC_ARG_WITH(proxy, AC_ARG_WITH(proxy,
[ --with-proxy Build irssi-proxy], [ --with-proxy Build irssi-proxy],
if test x$withval = xno; then if test x$withval = xno; then
@ -297,6 +310,30 @@ if test "x$want_textui" != "xno"; then
fi fi
dnl **
dnl ** irssifuzzer checks
dnl **
if test "$want_irssifuzzer" != "no"; then
dnl * we need to build with -fsanitize-coverage=trace-pc-guard
dnl * otherwise fuzzer won't be very successful at finding bugs :)
if test -z "$SANFLAGS"; then
SANFLAGS="-g -fsanitize=address -fsanitize-coverage=trace-pc-guard"
fi
CFLAGS="$CFLAGS $SANFLAGS"
CXXFLAGS="$CXXFLAGS $SANFLAGS"
AC_MSG_CHECKING(for fuzzer library)
if test -z "$fuzzerlibpath"; then
AC_MSG_RESULT([not found, building without fuzzer front end])
want_irssifuzzer=no
else
FUZZER_LIBS="$fuzzerlibpath"
AC_SUBST(FUZZER_LIBS)
fi
fi
dnl ** dnl **
dnl ** perl checks dnl ** perl checks
dnl ** dnl **
@ -456,6 +493,7 @@ fi
dnl ** check what we want to build dnl ** check what we want to build
AM_CONDITIONAL(BUILD_TEXTUI, test "$want_textui" = "yes") AM_CONDITIONAL(BUILD_TEXTUI, test "$want_textui" = "yes")
AM_CONDITIONAL(BUILD_IRSSIBOT, test "$want_irssibot" = "yes") AM_CONDITIONAL(BUILD_IRSSIBOT, test "$want_irssibot" = "yes")
AM_CONDITIONAL(BUILD_IRSSIFUZZER, test "$want_irssifuzzer" = "yes")
AM_CONDITIONAL(BUILD_IRSSIPROXY, test "$want_irssiproxy" = "yes") AM_CONDITIONAL(BUILD_IRSSIPROXY, test "$want_irssiproxy" = "yes")
AM_CONDITIONAL(HAVE_PERL, test "$want_perl" != "no") AM_CONDITIONAL(HAVE_PERL, test "$want_perl" != "no")
@ -572,6 +610,7 @@ src/fe-common/core/Makefile
src/fe-common/irc/Makefile src/fe-common/irc/Makefile
src/fe-common/irc/dcc/Makefile src/fe-common/irc/dcc/Makefile
src/fe-common/irc/notifylist/Makefile src/fe-common/irc/notifylist/Makefile
src/fe-fuzz/Makefile
src/fe-none/Makefile src/fe-none/Makefile
src/fe-text/Makefile src/fe-text/Makefile
src/lib-config/Makefile src/lib-config/Makefile

View File

@ -6,6 +6,10 @@ if BUILD_IRSSIBOT
BOTUI=fe-none BOTUI=fe-none
endif endif
if BUILD_IRSSIFUZZER
FUZZERUI=fe-fuzz
endif
if HAVE_PERL if HAVE_PERL
PERLDIR=perl PERLDIR=perl
endif endif
@ -14,4 +18,4 @@ pkginc_srcdir=$(pkgincludedir)/src
pkginc_src_HEADERS = \ pkginc_src_HEADERS = \
common.h common.h
SUBDIRS = lib-config core irc fe-common $(PERLDIR) $(TEXTUI) $(BOTUI) SUBDIRS = lib-config core irc fe-common $(PERLDIR) $(TEXTUI) $(BOTUI) $(FUZZERUI)

25
src/fe-fuzz/Makefile.am Normal file
View File

@ -0,0 +1,25 @@
bin_PROGRAMS = irssi-fuzz
# Force link with clang++ for libfuzzer support
CCLD=clang++ $(CXXFLAGS)
AM_CPPFLAGS = \
-I$(top_srcdir)/src \
-I$(top_srcdir)/src/core/ \
-I$(top_srcdir)/src/irc/core/ \
-I$(top_srcdir)/src/fe-common/core/ \
$(GLIB_CFLAGS)
irssi_fuzz_DEPENDENCIES = @COMMON_LIBS@
irssi_fuzz_LDADD = \
@COMMON_LIBS@ \
@PROG_LIBS@ \
$(FUZZER_LIBS)
irssi_fuzz_SOURCES = \
irssi.c \
$(top_srcdir)/src/fe-text/module-formats.c
noinst_HEADERS = \
$(top_srcdir)/src/fe-text/module-formats.h

57
src/fe-fuzz/irssi.c Normal file
View File

@ -0,0 +1,57 @@
/*
irssi.c : irssi
Copyright (C) 2017 Joseph Bisch
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 "module.h"
#include "modules-load.h"
#include "levels.h"
#include "../fe-text/module-formats.h" // need to explicitly grab from fe-text
#include "themes.h"
#include "core.h"
#include "fe-common-core.h"
#include "args.h"
#include "printtext.h"
#include <stddef.h>
#include <stdint.h>
#include <stdlib.h>
#include <string.h>
int LLVMFuzzerInitialize(int *argc, char ***argv) {
core_register_options();
fe_common_core_register_options();
/* no args */
args_execute(0, NULL);
core_preinit((*argv)[0]);
core_init();
fe_common_core_init();
theme_register(gui_text_formats);
module_register("core", "fe-fuzz");
printtext_string(NULL, NULL, MSGLEVEL_CLIENTCRAP, "init");
return 0;
}
int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size) {
char *copy = (char *)malloc(sizeof(char)*(size+1));
memcpy(copy, data, size);
copy[size] = '\0';
printtext_string(NULL, NULL, MSGLEVEL_CLIENTCRAP, copy);
free(copy);
return 0;
}

143
src/fe-fuzz/tokens.txt Normal file
View File

@ -0,0 +1,143 @@
"@%+"
"*@*!*"
"001"
"002"
"003"
"004"
"005"
"221"
"254"
"271"
"272"
"281"
"301"
"302"
"303"
"305"
"306"
"311"
"312"
"313"
"314"
"315"
"317"
"318"
"319"
"324"
"326"
"327"
"328"
"329"
"330"
"332"
"333"
"338"
"341"
"344"
"345"
"346"
"347"
"348"
"349"
"352"
"353"
"364"
"365"
"366"
"367"
"368"
"369"
"372"
"375"
"376"
"377"
"378"
"379"
"381"
"386"
"387"
"388"
"389"
"396"
"401"
"403"
"404"
"405"
"407"
"408"
"410"
"421"
"422"
"433"
"436"
"437"
"438"
"439"
"442"
"465"
"470"
"471"
"472"
"473"
"474"
"475"
"476"
"477"
"478"
"479"
"482"
"486"
"489"
"494"
"506"
"707"
"716"
"717"
"728"
"729"
"902"
"903"
"904"
"905"
"906"
"907"
":a"
"+a"
"ACK"
"authenticate"
"away"
"-b"
"+b"
"cap"
"#chan"
"connected"
"empty"
"error"
"invite"
"join"
"kick"
"kill"
"LS"
"mode"
"multi-prefix"
"NAK"
"network"
"nick"
"nicklen"
"notice"
"-o"
"+o"
"part"
"ping"
"pong"
"prefix"
"privmsg"
"quit"
"sasl"
"topic"
"wallops"
"watch"
":\x01"
":\x01ACTION"
":\x01PING"
":\x01VERSION"