Adding upstream version 1.2.1.
Signed-off-by: Daniel Baumann <daniel@debian.org>
This commit is contained in:
parent
8d1b12293d
commit
403c1e4421
340 changed files with 71346 additions and 6734 deletions
|
@ -18,4 +18,4 @@
|
|||
|
||||
dist_doc_DATA = capture.lua dumpdns2pcap.lua dumpdns.lua dumpdns-qr.lua \
|
||||
filter_rcode.lua qr-multi-pcap-state.lua readme.lua replay.lua \
|
||||
replay_multicli.lua respdiff.lua test_pcap_read.lua test_throughput.lua
|
||||
replay_multicli.lua respdiff.lua
|
||||
|
|
548
examples/Makefile.in
Normal file
548
examples/Makefile.in
Normal file
|
@ -0,0 +1,548 @@
|
|||
# Makefile.in generated by automake 1.16.1 from Makefile.am.
|
||||
# @configure_input@
|
||||
|
||||
# Copyright (C) 1994-2018 Free Software Foundation, Inc.
|
||||
|
||||
# This Makefile.in is free software; the Free Software Foundation
|
||||
# gives unlimited permission to copy and/or distribute it,
|
||||
# with or without modifications, as long as this notice is preserved.
|
||||
|
||||
# This program is distributed in the hope that it will be useful,
|
||||
# but WITHOUT ANY WARRANTY, to the extent permitted by law; without
|
||||
# even the implied warranty of MERCHANTABILITY or FITNESS FOR A
|
||||
# PARTICULAR PURPOSE.
|
||||
|
||||
@SET_MAKE@
|
||||
|
||||
# Copyright (c) 2018-2021, OARC, Inc.
|
||||
# All rights reserved.
|
||||
#
|
||||
# This file is part of dnsjit.
|
||||
#
|
||||
# dnsjit 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 3 of the License, or
|
||||
# (at your option) any later version.
|
||||
#
|
||||
# dnsjit 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 dnsjit. If not, see <http://www.gnu.org/licenses/>.
|
||||
|
||||
VPATH = @srcdir@
|
||||
am__is_gnu_make = { \
|
||||
if test -z '$(MAKELEVEL)'; then \
|
||||
false; \
|
||||
elif test -n '$(MAKE_HOST)'; then \
|
||||
true; \
|
||||
elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \
|
||||
true; \
|
||||
else \
|
||||
false; \
|
||||
fi; \
|
||||
}
|
||||
am__make_running_with_option = \
|
||||
case $${target_option-} in \
|
||||
?) ;; \
|
||||
*) echo "am__make_running_with_option: internal error: invalid" \
|
||||
"target option '$${target_option-}' specified" >&2; \
|
||||
exit 1;; \
|
||||
esac; \
|
||||
has_opt=no; \
|
||||
sane_makeflags=$$MAKEFLAGS; \
|
||||
if $(am__is_gnu_make); then \
|
||||
sane_makeflags=$$MFLAGS; \
|
||||
else \
|
||||
case $$MAKEFLAGS in \
|
||||
*\\[\ \ ]*) \
|
||||
bs=\\; \
|
||||
sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \
|
||||
| sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \
|
||||
esac; \
|
||||
fi; \
|
||||
skip_next=no; \
|
||||
strip_trailopt () \
|
||||
{ \
|
||||
flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \
|
||||
}; \
|
||||
for flg in $$sane_makeflags; do \
|
||||
test $$skip_next = yes && { skip_next=no; continue; }; \
|
||||
case $$flg in \
|
||||
*=*|--*) continue;; \
|
||||
-*I) strip_trailopt 'I'; skip_next=yes;; \
|
||||
-*I?*) strip_trailopt 'I';; \
|
||||
-*O) strip_trailopt 'O'; skip_next=yes;; \
|
||||
-*O?*) strip_trailopt 'O';; \
|
||||
-*l) strip_trailopt 'l'; skip_next=yes;; \
|
||||
-*l?*) strip_trailopt 'l';; \
|
||||
-[dEDm]) skip_next=yes;; \
|
||||
-[JT]) skip_next=yes;; \
|
||||
esac; \
|
||||
case $$flg in \
|
||||
*$$target_option*) has_opt=yes; break;; \
|
||||
esac; \
|
||||
done; \
|
||||
test $$has_opt = yes
|
||||
am__make_dryrun = (target_option=n; $(am__make_running_with_option))
|
||||
am__make_keepgoing = (target_option=k; $(am__make_running_with_option))
|
||||
pkgdatadir = $(datadir)/@PACKAGE@
|
||||
pkgincludedir = $(includedir)/@PACKAGE@
|
||||
pkglibdir = $(libdir)/@PACKAGE@
|
||||
pkglibexecdir = $(libexecdir)/@PACKAGE@
|
||||
am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd
|
||||
install_sh_DATA = $(install_sh) -c -m 644
|
||||
install_sh_PROGRAM = $(install_sh) -c
|
||||
install_sh_SCRIPT = $(install_sh) -c
|
||||
INSTALL_HEADER = $(INSTALL_DATA)
|
||||
transform = $(program_transform_name)
|
||||
NORMAL_INSTALL = :
|
||||
PRE_INSTALL = :
|
||||
POST_INSTALL = :
|
||||
NORMAL_UNINSTALL = :
|
||||
PRE_UNINSTALL = :
|
||||
POST_UNINSTALL = :
|
||||
build_triplet = @build@
|
||||
host_triplet = @host@
|
||||
subdir = examples
|
||||
ACLOCAL_M4 = $(top_srcdir)/aclocal.m4
|
||||
am__aclocal_m4_deps = $(top_srcdir)/m4/ax_cflags_warn_all.m4 \
|
||||
$(top_srcdir)/m4/ax_check_compile_flag.m4 \
|
||||
$(top_srcdir)/m4/ax_compiler_vendor.m4 \
|
||||
$(top_srcdir)/m4/ax_ext.m4 \
|
||||
$(top_srcdir)/m4/ax_gcc_x86_avx_xgetbv.m4 \
|
||||
$(top_srcdir)/m4/ax_gcc_x86_cpuid.m4 \
|
||||
$(top_srcdir)/m4/ax_prepend_flag.m4 \
|
||||
$(top_srcdir)/m4/ax_pthread.m4 \
|
||||
$(top_srcdir)/m4/ax_require_defined.m4 \
|
||||
$(top_srcdir)/m4/libtool.m4 $(top_srcdir)/m4/ltoptions.m4 \
|
||||
$(top_srcdir)/m4/ltsugar.m4 $(top_srcdir)/m4/ltversion.m4 \
|
||||
$(top_srcdir)/m4/lt~obsolete.m4 $(top_srcdir)/configure.ac
|
||||
am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \
|
||||
$(ACLOCAL_M4)
|
||||
DIST_COMMON = $(srcdir)/Makefile.am $(dist_doc_DATA) \
|
||||
$(am__DIST_COMMON)
|
||||
mkinstalldirs = $(install_sh) -d
|
||||
CONFIG_HEADER = $(top_builddir)/src/config.h
|
||||
CONFIG_CLEAN_FILES =
|
||||
CONFIG_CLEAN_VPATH_FILES =
|
||||
AM_V_P = $(am__v_P_@AM_V@)
|
||||
am__v_P_ = $(am__v_P_@AM_DEFAULT_V@)
|
||||
am__v_P_0 = false
|
||||
am__v_P_1 = :
|
||||
AM_V_GEN = $(am__v_GEN_@AM_V@)
|
||||
am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@)
|
||||
am__v_GEN_0 = @echo " GEN " $@;
|
||||
am__v_GEN_1 =
|
||||
AM_V_at = $(am__v_at_@AM_V@)
|
||||
am__v_at_ = $(am__v_at_@AM_DEFAULT_V@)
|
||||
am__v_at_0 = @
|
||||
am__v_at_1 =
|
||||
SOURCES =
|
||||
DIST_SOURCES =
|
||||
am__can_run_installinfo = \
|
||||
case $$AM_UPDATE_INFO_DIR in \
|
||||
n|no|NO) false;; \
|
||||
*) (install-info --version) >/dev/null 2>&1;; \
|
||||
esac
|
||||
am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`;
|
||||
am__vpath_adj = case $$p in \
|
||||
$(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \
|
||||
*) f=$$p;; \
|
||||
esac;
|
||||
am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`;
|
||||
am__install_max = 40
|
||||
am__nobase_strip_setup = \
|
||||
srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'`
|
||||
am__nobase_strip = \
|
||||
for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||"
|
||||
am__nobase_list = $(am__nobase_strip_setup); \
|
||||
for p in $$list; do echo "$$p $$p"; done | \
|
||||
sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \
|
||||
$(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \
|
||||
if (++n[$$2] == $(am__install_max)) \
|
||||
{ print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \
|
||||
END { for (dir in files) print dir, files[dir] }'
|
||||
am__base_list = \
|
||||
sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \
|
||||
sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g'
|
||||
am__uninstall_files_from_dir = { \
|
||||
test -z "$$files" \
|
||||
|| { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \
|
||||
|| { echo " ( cd '$$dir' && rm -f" $$files ")"; \
|
||||
$(am__cd) "$$dir" && rm -f $$files; }; \
|
||||
}
|
||||
am__installdirs = "$(DESTDIR)$(docdir)"
|
||||
DATA = $(dist_doc_DATA)
|
||||
am__extra_recursive_targets = gcov-recursive
|
||||
am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP)
|
||||
am__DIST_COMMON = $(srcdir)/Makefile.in
|
||||
DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST)
|
||||
ACLOCAL = @ACLOCAL@
|
||||
AMTAR = @AMTAR@
|
||||
AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@
|
||||
AR = @AR@
|
||||
AUTOCONF = @AUTOCONF@
|
||||
AUTOHEADER = @AUTOHEADER@
|
||||
AUTOMAKE = @AUTOMAKE@
|
||||
AWK = @AWK@
|
||||
CC = @CC@
|
||||
CCDEPMODE = @CCDEPMODE@
|
||||
CFLAGS = @CFLAGS@
|
||||
CPP = @CPP@
|
||||
CPPFLAGS = @CPPFLAGS@
|
||||
CPUEXT_FLAGS = @CPUEXT_FLAGS@
|
||||
CYGPATH_W = @CYGPATH_W@
|
||||
DEFS = @DEFS@
|
||||
DEPDIR = @DEPDIR@
|
||||
DLLTOOL = @DLLTOOL@
|
||||
DSYMUTIL = @DSYMUTIL@
|
||||
DUMPBIN = @DUMPBIN@
|
||||
ECHO_C = @ECHO_C@
|
||||
ECHO_N = @ECHO_N@
|
||||
ECHO_T = @ECHO_T@
|
||||
EGREP = @EGREP@
|
||||
EXEEXT = @EXEEXT@
|
||||
FGREP = @FGREP@
|
||||
GREP = @GREP@
|
||||
INSTALL = @INSTALL@
|
||||
INSTALL_DATA = @INSTALL_DATA@
|
||||
INSTALL_PROGRAM = @INSTALL_PROGRAM@
|
||||
INSTALL_SCRIPT = @INSTALL_SCRIPT@
|
||||
INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@
|
||||
LD = @LD@
|
||||
LDFLAGS = @LDFLAGS@
|
||||
LIBOBJS = @LIBOBJS@
|
||||
LIBS = @LIBS@
|
||||
LIBTOOL = @LIBTOOL@
|
||||
LIPO = @LIPO@
|
||||
LN_S = @LN_S@
|
||||
LTLIBOBJS = @LTLIBOBJS@
|
||||
LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@
|
||||
LUAJIT = @LUAJIT@
|
||||
MAKEINFO = @MAKEINFO@
|
||||
MANIFEST_TOOL = @MANIFEST_TOOL@
|
||||
MKDIR_P = @MKDIR_P@
|
||||
NM = @NM@
|
||||
NMEDIT = @NMEDIT@
|
||||
OBJDUMP = @OBJDUMP@
|
||||
OBJEXT = @OBJEXT@
|
||||
OTOOL = @OTOOL@
|
||||
OTOOL64 = @OTOOL64@
|
||||
PACKAGE = @PACKAGE@
|
||||
PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@
|
||||
PACKAGE_NAME = @PACKAGE_NAME@
|
||||
PACKAGE_STRING = @PACKAGE_STRING@
|
||||
PACKAGE_TARNAME = @PACKAGE_TARNAME@
|
||||
PACKAGE_URL = @PACKAGE_URL@
|
||||
PACKAGE_VERSION = @PACKAGE_VERSION@
|
||||
PATH_SEPARATOR = @PATH_SEPARATOR@
|
||||
PKG_CONFIG = @PKG_CONFIG@
|
||||
PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@
|
||||
PKG_CONFIG_PATH = @PKG_CONFIG_PATH@
|
||||
PTHREAD_CC = @PTHREAD_CC@
|
||||
PTHREAD_CFLAGS = @PTHREAD_CFLAGS@
|
||||
PTHREAD_LIBS = @PTHREAD_LIBS@
|
||||
RANLIB = @RANLIB@
|
||||
SED = @SED@
|
||||
SET_MAKE = @SET_MAKE@
|
||||
SHELL = @SHELL@
|
||||
SIMD_FLAGS = @SIMD_FLAGS@
|
||||
STRIP = @STRIP@
|
||||
VERSION = @VERSION@
|
||||
abs_builddir = @abs_builddir@
|
||||
abs_srcdir = @abs_srcdir@
|
||||
abs_top_builddir = @abs_top_builddir@
|
||||
abs_top_srcdir = @abs_top_srcdir@
|
||||
ac_ct_AR = @ac_ct_AR@
|
||||
ac_ct_CC = @ac_ct_CC@
|
||||
ac_ct_DUMPBIN = @ac_ct_DUMPBIN@
|
||||
am__include = @am__include@
|
||||
am__leading_dot = @am__leading_dot@
|
||||
am__quote = @am__quote@
|
||||
am__tar = @am__tar@
|
||||
am__untar = @am__untar@
|
||||
ax_pthread_config = @ax_pthread_config@
|
||||
bindir = @bindir@
|
||||
build = @build@
|
||||
build_alias = @build_alias@
|
||||
build_cpu = @build_cpu@
|
||||
build_os = @build_os@
|
||||
build_vendor = @build_vendor@
|
||||
builddir = @builddir@
|
||||
ck_CFLAGS = @ck_CFLAGS@
|
||||
ck_LIBS = @ck_LIBS@
|
||||
datadir = @datadir@
|
||||
datarootdir = @datarootdir@
|
||||
docdir = @docdir@
|
||||
dvidir = @dvidir@
|
||||
exec_prefix = @exec_prefix@
|
||||
host = @host@
|
||||
host_alias = @host_alias@
|
||||
host_cpu = @host_cpu@
|
||||
host_os = @host_os@
|
||||
host_vendor = @host_vendor@
|
||||
htmldir = @htmldir@
|
||||
includedir = @includedir@
|
||||
infodir = @infodir@
|
||||
install_sh = @install_sh@
|
||||
libdir = @libdir@
|
||||
libexecdir = @libexecdir@
|
||||
liblz4_CFLAGS = @liblz4_CFLAGS@
|
||||
liblz4_LIBS = @liblz4_LIBS@
|
||||
libzstd_CFLAGS = @libzstd_CFLAGS@
|
||||
libzstd_LIBS = @libzstd_LIBS@
|
||||
localedir = @localedir@
|
||||
localstatedir = @localstatedir@
|
||||
luajit_CFLAGS = @luajit_CFLAGS@
|
||||
luajit_LIBS = @luajit_LIBS@
|
||||
mandir = @mandir@
|
||||
mkdir_p = @mkdir_p@
|
||||
oldincludedir = @oldincludedir@
|
||||
pdfdir = @pdfdir@
|
||||
prefix = @prefix@
|
||||
program_transform_name = @program_transform_name@
|
||||
psdir = @psdir@
|
||||
runstatedir = @runstatedir@
|
||||
sbindir = @sbindir@
|
||||
sharedstatedir = @sharedstatedir@
|
||||
srcdir = @srcdir@
|
||||
sysconfdir = @sysconfdir@
|
||||
target_alias = @target_alias@
|
||||
top_build_prefix = @top_build_prefix@
|
||||
top_builddir = @top_builddir@
|
||||
top_srcdir = @top_srcdir@
|
||||
dist_doc_DATA = capture.lua dumpdns2pcap.lua dumpdns.lua dumpdns-qr.lua \
|
||||
filter_rcode.lua qr-multi-pcap-state.lua readme.lua replay.lua \
|
||||
replay_multicli.lua respdiff.lua
|
||||
|
||||
all: all-am
|
||||
|
||||
.SUFFIXES:
|
||||
$(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps)
|
||||
@for dep in $?; do \
|
||||
case '$(am__configure_deps)' in \
|
||||
*$$dep*) \
|
||||
( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \
|
||||
&& { if test -f $@; then exit 0; else break; fi; }; \
|
||||
exit 1;; \
|
||||
esac; \
|
||||
done; \
|
||||
echo ' cd $(top_srcdir) && $(AUTOMAKE) --foreign examples/Makefile'; \
|
||||
$(am__cd) $(top_srcdir) && \
|
||||
$(AUTOMAKE) --foreign examples/Makefile
|
||||
Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status
|
||||
@case '$?' in \
|
||||
*config.status*) \
|
||||
cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \
|
||||
*) \
|
||||
echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles)'; \
|
||||
cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles);; \
|
||||
esac;
|
||||
|
||||
$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES)
|
||||
cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
|
||||
|
||||
$(top_srcdir)/configure: $(am__configure_deps)
|
||||
cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
|
||||
$(ACLOCAL_M4): $(am__aclocal_m4_deps)
|
||||
cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
|
||||
$(am__aclocal_m4_deps):
|
||||
|
||||
mostlyclean-libtool:
|
||||
-rm -f *.lo
|
||||
|
||||
clean-libtool:
|
||||
-rm -rf .libs _libs
|
||||
install-dist_docDATA: $(dist_doc_DATA)
|
||||
@$(NORMAL_INSTALL)
|
||||
@list='$(dist_doc_DATA)'; test -n "$(docdir)" || list=; \
|
||||
if test -n "$$list"; then \
|
||||
echo " $(MKDIR_P) '$(DESTDIR)$(docdir)'"; \
|
||||
$(MKDIR_P) "$(DESTDIR)$(docdir)" || exit 1; \
|
||||
fi; \
|
||||
for p in $$list; do \
|
||||
if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \
|
||||
echo "$$d$$p"; \
|
||||
done | $(am__base_list) | \
|
||||
while read files; do \
|
||||
echo " $(INSTALL_DATA) $$files '$(DESTDIR)$(docdir)'"; \
|
||||
$(INSTALL_DATA) $$files "$(DESTDIR)$(docdir)" || exit $$?; \
|
||||
done
|
||||
|
||||
uninstall-dist_docDATA:
|
||||
@$(NORMAL_UNINSTALL)
|
||||
@list='$(dist_doc_DATA)'; test -n "$(docdir)" || list=; \
|
||||
files=`for p in $$list; do echo $$p; done | sed -e 's|^.*/||'`; \
|
||||
dir='$(DESTDIR)$(docdir)'; $(am__uninstall_files_from_dir)
|
||||
gcov-local:
|
||||
tags TAGS:
|
||||
|
||||
ctags CTAGS:
|
||||
|
||||
cscope cscopelist:
|
||||
|
||||
|
||||
distdir: $(BUILT_SOURCES)
|
||||
$(MAKE) $(AM_MAKEFLAGS) distdir-am
|
||||
|
||||
distdir-am: $(DISTFILES)
|
||||
@srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \
|
||||
topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \
|
||||
list='$(DISTFILES)'; \
|
||||
dist_files=`for file in $$list; do echo $$file; done | \
|
||||
sed -e "s|^$$srcdirstrip/||;t" \
|
||||
-e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \
|
||||
case $$dist_files in \
|
||||
*/*) $(MKDIR_P) `echo "$$dist_files" | \
|
||||
sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \
|
||||
sort -u` ;; \
|
||||
esac; \
|
||||
for file in $$dist_files; do \
|
||||
if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \
|
||||
if test -d $$d/$$file; then \
|
||||
dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \
|
||||
if test -d "$(distdir)/$$file"; then \
|
||||
find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \
|
||||
fi; \
|
||||
if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \
|
||||
cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \
|
||||
find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \
|
||||
fi; \
|
||||
cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \
|
||||
else \
|
||||
test -f "$(distdir)/$$file" \
|
||||
|| cp -p $$d/$$file "$(distdir)/$$file" \
|
||||
|| exit 1; \
|
||||
fi; \
|
||||
done
|
||||
check-am: all-am
|
||||
check: check-am
|
||||
all-am: Makefile $(DATA)
|
||||
installdirs:
|
||||
for dir in "$(DESTDIR)$(docdir)"; do \
|
||||
test -z "$$dir" || $(MKDIR_P) "$$dir"; \
|
||||
done
|
||||
install: install-am
|
||||
install-exec: install-exec-am
|
||||
install-data: install-data-am
|
||||
uninstall: uninstall-am
|
||||
|
||||
install-am: all-am
|
||||
@$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am
|
||||
|
||||
installcheck: installcheck-am
|
||||
install-strip:
|
||||
if test -z '$(STRIP)'; then \
|
||||
$(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \
|
||||
install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \
|
||||
install; \
|
||||
else \
|
||||
$(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \
|
||||
install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \
|
||||
"INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \
|
||||
fi
|
||||
mostlyclean-generic:
|
||||
|
||||
clean-generic:
|
||||
|
||||
distclean-generic:
|
||||
-test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES)
|
||||
-test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES)
|
||||
|
||||
maintainer-clean-generic:
|
||||
@echo "This command is intended for maintainers to use"
|
||||
@echo "it deletes files that may require special tools to rebuild."
|
||||
clean: clean-am
|
||||
|
||||
clean-am: clean-generic clean-libtool mostlyclean-am
|
||||
|
||||
distclean: distclean-am
|
||||
-rm -f Makefile
|
||||
distclean-am: clean-am distclean-generic
|
||||
|
||||
dvi: dvi-am
|
||||
|
||||
dvi-am:
|
||||
|
||||
gcov: gcov-am
|
||||
|
||||
gcov-am: gcov-local
|
||||
|
||||
html: html-am
|
||||
|
||||
html-am:
|
||||
|
||||
info: info-am
|
||||
|
||||
info-am:
|
||||
|
||||
install-data-am: install-dist_docDATA
|
||||
|
||||
install-dvi: install-dvi-am
|
||||
|
||||
install-dvi-am:
|
||||
|
||||
install-exec-am:
|
||||
|
||||
install-html: install-html-am
|
||||
|
||||
install-html-am:
|
||||
|
||||
install-info: install-info-am
|
||||
|
||||
install-info-am:
|
||||
|
||||
install-man:
|
||||
|
||||
install-pdf: install-pdf-am
|
||||
|
||||
install-pdf-am:
|
||||
|
||||
install-ps: install-ps-am
|
||||
|
||||
install-ps-am:
|
||||
|
||||
installcheck-am:
|
||||
|
||||
maintainer-clean: maintainer-clean-am
|
||||
-rm -f Makefile
|
||||
maintainer-clean-am: distclean-am maintainer-clean-generic
|
||||
|
||||
mostlyclean: mostlyclean-am
|
||||
|
||||
mostlyclean-am: mostlyclean-generic mostlyclean-libtool
|
||||
|
||||
pdf: pdf-am
|
||||
|
||||
pdf-am:
|
||||
|
||||
ps: ps-am
|
||||
|
||||
ps-am:
|
||||
|
||||
uninstall-am: uninstall-dist_docDATA
|
||||
|
||||
.MAKE: install-am install-strip
|
||||
|
||||
.PHONY: all all-am check check-am clean clean-generic clean-libtool \
|
||||
cscopelist-am ctags-am distclean distclean-generic \
|
||||
distclean-libtool distdir dvi dvi-am gcov-am gcov-local html \
|
||||
html-am info info-am install install-am install-data \
|
||||
install-data-am install-dist_docDATA install-dvi \
|
||||
install-dvi-am install-exec install-exec-am install-html \
|
||||
install-html-am install-info install-info-am install-man \
|
||||
install-pdf install-pdf-am install-ps install-ps-am \
|
||||
install-strip installcheck installcheck-am installdirs \
|
||||
maintainer-clean maintainer-clean-generic mostlyclean \
|
||||
mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \
|
||||
tags-am uninstall uninstall-am uninstall-dist_docDATA
|
||||
|
||||
.PRECIOUS: Makefile
|
||||
|
||||
|
||||
# Tell versions [3.59,3.63) of GNU make to not export all variables.
|
||||
# Otherwise a system limit (for SysV at least) may be exceeded.
|
||||
.NOEXPORT:
|
|
@ -1,50 +0,0 @@
|
|||
#!/usr/bin/env dnsjit
|
||||
-- count-pkts-per-ip.lua: count number of packets received from each IP/IPv6 address
|
||||
|
||||
local input = require("dnsjit.input.pcap").new()
|
||||
local layer = require("dnsjit.filter.layer").new()
|
||||
local object = require("dnsjit.core.objects")
|
||||
local ip = require("dnsjit.lib.ip")
|
||||
local trie = require("dnsjit.lib.trie").new("uint64_t", true)
|
||||
local getopt = require("dnsjit.lib.getopt").new({})
|
||||
|
||||
local pcap = unpack(getopt:parse())
|
||||
if pcap == nil then
|
||||
print("usage: "..arg[1].." <pcap>")
|
||||
end
|
||||
|
||||
-- Set up input
|
||||
input:open_offline(pcap)
|
||||
layer:producer(input)
|
||||
local produce, pctx = layer:produce()
|
||||
|
||||
-- Read input and count packets
|
||||
while true do
|
||||
local obj = produce(pctx)
|
||||
if obj == nil then break end
|
||||
local pkt = obj:cast_to(object.IP) or obj:cast_to(object.IP6)
|
||||
|
||||
if pkt ~= nil then
|
||||
local iplen = 4
|
||||
if pkt:type() == "ip6" then
|
||||
iplen = 16
|
||||
end
|
||||
|
||||
local node = trie:get_ins(pkt.src, iplen)
|
||||
node:set(node:get() + 1)
|
||||
end
|
||||
end
|
||||
|
||||
-- Print statistics
|
||||
local iter = trie:iter()
|
||||
local node = iter:node()
|
||||
|
||||
while node ~= nil do
|
||||
local npkts = tonumber(node:get())
|
||||
local key = node:key()
|
||||
local ipstr = ip.tostring(key, true)
|
||||
|
||||
print(ipstr.." sent "..npkts.." packets")
|
||||
iter:next()
|
||||
node = iter:node()
|
||||
end
|
|
@ -1,18 +1,30 @@
|
|||
#!/usr/bin/env dnsjit
|
||||
local pcap = arg[2]
|
||||
local compression = arg[3]
|
||||
|
||||
if pcap == nil then
|
||||
print("usage: "..arg[1].." <pcap>")
|
||||
print("usage: "..arg[1].." <pcap> [compression]")
|
||||
return
|
||||
end
|
||||
|
||||
local object = require("dnsjit.core.objects")
|
||||
local input = require("dnsjit.input.pcap").new()
|
||||
local zinput = require("dnsjit.input.zpcap").new()
|
||||
local layer = require("dnsjit.filter.layer").new()
|
||||
local dns = require("dnsjit.core.object.dns").new()
|
||||
|
||||
input:open_offline(pcap)
|
||||
layer:producer(input)
|
||||
if string.lower(string.sub(pcap, -4)) == ".zst" or compression == "zstd" then
|
||||
zinput:zstd()
|
||||
zinput:open(pcap)
|
||||
layer:producer(zinput)
|
||||
elseif string.lower(string.sub(pcap, -4)) == ".lz4" or compression == "lz4" then
|
||||
zinput:lz4()
|
||||
zinput:open(pcap)
|
||||
layer:producer(zinput)
|
||||
else
|
||||
input:open_offline(pcap)
|
||||
layer:producer(input)
|
||||
end
|
||||
local producer, ctx = layer:produce()
|
||||
|
||||
while true do
|
||||
|
|
|
@ -1,149 +0,0 @@
|
|||
#!/usr/bin/env dnsjit
|
||||
local clock = require("dnsjit.lib.clock")
|
||||
local log = require("dnsjit.core.log")
|
||||
local getopt = require("dnsjit.lib.getopt").new({
|
||||
{ "v", "verbose", 0, "Enable and increase verbosity for each time given", "?+" },
|
||||
{ "l", "layer", false, "Test also with dnsjit.filter.layer", "?" },
|
||||
{ "p", "producer", false, "Test with the producer interface rather then receiver interface", "?" },
|
||||
})
|
||||
local pcap, runs = unpack(getopt:parse())
|
||||
if getopt:val("help") then
|
||||
getopt:usage()
|
||||
return
|
||||
end
|
||||
local v = getopt:val("v")
|
||||
if v > 0 then
|
||||
log.enable("warning")
|
||||
end
|
||||
if v > 1 then
|
||||
log.enable("notice")
|
||||
end
|
||||
if v > 2 then
|
||||
log.enable("info")
|
||||
end
|
||||
if v > 3 then
|
||||
log.enable("debug")
|
||||
end
|
||||
|
||||
if pcap == nil then
|
||||
print("usage: "..arg[1].." <pcap> [runs]")
|
||||
return
|
||||
end
|
||||
|
||||
inputs = { "fpcap", "mmpcap", "pcap" }
|
||||
result = {}
|
||||
results = {}
|
||||
highest = nil
|
||||
|
||||
if runs == nil then
|
||||
runs = 10
|
||||
else
|
||||
runs = tonumber(runs)
|
||||
end
|
||||
|
||||
if getopt:val("p") then
|
||||
for _, name in pairs(inputs) do
|
||||
rt = 0.0
|
||||
p = 0
|
||||
|
||||
print("run", name)
|
||||
for n = 1, runs do
|
||||
o = require("dnsjit.output.null").new()
|
||||
i = require("dnsjit.input."..name).new()
|
||||
|
||||
if name == "pcap" then
|
||||
i:open_offline(pcap)
|
||||
else
|
||||
i:open(pcap)
|
||||
end
|
||||
|
||||
if getopt:val("l") then
|
||||
f = require("dnsjit.filter.layer").new()
|
||||
f:producer(i)
|
||||
o:producer(f)
|
||||
else
|
||||
o:producer(i)
|
||||
end
|
||||
|
||||
ss, sns = clock:monotonic()
|
||||
o:run()
|
||||
es, ens = clock:monotonic()
|
||||
|
||||
if es > ss then
|
||||
rt = rt + ((es - ss) - 1) + ((1000000000 - sns + ens)/1000000000)
|
||||
elseif es == ss and ens > sns then
|
||||
rt = rt + (ens - sns) / 1000000000
|
||||
end
|
||||
|
||||
p = p + o:packets()
|
||||
end
|
||||
|
||||
result[name] = {
|
||||
rt = rt,
|
||||
p = p
|
||||
}
|
||||
if highest == nil or rt > result[highest].rt then
|
||||
highest = name
|
||||
end
|
||||
table.insert(results, name)
|
||||
end
|
||||
else
|
||||
for _, name in pairs(inputs) do
|
||||
rt = 0.0
|
||||
p = 0
|
||||
|
||||
print("run", name)
|
||||
for n = 1, runs do
|
||||
o = require("dnsjit.output.null").new()
|
||||
i = require("dnsjit.input."..name).new()
|
||||
|
||||
if name == "pcap" then
|
||||
i:open_offline(pcap)
|
||||
else
|
||||
i:open(pcap)
|
||||
end
|
||||
|
||||
if getopt:val("l") then
|
||||
f = require("dnsjit.filter.layer").new()
|
||||
f:receiver(o)
|
||||
i:receiver(f)
|
||||
else
|
||||
i:receiver(o)
|
||||
end
|
||||
|
||||
ss, sns = clock:monotonic()
|
||||
if name == "pcap" then
|
||||
i:dispatch()
|
||||
else
|
||||
i:run()
|
||||
end
|
||||
es, ens = clock:monotonic()
|
||||
|
||||
if es > ss then
|
||||
rt = rt + ((es - ss) - 1) + ((1000000000 - sns + ens)/1000000000)
|
||||
elseif es == ss and ens > sns then
|
||||
rt = rt + (ens - sns) / 1000000000
|
||||
end
|
||||
|
||||
p = p + o:packets()
|
||||
end
|
||||
|
||||
result[name] = {
|
||||
rt = rt,
|
||||
p = p
|
||||
}
|
||||
if highest == nil or rt > result[highest].rt then
|
||||
highest = name
|
||||
end
|
||||
table.insert(results, name)
|
||||
end
|
||||
end
|
||||
|
||||
print("name", "runtime", "pps", "x", "pkts")
|
||||
print(highest, result[highest].rt, result[highest].p/result[highest].rt, 1.0, result[highest].p)
|
||||
for _, name in pairs(results) do
|
||||
if name ~= highest then
|
||||
local f = result[name].p / result[highest].p
|
||||
print(name, result[name].rt, result[name].p/result[name].rt, (result[highest].rt/result[name].rt)*f, result[name].p)
|
||||
end
|
||||
end
|
|
@ -1,539 +0,0 @@
|
|||
#!/usr/bin/env dnsjit
|
||||
local ffi = require("ffi")
|
||||
local object = require("dnsjit.core.objects")
|
||||
local clock = require("dnsjit.lib.clock")
|
||||
local log = require("dnsjit.core.log")
|
||||
local getopt = require("dnsjit.lib.getopt").new({
|
||||
{ "v", "verbose", 0, "Enable and increase verbosity for each time given", "?+" },
|
||||
{ "s", "split", false, "Test also with dnsjit.filter.split", "?" },
|
||||
{ "t", "thread", false, "Test also with dnsjit.core.thread using dnsjit.core.channel", "?" },
|
||||
})
|
||||
local num, runs = unpack(getopt:parse())
|
||||
if getopt:val("help") then
|
||||
getopt:usage()
|
||||
return
|
||||
end
|
||||
local v = getopt:val("v")
|
||||
if v > 0 then
|
||||
log.enable("warning")
|
||||
end
|
||||
if v > 1 then
|
||||
log.enable("notice")
|
||||
end
|
||||
if v > 2 then
|
||||
log.enable("info")
|
||||
end
|
||||
if v > 3 then
|
||||
log.enable("debug")
|
||||
end
|
||||
|
||||
if num == nil then
|
||||
print("usage: "..arg[1].." <num> [runs]")
|
||||
return
|
||||
else
|
||||
num = tonumber(num)
|
||||
end
|
||||
|
||||
if runs == nil then
|
||||
runs = 1
|
||||
else
|
||||
runs = tonumber(runs)
|
||||
end
|
||||
|
||||
print("zero:receiver() -> null:receive()")
|
||||
local run
|
||||
for run = 1, runs do
|
||||
local i = require("dnsjit.input.zero").new()
|
||||
local o = require("dnsjit.output.null").new()
|
||||
|
||||
i:receiver(o)
|
||||
local start_sec, start_nsec = clock:monotonic()
|
||||
i:run(num)
|
||||
local end_sec, end_nsec = clock:monotonic()
|
||||
|
||||
local runtime = 0
|
||||
if end_sec > start_sec then
|
||||
runtime = ((end_sec - start_sec) - 1) + ((1000000000 - start_nsec + end_nsec)/1000000000)
|
||||
elseif end_sec == start_sec and end_nsec > start_nsec then
|
||||
runtime = (end_nsec - start_nsec) / 1000000000
|
||||
end
|
||||
|
||||
print(run, "runtime", runtime, num/runtime, "/sec", o:packets())
|
||||
end
|
||||
|
||||
print("lua -> null:receive()")
|
||||
local run
|
||||
for run = 1, runs do
|
||||
local o = require("dnsjit.output.null").new()
|
||||
local recv, rctx = o:receive()
|
||||
local pkt = ffi.new("core_object_null_t")
|
||||
pkt.obj_type = object.NULL
|
||||
local obj = ffi.cast("core_object_t*", pkt)
|
||||
|
||||
local start_sec, start_nsec = clock:monotonic()
|
||||
for n = 1, num do
|
||||
recv(rctx, obj)
|
||||
end
|
||||
local end_sec, end_nsec = clock:monotonic()
|
||||
|
||||
local runtime = 0
|
||||
if end_sec > start_sec then
|
||||
runtime = ((end_sec - start_sec) - 1) + ((1000000000 - start_nsec + end_nsec)/1000000000)
|
||||
elseif end_sec == start_sec and end_nsec > start_nsec then
|
||||
runtime = (end_nsec - start_nsec) / 1000000000
|
||||
end
|
||||
|
||||
print(run, "runtime", runtime, num/runtime, "/sec", o:packets())
|
||||
end
|
||||
|
||||
-- TODO: use core.thread
|
||||
|
||||
print("zero:produce() <- null:producer()")
|
||||
local run
|
||||
for run = 1, runs do
|
||||
local i = require("dnsjit.input.zero").new()
|
||||
local o = require("dnsjit.output.null").new()
|
||||
|
||||
local start_sec, start_nsec = clock:monotonic()
|
||||
o:producer(i)
|
||||
o:run(num)
|
||||
local end_sec, end_nsec = clock:monotonic()
|
||||
|
||||
local runtime = 0
|
||||
if end_sec > start_sec then
|
||||
runtime = ((end_sec - start_sec) - 1) + ((1000000000 - start_nsec + end_nsec)/1000000000)
|
||||
elseif end_sec == start_sec and end_nsec > start_nsec then
|
||||
runtime = (end_nsec - start_nsec) / 1000000000
|
||||
end
|
||||
|
||||
print(run, "runtime", runtime, num/runtime, "/sec", o:packets())
|
||||
end
|
||||
|
||||
print("zero:produce() <- lua")
|
||||
local run
|
||||
for run = 1, runs do
|
||||
local i = require("dnsjit.input.zero").new()
|
||||
local prod, pctx = i:produce()
|
||||
|
||||
local start_sec, start_nsec = clock:monotonic()
|
||||
for n = 1, num do
|
||||
prod(pctx)
|
||||
end
|
||||
local end_sec, end_nsec = clock:monotonic()
|
||||
|
||||
local runtime = 0
|
||||
if end_sec > start_sec then
|
||||
runtime = ((end_sec - start_sec) - 1) + ((1000000000 - start_nsec + end_nsec)/1000000000)
|
||||
elseif end_sec == start_sec and end_nsec > start_nsec then
|
||||
runtime = (end_nsec - start_nsec) / 1000000000
|
||||
end
|
||||
|
||||
print(run, "runtime", runtime, num/runtime, "/sec", num)
|
||||
end
|
||||
|
||||
print("zero:produce() <- lua -> null:receive()")
|
||||
local run
|
||||
for run = 1, runs do
|
||||
local i = require("dnsjit.input.zero").new()
|
||||
local o = require("dnsjit.output.null").new()
|
||||
local prod, pctx = i:produce()
|
||||
local recv, rctx = o:receive()
|
||||
|
||||
local start_sec, start_nsec = clock:monotonic()
|
||||
for n = 1, num do
|
||||
recv(rctx, prod(pctx))
|
||||
end
|
||||
local end_sec, end_nsec = clock:monotonic()
|
||||
|
||||
local runtime = 0
|
||||
if end_sec > start_sec then
|
||||
runtime = ((end_sec - start_sec) - 1) + ((1000000000 - start_nsec + end_nsec)/1000000000)
|
||||
elseif end_sec == start_sec and end_nsec > start_nsec then
|
||||
runtime = (end_nsec - start_nsec) / 1000000000
|
||||
end
|
||||
|
||||
print(run, "runtime", runtime, num/runtime, "/sec", num)
|
||||
end
|
||||
|
||||
if getopt:val("s") then
|
||||
print("zero:receiver() -> split:receiver() -> null:receive() x1")
|
||||
local run
|
||||
for run = 1, runs do
|
||||
local i = require("dnsjit.input.zero").new()
|
||||
local s = require("dnsjit.filter.split").new()
|
||||
local o1 = require("dnsjit.output.null").new()
|
||||
|
||||
s:receiver(o1)
|
||||
i:receiver(s)
|
||||
local start_sec, start_nsec = clock:monotonic()
|
||||
i:run(num)
|
||||
local end_sec, end_nsec = clock:monotonic()
|
||||
|
||||
local runtime = 0
|
||||
if end_sec > start_sec then
|
||||
runtime = ((end_sec - start_sec) - 1) + ((1000000000 - start_nsec + end_nsec)/1000000000)
|
||||
elseif end_sec == start_sec and end_nsec > start_nsec then
|
||||
runtime = (end_nsec - start_nsec) / 1000000000
|
||||
end
|
||||
|
||||
print(run, "runtime", runtime, num/runtime, "/sec", o1:packets(), o1:packets())
|
||||
end
|
||||
|
||||
print("zero:receiver() -> split:receiver() -> null:receive() x2")
|
||||
local run
|
||||
for run = 1, runs do
|
||||
local i = require("dnsjit.input.zero").new()
|
||||
local s = require("dnsjit.filter.split").new()
|
||||
local o1 = require("dnsjit.output.null").new()
|
||||
local o2 = require("dnsjit.output.null").new()
|
||||
|
||||
s:receiver(o1)
|
||||
s:receiver(o2)
|
||||
i:receiver(s)
|
||||
local start_sec, start_nsec = clock:monotonic()
|
||||
i:run(num)
|
||||
local end_sec, end_nsec = clock:monotonic()
|
||||
|
||||
local runtime = 0
|
||||
if end_sec > start_sec then
|
||||
runtime = ((end_sec - start_sec) - 1) + ((1000000000 - start_nsec + end_nsec)/1000000000)
|
||||
elseif end_sec == start_sec and end_nsec > start_nsec then
|
||||
runtime = (end_nsec - start_nsec) / 1000000000
|
||||
end
|
||||
|
||||
print(run, "runtime", runtime, num/runtime, "/sec", o1:packets() + o2:packets(), o1:packets(), o2:packets())
|
||||
end
|
||||
|
||||
print("zero:receiver() -> split:receiver() -> null:receive() x4")
|
||||
local run
|
||||
for run = 1, runs do
|
||||
local i = require("dnsjit.input.zero").new()
|
||||
local s = require("dnsjit.filter.split").new()
|
||||
local o1 = require("dnsjit.output.null").new()
|
||||
local o2 = require("dnsjit.output.null").new()
|
||||
local o3 = require("dnsjit.output.null").new()
|
||||
local o4 = require("dnsjit.output.null").new()
|
||||
|
||||
s:receiver(o1)
|
||||
s:receiver(o2)
|
||||
s:receiver(o3)
|
||||
s:receiver(o4)
|
||||
i:receiver(s)
|
||||
local start_sec, start_nsec = clock:monotonic()
|
||||
i:run(num)
|
||||
local end_sec, end_nsec = clock:monotonic()
|
||||
|
||||
local runtime = 0
|
||||
if end_sec > start_sec then
|
||||
runtime = ((end_sec - start_sec) - 1) + ((1000000000 - start_nsec + end_nsec)/1000000000)
|
||||
elseif end_sec == start_sec and end_nsec > start_nsec then
|
||||
runtime = (end_nsec - start_nsec) / 1000000000
|
||||
end
|
||||
|
||||
print(run, "runtime", runtime, num/runtime, "/sec", o1:packets() + o2:packets() + o3:packets() + o4:packets(), o1:packets(), o2:packets(), o3:packets(), o4:packets())
|
||||
end
|
||||
|
||||
print("zero:receiver() -> lua split table -> null:receive() x4")
|
||||
local run
|
||||
for run = 1, runs do
|
||||
local i = require("dnsjit.input.zero").new()
|
||||
local o1 = require("dnsjit.output.null").new()
|
||||
local o2 = require("dnsjit.output.null").new()
|
||||
local o3 = require("dnsjit.output.null").new()
|
||||
local o4 = require("dnsjit.output.null").new()
|
||||
|
||||
local prod, pctx = i:produce()
|
||||
local recv, rctx = {}, {}
|
||||
|
||||
local f, c = o1:receive()
|
||||
table.insert(recv, f)
|
||||
table.insert(rctx, c)
|
||||
f, c = o2:receive()
|
||||
table.insert(recv, f)
|
||||
table.insert(rctx, c)
|
||||
f, c = o3:receive()
|
||||
table.insert(recv, f)
|
||||
table.insert(rctx, c)
|
||||
f, c = o4:receive()
|
||||
table.insert(recv, f)
|
||||
table.insert(rctx, c)
|
||||
|
||||
local start_sec, start_nsec = clock:monotonic()
|
||||
local idx = 1
|
||||
for n = 1, num do
|
||||
local f, c = recv[idx], rctx[idx]
|
||||
if not f then
|
||||
idx = 1
|
||||
f, c = recv[1], rctx[1]
|
||||
end
|
||||
f(c, prod(pctx))
|
||||
idx = idx + 1
|
||||
end
|
||||
local end_sec, end_nsec = clock:monotonic()
|
||||
|
||||
local runtime = 0
|
||||
if end_sec > start_sec then
|
||||
runtime = ((end_sec - start_sec) - 1) + ((1000000000 - start_nsec + end_nsec)/1000000000)
|
||||
elseif end_sec == start_sec and end_nsec > start_nsec then
|
||||
runtime = (end_nsec - start_nsec) / 1000000000
|
||||
end
|
||||
|
||||
print(run, "runtime", runtime, num/runtime, "/sec", o1:packets() + o2:packets() + o3:packets() + o4:packets(), o1:packets(), o2:packets(), o3:packets(), o4:packets())
|
||||
end
|
||||
|
||||
print("zero:receiver() -> lua split gen code -> null:receive() x4")
|
||||
local run
|
||||
for run = 1, runs do
|
||||
local i = require("dnsjit.input.zero").new()
|
||||
local o1 = require("dnsjit.output.null").new()
|
||||
local o2 = require("dnsjit.output.null").new()
|
||||
local o3 = require("dnsjit.output.null").new()
|
||||
local o4 = require("dnsjit.output.null").new()
|
||||
|
||||
local prod, pctx = i:produce()
|
||||
local f1, c1 = o1:receive()
|
||||
local f2, c2 = o2:receive()
|
||||
local f3, c3 = o3:receive()
|
||||
local f4, c4 = o4:receive()
|
||||
|
||||
local code = "return function (num, prod, pctx, f1, c1, f2, c2, f3, c3, f4, c4)\nlocal n = 0\nwhile n < num do\n"
|
||||
code = code .. "f1(c1,prod(pctx))\n"
|
||||
code = code .. "n = n + 1\n"
|
||||
code = code .. "f2(c2,prod(pctx))\n"
|
||||
code = code .. "n = n + 1\n"
|
||||
code = code .. "f3(c3,prod(pctx))\n"
|
||||
code = code .. "n = n + 1\n"
|
||||
code = code .. "f4(c4,prod(pctx))\n"
|
||||
code = code .. "n = n + 1\n"
|
||||
code = code .. "end\n"
|
||||
code = code .. "end"
|
||||
local f = assert(loadstring(code))()
|
||||
|
||||
local start_sec, start_nsec = clock:monotonic()
|
||||
f(num, prod, pctx, f1, c1, f2, c2, f3, c3, f4, c4)
|
||||
local end_sec, end_nsec = clock:monotonic()
|
||||
|
||||
local runtime = 0
|
||||
if end_sec > start_sec then
|
||||
runtime = ((end_sec - start_sec) - 1) + ((1000000000 - start_nsec + end_nsec)/1000000000)
|
||||
elseif end_sec == start_sec and end_nsec > start_nsec then
|
||||
runtime = (end_nsec - start_nsec) / 1000000000
|
||||
end
|
||||
|
||||
print(run, "runtime", runtime, num/runtime, "/sec", o1:packets() + o2:packets() + o3:packets() + o4:packets(), o1:packets(), o2:packets(), o3:packets(), o4:packets())
|
||||
end
|
||||
end
|
||||
|
||||
if getopt:val("t") then
|
||||
print("zero:receiver() -> thread lua x1")
|
||||
local run
|
||||
for run = 1, runs do
|
||||
local i = require("dnsjit.input.zero").new()
|
||||
local c = require("dnsjit.core.channel").new()
|
||||
local t = require("dnsjit.core.thread").new()
|
||||
|
||||
t:start(function(t)
|
||||
local c = t:pop()
|
||||
|
||||
while true do
|
||||
local o = c:get()
|
||||
if o == nil then break end
|
||||
end
|
||||
end)
|
||||
t:push(c)
|
||||
|
||||
local prod, pctx = i:produce()
|
||||
local start_sec, start_nsec = clock:monotonic()
|
||||
for n = 1, num do
|
||||
c:put(prod(pctx))
|
||||
end
|
||||
c:close()
|
||||
t:stop()
|
||||
local end_sec, end_nsec = clock:monotonic()
|
||||
|
||||
local runtime = 0
|
||||
if end_sec > start_sec then
|
||||
runtime = ((end_sec - start_sec) - 1) + ((1000000000 - start_nsec + end_nsec)/1000000000)
|
||||
elseif end_sec == start_sec and end_nsec > start_nsec then
|
||||
runtime = (end_nsec - start_nsec) / 1000000000
|
||||
end
|
||||
|
||||
print(run, "runtime", runtime, num/runtime, "/sec")
|
||||
end
|
||||
|
||||
print("zero:receiver() -> thread lua x2")
|
||||
local run
|
||||
for run = 1, runs do
|
||||
local i = require("dnsjit.input.zero").new()
|
||||
local c = require("dnsjit.core.channel").new()
|
||||
local c2 = require("dnsjit.core.channel").new()
|
||||
local t = require("dnsjit.core.thread").new()
|
||||
local t2 = require("dnsjit.core.thread").new()
|
||||
|
||||
local f = function(t)
|
||||
local c = t:pop()
|
||||
|
||||
while true do
|
||||
local o = c:get()
|
||||
if o == nil then break end
|
||||
end
|
||||
end
|
||||
|
||||
t:start(f)
|
||||
t2:start(f)
|
||||
t:push(c)
|
||||
t2:push(c2)
|
||||
|
||||
local prod, pctx = i:produce()
|
||||
local start_sec, start_nsec = clock:monotonic()
|
||||
for n = 1, num/2 do
|
||||
c:put(prod(pctx))
|
||||
c2:put(prod(pctx))
|
||||
end
|
||||
c:close()
|
||||
c2:close()
|
||||
t:stop()
|
||||
t2:stop()
|
||||
local end_sec, end_nsec = clock:monotonic()
|
||||
|
||||
local runtime = 0
|
||||
if end_sec > start_sec then
|
||||
runtime = ((end_sec - start_sec) - 1) + ((1000000000 - start_nsec + end_nsec)/1000000000)
|
||||
elseif end_sec == start_sec and end_nsec > start_nsec then
|
||||
runtime = (end_nsec - start_nsec) / 1000000000
|
||||
end
|
||||
|
||||
print(run, "runtime", runtime, num/runtime, "/sec")
|
||||
end
|
||||
|
||||
print("zero:receiver() -> thread lua x4")
|
||||
local run
|
||||
for run = 1, runs do
|
||||
local i = require("dnsjit.input.zero").new()
|
||||
local c = require("dnsjit.core.channel").new()
|
||||
local c2 = require("dnsjit.core.channel").new()
|
||||
local c3 = require("dnsjit.core.channel").new()
|
||||
local c4 = require("dnsjit.core.channel").new()
|
||||
local t = require("dnsjit.core.thread").new()
|
||||
local t2 = require("dnsjit.core.thread").new()
|
||||
local t3 = require("dnsjit.core.thread").new()
|
||||
local t4 = require("dnsjit.core.thread").new()
|
||||
|
||||
local f = function(t)
|
||||
local c = t:pop()
|
||||
|
||||
while true do
|
||||
local o = c:get()
|
||||
if o == nil then break end
|
||||
end
|
||||
end
|
||||
|
||||
t:start(f)
|
||||
t2:start(f)
|
||||
t3:start(f)
|
||||
t4:start(f)
|
||||
t:push(c)
|
||||
t2:push(c2)
|
||||
t3:push(c3)
|
||||
t4:push(c4)
|
||||
|
||||
local prod, pctx = i:produce()
|
||||
local start_sec, start_nsec = clock:monotonic()
|
||||
for n = 1, num/4 do
|
||||
c:put(prod(pctx))
|
||||
c2:put(prod(pctx))
|
||||
c3:put(prod(pctx))
|
||||
c4:put(prod(pctx))
|
||||
end
|
||||
c:close()
|
||||
c2:close()
|
||||
c3:close()
|
||||
c4:close()
|
||||
t:stop()
|
||||
t2:stop()
|
||||
t3:stop()
|
||||
t4:stop()
|
||||
local end_sec, end_nsec = clock:monotonic()
|
||||
|
||||
local runtime = 0
|
||||
if end_sec > start_sec then
|
||||
runtime = ((end_sec - start_sec) - 1) + ((1000000000 - start_nsec + end_nsec)/1000000000)
|
||||
elseif end_sec == start_sec and end_nsec > start_nsec then
|
||||
runtime = (end_nsec - start_nsec) / 1000000000
|
||||
end
|
||||
|
||||
print(run, "runtime", runtime, num/runtime, "/sec")
|
||||
end
|
||||
|
||||
print("zero:receiver() -> thread lua x1 -> null:receiver()")
|
||||
local run
|
||||
for run = 1, runs do
|
||||
local i = require("dnsjit.input.zero").new()
|
||||
local c = require("dnsjit.core.channel").new()
|
||||
local t = require("dnsjit.core.thread").new()
|
||||
|
||||
t:start(function(t)
|
||||
local c = t:pop()
|
||||
local o = require("dnsjit.output.null").new()
|
||||
|
||||
local recv, rctx = o:receive()
|
||||
while true do
|
||||
local obj = c:get()
|
||||
if obj == nil then break end
|
||||
recv(rctx, obj)
|
||||
end
|
||||
end)
|
||||
t:push(c)
|
||||
|
||||
local prod, pctx = i:produce()
|
||||
local start_sec, start_nsec = clock:monotonic()
|
||||
for n = 1, num do
|
||||
c:put(prod(pctx))
|
||||
end
|
||||
c:close()
|
||||
t:stop()
|
||||
local end_sec, end_nsec = clock:monotonic()
|
||||
|
||||
local runtime = 0
|
||||
if end_sec > start_sec then
|
||||
runtime = ((end_sec - start_sec) - 1) + ((1000000000 - start_nsec + end_nsec)/1000000000)
|
||||
elseif end_sec == start_sec and end_nsec > start_nsec then
|
||||
runtime = (end_nsec - start_nsec) / 1000000000
|
||||
end
|
||||
|
||||
print(run, "runtime", runtime, num/runtime, "/sec")
|
||||
end
|
||||
|
||||
print("zero:receiver() -> thread x1 -> null:receiver()")
|
||||
local run
|
||||
for run = 1, runs do
|
||||
local i = require("dnsjit.input.zero").new()
|
||||
local c = require("dnsjit.core.channel").new()
|
||||
local t = require("dnsjit.core.thread").new()
|
||||
|
||||
t:start(function(t)
|
||||
local c = t:pop()
|
||||
local o = require("dnsjit.output.null").new()
|
||||
|
||||
c:receiver(o)
|
||||
c:run()
|
||||
end)
|
||||
t:push(c)
|
||||
|
||||
i:receiver(c)
|
||||
local start_sec, start_nsec = clock:monotonic()
|
||||
i:run(num)
|
||||
c:close()
|
||||
t:stop()
|
||||
local end_sec, end_nsec = clock:monotonic()
|
||||
|
||||
local runtime = 0
|
||||
if end_sec > start_sec then
|
||||
runtime = ((end_sec - start_sec) - 1) + ((1000000000 - start_nsec + end_nsec)/1000000000)
|
||||
elseif end_sec == start_sec and end_nsec > start_nsec then
|
||||
runtime = (end_nsec - start_nsec) / 1000000000
|
||||
end
|
||||
|
||||
print(run, "runtime", runtime, num/runtime, "/sec")
|
||||
end
|
||||
end
|
Loading…
Add table
Add a link
Reference in a new issue