summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMax <msuraev@sysmocom.de>2016-03-24 17:46:19 +0100
committerMax <msuraev@sysmocom.de>2016-05-02 18:38:34 +0200
commit350263350d16751473df785cd0b8249ed2d34ac9 (patch)
tree62be2a73e17cc7b9869eb15b50db8be5c188a3c1
parentd333a0f04e73adaf1e8c020b443af2aa75ecda14 (diff)
Import gprsdecode utility
Add modernized version of gprsdecode: * port to latest libosmocore library * add regression tests The code is based on work of SRLabs available at https://srlabs.de/gprs/
-rw-r--r--src/Makefile8
-rw-r--r--src/host/gprsdecode/.gitignore3
-rw-r--r--src/host/gprsdecode/Makefile15
-rw-r--r--src/host/gprsdecode/README3
-rw-r--r--src/host/gprsdecode/burst_desc.h20
-rw-r--r--src/host/gprsdecode/crc.c148
-rw-r--r--src/host/gprsdecode/crc.h34
-rw-r--r--src/host/gprsdecode/gprs.c357
-rw-r--r--src/host/gprsdecode/gprs.h63
-rw-r--r--src/host/gprsdecode/gprs_20160129_1744_878_16846_0c.decoded6278
-rw-r--r--src/host/gprsdecode/gprs_20160129_1744_878_16846_0c.samplebin0 -> 846200 bytes
-rw-r--r--src/host/gprsdecode/gprs_262_80_0001_0000_20110710_2251_875_494777_0f.decoded450
-rw-r--r--src/host/gprsdecode/gprs_262_80_0001_0000_20110710_2251_875_494777_0f.samplebin0 -> 187450 bytes
-rw-r--r--src/host/gprsdecode/main.c74
-rw-r--r--src/host/gprsdecode/output.c66
-rw-r--r--src/host/gprsdecode/output.h7
-rw-r--r--src/host/gprsdecode/rlcmac.c377
-rw-r--r--src/host/gprsdecode/rlcmac.h44
18 files changed, 7946 insertions, 1 deletions
diff --git a/src/Makefile b/src/Makefile
index cda880f1..214194a2 100644
--- a/src/Makefile
+++ b/src/Makefile
@@ -20,7 +20,7 @@ OSMOCORE_CONFIGURE_ENV= LIBOSMOCORE_LIBS=$(TOPDIR)/shared/libosmocore/build-host
LIBOSMOCODEC_CFLAGS=-I$(TOPDIR)/shared/libosmocore/include
all: libosmocore-target nofirmware firmware mtk-firmware
-nofirmware: libosmocore-host layer23 osmocon gsmmap
+nofirmware: libosmocore-host layer23 osmocon gprsdecode gsmmap
libosmocore-host: shared/libosmocore/build-host/src/.libs/libosmocore.la
@@ -91,6 +91,11 @@ host/layer23/Makefile: host/layer23/configure
host/layer23/layer23: host/layer23/Makefile libosmocore-host
make -C host/layer23
+.PHONY: gprsdecode
+gprsdecode: host/gprsdecode/gprsdecode
+
+host/gprsdecode/gprsdecode:
+ make -C host/gprsdecode
.PHONY: firmware
firmware: libosmocore-target
@@ -106,6 +111,7 @@ clean:
make -C shared/libosmocore/build-target $@
make -C host/layer23 $@
make -C host/osmocon $@
+ make -C host/gprsdecode $@
make -C target/firmware $@
make -C target/firmware -f Makefile.mtk $@
diff --git a/src/host/gprsdecode/.gitignore b/src/host/gprsdecode/.gitignore
new file mode 100644
index 00000000..39141b06
--- /dev/null
+++ b/src/host/gprsdecode/.gitignore
@@ -0,0 +1,3 @@
+bursts*
+*.dat
+gprsdecode
diff --git a/src/host/gprsdecode/Makefile b/src/host/gprsdecode/Makefile
new file mode 100644
index 00000000..43c64897
--- /dev/null
+++ b/src/host/gprsdecode/Makefile
@@ -0,0 +1,15 @@
+default:
+ @echo [CC] $@
+ @gcc -Wall -O3 -pipe -flto -std=gnu99 -g -o gprsdecode main.c gprs.c output.c rlcmac.c crc.c -pthread -losmogsm -losmocore
+
+clean:
+ rm gprsdecode
+
+check: default
+ @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/README b/src/host/gprsdecode/README
new file mode 100644
index 00000000..52fec16f
--- /dev/null
+++ b/src/host/gprsdecode/README
@@ -0,0 +1,3 @@
+GPRS decoder for OsmocomBB
+
+Based on the version from https://srlabs.de/gprs/
diff --git a/src/host/gprsdecode/burst_desc.h b/src/host/gprsdecode/burst_desc.h
new file mode 100644
index 00000000..102b16d1
--- /dev/null
+++ b/src/host/gprsdecode/burst_desc.h
@@ -0,0 +1,20 @@
+#pragma once
+
+#include <stdint.h>
+
+#ifndef __L1CTL_PROTO_H__
+
+#define BI_FLG_DUMMY (1<<4)
+#define BI_FLG_SACCH (1<<5)
+
+struct l1ctl_burst_ind {
+ uint32_t frame_nr;
+ uint16_t band_arfcn; /* ARFCN + band + ul indicator */
+ uint8_t chan_nr; /* GSM 08.58 channel number (9.3.1) */
+ uint8_t flags; /* BI_FLG_xxx + burst_id = 2LSBs */
+ uint8_t rx_level; /* 0 .. 63 in typical GSM notation (dBm+110) */
+ uint8_t snr; /* Reported SNR >> 8 (0-255) */
+ uint8_t bits[15]; /* 114 bits + 2 steal bits. Filled MSB first */
+} __attribute__((packed));
+
+#endif
diff --git a/src/host/gprsdecode/crc.c b/src/host/gprsdecode/crc.c
new file mode 100644
index 00000000..0d5323a8
--- /dev/null
+++ b/src/host/gprsdecode/crc.c
@@ -0,0 +1,148 @@
+/*
+ * Code imported from GNURadio, GSMSTACK and Linux Kernel.
+ */
+
+#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);
+
+int 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;
+
+ return 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 00000000..f04a56b7
--- /dev/null
+++ b/src/host/gprsdecode/crc.h
@@ -0,0 +1,34 @@
+/*
+ * 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
+
+#include <stdint.h>
+
+typedef struct {
+ unsigned int crc_size;
+ unsigned int data_size;
+ unsigned int syn_start;
+ int syndrome_reg[40];
+} FC_CTX;
+
+int 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 00000000..f6df610a
--- /dev/null
+++ b/src/host/gprsdecode/gprs.c
@@ -0,0 +1,357 @@
+#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/gsm/gsm0503.h>
+#include <osmocom/core/crcgen.h>
+
+#include "crc.h"
+#include "gprs.h"
+#include "rlcmac.h"
+
+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 void gsm0503_xcch_deinterleave(sbit_t *cB, sbit_t *iB)
+{
+ int j, B;
+
+ for (int k = 0; k < 456; k++) {
+ B = k & 3;
+ j = 2 * ((49 * k) % 57) + ((k & 7) >> 2);
+ cB[k] = iB[B * 114 + j];
+ }
+}
+
+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 23;
+}
+
+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));
+ gsm0503_xcch_deinterleave((sbit_t *)conv_data, (sbit_t *)bb->data); // FIXME: hack, working with non-soft bits
+ 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 {// 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 00000000..9ca183ed
--- /dev/null
+++ b/src/host/gprsdecode/gprs.h
@@ -0,0 +1,63 @@
+#pragma once
+
+#include <stdint.h>
+#include <stdbool.h>
+
+#include <osmocom/core/conv.h>
+#include <osmocom/core/crcgen.h>
+
+#include "burst_desc.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};
+
+/*
+ * GSM PDTCH CS-2, CS-3, CS-4 parity
+ *
+ * g(x) = x^16 + x^12 + x^5 + 1
+ */
+static const struct osmo_crc16gen_code gsm0503_cs234_crc16 = {
+ .bits = 16,
+ .poly = 0x1021,
+ .init = 0x0000,
+ .remainder = 0xffff,
+};
+
+/*
+ * GSM (SACCH) parity (FIRE code)
+ *
+ * g(x) = (x^23 + 1)(x^17 + x^3 + 1)
+ * = x^40 + x^26 + x^23 + x^17 + x^3 + a1
+ */
+static const struct osmo_crc64gen_code gsm0503_fire_crc40 = {
+ .bits = 40,
+ .poly = 0x0004820009ULL,
+ .init = 0x0000000000ULL,
+ .remainder = 0xffffffffffULL,
+};
+
+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];
+};
+
+struct burst_buf gprs[16];
+
+void gprs_init();
+int process_pdch(struct l1ctl_burst_ind *bi, bool print);
diff --git a/src/host/gprsdecode/gprs_20160129_1744_878_16846_0c.decoded b/src/host/gprsdecode/gprs_20160129_1744_878_16846_0c.decoded
new file mode 100644
index 00000000..7af0753c
--- /dev/null
+++ b/src/host/gprsdecode/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/gprs_20160129_1744_878_16846_0c.sample b/src/host/gprsdecode/gprs_20160129_1744_878_16846_0c.sample
new file mode 100644
index 00000000..08f5f452
--- /dev/null
+++ b/src/host/gprsdecode/gprs_20160129_1744_878_16846_0c.sample
Binary files differ
diff --git a/src/host/gprsdecode/gprs_262_80_0001_0000_20110710_2251_875_494777_0f.decoded b/src/host/gprsdecode/gprs_262_80_0001_0000_20110710_2251_875_494777_0f.decoded
new file mode 100644
index 00000000..ea3cf944
--- /dev/null
+++ b/src/host/gprsdecode/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/gprs_262_80_0001_0000_20110710_2251_875_494777_0f.sample b/src/host/gprsdecode/gprs_262_80_0001_0000_20110710_2251_875_494777_0f.sample
new file mode 100644
index 00000000..4fe83da6
--- /dev/null
+++ b/src/host/gprsdecode/gprs_262_80_0001_0000_20110710_2251_875_494777_0f.sample
Binary files differ
diff --git a/src/host/gprsdecode/main.c b/src/host/gprsdecode/main.c
new file mode 100644
index 00000000..238ae9bd
--- /dev/null
+++ b/src/host/gprsdecode/main.c
@@ -0,0 +1,74 @@
+#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 "burst_desc.h"
+#include "gprs.h"
+#include "output.h"
+
+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 00000000..e14de00a
--- /dev/null
+++ b/src/host/gprsdecode/output.c
@@ -0,0 +1,66 @@
+#include <stdio.h>
+#include <string.h>
+#include <arpa/inet.h>
+#include <osmocom/core/gsmtap.h>
+#include <osmocom/core/gsmtap_util.h>
+
+#include "burst_desc.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 00000000..5709307c
--- /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 00000000..9b7642a0
--- /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 00000000..952fe020
--- /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);