[SCSI] fcoe: move netdev to fcoe_interface
[linux-2.6-block.git] / drivers / scsi / fcoe / fcoe.h
CommitLineData
fdd78027
VD
1/*
2 * Copyright(c) 2009 Intel Corporation. All rights reserved.
3 *
4 * This program is free software; you can redistribute it and/or modify it
5 * under the terms and conditions of the GNU General Public License,
6 * version 2, as published by the Free Software Foundation.
7 *
8 * This program is distributed in the hope it will be useful, but WITHOUT
9 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
10 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
11 * more details.
12 *
13 * You should have received a copy of the GNU General Public License along with
14 * this program; if not, write to the Free Software Foundation, Inc.,
15 * 51 Franklin St - Fifth Floor, Boston, MA 02110-1301 USA.
16 *
17 * Maintained at www.Open-FCoE.org
18 */
19
20#ifndef _FCOE_H_
21#define _FCOE_H_
22
23#include <linux/skbuff.h>
24#include <linux/kthread.h>
25
26#define FCOE_MAX_QUEUE_DEPTH 256
27#define FCOE_LOW_QUEUE_DEPTH 32
28
fdd78027
VD
29#define FCOE_WORD_TO_BYTE 4
30
31#define FCOE_VERSION "0.1"
32#define FCOE_NAME "fcoe"
33#define FCOE_VENDOR "Open-FCoE.org"
34
35#define FCOE_MAX_LUN 255
36#define FCOE_MAX_FCP_TARGET 256
37
38#define FCOE_MAX_OUTSTANDING_COMMANDS 1024
39
d7179680 40#define FCOE_MIN_XID 0x0000 /* the min xid supported by fcoe_sw */
e4bc50be 41#define FCOE_MAX_XID 0x0FFF /* the max xid supported by fcoe_sw */
fdd78027 42
d5488eb9
RL
43unsigned int fcoe_debug_logging;
44module_param_named(debug_logging, fcoe_debug_logging, int, S_IRUGO|S_IWUSR);
45MODULE_PARM_DESC(debug_logging, "a bit mask of logging levels");
46
47#define FCOE_LOGGING 0x01 /* General logging, not categorized */
48#define FCOE_NETDEV_LOGGING 0x02 /* Netdevice logging */
49
50#define FCOE_CHECK_LOGGING(LEVEL, CMD) \
51do { \
52 if (unlikely(fcoe_debug_logging & LEVEL)) \
53 do { \
54 CMD; \
55 } while (0); \
a69b06bc 56} while (0)
d5488eb9
RL
57
58#define FCOE_DBG(fmt, args...) \
59 FCOE_CHECK_LOGGING(FCOE_LOGGING, \
60 printk(KERN_INFO "fcoe: " fmt, ##args);)
61
62#define FCOE_NETDEV_DBG(netdev, fmt, args...) \
63 FCOE_CHECK_LOGGING(FCOE_NETDEV_LOGGING, \
ee610c67 64 printk(KERN_INFO "fcoe: %s: " fmt, \
d5488eb9
RL
65 netdev->name, ##args);)
66
fdd78027
VD
67/*
68 * this percpu struct for fcoe
69 */
70struct fcoe_percpu_s {
71 struct task_struct *thread;
72 struct sk_buff_head fcoe_rx_list;
73 struct page *crc_eof_page;
74 int crc_eof_offset;
75};
76
77/*
014f5c3f 78 * an FCoE interface, 1:1 with netdev
fdd78027 79 */
014f5c3f 80struct fcoe_interface {
fdd78027 81 struct list_head list;
014f5c3f
CL
82 /* This will be removed once all the shared values are
83 * moved out of fcoe_port */
84 struct fcoe_port *priv;
25024989 85 struct net_device *netdev;
014f5c3f
CL
86};
87
88/*
89 * the FCoE private structure that's allocated along with the
90 * Scsi_Host and libfc fc_lport structures
91 */
92struct fcoe_port {
93 struct fcoe_interface *fcoe;
d7179680 94 struct fc_exch_mgr *oem; /* offload exchange manger */
fdd78027 95 struct packet_type fcoe_packet_type;
97c8389d 96 struct packet_type fip_packet_type;
fdd78027
VD
97 struct sk_buff_head fcoe_pending_queue;
98 u8 fcoe_pending_queue_active;
1047f221 99 struct timer_list timer; /* queue timer */
97c8389d 100 struct fcoe_ctlr ctlr;
fdd78027
VD
101};
102
25024989 103#define fcoe_from_ctlr(fip) container_of(fip, struct fcoe_port, ctlr)
97c8389d 104
25024989 105static inline struct net_device *fcoe_netdev(const struct fc_lport *lp)
fdd78027 106{
25024989 107 return ((struct fcoe_port *)lport_priv(lp))->fcoe->netdev;
fdd78027
VD
108}
109
110#endif /* _FCOE_H_ */