aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAnish Bhatt <anish@chelsio.com>2014-10-08 22:02:31 -0700
committerMichael Mann <mmann78@netscape.net>2014-10-10 19:29:14 +0000
commitf7588eaec2ccfca96de83d8f4f9d754d61e3fec3 (patch)
tree359211b8a7370a243e61219b4d536273eca6d3fd
parenta168c44fc05210f84798c950f0271fe1afcbd462 (diff)
[ELMI] Add missing information elements, add support for sub-information elements.
Bug 10532 Updated with Bandwidth Profile support Change-Id: I0f31eb6c78a5e34bcb1c286a9a10730b3b63481c Reviewed-on: https://code.wireshark.org/review/4571 Reviewed-by: Alexis La Goutte <alexis.lagoutte@gmail.com> Petri-Dish: Alexis La Goutte <alexis.lagoutte@gmail.com> Tested-by: Petri Dish Buildbot <buildbot-no-reply@wireshark.org> Reviewed-by: Michael Mann <mmann78@netscape.net>
-rw-r--r--epan/dissectors/packet-elmi.c309
1 files changed, 307 insertions, 2 deletions
diff --git a/epan/dissectors/packet-elmi.c b/epan/dissectors/packet-elmi.c
index 7be255fe14..652943edf1 100644
--- a/epan/dissectors/packet-elmi.c
+++ b/epan/dissectors/packet-elmi.c
@@ -41,6 +41,7 @@ void proto_reg_handoff_elmi(void);
static gint ett_elmi = -1;
static gint ett_elmi_info_elem = -1;
+static gint ett_elmi_sub_info_elem = -1;
static int hf_elmi_ver = -1;
static int hf_elmi_msg_type = -1;
@@ -51,6 +52,38 @@ static int hf_elmi_snd_seq_num = -1;
static int hf_elmi_rcv_seq_num = -1;
static int hf_elmi_dat_inst = -1;
static int hf_elmi_reserved = -1;
+static int hf_elmi_uni_status = -1;
+static int hf_elmi_evc_refid = -1;
+static int hf_elmi_evc_status = -1;
+static int hf_last_ie = -1;
+static int hf_map_seq = -1;
+static int hf_priority = -1;
+static int hf_default_evc = -1;
+static int hf_elmi_sub_info_elem = -1;
+static int hf_elmi_sub_info_elem_len = -1;
+static int hf_elmi_uni_id = -1;
+static int hf_elmi_evc_type = -1;
+static int hf_elmi_evc_id = -1;
+static int hf_elmi_ce_vlan_id = -1;
+static int hf_elmi_sub_info_color_mode_flag = -1;
+static int hf_elmi_sub_info_coupling_flag = -1;
+static int hf_elmi_sub_info_per_cos_bit = -1;
+static int hf_elmi_sub_cir_magnitude = -1;
+static int hf_elmi_sub_cir_multiplier = -1;
+static int hf_elmi_sub_cbs_magnitude = -1;
+static int hf_elmi_sub_cbs_multiplier = -1;
+static int hf_elmi_sub_eir_magnitude = -1;
+static int hf_elmi_sub_eir_multiplier = -1;
+static int hf_elmi_sub_ebs_magnitude = -1;
+static int hf_elmi_sub_ebs_multiplier = -1;
+static int hf_elmi_sub_user_prio_0 = -1;
+static int hf_elmi_sub_user_prio_1 = -1;
+static int hf_elmi_sub_user_prio_2 = -1;
+static int hf_elmi_sub_user_prio_3 = -1;
+static int hf_elmi_sub_user_prio_4 = -1;
+static int hf_elmi_sub_user_prio_5 = -1;
+static int hf_elmi_sub_user_prio_6 = -1;
+static int hf_elmi_sub_user_prio_7 = -1;
static const value_string elmi_msg_type[] = {
{ 0x75, "Status enquiry" },
@@ -61,11 +94,17 @@ static const value_string elmi_msg_type[] = {
#define TAG_REPORT_TYPE 0x01
#define TAG_SEQ_NUM 0x02
#define TAG_DATA_INST 0x03
+#define TAG_UNI_STATUS 0x11
+#define TAG_EVC_STATUS 0x21
+#define TAG_VLAN_EVC 0x22
static const value_string elmi_info_elem_tag[] = {
{ TAG_REPORT_TYPE, "Report type" },
{ TAG_SEQ_NUM, "Sequence numbers" },
{ TAG_DATA_INST, "Data instance" },
+ { TAG_UNI_STATUS, "UNI Status" },
+ { TAG_EVC_STATUS, "EVC Status" },
+ { TAG_VLAN_EVC, "CE-VLAN ID/EVC Map" },
{ 0, NULL }
};
@@ -77,13 +116,142 @@ static const value_string elmi_report_type[] = {
{ 0, NULL }
};
+#define SUB_TAG_UNI_ID 0x51
+#define SUB_TAG_EVC_PRM 0x61
+#define SUB_TAG_EVC_ID 0x62
+#define SUB_TAG_EVC_MAP 0x63
+#define SUB_TAG_BW_PRO 0x71
+
+static const value_string elmi_sub_info_elem_tag[] = {
+ { SUB_TAG_UNI_ID, "UNI Identifier" },
+ { SUB_TAG_EVC_PRM, "EVC Parameters" },
+ { SUB_TAG_EVC_ID, "EVC Identifier" },
+ { SUB_TAG_EVC_MAP, "EVC Map Entry" },
+ { SUB_TAG_BW_PRO, "Bandwidth Profile" },
+ { 0, NULL }
+};
+
+static const value_string elmi_vlan_id_evc_map_type[] = {
+ { 0x01, "All to one binding" },
+ { 0x02, "Service Multiplexing with no bundling" },
+ { 0x03, "Bundling" },
+ { 0, NULL }
+};
+
+static const value_string elmi_evc_status_type[] = {
+ { 0x00, "Not Active" },
+ { 0x01, "New and Not Active" },
+ { 0x02, "Active" },
+ { 0x03, "New and Active" },
+ { 0x04, "Partially Active" },
+ { 0x05, "New and Partially Active" },
+ { 0, NULL }
+};
+
+static const value_string elmi_evc_type[] = {
+ { 0x00, "Point-to-Point EVC" },
+ { 0x01, "Multipoint-to-Multipoint EVC" },
+ { 0, NULL }
+};
+
+const true_false_string tfs_applicable_not_applicable = { "Applicable", "Not Applicable" };
+
+static gint
+dissect_elmi_sub_info_elem(
+ tvbuff_t *tvb, gint offset, proto_tree *tree)
+{
+ gint offset_start;
+ guint8 sub_tag, len;
+ proto_item *tree_pi;
+ proto_tree *sub_info_elem_tree = tree;
+
+ offset_start = offset;
+
+ sub_tag = tvb_get_guint8(tvb, offset);
+ len = tvb_get_guint8(tvb, offset + 1);
+
+ sub_info_elem_tree = proto_tree_add_subtree_format(
+ tree, tvb, offset, len + 2, ett_elmi_sub_info_elem, &tree_pi,
+ "Sub-information element: %s", val_to_str_const(sub_tag, elmi_sub_info_elem_tag, "unknown"));
+
+ proto_tree_add_item(sub_info_elem_tree, hf_elmi_sub_info_elem, tvb, offset, 1, ENC_BIG_ENDIAN);
+ offset++;
+
+ proto_tree_add_item(sub_info_elem_tree, hf_elmi_sub_info_elem_len, tvb, offset, 1, ENC_BIG_ENDIAN);
+ offset++;
+
+ switch (sub_tag) {
+ case SUB_TAG_UNI_ID:
+ proto_tree_add_item(sub_info_elem_tree, hf_elmi_uni_id, tvb, offset, len, ENC_ASCII|ENC_NA);
+ offset += len;
+ break;
+ case SUB_TAG_EVC_PRM:
+ proto_tree_add_item(sub_info_elem_tree, hf_elmi_evc_type, tvb, offset, 1, ENC_BIG_ENDIAN);
+ offset++;
+ break;
+ case SUB_TAG_EVC_ID:
+ proto_tree_add_item(sub_info_elem_tree, hf_elmi_evc_id, tvb, offset, len, ENC_ASCII|ENC_NA);
+ offset += len;
+ break;
+ case SUB_TAG_EVC_MAP:
+ while(offset < (offset_start + len + 2)) {
+ proto_tree_add_item(sub_info_elem_tree, hf_elmi_ce_vlan_id, tvb, offset, 2, ENC_BIG_ENDIAN);
+ offset += 2;
+ }
+ break;
+ case SUB_TAG_BW_PRO:
+ proto_tree_add_item(sub_info_elem_tree, hf_elmi_sub_info_color_mode_flag, tvb, offset, 1, ENC_BIG_ENDIAN);
+ proto_tree_add_item(sub_info_elem_tree, hf_elmi_sub_info_coupling_flag, tvb, offset, 1, ENC_BIG_ENDIAN);
+ proto_tree_add_item(sub_info_elem_tree, hf_elmi_sub_info_per_cos_bit, tvb, offset, 1, ENC_BIG_ENDIAN);
+ offset++;
+
+ proto_tree_add_item(sub_info_elem_tree, hf_elmi_sub_cir_magnitude, tvb, offset, 1, ENC_BIG_ENDIAN);
+ offset++;
+ proto_tree_add_item(sub_info_elem_tree, hf_elmi_sub_cir_multiplier, tvb, offset, 2, ENC_BIG_ENDIAN);
+ offset += 2;
+
+ proto_tree_add_item(sub_info_elem_tree, hf_elmi_sub_cbs_magnitude, tvb, offset, 1, ENC_BIG_ENDIAN);
+ offset++;
+ proto_tree_add_item(sub_info_elem_tree, hf_elmi_sub_cbs_multiplier, tvb, offset, 1, ENC_BIG_ENDIAN);
+ offset++;
+
+ proto_tree_add_item(sub_info_elem_tree, hf_elmi_sub_eir_magnitude, tvb, offset, 1, ENC_BIG_ENDIAN);
+ offset++;
+ proto_tree_add_item(sub_info_elem_tree, hf_elmi_sub_eir_multiplier, tvb, offset, 2, ENC_BIG_ENDIAN);
+ offset += 2;
+
+ proto_tree_add_item(sub_info_elem_tree, hf_elmi_sub_ebs_magnitude, tvb, offset, 1, ENC_BIG_ENDIAN);
+ offset++;
+ proto_tree_add_item(sub_info_elem_tree, hf_elmi_sub_ebs_multiplier, tvb, offset, 1, ENC_BIG_ENDIAN);
+ offset++;
+
+ proto_tree_add_item(sub_info_elem_tree, hf_elmi_sub_user_prio_0, tvb, offset, 1, ENC_BIG_ENDIAN);
+ proto_tree_add_item(sub_info_elem_tree, hf_elmi_sub_user_prio_1, tvb, offset, 1, ENC_BIG_ENDIAN);
+ proto_tree_add_item(sub_info_elem_tree, hf_elmi_sub_user_prio_2, tvb, offset, 1, ENC_BIG_ENDIAN);
+ proto_tree_add_item(sub_info_elem_tree, hf_elmi_sub_user_prio_3, tvb, offset, 1, ENC_BIG_ENDIAN);
+ proto_tree_add_item(sub_info_elem_tree, hf_elmi_sub_user_prio_4, tvb, offset, 1, ENC_BIG_ENDIAN);
+ proto_tree_add_item(sub_info_elem_tree, hf_elmi_sub_user_prio_5, tvb, offset, 1, ENC_BIG_ENDIAN);
+ proto_tree_add_item(sub_info_elem_tree, hf_elmi_sub_user_prio_6, tvb, offset, 1, ENC_BIG_ENDIAN);
+ proto_tree_add_item(sub_info_elem_tree, hf_elmi_sub_user_prio_7, tvb, offset, 1, ENC_BIG_ENDIAN);
+
+ offset ++;
+ break;
+ default:
+ offset += len;
+ break;
+ }
+
+ proto_item_set_len(tree_pi, offset-offset_start);
+ return offset-offset_start;
+
+}
static gint
dissect_elmi_info_elem(
tvbuff_t *tvb, gint offset, packet_info *pinfo _U_, proto_tree *tree)
{
gint offset_start;
- guint8 tag, len;
+ guint8 tag, len, ret;
proto_item *tree_pi;
proto_tree *info_elem_tree;
@@ -127,6 +295,46 @@ dissect_elmi_info_elem(
tvb, offset, 4, ENC_BIG_ENDIAN);
offset+=4;
break;
+ case TAG_UNI_STATUS:
+ proto_tree_add_item(info_elem_tree, hf_elmi_uni_status, tvb, offset, 1, ENC_BIG_ENDIAN);
+ offset++;
+
+ while(offset < (offset_start + len + 2)) {
+ ret = dissect_elmi_sub_info_elem(tvb, offset, info_elem_tree);
+ if (ret<=0)
+ break;
+ offset += ret;
+ }
+ break;
+ case TAG_EVC_STATUS:
+ proto_tree_add_item(info_elem_tree, hf_elmi_evc_refid, tvb, offset, 2, ENC_BIG_ENDIAN);
+ offset+=2;
+ proto_tree_add_item(info_elem_tree, hf_elmi_evc_status, tvb, offset, 1, ENC_BIG_ENDIAN);
+ offset++;
+
+ while(offset < (offset_start + len + 2)) {
+ ret = dissect_elmi_sub_info_elem(tvb, offset, info_elem_tree);
+ if (ret<=0)
+ break;
+ offset += ret;
+ }
+ break;
+ case TAG_VLAN_EVC:
+ proto_tree_add_item(info_elem_tree, hf_elmi_evc_refid, tvb, offset, 2, ENC_BIG_ENDIAN);
+ offset+=2;
+ proto_tree_add_item(info_elem_tree, hf_last_ie, tvb, offset, 1, ENC_BIG_ENDIAN);
+ proto_tree_add_item(info_elem_tree, hf_map_seq, tvb, offset, 1, ENC_BIG_ENDIAN);
+ offset++;
+ proto_tree_add_item(info_elem_tree, hf_priority, tvb, offset, 1, ENC_BIG_ENDIAN);
+ proto_tree_add_item(info_elem_tree, hf_default_evc, tvb, offset, 1, ENC_BIG_ENDIAN);
+ offset++;
+
+ while(offset < (offset_start + len + 2)) {
+ ret = dissect_elmi_sub_info_elem(tvb, offset, info_elem_tree);
+ if (ret<=0)
+ break;
+ offset += ret;
+ }
default:
offset += len;
break;
@@ -208,11 +416,108 @@ proto_register_elmi(void)
{ &hf_elmi_reserved,
{ "Reserved", "elmi.reserved", FT_UINT8, BASE_HEX,
NULL, 0, NULL, HFILL } },
+ { &hf_elmi_uni_status,
+ { "CE-VLAN ID/EVC Map Type", "elmi.map_type", FT_UINT8, BASE_HEX,
+ VALS(elmi_vlan_id_evc_map_type), 0, NULL, HFILL } },
+ { &hf_elmi_evc_refid,
+ { "EVC Reference Id", "elmi.evc.refid", FT_UINT16, BASE_DEC,
+ NULL, 0, NULL, HFILL } },
+ { &hf_elmi_evc_status,
+ { "EVC Status Type", "elmi.evc.status", FT_UINT8, BASE_HEX,
+ VALS(elmi_evc_status_type), 0x7, NULL, HFILL } },
+ { &hf_last_ie,
+ { "Last Information Element", "elmi.map.last_ie", FT_BOOLEAN, 8,
+ TFS(&tfs_yes_no), 0x40, NULL, HFILL } },
+ { &hf_map_seq,
+ { "CE-VLAN ID/EVC Map Sequence", "elmi.map.seq", FT_UINT8, BASE_DEC,
+ NULL, 0x3F, NULL, HFILL } },
+ { &hf_priority,
+ { "Priority Tagged", "elmi.map.priority", FT_BOOLEAN, 8,
+ TFS(&tfs_yes_no), 0x2, NULL, HFILL } },
+ { &hf_default_evc,
+ { "Default EVC", "elmi.map.evc", FT_BOOLEAN, 8,
+ TFS(&tfs_set_notset), 0x1, NULL, HFILL } },
+ { &hf_elmi_sub_info_elem,
+ { "Sub-Info Element :" , "elmi.sub_info.tag", FT_UINT8, BASE_HEX,
+ VALS(elmi_sub_info_elem_tag), 0, NULL, HFILL } },
+ { &hf_elmi_sub_info_elem_len,
+ { "Sub-Info Length", "elmi.sub_info.len", FT_UINT8, BASE_DEC,
+ NULL, 0, NULL, HFILL } },
+ { &hf_elmi_uni_id,
+ { "UNI Identifier", "elmi.sub_info.uni_id", FT_STRING, BASE_NONE,
+ NULL, 0, NULL, HFILL } },
+ { &hf_elmi_evc_type,
+ { "EVC Type", "elmi.sub_info.evc_type", FT_UINT8, BASE_DEC,
+ VALS(elmi_evc_type), 0x7, NULL, HFILL } },
+ { &hf_elmi_evc_id,
+ { "EVC Identifier", "elmi.sub_info.evc_id", FT_STRING, BASE_NONE,
+ NULL, 0, NULL, HFILL } },
+ { &hf_elmi_ce_vlan_id,
+ { "CE-VLAN ID", "elmi.sub_info.vlan_id", FT_UINT16, BASE_DEC,
+ NULL, 0, NULL, HFILL } },
+ { &hf_elmi_sub_info_color_mode_flag,
+ { "Color Mode Flag", "elmi.sub_info.color_mode_flag", FT_BOOLEAN, 8,
+ TFS(&tfs_set_notset), 0x4, NULL, HFILL } },
+ { &hf_elmi_sub_info_coupling_flag,
+ { "Coupling Flag", "elmi.sub_info.coupling_flag", FT_BOOLEAN, 8,
+ TFS(&tfs_set_notset), 0x2, NULL, HFILL } },
+ { &hf_elmi_sub_info_per_cos_bit,
+ { "Per CoS bit values", "elmi.sub_info.per_cos_bit", FT_BOOLEAN, 8,
+ TFS(&tfs_used_notused), 0x1, NULL, HFILL } },
+ { &hf_elmi_sub_cir_magnitude,
+ { "CIR Magnitude", "elmi.sub_info.cir_mag", FT_UINT8, BASE_DEC,
+ NULL, 0, NULL, HFILL } },
+ { &hf_elmi_sub_cir_multiplier,
+ { "CIR Multiplier", "elmi.sub_info.cir_mult", FT_UINT16, BASE_DEC,
+ NULL, 0, NULL, HFILL } },
+ { &hf_elmi_sub_cbs_magnitude,
+ { "CBS Magnitude", "elmi.sub_info.cbs_mag", FT_UINT8, BASE_DEC,
+ NULL, 0, NULL, HFILL } },
+ { &hf_elmi_sub_cbs_multiplier,
+ { "CBS Multiplier", "elmi.sub_info.cbs_mult", FT_UINT8, BASE_DEC,
+ NULL, 0, NULL, HFILL } },
+ { &hf_elmi_sub_eir_magnitude,
+ { "EIR Magnitude", "elmi.sub_info.eir_mag", FT_UINT8, BASE_DEC,
+ NULL, 0, NULL, HFILL } },
+ { &hf_elmi_sub_eir_multiplier,
+ { "EIR Multiplier", "elmi.sub_info.eir_mult", FT_UINT16, BASE_DEC,
+ NULL, 0, NULL, HFILL } },
+ { &hf_elmi_sub_ebs_magnitude,
+ { "EBS Magnitude", "elmi.sub_info.ebs_mag", FT_UINT8, BASE_DEC,
+ NULL, 0, NULL, HFILL } },
+ { &hf_elmi_sub_ebs_multiplier,
+ { "EBS Multiplier", "elmi.sub_info.ebs_mult", FT_UINT8, BASE_DEC,
+ NULL, 0, NULL, HFILL } },
+ { &hf_elmi_sub_user_prio_0,
+ { "User Priority 0", "elmi.sub_info.bw_prio0", FT_BOOLEAN, 8,
+ TFS(&tfs_applicable_not_applicable), 0x1, NULL, HFILL } },
+ { &hf_elmi_sub_user_prio_1,
+ { "User Priority 1", "elmi.sub_info.bw_prio1", FT_BOOLEAN, 8,
+ TFS(&tfs_applicable_not_applicable), 0x2, NULL, HFILL } },
+ { &hf_elmi_sub_user_prio_2,
+ { "User Priority 2", "elmi.sub_info.bw_prio2", FT_BOOLEAN, 8,
+ TFS(&tfs_applicable_not_applicable), 0x4, NULL, HFILL } },
+ { &hf_elmi_sub_user_prio_3,
+ { "User Priority 3", "elmi.sub_info.bw_prio3", FT_BOOLEAN, 8,
+ TFS(&tfs_applicable_not_applicable), 0x8, NULL, HFILL } },
+ { &hf_elmi_sub_user_prio_4,
+ { "User Priority 4", "elmi.sub_info.bw_prio4", FT_BOOLEAN, 8,
+ TFS(&tfs_applicable_not_applicable), 0x10, NULL, HFILL } },
+ { &hf_elmi_sub_user_prio_5,
+ { "User Priority 5", "elmi.sub_info.bw_prio5", FT_BOOLEAN, 8,
+ TFS(&tfs_applicable_not_applicable), 0x20, NULL, HFILL } },
+ { &hf_elmi_sub_user_prio_6,
+ { "User Priority 6", "elmi.sub_info.bw_prio6", FT_BOOLEAN, 8,
+ TFS(&tfs_applicable_not_applicable), 0x40, NULL, HFILL } },
+ { &hf_elmi_sub_user_prio_7,
+ { "User Priority 7", "elmi.sub_info.bw_prio7", FT_BOOLEAN, 8,
+ TFS(&tfs_applicable_not_applicable), 0x80, NULL, HFILL } },
};
static gint *ett[] = {
&ett_elmi,
- &ett_elmi_info_elem
+ &ett_elmi_info_elem,
+ &ett_elmi_sub_info_elem
};