[PATCH] osmocom-bb[master]: Import gprsdecode utility

Max gerrit-no-reply at lists.osmocom.org
Thu Feb 1 12:34:17 UTC 2018


Hello Vadim Yanitskiy, Jenkins Builder,

I'd like you to reexamine a change.  Please visit

    https://gerrit.osmocom.org/5992

to look at the new patch set (#2).

Import gprsdecode utility

Add modernized version of gprsdecode:
* port to latest libosmocore library
* add regression tests

The code is based on work of SRLabs https://srlabs.de/

Related: OS#1672
Change-Id: I12234d37c66b83b8abd60f7511fa1d7837db1856
---
M src/Makefile
A src/host/gprsdecode/.gitignore
A src/host/gprsdecode/AUTHORS
A src/host/gprsdecode/COPYING
A src/host/gprsdecode/ChangeLog
A src/host/gprsdecode/INSTALL
A src/host/gprsdecode/Makefile.am
A src/host/gprsdecode/NEWS
A src/host/gprsdecode/README
A src/host/gprsdecode/configure.ac
A src/host/gprsdecode/crc.c
A src/host/gprsdecode/crc.h
A src/host/gprsdecode/gprs.c
A src/host/gprsdecode/gprs.h
A src/host/gprsdecode/main.c
A src/host/gprsdecode/output.c
A src/host/gprsdecode/output.h
A src/host/gprsdecode/rlcmac.c
A src/host/gprsdecode/rlcmac.h
A src/host/gprsdecode/tests/.gitignore
A src/host/gprsdecode/tests/Makefile
A src/host/gprsdecode/tests/gprs_20160129_1744_878_16846_0c.decoded
A src/host/gprsdecode/tests/gprs_20160129_1744_878_16846_0c.sample
A src/host/gprsdecode/tests/gprs_262_80_0001_0000_20110710_2251_875_494777_0f.decoded
A src/host/gprsdecode/tests/gprs_262_80_0001_0000_20110710_2251_875_494777_0f.sample
25 files changed, 8,660 insertions(+), 1 deletion(-)


  git pull ssh://gerrit.osmocom.org:29418/osmocom-bb refs/changes/92/5992/2

diff --git a/src/Makefile b/src/Makefile
index 7a7d283..bb83d35 100644
--- a/src/Makefile
+++ b/src/Makefile
@@ -13,7 +13,7 @@
 
 all: libosmocore-target nofirmware firmware mtk-firmware
 
-nofirmware: layer23 osmocon gsmmap virtphy
+nofirmware: layer23 osmocon gsmmap gprsdecode virtphy
 
 libosmocore-target: shared/libosmocore/build-target/src/.libs/libosmocore.a
 
@@ -83,6 +83,17 @@
 host/layer23/layer23: host/layer23/Makefile
 	make -C host/layer23
 
+.PHONY: gprsdecode
+gprsdecode: host/gprsdecode/gprsdecode
+
+host/gprsdecode/configure: host/gprsdecode/configure.ac
+	cd host/gprsdecode && autoreconf -i
+
+host/gprsdecode/Makefile: host/gprsdecode/configure
+	cd host/gprsdecode && ./configure $(HOST_CONFARGS)
+
+host/gprsdecode/gprsdecode: host/gprsdecode/Makefile
+	make -C host/gprsdecode
 
 .PHONY: firmware
 firmware: libosmocore-target
@@ -98,6 +109,7 @@
 	make -C host/layer23 $@
 	make -C host/osmocon $@
 	make -C host/gsmmap $@
+	make -C host/gprsdecode $@
 	make -C host/virt_phy $@
 	make -C target/firmware $@
 	make -C target/firmware -f Makefile.mtk $@
@@ -107,6 +119,7 @@
 	make -C host/layer23 $@
 	make -C host/osmocon $@
 	make -C host/gsmmap $@
+	make -C host/gprsdecode $@
 	make -C host/virt_phy $@
 # 'firmware' also handles 'mtk-firmware'
 	make -C target/firmware $@
diff --git a/src/host/gprsdecode/.gitignore b/src/host/gprsdecode/.gitignore
new file mode 100644
index 0000000..a518ec2
--- /dev/null
+++ b/src/host/gprsdecode/.gitignore
@@ -0,0 +1,2 @@
+gprsdecode
+Makefile
diff --git a/src/host/gprsdecode/AUTHORS b/src/host/gprsdecode/AUTHORS
new file mode 100644
index 0000000..6544610
--- /dev/null
+++ b/src/host/gprsdecode/AUTHORS
@@ -0,0 +1,2 @@
+Luca Melette <luca at srlabs.de>
+Max <msuraev at sysmocom.de>
diff --git a/src/host/gprsdecode/COPYING b/src/host/gprsdecode/COPYING
new file mode 100644
index 0000000..d511905
--- /dev/null
+++ b/src/host/gprsdecode/COPYING
@@ -0,0 +1,339 @@
+		    GNU GENERAL PUBLIC LICENSE
+		       Version 2, June 1991
+
+ Copyright (C) 1989, 1991 Free Software Foundation, Inc.,
+ 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+ Everyone is permitted to copy and distribute verbatim copies
+ of this license document, but changing it is not allowed.
+
+			    Preamble
+
+  The licenses for most software are designed to take away your
+freedom to share and change it.  By contrast, the GNU General Public
+License is intended to guarantee your freedom to share and change free
+software--to make sure the software is free for all its users.  This
+General Public License applies to most of the Free Software
+Foundation's software and to any other program whose authors commit to
+using it.  (Some other Free Software Foundation software is covered by
+the GNU Lesser General Public License instead.)  You can apply it to
+your programs, too.
+
+  When we speak of free software, we are referring to freedom, not
+price.  Our General Public Licenses are designed to make sure that you
+have the freedom to distribute copies of free software (and charge for
+this service if you wish), that you receive source code or can get it
+if you want it, that you can change the software or use pieces of it
+in new free programs; and that you know you can do these things.
+
+  To protect your rights, we need to make restrictions that forbid
+anyone to deny you these rights or to ask you to surrender the rights.
+These restrictions translate to certain responsibilities for you if you
+distribute copies of the software, or if you modify it.
+
+  For example, if you distribute copies of such a program, whether
+gratis or for a fee, you must give the recipients all the rights that
+you have.  You must make sure that they, too, receive or can get the
+source code.  And you must show them these terms so they know their
+rights.
+
+  We protect your rights with two steps: (1) copyright the software, and
+(2) offer you this license which gives you legal permission to copy,
+distribute and/or modify the software.
+
+  Also, for each author's protection and ours, we want to make certain
+that everyone understands that there is no warranty for this free
+software.  If the software is modified by someone else and passed on, we
+want its recipients to know that what they have is not the original, so
+that any problems introduced by others will not reflect on the original
+authors' reputations.
+
+  Finally, any free program is threatened constantly by software
+patents.  We wish to avoid the danger that redistributors of a free
+program will individually obtain patent licenses, in effect making the
+program proprietary.  To prevent this, we have made it clear that any
+patent must be licensed for everyone's free use or not licensed at all.
+
+  The precise terms and conditions for copying, distribution and
+modification follow.
+
+		    GNU GENERAL PUBLIC LICENSE
+   TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
+
+  0. This License applies to any program or other work which contains
+a notice placed by the copyright holder saying it may be distributed
+under the terms of this General Public License.  The "Program", below,
+refers to any such program or work, and a "work based on the Program"
+means either the Program or any derivative work under copyright law:
+that is to say, a work containing the Program or a portion of it,
+either verbatim or with modifications and/or translated into another
+language.  (Hereinafter, translation is included without limitation in
+the term "modification".)  Each licensee is addressed as "you".
+
+Activities other than copying, distribution and modification are not
+covered by this License; they are outside its scope.  The act of
+running the Program is not restricted, and the output from the Program
+is covered only if its contents constitute a work based on the
+Program (independent of having been made by running the Program).
+Whether that is true depends on what the Program does.
+
+  1. You may copy and distribute verbatim copies of the Program's
+source code as you receive it, in any medium, provided that you
+conspicuously and appropriately publish on each copy an appropriate
+copyright notice and disclaimer of warranty; keep intact all the
+notices that refer to this License and to the absence of any warranty;
+and give any other recipients of the Program a copy of this License
+along with the Program.
+
+You may charge a fee for the physical act of transferring a copy, and
+you may at your option offer warranty protection in exchange for a fee.
+
+  2. You may modify your copy or copies of the Program or any portion
+of it, thus forming a work based on the Program, and copy and
+distribute such modifications or work under the terms of Section 1
+above, provided that you also meet all of these conditions:
+
+    a) You must cause the modified files to carry prominent notices
+    stating that you changed the files and the date of any change.
+
+    b) You must cause any work that you distribute or publish, that in
+    whole or in part contains or is derived from the Program or any
+    part thereof, to be licensed as a whole at no charge to all third
+    parties under the terms of this License.
+
+    c) If the modified program normally reads commands interactively
+    when run, you must cause it, when started running for such
+    interactive use in the most ordinary way, to print or display an
+    announcement including an appropriate copyright notice and a
+    notice that there is no warranty (or else, saying that you provide
+    a warranty) and that users may redistribute the program under
+    these conditions, and telling the user how to view a copy of this
+    License.  (Exception: if the Program itself is interactive but
+    does not normally print such an announcement, your work based on
+    the Program is not required to print an announcement.)
+
+These requirements apply to the modified work as a whole.  If
+identifiable sections of that work are not derived from the Program,
+and can be reasonably considered independent and separate works in
+themselves, then this License, and its terms, do not apply to those
+sections when you distribute them as separate works.  But when you
+distribute the same sections as part of a whole which is a work based
+on the Program, the distribution of the whole must be on the terms of
+this License, whose permissions for other licensees extend to the
+entire whole, and thus to each and every part regardless of who wrote it.
+
+Thus, it is not the intent of this section to claim rights or contest
+your rights to work written entirely by you; rather, the intent is to
+exercise the right to control the distribution of derivative or
+collective works based on the Program.
+
+In addition, mere aggregation of another work not based on the Program
+with the Program (or with a work based on the Program) on a volume of
+a storage or distribution medium does not bring the other work under
+the scope of this License.
+
+  3. You may copy and distribute the Program (or a work based on it,
+under Section 2) in object code or executable form under the terms of
+Sections 1 and 2 above provided that you also do one of the following:
+
+    a) Accompany it with the complete corresponding machine-readable
+    source code, which must be distributed under the terms of Sections
+    1 and 2 above on a medium customarily used for software interchange; or,
+
+    b) Accompany it with a written offer, valid for at least three
+    years, to give any third party, for a charge no more than your
+    cost of physically performing source distribution, a complete
+    machine-readable copy of the corresponding source code, to be
+    distributed under the terms of Sections 1 and 2 above on a medium
+    customarily used for software interchange; or,
+
+    c) Accompany it with the information you received as to the offer
+    to distribute corresponding source code.  (This alternative is
+    allowed only for noncommercial distribution and only if you
+    received the program in object code or executable form with such
+    an offer, in accord with Subsection b above.)
+
+The source code for a work means the preferred form of the work for
+making modifications to it.  For an executable work, complete source
+code means all the source code for all modules it contains, plus any
+associated interface definition files, plus the scripts used to
+control compilation and installation of the executable.  However, as a
+special exception, the source code distributed need not include
+anything that is normally distributed (in either source or binary
+form) with the major components (compiler, kernel, and so on) of the
+operating system on which the executable runs, unless that component
+itself accompanies the executable.
+
+If distribution of executable or object code is made by offering
+access to copy from a designated place, then offering equivalent
+access to copy the source code from the same place counts as
+distribution of the source code, even though third parties are not
+compelled to copy the source along with the object code.
+
+  4. You may not copy, modify, sublicense, or distribute the Program
+except as expressly provided under this License.  Any attempt
+otherwise to copy, modify, sublicense or distribute the Program is
+void, and will automatically terminate your rights under this License.
+However, parties who have received copies, or rights, from you under
+this License will not have their licenses terminated so long as such
+parties remain in full compliance.
+
+  5. You are not required to accept this License, since you have not
+signed it.  However, nothing else grants you permission to modify or
+distribute the Program or its derivative works.  These actions are
+prohibited by law if you do not accept this License.  Therefore, by
+modifying or distributing the Program (or any work based on the
+Program), you indicate your acceptance of this License to do so, and
+all its terms and conditions for copying, distributing or modifying
+the Program or works based on it.
+
+  6. Each time you redistribute the Program (or any work based on the
+Program), the recipient automatically receives a license from the
+original licensor to copy, distribute or modify the Program subject to
+these terms and conditions.  You may not impose any further
+restrictions on the recipients' exercise of the rights granted herein.
+You are not responsible for enforcing compliance by third parties to
+this License.
+
+  7. If, as a consequence of a court judgment or allegation of patent
+infringement or for any other reason (not limited to patent issues),
+conditions are imposed on you (whether by court order, agreement or
+otherwise) that contradict the conditions of this License, they do not
+excuse you from the conditions of this License.  If you cannot
+distribute so as to satisfy simultaneously your obligations under this
+License and any other pertinent obligations, then as a consequence you
+may not distribute the Program at all.  For example, if a patent
+license would not permit royalty-free redistribution of the Program by
+all those who receive copies directly or indirectly through you, then
+the only way you could satisfy both it and this License would be to
+refrain entirely from distribution of the Program.
+
+If any portion of this section is held invalid or unenforceable under
+any particular circumstance, the balance of the section is intended to
+apply and the section as a whole is intended to apply in other
+circumstances.
+
+It is not the purpose of this section to induce you to infringe any
+patents or other property right claims or to contest validity of any
+such claims; this section has the sole purpose of protecting the
+integrity of the free software distribution system, which is
+implemented by public license practices.  Many people have made
+generous contributions to the wide range of software distributed
+through that system in reliance on consistent application of that
+system; it is up to the author/donor to decide if he or she is willing
+to distribute software through any other system and a licensee cannot
+impose that choice.
+
+This section is intended to make thoroughly clear what is believed to
+be a consequence of the rest of this License.
+
+  8. If the distribution and/or use of the Program is restricted in
+certain countries either by patents or by copyrighted interfaces, the
+original copyright holder who places the Program under this License
+may add an explicit geographical distribution limitation excluding
+those countries, so that distribution is permitted only in or among
+countries not thus excluded.  In such case, this License incorporates
+the limitation as if written in the body of this License.
+
+  9. The Free Software Foundation may publish revised and/or new versions
+of the General Public License from time to time.  Such new versions will
+be similar in spirit to the present version, but may differ in detail to
+address new problems or concerns.
+
+Each version is given a distinguishing version number.  If the Program
+specifies a version number of this License which applies to it and "any
+later version", you have the option of following the terms and conditions
+either of that version or of any later version published by the Free
+Software Foundation.  If the Program does not specify a version number of
+this License, you may choose any version ever published by the Free Software
+Foundation.
+
+  10. If you wish to incorporate parts of the Program into other free
+programs whose distribution conditions are different, write to the author
+to ask for permission.  For software which is copyrighted by the Free
+Software Foundation, write to the Free Software Foundation; we sometimes
+make exceptions for this.  Our decision will be guided by the two goals
+of preserving the free status of all derivatives of our free software and
+of promoting the sharing and reuse of software generally.
+
+			    NO WARRANTY
+
+  11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY
+FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW.  EXCEPT WHEN
+OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES
+PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED
+OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
+MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.  THE ENTIRE RISK AS
+TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU.  SHOULD THE
+PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING,
+REPAIR OR CORRECTION.
+
+  12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
+WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR
+REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES,
+INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING
+OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED
+TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY
+YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER
+PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE
+POSSIBILITY OF SUCH DAMAGES.
+
+		     END OF TERMS AND CONDITIONS
+
+	    How to Apply These Terms to Your New Programs
+
+  If you develop a new program, and you want it to be of the greatest
+possible use to the public, the best way to achieve this is to make it
+free software which everyone can redistribute and change under these terms.
+
+  To do so, attach the following notices to the program.  It is safest
+to attach them to the start of each source file to most effectively
+convey the exclusion of warranty; and each file should have at least
+the "copyright" line and a pointer to where the full notice is found.
+
+    <one line to give the program's name and a brief idea of what it does.>
+    Copyright (C) <year>  <name of author>
+
+    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.
+
+Also add information on how to contact you by electronic and paper mail.
+
+If the program is interactive, make it output a short notice like this
+when it starts in an interactive mode:
+
+    Gnomovision version 69, Copyright (C) year name of author
+    Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'.
+    This is free software, and you are welcome to redistribute it
+    under certain conditions; type `show c' for details.
+
+The hypothetical commands `show w' and `show c' should show the appropriate
+parts of the General Public License.  Of course, the commands you use may
+be called something other than `show w' and `show c'; they could even be
+mouse-clicks or menu items--whatever suits your program.
+
+You should also get your employer (if you work as a programmer) or your
+school, if any, to sign a "copyright disclaimer" for the program, if
+necessary.  Here is a sample; alter the names:
+
+  Yoyodyne, Inc., hereby disclaims all copyright interest in the program
+  `Gnomovision' (which makes passes at compilers) written by James Hacker.
+
+  <signature of Ty Coon>, 1 April 1989
+  Ty Coon, President of Vice
+
+This General Public License does not permit incorporating your program into
+proprietary programs.  If your program is a subroutine library, you may
+consider it more useful to permit linking proprietary applications with the
+library.  If this is what you want to do, use the GNU Lesser General
+Public License instead of this License.
diff --git a/src/host/gprsdecode/ChangeLog b/src/host/gprsdecode/ChangeLog
new file mode 100644
index 0000000..e69de29
--- /dev/null
+++ b/src/host/gprsdecode/ChangeLog
diff --git a/src/host/gprsdecode/INSTALL b/src/host/gprsdecode/INSTALL
new file mode 100644
index 0000000..2099840
--- /dev/null
+++ b/src/host/gprsdecode/INSTALL
@@ -0,0 +1,370 @@
+Installation Instructions
+*************************
+
+Copyright (C) 1994-1996, 1999-2002, 2004-2013 Free Software Foundation,
+Inc.
+
+   Copying and distribution of this file, with or without modification,
+are permitted in any medium without royalty provided the copyright
+notice and this notice are preserved.  This file is offered as-is,
+without warranty of any kind.
+
+Basic Installation
+==================
+
+   Briefly, the shell command `./configure && make && make install'
+should configure, build, and install this package.  The following
+more-detailed instructions are generic; see the `README' file for
+instructions specific to this package.  Some packages provide this
+`INSTALL' file but do not implement all of the features documented
+below.  The lack of an optional feature in a given package is not
+necessarily a bug.  More recommendations for GNU packages can be found
+in *note Makefile Conventions: (standards)Makefile Conventions.
+
+   The `configure' shell script attempts to guess correct values for
+various system-dependent variables used during compilation.  It uses
+those values to create a `Makefile' in each directory of the package.
+It may also create one or more `.h' files containing system-dependent
+definitions.  Finally, it creates a shell script `config.status' that
+you can run in the future to recreate the current configuration, and a
+file `config.log' containing compiler output (useful mainly for
+debugging `configure').
+
+   It can also use an optional file (typically called `config.cache'
+and enabled with `--cache-file=config.cache' or simply `-C') that saves
+the results of its tests to speed up reconfiguring.  Caching is
+disabled by default to prevent problems with accidental use of stale
+cache files.
+
+   If you need to do unusual things to compile the package, please try
+to figure out how `configure' could check whether to do them, and mail
+diffs or instructions to the address given in the `README' so they can
+be considered for the next release.  If you are using the cache, and at
+some point `config.cache' contains results you don't want to keep, you
+may remove or edit it.
+
+   The file `configure.ac' (or `configure.in') is used to create
+`configure' by a program called `autoconf'.  You need `configure.ac' if
+you want to change it or regenerate `configure' using a newer version
+of `autoconf'.
+
+   The simplest way to compile this package is:
+
+  1. `cd' to the directory containing the package's source code and type
+     `./configure' to configure the package for your system.
+
+     Running `configure' might take a while.  While running, it prints
+     some messages telling which features it is checking for.
+
+  2. Type `make' to compile the package.
+
+  3. Optionally, type `make check' to run any self-tests that come with
+     the package, generally using the just-built uninstalled binaries.
+
+  4. Type `make install' to install the programs and any data files and
+     documentation.  When installing into a prefix owned by root, it is
+     recommended that the package be configured and built as a regular
+     user, and only the `make install' phase executed with root
+     privileges.
+
+  5. Optionally, type `make installcheck' to repeat any self-tests, but
+     this time using the binaries in their final installed location.
+     This target does not install anything.  Running this target as a
+     regular user, particularly if the prior `make install' required
+     root privileges, verifies that the installation completed
+     correctly.
+
+  6. You can remove the program binaries and object files from the
+     source code directory by typing `make clean'.  To also remove the
+     files that `configure' created (so you can compile the package for
+     a different kind of computer), type `make distclean'.  There is
+     also a `make maintainer-clean' target, but that is intended mainly
+     for the package's developers.  If you use it, you may have to get
+     all sorts of other programs in order to regenerate files that came
+     with the distribution.
+
+  7. Often, you can also type `make uninstall' to remove the installed
+     files again.  In practice, not all packages have tested that
+     uninstallation works correctly, even though it is required by the
+     GNU Coding Standards.
+
+  8. Some packages, particularly those that use Automake, provide `make
+     distcheck', which can by used by developers to test that all other
+     targets like `make install' and `make uninstall' work correctly.
+     This target is generally not run by end users.
+
+Compilers and Options
+=====================
+
+   Some systems require unusual options for compilation or linking that
+the `configure' script does not know about.  Run `./configure --help'
+for details on some of the pertinent environment variables.
+
+   You can give `configure' initial values for configuration parameters
+by setting variables in the command line or in the environment.  Here
+is an example:
+
+     ./configure CC=c99 CFLAGS=-g LIBS=-lposix
+
+   *Note Defining Variables::, for more details.
+
+Compiling For Multiple Architectures
+====================================
+
+   You can compile the package for more than one kind of computer at the
+same time, by placing the object files for each architecture in their
+own directory.  To do this, you can use GNU `make'.  `cd' to the
+directory where you want the object files and executables to go and run
+the `configure' script.  `configure' automatically checks for the
+source code in the directory that `configure' is in and in `..'.  This
+is known as a "VPATH" build.
+
+   With a non-GNU `make', it is safer to compile the package for one
+architecture at a time in the source code directory.  After you have
+installed the package for one architecture, use `make distclean' before
+reconfiguring for another architecture.
+
+   On MacOS X 10.5 and later systems, you can create libraries and
+executables that work on multiple system types--known as "fat" or
+"universal" binaries--by specifying multiple `-arch' options to the
+compiler but only a single `-arch' option to the preprocessor.  Like
+this:
+
+     ./configure CC="gcc -arch i386 -arch x86_64 -arch ppc -arch ppc64" \
+                 CXX="g++ -arch i386 -arch x86_64 -arch ppc -arch ppc64" \
+                 CPP="gcc -E" CXXCPP="g++ -E"
+
+   This is not guaranteed to produce working output in all cases, you
+may have to build one architecture at a time and combine the results
+using the `lipo' tool if you have problems.
+
+Installation Names
+==================
+
+   By default, `make install' installs the package's commands under
+`/usr/local/bin', include files under `/usr/local/include', etc.  You
+can specify an installation prefix other than `/usr/local' by giving
+`configure' the option `--prefix=PREFIX', where PREFIX must be an
+absolute file name.
+
+   You can specify separate installation prefixes for
+architecture-specific files and architecture-independent files.  If you
+pass the option `--exec-prefix=PREFIX' to `configure', the package uses
+PREFIX as the prefix for installing programs and libraries.
+Documentation and other data files still use the regular prefix.
+
+   In addition, if you use an unusual directory layout you can give
+options like `--bindir=DIR' to specify different values for particular
+kinds of files.  Run `configure --help' for a list of the directories
+you can set and what kinds of files go in them.  In general, the
+default for these options is expressed in terms of `${prefix}', so that
+specifying just `--prefix' will affect all of the other directory
+specifications that were not explicitly provided.
+
+   The most portable way to affect installation locations is to pass the
+correct locations to `configure'; however, many packages provide one or
+both of the following shortcuts of passing variable assignments to the
+`make install' command line to change installation locations without
+having to reconfigure or recompile.
+
+   The first method involves providing an override variable for each
+affected directory.  For example, `make install
+prefix=/alternate/directory' will choose an alternate location for all
+directory configuration variables that were expressed in terms of
+`${prefix}'.  Any directories that were specified during `configure',
+but not in terms of `${prefix}', must each be overridden at install
+time for the entire installation to be relocated.  The approach of
+makefile variable overrides for each directory variable is required by
+the GNU Coding Standards, and ideally causes no recompilation.
+However, some platforms have known limitations with the semantics of
+shared libraries that end up requiring recompilation when using this
+method, particularly noticeable in packages that use GNU Libtool.
+
+   The second method involves providing the `DESTDIR' variable.  For
+example, `make install DESTDIR=/alternate/directory' will prepend
+`/alternate/directory' before all installation names.  The approach of
+`DESTDIR' overrides is not required by the GNU Coding Standards, and
+does not work on platforms that have drive letters.  On the other hand,
+it does better at avoiding recompilation issues, and works well even
+when some directory options were not specified in terms of `${prefix}'
+at `configure' time.
+
+Optional Features
+=================
+
+   If the package supports it, you can cause programs to be installed
+with an extra prefix or suffix on their names by giving `configure' the
+option `--program-prefix=PREFIX' or `--program-suffix=SUFFIX'.
+
+   Some packages pay attention to `--enable-FEATURE' options to
+`configure', where FEATURE indicates an optional part of the package.
+They may also pay attention to `--with-PACKAGE' options, where PACKAGE
+is something like `gnu-as' or `x' (for the X Window System).  The
+`README' should mention any `--enable-' and `--with-' options that the
+package recognizes.
+
+   For packages that use the X Window System, `configure' can usually
+find the X include and library files automatically, but if it doesn't,
+you can use the `configure' options `--x-includes=DIR' and
+`--x-libraries=DIR' to specify their locations.
+
+   Some packages offer the ability to configure how verbose the
+execution of `make' will be.  For these packages, running `./configure
+--enable-silent-rules' sets the default to minimal output, which can be
+overridden with `make V=1'; while running `./configure
+--disable-silent-rules' sets the default to verbose, which can be
+overridden with `make V=0'.
+
+Particular systems
+==================
+
+   On HP-UX, the default C compiler is not ANSI C compatible.  If GNU
+CC is not installed, it is recommended to use the following options in
+order to use an ANSI C compiler:
+
+     ./configure CC="cc -Ae -D_XOPEN_SOURCE=500"
+
+and if that doesn't work, install pre-built binaries of GCC for HP-UX.
+
+   HP-UX `make' updates targets which have the same time stamps as
+their prerequisites, which makes it generally unusable when shipped
+generated files such as `configure' are involved.  Use GNU `make'
+instead.
+
+   On OSF/1 a.k.a. Tru64, some versions of the default C compiler cannot
+parse its `<wchar.h>' header file.  The option `-nodtk' can be used as
+a workaround.  If GNU CC is not installed, it is therefore recommended
+to try
+
+     ./configure CC="cc"
+
+and if that doesn't work, try
+
+     ./configure CC="cc -nodtk"
+
+   On Solaris, don't put `/usr/ucb' early in your `PATH'.  This
+directory contains several dysfunctional programs; working variants of
+these programs are available in `/usr/bin'.  So, if you need `/usr/ucb'
+in your `PATH', put it _after_ `/usr/bin'.
+
+   On Haiku, software installed for all users goes in `/boot/common',
+not `/usr/local'.  It is recommended to use the following options:
+
+     ./configure --prefix=/boot/common
+
+Specifying the System Type
+==========================
+
+   There may be some features `configure' cannot figure out
+automatically, but needs to determine by the type of machine the package
+will run on.  Usually, assuming the package is built to be run on the
+_same_ architectures, `configure' can figure that out, but if it prints
+a message saying it cannot guess the machine type, give it the
+`--build=TYPE' option.  TYPE can either be a short name for the system
+type, such as `sun4', or a canonical name which has the form:
+
+     CPU-COMPANY-SYSTEM
+
+where SYSTEM can have one of these forms:
+
+     OS
+     KERNEL-OS
+
+   See the file `config.sub' for the possible values of each field.  If
+`config.sub' isn't included in this package, then this package doesn't
+need to know the machine type.
+
+   If you are _building_ compiler tools for cross-compiling, you should
+use the option `--target=TYPE' to select the type of system they will
+produce code for.
+
+   If you want to _use_ a cross compiler, that generates code for a
+platform different from the build platform, you should specify the
+"host" platform (i.e., that on which the generated programs will
+eventually be run) with `--host=TYPE'.
+
+Sharing Defaults
+================
+
+   If you want to set default values for `configure' scripts to share,
+you can create a site shell script called `config.site' that gives
+default values for variables like `CC', `cache_file', and `prefix'.
+`configure' looks for `PREFIX/share/config.site' if it exists, then
+`PREFIX/etc/config.site' if it exists.  Or, you can set the
+`CONFIG_SITE' environment variable to the location of the site script.
+A warning: not all `configure' scripts look for a site script.
+
+Defining Variables
+==================
+
+   Variables not defined in a site shell script can be set in the
+environment passed to `configure'.  However, some packages may run
+configure again during the build, and the customized values of these
+variables may be lost.  In order to avoid this problem, you should set
+them in the `configure' command line, using `VAR=value'.  For example:
+
+     ./configure CC=/usr/local2/bin/gcc
+
+causes the specified `gcc' to be used as the C compiler (unless it is
+overridden in the site shell script).
+
+Unfortunately, this technique does not work for `CONFIG_SHELL' due to
+an Autoconf limitation.  Until the limitation is lifted, you can use
+this workaround:
+
+     CONFIG_SHELL=/bin/bash ./configure CONFIG_SHELL=/bin/bash
+
+`configure' Invocation
+======================
+
+   `configure' recognizes the following options to control how it
+operates.
+
+`--help'
+`-h'
+     Print a summary of all of the options to `configure', and exit.
+
+`--help=short'
+`--help=recursive'
+     Print a summary of the options unique to this package's
+     `configure', and exit.  The `short' variant lists options used
+     only in the top level, while the `recursive' variant lists options
+     also present in any nested packages.
+
+`--version'
+`-V'
+     Print the version of Autoconf used to generate the `configure'
+     script, and exit.
+
+`--cache-file=FILE'
+     Enable the cache: use and save the results of the tests in FILE,
+     traditionally `config.cache'.  FILE defaults to `/dev/null' to
+     disable caching.
+
+`--config-cache'
+`-C'
+     Alias for `--cache-file=config.cache'.
+
+`--quiet'
+`--silent'
+`-q'
+     Do not print messages saying which checks are being made.  To
+     suppress all normal output, redirect it to `/dev/null' (any error
+     messages will still be shown).
+
+`--srcdir=DIR'
+     Look for the package's source code in directory DIR.  Usually
+     `configure' can determine that directory automatically.
+
+`--prefix=DIR'
+     Use DIR as the installation prefix.  *note Installation Names::
+     for more details, including other options available for fine-tuning
+     the installation locations.
+
+`--no-create'
+`-n'
+     Run the configure checks, but stop before creating any output
+     files.
+
+`configure' also accepts some other, not widely useful, options.  Run
+`configure --help' for more details.
diff --git a/src/host/gprsdecode/Makefile.am b/src/host/gprsdecode/Makefile.am
new file mode 100644
index 0000000..61be35f
--- /dev/null
+++ b/src/host/gprsdecode/Makefile.am
@@ -0,0 +1,8 @@
+AM_CPPFLAGS = $(all_includes) -I$(top_srcdir)/../layer23/include
+AM_CFLAGS = -Wall -O3 -pipe -flto -std=gnu99 -g $(LIBOSMOCORE_CFLAGS) $(LIBOSMOGSM_CFLAGS) $(LIBOSMOCODING_CFLAGS) 
+LDADD = $(LIBOSMOCORE_LIBS) $(LIBOSMOGSM_LIBS) $(LIBOSMOCODING_LIBS)
+
+bin_PROGRAMS = gprsdecode
+
+gprsdecode_LDFLAGS = -pthread
+gprsdecode_SOURCES = main.c gprs.c output.c rlcmac.c crc.c
diff --git a/src/host/gprsdecode/NEWS b/src/host/gprsdecode/NEWS
new file mode 100644
index 0000000..e69de29
--- /dev/null
+++ b/src/host/gprsdecode/NEWS
diff --git a/src/host/gprsdecode/README b/src/host/gprsdecode/README
new file mode 100644
index 0000000..dbe45dc
--- /dev/null
+++ b/src/host/gprsdecode/README
@@ -0,0 +1,8 @@
+GPRS decoder for OsmocomBB
+
+Usage: ./gprsdecode <burstfile>
+
+The burstfile should contain samples, captured using burst_ind branch.
+An example of decoded output as well as few sample capture files could be found in tests/
+
+Based on the version from git://git.srlabs.de/gprsdecode.git
diff --git a/src/host/gprsdecode/configure.ac b/src/host/gprsdecode/configure.ac
new file mode 100644
index 0000000..9be44b5
--- /dev/null
+++ b/src/host/gprsdecode/configure.ac
@@ -0,0 +1,24 @@
+dnl Process this file with autoconf to produce a configure script
+AC_INIT([gprsdecode], [0.0.0])
+AM_INIT_AUTOMAKE
+
+dnl kernel style compile messages
+m4_ifdef([AM_SILENT_RULES], [AM_SILENT_RULES([yes])])
+
+dnl checks for programs
+AC_PROG_MAKE_SET
+AC_PROG_CC
+AC_PROG_INSTALL
+AC_PROG_RANLIB
+
+dnl checks for libraries
+PKG_CHECK_MODULES(LIBOSMOCORE, libosmocore)
+PKG_CHECK_MODULES(LIBOSMOGSM, libosmogsm)
+PKG_CHECK_MODULES(LIBOSMOCODING, libosmocoding)
+
+dnl checks for header files
+AC_HEADER_STDC
+
+dnl Checks for typedefs, structures and compiler characteristics
+
+AC_OUTPUT(Makefile)
diff --git a/src/host/gprsdecode/crc.c b/src/host/gprsdecode/crc.c
new file mode 100644
index 0000000..8094041
--- /dev/null
+++ b/src/host/gprsdecode/crc.c
@@ -0,0 +1,164 @@
+/*
+ * Copyright 2005 Free Software Foundation, Inc.
+ *
+ * Code imported from GNURadio, GSMSTACK and Linux Kernel.
+ *
+ * GNU Radio 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, or (at your option)
+ * any later version.
+ *
+ * GNU Radio 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 GNU Radio; see the file COPYING.  If not, write to
+ * the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
+ * Boston, MA 02111-1307, USA.
+ */
+
+#include <stdio.h>
+#include <string.h>
+#include <stdint.h>
+
+#include "crc.h"
+
+#define REM(x, y) (x) % (y)
+
+static int FC_syndrome_shift(FC_CTX *ctx, unsigned int bit);
+
+void FC_init(FC_CTX *ctx, unsigned int crc_size, unsigned int data_size)
+{
+	ctx->crc_size = crc_size;
+	ctx->data_size = data_size;
+	ctx->syn_start = 0;
+}
+
+int FC_check_crc(FC_CTX *ctx, unsigned char *input_bits, unsigned char *control_data)
+{
+	int j,error_count = 0, error_index = 0, success_flag = 0, syn_index = 0;
+	unsigned int i;
+
+	ctx->syn_start = 0;
+	/* reset the syndrome register */
+	memset(ctx->syndrome_reg, 0, sizeof(ctx->syndrome_reg));
+
+	/* shift in the data bits */
+	for (i = 0; i < ctx->data_size; i++) {
+		error_count = FC_syndrome_shift(ctx, input_bits[i]);
+		control_data[i] = input_bits[i];
+	}
+
+	/* shift in the crc bits */
+	for (i = 0; i < ctx->crc_size; i++) {
+		error_count = FC_syndrome_shift(ctx, 1 - input_bits[i + ctx->data_size]);
+	}
+
+	/* Find position of error burst */
+	if (error_count == 0)
+		error_index = 0;
+	else {
+		error_index = 1;
+		error_count = FC_syndrome_shift(ctx, 0);
+		error_index += 1;
+		while (error_index < (ctx->data_size + ctx->crc_size)) {
+			error_count = FC_syndrome_shift(ctx, 0);
+			error_index += 1;
+			if (error_count == 0)
+				break;
+		}
+	}
+
+	/* Test for correctable errors */
+	/* printf("error_index %d\n",error_index); */
+	if (error_index == 224)
+		success_flag = 0;
+	else {
+
+		/* correct index depending on the position of the error */
+		if (error_index == 0)
+			syn_index = error_index;
+		else
+			syn_index = error_index - 1;
+
+		/* error burst lies within data bits */
+		if (error_index < 184) {
+			/* printf("error < bit 184,%d\n",error_index); */
+			j = error_index;
+			while ( j < (error_index+12) ) {
+				if (j < 184) {
+					control_data[j] = control_data[j] ^
+						ctx->syndrome_reg[REM(ctx->syn_start + 39 - j + syn_index, 40)];
+				}
+				else
+					break;
+				j = j + 1;
+			}
+		} else if (error_index > 212) {
+			/* printf("error > bit 212,%d\n",error_index); */
+			j = 0;
+			while (j < (error_index - 212)) {
+				control_data[j] = control_data[j] ^
+					ctx->syndrome_reg[REM(ctx->syn_start + 39 - j - 224 + syn_index, 40)];
+				j = j + 1;
+			}
+		}
+		/* for 183 < error_index < 213 error in parity alone so ignore */
+		success_flag = 1;
+	}
+	return success_flag;
+}
+
+static int FC_syndrome_shift(FC_CTX *ctx, unsigned int bit)
+{
+	int error_count = 0;
+	unsigned int i;
+
+	if (ctx->syn_start == 0)
+		ctx->syn_start = 39;
+	else
+		ctx->syn_start -= 1;
+
+	int temp_syndrome_reg[sizeof ctx->syndrome_reg];
+
+	memcpy(temp_syndrome_reg, ctx->syndrome_reg, sizeof temp_syndrome_reg);
+
+	temp_syndrome_reg[REM(ctx->syn_start + 3, 40)] =
+		ctx->syndrome_reg[REM(ctx->syn_start + 3, 40)] ^ ctx->syndrome_reg[ctx->syn_start];
+	temp_syndrome_reg[REM(ctx->syn_start + 17, 40)] =
+		ctx->syndrome_reg[REM(ctx->syn_start + 17, 40)] ^ ctx->syndrome_reg[ctx->syn_start];
+	temp_syndrome_reg[REM(ctx->syn_start + 23, 40)] =
+		ctx->syndrome_reg[REM(ctx->syn_start + 23, 40)] ^ ctx->syndrome_reg[ctx->syn_start];
+	temp_syndrome_reg[REM(ctx->syn_start + 26, 40)] =
+		ctx->syndrome_reg[REM(ctx->syn_start + 26, 40)] ^ ctx->syndrome_reg[ctx->syn_start];
+
+	temp_syndrome_reg[REM(ctx->syn_start + 4, 40)] =
+		ctx->syndrome_reg[REM(ctx->syn_start + 4, 40)] ^ bit;
+	temp_syndrome_reg[REM(ctx->syn_start + 6, 40)] =
+		ctx->syndrome_reg[REM(ctx->syn_start + 6, 40)] ^ bit;
+	temp_syndrome_reg[REM(ctx->syn_start + 10, 40)] =
+		ctx->syndrome_reg[REM(ctx->syn_start + 10, 40)] ^ bit;
+	temp_syndrome_reg[REM(ctx->syn_start + 16, 40)] =
+		ctx->syndrome_reg[REM(ctx->syn_start + 16, 40)] ^ bit;
+	temp_syndrome_reg[REM(ctx->syn_start + 27, 40)] =
+		ctx->syndrome_reg[REM(ctx->syn_start + 27, 40)] ^ bit;
+	temp_syndrome_reg[REM(ctx->syn_start + 29, 40)] =
+		ctx->syndrome_reg[REM(ctx->syn_start + 29, 40)] ^ bit;
+	temp_syndrome_reg[REM(ctx->syn_start + 33, 40)] =
+		ctx->syndrome_reg[REM(ctx->syn_start + 33, 40)] ^ bit;
+	temp_syndrome_reg[REM(ctx->syn_start + 39, 40)] =
+		ctx->syndrome_reg[REM(ctx->syn_start + 39, 40)] ^ bit;
+
+	temp_syndrome_reg[ctx->syn_start] = ctx->syndrome_reg[ctx->syn_start] ^ bit;
+
+	memcpy(ctx->syndrome_reg, temp_syndrome_reg, sizeof ctx->syndrome_reg);
+
+	for (i = 0; i < 28; i++) {
+		error_count = error_count + ctx->syndrome_reg[REM(ctx->syn_start + i, 40)];
+	}
+
+	return error_count;
+}
+
diff --git a/src/host/gprsdecode/crc.h b/src/host/gprsdecode/crc.h
new file mode 100644
index 0000000..d7f76e9
--- /dev/null
+++ b/src/host/gprsdecode/crc.h
@@ -0,0 +1,32 @@
+/*
+ * Copyright 2005 Free Software Foundation, Inc.
+ *
+ * This file is part of GNU Radio
+ *
+ * GNU Radio 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, or (at your option)
+ * any later version.
+ *
+ * GNU Radio 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 GNU Radio; see the file COPYING.  If not, write to
+ * the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
+ * Boston, MA 02111-1307, USA.
+ */
+
+#pragma once
+
+typedef struct {
+	unsigned int crc_size;
+	unsigned int data_size;
+	unsigned int syn_start;
+	int syndrome_reg[40];
+} FC_CTX;
+
+void FC_init(FC_CTX *ctx, unsigned int crc_size, unsigned int data_size);
+int FC_check_crc(FC_CTX *ctx, unsigned char *input_bits, unsigned char *control_data);
diff --git a/src/host/gprsdecode/gprs.c b/src/host/gprsdecode/gprs.c
new file mode 100644
index 0000000..0240efb
--- /dev/null
+++ b/src/host/gprsdecode/gprs.c
@@ -0,0 +1,352 @@
+#include <stdio.h>
+#include <string.h>
+#include <stdbool.h>
+#include <arpa/inet.h>
+
+#include <osmocom/core/msgb.h>
+#include <osmocom/core/bits.h>
+#include <osmocom/core/gsmtap_util.h>
+#include <osmocom/core/gsmtap.h>
+#include <osmocom/core/crcgen.h>
+#include <osmocom/gsm/gsm0503.h>
+#include <osmocom/gsm/protocol/gsm_04_08.h>
+#include <osmocom/coding/gsm0503_interleaving.h>
+#include <osmocom/coding/gsm0503_parity.h>
+
+#include "crc.h"
+#include "gprs.h"
+#include "rlcmac.h"
+
+struct burst_buf gprs[16];
+
+void gprs_init()
+{
+	memset(tbf_table, 0, sizeof(tbf_table));
+}
+
+static inline unsigned distance(const uint8_t *a, const uint8_t *b, const unsigned size)
+{
+	int distance = 0;
+
+	for (int i = 0; i < size; i++)
+		distance += !!(a[i] ^ b[i]);
+
+	return distance;
+}
+
+static inline const char *cs_to_s(enum CS cs)
+{
+    switch (cs) {
+    case CS1: return "CS1";
+    case CS2: return "CS2";
+    case CS3: return "CS3";
+    case CS4: return "CS4";
+    case MCS1_4: return "MCS1_4";
+    case MCS5_6: return "MCS5_6";
+    case MCS7_9: return "MCS7_9";
+    }
+    return "LOL";
+}
+
+static inline enum CS cs_estimate(const uint8_t *sflags, bool print, unsigned prefer_mcs)
+{
+	if (print)
+		printf("CS estimation for %s:\n", osmo_hexdump(sflags, 8));
+	int i;
+	unsigned cs_dist[7];
+	const uint8_t cs_pattern[][8] = {{ 1, 1, 1, 1, 1, 1, 1, 1 }, /*  CS1   */
+					 { 1, 1, 0, 0, 1, 0, 0, 0 }, /*  CS2   */
+					 { 0, 0, 1, 0, 0, 0, 0, 1 }, /*  CS3   */
+					 { 0, 0, 0, 1, 0, 1, 1, 0 }, /*  CS4   */
+					 { 0, 0, 0, 1, 0, 1, 1, 0 }, /* MCS1-4 */
+					 { 0, 0, 0, 0, 0, 0, 0, 0 }, /* MCS5-6 */
+					 { 1, 1, 1, 0, 0, 1, 1, 1 }  /* MCS7-9 */
+	};
+
+	for (i = 0; i < 7; i++) {
+		cs_dist[i] = distance(sflags, cs_pattern[i], 8);
+		if (print)
+			printf("\tD[%d (%s)] = %d\n", i, cs_to_s(i), cs_dist[i]);
+	}
+
+	if (cs_dist[0] < cs_dist[1])
+		i = CS1;
+	else
+		i = CS2;
+	if (cs_dist[2] < cs_dist[i])
+		i = CS3;
+	if (cs_dist[3] < cs_dist[i])
+		i = CS4;
+
+	if (prefer_mcs) {/* enforce selecting MCS over CS in case of same distance */
+	    if (cs_dist[4] <= cs_dist[i])
+		i = MCS1_4;
+	} else {
+	    if (cs_dist[4] < cs_dist[i])
+		i = MCS1_4;
+	}
+
+	if (cs_dist[5] < cs_dist[i])
+		i = MCS5_6;
+	if (cs_dist[6] < cs_dist[i])
+		i = MCS7_9;
+
+	if (print)
+	    printf("\tselected: %d (%s)\n\n", i, cs_to_s(i));
+	return i;
+}
+
+static inline int usf6_estimate(const uint8_t *data)
+{
+	int i, min;
+	unsigned usf_dist[8];
+	const uint8_t usf_pattern[][6] = {{ 0, 0, 0, 0, 0, 0 },
+					  { 0, 0, 1, 0, 1, 1 },
+					  { 0, 1, 0, 1, 1, 0 },
+					  { 0, 1, 1, 1, 0, 1 },
+					  { 1, 0, 0, 1, 0, 1 },
+					  { 1, 0, 1, 1, 1, 0 },
+					  { 1, 1, 0, 0, 1, 1 },
+					  { 1, 1, 1, 0, 0, 0 }};
+
+
+	for (i = 0; i < 8; i++)
+		usf_dist[i] = distance(data, usf_pattern[i], 6);
+
+	for (i = 1, min = 0; i < 8; i++)
+		if (usf_dist[i] < usf_dist[min])
+			min = i;
+
+	return min;
+}
+
+static inline int usf12_estimate(const uint8_t *data)
+{
+	int i, min;
+	unsigned usf_dist[8];
+	const uint8_t usf_pattern[][12] = {{ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 },
+					   { 0, 0, 0, 0, 1, 1, 0, 1, 1, 1, 0, 1 },
+					   { 0, 0, 1, 1, 0, 1, 1, 1, 0, 1, 1, 0 },
+					   { 0, 0, 1, 1, 1, 0, 1, 0, 1, 0, 1, 1 },
+					   { 1, 1, 0, 1, 0, 0, 0, 0, 1, 0, 1, 1 },
+					   { 1, 1, 0, 1, 1, 1, 0, 1, 0, 1, 1, 0 },
+					   { 1, 1, 1, 0, 0, 1, 1, 1, 1, 1, 0, 1 },
+					   { 1, 1, 1, 0, 1, 0, 1, 0, 0, 0, 0, 0 }};
+
+
+	for (i = 0; i < 8; i++)
+		usf_dist[i] = distance(data, usf_pattern[i], 12);
+
+	for (i = 1, min = 0; i < 8; i++)
+		if (usf_dist[i] < usf_dist[min])
+			min = i;
+
+	return min;
+}
+
+static inline int decode_signalling(const uint8_t *conv_data, uint8_t *msg)
+{
+	uint8_t decoded_data[PARITY_OUTPUT_SIZE];
+	int8_t soft_input[CONV_SIZE];
+
+	/* convert to soft bits */
+	osmo_ubit2sbit(soft_input, conv_data, CONV_SIZE);
+
+	/* Viterbi decoding */
+	osmo_conv_decode(&gsm0503_xcch, soft_input, decoded_data);
+
+	/* parity check: if error detected try to fix it */
+	int ret = osmo_crc64gen_check_bits(&gsm0503_fire_crc40, decoded_data, 184, decoded_data + 184);
+	if (ret) {
+		FC_CTX fc_ctx;
+		FC_init(&fc_ctx, PARITY_SIZE, DATA_BLOCK_SIZE);
+		unsigned char crc_result[DATA_BLOCK_SIZE + PARITY_SIZE];
+		ret = FC_check_crc(&fc_ctx, decoded_data, crc_result);
+		if (!ret)
+			return 0;
+		/*
+		ubit_t crc_result[DATA_BLOCK_SIZE + PARITY_SIZE];
+		osmo_crc64gen_set_bits(&gsm0503_fire_crc40, decoded_data, 184, crc_result);
+		*/
+		memcpy(decoded_data, crc_result, sizeof crc_result);
+	}
+
+	osmo_ubit2pbit_ext(msg, 0, decoded_data, 0, DATA_BLOCK_SIZE, 1);
+
+	return GSM_MACBLOCK_LEN;
+}
+
+int process_pdch(struct l1ctl_burst_ind *bi, bool print)
+{
+	int len, ret, usf;
+	uint32_t fn;
+	uint16_t arfcn;
+	struct burst_buf *bb;
+	struct gprs_message gm;
+	uint8_t ts, ul, conv_data[CONV_SIZE], decoded_data[2 * CONV_SIZE], gprs_msg[54];
+	int8_t depunct_data[2 * CONV_SIZE];
+
+	/* get burst parameters */
+	fn = ntohl(bi->frame_nr);
+	arfcn = ntohs(bi->band_arfcn);
+	ul = !!(arfcn & GSMTAP_ARFCN_F_UPLINK);
+	ts = bi->chan_nr & 7;
+
+	/* select frame queue */
+	bb = (ul) ? (&gprs[2 * ts + 0]) : (&gprs[2 * ts + 1]);
+
+	/* align to first frame */
+	if ((bb->count == 0) && (((fn % 13) % 4) != 0))
+	    return -1;
+
+	/* enqueue data into message buffer */
+	osmo_pbit2ubit(bb->data + bb->count * 114, bi->bits, 114);
+
+	/* save stealing flags */
+	bb->sbit[bb->count * 2 + 0] = !!(bi->bits[14] & 0x10); /* check stealing bits location for MCS > 4 */
+	bb->sbit[bb->count * 2 + 1] = !!(bi->bits[14] & 0x20);
+	if (print)
+		printf("added stealing bits (%d::%d) at [%d::%d]\n",
+		       !!(bi->bits[14] & 0x10), !!(bi->bits[14] & 0x20), bb->count * 2 + 0, bb->count * 2 + 1);
+	bb->snr[bb->count] = bi->snr;
+	bb->rxl[bb->count] = bi->rx_level;
+	bb->fn[bb->count] = fn;
+	bb->count++;
+
+	/* Return if not enough bursts for a full message */
+	if (bb->count < 4)
+		return -2;
+
+	/* de-interleaving */
+	memset(conv_data, 0, sizeof(conv_data));
+	/* FIXME: hack, working with non-soft bits: */
+	gsm0503_xcch_deinterleave((sbit_t *)conv_data, (sbit_t *)bb->data);
+	len = 0;
+
+	enum CS cs = cs_estimate(bb->sbit, DEBUG_PRINT, PREFER_MCS);
+	switch (cs) {
+	case CS1:
+		if (print)
+			printf("processing CS1 (%d::%d)\n", *(bb->sbit), cs);
+		len = decode_signalling(conv_data, gprs_msg);
+		break;
+	case CS2:
+		if (print)
+			printf("processing CS2 (%d::%d)\n", *(bb->sbit), cs);
+		/* depuncture and convert to soft bits */
+		memset(depunct_data, 0, 294 * 2);
+		osmo_ubit2sbit(depunct_data, conv_data, 456);
+
+		/* Viterbi decode */
+		osmo_conv_decode(&gsm0503_cs2, depunct_data, decoded_data);
+
+		/* decode USF bits */
+		usf = usf6_estimate(decoded_data);
+
+		/* rebuild original data string for CRC check */
+		decoded_data[3] = (usf >> 2) & 1;
+		decoded_data[4] = (usf >> 1) & 1;
+		decoded_data[5] = (usf >> 0) & 1;
+
+		/* compute CRC-16 (CCITT) */
+		ret = osmo_crc16gen_check_bits(&gsm0503_cs234_crc16, decoded_data + 3, 271, decoded_data + 3 + 271);
+
+		if (!ret) {
+			osmo_ubit2pbit_ext(gprs_msg, 0, decoded_data + 3, 0, 33 * 8, 1);
+			len = 33;
+		}
+
+		break;
+	case CS3:
+		if (print)
+			printf("processing CS3 (%d::%d)\n", *(bb->sbit), cs);
+		/* depuncture and convert to soft bits */
+		memset(depunct_data, 0, 338 * 2);
+		osmo_ubit2sbit(depunct_data, conv_data, 456);
+
+		/* Viterbi decode */
+		osmo_conv_decode(&gsm0503_cs3, depunct_data, decoded_data);
+
+		/* decode USF bits */
+		usf = usf6_estimate(decoded_data);
+
+		/* rebuild original data string for CRC check */
+		decoded_data[3] = (usf >> 2) & 1;
+		decoded_data[4] = (usf >> 1) & 1;
+		decoded_data[5] = (usf >> 0) & 1;
+
+		/* compute CRC-16 (CCITT) */
+		ret = osmo_crc16gen_check_bits(&gsm0503_cs234_crc16, decoded_data + 3, 315, decoded_data + 3 + 315);
+		if (!ret) {
+			osmo_ubit2pbit_ext(gprs_msg, 0, decoded_data + 3, 0, 39 * 8, 1);
+			len = 39;
+		}
+		break;
+	case CS4:
+		if (print)
+			printf("processing CS4 (%d::%d)\n", *(bb->sbit), cs);
+		/* decode USF bits */
+		usf = usf12_estimate(conv_data);
+
+		/* rebuild original data string for CRC check */
+		conv_data[9] = (usf >> 2) & 1;
+		conv_data[10] = (usf >> 1) & 1;
+		conv_data[11] = (usf >> 0) & 1;
+
+		/* compute CRC-16 (CCITT) */
+		ret = osmo_crc16gen_check_bits(&gsm0503_cs234_crc16, conv_data + 9, 431, conv_data + 9 + 431);
+		if (!ret) {
+			osmo_ubit2pbit_ext(gprs_msg, 0, conv_data + 9, 0, 53 * 8, 1);
+			len = 53; /* last byte not used (0x2b) */
+		} else {/* TODO: try MCS1-4? */
+
+		}
+		break;
+	case MCS1_4:
+		if (print)
+			printf("MCS1-4 is unsupported ATM\n");
+		break;
+	case MCS5_6:
+		if (print)
+			printf("MCS5-6 is unsupported ATM\n");
+		break;
+	case MCS7_9:
+		if (print)
+			printf("MCS7-9 is unsupported ATM\n");
+		break;
+	default:
+		printf("(M)CS estimation failed for %d: %s\n", *(bb->sbit), cs_to_s(cs));
+		break;
+	}
+
+	/* if a message is decoded */
+	if (len) {
+		unsigned s_sum, r_sum;
+
+		/* fill gprs message struct */
+		s_sum = 0;
+		r_sum = 0;
+		for (int i = 0; i < 4; i++) {
+			s_sum += bb->snr[i];
+			r_sum += bb->rxl[i];
+		}
+		gm.snr = s_sum / 4;
+		gm.rxl = r_sum / 4;
+		gm.arfcn = arfcn;
+		gm.fn = fn - 3;
+		gm.ts = ts;
+		gm.len = len;
+		memcpy(gm.msg, gprs_msg, len);
+
+		/* call handler */
+		if (0 == rlc_type_handler(&gm))
+			cs_estimate(bb->sbit, DEBUG_PRINT, PREFER_MCS); /* check (M)CS selection */
+	}
+
+	/* reset buffer */
+	memset(bb->data, 0, sizeof(bb->data));
+	bb->count = 0;
+
+	return len;
+}
+
diff --git a/src/host/gprsdecode/gprs.h b/src/host/gprsdecode/gprs.h
new file mode 100644
index 0000000..42f1ed5
--- /dev/null
+++ b/src/host/gprsdecode/gprs.h
@@ -0,0 +1,36 @@
+#pragma once
+
+#include <stdint.h>
+#include <stdbool.h>
+
+#include <osmocom/core/conv.h>
+#include <osmocom/core/crcgen.h>
+
+#include <l1ctl_proto.h>
+
+enum CS { CS1 = 0, CS2, CS3, CS4, MCS1_4, MCS5_6, MCS7_9 };
+
+#define DATA_BLOCK_SIZE         184
+#define PARITY_SIZE             40
+#define FLUSH_BITS_SIZE         4
+#define PARITY_OUTPUT_SIZE (DATA_BLOCK_SIZE + PARITY_SIZE + FLUSH_BITS_SIZE)
+#define DEBUG_PRINT false
+#define PREFER_MCS 0
+#define CONV_SIZE		(2 * PARITY_OUTPUT_SIZE)
+#define MAX_MCS 5
+// 5 == MCS1-4
+
+enum { UNKNOWN = 0, BCCH = 1, CCCH = 2, SDCCH = 4, SACCH = 8 };
+
+struct burst_buf {
+	unsigned count;
+	unsigned errors;
+	unsigned snr[2 * 4];
+	unsigned rxl[2 * 4];
+	uint32_t fn[2 * 4];
+	uint8_t data[2 * 4 * 114];
+	uint8_t sbit[2 * 4 * 2];
+};
+
+void gprs_init();
+int process_pdch(struct l1ctl_burst_ind *bi, bool print);
diff --git a/src/host/gprsdecode/main.c b/src/host/gprsdecode/main.c
new file mode 100644
index 0000000..8f1d53c
--- /dev/null
+++ b/src/host/gprsdecode/main.c
@@ -0,0 +1,77 @@
+#include <stdio.h>
+#include <stdint.h>
+#include <string.h>
+#include <arpa/inet.h>
+#include <osmocom/gsm/rsl.h>
+#include <osmocom/core/select.h>
+#include <osmocom/gsm/gsm_utils.h>
+#include <osmocom/gsm/protocol/gsm_04_08.h>
+
+#include <l1ctl_proto.h>
+
+#include "gprs.h"
+#include "output.h"
+
+struct burst_buf gprs[16];
+
+void process_handle_burst(struct l1ctl_burst_ind *bi)
+{
+	uint32_t fn;
+	uint8_t type, subch, ts;
+
+	fn = ntohl(bi->frame_nr);
+	rsl_dec_chan_nr(bi->chan_nr, &type, &subch, &ts);
+
+	switch (type) {
+	case RSL_CHAN_Bm_ACCHs:
+	    if ((ts > 0) && ((fn % 13) != 12)) // wtf is 12?
+		process_pdch(bi, DEBUG_PRINT);
+/*		    printf("TS = %d, FN = %d (%d)\n", ts, fn, process_pdch(bi));
+		else
+		    printf("TS = %d, FN = %d [%d]\n", ts, fn, fn % 13);
+*/		break;
+	case RSL_CHAN_Lm_ACCHs:
+	case RSL_CHAN_BCCH:
+	case RSL_CHAN_SDCCH4_ACCH:
+	case RSL_CHAN_SDCCH8_ACCH:
+	case RSL_CHAN_RACH:
+	case RSL_CHAN_PCH_AGCH:
+	default:
+		break;
+		//printf("Type not handled! %.02x\n", type);
+	}
+}
+
+int main(int argc, char **argv)
+{
+	int ret;
+	FILE *burst_fd;
+        struct l1ctl_burst_ind bi;
+
+	if (argc < 2) {
+		printf("\nUsage: %s <burstfile>\n", argv[0]);
+		return -1;
+	}
+
+	burst_fd = fopen(argv[1], "rb");
+	if (!burst_fd) {
+		printf("Cannot open file\n");
+		return 0;
+	}
+
+	net_init();
+	gprs_init();
+	memset(gprs, 0, 16 * sizeof(struct burst_buf));
+
+	while (!feof(burst_fd)) {
+		ret = fread(&bi, sizeof(bi), 1, burst_fd);
+		if (!ret)
+			break;
+		process_handle_burst(&bi);
+	}
+
+	fclose(burst_fd);
+	fflush(NULL);
+	return 0;
+}
+
diff --git a/src/host/gprsdecode/output.c b/src/host/gprsdecode/output.c
new file mode 100644
index 0000000..121bc6e
--- /dev/null
+++ b/src/host/gprsdecode/output.c
@@ -0,0 +1,67 @@
+#include <stdio.h>
+#include <string.h>
+#include <arpa/inet.h>
+#include <osmocom/core/gsmtap.h>
+#include <osmocom/core/gsmtap_util.h>
+
+#include <l1ctl_proto.h>
+
+#include "output.h"
+
+static struct gsmtap_inst *gti;
+
+void net_init()
+{
+	gti = gsmtap_source_init("127.0.0.1", GSMTAP_UDP_PORT, 0);
+	gsmtap_source_add_sink(gti);
+}
+
+void net_send_rlcmac(uint8_t *msg, int len, uint8_t ts, uint8_t ul)
+{
+	if (gti) {
+		gsmtap_send(gti, ul ? GSMTAP_ARFCN_F_UPLINK : 0, ts, GSMTAP_CHANNEL_PACCH, 0, 0, 0, 0, msg, len);
+		while (osmo_select_main(1));
+	}
+}
+
+void net_send_llc(uint8_t *data, int len, uint8_t ul)
+{
+	struct msgb *msg;
+	struct gsmtap_hdr *gh;
+	uint8_t *dst;
+
+	if (!gti)
+		return;
+
+	/* skip null frames */
+	if ((data[0] == 0x43) &&
+	    (data[1] == 0xc0) &&
+	    (data[2] == 0x01))
+		return;
+
+	msg = msgb_alloc(sizeof(*gh) + len, "gsmtap_tx");
+	if (!msg)
+	        return;
+
+	gh = (struct gsmtap_hdr *) msgb_put(msg, sizeof(*gh));
+
+	gh->version = GSMTAP_VERSION;
+	gh->hdr_len = sizeof(*gh) / 4;
+	gh->type = GSMTAP_TYPE_GB_LLC;
+	gh->timeslot = 0;
+	gh->sub_slot = 0;
+	gh->arfcn = ul ? htons(GSMTAP_ARFCN_F_UPLINK) : 0;
+	gh->snr_db = 0;
+	gh->signal_dbm = 0;
+	gh->frame_number = 0;
+	gh->sub_type = 0;
+	gh->antenna_nr = 0;
+
+        dst = msgb_put(msg, len);
+        memcpy(dst, data, len);
+
+	gsmtap_sendmsg(gti, msg);
+
+	while (osmo_select_main(1));
+}
+
diff --git a/src/host/gprsdecode/output.h b/src/host/gprsdecode/output.h
new file mode 100644
index 0000000..5709307
--- /dev/null
+++ b/src/host/gprsdecode/output.h
@@ -0,0 +1,7 @@
+#pragma once
+
+#include <stdint.h>
+
+void net_init();
+void net_send_rlcmac(uint8_t *msg, int len, uint8_t ts, uint8_t ul);
+void net_send_llc(uint8_t *data, int len, uint8_t ul);
diff --git a/src/host/gprsdecode/rlcmac.c b/src/host/gprsdecode/rlcmac.c
new file mode 100644
index 0000000..9b7642a
--- /dev/null
+++ b/src/host/gprsdecode/rlcmac.c
@@ -0,0 +1,377 @@
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include <sys/time.h>
+#include <osmocom/core/gsmtap.h>
+#include <osmocom/core/gsmtap_util.h>
+
+#include "rlcmac.h"
+#include "output.h"
+
+inline int too_old(uint32_t current_fn, uint32_t test_fn)
+{
+	uint32_t delta = (current_fn - test_fn) & 0xffffffff;
+
+	/* more and less 30 seconds from now */
+	return (abs(delta) > OLD_TIME) ? 1 : 0;
+}
+
+inline int bsn_is_next(uint8_t first, uint8_t second)
+{
+	return (((first + 1) % 128) == second);
+}
+
+void print_pkt(uint8_t *msg, unsigned len)
+{
+	printf("MSG: ");
+	for (unsigned i = 0; i < len; i++)
+		printf("%.02x", msg[i]);
+
+	printf("\n");
+	fflush(stdout);
+}
+
+void process_blocks(struct gprs_tbf *t, int ul)
+{
+	struct gprs_frag *f;
+	struct gprs_lime *l;
+	unsigned skip, llc_len = 0;
+	uint8_t bsn, bsn2, llc_data[65536], llc_first_bsn, llc_last_bsn = 0, li_off;
+	uint32_t current_fn;
+
+	/* get current "time", oldest unreassembled frag */
+	bsn = t->start_bsn;
+	while (t->frags[bsn].len == 0) {
+		bsn = (bsn + 1) % 128;
+		if (bsn == t->start_bsn) {
+			printf("no valid  blocks in current TBF!\n");
+			fflush(stdout);
+			return;
+		}
+	}
+	current_fn = t->frags[bsn].fn;
+	t->start_bsn = bsn;
+
+	/* walk through fragments, mark reassembled/used blocks */
+	skip = 0;
+	for (bsn = t->start_bsn; bsn != ((t->last_bsn + 1) % 128); bsn = (bsn + 1) % 128) {
+		/* get fragment descriptor */
+		f = &t->frags[bsn];
+
+		printf(" bsn %d ", bsn);
+		fflush(stdout);
+
+		/* already processed or null */
+		if (!f->len) {
+			printf("null\n");
+			fflush(stdout);
+			llc_len = 0;
+			skip = 1;
+			continue;
+		}
+
+		/* check fragment age */
+		if (too_old(current_fn, f->fn)) {
+			printf("old segment\n");
+			fflush(stdout);
+			llc_len = 0;
+			skip = 1;
+			continue;
+		}
+
+		/* update "time" */
+		current_fn = f->fn;
+
+		if (llc_len && !bsn_is_next(llc_last_bsn, bsn)) {
+			printf("missing bsn, previous %d\n", llc_last_bsn);
+			fflush(stdout);
+			llc_len = 0;
+			skip = 1;
+			continue;
+		}
+
+		/* check for multiple blocks/parts */
+		if (f->n_blocks == 0) {
+			/* check if first part of message */
+			if (!llc_len)
+				llc_first_bsn = bsn;
+
+			/* append data to buffer */
+			memcpy(&llc_data[llc_len], f->data, f->len);
+
+			llc_len += f->len;
+
+			llc_last_bsn = bsn;
+
+			/* last TBF block? (very rare condition) */
+			if (f->last) {
+				printf("end of TBF\n");
+				fflush(stdout);
+				print_pkt(llc_data, llc_len);
+
+				net_send_llc(llc_data, llc_len, ul);
+
+				/* reset all fragments */
+				for (bsn2 = 0; bsn2 < 128; bsn2++) {
+					f = &t->frags[bsn2];
+					f->len = 0;
+					f->n_blocks = 0;
+				}
+
+				/* reset buffer state */
+				llc_len = 0;
+				t->start_bsn = 0;
+			}
+		} else {
+			/* multiple data parts */
+			li_off = 0;
+			for (unsigned i = 0; i < f->n_blocks; i++) {
+				printf("\nlime %d\n", i);
+				fflush(stdout);
+				l = &f->blocks[i];
+				if (l->used) {
+					if (llc_len) {
+						// error!
+						printf("\nlime error!\n");
+						fflush(stdout);
+						llc_len = 0;
+					}
+				} else {
+					if (!llc_len)
+						llc_first_bsn = bsn;
+
+					/* append data to buffer */
+					memcpy(&llc_data[llc_len], &f->data[li_off], l->li);
+
+					llc_len += l->li;
+
+					llc_last_bsn = bsn;
+
+					if (!l->e || !l->m || (l->e && l->m)) {
+						/* message ends here */
+						printf("end of message reached\n");
+						fflush(stdout);
+						print_pkt(llc_data, llc_len);
+
+						net_send_llc(llc_data, llc_len, ul);
+
+						/* mark frags as used */
+						l->used = 1;
+						if (llc_first_bsn != bsn) {
+						}
+
+
+						llc_len = 0;
+						if (!skip)
+							t->start_bsn = bsn;
+					}
+				}
+
+				li_off += l->li;
+			}
+
+			/* is spare data valid? */
+			if (l->m) {
+				if (llc_len) {
+					printf("spare and buffer not empty!\n");
+					print_pkt(llc_data, llc_len);
+					fflush(stdout);
+				}
+				if ((f->len > li_off) && (f->len-li_off < 65536)) {
+					memcpy(llc_data, &f->data[li_off], f->len-li_off);
+					llc_len = f->len - li_off;
+					llc_first_bsn = bsn;
+					llc_last_bsn = bsn;
+					t->start_bsn = bsn;
+				}
+			}
+
+		}
+	}
+
+	/* shift window if needed */
+	if (((t->last_bsn - t->start_bsn) % 128) > 64) {
+		t->start_bsn = (t->last_bsn - 64) % 128;
+		printf("shifting window\n");
+		fflush(stdout);
+	}
+}
+
+void rlc_data_handler(struct gprs_message *gm)
+{
+	int ul, off, d_bsn;
+	uint8_t tfi, bsn, cv = 1, fbi = 0;
+	uint32_t d_same_bsn, d_last_bsn;
+	struct gprs_tbf *t, *t_prev;
+	struct gprs_frag *f;
+	struct gprs_lime *l;
+
+	tfi = (gm->msg[1] & 0x3e) >> 1;
+	bsn = (gm->msg[2] & 0xfe) >> 1;
+
+	/* get "end of TBF" according to direction */
+	ul = !!(gm->arfcn & GSMTAP_ARFCN_F_UPLINK);
+	if (ul) {
+		cv = (gm->msg[0] & 0x3c) >> 2;
+		printf("TFI %d BSN %d CV %d ", tfi, bsn, cv);
+	} else {
+		fbi = (gm->msg[1] & 0x01);
+		printf("TFI %d BSN %d FBI %d ", tfi, bsn, fbi);
+	}
+
+	/* get TBF descriptor for TFI,UL couple */
+	t = &tbf_table[2 * tfi + ul];
+
+	d_same_bsn = (gm->fn - t->frags[bsn].fn) & 0xffffffff;
+	d_last_bsn = (gm->fn - t->frags[t->last_bsn].fn) & 0xffffffff;
+	d_bsn = (bsn - t->last_bsn) % 128;
+
+	printf("\nfn_same_bsn %d fn_last_bsn %d delta_bsn %d old_len %d\n",
+		d_same_bsn, d_last_bsn, d_bsn, t->frags[bsn].len);
+
+	/* new/old fragment decision */
+	if (d_same_bsn > OLD_TIME) {
+		if (d_last_bsn > OLD_TIME) {
+			// new tbf is starting, close old one...
+			t_prev = &tbf_table[2 * ((tfi + 1) % 32) + ul];
+			printf("clearing TBF %d, first %d last %d\n", (tfi + 1) % 32, t_prev->start_bsn, t_prev->last_bsn);
+			f = &t_prev->frags[t_prev->last_bsn];
+
+			// ...only if data is present
+			if (f->len) {
+				f->last = 1;
+				process_blocks(t_prev, ul);
+			}
+
+			printf("new TBF, starting from %d\n", bsn);
+			t->start_bsn = 0;
+			t->last_bsn = bsn;
+			memset(t->frags, 0, 128 * sizeof(struct gprs_frag));
+		} else {
+			// fresh frag, current tbf
+			if ((d_bsn >= 0) || (d_bsn < -64)) {
+				// new frag
+				t->last_bsn = bsn;
+			} else {
+				// out of sequence / duplicate
+				t->frags[bsn].fn = gm->fn;
+				printf("duplicate\n");
+				fflush(stdout);
+				return;
+			}
+		}
+	} else {
+		if (d_last_bsn > OLD_TIME) {
+			printf("fucking error last_bsn!\n");
+			fflush(stdout);
+			return;
+		} else {
+			// fresh frag, current tbf
+			if (d_bsn > 0) {
+				printf("fucking error d_bsn!\n");
+				fflush(stdout);
+				return;
+			} else {
+				if (d_bsn < -64) {
+					// new frag
+					t->last_bsn = bsn;
+				} else {
+					// duplicate
+					t->frags[bsn].fn = gm->fn;
+					printf("duplicate2\n");
+					fflush(stdout);
+					return;
+				}
+			}
+		}
+	}
+
+	/* get fragment struct for current BSN */
+	f = &t->frags[bsn];
+
+	/* scan for LI_M_E entries */
+	off = 2;
+	f->n_blocks = 0;
+	while (!(gm->msg[off++] & 0x01)) {
+		l = &f->blocks[f->n_blocks++];
+		l->li = (gm->msg[off] & 0xfc) >> 2;
+		l->m = (gm->msg[off] & 0x02) >> 1;
+		l->e = (gm->msg[off] & 0x01);
+		l->used = 0;
+	}
+
+	/* end of TBF? */
+	f->last = (!cv || fbi) ? 1 : 0;
+
+	/* optional fields for uplink, indicated in TI and PI */
+	if (ul) {
+		if (gm->msg[1] & 0x01) {
+			printf("TLLI 0x%.02x%.02x%.02x%.02x ", gm->msg[off],
+				gm->msg[off+1], gm->msg[off + 2], gm->msg[off + 3]);
+			off += 4;
+		}
+		if (gm->msg[1] & 0x40) {
+			printf("PFI %d ", gm->msg[off]);
+			off += 1;
+		}
+	}
+
+	/* copy data part of message */
+	f->len = gm->len - off;
+	f->fn = gm->fn;
+	memcpy(f->data, &gm->msg[off], f->len);
+
+	process_blocks(t, ul);
+}
+
+int rlc_type_handler(struct gprs_message *gm)
+{
+    int ret = 0;
+    switch((gm->msg[0] & 0xc0) >> 6) {
+    case 0:
+	    /* data block */
+	    printf("TS %d ", gm->ts);
+
+	    switch(gm->len) {
+	    case 23:
+		    printf("CS1 ");
+		    break;
+	    case 33:
+		    printf("CS2 ");
+		    break;
+	    case 39:
+		    printf("CS3 ");
+		    break;
+	    case 53:
+		    printf("CS4 ");
+		    break;
+	    default:
+		    printf("unknown (M)CS ");
+	    }
+
+	    printf((gm->arfcn & GSMTAP_ARFCN_F_UPLINK) ? "UL " : "DL ");
+
+	    net_send_rlcmac(gm->msg, gm->len, gm->ts, !!(gm->arfcn & GSMTAP_ARFCN_F_UPLINK));
+	    printf("DATA ");
+	    rlc_data_handler(gm);
+	    printf("\n");
+	    fflush(stdout);
+	    break;
+    case 1:
+    case 2:
+	    /* control block */
+//	    printf("RLC type: control block on TS %d (case %d)\n", gm->ts, (gm->msg[0] & 0xc0) >> 6);
+	    net_send_rlcmac(gm->msg, gm->len, gm->ts, !!(gm->arfcn & GSMTAP_ARFCN_F_UPLINK));
+	    return 1;
+    case 3:
+	    /* reserved */
+	    printf("RLC type: reserved\n");
+	    return 3;
+
+    default:
+	    printf("Unrecognized RLC type: %d\n", (gm->msg[0] & 0xc0) >> 6);
+	    return -1;
+    }
+    return ret;
+}
+
diff --git a/src/host/gprsdecode/rlcmac.h b/src/host/gprsdecode/rlcmac.h
new file mode 100644
index 0000000..952fe02
--- /dev/null
+++ b/src/host/gprsdecode/rlcmac.h
@@ -0,0 +1,44 @@
+#pragma once
+
+#include <stdint.h>
+
+#define OLD_TIME 2000
+
+struct gprs_message {
+	uint16_t arfcn;
+	uint32_t fn;
+	uint8_t ts;
+	uint8_t rxl;
+	uint8_t snr;
+	uint8_t len;
+	uint8_t msg[53];
+};
+
+struct gprs_lime {
+	uint8_t li:6,
+		m:1,
+		e:1;
+	uint8_t used;
+} __attribute__ ((packed));
+
+struct gprs_frag {
+	uint32_t fn;
+	uint8_t last;
+	uint8_t len;
+	uint8_t data[53];
+	uint8_t n_blocks;
+	struct gprs_lime blocks[20];
+} __attribute__ ((packed));
+
+struct gprs_tbf {
+	uint8_t last_bsn; // for windowing
+	uint8_t start_bsn; // first block of current message
+	struct gprs_frag frags[128];
+} __attribute__ ((packed));
+
+static struct gprs_tbf tbf_table[32 * 2]; // for one cell
+
+void print_pkt(uint8_t *msg, unsigned len);
+void process_blocks(struct gprs_tbf *t, int ul);
+void rlc_data_handler(struct gprs_message *gm);
+int rlc_type_handler(struct gprs_message *gm);
diff --git a/src/host/gprsdecode/tests/.gitignore b/src/host/gprsdecode/tests/.gitignore
new file mode 100644
index 0000000..4123e38
--- /dev/null
+++ b/src/host/gprsdecode/tests/.gitignore
@@ -0,0 +1,2 @@
+bursts*
+*.dat
diff --git a/src/host/gprsdecode/tests/Makefile b/src/host/gprsdecode/tests/Makefile
new file mode 100644
index 0000000..6f53fea
--- /dev/null
+++ b/src/host/gprsdecode/tests/Makefile
@@ -0,0 +1,7 @@
+check:
+	@echo test CS2
+	@./../gprsdecode gprs_262_80_0001_0000_20110710_2251_875_494777_0f.sample > cs2.dat
+	@diff gprs_262_80_0001_0000_20110710_2251_875_494777_0f.decoded cs2.dat
+	@echo test CS3
+	@./../gprsdecode gprs_20160129_1744_878_16846_0c.sample > cs3.dat
+	@diff gprs_20160129_1744_878_16846_0c.decoded cs3.dat
diff --git a/src/host/gprsdecode/tests/gprs_20160129_1744_878_16846_0c.decoded b/src/host/gprsdecode/tests/gprs_20160129_1744_878_16846_0c.decoded
new file mode 100644
index 0000000..7af0753
--- /dev/null
+++ b/src/host/gprsdecode/tests/gprs_20160129_1744_878_16846_0c.decoded
@@ -0,0 +1,6278 @@
+TS 4 CS2 DL DATA TFI 0 BSN 0 FBI 0 
+fn_same_bsn 16895 fn_last_bsn 16895 delta_bsn 0 old_len 0
+clearing TBF 1, first 0 last 0
+new TBF, starting from 0
+ bsn 0 
+lime 0
+end of message reached
+MSG: 41c001081502de8e9a
+
+lime 1
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS2 DL DATA TFI 0 BSN 0 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 28
+duplicate2
+
+TS 4 CS2 DL DATA TFI 0 BSN 0 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 28
+duplicate2
+
+TS 4 CS2 DL DATA TFI 0 BSN 0 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 28
+duplicate2
+
+TS 4 CS2 DL DATA TFI 0 BSN 0 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 28
+duplicate2
+
+TS 4 CS2 DL DATA TFI 0 BSN 0 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 28
+duplicate2
+
+TS 4 CS2 DL DATA TFI 0 BSN 0 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 28
+duplicate2
+
+TS 4 CS2 DL DATA TFI 0 BSN 0 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 28
+duplicate2
+
+TS 4 CS2 DL DATA TFI 0 BSN 0 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 28
+duplicate2
+
+TS 4 CS2 DL DATA TFI 0 BSN 0 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 28
+duplicate2
+
+TS 4 CS2 DL DATA TFI 0 BSN 0 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 28
+duplicate2
+
+TS 4 CS2 DL DATA TFI 0 BSN 0 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 28
+duplicate2
+
+TS 4 CS2 DL DATA TFI 0 BSN 0 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 28
+duplicate2
+
+TS 4 CS2 DL DATA TFI 0 BSN 1 FBI 0 
+fn_same_bsn 16986 fn_last_bsn 39 delta_bsn 1 old_len 0
+ bsn 0 
+lime 0
+
+lime 1
+ bsn 1 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS2 DL DATA TFI 0 BSN 1 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 29
+duplicate2
+
+TS 4 CS2 DL DATA TFI 0 BSN 2 FBI 0 
+fn_same_bsn 16999 fn_last_bsn 8 delta_bsn 1 old_len 0
+ bsn 1 
+lime 0
+ bsn 2 
+lime 0
+end of message reached
+MSG: 41c005081501c7d312
+
+lime 1
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS2 DL DATA TFI 0 BSN 2 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 28
+duplicate2
+
+TS 4 CS2 DL DATA TFI 0 BSN 2 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 28
+duplicate2
+
+TS 4 CS2 DL DATA TFI 0 BSN 2 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 28
+duplicate2
+
+TS 4 CS2 DL DATA TFI 0 BSN 2 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 28
+duplicate2
+
+TS 4 CS2 DL DATA TFI 0 BSN 2 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 28
+duplicate2
+
+TS 4 CS2 DL DATA TFI 0 BSN 2 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 28
+duplicate2
+
+TS 4 CS2 DL DATA TFI 0 BSN 2 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 28
+duplicate2
+
+TS 4 CS2 DL DATA TFI 0 BSN 2 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 28
+duplicate2
+
+TS 4 CS2 DL DATA TFI 0 BSN 3 FBI 0 
+fn_same_bsn 17064 fn_last_bsn 30 delta_bsn 1 old_len 0
+ bsn 2 
+lime 0
+
+lime 1
+ bsn 3 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS2 DL DATA TFI 0 BSN 3 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 29
+duplicate2
+
+TS 4 CS2 DL DATA TFI 0 BSN 3 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 29
+duplicate2
+
+TS 4 CS2 DL DATA TFI 0 BSN 3 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 29
+duplicate2
+
+TS 4 CS2 DL DATA TFI 0 BSN 3 FBI 0 
+fn_same_bsn 9 fn_last_bsn 9 delta_bsn 0 old_len 29
+duplicate2
+
+TS 4 CS2 DL DATA TFI 0 BSN 5 FBI 0 
+fn_same_bsn 17090 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 3 
+lime 0
+ bsn 4 null
+ bsn 5 
+lime 0
+end of message reached
+MSG: 2b2b2b
+
+lime 1
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS2 DL DATA TFI 0 BSN 5 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 28
+duplicate2
+
+TS 4 CS2 DL DATA TFI 0 BSN 5 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 28
+duplicate2
+
+TS 4 CS2 DL DATA TFI 0 BSN 5 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 28
+duplicate2
+
+TS 4 CS2 DL DATA TFI 0 BSN 5 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 28
+duplicate2
+
+TS 4 CS2 DL DATA TFI 0 BSN 5 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 28
+duplicate2
+
+TS 4 CS3 DL DATA TFI 0 BSN 6 FBI 0 
+fn_same_bsn 17142 fn_last_bsn 30 delta_bsn 1 old_len 0
+ bsn 3 
+lime 0
+ bsn 4 null
+ bsn 5 
+lime 0
+
+lime 1
+ bsn 6 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS3 DL DATA TFI 0 BSN 6 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 35
+duplicate2
+
+TS 4 CS3 DL DATA TFI 0 BSN 6 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 35
+duplicate2
+
+TS 4 CS3 DL DATA TFI 0 BSN 6 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 35
+duplicate2
+
+TS 4 CS3 DL DATA TFI 0 BSN 6 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 35
+duplicate2
+
+TS 4 CS3 DL DATA TFI 0 BSN 6 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 35
+duplicate2
+
+TS 4 CS3 DL DATA TFI 0 BSN 7 FBI 0 
+fn_same_bsn 17177 fn_last_bsn 13 delta_bsn 1 old_len 0
+ bsn 3 
+lime 0
+ bsn 4 null
+ bsn 5 
+lime 0
+
+lime 1
+ bsn 6 
+lime 0
+ bsn 7 
+TS 4 CS3 DL DATA TFI 0 BSN 7 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 36
+duplicate2
+
+TS 4 CS3 DL DATA TFI 0 BSN 7 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 36
+duplicate2
+
+TS 4 CS3 DL DATA TFI 0 BSN 7 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 36
+duplicate2
+
+TS 4 CS3 DL DATA TFI 0 BSN 7 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 36
+duplicate2
+
+TS 4 CS3 DL DATA TFI 0 BSN 7 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 36
+duplicate2
+
+TS 4 CS3 DL DATA TFI 0 BSN 9 FBI 0 
+fn_same_bsn 17203 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 3 
+lime 0
+ bsn 4 null
+ bsn 5 
+lime 0
+
+lime 1
+ bsn 6 
+lime 0
+ bsn 7  bsn 8 null
+ bsn 9 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS3 DL DATA TFI 0 BSN 9 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 35
+duplicate2
+
+TS 4 CS3 DL DATA TFI 0 BSN 9 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 35
+duplicate2
+
+TS 4 CS3 DL DATA TFI 0 BSN 9 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 35
+duplicate2
+
+TS 4 CS3 DL DATA TFI 0 BSN 9 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 35
+duplicate2
+
+TS 4 CS3 DL DATA TFI 0 BSN 9 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 35
+duplicate2
+
+TS 4 CS3 DL DATA TFI 0 BSN 10 FBI 0 
+fn_same_bsn 17264 fn_last_bsn 39 delta_bsn 1 old_len 0
+ bsn 3 
+lime 0
+ bsn 4 null
+ bsn 5 
+lime 0
+
+lime 1
+ bsn 6 
+lime 0
+ bsn 7  bsn 8 null
+ bsn 9 
+lime 0
+ bsn 10 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS3 DL DATA TFI 0 BSN 10 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 35
+duplicate2
+
+TS 4 CS3 DL DATA TFI 0 BSN 10 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 35
+duplicate2
+
+TS 4 CS3 DL DATA TFI 0 BSN 10 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 35
+duplicate2
+
+TS 4 CS3 DL DATA TFI 0 BSN 10 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 35
+duplicate2
+
+TS 4 CS3 DL DATA TFI 0 BSN 10 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 35
+duplicate2
+
+TS 4 CS3 DL DATA TFI 0 BSN 11 FBI 0 
+fn_same_bsn 17324 fn_last_bsn 39 delta_bsn 1 old_len 0
+ bsn 3 
+lime 0
+ bsn 4 null
+ bsn 5 
+lime 0
+
+lime 1
+ bsn 6 
+lime 0
+ bsn 7  bsn 8 null
+ bsn 9 
+lime 0
+ bsn 10 
+lime 0
+ bsn 11 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS3 DL DATA TFI 0 BSN 11 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 35
+duplicate2
+
+TS 4 CS3 DL DATA TFI 0 BSN 11 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 35
+duplicate2
+
+TS 4 CS3 DL DATA TFI 0 BSN 11 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 35
+duplicate2
+
+TS 4 CS3 DL DATA TFI 0 BSN 11 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 35
+duplicate2
+
+TS 4 CS3 DL DATA TFI 0 BSN 11 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 35
+duplicate2
+
+TS 4 CS3 DL DATA TFI 0 BSN 12 FBI 0 
+fn_same_bsn 17381 fn_last_bsn 35 delta_bsn 1 old_len 0
+ bsn 3 
+lime 0
+ bsn 4 null
+ bsn 5 
+lime 0
+
+lime 1
+ bsn 6 
+lime 0
+ bsn 7  bsn 8 null
+ bsn 9 
+lime 0
+ bsn 10 
+lime 0
+ bsn 11 
+lime 0
+ bsn 12 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS3 DL DATA TFI 0 BSN 12 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 35
+duplicate2
+
+TS 4 CS3 DL DATA TFI 0 BSN 12 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 35
+duplicate2
+
+TS 4 CS3 DL DATA TFI 0 BSN 12 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 35
+duplicate2
+
+TS 4 CS3 DL DATA TFI 0 BSN 12 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 35
+duplicate2
+
+TS 4 CS3 DL DATA TFI 0 BSN 12 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 35
+duplicate2
+
+TS 4 CS3 DL DATA TFI 0 BSN 13 FBI 0 
+fn_same_bsn 17441 fn_last_bsn 39 delta_bsn 1 old_len 0
+ bsn 3 
+lime 0
+ bsn 4 null
+ bsn 5 
+lime 0
+
+lime 1
+ bsn 6 
+lime 0
+ bsn 7  bsn 8 null
+ bsn 9 
+lime 0
+ bsn 10 
+lime 0
+ bsn 11 
+lime 0
+ bsn 12 
+lime 0
+ bsn 13 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS3 DL DATA TFI 0 BSN 13 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 35
+duplicate2
+
+TS 4 CS3 DL DATA TFI 0 BSN 13 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 35
+duplicate2
+
+TS 4 CS3 DL DATA TFI 0 BSN 13 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 35
+duplicate2
+
+TS 4 CS3 DL DATA TFI 0 BSN 13 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 35
+duplicate2
+
+TS 4 CS3 DL DATA TFI 0 BSN 13 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 35
+duplicate2
+
+TS 4 CS3 DL DATA TFI 0 BSN 14 FBI 0 
+fn_same_bsn 17498 fn_last_bsn 35 delta_bsn 1 old_len 0
+ bsn 3 
+lime 0
+ bsn 4 null
+ bsn 5 
+lime 0
+
+lime 1
+ bsn 6 
+lime 0
+ bsn 7  bsn 8 null
+ bsn 9 
+lime 0
+ bsn 10 
+lime 0
+ bsn 11 
+lime 0
+ bsn 12 
+lime 0
+ bsn 13 
+lime 0
+ bsn 14 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS3 DL DATA TFI 0 BSN 14 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 35
+duplicate2
+
+TS 4 CS3 DL DATA TFI 0 BSN 14 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 35
+duplicate2
+
+TS 4 CS3 DL DATA TFI 0 BSN 14 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 35
+duplicate2
+
+TS 4 CS3 DL DATA TFI 0 BSN 14 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 35
+duplicate2
+
+TS 4 CS3 DL DATA TFI 0 BSN 14 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 35
+duplicate2
+
+TS 4 CS3 DL DATA TFI 0 BSN 15 FBI 0 
+fn_same_bsn 17558 fn_last_bsn 39 delta_bsn 1 old_len 0
+ bsn 3 
+lime 0
+ bsn 4 null
+ bsn 5 
+lime 0
+
+lime 1
+ bsn 6 
+lime 0
+ bsn 7  bsn 8 null
+ bsn 9 
+lime 0
+ bsn 10 
+lime 0
+ bsn 11 
+lime 0
+ bsn 12 
+lime 0
+ bsn 13 
+lime 0
+ bsn 14 
+lime 0
+ bsn 15 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS3 DL DATA TFI 0 BSN 15 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 35
+duplicate2
+
+TS 4 CS3 DL DATA TFI 0 BSN 15 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 35
+duplicate2
+
+TS 4 CS3 DL DATA TFI 0 BSN 15 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 35
+duplicate2
+
+TS 4 CS3 DL DATA TFI 0 BSN 15 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 35
+duplicate2
+
+TS 4 CS3 DL DATA TFI 0 BSN 15 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 35
+duplicate2
+
+TS 4 CS3 DL DATA TFI 0 BSN 16 FBI 1 
+fn_same_bsn 18005 fn_last_bsn 425 delta_bsn 1 old_len 0
+ bsn 3 
+lime 0
+ bsn 4 null
+ bsn 5 
+lime 0
+
+lime 1
+ bsn 6 
+lime 0
+ bsn 7  bsn 8 null
+ bsn 9 
+lime 0
+ bsn 10 
+lime 0
+ bsn 11 
+lime 0
+ bsn 12 
+lime 0
+ bsn 13 
+lime 0
+ bsn 14 
+lime 0
+ bsn 15 
+lime 0
+ bsn 16 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS3 DL DATA TFI 0 BSN 16 FBI 1 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 35
+duplicate2
+
+TS 4 CS3 DL DATA TFI 0 BSN 16 FBI 1 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 35
+duplicate2
+
+TS 4 CS3 DL DATA TFI 0 BSN 16 FBI 1 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 35
+duplicate2
+
+TS 4 CS3 DL DATA TFI 0 BSN 16 FBI 1 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 35
+duplicate2
+
+TS 4 CS3 DL DATA TFI 0 BSN 16 FBI 1 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 35
+duplicate2
+
+TS 4 CS3 DL DATA TFI 1 BSN 1 FBI 0 
+fn_same_bsn 18109 fn_last_bsn 18109 delta_bsn 1 old_len 0
+clearing TBF 2, first 0 last 0
+new TBF, starting from 1
+ bsn 1 
+TS 4 CS3 DL DATA TFI 1 BSN 0 FBI 0 
+fn_same_bsn 18113 fn_last_bsn 4 delta_bsn -1 old_len 0
+duplicate
+
+TS 4 CS3 DL DATA TFI 1 BSN 2 FBI 0 
+fn_same_bsn 18117 fn_last_bsn 8 delta_bsn 1 old_len 0
+ bsn 1  bsn 2 
+lime 0
+end of message reached
+MSG: 26818000010001000000000277730367746d046163657203636f6d0000010001c00c00010001000000070004c76b780a5a9f7f
+
+lime 1
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS3 DL DATA TFI 1 BSN 1 FBI 0 
+fn_same_bsn 13 fn_last_bsn 5 delta_bsn -1 old_len 36
+duplicate2
+
+TS 4 CS3 DL DATA TFI 1 BSN 0 FBI 0 
+fn_same_bsn 13 fn_last_bsn 9 delta_bsn -2 old_len 0
+duplicate2
+
+TS 4 CS3 DL DATA TFI 1 BSN 2 FBI 0 
+fn_same_bsn 13 fn_last_bsn 13 delta_bsn 0 old_len 34
+duplicate2
+
+TS 4 CS3 DL DATA TFI 1 BSN 1 FBI 0 
+fn_same_bsn 13 fn_last_bsn 5 delta_bsn -1 old_len 36
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 3 FBI 0 
+fn_same_bsn 18174 fn_last_bsn 44 delta_bsn 1 old_len 0
+ bsn 2 
+lime 0
+
+lime 1
+ bsn 3 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS4 DL DATA TFI 1 BSN 3 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 3 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 3 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 3 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 3 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 3 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 3 FBI 0 
+fn_same_bsn 8 fn_last_bsn 8 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 3 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 3 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 3 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 3 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 3 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 5 FBI 0 
+fn_same_bsn 18234 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 3 
+lime 0
+ bsn 4 null
+ bsn 5 
+lime 0
+end of message reached
+MSG: 64010303000101080a2df10b9001cbcbdf04020000d10cd2
+
+lime 1
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS4 DL DATA TFI 1 BSN 5 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 48
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 5 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 48
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 5 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 48
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 5 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 48
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 5 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 48
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 6 FBI 0 
+fn_same_bsn 18286 fn_last_bsn 30 delta_bsn 1 old_len 0
+ bsn 3 
+lime 0
+ bsn 4 null
+ bsn 5 
+lime 0
+
+lime 1
+ bsn 6 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS4 DL DATA TFI 1 BSN 6 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 6 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 6 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 6 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 6 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 7 FBI 0 
+fn_same_bsn 18343 fn_last_bsn 35 delta_bsn 1 old_len 0
+ bsn 3 
+lime 0
+ bsn 4 null
+ bsn 5 
+lime 0
+
+lime 1
+ bsn 6 
+lime 0
+ bsn 7 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS4 DL DATA TFI 1 BSN 7 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 7 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 7 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 7 FBI 0 
+fn_same_bsn 8 fn_last_bsn 8 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 9 FBI 0 
+fn_same_bsn 18395 fn_last_bsn 31 delta_bsn 2 old_len 0
+ bsn 3 
+lime 0
+ bsn 4 null
+ bsn 5 
+lime 0
+
+lime 1
+ bsn 6 
+lime 0
+ bsn 7 
+lime 0
+ bsn 8 null
+ bsn 9 
+lime 0
+end of message reached
+MSG: 0a2df10e5d01cbcc1afd50b8
+
+TS 4 CS4 DL DATA TFI 1 BSN 11 FBI 0 
+fn_same_bsn 18399 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 9 
+lime 0
+ bsn 10 null
+ bsn 11 
+TS 4 CS4 DL DATA TFI 1 BSN 13 FBI 0 
+fn_same_bsn 18403 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 9 
+lime 0
+ bsn 10 null
+ bsn 11  bsn 12 null
+ bsn 13 
+TS 4 CS4 DL DATA TFI 1 BSN 15 FBI 0 
+fn_same_bsn 18408 fn_last_bsn 5 delta_bsn 2 old_len 0
+ bsn 9 
+lime 0
+ bsn 10 null
+ bsn 11  bsn 12 null
+ bsn 13  bsn 14 null
+ bsn 15 
+TS 4 CS4 DL DATA TFI 1 BSN 17 FBI 0 
+fn_same_bsn 18412 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 9 
+lime 0
+ bsn 10 null
+ bsn 11  bsn 12 null
+ bsn 13  bsn 14 null
+ bsn 15  bsn 16 null
+ bsn 17 
+TS 4 CS4 DL DATA TFI 1 BSN 19 FBI 0 
+fn_same_bsn 18416 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 9 
+lime 0
+ bsn 10 null
+ bsn 11  bsn 12 null
+ bsn 13  bsn 14 null
+ bsn 15  bsn 16 null
+ bsn 17  bsn 18 null
+ bsn 19 
+lime 0
+end of message reached
+MSG: 696c61626c653c2f68323e0d0a3c6872ae2662
+
+TS 4 CS4 DL DATA TFI 1 BSN 21 FBI 0 
+fn_same_bsn 18421 fn_last_bsn 5 delta_bsn 2 old_len 0
+ bsn 19 
+lime 0
+ bsn 20 null
+ bsn 21 
+TS 4 CS4 DL DATA TFI 1 BSN 8 FBI 0 
+fn_same_bsn 18425 fn_last_bsn 4 delta_bsn -13 old_len 0
+duplicate
+
+TS 4 CS4 DL DATA TFI 1 BSN 10 FBI 0 
+fn_same_bsn 18429 fn_last_bsn 8 delta_bsn -11 old_len 0
+duplicate
+
+TS 4 CS4 DL DATA TFI 1 BSN 12 FBI 0 
+fn_same_bsn 18434 fn_last_bsn 13 delta_bsn -9 old_len 0
+duplicate
+
+TS 4 CS4 DL DATA TFI 1 BSN 14 FBI 0 
+fn_same_bsn 18438 fn_last_bsn 17 delta_bsn -7 old_len 0
+duplicate
+
+TS 4 CS4 DL DATA TFI 1 BSN 16 FBI 0 
+fn_same_bsn 18442 fn_last_bsn 21 delta_bsn -5 old_len 0
+duplicate
+
+TS 4 CS4 DL DATA TFI 1 BSN 18 FBI 0 
+fn_same_bsn 18447 fn_last_bsn 26 delta_bsn -3 old_len 0
+duplicate
+
+TS 4 CS4 DL DATA TFI 1 BSN 20 FBI 0 
+fn_same_bsn 18451 fn_last_bsn 30 delta_bsn -1 old_len 0
+duplicate
+
+TS 4 CS4 DL DATA TFI 1 BSN 22 FBI 0 
+fn_same_bsn 18455 fn_last_bsn 34 delta_bsn 1 old_len 0
+ bsn 19 
+lime 0
+ bsn 20 null
+ bsn 21  bsn 22 
+lime 0
+end of message reached
+MSG: c015650000044500003406b94000ee0685e8c76b780ac0a800040050db85d1b579a8c324e273801112058d9300000101080a2df10e5e01cbcc1a1347bb
+
+lime 1
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS4 DL DATA TFI 1 BSN 9 FBI 0 
+fn_same_bsn 65 fn_last_bsn 5 delta_bsn -13 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 11 FBI 0 
+fn_same_bsn 65 fn_last_bsn 9 delta_bsn -11 old_len 50
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 13 FBI 0 
+fn_same_bsn 65 fn_last_bsn 13 delta_bsn -9 old_len 50
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 22 FBI 0 
+fn_same_bsn 22 fn_last_bsn 22 delta_bsn 0 old_len 48
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 22 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 48
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 22 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 48
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 22 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 48
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 22 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 48
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 22 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 48
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 22 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 48
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 22 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 48
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 22 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 48
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 22 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 48
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 22 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 48
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 23 FBI 0 
+fn_same_bsn 18559 fn_last_bsn 39 delta_bsn 1 old_len 0
+ bsn 19 
+lime 0
+ bsn 20 null
+ bsn 21  bsn 22 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 23 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS4 DL DATA TFI 1 BSN 23 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 23 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 23 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 23 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 23 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 24 FBI 0 
+fn_same_bsn 18616 fn_last_bsn 35 delta_bsn 1 old_len 0
+ bsn 19 
+lime 0
+ bsn 20 null
+ bsn 21  bsn 22 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 23 
+lime 0
+ bsn 24 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS4 DL DATA TFI 1 BSN 24 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 24 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 24 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 24 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 24 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 25 FBI 0 
+fn_same_bsn 18676 fn_last_bsn 39 delta_bsn 1 old_len 0
+ bsn 19 
+lime 0
+ bsn 20 null
+ bsn 21  bsn 22 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 23 
+lime 0
+ bsn 24 
+lime 0
+ bsn 25 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS4 DL DATA TFI 1 BSN 25 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 25 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 25 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 25 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 25 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 26 FBI 0 
+fn_same_bsn 18733 fn_last_bsn 35 delta_bsn 1 old_len 0
+ bsn 19 
+lime 0
+ bsn 20 null
+ bsn 21  bsn 22 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 23 
+lime 0
+ bsn 24 
+lime 0
+ bsn 25 
+lime 0
+ bsn 26 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS4 DL DATA TFI 1 BSN 26 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 26 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 26 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 26 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 26 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 27 FBI 0 
+fn_same_bsn 18793 fn_last_bsn 39 delta_bsn 1 old_len 0
+ bsn 19 
+lime 0
+ bsn 20 null
+ bsn 21  bsn 22 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 23 
+lime 0
+ bsn 24 
+lime 0
+ bsn 25 
+lime 0
+ bsn 26 
+lime 0
+ bsn 27 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS4 DL DATA TFI 1 BSN 27 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 27 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 27 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 27 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 27 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 28 FBI 0 
+fn_same_bsn 18850 fn_last_bsn 35 delta_bsn 1 old_len 0
+ bsn 19 
+lime 0
+ bsn 20 null
+ bsn 21  bsn 22 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 23 
+lime 0
+ bsn 24 
+lime 0
+ bsn 25 
+lime 0
+ bsn 26 
+lime 0
+ bsn 27 
+lime 0
+ bsn 28 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS4 DL DATA TFI 1 BSN 28 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 28 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 28 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 28 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 28 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 29 FBI 1 
+fn_same_bsn 19296 fn_last_bsn 425 delta_bsn 1 old_len 0
+ bsn 19 
+lime 0
+ bsn 20 null
+ bsn 21  bsn 22 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 23 
+lime 0
+ bsn 24 
+lime 0
+ bsn 25 
+lime 0
+ bsn 26 
+lime 0
+ bsn 27 
+lime 0
+ bsn 28 
+lime 0
+ bsn 29 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS4 DL DATA TFI 1 BSN 29 FBI 1 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 29 FBI 1 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 29 FBI 1 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 29 FBI 1 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 1 BSN 29 FBI 1 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 1 FBI 0 
+fn_same_bsn 2409 fn_last_bsn 1374 delta_bsn -15 old_len 29
+duplicate
+
+TS 4 CS4 DL DATA TFI 0 BSN 3 FBI 0 
+fn_same_bsn 2318 fn_last_bsn 1378 delta_bsn -13 old_len 29
+duplicate
+
+TS 4 CS4 DL DATA TFI 0 BSN 5 FBI 0 
+fn_same_bsn 2297 fn_last_bsn 1383 delta_bsn -11 old_len 28
+duplicate
+
+TS 4 CS4 DL DATA TFI 0 BSN 0 FBI 0 
+fn_same_bsn 2466 fn_last_bsn 1387 delta_bsn -16 old_len 28
+duplicate
+
+TS 4 CS4 DL DATA TFI 0 BSN 2 FBI 0 
+fn_same_bsn 2383 fn_last_bsn 1391 delta_bsn -14 old_len 28
+duplicate
+
+TS 4 CS4 DL DATA TFI 0 BSN 4 FBI 0 
+fn_same_bsn 19422 fn_last_bsn 1396 delta_bsn -12 old_len 0
+duplicate
+
+TS 4 CS4 DL DATA TFI 0 BSN 6 FBI 0 
+fn_same_bsn 2262 fn_last_bsn 1400 delta_bsn -10 old_len 35
+duplicate
+
+TS 4 CS4 DL DATA TFI 0 BSN 1 FBI 0 
+fn_same_bsn 30 fn_last_bsn 1404 delta_bsn -15 old_len 29
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 3 FBI 0 
+fn_same_bsn 31 fn_last_bsn 1409 delta_bsn -13 old_len 29
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 7 FBI 0 
+fn_same_bsn 2275 fn_last_bsn 1448 delta_bsn -9 old_len 36
+duplicate
+
+TS 4 CS4 DL DATA TFI 0 BSN 7 FBI 0 
+fn_same_bsn 4 fn_last_bsn 1452 delta_bsn -9 old_len 36
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 7 FBI 0 
+fn_same_bsn 4 fn_last_bsn 1456 delta_bsn -9 old_len 36
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 7 FBI 0 
+fn_same_bsn 5 fn_last_bsn 1461 delta_bsn -9 old_len 36
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 7 FBI 0 
+fn_same_bsn 4 fn_last_bsn 1465 delta_bsn -9 old_len 36
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 7 FBI 0 
+fn_same_bsn 4 fn_last_bsn 1469 delta_bsn -9 old_len 36
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 9 FBI 0 
+fn_same_bsn 2275 fn_last_bsn 1474 delta_bsn -7 old_len 35
+duplicate
+
+TS 4 CS4 DL DATA TFI 0 BSN 8 FBI 0 
+fn_same_bsn 19504 fn_last_bsn 1478 delta_bsn -8 old_len 0
+duplicate
+
+TS 4 CS4 DL DATA TFI 0 BSN 10 FBI 0 
+fn_same_bsn 2223 fn_last_bsn 1482 delta_bsn -6 old_len 35
+duplicate
+
+TS 4 CS4 DL DATA TFI 0 BSN 9 FBI 0 
+fn_same_bsn 13 fn_last_bsn 1487 delta_bsn -7 old_len 35
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 11 FBI 0 
+fn_same_bsn 2171 fn_last_bsn 1491 delta_bsn -5 old_len 35
+duplicate
+
+TS 4 CS4 DL DATA TFI 0 BSN 13 FBI 0 
+fn_same_bsn 2058 fn_last_bsn 1495 delta_bsn -3 old_len 35
+duplicate
+
+TS 4 CS4 DL DATA TFI 0 BSN 15 FBI 0 
+fn_same_bsn 1946 fn_last_bsn 1500 delta_bsn -1 old_len 35
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 17 FBI 0 
+fn_same_bsn 19530 fn_last_bsn 1504 delta_bsn 1 old_len 0
+ bsn 3 
+lime 0
+ bsn 4 null
+ bsn 5 
+lime 0
+
+lime 1
+ bsn 6 
+lime 0
+ bsn 7  bsn 8 null
+ bsn 9 
+lime 0
+ bsn 10 
+lime 0
+ bsn 11 
+lime 0
+ bsn 12 old segment
+ bsn 13 
+lime 0
+ bsn 14 old segment
+ bsn 15 
+lime 0
+ bsn 16 
+lime 0
+ bsn 17 
+lime 0
+end of message reached
+MSG: b40402080aeee79bbe01cbce350103030706c7b8
+
+TS 4 CS4 DL DATA TFI 0 BSN 11 FBI 0 
+fn_same_bsn 17 fn_last_bsn 4 delta_bsn -6 old_len 35
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 13 FBI 0 
+fn_same_bsn 18 fn_last_bsn 9 delta_bsn -4 old_len 35
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 16 FBI 0 
+fn_same_bsn 1521 fn_last_bsn 17 delta_bsn -1 old_len 35
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 18 FBI 0 
+fn_same_bsn 19552 fn_last_bsn 22 delta_bsn 1 old_len 0
+ bsn 17 
+lime 0
+ bsn 18 
+lime 0
+end of message reached
+MSG: 03c03d6500000e4500003c000040003206359e57fafa77c0a8000401bb95e64c065295b7e109dba0126e004ec700000204058c0402080a163d99fb01cbce330103030804ed0d
+
+lime 1
+end of message reached
+MSG: 43c0012b2b2b2b
+
+TS 4 CS4 DL DATA TFI 0 BSN 20 FBI 0 
+fn_same_bsn 19556 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 18 
+lime 0
+
+lime 1
+ bsn 19 null
+ bsn 20 
+lime 0
+end of message reached
+MSG: b40402080aeee79bfc01cbce3501030307a1edee
+
+TS 4 CS4 DL DATA TFI 0 BSN 19 FBI 0 
+fn_same_bsn 19560 fn_last_bsn 4 delta_bsn -1 old_len 0
+duplicate
+
+TS 4 CS4 DL DATA TFI 0 BSN 21 FBI 0 
+fn_same_bsn 19565 fn_last_bsn 9 delta_bsn 1 old_len 0
+ bsn 20 
+lime 0
+ bsn 21 
+lime 0
+end of message reached
+MSG: 03c0456500001045000038000040002f06df04364c75c3c0a8000401bbb5d384caa283890c2130901245eafe620000020423010402080a1bdb18a601cbce42f8f843
+
+lime 1
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b
+
+TS 4 CS4 DL DATA TFI 0 BSN 20 FBI 0 
+fn_same_bsn 13 fn_last_bsn 4 delta_bsn -1 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 19 FBI 0 
+fn_same_bsn 13 fn_last_bsn 8 delta_bsn -2 old_len 0
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 21 FBI 0 
+fn_same_bsn 13 fn_last_bsn 13 delta_bsn 0 old_len 48
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 22 FBI 0 
+fn_same_bsn 19608 fn_last_bsn 30 delta_bsn 1 old_len 0
+ bsn 21 
+lime 0
+
+lime 1
+ bsn 22 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS4 DL DATA TFI 0 BSN 22 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 22 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 22 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 22 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 22 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 23 FBI 0 
+fn_same_bsn 19669 fn_last_bsn 39 delta_bsn 1 old_len 0
+ bsn 22 
+lime 0
+ bsn 23 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS4 DL DATA TFI 0 BSN 23 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 23 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 23 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 23 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 23 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 25 FBI 0 
+fn_same_bsn 19695 fn_last_bsn 5 delta_bsn 2 old_len 0
+ bsn 23 
+lime 0
+ bsn 24 null
+ bsn 25 
+lime 0
+end of message reached
+MSG: 0a163d9a2801cbce5fe94175
+
+TS 4 CS4 DL DATA TFI 0 BSN 27 FBI 0 
+fn_same_bsn 19699 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 25 
+lime 0
+ bsn 26 null
+ bsn 27 
+TS 4 CS4 DL DATA TFI 0 BSN 29 FBI 0 
+fn_same_bsn 19703 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 25 
+lime 0
+ bsn 26 null
+ bsn 27  bsn 28 null
+ bsn 29 
+lime 0
+end of message reached
+MSG: 34e27903be69e04f8071066d74967e6bf6b6a56b6bfdf5fa35
+
+lime 1
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS4 DL DATA TFI 0 BSN 25 FBI 0 
+fn_same_bsn 13 fn_last_bsn 5 delta_bsn -4 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 27 FBI 0 
+fn_same_bsn 13 fn_last_bsn 9 delta_bsn -2 old_len 50
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 29 FBI 0 
+fn_same_bsn 13 fn_last_bsn 13 delta_bsn 0 old_len 48
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 25 FBI 0 
+fn_same_bsn 13 fn_last_bsn 5 delta_bsn -4 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 27 FBI 0 
+fn_same_bsn 13 fn_last_bsn 9 delta_bsn -2 old_len 50
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 29 FBI 0 
+fn_same_bsn 13 fn_last_bsn 13 delta_bsn 0 old_len 48
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 26 FBI 0 
+fn_same_bsn 19738 fn_last_bsn 9 delta_bsn -3 old_len 0
+duplicate
+
+TS 4 CS4 DL DATA TFI 0 BSN 28 FBI 0 
+fn_same_bsn 19742 fn_last_bsn 13 delta_bsn -1 old_len 0
+duplicate
+
+TS 4 CS4 DL DATA TFI 0 BSN 24 FBI 0 
+fn_same_bsn 19747 fn_last_bsn 18 delta_bsn -5 old_len 0
+duplicate
+
+TS 4 CS4 DL DATA TFI 0 BSN 28 FBI 0 
+fn_same_bsn 13 fn_last_bsn 26 delta_bsn -1 old_len 0
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 24 FBI 0 
+fn_same_bsn 13 fn_last_bsn 31 delta_bsn -5 old_len 0
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 31 FBI 0 
+fn_same_bsn 19773 fn_last_bsn 44 delta_bsn 2 old_len 0
+ bsn 25 
+lime 0
+ bsn 26 null
+ bsn 27  bsn 28 null
+ bsn 29 
+lime 0
+
+lime 1
+ bsn 30 null
+ bsn 31 
+lime 0
+end of message reached
+MSG: 8c0402080a1639ca4501cbce3301030308e9532c
+
+lime 1
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS4 DL DATA TFI 0 BSN 33 FBI 0 
+fn_same_bsn 19777 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 25 
+lime 0
+ bsn 26 null
+ bsn 27  bsn 28 null
+ bsn 29 
+lime 0
+
+lime 1
+ bsn 30 null
+ bsn 31 
+lime 0
+
+lime 1
+ bsn 32 null
+ bsn 33 
+lime 0
+end of message reached
+MSG: 0a163d996401cbce603a0eaa
+
+TS 4 CS4 DL DATA TFI 0 BSN 35 FBI 0 
+fn_same_bsn 19781 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 33 
+lime 0
+ bsn 34 null
+ bsn 35 
+TS 4 CS4 DL DATA TFI 0 BSN 37 FBI 0 
+fn_same_bsn 19786 fn_last_bsn 5 delta_bsn 2 old_len 0
+ bsn 33 
+lime 0
+ bsn 34 null
+ bsn 35  bsn 36 null
+ bsn 37 
+lime 0
+end of message reached
+MSG: 555117cafb1754b8f4c55e19a4ac7c2e7ad6797c0eb8aa1f9b
+
+TS 4 CS4 DL DATA TFI 0 BSN 39 FBI 0 
+fn_same_bsn 19790 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 37 
+lime 0
+ bsn 38 null
+ bsn 39 
+TS 4 CS4 DL DATA TFI 0 BSN 30 FBI 0 
+fn_same_bsn 19794 fn_last_bsn 4 delta_bsn -9 old_len 0
+duplicate
+
+TS 4 CS4 DL DATA TFI 0 BSN 35 FBI 0 
+fn_same_bsn 18 fn_last_bsn 9 delta_bsn -4 old_len 50
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 37 FBI 0 
+fn_same_bsn 17 fn_last_bsn 13 delta_bsn -2 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 39 FBI 0 
+fn_same_bsn 17 fn_last_bsn 17 delta_bsn 0 old_len 50
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 34 FBI 0 
+fn_same_bsn 19812 fn_last_bsn 5 delta_bsn -5 old_len 0
+duplicate
+
+TS 4 CS4 DL DATA TFI 0 BSN 36 FBI 0 
+fn_same_bsn 19816 fn_last_bsn 9 delta_bsn -3 old_len 0
+duplicate
+
+TS 4 CS4 DL DATA TFI 0 BSN 38 FBI 0 
+fn_same_bsn 19820 fn_last_bsn 13 delta_bsn -1 old_len 0
+duplicate
+
+TS 4 CS4 DL DATA TFI 0 BSN 42 FBI 0 
+fn_same_bsn 19825 fn_last_bsn 18 delta_bsn 3 old_len 0
+ bsn 37 
+lime 0
+ bsn 38 null
+ bsn 39  bsn 40 null
+ bsn 41 null
+ bsn 42 
+lime 0
+end of message reached
+MSG: 8c0402080a0d9c84ec01cbce3301030308ffb276
+
+TS 4 CS4 DL DATA TFI 0 BSN 41 FBI 0 
+fn_same_bsn 19829 fn_last_bsn 4 delta_bsn -1 old_len 0
+duplicate
+
+TS 4 CS4 DL DATA TFI 0 BSN 44 FBI 0 
+fn_same_bsn 19838 fn_last_bsn 13 delta_bsn 2 old_len 0
+ bsn 42 
+lime 0
+ bsn 43 null
+ bsn 44 
+TS 4 CS4 DL DATA TFI 0 BSN 41 FBI 0 
+fn_same_bsn 13 fn_last_bsn 4 delta_bsn -3 old_len 0
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 43 FBI 0 
+fn_same_bsn 19846 fn_last_bsn 8 delta_bsn -1 old_len 0
+duplicate
+
+TS 4 CS4 DL DATA TFI 0 BSN 45 FBI 0 
+fn_same_bsn 19851 fn_last_bsn 13 delta_bsn 1 old_len 0
+ bsn 42 
+lime 0
+ bsn 43 null
+ bsn 44  bsn 45 
+lime 0
+end of message reached
+MSG: 03c06d6500001a4500003c0000400034063d045fd3e938c0a800040050e05adb5fece59e0ae323a01238907b6a0000020405b40402080aeee7a13501cbce350103030754e3ff
+
+lime 1
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS4 DL DATA TFI 0 BSN 47 FBI 0 
+fn_same_bsn 19855 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 42 
+lime 0
+ bsn 43 null
+ bsn 44  bsn 45 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 46 null
+ bsn 47 
+lime 0
+end of message reached
+MSG: 0a1639ca9d01cbce68dafaea
+
+TS 4 CS4 DL DATA TFI 0 BSN 49 FBI 0 
+fn_same_bsn 19859 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 47 
+lime 0
+ bsn 48 null
+ bsn 49 
+TS 4 CS4 DL DATA TFI 0 BSN 51 FBI 0 
+fn_same_bsn 19864 fn_last_bsn 5 delta_bsn 2 old_len 0
+ bsn 47 
+lime 0
+ bsn 48 null
+ bsn 49  bsn 50 null
+ bsn 51 
+lime 0
+end of message reached
+MSG: 5e8ae919aa7cd608b26f7b8864c5b2498d8e2687925c30fb00
+
+lime 1
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS4 DL DATA TFI 0 BSN 45 FBI 0 
+fn_same_bsn 17 fn_last_bsn 4 delta_bsn -6 old_len 48
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 47 FBI 0 
+fn_same_bsn 17 fn_last_bsn 8 delta_bsn -4 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 49 FBI 0 
+fn_same_bsn 18 fn_last_bsn 13 delta_bsn -2 old_len 50
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 51 FBI 0 
+fn_same_bsn 17 fn_last_bsn 17 delta_bsn 0 old_len 48
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 49 FBI 0 
+fn_same_bsn 8 fn_last_bsn 4 delta_bsn -2 old_len 50
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 51 FBI 0 
+fn_same_bsn 9 fn_last_bsn 9 delta_bsn 0 old_len 48
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 49 FBI 0 
+fn_same_bsn 9 fn_last_bsn 4 delta_bsn -2 old_len 50
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 51 FBI 0 
+fn_same_bsn 8 fn_last_bsn 8 delta_bsn 0 old_len 48
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 53 FBI 0 
+fn_same_bsn 19907 fn_last_bsn 9 delta_bsn 2 old_len 0
+ bsn 47 
+lime 0
+ bsn 48 null
+ bsn 49  bsn 50 null
+ bsn 51 
+lime 0
+
+lime 1
+ bsn 52 null
+ bsn 53 
+lime 0
+end of message reached
+MSG: 0a1639c92a01cbce686b9012
+
+TS 4 CS4 DL DATA TFI 0 BSN 55 FBI 0 
+fn_same_bsn 19911 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 53 
+lime 0
+ bsn 54 null
+ bsn 55 
+TS 4 CS4 DL DATA TFI 0 BSN 57 FBI 0 
+fn_same_bsn 19916 fn_last_bsn 5 delta_bsn 2 old_len 0
+ bsn 53 
+lime 0
+ bsn 54 null
+ bsn 55  bsn 56 null
+ bsn 57 
+lime 0
+end of message reached
+MSG: b8bd67b7679737b1c39971d041f73e4bbd717654a340ef7aee
+
+lime 1
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS4 DL DATA TFI 0 BSN 53 FBI 0 
+fn_same_bsn 13 fn_last_bsn 4 delta_bsn -4 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 55 FBI 0 
+fn_same_bsn 13 fn_last_bsn 8 delta_bsn -2 old_len 50
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 57 FBI 0 
+fn_same_bsn 13 fn_last_bsn 13 delta_bsn 0 old_len 48
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 54 FBI 0 
+fn_same_bsn 19937 fn_last_bsn 8 delta_bsn -3 old_len 0
+duplicate
+
+TS 4 CS4 DL DATA TFI 0 BSN 58 FBI 0 
+fn_same_bsn 19942 fn_last_bsn 13 delta_bsn 1 old_len 0
+ bsn 53 
+lime 0
+ bsn 54 null
+ bsn 55  bsn 56 null
+ bsn 57 
+lime 0
+
+lime 1
+ bsn 58 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS4 DL DATA TFI 0 BSN 58 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 58 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 58 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 58 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 58 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 58 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 60 FBI 0 
+fn_same_bsn 19972 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 53 
+lime 0
+ bsn 54 null
+ bsn 55  bsn 56 null
+ bsn 57 
+lime 0
+
+lime 1
+ bsn 58 
+lime 0
+ bsn 59 null
+ bsn 60 
+lime 0
+end of message reached
+MSG: 0a0d9c859b01cbce6b917ee3
+
+TS 4 CS4 DL DATA TFI 0 BSN 62 FBI 0 
+fn_same_bsn 19976 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 60 
+lime 0
+ bsn 61 null
+ bsn 62 
+TS 4 CS4 DL DATA TFI 0 BSN 64 FBI 0 
+fn_same_bsn 19981 fn_last_bsn 5 delta_bsn 2 old_len 0
+ bsn 60 
+lime 0
+ bsn 61 null
+ bsn 62  bsn 63 null
+ bsn 64 
+lime 0
+end of message reached
+MSG: f1055b922d58930fad49f9855f360b6a8edbc53e5af6808100
+
+lime 1
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS4 DL DATA TFI 0 BSN 66 FBI 0 
+fn_same_bsn 19985 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 60 
+lime 0
+ bsn 61 null
+ bsn 62  bsn 63 null
+ bsn 64 
+lime 0
+
+lime 1
+ bsn 65 null
+ bsn 66 
+TS 4 CS4 DL DATA TFI 0 BSN 68 FBI 0 
+fn_same_bsn 19989 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 60 
+lime 0
+ bsn 61 null
+ bsn 62  bsn 63 null
+ bsn 64 
+lime 0
+
+lime 1
+ bsn 65 null
+ bsn 66  bsn 67 null
+ bsn 68 
+TS 4 CS4 DL DATA TFI 0 BSN 58 FBI 0 
+fn_same_bsn 26 fn_last_bsn 5 delta_bsn -10 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 60 FBI 0 
+fn_same_bsn 26 fn_last_bsn 9 delta_bsn -8 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 66 FBI 0 
+fn_same_bsn 17 fn_last_bsn 13 delta_bsn -2 old_len 50
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 68 FBI 0 
+fn_same_bsn 18 fn_last_bsn 18 delta_bsn 0 old_len 50
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 65 FBI 0 
+fn_same_bsn 20011 fn_last_bsn 4 delta_bsn -3 old_len 0
+duplicate
+
+TS 4 CS4 DL DATA TFI 0 BSN 67 FBI 0 
+fn_same_bsn 20015 fn_last_bsn 8 delta_bsn -1 old_len 0
+duplicate
+
+TS 4 CS4 DL DATA TFI 0 BSN 69 FBI 0 
+fn_same_bsn 20020 fn_last_bsn 13 delta_bsn 1 old_len 0
+ bsn 60 
+lime 0
+ bsn 61 null
+ bsn 62  bsn 63 null
+ bsn 64 
+lime 0
+
+lime 1
+ bsn 65 null
+ bsn 66  bsn 67 null
+ bsn 68  bsn 69 
+lime 0
+end of message reached
+MSG: 687474702f312e31140303000101160303002896ddbd90638cc55a2a61f5ecb3a75e6441d434e27903be69e04f8071066d74967e6bf6b6a56b6bfd645a6c
+
+lime 1
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS4 DL DATA TFI 0 BSN 66 FBI 0 
+fn_same_bsn 22 fn_last_bsn 4 delta_bsn -3 old_len 50
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 70 FBI 0 
+fn_same_bsn 20028 fn_last_bsn 8 delta_bsn 1 old_len 0
+ bsn 60 
+lime 0
+ bsn 61 null
+ bsn 62  bsn 63 null
+ bsn 64 
+lime 0
+
+lime 1
+ bsn 65 null
+ bsn 66  bsn 67 null
+ bsn 68  bsn 69 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 70 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS4 DL DATA TFI 0 BSN 70 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 70 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 70 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 70 FBI 0 
+fn_same_bsn 9 fn_last_bsn 9 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 72 FBI 0 
+fn_same_bsn 20080 fn_last_bsn 30 delta_bsn 2 old_len 0
+ bsn 60 
+lime 0
+ bsn 61 null
+ bsn 62  bsn 63 null
+ bsn 64 
+lime 0
+
+lime 1
+ bsn 65 null
+ bsn 66  bsn 67 null
+ bsn 68  bsn 69 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 70 
+lime 0
+ bsn 71 null
+ bsn 72 
+lime 0
+end of message reached
+MSG: 0aeee7a5a901cbce6dd5597d
+
+lime 1
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS4 DL DATA TFI 0 BSN 74 FBI 0 
+fn_same_bsn 20085 fn_last_bsn 5 delta_bsn 2 old_len 0
+ bsn 60 
+lime 0
+ bsn 61 null
+ bsn 62  bsn 63 null
+ bsn 64 
+lime 0
+
+lime 1
+ bsn 65 null
+ bsn 66  bsn 67 null
+ bsn 68  bsn 69 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 70 
+lime 0
+ bsn 71 null
+ bsn 72 
+lime 0
+
+lime 1
+ bsn 73 null
+ bsn 74 
+TS 4 CS4 DL DATA TFI 0 BSN 76 FBI 0 
+fn_same_bsn 20089 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 60 
+lime 0
+ bsn 61 null
+ bsn 62  bsn 63 null
+ bsn 64 
+lime 0
+
+lime 1
+ bsn 65 null
+ bsn 66  bsn 67 null
+ bsn 68  bsn 69 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 70 
+lime 0
+ bsn 71 null
+ bsn 72 
+lime 0
+
+lime 1
+ bsn 73 null
+ bsn 74  bsn 75 null
+ bsn 76 
+TS 4 CS4 DL DATA TFI 0 BSN 78 FBI 0 
+fn_same_bsn 20093 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 60 
+lime 0
+ bsn 61 null
+ bsn 62  bsn 63 null
+ bsn 64 
+lime 0
+
+lime 1
+ bsn 65 null
+ bsn 66  bsn 67 null
+ bsn 68  bsn 69 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 70 
+lime 0
+ bsn 71 null
+ bsn 72 
+lime 0
+
+lime 1
+ bsn 73 null
+ bsn 74  bsn 75 null
+ bsn 76  bsn 77 null
+ bsn 78 
+TS 4 CS4 DL DATA TFI 0 BSN 80 FBI 0 
+fn_same_bsn 20098 fn_last_bsn 5 delta_bsn 2 old_len 0
+ bsn 60 
+lime 0
+ bsn 61 null
+ bsn 62  bsn 63 null
+ bsn 64 
+lime 0
+
+lime 1
+ bsn 65 null
+ bsn 66  bsn 67 null
+ bsn 68  bsn 69 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 70 
+lime 0
+ bsn 71 null
+ bsn 72 
+lime 0
+
+lime 1
+ bsn 73 null
+ bsn 74  bsn 75 null
+ bsn 76  bsn 77 null
+ bsn 78  bsn 79 null
+ bsn 80 
+TS 4 CS4 DL DATA TFI 0 BSN 82 FBI 0 
+fn_same_bsn 20102 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 60 
+lime 0
+ bsn 61 null
+ bsn 62  bsn 63 null
+ bsn 64 
+lime 0
+
+lime 1
+ bsn 65 null
+ bsn 66  bsn 67 null
+ bsn 68  bsn 69 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 70 
+lime 0
+ bsn 71 null
+ bsn 72 
+lime 0
+
+lime 1
+ bsn 73 null
+ bsn 74  bsn 75 null
+ bsn 76  bsn 77 null
+ bsn 78  bsn 79 null
+ bsn 80  bsn 81 null
+ bsn 82 
+TS 4 CS4 DL DATA TFI 0 BSN 84 FBI 0 
+fn_same_bsn 20106 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 60 
+lime 0
+ bsn 61 null
+ bsn 62  bsn 63 null
+ bsn 64 
+lime 0
+
+lime 1
+ bsn 65 null
+ bsn 66  bsn 67 null
+ bsn 68  bsn 69 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 70 
+lime 0
+ bsn 71 null
+ bsn 72 
+lime 0
+
+lime 1
+ bsn 73 null
+ bsn 74  bsn 75 null
+ bsn 76  bsn 77 null
+ bsn 78  bsn 79 null
+ bsn 80  bsn 81 null
+ bsn 82  bsn 83 null
+ bsn 84 
+TS 4 CS4 DL DATA TFI 0 BSN 86 FBI 0 
+fn_same_bsn 20111 fn_last_bsn 5 delta_bsn 2 old_len 0
+ bsn 60 
+lime 0
+ bsn 61 null
+ bsn 62  bsn 63 null
+ bsn 64 
+lime 0
+
+lime 1
+ bsn 65 null
+ bsn 66  bsn 67 null
+ bsn 68  bsn 69 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 70 
+lime 0
+ bsn 71 null
+ bsn 72 
+lime 0
+
+lime 1
+ bsn 73 null
+ bsn 74  bsn 75 null
+ bsn 76  bsn 77 null
+ bsn 78  bsn 79 null
+ bsn 80  bsn 81 null
+ bsn 82  bsn 83 null
+ bsn 84  bsn 85 null
+ bsn 86 
+TS 4 CS4 DL DATA TFI 0 BSN 88 FBI 0 
+fn_same_bsn 20115 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 60 
+lime 0
+ bsn 61 null
+ bsn 62  bsn 63 null
+ bsn 64 
+lime 0
+
+lime 1
+ bsn 65 null
+ bsn 66  bsn 67 null
+ bsn 68  bsn 69 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 70 
+lime 0
+ bsn 71 null
+ bsn 72 
+lime 0
+
+lime 1
+ bsn 73 null
+ bsn 74  bsn 75 null
+ bsn 76  bsn 77 null
+ bsn 78  bsn 79 null
+ bsn 80  bsn 81 null
+ bsn 82  bsn 83 null
+ bsn 84  bsn 85 null
+ bsn 86  bsn 87 null
+ bsn 88 
+TS 4 CS4 DL DATA TFI 0 BSN 90 FBI 0 
+fn_same_bsn 20119 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 60 
+lime 0
+ bsn 61 null
+ bsn 62  bsn 63 null
+ bsn 64 
+lime 0
+
+lime 1
+ bsn 65 null
+ bsn 66  bsn 67 null
+ bsn 68  bsn 69 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 70 
+lime 0
+ bsn 71 null
+ bsn 72 
+lime 0
+
+lime 1
+ bsn 73 null
+ bsn 74  bsn 75 null
+ bsn 76  bsn 77 null
+ bsn 78  bsn 79 null
+ bsn 80  bsn 81 null
+ bsn 82  bsn 83 null
+ bsn 84  bsn 85 null
+ bsn 86  bsn 87 null
+ bsn 88  bsn 89 null
+ bsn 90 
+TS 4 CS4 DL DATA TFI 0 BSN 92 FBI 0 
+fn_same_bsn 20124 fn_last_bsn 5 delta_bsn 2 old_len 0
+ bsn 60 
+lime 0
+ bsn 61 null
+ bsn 62  bsn 63 null
+ bsn 64 
+lime 0
+
+lime 1
+ bsn 65 null
+ bsn 66  bsn 67 null
+ bsn 68  bsn 69 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 70 
+lime 0
+ bsn 71 null
+ bsn 72 
+lime 0
+
+lime 1
+ bsn 73 null
+ bsn 74  bsn 75 null
+ bsn 76  bsn 77 null
+ bsn 78  bsn 79 null
+ bsn 80  bsn 81 null
+ bsn 82  bsn 83 null
+ bsn 84  bsn 85 null
+ bsn 86  bsn 87 null
+ bsn 88  bsn 89 null
+ bsn 90  bsn 91 null
+ bsn 92 
+TS 4 CS4 DL DATA TFI 0 BSN 94 FBI 0 
+fn_same_bsn 20128 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 60 
+lime 0
+ bsn 61 null
+ bsn 62  bsn 63 null
+ bsn 64 
+lime 0
+
+lime 1
+ bsn 65 null
+ bsn 66  bsn 67 null
+ bsn 68  bsn 69 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 70 
+lime 0
+ bsn 71 null
+ bsn 72 
+lime 0
+
+lime 1
+ bsn 73 null
+ bsn 74  bsn 75 null
+ bsn 76  bsn 77 null
+ bsn 78  bsn 79 null
+ bsn 80  bsn 81 null
+ bsn 82  bsn 83 null
+ bsn 84  bsn 85 null
+ bsn 86  bsn 87 null
+ bsn 88  bsn 89 null
+ bsn 90  bsn 91 null
+ bsn 92  bsn 93 null
+ bsn 94 
+TS 4 CS4 DL DATA TFI 0 BSN 96 FBI 0 
+fn_same_bsn 20132 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 60 
+lime 0
+ bsn 61 null
+ bsn 62  bsn 63 null
+ bsn 64 
+lime 0
+
+lime 1
+ bsn 65 null
+ bsn 66  bsn 67 null
+ bsn 68  bsn 69 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 70 
+lime 0
+ bsn 71 null
+ bsn 72 
+lime 0
+
+lime 1
+ bsn 73 null
+ bsn 74  bsn 75 null
+ bsn 76  bsn 77 null
+ bsn 78  bsn 79 null
+ bsn 80  bsn 81 null
+ bsn 82  bsn 83 null
+ bsn 84  bsn 85 null
+ bsn 86  bsn 87 null
+ bsn 88  bsn 89 null
+ bsn 90  bsn 91 null
+ bsn 92  bsn 93 null
+ bsn 94  bsn 95 null
+ bsn 96 
+TS 4 CS4 DL DATA TFI 0 BSN 98 FBI 0 
+fn_same_bsn 20137 fn_last_bsn 5 delta_bsn 2 old_len 0
+ bsn 60 
+lime 0
+ bsn 61 null
+ bsn 62  bsn 63 null
+ bsn 64 
+lime 0
+
+lime 1
+ bsn 65 null
+ bsn 66  bsn 67 null
+ bsn 68  bsn 69 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 70 
+lime 0
+ bsn 71 null
+ bsn 72 
+lime 0
+
+lime 1
+ bsn 73 null
+ bsn 74  bsn 75 null
+ bsn 76  bsn 77 null
+ bsn 78  bsn 79 null
+ bsn 80  bsn 81 null
+ bsn 82  bsn 83 null
+ bsn 84  bsn 85 null
+ bsn 86  bsn 87 null
+ bsn 88  bsn 89 null
+ bsn 90  bsn 91 null
+ bsn 92  bsn 93 null
+ bsn 94  bsn 95 null
+ bsn 96  bsn 97 null
+ bsn 98 
+TS 4 CS4 DL DATA TFI 0 BSN 100 FBI 0 
+fn_same_bsn 20141 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 60 
+lime 0
+ bsn 61 null
+ bsn 62  bsn 63 null
+ bsn 64 
+lime 0
+
+lime 1
+ bsn 65 null
+ bsn 66  bsn 67 null
+ bsn 68  bsn 69 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 70 
+lime 0
+ bsn 71 null
+ bsn 72 
+lime 0
+
+lime 1
+ bsn 73 null
+ bsn 74  bsn 75 null
+ bsn 76  bsn 77 null
+ bsn 78  bsn 79 null
+ bsn 80  bsn 81 null
+ bsn 82  bsn 83 null
+ bsn 84  bsn 85 null
+ bsn 86  bsn 87 null
+ bsn 88  bsn 89 null
+ bsn 90  bsn 91 null
+ bsn 92  bsn 93 null
+ bsn 94  bsn 95 null
+ bsn 96  bsn 97 null
+ bsn 98  bsn 99 null
+ bsn 100 
+TS 4 CS4 DL DATA TFI 0 BSN 103 FBI 0 
+fn_same_bsn 20150 fn_last_bsn 9 delta_bsn 3 old_len 0
+ bsn 60 
+lime 0
+ bsn 61 null
+ bsn 62  bsn 63 null
+ bsn 64 
+lime 0
+
+lime 1
+ bsn 65 null
+ bsn 66  bsn 67 null
+ bsn 68  bsn 69 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 70 
+lime 0
+ bsn 71 null
+ bsn 72 
+lime 0
+
+lime 1
+ bsn 73 null
+ bsn 74  bsn 75 null
+ bsn 76  bsn 77 null
+ bsn 78  bsn 79 null
+ bsn 80  bsn 81 null
+ bsn 82  bsn 83 null
+ bsn 84  bsn 85 null
+ bsn 86  bsn 87 null
+ bsn 88  bsn 89 null
+ bsn 90  bsn 91 null
+ bsn 92  bsn 93 null
+ bsn 94  bsn 95 null
+ bsn 96  bsn 97 null
+ bsn 98  bsn 99 null
+ bsn 100  bsn 101 null
+ bsn 102 null
+ bsn 103 
+lime 0
+end of message reached
+MSG: ee0c389b4e15e6e0f8a5d57991a3b726998d0271
+
+lime 1
+end of message reached
+MSG: 03c09d253023e4e2adccdabd57986c3ecc83f8
+
+TS 4 CS4 DL DATA TFI 0 BSN 105 FBI 0 
+fn_same_bsn 20154 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 103 
+lime 0
+
+lime 1
+ bsn 104 null
+ bsn 105 
+TS 4 CS4 DL DATA TFI 0 BSN 107 FBI 0 
+fn_same_bsn 20158 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 103 
+lime 0
+
+lime 1
+ bsn 104 null
+ bsn 105  bsn 106 null
+ bsn 107 
+TS 4 CS4 DL DATA TFI 0 BSN 109 FBI 0 
+fn_same_bsn 20163 fn_last_bsn 5 delta_bsn 2 old_len 0
+ bsn 103 
+lime 0
+
+lime 1
+ bsn 104 null
+ bsn 105  bsn 106 null
+ bsn 107  bsn 108 null
+ bsn 109 
+TS 4 CS4 DL DATA TFI 0 BSN 111 FBI 0 
+fn_same_bsn 20167 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 103 
+lime 0
+
+lime 1
+ bsn 104 null
+ bsn 105  bsn 106 null
+ bsn 107  bsn 108 null
+ bsn 109  bsn 110 null
+ bsn 111 
+TS 4 CS4 DL DATA TFI 0 BSN 113 FBI 0 
+fn_same_bsn 20171 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 103 
+lime 0
+
+lime 1
+ bsn 104 null
+ bsn 105  bsn 106 null
+ bsn 107  bsn 108 null
+ bsn 109  bsn 110 null
+ bsn 111  bsn 112 null
+ bsn 113 
+lime 0
+end of message reached
+MSG: ec8bd7f1fb76d96eee54ec86ab6e2d2d266762c91bb72697164d8fe3aa656fbb95c6a9fc3615931fc6d54ea59a987a
+
+TS 4 CS4 DL DATA TFI 0 BSN 115 FBI 0 
+fn_same_bsn 20176 fn_last_bsn 5 delta_bsn 2 old_len 0
+ bsn 113 
+lime 0
+ bsn 114 null
+ bsn 115 
+TS 4 CS4 DL DATA TFI 0 BSN 117 FBI 0 
+fn_same_bsn 20180 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 113 
+lime 0
+ bsn 114 null
+ bsn 115  bsn 116 null
+ bsn 117 
+TS 4 CS4 DL DATA TFI 0 BSN 119 FBI 0 
+fn_same_bsn 20184 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 113 
+lime 0
+ bsn 114 null
+ bsn 115  bsn 116 null
+ bsn 117  bsn 118 null
+ bsn 119 
+TS 4 CS4 DL DATA TFI 0 BSN 121 FBI 0 
+fn_same_bsn 20189 fn_last_bsn 5 delta_bsn 2 old_len 0
+ bsn 113 
+lime 0
+ bsn 114 null
+ bsn 115  bsn 116 null
+ bsn 117  bsn 118 null
+ bsn 119  bsn 120 null
+ bsn 121 
+TS 4 CS4 DL DATA TFI 0 BSN 123 FBI 0 
+fn_same_bsn 20193 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 113 
+lime 0
+ bsn 114 null
+ bsn 115  bsn 116 null
+ bsn 117  bsn 118 null
+ bsn 119  bsn 120 null
+ bsn 121  bsn 122 null
+ bsn 123 
+TS 4 CS4 DL DATA TFI 0 BSN 125 FBI 0 
+fn_same_bsn 20197 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 113 
+lime 0
+ bsn 114 null
+ bsn 115  bsn 116 null
+ bsn 117  bsn 118 null
+ bsn 119  bsn 120 null
+ bsn 121  bsn 122 null
+ bsn 123  bsn 124 null
+ bsn 125 
+TS 4 CS4 DL DATA TFI 0 BSN 127 FBI 0 
+fn_same_bsn 20202 fn_last_bsn 5 delta_bsn 2 old_len 0
+ bsn 113 
+lime 0
+ bsn 114 null
+ bsn 115  bsn 116 null
+ bsn 117  bsn 118 null
+ bsn 119  bsn 120 null
+ bsn 121  bsn 122 null
+ bsn 123  bsn 124 null
+ bsn 125  bsn 126 null
+ bsn 127 
+TS 4 CS4 DL DATA TFI 0 BSN 3 FBI 0 
+fn_same_bsn 775 fn_last_bsn 8 delta_bsn -124 old_len 29
+ bsn 113 
+lime 0
+ bsn 114 null
+ bsn 115  bsn 116 null
+ bsn 117  bsn 118 null
+ bsn 119  bsn 120 null
+ bsn 121  bsn 122 null
+ bsn 123  bsn 124 null
+ bsn 125  bsn 126 null
+ bsn 127  bsn 0 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 1 
+lime 0
+ bsn 2 
+lime 0
+
+lime 1
+ bsn 3 
+TS 4 CS4 DL DATA TFI 0 BSN 5 FBI 0 
+fn_same_bsn 806 fn_last_bsn 5 delta_bsn 2 old_len 28
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 7 FBI 0 
+fn_same_bsn 724 fn_last_bsn 9 delta_bsn 4 old_len 36
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 9 FBI 0 
+fn_same_bsn 710 fn_last_bsn 13 delta_bsn 6 old_len 35
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 11 FBI 0 
+fn_same_bsn 694 fn_last_bsn 18 delta_bsn 8 old_len 35
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 13 FBI 0 
+fn_same_bsn 693 fn_last_bsn 22 delta_bsn 10 old_len 35
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 15 FBI 0 
+fn_same_bsn 710 fn_last_bsn 26 delta_bsn 12 old_len 35
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 17 FBI 0 
+fn_same_bsn 711 fn_last_bsn 31 delta_bsn 14 old_len 49
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 3 FBI 0 
+fn_same_bsn 35 fn_last_bsn 35 delta_bsn 0 old_len 50
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 19 FBI 0 
+fn_same_bsn 676 fn_last_bsn 4 delta_bsn 16 old_len 0
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 22 FBI 0 
+fn_same_bsn 628 fn_last_bsn 13 delta_bsn 19 old_len 49
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 24 FBI 0 
+fn_same_bsn 502 fn_last_bsn 17 delta_bsn 21 old_len 0
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 26 FBI 0 
+fn_same_bsn 529 fn_last_bsn 22 delta_bsn 23 old_len 0
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 28 FBI 0 
+fn_same_bsn 516 fn_last_bsn 26 delta_bsn 25 old_len 0
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 30 FBI 0 
+fn_same_bsn 481 fn_last_bsn 30 delta_bsn 27 old_len 0
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 32 FBI 0 
+fn_same_bsn 20280 fn_last_bsn 35 delta_bsn 29 old_len 0
+ bsn 113 
+lime 0
+ bsn 114 null
+ bsn 115  bsn 116 null
+ bsn 117  bsn 118 null
+ bsn 119  bsn 120 null
+ bsn 121  bsn 122 null
+ bsn 123  bsn 124 null
+ bsn 125  bsn 126 null
+ bsn 127  bsn 0 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 1 
+lime 0
+ bsn 2 
+lime 0
+
+lime 1
+ bsn 3  bsn 4 null
+ bsn 5 
+lime 0
+
+lime 1
+ bsn 6 
+lime 0
+ bsn 7  bsn 8 null
+ bsn 9 
+lime 0
+ bsn 10 
+lime 0
+ bsn 11 
+lime 0
+ bsn 12 old segment
+ bsn 13 
+lime 0
+ bsn 14 old segment
+ bsn 15 
+lime 0
+ bsn 16 
+lime 0
+ bsn 17 
+lime 0
+ bsn 18 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 19 null
+ bsn 20 
+lime 0
+ bsn 21 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 22 
+lime 0
+ bsn 23 
+lime 0
+ bsn 24 null
+ bsn 25 
+lime 0
+ bsn 26 null
+ bsn 27  bsn 28 null
+ bsn 29 
+lime 0
+
+lime 1
+ bsn 30 null
+ bsn 31 
+lime 0
+
+lime 1
+ bsn 32 
+TS 4 CS4 DL DATA TFI 0 BSN 34 FBI 0 
+fn_same_bsn 472 fn_last_bsn 4 delta_bsn 2 old_len 0
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 36 FBI 0 
+fn_same_bsn 472 fn_last_bsn 8 delta_bsn 4 old_len 0
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 38 FBI 0 
+fn_same_bsn 473 fn_last_bsn 13 delta_bsn 6 old_len 0
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 40 FBI 0 
+fn_same_bsn 20297 fn_last_bsn 17 delta_bsn 8 old_len 0
+ bsn 25 
+lime 0
+ bsn 26 null
+ bsn 27  bsn 28 null
+ bsn 29 
+lime 0
+
+lime 1
+ bsn 30 null
+ bsn 31 
+lime 0
+
+lime 1
+ bsn 32  bsn 33 
+lime 0
+
+lime error!
+ bsn 34 null
+ bsn 35  bsn 36 null
+ bsn 37 
+lime 0
+ bsn 38 null
+ bsn 39  bsn 40 
+TS 4 CS4 DL DATA TFI 0 BSN 42 FBI 0 
+fn_same_bsn 476 fn_last_bsn 4 delta_bsn 2 old_len 49
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 44 FBI 0 
+fn_same_bsn 468 fn_last_bsn 9 delta_bsn 4 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 46 FBI 0 
+fn_same_bsn 20310 fn_last_bsn 13 delta_bsn 6 old_len 0
+ bsn 37 
+lime 0
+ bsn 38 null
+ bsn 39  bsn 40  bsn 41 null
+ bsn 42 
+lime 0
+ bsn 43 null
+ bsn 44  bsn 45 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 46 
+TS 4 CS4 DL DATA TFI 0 BSN 48 FBI 0 
+fn_same_bsn 20314 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 42 
+lime 0
+ bsn 43 null
+ bsn 44  bsn 45 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 46  bsn 47 
+lime 0
+
+lime error!
+ bsn 48 
+TS 4 CS4 DL DATA TFI 0 BSN 50 FBI 0 
+fn_same_bsn 20319 fn_last_bsn 5 delta_bsn 2 old_len 0
+ bsn 47 
+lime 0
+ bsn 48  bsn 49  bsn 50 
+TS 4 CS4 DL DATA TFI 0 BSN 52 FBI 0 
+fn_same_bsn 20323 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 47 
+lime 0
+ bsn 48  bsn 49  bsn 50  bsn 51 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 52 
+TS 4 CS4 DL DATA TFI 0 BSN 54 FBI 0 
+fn_same_bsn 390 fn_last_bsn 4 delta_bsn 2 old_len 0
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 56 FBI 0 
+fn_same_bsn 20332 fn_last_bsn 9 delta_bsn 4 old_len 0
+ bsn 47 
+lime 0
+ bsn 48  bsn 49  bsn 50  bsn 51 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 52  bsn 53 
+lime 0
+
+lime error!
+ bsn 54 null
+ bsn 55  bsn 56 
+TS 4 CS4 DL DATA TFI 0 BSN 58 FBI 0 
+fn_same_bsn 342 fn_last_bsn 4 delta_bsn 2 old_len 49
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 60 FBI 0 
+fn_same_bsn 342 fn_last_bsn 8 delta_bsn 4 old_len 49
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 62 FBI 0 
+fn_same_bsn 369 fn_last_bsn 13 delta_bsn 6 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 65 FBI 0 
+fn_same_bsn 342 fn_last_bsn 21 delta_bsn 9 old_len 0
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 67 FBI 0 
+fn_same_bsn 343 fn_last_bsn 26 delta_bsn 11 old_len 0
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 69 FBI 0 
+fn_same_bsn 342 fn_last_bsn 30 delta_bsn 13 old_len 48
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 71 FBI 0 
+fn_same_bsn 20366 fn_last_bsn 34 delta_bsn 15 old_len 0
+ bsn 53 
+lime 0
+ bsn 54 null
+ bsn 55  bsn 56  bsn 57 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 58 
+lime 0
+ bsn 59 null
+ bsn 60 
+lime 0
+ bsn 61 null
+ bsn 62  bsn 63 null
+ bsn 64 
+lime 0
+
+lime 1
+ bsn 65 null
+ bsn 66  bsn 67 null
+ bsn 68  bsn 69 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 70 
+lime 0
+ bsn 71 
+TS 4 CS4 DL DATA TFI 0 BSN 73 FBI 0 
+fn_same_bsn 20371 fn_last_bsn 5 delta_bsn 2 old_len 0
+ bsn 60 
+lime 0
+ bsn 61 null
+ bsn 62  bsn 63 null
+ bsn 64 
+lime 0
+
+lime 1
+ bsn 65 null
+ bsn 66  bsn 67 null
+ bsn 68  bsn 69 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 70 
+lime 0
+ bsn 71  bsn 72 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 73 
+TS 4 CS4 DL DATA TFI 0 BSN 75 FBI 0 
+fn_same_bsn 20375 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 60 
+lime 0
+ bsn 61 null
+ bsn 62  bsn 63 null
+ bsn 64 
+lime 0
+
+lime 1
+ bsn 65 null
+ bsn 66  bsn 67 null
+ bsn 68  bsn 69 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 70 
+lime 0
+ bsn 71  bsn 72 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 73  bsn 74  bsn 75 
+TS 4 CS4 DL DATA TFI 0 BSN 77 FBI 0 
+fn_same_bsn 20379 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 60 
+lime 0
+ bsn 61 null
+ bsn 62  bsn 63 null
+ bsn 64 
+lime 0
+
+lime 1
+ bsn 65 null
+ bsn 66  bsn 67 null
+ bsn 68  bsn 69 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 70 
+lime 0
+ bsn 71  bsn 72 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 73  bsn 74  bsn 75  bsn 76  bsn 77 
+TS 4 CS4 DL DATA TFI 0 BSN 79 FBI 0 
+fn_same_bsn 20384 fn_last_bsn 5 delta_bsn 2 old_len 0
+ bsn 60 
+lime 0
+ bsn 61 null
+ bsn 62  bsn 63 null
+ bsn 64 
+lime 0
+
+lime 1
+ bsn 65 null
+ bsn 66  bsn 67 null
+ bsn 68  bsn 69 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 70 
+lime 0
+ bsn 71  bsn 72 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 73  bsn 74  bsn 75  bsn 76  bsn 77  bsn 78  bsn 79 
+TS 4 CS4 DL DATA TFI 0 BSN 81 FBI 0 
+fn_same_bsn 20388 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 60 
+lime 0
+ bsn 61 null
+ bsn 62  bsn 63 null
+ bsn 64 
+lime 0
+
+lime 1
+ bsn 65 null
+ bsn 66  bsn 67 null
+ bsn 68  bsn 69 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 70 
+lime 0
+ bsn 71  bsn 72 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 73  bsn 74  bsn 75  bsn 76  bsn 77  bsn 78  bsn 79  bsn 80  bsn 81 
+TS 4 CS4 DL DATA TFI 0 BSN 83 FBI 0 
+fn_same_bsn 20392 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 60 
+lime 0
+ bsn 61 null
+ bsn 62  bsn 63 null
+ bsn 64 
+lime 0
+
+lime 1
+ bsn 65 null
+ bsn 66  bsn 67 null
+ bsn 68  bsn 69 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 70 
+lime 0
+ bsn 71  bsn 72 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 73  bsn 74  bsn 75  bsn 76  bsn 77  bsn 78  bsn 79  bsn 80  bsn 81  bsn 82  bsn 83 
+TS 4 CS4 DL DATA TFI 0 BSN 85 FBI 0 
+fn_same_bsn 20397 fn_last_bsn 5 delta_bsn 2 old_len 0
+ bsn 60 
+lime 0
+ bsn 61 null
+ bsn 62  bsn 63 null
+ bsn 64 
+lime 0
+
+lime 1
+ bsn 65 null
+ bsn 66  bsn 67 null
+ bsn 68  bsn 69 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 70 
+lime 0
+ bsn 71  bsn 72 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 73  bsn 74  bsn 75  bsn 76  bsn 77  bsn 78  bsn 79  bsn 80  bsn 81  bsn 82  bsn 83  bsn 84  bsn 85 
+TS 4 CS4 DL DATA TFI 0 BSN 87 FBI 0 
+fn_same_bsn 20401 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 60 
+lime 0
+ bsn 61 null
+ bsn 62  bsn 63 null
+ bsn 64 
+lime 0
+
+lime 1
+ bsn 65 null
+ bsn 66  bsn 67 null
+ bsn 68  bsn 69 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 70 
+lime 0
+ bsn 71  bsn 72 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 73  bsn 74  bsn 75  bsn 76  bsn 77  bsn 78  bsn 79  bsn 80  bsn 81  bsn 82  bsn 83  bsn 84  bsn 85  bsn 86  bsn 87 
+TS 4 CS4 DL DATA TFI 0 BSN 89 FBI 0 
+fn_same_bsn 20405 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 60 
+lime 0
+ bsn 61 null
+ bsn 62  bsn 63 null
+ bsn 64 
+lime 0
+
+lime 1
+ bsn 65 null
+ bsn 66  bsn 67 null
+ bsn 68  bsn 69 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 70 
+lime 0
+ bsn 71  bsn 72 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 73  bsn 74  bsn 75  bsn 76  bsn 77  bsn 78  bsn 79  bsn 80  bsn 81  bsn 82  bsn 83  bsn 84  bsn 85  bsn 86  bsn 87  bsn 88  bsn 89 
+TS 4 CS4 DL DATA TFI 0 BSN 91 FBI 0 
+fn_same_bsn 20410 fn_last_bsn 5 delta_bsn 2 old_len 0
+ bsn 60 
+lime 0
+ bsn 61 null
+ bsn 62  bsn 63 null
+ bsn 64 
+lime 0
+
+lime 1
+ bsn 65 null
+ bsn 66  bsn 67 null
+ bsn 68  bsn 69 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 70 
+lime 0
+ bsn 71  bsn 72 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 73  bsn 74  bsn 75  bsn 76  bsn 77  bsn 78  bsn 79  bsn 80  bsn 81  bsn 82  bsn 83  bsn 84  bsn 85  bsn 86  bsn 87  bsn 88  bsn 89  bsn 90  bsn 91 
+TS 4 CS4 DL DATA TFI 0 BSN 93 FBI 0 
+fn_same_bsn 20414 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 60 
+lime 0
+ bsn 61 null
+ bsn 62  bsn 63 null
+ bsn 64 
+lime 0
+
+lime 1
+ bsn 65 null
+ bsn 66  bsn 67 null
+ bsn 68  bsn 69 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 70 
+lime 0
+ bsn 71  bsn 72 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 73  bsn 74  bsn 75  bsn 76  bsn 77  bsn 78  bsn 79  bsn 80  bsn 81  bsn 82  bsn 83  bsn 84  bsn 85  bsn 86  bsn 87  bsn 88  bsn 89  bsn 90  bsn 91  bsn 92  bsn 93 
+TS 4 CS4 DL DATA TFI 0 BSN 95 FBI 0 
+fn_same_bsn 20418 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 60 
+lime 0
+ bsn 61 null
+ bsn 62  bsn 63 null
+ bsn 64 
+lime 0
+
+lime 1
+ bsn 65 null
+ bsn 66  bsn 67 null
+ bsn 68  bsn 69 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 70 
+lime 0
+ bsn 71  bsn 72 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 73  bsn 74  bsn 75  bsn 76  bsn 77  bsn 78  bsn 79  bsn 80  bsn 81  bsn 82  bsn 83  bsn 84  bsn 85  bsn 86  bsn 87  bsn 88  bsn 89  bsn 90  bsn 91  bsn 92  bsn 93  bsn 94  bsn 95 
+TS 4 CS4 DL DATA TFI 0 BSN 97 FBI 0 
+fn_same_bsn 20423 fn_last_bsn 5 delta_bsn 2 old_len 0
+ bsn 60 
+lime 0
+ bsn 61 null
+ bsn 62  bsn 63 null
+ bsn 64 
+lime 0
+
+lime 1
+ bsn 65 null
+ bsn 66  bsn 67 null
+ bsn 68  bsn 69 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 70 
+lime 0
+ bsn 71  bsn 72 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 73  bsn 74  bsn 75  bsn 76  bsn 77  bsn 78  bsn 79  bsn 80  bsn 81  bsn 82  bsn 83  bsn 84  bsn 85  bsn 86  bsn 87  bsn 88  bsn 89  bsn 90  bsn 91  bsn 92  bsn 93  bsn 94  bsn 95  bsn 96  bsn 97 
+TS 4 CS4 DL DATA TFI 0 BSN 99 FBI 0 
+fn_same_bsn 20427 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 60 
+lime 0
+ bsn 61 null
+ bsn 62  bsn 63 null
+ bsn 64 
+lime 0
+
+lime 1
+ bsn 65 null
+ bsn 66  bsn 67 null
+ bsn 68  bsn 69 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 70 
+lime 0
+ bsn 71  bsn 72 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 73  bsn 74  bsn 75  bsn 76  bsn 77  bsn 78  bsn 79  bsn 80  bsn 81  bsn 82  bsn 83  bsn 84  bsn 85  bsn 86  bsn 87  bsn 88  bsn 89  bsn 90  bsn 91  bsn 92  bsn 93  bsn 94  bsn 95  bsn 96  bsn 97  bsn 98  bsn 99 
+lime 0
+end of message reached
+MSG: 3c0ad90c08e00458bf2e78747618f0e88f09501645cbfa54bcf50d095708925ad30db110f0da2889d04d19fa507faab6f0a90aeee7a5b901cbce6d485454502f312e3120323030204f4b0d0a5365727665723a206e67696e780d0a446174653a204d6f6ea153ea304f5d5cf96d0fceed3644a32c5b3cea051d6484df4a955277248b5abe10d6002c84a1a68718c44b5ae88f6d179dae6c3b20636861727365743d77696e646f77732d313235310d0a5472616e736665722d456e636f64696e673a206368756e6b653239042c683604ac53061c8a08878175ca4c0611e12582750a11facbdc5f7605c0c4800887817502de29dbbb3a97ae8c5cda4947494e0d0a436f6e74656e742d456e636f64696e673a20677a69700d0a0d0a343061640d0a1f8b0800000000000003ed9ddd8958c2bf7364d7a0c57d4116b9becda4bd96c8bb8ee0b27d478e084ea2a9356b5fc71caa4d4b42760cc36108924be137abb779bf5fc055fbc651e28d2ab12ccb99caec9b949b209a6ce2d2c4c514e92123eeef39a71b0d4908017638354cd564c602d135154b0ee31c0d812c95018722ad6190a5329341a4758990a583492b804206a4350cb25407097eab03cbc67bc916dd4211736c7af10f4edb6a379caafabcd3b0dbd6ad4973f9ca95b7b8652d5d4aa9e5d554a1982e2d441e66722bf987c589f854321e51db484008a5a2b6c9a91682b2c883d0a4800e8a884292821fe810b82f77442d051c710a614fcfe2cca47ba7e102e46b82a953981622a5f4a3d2a4fe5e48671722c5d266365d5c4da74bba35afbb5c6a8d5befe60b6ba9d2c44aba945e2e65f2b9885acee75599c820c2b94450d5d88d41518500b01810ce305055d0145a236ba22475d4cafa1a79997f9bbdaf5525d4a54cf67eea4ef66a2d93cbac6dac4d149753d9f4423c1ae352ead1ab97bce19d35d7a57c612a39b1965fca64d332e5db53b17822361d9b1e72750d9943bc0d858dd8343f6834699de203642a6163756aa7e6e617a889cd8e760c3ed36108879c26901e64f5b56b987f3abee2f5476b59168e1e5fe933c7dbf11b9be455a71f4dc6e353fa4dbf259b41bf2e59ef95cc83e84f36f2a5b492bfe4a5aa9f29160f7ca4ca4dbb0e3e0882040ecbe304144ec491ca9f4ee3850323689337c16aac6d14c867fbe08314b8f483ab8404c71529c815cfdb250ddd9af4a720b3592e64d64bbd1bf37eea41ca5c8da86261b9bba13753b216d16269f2fe4f36d285cdc978f4466c74b4fd88b4afbd143ccd114f9163f531afe631cb0fab1157284c8a798e63fd96b9c383f5667285cd3b2003ffc88844297798c9dd7b6dce2127cda6f169e6b53594cd79e5ec8564072bf520555077eea57ea216ccc7cf7faede7b7f9e1fe462747da3b879c2607c3ede57e99de9031d9c19063af8dca4076bab4cc891ad69576ad6b6f856240489d54810734f6d39bb80e275289338c97d0f56240f7834f567ee7d279bcd3ffc2e7c305de0e6526123dda7cd5221b5fcc13fa6eec17bd20f75438c71f4ee464e73c82d4092c5f244f64ba38748fcb25d857cc1d658e523bb4ede9f0c4740051a572310bc564b776440fcfa5600879a3ec1275a8fa9e2666e999664403245254fb0afb9343a22bcba3837a2167a7acae60d8b88ae17f2a5fc723eab6e2bef46b87a313ba2e6b0b4d0a881ee40c661806c3321806c33170064ebd91f3ee5de981ac265c478cf1d6994f186215cfa1a8c6393890cd00ca4fff19b9b3f4add93550e26f65eecfd79558caea70accf77bf9957434932ba60ba56fa61109e9d17ba97155d4afecc3b1513eaf0220b635
+
+TS 4 CS4 DL DATA TFI 0 BSN 101 FBI 0 
+fn_same_bsn 20431 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 99 
+lime 0
+ bsn 100  bsn 101 
+TS 4 CS4 DL DATA TFI 0 BSN 103 FBI 0 
+fn_same_bsn 286 fn_last_bsn 5 delta_bsn 2 old_len 48
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 105 FBI 0 
+fn_same_bsn 286 fn_last_bsn 9 delta_bsn 4 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 107 FBI 0 
+fn_same_bsn 286 fn_last_bsn 13 delta_bsn 6 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 110 FBI 0 
+fn_same_bsn 20453 fn_last_bsn 22 delta_bsn 9 old_len 0
+ bsn 99 
+lime 0
+ bsn 100  bsn 101  bsn 102 null
+ bsn 103 
+lime 0
+
+lime 1
+ bsn 104 null
+ bsn 105  bsn 106 null
+ bsn 107  bsn 108 null
+ bsn 109  bsn 110 
+TS 4 CS4 DL DATA TFI 0 BSN 112 FBI 0 
+fn_same_bsn 20457 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 103 
+lime 0
+
+lime 1
+ bsn 104 null
+ bsn 105  bsn 106 null
+ bsn 107  bsn 108 null
+ bsn 109  bsn 110  bsn 111  bsn 112 
+TS 4 CS4 DL DATA TFI 0 BSN 114 FBI 0 
+fn_same_bsn 20462 fn_last_bsn 5 delta_bsn 2 old_len 0
+ bsn 103 
+lime 0
+
+lime 1
+ bsn 104 null
+ bsn 105  bsn 106 null
+ bsn 107  bsn 108 null
+ bsn 109  bsn 110  bsn 111  bsn 112  bsn 113 
+lime 0
+
+lime error!
+ bsn 114 
+TS 4 CS4 DL DATA TFI 0 BSN 116 FBI 0 
+fn_same_bsn 20466 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 113 
+lime 0
+ bsn 114  bsn 115  bsn 116 
+TS 4 CS4 DL DATA TFI 0 BSN 118 FBI 0 
+fn_same_bsn 20470 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 113 
+lime 0
+ bsn 114  bsn 115  bsn 116  bsn 117  bsn 118 
+TS 4 CS4 DL DATA TFI 0 BSN 120 FBI 0 
+fn_same_bsn 20475 fn_last_bsn 5 delta_bsn 2 old_len 0
+ bsn 113 
+lime 0
+ bsn 114  bsn 115  bsn 116  bsn 117  bsn 118  bsn 119  bsn 120 
+TS 4 CS4 DL DATA TFI 0 BSN 122 FBI 0 
+fn_same_bsn 20479 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 113 
+lime 0
+ bsn 114  bsn 115  bsn 116  bsn 117  bsn 118  bsn 119  bsn 120  bsn 121  bsn 122 
+TS 4 CS4 DL DATA TFI 0 BSN 124 FBI 0 
+fn_same_bsn 20483 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 113 
+lime 0
+ bsn 114  bsn 115  bsn 116  bsn 117  bsn 118  bsn 119  bsn 120  bsn 121  bsn 122  bsn 123  bsn 124 
+TS 4 CS4 DL DATA TFI 0 BSN 126 FBI 0 
+fn_same_bsn 20488 fn_last_bsn 5 delta_bsn 2 old_len 0
+ bsn 113 
+lime 0
+ bsn 114  bsn 115  bsn 116  bsn 117  bsn 118  bsn 119  bsn 120  bsn 121  bsn 122  bsn 123  bsn 124  bsn 125  bsn 126 
+TS 4 CS4 DL DATA TFI 0 BSN 0 FBI 0 
+fn_same_bsn 1079 fn_last_bsn 4 delta_bsn -126 old_len 28
+ bsn 113 
+lime 0
+ bsn 114  bsn 115  bsn 116  bsn 117  bsn 118  bsn 119  bsn 120  bsn 121  bsn 122  bsn 123  bsn 124  bsn 125  bsn 126  bsn 127  bsn 0 
+TS 4 CS4 DL DATA TFI 0 BSN 2 FBI 0 
+fn_same_bsn 1079 fn_last_bsn 4 delta_bsn 2 old_len 28
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 4 FBI 0 
+fn_same_bsn 1079 fn_last_bsn 9 delta_bsn 4 old_len 0
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 6 FBI 0 
+fn_same_bsn 1079 fn_last_bsn 13 delta_bsn 6 old_len 35
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 116 FBI 0 
+fn_same_bsn 43 fn_last_bsn 17 delta_bsn 116 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 8 FBI 0 
+fn_same_bsn 1010 fn_last_bsn 22 delta_bsn 8 old_len 0
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 10 FBI 0 
+fn_same_bsn 1010 fn_last_bsn 26 delta_bsn 10 old_len 35
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 12 FBI 0 
+fn_same_bsn 3120 fn_last_bsn 30 delta_bsn 12 old_len 35
+ bsn 113 
+lime 0
+ bsn 114  bsn 115  bsn 116  bsn 117  bsn 118  bsn 119  bsn 120  bsn 121  bsn 122  bsn 123  bsn 124  bsn 125  bsn 126  bsn 127  bsn 0  bsn 1 
+lime 0
+
+lime error!
+ bsn 2 
+lime 0
+
+lime 1
+ bsn 3  bsn 4 null
+ bsn 5 
+lime 0
+
+lime 1
+ bsn 6 
+lime 0
+ bsn 7  bsn 8 null
+ bsn 9 
+lime 0
+ bsn 10 
+lime 0
+ bsn 11 
+lime 0
+ bsn 12 
+lime 0
+end of message reached
+MSG: 2f065dd9364c75c3c0a8000401bbb5d384caa284890c21e88010494826ae00000101080a1bdb241001cbce82028236
+
+TS 4 CS4 DL DATA TFI 0 BSN 14 FBI 0 
+fn_same_bsn 3008 fn_last_bsn 5 delta_bsn 2 old_len 35
+ bsn 12 
+lime 0
+ bsn 13 
+lime 0
+
+lime error!
+ bsn 14 
+TS 4 CS4 DL DATA TFI 0 BSN 16 FBI 0 
+fn_same_bsn 984 fn_last_bsn 4 delta_bsn 2 old_len 35
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 18 FBI 0 
+fn_same_bsn 983 fn_last_bsn 8 delta_bsn 4 old_len 48
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 20 FBI 0 
+fn_same_bsn 971 fn_last_bsn 13 delta_bsn 6 old_len 49
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 22 FBI 0 
+fn_same_bsn 914 fn_last_bsn 17 delta_bsn 8 old_len 49
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 25 FBI 0 
+fn_same_bsn 832 fn_last_bsn 26 delta_bsn 11 old_len 49
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 27 FBI 0 
+fn_same_bsn 832 fn_last_bsn 30 delta_bsn 13 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 29 FBI 0 
+fn_same_bsn 832 fn_last_bsn 34 delta_bsn 15 old_len 48
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 31 FBI 0 
+fn_same_bsn 793 fn_last_bsn 39 delta_bsn 17 old_len 48
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 33 FBI 0 
+fn_same_bsn 793 fn_last_bsn 43 delta_bsn 19 old_len 49
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 35 FBI 0 
+fn_same_bsn 775 fn_last_bsn 47 delta_bsn 21 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 37 FBI 0 
+fn_same_bsn 776 fn_last_bsn 52 delta_bsn 23 old_len 49
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 39 FBI 0 
+fn_same_bsn 776 fn_last_bsn 56 delta_bsn 25 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 41 FBI 0 
+fn_same_bsn 745 fn_last_bsn 60 delta_bsn 27 old_len 0
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 43 FBI 0 
+fn_same_bsn 746 fn_last_bsn 65 delta_bsn 29 old_len 0
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 45 FBI 0 
+fn_same_bsn 728 fn_last_bsn 69 delta_bsn 31 old_len 48
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 47 FBI 0 
+fn_same_bsn 728 fn_last_bsn 73 delta_bsn 33 old_len 49
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 49 FBI 0 
+fn_same_bsn 711 fn_last_bsn 78 delta_bsn 35 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 51 FBI 0 
+fn_same_bsn 711 fn_last_bsn 82 delta_bsn 37 old_len 48
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 53 FBI 0 
+fn_same_bsn 693 fn_last_bsn 86 delta_bsn 39 old_len 49
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 55 FBI 0 
+fn_same_bsn 694 fn_last_bsn 91 delta_bsn 41 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 57 FBI 0 
+fn_same_bsn 693 fn_last_bsn 95 delta_bsn 43 old_len 48
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 59 FBI 0 
+fn_same_bsn 20626 fn_last_bsn 99 delta_bsn 45 old_len 0
+ bsn 12 
+lime 0
+ bsn 13 
+lime 0
+
+lime error!
+ bsn 14  bsn 15 
+lime 0
+
+lime error!
+ bsn 16 
+lime 0
+ bsn 17 
+lime 0
+ bsn 18 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 19 null
+ bsn 20 
+lime 0
+ bsn 21 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 22 
+lime 0
+ bsn 23 
+lime 0
+ bsn 24 null
+ bsn 25 
+lime 0
+ bsn 26 null
+ bsn 27  bsn 28 null
+ bsn 29 
+lime 0
+
+lime 1
+ bsn 30 null
+ bsn 31 
+lime 0
+
+lime 1
+ bsn 32  bsn 33 
+lime 0
+
+lime error!
+ bsn 34 null
+ bsn 35  bsn 36 null
+ bsn 37 
+lime 0
+ bsn 38 null
+ bsn 39  bsn 40  bsn 41 null
+ bsn 42 
+lime 0
+ bsn 43 null
+ bsn 44  bsn 45 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 46  bsn 47 
+lime 0
+
+lime error!
+ bsn 48  bsn 49  bsn 50  bsn 51 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 52  bsn 53 
+lime 0
+
+lime error!
+ bsn 54 null
+ bsn 55  bsn 56  bsn 57 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 58 
+lime 0
+ bsn 59 
+TS 4 CS4 DL DATA TFI 0 BSN 61 FBI 0 
+fn_same_bsn 20631 fn_last_bsn 5 delta_bsn 2 old_len 0
+ bsn 53 
+lime 0
+ bsn 54 null
+ bsn 55  bsn 56  bsn 57 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 58 
+lime 0
+ bsn 59  bsn 60 
+lime 0
+
+lime error!
+ bsn 61 
+TS 4 CS4 DL DATA TFI 0 BSN 63 FBI 0 
+fn_same_bsn 20635 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 60 
+lime 0
+ bsn 61  bsn 62  bsn 63 
+TS 4 CS4 DL DATA TFI 0 BSN 65 FBI 0 
+fn_same_bsn 628 fn_last_bsn 4 delta_bsn 2 old_len 0
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 67 FBI 0 
+fn_same_bsn 629 fn_last_bsn 9 delta_bsn 4 old_len 0
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 70 FBI 0 
+fn_same_bsn 602 fn_last_bsn 17 delta_bsn 7 old_len 49
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 72 FBI 0 
+fn_same_bsn 577 fn_last_bsn 22 delta_bsn 9 old_len 48
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 74 FBI 0 
+fn_same_bsn 576 fn_last_bsn 26 delta_bsn 11 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 76 FBI 0 
+fn_same_bsn 576 fn_last_bsn 30 delta_bsn 13 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 78 FBI 0 
+fn_same_bsn 577 fn_last_bsn 35 delta_bsn 15 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 80 FBI 0 
+fn_same_bsn 576 fn_last_bsn 39 delta_bsn 17 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 82 FBI 0 
+fn_same_bsn 576 fn_last_bsn 43 delta_bsn 19 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 84 FBI 0 
+fn_same_bsn 577 fn_last_bsn 48 delta_bsn 21 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 86 FBI 0 
+fn_same_bsn 576 fn_last_bsn 52 delta_bsn 23 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 88 FBI 0 
+fn_same_bsn 576 fn_last_bsn 56 delta_bsn 25 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 90 FBI 0 
+fn_same_bsn 577 fn_last_bsn 61 delta_bsn 27 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 92 FBI 0 
+fn_same_bsn 576 fn_last_bsn 65 delta_bsn 29 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 94 FBI 0 
+fn_same_bsn 576 fn_last_bsn 69 delta_bsn 31 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 96 FBI 0 
+fn_same_bsn 577 fn_last_bsn 74 delta_bsn 33 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 98 FBI 0 
+fn_same_bsn 576 fn_last_bsn 78 delta_bsn 35 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 100 FBI 0 
+fn_same_bsn 576 fn_last_bsn 82 delta_bsn 37 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 102 FBI 0 
+fn_same_bsn 20722 fn_last_bsn 87 delta_bsn 39 old_len 0
+ bsn 60 
+lime 0
+ bsn 61  bsn 62  bsn 63  bsn 64 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 65 null
+ bsn 66  bsn 67 null
+ bsn 68  bsn 69 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 70 
+lime 0
+ bsn 71  bsn 72 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 73  bsn 74  bsn 75  bsn 76  bsn 77  bsn 78  bsn 79  bsn 80  bsn 81  bsn 82  bsn 83  bsn 84  bsn 85  bsn 86  bsn 87  bsn 88  bsn 89  bsn 90  bsn 91  bsn 92  bsn 93  bsn 94  bsn 95  bsn 96  bsn 97  bsn 98  bsn 99 
+lime 0
+
+lime error!
+ bsn 100  bsn 101  bsn 102 
+TS 4 CS4 DL DATA TFI 0 BSN 106 FBI 0 
+fn_same_bsn 20735 fn_last_bsn 13 delta_bsn 4 old_len 0
+ bsn 99 
+lime 0
+ bsn 100  bsn 101  bsn 102  bsn 103 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 104 null
+ bsn 105  bsn 106 
+TS 4 CS4 DL DATA TFI 0 BSN 108 FBI 0 
+fn_same_bsn 20739 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 103 
+lime 0
+
+lime 1
+ bsn 104 null
+ bsn 105  bsn 106  bsn 107  bsn 108 
+TS 4 CS4 DL DATA TFI 0 BSN 102 FBI 0 
+fn_same_bsn 43 fn_last_bsn 26 delta_bsn -6 old_len 50
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 120 FBI 0 
+fn_same_bsn 316 fn_last_bsn 52 delta_bsn 12 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 121 FBI 0 
+fn_same_bsn 797 fn_last_bsn 247 delta_bsn 13 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 123 FBI 0 
+fn_same_bsn 797 fn_last_bsn 251 delta_bsn 15 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 116 FBI 0 
+fn_same_bsn 529 fn_last_bsn 256 delta_bsn 8 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 0 FBI 0 
+fn_same_bsn 750 fn_last_bsn 503 delta_bsn -108 old_len 50
+ bsn 103 
+lime 0
+
+lime 1
+ bsn 104 null
+ bsn 105  bsn 106  bsn 107  bsn 108  bsn 109  bsn 110  bsn 111  bsn 112  bsn 113 
+lime 0
+
+lime error!
+ bsn 114  bsn 115  bsn 116  bsn 117  bsn 118  bsn 119  bsn 120  bsn 121  bsn 122  bsn 123  bsn 124  bsn 125  bsn 126  bsn 127  bsn 0 
+lime 0
+end of message reached
+MSG: 03c05c4dd7f0484f5b179a74015059e2d8c307e8ea1227f0273537767e120a01159cb900a860cf9bf249686a7618053e045450c67aeb7b1716ab6edda9b6fc950a1eb89bfa4964d1fd45cbda6bfb7bfb15e2909df9831ffed05f349f6a3cb65a7a9829a1ba6b6d8fe96c14f24fd9bf02e83b91c8f00bb1609d5d52554ecdaf22ad34517e8a5caea165db2d71b0517915e2a9cf4bf91eb0b6bdaf6fbc5b99dcfa46af9a6b5642348688d78df97b3d9b5a4eafe6b370bf8548dbaeb6dacaa939aae1d6eda6b7a922685bd9511be8f4853aa8d95bc4a1f7ed2a3d6a479cbef3093704084777ab86503b3dd0b4c76024dfde1b5c57d03e232e0ceca33b56d321b551cacf1b112057b834ef898139359594af9a010e90f88bb7ae4e4c4c4eaa5b57df7bf75beffce89df744ab7cebfbefa6ed38180d86d5500a89489a2ec43226bdfdf4a73fa58e1a7a0f8ddcbe8aff4e74200d3706838d5a66ba383f0c7126040c71d061eea50b4aa61d198b2ec1724723de0a8dabaee697f6553f79caff9fe84cf2346a130de9573877178db04843bc03517cfc549a949f514442fce490a84270562b6e3b0a6ade10fc730fef618a7a611c50c0cb6d8ad415314c36afa69bcabe655cf1ec7e3ae2998c236885baf73787e83fea7f16d2a58d42ae4741f57fe8fdfc50a5b3c5b4a71ef7fef0fadf98ef85d268e469670706e5e3b9108412023a357301d0a99ef7e1134a3c111f468c86804ec9804389d161a05332934162f41240a77a29c5f756f47760a6185ff0eb87a294faedbcba0b947e91ef695f8810ddfbbc4dfd567bb6d0cfbacffa6d945633c568119fc772a9f7bd4b3ff21d11a6203dc4fac2fe9c45440800438bb02f0c84107aa0c40b1e64ec45f13e63ef8a778b22b52480e394ae368fe58aee4cda4ddc7cff3a8cc56cc305b66e292d031137cb42045f02be153ed9635d6662be8862a8b5838011f7b820165fd17452056676ad360b6a8edbc53e5af6dd9138
+
+lime 1
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS4 DL DATA TFI 0 BSN 125 FBI 0 
+fn_same_bsn 1049 fn_last_bsn 4 delta_bsn 125 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 127 FBI 0 
+fn_same_bsn 1048 fn_last_bsn 8 delta_bsn 127 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 13 FBI 0 
+fn_same_bsn 1958 fn_last_bsn 255 delta_bsn 13 old_len 35
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 15 FBI 0 
+fn_same_bsn 1976 fn_last_bsn 260 delta_bsn 15 old_len 35
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 17 FBI 0 
+fn_same_bsn 1976 fn_last_bsn 264 delta_bsn 17 old_len 49
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 10 FBI 0 
+fn_same_bsn 2015 fn_last_bsn 281 delta_bsn 10 old_len 35
+ bsn 113 
+lime 0
+ bsn 114  bsn 115  bsn 116  bsn 117  bsn 118  bsn 119  bsn 120  bsn 121  bsn 122  bsn 123  bsn 124  bsn 125  bsn 126  bsn 127  bsn 0 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 1 
+lime 0
+ bsn 2 
+lime 0
+
+lime 1
+ bsn 3  bsn 4 null
+ bsn 5 
+lime 0
+
+lime 1
+ bsn 6 
+lime 0
+ bsn 7  bsn 8 null
+ bsn 9 
+lime 0
+ bsn 10 old segment
+
+TS 4 CS4 DL DATA TFI 0 BSN 27 FBI 0 
+fn_same_bsn 1824 fn_last_bsn 26 delta_bsn 17 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 49 FBI 0 
+fn_same_bsn 1920 fn_last_bsn 291 delta_bsn 39 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 49 FBI 0 
+fn_same_bsn 1924 fn_last_bsn 295 delta_bsn 39 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 49 FBI 0 
+fn_same_bsn 1928 fn_last_bsn 299 delta_bsn 39 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 49 FBI 0 
+fn_same_bsn 1941 fn_last_bsn 312 delta_bsn 39 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 49 FBI 0 
+fn_same_bsn 1950 fn_last_bsn 321 delta_bsn 39 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 49 FBI 0 
+fn_same_bsn 1954 fn_last_bsn 325 delta_bsn 39 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 49 FBI 0 
+fn_same_bsn 1959 fn_last_bsn 330 delta_bsn 39 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 49 FBI 0 
+fn_same_bsn 1963 fn_last_bsn 334 delta_bsn 39 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 49 FBI 0 
+fn_same_bsn 1967 fn_last_bsn 338 delta_bsn 39 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 49 FBI 0 
+fn_same_bsn 1972 fn_last_bsn 343 delta_bsn 39 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 49 FBI 0 
+fn_same_bsn 1976 fn_last_bsn 347 delta_bsn 39 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 49 FBI 0 
+fn_same_bsn 1980 fn_last_bsn 351 delta_bsn 39 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 49 FBI 0 
+fn_same_bsn 1985 fn_last_bsn 356 delta_bsn 39 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 49 FBI 0 
+fn_same_bsn 1989 fn_last_bsn 360 delta_bsn 39 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 49 FBI 0 
+fn_same_bsn 1993 fn_last_bsn 364 delta_bsn 39 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 49 FBI 0 
+fn_same_bsn 1998 fn_last_bsn 369 delta_bsn 39 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 49 FBI 0 
+fn_same_bsn 2002 fn_last_bsn 373 delta_bsn 39 old_len 50
+ bsn 113 
+lime 0
+ bsn 114  bsn 115  bsn 116  bsn 117  bsn 118  bsn 119  bsn 120  bsn 121  bsn 122  bsn 123  bsn 124  bsn 125  bsn 126  bsn 127  bsn 0 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 1 
+lime 0
+ bsn 2 
+lime 0
+
+lime 1
+ bsn 3  bsn 4 null
+ bsn 5 
+lime 0
+
+lime 1
+ bsn 6 
+lime 0
+ bsn 7  bsn 8 null
+ bsn 9 
+lime 0
+ bsn 10 old segment
+ bsn 11 
+lime 0
+ bsn 12 
+lime 0
+ bsn 13 
+lime 0
+
+lime error!
+ bsn 14  bsn 15 
+lime 0
+
+lime error!
+ bsn 16 
+lime 0
+ bsn 17 
+lime 0
+ bsn 18 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 19 null
+ bsn 20 
+lime 0
+ bsn 21 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 22 
+lime 0
+ bsn 23 
+lime 0
+ bsn 24 null
+ bsn 25 
+lime 0
+ bsn 26 null
+ bsn 27  bsn 28 null
+ bsn 29 
+lime 0
+
+lime 1
+ bsn 30 null
+ bsn 31 
+lime 0
+
+lime 1
+ bsn 32  bsn 33 
+lime 0
+
+lime error!
+ bsn 34 null
+ bsn 35  bsn 36 null
+ bsn 37 
+lime 0
+ bsn 38 null
+ bsn 39  bsn 40  bsn 41 null
+ bsn 42 
+lime 0
+ bsn 43 null
+ bsn 44  bsn 45 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 46  bsn 47 
+lime 0
+
+lime error!
+ bsn 48  bsn 49 
+lime 0
+end of message reached
+MSG: 03c0756500001c450000ca37bd40003206fd5257fafa77c0a8000401bb95e397cdfdee0abb68f450a4af68c4676e0ca16930e0733b6f64c061340dfa1aecbc91990cd034a4ff73691aff91bc3236c04f3b7ba30fafc4fb43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS4 DL DATA TFI 0 BSN 49 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 49 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 49 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 49 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 49 FBI 0 
+fn_same_bsn 9 fn_last_bsn 9 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 49 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 49 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 49 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 49 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 49 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 49 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 49 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 49 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 49 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 49 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 49 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 51 FBI 0 
+fn_same_bsn 2076 fn_last_bsn 4 delta_bsn 2 old_len 48
+ bsn 47 
+lime 0
+ bsn 48  bsn 49 
+lime 0
+
+lime error!
+ bsn 50  bsn 51 
+TS 4 CS4 DL DATA TFI 0 BSN 53 FBI 0 
+fn_same_bsn 2058 fn_last_bsn 4 delta_bsn 2 old_len 49
+ bsn 47 
+lime 0
+ bsn 48  bsn 49 
+lime 0
+
+lime error!
+ bsn 50  bsn 51  bsn 52  bsn 53 
+TS 4 CS4 DL DATA TFI 0 BSN 55 FBI 0 
+fn_same_bsn 2059 fn_last_bsn 5 delta_bsn 2 old_len 50
+ bsn 47 
+lime 0
+ bsn 48  bsn 49 
+lime 0
+
+lime error!
+ bsn 50  bsn 51  bsn 52  bsn 53  bsn 54 null
+ bsn 55 
+TS 4 CS4 DL DATA TFI 0 BSN 57 FBI 0 
+fn_same_bsn 2058 fn_last_bsn 4 delta_bsn 2 old_len 48
+ bsn 47 
+lime 0
+ bsn 48  bsn 49 
+lime 0
+
+lime error!
+ bsn 50  bsn 51  bsn 52  bsn 53  bsn 54 null
+ bsn 55  bsn 56  bsn 57 
+TS 4 CS4 DL DATA TFI 0 BSN 59 FBI 0 
+fn_same_bsn 1365 fn_last_bsn 4 delta_bsn 2 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 61 FBI 0 
+fn_same_bsn 1365 fn_last_bsn 9 delta_bsn 4 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 54 FBI 0 
+fn_same_bsn 2072 fn_last_bsn 22 delta_bsn -3 old_len 0
+duplicate
+
+TS 4 CS4 DL DATA TFI 0 BSN 56 FBI 0 
+fn_same_bsn 1681 fn_last_bsn 26 delta_bsn -1 old_len 50
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 58 FBI 0 
+fn_same_bsn 2023 fn_last_bsn 30 delta_bsn 1 old_len 49
+ bsn 47 
+lime 0
+ bsn 48  bsn 49 
+lime 0
+
+lime error!
+ bsn 50  bsn 51  bsn 52  bsn 53  bsn 54 null
+ bsn 55  bsn 56  bsn 57  bsn 58 
+TS 4 CS4 DL DATA TFI 0 BSN 62 FBI 0 
+fn_same_bsn 2050 fn_last_bsn 9 delta_bsn 4 old_len 50
+ bsn 47 
+lime 0
+ bsn 48  bsn 49 
+lime 0
+
+lime error!
+ bsn 50  bsn 51  bsn 52  bsn 53  bsn 54 null
+ bsn 55  bsn 56  bsn 57  bsn 58  bsn 59  bsn 60 
+lime 0
+
+lime error!
+ bsn 61  bsn 62 
+TS 4 CS4 DL DATA TFI 0 BSN 64 FBI 0 
+fn_same_bsn 2049 fn_last_bsn 4 delta_bsn 2 old_len 48
+ bsn 60 
+lime 0
+ bsn 61  bsn 62  bsn 63  bsn 64 
+TS 4 CS4 DL DATA TFI 0 BSN 68 FBI 0 
+fn_same_bsn 2032 fn_last_bsn 9 delta_bsn 4 old_len 50
+ bsn 60 
+lime 0
+ bsn 61  bsn 62  bsn 63  bsn 64  bsn 65 null
+ bsn 66 old segment
+ bsn 67 null
+ bsn 68 
+TS 4 CS4 DL DATA TFI 0 BSN 70 FBI 0 
+fn_same_bsn 1993 fn_last_bsn 4 delta_bsn 2 old_len 49
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 72 FBI 0 
+fn_same_bsn 1968 fn_last_bsn 9 delta_bsn 4 old_len 48
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 74 FBI 0 
+fn_same_bsn 1967 fn_last_bsn 13 delta_bsn 6 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 1 FBI 0 
+fn_same_bsn 4169 fn_last_bsn 1560 delta_bsn -67 old_len 29
+ bsn 60 
+lime 0
+ bsn 61  bsn 62  bsn 63  bsn 64  bsn 65 null
+ bsn 66 old segment
+ bsn 67 null
+ bsn 68  bsn 69 old segment
+ bsn 70 
+lime 0
+ bsn 71  bsn 72 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 73  bsn 74  bsn 75  bsn 76  bsn 77  bsn 78  bsn 79  bsn 80  bsn 81  bsn 82  bsn 83  bsn 84  bsn 85  bsn 86  bsn 87  bsn 88  bsn 89  bsn 90  bsn 91  bsn 92  bsn 93  bsn 94  bsn 95  bsn 96  bsn 97  bsn 98  bsn 99 
+lime 0
+
+lime error!
+ bsn 100  bsn 101  bsn 102  bsn 103 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 104 null
+ bsn 105  bsn 106  bsn 107  bsn 108  bsn 109  bsn 110  bsn 111  bsn 112  bsn 113 
+lime 0
+
+lime error!
+ bsn 114  bsn 115  bsn 116  bsn 117  bsn 118  bsn 119  bsn 120  bsn 121  bsn 122  bsn 123  bsn 124  bsn 125  bsn 126  bsn 127  bsn 0 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 1 old segment
+
+TS 4 CS4 DL DATA TFI 0 BSN 3 FBI 0 
+fn_same_bsn 3358 fn_last_bsn 4 delta_bsn 2 old_len 50
+ bsn 113 
+lime 0
+ bsn 114  bsn 115  bsn 116  bsn 117  bsn 118  bsn 119  bsn 120  bsn 121  bsn 122  bsn 123  bsn 124  bsn 125  bsn 126  bsn 127  bsn 0 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 1 old segment
+ bsn 2 
+lime 0
+
+lime 1
+ bsn 3 old segment
+
+TS 4 CS4 DL DATA TFI 0 BSN 5 FBI 0 
+fn_same_bsn 4199 fn_last_bsn 5 delta_bsn 2 old_len 28
+ bsn 113 
+lime 0
+ bsn 114  bsn 115  bsn 116  bsn 117  bsn 118  bsn 119  bsn 120  bsn 121  bsn 122  bsn 123  bsn 124  bsn 125  bsn 126  bsn 127  bsn 0 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 1 old segment
+ bsn 2 
+lime 0
+
+lime 1
+ bsn 3 old segment
+ bsn 4 null
+ bsn 5 old segment
+
+TS 4 CS4 DL DATA TFI 0 BSN 7 FBI 0 
+fn_same_bsn 4117 fn_last_bsn 4 delta_bsn 2 old_len 36
+ bsn 113 
+lime 0
+ bsn 114  bsn 115  bsn 116  bsn 117  bsn 118  bsn 119  bsn 120  bsn 121  bsn 122  bsn 123  bsn 124  bsn 125  bsn 126  bsn 127  bsn 0 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 1 old segment
+ bsn 2 
+lime 0
+
+lime 1
+ bsn 3 old segment
+ bsn 4 null
+ bsn 5 old segment
+ bsn 6 
+lime 0
+ bsn 7 old segment
+
+TS 4 CS4 DL DATA TFI 0 BSN 9 FBI 0 
+fn_same_bsn 4103 fn_last_bsn 4 delta_bsn 2 old_len 35
+ bsn 113 
+lime 0
+ bsn 114  bsn 115  bsn 116  bsn 117  bsn 118  bsn 119  bsn 120  bsn 121  bsn 122  bsn 123  bsn 124  bsn 125  bsn 126  bsn 127  bsn 0 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 1 old segment
+ bsn 2 
+lime 0
+
+lime 1
+ bsn 3 old segment
+ bsn 4 null
+ bsn 5 old segment
+ bsn 6 
+lime 0
+ bsn 7 old segment
+ bsn 8 null
+ bsn 9 old segment
+
+TS 4 CS4 DL DATA TFI 0 BSN 13 FBI 0 
+fn_same_bsn 4086 fn_last_bsn 9 delta_bsn 4 old_len 35
+ bsn 113 
+lime 0
+ bsn 114  bsn 115  bsn 116  bsn 117  bsn 118  bsn 119  bsn 120  bsn 121  bsn 122  bsn 123  bsn 124  bsn 125  bsn 126  bsn 127  bsn 0 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 1 old segment
+ bsn 2 
+lime 0
+
+lime 1
+ bsn 3 old segment
+ bsn 4 null
+ bsn 5 old segment
+ bsn 6 
+lime 0
+ bsn 7 old segment
+ bsn 8 null
+ bsn 9 old segment
+ bsn 10 old segment
+ bsn 11 
+lime 0
+ bsn 12 
+lime 0
+ bsn 13 old segment
+
+TS 4 CS4 DL DATA TFI 0 BSN 15 FBI 0 
+fn_same_bsn 4103 fn_last_bsn 4 delta_bsn 2 old_len 35
+ bsn 12 
+lime 0
+ bsn 13 old segment
+ bsn 14  bsn 15 old segment
+
+TS 4 CS4 DL DATA TFI 0 BSN 19 FBI 0 
+fn_same_bsn 4065 fn_last_bsn 9 delta_bsn 4 old_len 0
+ bsn 12 
+lime 0
+ bsn 13 old segment
+ bsn 14  bsn 15 old segment
+ bsn 16 
+lime 0
+ bsn 17 
+lime 0
+ bsn 18 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 19 old segment
+
+TS 4 CS4 DL DATA TFI 0 BSN 29 FBI 0 
+fn_same_bsn 3931 fn_last_bsn 22 delta_bsn 10 old_len 48
+ bsn 17 
+lime 0
+ bsn 18 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 19 old segment
+ bsn 20 
+lime 0
+ bsn 21 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 22 
+lime 0
+ bsn 23 
+lime 0
+ bsn 24 null
+ bsn 25 
+lime 0
+ bsn 26 null
+ bsn 27  bsn 28 null
+ bsn 29 old segment
+
+TS 4 CS4 DL DATA TFI 0 BSN 31 FBI 0 
+fn_same_bsn 3891 fn_last_bsn 4 delta_bsn 2 old_len 48
+ bsn 25 
+lime 0
+ bsn 26 null
+ bsn 27  bsn 28 null
+ bsn 29 old segment
+ bsn 30 null
+ bsn 31 old segment
+
+TS 4 CS4 DL DATA TFI 0 BSN 34 FBI 0 
+fn_same_bsn 3861 fn_last_bsn 9 delta_bsn 3 old_len 0
+ bsn 25 
+lime 0
+ bsn 26 null
+ bsn 27  bsn 28 null
+ bsn 29 old segment
+ bsn 30 null
+ bsn 31 old segment
+ bsn 32  bsn 33 
+lime 0
+
+lime error!
+ bsn 34 old segment
+
+TS 4 CS4 DL DATA TFI 0 BSN 24 FBI 0 
+fn_same_bsn 3917 fn_last_bsn 4 delta_bsn -10 old_len 0
+duplicate
+
+TS 4 CS4 DL DATA TFI 0 BSN 26 FBI 0 
+fn_same_bsn 3943 fn_last_bsn 8 delta_bsn -8 old_len 0
+duplicate
+
+TS 4 CS4 DL DATA TFI 0 BSN 32 FBI 0 
+fn_same_bsn 3414 fn_last_bsn 21 delta_bsn -2 old_len 50
+duplicate
+
+TS 4 CS4 DL DATA TFI 0 BSN 34 FBI 0 
+fn_same_bsn 26 fn_last_bsn 26 delta_bsn 0 old_len 50
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 36 FBI 0 
+fn_same_bsn 3887 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 33 
+lime 0
+ bsn 34 old segment
+ bsn 35  bsn 36 old segment
+
+TS 4 CS4 DL DATA TFI 0 BSN 38 FBI 0 
+fn_same_bsn 3887 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 33 
+lime 0
+ bsn 34 old segment
+ bsn 35  bsn 36 old segment
+ bsn 37 
+lime 0
+ bsn 38 old segment
+
+TS 4 CS4 DL DATA TFI 0 BSN 40 FBI 0 
+fn_same_bsn 3415 fn_last_bsn 5 delta_bsn 2 old_len 50
+ bsn 37 
+lime 0
+ bsn 38 old segment
+ bsn 39  bsn 40 old segment
+
+TS 4 CS4 DL DATA TFI 0 BSN 37 FBI 0 
+fn_same_bsn 3917 fn_last_bsn 8 delta_bsn -3 old_len 49
+duplicate
+
+TS 4 CS4 DL DATA TFI 0 BSN 39 FBI 0 
+fn_same_bsn 3918 fn_last_bsn 13 delta_bsn -1 old_len 50
+duplicate
+
+TS 4 CS4 DL DATA TFI 0 BSN 36 FBI 0 
+fn_same_bsn 26 fn_last_bsn 17 delta_bsn -4 old_len 50
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 38 FBI 0 
+fn_same_bsn 26 fn_last_bsn 21 delta_bsn -2 old_len 50
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 40 FBI 0 
+fn_same_bsn 26 fn_last_bsn 26 delta_bsn 0 old_len 48
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 42 FBI 0 
+fn_same_bsn 3917 fn_last_bsn 4 delta_bsn 2 old_len 49
+ bsn 37 
+lime 0
+ bsn 38  bsn 39  bsn 40 
+lime 0
+end of message reached
+MSG: 03c05d6500001645000038000040002f06df04364c75c3c01f1120abc1965ea60c31f0d55c55ae3cbc43ce8e7f5af9db38514f7b1f3dcaf7a6b839c02b000012ff0100010033740009084500003c0000400034063d045fd3e938c0a800040050e05b19d049c8d8cf3372a012389055cb0000020405b40402080aeee7f73e4bbd717654a3404f0744
+
+lime 1
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+ bsn 41 null
+ bsn 42 
+TS 4 CS4 DL DATA TFI 0 BSN 44 FBI 0 
+fn_same_bsn 3908 fn_last_bsn 4 delta_bsn 2 old_len 50
+ bsn 40 
+lime 0
+
+lime 1
+ bsn 41 null
+ bsn 42  bsn 43 null
+ bsn 44 
+TS 4 CS4 DL DATA TFI 0 BSN 46 FBI 0 
+fn_same_bsn 3441 fn_last_bsn 5 delta_bsn 2 old_len 50
+ bsn 40 
+lime 0
+
+lime 1
+ bsn 41 null
+ bsn 42  bsn 43 null
+ bsn 44  bsn 45 old segment
+ bsn 46 
+lime 0
+end of message reached
+MSG: 01000436b70e872c7883
+
+lime 1
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS4 DL DATA TFI 0 BSN 42 FBI 0 
+fn_same_bsn 13 fn_last_bsn 4 delta_bsn -4 old_len 50
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 44 FBI 0 
+fn_same_bsn 13 fn_last_bsn 8 delta_bsn -2 old_len 50
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 46 FBI 0 
+fn_same_bsn 13 fn_last_bsn 13 delta_bsn 0 old_len 48
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 42 FBI 0 
+fn_same_bsn 13 fn_last_bsn 4 delta_bsn -4 old_len 50
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 44 FBI 0 
+fn_same_bsn 13 fn_last_bsn 8 delta_bsn -2 old_len 50
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 47 FBI 0 
+fn_same_bsn 3905 fn_last_bsn 13 delta_bsn 1 old_len 49
+ bsn 40 
+lime 0
+
+lime 1
+ bsn 41 null
+ bsn 42  bsn 43 null
+ bsn 44  bsn 45 old segment
+ bsn 46 
+lime 0
+
+lime 1
+ bsn 47 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS4 DL DATA TFI 0 BSN 47 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 47 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 47 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 47 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 47 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 49 FBI 0 
+fn_same_bsn 1846 fn_last_bsn 18 delta_bsn 2 old_len 49
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 50 FBI 0 
+fn_same_bsn 3505 fn_last_bsn 26 delta_bsn 3 old_len 50
+ bsn 40 
+lime 0
+
+lime 1
+ bsn 41 null
+ bsn 42  bsn 43 null
+ bsn 44  bsn 45 old segment
+ bsn 46 
+lime 0
+
+lime 1
+ bsn 47 
+lime 0
+ bsn 48 old segment
+ bsn 49 
+lime 0
+ bsn 50 
+TS 4 CS4 DL DATA TFI 0 BSN 52 FBI 0 
+fn_same_bsn 3506 fn_last_bsn 5 delta_bsn 2 old_len 50
+ bsn 40 
+lime 0
+
+lime 1
+ bsn 41 null
+ bsn 42  bsn 43 null
+ bsn 44  bsn 45 old segment
+ bsn 46 
+lime 0
+
+lime 1
+ bsn 47 
+lime 0
+ bsn 48 old segment
+ bsn 49 
+lime 0
+ bsn 50  bsn 51  bsn 52 
+TS 4 CS4 DL DATA TFI 0 BSN 56 FBI 0 
+fn_same_bsn 1824 fn_last_bsn 8 delta_bsn 4 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 58 FBI 0 
+fn_same_bsn 1825 fn_last_bsn 13 delta_bsn 6 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 60 FBI 0 
+fn_same_bsn 3848 fn_last_bsn 17 delta_bsn 8 old_len 49
+ bsn 40 
+lime 0
+
+lime 1
+ bsn 41 null
+ bsn 42  bsn 43 null
+ bsn 44  bsn 45 old segment
+ bsn 46 
+lime 0
+
+lime 1
+ bsn 47 
+lime 0
+ bsn 48 old segment
+ bsn 49 
+lime 0
+ bsn 50  bsn 51  bsn 52  bsn 53  bsn 54 null
+ bsn 55  bsn 56  bsn 57  bsn 58  bsn 59  bsn 60 old segment
+
+TS 4 CS4 DL DATA TFI 0 BSN 53 FBI 0 
+fn_same_bsn 1881 fn_last_bsn 13 delta_bsn -7 old_len 50
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 57 FBI 0 
+fn_same_bsn 1881 fn_last_bsn 22 delta_bsn -3 old_len 50
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 64 FBI 0 
+fn_same_bsn 1842 fn_last_bsn 26 delta_bsn 4 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 66 FBI 0 
+fn_same_bsn 3852 fn_last_bsn 30 delta_bsn 6 old_len 50
+ bsn 40 
+lime 0
+
+lime 1
+ bsn 41 null
+ bsn 42  bsn 43 null
+ bsn 44  bsn 45 old segment
+ bsn 46 
+lime 0
+
+lime 1
+ bsn 47 
+lime 0
+ bsn 48 old segment
+ bsn 49 
+lime 0
+ bsn 50  bsn 51  bsn 52  bsn 53  bsn 54 null
+ bsn 55  bsn 56  bsn 57  bsn 58  bsn 59  bsn 60 old segment
+ bsn 61  bsn 62  bsn 63  bsn 64  bsn 65 null
+ bsn 66 
+lime 0
+end of message reached
+MSG: 840abbd16d8010007b8e8400000101080a1639dcbc01cbd5c461f664
+
+TS 4 CS4 DL DATA TFI 0 BSN 63 FBI 0 
+fn_same_bsn 3246 fn_last_bsn 5 delta_bsn -3 old_len 50
+duplicate
+
+TS 4 CS4 DL DATA TFI 0 BSN 65 FBI 0 
+fn_same_bsn 3874 fn_last_bsn 9 delta_bsn -1 old_len 0
+duplicate
+
+TS 4 CS4 DL DATA TFI 0 BSN 67 FBI 0 
+fn_same_bsn 3874 fn_last_bsn 13 delta_bsn 1 old_len 0
+ bsn 66 
+lime 0
+ bsn 67 
+lime 0
+end of message reached
+MSG: 03c1c56500004b4500003437bf40003206fde657fafa77c0a8000401bb95e397cdfe840abbd16d8011007b8e8300000101080a1639dcbc01cbd5c4da773a
+
+lime 1
+end of message reached
+MSG: 43c0012b2b2b2b
+
+TS 4 CS4 DL DATA TFI 0 BSN 64 FBI 0 
+fn_same_bsn 1864 fn_last_bsn 5 delta_bsn -3 old_len 50
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 68 FBI 0 
+fn_same_bsn 1859 fn_last_bsn 9 delta_bsn 1 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 70 FBI 0 
+fn_same_bsn 3852 fn_last_bsn 13 delta_bsn 3 old_len 49
+ bsn 67 
+lime 0
+
+lime 1
+ bsn 68  bsn 69 old segment
+ bsn 70 
+lime 0
+end of message reached
+MSG: 2d616e616c7974696373016c06676f6f676c65c021c036000100010000005e0004d83ad34e48fecd
+
+lime 1
+end of message reached
+MSG: 43c0012b2b2b2b2b
+
+TS 4 CS4 DL DATA TFI 0 BSN 72 FBI 0 
+fn_same_bsn 3835 fn_last_bsn 13 delta_bsn 2 old_len 48
+ bsn 67 
+lime 0
+
+lime 1
+ bsn 68  bsn 69 old segment
+ bsn 70 
+lime 0
+
+lime 1
+ bsn 71 old segment
+ bsn 72 
+lime 0
+end of message reached
+MSG: 23
+
+lime 1
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS4 DL DATA TFI 0 BSN 72 FBI 0 
+fn_same_bsn 9 fn_last_bsn 9 delta_bsn 0 old_len 48
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 72 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 48
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 72 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 48
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 72 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 48
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 73 FBI 0 
+fn_same_bsn 3575 fn_last_bsn 9 delta_bsn 1 old_len 50
+ bsn 67 
+lime 0
+
+lime 1
+ bsn 68  bsn 69 old segment
+ bsn 70 
+lime 0
+
+lime 1
+ bsn 71 old segment
+ bsn 72 
+lime 0
+
+lime 1
+ bsn 73 
+TS 4 CS4 DL DATA TFI 0 BSN 74 FBI 0 
+fn_same_bsn 3869 fn_last_bsn 8 delta_bsn 1 old_len 50
+ bsn 67 
+lime 0
+
+lime 1
+ bsn 68  bsn 69 old segment
+ bsn 70 
+lime 0
+
+lime 1
+ bsn 71 old segment
+ bsn 72 
+lime 0
+
+lime 1
+ bsn 73  bsn 74 
+lime 0
+end of message reached
+MSG: 03c1d16500004e4500003c0000400034063d055fd3e937c0a800040050e85c23fe0d33dbc2bd33a0123890a0b00000020405b40402080aeee7eb4501cbd62a010303075247e3
+
+TS 4 CS4 DL DATA TFI 0 BSN 74 FBI 0 
+fn_same_bsn 13 fn_last_bsn 13 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 76 FBI 0 
+fn_same_bsn 3883 fn_last_bsn 5 delta_bsn 2 old_len 50
+ bsn 74 
+lime 0
+ bsn 75 old segment
+ bsn 76 
+TS 4 CS4 DL DATA TFI 0 BSN 77 FBI 0 
+fn_same_bsn 3610 fn_last_bsn 17 delta_bsn 1 old_len 50
+ bsn 74 
+lime 0
+ bsn 75 old segment
+ bsn 76  bsn 77 
+lime 0
+end of message reached
+MSG: 03c1d9650000504500003c000040002b06d71736b78141c0a800040050a2efb3d3d9ab159e9e3ca01238909dee0000020405b40402080af609464e01cbd60e01030308bff2bd
+
+lime 1
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS4 DL DATA TFI 0 BSN 77 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 48
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 77 FBI 0 
+fn_same_bsn 9 fn_last_bsn 9 delta_bsn 0 old_len 48
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 77 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 48
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 77 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 48
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 77 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 48
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 77 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 48
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 77 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 48
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 83 FBI 0 
+fn_same_bsn 3658 fn_last_bsn 26 delta_bsn 6 old_len 50
+ bsn 74 
+lime 0
+ bsn 75 old segment
+ bsn 76  bsn 77 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 78 old segment
+ bsn 79 old segment
+ bsn 80 old segment
+ bsn 81 old segment
+ bsn 82 old segment
+ bsn 83 
+lime 0
+end of message reached
+MSG: 960402080aa3c65a3801cbd64201030307abdf87
+
+lime 1
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS4 DL DATA TFI 0 BSN 83 FBI 0 
+fn_same_bsn 13 fn_last_bsn 13 delta_bsn 0 old_len 48
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 81 FBI 0 
+fn_same_bsn 3683 fn_last_bsn 8 delta_bsn -2 old_len 50
+duplicate
+
+TS 4 CS4 DL DATA TFI 0 BSN 83 FBI 0 
+fn_same_bsn 13 fn_last_bsn 13 delta_bsn 0 old_len 48
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 79 FBI 0 
+fn_same_bsn 3705 fn_last_bsn 13 delta_bsn -4 old_len 50
+duplicate
+
+TS 4 CS4 DL DATA TFI 0 BSN 87 FBI 0 
+fn_same_bsn 3696 fn_last_bsn 21 delta_bsn 4 old_len 50
+ bsn 74 
+lime 0
+ bsn 75 old segment
+ bsn 76  bsn 77 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 78 old segment
+ bsn 79  bsn 80 old segment
+ bsn 81  bsn 82 old segment
+ bsn 83 
+lime 0
+
+lime 1
+ bsn 84 old segment
+ bsn 85 old segment
+ bsn 86 old segment
+ bsn 87 
+lime 0
+end of message reached
+MSG: 960402080aa3c6607c01cbd65d0103030772f846
+
+lime 1
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS4 DL DATA TFI 0 BSN 89 FBI 0 
+fn_same_bsn 3697 fn_last_bsn 5 delta_bsn 2 old_len 50
+ bsn 74 
+lime 0
+ bsn 75 old segment
+ bsn 76  bsn 77 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 78 old segment
+ bsn 79  bsn 80 old segment
+ bsn 81  bsn 82 old segment
+ bsn 83 
+lime 0
+
+lime 1
+ bsn 84 old segment
+ bsn 85 old segment
+ bsn 86 old segment
+ bsn 87 
+lime 0
+
+lime 1
+ bsn 88 old segment
+ bsn 89 
+lime 0
+end of message reached
+MSG: 960402080aa43557eb01cbd668010303073b787f
+
+lime 1
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS4 DL DATA TFI 0 BSN 87 FBI 0 
+fn_same_bsn 13 fn_last_bsn 8 delta_bsn -2 old_len 48
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 91 FBI 0 
+fn_same_bsn 3709 fn_last_bsn 17 delta_bsn 2 old_len 50
+ bsn 74 
+lime 0
+ bsn 75 old segment
+ bsn 76  bsn 77 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 78 old segment
+ bsn 79  bsn 80 old segment
+ bsn 81  bsn 82 old segment
+ bsn 83 
+lime 0
+
+lime 1
+ bsn 84 old segment
+ bsn 85 old segment
+ bsn 86 old segment
+ bsn 87 
+lime 0
+
+lime 1
+ bsn 88 old segment
+ bsn 89 
+lime 0
+
+lime 1
+ bsn 90 old segment
+ bsn 91 
+lime 0
+end of message reached
+MSG: 960402080aa3c65b6401cbd64201030307b35ba6
+
+lime 1
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS4 DL DATA TFI 0 BSN 89 FBI 0 
+fn_same_bsn 21 fn_last_bsn 4 delta_bsn -2 old_len 48
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 92 FBI 0 
+fn_same_bsn 4021 fn_last_bsn 26 delta_bsn 1 old_len 50
+ bsn 74 
+lime 0
+ bsn 75 old segment
+ bsn 76  bsn 77 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 78 old segment
+ bsn 79  bsn 80 old segment
+ bsn 81  bsn 82 old segment
+ bsn 83 
+lime 0
+
+lime 1
+ bsn 84 old segment
+ bsn 85 old segment
+ bsn 86 old segment
+ bsn 87 
+lime 0
+
+lime 1
+ bsn 88 old segment
+ bsn 89 
+lime 0
+
+lime 1
+ bsn 90 old segment
+ bsn 91 
+lime 0
+
+lime 1
+ bsn 92 
+TS 4 CS4 DL DATA TFI 0 BSN 122 FBI 0 
+fn_same_bsn 3731 fn_last_bsn 65 delta_bsn 30 old_len 50
+ bsn 74 
+lime 0
+ bsn 75 old segment
+ bsn 76  bsn 77 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 78 old segment
+ bsn 79  bsn 80 old segment
+ bsn 81  bsn 82 old segment
+ bsn 83 
+lime 0
+
+lime 1
+ bsn 84 old segment
+ bsn 85 old segment
+ bsn 86 old segment
+ bsn 87 
+lime 0
+
+lime 1
+ bsn 88 old segment
+ bsn 89 
+lime 0
+
+lime 1
+ bsn 90 old segment
+ bsn 91 
+lime 0
+
+lime 1
+ bsn 92  bsn 93 old segment
+ bsn 94 old segment
+ bsn 95 old segment
+ bsn 96 old segment
+ bsn 97 old segment
+ bsn 98 old segment
+ bsn 99 old segment
+ bsn 100 old segment
+ bsn 101 old segment
+ bsn 102 old segment
+ bsn 103 old segment
+ bsn 104 null
+ bsn 105 old segment
+ bsn 106 old segment
+ bsn 107 old segment
+ bsn 108 old segment
+ bsn 109 old segment
+ bsn 110 old segment
+ bsn 111 old segment
+ bsn 112 old segment
+ bsn 113 old segment
+ bsn 114 old segment
+ bsn 115 old segment
+ bsn 116 old segment
+ bsn 117 old segment
+ bsn 118 old segment
+ bsn 119 old segment
+ bsn 120 old segment
+ bsn 121 old segment
+ bsn 122 
+TS 4 CS4 DL DATA TFI 0 BSN 124 FBI 0 
+fn_same_bsn 3731 fn_last_bsn 4 delta_bsn 2 old_len 50
+ bsn 74 
+lime 0
+ bsn 75 old segment
+ bsn 76  bsn 77 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 78 old segment
+ bsn 79  bsn 80 old segment
+ bsn 81  bsn 82 old segment
+ bsn 83 
+lime 0
+
+lime 1
+ bsn 84 old segment
+ bsn 85 old segment
+ bsn 86 old segment
+ bsn 87 
+lime 0
+
+lime 1
+ bsn 88 old segment
+ bsn 89 
+lime 0
+
+lime 1
+ bsn 90 old segment
+ bsn 91 
+lime 0
+
+lime 1
+ bsn 92  bsn 93 old segment
+ bsn 94 old segment
+ bsn 95 old segment
+ bsn 96 old segment
+ bsn 97 old segment
+ bsn 98 old segment
+ bsn 99 old segment
+ bsn 100 old segment
+ bsn 101 old segment
+ bsn 102 old segment
+ bsn 103 old segment
+ bsn 104 null
+ bsn 105 old segment
+ bsn 106 old segment
+ bsn 107 old segment
+ bsn 108 old segment
+ bsn 109 old segment
+ bsn 110 old segment
+ bsn 111 old segment
+ bsn 112 old segment
+ bsn 113 old segment
+ bsn 114 old segment
+ bsn 115 old segment
+ bsn 116 old segment
+ bsn 117 old segment
+ bsn 118 old segment
+ bsn 119 old segment
+ bsn 120 old segment
+ bsn 121 old segment
+ bsn 122  bsn 123 old segment
+ bsn 124 
+TS 4 CS4 DL DATA TFI 0 BSN 13 FBI 0 
+fn_same_bsn 628 fn_last_bsn 39 delta_bsn -111 old_len 50
+ bsn 74 
+lime 0
+ bsn 75 old segment
+ bsn 76  bsn 77 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 78 old segment
+ bsn 79  bsn 80 old segment
+ bsn 81  bsn 82 old segment
+ bsn 83 
+lime 0
+
+lime 1
+ bsn 84 old segment
+ bsn 85 old segment
+ bsn 86 old segment
+ bsn 87 
+lime 0
+
+lime 1
+ bsn 88 old segment
+ bsn 89 
+lime 0
+
+lime 1
+ bsn 90 old segment
+ bsn 91 
+lime 0
+
+lime 1
+ bsn 92  bsn 93 old segment
+ bsn 94 old segment
+ bsn 95 old segment
+ bsn 96 old segment
+ bsn 97 old segment
+ bsn 98 old segment
+ bsn 99 old segment
+ bsn 100 old segment
+ bsn 101 old segment
+ bsn 102 old segment
+ bsn 103 old segment
+ bsn 104 null
+ bsn 105 old segment
+ bsn 106 old segment
+ bsn 107 old segment
+ bsn 108 old segment
+ bsn 109 old segment
+ bsn 110 old segment
+ bsn 111 old segment
+ bsn 112 old segment
+ bsn 113 old segment
+ bsn 114 old segment
+ bsn 115 old segment
+ bsn 116 old segment
+ bsn 117 old segment
+ bsn 118 old segment
+ bsn 119 old segment
+ bsn 120 old segment
+ bsn 121 old segment
+ bsn 122  bsn 123 old segment
+ bsn 124  bsn 125 old segment
+ bsn 126 old segment
+ bsn 127 old segment
+ bsn 0 old segment
+ bsn 1  bsn 2 old segment
+ bsn 3  bsn 4 null
+ bsn 5  bsn 6 old segment
+ bsn 7  bsn 8 null
+ bsn 9  bsn 10 old segment
+ bsn 11 old segment
+ bsn 12 old segment
+ bsn 13 
+TS 4 CS4 DL DATA TFI 0 BSN 27 FBI 0 
+fn_same_bsn 4559 fn_last_bsn 31 delta_bsn 14 old_len 50
+ bsn 74 
+lime 0
+ bsn 75 old segment
+ bsn 76  bsn 77 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 78 old segment
+ bsn 79  bsn 80 old segment
+ bsn 81  bsn 82 old segment
+ bsn 83 
+lime 0
+
+lime 1
+ bsn 84 old segment
+ bsn 85 old segment
+ bsn 86 old segment
+ bsn 87 
+lime 0
+
+lime 1
+ bsn 88 old segment
+ bsn 89 
+lime 0
+
+lime 1
+ bsn 90 old segment
+ bsn 91 
+lime 0
+
+lime 1
+ bsn 92  bsn 93 old segment
+ bsn 94 old segment
+ bsn 95 old segment
+ bsn 96 old segment
+ bsn 97 old segment
+ bsn 98 old segment
+ bsn 99 old segment
+ bsn 100 old segment
+ bsn 101 old segment
+ bsn 102 old segment
+ bsn 103 old segment
+ bsn 104 null
+ bsn 105 old segment
+ bsn 106 old segment
+ bsn 107 old segment
+ bsn 108 old segment
+ bsn 109 old segment
+ bsn 110 old segment
+ bsn 111 old segment
+ bsn 112 old segment
+ bsn 113 old segment
+ bsn 114 old segment
+ bsn 115 old segment
+ bsn 116 old segment
+ bsn 117 old segment
+ bsn 118 old segment
+ bsn 119 old segment
+ bsn 120 old segment
+ bsn 121 old segment
+ bsn 122  bsn 123 old segment
+ bsn 124  bsn 125 old segment
+ bsn 126 old segment
+ bsn 127 old segment
+ bsn 0 old segment
+ bsn 1  bsn 2 old segment
+ bsn 3  bsn 4 null
+ bsn 5  bsn 6 old segment
+ bsn 7  bsn 8 null
+ bsn 9  bsn 10 old segment
+ bsn 11 old segment
+ bsn 12 old segment
+ bsn 13  bsn 14 old segment
+ bsn 15  bsn 16 old segment
+ bsn 17 old segment
+ bsn 18 old segment
+ bsn 19 
+lime 0
+end of message reached
+MSG: c9c9
+ bsn 20 old segment
+ bsn 21 old segment
+ bsn 22 old segment
+ bsn 23 old segment
+ bsn 24 null
+ bsn 25 old segment
+ bsn 26 null
+ bsn 27 
+TS 4 CS3 DL DATA TFI 0 BSN 51 FBI 0 
+fn_same_bsn 2392 fn_last_bsn 82 delta_bsn 24 old_len 50
+ bsn 19 
+lime 0
+ bsn 20 old segment
+ bsn 21 old segment
+ bsn 22 old segment
+ bsn 23 old segment
+ bsn 24 null
+ bsn 25 old segment
+ bsn 26 null
+ bsn 27  bsn 28 null
+ bsn 29  bsn 30 null
+ bsn 31 
+lime 0
+end of message reached
+MSG: 86028727b54aaec540b87534a56f099c3abd
+ bsn 32  bsn 33 old segment
+ bsn 34  bsn 35 old segment
+ bsn 36  bsn 37 
+lime 0
+
+lime error!
+ bsn 38  bsn 39  bsn 40 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 41 null
+ bsn 42  bsn 43 null
+ bsn 44  bsn 45 old segment
+ bsn 46 
+lime 0
+
+lime 1
+ bsn 47 
+lime 0
+ bsn 48 old segment
+ bsn 49 
+lime 0
+ bsn 50  bsn 51 
+TS 4 CS3 DL DATA TFI 0 BSN 55 FBI 0 
+fn_same_bsn 2392 fn_last_bsn 9 delta_bsn 4 old_len 50
+ bsn 37 
+lime 0
+ bsn 38  bsn 39  bsn 40 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 41 null
+ bsn 42  bsn 43 null
+ bsn 44  bsn 45 old segment
+ bsn 46 
+lime 0
+
+lime 1
+ bsn 47 
+lime 0
+ bsn 48 old segment
+ bsn 49 
+lime 0
+ bsn 50  bsn 51  bsn 52  bsn 53  bsn 54 null
+ bsn 55 
+TS 4 CS3 DL DATA TFI 0 BSN 57 FBI 0 
+fn_same_bsn 511 fn_last_bsn 4 delta_bsn 2 old_len 50
+fucking error d_bsn!
+
+TS 4 CS3 DL DATA TFI 0 BSN 55 FBI 0 
+fn_same_bsn 17 fn_last_bsn 17 delta_bsn 0 old_len 36
+duplicate2
+
+TS 4 CS3 DL DATA TFI 0 BSN 57 FBI 0 
+fn_same_bsn 528 fn_last_bsn 4 delta_bsn 2 old_len 50
+fucking error d_bsn!
+
+TS 4 CS3 DL DATA TFI 0 BSN 54 FBI 0 
+fn_same_bsn 2392 fn_last_bsn 9 delta_bsn -1 old_len 0
+duplicate
+
+TS 4 CS3 DL DATA TFI 0 BSN 56 FBI 0 
+fn_same_bsn 2392 fn_last_bsn 13 delta_bsn 1 old_len 50
+ bsn 37 
+lime 0
+ bsn 38  bsn 39  bsn 40 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 41 null
+ bsn 42  bsn 43 null
+ bsn 44  bsn 45 old segment
+ bsn 46 
+lime 0
+
+lime 1
+ bsn 47 
+lime 0
+ bsn 48 old segment
+ bsn 49 
+lime 0
+ bsn 50  bsn 51  bsn 52  bsn 53  bsn 54 null
+ bsn 55  bsn 56 
+TS 4 CS3 DL DATA TFI 0 BSN 58 FBI 0 
+fn_same_bsn 2392 fn_last_bsn 4 delta_bsn 2 old_len 50
+ bsn 37 
+lime 0
+ bsn 38  bsn 39  bsn 40 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 41 null
+ bsn 42  bsn 43 null
+ bsn 44  bsn 45 old segment
+ bsn 46 
+lime 0
+
+lime 1
+ bsn 47 
+lime 0
+ bsn 48 old segment
+ bsn 49 
+lime 0
+ bsn 50  bsn 51  bsn 52  bsn 53  bsn 54 null
+ bsn 55  bsn 56  bsn 57  bsn 58 
+lime 0
+end of message reached
+MSG: 0e000037116eb308080808c0a8000400357aea005c6e58ce5f8180000100020000000007616e64726f696407636c69656e747306676f6f676c6503636f6d0000010001c00c000500e98e95f24fc0197bdcd2efd3a7c91c164d46fbc132b155951b986dda15244ccbd3cbced0e833245333cb33a8ff9d2c0bed949f7c
+
+lime 1
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS3 DL DATA TFI 0 BSN 55 FBI 0 
+fn_same_bsn 22 fn_last_bsn 5 delta_bsn -3 old_len 36
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 68 FBI 0 
+fn_same_bsn 2435 fn_last_bsn 65 delta_bsn 10 old_len 50
+ bsn 37 
+lime 0
+ bsn 38  bsn 39  bsn 40 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 41 null
+ bsn 42  bsn 43 null
+ bsn 44  bsn 45 old segment
+ bsn 46 
+lime 0
+
+lime 1
+ bsn 47 
+lime 0
+ bsn 48 old segment
+ bsn 49 
+lime 0
+ bsn 50  bsn 51  bsn 52  bsn 53  bsn 54 null
+ bsn 55  bsn 56  bsn 57  bsn 58 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 59 old segment
+ bsn 60  bsn 61 old segment
+ bsn 62  bsn 63  bsn 64  bsn 65 null
+ bsn 66 
+lime 0
+ bsn 67 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 68 
+TS 4 CS4 DL DATA TFI 0 BSN 90 FBI 0 
+fn_same_bsn 4403 fn_last_bsn 48 delta_bsn 22 old_len 50
+ bsn 66 
+lime 0
+ bsn 67 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 68  bsn 69 old segment
+ bsn 70 
+lime 0
+
+lime 1
+ bsn 71 old segment
+ bsn 72 
+lime 0
+
+lime 1
+ bsn 73  bsn 74 
+lime 0
+
+lime error!
+ bsn 75 old segment
+ bsn 76  bsn 77 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 78 old segment
+ bsn 79  bsn 80 old segment
+ bsn 81  bsn 82 old segment
+ bsn 83 
+lime 0
+
+lime 1
+ bsn 84 old segment
+ bsn 85 old segment
+ bsn 86 old segment
+ bsn 87 
+lime 0
+
+lime 1
+ bsn 88 old segment
+ bsn 89 
+lime 0
+
+lime 1
+ bsn 90 
+TS 4 CS4 DL DATA TFI 0 BSN 100 FBI 0 
+fn_same_bsn 4446 fn_last_bsn 65 delta_bsn 10 old_len 50
+ bsn 74 
+lime 0
+ bsn 75 old segment
+ bsn 76  bsn 77 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 78 old segment
+ bsn 79  bsn 80 old segment
+ bsn 81  bsn 82 old segment
+ bsn 83 
+lime 0
+
+lime 1
+ bsn 84 old segment
+ bsn 85 old segment
+ bsn 86 old segment
+ bsn 87 
+lime 0
+
+lime 1
+ bsn 88 old segment
+ bsn 89 
+lime 0
+
+lime 1
+ bsn 90  bsn 91 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 92  bsn 93 old segment
+ bsn 94 old segment
+ bsn 95 old segment
+ bsn 96 old segment
+ bsn 97 old segment
+ bsn 98 old segment
+ bsn 99 old segment
+ bsn 100 
+TS 4 CS4 DL DATA TFI 0 BSN 12 FBI 0 
+fn_same_bsn 4117 fn_last_bsn 52 delta_bsn -88 old_len 49
+ bsn 74 
+lime 0
+ bsn 75 old segment
+ bsn 76  bsn 77 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 78 old segment
+ bsn 79  bsn 80 old segment
+ bsn 81  bsn 82 old segment
+ bsn 83 
+lime 0
+
+lime 1
+ bsn 84 old segment
+ bsn 85 old segment
+ bsn 86 old segment
+ bsn 87 
+lime 0
+
+lime 1
+ bsn 88 old segment
+ bsn 89 
+lime 0
+
+lime 1
+ bsn 90  bsn 91 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 92  bsn 93 old segment
+ bsn 94 old segment
+ bsn 95 old segment
+ bsn 96 old segment
+ bsn 97 old segment
+ bsn 98 old segment
+ bsn 99 old segment
+ bsn 100  bsn 101 old segment
+ bsn 102 old segment
+ bsn 103 old segment
+ bsn 104 null
+ bsn 105 old segment
+ bsn 106 old segment
+ bsn 107 old segment
+ bsn 108 old segment
+ bsn 109 old segment
+ bsn 110 old segment
+ bsn 111 old segment
+ bsn 112 old segment
+ bsn 113 old segment
+ bsn 114 old segment
+ bsn 115 old segment
+ bsn 116 old segment
+ bsn 117 old segment
+ bsn 118 old segment
+ bsn 119 old segment
+ bsn 120 old segment
+ bsn 121 old segment
+ bsn 122  bsn 123 old segment
+ bsn 124  bsn 125 old segment
+ bsn 126 old segment
+ bsn 127 old segment
+ bsn 0 old segment
+ bsn 1  bsn 2 old segment
+ bsn 3  bsn 4 null
+ bsn 5  bsn 6 old segment
+ bsn 7  bsn 8 null
+ bsn 9  bsn 10 old segment
+ bsn 11 old segment
+ bsn 12 
+TS 4 CS4 DL DATA TFI 0 BSN 45 FBI 0 
+fn_same_bsn 4845 fn_last_bsn 74 delta_bsn 33 old_len 48
+ bsn 74 
+lime 0
+ bsn 75 old segment
+ bsn 76  bsn 77 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 78 old segment
+ bsn 79  bsn 80 old segment
+ bsn 81  bsn 82 old segment
+ bsn 83 
+lime 0
+
+lime 1
+ bsn 84 old segment
+ bsn 85 old segment
+ bsn 86 old segment
+ bsn 87 
+lime 0
+
+lime 1
+ bsn 88 old segment
+ bsn 89 
+lime 0
+
+lime 1
+ bsn 90  bsn 91 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 92  bsn 93 old segment
+ bsn 94 old segment
+ bsn 95 old segment
+ bsn 96 old segment
+ bsn 97 old segment
+ bsn 98 old segment
+ bsn 99 old segment
+ bsn 100  bsn 101 old segment
+ bsn 102 old segment
+ bsn 103 old segment
+ bsn 104 null
+ bsn 105 old segment
+ bsn 106 old segment
+ bsn 107 old segment
+ bsn 108 old segment
+ bsn 109 old segment
+ bsn 110 old segment
+ bsn 111 old segment
+ bsn 112 old segment
+ bsn 113 old segment
+ bsn 114 old segment
+ bsn 115 old segment
+ bsn 116 old segment
+ bsn 117 old segment
+ bsn 118 old segment
+ bsn 119 old segment
+ bsn 120 old segment
+ bsn 121 old segment
+ bsn 122  bsn 123 old segment
+ bsn 124  bsn 125 old segment
+ bsn 126 old segment
+ bsn 127 old segment
+ bsn 0 old segment
+ bsn 1  bsn 2 old segment
+ bsn 3  bsn 4 null
+ bsn 5  bsn 6 old segment
+ bsn 7  bsn 8 null
+ bsn 9  bsn 10 old segment
+ bsn 11 old segment
+ bsn 12  bsn 13  bsn 14 old segment
+ bsn 15  bsn 16 old segment
+ bsn 17 old segment
+ bsn 18 old segment
+ bsn 19 
+lime 0
+ bsn 20 old segment
+ bsn 21 old segment
+ bsn 22 old segment
+ bsn 23 old segment
+ bsn 24 null
+ bsn 25 old segment
+ bsn 26 null
+ bsn 27  bsn 28 null
+ bsn 29  bsn 30 null
+ bsn 31 
+lime 0
+ bsn 32  bsn 33 old segment
+ bsn 34  bsn 35 old segment
+ bsn 36  bsn 37 
+lime 0
+
+lime error!
+ bsn 38  bsn 39  bsn 40 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 41 null
+ bsn 42  bsn 43 null
+ bsn 44  bsn 45 
+TS 4 CS4 DL DATA TFI 0 BSN 55 FBI 0 
+fn_same_bsn 320 fn_last_bsn 21 delta_bsn 10 old_len 36
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 125 FBI 0 
+fn_same_bsn 4702 fn_last_bsn 186 delta_bsn 80 old_len 50
+ bsn 37 
+lime 0
+ bsn 38  bsn 39  bsn 40 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 41 null
+ bsn 42  bsn 43 null
+ bsn 44  bsn 45  bsn 46 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 47 
+lime 0
+ bsn 48 old segment
+ bsn 49 
+lime 0
+ bsn 50  bsn 51  bsn 52  bsn 53  bsn 54 null
+ bsn 55  bsn 56  bsn 57  bsn 58 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 59 old segment
+ bsn 60  bsn 61 old segment
+ bsn 62  bsn 63  bsn 64  bsn 65 null
+ bsn 66 
+lime 0
+ bsn 67 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 68  bsn 69 old segment
+ bsn 70 
+lime 0
+
+lime 1
+ bsn 71 old segment
+ bsn 72 
+lime 0
+
+lime 1
+ bsn 73  bsn 74 
+lime 0
+
+lime error!
+ bsn 75 old segment
+ bsn 76  bsn 77 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 78 old segment
+ bsn 79  bsn 80 old segment
+ bsn 81  bsn 82 old segment
+ bsn 83 
+lime 0
+
+lime 1
+ bsn 84 old segment
+ bsn 85 old segment
+ bsn 86 old segment
+ bsn 87 
+lime 0
+
+lime 1
+ bsn 88 old segment
+ bsn 89 
+lime 0
+
+lime 1
+ bsn 90  bsn 91 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 92  bsn 93 old segment
+ bsn 94 old segment
+ bsn 95 old segment
+ bsn 96 old segment
+ bsn 97 old segment
+ bsn 98 old segment
+ bsn 99 old segment
+ bsn 100  bsn 101 old segment
+ bsn 102 old segment
+ bsn 103 old segment
+ bsn 104 null
+ bsn 105 old segment
+ bsn 106 old segment
+ bsn 107 old segment
+ bsn 108 old segment
+ bsn 109 old segment
+ bsn 110 old segment
+ bsn 111 old segment
+ bsn 112 old segment
+ bsn 113 old segment
+ bsn 114 old segment
+ bsn 115 old segment
+ bsn 116 old segment
+ bsn 117 old segment
+ bsn 118 old segment
+ bsn 119 old segment
+ bsn 120 old segment
+ bsn 121 old segment
+ bsn 122  bsn 123 old segment
+ bsn 124  bsn 125 
+TS 4 CS4 DL DATA TFI 0 BSN 7 FBI 0 
+fn_same_bsn 1309 fn_last_bsn 22 delta_bsn -118 old_len 50
+ bsn 74 
+lime 0
+ bsn 75 old segment
+ bsn 76  bsn 77 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 78 old segment
+ bsn 79  bsn 80 old segment
+ bsn 81  bsn 82 old segment
+ bsn 83 
+lime 0
+
+lime 1
+ bsn 84 old segment
+ bsn 85 old segment
+ bsn 86 old segment
+ bsn 87 
+lime 0
+
+lime 1
+ bsn 88 old segment
+ bsn 89 
+lime 0
+
+lime 1
+ bsn 90  bsn 91 
+lime 0
+
+lime error!
+
+lime 1
+ bsn 92  bsn 93 old segment
+ bsn 94 old segment
+ bsn 95 old segment
+ bsn 96 old segment
+ bsn 97 old segment
+ bsn 98 old segment
+ bsn 99 old segment
+ bsn 100  bsn 101 old segment
+ bsn 102 old segment
+ bsn 103 old segment
+ bsn 104 null
+ bsn 105 old segment
+ bsn 106 old segment
+ bsn 107 old segment
+ bsn 108 old segment
+ bsn 109 old segment
+ bsn 110 old segment
+ bsn 111 old segment
+ bsn 112 old segment
+ bsn 113 old segment
+ bsn 114 old segment
+ bsn 115 old segment
+ bsn 116 old segment
+ bsn 117 old segment
+ bsn 118 old segment
+ bsn 119 old segment
+ bsn 120 old segment
+ bsn 121 old segment
+ bsn 122  bsn 123 old segment
+ bsn 124  bsn 125  bsn 126 old segment
+ bsn 127 old segment
+ bsn 0 old segment
+ bsn 1  bsn 2 old segment
+ bsn 3  bsn 4 null
+ bsn 5  bsn 6 old segment
+ bsn 7 
+lime 0
+end of message reached
+MSG: 0100000035000436b7cfd882fd7f
+
+TS 4 CS4 DL DATA TFI 0 BSN 4 FBI 0 
+fn_same_bsn 5529 fn_last_bsn 30 delta_bsn -3 old_len 0
+duplicate
+
+TS 4 CS4 DL DATA TFI 0 BSN 23 FBI 0 
+fn_same_bsn 5317 fn_last_bsn 86 delta_bsn 16 old_len 49
+ bsn 7 
+lime 0
+ bsn 8 null
+ bsn 9  bsn 10 old segment
+ bsn 11 old segment
+ bsn 12  bsn 13  bsn 14 old segment
+ bsn 15  bsn 16 old segment
+ bsn 17 old segment
+ bsn 18 old segment
+ bsn 19 
+lime 0
+ bsn 20 old segment
+ bsn 21 old segment
+ bsn 22 old segment
+ bsn 23 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS4 DL DATA TFI 0 BSN 23 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 23 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 23 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 25 FBI 0 
+fn_same_bsn 5317 fn_last_bsn 18 delta_bsn 2 old_len 49
+ bsn 19 
+lime 0
+ bsn 20 old segment
+ bsn 21 old segment
+ bsn 22 old segment
+ bsn 23 
+lime 0
+ bsn 24 null
+ bsn 25 
+lime 0
+end of message reached
+MSG: 010402080a1bdb7b6501cbd7ad4c0575
+
+lime 1
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS4 DL DATA TFI 0 BSN 27 FBI 0 
+fn_same_bsn 758 fn_last_bsn 4 delta_bsn 2 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 25 FBI 0 
+fn_same_bsn 8 fn_last_bsn 8 delta_bsn 0 old_len 48
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 28 FBI 0 
+fn_same_bsn 5304 fn_last_bsn 13 delta_bsn 3 old_len 0
+ bsn 19 
+lime 0
+ bsn 20 old segment
+ bsn 21 old segment
+ bsn 22 old segment
+ bsn 23 
+lime 0
+ bsn 24 null
+ bsn 25 
+lime 0
+
+lime 1
+ bsn 26 null
+ bsn 27  bsn 28 
+lime 0
+end of message reached
+MSG: 5472616e736665722d456e636f64696e673a206368756e6b65640d0a436f6e6e656374696f6e3a206b6565702d616c69766543c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS4 DL DATA TFI 0 BSN 28 FBI 0 
+fn_same_bsn 13 fn_last_bsn 13 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 28 FBI 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 28 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 28 FBI 0 
+fn_same_bsn 9 fn_last_bsn 9 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 28 FBI 0 
+fn_same_bsn 17 fn_last_bsn 17 delta_bsn 0 old_len 49
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 30 FBI 0 
+fn_same_bsn 5317 fn_last_bsn 4 delta_bsn 2 old_len 0
+ bsn 19 
+lime 0
+ bsn 20 old segment
+ bsn 21 old segment
+ bsn 22 old segment
+ bsn 23 
+lime 0
+ bsn 24 null
+ bsn 25 
+lime 0
+
+lime 1
+ bsn 26 null
+ bsn 27  bsn 28 
+lime 0
+
+lime error!
+ bsn 29  bsn 30 
+lime 0
+end of message reached
+MSG: 40d486f6b93071160dffd2ad4c133ca892764b19c946f823996fb70573d9939ab7e19c9776447e75551957a5f0ffa3e4e75d960402080aa3c66aa701cbd7b1010303076209bb
+
+lime 1
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 4 CS4 DL DATA TFI 0 BSN 30 FBI 0 
+fn_same_bsn 18 fn_last_bsn 18 delta_bsn 0 old_len 48
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 30 FBI 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 48
+duplicate2
+
+TS 4 CS4 DL DATA TFI 0 BSN 31 FBI 0 
+fn_same_bsn 1478 fn_last_bsn 9 delta_bsn 1 old_len 49
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 32 FBI 0 
+fn_same_bsn 1456 fn_last_bsn 17 delta_bsn 2 old_len 50
+fucking error d_bsn!
+
+TS 4 CS4 DL DATA TFI 0 BSN 31 FBI 0 
+fn_same_bsn 1491 fn_last_bsn 22 delta_bsn 1 old_len 49
+fucking error d_bsn!
+
diff --git a/src/host/gprsdecode/tests/gprs_20160129_1744_878_16846_0c.sample b/src/host/gprsdecode/tests/gprs_20160129_1744_878_16846_0c.sample
new file mode 100644
index 0000000..08f5f45
--- /dev/null
+++ b/src/host/gprsdecode/tests/gprs_20160129_1744_878_16846_0c.sample
Binary files differ
diff --git a/src/host/gprsdecode/tests/gprs_262_80_0001_0000_20110710_2251_875_494777_0f.decoded b/src/host/gprsdecode/tests/gprs_262_80_0001_0000_20110710_2251_875_494777_0f.decoded
new file mode 100644
index 0000000..ea3cf94
--- /dev/null
+++ b/src/host/gprsdecode/tests/gprs_262_80_0001_0000_20110710_2251_875_494777_0f.decoded
@@ -0,0 +1,450 @@
+TS 7 CS2 UL DATA TFI 21 BSN 0 CV 1 
+fn_same_bsn 494819 fn_last_bsn 494819 delta_bsn 0 old_len 0
+clearing TBF 22, first 0 last 0
+new TBF, starting from 0
+ bsn 0 
+TS 7 CS2 UL DATA TFI 21 BSN 1 CV 0 
+fn_same_bsn 494823 fn_last_bsn 4 delta_bsn 1 old_len 0
+ bsn 0  bsn 1 
+lime 0
+end of message reached
+MSG: 01c001080102e5e071070405f41b40072b62f208000100121953422ae57ef909006aa4d594321200d5401716cfabbb
+
+TS 7 CS2 UL DATA TFI 21 BSN 0 CV 1 
+fn_same_bsn 8 fn_last_bsn 4 delta_bsn -1 old_len 30
+duplicate2
+
+TS 7 CS2 UL DATA TFI 21 BSN 1 CV 0 
+fn_same_bsn 9 fn_last_bsn 9 delta_bsn 0 old_len 29
+duplicate2
+
+TS 7 CS2 UL DATA TFI 21 BSN 0 CV 1 
+fn_same_bsn 9 fn_last_bsn 4 delta_bsn -1 old_len 30
+duplicate2
+
+TS 7 CS2 DL DATA TFI 16 BSN 0 FBI 0 
+fn_same_bsn 494866 fn_last_bsn 494866 delta_bsn 0 old_len 0
+clearing TBF 17, first 0 last 0
+new TBF, starting from 0
+ bsn 0 
+lime 0
+end of message reached
+MSG: 01c0010802012a0462f2080001001805f444f70250b6151a
+
+TS 7 CS4 DL DATA TFI 16 BSN 1 FBI 0 
+fn_same_bsn 494897 fn_last_bsn 31 delta_bsn 1 old_len 0
+ bsn 0 
+lime 0
+ bsn 1 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b
+
+lime 1
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 7 CS4 DL DATA TFI 16 BSN 2 FBI 0 
+fn_same_bsn 494914 fn_last_bsn 17 delta_bsn 1 old_len 0
+ bsn 1 
+lime 0
+
+lime 1
+ bsn 2 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 7 CS4 DL DATA TFI 16 BSN 3 FBI 0 
+fn_same_bsn 494936 fn_last_bsn 22 delta_bsn 1 old_len 0
+ bsn 2 
+lime 0
+ bsn 3 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 7 CS4 UL DATA TFI 20 BSN 0 CV 0 
+fn_same_bsn 494953 fn_last_bsn 494953 delta_bsn 0 old_len 0
+clearing TBF 21, first 1 last 1
+ bsn 1 
+lime 0
+new TBF, starting from 0
+ bsn 0 
+lime 0
+end of message reached
+MSG: 01c00508038d8a47
+
+TS 7 CS4 UL DATA TFI 20 BSN 0 CV 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 7 CS4 UL DATA TFI 20 BSN 0 CV 0 
+fn_same_bsn 5 fn_last_bsn 5 delta_bsn 0 old_len 49
+duplicate2
+
+TS 7 CS4 UL DATA TFI 20 BSN 0 CV 0 
+fn_same_bsn 4 fn_last_bsn 4 delta_bsn 0 old_len 49
+duplicate2
+
+TS 7 CS4 DL DATA TFI 16 BSN 4 FBI 0 
+fn_same_bsn 494992 fn_last_bsn 56 delta_bsn 1 old_len 0
+ bsn 3 
+lime 0
+ bsn 4 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 7 CS4 DL DATA TFI 16 BSN 5 FBI 0 
+fn_same_bsn 495009 fn_last_bsn 17 delta_bsn 1 old_len 0
+ bsn 4 
+lime 0
+ bsn 5 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 7 CS4 DL DATA TFI 16 BSN 6 FBI 0 
+fn_same_bsn 495031 fn_last_bsn 22 delta_bsn 1 old_len 0
+ bsn 5 
+lime 0
+ bsn 6 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 7 CS4 UL DATA TFI 19 BSN 0 CV 1 
+fn_same_bsn 495048 fn_last_bsn 495048 delta_bsn 0 old_len 0
+clearing TBF 20, first 0 last 0
+ bsn 0 
+lime 0
+new TBF, starting from 0
+ bsn 0 
+TS 7 CS4 UL DATA TFI 19 BSN 1 CV 0 
+fn_same_bsn 495053 fn_last_bsn 5 delta_bsn 1 old_len 0
+ bsn 0  bsn 1 
+lime 0
+end of message reached
+MSG: 01c0090a4105030e00001f10000000000000000000000201212806056a7564666f272680c0230f0100000f04666a6b640567666a6d668021100100001081060000000083060000000032e5d0
+
+TS 7 CS4 UL DATA TFI 19 BSN 0 CV 1 
+fn_same_bsn 9 fn_last_bsn 4 delta_bsn -1 old_len 50
+duplicate2
+
+TS 7 CS4 UL DATA TFI 19 BSN 1 CV 0 
+fn_same_bsn 8 fn_last_bsn 8 delta_bsn 0 old_len 49
+duplicate2
+
+TS 7 CS4 DL DATA TFI 16 BSN 7 FBI 0 
+fn_same_bsn 495066 fn_last_bsn 35 delta_bsn 1 old_len 0
+ bsn 6 
+lime 0
+ bsn 7 
+TS 7 CS4 UL DATA TFI 19 BSN 0 CV 1 
+fn_same_bsn 9 fn_last_bsn 5 delta_bsn -1 old_len 50
+duplicate2
+
+TS 7 CS4 DL DATA TFI 16 BSN 8 FBI 0 
+fn_same_bsn 495074 fn_last_bsn 8 delta_bsn 1 old_len 0
+ bsn 6 
+lime 0
+ bsn 7  bsn 8 
+lime 0
+end of message reached
+MSG: 01c0058a42030e23621f72993f3f1143ffff000000002b0601210a00000627148080211002000010810608080808830600000000d68800
+
+lime 1
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 7 CS4 DL DATA TFI 16 BSN 9 FBI 0 
+fn_same_bsn 495096 fn_last_bsn 22 delta_bsn 1 old_len 0
+ bsn 8 
+lime 0
+
+lime 1
+ bsn 9 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 7 CS4 DL DATA TFI 16 BSN 10 FBI 0 
+fn_same_bsn 495113 fn_last_bsn 17 delta_bsn 1 old_len 0
+ bsn 9 
+lime 0
+ bsn 10 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 7 CS4 DL DATA TFI 16 BSN 11 FBI 0 
+fn_same_bsn 495131 fn_last_bsn 18 delta_bsn 1 old_len 0
+ bsn 10 
+lime 0
+ bsn 11 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 7 CS4 DL DATA TFI 16 BSN 12 FBI 0 
+fn_same_bsn 495148 fn_last_bsn 17 delta_bsn 1 old_len 0
+ bsn 11 
+lime 0
+ bsn 12 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 7 CS4 DL DATA TFI 16 BSN 13 FBI 0 
+fn_same_bsn 495165 fn_last_bsn 17 delta_bsn 1 old_len 0
+ bsn 12 
+lime 0
+ bsn 13 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 7 CS4 DL DATA TFI 16 BSN 14 FBI 0 
+fn_same_bsn 495183 fn_last_bsn 18 delta_bsn 1 old_len 0
+ bsn 13 
+lime 0
+ bsn 14 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 7 CS4 DL DATA TFI 16 BSN 15 FBI 0 
+fn_same_bsn 495200 fn_last_bsn 17 delta_bsn 1 old_len 0
+ bsn 14 
+lime 0
+ bsn 15 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 7 CS4 DL DATA TFI 16 BSN 16 FBI 0 
+fn_same_bsn 495217 fn_last_bsn 17 delta_bsn 1 old_len 0
+ bsn 15 
+lime 0
+ bsn 16 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 7 CS4 DL DATA TFI 16 BSN 17 FBI 0 
+fn_same_bsn 495235 fn_last_bsn 18 delta_bsn 1 old_len 0
+ bsn 16 
+lime 0
+ bsn 17 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 7 CS4 DL DATA TFI 16 BSN 18 FBI 0 
+fn_same_bsn 495252 fn_last_bsn 17 delta_bsn 1 old_len 0
+ bsn 17 
+lime 0
+ bsn 18 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 7 CS4 DL DATA TFI 16 BSN 19 FBI 0 
+fn_same_bsn 495269 fn_last_bsn 17 delta_bsn 1 old_len 0
+ bsn 18 
+lime 0
+ bsn 19 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 7 CS4 DL DATA TFI 16 BSN 20 FBI 0 
+fn_same_bsn 495287 fn_last_bsn 18 delta_bsn 1 old_len 0
+ bsn 19 
+lime 0
+ bsn 20 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 7 CS4 DL DATA TFI 16 BSN 21 FBI 0 
+fn_same_bsn 495304 fn_last_bsn 17 delta_bsn 1 old_len 0
+ bsn 20 
+lime 0
+ bsn 21 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 7 CS4 DL DATA TFI 16 BSN 22 FBI 0 
+fn_same_bsn 495321 fn_last_bsn 17 delta_bsn 1 old_len 0
+ bsn 21 
+lime 0
+ bsn 22 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 7 CS4 DL DATA TFI 16 BSN 23 FBI 0 
+fn_same_bsn 495339 fn_last_bsn 18 delta_bsn 1 old_len 0
+ bsn 22 
+lime 0
+ bsn 23 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 7 CS4 DL DATA TFI 16 BSN 24 FBI 0 
+fn_same_bsn 495356 fn_last_bsn 17 delta_bsn 1 old_len 0
+ bsn 23 
+lime 0
+ bsn 24 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 7 CS4 DL DATA TFI 16 BSN 25 FBI 0 
+fn_same_bsn 495373 fn_last_bsn 17 delta_bsn 1 old_len 0
+ bsn 24 
+lime 0
+ bsn 25 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 7 CS4 DL DATA TFI 16 BSN 26 FBI 0 
+fn_same_bsn 495391 fn_last_bsn 18 delta_bsn 1 old_len 0
+ bsn 25 
+lime 0
+ bsn 26 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 7 CS4 DL DATA TFI 16 BSN 27 FBI 0 
+fn_same_bsn 495408 fn_last_bsn 17 delta_bsn 1 old_len 0
+ bsn 26 
+lime 0
+ bsn 27 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 7 CS4 DL DATA TFI 16 BSN 28 FBI 0 
+fn_same_bsn 495425 fn_last_bsn 17 delta_bsn 1 old_len 0
+ bsn 27 
+lime 0
+ bsn 28 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 7 CS4 DL DATA TFI 16 BSN 29 FBI 0 
+fn_same_bsn 495443 fn_last_bsn 18 delta_bsn 1 old_len 0
+ bsn 28 
+lime 0
+ bsn 29 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 7 CS4 DL DATA TFI 16 BSN 30 FBI 0 
+fn_same_bsn 495460 fn_last_bsn 17 delta_bsn 1 old_len 0
+ bsn 29 
+lime 0
+ bsn 30 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 7 CS4 DL DATA TFI 16 BSN 31 FBI 0 
+fn_same_bsn 495477 fn_last_bsn 17 delta_bsn 1 old_len 0
+ bsn 30 
+lime 0
+ bsn 31 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 7 CS4 DL DATA TFI 16 BSN 32 FBI 0 
+fn_same_bsn 495495 fn_last_bsn 18 delta_bsn 1 old_len 0
+ bsn 31 
+lime 0
+ bsn 32 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 7 CS4 DL DATA TFI 16 BSN 33 FBI 0 
+fn_same_bsn 495512 fn_last_bsn 17 delta_bsn 1 old_len 0
+ bsn 32 
+lime 0
+ bsn 33 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 7 CS4 DL DATA TFI 16 BSN 34 FBI 0 
+fn_same_bsn 495529 fn_last_bsn 17 delta_bsn 1 old_len 0
+ bsn 33 
+lime 0
+ bsn 34 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 7 CS4 DL DATA TFI 16 BSN 35 FBI 0 
+fn_same_bsn 495547 fn_last_bsn 18 delta_bsn 1 old_len 0
+ bsn 34 
+lime 0
+ bsn 35 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 7 CS4 DL DATA TFI 16 BSN 36 FBI 0 
+fn_same_bsn 495564 fn_last_bsn 17 delta_bsn 1 old_len 0
+ bsn 35 
+lime 0
+ bsn 36 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 7 CS4 DL DATA TFI 16 BSN 37 FBI 0 
+fn_same_bsn 495581 fn_last_bsn 17 delta_bsn 1 old_len 0
+ bsn 36 
+lime 0
+ bsn 37 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 7 CS4 DL DATA TFI 16 BSN 38 FBI 0 
+fn_same_bsn 495599 fn_last_bsn 18 delta_bsn 1 old_len 0
+ bsn 37 
+lime 0
+ bsn 38 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 7 CS4 DL DATA TFI 16 BSN 39 FBI 0 
+fn_same_bsn 495616 fn_last_bsn 17 delta_bsn 1 old_len 0
+ bsn 38 
+lime 0
+ bsn 39 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
+TS 7 CS4 DL DATA TFI 16 BSN 40 FBI 1 
+fn_same_bsn 495620 fn_last_bsn 4 delta_bsn 1 old_len 0
+ bsn 39 
+lime 0
+ bsn 40 
+lime 0
+end of message reached
+MSG: 43c0012b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b2b
+
diff --git a/src/host/gprsdecode/tests/gprs_262_80_0001_0000_20110710_2251_875_494777_0f.sample b/src/host/gprsdecode/tests/gprs_262_80_0001_0000_20110710_2251_875_494777_0f.sample
new file mode 100644
index 0000000..4fe83da
--- /dev/null
+++ b/src/host/gprsdecode/tests/gprs_262_80_0001_0000_20110710_2251_875_494777_0f.sample
Binary files differ

-- 
To view, visit https://gerrit.osmocom.org/5992
To unsubscribe, visit https://gerrit.osmocom.org/settings

Gerrit-MessageType: newpatchset
Gerrit-Change-Id: I12234d37c66b83b8abd60f7511fa1d7837db1856
Gerrit-PatchSet: 2
Gerrit-Project: osmocom-bb
Gerrit-Branch: master
Gerrit-Owner: Max <msuraev at sysmocom.de>
Gerrit-Reviewer: Jenkins Builder
Gerrit-Reviewer: Vadim Yanitskiy <axilirator at gmail.com>
Gerrit-Reviewer: fixeria <axilirator at gmail.com>


More information about the gerrit-log mailing list