enic.h 5.3 KB
Newer Older
1
/*
V
Vasanthy Kolluri 已提交
2
 * Copyright 2008-2010 Cisco Systems, Inc.  All rights reserved.
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
 * Copyright 2007 Nuova Systems, Inc.  All rights reserved.
 *
 * This program is free software; you may redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; version 2 of the License.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
 * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
 * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
 * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
 * SOFTWARE.
 *
 */

#ifndef _ENIC_H_
#define _ENIC_H_

#include "vnic_enet.h"
#include "vnic_dev.h"
#include "vnic_wq.h"
#include "vnic_rq.h"
#include "vnic_cq.h"
#include "vnic_intr.h"
#include "vnic_stats.h"
30
#include "vnic_nic.h"
31
#include "vnic_rss.h"
32
#include <linux/irq.h>
33 34

#define DRV_NAME		"enic"
35
#define DRV_DESCRIPTION		"Cisco VIC Ethernet NIC Driver"
36
#define DRV_VERSION		"2.1.1.50"
37
#define DRV_COPYRIGHT		"Copyright 2008-2013 Cisco Systems, Inc"
38

39 40
#define ENIC_BARS_MAX		6

41
#define ENIC_WQ_MAX		8
42
#define ENIC_RQ_MAX		8
43 44 45
#define ENIC_CQ_MAX		(ENIC_WQ_MAX + ENIC_RQ_MAX)
#define ENIC_INTR_MAX		(ENIC_CQ_MAX + 2)

46 47
#define ENIC_AIC_LARGE_PKT_DIFF	3

48 49 50 51 52 53 54
struct enic_msix_entry {
	int requested;
	char devname[IFNAMSIZ];
	irqreturn_t (*isr)(int, void *);
	void *devid;
};

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
/* Store only the lower range.  Higher range is given by fw. */
struct enic_intr_mod_range {
	u32 small_pkt_range_start;
	u32 large_pkt_range_start;
};

struct enic_intr_mod_table {
	u32 rx_rate;
	u32 range_percent;
};

#define ENIC_MAX_LINK_SPEEDS		3
#define ENIC_LINK_SPEED_10G		10000
#define ENIC_LINK_SPEED_4G		4000
#define ENIC_LINK_40G_INDEX		2
#define ENIC_LINK_10G_INDEX		1
#define ENIC_LINK_4G_INDEX		0
#define ENIC_RX_COALESCE_RANGE_END	125
#define ENIC_AIC_TS_BREAK		100

struct enic_rx_coal {
	u32 small_pkt_range_start;
	u32 large_pkt_range_start;
	u32 range_end;
	u32 use_adaptive_rx_coalesce;
};

R
Roopa Prabhu 已提交
82 83 84 85
/* priv_flags */
#define ENIC_SRIOV_ENABLED		(1 << 0)

/* enic port profile set flags */
86
#define ENIC_PORT_REQUEST_APPLIED	(1 << 0)
87 88 89 90 91
#define ENIC_SET_REQUEST		(1 << 1)
#define ENIC_SET_NAME			(1 << 2)
#define ENIC_SET_INSTANCE		(1 << 3)
#define ENIC_SET_HOST			(1 << 4)

92
struct enic_port_profile {
93
	u32 set;
94 95 96 97
	u8 request;
	char name[PORT_PROFILE_MAX];
	u8 instance_uuid[PORT_UUID_MAX];
	u8 host_uuid[PORT_UUID_MAX];
98
	u8 vf_mac[ETH_ALEN];
99
	u8 mac_addr[ETH_ALEN];
100 101
};

102 103 104 105 106
/* Per-instance private data structure */
struct enic {
	struct net_device *netdev;
	struct pci_dev *pdev;
	struct vnic_enet_config config;
107
	struct vnic_dev_bar bar[ENIC_BARS_MAX];
108 109 110
	struct vnic_dev *vdev;
	struct timer_list notify_timer;
	struct work_struct reset;
111
	struct work_struct change_mtu_work;
112 113
	struct msix_entry msix_entry[ENIC_INTR_MAX];
	struct enic_msix_entry msix[ENIC_INTR_MAX];
114 115 116
	u32 msg_enable;
	spinlock_t devcmd_lock;
	u8 mac_addr[ETH_ALEN];
117
	unsigned int flags;
R
Roopa Prabhu 已提交
118
	unsigned int priv_flags;
119
	unsigned int mc_count;
120
	unsigned int uc_count;
121
	u32 port_mtu;
122
	struct enic_rx_coal rx_coalesce_setting;
123 124
	u32 rx_coalesce_usecs;
	u32 tx_coalesce_usecs;
R
Roopa Prabhu 已提交
125
#ifdef CONFIG_PCI_IOV
126
	u16 num_vfs;
R
Roopa Prabhu 已提交
127
#endif
128
	spinlock_t enic_api_lock;
129
	struct enic_port_profile *pp;
130 131

	/* work queue cache line section */
132 133
	____cacheline_aligned struct vnic_wq wq[ENIC_WQ_MAX];
	spinlock_t wq_lock[ENIC_WQ_MAX];
134
	unsigned int wq_count;
135 136
	u16 loop_enable;
	u16 loop_tag;
137 138

	/* receive queue cache line section */
139
	____cacheline_aligned struct vnic_rq rq[ENIC_RQ_MAX];
140
	unsigned int rq_count;
141
	u64 rq_truncated_pkts;
142
	u64 rq_bad_fcs;
143
	struct napi_struct napi[ENIC_RQ_MAX];
144 145

	/* interrupt resource cache line section */
146
	____cacheline_aligned struct vnic_intr intr[ENIC_INTR_MAX];
147 148 149 150 151 152 153 154
	unsigned int intr_count;
	u32 __iomem *legacy_pba;		/* memory-mapped */

	/* completion queue cache line section */
	____cacheline_aligned struct vnic_cq cq[ENIC_CQ_MAX];
	unsigned int cq_count;
};

155 156 157 158 159
static inline struct device *enic_get_dev(struct enic *enic)
{
	return &(enic->pdev->dev);
}

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
static inline unsigned int enic_cq_rq(struct enic *enic, unsigned int rq)
{
	return rq;
}

static inline unsigned int enic_cq_wq(struct enic *enic, unsigned int wq)
{
	return enic->rq_count + wq;
}

static inline unsigned int enic_legacy_io_intr(void)
{
	return 0;
}

static inline unsigned int enic_legacy_err_intr(void)
{
	return 1;
}

static inline unsigned int enic_legacy_notify_intr(void)
{
	return 2;
}

static inline unsigned int enic_msix_rq_intr(struct enic *enic,
	unsigned int rq)
{
	return enic->cq[enic_cq_rq(enic, rq)].interrupt_offset;
}

static inline unsigned int enic_msix_wq_intr(struct enic *enic,
	unsigned int wq)
{
	return enic->cq[enic_cq_wq(enic, wq)].interrupt_offset;
}

static inline unsigned int enic_msix_err_intr(struct enic *enic)
{
	return enic->rq_count + enic->wq_count;
}

static inline unsigned int enic_msix_notify_intr(struct enic *enic)
{
	return enic->rq_count + enic->wq_count + 1;
}

207
void enic_reset_addr_lists(struct enic *enic);
R
Roopa Prabhu 已提交
208
int enic_sriov_enabled(struct enic *enic);
209
int enic_is_valid_vf(struct enic *enic, int vf);
210
int enic_is_dynamic(struct enic *enic);
211
void enic_set_ethtool_ops(struct net_device *netdev);
212

213
#endif /* _ENIC_H_ */