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
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
|
/* fc.h: Definitions for Fibre Channel Physical and Signaling Interface.
*
* Copyright (C) 1996,1997 Jakub Jelinek (jj@sunsite.mff.cuni.cz)
*
* Sources:
* Fibre Channel Physical & Signaling Interface (FC-PH), dpANS, 1994
* dpANS Fibre Channel Protocol for SCSI (X3.269-199X), Rev. 012, 1995
*/
#ifndef __FC_H
#define __FC_H
/* World Wide Name */
#define NAAID_IEEE 1
#define NAAID_IEEE_EXT 2
#define NAAID_LOCAL 3
#define NAAID_IP 4
#define NAAID_CCITT 12
#define NAAID_CCITT_GRP 14
typedef struct {
u32 naaid:4;
u32 nportid:12;
u32 hi:16;
u32 lo;
} fc_wwn;
/* Frame header for FC-PH frames */
/* r_ctl field */
#define R_CTL_DEVICE_DATA 0x00 /* FC4 Device_Data frame */
#define R_CTL_EXTENDED_SVC 0x20 /* Extended Link_Data frame */
#define R_CTL_FC4_SVC 0x30 /* FC4 Link_Data frame */
#define R_CTL_VIDEO 0x40 /* Video_Data frame */
#define R_CTL_BASIC_SVC 0x80 /* Basic Link_Data frame */
#define R_CTL_LINK_CTL 0xc0 /* Link_Control frame */
/* FC4 Device_Data frames */
#define R_CTL_UNCATEGORIZED 0x00
#define R_CTL_SOLICITED_DATA 0x01
#define R_CTL_UNSOL_CONTROL 0x02
#define R_CTL_SOLICITED_CONTROL 0x03
#define R_CTL_UNSOL_DATA 0x04
#define R_CTL_XFER_RDY 0x05
#define R_CTL_COMMAND 0x06
#define R_CTL_STATUS 0x07
/* Basic Link_Data frames */
#define R_CTL_LS_NOP 0x80
#define R_CTL_LS_ABTS 0x81
#define R_CTL_LS_RMC 0x82
#define R_CTL_LS_BA_ACC 0x84
#define R_CTL_LS_BA_RJT 0x85
/* Extended Link_Data frames */
#define R_CTL_ELS_REQ 0x22
#define R_CTL_ELS_RSP 0x23
/* Link_Control frames */
#define R_CTL_ACK_1 0xc0
#define R_CTL_ACK_N 0xc1
#define R_CTL_P_RJT 0xc2
#define R_CTL_F_RJT 0xc3
#define R_CTL_P_BSY 0xc4
#define R_CTL_F_BSY_DF 0xc5
#define R_CTL_F_BSY_LC 0xc6
#define R_CTL_LCR 0xc7
/* type field */
#define TYPE_BASIC_LS 0x00
#define TYPE_EXTENDED_LS 0x01
#define TYPE_IS8802 0x04
#define TYPE_IS8802_SNAP 0x05
#define TYPE_SCSI_FCP 0x08
#define TYPE_SCSI_GPP 0x09
#define TYPE_HIPP_FP 0x0a
#define TYPE_IPI3_MASTER 0x11
#define TYPE_IPI3_SLAVE 0x12
#define TYPE_IPI3_PEER 0x13
/* f_ctl field */
#define F_CTL_FILL_BYTES 0x000003
#define F_CTL_XCHG_REASSEMBLE 0x000004
#define F_CTL_RO_PRESENT 0x000008
#define F_CTL_ABORT_SEQ 0x000030
#define F_CTL_CONTINUE_SEQ 0x0000c0
#define F_CTL_INVALIDATE_XID 0x004000
#define F_CTL_XID_REASSIGNED 0x008000
#define F_CTL_SEQ_INITIATIVE 0x010000
#define F_CTL_CHAINED_SEQ 0x020000
#define F_CTL_END_CONNECT 0x040000
#define F_CTL_END_SEQ 0x080000
#define F_CTL_LAST_SEQ 0x100000
#define F_CTL_FIRST_SEQ 0x200000
#define F_CTL_SEQ_CONTEXT 0x400000
#define F_CTL_XCHG_CONTEXT 0x800000
typedef struct {
u32 r_ctl:8, did:24;
u32 xxx1:8, sid:24;
u32 type:8, f_ctl:24;
u32 seq_id:8, df_ctl:8, seq_cnt:16;
u16 ox_id, rx_id;
u32 param;
} fc_hdr;
/* The following are ugly macros to make setup of this structure faster */
#define FILL_FCHDR_RCTL_DID(fch, r_ctl, did) *(u32 *)(fch) = ((r_ctl) << 24) | (did);
#define FILL_FCHDR_SID(fch, sid) *((u32 *)(fch)+1) = (sid);
#define FILL_FCHDR_TYPE_FCTL(fch, type, f_ctl) *((u32 *)(fch)+2) = ((type) << 24) | (f_ctl);
#define FILL_FCHDR_SEQ_DF_SEQ(fch, seq_id, df_ctl, seq_cnt) *((u32 *)(fch)+3) = ((seq_id) << 24) | ((df_ctl) << 16) | (seq_cnt);
#define FILL_FCHDR_OXRX(fch, ox_id, rx_id) *((u32 *)(fch)+4) = ((ox_id) << 16) | (rx_id);
/* Well known addresses */
#define FS_GENERAL_MULTICAST 0xfffff7
#define FS_WELL_KNOWN_MULTICAST 0xfffff8
#define FS_HUNT_GROUP 0xfffff9
#define FS_MANAGEMENT_SERVER 0xfffffa
#define FS_TIME_SERVER 0xfffffb
#define FS_NAME_SERVER 0xfffffc
#define FS_FABRIC_CONTROLLER 0xfffffd
#define FS_FABRIC_F_PORT 0xfffffe
#define FS_BROADCAST 0xffffff
/* Reject frames */
/* The param field should be cast to this structure */
typedef struct {
u8 action;
u8 reason;
u8 xxx;
u8 vendor_unique;
} rjt_param;
/* Reject action codes */
#define RJT_RETRY 0x01
#define RJT_NONRETRY 0x02
/* Reject reason codes */
#define RJT_INVALID_DID 0x01
#define RJT_INVALID_SID 0x02
#define RJT_NPORT_NOT_AVAIL_TEMP 0x03
#define RJT_NPORT_NOT_AVAIL_PERM 0x04
#define RJT_CLASS_NOT_SUPPORTED 0x05
#define RJT_DELIMITER_ERROR 0x06
#define RJT_TYPE_NOT_SUPPORTED 0x07
#define RJT_INVALID_LINK_CONTROL 0x08
#define RJT_INVALID_R_CTL 0x09
#define RJT_INVALID_F_CTL 0x0a
#define RJT_INVALID_OX_ID 0x0b
#define RJT_INVALID_RX_ID 0x0c
#define RJT_INVALID_SEQ_ID 0x0d
#define RJT_INVALID_DF_CTL 0x0e
#define RJT_INVALID_SEQ_CNT 0x0f
#define RJT_INVALID_PARAMETER 0x10
#define RJT_EXCHANGE_ERROR 0x11
#define RJT_PROTOCOL_ERROR 0x12
#define RJT_INCORRECT_LENGTH 0x13
#define RJT_UNEXPECTED_ACK 0x14
#define RJT_UNEXPECTED_LINK_RESP 0x15
#define RJT_LOGIN_REQUIRED 0x16
#define RJT_EXCESSIVE_SEQUENCES 0x17
#define RJT_CANT_ESTABLISH_EXCHANGE 0x18
#define RJT_SECURITY_NOT_SUPPORTED 0x19
#define RJT_FABRIC_NA 0x1a
#define RJT_VENDOR_UNIQUE 0xff
#define SP_F_PORT_LOGIN 0x10
/* Extended SVC commands */
#define LS_RJT 0x01000000
#define LS_ACC 0x02000000
#define LS_PLOGI 0x03000000
#define LS_FLOGI 0x04000000
#define LS_LOGO 0x05000000
#define LS_ABTX 0x06000000
#define LS_RCS 0x07000000
#define LS_RES 0x08000000
#define LS_RSS 0x09000000
#define LS_RSI 0x0a000000
#define LS_ESTS 0x0b000000
#define LS_ESTC 0x0c000000
#define LS_ADVC 0x0d000000
#define LS_RTV 0x0e000000
#define LS_RLS 0x0f000000
#define LS_ECHO 0x10000000
#define LS_TEST 0x11000000
#define LS_RRQ 0x12000000
#define LS_IDENT 0x20000000
#define LS_DISPLAY 0x21000000
typedef struct {
u8 fcph_hi, fcph_lo;
u16 buf2buf_credit;
u8 common_features;
u8 xxx1;
u16 buf2buf_size;
u8 xxx2;
u8 total_concurrent;
u16 off_by_info;
u32 e_d_tov;
} common_svc_parm;
typedef struct {
u16 serv_opts;
u16 initiator_ctl;
u16 rcpt_ctl;
u16 recv_size;
u8 xxx1;
u8 concurrent_seqs;
u16 end2end_credit;
u16 open_seqs_per_xchg;
u16 xxx2;
} svc_parm;
/* Login */
typedef struct {
u32 code;
common_svc_parm common;
fc_wwn nport_wwn;
fc_wwn node_wwn;
svc_parm class1;
svc_parm class2;
svc_parm class3;
} logi;
#endif /* !(__FC_H) */
|