aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/benet/be_cmds.h
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/net/benet/be_cmds.h')
-rw-r--r--drivers/net/benet/be_cmds.h658
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
86struct be_async_event_trailer { 92struct 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 */
117struct 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 */
128struct 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 */
141struct 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
108struct be_mcc_mailbox { 150struct 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 */
281struct amap_cq_context { 331struct 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
354struct 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
304struct be_cmd_req_cq_create { 370struct 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
312struct be_cmd_resp_cq_create { 380struct 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
386struct 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
395struct 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 */
321struct amap_mcc_context { 407struct 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
422struct 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
336struct be_cmd_req_mcc_create { 433struct 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 */
356struct amap_tx_context { 454struct 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 {
409struct be_cmd_resp_eth_rx_create { 507struct 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 **********************************/
474struct be_port_rxf_stats { 573struct 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
543struct be_rxf_stats { 642struct 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
564struct be_erx_stats { 666struct 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*/ 671struct be_pmem_stats {
672 u32 eth_red_drops;
673 u32 rsvd[5];
570}; 674};
571 675
572struct be_hw_stats { 676struct 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
683struct be_cmd_req_get_stats_v0 {
684 struct be_cmd_req_hdr hdr;
685 u8 rsvd[sizeof(struct be_hw_stats_v0)];
686};
687
688struct 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)
694struct 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
861struct pport_stats_params {
862 u16 pport_num;
863 u8 rsvd;
864 u8 reset_stats;
576}; 865};
577 866
578struct be_cmd_req_get_stats { 867struct 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
875struct lancer_cmd_resp_pport_stats {
876 struct be_cmd_resp_hdr hdr;
877 struct lancer_cmd_pport_stats pport_stats;
878};
879
880static 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
887struct be_cmd_req_get_cntl_addnl_attribs {
888 struct be_cmd_req_hdr hdr;
889 u8 rsvd[8];
581}; 890};
582 891
583struct be_cmd_resp_get_stats { 892struct 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
588struct be_cmd_req_vlan_config { 901struct 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
597struct 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 */
606struct macaddr { 912struct 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
618static inline struct be_hw_stats * 924/******************* RX FILTER ******************************/
619hw_stats_from_cmd(struct be_cmd_resp_get_stats *cmd) 925struct 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 *******************/
625struct be_cmd_req_link_status { 938struct 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
742struct be_cmd_req_query_fw_cfg { 1056struct 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
747struct be_cmd_resp_query_fw_cfg { 1061struct 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
1079struct 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 ************/
1136struct amap_lancer_write_obj_context {
1137 u8 write_length[24];
1138 u8 reserved1[7];
1139 u8 eof;
1140} __packed;
1141
1142struct 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
1153struct 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 *******************************/
802struct be_cmd_req_acpi_wol_magic_config{ 1166struct 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 ***********************/
1279struct be_cmd_req_cntl_attribs {
1280 struct be_cmd_req_hdr hdr;
1281};
1282
1283struct 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
1292struct 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
1299struct 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
1308struct 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
1345struct 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
1360struct be_erx_stats_v1 {
1361 u32 rx_drops_no_fragments[68]; /* dwordS 0 to 67*/
1362 u32 rsvd[4];
1363};
1364
1365struct 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
1373struct be_cmd_req_get_stats_v1 {
1374 struct be_cmd_req_hdr hdr;
1375 u8 rsvd[sizeof(struct be_hw_stats_v1)];
1376};
1377
1378struct be_cmd_resp_get_stats_v1 {
1379 struct be_cmd_resp_hdr hdr;
1380 struct be_hw_stats_v1 hw_stats;
1381};
1382
1383static inline void *
1384hw_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
1397static 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
1412static 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
1425static 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
1438static 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
914extern int be_pci_fnum_get(struct be_adapter *adapter); 1451extern int be_pci_fnum_get(struct be_adapter *adapter);
915extern int be_cmd_POST(struct be_adapter *adapter); 1452extern int be_cmd_POST(struct be_adapter *adapter);
916extern int be_cmd_mac_addr_query(struct be_adapter *adapter, u8 *mac_addr, 1453extern 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);
918extern int be_cmd_pmac_add(struct be_adapter *adapter, u8 *mac_addr, 1455extern 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);
920extern int be_cmd_pmac_del(struct be_adapter *adapter, u32 if_id, u32 pmac_id); 1457extern int be_cmd_pmac_del(struct be_adapter *adapter, u32 if_id,
1458 u32 pmac_id, u32 domain);
921extern int be_cmd_if_create(struct be_adapter *adapter, u32 cap_flags, 1459extern 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);
924extern int be_cmd_if_destroy(struct be_adapter *adapter, u32 if_handle); 1462extern int be_cmd_if_destroy(struct be_adapter *adapter, u32 if_handle,
1463 u32 domain);
925extern int be_cmd_eq_create(struct be_adapter *adapter, 1464extern 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);
927extern int be_cmd_cq_create(struct be_adapter *adapter, 1466extern int be_cmd_cq_create(struct be_adapter *adapter,
@@ -937,22 +1476,23 @@ extern int be_cmd_txq_create(struct be_adapter *adapter,
937extern int be_cmd_rxq_create(struct be_adapter *adapter, 1476extern 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);
941extern int be_cmd_q_destroy(struct be_adapter *adapter, struct be_queue_info *q, 1480extern int be_cmd_q_destroy(struct be_adapter *adapter, struct be_queue_info *q,
942 int type); 1481 int type);
943extern int be_cmd_link_status_query(struct be_adapter *adapter, 1482extern 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);
945extern int be_cmd_reset(struct be_adapter *adapter); 1484extern int be_cmd_reset(struct be_adapter *adapter);
946extern int be_cmd_get_stats(struct be_adapter *adapter, 1485extern int be_cmd_get_stats(struct be_adapter *adapter,
947 struct be_dma_mem *nonemb_cmd); 1486 struct be_dma_mem *nonemb_cmd);
1487extern int lancer_cmd_get_pport_stats(struct be_adapter *adapter,
1488 struct be_dma_mem *nonemb_cmd);
948extern int be_cmd_get_fw_ver(struct be_adapter *adapter, char *fw_ver); 1489extern int be_cmd_get_fw_ver(struct be_adapter *adapter, char *fw_ver);
949 1490
950extern int be_cmd_modify_eqd(struct be_adapter *adapter, u32 eq_id, u32 eqd); 1491extern int be_cmd_modify_eqd(struct be_adapter *adapter, u32 eq_id, u32 eqd);
951extern int be_cmd_vlan_config(struct be_adapter *adapter, u32 if_id, 1492extern 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);
954extern int be_cmd_promiscuous_config(struct be_adapter *adapter, 1495extern int be_cmd_promiscuous_config(struct be_adapter *adapter, bool en);
955 u8 port_num, bool en);
956extern int be_cmd_multicast_set(struct be_adapter *adapter, u32 if_id, 1496extern 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);
958extern int be_cmd_set_flow_control(struct be_adapter *adapter, 1498extern 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,
960extern int be_cmd_get_flow_control(struct be_adapter *adapter, 1500extern int be_cmd_get_flow_control(struct be_adapter *adapter,
961 u32 *tx_fc, u32 *rx_fc); 1501 u32 *tx_fc, u32 *rx_fc);
962extern int be_cmd_query_fw_cfg(struct be_adapter *adapter, 1502extern 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);
964extern int be_cmd_reset_function(struct be_adapter *adapter); 1504extern int be_cmd_reset_function(struct be_adapter *adapter);
1505extern int be_cmd_rss_config(struct be_adapter *adapter, u8 *rsstable,
1506 u16 table_size);
965extern int be_process_mcc(struct be_adapter *adapter, int *status); 1507extern int be_process_mcc(struct be_adapter *adapter, int *status);
966extern int be_cmd_set_beacon_state(struct be_adapter *adapter, 1508extern 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);
968extern int be_cmd_get_beacon_state(struct be_adapter *adapter, 1510extern int be_cmd_get_beacon_state(struct be_adapter *adapter,
969 u8 port_num, u32 *state); 1511 u8 port_num, u32 *state);
970extern int be_cmd_read_port_type(struct be_adapter *adapter, u32 port,
971 u8 *connector);
972extern int be_cmd_write_flashrom(struct be_adapter *adapter, 1512extern 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);
1515extern 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);
975int be_cmd_get_flash_crc(struct be_adapter *adapter, u8 *flashed_crc, 1520int be_cmd_get_flash_crc(struct be_adapter *adapter, u8 *flashed_crc,
976 int offset); 1521 int offset);
977extern int be_cmd_enable_magic_wol(struct be_adapter *adapter, u8 *mac, 1522extern 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);
994extern int be_cmd_set_qos(struct be_adapter *adapter, u32 bps, u32 domain); 1539extern int be_cmd_set_qos(struct be_adapter *adapter, u32 bps, u32 domain);
995extern void be_detect_dump_ue(struct be_adapter *adapter); 1540extern void be_detect_dump_ue(struct be_adapter *adapter);
1541extern int be_cmd_get_die_temperature(struct be_adapter *adapter);
1542extern int be_cmd_get_cntl_attributes(struct be_adapter *adapter);
1543extern int be_cmd_check_native_mode(struct be_adapter *adapter);
1544extern int be_cmd_get_reg_len(struct be_adapter *adapter, u32 *log_size);
1545extern void be_cmd_get_regs(struct be_adapter *adapter, u32 buf_len, void *buf);
996 1546