static int hf_fp_channel_type = -1;
static int hf_fp_division = -1;
static int hf_fp_direction = -1;
+static int hf_fp_ddi_config = -1;
+static int hf_fp_ddi_config_ddi = -1;
+static int hf_fp_ddi_config_macd_pdu_size = -1;
+
static int hf_fp_header_crc = -1;
static int hf_fp_ft = -1;
static int hf_fp_cfn = -1;
static int hf_fp_edch_pdu_padding = -1;
static int hf_fp_edch_tsn = -1;
static int hf_fp_edch_mac_es_pdu = -1;
+
+static int hf_fp_edch_user_buffer_size = -1;
+static int hf_fp_edch_no_macid_sdus = -1;
+static int hf_fp_edch_number_of_mac_is_pdus = -1;
+
+static int hf_fp_edch_e_rnti = -1;
+static int hf_fp_edch_macis_descriptors = -1;
+static int hf_fp_edch_macis_lchid = -1;
+static int hf_fp_edch_macis_length = -1;
+static int hf_fp_edch_macis_flag = -1;
+static int hf_fp_edch_macis_tsn = -1;
+static int hf_fp_edch_macis_ss = -1;
+static int hf_fp_edch_macis_sdu = -1;
+
static int hf_fp_frame_seq_nr = -1;
static int hf_fp_hsdsch_pdu_block_header = -1;
static int hf_fp_hsdsch_pdu_block = -1;
static int ett_fp_release = -1;
static int ett_fp_data = -1;
static int ett_fp_crcis = -1;
+static int ett_fp_ddi_config = -1;
static int ett_fp_edch_subframe_header = -1;
static int ett_fp_edch_subframe = -1;
static int ett_fp_edch_maces = -1;
+static int ett_fp_edch_macis_descriptors = -1;
+static int ett_fp_edch_macis_pdu = -1;
static int ett_fp_hsdsch_new_ie_flags = -1;
static int ett_fp_rach_new_ie_flags = -1;
static int ett_fp_hsdsch_pdu_block_header = -1;
static gboolean preferences_show_release_info = TRUE;
-/* E-DCH channel header information */
-struct subframe_info
+/* E-DCH (T1) channel header information */
+struct edch_t1_subframe_info
{
guint8 subframe_number;
guint8 number_of_mac_es_pdus;
guint16 number_of_mac_d_pdus[64];
};
+/* E-DCH (T2) channel header information */
+struct edch_t2_subframe_info
+{
+ guint8 subframe_number;
+ guint8 number_of_mac_is_pdus;
+ guint8 number_of_mac_is_sdus[16];
+ guint8 mac_is_lchid[16][16];
+ guint16 mac_is_length[16][16];
+};
+
+
static const value_string channel_type_vals[] =
{
{ CHANNEL_RACH_FDD, "RACH_FDD" },
{ CHANNEL_IUR_DSCH, "IUR DSCH" },
{ CHANNEL_EDCH, "EDCH" },
{ CHANNEL_RACH_TDD_128, "RACH_TDD_128" },
+ { CHANNEL_HSDSCH_COMMON,"HSDSCH-COMMON" },
+ { CHANNEL_HSDSCH_COMMON_T3,"HSDSCH-COMMON-T3" },
+ { CHANNEL_EDCH_COMMON, "EDCH-COMMON"},
{ 0, NULL }
};
{ 0, NULL }
};
+/* TODO: add and use */
+static const value_string segmentation_status_vals[] = {
+ { 0, "" },
+ { 1, "" },
+ { 2, "" },
+ { 3, "" },
+ { 0, NULL }
+};
+
+static const value_string lchid_vals[] = {
+ { 0, "Logical Channel 1" },
+ { 1, "Logical Channel 2" },
+ { 2, "Logical Channel 3" },
+ { 3, "Logical Channel 4" },
+ { 4, "Logical Channel 5" },
+ { 5, "Logical Channel 6" },
+ { 6, "Logical Channel 7" },
+ { 7, "Logical Channel 8" },
+ { 8, "Logical Channel 9" },
+ { 9, "Logical Channel 10" },
+ { 10, "Logical Channel 11" },
+ { 11, "Logical Channel 12" },
+ { 12, "Logical Channel 13" },
+ { 13, "Logical Channel 14" },
+ { 14, "CCCH (SRB0)" },
+ { 15, "E-RNTI being included (FDD only)" },
+ { 0, NULL }
+};
/* Dedicated control types */
#define DCH_OUTER_LOOP_POWER_CONTROL 1
#define COMMON_TIMING_ADJUSTMENT 2
#define COMMON_DL_SYNCHRONISATION 3
#define COMMON_UL_SYNCHRONISATION 4
-
+
#define COMMON_DL_NODE_SYNCHRONISATION 6
#define COMMON_UL_NODE_SYNCHRONISATION 7
#define COMMON_DYNAMIC_PUSCH_ASSIGNMENT 8
static void dissect_bch_channel_info(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree,
int offset, struct fp_info *p_fp_info);
static void dissect_iur_dsch_channel_info(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree,
- int offset, struct fp_info *p_fp_info _U_);
+ int offset, struct fp_info *p_fp_info);
static void dissect_hsdsch_channel_info(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree,
int offset, struct fp_info *p_fp_info);
static void dissect_hsdsch_type_2_channel_info(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree,
/* Dissect dedicated channels */
static void dissect_e_dch_channel_info(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree,
- int offset, struct fp_info *p_fp_info);
+ int offset, struct fp_info *p_fp_info,
+ gboolean is_common);
+
+static void dissect_e_dch_t2_or_common_channel_info(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree,
+ int offset, struct fp_info *p_fp_info,
+ int number_of_subframes,
+ gboolean is_common);
/* Main dissection function */
static void dissect_fp(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree);
if (tree)
{
/* Add data subtree */
- tree_ti = proto_tree_add_item(tree, hf_fp_data, tvb, offset, -1, FALSE);
+ tree_ti = proto_tree_add_item(tree, hf_fp_data, tvb, offset, -1, ENC_NA);
proto_item_set_text(tree_ti, "TB data for %u chans", p_fp_info->num_chans);
data_tree = proto_item_add_subtree(tree_ti, ett_fp_data);
}
ti = proto_tree_add_item(data_tree, hf_fp_tb, tvb,
offset + (bit_offset/8),
((bit_offset % 8) + p_fp_info->chan_tf_size[chan] + 7) / 8,
- FALSE);
+ ENC_NA);
proto_item_set_text(ti, "TB (chan %u, tb %u, %u bits)",
chan+1, n+1, p_fp_info->chan_tf_size[chan]);
}
/* Add data subtree */
if (tree)
{
- pdus_ti = proto_tree_add_item(tree, hf_fp_data, tvb, offset, -1, FALSE);
+ pdus_ti = proto_tree_add_item(tree, hf_fp_data, tvb, offset, -1, ENC_NA);
proto_item_set_text(pdus_ti, "%u MAC-d PDUs of %u bits", number_of_pdus, length);
data_tree = proto_item_add_subtree(pdus_ti, ett_fp_data);
}
if (data_tree) {
/* Show 4 bits padding at start of PDU */
- proto_tree_add_item(data_tree, hf_fp_hsdsch_data_padding, tvb, offset+(bit_offset/8), 1, FALSE);
+ proto_tree_add_item(data_tree, hf_fp_hsdsch_data_padding, tvb, offset+(bit_offset/8), 1, ENC_BIG_ENDIAN);
}
bit_offset += 4;
pdu_ti = proto_tree_add_item(data_tree, hf_fp_mac_d_pdu, tvb,
offset + (bit_offset/8),
((bit_offset % 8) + length + 7) / 8,
- FALSE);
+ ENC_NA);
proto_item_set_text(pdu_ti, "MAC-d PDU (PDU %u)", pdu+1);
}
if (preferences_call_mac_dissectors) {
proto_item *pdus_ti = NULL;
proto_tree *data_tree = NULL;
int first_offset = offset;
+ gboolean dissected = FALSE;
/* Add data subtree */
if (tree)
{
- pdus_ti = proto_tree_add_item(tree, hf_fp_data, tvb, offset, -1, FALSE);
+ pdus_ti = proto_tree_add_item(tree, hf_fp_data, tvb, offset, -1, ENC_NA);
proto_item_set_text(pdus_ti, "%u MAC-d PDUs of %u bytes", number_of_pdus, length);
data_tree = proto_item_add_subtree(pdus_ti, ett_fp_data);
}
if (data_tree)
{
pdu_ti = proto_tree_add_item(data_tree, hf_fp_mac_d_pdu, tvb,
- offset, length, FALSE);
+ offset, length, ENC_NA);
proto_item_set_text(pdu_ti, "MAC-d PDU (PDU %u)", pdu+1);
+ if (preferences_call_mac_dissectors) {
+ tvbuff_t *next_tvb = tvb_new_subset(tvb, offset, length, -1);
+ call_dissector(mac_fdd_hsdsch_handle, next_tvb, pinfo, top_level_tree);
+ dissected = TRUE;
+ }
}
/* Advance offset */
proto_item_set_len(pdus_ti, offset-first_offset);
/* Show summary in info column */
- col_append_fstr(pinfo->cinfo, COL_INFO, " %u PDUs of %u bits",
- number_of_pdus, length*8);
+ if (!dissected) {
+ col_append_fstr(pinfo->cinfo, COL_INFO, " %u PDUs of %u bits",
+ number_of_pdus, length*8);
+ }
return offset;
}
/* Add CRCIs subtree */
if (tree)
{
- ti = proto_tree_add_item(tree, hf_fp_crcis, tvb, offset, (num_tbs+7)/8, FALSE);
+ ti = proto_tree_add_item(tree, hf_fp_crcis, tvb, offset, (num_tbs+7)/8, ENC_NA);
proto_item_set_text(ti, "CRCI bits for %u tbs", num_tbs);
crcis_tree = proto_item_add_subtree(ti, ett_fp_crcis);
}
{
int bit = (tvb_get_guint8(tvb, offset+(n/8)) >> (7-(n%8))) & 0x01;
proto_tree_add_item(crcis_tree, hf_fp_crci[n%8], tvb, offset+(n/8),
- 1, FALSE);
+ 1, ENC_BIG_ENDIAN);
if (bit == 1)
{
if (remain > crc_size)
{
ti = proto_tree_add_item(tree, hf_fp_spare_extension, tvb,
- offset, remain-crc_size, FALSE);
+ offset, remain-crc_size, ENC_NA);
proto_item_append_text(ti, " (%u octets)", remain-crc_size);
expert_add_info_format(pinfo, ti,
PI_UNDECODED, PI_WARN,
if (crc_size)
{
proto_tree_add_item(tree, hf_fp_payload_crc, tvb, offset, crc_size,
- FALSE);
+ ENC_BIG_ENDIAN);
}
}
/* CFN control */
cfn = tvb_get_guint8(tvb, offset);
- proto_tree_add_item(tree, hf_fp_cfn_control, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_cfn_control, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
/* ToA */
toa = tvb_get_ntohs(tvb, offset);
- proto_tree_add_item(tree, hf_fp_toa, tvb, offset, 2, FALSE);
+ proto_tree_add_item(tree, hf_fp_toa, tvb, offset, 2, ENC_BIG_ENDIAN);
offset += 2;
col_append_fstr(pinfo->cinfo, COL_INFO, " CFN=%u, ToA=%d", cfn, toa);
/* PCH CFN is 12 bits */
cfn = (tvb_get_ntohs(tvb, offset) >> 4);
- proto_tree_add_item(tree, hf_fp_pch_cfn, tvb, offset, 2, FALSE);
+ proto_tree_add_item(tree, hf_fp_pch_cfn, tvb, offset, 2, ENC_BIG_ENDIAN);
offset += 2;
/* 4 bits of padding follow... */
{
/* T1 (3 bytes) */
guint32 t1 = tvb_get_ntoh24(tvb, offset);
- proto_tree_add_item(tree, hf_fp_t1, tvb, offset, 3, FALSE);
+ proto_tree_add_item(tree, hf_fp_t1, tvb, offset, 3, ENC_BIG_ENDIAN);
offset += 3;
col_append_fstr(pinfo->cinfo, COL_INFO, " T1=%u", t1);
/* T1 (3 bytes) */
t1 = tvb_get_ntoh24(tvb, offset);
- proto_tree_add_item(tree, hf_fp_t1, tvb, offset, 3, FALSE);
+ proto_tree_add_item(tree, hf_fp_t1, tvb, offset, 3, ENC_BIG_ENDIAN);
offset += 3;
/* T2 (3 bytes) */
t2 = tvb_get_ntoh24(tvb, offset);
- proto_tree_add_item(tree, hf_fp_t2, tvb, offset, 3, FALSE);
+ proto_tree_add_item(tree, hf_fp_t2, tvb, offset, 3, ENC_BIG_ENDIAN);
offset += 3;
/* T3 (3 bytes) */
t3 = tvb_get_ntoh24(tvb, offset);
- proto_tree_add_item(tree, hf_fp_t3, tvb, offset, 3, FALSE);
+ proto_tree_add_item(tree, hf_fp_t3, tvb, offset, 3, ENC_BIG_ENDIAN);
offset += 3;
col_append_fstr(pinfo->cinfo, COL_INFO, " T1=%u T2=%u, T3=%u",
{
/* CFN control */
cfn = tvb_get_guint8(tvb, offset);
- proto_tree_add_item(tree, hf_fp_cfn_control, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_cfn_control, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
}
else
{
/* PCH CFN is 12 bits */
cfn = (tvb_get_ntohs(tvb, offset) >> 4);
- proto_tree_add_item(tree, hf_fp_pch_cfn, tvb, offset, 2, FALSE);
+ proto_tree_add_item(tree, hf_fp_pch_cfn, tvb, offset, 2, ENC_BIG_ENDIAN);
/* 4 bits of padding follow... */
offset += 2;
/* CFN control */
cfn = tvb_get_guint8(tvb, offset);
- proto_tree_add_item(tree, hf_fp_cfn_control, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_cfn_control, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
/* Timing Advance */
/* CmCH-PI */
priority = (tvb_get_guint8(tvb, offset) & 0x0f);
- proto_tree_add_item(tree, hf_fp_cmch_pi, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_cmch_pi, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
/* User buffer size */
user_buffer_size = tvb_get_ntohs(tvb, offset);
- proto_tree_add_item(tree, hf_fp_user_buffer_size, tvb, offset, 2, FALSE);
+ proto_tree_add_item(tree, hf_fp_user_buffer_size, tvb, offset, 2, ENC_BIG_ENDIAN);
offset += 2;
col_append_fstr(pinfo->cinfo, COL_INFO, " CmCH-PI=%u User-Buffer-Size=%u",
if ((p_fp_info->release == 6) || (p_fp_info->release == 7))
{
proto_tree_add_bits_item(tree, hf_fp_congestion_status, tvb,
- offset*8 + 2, 2, FALSE);
+ offset*8 + 2, 2, ENC_BIG_ENDIAN);
}
/* CmCH-PI */
- proto_tree_add_item(tree, hf_fp_cmch_pi, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_cmch_pi, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
/* Max MAC-d PDU length (13 bits) */
max_pdu_length = tvb_get_ntohs(tvb, offset) >> 3;
- proto_tree_add_item(tree, hf_fp_hsdsch_max_macd_pdu_len, tvb, offset, 2, FALSE);
+ proto_tree_add_item(tree, hf_fp_hsdsch_max_macd_pdu_len, tvb, offset, 2, ENC_BIG_ENDIAN);
offset++;
/* HS-DSCH credits (11 bits) */
ti = proto_tree_add_bits_ret_val(tree, hf_fp_hsdsch_credits, tvb,
- offset*8 + 5, 11, &credits, FALSE);
+ offset*8 + 5, 11, &credits, ENC_BIG_ENDIAN);
offset += 2;
/* Interesting values */
/* HS-DSCH Repetition period */
repetition_period = tvb_get_guint8(tvb, offset);
- ti = proto_tree_add_item(tree, hf_fp_hsdsch_repetition_period, tvb, offset, 1, FALSE);
+ ti = proto_tree_add_item(tree, hf_fp_hsdsch_repetition_period, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
if (repetition_period == 0)
{
/* Calculated and show effective rate enabled */
if (credits == 2047)
{
- rate_ti = proto_tree_add_item(tree, hf_fp_hsdsch_unlimited_rate, tvb, 0, 0, FALSE);
+ rate_ti = proto_tree_add_item(tree, hf_fp_hsdsch_unlimited_rate, tvb, 0, 0, ENC_NA);
PROTO_ITEM_SET_GENERATED(rate_ti);
}
else
/* Congestion status */
proto_tree_add_bits_item(tree, hf_fp_congestion_status, tvb,
- offset*8 + 2, 2, FALSE);
+ offset*8 + 2, 2, ENC_BIG_ENDIAN);
/* CmCH-PI */
- proto_tree_add_item(tree, hf_fp_cmch_pi, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_cmch_pi, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
/* 5 spare bits follow here */
/* Max MAC-d/c PDU length (11 bits) */
max_pdu_length = tvb_get_ntohs(tvb, offset) & 0x7ff;
- proto_tree_add_item(tree, hf_fp_hsdsch_max_macdc_pdu_len, tvb, offset, 2, FALSE);
+ proto_tree_add_item(tree, hf_fp_hsdsch_max_macdc_pdu_len, tvb, offset, 2, ENC_BIG_ENDIAN);
offset += 2;
/* HS-DSCH credits (16 bits) */
/* HS-DSCH Repetition period */
repetition_period = tvb_get_guint8(tvb, offset);
- ti = proto_tree_add_item(tree, hf_fp_hsdsch_repetition_period, tvb, offset, 1, FALSE);
+ ti = proto_tree_add_item(tree, hf_fp_hsdsch_repetition_period, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
if (repetition_period == 0)
{
/* Calculated and show effective rate enabled */
if (credits == 65535)
{
- rate_ti = proto_tree_add_item(tree, hf_fp_hsdsch_unlimited_rate, tvb, 0, 0, FALSE);
+ rate_ti = proto_tree_add_item(tree, hf_fp_hsdsch_unlimited_rate, tvb, 0, 0, ENC_NA);
PROTO_ITEM_SET_GENERATED(rate_ti);
}
else
/* PUSCH Set Id */
pusch_set_id = tvb_get_guint8(tvb, offset);
- proto_tree_add_item(tree, hf_fp_pusch_set_id, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_pusch_set_id, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
/* Activation CFN */
activation_cfn = tvb_get_guint8(tvb, offset);
- proto_tree_add_item(tree, hf_fp_activation_cfn, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_activation_cfn, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
/* Duration */
{
/* Common control frame type */
guint8 control_frame_type = tvb_get_guint8(tvb, offset);
- proto_tree_add_item(tree, hf_fp_common_control_frame_type, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_common_control_frame_type, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
col_append_str(pinfo->cinfo, COL_INFO,
- val_to_str(control_frame_type, common_control_frame_type_vals, "Unknown"));
+ val_to_str_const(control_frame_type, common_control_frame_type_vals, "Unknown"));
/* Frame-type specific dissection */
switch (control_frame_type)
gboolean is_control_frame;
/* Header CRC */
- proto_tree_add_item(tree, hf_fp_header_crc, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_header_crc, tvb, offset, 1, ENC_BIG_ENDIAN);
/* Frame Type */
is_control_frame = tvb_get_guint8(tvb, offset) & 0x01;
- proto_tree_add_item(tree, hf_fp_ft, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_ft, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
col_append_str(pinfo->cinfo, COL_INFO, is_control_frame ? " [Control] " : " [Data] ");
/* CFN */
cfn = tvb_get_guint8(tvb, offset);
- proto_tree_add_item(tree, hf_fp_cfn, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_cfn, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
col_append_fstr(pinfo->cinfo, COL_INFO, "CFN=%03u ", cfn);
/* TFI */
- proto_tree_add_item(tree, hf_fp_tfi, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_tfi, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
if (p_fp_info->channel == CHANNEL_RACH_FDD)
{
/* Rx Timing Deviation */
rx_timing_deviation = tvb_get_guint8(tvb, offset);
- rx_timing_deviation_ti = proto_tree_add_item(tree, hf_fp_rx_timing_deviation, tvb, offset, 1, FALSE);
+ rx_timing_deviation_ti = proto_tree_add_item(tree, hf_fp_rx_timing_deviation, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
}
/* Received SYNC UL Timing Deviation */
received_sync_ul_timing_deviation = tvb_get_guint8(tvb, offset);
received_sync_ul_timing_deviation_ti =
- proto_tree_add_item(tree, hf_fp_received_sync_ul_timing_deviation, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_received_sync_ul_timing_deviation, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
}
{
int n;
guint8 flags;
- guint8 flag_bytes = 0;
+ /* guint8 flag_bytes = 0; */
gboolean cell_portion_id_present = FALSE;
gboolean ext_propagation_delay_present = FALSE;
/* Read next byte */
flags = tvb_get_guint8(tvb, offset);
- flag_bytes++;
+ /* flag_bytes++ */
/* Dissect individual bits */
for (n=0; n < 8; n++)
/* Ext propagation delay */
ext_propagation_delay_present = TRUE;
proto_tree_add_item(new_ie_flags_tree, hf_fp_rach_ext_propagation_delay_present,
- tvb, offset, 1, FALSE);
+ tvb, offset, 1, ENC_BIG_ENDIAN);
break;
case Division_TDD_128:
/* Ext Rx Sync UL Timing */
ext_rx_sync_ul_timing_deviation_present = TRUE;
proto_tree_add_item(new_ie_flags_tree, hf_fp_rach_ext_rx_sync_ul_timing_deviation_present,
- tvb, offset, 1, FALSE);
-
+ tvb, offset, 1, ENC_BIG_ENDIAN);
+
break;
default:
/* Not defined */
- proto_tree_add_item(new_ie_flags_tree, hf_fp_rach_new_ie_flag_unused[n],
- tvb, offset, 1, FALSE);
+ proto_tree_add_item(new_ie_flags_tree, hf_fp_rach_new_ie_flag_unused[6],
+ tvb, offset, 1, ENC_BIG_ENDIAN);
break;
}
break;
/* Cell Portion ID */
cell_portion_id_present = TRUE;
proto_tree_add_item(new_ie_flags_tree, hf_fp_rach_cell_portion_id_present,
- tvb, offset, 1, FALSE);
+ tvb, offset, 1, ENC_BIG_ENDIAN);
break;
case Division_TDD_128:
/* AOA */
angle_of_arrival_present = TRUE;
proto_tree_add_item(new_ie_flags_tree, hf_fp_rach_angle_of_arrival_present,
- tvb, offset, 1, FALSE);
+ tvb, offset, 1, ENC_BIG_ENDIAN);
break;
case Division_TDD_384:
case Division_TDD_768:
/* Extended Rx Timing Deviation */
ext_rx_timing_deviation_present = TRUE;
proto_tree_add_item(new_ie_flags_tree, hf_fp_rach_ext_rx_timing_deviation_present,
- tvb, offset, 1, FALSE);
+ tvb, offset, 1, ENC_BIG_ENDIAN);
break;
}
break;
default:
/* No defined meanings */
+ /* Visual Studio Code Analyzer wrongly thinks n can be 7 here. It can't */
proto_tree_add_item(new_ie_flags_tree, hf_fp_rach_new_ie_flag_unused[n],
- tvb, offset, 1, FALSE);
+ tvb, offset, 1, ENC_BIG_ENDIAN);
break;
}
if ((flags >> (7-n)) & 0x01)
/* Cell Portion ID */
if (cell_portion_id_present) {
- proto_tree_add_item(tree, hf_fp_cell_portion_id, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_cell_portion_id, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
}
case Division_TDD_768:
bits_to_extend = 2;
break;
-
+
default:
/* TODO: report unexpected division type */
bits_to_extend = 1;
" (extended to 0x%x)",
rx_timing_deviation);
proto_tree_add_bits_item(tree, hf_fp_extended_bits, tvb,
- offset*8 + (8-bits_to_extend), bits_to_extend, FALSE);
+ offset*8 + (8-bits_to_extend), bits_to_extend, ENC_BIG_ENDIAN);
offset++;
}
if (ext_propagation_delay_present)
{
guint16 extra_bits = tvb_get_ntohs(tvb, offset) & 0x03ff;
- proto_tree_add_item(tree, hf_fp_ext_propagation_delay, tvb, offset, 2, FALSE);
+ proto_tree_add_item(tree, hf_fp_ext_propagation_delay, tvb, offset, 2, ENC_BIG_ENDIAN);
/* Adding 10 bits to original 8 */
proto_item_append_text(propagation_delay_ti, " (extended to %u)",
/* Angle of Arrival (AOA) */
if (angle_of_arrival_present)
{
- proto_tree_add_item(tree, hf_fp_angle_of_arrival, tvb, offset, 2, FALSE);
+ proto_tree_add_item(tree, hf_fp_angle_of_arrival, tvb, offset, 2, ENC_BIG_ENDIAN);
offset += 2;
}
/* Ext received Sync UL Timing Deviation */
extra_bits = tvb_get_ntohs(tvb, offset) & 0x1fff;
- proto_tree_add_item(tree, hf_fp_ext_received_sync_ul_timing_deviation, tvb, offset, 2, FALSE);
+ proto_tree_add_item(tree, hf_fp_ext_received_sync_ul_timing_deviation, tvb, offset, 2, ENC_BIG_ENDIAN);
/* Adding 13 bits to original 8 */
proto_item_append_text(received_sync_ul_timing_deviation_ti, " (extended to %u)",
gboolean is_control_frame;
/* Header CRC */
- proto_tree_add_item(tree, hf_fp_header_crc, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_header_crc, tvb, offset, 1, ENC_BIG_ENDIAN);
/* Frame Type */
is_control_frame = tvb_get_guint8(tvb, offset) & 0x01;
- proto_tree_add_item(tree, hf_fp_ft, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_ft, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
col_append_str(pinfo->cinfo, COL_INFO, is_control_frame ? " [Control] " : " [Data] ");
/* CFN */
cfn = tvb_get_guint8(tvb, offset);
- proto_tree_add_item(tree, hf_fp_cfn, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_cfn, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
col_append_fstr(pinfo->cinfo, COL_INFO, "CFN=%03u ", cfn);
/* TFI */
- proto_tree_add_item(tree, hf_fp_fach_tfi, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_fach_tfi, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
/* Transmit power level */
if (aoa_present)
{
- proto_tree_add_item(tree, hf_fp_angle_of_arrival, tvb, offset, 2, FALSE);
+ proto_tree_add_item(tree, hf_fp_angle_of_arrival, tvb, offset, 2, ENC_BIG_ENDIAN);
offset += 2;
}
}
gboolean is_control_frame;
/* Header CRC */
- proto_tree_add_item(tree, hf_fp_header_crc, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_header_crc, tvb, offset, 1, ENC_BIG_ENDIAN);
/* Frame Type */
is_control_frame = tvb_get_guint8(tvb, offset) & 0x01;
- proto_tree_add_item(tree, hf_fp_ft, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_ft, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
col_append_str(pinfo->cinfo, COL_INFO, is_control_frame ? " [Control] " : " [Data] ");
/* CFN */
cfn = tvb_get_guint8(tvb, offset);
- proto_tree_add_item(tree, hf_fp_cfn, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_cfn, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
col_append_fstr(pinfo->cinfo, COL_INFO, "CFN=%03u ", cfn);
/* TFI */
- proto_tree_add_item(tree, hf_fp_tfi, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_tfi, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
offset++;
/* Code number */
- proto_tree_add_item(tree, hf_fp_code_number, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_code_number, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
/* Spreading Factor (3 bits) */
- proto_tree_add_item(tree, hf_fp_spreading_factor, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_spreading_factor, tvb, offset, 1, ENC_BIG_ENDIAN);
/* MC info (4 bits)*/
- proto_tree_add_item(tree, hf_fp_mc_info, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_mc_info, tvb, offset, 1, ENC_BIG_ENDIAN);
/* Last bit of this byte is spare */
offset++;
/* Normal case */
/* PDSCH Set Id */
- proto_tree_add_item(tree, hf_fp_pdsch_set_id, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_pdsch_set_id, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
/* Transmit power level */
gboolean is_control_frame;
/* Header CRC */
- proto_tree_add_item(tree, hf_fp_header_crc, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_header_crc, tvb, offset, 1, ENC_BIG_ENDIAN);
/* Frame Type */
is_control_frame = tvb_get_guint8(tvb, offset) & 0x01;
- proto_tree_add_item(tree, hf_fp_ft, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_ft, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
col_append_str(pinfo->cinfo, COL_INFO, is_control_frame ? " [Control] " : " [Data] ");
/* CFN */
cfn = tvb_get_guint8(tvb, offset);
- proto_tree_add_item(tree, hf_fp_cfn, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_cfn, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
col_append_fstr(pinfo->cinfo, COL_INFO, "CFN=%03u ", cfn);
/* TFI */
- proto_tree_add_item(tree, hf_fp_usch_tfi, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_usch_tfi, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
/* Rx Timing Deviation */
rx_timing_deviation = tvb_get_guint8(tvb, offset);
rx_timing_deviation_ti = proto_tree_add_item(tree, hf_fp_rx_timing_deviation,
- tvb, offset, 1, FALSE);
+ tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
/* TB data */
offset = dissect_tb_data(tvb, pinfo, tree, offset, p_fp_info, NULL);
/* QE */
- proto_tree_add_item(tree, hf_fp_quality_estimate, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_quality_estimate, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
/* CRCIs */
gboolean paging_indication;
/* Header CRC */
- proto_tree_add_item(tree, hf_fp_header_crc, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_header_crc, tvb, offset, 1, ENC_BIG_ENDIAN);
/* Frame Type */
is_control_frame = tvb_get_guint8(tvb, offset) & 0x01;
- proto_tree_add_item(tree, hf_fp_ft, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_ft, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
col_append_str(pinfo->cinfo, COL_INFO, is_control_frame ? " [Control] " : " [Data] ");
/* DATA */
/* 12-bit CFN value */
- proto_tree_add_item(tree, hf_fp_pch_cfn, tvb, offset, 2, FALSE);
+ proto_tree_add_item(tree, hf_fp_pch_cfn, tvb, offset, 2, ENC_BIG_ENDIAN);
pch_cfn = (tvb_get_ntohs(tvb, offset) & 0xfff0) >> 4;
offset++;
col_append_fstr(pinfo->cinfo, COL_INFO, "CFN=%04u ", pch_cfn);
/* Paging indication */
- proto_tree_add_item(tree, hf_fp_pch_pi, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_pch_pi, tvb, offset, 1, ENC_BIG_ENDIAN);
paging_indication = tvb_get_guint8(tvb, offset) & 0x01;
offset++;
/* 5-bit TFI */
- proto_tree_add_item(tree, hf_fp_pch_tfi, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_pch_tfi, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
/* Optional paging indications */
ti = proto_tree_add_item(tree, hf_fp_paging_indication_bitmap, tvb,
offset,
(p_fp_info->paging_indications+7) / 8,
- FALSE);
+ ENC_NA);
proto_item_append_text(ti, " (%u bits)", p_fp_info->paging_indications);
offset += ((p_fp_info->paging_indications+7) / 8);
}
gboolean is_control_frame;
/* Header CRC */
- proto_tree_add_item(tree, hf_fp_header_crc, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_header_crc, tvb, offset, 1, ENC_BIG_ENDIAN);
/* Frame Type */
is_control_frame = tvb_get_guint8(tvb, offset) & 0x01;
- proto_tree_add_item(tree, hf_fp_ft, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_ft, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
col_append_str(pinfo->cinfo, COL_INFO, is_control_frame ? " [Control] " : " [Data] ");
/* CFN */
cfn = tvb_get_guint8(tvb, offset);
- proto_tree_add_item(tree, hf_fp_cfn, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_cfn, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
col_append_fstr(pinfo->cinfo, COL_INFO, "CFN=%03u ", cfn);
/* TFI */
- proto_tree_add_item(tree, hf_fp_cpch_tfi, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_cpch_tfi, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
/* Propagation delay */
gboolean is_control_frame;
/* Header CRC */
- proto_tree_add_item(tree, hf_fp_header_crc, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_header_crc, tvb, offset, 1, ENC_BIG_ENDIAN);
/* Frame Type */
is_control_frame = tvb_get_guint8(tvb, offset) & 0x01;
- proto_tree_add_item(tree, hf_fp_ft, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_ft, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
col_append_str(pinfo->cinfo, COL_INFO, is_control_frame ? " [Control] " : " [Data] ");
/********************************/
/* Dissect an IUR DSCH channel */
static void dissect_iur_dsch_channel_info(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree,
- int offset, struct fp_info *p_fp_info _U_)
+ int offset, struct fp_info *p_fp_info)
{
gboolean is_control_frame;
/* Header CRC */
- proto_tree_add_item(tree, hf_fp_header_crc, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_header_crc, tvb, offset, 1, ENC_BIG_ENDIAN);
/* Frame Type */
is_control_frame = tvb_get_guint8(tvb, offset) & 0x01;
- proto_tree_add_item(tree, hf_fp_ft, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_ft, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
col_append_str(pinfo->cinfo, COL_INFO, is_control_frame ? " [Control] " : " [Data] ");
/* CFN control */
control_cfn = tvb_get_guint8(tvb, offset);
- proto_tree_add_item(tree, hf_fp_cfn_control, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_cfn_control, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
/* ToA */
toa = tvb_get_ntohs(tvb, offset);
- toa_ti = proto_tree_add_item(tree, hf_fp_toa, tvb, offset, 2, FALSE);
+ toa_ti = proto_tree_add_item(tree, hf_fp_toa, tvb, offset, 2, ENC_BIG_ENDIAN);
offset += 2;
expert_add_info_format(pinfo, toa_ti,
proto_item *timing_deviation_ti = NULL;
/* CFN control */
- proto_tree_add_item(tree, hf_fp_cfn_control, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_cfn_control, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
/* Rx Timing Deviation */
timing_deviation = tvb_get_guint8(tvb, offset);
- timing_deviation_ti = proto_tree_add_item(tree, hf_fp_dch_rx_timing_deviation, tvb, offset, 1, FALSE);
+ timing_deviation_ti = proto_tree_add_item(tree, hf_fp_dch_rx_timing_deviation, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
/* May be extended in R7, but in this case there are at least 2 bytes remaining */
/* Read flags */
proto_tree_add_bits_ret_val(tree, hf_fp_e_rucch_present, tvb,
- offset*8 + 6, 1, &e_rucch_present, FALSE);
+ offset*8 + 6, 1, &e_rucch_present, ENC_BIG_ENDIAN);
proto_tree_add_bits_ret_val(tree, hf_fp_extended_bits_present, tvb,
- offset*8 + 7, 1, &extended_bits_present, FALSE);
+ offset*8 + 7, 1, &extended_bits_present, ENC_BIG_ENDIAN);
offset++;
/* Optional E-RUCCH */
}
}
- proto_tree_add_item(tree, hf_fp_dch_e_rucch_flag, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_dch_e_rucch_flag, tvb, offset, 1, ENC_BIG_ENDIAN);
proto_tree_add_bits_item(tree, hf_fp_dch_e_rucch_flag, tvb,
- offset*8 + bit_offset, 1, FALSE);
+ offset*8 + bit_offset, 1, ENC_BIG_ENDIAN);
}
/* Timing deviation may be extended by another:
" (extended to 0x%x)",
timing_deviation);
proto_tree_add_bits_item(tree, hf_fp_extended_bits, tvb,
- offset*8 + (8-bits_to_extend), bits_to_extend, FALSE);
+ offset*8 + (8-bits_to_extend), bits_to_extend, ENC_BIG_ENDIAN);
offset++;
}
}
{
/* CFN control */
guint cfn = tvb_get_guint8(tvb, offset);
- proto_tree_add_item(tree, hf_fp_cfn_control, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_cfn_control, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
col_append_fstr(pinfo->cinfo, COL_INFO, " CFN = %u", cfn);
/* CFN control */
cfn = tvb_get_guint8(tvb, offset);
- proto_tree_add_item(tree, hf_fp_cfn_control, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_cfn_control, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
/* ToA */
toa = tvb_get_ntohs(tvb, offset);
- proto_tree_add_item(tree, hf_fp_toa, tvb, offset, 2, FALSE);
+ proto_tree_add_item(tree, hf_fp_toa, tvb, offset, 2, ENC_BIG_ENDIAN);
offset += 2;
col_append_fstr(pinfo->cinfo, COL_INFO, " CFN = %u, ToA = %d",
static int dissect_dch_radio_interface_parameter_update(proto_tree *tree, packet_info *pinfo _U_, tvbuff_t *tvb, int offset)
{
int n;
- guint8 cfn;
guint8 value;
/* Show defined flags in these 2 bytes */
for (n=4; n >= 0; n--)
{
- proto_tree_add_item(tree, hf_fp_radio_interface_parameter_update_flag[n], tvb, offset, 2, FALSE);
+ proto_tree_add_item(tree, hf_fp_radio_interface_parameter_update_flag[n], tvb, offset, 2, ENC_BIG_ENDIAN);
}
offset += 2;
/* CFN */
- cfn = tvb_get_guint8(tvb, offset);
- proto_tree_add_item(tree, hf_fp_cfn, tvb, offset, 1, FALSE);
+ tvb_get_guint8(tvb, offset);
+ proto_tree_add_item(tree, hf_fp_cfn, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
/* DPC mode */
- proto_tree_add_item(tree, hf_fp_dpc_mode, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_dpc_mode, tvb, offset, 1, ENC_BIG_ENDIAN);
/* TPC PO */
- proto_tree_add_item(tree, hf_fp_tpc_po, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_tpc_po, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
/* Multiple RL sets indicator */
- proto_tree_add_item(tree, hf_fp_multiple_rl_set_indicator, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_multiple_rl_set_indicator, tvb, offset, 1, ENC_BIG_ENDIAN);
offset += 2;
/* MAX_UE_TX_POW */
/* CFN control */
cfn = tvb_get_guint8(tvb, offset);
- proto_tree_add_item(tree, hf_fp_cfn_control, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_cfn_control, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
/* Timing Advance */
/* Congestion status */
proto_tree_add_bits_ret_val(tree, hf_fp_congestion_status, tvb,
- offset*8 + 6, 2, &status, FALSE);
+ offset*8 + 6, 2, &status, ENC_BIG_ENDIAN);
offset++;
col_append_fstr(pinfo->cinfo, COL_INFO, " status = %s",
- val_to_str((guint16)status, congestion_status_vals, "unknown"));
+ val_to_str_const((guint16)status, congestion_status_vals, "unknown"));
return offset;
}
{
/* Control frame type */
guint8 control_frame_type = tvb_get_guint8(tvb, offset);
- proto_tree_add_item(tree, hf_fp_dch_control_frame_type, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_dch_control_frame_type, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
col_append_str(pinfo->cinfo, COL_INFO,
- val_to_str(control_frame_type,
- dch_control_frame_type_vals, "Unknown"));
+ val_to_str_const(control_frame_type,
+ dch_control_frame_type_vals, "Unknown"));
switch (control_frame_type)
{
guint8 cfn;
/* Header CRC */
- proto_tree_add_item(tree, hf_fp_header_crc, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_header_crc, tvb, offset, 1, ENC_BIG_ENDIAN);
/* Frame Type */
is_control_frame = tvb_get_guint8(tvb, offset) & 0x01;
- proto_tree_add_item(tree, hf_fp_ft, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_ft, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
col_append_str(pinfo->cinfo, COL_INFO,
int chan;
/* CFN */
- proto_tree_add_item(tree, hf_fp_cfn, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_cfn, tvb, offset, 1, ENC_BIG_ENDIAN);
cfn = tvb_get_guint8(tvb, offset);
offset++;
/* One TFI for each channel */
for (chan=0; chan < p_fp_info->num_chans; chan++)
{
- proto_tree_add_item(tree, hf_fp_tfi, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_tfi, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
}
/* QE (uplink only) */
if (p_fp_info->is_uplink)
{
- proto_tree_add_item(tree, hf_fp_quality_estimate, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_quality_estimate, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
}
/**********************************/
/* Dissect an E-DCH channel */
static void dissect_e_dch_channel_info(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree,
- int offset, struct fp_info *p_fp_info)
+ int offset, struct fp_info *p_fp_info,
+ gboolean is_common)
{
gboolean is_control_frame;
guint8 number_of_subframes;
guint8 cfn;
int n;
- struct subframe_info subframes[16];
+ struct edch_t1_subframe_info subframes[16];
+
+ if (p_fp_info->edch_type == 1) {
+ col_append_str(pinfo->cinfo, COL_INFO, " (T2)");
+ }
/* Header CRC */
- proto_tree_add_item(tree, hf_fp_edch_header_crc, tvb, offset, 2, FALSE);
+ proto_tree_add_item(tree, hf_fp_edch_header_crc, tvb, offset, 2, ENC_BIG_ENDIAN);
/* Frame Type */
is_control_frame = tvb_get_guint8(tvb, offset) & 0x01;
- proto_tree_add_item(tree, hf_fp_ft, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_ft, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
col_append_str(pinfo->cinfo, COL_INFO, is_control_frame ? " [Control] " : " [Data] ");
gboolean dissected = FALSE;
/* FSN */
- proto_tree_add_item(tree, hf_fp_edch_fsn, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_edch_fsn, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
/* Number of subframes.
/* CFN */
cfn = tvb_get_guint8(tvb, offset);
- proto_tree_add_item(tree, hf_fp_cfn, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_cfn, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
+ /* Remainder of T2 or common data frames differ here... */
+ if (p_fp_info->edch_type == 1) {
+ dissect_e_dch_t2_or_common_channel_info(tvb, pinfo, tree, offset, p_fp_info,
+ number_of_subframes, is_common);
+ return;
+ }
+
/* EDCH subframe header list */
for (n=0; n < number_of_subframes; n++)
{
/* Number of HARQ Retransmissions */
proto_tree_add_item(subframe_header_tree, hf_fp_edch_harq_retransmissions, tvb,
- offset, 1, FALSE);
+ offset, 1, ENC_BIG_ENDIAN);
/* Subframe number */
subframes[n].subframe_number = (tvb_get_guint8(tvb, offset) & 0x07);
- proto_tree_add_item(subframe_header_tree, hf_fp_edch_subframe_number, tvb,
- offset, 1, FALSE);
+ proto_tree_add_bits_item(subframe_header_tree, hf_fp_edch_subframe_number, tvb,
+ offset*8+5, 1, ENC_BIG_ENDIAN);
offset++;
/* Number of MAC-es PDUs */
subframes[n].number_of_mac_es_pdus = (tvb_get_guint8(tvb, offset) & 0xf0) >> 4;
proto_tree_add_item(subframe_header_tree, hf_fp_edch_number_of_mac_es_pdus,
- tvb, offset, 1, FALSE);
+ tvb, offset, 1, ENC_BIG_ENDIAN);
bit_offset = 4;
proto_item_append_text(subframe_header_ti, " %u header (%u MAC-es PDUs)",
for (i=0; i < subframes[n].number_of_mac_es_pdus; i++)
{
guint64 ddi;
- int ddi_offset;
guint64 n_pdus;
- int n_pdus_offset;
+ proto_item *ddi_ti;
+ gint ddi_size = -1;
+ int p;
/* DDI (6 bits) */
- ddi_offset = offset + (bit_offset / 8);
+ ddi_ti = proto_tree_add_bits_ret_val(subframe_header_tree, hf_fp_edch_ddi, tvb,
+ offset*8 + bit_offset, 6, &ddi, ENC_BIG_ENDIAN);
- proto_tree_add_bits_ret_val(subframe_header_tree, hf_fp_edch_ddi, tvb,
- offset*8 + bit_offset, 6, &ddi, FALSE);
+ /* Look up the size from this DDI value */
+ for (p=0; p < p_fp_info->no_ddi_entries; p++)
+ {
+ if (ddi == p_fp_info->edch_ddi[p])
+ {
+ ddi_size = p_fp_info->edch_macd_pdu_size[p];
+ break;
+ }
+ }
+ if (ddi_size == -1)
+ {
+ expert_add_info_format(pinfo, ddi_ti,
+ PI_MALFORMED, PI_ERROR,
+ "DDI %u not defined for this UE!", (guint)ddi);
+ return;
+ }
+ else
+ {
+ proto_item_append_text(ddi_ti, " (%d bits)", ddi_size);
+ }
subframes[n].ddi[i] = (guint8)ddi;
bit_offset += 6;
/* Number of MAC-d PDUs (6 bits) */
- n_pdus_offset = offset + (bit_offset / 8);
-
proto_tree_add_bits_ret_val(subframe_header_tree, hf_fp_edch_number_of_mac_d_pdus, tvb,
- offset*8 + bit_offset, 6, &n_pdus, FALSE);
+ offset*8 + bit_offset, 6, &n_pdus, ENC_BIG_ENDIAN);
subframes[n].number_of_mac_d_pdus[i] = (guint8)n_pdus;
bit_offset += 6;
{
int m;
guint16 size = 0;
- guint8 tsn;
+ /* guint8 tsn; */
guint send_size;
proto_item *ti;
int macd_idx;
/* 2 bits spare */
proto_tree_add_item(subframe_tree, hf_fp_edch_pdu_padding, tvb,
offset + (bit_offset/8),
- 1, FALSE);
+ 1, ENC_BIG_ENDIAN);
bit_offset += 2;
/* TSN */
- tsn = (tvb_get_guint8(tvb, offset + (bit_offset/8)) & 0x3f);
+ /* tsn = (tvb_get_guint8(tvb, offset + (bit_offset/8)) & 0x3f); */
proto_tree_add_item(subframe_tree, hf_fp_edch_tsn, tvb,
offset + (bit_offset/8),
- 1, FALSE);
+ 1, ENC_BIG_ENDIAN);
bit_offset += 6;
/* PDU */
ti = proto_tree_add_item(subframe_tree, hf_fp_edch_mac_es_pdu, tvb,
offset + (bit_offset/8),
((bit_offset % 8) + send_size + 7) / 8,
- FALSE);
+ ENC_NA);
proto_item_append_text(ti, " (%u * %u = %u bits, PDU %d)",
size, subframes[n].number_of_mac_d_pdus[i],
send_size, n);
maces_tree = proto_item_add_subtree(ti, ett_fp_edch_maces);
}
for (macd_idx = 0; macd_idx < subframes[n].number_of_mac_d_pdus[i]; macd_idx++) {
-
+
if (preferences_call_mac_dissectors) {
tvbuff_t *next_tvb;
pinfo->fd->subnum = macd_idx; /* set subframe number to current TB */
proto_tree_add_item(maces_tree, hf_fp_mac_d_pdu, tvb,
offset + (bit_offset/8),
((bit_offset % 8) + size + 7) / 8,
- FALSE);
+ ENC_NA);
}
bit_offset += size;
}
}
}
+/* Dissect the remainder of the T2 or common frame that differs from T1 */
+static void dissect_e_dch_t2_or_common_channel_info(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree,
+ int offset, struct fp_info *p_fp_info,
+ int number_of_subframes,
+ gboolean is_common)
+{
+ int n;
+ int pdu_no;
+ static struct edch_t2_subframe_info subframes[16];
+ guint64 total_macis_sdus;
+ guint16 macis_sdus_found = 0;
+ guint16 macis_pdus = 0;
+ guint32 total_bytes = 0;
+ gboolean F = TRUE; /* We want to continue loop if get E-RNTI indication... */
+ proto_item *subframe_macis_descriptors_ti = NULL;
+ gint bit_offset;
+
+ /* User Buffer size */
+ proto_tree_add_bits_item(tree, hf_fp_edch_user_buffer_size, tvb, offset*8,
+ 18, ENC_BIG_ENDIAN);
+ offset += 2;
+
+ /* Spare is in-between... */
+
+ /* Total number of MAC-is SDUs */
+ proto_tree_add_bits_ret_val(tree, hf_fp_edch_no_macid_sdus, tvb, offset*8+4,
+ 12, &total_macis_sdus, ENC_BIG_ENDIAN);
+ offset += 2;
+
+ if (is_common) {
+ /* E-RNTI */
+ proto_tree_add_item(tree, hf_fp_edch_e_rnti, tvb, offset, 2, ENC_BIG_ENDIAN);
+ offset += 2;
+ }
+
+ bit_offset = offset*8;
+ /* EDCH subframe header list */
+ for (n=0; n < number_of_subframes; n++) {
+ guint64 subframe_number;
+ guint64 no_of_macis_pdus;
+ proto_item *subframe_header_ti;
+ proto_tree *subframe_header_tree;
+
+ /* Add subframe header subtree */
+ subframe_header_ti = proto_tree_add_string_format(tree, hf_fp_edch_subframe_header, tvb, offset, 0,
+ "", "Subframe");
+ subframe_header_tree = proto_item_add_subtree(subframe_header_ti, ett_fp_edch_subframe_header);
+
+ /* Spare bit */
+ bit_offset++;
+
+ if (!is_common) {
+ /* Number of HARQ Retransmissions */
+ proto_tree_add_item(subframe_header_tree, hf_fp_edch_harq_retransmissions, tvb,
+ bit_offset/8, 1, ENC_BIG_ENDIAN);
+ bit_offset += 4;
+ }
+
+ /* Subframe number */
+ proto_tree_add_bits_ret_val(subframe_header_tree, hf_fp_edch_subframe_number, tvb,
+ bit_offset, 3, &subframe_number, ENC_BIG_ENDIAN);
+ subframes[n].subframe_number = (guint8)subframe_number;
+ bit_offset += 3;
+
+ /* Number of MAC-is PDUs */
+ proto_tree_add_bits_ret_val(subframe_header_tree, hf_fp_edch_number_of_mac_is_pdus, tvb,
+ bit_offset, 4, &no_of_macis_pdus, ENC_BIG_ENDIAN);
+ bit_offset += 4;
+ subframes[n].number_of_mac_is_pdus = (guint8)no_of_macis_pdus;
+ macis_pdus += subframes[n].number_of_mac_is_pdus;
+
+ /* Next 4 bits are spare for T2*/
+ if (!is_common) {
+ bit_offset += 4;
+ }
+
+ /* Show summary in root */
+ proto_item_append_text(subframe_header_ti, " (SFN %u, %u MAC-is PDUs)",
+ subframes[n].subframe_number, subframes[n].number_of_mac_is_pdus);
+ proto_item_set_len(subframe_header_ti, is_common ? 1 : 2);
+ }
+ offset = bit_offset / 8;
+
+
+ /* MAC-is PDU descriptors for each subframe follow */
+ for (n=0; n < number_of_subframes; n++) {
+ proto_tree *subframe_macis_descriptors_tree;
+
+ /* Add subframe header subtree */
+ subframe_macis_descriptors_ti = proto_tree_add_string_format(tree, hf_fp_edch_macis_descriptors, tvb, offset, 0,
+ "", "MAC-is descriptors (SFN %u)", subframes[n].subframe_number);
+ proto_item_set_len(subframe_macis_descriptors_ti, subframes[n].number_of_mac_is_pdus*2);
+ subframe_macis_descriptors_tree = proto_item_add_subtree(subframe_macis_descriptors_ti,
+ ett_fp_edch_macis_descriptors);
+
+ /* Find a sequence of descriptors for each MAC-is PDU in this subframe */
+ for (pdu_no=0; pdu_no < subframes[n].number_of_mac_is_pdus; pdu_no++) {
+ proto_item *f_ti = NULL;
+
+ subframes[n].number_of_mac_is_sdus[pdu_no] = 0;
+
+ do {
+ /* Check we haven't gone past the limit */
+ if (macis_sdus_found++ > total_macis_sdus) {
+ expert_add_info_format(pinfo, f_ti, PI_MALFORMED, PI_ERROR,
+ "Found too many (%u) MAC-is SDUs - header said there were %u",
+ macis_sdus_found, (guint16)total_macis_sdus);
+ }
+
+ /* LCH-ID */
+ subframes[n].mac_is_lchid[pdu_no][subframes[n].number_of_mac_is_sdus[pdu_no]] = (tvb_get_guint8(tvb, offset) & 0xf0) >> 4;
+ proto_tree_add_item(subframe_macis_descriptors_tree, hf_fp_edch_macis_lchid, tvb, offset, 1, ENC_BIG_ENDIAN);
+ if (subframes[n].mac_is_lchid[pdu_no][subframes[n].number_of_mac_is_sdus[pdu_no]] == 15) {
+ proto_item *ti;
+
+ /* 4 bits of spare */
+ offset++;
+
+ /* E-RNTI */
+ ti = proto_tree_add_item(tree, hf_fp_edch_e_rnti, tvb, offset, 2, ENC_BIG_ENDIAN);
+ offset += 2;
+
+ /* This is only allowed if:
+ - its the common case AND
+ - its the first descriptor */
+ if (!is_common) {
+ expert_add_info_format(pinfo, ti,
+ PI_MALFORMED, PI_ERROR,
+ "E-RNTI not supposed to appear for T2 EDCH frames");
+ }
+ if (subframes[n].number_of_mac_is_sdus[pdu_no] > 0) {
+ expert_add_info_format(pinfo, ti,
+ PI_MALFORMED, PI_ERROR,
+ "E-RNTI must be first entry among descriptors");
+ }
+ continue;
+ }
+
+ /* Length */
+ subframes[n].mac_is_length[pdu_no][subframes[n].number_of_mac_is_sdus[pdu_no]] = (tvb_get_ntohs(tvb, offset) & 0x0ffe) >> 1;
+ proto_tree_add_item(subframe_macis_descriptors_tree, hf_fp_edch_macis_length, tvb, offset, 2, ENC_BIG_ENDIAN);
+ offset++;
+
+ /* Flag */
+ F = tvb_get_guint8(tvb, offset) & 0x01;
+ f_ti = proto_tree_add_item(subframe_macis_descriptors_tree, hf_fp_edch_macis_flag, tvb, offset, 1, ENC_BIG_ENDIAN);
+
+ subframes[n].number_of_mac_is_sdus[pdu_no]++;
+
+ offset++;
+ } while (F == 0);
+ }
+ }
+
+ /* Check overall count of MAC-is SDUs */
+ if (macis_sdus_found != total_macis_sdus) {
+ expert_add_info_format(pinfo, subframe_macis_descriptors_ti, PI_MALFORMED, PI_ERROR,
+ "Frame contains %u MAC-is SDUs - header said there would be %u!",
+ macis_sdus_found, (guint16)total_macis_sdus);
+ }
+
+ /* Now PDUs */
+ for (n=0; n < number_of_subframes; n++) {
+
+ /* MAC-is PDU */
+ for (pdu_no=0; pdu_no < subframes[n].number_of_mac_is_pdus; pdu_no++) {
+ int sdu_no;
+ guint8 ss, tsn;
+ guint32 subframe_bytes = 0;
+ proto_item *ti;
+
+ proto_item *macis_pdu_ti;
+ proto_tree *macis_pdu_tree;
+
+ /* Add subframe header subtree */
+ macis_pdu_ti = proto_tree_add_string_format(tree, hf_fp_edch_subframe_header, tvb, offset, 0,
+ "", "MAC-is PDU (SFN=%u PDU %u)",
+ subframes[n].subframe_number, pdu_no+1);
+ macis_pdu_tree = proto_item_add_subtree(macis_pdu_ti, ett_fp_edch_macis_pdu);
+
+
+ /* SS */
+ ss = (tvb_get_guint8(tvb, offset) & 0xc0) >> 6;
+ proto_tree_add_item(macis_pdu_tree, hf_fp_edch_macis_ss, tvb, offset, 1, ENC_BIG_ENDIAN);
+
+ /* TSN */
+ tsn = tvb_get_guint8(tvb, offset) & 0x03;
+ proto_tree_add_item(macis_pdu_tree, hf_fp_edch_macis_tsn, tvb, offset, 1, ENC_BIG_ENDIAN);
+
+ offset++;
+
+ /* MAC-is SDUs (i.e. MACd PDUs) */
+ for (sdu_no=0; sdu_no < subframes[n].number_of_mac_is_sdus[pdu_no]; sdu_no++) {
+
+ ti = proto_tree_add_item(macis_pdu_tree, hf_fp_edch_macis_sdu, tvb,
+ offset,
+ subframes[n].mac_is_length[pdu_no][sdu_no],
+ ENC_NA);
+ proto_item_append_text(ti, " (%s Len=%u): %s",
+ val_to_str_const(subframes[n].mac_is_lchid[pdu_no][sdu_no], lchid_vals, "Unknown"),
+ subframes[n].mac_is_length[pdu_no][sdu_no],
+ tvb_bytes_to_str(tvb, offset, subframes[n].mac_is_length[pdu_no][sdu_no]));
+
+ offset += subframes[n].mac_is_length[pdu_no][sdu_no];
+ subframe_bytes += subframes[n].mac_is_length[pdu_no][sdu_no];
+ }
+
+ proto_item_append_text(macis_pdu_ti, " - SS=%u TSN=%u (%u bytes in %u SDUs)",
+ ss, tsn, subframe_bytes, subframes[n].number_of_mac_is_sdus[pdu_no]);
+
+ proto_item_set_len(macis_pdu_ti, 1+subframe_bytes);
+ total_bytes += subframe_bytes;
+ }
+ }
+
+ /* Add data summary to info column */
+ col_append_fstr(pinfo->cinfo, COL_INFO, " (%u bytes in %u SDUs in %u MAC-is PDUs in %u subframes)",
+ total_bytes, macis_sdus_found, macis_pdus, number_of_subframes);;
+
+ /* Spare extension and payload CRC (optional) */
+ dissect_spare_extension_and_crc(tvb, pinfo, tree,
+ p_fp_info->dch_crc_present, offset);
+}
+
/**********************************************************/
/* Dissect an HSDSCH channel */
gboolean is_control_frame;
/* Header CRC */
- proto_tree_add_item(tree, hf_fp_header_crc, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_header_crc, tvb, offset, 1, ENC_BIG_ENDIAN);
/* Frame Type */
is_control_frame = tvb_get_guint8(tvb, offset) & 0x01;
- proto_tree_add_item(tree, hf_fp_ft, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_ft, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
col_append_str(pinfo->cinfo, COL_INFO, is_control_frame ? " [Control] " : " [Data] ");
(p_fp_info->release == 7))
{
guint8 frame_seq_no = (tvb_get_guint8(tvb, offset) & 0xf0) >> 4;
- proto_tree_add_item(tree, hf_fp_frame_seq_nr, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_frame_seq_nr, tvb, offset, 1, ENC_BIG_ENDIAN);
col_append_fstr(pinfo->cinfo, COL_INFO, " seqno=%u", frame_seq_no);
}
/* CmCH-PI */
- proto_tree_add_item(tree, hf_fp_cmch_pi, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_cmch_pi, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
/* MAC-d PDU Length (13 bits) */
pdu_length = (tvb_get_ntohs(tvb, offset) >> 3);
- proto_tree_add_item(tree, hf_fp_mac_d_pdu_len, tvb, offset, 2, FALSE);
+ proto_tree_add_item(tree, hf_fp_mac_d_pdu_len, tvb, offset, 2, ENC_BIG_ENDIAN);
offset += 2;
if ((p_fp_info->release == 6) ||
(p_fp_info->release == 7))
{
/* Flush bit */
- proto_tree_add_item(tree, hf_fp_flush, tvb, offset-1, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_flush, tvb, offset-1, 1, ENC_BIG_ENDIAN);
/* FSN/DRT reset bit */
- proto_tree_add_item(tree, hf_fp_fsn_drt_reset, tvb, offset-1, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_fsn_drt_reset, tvb, offset-1, 1, ENC_BIG_ENDIAN);
}
/* Num of PDUs */
number_of_pdus = tvb_get_guint8(tvb, offset);
- proto_tree_add_item(tree, hf_fp_num_of_pdu, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_num_of_pdu, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
/* User buffer size */
user_buffer_size = tvb_get_ntohs(tvb, offset);
- proto_tree_add_item(tree, hf_fp_user_buffer_size, tvb, offset, 2, FALSE);
+ proto_tree_add_item(tree, hf_fp_user_buffer_size, tvb, offset, 2, ENC_BIG_ENDIAN);
offset += 2;
/* MAC-d PDUs */
{
int n;
guint8 flags;
- guint8 flag_bytes = 0;
+ /* guint8 flag_bytes = 0; */
/* New IE flags */
do
/* Read next byte */
flags = tvb_get_guint8(tvb, offset);
- flag_bytes++;
+ /* flag_bytes++; */
/* Dissect individual bits */
for (n=0; n < 8; n++)
{
- proto_tree_add_item(new_ie_flags_tree, hf_fp_hsdsch_new_ie_flag[n], tvb, offset, 1, FALSE);
+ proto_tree_add_item(new_ie_flags_tree, hf_fp_hsdsch_new_ie_flag[n], tvb, offset, 1, ENC_BIG_ENDIAN);
if ((flags >> (7-n)) & 0x01)
{
ies_found++;
but the description below it states that
it should depend upon the first bit. The detailed description of
New IE flags doesn't agree, so treat as mandatory for now... */
- proto_tree_add_item(tree, hf_fp_hsdsch_drt, tvb, offset, 2, FALSE);
+ proto_tree_add_item(tree, hf_fp_hsdsch_drt, tvb, offset, 2, ENC_BIG_ENDIAN);
offset += 2;
}
}
gboolean is_control_frame;
/* Header CRC */
- proto_tree_add_item(tree, hf_fp_header_crc, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_header_crc, tvb, offset, 1, ENC_BIG_ENDIAN);
/* Frame Type */
is_control_frame = tvb_get_guint8(tvb, offset) & 0x01;
- proto_tree_add_item(tree, hf_fp_ft, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_ft, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
col_append_str(pinfo->cinfo, COL_INFO, is_control_frame ? " [Control] " : " [Data] ");
(p_fp_info->release == 7))
{
guint8 frame_seq_no = (tvb_get_guint8(tvb, offset) & 0xf0) >> 4;
- proto_tree_add_item(tree, hf_fp_frame_seq_nr, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_frame_seq_nr, tvb, offset, 1, ENC_BIG_ENDIAN);
col_append_fstr(pinfo->cinfo, COL_INFO, " seqno=%u", frame_seq_no);
}
/* CmCH-PI (4 bits) */
- proto_tree_add_item(tree, hf_fp_cmch_pi, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_cmch_pi, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
/* Total number of PDU blocks (5 bits) */
number_of_pdu_blocks = (tvb_get_guint8(tvb, offset) >> 3);
- proto_tree_add_item(tree, hf_fp_total_pdu_blocks, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_total_pdu_blocks, tvb, offset, 1, ENC_BIG_ENDIAN);
if (p_fp_info->release == 7)
{
/* Flush bit */
- proto_tree_add_item(tree, hf_fp_flush, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_flush, tvb, offset, 1, ENC_BIG_ENDIAN);
/* FSN/DRT reset bit */
- proto_tree_add_item(tree, hf_fp_fsn_drt_reset, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_fsn_drt_reset, tvb, offset, 1, ENC_BIG_ENDIAN);
/* DRT Indicator */
drt_present = tvb_get_guint8(tvb, offset) & 0x01;
- proto_tree_add_item(tree, hf_fp_drt_indicator, tvb, offset, 1, FALSE);
+ proto_tree_add_item(tree, hf_fp_drt_indicator, tvb, offset, 1, ENC_BIG_ENDIAN);
}
offset++;
/* FACH Indicator flag */
- fach_present = (tvb_get_guint8(tvb, offset) & 0x08) >> 7;
- proto_tree_add_item(tree, hf_fp_fach_indicator, tvb, offset, 1, FALSE);
+ fach_present = (tvb_get_guint8(tvb, offset) & 0x80) >> 7;
+ proto_tree_add_item(tree, hf_fp_fach_indicator, tvb, offset, 1, ENC_BIG_ENDIAN);
offset++;
/* User buffer size */
user_buffer_size = tvb_get_ntohs(tvb, offset);
- proto_tree_add_item(tree, hf_fp_user_buffer_size, tvb, offset, 2, FALSE);
+ proto_tree_add_item(tree, hf_fp_user_buffer_size, tvb, offset, 2, ENC_BIG_ENDIAN);
offset += 2;
col_append_fstr(pinfo->cinfo, COL_INFO, " User-Buffer-Size=%u", user_buffer_size);
/* MAC-d/c PDU length in this block (11 bits) */
proto_tree_add_bits_ret_val(pdu_block_header_tree, hf_fp_pdu_length_in_block, tvb,
(offset*8) + ((n % 2) ? 4 : 0), 11,
- &pdu_length[n], FALSE);
+ &pdu_length[n], ENC_BIG_ENDIAN);
if ((n % 2) == 0)
offset++;
else
/* # PDUs in this block (4 bits) */
proto_tree_add_bits_ret_val(pdu_block_header_tree, hf_fp_pdus_in_block, tvb,
(offset*8) + ((n % 2) ? 0 : 4), 4,
- &no_of_pdus[n], FALSE);
+ &no_of_pdus[n], ENC_BIG_ENDIAN);
if ((n % 2) == 0) {
offset++;
}
/* Logical channel ID in block (4 bits) */
proto_tree_add_bits_ret_val(pdu_block_header_tree, hf_fp_lchid, tvb,
(offset*8) + ((n % 2) ? 4 : 0), 4,
- &lchid[n], FALSE);
+ &lchid[n], ENC_BIG_ENDIAN);
if ((n % 2) == 1) {
offset++;
}
if (drt_present)
{
/* DRT */
- proto_tree_add_item(tree, hf_fp_drt, tvb, offset, 2, FALSE);
+ proto_tree_add_item(tree, hf_fp_drt, tvb, offset, 2, ENC_BIG_ENDIAN);
offset += 2;
}
if (fach_present)
{
/* H-RNTI: */
- proto_tree_add_item(tree, hf_fp_hrnti, tvb, offset, 2, FALSE);
+ proto_tree_add_item(tree, hf_fp_hrnti, tvb, offset, 2, ENC_BIG_ENDIAN);
offset += 2;
/* RACH Measurement Result */
- proto_tree_add_item(tree, hf_fp_rach_measurement_result, tvb, offset, 2, FALSE);
+ proto_tree_add_item(tree, hf_fp_rach_measurement_result, tvb, offset, 2, ENC_BIG_ENDIAN);
offset++;
}
if (!p_fp_info->srcport || !p_fp_info->destport) {
p_fp_info->srcport = pinfo->srcport;
p_fp_info->destport = pinfo->destport;
- }
+ }
/* discriminate 'lower' UDP layer from 'user data' UDP layer
* (i.e. if an FP over UDP packet contains a user UDP packet */
col_set_str(pinfo->cinfo, COL_PROTOCOL, "FP");
/* Create fp tree. */
- ti = proto_tree_add_item(tree, proto_fp, tvb, offset, -1, FALSE);
+ ti = proto_tree_add_item(tree, proto_fp, tvb, offset, -1, ENC_NA);
fp_tree = proto_item_add_subtree(ti, ett_fp);
top_level_tree = tree;
proto_tree *release_tree;
proto_item *temp_ti;
- release_ti = proto_tree_add_item(fp_tree, hf_fp_release, tvb, 0, 0, FALSE);
+ release_ti = proto_tree_add_item(fp_tree, hf_fp_release, tvb, 0, 0, ENC_NA);
PROTO_ITEM_SET_GENERATED(release_ti);
proto_item_append_text(release_ti, " R%u (%d/%d)",
p_fp_info->release, p_fp_info->release_year, p_fp_info->release_month);
/* Show channel type in info column, tree */
col_add_str(pinfo->cinfo, COL_INFO,
- val_to_str(p_fp_info->channel,
- channel_type_vals,
- "Unknown channel type"));
+ val_to_str_const(p_fp_info->channel,
+ channel_type_vals,
+ "Unknown channel type"));
proto_item_append_text(ti, " (%s)",
- val_to_str(p_fp_info->channel,
- channel_type_vals,
- "Unknown channel type"));
+ val_to_str_const(p_fp_info->channel,
+ channel_type_vals,
+ "Unknown channel type"));
/* Add channel type as a generated field */
ti = proto_tree_add_uint(fp_tree, hf_fp_channel_type, tvb, 0, 0, p_fp_info->channel);
return;
}
+ /* Show DDI config info */
+ if (p_fp_info->no_ddi_entries > 0) {
+ int n;
+ proto_item *ddi_config_ti;
+ proto_tree *ddi_config_tree;
+
+ ddi_config_ti = proto_tree_add_string_format(fp_tree, hf_fp_ddi_config, tvb, offset, 0,
+ "", "DDI Config (");
+ PROTO_ITEM_SET_GENERATED(ddi_config_ti);
+ ddi_config_tree = proto_item_add_subtree(ddi_config_ti, ett_fp_ddi_config);
+
+ /* Add each entry */
+ for (n=0; n < p_fp_info->no_ddi_entries; n++) {
+ proto_item_append_text(ddi_config_ti, "%s%u->%ubits",
+ (n==0) ? "" : " ",
+ p_fp_info->edch_ddi[n], p_fp_info->edch_macd_pdu_size[n]);
+ ti = proto_tree_add_uint(ddi_config_tree, hf_fp_ddi_config_ddi, tvb, 0, 0,
+ p_fp_info->edch_ddi[n]);
+ PROTO_ITEM_SET_GENERATED(ti);
+ ti = proto_tree_add_uint(ddi_config_tree, hf_fp_ddi_config_macd_pdu_size, tvb, 0, 0,
+ p_fp_info->edch_macd_pdu_size[n]);
+ PROTO_ITEM_SET_GENERATED(ti);
+
+ }
+ proto_item_append_text(ddi_config_ti, ")");
+ }
+
/*************************************/
/* Dissect according to channel type */
switch (p_fp_info->channel)
break;
}
break;
+ case CHANNEL_HSDSCH_COMMON:
+ /* TODO: */
+ break;
+ case CHANNEL_HSDSCH_COMMON_T3:
+ /* TODO: */
+ break;
case CHANNEL_IUR_CPCHF:
/* TODO: */
break;
dissect_iur_dsch_channel_info(tvb, pinfo, fp_tree, offset, p_fp_info);
break;
case CHANNEL_EDCH:
- dissect_e_dch_channel_info(tvb, pinfo, fp_tree, offset, p_fp_info);
+ case CHANNEL_EDCH_COMMON:
+ dissect_e_dch_channel_info(tvb, pinfo, fp_tree, offset, p_fp_info,
+ p_fp_info->channel == CHANNEL_EDCH_COMMON);
break;
default:
"Link direction", HFILL
}
},
+ { &hf_fp_ddi_config,
+ { "DDI Config",
+ "fp.ddi-config", FT_STRING, BASE_NONE, NULL, 0x0,
+ "DDI Config (for E-DCH)", HFILL
+ }
+ },
+ { &hf_fp_ddi_config_ddi,
+ { "DDI",
+ "fp.ddi-config.ddi", FT_UINT8, BASE_DEC, NULL, 0x0,
+ NULL, HFILL
+ }
+ },
+ { &hf_fp_ddi_config_macd_pdu_size,
+ { "MACd PDU Size",
+ "fp.ddi-config.macd-pdu-size", FT_UINT16, BASE_DEC, NULL, 0x0,
+ NULL, HFILL
+ }
+ },
+
+
{ &hf_fp_header_crc,
{ "Header CRC",
"fp.header-crc", FT_UINT8, BASE_HEX, NULL, 0xfe,
},
{ &hf_fp_edch_header_crc,
{ "E-DCH Header CRC",
- "fp.edch.header-crc", FT_UINT16, BASE_HEX, 0, 0xfef,
+ "fp.edch.header-crc", FT_UINT16, BASE_HEX, 0, 0xfef0,
NULL, HFILL
}
},
},
{ &hf_fp_edch_subframe_number,
{ "Subframe number",
- "fp.edch.subframe-number", FT_UINT8, BASE_DEC, 0, 0x07,
+ "fp.edch.subframe-number", FT_UINT8, BASE_DEC, 0, 0x0,
"E-DCH Subframe number", HFILL
}
},
NULL, HFILL
}
},
+
+ { &hf_fp_edch_user_buffer_size,
+ { "User Buffer Size",
+ "fp.edch.user-buffer-size", FT_UINT24, BASE_DEC, NULL, 0x0,
+ NULL, HFILL
+ }
+ },
+ { &hf_fp_edch_no_macid_sdus,
+ { "No of MAC-is SDUs",
+ "fp.edch.no-macis-sdus", FT_UINT16, BASE_DEC, NULL, 0x0,
+ NULL, HFILL
+ }
+ },
+ { &hf_fp_edch_number_of_mac_is_pdus,
+ { "Number of Mac-is PDUs",
+ "fp.edch.number-of-mac-is-pdus", FT_UINT8, BASE_DEC, 0, 0x0,
+ NULL, HFILL
+ }
+ },
+ { &hf_fp_edch_e_rnti,
+ { "E-RNTI",
+ "fp.edch.e-rnti", FT_UINT16, BASE_DEC, 0, 0x0,
+ NULL, HFILL
+ }
+ },
+
+ { &hf_fp_edch_macis_descriptors,
+ { "MAC-is Descriptors",
+ "fp.edch.mac-is.descriptors", FT_STRING, BASE_NONE, NULL, 0x0,
+ NULL, HFILL
+ }
+ },
+ { &hf_fp_edch_macis_lchid,
+ { "LCH-ID",
+ "fp.edch.mac-is.lchid", FT_UINT8, BASE_HEX, VALS(lchid_vals), 0xf0,
+ NULL, HFILL
+ }
+ },
+ { &hf_fp_edch_macis_length,
+ { "Length",
+ "fp.edch.mac-is.length", FT_UINT16, BASE_DEC, 0, 0x0ffe,
+ NULL, HFILL
+ }
+ },
+ { &hf_fp_edch_macis_flag,
+ { "Flag",
+ "fp.edch.mac-is.lchid", FT_UINT8, BASE_HEX, 0, 0x01,
+ "Indicates if another entry follows", HFILL
+ }
+ },
+ { &hf_fp_edch_macis_ss,
+ { "SS",
+ /* TODO: VALS */
+ "fp.edch.mac-is.tsn", FT_UINT8, BASE_HEX, 0, 0xc0,
+ "Segmentation Status", HFILL
+ }
+ },
+ { &hf_fp_edch_macis_tsn,
+ { "TSN",
+ "fp.edch.mac-is.tsn", FT_UINT8, BASE_HEX, 0, 0x3f,
+ "Transmission Sequence Number", HFILL
+ }
+ },
+ { &hf_fp_edch_macis_sdu,
+ { "MAC-is SDU",
+ "fp.edch.mac-is.sdu", FT_NONE, BASE_NONE, NULL, 0x0,
+ NULL, HFILL
+ }
+ },
+
+
{ &hf_fp_frame_seq_nr,
{ "Frame Seq Nr",
"fp.frame-seq-nr", FT_UINT8, BASE_DEC, 0, 0xf0,
},
{ &hf_fp_lchid,
{ "Logical Channel ID",
- "fp.lchid", FT_UINT8, BASE_DEC, 0, 0x0,
+ "fp.lchid", FT_UINT8, BASE_DEC, NULL, 0x0,
NULL, HFILL
}
},
&ett_fp,
&ett_fp_data,
&ett_fp_crcis,
+ &ett_fp_ddi_config,
&ett_fp_edch_subframe_header,
&ett_fp_edch_subframe,
&ett_fp_edch_maces,
+ &ett_fp_edch_macis_descriptors,
+ &ett_fp_edch_macis_pdu,
&ett_fp_hsdsch_new_ie_flags,
&ett_fp_rach_new_ie_flags,
&ett_fp_hsdsch_pdu_block_header,