diff options
Diffstat (limited to 'drivers/net/benet/be.h')
-rw-r--r-- | drivers/net/benet/be.h | 230 |
1 files changed, 168 insertions, 62 deletions
diff --git a/drivers/net/benet/be.h b/drivers/net/benet/be.h index 53306bf3f401..a7db870d1641 100644 --- a/drivers/net/benet/be.h +++ b/drivers/net/benet/be.h | |||
@@ -1,5 +1,5 @@ | |||
1 | /* | 1 | /* |
2 | * Copyright (C) 2005 - 2010 ServerEngines | 2 | * Copyright (C) 2005 - 2011 Emulex |
3 | * All rights reserved. | 3 | * All rights reserved. |
4 | * | 4 | * |
5 | * This program is free software; you can redistribute it and/or | 5 | * This program is free software; you can redistribute it and/or |
@@ -8,11 +8,11 @@ | |||
8 | * Public License is included in this distribution in the file called COPYING. | 8 | * Public License is included in this distribution in the file called COPYING. |
9 | * | 9 | * |
10 | * Contact Information: | 10 | * Contact Information: |
11 | * linux-drivers@serverengines.com | 11 | * linux-drivers@emulex.com |
12 | * | 12 | * |
13 | * ServerEngines | 13 | * Emulex |
14 | * 209 N. Fair Oaks Ave | 14 | * 3333 Susan Street |
15 | * Sunnyvale, CA 94085 | 15 | * Costa Mesa, CA 92626 |
16 | */ | 16 | */ |
17 | 17 | ||
18 | #ifndef BE_H | 18 | #ifndef BE_H |
@@ -33,19 +33,23 @@ | |||
33 | 33 | ||
34 | #include "be_hw.h" | 34 | #include "be_hw.h" |
35 | 35 | ||
36 | #define DRV_VER "2.103.175u" | 36 | #define DRV_VER "4.0.100u" |
37 | #define DRV_NAME "be2net" | 37 | #define DRV_NAME "be2net" |
38 | #define BE_NAME "ServerEngines BladeEngine2 10Gbps NIC" | 38 | #define BE_NAME "ServerEngines BladeEngine2 10Gbps NIC" |
39 | #define BE3_NAME "ServerEngines BladeEngine3 10Gbps NIC" | 39 | #define BE3_NAME "ServerEngines BladeEngine3 10Gbps NIC" |
40 | #define OC_NAME "Emulex OneConnect 10Gbps NIC" | 40 | #define OC_NAME "Emulex OneConnect 10Gbps NIC" |
41 | #define OC_NAME1 "Emulex OneConnect 10Gbps NIC (be3)" | 41 | #define OC_NAME_BE OC_NAME "(be3)" |
42 | #define OC_NAME_LANCER OC_NAME "(Lancer)" | ||
42 | #define DRV_DESC "ServerEngines BladeEngine 10Gbps NIC Driver" | 43 | #define DRV_DESC "ServerEngines BladeEngine 10Gbps NIC Driver" |
43 | 44 | ||
44 | #define BE_VENDOR_ID 0x19a2 | 45 | #define BE_VENDOR_ID 0x19a2 |
46 | #define EMULEX_VENDOR_ID 0x10df | ||
45 | #define BE_DEVICE_ID1 0x211 | 47 | #define BE_DEVICE_ID1 0x211 |
46 | #define BE_DEVICE_ID2 0x221 | 48 | #define BE_DEVICE_ID2 0x221 |
47 | #define OC_DEVICE_ID1 0x700 | 49 | #define OC_DEVICE_ID1 0x700 /* Device Id for BE2 cards */ |
48 | #define OC_DEVICE_ID2 0x710 | 50 | #define OC_DEVICE_ID2 0x710 /* Device Id for BE3 cards */ |
51 | #define OC_DEVICE_ID3 0xe220 /* Device id for Lancer cards */ | ||
52 | #define OC_DEVICE_ID4 0xe228 /* Device id for VF in Lancer */ | ||
49 | 53 | ||
50 | static inline char *nic_name(struct pci_dev *pdev) | 54 | static inline char *nic_name(struct pci_dev *pdev) |
51 | { | 55 | { |
@@ -53,7 +57,10 @@ static inline char *nic_name(struct pci_dev *pdev) | |||
53 | case OC_DEVICE_ID1: | 57 | case OC_DEVICE_ID1: |
54 | return OC_NAME; | 58 | return OC_NAME; |
55 | case OC_DEVICE_ID2: | 59 | case OC_DEVICE_ID2: |
56 | return OC_NAME1; | 60 | return OC_NAME_BE; |
61 | case OC_DEVICE_ID3: | ||
62 | case OC_DEVICE_ID4: | ||
63 | return OC_NAME_LANCER; | ||
57 | case BE_DEVICE_ID2: | 64 | case BE_DEVICE_ID2: |
58 | return BE3_NAME; | 65 | return BE3_NAME; |
59 | default: | 66 | default: |
@@ -62,7 +69,7 @@ static inline char *nic_name(struct pci_dev *pdev) | |||
62 | } | 69 | } |
63 | 70 | ||
64 | /* Number of bytes of an RX frame that are copied to skb->data */ | 71 | /* Number of bytes of an RX frame that are copied to skb->data */ |
65 | #define BE_HDR_LEN 64 | 72 | #define BE_HDR_LEN ((u16) 64) |
66 | #define BE_MAX_JUMBO_FRAME_SIZE 9018 | 73 | #define BE_MAX_JUMBO_FRAME_SIZE 9018 |
67 | #define BE_MIN_MTU 256 | 74 | #define BE_MIN_MTU 256 |
68 | 75 | ||
@@ -78,14 +85,15 @@ static inline char *nic_name(struct pci_dev *pdev) | |||
78 | #define MCC_Q_LEN 128 /* total size not to exceed 8 pages */ | 85 | #define MCC_Q_LEN 128 /* total size not to exceed 8 pages */ |
79 | #define MCC_CQ_LEN 256 | 86 | #define MCC_CQ_LEN 256 |
80 | 87 | ||
88 | #define MAX_RSS_QS 4 /* BE limit is 4 queues/port */ | ||
89 | #define MAX_RX_QS (MAX_RSS_QS + 1) /* RSS qs + 1 def Rx */ | ||
90 | #define BE_MAX_MSIX_VECTORS (MAX_RX_QS + 1)/* RX + TX */ | ||
81 | #define BE_NAPI_WEIGHT 64 | 91 | #define BE_NAPI_WEIGHT 64 |
82 | #define MAX_RX_POST BE_NAPI_WEIGHT /* Frags posted at a time */ | 92 | #define MAX_RX_POST BE_NAPI_WEIGHT /* Frags posted at a time */ |
83 | #define RX_FRAGS_REFILL_WM (RX_Q_LEN - MAX_RX_POST) | 93 | #define RX_FRAGS_REFILL_WM (RX_Q_LEN - MAX_RX_POST) |
84 | 94 | ||
85 | #define FW_VER_LEN 32 | 95 | #define FW_VER_LEN 32 |
86 | 96 | ||
87 | #define BE_MAX_VF 32 | ||
88 | |||
89 | struct be_dma_mem { | 97 | struct be_dma_mem { |
90 | void *va; | 98 | void *va; |
91 | dma_addr_t dma; | 99 | dma_addr_t dma; |
@@ -147,6 +155,7 @@ struct be_eq_obj { | |||
147 | u16 min_eqd; /* in usecs */ | 155 | u16 min_eqd; /* in usecs */ |
148 | u16 max_eqd; /* in usecs */ | 156 | u16 max_eqd; /* in usecs */ |
149 | u16 cur_eqd; /* in usecs */ | 157 | u16 cur_eqd; /* in usecs */ |
158 | u8 eq_idx; | ||
150 | 159 | ||
151 | struct napi_struct napi; | 160 | struct napi_struct napi; |
152 | }; | 161 | }; |
@@ -157,10 +166,9 @@ struct be_mcc_obj { | |||
157 | bool rearm_cq; | 166 | bool rearm_cq; |
158 | }; | 167 | }; |
159 | 168 | ||
160 | struct be_drvr_stats { | 169 | struct be_tx_stats { |
161 | u32 be_tx_reqs; /* number of TX requests initiated */ | 170 | u32 be_tx_reqs; /* number of TX requests initiated */ |
162 | u32 be_tx_stops; /* number of times TX Q was stopped */ | 171 | u32 be_tx_stops; /* number of times TX Q was stopped */ |
163 | u32 be_fwd_reqs; /* number of send reqs through forwarding i/f */ | ||
164 | u32 be_tx_wrbs; /* number of tx WRBs used */ | 172 | u32 be_tx_wrbs; /* number of tx WRBs used */ |
165 | u32 be_tx_events; /* number of tx completion events */ | 173 | u32 be_tx_events; /* number of tx completion events */ |
166 | u32 be_tx_compl; /* number of tx completion entries processed */ | 174 | u32 be_tx_compl; /* number of tx completion entries processed */ |
@@ -169,35 +177,6 @@ struct be_drvr_stats { | |||
169 | u64 be_tx_bytes_prev; | 177 | u64 be_tx_bytes_prev; |
170 | u64 be_tx_pkts; | 178 | u64 be_tx_pkts; |
171 | u32 be_tx_rate; | 179 | u32 be_tx_rate; |
172 | |||
173 | u32 cache_barrier[16]; | ||
174 | |||
175 | u32 be_ethrx_post_fail;/* number of ethrx buffer alloc failures */ | ||
176 | u32 be_rx_polls; /* number of times NAPI called poll function */ | ||
177 | u32 be_rx_events; /* number of ucast rx completion events */ | ||
178 | u32 be_rx_compl; /* number of rx completion entries processed */ | ||
179 | ulong be_rx_jiffies; | ||
180 | u64 be_rx_bytes; | ||
181 | u64 be_rx_bytes_prev; | ||
182 | u64 be_rx_pkts; | ||
183 | u32 be_rx_rate; | ||
184 | u32 be_rx_mcast_pkt; | ||
185 | /* number of non ether type II frames dropped where | ||
186 | * frame len > length field of Mac Hdr */ | ||
187 | u32 be_802_3_dropped_frames; | ||
188 | /* number of non ether type II frames malformed where | ||
189 | * in frame len < length field of Mac Hdr */ | ||
190 | u32 be_802_3_malformed_frames; | ||
191 | u32 be_rxcp_err; /* Num rx completion entries w/ err set. */ | ||
192 | ulong rx_fps_jiffies; /* jiffies at last FPS calc */ | ||
193 | u32 be_rx_frags; | ||
194 | u32 be_prev_rx_frags; | ||
195 | u32 be_rx_fps; /* Rx frags per second */ | ||
196 | }; | ||
197 | |||
198 | struct be_stats_obj { | ||
199 | struct be_drvr_stats drvr_stats; | ||
200 | struct be_dma_mem cmd; | ||
201 | }; | 180 | }; |
202 | 181 | ||
203 | struct be_tx_obj { | 182 | struct be_tx_obj { |
@@ -215,10 +194,95 @@ struct be_rx_page_info { | |||
215 | bool last_page_user; | 194 | bool last_page_user; |
216 | }; | 195 | }; |
217 | 196 | ||
197 | struct be_rx_stats { | ||
198 | u32 rx_post_fail;/* number of ethrx buffer alloc failures */ | ||
199 | u32 rx_polls; /* number of times NAPI called poll function */ | ||
200 | u32 rx_events; /* number of ucast rx completion events */ | ||
201 | u32 rx_compl; /* number of rx completion entries processed */ | ||
202 | ulong rx_jiffies; | ||
203 | u64 rx_bytes; | ||
204 | u64 rx_bytes_prev; | ||
205 | u64 rx_pkts; | ||
206 | u32 rx_rate; | ||
207 | u32 rx_mcast_pkts; | ||
208 | u32 rxcp_err; /* Num rx completion entries w/ err set. */ | ||
209 | ulong rx_fps_jiffies; /* jiffies at last FPS calc */ | ||
210 | u32 rx_frags; | ||
211 | u32 prev_rx_frags; | ||
212 | u32 rx_fps; /* Rx frags per second */ | ||
213 | }; | ||
214 | |||
215 | struct be_rx_compl_info { | ||
216 | u32 rss_hash; | ||
217 | u16 vlan_tag; | ||
218 | u16 pkt_size; | ||
219 | u16 rxq_idx; | ||
220 | u16 mac_id; | ||
221 | u8 vlanf; | ||
222 | u8 num_rcvd; | ||
223 | u8 err; | ||
224 | u8 ipf; | ||
225 | u8 tcpf; | ||
226 | u8 udpf; | ||
227 | u8 ip_csum; | ||
228 | u8 l4_csum; | ||
229 | u8 ipv6; | ||
230 | u8 vtm; | ||
231 | u8 pkt_type; | ||
232 | }; | ||
233 | |||
218 | struct be_rx_obj { | 234 | struct be_rx_obj { |
235 | struct be_adapter *adapter; | ||
219 | struct be_queue_info q; | 236 | struct be_queue_info q; |
220 | struct be_queue_info cq; | 237 | struct be_queue_info cq; |
238 | struct be_rx_compl_info rxcp; | ||
221 | struct be_rx_page_info page_info_tbl[RX_Q_LEN]; | 239 | struct be_rx_page_info page_info_tbl[RX_Q_LEN]; |
240 | struct be_eq_obj rx_eq; | ||
241 | struct be_rx_stats stats; | ||
242 | u8 rss_id; | ||
243 | bool rx_post_starved; /* Zero rx frags have been posted to BE */ | ||
244 | u32 cache_line_barrier[16]; | ||
245 | }; | ||
246 | |||
247 | struct be_drv_stats { | ||
248 | u8 be_on_die_temperature; | ||
249 | u64 be_tx_events; | ||
250 | u64 eth_red_drops; | ||
251 | u64 rx_drops_no_pbuf; | ||
252 | u64 rx_drops_no_txpb; | ||
253 | u64 rx_drops_no_erx_descr; | ||
254 | u64 rx_drops_no_tpre_descr; | ||
255 | u64 rx_drops_too_many_frags; | ||
256 | u64 rx_drops_invalid_ring; | ||
257 | u64 forwarded_packets; | ||
258 | u64 rx_drops_mtu; | ||
259 | u64 rx_crc_errors; | ||
260 | u64 rx_alignment_symbol_errors; | ||
261 | u64 rx_pause_frames; | ||
262 | u64 rx_priority_pause_frames; | ||
263 | u64 rx_control_frames; | ||
264 | u64 rx_in_range_errors; | ||
265 | u64 rx_out_range_errors; | ||
266 | u64 rx_frame_too_long; | ||
267 | u64 rx_address_match_errors; | ||
268 | u64 rx_dropped_too_small; | ||
269 | u64 rx_dropped_too_short; | ||
270 | u64 rx_dropped_header_too_small; | ||
271 | u64 rx_dropped_tcp_length; | ||
272 | u64 rx_dropped_runt; | ||
273 | u64 rx_ip_checksum_errs; | ||
274 | u64 rx_tcp_checksum_errs; | ||
275 | u64 rx_udp_checksum_errs; | ||
276 | u64 rx_switched_unicast_packets; | ||
277 | u64 rx_switched_multicast_packets; | ||
278 | u64 rx_switched_broadcast_packets; | ||
279 | u64 tx_pauseframes; | ||
280 | u64 tx_priority_pauseframes; | ||
281 | u64 tx_controlframes; | ||
282 | u64 rxpp_fifo_overflow_drop; | ||
283 | u64 rx_input_fifo_overflow_drop; | ||
284 | u64 pmem_fifo_overflow_drop; | ||
285 | u64 jabber_events; | ||
222 | }; | 286 | }; |
223 | 287 | ||
224 | struct be_vf_cfg { | 288 | struct be_vf_cfg { |
@@ -229,8 +293,8 @@ struct be_vf_cfg { | |||
229 | u32 vf_tx_rate; | 293 | u32 vf_tx_rate; |
230 | }; | 294 | }; |
231 | 295 | ||
232 | #define BE_NUM_MSIX_VECTORS 2 /* 1 each for Tx and Rx */ | ||
233 | #define BE_INVALID_PMAC_ID 0xffffffff | 296 | #define BE_INVALID_PMAC_ID 0xffffffff |
297 | |||
234 | struct be_adapter { | 298 | struct be_adapter { |
235 | struct pci_dev *pdev; | 299 | struct pci_dev *pdev; |
236 | struct net_device *netdev; | 300 | struct net_device *netdev; |
@@ -239,7 +303,7 @@ struct be_adapter { | |||
239 | u8 __iomem *db; /* Door Bell */ | 303 | u8 __iomem *db; /* Door Bell */ |
240 | u8 __iomem *pcicfg; /* PCI config space */ | 304 | u8 __iomem *pcicfg; /* PCI config space */ |
241 | 305 | ||
242 | spinlock_t mbox_lock; /* For serializing mbox cmds to BE card */ | 306 | struct mutex mbox_lock; /* For serializing mbox cmds to BE card */ |
243 | struct be_dma_mem mbox_mem; | 307 | struct be_dma_mem mbox_mem; |
244 | /* Mbox mem is adjusted to align to 16 bytes. The allocated addr | 308 | /* Mbox mem is adjusted to align to 16 bytes. The allocated addr |
245 | * is stored for freeing purpose */ | 309 | * is stored for freeing purpose */ |
@@ -249,37 +313,43 @@ struct be_adapter { | |||
249 | spinlock_t mcc_lock; /* For serializing mcc cmds to BE card */ | 313 | spinlock_t mcc_lock; /* For serializing mcc cmds to BE card */ |
250 | spinlock_t mcc_cq_lock; | 314 | spinlock_t mcc_cq_lock; |
251 | 315 | ||
252 | struct msix_entry msix_entries[BE_NUM_MSIX_VECTORS]; | 316 | struct msix_entry msix_entries[BE_MAX_MSIX_VECTORS]; |
253 | bool msix_enabled; | 317 | u32 num_msix_vec; |
254 | bool isr_registered; | 318 | bool isr_registered; |
255 | 319 | ||
256 | /* TX Rings */ | 320 | /* TX Rings */ |
257 | struct be_eq_obj tx_eq; | 321 | struct be_eq_obj tx_eq; |
258 | struct be_tx_obj tx_obj; | 322 | struct be_tx_obj tx_obj; |
323 | struct be_tx_stats tx_stats; | ||
259 | 324 | ||
260 | u32 cache_line_break[8]; | 325 | u32 cache_line_break[8]; |
261 | 326 | ||
262 | /* Rx rings */ | 327 | /* Rx rings */ |
263 | struct be_eq_obj rx_eq; | 328 | struct be_rx_obj rx_obj[MAX_RX_QS]; |
264 | struct be_rx_obj rx_obj; | 329 | u32 num_rx_qs; |
265 | u32 big_page_size; /* Compounded page size shared by rx wrbs */ | 330 | u32 big_page_size; /* Compounded page size shared by rx wrbs */ |
266 | bool rx_post_starved; /* Zero rx frags have been posted to BE */ | 331 | |
332 | u8 eq_next_idx; | ||
333 | struct be_drv_stats drv_stats; | ||
267 | 334 | ||
268 | struct vlan_group *vlan_grp; | 335 | struct vlan_group *vlan_grp; |
269 | u16 vlans_added; | 336 | u16 vlans_added; |
270 | u16 max_vlans; /* Number of vlans supported */ | 337 | u16 max_vlans; /* Number of vlans supported */ |
271 | u8 vlan_tag[VLAN_GROUP_ARRAY_LEN]; | 338 | u8 vlan_tag[VLAN_N_VID]; |
339 | u8 vlan_prio_bmap; /* Available Priority BitMap */ | ||
340 | u16 recommended_prio; /* Recommended Priority */ | ||
272 | struct be_dma_mem mc_cmd_mem; | 341 | struct be_dma_mem mc_cmd_mem; |
273 | 342 | ||
274 | struct be_stats_obj stats; | 343 | struct be_dma_mem stats_cmd; |
275 | /* Work queue used to perform periodic tasks like getting statistics */ | 344 | /* Work queue used to perform periodic tasks like getting statistics */ |
276 | struct delayed_work work; | 345 | struct delayed_work work; |
346 | u16 work_counter; | ||
277 | 347 | ||
278 | /* Ethtool knobs and info */ | 348 | /* Ethtool knobs and info */ |
279 | bool rx_csum; /* BE card must perform rx-checksumming */ | ||
280 | char fw_ver[FW_VER_LEN]; | 349 | char fw_ver[FW_VER_LEN]; |
281 | u32 if_handle; /* Used to configure filtering */ | 350 | u32 if_handle; /* Used to configure filtering */ |
282 | u32 pmac_id; /* MAC addr handle used by BE card */ | 351 | u32 pmac_id; /* MAC addr handle used by BE card */ |
352 | u32 beacon_state; /* for set_phys_id */ | ||
283 | 353 | ||
284 | bool eeh_err; | 354 | bool eeh_err; |
285 | bool link_up; | 355 | bool link_up; |
@@ -287,10 +357,11 @@ struct be_adapter { | |||
287 | bool promiscuous; | 357 | bool promiscuous; |
288 | bool wol; | 358 | bool wol; |
289 | u32 function_mode; | 359 | u32 function_mode; |
360 | u32 function_caps; | ||
290 | u32 rx_fc; /* Rx flow control */ | 361 | u32 rx_fc; /* Rx flow control */ |
291 | u32 tx_fc; /* Tx flow control */ | 362 | u32 tx_fc; /* Tx flow control */ |
292 | bool ue_detected; | 363 | bool ue_detected; |
293 | bool stats_ioctl_sent; | 364 | bool stats_cmd_sent; |
294 | int link_speed; | 365 | int link_speed; |
295 | u8 port_type; | 366 | u8 port_type; |
296 | u8 transceiver; | 367 | u8 transceiver; |
@@ -299,10 +370,13 @@ struct be_adapter { | |||
299 | u32 flash_status; | 370 | u32 flash_status; |
300 | struct completion flash_compl; | 371 | struct completion flash_compl; |
301 | 372 | ||
373 | bool be3_native; | ||
302 | bool sriov_enabled; | 374 | bool sriov_enabled; |
303 | struct be_vf_cfg vf_cfg[BE_MAX_VF]; | 375 | struct be_vf_cfg *vf_cfg; |
304 | u8 base_eq_id; | ||
305 | u8 is_virtfn; | 376 | u8 is_virtfn; |
377 | u32 sli_family; | ||
378 | u8 hba_port_num; | ||
379 | u16 pvid; | ||
306 | }; | 380 | }; |
307 | 381 | ||
308 | #define be_physfn(adapter) (!adapter->is_virtfn) | 382 | #define be_physfn(adapter) (!adapter->is_virtfn) |
@@ -311,12 +385,26 @@ struct be_adapter { | |||
311 | #define BE_GEN2 2 | 385 | #define BE_GEN2 2 |
312 | #define BE_GEN3 3 | 386 | #define BE_GEN3 3 |
313 | 387 | ||
388 | #define lancer_chip(adapter) ((adapter->pdev->device == OC_DEVICE_ID3) || \ | ||
389 | (adapter->pdev->device == OC_DEVICE_ID4)) | ||
390 | |||
314 | extern const struct ethtool_ops be_ethtool_ops; | 391 | extern const struct ethtool_ops be_ethtool_ops; |
315 | 392 | ||
316 | #define drvr_stats(adapter) (&adapter->stats.drvr_stats) | 393 | #define msix_enabled(adapter) (adapter->num_msix_vec > 0) |
394 | #define tx_stats(adapter) (&adapter->tx_stats) | ||
395 | #define rx_stats(rxo) (&rxo->stats) | ||
317 | 396 | ||
318 | #define BE_SET_NETDEV_OPS(netdev, ops) (netdev->netdev_ops = ops) | 397 | #define BE_SET_NETDEV_OPS(netdev, ops) (netdev->netdev_ops = ops) |
319 | 398 | ||
399 | #define for_all_rx_queues(adapter, rxo, i) \ | ||
400 | for (i = 0, rxo = &adapter->rx_obj[i]; i < adapter->num_rx_qs; \ | ||
401 | i++, rxo++) | ||
402 | |||
403 | /* Just skip the first default non-rss queue */ | ||
404 | #define for_all_rss_queues(adapter, rxo, i) \ | ||
405 | for (i = 0, rxo = &adapter->rx_obj[i+1]; i < (adapter->num_rx_qs - 1);\ | ||
406 | i++, rxo++) | ||
407 | |||
320 | #define PAGE_SHIFT_4K 12 | 408 | #define PAGE_SHIFT_4K 12 |
321 | #define PAGE_SIZE_4K (1 << PAGE_SHIFT_4K) | 409 | #define PAGE_SIZE_4K (1 << PAGE_SHIFT_4K) |
322 | 410 | ||
@@ -407,16 +495,34 @@ static inline u8 is_udp_pkt(struct sk_buff *skb) | |||
407 | 495 | ||
408 | static inline void be_check_sriov_fn_type(struct be_adapter *adapter) | 496 | static inline void be_check_sriov_fn_type(struct be_adapter *adapter) |
409 | { | 497 | { |
410 | u8 data; | 498 | u32 sli_intf; |
499 | |||
500 | pci_read_config_dword(adapter->pdev, SLI_INTF_REG_OFFSET, &sli_intf); | ||
501 | adapter->is_virtfn = (sli_intf & SLI_INTF_FT_MASK) ? 1 : 0; | ||
502 | } | ||
503 | |||
504 | static inline void be_vf_eth_addr_generate(struct be_adapter *adapter, u8 *mac) | ||
505 | { | ||
506 | u32 addr; | ||
507 | |||
508 | addr = jhash(adapter->netdev->dev_addr, ETH_ALEN, 0); | ||
411 | 509 | ||
412 | pci_write_config_byte(adapter->pdev, 0xFE, 0xAA); | 510 | mac[5] = (u8)(addr & 0xFF); |
413 | pci_read_config_byte(adapter->pdev, 0xFE, &data); | 511 | mac[4] = (u8)((addr >> 8) & 0xFF); |
414 | adapter->is_virtfn = (data != 0xAA); | 512 | mac[3] = (u8)((addr >> 16) & 0xFF); |
513 | /* Use the OUI from the current MAC address */ | ||
514 | memcpy(mac, adapter->netdev->dev_addr, 3); | ||
515 | } | ||
516 | |||
517 | static inline bool be_multi_rxq(const struct be_adapter *adapter) | ||
518 | { | ||
519 | return adapter->num_rx_qs > 1; | ||
415 | } | 520 | } |
416 | 521 | ||
417 | extern void be_cq_notify(struct be_adapter *adapter, u16 qid, bool arm, | 522 | extern void be_cq_notify(struct be_adapter *adapter, u16 qid, bool arm, |
418 | u16 num_popped); | 523 | u16 num_popped); |
419 | extern void be_link_status_update(struct be_adapter *adapter, bool link_up); | 524 | extern void be_link_status_update(struct be_adapter *adapter, bool link_up); |
420 | extern void netdev_stats_update(struct be_adapter *adapter); | 525 | extern void netdev_stats_update(struct be_adapter *adapter); |
526 | extern void be_parse_stats(struct be_adapter *adapter); | ||
421 | extern int be_load_fw(struct be_adapter *adapter, u8 *func); | 527 | extern int be_load_fw(struct be_adapter *adapter, u8 *func); |
422 | #endif /* BE_H */ | 528 | #endif /* BE_H */ |