diff options
author | Mario Preksavec <mario at slackware dot hr> | 2017-11-24 00:56:19 +0000 |
---|---|---|
committer | David Spencer <idlemoor@slackbuilds.org> | 2017-11-24 00:56:19 +0000 |
commit | 3df30f21d4a37c14f7373e3ae8652472e1930756 (patch) | |
tree | 495826e790df118322b38a3f05b102a59bfe3b7e | |
parent | d9af86bf24bd35747c10bd36bf459e7f80c1d772 (diff) |
network/iptv-analyzer: Added (IPTV MPEG2 Transport Stream Analyzer).
Signed-off-by: David Spencer <idlemoor@slackbuilds.org>
-rw-r--r-- | network/iptv-analyzer/README | 8 | ||||
-rw-r--r-- | network/iptv-analyzer/doinst.sh | 3 | ||||
-rw-r--r-- | network/iptv-analyzer/iptv-analyzer.SlackBuild | 143 | ||||
-rw-r--r-- | network/iptv-analyzer/iptv-analyzer.info | 10 | ||||
-rw-r--r-- | network/iptv-analyzer/patches/Makefile.am.diff | 13 | ||||
-rw-r--r-- | network/iptv-analyzer/patches/Makefile.in.diff | 11 | ||||
-rw-r--r-- | network/iptv-analyzer/patches/e5d7c0b90cfe3218d67b56e122140456206f6a65.patch | 41 | ||||
-rw-r--r-- | network/iptv-analyzer/patches/kernel-4.4.diff | 81 | ||||
-rw-r--r-- | network/iptv-analyzer/slack-desc | 19 |
9 files changed, 329 insertions, 0 deletions
diff --git a/network/iptv-analyzer/README b/network/iptv-analyzer/README new file mode 100644 index 000000000000..4388448340a3 --- /dev/null +++ b/network/iptv-analyzer/README @@ -0,0 +1,8 @@ +The IPTV-Analyzer is a continuous/real-time tool for analyzing the contents +of MPEG2 Transport Stream (TS) packets, which is commonly used for IPTV +multicast signals. + +The main purpose is continuous quality measurement, with a focus on detecting +MPEG2 TS/CC packet drops. + +It scales to hundreds of IPTV channels, even on small ATOM based CPUs. diff --git a/network/iptv-analyzer/doinst.sh b/network/iptv-analyzer/doinst.sh new file mode 100644 index 000000000000..a4258c7da6e3 --- /dev/null +++ b/network/iptv-analyzer/doinst.sh @@ -0,0 +1,3 @@ +if [ -x sbin/depmod ]; then + chroot . /sbin/depmod -a @@KERNEL@@ >/dev/null 2>&1 +fi diff --git a/network/iptv-analyzer/iptv-analyzer.SlackBuild b/network/iptv-analyzer/iptv-analyzer.SlackBuild new file mode 100644 index 000000000000..6b2631355ab4 --- /dev/null +++ b/network/iptv-analyzer/iptv-analyzer.SlackBuild @@ -0,0 +1,143 @@ +#!/bin/sh + +# Slackware build script for iptv-analyzer + +# Copyright 2013, 2015, 2016, 2017 Mario Preksavec, Zagreb, Croatia +# All rights reserved. +# +# Redistribution and use of this script, with or without modification, is +# permitted provided that the following conditions are met: +# +# 1. Redistributions of this script must retain the above copyright +# notice, this list of conditions and the following disclaimer. +# +# THIS SOFTWARE IS PROVIDED BY THE AUTHOR "AS IS" AND ANY EXPRESS OR IMPLIED +# WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF +# MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO +# EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, +# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, +# PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; +# OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, +# WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR +# OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF +# ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + +PRGNAM=iptv-analyzer +VERSION=${VERSION:-0.9.4} +BUILD=${BUILD:-1} +TAG=${TAG:-_SBo} + +SRCNAM=IPTV-Analyzer +KERNEL=${KERNEL:-$( uname -r )} + +if [ -z "$ARCH" ]; then + case "$( uname -m )" in + i?86) ARCH=i586 ;; + arm*) ARCH=arm ;; + *) ARCH=$( uname -m ) ;; + esac +fi + +CWD=$(pwd) +TMP=${TMP:-/tmp/SBo} +PKG=$TMP/package-$PRGNAM +OUTPUT=${OUTPUT:-/tmp} + +if [ "$ARCH" = "i586" ]; then + SLKCFLAGS="-O2 -march=i586 -mtune=i686" + LIBDIRSUFFIX="" +elif [ "$ARCH" = "i686" ]; then + SLKCFLAGS="-O2 -march=i686 -mtune=i686" + LIBDIRSUFFIX="" +elif [ "$ARCH" = "x86_64" ]; then + SLKCFLAGS="-O2 -fPIC" + LIBDIRSUFFIX="64" +else + SLKCFLAGS="-O2" + LIBDIRSUFFIX="" +fi + +set -e + +rm -rf $PKG +mkdir -p $TMP $PKG $OUTPUT +cd $TMP +rm -rf $SRCNAM-$VERSION +tar xvf $CWD/$SRCNAM-$VERSION.tar.gz +cd $SRCNAM-$VERSION +chown -R root:root . +find -L . \ + \( -perm 777 -o -perm 775 -o -perm 750 -o -perm 711 -o -perm 555 \ + -o -perm 511 \) -exec chmod 755 {} \; -o \ + \( -perm 666 -o -perm 664 -o -perm 640 -o -perm 600 -o -perm 444 \ + -o -perm 440 -o -perm 400 \) -exec chmod 644 {} \; + +patch -p1 <$CWD/patches/e5d7c0b90cfe3218d67b56e122140456206f6a65.patch +patch -p1 <$CWD/patches/kernel-4.4.diff +patch -p1 <$CWD/patches/Makefile.am.diff +patch -p1 <$CWD/patches/Makefile.in.diff + +./autogen.sh + +mkdir -p $PKG/usr/lib${LIBDIRSUFFIX}/xtables + +env -u ARCH \ +CFLAGS="$SLKCFLAGS" \ +CXXFLAGS="$SLKCFLAGS" \ +./configure \ + --prefix=/usr \ + --libdir=/usr/lib${LIBDIRSUFFIX} \ + --sysconfdir=/etc \ + --localstatedir=/var \ + --mandir=/usr/man \ + --docdir=/usr/doc/$PRGNAM-$VERSION \ + --datarootdir=/usr \ + --with-xtlibdir=$PKG/usr/lib${LIBDIRSUFFIX}/xtables \ + --with-kbuild=/lib/modules/$KERNEL/build \ + --build=$ARCH-slackware-linux + +make +make install DESTDIR=$PKG \ + INSTALLDIRS=vendor \ + INST_ETC=$PKG/etc/$PRGNAM \ + INSTALL_MOD_PATH=$PKG + +# Module installer was too leaky +mkdir -p $PKG/lib/modules/$KERNEL/extra +cp -a iptables-module/{compat_xtables,xt_mpeg2ts}.ko \ + $PKG/lib/modules/$KERNEL/extra + +# Manpages are a bit stubborn +mv $PKG/usr/share/man $PKG/usr + +# Fonts are elsewhere +sed -i 's#usr/share/fonts/truetype/freefont#usr/share/fonts/TTF#' \ + webfrontend/www/{graphs.inc.php,staging/pie01.php} + +find $PKG -print0 | xargs -0 file | grep -e "executable" -e "shared object" | grep ELF \ + | cut -f 1 -d : | xargs strip --strip-unneeded 2> /dev/null || true + +find $PKG/usr/man -type f -exec gzip -9 {} \; +for i in $( find $PKG/usr/man -type l ) ; do ln -s $( readlink $i ).gz $i.gz ; rm $i ; done + +# Remove perllocal.pod and other special files that don't need to be installed +find $PKG -name perllocal.pod -o -name ".packlist" -o -name "*.bs" | xargs rm -f || true + +# Remove empty directories +find $PKG -depth -type d -empty -delete || true + +# Remove git cruft +find $PKG -type f -name .gitignore -delete + +mkdir -p $PKG/usr/doc/$PRGNAM-$VERSION +cp -a COPYING ChangeLog INSTALL README.wiki TODO database doc/* \ + collector/bin/generate-test-snmptrap.pl webfrontend $PKG/usr/doc/$PRGNAM-$VERSION +cp -a snmp/mibs $PKG/usr/doc/$PRGNAM-$VERSION/snmp-mibs +cat $CWD/$PRGNAM.SlackBuild > $PKG/usr/doc/$PRGNAM-$VERSION/$PRGNAM.SlackBuild + +mkdir -p $PKG/install +cat $CWD/slack-desc > $PKG/install/slack-desc +sed -e "s:@@KERNEL@@:$KERNEL:" $CWD/doinst.sh > $PKG/install/doinst.sh + +cd $PKG +/sbin/makepkg -l y -c n $OUTPUT/$PRGNAM-${VERSION}_${KERNEL//-/_}-$ARCH-$BUILD$TAG.${PKGTYPE:-tgz} diff --git a/network/iptv-analyzer/iptv-analyzer.info b/network/iptv-analyzer/iptv-analyzer.info new file mode 100644 index 000000000000..3b55c729fe52 --- /dev/null +++ b/network/iptv-analyzer/iptv-analyzer.info @@ -0,0 +1,10 @@ +PRGNAM="iptv-analyzer" +VERSION="0.9.4" +HOMEPAGE="https://github.com/netoptimizer/IPTV-Analyzer/" +DOWNLOAD="https://github.com/netoptimizer/IPTV-Analyzer/archive/v0.9.4/IPTV-Analyzer-0.9.4.tar.gz" +MD5SUM="b1c307eb8c0afe846d53b901386b3453" +DOWNLOAD_x86_64="" +MD5SUM_x86_64="" +REQUIRES="perl-Config-File perl-Data-Compare perl-Log-Dispatch perl-Log-Log4perl perl-Net-SNMP perl-Proc-Daemon perl-Proc-PID-File" +MAINTAINER="Mario Preksavec" +EMAIL="mario at slackware dot hr" diff --git a/network/iptv-analyzer/patches/Makefile.am.diff b/network/iptv-analyzer/patches/Makefile.am.diff new file mode 100644 index 000000000000..8e03aab10ee5 --- /dev/null +++ b/network/iptv-analyzer/patches/Makefile.am.diff @@ -0,0 +1,13 @@ +--- IPTV-Analyzer-0.9.4/Makefile.am.orig 2015-03-04 10:41:03.000000000 +0100 ++++ IPTV-Analyzer-0.9.4/Makefile.am 2017-11-05 00:20:05.903209784 +0100 +@@ -21,8 +21,8 @@ + #xtables-addons.8: FORCE + # ${MAKE} -f Makefile.mans all; + +-install-exec-hook: +- depmod -a || :; ++#install-exec-hook: ++# depmod -a || :; + + #config.status: Makefile.iptrules.in + diff --git a/network/iptv-analyzer/patches/Makefile.in.diff b/network/iptv-analyzer/patches/Makefile.in.diff new file mode 100644 index 000000000000..f0c93e492d99 --- /dev/null +++ b/network/iptv-analyzer/patches/Makefile.in.diff @@ -0,0 +1,11 @@ +--- IPTV-Analyzer-0.9.4/iptables-module/Makefile.in.orig 2015-03-04 10:41:03.000000000 +0100 ++++ IPTV-Analyzer-0.9.4/iptables-module/Makefile.in 2017-11-05 03:37:21.671512778 +0100 +@@ -115,7 +115,7 @@ + exit 2; \ + fi + +-install: lib_install modules_install ++install: lib_install modules + + + clean: diff --git a/network/iptv-analyzer/patches/e5d7c0b90cfe3218d67b56e122140456206f6a65.patch b/network/iptv-analyzer/patches/e5d7c0b90cfe3218d67b56e122140456206f6a65.patch new file mode 100644 index 000000000000..4a84020a1e0b --- /dev/null +++ b/network/iptv-analyzer/patches/e5d7c0b90cfe3218d67b56e122140456206f6a65.patch @@ -0,0 +1,41 @@ +From e5d7c0b90cfe3218d67b56e122140456206f6a65 Mon Sep 17 00:00:00 2001 +From: Hoai-Thu Vuong <thuvh87@gmail.com> +Date: Tue, 12 Jan 2016 17:30:45 +0700 +Subject: [PATCH] using echo and tag php in code + +--- + webfrontend/www/design.inc.php | 8 ++++---- + 1 file changed, 4 insertions(+), 4 deletions(-) + +diff --git a/webfrontend/www/design.inc.php b/webfrontend/www/design.inc.php +index 174e04a..9fcd7b0 100644 +--- a/webfrontend/www/design.inc.php ++++ b/webfrontend/www/design.inc.php +@@ -29,12 +29,12 @@ function doHeader($title="", $options=FALSE) { + <meta name="description" content="tvprobe webfrontend" /> + <meta name="publisher" content="ComX Networks A/S" /> + +- <link rel="stylesheet" type="text/css" href="<?=$incdir?>css/motorola.css"> ++ <link rel="stylesheet" type="text/css" href="<?php echo $incdir; ?>css/motorola.css"> + <?php + if ($include_javascript == TRUE) { + ?> + <script +- src="<?=$incdir?>functions.js" type="text/javascript" language='javascript'> ++ src="<?php echo $incdir; ?>functions.js" type="text/javascript" language='javascript'> + </script> + <?php + } +@@ -44,10 +44,10 @@ function doHeader($title="", $options=FALSE) { + ?> + <!--Epoch's styles--> + <link rel="stylesheet" type="text/css" +- href="<?=$incdir?>js/epoch_v202_en/epoch_styles.css" /> ++ href="<?php echo $incdir; ?>js/epoch_v202_en/epoch_styles.css" /> + + <!--Epoch's Code--> +- <script type="text/javascript" src="<?=$incdir?>js/epoch_v202_en/epoch_classes.js"> ++ <script type="text/javascript" src="<?php echo $incdir; ?>js/epoch_v202_en/epoch_classes.js"> + </script> + + <script type="text/javascript"> diff --git a/network/iptv-analyzer/patches/kernel-4.4.diff b/network/iptv-analyzer/patches/kernel-4.4.diff new file mode 100644 index 000000000000..471305bd4f7b --- /dev/null +++ b/network/iptv-analyzer/patches/kernel-4.4.diff @@ -0,0 +1,81 @@ +diff --git a/iptables-module/compat_xtables.c b/iptables-module/compat_xtables.c +index c5b67a4..40f83c8 100644 +--- a/iptables-module/compat_xtables.c ++++ b/iptables-module/compat_xtables.c +@@ -464,6 +464,7 @@ struct xt_match *xtnu_request_find_match(unsigned int af, const char *name, + } + EXPORT_SYMBOL_GPL(xtnu_request_find_match); + ++#if LINUX_VERSION_CODE < KERNEL_VERSION(4, 4, 0) + int xtnu_ip_route_me_harder(struct sk_buff **pskb, unsigned int addr_type) + { + #if LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 17) +@@ -476,6 +477,7 @@ int xtnu_ip_route_me_harder(struct sk_buff **pskb, unsigned int addr_type) + #endif + } + EXPORT_SYMBOL_GPL(xtnu_ip_route_me_harder); ++#endif + + int xtnu_skb_make_writable(struct sk_buff **pskb, unsigned int len) + { +diff --git a/iptables-module/compat_xtnu.h b/iptables-module/compat_xtnu.h +index 02b6575..253e3df 100644 +--- a/iptables-module/compat_xtnu.h ++++ b/iptables-module/compat_xtnu.h +@@ -143,7 +143,9 @@ static inline __wsum csum_unfold(__sum16 n) + #endif + ++#if LINUX_VERSION_CODE < KERNEL_VERSION(4, 4, 0) + extern int xtnu_ip_local_out(struct sk_buff *); + extern int xtnu_ip_route_me_harder(struct sk_buff **, unsigned int); ++#endif + extern int xtnu_skb_make_writable(struct sk_buff **, unsigned int); + extern int xtnu_register_match(struct xtnu_match *); + extern int xtnu_ip_route_output_key(void *, struct rtable **, struct flowi *); +diff --git a/iptables-module/xt_mpeg2ts.c b/iptables-module/xt_mpeg2ts.c +index 91ae4a0..87cfb17 100644 +--- a/iptables-module/xt_mpeg2ts.c ++++ b/iptables-module/xt_mpeg2ts.c +@@ -99,7 +99,7 @@ static const struct file_operations dl_file_ops; + #endif + + static int debug = -1; +-static int msg_level; ++static int msg_level = MPEG2TS_MSG_DEFAULT; + module_param(debug, int, 0); + module_param(msg_level, int, 0664); + MODULE_PARM_DESC(debug, "Set low N bits of message level"); +@@ -1299,14 +1299,12 @@ static void mpeg2ts_seq_stop(struct seq_file *s, void *v) + static int mpeg2ts_seq_show_real(struct mpeg2ts_stream *stream, + struct seq_file *s, unsigned int bucket) + { +- int res; +- + if (!atomic_inc_not_zero(&stream->use)) { + /* If "use" is zero, then we about to be free'd */ + return 0; + } + +- res = seq_printf(s, "bucket:%d dst:%pI4 src:%pI4 dport:%u sport:%u " ++ seq_printf(s, "bucket:%d dst:%pI4 src:%pI4 dport:%u sport:%u " + "pids:%d skips:%llu discontinuity:%llu " + "payload_bytes:%llu packets:%llu\n", + bucket, +@@ -1323,7 +1321,7 @@ static int mpeg2ts_seq_show_real(struct mpeg2ts_stream *stream, + + atomic_dec(&stream->use); + +- return res; ++ return seq_has_overflowed(s); + } + + static int mpeg2ts_seq_show(struct seq_file *s, void *v) +@@ -1434,7 +1432,7 @@ static int __init mpeg2ts_mt_init(void) + */ + INIT_LIST_HEAD(&conn_htables); + +- msg_level = netif_msg_init(debug, MPEG2TS_MSG_DEFAULT); ++ msg_level = netif_msg_init(debug, msg_level); + msg_info(DRV, "Loading: %s", version); + msg_dbg(DRV, "Message level (msg_level): 0x%X", msg_level); + diff --git a/network/iptv-analyzer/slack-desc b/network/iptv-analyzer/slack-desc new file mode 100644 index 000000000000..6c7511834e7a --- /dev/null +++ b/network/iptv-analyzer/slack-desc @@ -0,0 +1,19 @@ +# HOW TO EDIT THIS FILE: +# The "handy ruler" below makes it easier to edit a package description. +# Line up the first '|' above the ':' following the base package name, and +# the '|' on the right side marks the last column you can put a character in. +# You must make exactly 11 lines for the formatting to be correct. It's also +# customary to leave one space after the ':' except on otherwise blank lines. + + |-----handy-ruler------------------------------------------------------| +iptv-analyzer: iptv-analyzer (IPTV MPEG2 Transport Stream Analyzer) +iptv-analyzer: +iptv-analyzer: The IPTV-Analyzer is a continuous/real-time tool for analyzing the +iptv-analyzer: contents of MPEG2 Transport Stream (TS) packets, which is commonly +iptv-analyzer: used for IPTV multicast signals. The main purpose is continuous +iptv-analyzer: quality measurement, with a focus on detecting MPEG2 TS/CC packet +iptv-analyzer: drops. +iptv-analyzer: +iptv-analyzer: Homepage: https://github.com/netoptimizer/IPTV-Analyzer/ +iptv-analyzer: +iptv-analyzer: |