diff options
author | Gerald Combs <gerald@wireshark.org> | 2007-05-25 23:40:42 +0000 |
---|---|---|
committer | Gerald Combs <gerald@wireshark.org> | 2007-05-25 23:40:42 +0000 |
commit | a491fec183044f6065b8d92a3775f5130049b636 (patch) | |
tree | 3f899da6a2bb6dead6dbfa2392764a88ac26faa6 /plugins/wimax/msg_dreg.c | |
parent | 1e7c1bc0369f0c962ed73e8e34fa5ba7fa1a6c3d (diff) |
From Mike Harvey: Support for WiMAX and the WiMAX M2M encapsulation protocol.
Add support for WiMAX and M2M to various makefiles and installer files. Add
basic support for M2M to randpkt.
svn path=/trunk/; revision=21945
Diffstat (limited to 'plugins/wimax/msg_dreg.c')
-rw-r--r-- | plugins/wimax/msg_dreg.c | 571 |
1 files changed, 571 insertions, 0 deletions
diff --git a/plugins/wimax/msg_dreg.c b/plugins/wimax/msg_dreg.c new file mode 100644 index 0000000000..dbbc268bd5 --- /dev/null +++ b/plugins/wimax/msg_dreg.c @@ -0,0 +1,571 @@ +/* msg_dreg.c + * WiMax MAC Management DREG-REQ, DREG-CMD Message decoders + * + * Copyright (c) 2007 by Intel Corporation. + * + * Author: John R. Underwood <junderx@yahoo.com> + * + * $Id$ + * + * Wireshark - Network traffic analyzer + * By Gerald Combs <gerald@wireshark.org> + * Copyright 1999 Gerald Combs + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License + * as published by the Free Software Foundation; either version 2 + * of the License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. + */ + +/* Include files */ + +#ifdef HAVE_CONFIG_H +#include "config.h" +#endif + +#include "moduleinfo.h" + +#include <gmodule.h> +#include <epan/packet.h> +#include <epan/prefs.h> +#include "crc.h" +#include "wimax_tlv.h" +#include "wimax_mac.h" +#include "wimax_utils.h" + +extern gint man_ofdma; +extern gboolean include_cor2_changes; + +/* Forward reference */ +static void dissect_dreg_tlv(proto_tree *dreg_tree, gint tlv_type, tvbuff_t *tvb, guint tlv_offset, guint tlv_len, gint dreg_decoder); +void dissect_mac_mgmt_msg_dreg_req_decoder(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree); +void dissect_mac_mgmt_msg_dreg_cmd_decoder(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree); + +static gint proto_mac_mgmt_msg_dreg_req_decoder = -1; +static gint proto_mac_mgmt_msg_dreg_cmd_decoder = -1; + +static gint ett_mac_mgmt_msg_dreg_decoder = -1; + +/* Setup protocol subtree array */ +static gint *ett[] = +{ + &ett_mac_mgmt_msg_dreg_decoder, +}; + +/* DREG fields */ +static gint hf_dreg_cmd_message_type = -1; +static gint hf_dreg_req_message_type = -1; +static gint hf_ack_type_reserved = -1; +static gint hf_dreg_cmd_action = -1; +static gint hf_dreg_cmd_action_cor2 = -1; +static gint hf_dreg_cmd_reserved = -1; +static gint hf_dreg_paging_cycle = -1; +static gint hf_dreg_paging_offset = -1; +static gint hf_dreg_paging_group_id = -1; +static gint hf_dreg_req_duration = -1; +static gint hf_paging_controller_id = -1; +static gint hf_mac_hash_skip_threshold = -1; +static gint hf_dreg_paging_cycle_request = -1; +static gint hf_dreg_retain_ms_service_sbc = -1; +static gint hf_dreg_retain_ms_service_pkm = -1; +static gint hf_dreg_retain_ms_service_reg = -1; +static gint hf_dreg_retain_ms_service_network_address = -1; +static gint hf_dreg_retain_ms_service_tod = -1; +static gint hf_dreg_retain_ms_service_tftp = -1; +static gint hf_dreg_retain_ms_service_full_service = -1; +static gint hf_dreg_consider_paging_pref = -1; +static gint hf_tlv_value = -1; +static gint hf_dreg_req_action = -1; +static gint hf_dreg_req_reserved = -1; +static gint hf_dreg_invalid_tlv = -1; + +/* STRING RESOURCES */ +static const value_string vals_dreg_req_code[] = { + {0, "SS De-Registration request from BS and network"}, + {1, "MS request for De-Registration from serving BS and initiation of Idle Mode"}, + {2, "MS response for the Unsolicited De-Registration initiated by BS"}, + {3, "Reject for the unsolicited DREG-CMD with action \ +code 05 (idle mode request) by the BS. \ +Applicable only when MS has pending UL data to transmit"}, + {4, "Reserved"}, + {0, NULL} +}; + +static const value_string vals_dreg_cmd_action[] = { + {0, "SS shall immediately terminate service with the BS and \ +should attempt network entry at another BS"}, + {1, "SS shall listen to the current channel BS but shall not \ +transmit until an RES-CMD message or DREG-CMD with \ +Action Code 02 or 03 is received"}, + {2, "SS shall listen to the BS but only transmit \ +on the Basic, and Primary Management Connections"}, + {3, "SS shall return to normal operation and may transmit on \ +any of its active connections"}, + {4, "SS shall terminate current Normal Operations with the BS; \ +the BS shall transmit this action code only in response \ +to any SS DREG-REQ message"}, + {5, "MS shall immediately begin de-registration from serving \ +BS and request initiation of MS Idle Mode"}, + {6, "The MS may retransmit the DREG-REQ message after the \ +time duration (REQ-duration) provided in the message"}, + {7, "The MS shall not retransmit the DREG-REQ message and shall \ +wait for the DREG-CMD message. BS transmittal of a \ +subsequent DREG-CMD with Action Code 03 shall cancel \ +this restriction"}, + {0, NULL} +}; + +static const value_string vals_dreg_cmd_action_cor2[] = { + {0, "SS shall immediately terminate service with the BS and \ +should attempt network entry at another BS"}, + {1, "SS shall listen to the current channel BS but shall not \ +transmit until an RES-CMD message or DREG-CMD with \ +Action Code 02 or 03 is received"}, + {2, "SS shall listen to the BS but only transmit \ +on the Basic, and Primary Management Connections"}, + {3, "SS shall return to normal operation and may transmit on \ +any of its active connections"}, + {4, "Only valid in response to a DREG-REQ message with DREG \ +Code = 00. SS shall terminate current Normal Operations with the BS"}, + {5, "MS shall immediately begin de-registration from serving \ +BS and request initiation of MS Idle Mode"}, + {6, "Only valid in response to a DREG-REQ message with DREG \ +Code = 01. The MS may retransmit the DREG-REQ message after the \ +REQ-duration provided in the message; \ +BS sending a subsequent DREG-CMD message with \ +Action Code 03 cancels this restriction"}, + {0, NULL} +}; + +/* DREG fields display */ +static hf_register_info hf[] = +{ + { + &hf_dreg_consider_paging_pref, + { + "Consider Paging Preference of each Service Flow in resource retention", "wimax.dreg.consider_paging_preference", + FT_UINT8, BASE_DEC, NULL, 0x80, "", HFILL + } + }, + { + &hf_dreg_invalid_tlv, + { + "Invalid TLV", "wimax.dreg.invalid_tlv", + FT_BYTES, BASE_HEX, NULL, 0, "", HFILL + } + }, + { + &hf_mac_hash_skip_threshold, + { + "MAC Hash Skip Threshold", "wimax.dreg.mac_hash_skip_threshold", + FT_UINT16, BASE_DEC, NULL, 0x0, "", HFILL + } + }, + { + &hf_paging_controller_id, + { + "Paging Controller ID", "wimax.dreg.paging_controller_id", + FT_ETHER, BASE_DEC, NULL, 0x0, "", HFILL + } + }, + { + &hf_dreg_paging_cycle, + { + "PAGING CYCLE", "wimax.dreg.paging_cycle", + FT_UINT16, BASE_DEC, NULL, 0x0, "", HFILL + } + }, + { + &hf_dreg_paging_cycle_request, + { + "Paging Cycle Request", "wimax.dreg.paging_cycle_request", + FT_UINT16, BASE_DEC, NULL, 0x0, "", HFILL + } + }, + { + &hf_dreg_paging_group_id, + { + "Paging-group-ID", "wimax.dreg.paging_group_id", + FT_UINT16, BASE_DEC, NULL, 0x0, "", HFILL + } + }, + { + &hf_dreg_paging_offset, + { + "PAGING OFFSET", "wimax.dreg.paging_offset", + FT_UINT8, BASE_DEC, NULL, 0x0, "", HFILL + } + }, + { + &hf_dreg_req_duration, + { + "REQ-duration (Waiting value for the DREG-REQ message re-transmission in frames)", "wimax.dreg.req_duration", + FT_UINT8, BASE_DEC, NULL, 0x0, "", HFILL + } + }, + { + &hf_dreg_retain_ms_service_full_service, + { + "Retain MS service and operation information associated with Full service", "wimax.dreg.retain_ms_full_service", + FT_UINT8, BASE_DEC, NULL, 0x40, "", HFILL + } + }, + { + &hf_dreg_retain_ms_service_network_address, + { + "Retain MS service and operational information associated with Network Address", "wimax.dreg.retain_ms_service_network_address", + FT_UINT8, BASE_DEC, NULL, 0x08, "", HFILL + } + }, + { + &hf_dreg_retain_ms_service_pkm, + { + "Retain MS service and operational information associated with PKM-REQ/RSP", "wimax.dreg.retain_ms_service_pkm", + FT_UINT8, BASE_DEC, NULL, 0x02, "", HFILL + } + }, + { + &hf_dreg_retain_ms_service_reg, + { + "Retain MS service and operational information associated with REG-REQ/RSP", "wimax.dreg.retain_ms_service_reg", + FT_UINT8, BASE_DEC, NULL, 0x04, "", HFILL + } + }, + { + &hf_dreg_retain_ms_service_sbc, + { + "Retain MS service and operational information associated with SBC-REQ/RSP", "wimax.dreg.retain_ms_service_sbc", + FT_UINT8, BASE_DEC, NULL, 0x01, "", HFILL + } + }, + { + &hf_dreg_retain_ms_service_tftp, + { + "Retain MS service and operational information associated with TFTP messages", "wimax.dreg.retain_ms_service_tftp", + FT_UINT8, BASE_DEC, NULL, 0x20, "", HFILL + } + }, + { + &hf_dreg_retain_ms_service_tod, + { + "Retain MS service and operational information associated with Time of Day", "wimax.dreg.retain_ms_service_tod", + FT_UINT8, BASE_DEC, NULL, 0x10, "", HFILL + } + }, + { + &hf_dreg_cmd_message_type, + { + "MAC Management Message Type", "wimax.macmgtmsgtype.dreg_cmd", + FT_UINT8, BASE_DEC, NULL, 0x0, "", HFILL + } + }, + { + &hf_dreg_cmd_action, + { + "DREG-CMD Action code", "wimax.dreg_cmd.action", + FT_UINT8, BASE_DEC, VALS(vals_dreg_cmd_action), 0x07, "", HFILL + } + }, + { + &hf_dreg_cmd_action_cor2, + { + "DREG-CMD Action code", "wimax.dreg_cmd.action", + FT_UINT8, BASE_DEC, VALS(vals_dreg_cmd_action_cor2), 0x07, "", HFILL + } + }, + { + &hf_dreg_cmd_reserved, + { + "Reserved", "wimax.dreg_cmd.action_reserved", + FT_UINT8, BASE_DEC, NULL, 0xF8, "", HFILL + } + }, + { + &hf_dreg_req_message_type, + { + "MAC Management Message Type", "wimax.macmgtmsgtype.dreg_req", + FT_UINT8, BASE_DEC, NULL, 0x0, "", HFILL + } + }, + { + &hf_dreg_req_action, + { + "DREG-REQ Action code", "wimax.dreg_req.action", + FT_UINT8, BASE_DEC, VALS(vals_dreg_req_code), 0x03, "", HFILL + } + }, + { + &hf_dreg_req_reserved, + { + "Reserved", "wimax.dreg_req.action_reserved", + FT_UINT8, BASE_DEC, NULL, 0xFC, "", HFILL + } + }, + { + &hf_tlv_value, + { + "Value", "wimax.dreg.unknown_tlv_value", + FT_BYTES, BASE_NONE, NULL, 0x00, "", HFILL + } + }, + { + &hf_ack_type_reserved, + { + "Reserved", "wimax.ack_type_reserved", + FT_UINT8, BASE_DEC, NULL, 0x03, "", HFILL + } + } +}; + + +/* Decode sub-TLV's of either DREG-REQ or DREG-CMD. */ +static void dissect_dreg_tlv(proto_tree *dreg_tree, gint tlv_type, tvbuff_t *tvb, guint tlv_offset, guint tlv_len, gint dreg_decoder) +{ + guint tvb_len; + /*guint tlv_len;*/ + + /* Get the tvb length */ + tvb_len = tvb_length(tvb); + + switch (tlv_type) { + case DREG_PAGING_INFO: + proto_tree_add_item(dreg_tree, hf_dreg_paging_cycle, tvb, tlv_offset, 2, FALSE); + proto_tree_add_item(dreg_tree, hf_dreg_paging_offset, tvb, tlv_offset + 2, 1, FALSE); + proto_tree_add_item(dreg_tree, hf_dreg_paging_group_id, tvb, tlv_offset + 3, 2, FALSE); + break; + case DREG_REQ_DURATION: + proto_tree_add_item(dreg_tree, hf_dreg_req_duration, tvb, tlv_offset, 1, FALSE); + break; + case DREG_PAGING_CONTROLLER_ID: + proto_tree_add_item(dreg_tree, hf_paging_controller_id, tvb, tlv_offset, 6, FALSE); + break; + case DREG_IDLE_MODE_RETAIN_INFO: + proto_tree_add_item(dreg_tree, hf_dreg_retain_ms_service_sbc, tvb, tlv_offset, 1, FALSE); + proto_tree_add_item(dreg_tree, hf_dreg_retain_ms_service_pkm, tvb, tlv_offset, 1, FALSE); + proto_tree_add_item(dreg_tree, hf_dreg_retain_ms_service_reg, tvb, tlv_offset, 1, FALSE); + proto_tree_add_item(dreg_tree, hf_dreg_retain_ms_service_network_address, tvb, tlv_offset, 1, FALSE); + proto_tree_add_item(dreg_tree, hf_dreg_retain_ms_service_tod, tvb, tlv_offset, 1, FALSE); + proto_tree_add_item(dreg_tree, hf_dreg_retain_ms_service_tftp, tvb, tlv_offset, 1, FALSE); + proto_tree_add_item(dreg_tree, hf_dreg_retain_ms_service_full_service, tvb, tlv_offset, 1, FALSE); + proto_tree_add_item(dreg_tree, hf_dreg_consider_paging_pref, tvb, tlv_offset, 1, FALSE); + break; + case DREG_MAC_HASH_SKIP_THRESHOLD: + proto_tree_add_item(dreg_tree, hf_mac_hash_skip_threshold, tvb, tlv_offset, 2, FALSE); + break; + case DREG_PAGING_CYCLE_REQUEST: + proto_tree_add_item(dreg_tree, hf_dreg_paging_cycle_request, tvb, tlv_offset, 2, FALSE); + break; + default: + proto_tree_add_item(dreg_tree, hf_tlv_value, tvb, tlv_offset, tlv_len, FALSE); + break; + } +} + +/* Register Wimax Mac Payload Protocol and Dissector */ +void proto_register_mac_mgmt_msg_dreg_req(void) +{ + if (proto_mac_mgmt_msg_dreg_req_decoder == -1) { + proto_mac_mgmt_msg_dreg_req_decoder = proto_register_protocol ( + "WiMax DREG-REQ/CMD Messages", /* name */ + "WiMax DREG-REQ/CMD (dreg)", /* short name */ + "dreg" /* abbrev */ + ); + + proto_register_field_array(proto_mac_mgmt_msg_dreg_req_decoder, hf, array_length(hf)); + proto_register_subtree_array(ett, array_length(ett)); + } +} + +/* Register Wimax Mac Payload Protocol and Dissector */ +void proto_register_mac_mgmt_msg_dreg_cmd(void) +{ + if (proto_mac_mgmt_msg_dreg_cmd_decoder == -1) { + proto_mac_mgmt_msg_dreg_cmd_decoder = proto_mac_mgmt_msg_dreg_req_decoder; + + proto_register_subtree_array(ett, array_length(ett)); + } +} + +/* Decode DREG-REQ messages. */ +void dissect_mac_mgmt_msg_dreg_req_decoder(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree) +{ + guint offset = 0; + guint tlv_offset; + guint tvb_len, payload_type; + proto_item *dreg_req_item = NULL; + proto_tree *dreg_req_tree = NULL; + proto_tree *tlv_tree = NULL; + tlv_info_t tlv_info; + gint tlv_type; + gint tlv_len; + gboolean hmac_found = FALSE; + + /* Ensure the right payload type */ + payload_type = tvb_get_guint8(tvb, 0); + if(payload_type != MAC_MGMT_MSG_DREG_REQ) + { + return; + } + + if (tree) + { /* we are being asked for details */ + + /* Get the tvb length */ + tvb_len = tvb_length(tvb); + /* display MAC payload type DREG-REQ */ + dreg_req_item = proto_tree_add_protocol_format(tree, proto_mac_mgmt_msg_dreg_req_decoder, tvb, 0, tvb_len, "MAC Management Message, DREG-REQ (49)"); + /* add MAC DREG REQ subtree */ + dreg_req_tree = proto_item_add_subtree(dreg_req_item, ett_mac_mgmt_msg_dreg_decoder); + /* display the Message Type */ + proto_tree_add_item(dreg_req_tree, hf_dreg_req_message_type, tvb, offset, 1, FALSE); + offset++; + /* display the Action Code */ + proto_tree_add_item(dreg_req_tree, hf_dreg_req_action, tvb, offset, 1, FALSE); + /* show the Reserved bits */ + proto_tree_add_item(dreg_req_tree, hf_dreg_req_reserved, tvb, offset, 1, FALSE); + offset++; + + while(offset < tvb_len) + { + /* Get the TLV data. */ + init_tlv_info(&tlv_info, tvb, offset); + /* get the TLV type */ + tlv_type = get_tlv_type(&tlv_info); + /* get the TLV length */ + tlv_len = get_tlv_length(&tlv_info); + if(tlv_type == -1 || tlv_len > MAX_TLV_LEN || tlv_len < 1) + { /* invalid tlv info */ + if (pinfo->cinfo) + { + col_append_sep_str(pinfo->cinfo, COL_INFO, NULL, "DREG-REQ TLV error"); + } + proto_tree_add_item(dreg_req_tree, hf_dreg_invalid_tlv, tvb, offset, (tvb_len - offset), FALSE); + break; + } + /* get the offset to the TLV data */ + tlv_offset = offset + get_tlv_value_offset(&tlv_info); + + switch (tlv_type) { + case HMAC_TUPLE: /* Table 348d */ + /* decode and display the HMAC Tuple */ + tlv_tree = add_protocol_subtree(&tlv_info, ett_mac_mgmt_msg_dreg_decoder, dreg_req_tree, proto_mac_mgmt_msg_dreg_req_decoder, tvb, tlv_offset, tlv_len, "HMAC Tuple (%u byte(s))", tlv_len); + wimax_hmac_tuple_decoder(tlv_tree, tvb, tlv_offset, tlv_len); + hmac_found = TRUE; + break; + case CMAC_TUPLE: /* Table 348b */ + /* decode and display the CMAC Tuple */ + tlv_tree = add_protocol_subtree(&tlv_info, ett_mac_mgmt_msg_dreg_decoder, dreg_req_tree, proto_mac_mgmt_msg_dreg_req_decoder, tvb, tlv_offset, tlv_len, "CMAC Tuple (%u byte(s))", tlv_len); + wimax_cmac_tuple_decoder(tlv_tree, tvb, tlv_offset, tlv_len); + break; + default: + /* Decode DREG-REQ sub-TLV's */ + tlv_tree = add_protocol_subtree(&tlv_info, ett_mac_mgmt_msg_dreg_decoder, dreg_req_tree, proto_mac_mgmt_msg_dreg_req_decoder, tvb, tlv_offset, tlv_len, "DREG-REQ sub-TLV's (%u byte(s))", tlv_len); + dissect_dreg_tlv(tlv_tree, tlv_type, tvb, tlv_offset, tlv_len, proto_mac_mgmt_msg_dreg_req_decoder); + break; + } + + + offset = tlv_len + tlv_offset; + } /* end of TLV process while loop */ + if (!hmac_found) + proto_item_append_text(dreg_req_tree, " (HMAC Tuple is missing !)"); + } +} + +/* Decode DREG-CMD messages. */ +void dissect_mac_mgmt_msg_dreg_cmd_decoder(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree) +{ + guint offset = 0; + guint tlv_offset; + guint tvb_len, payload_type; + proto_item *dreg_cmd_item = NULL; + proto_tree *dreg_cmd_tree = NULL; + proto_tree *tlv_tree = NULL; + tlv_info_t tlv_info; + gint tlv_type; + gint tlv_len; + gboolean hmac_found = FALSE; + + /* Ensure the right payload type */ + payload_type = tvb_get_guint8(tvb, 0); + if(payload_type != MAC_MGMT_MSG_DREG_CMD) + { + return; + } + + if (tree) + { /* we are being asked for details */ + + /* Get the tvb length */ + tvb_len = tvb_length(tvb); + /* display MAC payload type DREG-CMD */ + dreg_cmd_item = proto_tree_add_protocol_format(tree, proto_mac_mgmt_msg_dreg_cmd_decoder, tvb, 0, tvb_len, "MAC Management Message, DREG-CMD (29)"); + /* add MAC DREG CMD subtree */ + dreg_cmd_tree = proto_item_add_subtree(dreg_cmd_item, ett_mac_mgmt_msg_dreg_decoder); + /* display the Message Type */ + proto_tree_add_item(dreg_cmd_tree, hf_dreg_cmd_message_type, tvb, offset, 1, FALSE); + offset ++; + /* display the Action Code */ + if (include_cor2_changes) + proto_tree_add_item(dreg_cmd_tree, hf_dreg_cmd_action_cor2, tvb, offset, 1, FALSE); + else + proto_tree_add_item(dreg_cmd_tree, hf_dreg_cmd_action, tvb, offset, 1, FALSE); + /* show the Reserved bits */ + proto_tree_add_item(dreg_cmd_tree, hf_dreg_cmd_reserved, tvb, offset, 1, FALSE); + offset ++; + + while(offset < tvb_len) + { + /* Get the TLV data. */ + init_tlv_info(&tlv_info, tvb, offset); + /* get the TLV type */ + tlv_type = get_tlv_type(&tlv_info); + /* get the TLV length */ + tlv_len = get_tlv_length(&tlv_info); + if(tlv_type == -1 || tlv_len > MAX_TLV_LEN || tlv_len < 1) + { /* invalid tlv info */ + if (pinfo->cinfo) + { + col_append_sep_str(pinfo->cinfo, COL_INFO, NULL, "DREG-CMD TLV error"); + } + proto_tree_add_item(dreg_cmd_tree, hf_dreg_invalid_tlv, tvb, offset, (tvb_len - offset), FALSE); + break; + } + /* get the offset to the TLV data */ + tlv_offset = offset + get_tlv_value_offset(&tlv_info); + + switch (tlv_type) { + case HMAC_TUPLE: /* Table 348d */ + /* decode and display the HMAC Tuple */ + tlv_tree = add_protocol_subtree(&tlv_info, ett_mac_mgmt_msg_dreg_decoder, dreg_cmd_tree, proto_mac_mgmt_msg_dreg_cmd_decoder, tvb, tlv_offset, tlv_len, "HMAC Tuple (%u byte(s))", tlv_len); + wimax_hmac_tuple_decoder(tlv_tree, tvb, tlv_offset, tlv_len); + hmac_found = TRUE; + break; + case CMAC_TUPLE: /* Table 348b */ + /* decode and display the CMAC Tuple */ + tlv_tree = add_protocol_subtree(&tlv_info, ett_mac_mgmt_msg_dreg_decoder, dreg_cmd_tree, proto_mac_mgmt_msg_dreg_cmd_decoder, tvb, tlv_offset, tlv_len, "CMAC Tuple (%u byte(s))", tlv_len); + wimax_cmac_tuple_decoder(tlv_tree, tvb, tlv_offset, tlv_len); + break; + default: + /* Decode DREG-CMD sub-TLV's */ + tlv_tree = add_protocol_subtree(&tlv_info, ett_mac_mgmt_msg_dreg_decoder, dreg_cmd_tree, proto_mac_mgmt_msg_dreg_cmd_decoder, tvb, tlv_offset, tlv_len, "DREG-CMD sub-TLV's (%u byte(s))", tlv_len); + dissect_dreg_tlv(tlv_tree, tlv_type, tvb, tlv_offset, tlv_len, proto_mac_mgmt_msg_dreg_cmd_decoder); + break; + } + + offset = tlv_len + tlv_offset; + } /* end of TLV process while loop */ + if (!hmac_found) + proto_item_append_text(dreg_cmd_tree, " (HMAC Tuple is missing !)"); + } +} + |