Linux Kernel  3.7.1
 All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Macros Groups Pages
libfcoe.h
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2008-2009 Cisco Systems, Inc. All rights reserved.
3  * Copyright (c) 2007-2008 Intel Corporation. All rights reserved.
4  *
5  * This program is free software; you can redistribute it and/or modify it
6  * under the terms and conditions of the GNU General Public License,
7  * version 2, as published by the Free Software Foundation.
8  *
9  * This program is distributed in the hope it will be useful, but WITHOUT
10  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
12  * more details.
13  *
14  * You should have received a copy of the GNU General Public License along with
15  * this program; if not, write to the Free Software Foundation, Inc.,
16  * 51 Franklin St - Fifth Floor, Boston, MA 02110-1301 USA.
17  *
18  * Maintained at www.Open-FCoE.org
19  */
20 
21 #ifndef _LIBFCOE_H
22 #define _LIBFCOE_H
23 
24 #include <linux/etherdevice.h>
25 #include <linux/if_ether.h>
26 #include <linux/netdevice.h>
27 #include <linux/skbuff.h>
28 #include <linux/workqueue.h>
29 #include <linux/random.h>
30 #include <scsi/fc/fc_fcoe.h>
31 #include <scsi/libfc.h>
32 #include <scsi/fcoe_sysfs.h>
33 
34 #define FCOE_MAX_CMD_LEN 16 /* Supported CDB length */
35 
36 /*
37  * Max MTU for FCoE: 14 (FCoE header) + 24 (FC header) + 2112 (max FC payload)
38  * + 4 (FC CRC) + 4 (FCoE trailer) = 2158 bytes
39  */
40 #define FCOE_MTU 2158
41 
42 /*
43  * FIP tunable parameters.
44  */
45 #define FCOE_CTLR_START_DELAY 2000 /* mS after first adv. to choose FCF */
46 #define FCOE_CTRL_SOL_TOV 2000 /* min. solicitation interval (mS) */
47 #define FCOE_CTLR_FCF_LIMIT 20 /* max. number of FCF entries */
48 #define FCOE_CTLR_VN2VN_LOGIN_LIMIT 3 /* max. VN2VN rport login retries */
49 
63 enum fip_state {
74 };
75 
76 /*
77  * Modes:
78  * The mode is the state that is to be entered after link up.
79  * It must not change after fcoe_ctlr_init() sets it.
80  */
81 #define FIP_MODE_AUTO FIP_ST_AUTO
82 #define FIP_MODE_NON_FIP FIP_ST_NON_FIP
83 #define FIP_MODE_FABRIC FIP_ST_ENABLED
84 #define FIP_MODE_VN2VN FIP_ST_VNMP_START
85 
124 struct fcoe_ctlr {
127  struct fc_lport *lp;
128  struct fcoe_fcf *sel_fcf;
129  struct list_head fcfs;
131  unsigned long sol_time;
132  unsigned long sel_time;
133  unsigned long port_ka_time;
134  unsigned long ctlr_ka_time;
140 
143 
154 
155  void (*send)(struct fcoe_ctlr *, struct sk_buff *);
156  void (*update_mac)(struct fc_lport *, u8 *addr);
157  u8 * (*get_src_addr)(struct fc_lport *);
160 };
161 
166 static inline void *fcoe_ctlr_priv(const struct fcoe_ctlr *ctlr)
167 {
168  return (void *)(ctlr + 1);
169 }
170 
171 #define fcoe_ctlr_to_ctlr_dev(x) \
172  (struct fcoe_ctlr_device *)(((struct fcoe_ctlr_device *)(x)) - 1)
173 
200 struct fcoe_fcf {
201  struct list_head list;
203  struct fcoe_ctlr *fip;
205  unsigned long time;
206 
213 
219 };
220 
221 #define fcoe_fcf_to_fcf_dev(x) \
222  ((x)->fcf_dev)
223 
233 struct fcoe_rport {
234  unsigned long time;
240 };
241 
242 /* FIP API functions */
243 void fcoe_ctlr_init(struct fcoe_ctlr *, enum fip_state);
244 void fcoe_ctlr_destroy(struct fcoe_ctlr *);
245 void fcoe_ctlr_link_up(struct fcoe_ctlr *);
246 int fcoe_ctlr_link_down(struct fcoe_ctlr *);
247 int fcoe_ctlr_els_send(struct fcoe_ctlr *, struct fc_lport *, struct sk_buff *);
248 void fcoe_ctlr_recv(struct fcoe_ctlr *, struct sk_buff *);
249 int fcoe_ctlr_recv_flogi(struct fcoe_ctlr *, struct fc_lport *,
250  struct fc_frame *);
251 
252 /* libfcoe funcs */
253 u64 fcoe_wwn_from_mac(unsigned char mac[], unsigned int, unsigned int);
254 int fcoe_libfc_config(struct fc_lport *, struct fcoe_ctlr *,
255  const struct libfc_function_template *, int init_fcp);
256 u32 fcoe_fc_crc(struct fc_frame *fp);
257 int fcoe_start_io(struct sk_buff *skb);
258 int fcoe_get_wwn(struct net_device *netdev, u64 *wwn, int type);
259 void __fcoe_get_lesb(struct fc_lport *lport, struct fc_els_lesb *fc_lesb,
260  struct net_device *netdev);
261 void fcoe_wwn_to_str(u64 wwn, char *buf, int len);
263 
268 static inline bool is_fip_mode(struct fcoe_ctlr *fip)
269 {
270  return fip->state == FIP_ST_ENABLED;
271 }
272 
273 /* helper for FCoE SW HBA drivers, can include subven and subdev if needed. The
274  * modpost would use pci_device_id table to auto-generate formatted module alias
275  * into the corresponding .mod.c file, but there may or may not be a pci device
276  * id table for FCoE drivers so we use the following helper for build the fcoe
277  * driver module alias.
278  */
279 #define MODULE_ALIAS_FCOE_PCI(ven, dev) \
280  MODULE_ALIAS("fcoe-pci:" \
281  "v" __stringify(ven) \
282  "d" __stringify(dev) "sv*sd*bc*sc*i*")
283 
284 /* the name of the default FCoE transport driver fcoe.ko */
285 #define FCOE_TRANSPORT_DEFAULT "fcoe"
286 
287 /* struct fcoe_transport - The FCoE transport interface
288  * @name: a vendor specific name for their FCoE transport driver
289  * @attached: whether this transport is already attached
290  * @list: list linkage to all attached transports
291  * @match: handler to allow the transport driver to match up a given netdev
292  * @create: handler to sysfs entry of create for FCoE instances
293  * @destroy: handler to sysfs entry of destroy for FCoE instances
294  * @enable: handler to sysfs entry of enable for FCoE instances
295  * @disable: handler to sysfs entry of disable for FCoE instances
296  */
298  char name[IFNAMSIZ];
299  bool attached;
300  struct list_head list;
301  bool (*match) (struct net_device *device);
302  int (*create) (struct net_device *device, enum fip_state fip_mode);
303  int (*destroy) (struct net_device *device);
304  int (*enable) (struct net_device *device);
305  int (*disable) (struct net_device *device);
306 };
307 
321 };
322 
340 struct fcoe_port {
341  void *priv;
342  struct fc_lport *lport;
350 };
351 void fcoe_clean_pending_queue(struct fc_lport *);
352 void fcoe_check_wait_queue(struct fc_lport *lport, struct sk_buff *skb);
354 int fcoe_get_paged_crc_eof(struct sk_buff *skb, int tlen,
355  struct fcoe_percpu_s *fps);
356 
357 /* FCoE Sysfs helpers */
360 
366  struct list_head list;
369 };
370 
371 /* fcoe transports registration and deregistration */
374 
375 #endif /* _LIBFCOE_H */