From 806b6a95953fcd2d7771e7c10b041d3fa52e0afd Mon Sep 17 00:00:00 2001
From: Cedric Roux <cedric.roux@eurecom.fr>
Date: Wed, 25 May 2016 13:55:37 +0200
Subject: [PATCH] remove remote_old.c

---
 common/utils/T/tracer/Makefile.remote |   3 -
 common/utils/T/tracer/remote_old.c    | 459 --------------------------
 2 files changed, 462 deletions(-)
 delete mode 100644 common/utils/T/tracer/remote_old.c

diff --git a/common/utils/T/tracer/Makefile.remote b/common/utils/T/tracer/Makefile.remote
index e4b2e171af..b6ff0f3cad 100644
--- a/common/utils/T/tracer/Makefile.remote
+++ b/common/utils/T/tracer/Makefile.remote
@@ -5,9 +5,6 @@ CFLAGS=-Wall -g -pthread -DT_TRACER -I.
 
 LIBS=-lX11 -lm -lpng -lXft
 
-tracer_remote: remote_old.o plot.o database.o gui.o utils.o gui/gui.a
-	$(CC) $(CFLAGS) -o tracer_remote $^ $(LIBS)
-
 textlog: utils.o textlog.o database.o event.o handler.o \
          event_selector.o view/view.a gui/gui.a logger/logger.a
 	$(CC) $(CFLAGS) -o textlog $^ $(LIBS)
diff --git a/common/utils/T/tracer/remote_old.c b/common/utils/T/tracer/remote_old.c
deleted file mode 100644
index 8a53e8f89d..0000000000
--- a/common/utils/T/tracer/remote_old.c
+++ /dev/null
@@ -1,459 +0,0 @@
-#include <stdio.h>
-#include <string.h>
-#include <netinet/ip.h>
-#include <arpa/inet.h>
-#include <stdlib.h>
-#include <unistd.h>
-#include <sys/mman.h>
-#include <sys/stat.h>
-#include <fcntl.h>
-#include <math.h>
-#include <pthread.h>
-
-#include "defs.h"
-#include "database.h"
-
-#define DEFAULT_REMOTE_PORT 2020
-
-#define T_ID(x) x
-#include "../T_IDs.h"
-#include "../T_defs.h"
-
-#define BLUE "#0c0c72"
-#define RED "#d72828"
-
-void *ul_plot;
-void *chest_plot;
-void *pusch_iq_plot;
-void *pucch_iq_plot;
-void *pucch_plot;
-
-#define GET fullread
-
-int fullread(int fd, void *_buf, int count)
-{
-  char *buf = _buf;
-  int ret = 0;
-  int l;
-  while (count) {
-    l = read(fd, buf, count);
-    if (l <= 0) { printf("read socket problem\n"); abort(); }
-    count -= l;
-    buf += l;
-    ret += l;
-  }
-  return ret;
-}
-
-int get_connection(char *addr, int port)
-{
-  struct sockaddr_in a;
-  socklen_t alen;
-  int s, t;
-
-  printf("waiting for connection on %s:%d\n", addr, port);
-
-  s = socket(AF_INET, SOCK_STREAM, 0);
-  if (s == -1) { perror("socket"); exit(1); }
-  t = 1;
-  if (setsockopt(s, SOL_SOCKET, SO_REUSEADDR, &t, sizeof(int)))
-    { perror("setsockopt"); exit(1); }
-
-  a.sin_family = AF_INET;
-  a.sin_port = htons(port);
-  a.sin_addr.s_addr = inet_addr(addr);
-
-  if (bind(s, (struct sockaddr *)&a, sizeof(a))) { perror("bind"); exit(1); }
-  if (listen(s, 5)) { perror("bind"); exit(1); }
-  alen = sizeof(a);
-  t = accept(s, (struct sockaddr *)&a, &alen);
-  if (t == -1) { perror("accept"); exit(1); }
-  close(s);
-
-  printf("connected\n");
-
-  return t;
-}
-
-void get_string(int s, char *out)
-{
-  while (1) {
-    if (GET(s, out, 1) != 1) abort();
-    if (*out == 0) break;
-    out++;
-  }
-}
-
-void get_message(int s)
-{
-#define S(x, y) do { \
-    char str[T_BUFFER_MAX]; \
-    get_string(s, str); \
-    printf("["x"]["y"] %s", str); \
-  } while (0)
-
-  int32_t size;
-  int m;
-#ifdef T_SEND_TIME
-  struct timespec t;
-#endif
-  if (GET(s, &size, 4) != 4) abort();
-#ifdef T_SEND_TIME
-  if (GET(s, &t, sizeof(struct timespec)) != sizeof(struct timespec)) abort();
-#endif
-  if (GET(s, &m, sizeof(int)) != sizeof(int)) abort();
-  switch (m) {
-  case T_first: {
-    char str[T_BUFFER_MAX];
-    get_string(s, str);
-    printf("%s", str);
-    break;
-  }
-  case T_LEGACY_MAC_INFO: S("MAC", "INFO"); break;
-  case T_LEGACY_MAC_ERROR: S("MAC", "ERROR"); break;
-  case T_LEGACY_MAC_WARNING: S("MAC", "WARNING"); break;
-  case T_LEGACY_MAC_DEBUG: S("MAC", "DEBUG"); break;
-  case T_LEGACY_MAC_TRACE: S("MAC", "TRACE"); break;
-  case T_LEGACY_PHY_INFO: S("PHY", "INFO"); break;
-  case T_LEGACY_PHY_ERROR: S("PHY", "ERROR"); break;
-  case T_LEGACY_PHY_WARNING: S("PHY", "WARNING"); break;
-  case T_LEGACY_PHY_DEBUG: S("PHY", "DEBUG"); break;
-  case T_LEGACY_PHY_TRACE: S("PHY", "TRACE"); break;
-  case T_LEGACY_S1AP_INFO: S("S1AP", "INFO"); break;
-  case T_LEGACY_S1AP_ERROR: S("S1AP", "ERROR"); break;
-  case T_LEGACY_S1AP_WARNING: S("S1AP", "WARNING"); break;
-  case T_LEGACY_S1AP_DEBUG: S("S1AP", "DEBUG"); break;
-  case T_LEGACY_S1AP_TRACE: S("S1AP", "TRACE"); break;
-  case T_LEGACY_RRC_INFO: S("RRC", "INFO"); break;
-  case T_LEGACY_RRC_ERROR: S("RRC", "ERROR"); break;
-  case T_LEGACY_RRC_WARNING: S("RRC", "WARNING"); break;
-  case T_LEGACY_RRC_DEBUG: S("RRC", "DEBUG"); break;
-  case T_LEGACY_RRC_TRACE: S("RRC", "TRACE"); break;
-  case T_LEGACY_RLC_INFO: S("RLC", "INFO"); break;
-  case T_LEGACY_RLC_ERROR: S("RLC", "ERROR"); break;
-  case T_LEGACY_RLC_WARNING: S("RLC", "WARNING"); break;
-  case T_LEGACY_RLC_DEBUG: S("RLC", "DEBUG"); break;
-  case T_LEGACY_RLC_TRACE: S("RLC", "TRACE"); break;
-  case T_LEGACY_PDCP_INFO: S("PDCP", "INFO"); break;
-  case T_LEGACY_PDCP_ERROR: S("PDCP", "ERROR"); break;
-  case T_LEGACY_PDCP_WARNING: S("PDCP", "WARNING"); break;
-  case T_LEGACY_PDCP_DEBUG: S("PDCP", "DEBUG"); break;
-  case T_LEGACY_PDCP_TRACE: S("PDCP", "TRACE"); break;
-  case T_LEGACY_ENB_APP_INFO: S("ENB_APP", "INFO"); break;
-  case T_LEGACY_ENB_APP_ERROR: S("ENB_APP", "ERROR"); break;
-  case T_LEGACY_ENB_APP_WARNING: S("ENB_APP", "WARNING"); break;
-  case T_LEGACY_ENB_APP_DEBUG: S("ENB_APP", "DEBUG"); break;
-  case T_LEGACY_ENB_APP_TRACE: S("ENB_APP", "TRACE"); break;
-  case T_LEGACY_SCTP_INFO: S("SCTP", "INFO"); break;
-  case T_LEGACY_SCTP_ERROR: S("SCTP", "ERROR"); break;
-  case T_LEGACY_SCTP_WARNING: S("SCTP", "WARNING"); break;
-  case T_LEGACY_SCTP_DEBUG: S("SCTP", "DEBUG"); break;
-  case T_LEGACY_SCTP_TRACE: S("SCTP", "TRACE"); break;
-  case T_LEGACY_UDP__INFO: S("UDP", "INFO"); break;
-  case T_LEGACY_UDP__ERROR: S("UDP", "ERROR"); break;
-  case T_LEGACY_UDP__WARNING: S("UDP", "WARNING"); break;
-  case T_LEGACY_UDP__DEBUG: S("UDP", "DEBUG"); break;
-  case T_LEGACY_UDP__TRACE: S("UDP", "TRACE"); break;
-  case T_LEGACY_NAS_INFO: S("NAS", "INFO"); break;
-  case T_LEGACY_NAS_ERROR: S("NAS", "ERROR"); break;
-  case T_LEGACY_NAS_WARNING: S("NAS", "WARNING"); break;
-  case T_LEGACY_NAS_DEBUG: S("NAS", "DEBUG"); break;
-  case T_LEGACY_NAS_TRACE: S("NAS", "TRACE"); break;
-  case T_LEGACY_HW_INFO: S("HW", "INFO"); break;
-  case T_LEGACY_HW_ERROR: S("HW", "ERROR"); break;
-  case T_LEGACY_HW_WARNING: S("HW", "WARNING"); break;
-  case T_LEGACY_HW_DEBUG: S("HW", "DEBUG"); break;
-  case T_LEGACY_HW_TRACE: S("HW", "TRACE"); break;
-  case T_LEGACY_EMU_INFO: S("EMU", "INFO"); break;
-  case T_LEGACY_EMU_ERROR: S("EMU", "ERROR"); break;
-  case T_LEGACY_EMU_WARNING: S("EMU", "WARNING"); break;
-  case T_LEGACY_EMU_DEBUG: S("EMU", "DEBUG"); break;
-  case T_LEGACY_EMU_TRACE: S("EMU", "TRACE"); break;
-  case T_LEGACY_OTG_INFO: S("OTG", "INFO"); break;
-  case T_LEGACY_OTG_ERROR: S("OTG", "ERROR"); break;
-  case T_LEGACY_OTG_WARNING: S("OTG", "WARNING"); break;
-  case T_LEGACY_OTG_DEBUG: S("OTG", "DEBUG"); break;
-  case T_LEGACY_OTG_TRACE: S("OTG", "TRACE"); break;
-  case T_LEGACY_OCG_INFO: S("OCG", "INFO"); break;
-  case T_LEGACY_OCG_ERROR: S("OCG", "ERROR"); break;
-  case T_LEGACY_OCG_WARNING: S("OCG", "WARNING"); break;
-  case T_LEGACY_OCG_DEBUG: S("OCG", "DEBUG"); break;
-  case T_LEGACY_OCG_TRACE: S("OCG", "TRACE"); break;
-  case T_LEGACY_OCM_INFO: S("OCM", "INFO"); break;
-  case T_LEGACY_OCM_ERROR: S("OCM", "ERROR"); break;
-  case T_LEGACY_OCM_WARNING: S("OCM", "WARNING"); break;
-  case T_LEGACY_OCM_DEBUG: S("OCM", "DEBUG"); break;
-  case T_LEGACY_OCM_TRACE: S("OCM", "TRACE"); break;
-  case T_LEGACY_OMG_INFO: S("OMG", "INFO"); break;
-  case T_LEGACY_OMG_ERROR: S("OMG", "ERROR"); break;
-  case T_LEGACY_OMG_WARNING: S("OMG", "WARNING"); break;
-  case T_LEGACY_OMG_DEBUG: S("OMG", "DEBUG"); break;
-  case T_LEGACY_OMG_TRACE: S("OMG", "TRACE"); break;
-  case T_LEGACY_OIP_INFO: S("OIP", "INFO"); break;
-  case T_LEGACY_OIP_ERROR: S("OIP", "ERROR"); break;
-  case T_LEGACY_OIP_WARNING: S("OIP", "WARNING"); break;
-  case T_LEGACY_OIP_DEBUG: S("OIP", "DEBUG"); break;
-  case T_LEGACY_OIP_TRACE: S("OIP", "TRACE"); break;
-  case T_LEGACY_GTPU_INFO: S("GTPU", "INFO"); break;
-  case T_LEGACY_GTPU_ERROR: S("GTPU", "ERROR"); break;
-  case T_LEGACY_GTPU_WARNING: S("GTPU", "WARNING"); break;
-  case T_LEGACY_GTPU_DEBUG: S("GTPU", "DEBUG"); break;
-  case T_LEGACY_GTPU_TRACE: S("GTPU", "TRACE"); break;
-  case T_LEGACY_TMR_INFO: S("TMR", "INFO"); break;
-  case T_LEGACY_TMR_ERROR: S("TMR", "ERROR"); break;
-  case T_LEGACY_TMR_WARNING: S("TMR", "WARNING"); break;
-  case T_LEGACY_TMR_DEBUG: S("TMR", "DEBUG"); break;
-  case T_LEGACY_TMR_TRACE: S("TMR", "TRACE"); break;
-  case T_LEGACY_OSA_INFO: S("OSA", "INFO"); break;
-  case T_LEGACY_OSA_ERROR: S("OSA", "ERROR"); break;
-  case T_LEGACY_OSA_WARNING: S("OSA", "WARNING"); break;
-  case T_LEGACY_OSA_DEBUG: S("OSA", "DEBUG"); break;
-  case T_LEGACY_OSA_TRACE: S("OSA", "TRACE"); break;
-  case T_LEGACY_component_INFO: S("XXX", "INFO"); break;
-  case T_LEGACY_component_ERROR: S("XXX", "ERROR"); break;
-  case T_LEGACY_component_WARNING: S("XXX", "WARNING"); break;
-  case T_LEGACY_component_DEBUG: S("XXX", "DEBUG"); break;
-  case T_LEGACY_component_TRACE: S("XXX", "TRACE"); break;
-  case T_LEGACY_componentP_INFO: S("XXX", "INFO"); break;
-  case T_LEGACY_componentP_ERROR: S("XXX", "ERROR"); break;
-  case T_LEGACY_componentP_WARNING: S("XXX", "WARNING"); break;
-  case T_LEGACY_componentP_DEBUG: S("XXX", "DEBUG"); break;
-  case T_LEGACY_componentP_TRACE: S("XXX", "TRACE"); break;
-  case T_LEGACY_CLI_INFO: S("CLI", "INFO"); break;
-  case T_LEGACY_CLI_ERROR: S("CLI", "ERROR"); break;
-  case T_LEGACY_CLI_WARNING: S("CLI", "WARNING"); break;
-  case T_LEGACY_CLI_DEBUG: S("CLI", "DEBUG"); break;
-  case T_LEGACY_CLI_TRACE: S("CLI", "TRACE"); break;
-  case T_ENB_INPUT_SIGNAL: {
-    unsigned char buf[T_BUFFER_MAX];
-    int size;
-    int eNB, frame, subframe, antenna;
-    GET(s, &eNB, sizeof(int));
-    GET(s, &frame, sizeof(int));
-    GET(s, &subframe, sizeof(int));
-    GET(s, &antenna, sizeof(int));
-    GET(s, &size, sizeof(int));
-    GET(s, buf, size);
-#if 0
-    printf("got T_ENB_INPUT_SIGNAL eNB %d frame %d subframe %d antenna "
-           "%d size %d %2.2x %2.2x %2.2x %2.2x %2.2x %2.2x %2.2x %2.2x "
-           "%2.2x %2.2x %2.2x %2.2x %2.2x %2.2x %2.2x %2.2x\n",
-           eNB, frame, subframe, antenna, size, buf[0],buf[1],buf[2],
-           buf[3],buf[4],buf[5],buf[6],buf[7],buf[8],buf[9],buf[10],
-           buf[11],buf[12],buf[13],buf[14],buf[15]);
-#endif
-    if (size != 4 * 7680)
-      {printf("bad T_ENB_INPUT_SIGNAL, only 7680 samples allowed "
-              "(received %d bytes = %d samples)\n", size, size/4);abort();}
-    if (ul_plot) iq_plot_set(ul_plot, (short*)buf, 7680, subframe*7680, 0);
-    t_gui_set_input_signal(eNB, frame, subframe, antenna, size, buf);
-    break;
-  }
-  case T_ENB_UL_CHANNEL_ESTIMATE: {
-    unsigned char buf[T_BUFFER_MAX];
-    int size;
-    int eNB, UE, frame, subframe, antenna;
-    GET(s, &eNB, sizeof(int));
-    GET(s, &UE, sizeof(int));
-    GET(s, &frame, sizeof(int));
-    GET(s, &subframe, sizeof(int));
-    GET(s, &antenna, sizeof(int));
-    GET(s, &size, sizeof(int));
-    GET(s, buf, size);
-    if (size != 512*4)
-      {printf("bad T_ENB_UL_CHANNEL_ESTIMATE, only 512 samples allowed\n");
-       abort();}
-    if (chest_plot) iq_plot_set(chest_plot, (short*)buf, 512, 0, 0);
-    break;
-  }
-  case T_PUSCH_IQ: {
-    unsigned char buf[T_BUFFER_MAX];
-    int size;
-    int eNB, UE, frame, subframe, nb_rb;
-    GET(s, &eNB, sizeof(int));
-    GET(s, &UE, sizeof(int));
-    GET(s, &frame, sizeof(int));
-    GET(s, &subframe, sizeof(int));
-    GET(s, &nb_rb, sizeof(int));
-    GET(s, &size, sizeof(int));
-    GET(s, buf, size);
-    if (size != 12*25*14*4)
-      {printf("bad T_PUSCH_IQ, we want 25 RBs and 14 symbols/TTI\n");
-       abort();}
-    if (pusch_iq_plot) {
-      uint32_t *src, *dst;
-      int i, l;
-      dst = (uint32_t*)buf;
-      for (l = 0; l < 14; l++) {
-        src = (uint32_t*)buf + l * 12 * 25;
-        for (i = 0; i < nb_rb*12; i++) *dst++ = *src++;
-      }
-      iq_plot_set_sized(pusch_iq_plot, (short*)buf, nb_rb*12*14, 0);
-    }
-    break;
-  }
-  case T_PUCCH_1AB_IQ: {
-    int eNB, UE, frame, subframe, I, Q;
-    GET(s, &eNB, sizeof(int));
-    GET(s, &UE, sizeof(int));
-    GET(s, &frame, sizeof(int));
-    GET(s, &subframe, sizeof(int));
-    GET(s, &I, sizeof(int));
-    GET(s, &Q, sizeof(int));
-    if (pucch_iq_plot) iq_plot_add_iq_point_loop(pucch_iq_plot,I*10,Q*10, 0);
-    break;
-  }
-  case T_PUCCH_1_ENERGY: {
-    int eNB, UE, frame, subframe, e, t;
-    GET(s, &eNB, sizeof(int));
-    GET(s, &UE, sizeof(int));
-    GET(s, &frame, sizeof(int));
-    GET(s, &subframe, sizeof(int));
-    GET(s, &e, sizeof(int));
-    GET(s, &t, sizeof(int));
-//printf("t %d e %d\n", t, (int)(10*log10(e)));
-    if (pucch_plot) {
-      iq_plot_add_energy_point_loop(pucch_plot, t, 0);
-      iq_plot_add_energy_point_loop(pucch_plot, 10*log10(e), 1);
-    }
-    break;
-  }
-  case T_buf_test: {
-    unsigned char buf[T_BUFFER_MAX];
-    int size;
-    GET(s, &size, sizeof(int));
-    GET(s, buf, size);
-    printf("got buffer size %d %2.2x %2.2x %2.2x %2.2x %2.2x %2.2x %2.2x"
-           " %2.2x %2.2x %2.2x %2.2x %2.2x %2.2x %2.2x %2.2x %2.2x\n",
-           size, buf[0],buf[1],buf[2],buf[3],buf[4],buf[5],buf[6],buf[7],
-           buf[8],buf[9],buf[10],buf[11],buf[12],buf[13],buf[14],buf[15]);
-    break;
-  }
-  default: printf("unkown message type %d\n", m); abort();
-  }
-}
-
-void usage(void)
-{
-  printf(
-"tracer - remote side\n"
-"options:\n"
-"    -d <database file>        this option is mandatory\n"
-"    -li                       print IDs in the database\n"
-"    -lg                       print GROUPs in the database\n"
-"    -dump                     dump the database\n"
-"    -x                        run with XFORMS (revisited)\n"
-"    -T                        run with T GUI\n"
-"    -on <GROUP or ID>         turn log ON for given GROUP or ID\n"
-"    -off <GROUP or ID>        turn log OFF for given GROUP or ID\n"
-"    -ON                       turn all logs ON\n"
-"    -OFF                      turn all logs OFF\n"
-"note: you may pass several -on/-off/-ON/-OFF, they will be processed in order\n"
-"      by default, all is off\n"
-"    -r <port>                 remote side: use given port (default %d)\n",
-  DEFAULT_REMOTE_PORT
-  );
-  exit(1);
-}
-
-int main(int n, char **v)
-{
-  char *database_filename = NULL;
-  void *database;
-  int s;
-  int l;
-  char t;
-  int i;
-  int do_list_ids = 0;
-  int do_list_groups = 0;
-  int do_dump_database = 0;
-  int do_xforms = 0;
-  int do_T_gui = 0;
-  char **on_off_name;
-  int *on_off_action;
-  int on_off_n = 0;
-  int is_on[T_NUMBER_OF_IDS];
-  int port = DEFAULT_REMOTE_PORT;
-
-  memset(is_on, 0, sizeof(is_on));
-
-  on_off_name = malloc(n * sizeof(char *)); if (on_off_name == NULL) abort();
-  on_off_action = malloc(n * sizeof(int)); if (on_off_action == NULL) abort();
-
-  for (i = 1; i < n; i++) {
-    if (!strcmp(v[i], "-h") || !strcmp(v[i], "--help")) usage();
-    if (!strcmp(v[i], "-d"))
-      { if (i > n-2) usage(); database_filename = v[++i]; continue; }
-    if (!strcmp(v[i], "-li")) { do_list_ids = 1; continue; }
-    if (!strcmp(v[i], "-lg")) { do_list_groups = 1; continue; }
-    if (!strcmp(v[i], "-dump")) { do_dump_database = 1; continue; }
-    if (!strcmp(v[i], "-x")) { do_xforms = 1; continue; }
-    if (!strcmp(v[i], "-T")) { do_T_gui = 1; continue; }
-    if (!strcmp(v[i], "-on")) { if (i > n-2) usage();
-      on_off_name[on_off_n]=v[++i]; on_off_action[on_off_n++]=1; continue; }
-    if (!strcmp(v[i], "-off")) { if (i > n-2) usage();
-      on_off_name[on_off_n]=v[++i]; on_off_action[on_off_n++]=0; continue; }
-    if (!strcmp(v[i], "-ON"))
-      { on_off_name[on_off_n]=NULL; on_off_action[on_off_n++]=1; continue; }
-    if (!strcmp(v[i], "-OFF"))
-      { on_off_name[on_off_n]=NULL; on_off_action[on_off_n++]=0; continue; }
-    if (!strcmp(v[i], "-r")) { if (i > n-2) usage();
-      port = atoi(v[++i]); continue; }
-    printf("ERROR: unknown option %s\n", v[i]);
-    usage();
-  }
-
-  /* TODO: setup 'secure' connection with remote part */
-
-  if (database_filename == NULL) {
-    printf("ERROR: provide a database file (-d)\n");
-    exit(1);
-  }
-
-  database = parse_database(database_filename);
-
-  if (do_list_ids + do_list_groups + do_dump_database > 1) usage();
-  if (do_list_ids) { list_ids(database); return 0; }
-  if (do_list_groups) { list_groups(database); return 0; }
-  if (do_dump_database) { dump_database(database); return 0; }
-
-  for (i = 0; i < on_off_n; i++)
-    on_off(database, on_off_name[i], is_on, on_off_action[i]);
-
-  if (do_xforms) {
-    ul_plot = make_plot(512, 100, "UL Input Signal", 1,
-                        7680*10, PLOT_VS_TIME, BLUE);
-    chest_plot = make_plot(512, 100, "UL Channel Estimate UE 0", 1,
-                           512, PLOT_VS_TIME, BLUE);
-    pusch_iq_plot = make_plot(100, 100, "PUSCH IQ", 1,
-                              12*25*14, PLOT_IQ_POINTS, BLUE);
-    pucch_iq_plot = make_plot(100, 100, "PUCCH IQ", 1,
-                              1000, PLOT_IQ_POINTS, BLUE);
-    pucch_plot = make_plot(512, 100, "PUCCH 1 energy (SR)", 2,
-                           /* threshold */
-                           10240, PLOT_MINMAX, RED,
-                           /* pucch 1 */
-                           10240, PLOT_MINMAX, BLUE);
-  }
-  if (do_T_gui) {
-    t_gui_start();
-  }
-
-  s = get_connection("127.0.0.1", port);
-
-  /* send the first message - activate selected traces */
-  t = 0;
-  if (write(s, &t, 1) != 1) abort();
-  l = 0;
-  for (i = 0; i < T_NUMBER_OF_IDS; i++) if (is_on[i]) l++;
-  if (write(s, &l, sizeof(int)) != sizeof(int)) abort();
-  for (l = 0; l < T_NUMBER_OF_IDS; l++)
-    if (is_on[l])
-      if (write(s, &l, sizeof(int)) != sizeof(int)) abort();
-
-  /* read messages */
-  while (1) {
-    get_message(s);
-  }
-  return 0;
-}
-- 
2.26.2