diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-09-19 04:14:53 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-09-19 04:14:53 +0000 |
commit | a86c5f7cae7ec9a3398300555a0b644689d946a1 (patch) | |
tree | 39fe4b107c71174fd1e8a8ceb9a4d2aa14116248 /epan/dissectors/packet-3g-a11.c | |
parent | Releasing progress-linux version 4.2.6-1~progress7.99u1. (diff) | |
download | wireshark-a86c5f7cae7ec9a3398300555a0b644689d946a1.tar.xz wireshark-a86c5f7cae7ec9a3398300555a0b644689d946a1.zip |
Merging upstream version 4.4.0.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'epan/dissectors/packet-3g-a11.c')
-rw-r--r-- | epan/dissectors/packet-3g-a11.c | 511 |
1 files changed, 254 insertions, 257 deletions
diff --git a/epan/dissectors/packet-3g-a11.c b/epan/dissectors/packet-3g-a11.c index 27080c46..4918c8e1 100644 --- a/epan/dissectors/packet-3g-a11.c +++ b/epan/dissectors/packet-3g-a11.c @@ -24,6 +24,8 @@ * https://www.3gpp2.org/Public_html/Specs/A.S0017-D%20v3.0_Interoperability%20Specification%20%28IOS%29%20for%20cdma2000%20Access%20Network%20Interfaces%20-%20Part%207%20%28A10%20and%20A11%20Interfaces%29_20110701.pdf * https://www.3gpp2.org/Public_html/Specs/A00-20110419-002Er0%20A.S0008-C%20v4.0%20HRPD%20IOS-Pub_20110513.pdf * https://www.3gpp2.org/Public_html/Specs/A.S0022-0_v2.0_100426.pdf + * + * https://web.archive.org/web/20070812071100/http://3gpp2.org:80/Public_html/specs/A.S0017-0_v2.0.pdf */ #include "config.h" @@ -33,6 +35,7 @@ /* Include vendor id translation */ #include <epan/sminmpec.h> #include <epan/addr_resolv.h> +#include <epan/tfs.h> #include "packet-radius.h" @@ -40,178 +43,178 @@ void proto_register_a11(void); void proto_reg_handoff_a11(void); -static int registration_request_msg =0; +static int registration_request_msg; /* Initialize the protocol and registered fields */ -static int proto_a11 = -1; -static int hf_a11_type = -1; -static int hf_a11_flags = -1; -static int hf_a11_s = -1; -static int hf_a11_b = -1; -static int hf_a11_d = -1; -static int hf_a11_m = -1; -static int hf_a11_g = -1; -static int hf_a11_v = -1; -static int hf_a11_t = -1; -static int hf_a11_code = -1; -static int hf_a11_status = -1; -static int hf_a11_life = -1; -static int hf_a11_homeaddr = -1; -static int hf_a11_haaddr = -1; -static int hf_a11_coa = -1; -static int hf_a11_ident = -1; -static int hf_a11_ext_type = -1; -static int hf_a11_ext_stype = -1; -static int hf_a11_ext_len = -1; -static int hf_a11_ext = -1; -static int hf_a11_aext_spi = -1; -static int hf_a11_aext_auth = -1; -static int hf_a11_next_nai = -1; - -static int hf_a11_ses_key = -1; -static int hf_a11_ses_mnsrid = -1; -static int hf_a11_ses_sidver = -1; -static int hf_a11_ses_msid_type = -1; -static int hf_a11_ses_msid_len = -1; -static int hf_a11_ses_msid = -1; -static int hf_a11_ses_ptype = -1; - -static int hf_a11_vse_vid = -1; -static int hf_a11_vse_apptype = -1; -static int hf_a11_vse_canid = -1; -static int hf_a11_vse_panid = -1; -static int hf_a11_vse_srvopt = -1; -static int hf_a11_vse_qosmode = -1; -static int hf_a11_vse_pdit = -1; -static int hf_a11_vse_session_parameter = -1; -static int hf_a11_vse_code = -1; -static int hf_a11_vse_dormant = -1; -static int hf_a11_vse_ehrpd_mode = -1; -static int hf_a11_vse_ehrpd_pmk = -1; -static int hf_a11_vse_ehrpd_handoff_info = -1; -static int hf_a11_vse_ehrpd_tunnel_mode = -1; -static int hf_a11_vse_ppaddr = -1; +static int proto_a11; +static int hf_a11_type; +static int hf_a11_flags; +static int hf_a11_s; +static int hf_a11_b; +static int hf_a11_d; +static int hf_a11_m; +static int hf_a11_g; +static int hf_a11_v; +static int hf_a11_t; +static int hf_a11_code; +static int hf_a11_status; +static int hf_a11_life; +static int hf_a11_homeaddr; +static int hf_a11_haaddr; +static int hf_a11_coa; +static int hf_a11_ident; +static int hf_a11_ext_type; +static int hf_a11_ext_stype; +static int hf_a11_ext_len; +static int hf_a11_ext; +static int hf_a11_aext_spi; +static int hf_a11_aext_auth; +static int hf_a11_next_nai; + +static int hf_a11_ses_key; +static int hf_a11_ses_mnsrid; +static int hf_a11_ses_sidver; +static int hf_a11_ses_msid_type; +static int hf_a11_ses_msid_len; +static int hf_a11_ses_msid; +static int hf_a11_ses_ptype; + +static int hf_a11_vse_vid; +static int hf_a11_vse_apptype; +static int hf_a11_vse_canid; +static int hf_a11_vse_panid; +static int hf_a11_vse_srvopt; +static int hf_a11_vse_qosmode; +static int hf_a11_vse_pdit; +static int hf_a11_vse_session_parameter; +static int hf_a11_vse_code; +static int hf_a11_vse_dormant; +static int hf_a11_vse_ehrpd_mode; +static int hf_a11_vse_ehrpd_pmk; +static int hf_a11_vse_ehrpd_handoff_info; +static int hf_a11_vse_ehrpd_tunnel_mode; +static int hf_a11_vse_ppaddr; /* Additional Session Information */ -static int hf_a11_ase_len_type = -1; -static int hf_a11_ase_srid_type = -1; -static int hf_a11_ase_servopt_type = -1; -static int hf_a11_ase_gre_proto_type = -1; -static int hf_a11_ase_gre_key = -1; -static int hf_a11_ase_pcf_addr_key = -1; - -static int hf_a11_ase_forward_rohc_info_len = -1; -static int hf_a11_ase_forward_maxcid = -1; -static int hf_a11_ase_forward_mrru = -1; -static int hf_a11_ase_forward_large_cids = -1; -static int hf_a11_ase_forward_profile_count = -1; -static int hf_a11_ase_forward_profile = -1; - -static int hf_a11_ase_reverse_rohc_info_len = -1; -static int hf_a11_ase_reverse_maxcid = -1; -static int hf_a11_ase_reverse_mrru = -1; -static int hf_a11_ase_reverse_large_cids = -1; -static int hf_a11_ase_reverse_profile_count = -1; -static int hf_a11_ase_reverse_profile = -1; -static int hf_a11_aut_flow_prof_sub_type = -1; -static int hf_a11_aut_flow_prof_sub_type_len = -1; -static int hf_a11_aut_flow_prof_sub_type_value = -1; -static int hf_a11_serv_opt_prof_max_serv = -1; -static int hf_a11_sub_type = -1; -static int hf_a11_sub_type_length = -1; -static int hf_a11_serv_opt = -1; -static int hf_a11_max_num_serv_opt = -1; -static int hf_a11_bcmcs_stype = -1; -static int hf_a11_bcmcs_entry_len = -1; +static int hf_a11_ase_len_type; +static int hf_a11_ase_srid_type; +static int hf_a11_ase_servopt_type; +static int hf_a11_ase_gre_proto_type; +static int hf_a11_ase_gre_key; +static int hf_a11_ase_pcf_addr_key; + +static int hf_a11_ase_forward_rohc_info_len; +static int hf_a11_ase_forward_maxcid; +static int hf_a11_ase_forward_mrru; +static int hf_a11_ase_forward_large_cids; +static int hf_a11_ase_forward_profile_count; +static int hf_a11_ase_forward_profile; + +static int hf_a11_ase_reverse_rohc_info_len; +static int hf_a11_ase_reverse_maxcid; +static int hf_a11_ase_reverse_mrru; +static int hf_a11_ase_reverse_large_cids; +static int hf_a11_ase_reverse_profile_count; +static int hf_a11_ase_reverse_profile; +static int hf_a11_aut_flow_prof_sub_type; +static int hf_a11_aut_flow_prof_sub_type_len; +static int hf_a11_aut_flow_prof_sub_type_value; +static int hf_a11_serv_opt_prof_max_serv; +static int hf_a11_sub_type; +static int hf_a11_sub_type_length; +static int hf_a11_serv_opt; +static int hf_a11_max_num_serv_opt; +static int hf_a11_bcmcs_stype; +static int hf_a11_bcmcs_entry_len; /* Forward QoS Information */ -static int hf_a11_fqi_srid = -1; -static int hf_a11_fqi_flags = -1; -static int hf_a11_fqi_flags_ip_flow = -1; -static int hf_a11_fqi_flags_dscp = -1; -static int hf_a11_fqi_entry_flag = -1; -static int hf_a11_fqi_entry_flag_dscp = -1; -static int hf_a11_fqi_entry_flag_flow_state = -1; -static int hf_a11_fqi_flowcount = -1; -static int hf_a11_fqi_flowid = -1; -static int hf_a11_fqi_entrylen = -1; -/* static int hf_a11_fqi_flowstate = -1; */ -static int hf_a11_fqi_requested_qoslen = -1; -static int hf_a11_fqi_flow_priority = -1; -static int hf_a11_fqi_num_qos_attribute_set = -1; -static int hf_a11_fqi_qos_attribute_setlen = -1; -static int hf_a11_fqi_qos_attribute_setid = -1; -static int hf_a11_fqi_qos_granted_attribute_setid = -1; -static int hf_a11_fqi_verbose = -1; -static int hf_a11_fqi_flow_profileid = -1; -static int hf_a11_fqi_granted_qoslen = -1; +static int hf_a11_fqi_srid; +static int hf_a11_fqi_flags; +static int hf_a11_fqi_flags_ip_flow; +static int hf_a11_fqi_flags_dscp; +static int hf_a11_fqi_entry_flag; +static int hf_a11_fqi_entry_flag_dscp; +static int hf_a11_fqi_entry_flag_flow_state; +static int hf_a11_fqi_flowcount; +static int hf_a11_fqi_flowid; +static int hf_a11_fqi_entrylen; +/* static int hf_a11_fqi_flowstate; */ +static int hf_a11_fqi_requested_qoslen; +static int hf_a11_fqi_flow_priority; +static int hf_a11_fqi_num_qos_attribute_set; +static int hf_a11_fqi_qos_attribute_setlen; +static int hf_a11_fqi_qos_attribute_setid; +static int hf_a11_fqi_qos_granted_attribute_setid; +static int hf_a11_fqi_verbose; +static int hf_a11_fqi_flow_profileid; +static int hf_a11_fqi_granted_qoslen; /* Reverse QoS Information */ -static int hf_a11_rqi_srid = -1; -static int hf_a11_rqi_flowcount = -1; -static int hf_a11_rqi_flowid = -1; -static int hf_a11_rqi_entrylen = -1; -static int hf_a11_rqi_entry_flag = -1; -static int hf_a11_rqi_entry_flag_flow_state = -1; -/* static int hf_a11_rqi_flowstate = -1; */ -static int hf_a11_rqi_requested_qoslen = -1; -static int hf_a11_rqi_flow_priority = -1; -static int hf_a11_rqi_num_qos_attribute_set = -1; -static int hf_a11_rqi_qos_attribute_setlen = -1; -static int hf_a11_rqi_qos_attribute_setid = -1; -static int hf_a11_rqi_qos_granted_attribute_setid = -1; -static int hf_a11_rqi_verbose = -1; -static int hf_a11_rqi_flow_profileid = -1; -/* static int hf_a11_rqi_requested_qos = -1; */ -static int hf_a11_rqi_granted_qoslen = -1; -/* static int hf_a11_rqi_granted_qos = -1; */ +static int hf_a11_rqi_srid; +static int hf_a11_rqi_flowcount; +static int hf_a11_rqi_flowid; +static int hf_a11_rqi_entrylen; +static int hf_a11_rqi_entry_flag; +static int hf_a11_rqi_entry_flag_flow_state; +/* static int hf_a11_rqi_flowstate; */ +static int hf_a11_rqi_requested_qoslen; +static int hf_a11_rqi_flow_priority; +static int hf_a11_rqi_num_qos_attribute_set; +static int hf_a11_rqi_qos_attribute_setlen; +static int hf_a11_rqi_qos_attribute_setid; +static int hf_a11_rqi_qos_granted_attribute_setid; +static int hf_a11_rqi_verbose; +static int hf_a11_rqi_flow_profileid; +/* static int hf_a11_rqi_requested_qos; */ +static int hf_a11_rqi_granted_qoslen; +/* static int hf_a11_rqi_granted_qos; */ /* QoS Update Information */ -static int hf_a11_fqui_flowcount = -1; -static int hf_a11_rqui_flowcount = -1; -static int hf_a11_fqui_updated_qoslen = -1; -static int hf_a11_fqui_updated_qos = -1; -static int hf_a11_rqui_updated_qoslen = -1; -static int hf_a11_rqui_updated_qos = -1; -static int hf_a11_subsciber_profile = -1; -/* static int hf_a11_subsciber_profile_len = -1; */ +static int hf_a11_fqui_flowcount; +static int hf_a11_rqui_flowcount; +static int hf_a11_fqui_updated_qoslen; +static int hf_a11_fqui_updated_qos; +static int hf_a11_rqui_updated_qoslen; +static int hf_a11_rqui_updated_qos; +static int hf_a11_subscriber_profile; +/* static int hf_a11_subscriber_profile_len; */ /* Initialize the subtree pointers */ -static gint ett_a11 = -1; -static gint ett_a11_flags = -1; -static gint ett_a11_ext = -1; -static gint ett_a11_exts = -1; -static gint ett_a11_radius = -1; -static gint ett_a11_radiuses = -1; -static gint ett_a11_ase = -1; -static gint ett_a11_fqi_flowentry = -1; -static gint ett_a11_fqi_requestedqos = -1; -static gint ett_a11_fqi_qos_attribute_set = -1; -static gint ett_a11_fqi_grantedqos = -1; -static gint ett_a11_rqi_flowentry = -1; -static gint ett_a11_rqi_requestedqos = -1; -static gint ett_a11_rqi_qos_attribute_set = -1; -static gint ett_a11_rqi_grantedqos = -1; -static gint ett_a11_fqi_flags = -1; -static gint ett_a11_fqi_entry_flags = -1; -static gint ett_a11_rqi_entry_flags = -1; -static gint ett_a11_fqui_flowentry = -1; -static gint ett_a11_rqui_flowentry = -1; -static gint ett_a11_subscriber_profile = -1; -static gint ett_a11_forward_rohc = -1; -static gint ett_a11_reverse_rohc = -1; -static gint ett_a11_forward_profile = -1; -static gint ett_a11_reverse_profile = -1; -static gint ett_a11_aut_flow_profile_ids = -1; -static gint ett_a11_bcmcs_entry = -1; - -static expert_field ei_a11_sub_type_length_not2 = EI_INIT; -static expert_field ei_a11_sse_too_short = EI_INIT; -static expert_field ei_a11_bcmcs_too_short = EI_INIT; -static expert_field ei_a11_entry_data_not_dissected = EI_INIT; -static expert_field ei_a11_session_data_not_dissected = EI_INIT; - -static dissector_handle_t a11_handle = NULL; +static int ett_a11; +static int ett_a11_flags; +static int ett_a11_ext; +static int ett_a11_exts; +static int ett_a11_radius; +static int ett_a11_radiuses; +static int ett_a11_ase; +static int ett_a11_fqi_flowentry; +static int ett_a11_fqi_requestedqos; +static int ett_a11_fqi_qos_attribute_set; +static int ett_a11_fqi_grantedqos; +static int ett_a11_rqi_flowentry; +static int ett_a11_rqi_requestedqos; +static int ett_a11_rqi_qos_attribute_set; +static int ett_a11_rqi_grantedqos; +static int ett_a11_fqi_flags; +static int ett_a11_fqi_entry_flags; +static int ett_a11_rqi_entry_flags; +static int ett_a11_fqui_flowentry; +static int ett_a11_rqui_flowentry; +static int ett_a11_subscriber_profile; +static int ett_a11_forward_rohc; +static int ett_a11_reverse_rohc; +static int ett_a11_forward_profile; +static int ett_a11_reverse_profile; +static int ett_a11_aut_flow_profile_ids; +static int ett_a11_bcmcs_entry; + +static expert_field ei_a11_sub_type_length_not2; +static expert_field ei_a11_sse_too_short; +static expert_field ei_a11_bcmcs_too_short; +static expert_field ei_a11_entry_data_not_dissected; +static expert_field ei_a11_session_data_not_dissected; + +static dissector_handle_t a11_handle; /* Port used for Mobile IP based Tunneling Protocol (A11) */ #define UDP_PORT_3GA11 699 /* Not IANA registered */ @@ -505,11 +508,6 @@ static const value_string a11_rohc_profile_vals[] = }; static value_string_ext a11_rohc_profile_vals_ext = VALUE_STRING_EXT_INIT(a11_rohc_profile_vals); -#define NUM_ATTR (sizeof(attrs)/sizeof(struct radius_attribute)) - -#define RADIUS_VENDOR_SPECIFIC 26 -#define SKIP_HDR_LEN 6 - /* decode MSID from SSE */ /* MSID is encoded in Binary Coded Decimal format @@ -546,15 +544,15 @@ static int * const a11_flags[] = { }; static void -decode_sse(proto_tree *ext_tree, packet_info *pinfo, tvbuff_t *tvb, int offset, guint ext_len, proto_item *ext_len_item) +decode_sse(proto_tree *ext_tree, packet_info *pinfo, tvbuff_t *tvb, int offset, unsigned ext_len, proto_item *ext_len_item) { - guint8 msid_len; - guint8 msid_start_offset; - guint8 msid_num_digits; - guint8 msid_index; + uint8_t msid_len; + uint8_t msid_start_offset; + uint8_t msid_num_digits; + uint8_t msid_index; char *msid_digits; const char *p_msid; - gboolean odd_even_ind; + bool odd_even_ind; /* Decode Protocol Type */ if (ext_len < 2) { @@ -615,7 +613,7 @@ decode_sse(proto_tree *ext_tree, packet_info *pinfo, tvbuff_t *tvb, int offset, "Cannot decode MSID Length - SSE too short"); return; } - msid_len = tvb_get_guint8(tvb, offset); + msid_len = tvb_get_uint8(tvb, offset); proto_tree_add_item(ext_tree, hf_a11_ses_msid_len, tvb, offset, 1, ENC_BIG_ENDIAN); offset += 1; ext_len -= 1; @@ -637,7 +635,7 @@ decode_sse(proto_tree *ext_tree, packet_info *pinfo, tvbuff_t *tvb, int offset, } else { /* Decode the BCD digits */ for (msid_index=0; msid_index<msid_len; msid_index++) { - guint8 msid_digit = tvb_get_guint8(tvb, offset); + uint8_t msid_digit = tvb_get_uint8(tvb, offset); offset += 1; ext_len -= 1; @@ -661,10 +659,10 @@ decode_sse(proto_tree *ext_tree, packet_info *pinfo, tvbuff_t *tvb, int offset, } static void -decode_bcmcs(proto_tree* ext_tree, packet_info *pinfo, tvbuff_t* tvb, int offset, guint ext_len, proto_item *ext_len_item) +decode_bcmcs(proto_tree* ext_tree, packet_info *pinfo, tvbuff_t* tvb, int offset, unsigned ext_len, proto_item *ext_len_item) { - guint8 bc_stype, entry_len; + uint8_t bc_stype, entry_len; /* Decode Protocol Type */ if (ext_len < 2) { @@ -673,7 +671,7 @@ decode_bcmcs(proto_tree* ext_tree, packet_info *pinfo, tvbuff_t* tvb, int offset return; } - bc_stype=tvb_get_guint8(tvb, offset); + bc_stype=tvb_get_uint8(tvb, offset); proto_tree_add_item(ext_tree, hf_a11_bcmcs_stype, tvb, offset, 1, ENC_BIG_ENDIAN); offset += 1; ext_len -= 1; @@ -685,7 +683,7 @@ decode_bcmcs(proto_tree* ext_tree, packet_info *pinfo, tvbuff_t* tvb, int offset proto_tree *entry_tree; while (ext_len > 0) { i++; - entry_len = tvb_get_guint8(tvb, offset); + entry_len = tvb_get_uint8(tvb, offset); if (entry_len == 0) { ext_len -= 1; entry_len = 1; @@ -704,7 +702,6 @@ decode_bcmcs(proto_tree* ext_tree, packet_info *pinfo, tvbuff_t* tvb, int offset default: proto_tree_add_expert_format(ext_tree, pinfo, &ei_a11_session_data_not_dissected, tvb, offset, -1, "Session Data Type %u Not dissected yet", bc_stype); return; - break; } @@ -727,17 +724,17 @@ dissect_a11_radius( tvbuff_t *tvb, packet_info *pinfo, int offset, proto_tree *t radius_tree = proto_tree_add_subtree(tree, tvb, offset - 2, app_len, ett_a11_radiuses, NULL, "Airlink Record"); - dissect_attribute_value_pairs(radius_tree, pinfo, tvb, offset, app_len-2); + dissect_attribute_value_pairs(radius_tree, pinfo, tvb, offset, app_len-2, NULL); } /* X.S0011-005-D v2.0 Service Option Profile */ -static const gchar * +static const char * dissect_3gpp2_service_option_profile(proto_tree *tree, tvbuff_t *tvb, packet_info *pinfo) { int offset = 0; - guint8 sub_type, sub_type_length; + uint8_t sub_type, sub_type_length; proto_item *pi; /* Maximum service connections/Link Flows total 32 bit*/ @@ -745,9 +742,9 @@ dissect_3gpp2_service_option_profile(proto_tree *tree, tvbuff_t *tvb, packet_i offset+=4; while (tvb_reported_length_remaining(tvb,offset) > 0) { - sub_type_length = tvb_get_guint8(tvb,offset+1); + sub_type_length = tvb_get_uint8(tvb,offset+1); - sub_type = tvb_get_guint8(tvb,offset); + sub_type = tvb_get_uint8(tvb,offset); proto_tree_add_item(tree, hf_a11_sub_type, tvb, offset, 1, ENC_BIG_ENDIAN); offset += 1; pi = proto_tree_add_item(tree, hf_a11_sub_type_length, tvb, offset, 1, ENC_BIG_ENDIAN); @@ -779,18 +776,18 @@ static const value_string a11_aut_flow_prof_subtype_vals[] = { }; /* X.S0011-005-D v2.0 Authorized Flow Profile IDs for the User */ -static const gchar * +static const char * dissect_3gpp2_radius_aut_flow_profile_ids(proto_tree *tree, tvbuff_t *tvb, packet_info *pinfo) { proto_tree *sub_tree; int offset = 0; proto_item *item; - guint8 sub_type, sub_type_length; - guint32 value; + uint8_t sub_type, sub_type_length; + uint32_t value; while (tvb_reported_length_remaining(tvb,offset) > 0) { - sub_type = tvb_get_guint8(tvb,offset); - sub_type_length = tvb_get_guint8(tvb,offset+1); + sub_type = tvb_get_uint8(tvb,offset); + sub_type_length = tvb_get_uint8(tvb,offset+1); /* value is 2 octets */ value = tvb_get_ntohs(tvb,offset+2); sub_tree = proto_tree_add_subtree_format(tree, tvb, offset, sub_type_length, ett_a11_aut_flow_profile_ids, &item, @@ -814,20 +811,20 @@ dissect_3gpp2_radius_aut_flow_profile_ids(proto_tree *tree, tvbuff_t *tvb, pac /* Code to dissect Additional Session Info */ static void -dissect_ase(tvbuff_t *tvb, int offset, guint ase_len, proto_tree *ext_tree) +dissect_ase(tvbuff_t *tvb, int offset, unsigned ase_len, proto_tree *ext_tree) { - guint clen = 0; /* consumed length */ + unsigned clen = 0; /* consumed length */ while (clen < ase_len) { proto_tree *exts_tree; - guint8 srid = tvb_get_guint8(tvb, offset+1); - guint16 service_option = tvb_get_ntohs(tvb, offset+2); - guint8 entry_length; + uint8_t srid = tvb_get_uint8(tvb, offset+1); + uint16_t service_option = tvb_get_ntohs(tvb, offset+2); + uint8_t entry_length; int entry_start_offset; /* Entry Length */ entry_start_offset = offset; - entry_length = tvb_get_guint8(tvb, offset); + entry_length = tvb_get_uint8(tvb, offset); if (registration_request_msg && ((service_option == 64) || (service_option == 67))) exts_tree = proto_tree_add_subtree_format(ext_tree, tvb, offset, entry_length+1, @@ -862,9 +859,9 @@ dissect_ase(tvbuff_t *tvb, int offset, guint ase_len, proto_tree *ext_tree) if ((entry_length>14)&&(registration_request_msg)) { if (service_option == 0x0043) { proto_tree *extv_tree; - guint8 profile_count = tvb_get_guint8(tvb, offset+6); - guint8 profile_index = 0; - guint8 reverse_profile_count; + uint8_t profile_count = tvb_get_uint8(tvb, offset+6); + uint8_t profile_index = 0; + uint8_t reverse_profile_count; proto_tree *extt_tree = proto_tree_add_subtree(exts_tree, tvb, offset,6+(profile_count*2)+1, ett_a11_forward_rohc, NULL, "Forward ROHC Info"); @@ -878,7 +875,7 @@ dissect_ase(tvbuff_t *tvb, int offset, guint ase_len, proto_tree *ext_tree) offset += 2; proto_tree_add_item(extt_tree, hf_a11_ase_forward_large_cids, tvb, offset, 1, ENC_BIG_ENDIAN); offset += 1; - profile_count=tvb_get_guint8(tvb, offset); + profile_count=tvb_get_uint8(tvb, offset); proto_tree_add_item(extt_tree, hf_a11_ase_forward_profile_count, tvb, offset, 1, ENC_BIG_ENDIAN); offset += 1; @@ -892,7 +889,7 @@ dissect_ase(tvbuff_t *tvb, int offset, guint ase_len, proto_tree *ext_tree) }/*for*/ - reverse_profile_count=tvb_get_guint8(tvb, offset+6); + reverse_profile_count=tvb_get_uint8(tvb, offset+6); extv_tree = proto_tree_add_subtree(exts_tree, tvb, offset,6+(reverse_profile_count*2)+1, ett_a11_reverse_rohc, NULL, "Reverse ROHC Info"); @@ -908,7 +905,7 @@ dissect_ase(tvbuff_t *tvb, int offset, guint ase_len, proto_tree *ext_tree) proto_tree_add_item(extv_tree, hf_a11_ase_reverse_large_cids, tvb, offset, 1, ENC_BIG_ENDIAN); offset += 1; - profile_count=tvb_get_guint8(tvb, offset); + profile_count=tvb_get_uint8(tvb, offset); proto_tree_add_item(extv_tree, hf_a11_ase_reverse_profile_count, tvb, offset, 1, ENC_BIG_ENDIAN); offset += 1; @@ -938,9 +935,9 @@ dissect_ase(tvbuff_t *tvb, int offset, guint ase_len, proto_tree *ext_tree) #define A11_FQI_DSCP_INCLUDED 0x40 static void -dissect_fwd_qosinfo_flags(tvbuff_t *tvb, int offset, proto_tree *ext_tree, guint8 *p_dscp_included) +dissect_fwd_qosinfo_flags(tvbuff_t *tvb, int offset, proto_tree *ext_tree, uint8_t *p_dscp_included) { - guint8 flags = tvb_get_guint8(tvb, offset); + uint8_t flags = tvb_get_uint8(tvb, offset); proto_item *ti = proto_tree_add_item(ext_tree, hf_a11_fqi_flags, tvb, offset, 1, ENC_BIG_ENDIAN); proto_tree *flags_tree = proto_item_add_subtree(ti, ett_a11_fqi_flags); @@ -956,7 +953,7 @@ dissect_fwd_qosinfo_flags(tvbuff_t *tvb, int offset, proto_tree *ext_tree, guint } static void -dissect_fqi_entry_flags(tvbuff_t *tvb, int offset, proto_tree *ext_tree, guint8 dscp_enabled) +dissect_fqi_entry_flags(tvbuff_t *tvb, int offset, proto_tree *ext_tree, uint8_t dscp_enabled) { proto_item *ti = proto_tree_add_item(ext_tree, hf_a11_fqi_entry_flag, tvb, offset, 1, ENC_BIG_ENDIAN); proto_tree *flags_tree = proto_item_add_subtree(ti, ett_a11_fqi_entry_flags); @@ -982,9 +979,9 @@ static void dissect_fwd_qosinfo(tvbuff_t *tvb, int offset, proto_tree *ext_tree) { int clen = 0; /* consumed length */ - guint8 flow_count; - guint8 flow_index; - guint8 dscp_enabled = 0; + uint8_t flow_count; + uint8_t flow_index; + uint8_t dscp_enabled = 0; /* SR Id */ proto_tree_add_item(ext_tree, hf_a11_fqi_srid, tvb, offset+clen, 1, ENC_BIG_ENDIAN); @@ -995,17 +992,17 @@ dissect_fwd_qosinfo(tvbuff_t *tvb, int offset, proto_tree *ext_tree) clen++; /* Flow Count */ - flow_count = tvb_get_guint8(tvb, offset+clen); + flow_count = tvb_get_uint8(tvb, offset+clen); flow_count &= 0x1F; proto_tree_add_item(ext_tree, hf_a11_fqi_flowcount, tvb, offset+clen, 1, ENC_BIG_ENDIAN); clen++; for (flow_index=0; flow_index<flow_count; flow_index++) { - guint8 requested_qos_len = 0; - guint8 granted_qos_len = 0; + uint8_t requested_qos_len = 0; + uint8_t granted_qos_len = 0; - guint8 entry_len = tvb_get_guint8(tvb, offset+clen); - guint8 flow_id = tvb_get_guint8(tvb, offset+clen+1); + uint8_t entry_len = tvb_get_uint8(tvb, offset+clen); + uint8_t flow_id = tvb_get_uint8(tvb, offset+clen+1); proto_tree *flow_tree = proto_tree_add_subtree_format(ext_tree, tvb, offset+clen, entry_len+1, ett_a11_fqi_flowentry, NULL, "Forward Flow Entry (Flow Id: %d)", flow_id); @@ -1024,7 +1021,7 @@ dissect_fwd_qosinfo(tvbuff_t *tvb, int offset, proto_tree *ext_tree) /* Requested QoS Length */ - requested_qos_len = tvb_get_guint8(tvb, offset+clen); + requested_qos_len = tvb_get_uint8(tvb, offset+clen); proto_tree_add_item(flow_tree, hf_a11_fqi_requested_qoslen, tvb, offset+clen, 1, ENC_BIG_ENDIAN); clen++; @@ -1063,7 +1060,7 @@ dissect_fwd_qosinfo(tvbuff_t *tvb, int offset, proto_tree *ext_tree) } /* Granted QoS Length */ - granted_qos_len = tvb_get_guint8(tvb, offset+clen); + granted_qos_len = tvb_get_uint8(tvb, offset+clen); proto_tree_add_item(flow_tree, hf_a11_fqi_granted_qoslen, tvb, offset+clen, 1, ENC_BIG_ENDIAN); clen++; @@ -1086,25 +1083,25 @@ static void dissect_rev_qosinfo(tvbuff_t *tvb, int offset, proto_tree *ext_tree) { int clen = 0; /* consumed length */ - guint8 flow_count; - guint8 flow_index; + uint8_t flow_count; + uint8_t flow_index; /* SR Id */ proto_tree_add_item(ext_tree, hf_a11_rqi_srid, tvb, offset+clen, 1, ENC_BIG_ENDIAN); clen++; /* Flow Count */ - flow_count = tvb_get_guint8(tvb, offset+clen); + flow_count = tvb_get_uint8(tvb, offset+clen); flow_count &= 0x1F; proto_tree_add_item(ext_tree, hf_a11_rqi_flowcount, tvb, offset+clen, 1, ENC_BIG_ENDIAN); clen++; for (flow_index=0; flow_index<flow_count; flow_index++) { - guint8 requested_qos_len; - guint8 granted_qos_len; + uint8_t requested_qos_len; + uint8_t granted_qos_len; - guint8 entry_len = tvb_get_guint8(tvb, offset+clen); - guint8 flow_id = tvb_get_guint8(tvb, offset+clen+1); + uint8_t entry_len = tvb_get_uint8(tvb, offset+clen); + uint8_t flow_id = tvb_get_uint8(tvb, offset+clen+1); proto_tree *flow_tree = proto_tree_add_subtree_format (ext_tree, tvb, offset+clen, entry_len+1, ett_a11_rqi_flowentry, NULL, @@ -1123,7 +1120,7 @@ dissect_rev_qosinfo(tvbuff_t *tvb, int offset, proto_tree *ext_tree) clen++; /* Requested QoS Length */ - requested_qos_len = tvb_get_guint8(tvb, offset+clen); + requested_qos_len = tvb_get_uint8(tvb, offset+clen); proto_tree_add_item(flow_tree, hf_a11_rqi_requested_qoslen, tvb, offset+clen, 1, ENC_BIG_ENDIAN); clen++; @@ -1161,7 +1158,7 @@ dissect_rev_qosinfo(tvbuff_t *tvb, int offset, proto_tree *ext_tree) } /* Granted QoS Length */ - granted_qos_len = tvb_get_guint8(tvb, offset+clen); + granted_qos_len = tvb_get_uint8(tvb, offset+clen); proto_tree_add_item(flow_tree, hf_a11_rqi_granted_qoslen, tvb, offset+clen, 1, ENC_BIG_ENDIAN); clen++; @@ -1196,10 +1193,10 @@ dissect_subscriber_qos_profile(tvbuff_t *tvb, packet_info *pinfo, int offset, in /* Subscriber QoS profile */ if (qos_profile_len) { proto_tree_add_item - (exts_tree, hf_a11_subsciber_profile, tvb, offset, + (exts_tree, hf_a11_subscriber_profile, tvb, offset, qos_profile_len, ENC_NA); - dissect_attribute_value_pairs(exts_tree, pinfo, tvb, offset, qos_profile_len); + dissect_attribute_value_pairs(exts_tree, pinfo, tvb, offset, qos_profile_len, NULL); } } @@ -1208,19 +1205,19 @@ static void dissect_fwd_qosupdate_info(tvbuff_t *tvb, int offset, proto_tree *ext_tree) { int clen = 0; /* consumed length */ - guint8 flow_count; - guint8 flow_index; + uint8_t flow_count; + uint8_t flow_index; /* Flow Count */ - flow_count = tvb_get_guint8(tvb, offset+clen); + flow_count = tvb_get_uint8(tvb, offset+clen); proto_tree_add_item(ext_tree, hf_a11_fqui_flowcount, tvb, offset+clen, 1, ENC_BIG_ENDIAN); clen++; for (flow_index=0; flow_index<flow_count; flow_index++) { proto_tree *exts_tree; - guint8 granted_qos_len; + uint8_t granted_qos_len; - guint8 flow_id = tvb_get_guint8(tvb, offset+clen); + uint8_t flow_id = tvb_get_uint8(tvb, offset+clen); exts_tree = proto_tree_add_subtree_format (ext_tree, tvb, offset+clen, 1, ett_a11_fqui_flowentry, NULL, @@ -1229,7 +1226,7 @@ dissect_fwd_qosupdate_info(tvbuff_t *tvb, int offset, proto_tree *ext_tree) clen++; /* Forward QoS Sub Blob Length */ - granted_qos_len = tvb_get_guint8(tvb, offset+clen); + granted_qos_len = tvb_get_uint8(tvb, offset+clen); proto_tree_add_item (exts_tree, hf_a11_fqui_updated_qoslen, tvb, offset+clen, 1, ENC_BIG_ENDIAN); clen++; @@ -1250,19 +1247,19 @@ static void dissect_rev_qosupdate_info(tvbuff_t *tvb, int offset, proto_tree *ext_tree) { int clen = 0; /* consumed length */ - guint8 flow_count; - guint8 flow_index; + uint8_t flow_count; + uint8_t flow_index; /* Flow Count */ - flow_count = tvb_get_guint8(tvb, offset+clen); + flow_count = tvb_get_uint8(tvb, offset+clen); proto_tree_add_item(ext_tree, hf_a11_rqui_flowcount, tvb, offset+clen, 1, ENC_BIG_ENDIAN); clen++; for (flow_index=0; flow_index<flow_count; flow_index++) { proto_tree *exts_tree; - guint8 granted_qos_len; + uint8_t granted_qos_len; - guint8 flow_id = tvb_get_guint8(tvb, offset+clen); + uint8_t flow_id = tvb_get_uint8(tvb, offset+clen); exts_tree = proto_tree_add_subtree_format (ext_tree, tvb, offset+clen, 1, ett_a11_rqui_flowentry, NULL, @@ -1270,7 +1267,7 @@ dissect_rev_qosupdate_info(tvbuff_t *tvb, int offset, proto_tree *ext_tree) clen++; /* Reverse QoS Sub Blob Length */ - granted_qos_len = tvb_get_guint8(tvb, offset+clen); + granted_qos_len = tvb_get_uint8(tvb, offset+clen); proto_tree_add_item (exts_tree, hf_a11_rqui_updated_qoslen, tvb, offset+clen, 1, ENC_BIG_ENDIAN); clen++; @@ -1292,12 +1289,12 @@ dissect_a11_extensions( tvbuff_t *tvb, packet_info *pinfo, int offset, proto_tre proto_tree *exts_tree; proto_tree *ext_tree; proto_item *ext_len_item = NULL; - guint ext_len; - guint8 ext_type; - guint8 ext_subtype = 0; - guint hdrLen; + unsigned ext_len; + uint8_t ext_type; + uint8_t ext_subtype = 0; + unsigned hdrLen; - gint16 apptype = -1; + int16_t apptype = -1; /* Add our tree, if we have extensions */ exts_tree = proto_tree_add_subtree(tree, tvb, offset, -1, ett_a11_exts, NULL, "Extensions"); @@ -1306,21 +1303,21 @@ dissect_a11_extensions( tvbuff_t *tvb, packet_info *pinfo, int offset, proto_tre while (tvb_reported_length_remaining(tvb, offset) > 0) { /* Get our extension info */ - ext_type = tvb_get_guint8(tvb, offset); + ext_type = tvb_get_uint8(tvb, offset); if (ext_type == GEN_AUTH_EXT) { /* * Very nasty . . breaks normal extensions, since the length is * in the wrong place :( */ - ext_subtype = tvb_get_guint8(tvb, offset + 1); + ext_subtype = tvb_get_uint8(tvb, offset + 1); ext_len = tvb_get_ntohs(tvb, offset + 2); hdrLen = 4; } else if ((ext_type == CVSE_EXT) || (ext_type == OLD_CVSE_EXT)) { ext_len = tvb_get_ntohs(tvb, offset + 2); - ext_subtype = tvb_get_guint8(tvb, offset + 8); + ext_subtype = tvb_get_uint8(tvb, offset + 8); hdrLen = 4; } else { - ext_len = tvb_get_guint8(tvb, offset + 1); + ext_len = tvb_get_uint8(tvb, offset + 1); hdrLen = 2; } @@ -1536,13 +1533,13 @@ dissect_a11( tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, void *data _U_ /* Set up structures we will need to add the protocol subtree and manage it */ proto_item *ti; proto_tree *a11_tree = NULL; - guint8 type; - guint offset = 0; + uint8_t type; + unsigned offset = 0; if (!tvb_bytes_exist(tvb, offset, 1)) return 0; /* not enough data to check message type */ - type = tvb_get_guint8(tvb, offset); + type = tvb_get_uint8(tvb, offset); if (try_val_to_str_ext(type, &a11_types_ext) == NULL) return 0; /* not a known message type */ @@ -1602,7 +1599,7 @@ dissect_a11( tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, void *data _U_ break; case REGISTRATION_REPLY: col_add_fstr(pinfo->cinfo, COL_INFO, "Reg Reply: PDSN=%s, Code=%u", - tvb_ip_to_str(pinfo->pool, tvb, 8), tvb_get_guint8(tvb,1)); + tvb_ip_to_str(pinfo->pool, tvb, 8), tvb_get_uint8(tvb,1)); if (tree) { /* Add Subtree */ @@ -1667,7 +1664,7 @@ dissect_a11( tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, void *data _U_ case REGISTRATION_ACK: col_add_fstr(pinfo->cinfo, COL_INFO, "Reg Ack: PCF=%s Status=%u", tvb_ip_to_str(pinfo->pool, tvb, 8), - tvb_get_guint8(tvb,3)); + tvb_get_uint8(tvb,3)); if (tree) { /* Add Subtree */ ti = proto_tree_add_item(tree, proto_a11, tvb, offset, -1, ENC_NA); @@ -1730,7 +1727,7 @@ dissect_a11( tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, void *data _U_ case SESSION_ACK: /* IOS4.3 */ col_add_fstr(pinfo->cinfo, COL_INFO, "Ses Upd Ack: PCF=%s, Status=%u", tvb_ip_to_str(pinfo->pool, tvb, 8), - tvb_get_guint8(tvb,3)); + tvb_get_uint8(tvb,3)); if (tree) { /* Add Subtree */ ti = proto_tree_add_item(tree, proto_a11, tvb, offset, -1, ENC_NA); @@ -1926,7 +1923,7 @@ dissect_a11( tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, void *data _U_ case BC_REGISTRATION_REPLY: col_add_fstr(pinfo->cinfo, COL_INFO, "BC Reg Reply: BSN=%s, Code=%u", tvb_ip_to_str(pinfo->pool, tvb, offset + 8), - tvb_get_guint8(tvb, offset + 1)); + tvb_get_uint8(tvb, offset + 1)); if (tree) { /* Add Subtree */ @@ -1992,7 +1989,7 @@ dissect_a11( tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, void *data _U_ case BC_REGISTRATION_ACK: col_add_fstr(pinfo->cinfo, COL_INFO, "BC Reg Acknowledge: PCF=%s Status=%u", tvb_ip_to_str(pinfo->pool, tvb, offset + 8), - tvb_get_guint8(tvb, offset + 3)); + tvb_get_uint8(tvb, offset + 3)); if (tree) { /* Add Subtree */ ti = proto_tree_add_item(tree, proto_a11, tvb, offset, -1, ENC_NA); @@ -2217,7 +2214,7 @@ proto_register_a11(void) }, { &hf_a11_vse_ehrpd_mode, { "eHRPD Mode", "a11.ext.ehrpd.mode", - FT_BOOLEAN, 8, TFS(&a11_tfs_ehrpd_mode), 0, + FT_BOOLEAN, BASE_NONE, TFS(&a11_tfs_ehrpd_mode), 0, NULL, HFILL } }, { &hf_a11_vse_ehrpd_pmk, @@ -2530,13 +2527,13 @@ proto_register_a11(void) NULL, HFILL } }, #if 0 - { &hf_a11_subsciber_profile_len, + { &hf_a11_subscriber_profile_len, { "Subscriber QoS Profile Length", "a11.ext.sqp.profilelen", FT_BYTES, BASE_NONE, NULL, 0, NULL, HFILL } }, #endif - { &hf_a11_subsciber_profile, + { &hf_a11_subscriber_profile, { "Subscriber QoS Profile", "a11.ext.sqp.profile", FT_BYTES, BASE_NONE, NULL, 0, NULL, HFILL } @@ -2669,7 +2666,7 @@ proto_register_a11(void) }; /* Setup protocol subtree array */ - static gint *ett[] = { + static int *ett[] = { &ett_a11, &ett_a11_flags, &ett_a11_ext, |