blob: dc4f220c8504e7a50bef08582a81c631954f1dff (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
|
/* packet-fcswils.h
* Fibre Channel Switch InterLink Services Definitions
* Copyright 2001 Dinesh G Dutt (ddutt@cisco.com)
*
* Wireshark - Network traffic analyzer
* By Gerald Combs <gerald@wireshark.org>
* Copyright 1998 Gerald Combs
*
* SPDX-License-Identifier: GPL-2.0-or-later
*/
#ifndef __PACKET_FCSWILS_H_
#define __PACKET_FCSWILS_H_
/* Command codes */
#define FC_SWILS_SWRJT 0x01
#define FC_SWILS_SWACC 0x02
#define FC_SWILS_ELP 0x10
#define FC_SWILS_EFP 0x11
#define FC_SWILS_DIA 0x12
#define FC_SWILS_RDI 0x13
#define FC_SWILS_HLO 0x14
#define FC_SWILS_LSU 0x15
#define FC_SWILS_LSA 0x16
#define FC_SWILS_BF 0x17
#define FC_SWILS_RCF 0x18
#define FC_SWILS_RSCN 0x1B
#define FC_SWILS_DRLIR 0x1E
#define FC_SWILS_DSCN 0x20
#define FC_SWILS_LOOPD 0x21
#define FC_SWILS_MR 0x22
#define FC_SWILS_ACA 0x23
#define FC_SWILS_RCA 0x24
#define FC_SWILS_SFC 0x25
#define FC_SWILS_UFC 0x26
#define FC_SWILS_ESC 0x30
#define FC_SWILS_ESS 0x31
#define FC_SWILS_MRRA 0x34
#define FC_SWILS_AUTH_ILS 0x40
#define FC_SWILS_MAXCODE 0x35 /* the dissector jump table is sized to
this table */
/* Reject reason codes */
#define FC_SWILS_RJT_INVCODE 0x01
#define FC_SWILS_RJT_INVVER 0x02
#define FC_SWILS_RJT_LOGERR 0x03
#define FC_SWILS_RJT_INVSIZE 0x04
#define FC_SWILS_RJT_LOGBSY 0x05
#define FC_SWILS_RJT_PROTERR 0x07
#define FC_SWILS_RJT_GENFAIL 0x09
#define FC_SWILS_RJT_CMDNOTSUPP 0x0B
#define FC_SWILS_RJT_VENDUNIQ 0xFF
/* Detailed reason code defines */
#define FC_SWILS_RJT_NODET 0x0
#define FC_SWILS_RJT_CLSF_ERR 0x1
#define FC_SWILS_RJT_CLSN_ERR 0x3
#define FC_SWILS_RJT_INVFC_CODE 0x4
#define FC_SWILS_RJT_INVFC_PARM 0x5
#define FC_SWILS_RJT_INV_PNAME 0xD
#define FC_SWILS_RJT_INV_SNAME 0xE
#define FC_SWILS_RJT_TOV_MSMTCH 0xF
#define FC_SWILS_RJT_INV_DIDLST 0x10
#define FC_SWILS_RJT_CMD_INPROG 0x19
#define FC_SWILS_RJT_OORSRC 0x29
#define FC_SWILS_RJT_NO_DID 0x2A
#define FC_SWILS_RJT_INV_DID 0x2B
#define FC_SWILS_RJT_NO_REQ 0x2C
#define FC_SWILS_RJT_NOLNK_PARM 0x2D
#define FC_SWILS_RJT_NO_REQDID 0x2E
#define FC_SWILS_RJT_EP_ISOL 0x2F
typedef struct _fcswils_elp {
uint8_t revision;
uint8_t flags[2];
uint8_t rsvd1;
uint32_t r_a_tov;
uint32_t e_d_tov;
uint8_t req_epname[8];
uint8_t req_sname[8];
uint8_t clsf_svcparm[6];
uint16_t clsf_rcvsize;
uint16_t clsf_conseq;
uint16_t clsf_e2e;
uint16_t clsf_openseq;
uint16_t rsvd;
uint8_t cls1_svcparm[2];
uint16_t cls1_rcvsize;
uint8_t cls2_svcparm[2];
uint16_t cls2_rcvsize;
uint8_t cls3_svcparm[2];
uint16_t cls3_rcvsize;
uint8_t rsvd2[20];
uint16_t isl_flwctrl_mode;
uint16_t flw_ctrl_parmlen;
uint32_t b2b_credit;
uint32_t compat_p1;
uint32_t compat_p2;
uint32_t compat_p3;
uint32_t compat_p4;
} fcswils_elp;
#define FC_SWILS_ELP_SIZE 100
#define FC_SWILS_ELP_FC_VENDOR 0x1
#define FC_SWILS_ELP_FC_RRDY 0x2
struct _fcswils_efp_didrec {
uint8_t rec_type;
uint8_t dom_id;
uint16_t rsvd1;
uint32_t rsvd2;
uint8_t sname[8];
};
struct _fcswils_efp_mcastrec {
uint8_t rec_type;
uint8_t mcast_grpnum;
uint8_t rsvd[14];
};
typedef union _fcswils_efp_listrec {
struct _fcswils_efp_didrec didrec;
struct _fcswils_efp_mcastrec mcastrec;
} fcswils_efp_listrec;
#define FC_SWILS_LRECTYPE_DOMAIN 0x1
#define FC_SWILS_LRECTYPE_MCAST 0x2
typedef struct _fcswils_efp {
uint8_t opcode;
uint8_t reclen;
uint16_t payload_len;
uint8_t rsvd1[3];
uint8_t pswitch_prio;
uint8_t pswitch_name[8];
} fcswils_efp;
#define FC_SWILS_EFP_SIZE 16
typedef struct _fcswils_dia {
uint8_t switch_name[8];
uint8_t rsvd[4];
} fcswils_dia;
typedef struct _fcswils_rdi_req {
uint8_t rsvd[3];
uint8_t domain_id;
} fcswils_rdi_req;
#define FC_SWILS_RDIREQ_SIZE 4
#define FC_SWILS_LSR_SLR 0x1 /* switch link record */
#define FC_SWILS_LSR_ARS 0x2 /* AR Summary record */
#define FC_SWILS_PDESC_FSPF_BB 0x01
#define FC_SWILS_PDESC_FSPF 0x02
#define FC_SWILS_ZONEOBJ_ZONESET 1
#define FC_SWILS_ZONEOBJ_ZONE 2
#define FC_SWILS_ZONEOBJ_ZONEALIAS 3
#define FC_SWILS_ZONEMBR_WWN 1
#define FC_SWILS_ZONEMBR_DP 2
#define FC_SWILS_ZONEMBR_FCID 3
#define FC_SWILS_ZONEMBR_ALIAS 4
#define FC_SWILS_ZONEMBR_WWN_LUN 0xE1
#define FC_SWILS_ZONEMBR_DP_LUN 0xE2
#define FC_SWILS_ZONEMBR_FCID_LUN 0xE3
extern const value_string fc_swils_zonembr_type_val[];
#endif
|