summaryrefslogtreecommitdiffstats
path: root/epan/dissectors/asn1/nbap
diff options
context:
space:
mode:
Diffstat (limited to 'epan/dissectors/asn1/nbap')
-rw-r--r--epan/dissectors/asn1/nbap/nbap.cnf235
-rw-r--r--epan/dissectors/asn1/nbap/packet-nbap-template.c278
-rw-r--r--epan/dissectors/asn1/nbap/packet-nbap-template.h4
3 files changed, 260 insertions, 257 deletions
diff --git a/epan/dissectors/asn1/nbap/nbap.cnf b/epan/dissectors/asn1/nbap/nbap.cnf
index c4f4dcbc..428c94b5 100644
--- a/epan/dissectors/asn1/nbap/nbap.cnf
+++ b/epan/dissectors/asn1/nbap/nbap.cnf
@@ -81,11 +81,12 @@ ProtocolIE-ContainerPairList
#.END
#.FN_BODY ProtocolIE-ID VAL_PTR = &protocol_ie_id
- guint32 protocol_ie_id;
+ uint32_t protocol_ie_id;
%(DEFAULT_BODY)s
nbap_get_private_data(actx->pinfo)->protocol_ie_id = protocol_ie_id; /* To carry around the packet */
if (tree) {
- proto_item_append_text(proto_item_get_parent_nth(actx->created_item, 2), ": %%s", val_to_str_ext(protocol_ie_id, &nbap_ProtocolIE_ID_vals_ext, "unknown (%%d)"));
+ proto_item_append_text(proto_item_get_parent_nth(actx->created_item, 2), ": %%s",
+ val_to_str_ext(protocol_ie_id, &nbap_ProtocolIE_ID_vals_ext, "unknown (%%d)"));
}
#.END
@@ -94,12 +95,12 @@ ProtocolIE-ContainerPairList
#.FN_PARS ProtocolExtensionField/extensionValue FN_VARIANT=_pdu_new TYPE_REF_FN=dissect_ProtocolExtensionFieldExtensionValue
#.FN_BODY ProcedureCode VAL_PTR = &procedure_code
- guint32 procedure_code;
+ uint32_t procedure_code;
%(DEFAULT_BODY)s
nbap_get_private_data(actx->pinfo)->procedure_code = procedure_code;
col_add_fstr(actx->pinfo->cinfo, COL_INFO, "%%s ",
- val_to_str(procedure_code, nbap_ProcedureCode_vals,
- "unknown message"));
+ val_to_str_const(procedure_code, nbap_ProcedureCode_vals,
+ "unknown message"));
#.FN_PARS ProcedureID/ddMode VAL_PTR = &nbap_get_private_data(actx->pinfo)->dd_mode
@@ -110,7 +111,7 @@ ProtocolIE-ContainerPairList
ProcedureID = wmem_strdup_printf(actx->pinfo->pool, "%%s/%%s",
val_to_str(nbap_private_data->procedure_code, VALS(nbap_ProcedureCode_vals), "unknown(%%u)"),
val_to_str(nbap_private_data->dd_mode, VALS(nbap_DdMode_vals), "unknown(%%u)"));
- nbap_private_data->crnc_context_present = FALSE; /*Reset CRNC Com context present flag.*/
+ nbap_private_data->crnc_context_present = false; /*Reset CRNC Com context present flag.*/
#.FN_PARS TransactionID/shortTransActionId VAL_PTR = &nbap_get_private_data(actx->pinfo)->transaction_id
@@ -178,8 +179,8 @@ actx->pinfo->link_dir=P2P_DIR_UL;
address dst_addr;
nbap_setup_conv_t *request_conv;
conversation_t *conv;
-guint32 transportLayerAddress_ipv4;
-guint16 bindingID;
+uint32_t transportLayerAddress_ipv4;
+uint16_t bindingID;
nbap_private_data_t* nbap_private_data = nbap_get_private_data(actx->pinfo);
nbap_debug("Frame %%u CommonTransportChannel-InformationResponse Start", actx->pinfo->num);
@@ -581,25 +582,25 @@ actx->pinfo->link_dir=P2P_DIR_UL;
tvbuff_t *final_tvb=NULL;
proto_item *ti;
proto_tree *subtree;
- guint32 segment_type;
+ uint32_t segment_type;
/* reassembly variables */
- gboolean is_short = FALSE;
- guint32 total_bit_size = 0;
- guint32 total_byte_size = 0;
+ bool is_short = false;
+ uint32_t total_bit_size = 0;
+ uint32_t total_byte_size = 0;
nbap_ib_segment_t* nbap_ib_segment;
wmem_list_t *list = NULL;
wmem_list_frame_t *curr_frame;
- guint8 *final_arr;
- guint8 final_byte_off = 0;
- guint8 final_bit_off = 0x80;
- guint8 *source;
- guint32 bit_length;
- guint32 byte_off = 0;
- guint32 bit_off = 0x80;
- guint32 sources_count;
- guint8* data;
- guint32 per_length;
- guint32 first_off;
+ uint8_t *final_arr;
+ uint8_t final_byte_off = 0;
+ uint8_t final_bit_off = 0x80;
+ uint8_t *source;
+ uint32_t bit_length;
+ uint32_t byte_off = 0;
+ uint32_t bit_off = 0x80;
+ uint32_t sources_count;
+ uint8_t* data;
+ uint32_t per_length;
+ uint32_t first_off;
nbap_private_data_t* nbap_private_data = nbap_get_private_data(actx->pinfo);
/* compute aligned PER length*/
@@ -648,7 +649,7 @@ actx->pinfo->link_dir=P2P_DIR_UL;
}
else { /* This is IB_SG_DATA_ENC_VAR_2 */
/* Using the per encoded length */
- data = (guint8*)tvb_memdup(actx->pinfo->pool, parameter_tvb, 0, (per_length + 7)/8);
+ data = (uint8_t*)tvb_memdup(actx->pinfo->pool, parameter_tvb, 0, (per_length + 7)/8);
nbap_ib_segment = wmem_new(actx->pinfo->pool, nbap_ib_segment_t);
nbap_ib_segment->bit_length = per_length;
nbap_ib_segment->data = data;
@@ -675,7 +676,7 @@ actx->pinfo->link_dir=P2P_DIR_UL;
/* Sum all length of all segments */
sources_count = wmem_list_count(list);
curr_frame = wmem_list_head(list);
- for (guint32 src_indx = 0; src_indx < sources_count; src_indx++) {
+ for (uint32_t src_indx = 0; src_indx < sources_count; src_indx++) {
nbap_ib_segment = (nbap_ib_segment_t*)(wmem_list_frame_data(curr_frame));
total_bit_size += nbap_ib_segment->bit_length;
curr_frame = wmem_list_frame_next(curr_frame);
@@ -683,17 +684,17 @@ actx->pinfo->link_dir=P2P_DIR_UL;
/* Create an array large enough for all segments */
total_byte_size = (total_bit_size+7)/8;
- final_arr = wmem_alloc0_array(actx->pinfo->pool,guint8,total_byte_size);
+ final_arr = wmem_alloc0_array(actx->pinfo->pool,uint8_t,total_byte_size);
/* Reassemble all segment into the final array */
curr_frame = wmem_list_head(list);
- for (guint32 src_indx = 0; src_indx < sources_count; src_indx++) {
+ for (uint32_t src_indx = 0; src_indx < sources_count; src_indx++) {
nbap_ib_segment = (nbap_ib_segment_t*)(wmem_list_frame_data(curr_frame));
source = nbap_ib_segment->data;
bit_length = nbap_ib_segment->bit_length;
byte_off = 0;
bit_off = 0x80;
- for (guint32 i=0;i<bit_length;i++) {
+ for (uint32_t i=0;i<bit_length;i++) {
if (((*(source+byte_off)) & bit_off) == bit_off) {
final_arr[final_byte_off] |= final_bit_off;
}
@@ -847,9 +848,9 @@ actx->pinfo->link_dir=P2P_DIR_UL;
tvbuff_t *parameter_tvb=NULL;
proto_item *item;
proto_tree *subtree, *nsap_tree;
- guint8 *padded_nsap_bytes;
+ uint8_t *padded_nsap_bytes;
tvbuff_t *nsap_tvb;
- gint tvb_len;
+ int tvb_len;
nbap_private_data_t* nbap_private_data = nbap_get_private_data(actx->pinfo);
%(DEFAULT_BODY)s
@@ -874,7 +875,7 @@ actx->pinfo->link_dir=P2P_DIR_UL;
if (tvb_len == 7){
/* Unpadded IPv4 NSAP */
/* Creating a new TVB with padding */
- padded_nsap_bytes = (guint8*) wmem_alloc0(actx->pinfo->pool, 20);
+ padded_nsap_bytes = (uint8_t*) wmem_alloc0(actx->pinfo->pool, 20);
tvb_memcpy(parameter_tvb, padded_nsap_bytes, 0, tvb_len);
nsap_tvb = tvb_new_child_real_data(tvb, padded_nsap_bytes, 20, 20);
add_new_data_source(actx->pinfo, nsap_tvb, "Padded NSAP Data");
@@ -892,31 +893,31 @@ actx->pinfo->link_dir=P2P_DIR_UL;
}
#.FN_BODY PayloadCRC-PresenceIndicator VAL_PTR = &payload_crc_value
-guint32 payload_crc_value;
+uint32_t payload_crc_value;
%(DEFAULT_BODY)s
if(payload_crc_value == 0){
- nbap_get_private_data(actx->pinfo)->dch_crc_present = TRUE;
+ nbap_get_private_data(actx->pinfo)->dch_crc_present = true;
}else{
- nbap_get_private_data(actx->pinfo)->dch_crc_present = FALSE;
+ nbap_get_private_data(actx->pinfo)->dch_crc_present = false;
}
#.FN_PARS DCH-ID VAL_PTR = &nbap_get_private_data(actx->pinfo)->t_dch_id
#.FN_BODY DCH-Specific-FDD-Item/dCH-ID
- guint32 dch_id;
- gint num_dch_in_flow;
+ uint32_t dch_id;
+ int num_dch_in_flow;
nbap_dch_channel_info_t* nbap_dch_chnl_info;
nbap_private_data_t* nbap_private_data = nbap_get_private_data(actx->pinfo);
nbap_dch_chnl_info = nbap_private_data->nbap_dch_chnl_info;
offset = dissect_per_constrained_integer(tvb, offset, actx, tree, hf_index,
- 0U, 255U, &dch_id, FALSE);
+ 0U, 255U, &dch_id, false);
num_dch_in_flow = nbap_private_data->num_dch_in_flow;
nbap_private_data->dch_id = dch_id;
if(num_dch_in_flow>0){
- guint32 prev_dch_id = nbap_private_data->prev_dch_id;
+ uint32_t prev_dch_id = nbap_private_data->prev_dch_id;
nbap_dch_chnl_info[dch_id].next_dch = 0;
if(prev_dch_id != 0 && prev_dch_id != 0xffffffff && prev_dch_id != dch_id){
nbap_dch_chnl_info[prev_dch_id].next_dch = dch_id;
@@ -927,7 +928,7 @@ guint32 payload_crc_value;
nbap_get_private_data(actx->pinfo)->dch_id = nbap_get_private_data(actx->pinfo)->t_dch_id;
#.FN_BODY CommonPhysicalChannelID VAL_PTR = &commonphysicalchannelid
- guint32 commonphysicalchannelid;
+ uint32_t commonphysicalchannelid;
nbap_dch_channel_info_t* nbap_dch_chnl_info;
nbap_private_data_t* nbap_private_data = nbap_get_private_data(actx->pinfo);
nbap_dch_chnl_info = nbap_private_data->nbap_dch_chnl_info;
@@ -937,7 +938,7 @@ guint32 payload_crc_value;
nbap_dch_chnl_info[commonphysicalchannelid].next_dch = 0;
#.FN_BODY CommonTransportChannelID VAL_PTR = &commontransportchannelid
- guint32 commontransportchannelid;
+ uint32_t commontransportchannelid;
nbap_dch_channel_info_t* nbap_dch_chnl_info;
nbap_private_data_t* nbap_private_data = nbap_get_private_data(actx->pinfo);
nbap_dch_chnl_info = nbap_private_data->nbap_dch_chnl_info;
@@ -949,9 +950,9 @@ guint32 payload_crc_value;
#.FN_PARS E-DCH-MACdFlow-ID VAL_PTR = &nbap_get_private_data(actx->pinfo)->e_dch_macdflow_id
#.FN_BODY HSDSCH-MACdFlow-ID VAL_PTR = &hsdsch_macdflow_id
- guint32 hsdsch_macdflow_id;
- guint num_items;
- gint* hsdsch_macdflow_ids;
+ uint32_t hsdsch_macdflow_id;
+ unsigned num_items;
+ int* hsdsch_macdflow_ids;
nbap_private_data_t* nbap_private_data = nbap_get_private_data(actx->pinfo);
%(DEFAULT_BODY)s
nbap_private_data->hsdsch_macdflow_id = hsdsch_macdflow_id;
@@ -965,7 +966,7 @@ hsdsch_macdflow_ids[num_items-1] = hsdsch_macdflow_id;
#.FN_BODY BindingID VAL_PTR = &parameter_tvb
tvbuff_t *parameter_tvb=NULL;
- guint16 binding_id_port;
+ uint16_t binding_id_port;
%(DEFAULT_BODY)s
@@ -982,8 +983,8 @@ hsdsch_macdflow_ids[num_items-1] = hsdsch_macdflow_id;
}
#.FN_BODY UL-ScramblingCodeNumber VAL_PTR = &ul_scrambling_code
- guint32 ul_scrambling_code;
- guint32 com_context_id;
+ uint32_t ul_scrambling_code;
+ uint32_t com_context_id;
%(DEFAULT_BODY)s
nbap_get_private_data(actx->pinfo)->ul_scrambling_code = ul_scrambling_code;
com_context_id = nbap_get_private_data(actx->pinfo)->com_context_id;
@@ -997,9 +998,9 @@ conversation_t *conversation;
fp_rach_channel_info_t* fp_rach_channel_info;
umts_fp_conversation_info_t *umts_fp_conversation_info;
int j, num_tf;
-guint32 transportLayerAddress_ipv4;
-guint16 bindingID;
-guint32 common_physical_channel_id;
+uint32_t transportLayerAddress_ipv4;
+uint16_t bindingID;
+uint32_t common_physical_channel_id;
nbap_dch_channel_info_t* nbap_dch_chnl_info;
nbap_private_data_t* nbap_private_data = nbap_get_private_data(actx->pinfo);
nbap_dch_chnl_info = nbap_private_data->nbap_dch_chnl_info;
@@ -1069,7 +1070,7 @@ nbap_private_data->transport_format_set_type = NBAP_CPCH;
}
#.FN_BODY PICH-Mode VAL_PTR = &PICH_Mode
-guint32 PICH_Mode = 0;
+uint32_t PICH_Mode = 0;
%(DEFAULT_BODY)s
switch(PICH_Mode){
@@ -1095,9 +1096,9 @@ conversation_t *conversation;
fp_pch_channel_info_t *fp_pch_channel_info;
umts_fp_conversation_info_t *umts_fp_conversation_info;
int i, j, num_tf;
-guint32 transportLayerAddress_ipv4;
-guint16 bindingID;
-guint32 common_transport_channel_id;
+uint32_t transportLayerAddress_ipv4;
+uint16_t bindingID;
+uint32_t common_transport_channel_id;
nbap_dch_channel_info_t* nbap_dch_chnl_info;
nbap_private_data_t* nbap_private_data = nbap_get_private_data(actx->pinfo);
nbap_dch_chnl_info = nbap_private_data->nbap_dch_chnl_info;
@@ -1206,9 +1207,9 @@ conversation_t *conversation;
fp_fach_channel_info_t* fp_fach_channel_info;
umts_fp_conversation_info_t *umts_fp_conversation_info;
int i, j, num_tf;
-guint32 transportLayerAddress_ipv4;
-guint16 bindingID;
-guint32 common_physical_channel_id;
+uint32_t transportLayerAddress_ipv4;
+uint16_t bindingID;
+uint32_t common_physical_channel_id;
nbap_dch_channel_info_t* nbap_dch_chnl_info;
nbap_private_data_t* nbap_private_data = nbap_get_private_data(actx->pinfo);
nbap_dch_chnl_info = nbap_private_data->nbap_dch_chnl_info;
@@ -1311,7 +1312,7 @@ nbap_private_data->transport_format_set_type = NBAP_CPCH;
#.FN_HDR DCH-Specific-FDD-Item/ul-TransportFormatSet
nbap_private_data_t* nbap_private_data = nbap_get_private_data(actx->pinfo);
- guint32 dch_id = nbap_private_data->dch_id;
+ uint32_t dch_id = nbap_private_data->dch_id;
nbap_dch_channel_info_t* nbap_dch_chnl_info;
nbap_dch_chnl_info = nbap_private_data->nbap_dch_chnl_info;
nbap_private_data->transport_format_set_type = NBAP_DCH_UL;
@@ -1321,7 +1322,7 @@ nbap_private_data->transport_format_set_type = NBAP_CPCH;
#.FN_HDR DCH-Specific-FDD-Item/dl-TransportFormatSet
nbap_private_data_t* nbap_private_data = nbap_get_private_data(actx->pinfo);
- guint32 dch_id = nbap_private_data->dch_id;
+ uint32_t dch_id = nbap_private_data->dch_id;
nbap_dch_channel_info_t* nbap_dch_chnl_info;
nbap_dch_chnl_info = nbap_private_data->nbap_dch_chnl_info;
nbap_private_data->transport_format_set_type = NBAP_DCH_DL;
@@ -1331,7 +1332,7 @@ nbap_private_data->transport_format_set_type = NBAP_CPCH;
#.FN_HDR DCH-ModifySpecificItem-FDD/ul-TransportFormatSet
nbap_private_data_t* nbap_private_data = nbap_get_private_data(actx->pinfo);
- guint32 dch_id = nbap_private_data->dch_id;
+ uint32_t dch_id = nbap_private_data->dch_id;
nbap_dch_channel_info_t* nbap_dch_chnl_info;
nbap_dch_chnl_info = nbap_private_data->nbap_dch_chnl_info;
nbap_private_data->transport_format_set_type = NBAP_DCH_UL;
@@ -1341,7 +1342,7 @@ nbap_private_data->transport_format_set_type = NBAP_CPCH;
#.FN_HDR DCH-ModifySpecificItem-FDD/dl-TransportFormatSet
nbap_private_data_t* nbap_private_data = nbap_get_private_data(actx->pinfo);
- guint32 dch_id = nbap_private_data->dch_id;
+ uint32_t dch_id = nbap_private_data->dch_id;
nbap_dch_channel_info_t* nbap_dch_chnl_info;
nbap_dch_chnl_info = nbap_private_data->nbap_dch_chnl_info;
nbap_private_data->transport_format_set_type = NBAP_DCH_DL;
@@ -1364,11 +1365,11 @@ nbap_private_data->transport_format_set_type = NBAP_CPCH;
nbap_get_private_data(actx->pinfo)->num_items++;
#.FN_BODY TransportFormatSet-NrOfTransportBlocks VAL_PTR = &NrOfTransportBlocks
-guint32 NrOfTransportBlocks;
-guint num_items;
-guint32 dch_id;
-guint32 common_physical_channel_id;
-guint32 common_transport_channel_id;
+uint32_t NrOfTransportBlocks;
+unsigned num_items;
+uint32_t dch_id;
+uint32_t common_physical_channel_id;
+uint32_t common_transport_channel_id;
nbap_dch_channel_info_t* nbap_dch_chnl_info;
nbap_private_data_t* nbap_private_data = nbap_get_private_data(actx->pinfo);
nbap_dch_chnl_info = nbap_private_data->nbap_dch_chnl_info;
@@ -1409,11 +1410,11 @@ nbap_dch_chnl_info = nbap_private_data->nbap_dch_chnl_info;
}
#.FN_BODY TransportFormatSet-TransportBlockSize VAL_PTR = &TransportBlockSize
-guint32 TransportBlockSize;
-guint num_items;
-guint32 dch_id;
-guint32 common_physical_channel_id;
-guint32 common_transport_channel_id;
+uint32_t TransportBlockSize;
+unsigned num_items;
+uint32_t dch_id;
+uint32_t common_physical_channel_id;
+uint32_t common_transport_channel_id;
nbap_dch_channel_info_t* nbap_dch_chnl_info;
nbap_private_data_t* nbap_private_data = nbap_get_private_data(actx->pinfo);
nbap_dch_chnl_info = nbap_private_data->nbap_dch_chnl_info;
@@ -1455,9 +1456,9 @@ address dst_addr, null_addr;
conversation_t *conversation = NULL;
umts_fp_conversation_info_t *umts_fp_conversation_info;
int i, j, num_tf;
-guint32 transportLayerAddress_ipv4;
-guint16 bindingID;
-guint32 dch_id;
+uint32_t transportLayerAddress_ipv4;
+uint16_t bindingID;
+uint32_t dch_id;
nbap_dch_channel_info_t* nbap_dch_chnl_info;
nbap_private_data_t* nbap_private_data = nbap_get_private_data(actx->pinfo);
nbap_dch_chnl_info = nbap_private_data->nbap_dch_chnl_info;
@@ -1571,9 +1572,9 @@ conversation_t *conversation;
umts_fp_conversation_info_t *umts_fp_conversation_info = NULL;
fp_edch_channel_info_t* fp_edch_channel_info;
nbap_edch_port_info_t *old_info = NULL;
-guint32 transportLayerAddress_ipv4;
-guint16 bindingID;
-guint32 e_dch_macdflow_id;
+uint32_t transportLayerAddress_ipv4;
+uint16_t bindingID;
+uint32_t e_dch_macdflow_id;
nbap_edch_channel_info_t* nbap_edch_channel_info;
nbap_private_data_t* nbap_private_data = nbap_get_private_data(actx->pinfo);
nbap_edch_channel_info = nbap_private_data->nbap_edch_channel_info;
@@ -1632,7 +1633,7 @@ nbap_private_data->binding_id_port = 0;
expert_add_info(actx->pinfo, NULL, &ei_nbap_no_set_comm_context_id);
}
- /* Check if we allready have this context */
+ /* Check if we already have this context */
e_dch_macdflow_id = nbap_private_data->e_dch_macdflow_id;
if( (old_info = (nbap_edch_port_info_t *)wmem_tree_lookup32(edch_flow_port_map,nbap_private_data->com_context_id)) == NULL ){
nbap_edch_port_info_t * nbap_edch_port_info;
@@ -1676,14 +1677,14 @@ umts_fp_conversation_info_t *p_conv_data = NULL;
fp_edch_channel_info_t* fp_edch_channel_info = NULL;
address null_addr;
conversation_t *p_conv;
-guint32 no_ddi_entries, i;
-guint32 e_dch_macdflow_id;
+uint32_t no_ddi_entries, i;
+uint32_t e_dch_macdflow_id;
nbap_edch_channel_info_t* nbap_edch_channel_info;
nbap_private_data_t* nbap_private_data = nbap_get_private_data(actx->pinfo);
nbap_edch_channel_info = nbap_private_data->nbap_edch_channel_info;
/* Resetting entity recognition flag to check if it's set in this InfoItem */
- nbap_private_data->max_mac_d_pdu_size_ext_ie_present = FALSE;
+ nbap_private_data->max_mac_d_pdu_size_ext_ie_present = false;
%(DEFAULT_BODY)s
if (PINFO_FD_VISITED(actx->pinfo)) {
return offset;
@@ -1722,7 +1723,7 @@ nbap_edch_channel_info = nbap_private_data->nbap_edch_channel_info;
* MAC-i/is => Type 2
* The specifications isn't very clear about the indicator for what entity
* should be used. For now, it seems like the presence of the "Maximum MAC-d PDU Size Extended IE"
- * indicates MAC-i/is and it's absense means MAC-e/es
+ * indicates MAC-i/is and it's absence means MAC-e/es
*/
if(nbap_private_data->max_mac_d_pdu_size_ext_ie_present){
fp_edch_channel_info->edch_type = 1; /* 1 means Type 2 */
@@ -1741,9 +1742,9 @@ conversation_t *conversation,*old_conversation = NULL;
umts_fp_conversation_info_t *umts_fp_conversation_info _U_;
fp_edch_channel_info_t* fp_edch_channel_info;
void *conv_proto_data = NULL;
-guint32 transportLayerAddress_ipv4;
-guint16 bindingID;
-guint32 e_dch_macdflow_id;
+uint32_t transportLayerAddress_ipv4;
+uint16_t bindingID;
+uint32_t e_dch_macdflow_id;
nbap_edch_channel_info_t* nbap_edch_channel_info;
nbap_private_data_t* nbap_private_data = nbap_get_private_data(actx->pinfo);
nbap_edch_channel_info = nbap_private_data->nbap_edch_channel_info;
@@ -1820,19 +1821,19 @@ nbap_private_data->binding_id_port = 0;
nbap_edch_channel_info[e_dch_macdflow_id].crnc_port = bindingID;
/*Indicate that the frag table has to be reset*/
- umts_fp_conversation_info->reset_frag = TRUE;
+ umts_fp_conversation_info->reset_frag = true;
set_umts_fp_conv_data(conversation, umts_fp_conversation_info);
}
#.FN_BODY E-DCH-MACdFlow-Specific-InfoItem-to-Modify
-guint32 no_ddi_entries, i;
+uint32_t no_ddi_entries, i;
address null_addr;
nbap_edch_port_info_t *old_info;
umts_fp_conversation_info_t *p_conv_data = NULL;
fp_edch_channel_info_t* fp_edch_channel_info;
conversation_t *p_conv;
-guint32 e_dch_macdflow_id;
+uint32_t e_dch_macdflow_id;
nbap_edch_channel_info_t* nbap_edch_channel_info;
nbap_private_data_t* nbap_private_data = nbap_get_private_data(actx->pinfo);
nbap_edch_channel_info = nbap_private_data->nbap_edch_channel_info;
@@ -1905,7 +1906,7 @@ nbap_private_data->num_items = 1;
* MAC-i/is => Type 2
* The specifications isn't very clear about the indicator for what entity
* should be used. For now, it seems like the presence of the "Maximum MAC-d PDU Size Extended IE"
- * indicates MAC-i/is and it's absense means MAC-e/es
+ * indicates MAC-i/is and it's absence means MAC-e/es
*/
if(nbap_private_data->max_mac_d_pdu_size_ext_ie_present){
fp_edch_channel_info->edch_type = 1; /* 1 means Type 2 */
@@ -1933,8 +1934,8 @@ nbap_edch_channel_info[nbap_private_data->e_dch_macdflow_id].no_ddi_entries = nb
nbap_get_private_data(actx->pinfo)->num_items++;
#.FN_BODY E-DCH-DDI-Value VAL_PTR = &e_dch_ddi_value
- guint32 e_dch_ddi_value;
- guint num_items;
+ uint32_t e_dch_ddi_value;
+ unsigned num_items;
nbap_edch_channel_info_t* nbap_edch_channel_info;
nbap_private_data_t* nbap_private_data = nbap_get_private_data(actx->pinfo);
nbap_edch_channel_info = nbap_private_data->nbap_edch_channel_info;
@@ -1950,8 +1951,8 @@ nbap_edch_channel_info[nbap_private_data->e_dch_macdflow_id].no_ddi_entries = nb
nbap_edch_channel_info[nbap_private_data->e_dch_macdflow_id].edch_ddi[num_items-1] = nbap_private_data->e_dch_ddi_value;
#.FN_BODY MACdPDU-Size VAL_PTR = &mac_d_pdu_size
-guint32 mac_d_pdu_size;
-guint num_items;
+uint32_t mac_d_pdu_size;
+unsigned num_items;
nbap_edch_channel_info_t* nbap_edch_channel_info;
nbap_private_data_t* nbap_private_data = nbap_get_private_data(actx->pinfo);
nbap_edch_channel_info = nbap_private_data->nbap_edch_channel_info;
@@ -1967,8 +1968,8 @@ nbap_edch_channel_info = nbap_private_data->nbap_edch_channel_info;
nbap_edch_channel_info[nbap_private_data->e_dch_macdflow_id].edch_macd_pdu_size[num_items-1] = nbap_private_data->mac_d_pdu_size;
#.FN_BODY LogicalChannelID VAL_PTR = &logical_channel_id
- guint32 logical_channel_id;
- guint num_items;
+ uint32_t logical_channel_id;
+ unsigned num_items;
nbap_edch_channel_info_t* nbap_edch_channel_info;
nbap_private_data_t* nbap_private_data = nbap_get_private_data(actx->pinfo);
nbap_edch_channel_info = nbap_private_data->nbap_edch_channel_info;
@@ -1981,7 +1982,7 @@ nbap_edch_channel_info = nbap_private_data->nbap_edch_channel_info;
nbap_edch_channel_info[nbap_private_data->e_dch_macdflow_id].lchId[num_items-1] = nbap_private_data->logical_channel_id;
#.FN_BODY RLC-Mode VAL_PTR = &rlc_mode
- guint32 rlc_mode;
+ uint32_t rlc_mode;
nbap_hsdsch_channel_info_t* nbap_hsdsch_channel_info;
nbap_private_data_t* nbap_private_data = nbap_get_private_data(actx->pinfo);
nbap_hsdsch_channel_info = nbap_private_data->nbap_hsdsch_channel_info;
@@ -2000,7 +2001,7 @@ nbap_edch_channel_info = nbap_private_data->nbap_edch_channel_info;
}
#.FN_BODY UE-Capability-Information/hSDSCH-Physical-Layer-Category VAL_PTR = &hsdsch_physical_layer_category
- guint32 hsdsch_physical_layer_category;
+ uint32_t hsdsch_physical_layer_category;
nbap_hsdsch_channel_info_t* nbap_hsdsch_channel_info;
nbap_private_data_t* nbap_private_data = nbap_get_private_data(actx->pinfo);
nbap_hsdsch_channel_info = nbap_private_data->nbap_hsdsch_channel_info;
@@ -2011,7 +2012,7 @@ nbap_edch_channel_info = nbap_private_data->nbap_edch_channel_info;
#.FN_BODY HSDSCH-MACdFlows-Information
int protocol_ie_id;
- guint32 i;
+ uint32_t i;
nbap_private_data_t* nbap_private_data = nbap_get_private_data(actx->pinfo);
nbap_private_data->num_items = 0;
protocol_ie_id = nbap_private_data->protocol_ie_id;
@@ -2060,9 +2061,9 @@ nbap_edch_channel_info = nbap_private_data->nbap_edch_channel_info;
#.FN_BODY HSDSCH-MACdFlow-Specific-InfoItem
address dst_addr;
- guint32 transportLayerAddress_ipv4;
- guint16 bindingID;
- guint32 hsdsch_macdflow_id;
+ uint32_t transportLayerAddress_ipv4;
+ uint16_t bindingID;
+ uint32_t hsdsch_macdflow_id;
nbap_private_data_t* nbap_private_data = nbap_get_private_data(actx->pinfo);
nbap_hsdsch_channel_info_t* nbap_hsdsch_channel_info;
nbap_hsdsch_channel_info = nbap_private_data->nbap_hsdsch_channel_info;
@@ -2086,11 +2087,11 @@ nbap_edch_channel_info = nbap_private_data->nbap_edch_channel_info;
nbap_hsdsch_channel_info[hsdsch_macdflow_id].crnc_port = bindingID;
#.FN_BODY MAC-PDU-SizeExtended
-guint32 hsdsch_macdflow_id;
+uint32_t hsdsch_macdflow_id;
nbap_hsdsch_channel_info_t* nbap_hsdsch_channel_info;
nbap_hsdsch_channel_info = nbap_get_private_data(actx->pinfo)->nbap_hsdsch_channel_info;
%(DEFAULT_BODY)s
- nbap_get_private_data(actx->pinfo)->max_mac_d_pdu_size_ext_ie_present = TRUE;
+ nbap_get_private_data(actx->pinfo)->max_mac_d_pdu_size_ext_ie_present = true;
hsdsch_macdflow_id = nbap_get_private_data(actx->pinfo)->hsdsch_macdflow_id;
if(nbap_hsdsch_channel_info[hsdsch_macdflow_id].crnc_port != 0){
nbap_hsdsch_channel_info[hsdsch_macdflow_id].entity = ehs;
@@ -2104,7 +2105,7 @@ nbap_hsdsch_channel_info = nbap_get_private_data(actx->pinfo)->nbap_hsdsch_chann
conversation_t *conversation = NULL;
umts_fp_conversation_info_t *umts_fp_conversation_info;
fp_hsdsch_channel_info_t* fp_hsdsch_channel_info = NULL;
- guint32 i;
+ uint32_t i;
nbap_hsdsch_channel_info_t* nbap_hsdsch_channel_info;
nbap_hsdsch_channel_info = nbap_get_private_data(actx->pinfo)->nbap_hsdsch_channel_info;
@@ -2194,8 +2195,8 @@ nbap_hsdsch_channel_info = nbap_get_private_data(actx->pinfo)->nbap_hsdsch_chann
#.FN_BODY HSDSCH-MACdFlow-Specific-InfoItem-to-Modify
address dst_addr;
- guint32 transportLayerAddress_ipv4;
- guint16 bindingID;
+ uint32_t transportLayerAddress_ipv4;
+ uint16_t bindingID;
nbap_private_data_t* nbap_private_data = nbap_get_private_data(actx->pinfo);
nbap_private_data->transportLayerAddress_ipv4 = 0;
nbap_private_data->binding_id_port = 0;
@@ -2226,7 +2227,7 @@ nbap_hsdsch_channel_info = nbap_get_private_data(actx->pinfo)->nbap_hsdsch_chann
conversation_t *conversation = NULL;
umts_fp_conversation_info_t *umts_fp_conversation_info;
fp_hsdsch_channel_info_t* fp_hsdsch_channel_info = NULL;
- guint32 i;
+ uint32_t i;
nbap_hsdsch_channel_info_t* nbap_hsdsch_channel_info;
nbap_hsdsch_channel_info = nbap_get_private_data(actx->pinfo)->nbap_hsdsch_channel_info;
@@ -2315,7 +2316,7 @@ nbap_hsdsch_channel_info = nbap_get_private_data(actx->pinfo)->nbap_hsdsch_chann
umts_fp_conversation_info->rlc_mode = nbap_hsdsch_channel_info[i].rlc_mode;
/*Indicate that the frag table has to be reset*/
- umts_fp_conversation_info->reset_frag = TRUE;
+ umts_fp_conversation_info->reset_frag = true;
set_umts_fp_conv_data(conversation, umts_fp_conversation_info);
}
@@ -2332,9 +2333,9 @@ nbap_hsdsch_channel_info = nbap_get_private_data(actx->pinfo)->nbap_hsdsch_chann
/*THIS STUFF IST NOT DONE YET!*/
#.FN_BODY CommonMACFlow-Specific-InfoItem
address dst_addr;
- guint32 transportLayerAddress_ipv4;
- guint16 bindingID;
- guint32 common_macdflow_id;
+ uint32_t transportLayerAddress_ipv4;
+ uint16_t bindingID;
+ uint32_t common_macdflow_id;
nbap_private_data_t* nbap_private_data = nbap_get_private_data(actx->pinfo);
nbap_private_data->transportLayerAddress_ipv4 = 0;
nbap_private_data->binding_id_port = 0;
@@ -2444,14 +2445,14 @@ int i;
#
#.FN_BODY CRNC-CommunicationContextID VAL_PTR = &com_context_id
-guint32 com_context_id;
+uint32_t com_context_id;
%(DEFAULT_BODY)s
nbap_get_private_data(actx->pinfo)->com_context_id = com_context_id;
-nbap_get_private_data(actx->pinfo)->crnc_context_present = TRUE;
+nbap_get_private_data(actx->pinfo)->crnc_context_present = true;
#.FN_BODY NodeB-CommunicationContextID VAL_PTR = &node_b_com_context_id
- gboolean crnc_context_present;
- guint node_b_com_context_id;
+ bool crnc_context_present;
+ unsigned node_b_com_context_id;
nbap_com_context_id_t *cur_val;
nbap_private_data_t* nbap_private_data = nbap_get_private_data(actx->pinfo);
@@ -2480,12 +2481,12 @@ nbap_get_private_data(actx->pinfo)->crnc_context_present = TRUE;
if(cur_val != NULL){
/* A mapping was found. Adding to prvivate data. */
nbap_private_data->com_context_id = cur_val->crnc_context;
- nbap_private_data->crnc_context_present = TRUE;
+ nbap_private_data->crnc_context_present = true;
}
}
#.FN_BODY HSDSCH-RNTI VAL_PTR = &hrnti
- gint hrnti;
+ int hrnti;
umts_fp_conversation_info_t *umts_fp_conversation_info = NULL;
fp_hsdsch_channel_info_t* fp_hsdsch_channel_info = NULL;
address null_addr;
@@ -2502,7 +2503,7 @@ nbap_hsdsch_channel_info = nbap_private_data->nbap_hsdsch_channel_info;
return offset;
}
- /*Find the conversations assoicated with the HS-DSCH flows in this packet and set proper H-RNTI*/
+ /*Find the conversations associated with the HS-DSCH flows in this packet and set proper H-RNTI*/
clear_address(&null_addr);
for (i = 0; i < maxNrOfMACdFlows; i++) {
if (nbap_hsdsch_channel_info[i].crnc_port != 0){
diff --git a/epan/dissectors/asn1/nbap/packet-nbap-template.c b/epan/dissectors/asn1/nbap/packet-nbap-template.c
index 4e62365f..4c8513c0 100644
--- a/epan/dissectors/asn1/nbap/packet-nbap-template.c
+++ b/epan/dissectors/asn1/nbap/packet-nbap-template.c
@@ -21,6 +21,7 @@
#include <epan/prefs.h>
#include <epan/proto_data.h>
#include <epan/uat.h>
+#include <wsutil/array.h>
#include "packet-per.h"
#include "packet-isup.h"
@@ -60,25 +61,25 @@ static dissector_handle_t fp_handle;
#include "packet-nbap-val.h"
/* Initialize the protocol and registered fields */
-static int proto_nbap = -1;
-static int hf_nbap_transportLayerAddress_ipv4 = -1;
-static int hf_nbap_transportLayerAddress_ipv6 = -1;
-static int hf_nbap_transportLayerAddress_nsap = -1;
-static int hf_nbap_reassembled_information_block = -1;
+static int proto_nbap;
+static int hf_nbap_transportLayerAddress_ipv4;
+static int hf_nbap_transportLayerAddress_ipv6;
+static int hf_nbap_transportLayerAddress_nsap;
+static int hf_nbap_reassembled_information_block;
#include "packet-nbap-hf.c"
/* Initialize the subtree pointers */
-static int ett_nbap = -1;
-static int ett_nbap_TransportLayerAddress = -1;
-static int ett_nbap_TransportLayerAddress_nsap = -1;
-static int ett_nbap_ib_sg_data = -1;
+static int ett_nbap;
+static int ett_nbap_TransportLayerAddress;
+static int ett_nbap_TransportLayerAddress_nsap;
+static int ett_nbap_ib_sg_data;
#include "packet-nbap-ett.c"
-static expert_field ei_nbap_no_find_port_info = EI_INIT;
-static expert_field ei_nbap_no_set_comm_context_id = EI_INIT;
-static expert_field ei_nbap_hsdsch_entity_not_specified = EI_INIT;
+static expert_field ei_nbap_no_find_port_info;
+static expert_field ei_nbap_no_set_comm_context_id;
+static expert_field ei_nbap_hsdsch_entity_not_specified;
extern int proto_fp;
@@ -92,12 +93,12 @@ static dissector_handle_t nbap_handle;
*/
typedef struct nbap_setup_conv
{
- guint32 transaction_id;
- guint32 dd_mode;
- guint32 channel_id;
- guint32 request_frame_number;
+ uint32_t transaction_id;
+ uint32_t dd_mode;
+ uint32_t channel_id;
+ uint32_t request_frame_number;
address addr;
- guint32 port;
+ uint32_t port;
umts_fp_conversation_info_t *umts_fp_conversation_info;
conversation_t *conv;
}nbap_setup_conv_t;
@@ -110,14 +111,14 @@ static wmem_map_t *nbap_setup_conv_table;
typedef struct
{
- gint num_dch_in_flow;
- gint next_dch;
- gint num_ul_chans;
- gint ul_chan_tf_size[MAX_FP_CHANS];
- gint ul_chan_num_tbs[MAX_FP_CHANS];
- gint num_dl_chans;
- gint dl_chan_tf_size[MAX_FP_CHANS];
- gint dl_chan_num_tbs[MAX_FP_CHANS];
+ int num_dch_in_flow;
+ int next_dch;
+ int num_ul_chans;
+ int ul_chan_tf_size[MAX_FP_CHANS];
+ int ul_chan_num_tbs[MAX_FP_CHANS];
+ int num_dl_chans;
+ int dl_chan_tf_size[MAX_FP_CHANS];
+ int dl_chan_num_tbs[MAX_FP_CHANS];
}nbap_dch_channel_info_t;
/* Struct to collect E-DCH data in a packet
@@ -128,42 +129,42 @@ typedef struct
typedef struct
{
address crnc_address;
- guint16 crnc_port;
- gint no_ddi_entries;
- guint8 edch_ddi[MAX_EDCH_DDIS];
- guint edch_macd_pdu_size[MAX_EDCH_DDIS];
- guint8 edch_type; /* 1 means T2 */
- guint8 lchId[MAX_EDCH_DDIS]; /*Logical channel ids.*/
+ uint16_t crnc_port;
+ int no_ddi_entries;
+ uint8_t edch_ddi[MAX_EDCH_DDIS];
+ unsigned edch_macd_pdu_size[MAX_EDCH_DDIS];
+ uint8_t edch_type; /* 1 means T2 */
+ uint8_t lchId[MAX_EDCH_DDIS]; /*Logical channel ids.*/
} nbap_edch_channel_info_t;
typedef struct
{
- guint32 crnc_address;
- guint16 crnc_port[maxNrOfEDCHMACdFlows];
+ uint32_t crnc_address;
+ uint16_t crnc_port[maxNrOfEDCHMACdFlows];
} nbap_edch_port_info_t;
typedef struct
{
address crnc_address;
- guint16 crnc_port;
+ uint16_t crnc_port;
enum fp_rlc_mode rlc_mode;
- guint32 hsdsch_physical_layer_category;
- guint8 entity; /* "ns" means type 1 and "ehs" means type 2, type 3 == ?*/
+ uint32_t hsdsch_physical_layer_category;
+ uint8_t entity; /* "ns" means type 1 and "ehs" means type 2, type 3 == ?*/
} nbap_hsdsch_channel_info_t;
typedef struct
{
address crnc_address;
- guint16 crnc_port;
+ uint16_t crnc_port;
enum fp_rlc_mode rlc_mode;
} nbap_common_channel_info_t;
-/*Stuff for mapping NodeB-Comuncation Context ID to CRNC Communication Context ID*/
+/*Stuff for mapping NodeB-Communication Context ID to CRNC Communication Context ID*/
typedef struct com_ctxt_{
- /*guint nodeb_context;*/
- guint crnc_context;
- guint frame_num;
+ /*unsigned nodeb_context;*/
+ unsigned crnc_context;
+ unsigned frame_num;
}nbap_com_context_id_t;
enum TransportFormatSet_type_enum
@@ -178,25 +179,25 @@ enum TransportFormatSet_type_enum
#define NBAP_MAX_IB_SEGMENT_LENGTH 222
typedef struct nbap_ib_segment_t {
- guint32 bit_length;
- guint8* data;
+ uint32_t bit_length;
+ uint8_t* data;
} nbap_ib_segment_t;
-static nbap_ib_segment_t* nbap_parse_ib_sg_data_var1(packet_info *pinfo, tvbuff_t *tvb,gboolean is_short)
+static nbap_ib_segment_t* nbap_parse_ib_sg_data_var1(packet_info *pinfo, tvbuff_t *tvb,bool is_short)
{
- guint8 bit_length;
- guint8* data;
+ uint8_t bit_length;
+ uint8_t* data;
nbap_ib_segment_t* output;
if ( tvb_captured_length(tvb) < 2 ) {
return NULL;
}
if (is_short) {
- bit_length = tvb_get_guint8(tvb,0) + 1;
- data = (guint8*)tvb_memdup(pinfo->pool,tvb,1,(bit_length+7)/8);
+ bit_length = tvb_get_uint8(tvb,0) + 1;
+ data = (uint8_t*)tvb_memdup(pinfo->pool,tvb,1,(bit_length+7)/8);
}
else {
bit_length = NBAP_MAX_IB_SEGMENT_LENGTH;
- data = (guint8*)tvb_memdup(pinfo->pool,tvb,0,(bit_length+7)/8);
+ data = (uint8_t*)tvb_memdup(pinfo->pool,tvb,0,(bit_length+7)/8);
}
output = wmem_new(pinfo->pool, nbap_ib_segment_t);
output->bit_length = bit_length;
@@ -213,39 +214,39 @@ static nbap_ib_segment_t* nbap_parse_ib_sg_data_var1(packet_info *pinfo, tvbuff_
typedef struct nbap_private_data_t
{
- guint32 transportLayerAddress_ipv4;
- guint16 binding_id_port;
+ uint32_t transportLayerAddress_ipv4;
+ uint16_t binding_id_port;
enum TransportFormatSet_type_enum transport_format_set_type;
- guint32 procedure_code;
- guint num_items;
- guint32 ul_scrambling_code;
- guint32 com_context_id;
- gint num_dch_in_flow;
- gint hrnti;
- guint32 protocol_ie_id;
- guint32 dd_mode;
- guint32 transaction_id;
- guint32 t_dch_id;
- guint32 dch_id;
- guint32 prev_dch_id;
- guint32 common_physical_channel_id;
- guint32 e_dch_macdflow_id;
- guint32 hsdsch_macdflow_id;
- gboolean max_mac_d_pdu_size_ext_ie_present;
- guint32 e_dch_ddi_value;
- guint32 logical_channel_id;
- guint32 common_macdflow_id;
- guint32 mac_d_pdu_size;
- guint32 common_transport_channel_id;
- gint paging_indications;
- guint32 ib_type;
- guint32 segment_type;
- gboolean crnc_context_present; /* Whether 'com_context_id' is set */
- guint8 dch_crc_present;
+ uint32_t procedure_code;
+ unsigned num_items;
+ uint32_t ul_scrambling_code;
+ uint32_t com_context_id;
+ int num_dch_in_flow;
+ int hrnti;
+ uint32_t protocol_ie_id;
+ uint32_t dd_mode;
+ uint32_t transaction_id;
+ uint32_t t_dch_id;
+ uint32_t dch_id;
+ uint32_t prev_dch_id;
+ uint32_t common_physical_channel_id;
+ uint32_t e_dch_macdflow_id;
+ uint32_t hsdsch_macdflow_id;
+ bool max_mac_d_pdu_size_ext_ie_present;
+ uint32_t e_dch_ddi_value;
+ uint32_t logical_channel_id;
+ uint32_t common_macdflow_id;
+ uint32_t mac_d_pdu_size;
+ uint32_t common_transport_channel_id;
+ int paging_indications;
+ uint32_t ib_type;
+ uint32_t segment_type;
+ bool crnc_context_present; /* Whether 'com_context_id' is set */
+ uint8_t dch_crc_present;
/* Arrays */
nbap_dch_channel_info_t nbap_dch_chnl_info[256];
nbap_edch_channel_info_t nbap_edch_channel_info[maxNrOfEDCHMACdFlows];
- gint hsdsch_macdflow_ids[maxNrOfMACdFlows];
+ int hsdsch_macdflow_ids[maxNrOfMACdFlows];
nbap_hsdsch_channel_info_t nbap_hsdsch_channel_info[maxNrOfMACdFlows];
nbap_common_channel_info_t nbap_common_channel_info[maxNrOfMACdFlows]; /*TODO: Fix this!*/
wmem_list_t* ib_segments; /* Information block segments */
@@ -255,7 +256,7 @@ typedef struct nbap_private_data_t
/* Helper function to get or create a private_data struct */
static nbap_private_data_t* nbap_get_private_data(packet_info *pinfo)
{
- guint8 i;
+ uint8_t i;
/* NOTE: Unlike other ASN.1 dissectors which store information in
* actx->private_data the NBAP dissector can't do so because some fields
* are defined as their own 'PDU' (Like BindingID and TransportLayerAddress)
@@ -269,7 +270,7 @@ static nbap_private_data_t* nbap_get_private_data(packet_info *pinfo)
p_add_proto_data(pinfo->pool, pinfo, proto_nbap, 0, private_data);
/* Setting default values */
private_data->hsdsch_macdflow_id = 3;
- private_data->crnc_context_present = FALSE;
+ private_data->crnc_context_present = false;
private_data->procedure_code = 0xFFFF;
private_data->dd_mode = 0xFFFF;
private_data->dch_crc_present = 2; /* Unknown */
@@ -292,16 +293,16 @@ static void nbap_reset_private_data(packet_info *pinfo)
/* Global Variables */
/* Variables for sub elements dissection */
-static const gchar *ProcedureID;
+static const char *ProcedureID;
/* Trees */
-static wmem_tree_t* edch_flow_port_map = NULL;
-wmem_tree_t *nbap_scrambling_code_crncc_map = NULL;
-wmem_tree_t *nbap_crncc_urnti_map = NULL;
+static wmem_tree_t* edch_flow_port_map;
+wmem_tree_t *nbap_scrambling_code_crncc_map;
+wmem_tree_t *nbap_crncc_urnti_map;
static wmem_tree_t* com_context_map;
/* This table is used externally from FP, MAC and such, TODO: merge this with
* lch_contents[] */
-guint8 lchId_type_table[]= {
+uint8_t lchId_type_table[]= {
MAC_CONTENT_UNKNOWN, /* Shouldn't happen*/
MAC_CONTENT_DCCH, /* 1 to 4 SRB => DCCH*/
MAC_CONTENT_DCCH,
@@ -321,7 +322,7 @@ guint8 lchId_type_table[]= {
};
/* Mapping logicalchannel id to RLC_MODE */
-guint8 lchId_rlc_map[] = {
+uint8_t lchId_rlc_map[] = {
0,
RLC_UM, /* Logical channel id = 1 is SRB1 which uses RLC_UM*/
RLC_AM,
@@ -408,7 +409,7 @@ static const enum_val_t ib_sg_enc_vals[] = {
{NULL, NULL, -1}
};
-static gint preferences_ib_sg_data_encoding = IB_SG_DATA_ENC_VAR_1;
+static int preferences_ib_sg_data_encoding = IB_SG_DATA_ENC_VAR_1;
/* Dissector tables */
static dissector_table_t nbap_ies_dissector_table;
@@ -423,10 +424,10 @@ static int dissect_InitiatingMessageValue(tvbuff_t *tvb, packet_info *pinfo, pro
static int dissect_SuccessfulOutcomeValue(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, void *);
static int dissect_UnsuccessfulOutcomeValue(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, void *);
-static guint32 calculate_setup_conv_key(const guint32 transaction_id, const guint32 dd_mode, const guint32 channel_id);
-static void add_setup_conv(const packet_info *pinfo _U_, const guint32 transaction_id, const guint32 dd_mode, const guint32 channel_id, const guint32 req_frame_number,
- const address *addr, const guint32 port, umts_fp_conversation_info_t * umts_fp_conversation_info, conversation_t *conv);
-static nbap_setup_conv_t* find_setup_conv(const packet_info *pinfo _U_, const guint32 transaction_id, const guint32 dd_mode, const guint32 channel_id);
+static uint32_t calculate_setup_conv_key(const uint32_t transaction_id, const uint32_t dd_mode, const uint32_t channel_id);
+static void add_setup_conv(const packet_info *pinfo _U_, const uint32_t transaction_id, const uint32_t dd_mode, const uint32_t channel_id, const uint32_t req_frame_number,
+ const address *addr, const uint32_t port, umts_fp_conversation_info_t * umts_fp_conversation_info, conversation_t *conv);
+static nbap_setup_conv_t* find_setup_conv(const packet_info *pinfo _U_, const uint32_t transaction_id, const uint32_t dd_mode, const uint32_t channel_id);
static void delete_setup_conv(nbap_setup_conv_t *conv);
/*Easy way to add hsdhsch binds for corner cases*/
@@ -436,16 +437,16 @@ static void add_hsdsch_bind(packet_info * pinfo);
static int dissect_ProtocolIEFieldValue(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, void *data _U_)
{
- guint32 protocol_ie_id;
+ uint32_t protocol_ie_id;
protocol_ie_id = nbap_get_private_data(pinfo)->protocol_ie_id;
- return (dissector_try_uint_new(nbap_ies_dissector_table, protocol_ie_id, tvb, pinfo, tree, FALSE, NULL)) ? tvb_captured_length(tvb) : 0;
+ return (dissector_try_uint_new(nbap_ies_dissector_table, protocol_ie_id, tvb, pinfo, tree, false, NULL)) ? tvb_captured_length(tvb) : 0;
}
static int dissect_ProtocolExtensionFieldExtensionValue(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, void *data _U_)
{
- guint32 protocol_ie_id;
+ uint32_t protocol_ie_id;
protocol_ie_id = nbap_get_private_data(pinfo)->protocol_ie_id;
- return (dissector_try_uint_new(nbap_extension_dissector_table, protocol_ie_id, tvb, pinfo, tree, FALSE, NULL)) ? tvb_captured_length(tvb) : 0;
+ return (dissector_try_uint_new(nbap_extension_dissector_table, protocol_ie_id, tvb, pinfo, tree, false, NULL)) ? tvb_captured_length(tvb) : 0;
}
static int dissect_InitiatingMessageValue(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, void *data _U_)
@@ -470,7 +471,7 @@ static void add_hsdsch_bind(packet_info *pinfo){
conversation_t *conversation = NULL;
umts_fp_conversation_info_t *umts_fp_conversation_info;
fp_hsdsch_channel_info_t* fp_hsdsch_channel_info = NULL;
- guint32 i;
+ uint32_t i;
nbap_private_data_t* nbap_private_data;
nbap_hsdsch_channel_info_t* nbap_hsdsch_channel_info;
@@ -541,14 +542,14 @@ static void add_hsdsch_bind(packet_info *pinfo){
/*
* Function used to manage conversation declared in Setup Request/Response message
*/
-static guint32 calculate_setup_conv_key(const guint32 transaction_id, const guint32 dd_mode, const guint32 channel_id)
+static uint32_t calculate_setup_conv_key(const uint32_t transaction_id, const uint32_t dd_mode, const uint32_t channel_id)
{
/* We need to pack 3 values on 32 bits:
* 31-16 transaction_id
* 15-14 dd_mode
* 13-0 channel_id
*/
- guint32 key;
+ uint32_t key;
key = transaction_id << 16;
key |= (dd_mode & 0x03) << 14;
key |= (channel_id & 0x3fff);
@@ -556,11 +557,11 @@ static guint32 calculate_setup_conv_key(const guint32 transaction_id, const guin
return key;
}
-static void add_setup_conv(const packet_info *pinfo _U_, const guint32 transaction_id, const guint32 dd_mode, const guint32 channel_id, const guint32 req_frame_number,
- const address *addr, const guint32 port, umts_fp_conversation_info_t * umts_fp_conversation_info, conversation_t *conv)
+static void add_setup_conv(const packet_info *pinfo _U_, const uint32_t transaction_id, const uint32_t dd_mode, const uint32_t channel_id, const uint32_t req_frame_number,
+ const address *addr, const uint32_t port, umts_fp_conversation_info_t * umts_fp_conversation_info, conversation_t *conv)
{
nbap_setup_conv_t *new_conv = NULL;
- guint32 key;
+ uint32_t key;
nbap_debug("Creating new setup conv\t TransactionID: %u\tddMode: %u\tChannelID: %u\t %s:%u",
transaction_id, dd_mode, channel_id, address_to_str(pinfo->pool, addr), port);
@@ -582,10 +583,10 @@ static void add_setup_conv(const packet_info *pinfo _U_, const guint32 transacti
wmem_map_insert(nbap_setup_conv_table, GUINT_TO_POINTER(key), new_conv);
}
-static nbap_setup_conv_t* find_setup_conv(const packet_info *pinfo _U_, const guint32 transaction_id, const guint32 dd_mode, const guint32 channel_id)
+static nbap_setup_conv_t* find_setup_conv(const packet_info *pinfo _U_, const uint32_t transaction_id, const uint32_t dd_mode, const uint32_t channel_id)
{
nbap_setup_conv_t *conv;
- guint32 key;
+ uint32_t key;
nbap_debug("Looking for Setup Conversation match\t TransactionID: %u\t ddMode: %u\t ChannelID: %u", transaction_id, dd_mode, channel_id);
key = calculate_setup_conv_key(transaction_id, dd_mode, channel_id);
@@ -604,7 +605,7 @@ static nbap_setup_conv_t* find_setup_conv(const packet_info *pinfo _U_, const gu
static void delete_setup_conv(nbap_setup_conv_t *conv)
{
- guint32 key;
+ uint32_t key;
/* check if conversation exist */
if(conv == NULL){
@@ -616,18 +617,10 @@ static void delete_setup_conv(nbap_setup_conv_t *conv)
}
static void nbap_init(void){
- guint8 i;
- /*Initialize*/
- com_context_map = wmem_tree_new_autoreset(wmem_epan_scope(), wmem_file_scope());
-
- /*Initialize structure for muxed flow indication*/
- edch_flow_port_map = wmem_tree_new_autoreset(wmem_epan_scope(), wmem_file_scope());
+ uint8_t i;
/*Initialize Setup Conversation hash table*/
nbap_setup_conv_table = wmem_map_new(wmem_file_scope(), g_direct_hash, g_direct_equal);
- /*Initializing Scrambling Code to C-RNC Context & C-RNC Context to U-RNTI maps*/
- nbap_scrambling_code_crncc_map = wmem_tree_new_autoreset(wmem_epan_scope(), wmem_file_scope());
- nbap_crncc_urnti_map = wmem_tree_new_autoreset(wmem_epan_scope(), wmem_file_scope());
for (i = 0; i < 15; i++) {
lchId_type_table[i+1] = lch_contents[i];
@@ -655,50 +648,50 @@ dissect_nbap(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, void *data)
/* Highest ProcedureCode value, used in heuristics */
#define NBAP_MAX_PC 56 /* id-secondaryULFrequencyUpdate = 56*/
#define NBAP_MSG_MIN_LENGTH 7
-static gboolean
+static bool
dissect_nbap_heur(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, void *data)
{
- guint8 pdu_type;
- guint8 procedure_id;
- guint8 dd_mode;
- guint8 criticality;
- guint8 transaction_id_type;
- guint length;
+ uint8_t pdu_type;
+ uint8_t procedure_id;
+ uint8_t dd_mode;
+ uint8_t criticality;
+ uint8_t transaction_id_type;
+ unsigned length;
int length_field_offset;
#define PDU_TYPE_OFFSET 0
#define PROC_CODE_OFFSET 1
#define DD_CRIT_OFFSET 2
if (tvb_captured_length(tvb) < NBAP_MSG_MIN_LENGTH) {
- return FALSE;
+ return false;
}
- pdu_type = tvb_get_guint8(tvb, PDU_TYPE_OFFSET);
+ pdu_type = tvb_get_uint8(tvb, PDU_TYPE_OFFSET);
if (pdu_type & 0x1f) {
/* pdu_type is not 0x00 (initiatingMessage), 0x20 (succesfulOutcome),
0x40 (unsuccesfulOutcome) or 0x60 (outcome), ignore extension bit (0x80) */
- return FALSE;
+ return false;
}
- procedure_id = tvb_get_guint8(tvb, PROC_CODE_OFFSET);
+ procedure_id = tvb_get_uint8(tvb, PROC_CODE_OFFSET);
if (procedure_id > NBAP_MAX_PC) {
- return FALSE;
+ return false;
}
- dd_mode = tvb_get_guint8(tvb, DD_CRIT_OFFSET) >> 5;
+ dd_mode = tvb_get_uint8(tvb, DD_CRIT_OFFSET) >> 5;
if (dd_mode >= 0x03) {
/* dd_mode is not 0x00 (tdd), 0x01 (fdd) or 0x02 (common) */
- return FALSE;
+ return false;
}
- criticality = (tvb_get_guint8(tvb, DD_CRIT_OFFSET) & 0x18) >> 3;
+ criticality = (tvb_get_uint8(tvb, DD_CRIT_OFFSET) & 0x18) >> 3;
if (criticality == 0x03) {
/* criticality is not 0x00 (reject), 0x01 (ignore) or 0x02 (notify) */
- return FALSE;
+ return false;
}
/* Finding the offset for the length field - depends on wether the transaction id is long or short */
- transaction_id_type = (tvb_get_guint8(tvb, DD_CRIT_OFFSET) & 0x02) >> 1;
+ transaction_id_type = (tvb_get_uint8(tvb, DD_CRIT_OFFSET) & 0x02) >> 1;
if(transaction_id_type == 0x00) { /* Short transaction id - 1 byte*/
length_field_offset = 4;
}
@@ -708,32 +701,32 @@ dissect_nbap_heur(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, void *dat
/* compute aligned PER length determinant without calling dissect_per_length_determinant()
to avoid exceptions and info added to tree, info column and expert info */
- length = tvb_get_guint8(tvb, length_field_offset);
+ length = tvb_get_uint8(tvb, length_field_offset);
length_field_offset += 1;
if (length & 0x80) {
if ((length & 0xc0) == 0x80) {
length &= 0x3f;
length <<= 8;
- length += tvb_get_guint8(tvb, length_field_offset);
+ length += tvb_get_uint8(tvb, length_field_offset);
length_field_offset += 1;
} else {
length = 0;
}
}
if (length!= (tvb_reported_length(tvb) - length_field_offset)){
- return FALSE;
+ return false;
}
dissect_nbap(tvb, pinfo, tree, data);
- return TRUE;
+ return true;
}
/*--- proto_register_nbap -------------------------------------------*/
void proto_register_nbap(void)
{
module_t *nbap_module;
- guint8 i;
+ uint8_t i;
/* List of fields */
static hf_register_info hf[] = {
@@ -757,7 +750,7 @@ void proto_register_nbap(void)
};
/* List of subtrees */
- static gint *ett[] = {
+ static int *ett[] = {
&ett_nbap,
&ett_nbap_TransportLayerAddress,
&ett_nbap_TransportLayerAddress_nsap,
@@ -788,12 +781,12 @@ void proto_register_nbap(void)
/* Register preferences for mapping logical channel IDs to MAC content types. */
for (i = 0; i < 16; i++) {
- prefs_register_enum_preference(nbap_module, ch_strings[i].name, ch_strings[i].title, ch_strings[i].description, &lch_contents[i], content_types, FALSE);
+ prefs_register_enum_preference(nbap_module, ch_strings[i].name, ch_strings[i].title, ch_strings[i].description, &lch_contents[i], content_types, false);
}
prefs_register_enum_preference(nbap_module, "ib_sg_data_encoding",
"IB_SG_DATA encoding",
"Encoding used for the IB-SG-DATA element carrying segments of information blocks",
- &preferences_ib_sg_data_encoding, ib_sg_enc_vals, FALSE);
+ &preferences_ib_sg_data_encoding, ib_sg_enc_vals, false);
/* Register dissector tables */
nbap_ies_dissector_table = register_dissector_table("nbap.ies", "NBAP-PROTOCOL-IES", proto_nbap, FT_UINT32, BASE_DEC);
@@ -803,6 +796,15 @@ void proto_register_nbap(void)
nbap_proc_uout_dissector_table = register_dissector_table("nbap.proc.uout", "NBAP-ELEMENTARY-PROCEDURE UnsuccessfulOutcome", proto_nbap, FT_STRING, STRING_CASE_SENSITIVE);
register_init_routine(nbap_init);
+
+ com_context_map = wmem_tree_new_autoreset(wmem_epan_scope(), wmem_file_scope());
+
+ /*Initialize structure for muxed flow indication*/
+ edch_flow_port_map = wmem_tree_new_autoreset(wmem_epan_scope(), wmem_file_scope());
+
+ /*Initializing Scrambling Code to C-RNC Context & C-RNC Context to U-RNTI maps*/
+ nbap_scrambling_code_crncc_map = wmem_tree_new_autoreset(wmem_epan_scope(), wmem_file_scope());
+ nbap_crncc_urnti_map = wmem_tree_new_autoreset(wmem_epan_scope(), wmem_file_scope());
}
/*
diff --git a/epan/dissectors/asn1/nbap/packet-nbap-template.h b/epan/dissectors/asn1/nbap/packet-nbap-template.h
index a19d11af..f3170080 100644
--- a/epan/dissectors/asn1/nbap/packet-nbap-template.h
+++ b/epan/dissectors/asn1/nbap/packet-nbap-template.h
@@ -20,10 +20,10 @@
/*Array are indexed on logical channel id, meaning they need to be defined for 1-15*/
/* Mapping from logical channel id to MAC content type ie. DCCH or DTCH*/
-extern guint8 lchId_type_table[];
+extern uint8_t lchId_type_table[];
/* Mapping logicalchannel id to RLC_MODE */
-extern guint8 lchId_rlc_map[];
+extern uint8_t lchId_rlc_map[];
/* Mapping Scrambling Codes to C-RNC Contexts */
extern wmem_tree_t *nbap_scrambling_code_crncc_map;