diff options
Diffstat (limited to 'epan/dissectors/packet-isns.c')
-rw-r--r-- | epan/dissectors/packet-isns.c | 1922 |
1 files changed, 1922 insertions, 0 deletions
diff --git a/epan/dissectors/packet-isns.c b/epan/dissectors/packet-isns.c new file mode 100644 index 0000000000..f4fa286494 --- /dev/null +++ b/epan/dissectors/packet-isns.c @@ -0,0 +1,1922 @@ +/* XXX fixme can not reassemple multiple isns PDU fragments into one + isns PDU +*/ + +/* packet-isns.c + * Routines for iSNS dissection + * Copyright 2003, Elipsan, Gareth Bushell <gbushell@elipsan.com> + * (c) 2004 Ronnie Sahlberg updates + * + * $Id$ + * + * Ethereal - Network traffic analyzer + * By Gerald Combs <gerald@ethereal.com> + * Copyright 1998 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. + */ + +#ifdef HAVE_CONFIG_H +# include "config.h" +#endif + +#include <stdio.h> +#include <stdlib.h> +#include <string.h> + +#ifdef HAVE_SYS_TYPES_H +# include <sys/types.h> +#endif + +#ifdef HAVE_NETINET_IN_H +# include <netinet/in.h> +#endif + +#include <glib.h> + +#ifdef NEED_SNPRINTF_H +# include "snprintf.h" +#endif + +#include <epan/packet.h> +#include <epan/conversation.h> +#include "packet-tcp.h" +#include "prefs.h" + + +#define ISNS_PROTO_VER 0x1 +#define ISNS_HEADER_SIZE 12 + +#define ISNS_TCP_PORT 3205 +#define ISNS_UDP_PORT 3205 + +#define ISNS_OTHER_PORT 0 +#define ISNS_ESI_PORT 1 +#define ISNS_SCN_PORT 2 + + +dissector_handle_t isns_tcp_handle; +dissector_handle_t isns_udp_handle; + +static gint ett_isns_flags = -1; +static gint ett_isns_payload = -1; +static gint ett_isns_attribute = -1; +static gint ett_isns_port = -1; +static gint ett_isns_isnt = -1; + +static guint AddAttribute(packet_info *pinfo, tvbuff_t *tvb, proto_tree *tree, + guint offset, guint16 function_id); + +/* Initialize the protocol and registered fields */ +static int proto_isns = -1; + + +/* Header Stuff */ +static int hf_isns_version = -1; +static int hf_isns_function_id = -1; +static int hf_isns_pdu_length = -1; +static int hf_isns_flags = -1; +static int hf_isns_transaction_id = -1; +static int hf_isns_sequence_id = -1; +static int hf_isns_payload = -1; +static int hf_isns_first_pdu = -1; +static int hf_isns_last_pdu = -1; +static int hf_isns_replace = -1; +static int hf_isns_auth = -1; +static int hf_isns_server = -1; +static int hf_isns_client = -1; + +/* Payload stuff */ +static int hf_isns_scn_bitmap = -1; +static int hf_isns_scn_bitmap_initiator_and_self_information_only = -1; +static int hf_isns_scn_bitmap_target_and_self_information_only = -1; +static int hf_isns_scn_bitmap_management_registration_scn = -1; +static int hf_isns_scn_bitmap_object_removed = -1; +static int hf_isns_scn_bitmap_object_added = -1; +static int hf_isns_scn_bitmap_object_updated = -1; +static int hf_isns_scn_bitmap_dd_dds_member_removed = -1; +static int hf_isns_scn_bitmap_dd_dds_member_added = -1; +static int hf_isns_isnt_control = -1; +static int hf_isns_isnt_initiator = -1; +static int hf_isns_isnt_target = -1; + +static int hf_isns_psb = -1; +static int hf_isns_psb_tunnel_mode = -1; +static int hf_isns_psb_transport_mode = -1; +static int hf_isns_psb_pfs = -1; +static int hf_isns_psb_aggressive_mode = -1; +static int hf_isns_psb_main_mode = -1; +static int hf_isns_psb_ike_ipsec = -1; +static int hf_isns_psb_bitmap = -1; + +static int hf_isns_dd_member_portal_port = -1; +static int hf_isns_portal_port = -1; +static int hf_isns_esi_port = -1; +static int hf_isns_scn_port = -1; +static int hf_isns_port_type = -1; + +static int hf_isns_entity_protocol = -1; +static int hf_isns_iscsi_node_type = -1; +static int hf_isns_resp_errorcode = -1; +static int hf_isns_attr_tag = -1; +static int hf_isns_attr_len = -1; +static int hf_isns_heartbeat_ipv6_addr = -1; +static int hf_isns_heartbeat_udp_port = -1; +static int hf_isns_heartbeat_tcp_port = -1; +static int hf_isns_heartbeat_interval = -1; +static int hf_isns_heartbeat_counter = -1; + +static int hf_isns_mgmt_ip_addr = -1; +static int hf_isns_node_ip_addr = -1; +static int hf_isns_port_ip_addr = -1; +static int hf_isns_portal_ip_addr = -1; +static int hf_isns_dd_member_portal_ip_addr = -1; +static int hf_isns_iscsi_name = -1; +static int hf_isns_switch_name = -1; +static int hf_isns_dd_member_iscsi_name = -1; +static int hf_isns_virtual_fabric_id = -1; +static int hf_isns_proxy_iscsi_name = -1; +static int hf_isns_fc4_descriptor = -1; +static int hf_isns_iscsi_auth_method = -1; +static int hf_isns_iscsi_alias = -1; +static int hf_isns_portal_symbolic_name = -1; +static int hf_isns_dd_set_symbolic_name = -1; +static int hf_isns_dd_symbolic_name = -1; +static int hf_isns_symbolic_port_name = -1; +static int hf_isns_symbolic_node_name = -1; +static int hf_isns_entity_identifier = -1; +static int hf_isns_dd_id_next_id = -1; +static int hf_isns_member_iscsi_index = -1; +static int hf_isns_member_portal_index = -1; +static int hf_isns_member_ifcp_node = -1; +static int hf_isns_vendor_oui = -1; +static int hf_isns_preferred_id = -1; +static int hf_isns_assigned_id = -1; +static int hf_isns_dd_id = -1; +static int hf_isns_dd_set_id = -1; +static int hf_isns_dd_set_next_id = -1; +static int hf_isns_node_index = -1; +static int hf_isns_node_next_index = -1; +static int hf_isns_entity_index = -1; +static int hf_isns_portal_index = -1; +static int hf_isns_portal_next_index = -1; +static int hf_isns_entity_next_index = -1; +static int hf_isns_timestamp = -1; +static int hf_isns_esi_interval = -1; +static int hf_isns_registration_period = -1; +static int hf_isns_port_id = -1; +static int hf_isns_hard_address = -1; +static int hf_isns_wwnn_token = -1; +static int hf_isns_node_ipa = -1; +static int hf_isns_fc_port_name_wwpn = -1; +static int hf_isns_fc_node_name_wwnn = -1; +static int hf_isns_fabric_port_name = -1; +static int hf_isns_permanent_port_name = -1; +static int hf_isns_delimiter = -1; +static int hf_isns_not_decoded_yet = -1; +static int hf_isns_portal_group_tag = -1; +static int hf_isns_pg_portal_ip_addr = -1; +static int hf_isns_pg_portal_port = -1; + + + +/* Desegment iSNS over TCP messages */ +static gboolean isns_desegment = TRUE; + +/* Function Id's */ +#define ISNS_FUNC_DEVATTRREG 0x0001 +#define ISNS_FUNC_DEVATTRQRY 0x0002 +#define ISNS_FUNC_DEVGETNEXT 0x0003 +#define ISNS_FUNC_DEREGDEV 0x0004 +#define ISNS_FUNC_SCNREG 0x0005 +#define ISNS_FUNC_SCNDEREG 0x0006 +#define ISNS_FUNC_SCNEVENT 0x0007 +#define ISNS_FUNC_SCN 0x0008 +#define ISNS_FUNC_DDREG 0x0009 +#define ISNS_FUNC_DDDEREG 0x000a +#define ISNS_FUNC_DDSREG 0x000b +#define ISNS_FUNC_DDSDEREG 0x000c +#define ISNS_FUNC_ESI 0x000d +#define ISNS_FUNC_HEARTBEAT 0x000e + +#define ISNS_FUNC_RSP_DEVATTRREG 0x8001 +#define ISNS_FUNC_RSP_DEVATTRQRY 0x8002 +#define ISNS_FUNC_RSP_DEVGETNEXT 0x8003 +#define ISNS_FUNC_RSP_DEREGDEV 0x8004 +#define ISNS_FUNC_RSP_SCNREG 0x8005 +#define ISNS_FUNC_RSP_SCNDEREG 0x8006 +#define ISNS_FUNC_RSP_SCNEVENT 0x8007 +#define ISNS_FUNC_RSP_SCN 0x8008 +#define ISNS_FUNC_RSP_DDREG 0x8009 +#define ISNS_FUNC_RSP_DDDEREG 0x800a +#define ISNS_FUNC_RSP_DDSREG 0x800b +#define ISNS_FUNC_RSP_DDSDEREG 0x800c +#define ISNS_FUNC_RSP_ESI 0x800d + +static const value_string isns_function_ids[] = { +/* Requests*/ + {ISNS_FUNC_DEVATTRREG, "DevAttrReg"}, + {ISNS_FUNC_DEVATTRQRY, "DevAttrQry"}, + {ISNS_FUNC_DEVGETNEXT, "DevGetNext"}, + {ISNS_FUNC_DEREGDEV, "DeregDev"}, + {ISNS_FUNC_SCNREG, "SCNReg"}, + {ISNS_FUNC_SCNDEREG, "SCNDereg"}, + {ISNS_FUNC_SCNEVENT, "SCNEvent"}, + {ISNS_FUNC_SCN, "SCN"}, + {ISNS_FUNC_DDREG, "DDReg"}, + {ISNS_FUNC_DDDEREG, "DDDereg"}, + {ISNS_FUNC_DDSREG, "DDSReg"}, + {ISNS_FUNC_DDSDEREG, "DDSDereg"}, + {ISNS_FUNC_ESI, "ESI"}, + {ISNS_FUNC_HEARTBEAT, "Heartbeat"}, + +/* Responses */ + {ISNS_FUNC_RSP_DEVATTRREG, "DevAttrRegRsp"}, + {ISNS_FUNC_RSP_DEVATTRQRY, "DevAttrQryRsp"}, + {ISNS_FUNC_RSP_DEVGETNEXT, "DevGetNextRsp"}, + {ISNS_FUNC_RSP_DEREGDEV, "DeregDevRsp"}, + {ISNS_FUNC_RSP_SCNREG, "SCNRegRsp"}, + {ISNS_FUNC_RSP_SCNDEREG, "SCNDeregRsp"}, + {ISNS_FUNC_RSP_SCNEVENT, "SCNEventRsp"}, + {ISNS_FUNC_RSP_SCN, "SCNRsp"}, + {ISNS_FUNC_RSP_DDREG, "DDRegRsp"}, + {ISNS_FUNC_RSP_DDDEREG, "DDDeregRsp"}, + {ISNS_FUNC_RSP_DDSREG, "DDSRegRsp"}, + {ISNS_FUNC_RSP_DDSDEREG, "DDSDeregRsp"}, + {ISNS_FUNC_RSP_ESI, "ESIRsp"}, + + {0x0,NULL}, +}; + +#define ISNS_ENTITY_PROTOCOL_NO_PROTOCOL 1 +#define ISNS_ENTITY_PROTOCOL_ISCSI 2 +#define ISNS_ENTITY_PROTOCOL_IFCP 3 + + +static const value_string isns_entity_protocol[] = { + {ISNS_ENTITY_PROTOCOL_NO_PROTOCOL, "No Protocol"}, + {ISNS_ENTITY_PROTOCOL_ISCSI, "iSCSI"}, + {ISNS_ENTITY_PROTOCOL_IFCP, "iFCP"}, + + {0x0,NULL}, +}; + +static const value_string isns_errorcode[] = { + { 0,"No Error"}, + { 1,"Unknown Error"}, + { 2,"Message Format Error"}, + { 3,"Invalid Registration"}, + { 4,"Requested ESI Period Too short"}, + { 5,"Invalid Query"}, + { 6,"Authentication Unknown"}, + { 7,"Authentication Absent"}, + { 8,"Authentication Failed"}, + { 9,"No such Entry"}, + {10,"Version Not Supported"}, + {11,"Internal Bus Error"}, + {12,"Busy Now"}, + {13,"Option Not Understood"}, + {14,"Invalid Update"}, + {15,"Message Not supported"}, + {16,"SCN Event Rejected"}, + {17,"SCN Registration Rejected"}, + {18,"Attribute Not Implemented"}, + {19,"SWITCH_ID Not available"}, + {20,"SWITCH_ID not allocated"}, + {21,"ESI Not Available"}, + + {0x0,NULL} +}; + + +#define ISNS_ATTR_TAG_DELIMITER 0 +#define ISNS_ATTR_TAG_ENTITY_IDENTIFIER 1 +#define ISNS_ATTR_TAG_ENTITY_PROTOCOL 2 +#define ISNS_ATTR_TAG_MGMT_IP_ADDRESS 3 +#define ISNS_ATTR_TAG_TIMESTAMP 4 +#define ISNS_ATTR_TAG_PROTOCOL_VERSION_RANGE 5 +#define ISNS_ATTR_TAG_REGISTRATION_PERIOD 6 +#define ISNS_ATTR_TAG_ENTITY_INDEX 7 +#define ISNS_ATTR_TAG_ENTITY_NEXT_INDEX 8 +#define ISNS_ATTR_TAG_ENTITY_ISAKMP_PHASE_1 11 +#define ISNS_ATTR_TAG_ENTITY_CERTIFICATE 12 +#define ISNS_ATTR_TAG_PORTAL_IP_ADDRESS 16 +#define ISNS_ATTR_TAG_PORTAL_PORT 17 +#define ISNS_ATTR_TAG_PORTAL_SYMBOLIC_NAME 18 +#define ISNS_ATTR_TAG_ESI_INTERVAL 19 +#define ISNS_ATTR_TAG_ESI_PORT 20 +#define ISNS_ATTR_TAG_PORTAL_GROUP 21 +#define ISNS_ATTR_TAG_PORTAL_INDEX 22 +#define ISNS_ATTR_TAG_SCN_PORT 23 +#define ISNS_ATTR_TAG_PORTAL_NEXT_INDEX 24 +#define ISNS_ATTR_TAG_PORTAL_SECURITY_BITMAP 27 +#define ISNS_ATTR_TAG_PORTAL_ISAKMP_PHASE_1 28 +#define ISNS_ATTR_TAG_PORTAL_ISAKMP_PHASE_2 29 +#define ISNS_ATTR_TAG_PORTAL_CERTIFICATE 31 +#define ISNS_ATTR_TAG_ISCSI_NAME 32 +#define ISNS_ATTR_TAG_ISCSI_NODE_TYPE 33 +#define ISNS_ATTR_TAG_ISCSI_ALIAS 34 +#define ISNS_ATTR_TAG_ISCSI_SCN_BITMAP 35 +#define ISNS_ATTR_TAG_ISCSI_NODE_INDEX 36 +#define ISNS_ATTR_TAG_WWNN_TOKEN 37 +#define ISNS_ATTR_TAG_ISCSI_NODE_NEXT_INDEX 38 +#define ISNS_ATTR_TAG_ISCSI_AUTH_METHOD 42 +#define ISNS_ATTR_TAG_ISCSI_NODE_CERTIFICATE 43 +#define ISNS_ATTR_TAG_PG_PORTAL_IP_ADDR 49 +#define ISNS_ATTR_TAG_PG_PORTAL_PORT 50 +#define ISNS_ATTR_TAG_PORTAL_GROUP_TAG 51 +#define ISNS_ATTR_TAG_FC_PORT_NAME_WWPN 64 +#define ISNS_ATTR_TAG_PORT_ID 65 +#define ISNS_ATTR_TAG_FC_PORT_TYPE 66 +#define ISNS_ATTR_TAG_SYMBOLIC_PORT_NAME 67 +#define ISNS_ATTR_TAG_FABRIC_PORT_NAME 68 +#define ISNS_ATTR_TAG_HARD_ADDRESS 69 +#define ISNS_ATTR_TAG_PORT_IP_ADDRESS 70 +#define ISNS_ATTR_TAG_CLASS_OF_SERVICE 71 +#define ISNS_ATTR_TAG_FC4_TYPES 72 +#define ISNS_ATTR_TAG_FC4_DESCRIPTOR 73 +#define ISNS_ATTR_TAG_FC4_FEATURES 74 +#define ISNS_ATTR_TAG_IFCP_SCN_BITMAP 75 +#define ISNS_ATTR_TAG_PORT_ROLE 76 +#define ISNS_ATTR_TAG_PERMANENT_PORT_NAME 77 +#define ISNS_ATTR_TAG_PORT_CERTIFICATE 83 +#define ISNS_ATTR_TAG_FC4_TYPE_CODE 95 +#define ISNS_ATTR_TAG_FC_NODE_NAME_WWNN 96 +#define ISNS_ATTR_TAG_SYMBOLIC_NODE_NAME 97 +#define ISNS_ATTR_TAG_NODE_IP_ADDRESS 98 +#define ISNS_ATTR_TAG_NODE_IPA 99 +#define ISNS_ATTR_TAG_NODE_CERTIFICATE 100 +#define ISNS_ATTR_TAG_PROXY_ISCSI_NAME 101 +#define ISNS_ATTR_TAG_SWITCH_NAME 128 +#define ISNS_ATTR_TAG_PREFERRED_ID 129 +#define ISNS_ATTR_TAG_ASSIGNED_ID 130 +#define ISNS_ATTR_TAG_VIRTUAL_FABRIC_ID 131 +#define ISNS_ATTR_TAG_VENDOR_OUI 256 +#define ISNS_ATTR_TAG_DD_SET_ID 2049 +#define ISNS_ATTR_TAG_DD_SET_SYMBOLIC_NAME 2050 +#define ISNS_ATTR_TAG_DD_SET_STATUS 2051 +#define ISNS_ATTR_TAG_DD_SET_NEXT_ID 2052 +#define ISNS_ATTR_TAG_DD_ID 2065 +#define ISNS_ATTR_TAG_DD_SYMBOLIC_NAME 2066 +#define ISNS_ATTR_TAG_DD_MEMBER_ISCSI_INDEX 2067 +#define ISNS_ATTR_TAG_DD_MEMBER_ISCSI_NAME 2068 +#define ISNS_ATTR_TAG_DD_MEMBER_IFCP_NODE 2069 +#define ISNS_ATTR_TAG_DD_MEMBER_PORTAL_INDEX 2070 +#define ISNS_ATTR_TAG_DD_MEMBER_PORTAL_IP_ADDRESS 2071 +#define ISNS_ATTR_TAG_DD_MEMBER_PORTAL_PORT 2072 +#define ISNS_ATTR_TAG_DD_FEATURES 2078 +#define ISNS_ATTR_TAG_DD_ID_NEXT_ID 2079 + + +static const value_string isns_attribute_tags[] = { + {ISNS_ATTR_TAG_DELIMITER, "Delimiter"}, + {ISNS_ATTR_TAG_ENTITY_IDENTIFIER, "Entity Identifier (EID)"}, + {ISNS_ATTR_TAG_ENTITY_PROTOCOL, "Entity Protocol"}, + {ISNS_ATTR_TAG_MGMT_IP_ADDRESS, "Management IP Address"}, + {ISNS_ATTR_TAG_TIMESTAMP, "Timestamp"}, + {ISNS_ATTR_TAG_PROTOCOL_VERSION_RANGE, "Protocol Version Range"}, + {ISNS_ATTR_TAG_REGISTRATION_PERIOD, "Registration Period"}, + {ISNS_ATTR_TAG_ENTITY_INDEX, "Entity Index"}, + {ISNS_ATTR_TAG_ENTITY_NEXT_INDEX, "Entity Next Index"}, + {ISNS_ATTR_TAG_ENTITY_ISAKMP_PHASE_1, "Entity ISAKMP Phase-1"}, + {ISNS_ATTR_TAG_ENTITY_CERTIFICATE, "Entity Certificate"}, + {ISNS_ATTR_TAG_PORTAL_IP_ADDRESS, "Portal IP Address"}, + {ISNS_ATTR_TAG_PORTAL_PORT, "Portal TCP/UDP Port"}, + {ISNS_ATTR_TAG_PORTAL_SYMBOLIC_NAME, "Portal Symbolic Name"}, + {ISNS_ATTR_TAG_ESI_INTERVAL, "ESI Interval"}, + {ISNS_ATTR_TAG_ESI_PORT, "ESI Port"}, + {ISNS_ATTR_TAG_PORTAL_GROUP, "Portal Group Tag"}, + {ISNS_ATTR_TAG_PORTAL_INDEX, "Portal Index"}, + {ISNS_ATTR_TAG_SCN_PORT, "SCN Port"}, + {ISNS_ATTR_TAG_PORTAL_NEXT_INDEX, "Portal Next Index"}, + {ISNS_ATTR_TAG_PORTAL_SECURITY_BITMAP, "Portal Security Bitmap"}, + {ISNS_ATTR_TAG_PORTAL_ISAKMP_PHASE_1, "Portal ISAKMP Phase-1"}, + {ISNS_ATTR_TAG_PORTAL_ISAKMP_PHASE_2, "Portal ISAKMP Phase-2"}, + {ISNS_ATTR_TAG_PORTAL_CERTIFICATE, "Portal Certificate"}, + {ISNS_ATTR_TAG_ISCSI_NAME, "iSCSI Name"}, + {ISNS_ATTR_TAG_ISCSI_NODE_TYPE, "iSCSI Node Type"}, + {ISNS_ATTR_TAG_ISCSI_ALIAS, "iSCSI Alias"}, + {ISNS_ATTR_TAG_ISCSI_SCN_BITMAP, "iSCSI SCN Bitmap"}, + {ISNS_ATTR_TAG_ISCSI_NODE_INDEX, "iSCSI Node Index"}, + {ISNS_ATTR_TAG_WWNN_TOKEN, "WWNN Token"}, + {ISNS_ATTR_TAG_ISCSI_NODE_NEXT_INDEX, "iSCSI Node Next Index"}, + {ISNS_ATTR_TAG_ISCSI_AUTH_METHOD, "iSCSI AuthMethod"}, + {ISNS_ATTR_TAG_ISCSI_NODE_CERTIFICATE, "iSCSI Node Certificate"}, + {ISNS_ATTR_TAG_PG_PORTAL_IP_ADDR, "PG Portal IP Addr"}, + {ISNS_ATTR_TAG_PG_PORTAL_PORT, "PG Portal Port"}, + {ISNS_ATTR_TAG_PORTAL_GROUP_TAG, "Portal Group Tag"}, + {ISNS_ATTR_TAG_FC_PORT_NAME_WWPN, "FC Port Name WWPN"}, + {ISNS_ATTR_TAG_PORT_ID, "Port ID"}, + {ISNS_ATTR_TAG_FC_PORT_TYPE, "FC Port Type"}, + {ISNS_ATTR_TAG_SYMBOLIC_PORT_NAME, "Symbolic Port Name"}, + {ISNS_ATTR_TAG_FABRIC_PORT_NAME, "Fabric Port Name"}, + {ISNS_ATTR_TAG_HARD_ADDRESS, "Hard Address"}, + {ISNS_ATTR_TAG_PORT_IP_ADDRESS, "Port IP-Address"}, + {ISNS_ATTR_TAG_CLASS_OF_SERVICE, "Class of Service"}, + {ISNS_ATTR_TAG_FC4_TYPES, "FC-4 Types"}, + {ISNS_ATTR_TAG_FC4_DESCRIPTOR, "FC-4 Descriptor"}, + {ISNS_ATTR_TAG_FC4_FEATURES, "FC-4 Features"}, + {ISNS_ATTR_TAG_IFCP_SCN_BITMAP, "iFCP SCN bitmap"}, + {ISNS_ATTR_TAG_PORT_ROLE, "Port Role"}, + {ISNS_ATTR_TAG_PERMANENT_PORT_NAME, "Permanent Port Name"}, + {ISNS_ATTR_TAG_PORT_CERTIFICATE, "Port Certificate"}, + {ISNS_ATTR_TAG_FC4_TYPE_CODE, "FC-4 Type Code"}, + {ISNS_ATTR_TAG_FC_NODE_NAME_WWNN, "FC Node Name WWNN"}, + {ISNS_ATTR_TAG_SYMBOLIC_NODE_NAME, "Symbolic Node Name"}, + {ISNS_ATTR_TAG_NODE_IP_ADDRESS, "Node IP-Address"}, + {ISNS_ATTR_TAG_NODE_IPA, "Node IPA"}, + {ISNS_ATTR_TAG_NODE_CERTIFICATE, "Node Certificate"}, + {ISNS_ATTR_TAG_PROXY_ISCSI_NAME, "Proxy iSCSI Name"}, + {ISNS_ATTR_TAG_SWITCH_NAME, "Switch Name"}, + {ISNS_ATTR_TAG_PREFERRED_ID, "Preferred ID"}, + {ISNS_ATTR_TAG_ASSIGNED_ID, "Assigned ID"}, + {ISNS_ATTR_TAG_VIRTUAL_FABRIC_ID, "Virtual_Fabric_ID"}, + {ISNS_ATTR_TAG_VENDOR_OUI, "iSNS Server Vendor OUI"}, + {ISNS_ATTR_TAG_DD_SET_ID, "DD_Set ID"}, + {ISNS_ATTR_TAG_DD_SET_SYMBOLIC_NAME, "DD_Set Sym Name"}, + {ISNS_ATTR_TAG_DD_SET_STATUS, "DD_Set Status"}, + {ISNS_ATTR_TAG_DD_SET_NEXT_ID, "DD_Set_Next_ID"}, + {ISNS_ATTR_TAG_DD_ID, "DD_ID"}, + {ISNS_ATTR_TAG_DD_SYMBOLIC_NAME, "DD_Symbolic Name"}, + {ISNS_ATTR_TAG_DD_MEMBER_ISCSI_INDEX, "DD_Member iSCSI Index"}, + {ISNS_ATTR_TAG_DD_MEMBER_ISCSI_NAME, "DD_Member iSCSI Name"}, + {ISNS_ATTR_TAG_DD_MEMBER_IFCP_NODE, "DD_Member iFCP Node"}, + {ISNS_ATTR_TAG_DD_MEMBER_PORTAL_INDEX, "DD Member Portal Index"}, + {ISNS_ATTR_TAG_DD_MEMBER_PORTAL_IP_ADDRESS, "DD_Member Portal IP Addr"}, + {ISNS_ATTR_TAG_DD_MEMBER_PORTAL_PORT, "DD Member Portal TCP/UDP"}, + {ISNS_ATTR_TAG_DD_FEATURES, "DD_Features"}, + {ISNS_ATTR_TAG_DD_ID_NEXT_ID, "DD_ID Next ID"}, + + {0,NULL} +}; + + +/* iSNS flags */ +#define ISNS_FLAGS_CLIENT 0x8000 +#define ISNS_FLAGS_SERVER 0x4000 +#define ISNS_FLAGS_AUTH 0x2000 +#define ISNS_FLAGS_REPLACE 0x1000 +#define ISNS_FLAGS_LAST_PDU 0x0800 +#define ISNS_FLAGS_FIRST_PDU 0x0400 + + +static const true_false_string isns_scn_bitmap_initiator_and_self_information_only = { + "True", + "False" +}; +static const true_false_string isns_scn_bitmap_target_and_self_information_only = { + "True", + "False" +}; +static const true_false_string isns_scn_bitmap_management_registration_scn = { + "True", + "False" +}; +static const true_false_string isns_scn_bitmap_object_removed = { + "True", + "False" +}; +static const true_false_string isns_scn_bitmap_object_added = { + "True", + "False" +}; +static const true_false_string isns_scn_bitmap_object_updated = { + "True", + "False" +}; +static const true_false_string isns_scn_bitmap_dd_dds_member_removed = { + "True", + "False" +}; +static const true_false_string isns_scn_bitmap_dd_dds_member_added = { + "True", + "False" +}; + +static const true_false_string isns_psb_tunnel_mode = { + "Preferred", + "No Preference" +}; +static const true_false_string isns_psb_transport_mode = { + "Preferred", + "No Preference" +}; +static const true_false_string isns_psb_pfs = { + "Enabled", + "Disabled" +}; +static const true_false_string isns_psb_aggressive_mode = { + "Enabled", + "Disabled" +}; +static const true_false_string isns_psb_main_mode = { + "Enabled", + "Disabled" +}; +static const true_false_string isns_psb_ike_ipsec = { + "Enabled", + "Disabled" +}; +static const true_false_string isns_psb_bitmap = { + "VALID", + "INVALID" +}; + +static const true_false_string isns_isnt_control = { + "Yes", + "No" +}; +static const true_false_string isns_isnt_initiator = { + "Yes", + "No" +}; +static const true_false_string isns_isnt_target = { + "Yes", + "No" +}; + +static const true_false_string isns_port_type = { + "UDP", + "TCP" +}; + +static const true_false_string isns_flag_first_pdu = { + "First PDU of iSNS Message", + "Not the first PDU of iSNS Message" +}; + +static const true_false_string isns_flag_last_pdu = { + "Last PDU of iSNS Message", + "Not the Last PDU of iSNS Message" +}; + +static const true_false_string isns_flag_replace = { + "Replace", + "Don't replace" +}; + +static const true_false_string isns_flag_auth = { + "Authentication Block is PRESENT", + "No authentication block" +}; + +static const true_false_string isns_flag_server = { + "Sender is iSNS server", + "Sender is not iSNS server" +}; + +static const true_false_string isns_flag_client = { + "Sender is iSNS client", + "Sender is not iSNS client" +}; + + +/* Initialize the subtree pointers */ +static gint ett_isns = -1; + + +/* Code to actually dissect the packets */ +static void +dissect_isns_pdu(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree) +{ + guint offset = 0; + guint16 function_id; + guint16 isns_protocol_version; + guint32 packet_len = tvb_length_remaining(tvb, offset); + char * function_id_str; + /* Set up structures needed to add the protocol subtree and manage it */ + proto_item *ti = NULL; + proto_tree *isns_tree = NULL; + + if( packet_len < 12 ) + return; + + /* Make entries in Protocol column and Info column on summary display */ + if (check_col(pinfo->cinfo, COL_PROTOCOL)) + col_set_str(pinfo->cinfo, COL_PROTOCOL, "isns"); + if (check_col(pinfo->cinfo, COL_INFO)) + col_clear(pinfo->cinfo, COL_INFO); + + /* Get the function id from the packet */ + function_id = tvb_get_ntohs(tvb, offset + 2); + function_id_str = match_strval(function_id, isns_function_ids); + + /* Get the protocol version - only version one at the moment*/ + isns_protocol_version = tvb_get_ntohs(tvb, offset + 0); + if( (function_id_str == NULL) || (isns_protocol_version != ISNS_PROTO_VER) ) + return; + + /* Add the function name in the info col */ + if (check_col(pinfo->cinfo, COL_INFO)) + col_add_str(pinfo->cinfo, COL_INFO, function_id_str); + + /* In the interest of speed, if "tree" is NULL, don't do any work not + * necessary to generate protocol tree items. + */ + if (tree) { + guint16 b; + guint16 flags; + proto_tree *tt; + proto_item *tflags; + proto_item *tpayload; + + /* NOTE: The offset and length values in the call to + * "proto_tree_add_item()" define what data bytes to highlight in the hex + * display window when the line in the protocol tree display + * corresponding to that item is selected. + * tvb_length(tvb) is a handy way to highlight all data from the offset to + * the end of the packet. + */ + + /* create display subtree for the protocol */ + ti = proto_tree_add_item(tree, proto_isns, tvb, 0, -1, FALSE); + isns_tree = proto_item_add_subtree(ti, ett_isns); + + /* OK... Sort out the header */ + b = tvb_get_ntohs(tvb, offset); + proto_tree_add_uint(isns_tree, hf_isns_version, tvb, offset, 2, b); + + b = tvb_get_ntohs(tvb, offset + 2); + proto_tree_add_uint(isns_tree, hf_isns_function_id, tvb, offset+2, 2, b); + + b = tvb_get_ntohs(tvb, offset + 4); + proto_tree_add_uint(isns_tree, hf_isns_pdu_length, tvb, offset+4, 2, b); + + /*FLAGS*/ + flags = tvb_get_ntohs(tvb, offset + 6); + tflags = proto_tree_add_uint(isns_tree, hf_isns_flags, tvb, offset+6, 2, flags); + tt = proto_item_add_subtree(tflags, ett_isns_flags); + + proto_tree_add_boolean(tt, hf_isns_client, tvb, offset+6, 2, flags); + proto_tree_add_boolean(tt, hf_isns_server, tvb, offset+6, 2, flags); + proto_tree_add_boolean(tt, hf_isns_auth, tvb, offset+6, 2, flags); + proto_tree_add_boolean(tt, hf_isns_replace, tvb, offset+6, 2, flags); + proto_tree_add_boolean(tt, hf_isns_last_pdu, tvb, offset+6, 2, flags); + proto_tree_add_boolean(tt, hf_isns_first_pdu, tvb, offset+6, 2, flags); + + b = tvb_get_ntohs(tvb, offset + 8); + proto_tree_add_uint(isns_tree, hf_isns_transaction_id, tvb, offset+8, 2, b); + + b = tvb_get_ntohs(tvb, offset + 10); + proto_tree_add_uint(isns_tree, hf_isns_sequence_id, tvb, offset+10, 2, b); + + tpayload = proto_tree_add_item(isns_tree, hf_isns_payload, tvb, offset+12, packet_len - 12 , FALSE); + tt = proto_item_add_subtree(tpayload, ett_isns_payload); + + /* Now set the offset to the start of the payload */ + offset += ISNS_HEADER_SIZE; + + /* Decode those attributes baby - Yeah!*/ + switch (function_id) + { + case ISNS_FUNC_HEARTBEAT: + { + guint8 hb_ipv6[16]; + guint16 port; + guint32 c; + tvb_memcpy(tvb,hb_ipv6,offset,16); + proto_tree_add_ipv6(tt,hf_isns_heartbeat_ipv6_addr, tvb, offset, 16, hb_ipv6); + offset += 16; + + port = tvb_get_ntohs(tvb, offset); + proto_tree_add_uint(tt,hf_isns_heartbeat_tcp_port, tvb, offset, 2, port); + offset += 2; + + port = tvb_get_ntohs(tvb, offset); + proto_tree_add_uint(tt,hf_isns_heartbeat_udp_port, tvb, offset, 2, port); + offset += 2; + + c = tvb_get_ntohl(tvb, offset); + proto_tree_add_uint(tt,hf_isns_heartbeat_interval, tvb, offset, 4, c); + offset += 4; + + c = tvb_get_ntohl(tvb, offset); + proto_tree_add_uint(tt,hf_isns_heartbeat_counter, tvb, offset, 4, c); + offset += 4; + break; + } + /* Responses */ + case ISNS_FUNC_RSP_DEVATTRREG: + case ISNS_FUNC_RSP_DEVATTRQRY: + case ISNS_FUNC_RSP_DEVGETNEXT: + case ISNS_FUNC_RSP_DEREGDEV: + case ISNS_FUNC_RSP_SCNREG: + case ISNS_FUNC_RSP_SCNDEREG: + case ISNS_FUNC_RSP_SCNEVENT: + case ISNS_FUNC_RSP_SCN: + case ISNS_FUNC_RSP_DDREG: + case ISNS_FUNC_RSP_DDDEREG: + case ISNS_FUNC_RSP_DDSREG: + case ISNS_FUNC_RSP_DDSDEREG: + case ISNS_FUNC_RSP_ESI: + { + /* Get the Error message of the response */ + guint32 errorcode = tvb_get_ntohl(tvb, offset); + proto_tree_add_uint(tt,hf_isns_resp_errorcode, tvb, offset, 4, errorcode); + offset += 4; + /* Messages */ + } + case ISNS_FUNC_DEVATTRREG: + case ISNS_FUNC_DEVATTRQRY: + case ISNS_FUNC_DEVGETNEXT: + case ISNS_FUNC_DEREGDEV: + case ISNS_FUNC_SCNREG: + case ISNS_FUNC_SCNDEREG: + case ISNS_FUNC_SCNEVENT: + case ISNS_FUNC_SCN: + case ISNS_FUNC_DDREG: + case ISNS_FUNC_DDDEREG: + case ISNS_FUNC_DDSREG: + case ISNS_FUNC_DDSDEREG: + case ISNS_FUNC_ESI: + default: + /* we can only look at the attributes for the first PDU */ + if(!(flags&ISNS_FLAGS_FIRST_PDU)){ + proto_tree_add_text(tt, tvb, offset, packet_len-offset, "This is not the first PDU. The attributes are not decoded"); + return; + } + + while( offset < packet_len ) + { + offset = AddAttribute(pinfo, tvb, tt, offset, function_id); + } + } + } + + return; +} + +static guint +get_isns_pdu_len(tvbuff_t *tvb, int offset) +{ + guint16 isns_len; + + isns_len = tvb_get_ntohs(tvb, offset+4); + return (isns_len+12); +} + +static void +dissect_isns_tcp(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree) +{ + /* Make entries in Protocol column and Info column on summary display*/ + if (check_col(pinfo->cinfo, COL_PROTOCOL)) + col_set_str(pinfo->cinfo, COL_PROTOCOL, "isns"); + if (check_col(pinfo->cinfo, COL_INFO)) + col_clear(pinfo->cinfo, COL_INFO); + + tcp_dissect_pdus(tvb, pinfo, tree, isns_desegment, 12, get_isns_pdu_len, + dissect_isns_pdu); + + +} + +static void +dissect_isns_udp(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree) +{ + /* Make entries in Protocol column and Info column on summary display*/ + if (check_col(pinfo->cinfo, COL_PROTOCOL)) + col_set_str(pinfo->cinfo, COL_PROTOCOL, "isns"); + if (check_col(pinfo->cinfo, COL_INFO)) + col_clear(pinfo->cinfo, COL_INFO); + + dissect_isns_pdu(tvb, pinfo, tree); +} + + +static guint +dissect_isns_attr_ip_address(tvbuff_t *tvb, guint offset, proto_tree *parent_tree, int hf_index, guint32 tag, guint32 len) +{ + proto_item *item=NULL; + proto_tree *tree=NULL; + + if(parent_tree){ + item=proto_tree_add_item(parent_tree, hf_index, tvb, offset + 8, len, FALSE); + tree = proto_item_add_subtree(item, ett_isns_attribute); + } + + proto_tree_add_uint(tree, hf_isns_attr_tag, tvb, offset, 4, tag); + proto_tree_add_uint(tree, hf_isns_attr_len, tvb, offset+4, 4, len); + + return offset+8+len; +} + +static guint +dissect_isns_attr_string(tvbuff_t *tvb, guint offset, proto_tree *parent_tree, int hf_index, guint32 tag, guint32 len) +{ + proto_item *item=NULL; + proto_tree *tree=NULL; + + if(parent_tree){ + item=proto_tree_add_item(parent_tree, hf_index, tvb, offset + 8, len, FALSE); + tree = proto_item_add_subtree(item, ett_isns_attribute); + } + + proto_tree_add_uint(tree, hf_isns_attr_tag, tvb, offset, 4, tag); + proto_tree_add_uint(tree, hf_isns_attr_len, tvb, offset+4, 4, len); + + return offset+8+len; +} + +static guint +dissect_isns_attr_integer(tvbuff_t *tvb, guint offset, proto_tree *parent_tree, int hf_index, guint32 tag, guint32 len, guint16 function_id) +{ + proto_item *item=NULL; + proto_tree *tree=NULL; + + /* + * 5.6.5.1 + * in a DevAttrReg , the PGT (tag 51) may be sent as 0 length + * which then means that we wish to register the portal group tag + * as NULL. + * (At least) some servers will respond with PGT as a 0 length + * value in these instances in the DevAttrRegRsp (eventhough I can + * not find this mentioned in the standard) so allow it for the + * response as well. + */ + if(len){ + if(parent_tree){ + item=proto_tree_add_item(parent_tree, hf_index, tvb, offset + 8, len, FALSE); + tree = proto_item_add_subtree(item, ett_isns_attribute); + } + } else if((tag==ISNS_ATTR_TAG_PORTAL_GROUP_TAG)&&((function_id==ISNS_FUNC_DEVATTRREG)||(function_id==ISNS_FUNC_RSP_DEVATTRREG))){ + /* 5.6.5.1 */ + if(parent_tree){ + item=proto_tree_add_uint_format(parent_tree, hf_isns_portal_group_tag, tvb, offset, 8, 0, "PG Tag: <NULL>"); + tree = proto_item_add_subtree(item, ett_isns_attribute); + } + } else { + if(parent_tree){ + item=proto_tree_add_text(parent_tree, tvb, offset, 8, "Oops, you surprised me here. a 0 byte integer."); + tree = proto_item_add_subtree(item, ett_isns_attribute); + } + } + + proto_tree_add_uint(tree, hf_isns_attr_tag, tvb, offset, 4, tag); + proto_tree_add_uint(tree, hf_isns_attr_len, tvb, offset+4, 4, len); + + return offset+8+len; +} + +static guint +dissect_isns_attr_port(tvbuff_t *tvb, guint offset, proto_tree *parent_tree, int hf_index, guint32 tag, guint32 len, + guint16 port_type, packet_info *pinfo) +{ + proto_item *tree=NULL; + proto_item *item=NULL; + guint16 port = tvb_get_ntohs(tvb, offset + 10); + guint16 isudp = tvb_get_ntohs(tvb, offset + 8)&0x01; + conversation_t *conversation; + + if(parent_tree){ + item = proto_tree_add_uint(parent_tree, hf_index, tvb, offset+8, 4, port); + tree = proto_item_add_subtree(item, ett_isns_port); + } + + proto_tree_add_boolean(tree, hf_isns_port_type, tvb, offset+8, 2, isudp); + + proto_tree_add_uint(tree, hf_isns_attr_tag, tvb, offset, 4, tag); + proto_tree_add_uint(tree, hf_isns_attr_len, tvb, offset+4, 4, len); + + if ((port_type == ISNS_ESI_PORT) || (port_type == ISNS_SCN_PORT)) { + if (isudp) { + conversation = find_conversation (&pinfo->src, &pinfo->dst, PT_UDP, + port, 0, NO_PORT_B); + if (conversation == NULL) { + conversation = conversation_new (&pinfo->src, &pinfo->dst, + PT_UDP, port, 0, NO_PORT2_FORCE); + conversation_set_dissector (conversation, isns_udp_handle); + } + } + else { + conversation = find_conversation (&pinfo->src, &pinfo->dst, PT_TCP, + port, 0, NO_PORT_B); + if (conversation == NULL) { + conversation = conversation_new (&pinfo->src, &pinfo->dst, + PT_TCP, port, 0, NO_PORT2_FORCE); + conversation_set_dissector (conversation, isns_tcp_handle); + } + } + } + + return offset+8+len; +} + +static guint +dissect_isns_attr_none(tvbuff_t *tvb, guint offset, proto_tree *parent_tree, int hf_index, guint32 tag, guint32 len) +{ + proto_item *tree=NULL; + proto_item *item=NULL; + + if(parent_tree){ + item=proto_tree_add_item(parent_tree, hf_index, tvb, offset, 8, FALSE); + tree = proto_item_add_subtree(item, ett_isns_port); + } + + proto_tree_add_uint(tree, hf_isns_attr_tag, tvb, offset, 4, tag); + proto_tree_add_uint(tree, hf_isns_attr_len, tvb, offset+4, 4, len); + + return offset+8+len; +} + +static guint +dissect_isns_attr_not_decoded_yet(tvbuff_t *tvb, guint offset, proto_tree *parent_tree, int hf_index, guint32 tag, guint32 len) +{ + proto_item *tree=NULL; + proto_item *item=NULL; + + if(parent_tree){ + item=proto_tree_add_item(parent_tree, hf_index, tvb, offset + 8, len, FALSE); + tree = proto_item_add_subtree(item, ett_isns_port); + } + + proto_tree_add_uint(tree, hf_isns_attr_tag, tvb, offset, 4, tag); + proto_tree_add_uint(tree, hf_isns_attr_len, tvb, offset+4, 4, len); + + return offset+8+len; +} + +static guint +dissect_isns_attr_iscsi_node_type(tvbuff_t *tvb, guint offset, proto_tree *parent_tree, int hf_index, guint32 tag, guint32 len) +{ + proto_item *item=NULL; + proto_tree *tree=NULL; + guint32 node_type=tvb_get_ntohl(tvb, offset + 8); + + if(parent_tree){ + item=proto_tree_add_item(parent_tree, hf_index, tvb, offset + 8, len, FALSE); + tree = proto_item_add_subtree(item, ett_isns_attribute); + } + + proto_tree_add_boolean(tree, hf_isns_isnt_control, tvb, offset+8, 4, node_type); + if(node_type&0x00000004){ + proto_item_append_text(item, " Control"); + } + proto_tree_add_boolean(tree, hf_isns_isnt_initiator, tvb, offset+8, 4, node_type); + if(node_type&0x00000002){ + proto_item_append_text(item, " Initiator"); + } + proto_tree_add_boolean(tree, hf_isns_isnt_target, tvb, offset+8, 4, node_type); + if(node_type&0x00000001){ + proto_item_append_text(item, " Target"); + } + + proto_tree_add_uint(tree, hf_isns_attr_tag, tvb, offset, 4, tag); + proto_tree_add_uint(tree, hf_isns_attr_len, tvb, offset+4, 4, len); + + return offset+8+len; +} + + + +static guint +dissect_isns_attr_portal_security_bitmap(tvbuff_t *tvb, guint offset, proto_tree *parent_tree, int hf_index, guint32 tag, guint32 len) +{ + proto_item *item=NULL; + proto_tree *tree=NULL; + guint32 psb=tvb_get_ntohl(tvb, offset + 8); + + if(parent_tree){ + item=proto_tree_add_item(parent_tree, hf_index, tvb, offset + 8, len, FALSE); + tree = proto_item_add_subtree(item, ett_isns_attribute); + } + + proto_tree_add_boolean(tree, hf_isns_psb_tunnel_mode, tvb, offset+8, 4, psb); + proto_tree_add_boolean(tree, hf_isns_psb_transport_mode, tvb, offset+8, 4, psb); + proto_tree_add_boolean(tree, hf_isns_psb_pfs, tvb, offset+8, 4, psb); + proto_tree_add_boolean(tree, hf_isns_psb_aggressive_mode, tvb, offset+8, 4, psb); + proto_tree_add_boolean(tree, hf_isns_psb_main_mode, tvb, offset+8, 4, psb); + proto_tree_add_boolean(tree, hf_isns_psb_ike_ipsec, tvb, offset+8, 4, psb); + proto_tree_add_boolean(tree, hf_isns_psb_bitmap, tvb, offset+8, 4, psb); + + proto_tree_add_uint(tree, hf_isns_attr_tag, tvb, offset, 4, tag); + proto_tree_add_uint(tree, hf_isns_attr_len, tvb, offset+4, 4, len); + + return offset+8+len; +} + + + +static guint +dissect_isns_attr_scn_bitmap(tvbuff_t *tvb, guint offset, proto_tree *parent_tree, int hf_index, guint32 tag, guint32 len) +{ + proto_item *item=NULL; + proto_tree *tree=NULL; + guint32 scn_bitmap=tvb_get_ntohl(tvb, offset + 8); + + if(parent_tree){ + item=proto_tree_add_item(parent_tree, hf_index, tvb, offset + 8, len, FALSE); + tree = proto_item_add_subtree(item, ett_isns_attribute); + } + + + /* + 24 INITIATOR AND SELF INFORMATION ONLY + 25 TARGET AND SELF INFORMATION ONLY + 26 MANAGEMENT REGISTRATION/SCN + 27 OBJECT REMOVED + 28 OBJECT ADDED + 29 OBJECT UPDATED + 30 DD/DDS MEMBER REMOVED (Mgmt Reg/SCN only) + 31 (Lsb) DD/DDS MEMBER ADDED (Mgmt Reg/SCN only) + */ + proto_tree_add_boolean(tree, hf_isns_scn_bitmap_initiator_and_self_information_only, tvb, offset+8, 4, scn_bitmap); + proto_tree_add_boolean(tree, hf_isns_scn_bitmap_target_and_self_information_only, tvb, offset+8, 4, scn_bitmap); + proto_tree_add_boolean(tree, hf_isns_scn_bitmap_management_registration_scn, tvb, offset+8, 4, scn_bitmap); + proto_tree_add_boolean(tree, hf_isns_scn_bitmap_object_removed, tvb, offset+8, 4, scn_bitmap); + proto_tree_add_boolean(tree, hf_isns_scn_bitmap_object_added, tvb, offset+8, 4, scn_bitmap); + proto_tree_add_boolean(tree, hf_isns_scn_bitmap_object_updated, tvb, offset+8, 4, scn_bitmap); + proto_tree_add_boolean(tree, hf_isns_scn_bitmap_dd_dds_member_removed, tvb, offset+8, 4, scn_bitmap); + proto_tree_add_boolean(tree, hf_isns_scn_bitmap_dd_dds_member_added, tvb, offset+8, 4, scn_bitmap); + + proto_tree_add_uint(tree, hf_isns_attr_tag, tvb, offset, 4, tag); + proto_tree_add_uint(tree, hf_isns_attr_len, tvb, offset+4, 4, len); + + return offset+8+len; +} + + + + +static guint +AddAttribute(packet_info *pinfo, tvbuff_t *tvb, proto_tree *tree, guint offset, + guint16 function_id) +{ + guint32 tag,len; + + + /* Get the Tag */ + tag = tvb_get_ntohl(tvb, offset); + + /* Now the Length */ + len = tvb_get_ntohl(tvb, offset + 4); + + if (!len) { + if (tree) { + proto_tree_add_uint(tree, hf_isns_attr_tag, tvb, offset, 4, tag); + proto_tree_add_uint(tree, hf_isns_attr_len, tvb, offset+4, 4, len); + } + return (offset+8); + } + + switch( tag ) + { + case ISNS_ATTR_TAG_DELIMITER: + offset = dissect_isns_attr_none(tvb, offset, tree, hf_isns_delimiter, tag, len); + break; + case ISNS_ATTR_TAG_ENTITY_IDENTIFIER: + offset = dissect_isns_attr_string(tvb, offset, tree, hf_isns_entity_identifier, tag, len); + break; + case ISNS_ATTR_TAG_ENTITY_PROTOCOL: + offset = dissect_isns_attr_integer(tvb, offset, tree, hf_isns_entity_protocol, tag, len, function_id); + break; + case ISNS_ATTR_TAG_MGMT_IP_ADDRESS: + offset = dissect_isns_attr_ip_address(tvb, offset, tree, hf_isns_mgmt_ip_addr, tag, len); + break; + case ISNS_ATTR_TAG_TIMESTAMP: + offset = dissect_isns_attr_integer(tvb, offset, tree, hf_isns_timestamp, tag, len, function_id); + break; + case ISNS_ATTR_TAG_PROTOCOL_VERSION_RANGE: + offset = dissect_isns_attr_not_decoded_yet(tvb, offset, tree, hf_isns_not_decoded_yet, tag, len); + break; + case ISNS_ATTR_TAG_REGISTRATION_PERIOD: + offset = dissect_isns_attr_integer(tvb, offset, tree, hf_isns_registration_period, tag, len, function_id); + break; + case ISNS_ATTR_TAG_ENTITY_INDEX: + offset = dissect_isns_attr_integer(tvb, offset, tree, hf_isns_entity_index, tag, len, function_id); + break; + case ISNS_ATTR_TAG_ENTITY_NEXT_INDEX: + offset = dissect_isns_attr_integer(tvb, offset, tree, hf_isns_entity_next_index, tag, len, function_id); + break; + case ISNS_ATTR_TAG_ENTITY_ISAKMP_PHASE_1: + offset = dissect_isns_attr_not_decoded_yet(tvb, offset, tree, hf_isns_not_decoded_yet, tag, len); + break; + case ISNS_ATTR_TAG_ENTITY_CERTIFICATE: + offset = dissect_isns_attr_not_decoded_yet(tvb, offset, tree, hf_isns_not_decoded_yet, tag, len); + break; + case ISNS_ATTR_TAG_PORTAL_IP_ADDRESS: + offset = dissect_isns_attr_ip_address(tvb, offset, tree, hf_isns_portal_ip_addr, tag, len); + break; + case ISNS_ATTR_TAG_PORTAL_PORT: + offset = dissect_isns_attr_port(tvb, offset, tree, hf_isns_portal_port, tag, len, ISNS_OTHER_PORT, pinfo); + break; + case ISNS_ATTR_TAG_PORTAL_SYMBOLIC_NAME: + offset = dissect_isns_attr_string(tvb, offset, tree, hf_isns_portal_symbolic_name, tag, len); + break; + case ISNS_ATTR_TAG_ESI_INTERVAL: + offset = dissect_isns_attr_integer(tvb, offset, tree, hf_isns_esi_interval, tag, len, function_id); + break; + case ISNS_ATTR_TAG_ESI_PORT: + offset = dissect_isns_attr_port(tvb, offset, tree, hf_isns_esi_port, tag, len, ISNS_ESI_PORT, pinfo); + break; + case ISNS_ATTR_TAG_PORTAL_GROUP: + offset = dissect_isns_attr_not_decoded_yet(tvb, offset, tree, hf_isns_not_decoded_yet, tag, len); + break; + case ISNS_ATTR_TAG_PORTAL_INDEX: + offset = dissect_isns_attr_integer(tvb, offset, tree, hf_isns_portal_index, tag, len, function_id); + break; + case ISNS_ATTR_TAG_SCN_PORT: + offset = dissect_isns_attr_port(tvb, offset, tree, hf_isns_scn_port, tag, len, ISNS_SCN_PORT, pinfo); + break; + case ISNS_ATTR_TAG_PORTAL_NEXT_INDEX: + offset = dissect_isns_attr_integer(tvb, offset, tree, hf_isns_portal_next_index, tag, len, function_id); + break; + case ISNS_ATTR_TAG_PORTAL_SECURITY_BITMAP: + offset = dissect_isns_attr_portal_security_bitmap(tvb, offset, tree, hf_isns_psb, tag, len); + break; + case ISNS_ATTR_TAG_PORTAL_ISAKMP_PHASE_1: + offset = dissect_isns_attr_not_decoded_yet(tvb, offset, tree, hf_isns_not_decoded_yet, tag, len); + break; + case ISNS_ATTR_TAG_PORTAL_ISAKMP_PHASE_2: + offset = dissect_isns_attr_not_decoded_yet(tvb, offset, tree, hf_isns_not_decoded_yet, tag, len); + break; + case ISNS_ATTR_TAG_PORTAL_CERTIFICATE: + offset = dissect_isns_attr_not_decoded_yet(tvb, offset, tree, hf_isns_not_decoded_yet, tag, len); + break; + case ISNS_ATTR_TAG_ISCSI_NAME: + offset = dissect_isns_attr_string(tvb, offset, tree, hf_isns_iscsi_name, tag, len); + break; + case ISNS_ATTR_TAG_ISCSI_NODE_TYPE: + offset = dissect_isns_attr_iscsi_node_type(tvb, offset, tree, hf_isns_iscsi_node_type, tag, len); + break; + case ISNS_ATTR_TAG_ISCSI_ALIAS: + offset = dissect_isns_attr_string(tvb, offset, tree, hf_isns_iscsi_alias, tag, len); + break; + case ISNS_ATTR_TAG_ISCSI_SCN_BITMAP: + offset = dissect_isns_attr_scn_bitmap(tvb, offset, tree, hf_isns_scn_bitmap, tag, len); + break; + case ISNS_ATTR_TAG_ISCSI_NODE_INDEX: + offset = dissect_isns_attr_integer(tvb, offset, tree, hf_isns_node_index, tag, len, function_id); + break; + case ISNS_ATTR_TAG_WWNN_TOKEN: + offset = dissect_isns_attr_integer(tvb, offset, tree, hf_isns_wwnn_token, tag, len, function_id); + break; + case ISNS_ATTR_TAG_ISCSI_NODE_NEXT_INDEX: + offset = dissect_isns_attr_integer(tvb, offset, tree, hf_isns_node_next_index, tag, len, function_id); + break; + case ISNS_ATTR_TAG_ISCSI_AUTH_METHOD: + offset = dissect_isns_attr_string(tvb, offset, tree, hf_isns_iscsi_auth_method, tag, len); + break; + case ISNS_ATTR_TAG_ISCSI_NODE_CERTIFICATE: + offset = dissect_isns_attr_not_decoded_yet(tvb, offset, tree, hf_isns_not_decoded_yet, tag, len); + break; + case ISNS_ATTR_TAG_PG_PORTAL_IP_ADDR: + offset = dissect_isns_attr_ip_address(tvb, offset, tree, hf_isns_pg_portal_ip_addr, tag, len); + break; + case ISNS_ATTR_TAG_PG_PORTAL_PORT: + offset = dissect_isns_attr_port(tvb, offset, tree, hf_isns_pg_portal_port, tag, len, ISNS_OTHER_PORT, pinfo); + break; + case ISNS_ATTR_TAG_PORTAL_GROUP_TAG: + offset = dissect_isns_attr_integer(tvb, offset, tree, hf_isns_portal_group_tag, tag, len, function_id); + break; + case ISNS_ATTR_TAG_FC_PORT_NAME_WWPN: + offset = dissect_isns_attr_integer(tvb, offset, tree, hf_isns_fc_port_name_wwpn, tag, len, function_id); + break; + case ISNS_ATTR_TAG_PORT_ID: + offset = dissect_isns_attr_integer(tvb, offset, tree, hf_isns_port_id, tag, len, function_id); + break; + case ISNS_ATTR_TAG_FC_PORT_TYPE: + offset = dissect_isns_attr_not_decoded_yet(tvb, offset, tree, hf_isns_not_decoded_yet, tag, len); + break; + /* + 0x0000 Unidentified/Null Entry + 0x0001 Fibre Channel N_Port + 0x0002 Fibre Channel NL_Port + 0x0003 Fibre Channel F/NL_Port + 0x0081 Fibre Channel F_Port + 0x0082 Fibre Channel FL_Port + 0x0084 Fibre Channel E_Port + 0xFF12 iFCP Port + */ + case ISNS_ATTR_TAG_SYMBOLIC_PORT_NAME: + offset = dissect_isns_attr_string(tvb, offset, tree, hf_isns_symbolic_port_name, tag, len); + break; + case ISNS_ATTR_TAG_FABRIC_PORT_NAME: + offset = dissect_isns_attr_integer(tvb, offset, tree, hf_isns_fabric_port_name, tag, len, function_id); + break; + case ISNS_ATTR_TAG_HARD_ADDRESS: + offset = dissect_isns_attr_integer(tvb, offset, tree, hf_isns_hard_address, tag, len, function_id); + break; + case ISNS_ATTR_TAG_PORT_IP_ADDRESS: + offset = dissect_isns_attr_ip_address(tvb, offset, tree, hf_isns_port_ip_addr, tag, len); + break; + case ISNS_ATTR_TAG_CLASS_OF_SERVICE: + offset = dissect_isns_attr_not_decoded_yet(tvb, offset, tree, hf_isns_not_decoded_yet, tag, len); + break; + /* + bit 29 Fibre Channel Class 2 Supported + bit 28 Fibre Channel Class 3 Supported + */ + case ISNS_ATTR_TAG_FC4_TYPES: + offset = dissect_isns_attr_not_decoded_yet(tvb, offset, tree, hf_isns_not_decoded_yet, tag, len); + break; + case ISNS_ATTR_TAG_FC4_DESCRIPTOR: + offset = dissect_isns_attr_string(tvb, offset, tree, hf_isns_fc4_descriptor, tag, len); + break; + case ISNS_ATTR_TAG_FC4_FEATURES: + offset = dissect_isns_attr_not_decoded_yet(tvb, offset, tree, hf_isns_not_decoded_yet, tag, len); + break; + case ISNS_ATTR_TAG_IFCP_SCN_BITMAP: + offset = dissect_isns_attr_not_decoded_yet(tvb, offset, tree, hf_isns_not_decoded_yet, tag, len); + break; + /* + bit 24 INITIATOR AND SELF INFORMATION ONLY + bit 25 TARGET AND SELF INFORMATION ONLY + bit 26 MANAGEMENT REGISTRATION/SCN + bit 27 OBJECT REMOVED + bit 28 OBJECT ADDED + bit 29 OBJECT UPDATED + bit 30 DD/DDS MEMBER REMOVED (Mgmt Reg/SCN only) + bit 31 (Lsb) DD/DDS MEMBER ADDED (Mgmt Reg/SCN only) + */ + case ISNS_ATTR_TAG_PORT_ROLE: + offset = dissect_isns_attr_not_decoded_yet(tvb, offset, tree, hf_isns_not_decoded_yet, tag, len); + break; + /* + bit 29 Control + bit 30 FCP Initiator + bit 31 (Lsb) FCP Target + */ + case ISNS_ATTR_TAG_PERMANENT_PORT_NAME: + offset = dissect_isns_attr_integer(tvb, offset, tree, hf_isns_permanent_port_name, tag, len, function_id); + break; + case ISNS_ATTR_TAG_PORT_CERTIFICATE: + offset = dissect_isns_attr_not_decoded_yet(tvb, offset, tree, hf_isns_not_decoded_yet, tag, len); + break; + case ISNS_ATTR_TAG_FC4_TYPE_CODE: + offset = dissect_isns_attr_not_decoded_yet(tvb, offset, tree, hf_isns_not_decoded_yet, tag, len); + break; + /* 8bit type code in byte0 */ + case ISNS_ATTR_TAG_FC_NODE_NAME_WWNN: + offset = dissect_isns_attr_integer(tvb, offset, tree, hf_isns_fc_node_name_wwnn, tag, len, function_id); + break; + case ISNS_ATTR_TAG_SYMBOLIC_NODE_NAME: + offset = dissect_isns_attr_string(tvb, offset, tree, hf_isns_symbolic_node_name, tag, len); + break; + case ISNS_ATTR_TAG_NODE_IP_ADDRESS: + offset = dissect_isns_attr_ip_address(tvb, offset, tree, hf_isns_node_ip_addr, tag, len); + break; + case ISNS_ATTR_TAG_NODE_IPA: + offset = dissect_isns_attr_integer(tvb, offset, tree, hf_isns_node_ipa, tag, len, function_id); + break; + case ISNS_ATTR_TAG_NODE_CERTIFICATE: + offset = dissect_isns_attr_not_decoded_yet(tvb, offset, tree, hf_isns_not_decoded_yet, tag, len); + break; + case ISNS_ATTR_TAG_PROXY_ISCSI_NAME: + offset = dissect_isns_attr_string(tvb, offset, tree, hf_isns_proxy_iscsi_name, tag, len); + break; + case ISNS_ATTR_TAG_SWITCH_NAME: + offset = dissect_isns_attr_integer(tvb, offset, tree, hf_isns_switch_name, tag, len, function_id); + break; + case ISNS_ATTR_TAG_PREFERRED_ID: + offset = dissect_isns_attr_integer(tvb, offset, tree, hf_isns_preferred_id, tag, len, function_id); + break; + case ISNS_ATTR_TAG_ASSIGNED_ID: + offset = dissect_isns_attr_integer(tvb, offset, tree, hf_isns_assigned_id, tag, len, function_id); + break; + case ISNS_ATTR_TAG_VIRTUAL_FABRIC_ID: + offset = dissect_isns_attr_string(tvb, offset, tree, hf_isns_virtual_fabric_id, tag, len); + break; + case ISNS_ATTR_TAG_VENDOR_OUI: + offset = dissect_isns_attr_integer(tvb, offset, tree, hf_isns_vendor_oui, tag, len, function_id); + break; + case ISNS_ATTR_TAG_DD_SET_ID: + offset = dissect_isns_attr_integer(tvb, offset, tree, hf_isns_dd_set_id, tag, len, function_id); + break; + case ISNS_ATTR_TAG_DD_SET_SYMBOLIC_NAME: + offset = dissect_isns_attr_string(tvb, offset, tree, hf_isns_dd_set_symbolic_name, tag, len); + break; + case ISNS_ATTR_TAG_DD_SET_STATUS: + offset = dissect_isns_attr_not_decoded_yet(tvb, offset, tree, hf_isns_not_decoded_yet, tag, len); + break; + case ISNS_ATTR_TAG_DD_SET_NEXT_ID: + offset = dissect_isns_attr_integer(tvb, offset, tree, hf_isns_dd_set_next_id, tag, len, function_id); + break; + case ISNS_ATTR_TAG_DD_ID: + offset = dissect_isns_attr_integer(tvb, offset, tree, hf_isns_dd_id, tag, len, function_id); + break; + case ISNS_ATTR_TAG_DD_SYMBOLIC_NAME: + offset = dissect_isns_attr_string(tvb, offset, tree, hf_isns_dd_symbolic_name, tag, len); + break; + case ISNS_ATTR_TAG_DD_MEMBER_ISCSI_INDEX: + offset = dissect_isns_attr_integer(tvb, offset, tree, hf_isns_member_iscsi_index, tag, len, function_id); + break; + case ISNS_ATTR_TAG_DD_MEMBER_ISCSI_NAME: + offset = dissect_isns_attr_string(tvb, offset, tree, hf_isns_dd_member_iscsi_name, tag, len); + break; + case ISNS_ATTR_TAG_DD_MEMBER_IFCP_NODE: + offset = dissect_isns_attr_integer(tvb, offset, tree, hf_isns_member_ifcp_node, tag, len, function_id); + break; + case ISNS_ATTR_TAG_DD_MEMBER_PORTAL_INDEX: + offset = dissect_isns_attr_integer(tvb, offset, tree, hf_isns_member_portal_index, tag, len, function_id); + break; + case ISNS_ATTR_TAG_DD_MEMBER_PORTAL_IP_ADDRESS: + offset = dissect_isns_attr_ip_address(tvb, offset, tree, hf_isns_dd_member_portal_ip_addr, tag, len); + break; + case ISNS_ATTR_TAG_DD_MEMBER_PORTAL_PORT: + offset = dissect_isns_attr_port(tvb, offset, tree, hf_isns_dd_member_portal_port, + tag, len, ISNS_OTHER_PORT, pinfo); + break; + case ISNS_ATTR_TAG_DD_FEATURES: + offset = dissect_isns_attr_not_decoded_yet(tvb, offset, tree, hf_isns_not_decoded_yet, tag, len); + break; + case ISNS_ATTR_TAG_DD_ID_NEXT_ID: + offset = dissect_isns_attr_integer(tvb, offset, tree, hf_isns_dd_id_next_id, tag, len, function_id); + break; + default: + offset = dissect_isns_attr_not_decoded_yet(tvb, offset, tree, hf_isns_not_decoded_yet, tag, len); + } + + + /* move on the offset to next attribute */ + + return offset; +} + + + +/* Register the protocol with Ethereal */ + +/* this format is require because a script is used to build the C function + that calls all the protocol registration. +*/ + +void proto_register_isns(void) +{ + /* Setup list of header fields See Section 1.6.1 for details*/ + static hf_register_info hf[] = { + /* The Header Stuff */ + { &hf_isns_version, + { "iSNSP Version","isns.PVer", + FT_UINT16, BASE_DEC, NULL, 0, + "iSNS Protocol Version" ,HFILL} + }, + { &hf_isns_function_id, + { "Function ID","isns.functionid", + FT_UINT16, BASE_DEC,VALS(&isns_function_ids),0, + "iSNS Function ID" ,HFILL} + }, + { &hf_isns_pdu_length, + { "PDU Length","isns.pdulength", + FT_UINT16, BASE_DEC,NULL,0, + "iSNS PDU Length" ,HFILL} + }, + + { &hf_isns_flags, + { "Flags","isns.flags", + FT_UINT16, BASE_HEX,NULL,0, + "iSNS Flags" ,HFILL} + }, + { &hf_isns_client, + { "Client ","isns.flags.client", + FT_BOOLEAN, 16, TFS(&isns_flag_client), ISNS_FLAGS_CLIENT, + "iSNS Client" ,HFILL} + }, + { &hf_isns_server, + { "Server ","isns.flags.server", + FT_BOOLEAN, 16, TFS(&isns_flag_server), ISNS_FLAGS_SERVER, + "iSNS Server" ,HFILL} + }, + { &hf_isns_auth, + { "Auth ","isns.flags.authentication_block", + FT_BOOLEAN, 16, TFS(&isns_flag_auth), ISNS_FLAGS_AUTH, + "is iSNS Authentication Block present?" ,HFILL} + }, + { &hf_isns_replace, + { "Replace ","isns.flags.replace", + FT_BOOLEAN, 16, TFS(&isns_flag_replace), ISNS_FLAGS_REPLACE, + "iSNS Replace" ,HFILL} + }, + { &hf_isns_last_pdu, + { "Last PDU ","isns.flags.lastpdu", + FT_BOOLEAN, 16, TFS(&isns_flag_last_pdu), ISNS_FLAGS_LAST_PDU, + "iSNS Last PDU" ,HFILL} + }, + { &hf_isns_first_pdu, + { "First PDU ","isns.flags.firstpdu", + FT_BOOLEAN, 16, TFS(&isns_flag_first_pdu), ISNS_FLAGS_FIRST_PDU, + "iSNS First PDU",HFILL } + }, + + + { &hf_isns_transaction_id, + { "Transaction ID","isns.transactionid", + FT_UINT16, BASE_DEC,NULL,0, + "iSNS transaction ID" ,HFILL} + }, + { &hf_isns_sequence_id, + { "Sequence ID","isns.sequenceid", + FT_UINT16, BASE_DEC,NULL,0, + "iSNS sequence ID" ,HFILL} + }, + + { &hf_isns_entity_protocol, + { "Entity Protocol","isns.entity_protocol", + FT_UINT32, BASE_DEC,VALS(isns_entity_protocol),0, + "iSNS Entity Protocol" ,HFILL} + }, + /* The Payload stuff */ + + { &hf_isns_dd_member_portal_port, + { "DD Member Portal Port","isns.dd_member_portal_port", + FT_UINT32, BASE_DEC, NULL, 0, + "TCP/UDP DD Member Portal Port", HFILL } + }, + + { &hf_isns_iscsi_node_type, + { "iSCSI Node Type","isns.iscsi.node_type", + FT_UINT32, BASE_HEX, NULL, 0, + "iSCSI Node Type", HFILL } + }, + + { &hf_isns_esi_port, + { "ESI Port","isns.esi_port", + FT_UINT32, BASE_DEC, NULL, 0, + "TCP/UDP ESI Port", HFILL } + }, + + { &hf_isns_scn_port, + { "SCN Port","isns.scn_port", + FT_UINT32, BASE_DEC, NULL, 0, + "TCP/UDP SCN Port", HFILL } + }, + + { &hf_isns_portal_port, + { "Portal Port","isns.portal_port", + FT_UINT32, BASE_DEC, NULL, 0, + "TCP/UDP Portal Port", HFILL } + }, + + { &hf_isns_pg_portal_port, + { "PG Portal Port","isns.pg.portal_port", + FT_UINT32, BASE_DEC, NULL, 0, + "PG Portal TCP/UDP Port", HFILL } + }, + + { &hf_isns_port_type, + { "Port Type","isns.port.port_type", + FT_BOOLEAN, 16, TFS(&isns_port_type), 0x01, /* bit 15 (or bit 1 of a 16bit word) */ + "Port Type",HFILL } + }, + + { &hf_isns_psb, + { "Portal Security Bitmap","isns.psb", + FT_UINT32, BASE_HEX, NULL, 0, + "Portal Security Bitmap", HFILL } + }, + { &hf_isns_psb_tunnel_mode, + { "Tunnel Mode ","isns.psb.tunnel", + FT_BOOLEAN, 32, TFS(&isns_psb_tunnel_mode), 0x0040, /* bit 25 */ + "Tunnel Mode Preferred",HFILL } + }, + { &hf_isns_psb_transport_mode, + { "Transport Mode ","isns.psb.transport", + FT_BOOLEAN, 32, TFS(&isns_psb_transport_mode), 0x0020, /* bit 26 */ + "Transport Mode",HFILL } + }, + { &hf_isns_psb_pfs, + { "PFS ","isns.psb.pfs", + FT_BOOLEAN, 32, TFS(&isns_psb_pfs), 0x0010, /* bit 27 */ + "PFS",HFILL } + }, + { &hf_isns_psb_aggressive_mode, + { "Aggressive Mode ","isns.psb.aggressive_mode", + FT_BOOLEAN, 32, TFS(&isns_psb_aggressive_mode), 0x0008, /* bit 28 */ + "Aggressive Mode",HFILL } + }, + { &hf_isns_psb_main_mode, + { "Main Mode ","isns.psb.main_mode", + FT_BOOLEAN, 32, TFS(&isns_psb_main_mode), 0x0004, /* bit 29 */ + "Main Mode",HFILL } + }, + { &hf_isns_psb_ike_ipsec, + { "IKE/IPSec ","isns.psb.ike_ipsec", + FT_BOOLEAN, 32, TFS(&isns_psb_ike_ipsec), 0x0002, /* bit 30 */ + "IKE/IPSec",HFILL } + }, + { &hf_isns_psb_bitmap, + { "Bitmap ","isns.psb.bitmap", + FT_BOOLEAN, 32, TFS(&isns_psb_bitmap), 0x0001, /* bit 31 */ + "Bitmap",HFILL } + }, + + + + { &hf_isns_scn_bitmap, + { "iSCSI SCN Bitmap","isns.scn_bitmap", + FT_UINT32, BASE_HEX, NULL, 0, + "iSCSI SCN Bitmap", HFILL } + }, + { &hf_isns_scn_bitmap_initiator_and_self_information_only, + { "Initiator And Self Information Only","isns.scn_bitmap.initiator_and_self_information_only", + FT_BOOLEAN, 32, TFS(&isns_scn_bitmap_initiator_and_self_information_only), 0x0080, /* bit 24 */ + "Initiator And Self Information Only",HFILL } + }, + { &hf_isns_scn_bitmap_target_and_self_information_only, + { "Target And Self Information Only","isns.scn_bitmap.target_and_self_information_only", + FT_BOOLEAN, 32, TFS(&isns_scn_bitmap_target_and_self_information_only), 0x0040, /* bit 25 */ + "Target And Self Information Only",HFILL } + }, + { &hf_isns_scn_bitmap_management_registration_scn, + { "Management Registration/SCN","isns.scn_bitmap.management_registration_scn", + FT_BOOLEAN, 32, TFS(&isns_scn_bitmap_management_registration_scn), 0x0020, /* bit 26 */ + "Management Registration/SCN",HFILL } + }, + { &hf_isns_scn_bitmap_object_removed, + { "Object Removed","isns.scn_bitmap.object_removed", + FT_BOOLEAN, 32, TFS(&isns_scn_bitmap_object_removed), 0x0010, /* bit 27 */ + "Object Removed",HFILL } + }, + { &hf_isns_scn_bitmap_object_added, + { "Object Added","isns.scn_bitmap.object_added", + FT_BOOLEAN, 32, TFS(&isns_scn_bitmap_object_added), 0x0008, /* bit 28 */ + "Object Added",HFILL } + }, + { &hf_isns_scn_bitmap_object_updated, + { "Object Updated","isns.scn_bitmap.object_updated", + FT_BOOLEAN, 32, TFS(&isns_scn_bitmap_object_updated), 0x0004, /* bit 29 */ + "Object Updated",HFILL } + }, + { &hf_isns_scn_bitmap_dd_dds_member_removed, + { "DD/DDS Member Removed (Mgmt Reg/SCN only)","isns.scn_bitmap.dd_dds_member_removed", + FT_BOOLEAN, 32, TFS(&isns_scn_bitmap_dd_dds_member_removed), 0x0002, /* bit 30 */ + "DD/DDS Member Removed (Mgmt Reg/SCN only)",HFILL } + }, + { &hf_isns_scn_bitmap_dd_dds_member_added, + { "DD/DDS Member Added (Mgmt Reg/SCN only)","isns.scn_bitmap.dd_dds_member_added", + FT_BOOLEAN, 32, TFS(&isns_scn_bitmap_dd_dds_member_added), 0x0001, /* bit 31 */ + "DD/DDS Member Added (Mgmt Reg/SCN only)",HFILL } + }, + + + { &hf_isns_isnt_control, + { "Control ","isns.isnt.control", + FT_BOOLEAN, 32, TFS(&isns_isnt_control), 0x0004, /* bit 29 */ + "Control",HFILL } + }, + { &hf_isns_isnt_initiator, + { "Initiator ","isns.isnt.initiator", + FT_BOOLEAN, 32, TFS(&isns_isnt_initiator), 0x0002, /* bit 30 */ + "Initiator",HFILL } + }, + { &hf_isns_isnt_target, + { "Target ","isns.isnt.target", + FT_BOOLEAN, 32, TFS(&isns_isnt_target), 0x0001, /* bit 31 */ + "Target",HFILL } + }, + + + { &hf_isns_resp_errorcode, + { "ErrorCode","isns.errorcode", + FT_UINT32, BASE_DEC,TFS(isns_errorcode),0, + "iSNS Response Error Code" ,HFILL} + }, + + { &hf_isns_attr_tag, + { "Attribute Tag","isns.attr.tag", + FT_UINT32, BASE_DEC,TFS(isns_attribute_tags),0, + "iSNS Attribute Tag" ,HFILL} + }, + + { &hf_isns_attr_len, + { "Attribute Length","isns.attr.len", + FT_UINT32, BASE_DEC,NULL,0, + "iSNS Attribute Length" ,HFILL} + }, + + { &hf_isns_delimiter, + { "Delimiter","isns.delimiter", + FT_NONE, BASE_NONE, NULL,0, + "iSNS Delimiter" ,HFILL} + }, + + { &hf_isns_not_decoded_yet, + { "Not Decoded Yet","isns.not_decoded_yet", + FT_NONE, BASE_NONE, NULL,0, + "This tag is not yet decoded by ethereal" ,HFILL} + }, + + { &hf_isns_heartbeat_ipv6_addr, + { "Heartbeat Address (ipv6)","isns.heartbeat.address", + FT_IPv6, BASE_NONE, NULL, 0x0, + "Server IPv6 Address", HFILL }}, + + { &hf_isns_heartbeat_tcp_port, + { "Heartbeat TCP Port","isns.heartbeat.tcpport", + FT_UINT16, BASE_DEC, NULL, 0x0, + "Server TCP Port", HFILL }}, + + { &hf_isns_heartbeat_udp_port, + { "Heartbeat UDP Port","isns.heartbeat.udpport", + FT_UINT16, BASE_DEC, NULL, 0x0, + "Server UDP Port", HFILL }}, + + + { &hf_isns_heartbeat_interval, + { "Heartbeat Interval (secs)","isns.heartbeat.interval", + FT_UINT32, BASE_DEC, NULL, 0x0, + "Server Heartbeat interval", HFILL }}, + + { &hf_isns_heartbeat_counter, + { "Heartbeat counter","isns.heartbeat.counter", + FT_UINT32, BASE_DEC, NULL, 0x0, + "Server Heartbeat Counter", HFILL }}, + + { &hf_isns_iscsi_name, + { "iSCSI Name","isns.iscsi_name", + FT_STRING, BASE_NONE, NULL, 0x0, + "iSCSI Name of device", HFILL }}, + + { &hf_isns_dd_member_iscsi_name, + { "DD Member iSCSI Name","isns.dd_member.iscsi_name", + FT_STRING, BASE_NONE, NULL, 0x0, + "DD Member iSCSI Name of device", HFILL }}, + + { &hf_isns_virtual_fabric_id, + { "Virtual Fabric ID","isns.virtual_fabric_id", + FT_STRING, BASE_NONE, NULL, 0x0, + "Virtual fabric ID", HFILL }}, + + { &hf_isns_proxy_iscsi_name, + { "Proxy iSCSI Name","isns.proxy_iscsi_name", + FT_STRING, BASE_NONE, NULL, 0x0, + "Proxy iSCSI Name", HFILL }}, + + { &hf_isns_fc4_descriptor, + { "FC4 Descriptor","isns.fc4_descriptor", + FT_STRING, BASE_NONE, NULL, 0x0, + "FC4 Descriptor of this device", HFILL }}, + + { &hf_isns_iscsi_auth_method, + { "iSCSI Auth Method","isns.iscsi_auth_method", + FT_STRING, BASE_NONE, NULL, 0x0, + "Authentication Method required by this device", HFILL }}, + + { &hf_isns_iscsi_alias, + { "iSCSI Alias","isns.iscsi_alias", + FT_STRING, BASE_NONE, NULL, 0x0, + "iSCSI Alias of device", HFILL }}, + + { &hf_isns_portal_symbolic_name, + { "Portal Symbolic Name","isns.portal.symbolic_name", + FT_STRING, BASE_NONE, NULL, 0x0, + "Symbolic name of this portal", HFILL }}, + + { &hf_isns_dd_set_symbolic_name, + { "DD Set Symbolic Name","isns.dd_set.symbolic_name", + FT_STRING, BASE_NONE, NULL, 0x0, + "Symbolic name of this DD Set", HFILL }}, + + { &hf_isns_dd_symbolic_name, + { "DD Symbolic Name","isns.dd.symbolic_name", + FT_STRING, BASE_NONE, NULL, 0x0, + "Symbolic name of this DD", HFILL }}, + + { &hf_isns_symbolic_port_name, + { "Symbolic Port Name","isns.port.symbolic_name", + FT_STRING, BASE_NONE, NULL, 0x0, + "Symbolic name of this port", HFILL }}, + + { &hf_isns_symbolic_node_name, + { "Symbolic Node Name","isns.node.symbolic_name", + FT_STRING, BASE_NONE, NULL, 0x0, + "Symbolic name of this node", HFILL }}, + + { &hf_isns_entity_identifier, + { "Entity Identifier","isns.entity_identifier", + FT_STRING, BASE_NONE, NULL, 0x0, + "Entity Identifier of this object", HFILL }}, + + { &hf_isns_mgmt_ip_addr, + { "Management IP Address","isns.mgmt.ip_address", + FT_IPv6, BASE_NONE, NULL, 0x0, + "Management IPv4/IPv6 Address", HFILL }}, + + { &hf_isns_node_ip_addr, + { "Node IP Address","isns.node.ip_address", + FT_IPv6, BASE_NONE, NULL, 0x0, + "Node IPv4/IPv6 Address", HFILL }}, + + { &hf_isns_port_ip_addr, + { "Port IP Address","isns.port.ip_address", + FT_IPv6, BASE_NONE, NULL, 0x0, + "Port IPv4/IPv6 Address", HFILL }}, + + { &hf_isns_portal_ip_addr, + { "Portal IP Address","isns.portal.ip_address", + FT_IPv6, BASE_NONE, NULL, 0x0, + "Portal IPv4/IPv6 Address", HFILL }}, + + { &hf_isns_dd_member_portal_ip_addr, + { "DD Member Portal IP Address","isns.dd.member_portal.ip_address", + FT_IPv6, BASE_NONE, NULL, 0x0, + "DD Member Portal IPv4/IPv6 Address", HFILL }}, + + { &hf_isns_pg_portal_ip_addr, + { "PG Portal IP Address","isns.pg_portal.ip_address", + FT_IPv6, BASE_NONE, NULL, 0x0, + "PG Portal IPv4/IPv6 Address", HFILL }}, + + { &hf_isns_dd_id_next_id, + { "DD ID Next ID","isns.index", + FT_UINT32, BASE_DEC, NULL, 0x0, + "DD ID Next ID", HFILL }}, + + { &hf_isns_member_iscsi_index, + { "Member iSCSI Index","isns.member_iscsi_index", + FT_UINT32, BASE_DEC, NULL, 0x0, + "Member iSCSI Index", HFILL }}, + + { &hf_isns_member_portal_index, + { "Member Portal Index","isns.member_portal_index", + FT_UINT32, BASE_DEC, NULL, 0x0, + "Member Portal Index", HFILL }}, + + { &hf_isns_member_ifcp_node, + { "Member iFCP Node","isns.member_ifcp_node", + FT_UINT32, BASE_DEC, NULL, 0x0, + "Member iFCP Node", HFILL }}, + + { &hf_isns_vendor_oui, + { "Vendor OUI","isns.index", + FT_UINT32, BASE_DEC, NULL, 0x0, + "Vendor OUI", HFILL }}, + + { &hf_isns_preferred_id, + { "Preferred ID","isns.preferred_id", + FT_UINT32, BASE_DEC, NULL, 0x0, + "Preferred ID", HFILL }}, + + { &hf_isns_dd_set_id, + { "DD Set ID","isns.dd_set_id", + FT_UINT32, BASE_DEC, NULL, 0x0, + "DD Set ID", HFILL }}, + + { &hf_isns_dd_id, + { "DD ID","isns.dd_id", + FT_UINT32, BASE_DEC, NULL, 0x0, + "DD ID", HFILL }}, + + { &hf_isns_port_id, + { "Port ID","isns.port_id", + FT_UINT24, BASE_HEX, NULL, 0x0, + "Port ID", HFILL }}, + + { &hf_isns_hard_address, + { "Hard Address","isns.hard_address", + FT_UINT24, BASE_HEX, NULL, 0x0, + "Hard Address", HFILL }}, + + { &hf_isns_wwnn_token, + { "WWNN Token","isns.wwnn_token", + FT_UINT64, BASE_HEX, NULL, 0x0, + "WWNN Token", HFILL }}, + + { &hf_isns_fc_port_name_wwpn, + { "FC Port Name WWPN","isns.fc_port_name_wwpn", + FT_UINT64, BASE_HEX, NULL, 0x0, + "FC Port Name WWPN", HFILL }}, + + { &hf_isns_fc_node_name_wwnn, + { "FC Node Name WWNN","isns.fc_node_name_wwnn", + FT_UINT64, BASE_HEX, NULL, 0x0, + "FC Node Name WWNN", HFILL }}, + + { &hf_isns_node_ipa, + { "Node IPA","isns.node_ipa", + FT_UINT64, BASE_HEX, NULL, 0x0, + "Node IPA", HFILL }}, + + { &hf_isns_fabric_port_name, + { "Fabric Port Name","isns.fabric_port_name", + FT_UINT64, BASE_HEX, NULL, 0x0, + "Fabric Port Name", HFILL }}, + + { &hf_isns_permanent_port_name, + { "Permanent Port Name","isns.permanent_port_name", + FT_UINT64, BASE_HEX, NULL, 0x0, + "Permanent Port Name", HFILL }}, + + { &hf_isns_switch_name, + { "Switch Name","isns.switch_name", + FT_UINT64, BASE_HEX, NULL, 0x0, + "Switch Name", HFILL }}, + + { &hf_isns_dd_set_next_id, + { "DD Set Next ID","isns.dd_set_next_id", + FT_UINT32, BASE_DEC, NULL, 0x0, + "DD Set Next ID", HFILL }}, + + { &hf_isns_assigned_id, + { "Assigned ID","isns.assigned_id", + FT_UINT32, BASE_DEC, NULL, 0x0, + "Assigned ID", HFILL }}, + + { &hf_isns_node_index, + { "Node Index","isns.node.index", + FT_UINT32, BASE_DEC, NULL, 0x0, + "Node Index", HFILL }}, + + { &hf_isns_node_next_index, + { "Node Next Index","isns.node.next_index", + FT_UINT32, BASE_DEC, NULL, 0x0, + "Node INext ndex", HFILL }}, + + { &hf_isns_portal_index, + { "Portal Index","isns.portal.index", + FT_UINT32, BASE_DEC, NULL, 0x0, + "Portal Index", HFILL }}, + + { &hf_isns_portal_next_index, + { "Portal Next Index","isns.portal.next_index", + FT_UINT32, BASE_DEC, NULL, 0x0, + "Portal Next Index", HFILL }}, + + { &hf_isns_entity_index, + { "Entity Index","isns.entity.index", + FT_UINT32, BASE_DEC, NULL, 0x0, + "Entity Index", HFILL }}, + + { &hf_isns_entity_next_index, + { "Entity Next Index","isns.entity.next_index", + FT_UINT32, BASE_DEC, NULL, 0x0, + "Next Entity Index", HFILL }}, + + { &hf_isns_timestamp, + { "Timestamp","isns.timestamp", + FT_UINT64, BASE_DEC, NULL, 0x0, + "Timestamp in Seconds", HFILL }}, + + { &hf_isns_esi_interval, + { "ESI Interval","isns.esi_interval", + FT_UINT32, BASE_DEC, NULL, 0x0, + "ESI Interval in Seconds", HFILL }}, + + { &hf_isns_registration_period, + { "Registration Period","isns.registration_period", + FT_UINT32, BASE_DEC, NULL, 0x0, + "Registration Period in Seconds", HFILL }}, + + { &hf_isns_portal_group_tag, + { "PG Tag","isns.portal_group_tag", + FT_UINT32, BASE_DEC, NULL, 0x0, + "Portal Group Tag", HFILL }}, + + { &hf_isns_payload, + { "Payload", "isns.payload", + FT_BYTES, BASE_HEX, NULL, 0, + "Payload" ,HFILL} + } + }; + +/* Setup protocol subtree array */ + static gint *ett[] = { + &ett_isns, + &ett_isns_flags, + &ett_isns_payload, + &ett_isns_attribute, + &ett_isns_port, + &ett_isns_isnt + }; + module_t *isns_module; + +/* Register the protocol name and description */ + proto_isns = proto_register_protocol("iSNS", + "iSNS", "isns"); + proto_register_field_array(proto_isns, hf, array_length(hf)); + proto_register_subtree_array(ett, array_length(ett)); + + /* Register preferences */ + isns_module = prefs_register_protocol(proto_isns, NULL); + prefs_register_bool_preference(isns_module, "desegment", + "Desegment iSNS over TCP messages", + "Whether the dissector should desegment " + "multi-segment iSNS messages", &isns_desegment); + +} + +/* If this dissector uses sub-dissector registration add a registration routine. + This format is required because a script is used to find these routines and + create the code that calls these routines. +*/ + +void +proto_reg_handoff_isns(void) +{ + isns_tcp_handle = create_dissector_handle(dissect_isns_tcp,proto_isns); + isns_udp_handle = create_dissector_handle(dissect_isns_udp,proto_isns); + + dissector_add("tcp.port",ISNS_TCP_PORT,isns_tcp_handle); + dissector_add("udp.port",ISNS_UDP_PORT,isns_udp_handle); +} |