diff options
Diffstat (limited to 'drivers/net/benet/be_cmds.h')
-rw-r--r-- | drivers/net/benet/be_cmds.h | 658 |
1 files changed, 604 insertions, 54 deletions
diff --git a/drivers/net/benet/be_cmds.h b/drivers/net/benet/be_cmds.h index ad1e6fac60c5..8148cc66cbe9 100644 --- a/drivers/net/benet/be_cmds.h +++ b/drivers/net/benet/be_cmds.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 | /* | 18 | /* |
@@ -82,7 +82,13 @@ struct be_mcc_compl { | |||
82 | */ | 82 | */ |
83 | #define ASYNC_TRAILER_EVENT_CODE_SHIFT 8 /* bits 8 - 15 */ | 83 | #define ASYNC_TRAILER_EVENT_CODE_SHIFT 8 /* bits 8 - 15 */ |
84 | #define ASYNC_TRAILER_EVENT_CODE_MASK 0xFF | 84 | #define ASYNC_TRAILER_EVENT_CODE_MASK 0xFF |
85 | #define ASYNC_TRAILER_EVENT_TYPE_SHIFT 16 | ||
86 | #define ASYNC_TRAILER_EVENT_TYPE_MASK 0xFF | ||
85 | #define ASYNC_EVENT_CODE_LINK_STATE 0x1 | 87 | #define ASYNC_EVENT_CODE_LINK_STATE 0x1 |
88 | #define ASYNC_EVENT_CODE_GRP_5 0x5 | ||
89 | #define ASYNC_EVENT_QOS_SPEED 0x1 | ||
90 | #define ASYNC_EVENT_COS_PRIORITY 0x2 | ||
91 | #define ASYNC_EVENT_PVID_STATE 0x3 | ||
86 | struct be_async_event_trailer { | 92 | struct be_async_event_trailer { |
87 | u32 code; | 93 | u32 code; |
88 | }; | 94 | }; |
@@ -105,6 +111,42 @@ struct be_async_event_link_state { | |||
105 | struct be_async_event_trailer trailer; | 111 | struct be_async_event_trailer trailer; |
106 | } __packed; | 112 | } __packed; |
107 | 113 | ||
114 | /* When the event code of an async trailer is GRP-5 and event_type is QOS_SPEED | ||
115 | * the mcc_compl must be interpreted as follows | ||
116 | */ | ||
117 | struct be_async_event_grp5_qos_link_speed { | ||
118 | u8 physical_port; | ||
119 | u8 rsvd[5]; | ||
120 | u16 qos_link_speed; | ||
121 | u32 event_tag; | ||
122 | struct be_async_event_trailer trailer; | ||
123 | } __packed; | ||
124 | |||
125 | /* When the event code of an async trailer is GRP5 and event type is | ||
126 | * CoS-Priority, the mcc_compl must be interpreted as follows | ||
127 | */ | ||
128 | struct be_async_event_grp5_cos_priority { | ||
129 | u8 physical_port; | ||
130 | u8 available_priority_bmap; | ||
131 | u8 reco_default_priority; | ||
132 | u8 valid; | ||
133 | u8 rsvd0; | ||
134 | u8 event_tag; | ||
135 | struct be_async_event_trailer trailer; | ||
136 | } __packed; | ||
137 | |||
138 | /* When the event code of an async trailer is GRP5 and event type is | ||
139 | * PVID state, the mcc_compl must be interpreted as follows | ||
140 | */ | ||
141 | struct be_async_event_grp5_pvid_state { | ||
142 | u8 enabled; | ||
143 | u8 rsvd0; | ||
144 | u16 tag; | ||
145 | u32 event_tag; | ||
146 | u32 rsvd1; | ||
147 | struct be_async_event_trailer trailer; | ||
148 | } __packed; | ||
149 | |||
108 | struct be_mcc_mailbox { | 150 | struct be_mcc_mailbox { |
109 | struct be_mcc_wrb wrb; | 151 | struct be_mcc_wrb wrb; |
110 | struct be_mcc_compl compl; | 152 | struct be_mcc_compl compl; |
@@ -123,9 +165,11 @@ struct be_mcc_mailbox { | |||
123 | #define OPCODE_COMMON_WRITE_FLASHROM 7 | 165 | #define OPCODE_COMMON_WRITE_FLASHROM 7 |
124 | #define OPCODE_COMMON_CQ_CREATE 12 | 166 | #define OPCODE_COMMON_CQ_CREATE 12 |
125 | #define OPCODE_COMMON_EQ_CREATE 13 | 167 | #define OPCODE_COMMON_EQ_CREATE 13 |
126 | #define OPCODE_COMMON_MCC_CREATE 21 | 168 | #define OPCODE_COMMON_MCC_CREATE 21 |
127 | #define OPCODE_COMMON_SET_QOS 28 | 169 | #define OPCODE_COMMON_SET_QOS 28 |
170 | #define OPCODE_COMMON_MCC_CREATE_EXT 90 | ||
128 | #define OPCODE_COMMON_SEEPROM_READ 30 | 171 | #define OPCODE_COMMON_SEEPROM_READ 30 |
172 | #define OPCODE_COMMON_GET_CNTL_ATTRIBUTES 32 | ||
129 | #define OPCODE_COMMON_NTWK_RX_FILTER 34 | 173 | #define OPCODE_COMMON_NTWK_RX_FILTER 34 |
130 | #define OPCODE_COMMON_GET_FW_VERSION 35 | 174 | #define OPCODE_COMMON_GET_FW_VERSION 35 |
131 | #define OPCODE_COMMON_SET_FLOW_CONTROL 36 | 175 | #define OPCODE_COMMON_SET_FLOW_CONTROL 36 |
@@ -142,11 +186,16 @@ struct be_mcc_mailbox { | |||
142 | #define OPCODE_COMMON_NTWK_PMAC_ADD 59 | 186 | #define OPCODE_COMMON_NTWK_PMAC_ADD 59 |
143 | #define OPCODE_COMMON_NTWK_PMAC_DEL 60 | 187 | #define OPCODE_COMMON_NTWK_PMAC_DEL 60 |
144 | #define OPCODE_COMMON_FUNCTION_RESET 61 | 188 | #define OPCODE_COMMON_FUNCTION_RESET 61 |
189 | #define OPCODE_COMMON_MANAGE_FAT 68 | ||
145 | #define OPCODE_COMMON_ENABLE_DISABLE_BEACON 69 | 190 | #define OPCODE_COMMON_ENABLE_DISABLE_BEACON 69 |
146 | #define OPCODE_COMMON_GET_BEACON_STATE 70 | 191 | #define OPCODE_COMMON_GET_BEACON_STATE 70 |
147 | #define OPCODE_COMMON_READ_TRANSRECV_DATA 73 | 192 | #define OPCODE_COMMON_READ_TRANSRECV_DATA 73 |
148 | #define OPCODE_COMMON_GET_PHY_DETAILS 102 | 193 | #define OPCODE_COMMON_GET_PHY_DETAILS 102 |
194 | #define OPCODE_COMMON_SET_DRIVER_FUNCTION_CAP 103 | ||
195 | #define OPCODE_COMMON_GET_CNTL_ADDITIONAL_ATTRIBUTES 121 | ||
196 | #define OPCODE_COMMON_WRITE_OBJECT 172 | ||
149 | 197 | ||
198 | #define OPCODE_ETH_RSS_CONFIG 1 | ||
150 | #define OPCODE_ETH_ACPI_CONFIG 2 | 199 | #define OPCODE_ETH_ACPI_CONFIG 2 |
151 | #define OPCODE_ETH_PROMISCUOUS 3 | 200 | #define OPCODE_ETH_PROMISCUOUS 3 |
152 | #define OPCODE_ETH_GET_STATISTICS 4 | 201 | #define OPCODE_ETH_GET_STATISTICS 4 |
@@ -155,6 +204,7 @@ struct be_mcc_mailbox { | |||
155 | #define OPCODE_ETH_TX_DESTROY 9 | 204 | #define OPCODE_ETH_TX_DESTROY 9 |
156 | #define OPCODE_ETH_RX_DESTROY 10 | 205 | #define OPCODE_ETH_RX_DESTROY 10 |
157 | #define OPCODE_ETH_ACPI_WOL_MAGIC_CONFIG 12 | 206 | #define OPCODE_ETH_ACPI_WOL_MAGIC_CONFIG 12 |
207 | #define OPCODE_ETH_GET_PPORT_STATS 18 | ||
158 | 208 | ||
159 | #define OPCODE_LOWLEVEL_HOST_DDR_DMA 17 | 209 | #define OPCODE_LOWLEVEL_HOST_DDR_DMA 17 |
160 | #define OPCODE_LOWLEVEL_LOOPBACK_TEST 18 | 210 | #define OPCODE_LOWLEVEL_LOOPBACK_TEST 18 |
@@ -278,7 +328,7 @@ struct be_cmd_req_pmac_del { | |||
278 | /******************** Create CQ ***************************/ | 328 | /******************** Create CQ ***************************/ |
279 | /* Pseudo amap definition in which each bit of the actual structure is defined | 329 | /* Pseudo amap definition in which each bit of the actual structure is defined |
280 | * as a byte: used to calculate offset/shift/mask of each field */ | 330 | * as a byte: used to calculate offset/shift/mask of each field */ |
281 | struct amap_cq_context { | 331 | struct amap_cq_context_be { |
282 | u8 cidx[11]; /* dword 0*/ | 332 | u8 cidx[11]; /* dword 0*/ |
283 | u8 rsvd0; /* dword 0*/ | 333 | u8 rsvd0; /* dword 0*/ |
284 | u8 coalescwm[2]; /* dword 0*/ | 334 | u8 coalescwm[2]; /* dword 0*/ |
@@ -301,24 +351,60 @@ struct amap_cq_context { | |||
301 | u8 rsvd5[32]; /* dword 3*/ | 351 | u8 rsvd5[32]; /* dword 3*/ |
302 | } __packed; | 352 | } __packed; |
303 | 353 | ||
354 | struct amap_cq_context_lancer { | ||
355 | u8 rsvd0[12]; /* dword 0*/ | ||
356 | u8 coalescwm[2]; /* dword 0*/ | ||
357 | u8 nodelay; /* dword 0*/ | ||
358 | u8 rsvd1[12]; /* dword 0*/ | ||
359 | u8 count[2]; /* dword 0*/ | ||
360 | u8 valid; /* dword 0*/ | ||
361 | u8 rsvd2; /* dword 0*/ | ||
362 | u8 eventable; /* dword 0*/ | ||
363 | u8 eqid[16]; /* dword 1*/ | ||
364 | u8 rsvd3[15]; /* dword 1*/ | ||
365 | u8 armed; /* dword 1*/ | ||
366 | u8 rsvd4[32]; /* dword 2*/ | ||
367 | u8 rsvd5[32]; /* dword 3*/ | ||
368 | } __packed; | ||
369 | |||
304 | struct be_cmd_req_cq_create { | 370 | struct be_cmd_req_cq_create { |
305 | struct be_cmd_req_hdr hdr; | 371 | struct be_cmd_req_hdr hdr; |
306 | u16 num_pages; | 372 | u16 num_pages; |
307 | u16 rsvd0; | 373 | u8 page_size; |
308 | u8 context[sizeof(struct amap_cq_context) / 8]; | 374 | u8 rsvd0; |
375 | u8 context[sizeof(struct amap_cq_context_be) / 8]; | ||
309 | struct phys_addr pages[8]; | 376 | struct phys_addr pages[8]; |
310 | } __packed; | 377 | } __packed; |
311 | 378 | ||
379 | |||
312 | struct be_cmd_resp_cq_create { | 380 | struct be_cmd_resp_cq_create { |
313 | struct be_cmd_resp_hdr hdr; | 381 | struct be_cmd_resp_hdr hdr; |
314 | u16 cq_id; | 382 | u16 cq_id; |
315 | u16 rsvd0; | 383 | u16 rsvd0; |
316 | } __packed; | 384 | } __packed; |
317 | 385 | ||
386 | struct be_cmd_req_get_fat { | ||
387 | struct be_cmd_req_hdr hdr; | ||
388 | u32 fat_operation; | ||
389 | u32 read_log_offset; | ||
390 | u32 read_log_length; | ||
391 | u32 data_buffer_size; | ||
392 | u32 data_buffer[1]; | ||
393 | } __packed; | ||
394 | |||
395 | struct be_cmd_resp_get_fat { | ||
396 | struct be_cmd_resp_hdr hdr; | ||
397 | u32 log_size; | ||
398 | u32 read_log_length; | ||
399 | u32 rsvd[2]; | ||
400 | u32 data_buffer[1]; | ||
401 | } __packed; | ||
402 | |||
403 | |||
318 | /******************** Create MCCQ ***************************/ | 404 | /******************** Create MCCQ ***************************/ |
319 | /* Pseudo amap definition in which each bit of the actual structure is defined | 405 | /* Pseudo amap definition in which each bit of the actual structure is defined |
320 | * as a byte: used to calculate offset/shift/mask of each field */ | 406 | * as a byte: used to calculate offset/shift/mask of each field */ |
321 | struct amap_mcc_context { | 407 | struct amap_mcc_context_be { |
322 | u8 con_index[14]; | 408 | u8 con_index[14]; |
323 | u8 rsvd0[2]; | 409 | u8 rsvd0[2]; |
324 | u8 ring_size[4]; | 410 | u8 ring_size[4]; |
@@ -333,11 +419,23 @@ struct amap_mcc_context { | |||
333 | u8 rsvd2[32]; | 419 | u8 rsvd2[32]; |
334 | } __packed; | 420 | } __packed; |
335 | 421 | ||
422 | struct amap_mcc_context_lancer { | ||
423 | u8 async_cq_id[16]; | ||
424 | u8 ring_size[4]; | ||
425 | u8 rsvd0[12]; | ||
426 | u8 rsvd1[31]; | ||
427 | u8 valid; | ||
428 | u8 async_cq_valid[1]; | ||
429 | u8 rsvd2[31]; | ||
430 | u8 rsvd3[32]; | ||
431 | } __packed; | ||
432 | |||
336 | struct be_cmd_req_mcc_create { | 433 | struct be_cmd_req_mcc_create { |
337 | struct be_cmd_req_hdr hdr; | 434 | struct be_cmd_req_hdr hdr; |
338 | u16 num_pages; | 435 | u16 num_pages; |
339 | u16 rsvd0; | 436 | u16 cq_id; |
340 | u8 context[sizeof(struct amap_mcc_context) / 8]; | 437 | u32 async_event_bitmap[1]; |
438 | u8 context[sizeof(struct amap_mcc_context_be) / 8]; | ||
341 | struct phys_addr pages[8]; | 439 | struct phys_addr pages[8]; |
342 | } __packed; | 440 | } __packed; |
343 | 441 | ||
@@ -354,7 +452,7 @@ struct be_cmd_resp_mcc_create { | |||
354 | /* Pseudo amap definition in which each bit of the actual structure is defined | 452 | /* Pseudo amap definition in which each bit of the actual structure is defined |
355 | * as a byte: used to calculate offset/shift/mask of each field */ | 453 | * as a byte: used to calculate offset/shift/mask of each field */ |
356 | struct amap_tx_context { | 454 | struct amap_tx_context { |
357 | u8 rsvd0[16]; /* dword 0 */ | 455 | u8 if_id[16]; /* dword 0 */ |
358 | u8 tx_ring_size[4]; /* dword 0 */ | 456 | u8 tx_ring_size[4]; /* dword 0 */ |
359 | u8 rsvd1[26]; /* dword 0 */ | 457 | u8 rsvd1[26]; /* dword 0 */ |
360 | u8 pci_func_id[8]; /* dword 1 */ | 458 | u8 pci_func_id[8]; /* dword 1 */ |
@@ -409,7 +507,7 @@ struct be_cmd_req_eth_rx_create { | |||
409 | struct be_cmd_resp_eth_rx_create { | 507 | struct be_cmd_resp_eth_rx_create { |
410 | struct be_cmd_resp_hdr hdr; | 508 | struct be_cmd_resp_hdr hdr; |
411 | u16 id; | 509 | u16 id; |
412 | u8 cpu_id; | 510 | u8 rss_id; |
413 | u8 rsvd0; | 511 | u8 rsvd0; |
414 | } __packed; | 512 | } __packed; |
415 | 513 | ||
@@ -442,7 +540,8 @@ enum be_if_flags { | |||
442 | BE_IF_FLAGS_VLAN = 0x100, | 540 | BE_IF_FLAGS_VLAN = 0x100, |
443 | BE_IF_FLAGS_MCAST_PROMISCUOUS = 0x200, | 541 | BE_IF_FLAGS_MCAST_PROMISCUOUS = 0x200, |
444 | BE_IF_FLAGS_PASS_L2_ERRORS = 0x400, | 542 | BE_IF_FLAGS_PASS_L2_ERRORS = 0x400, |
445 | BE_IF_FLAGS_PASS_L3L4_ERRORS = 0x800 | 543 | BE_IF_FLAGS_PASS_L3L4_ERRORS = 0x800, |
544 | BE_IF_FLAGS_MULTICAST = 0x1000 | ||
446 | }; | 545 | }; |
447 | 546 | ||
448 | /* An RX interface is an object with one or more MAC addresses and | 547 | /* An RX interface is an object with one or more MAC addresses and |
@@ -471,7 +570,7 @@ struct be_cmd_req_if_destroy { | |||
471 | }; | 570 | }; |
472 | 571 | ||
473 | /*************** HW Stats Get **********************************/ | 572 | /*************** HW Stats Get **********************************/ |
474 | struct be_port_rxf_stats { | 573 | struct be_port_rxf_stats_v0 { |
475 | u32 rx_bytes_lsd; /* dword 0*/ | 574 | u32 rx_bytes_lsd; /* dword 0*/ |
476 | u32 rx_bytes_msd; /* dword 1*/ | 575 | u32 rx_bytes_msd; /* dword 1*/ |
477 | u32 rx_total_frames; /* dword 2*/ | 576 | u32 rx_total_frames; /* dword 2*/ |
@@ -540,8 +639,8 @@ struct be_port_rxf_stats { | |||
540 | u32 rx_input_fifo_overflow; /* dword 65*/ | 639 | u32 rx_input_fifo_overflow; /* dword 65*/ |
541 | }; | 640 | }; |
542 | 641 | ||
543 | struct be_rxf_stats { | 642 | struct be_rxf_stats_v0 { |
544 | struct be_port_rxf_stats port[2]; | 643 | struct be_port_rxf_stats_v0 port[2]; |
545 | u32 rx_drops_no_pbuf; /* dword 132*/ | 644 | u32 rx_drops_no_pbuf; /* dword 132*/ |
546 | u32 rx_drops_no_txpb; /* dword 133*/ | 645 | u32 rx_drops_no_txpb; /* dword 133*/ |
547 | u32 rx_drops_no_erx_descr; /* dword 134*/ | 646 | u32 rx_drops_no_erx_descr; /* dword 134*/ |
@@ -558,31 +657,245 @@ struct be_rxf_stats { | |||
558 | u32 rx_drops_invalid_ring; /* dword 145*/ | 657 | u32 rx_drops_invalid_ring; /* dword 145*/ |
559 | u32 forwarded_packets; /* dword 146*/ | 658 | u32 forwarded_packets; /* dword 146*/ |
560 | u32 rx_drops_mtu; /* dword 147*/ | 659 | u32 rx_drops_mtu; /* dword 147*/ |
561 | u32 rsvd0[15]; | 660 | u32 rsvd0[7]; |
661 | u32 port0_jabber_events; | ||
662 | u32 port1_jabber_events; | ||
663 | u32 rsvd1[6]; | ||
562 | }; | 664 | }; |
563 | 665 | ||
564 | struct be_erx_stats { | 666 | struct be_erx_stats_v0 { |
565 | u32 rx_drops_no_fragments[44]; /* dwordS 0 to 43*/ | 667 | u32 rx_drops_no_fragments[44]; /* dwordS 0 to 43*/ |
566 | u32 debug_wdma_sent_hold; /* dword 44*/ | 668 | u32 rsvd[4]; |
567 | u32 debug_wdma_pbfree_sent_hold; /* dword 45*/ | 669 | }; |
568 | u32 debug_wdma_zerobyte_pbfree_sent_hold; /* dword 46*/ | 670 | |
569 | u32 debug_pmem_pbuf_dealloc; /* dword 47*/ | 671 | struct be_pmem_stats { |
672 | u32 eth_red_drops; | ||
673 | u32 rsvd[5]; | ||
570 | }; | 674 | }; |
571 | 675 | ||
572 | struct be_hw_stats { | 676 | struct be_hw_stats_v0 { |
573 | struct be_rxf_stats rxf; | 677 | struct be_rxf_stats_v0 rxf; |
574 | u32 rsvd[48]; | 678 | u32 rsvd[48]; |
575 | struct be_erx_stats erx; | 679 | struct be_erx_stats_v0 erx; |
680 | struct be_pmem_stats pmem; | ||
681 | }; | ||
682 | |||
683 | struct be_cmd_req_get_stats_v0 { | ||
684 | struct be_cmd_req_hdr hdr; | ||
685 | u8 rsvd[sizeof(struct be_hw_stats_v0)]; | ||
686 | }; | ||
687 | |||
688 | struct be_cmd_resp_get_stats_v0 { | ||
689 | struct be_cmd_resp_hdr hdr; | ||
690 | struct be_hw_stats_v0 hw_stats; | ||
691 | }; | ||
692 | |||
693 | #define make_64bit_val(hi_32, lo_32) (((u64)hi_32<<32) | lo_32) | ||
694 | struct lancer_cmd_pport_stats { | ||
695 | u32 tx_packets_lo; | ||
696 | u32 tx_packets_hi; | ||
697 | u32 tx_unicast_packets_lo; | ||
698 | u32 tx_unicast_packets_hi; | ||
699 | u32 tx_multicast_packets_lo; | ||
700 | u32 tx_multicast_packets_hi; | ||
701 | u32 tx_broadcast_packets_lo; | ||
702 | u32 tx_broadcast_packets_hi; | ||
703 | u32 tx_bytes_lo; | ||
704 | u32 tx_bytes_hi; | ||
705 | u32 tx_unicast_bytes_lo; | ||
706 | u32 tx_unicast_bytes_hi; | ||
707 | u32 tx_multicast_bytes_lo; | ||
708 | u32 tx_multicast_bytes_hi; | ||
709 | u32 tx_broadcast_bytes_lo; | ||
710 | u32 tx_broadcast_bytes_hi; | ||
711 | u32 tx_discards_lo; | ||
712 | u32 tx_discards_hi; | ||
713 | u32 tx_errors_lo; | ||
714 | u32 tx_errors_hi; | ||
715 | u32 tx_pause_frames_lo; | ||
716 | u32 tx_pause_frames_hi; | ||
717 | u32 tx_pause_on_frames_lo; | ||
718 | u32 tx_pause_on_frames_hi; | ||
719 | u32 tx_pause_off_frames_lo; | ||
720 | u32 tx_pause_off_frames_hi; | ||
721 | u32 tx_internal_mac_errors_lo; | ||
722 | u32 tx_internal_mac_errors_hi; | ||
723 | u32 tx_control_frames_lo; | ||
724 | u32 tx_control_frames_hi; | ||
725 | u32 tx_packets_64_bytes_lo; | ||
726 | u32 tx_packets_64_bytes_hi; | ||
727 | u32 tx_packets_65_to_127_bytes_lo; | ||
728 | u32 tx_packets_65_to_127_bytes_hi; | ||
729 | u32 tx_packets_128_to_255_bytes_lo; | ||
730 | u32 tx_packets_128_to_255_bytes_hi; | ||
731 | u32 tx_packets_256_to_511_bytes_lo; | ||
732 | u32 tx_packets_256_to_511_bytes_hi; | ||
733 | u32 tx_packets_512_to_1023_bytes_lo; | ||
734 | u32 tx_packets_512_to_1023_bytes_hi; | ||
735 | u32 tx_packets_1024_to_1518_bytes_lo; | ||
736 | u32 tx_packets_1024_to_1518_bytes_hi; | ||
737 | u32 tx_packets_1519_to_2047_bytes_lo; | ||
738 | u32 tx_packets_1519_to_2047_bytes_hi; | ||
739 | u32 tx_packets_2048_to_4095_bytes_lo; | ||
740 | u32 tx_packets_2048_to_4095_bytes_hi; | ||
741 | u32 tx_packets_4096_to_8191_bytes_lo; | ||
742 | u32 tx_packets_4096_to_8191_bytes_hi; | ||
743 | u32 tx_packets_8192_to_9216_bytes_lo; | ||
744 | u32 tx_packets_8192_to_9216_bytes_hi; | ||
745 | u32 tx_lso_packets_lo; | ||
746 | u32 tx_lso_packets_hi; | ||
747 | u32 rx_packets_lo; | ||
748 | u32 rx_packets_hi; | ||
749 | u32 rx_unicast_packets_lo; | ||
750 | u32 rx_unicast_packets_hi; | ||
751 | u32 rx_multicast_packets_lo; | ||
752 | u32 rx_multicast_packets_hi; | ||
753 | u32 rx_broadcast_packets_lo; | ||
754 | u32 rx_broadcast_packets_hi; | ||
755 | u32 rx_bytes_lo; | ||
756 | u32 rx_bytes_hi; | ||
757 | u32 rx_unicast_bytes_lo; | ||
758 | u32 rx_unicast_bytes_hi; | ||
759 | u32 rx_multicast_bytes_lo; | ||
760 | u32 rx_multicast_bytes_hi; | ||
761 | u32 rx_broadcast_bytes_lo; | ||
762 | u32 rx_broadcast_bytes_hi; | ||
763 | u32 rx_unknown_protos; | ||
764 | u32 rsvd_69; /* Word 69 is reserved */ | ||
765 | u32 rx_discards_lo; | ||
766 | u32 rx_discards_hi; | ||
767 | u32 rx_errors_lo; | ||
768 | u32 rx_errors_hi; | ||
769 | u32 rx_crc_errors_lo; | ||
770 | u32 rx_crc_errors_hi; | ||
771 | u32 rx_alignment_errors_lo; | ||
772 | u32 rx_alignment_errors_hi; | ||
773 | u32 rx_symbol_errors_lo; | ||
774 | u32 rx_symbol_errors_hi; | ||
775 | u32 rx_pause_frames_lo; | ||
776 | u32 rx_pause_frames_hi; | ||
777 | u32 rx_pause_on_frames_lo; | ||
778 | u32 rx_pause_on_frames_hi; | ||
779 | u32 rx_pause_off_frames_lo; | ||
780 | u32 rx_pause_off_frames_hi; | ||
781 | u32 rx_frames_too_long_lo; | ||
782 | u32 rx_frames_too_long_hi; | ||
783 | u32 rx_internal_mac_errors_lo; | ||
784 | u32 rx_internal_mac_errors_hi; | ||
785 | u32 rx_undersize_packets; | ||
786 | u32 rx_oversize_packets; | ||
787 | u32 rx_fragment_packets; | ||
788 | u32 rx_jabbers; | ||
789 | u32 rx_control_frames_lo; | ||
790 | u32 rx_control_frames_hi; | ||
791 | u32 rx_control_frames_unknown_opcode_lo; | ||
792 | u32 rx_control_frames_unknown_opcode_hi; | ||
793 | u32 rx_in_range_errors; | ||
794 | u32 rx_out_of_range_errors; | ||
795 | u32 rx_address_match_errors; | ||
796 | u32 rx_vlan_mismatch_errors; | ||
797 | u32 rx_dropped_too_small; | ||
798 | u32 rx_dropped_too_short; | ||
799 | u32 rx_dropped_header_too_small; | ||
800 | u32 rx_dropped_invalid_tcp_length; | ||
801 | u32 rx_dropped_runt; | ||
802 | u32 rx_ip_checksum_errors; | ||
803 | u32 rx_tcp_checksum_errors; | ||
804 | u32 rx_udp_checksum_errors; | ||
805 | u32 rx_non_rss_packets; | ||
806 | u32 rsvd_111; | ||
807 | u32 rx_ipv4_packets_lo; | ||
808 | u32 rx_ipv4_packets_hi; | ||
809 | u32 rx_ipv6_packets_lo; | ||
810 | u32 rx_ipv6_packets_hi; | ||
811 | u32 rx_ipv4_bytes_lo; | ||
812 | u32 rx_ipv4_bytes_hi; | ||
813 | u32 rx_ipv6_bytes_lo; | ||
814 | u32 rx_ipv6_bytes_hi; | ||
815 | u32 rx_nic_packets_lo; | ||
816 | u32 rx_nic_packets_hi; | ||
817 | u32 rx_tcp_packets_lo; | ||
818 | u32 rx_tcp_packets_hi; | ||
819 | u32 rx_iscsi_packets_lo; | ||
820 | u32 rx_iscsi_packets_hi; | ||
821 | u32 rx_management_packets_lo; | ||
822 | u32 rx_management_packets_hi; | ||
823 | u32 rx_switched_unicast_packets_lo; | ||
824 | u32 rx_switched_unicast_packets_hi; | ||
825 | u32 rx_switched_multicast_packets_lo; | ||
826 | u32 rx_switched_multicast_packets_hi; | ||
827 | u32 rx_switched_broadcast_packets_lo; | ||
828 | u32 rx_switched_broadcast_packets_hi; | ||
829 | u32 num_forwards_lo; | ||
830 | u32 num_forwards_hi; | ||
831 | u32 rx_fifo_overflow; | ||
832 | u32 rx_input_fifo_overflow; | ||
833 | u32 rx_drops_too_many_frags_lo; | ||
834 | u32 rx_drops_too_many_frags_hi; | ||
835 | u32 rx_drops_invalid_queue; | ||
836 | u32 rsvd_141; | ||
837 | u32 rx_drops_mtu_lo; | ||
838 | u32 rx_drops_mtu_hi; | ||
839 | u32 rx_packets_64_bytes_lo; | ||
840 | u32 rx_packets_64_bytes_hi; | ||
841 | u32 rx_packets_65_to_127_bytes_lo; | ||
842 | u32 rx_packets_65_to_127_bytes_hi; | ||
843 | u32 rx_packets_128_to_255_bytes_lo; | ||
844 | u32 rx_packets_128_to_255_bytes_hi; | ||
845 | u32 rx_packets_256_to_511_bytes_lo; | ||
846 | u32 rx_packets_256_to_511_bytes_hi; | ||
847 | u32 rx_packets_512_to_1023_bytes_lo; | ||
848 | u32 rx_packets_512_to_1023_bytes_hi; | ||
849 | u32 rx_packets_1024_to_1518_bytes_lo; | ||
850 | u32 rx_packets_1024_to_1518_bytes_hi; | ||
851 | u32 rx_packets_1519_to_2047_bytes_lo; | ||
852 | u32 rx_packets_1519_to_2047_bytes_hi; | ||
853 | u32 rx_packets_2048_to_4095_bytes_lo; | ||
854 | u32 rx_packets_2048_to_4095_bytes_hi; | ||
855 | u32 rx_packets_4096_to_8191_bytes_lo; | ||
856 | u32 rx_packets_4096_to_8191_bytes_hi; | ||
857 | u32 rx_packets_8192_to_9216_bytes_lo; | ||
858 | u32 rx_packets_8192_to_9216_bytes_hi; | ||
859 | }; | ||
860 | |||
861 | struct pport_stats_params { | ||
862 | u16 pport_num; | ||
863 | u8 rsvd; | ||
864 | u8 reset_stats; | ||
576 | }; | 865 | }; |
577 | 866 | ||
578 | struct be_cmd_req_get_stats { | 867 | struct lancer_cmd_req_pport_stats { |
579 | struct be_cmd_req_hdr hdr; | 868 | struct be_cmd_req_hdr hdr; |
580 | u8 rsvd[sizeof(struct be_hw_stats)]; | 869 | union { |
870 | struct pport_stats_params params; | ||
871 | u8 rsvd[sizeof(struct lancer_cmd_pport_stats)]; | ||
872 | } cmd_params; | ||
873 | }; | ||
874 | |||
875 | struct lancer_cmd_resp_pport_stats { | ||
876 | struct be_cmd_resp_hdr hdr; | ||
877 | struct lancer_cmd_pport_stats pport_stats; | ||
878 | }; | ||
879 | |||
880 | static inline struct lancer_cmd_pport_stats* | ||
881 | pport_stats_from_cmd(struct be_adapter *adapter) | ||
882 | { | ||
883 | struct lancer_cmd_resp_pport_stats *cmd = adapter->stats_cmd.va; | ||
884 | return &cmd->pport_stats; | ||
885 | } | ||
886 | |||
887 | struct be_cmd_req_get_cntl_addnl_attribs { | ||
888 | struct be_cmd_req_hdr hdr; | ||
889 | u8 rsvd[8]; | ||
581 | }; | 890 | }; |
582 | 891 | ||
583 | struct be_cmd_resp_get_stats { | 892 | struct be_cmd_resp_get_cntl_addnl_attribs { |
584 | struct be_cmd_resp_hdr hdr; | 893 | struct be_cmd_resp_hdr hdr; |
585 | struct be_hw_stats hw_stats; | 894 | u16 ipl_file_number; |
895 | u8 ipl_file_version; | ||
896 | u8 rsvd0; | ||
897 | u8 on_die_temperature; /* in degrees centigrade*/ | ||
898 | u8 rsvd1[3]; | ||
586 | }; | 899 | }; |
587 | 900 | ||
588 | struct be_cmd_req_vlan_config { | 901 | struct be_cmd_req_vlan_config { |
@@ -594,13 +907,6 @@ struct be_cmd_req_vlan_config { | |||
594 | u16 normal_vlan[64]; | 907 | u16 normal_vlan[64]; |
595 | } __packed; | 908 | } __packed; |
596 | 909 | ||
597 | struct be_cmd_req_promiscuous_config { | ||
598 | struct be_cmd_req_hdr hdr; | ||
599 | u8 port0_promiscuous; | ||
600 | u8 port1_promiscuous; | ||
601 | u16 rsvd0; | ||
602 | } __packed; | ||
603 | |||
604 | /******************** Multicast MAC Config *******************/ | 910 | /******************** Multicast MAC Config *******************/ |
605 | #define BE_MAX_MC 64 /* set mcast promisc if > 64 */ | 911 | #define BE_MAX_MC 64 /* set mcast promisc if > 64 */ |
606 | struct macaddr { | 912 | struct macaddr { |
@@ -615,11 +921,18 @@ struct be_cmd_req_mcast_mac_config { | |||
615 | struct macaddr mac[BE_MAX_MC]; | 921 | struct macaddr mac[BE_MAX_MC]; |
616 | } __packed; | 922 | } __packed; |
617 | 923 | ||
618 | static inline struct be_hw_stats * | 924 | /******************* RX FILTER ******************************/ |
619 | hw_stats_from_cmd(struct be_cmd_resp_get_stats *cmd) | 925 | struct be_cmd_req_rx_filter { |
620 | { | 926 | struct be_cmd_req_hdr hdr; |
621 | return &cmd->hw_stats; | 927 | u32 global_flags_mask; |
622 | } | 928 | u32 global_flags; |
929 | u32 if_flags_mask; | ||
930 | u32 if_flags; | ||
931 | u32 if_id; | ||
932 | u32 multicast_num; | ||
933 | struct macaddr mac[BE_MAX_MC]; | ||
934 | }; | ||
935 | |||
623 | 936 | ||
624 | /******************** Link Status Query *******************/ | 937 | /******************** Link Status Query *******************/ |
625 | struct be_cmd_req_link_status { | 938 | struct be_cmd_req_link_status { |
@@ -739,9 +1052,10 @@ struct be_cmd_resp_modify_eq_delay { | |||
739 | } __packed; | 1052 | } __packed; |
740 | 1053 | ||
741 | /******************** Get FW Config *******************/ | 1054 | /******************** Get FW Config *******************/ |
1055 | #define BE_FUNCTION_CAPS_RSS 0x2 | ||
742 | struct be_cmd_req_query_fw_cfg { | 1056 | struct be_cmd_req_query_fw_cfg { |
743 | struct be_cmd_req_hdr hdr; | 1057 | struct be_cmd_req_hdr hdr; |
744 | u32 rsvd[30]; | 1058 | u32 rsvd[31]; |
745 | }; | 1059 | }; |
746 | 1060 | ||
747 | struct be_cmd_resp_query_fw_cfg { | 1061 | struct be_cmd_resp_query_fw_cfg { |
@@ -751,6 +1065,26 @@ struct be_cmd_resp_query_fw_cfg { | |||
751 | u32 phys_port; | 1065 | u32 phys_port; |
752 | u32 function_mode; | 1066 | u32 function_mode; |
753 | u32 rsvd[26]; | 1067 | u32 rsvd[26]; |
1068 | u32 function_caps; | ||
1069 | }; | ||
1070 | |||
1071 | /******************** RSS Config *******************/ | ||
1072 | /* RSS types */ | ||
1073 | #define RSS_ENABLE_NONE 0x0 | ||
1074 | #define RSS_ENABLE_IPV4 0x1 | ||
1075 | #define RSS_ENABLE_TCP_IPV4 0x2 | ||
1076 | #define RSS_ENABLE_IPV6 0x4 | ||
1077 | #define RSS_ENABLE_TCP_IPV6 0x8 | ||
1078 | |||
1079 | struct be_cmd_req_rss_config { | ||
1080 | struct be_cmd_req_hdr hdr; | ||
1081 | u32 if_id; | ||
1082 | u16 enable_rss; | ||
1083 | u16 cpu_table_size_log2; | ||
1084 | u32 hash[10]; | ||
1085 | u8 cpu_table[128]; | ||
1086 | u8 flush; | ||
1087 | u8 rsvd0[3]; | ||
754 | }; | 1088 | }; |
755 | 1089 | ||
756 | /******************** Port Beacon ***************************/ | 1090 | /******************** Port Beacon ***************************/ |
@@ -798,6 +1132,36 @@ struct be_cmd_write_flashrom { | |||
798 | struct flashrom_params params; | 1132 | struct flashrom_params params; |
799 | }; | 1133 | }; |
800 | 1134 | ||
1135 | /**************** Lancer Firmware Flash ************/ | ||
1136 | struct amap_lancer_write_obj_context { | ||
1137 | u8 write_length[24]; | ||
1138 | u8 reserved1[7]; | ||
1139 | u8 eof; | ||
1140 | } __packed; | ||
1141 | |||
1142 | struct lancer_cmd_req_write_object { | ||
1143 | struct be_cmd_req_hdr hdr; | ||
1144 | u8 context[sizeof(struct amap_lancer_write_obj_context) / 8]; | ||
1145 | u32 write_offset; | ||
1146 | u8 object_name[104]; | ||
1147 | u32 descriptor_count; | ||
1148 | u32 buf_len; | ||
1149 | u32 addr_low; | ||
1150 | u32 addr_high; | ||
1151 | }; | ||
1152 | |||
1153 | struct lancer_cmd_resp_write_object { | ||
1154 | u8 opcode; | ||
1155 | u8 subsystem; | ||
1156 | u8 rsvd1[2]; | ||
1157 | u8 status; | ||
1158 | u8 additional_status; | ||
1159 | u8 rsvd2[2]; | ||
1160 | u32 resp_len; | ||
1161 | u32 actual_resp_len; | ||
1162 | u32 actual_write_len; | ||
1163 | }; | ||
1164 | |||
801 | /************************ WOL *******************************/ | 1165 | /************************ WOL *******************************/ |
802 | struct be_cmd_req_acpi_wol_magic_config{ | 1166 | struct be_cmd_req_acpi_wol_magic_config{ |
803 | struct be_cmd_req_hdr hdr; | 1167 | struct be_cmd_req_hdr hdr; |
@@ -911,17 +1275,192 @@ struct be_cmd_resp_set_qos { | |||
911 | u32 rsvd; | 1275 | u32 rsvd; |
912 | }; | 1276 | }; |
913 | 1277 | ||
1278 | /*********************** Controller Attributes ***********************/ | ||
1279 | struct be_cmd_req_cntl_attribs { | ||
1280 | struct be_cmd_req_hdr hdr; | ||
1281 | }; | ||
1282 | |||
1283 | struct be_cmd_resp_cntl_attribs { | ||
1284 | struct be_cmd_resp_hdr hdr; | ||
1285 | struct mgmt_controller_attrib attribs; | ||
1286 | }; | ||
1287 | |||
1288 | /*********************** Set driver function ***********************/ | ||
1289 | #define CAPABILITY_SW_TIMESTAMPS 2 | ||
1290 | #define CAPABILITY_BE3_NATIVE_ERX_API 4 | ||
1291 | |||
1292 | struct be_cmd_req_set_func_cap { | ||
1293 | struct be_cmd_req_hdr hdr; | ||
1294 | u32 valid_cap_flags; | ||
1295 | u32 cap_flags; | ||
1296 | u8 rsvd[212]; | ||
1297 | }; | ||
1298 | |||
1299 | struct be_cmd_resp_set_func_cap { | ||
1300 | struct be_cmd_resp_hdr hdr; | ||
1301 | u32 valid_cap_flags; | ||
1302 | u32 cap_flags; | ||
1303 | u8 rsvd[212]; | ||
1304 | }; | ||
1305 | |||
1306 | /*************** HW Stats Get v1 **********************************/ | ||
1307 | #define BE_TXP_SW_SZ 48 | ||
1308 | struct be_port_rxf_stats_v1 { | ||
1309 | u32 rsvd0[12]; | ||
1310 | u32 rx_crc_errors; | ||
1311 | u32 rx_alignment_symbol_errors; | ||
1312 | u32 rx_pause_frames; | ||
1313 | u32 rx_priority_pause_frames; | ||
1314 | u32 rx_control_frames; | ||
1315 | u32 rx_in_range_errors; | ||
1316 | u32 rx_out_range_errors; | ||
1317 | u32 rx_frame_too_long; | ||
1318 | u32 rx_address_match_errors; | ||
1319 | u32 rx_dropped_too_small; | ||
1320 | u32 rx_dropped_too_short; | ||
1321 | u32 rx_dropped_header_too_small; | ||
1322 | u32 rx_dropped_tcp_length; | ||
1323 | u32 rx_dropped_runt; | ||
1324 | u32 rsvd1[10]; | ||
1325 | u32 rx_ip_checksum_errs; | ||
1326 | u32 rx_tcp_checksum_errs; | ||
1327 | u32 rx_udp_checksum_errs; | ||
1328 | u32 rsvd2[7]; | ||
1329 | u32 rx_switched_unicast_packets; | ||
1330 | u32 rx_switched_multicast_packets; | ||
1331 | u32 rx_switched_broadcast_packets; | ||
1332 | u32 rsvd3[3]; | ||
1333 | u32 tx_pauseframes; | ||
1334 | u32 tx_priority_pauseframes; | ||
1335 | u32 tx_controlframes; | ||
1336 | u32 rsvd4[10]; | ||
1337 | u32 rxpp_fifo_overflow_drop; | ||
1338 | u32 rx_input_fifo_overflow_drop; | ||
1339 | u32 pmem_fifo_overflow_drop; | ||
1340 | u32 jabber_events; | ||
1341 | u32 rsvd5[3]; | ||
1342 | }; | ||
1343 | |||
1344 | |||
1345 | struct be_rxf_stats_v1 { | ||
1346 | struct be_port_rxf_stats_v1 port[4]; | ||
1347 | u32 rsvd0[2]; | ||
1348 | u32 rx_drops_no_pbuf; | ||
1349 | u32 rx_drops_no_txpb; | ||
1350 | u32 rx_drops_no_erx_descr; | ||
1351 | u32 rx_drops_no_tpre_descr; | ||
1352 | u32 rsvd1[6]; | ||
1353 | u32 rx_drops_too_many_frags; | ||
1354 | u32 rx_drops_invalid_ring; | ||
1355 | u32 forwarded_packets; | ||
1356 | u32 rx_drops_mtu; | ||
1357 | u32 rsvd2[14]; | ||
1358 | }; | ||
1359 | |||
1360 | struct be_erx_stats_v1 { | ||
1361 | u32 rx_drops_no_fragments[68]; /* dwordS 0 to 67*/ | ||
1362 | u32 rsvd[4]; | ||
1363 | }; | ||
1364 | |||
1365 | struct be_hw_stats_v1 { | ||
1366 | struct be_rxf_stats_v1 rxf; | ||
1367 | u32 rsvd0[BE_TXP_SW_SZ]; | ||
1368 | struct be_erx_stats_v1 erx; | ||
1369 | struct be_pmem_stats pmem; | ||
1370 | u32 rsvd1[3]; | ||
1371 | }; | ||
1372 | |||
1373 | struct be_cmd_req_get_stats_v1 { | ||
1374 | struct be_cmd_req_hdr hdr; | ||
1375 | u8 rsvd[sizeof(struct be_hw_stats_v1)]; | ||
1376 | }; | ||
1377 | |||
1378 | struct be_cmd_resp_get_stats_v1 { | ||
1379 | struct be_cmd_resp_hdr hdr; | ||
1380 | struct be_hw_stats_v1 hw_stats; | ||
1381 | }; | ||
1382 | |||
1383 | static inline void * | ||
1384 | hw_stats_from_cmd(struct be_adapter *adapter) | ||
1385 | { | ||
1386 | if (adapter->generation == BE_GEN3) { | ||
1387 | struct be_cmd_resp_get_stats_v1 *cmd = adapter->stats_cmd.va; | ||
1388 | |||
1389 | return &cmd->hw_stats; | ||
1390 | } else { | ||
1391 | struct be_cmd_resp_get_stats_v0 *cmd = adapter->stats_cmd.va; | ||
1392 | |||
1393 | return &cmd->hw_stats; | ||
1394 | } | ||
1395 | } | ||
1396 | |||
1397 | static inline void *be_port_rxf_stats_from_cmd(struct be_adapter *adapter) | ||
1398 | { | ||
1399 | if (adapter->generation == BE_GEN3) { | ||
1400 | struct be_hw_stats_v1 *hw_stats = hw_stats_from_cmd(adapter); | ||
1401 | struct be_rxf_stats_v1 *rxf_stats = &hw_stats->rxf; | ||
1402 | |||
1403 | return &rxf_stats->port[adapter->port_num]; | ||
1404 | } else { | ||
1405 | struct be_hw_stats_v0 *hw_stats = hw_stats_from_cmd(adapter); | ||
1406 | struct be_rxf_stats_v0 *rxf_stats = &hw_stats->rxf; | ||
1407 | |||
1408 | return &rxf_stats->port[adapter->port_num]; | ||
1409 | } | ||
1410 | } | ||
1411 | |||
1412 | static inline void *be_rxf_stats_from_cmd(struct be_adapter *adapter) | ||
1413 | { | ||
1414 | if (adapter->generation == BE_GEN3) { | ||
1415 | struct be_hw_stats_v1 *hw_stats = hw_stats_from_cmd(adapter); | ||
1416 | |||
1417 | return &hw_stats->rxf; | ||
1418 | } else { | ||
1419 | struct be_hw_stats_v0 *hw_stats = hw_stats_from_cmd(adapter); | ||
1420 | |||
1421 | return &hw_stats->rxf; | ||
1422 | } | ||
1423 | } | ||
1424 | |||
1425 | static inline void *be_erx_stats_from_cmd(struct be_adapter *adapter) | ||
1426 | { | ||
1427 | if (adapter->generation == BE_GEN3) { | ||
1428 | struct be_hw_stats_v1 *hw_stats = hw_stats_from_cmd(adapter); | ||
1429 | |||
1430 | return &hw_stats->erx; | ||
1431 | } else { | ||
1432 | struct be_hw_stats_v0 *hw_stats = hw_stats_from_cmd(adapter); | ||
1433 | |||
1434 | return &hw_stats->erx; | ||
1435 | } | ||
1436 | } | ||
1437 | |||
1438 | static inline void *be_pmem_stats_from_cmd(struct be_adapter *adapter) | ||
1439 | { | ||
1440 | if (adapter->generation == BE_GEN3) { | ||
1441 | struct be_hw_stats_v1 *hw_stats = hw_stats_from_cmd(adapter); | ||
1442 | |||
1443 | return &hw_stats->pmem; | ||
1444 | } else { | ||
1445 | struct be_hw_stats_v0 *hw_stats = hw_stats_from_cmd(adapter); | ||
1446 | |||
1447 | return &hw_stats->pmem; | ||
1448 | } | ||
1449 | } | ||
1450 | |||
914 | extern int be_pci_fnum_get(struct be_adapter *adapter); | 1451 | extern int be_pci_fnum_get(struct be_adapter *adapter); |
915 | extern int be_cmd_POST(struct be_adapter *adapter); | 1452 | extern int be_cmd_POST(struct be_adapter *adapter); |
916 | extern int be_cmd_mac_addr_query(struct be_adapter *adapter, u8 *mac_addr, | 1453 | extern int be_cmd_mac_addr_query(struct be_adapter *adapter, u8 *mac_addr, |
917 | u8 type, bool permanent, u32 if_handle); | 1454 | u8 type, bool permanent, u32 if_handle); |
918 | extern int be_cmd_pmac_add(struct be_adapter *adapter, u8 *mac_addr, | 1455 | extern int be_cmd_pmac_add(struct be_adapter *adapter, u8 *mac_addr, |
919 | u32 if_id, u32 *pmac_id); | 1456 | u32 if_id, u32 *pmac_id, u32 domain); |
920 | extern int be_cmd_pmac_del(struct be_adapter *adapter, u32 if_id, u32 pmac_id); | 1457 | extern int be_cmd_pmac_del(struct be_adapter *adapter, u32 if_id, |
1458 | u32 pmac_id, u32 domain); | ||
921 | extern int be_cmd_if_create(struct be_adapter *adapter, u32 cap_flags, | 1459 | extern int be_cmd_if_create(struct be_adapter *adapter, u32 cap_flags, |
922 | u32 en_flags, u8 *mac, bool pmac_invalid, | 1460 | u32 en_flags, u8 *mac, bool pmac_invalid, |
923 | u32 *if_handle, u32 *pmac_id, u32 domain); | 1461 | u32 *if_handle, u32 *pmac_id, u32 domain); |
924 | extern int be_cmd_if_destroy(struct be_adapter *adapter, u32 if_handle); | 1462 | extern int be_cmd_if_destroy(struct be_adapter *adapter, u32 if_handle, |
1463 | u32 domain); | ||
925 | extern int be_cmd_eq_create(struct be_adapter *adapter, | 1464 | extern int be_cmd_eq_create(struct be_adapter *adapter, |
926 | struct be_queue_info *eq, int eq_delay); | 1465 | struct be_queue_info *eq, int eq_delay); |
927 | extern int be_cmd_cq_create(struct be_adapter *adapter, | 1466 | extern int be_cmd_cq_create(struct be_adapter *adapter, |
@@ -937,22 +1476,23 @@ extern int be_cmd_txq_create(struct be_adapter *adapter, | |||
937 | extern int be_cmd_rxq_create(struct be_adapter *adapter, | 1476 | extern int be_cmd_rxq_create(struct be_adapter *adapter, |
938 | struct be_queue_info *rxq, u16 cq_id, | 1477 | struct be_queue_info *rxq, u16 cq_id, |
939 | u16 frag_size, u16 max_frame_size, u32 if_id, | 1478 | u16 frag_size, u16 max_frame_size, u32 if_id, |
940 | u32 rss); | 1479 | u32 rss, u8 *rss_id); |
941 | extern int be_cmd_q_destroy(struct be_adapter *adapter, struct be_queue_info *q, | 1480 | extern int be_cmd_q_destroy(struct be_adapter *adapter, struct be_queue_info *q, |
942 | int type); | 1481 | int type); |
943 | extern int be_cmd_link_status_query(struct be_adapter *adapter, | 1482 | extern int be_cmd_link_status_query(struct be_adapter *adapter, |
944 | bool *link_up, u8 *mac_speed, u16 *link_speed); | 1483 | bool *link_up, u8 *mac_speed, u16 *link_speed, u32 dom); |
945 | extern int be_cmd_reset(struct be_adapter *adapter); | 1484 | extern int be_cmd_reset(struct be_adapter *adapter); |
946 | extern int be_cmd_get_stats(struct be_adapter *adapter, | 1485 | extern int be_cmd_get_stats(struct be_adapter *adapter, |
947 | struct be_dma_mem *nonemb_cmd); | 1486 | struct be_dma_mem *nonemb_cmd); |
1487 | extern int lancer_cmd_get_pport_stats(struct be_adapter *adapter, | ||
1488 | struct be_dma_mem *nonemb_cmd); | ||
948 | extern int be_cmd_get_fw_ver(struct be_adapter *adapter, char *fw_ver); | 1489 | extern int be_cmd_get_fw_ver(struct be_adapter *adapter, char *fw_ver); |
949 | 1490 | ||
950 | extern int be_cmd_modify_eqd(struct be_adapter *adapter, u32 eq_id, u32 eqd); | 1491 | extern int be_cmd_modify_eqd(struct be_adapter *adapter, u32 eq_id, u32 eqd); |
951 | extern int be_cmd_vlan_config(struct be_adapter *adapter, u32 if_id, | 1492 | extern int be_cmd_vlan_config(struct be_adapter *adapter, u32 if_id, |
952 | u16 *vtag_array, u32 num, bool untagged, | 1493 | u16 *vtag_array, u32 num, bool untagged, |
953 | bool promiscuous); | 1494 | bool promiscuous); |
954 | extern int be_cmd_promiscuous_config(struct be_adapter *adapter, | 1495 | extern int be_cmd_promiscuous_config(struct be_adapter *adapter, bool en); |
955 | u8 port_num, bool en); | ||
956 | extern int be_cmd_multicast_set(struct be_adapter *adapter, u32 if_id, | 1496 | extern int be_cmd_multicast_set(struct be_adapter *adapter, u32 if_id, |
957 | struct net_device *netdev, struct be_dma_mem *mem); | 1497 | struct net_device *netdev, struct be_dma_mem *mem); |
958 | extern int be_cmd_set_flow_control(struct be_adapter *adapter, | 1498 | extern int be_cmd_set_flow_control(struct be_adapter *adapter, |
@@ -960,18 +1500,23 @@ extern int be_cmd_set_flow_control(struct be_adapter *adapter, | |||
960 | extern int be_cmd_get_flow_control(struct be_adapter *adapter, | 1500 | extern int be_cmd_get_flow_control(struct be_adapter *adapter, |
961 | u32 *tx_fc, u32 *rx_fc); | 1501 | u32 *tx_fc, u32 *rx_fc); |
962 | extern int be_cmd_query_fw_cfg(struct be_adapter *adapter, | 1502 | extern int be_cmd_query_fw_cfg(struct be_adapter *adapter, |
963 | u32 *port_num, u32 *cap); | 1503 | u32 *port_num, u32 *function_mode, u32 *function_caps); |
964 | extern int be_cmd_reset_function(struct be_adapter *adapter); | 1504 | extern int be_cmd_reset_function(struct be_adapter *adapter); |
1505 | extern int be_cmd_rss_config(struct be_adapter *adapter, u8 *rsstable, | ||
1506 | u16 table_size); | ||
965 | extern int be_process_mcc(struct be_adapter *adapter, int *status); | 1507 | extern int be_process_mcc(struct be_adapter *adapter, int *status); |
966 | extern int be_cmd_set_beacon_state(struct be_adapter *adapter, | 1508 | extern int be_cmd_set_beacon_state(struct be_adapter *adapter, |
967 | u8 port_num, u8 beacon, u8 status, u8 state); | 1509 | u8 port_num, u8 beacon, u8 status, u8 state); |
968 | extern int be_cmd_get_beacon_state(struct be_adapter *adapter, | 1510 | extern int be_cmd_get_beacon_state(struct be_adapter *adapter, |
969 | u8 port_num, u32 *state); | 1511 | u8 port_num, u32 *state); |
970 | extern int be_cmd_read_port_type(struct be_adapter *adapter, u32 port, | ||
971 | u8 *connector); | ||
972 | extern int be_cmd_write_flashrom(struct be_adapter *adapter, | 1512 | extern int be_cmd_write_flashrom(struct be_adapter *adapter, |
973 | struct be_dma_mem *cmd, u32 flash_oper, | 1513 | struct be_dma_mem *cmd, u32 flash_oper, |
974 | u32 flash_opcode, u32 buf_size); | 1514 | u32 flash_opcode, u32 buf_size); |
1515 | extern int lancer_cmd_write_object(struct be_adapter *adapter, | ||
1516 | struct be_dma_mem *cmd, | ||
1517 | u32 data_size, u32 data_offset, | ||
1518 | const char *obj_name, | ||
1519 | u32 *data_written, u8 *addn_status); | ||
975 | int be_cmd_get_flash_crc(struct be_adapter *adapter, u8 *flashed_crc, | 1520 | int be_cmd_get_flash_crc(struct be_adapter *adapter, u8 *flashed_crc, |
976 | int offset); | 1521 | int offset); |
977 | extern int be_cmd_enable_magic_wol(struct be_adapter *adapter, u8 *mac, | 1522 | extern int be_cmd_enable_magic_wol(struct be_adapter *adapter, u8 *mac, |
@@ -993,4 +1538,9 @@ extern int be_cmd_get_phy_info(struct be_adapter *adapter, | |||
993 | struct be_dma_mem *cmd); | 1538 | struct be_dma_mem *cmd); |
994 | extern int be_cmd_set_qos(struct be_adapter *adapter, u32 bps, u32 domain); | 1539 | extern int be_cmd_set_qos(struct be_adapter *adapter, u32 bps, u32 domain); |
995 | extern void be_detect_dump_ue(struct be_adapter *adapter); | 1540 | extern void be_detect_dump_ue(struct be_adapter *adapter); |
1541 | extern int be_cmd_get_die_temperature(struct be_adapter *adapter); | ||
1542 | extern int be_cmd_get_cntl_attributes(struct be_adapter *adapter); | ||
1543 | extern int be_cmd_check_native_mode(struct be_adapter *adapter); | ||
1544 | extern int be_cmd_get_reg_len(struct be_adapter *adapter, u32 *log_size); | ||
1545 | extern void be_cmd_get_regs(struct be_adapter *adapter, u32 buf_len, void *buf); | ||
996 | 1546 | ||