diff options
Diffstat (limited to 'tools')
| -rw-r--r-- | tools/chdr-dissector/packet-chdr.c | 52 | 
1 files changed, 27 insertions, 25 deletions
| diff --git a/tools/chdr-dissector/packet-chdr.c b/tools/chdr-dissector/packet-chdr.c index acacf817d..cce46bb84 100644 --- a/tools/chdr-dissector/packet-chdr.c +++ b/tools/chdr-dissector/packet-chdr.c @@ -1,8 +1,7 @@ -/*  - * packet-chdr.c +/*   * Dissector for UHD CHDR packets   * - * Copyright 2010-2013 Ettus Research LLC + * Copyright 2010-2014 Ettus Research LLC   *   * This program is free software: you can redistribute it and/or modify   * it under the terms of the GNU General Public License as published by @@ -26,13 +25,15 @@  #include <ctype.h>  #include <stdio.h> +#include "../../host/lib/usrp/x300/x300_fw_common.h" +  #define LOG_HEADER  "[UHD CHDR] "  #ifndef min  #define min(a,b)    ((a<b)?a:b)  #endif // min -const unsigned int CHDR_PORT = 49153; +const unsigned int CHDR_PORT = X300_VITA_UDP_PORT;  static int proto_chdr = -1;  static int hf_chdr_hdr = -1; @@ -76,19 +77,19 @@ static gboolean heur_dissect_chdr(tvbuff_t *tvb, packet_info *pinfo, proto_tree          printf(LOG_HEADER"heuristic dissector always returns true!\n");          heur_warning_printed++;      } -    dissect_chdr(tvb, pinfo, tree);  +    dissect_chdr(tvb, pinfo, tree);      return (TRUE);  }  static void byte_swap(guint8 *bytes, gint len)  {      guint8 tmp[4]; -     +      if(len != sizeof(tmp)){          printf(LOG_HEADER"FATAL! number of bytes don't match 32 bit!\n");          return;      } -     +      memcpy(tmp, bytes, sizeof(tmp));      bytes[0] = tmp[3];      bytes[1] = tmp[2]; @@ -101,14 +102,14 @@ static unsigned long long get_timestamp(guint8 *bytes, gint len)      unsigned long long ts;      unsigned long long trans;      int it; -     +      if(len != sizeof(unsigned long long)){          printf(LOG_HEADER"FATAL! timestamps always consist of 64 bits!\n");      } -     +      byte_swap(bytes + 0, 4);      byte_swap(bytes + 4, 4); -     +      ts = 0;      for(it = 0; it < 8; it++){          ts = ts << 8; @@ -122,7 +123,7 @@ static unsigned long long get_timestamp(guint8 *bytes, gint len)  /* The dissector itself */  static void dissect_chdr(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree)  { -    // Here are all the variables    +    // Here are all the variables      proto_item *item;      proto_item *stream_item;      proto_tree *chdr_tree; @@ -132,7 +133,7 @@ static void dissect_chdr(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree)      proto_item *response_item;      proto_tree *response_tree;      gint len; -     +      gint flag_offset;      guint8 *bytes;      gboolean flag_has_time; @@ -142,7 +143,7 @@ static void dissect_chdr(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree)      gint id_pos_usb[4] = {7, 6, 5, 4};      gint id_pos_net[4] = {4, 5, 6, 7};      gint id_pos[4] = {7, 6, 5, 4}; -     +      if(pinfo->match_uint == CHDR_PORT){          is_network = TRUE;          flag_offset = 0; @@ -159,12 +160,13 @@ static void dissect_chdr(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree)      len = tvb_reported_length(tvb);      col_append_str(pinfo->cinfo, COL_PROTOCOL, "/CHDR"); -    col_append_sep_fstr(pinfo->cinfo, COL_INFO, NULL, "CHDR", -        tvb_format_text_wsp(tvb, 0, len)); +    /* This throws a warning: */ +    /*col_append_sep_fstr(pinfo->cinfo, COL_INFO, NULL, "CHDR", tvb_format_text_wsp(tvb, 0, len));*/ +    col_append_sep_fstr(pinfo->cinfo, COL_INFO, NULL, "CHDR");      if (tree){          int chdr_size = -1; -         +          if (len >= 4){              chdr_size = 8;              bytes = tvb_get_string(tvb, 0, 4); @@ -172,13 +174,13 @@ static void dissect_chdr(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree)              if (flag_has_time)                  chdr_size += 8; // 64-bit timestamp          } -         +          /* Start with a top-level item to add everything else to */          item = proto_tree_add_item(tree, proto_chdr, tvb, 0, min(len, chdr_size), ENC_NA); -         +          if (len >= 4){              chdr_tree = proto_item_add_subtree(item, ett_chdr); -             +              header_item = proto_tree_add_item(chdr_tree, hf_chdr_hdr, tvb, flag_offset, 1, endianness);              header_tree = proto_item_add_subtree(header_item, ett_chdr_header); @@ -191,7 +193,7 @@ static void dissect_chdr(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree)              /* These lines add sequence, packet_size and stream ID */              proto_tree_add_item(chdr_tree, hf_chdr_sequence, tvb, (is_network ? 0:2), 2, endianness);              proto_tree_add_item(chdr_tree, hf_chdr_packet_size, tvb, (is_network ? 2:0), 2, endianness); -             +              if (len >= 8){                  /* stream id can be broken down to 4 sections. these are collapsed in a subtree */                  stream_item = proto_tree_add_item(chdr_tree, hf_chdr_stream_id, tvb, 4, 4, endianness); @@ -200,7 +202,7 @@ static void dissect_chdr(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree)                  proto_tree_add_item(stream_tree, hf_chdr_src_ep, tvb, id_pos[1], 1, ENC_NA);                  proto_tree_add_item(stream_tree, hf_chdr_dst_dev, tvb, id_pos[2], 1, ENC_NA);                  proto_tree_add_item(stream_tree, hf_chdr_dst_ep, tvb, id_pos[3], 1, ENC_NA); -                 +                  /* if has_time flag is present interpret timestamp */                  if ((flag_has_time) && (len >= 16)){                      if (is_network) @@ -211,21 +213,21 @@ static void dissect_chdr(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree)                          proto_tree_add_uint64(chdr_tree, hf_chdr_timestamp, tvb, 8, 8, timestamp);                      }                  } -                 +                  int remaining_bytes = (len - chdr_size);                  int show_raw_payload = (remaining_bytes > 0); -                 +                  if (hf_chdr_is_extension){                      if (remaining_bytes == 8){  // Interpret this as a response packet                          response_item = proto_tree_add_item(chdr_tree, hf_chdr_ext_response, tvb, chdr_size, 8, endianness);                          response_tree = proto_item_add_subtree(response_item, ett_chdr_response); -                         +                          proto_tree_add_item(response_tree, hf_chdr_ext_status_code, tvb, chdr_size, 4, endianness);                          /* This will show the 12-bits of sequence ID in the last 2 bytes */                          proto_tree_add_item(response_tree, hf_chdr_ext_seq_num, tvb, (chdr_size + 4 + (is_network ? 2 : 0)), 2, endianness);                      }                  } -                 +                  if (show_raw_payload)                      proto_tree_add_item(chdr_tree, hf_chdr_payload, tvb, chdr_size, -1, ENC_NA);              } | 
