xref: /dpdk/drivers/net/bnx2x/ecore_mfw_req.h (revision 0cb4150f82ff77e1c74826ae425f36388d9172fb)
1688654bfSRasesh Mody /* SPDX-License-Identifier: BSD-3-Clause
29eb5dc09SRasesh Mody  * Copyright (c) 2007-2013 Broadcom Corporation.
3b5bf7719SStephen Hemminger  *
4b5bf7719SStephen Hemminger  * Eric Davis        <edavis@broadcom.com>
5b5bf7719SStephen Hemminger  * David Christensen <davidch@broadcom.com>
6b5bf7719SStephen Hemminger  * Gary Zambrano     <zambrano@broadcom.com>
7b5bf7719SStephen Hemminger  *
8e3de5dadSRasesh Mody  * Copyright (c) 2014-2018 Cavium Inc.
9059113ccSRasesh Mody  * All rights reserved.
10e3de5dadSRasesh Mody  * www.cavium.com
11b5bf7719SStephen Hemminger  */
12b5bf7719SStephen Hemminger 
13b5bf7719SStephen Hemminger #ifndef ECORE_MFW_REQ_H
14b5bf7719SStephen Hemminger #define ECORE_MFW_REQ_H
15b5bf7719SStephen Hemminger 
16b5bf7719SStephen Hemminger 
17b5bf7719SStephen Hemminger #define PORT_0              0
18b5bf7719SStephen Hemminger #define PORT_1              1
19b5bf7719SStephen Hemminger #define PORT_MAX            2
20b5bf7719SStephen Hemminger #define NVM_PATH_MAX        2
21b5bf7719SStephen Hemminger 
22b5bf7719SStephen Hemminger /* FCoE capabilities required from the driver */
23b5bf7719SStephen Hemminger struct fcoe_capabilities {
24b5bf7719SStephen Hemminger 	uint32_t capability1;
25b5bf7719SStephen Hemminger 	/* Maximum number of I/Os per connection */
26b5bf7719SStephen Hemminger 	#define FCOE_IOS_PER_CONNECTION_MASK    0x0000ffff
27b5bf7719SStephen Hemminger 	#define FCOE_IOS_PER_CONNECTION_SHIFT   0
28b5bf7719SStephen Hemminger 	/* Maximum number of Logins per port */
29b5bf7719SStephen Hemminger 	#define FCOE_LOGINS_PER_PORT_MASK       0xffff0000
30b5bf7719SStephen Hemminger 	#define FCOE_LOGINS_PER_PORT_SHIFT   16
31b5bf7719SStephen Hemminger 
32b5bf7719SStephen Hemminger 	uint32_t capability2;
33b5bf7719SStephen Hemminger 	/* Maximum number of exchanges */
34b5bf7719SStephen Hemminger 	#define FCOE_NUMBER_OF_EXCHANGES_MASK   0x0000ffff
35b5bf7719SStephen Hemminger 	#define FCOE_NUMBER_OF_EXCHANGES_SHIFT  0
36b5bf7719SStephen Hemminger 	/* Maximum NPIV WWN per port */
37b5bf7719SStephen Hemminger 	#define FCOE_NPIV_WWN_PER_PORT_MASK     0xffff0000
38b5bf7719SStephen Hemminger 	#define FCOE_NPIV_WWN_PER_PORT_SHIFT    16
39b5bf7719SStephen Hemminger 
40b5bf7719SStephen Hemminger 	uint32_t capability3;
41b5bf7719SStephen Hemminger 	/* Maximum number of targets supported */
42b5bf7719SStephen Hemminger 	#define FCOE_TARGETS_SUPPORTED_MASK     0x0000ffff
43b5bf7719SStephen Hemminger 	#define FCOE_TARGETS_SUPPORTED_SHIFT    0
44b5bf7719SStephen Hemminger 	/* Maximum number of outstanding commands across all connections */
45b5bf7719SStephen Hemminger 	#define FCOE_OUTSTANDING_COMMANDS_MASK  0xffff0000
46b5bf7719SStephen Hemminger 	#define FCOE_OUTSTANDING_COMMANDS_SHIFT 16
47b5bf7719SStephen Hemminger 
48b5bf7719SStephen Hemminger 	uint32_t capability4;
49b5bf7719SStephen Hemminger 	#define FCOE_CAPABILITY4_STATEFUL       		0x00000001
50b5bf7719SStephen Hemminger 	#define FCOE_CAPABILITY4_STATELESS      		0x00000002
51b5bf7719SStephen Hemminger 	#define FCOE_CAPABILITY4_CAPABILITIES_REPORTED_VALID   	0x00000004
52b5bf7719SStephen Hemminger };
53b5bf7719SStephen Hemminger 
54b5bf7719SStephen Hemminger struct glob_ncsi_oem_data
55b5bf7719SStephen Hemminger {
56b5bf7719SStephen Hemminger 	uint32_t driver_version;
57b5bf7719SStephen Hemminger 	uint32_t unused[3];
58b5bf7719SStephen Hemminger 	struct fcoe_capabilities fcoe_features[NVM_PATH_MAX][PORT_MAX];
59b5bf7719SStephen Hemminger };
60b5bf7719SStephen Hemminger 
61b5bf7719SStephen Hemminger /* current drv_info version */
62b5bf7719SStephen Hemminger #define DRV_INFO_CUR_VER 2
63b5bf7719SStephen Hemminger 
64b5bf7719SStephen Hemminger /* drv_info op codes supported */
65b5bf7719SStephen Hemminger enum drv_info_opcode {
66b5bf7719SStephen Hemminger 	ETH_STATS_OPCODE,
67b5bf7719SStephen Hemminger 	FCOE_STATS_OPCODE,
68b5bf7719SStephen Hemminger 	ISCSI_STATS_OPCODE
69b5bf7719SStephen Hemminger };
70b5bf7719SStephen Hemminger 
71b5bf7719SStephen Hemminger #define ETH_STAT_INFO_VERSION_LEN	12
72b5bf7719SStephen Hemminger /*  Per PCI Function Ethernet Statistics required from the driver */
73b5bf7719SStephen Hemminger struct eth_stats_info {
74b5bf7719SStephen Hemminger 	/* Function's Driver Version. padded to 12 */
75b5bf7719SStephen Hemminger 	char version[ETH_STAT_INFO_VERSION_LEN];
76b5bf7719SStephen Hemminger 	/* Locally Admin Addr. BigEndian EIU48. Actual size is 6 bytes */
77b5bf7719SStephen Hemminger 	uint8_t mac_local[8];
78b5bf7719SStephen Hemminger 	uint8_t mac_add1[8];		/* Additional Programmed MAC Addr 1. */
79b5bf7719SStephen Hemminger 	uint8_t mac_add2[8];		/* Additional Programmed MAC Addr 2. */
80b5bf7719SStephen Hemminger 	uint32_t mtu_size;		/* MTU Size. Note   : Negotiated MTU */
81b5bf7719SStephen Hemminger 	uint32_t feature_flags;	/* Feature_Flags. */
82b5bf7719SStephen Hemminger #define FEATURE_ETH_CHKSUM_OFFLOAD_MASK		0x01
83b5bf7719SStephen Hemminger #define FEATURE_ETH_LSO_MASK			0x02
84b5bf7719SStephen Hemminger #define FEATURE_ETH_BOOTMODE_MASK		0x1C
85b5bf7719SStephen Hemminger #define FEATURE_ETH_BOOTMODE_SHIFT		2
86b5bf7719SStephen Hemminger #define FEATURE_ETH_BOOTMODE_NONE		(0x0 << 2)
87b5bf7719SStephen Hemminger #define FEATURE_ETH_BOOTMODE_PXE		(0x1 << 2)
88b5bf7719SStephen Hemminger #define FEATURE_ETH_BOOTMODE_ISCSI		(0x2 << 2)
89b5bf7719SStephen Hemminger #define FEATURE_ETH_BOOTMODE_FCOE		(0x3 << 2)
90b5bf7719SStephen Hemminger #define FEATURE_ETH_TOE_MASK			0x20
91b5bf7719SStephen Hemminger 	uint32_t lso_max_size;	/* LSO MaxOffloadSize. */
92b5bf7719SStephen Hemminger 	uint32_t lso_min_seg_cnt;	/* LSO MinSegmentCount. */
93b5bf7719SStephen Hemminger 	/* Num Offloaded Connections TCP_IPv4. */
94b5bf7719SStephen Hemminger 	uint32_t ipv4_ofld_cnt;
95b5bf7719SStephen Hemminger 	/* Num Offloaded Connections TCP_IPv6. */
96b5bf7719SStephen Hemminger 	uint32_t ipv6_ofld_cnt;
97b5bf7719SStephen Hemminger 	uint32_t promiscuous_mode;	/* Promiscuous Mode. non-zero true */
98b5bf7719SStephen Hemminger 	uint32_t txq_size;		/* TX Descriptors Queue Size */
99b5bf7719SStephen Hemminger 	uint32_t rxq_size;		/* RX Descriptors Queue Size */
100b5bf7719SStephen Hemminger 	/* TX Descriptor Queue Avg Depth. % Avg Queue Depth since last poll */
101b5bf7719SStephen Hemminger 	uint32_t txq_avg_depth;
102b5bf7719SStephen Hemminger 	/* RX Descriptors Queue Avg Depth. % Avg Queue Depth since last poll */
103b5bf7719SStephen Hemminger 	uint32_t rxq_avg_depth;
104b5bf7719SStephen Hemminger 	/* IOV_Offload. 0=none; 1=MultiQueue, 2=VEB 3= VEPA*/
105b5bf7719SStephen Hemminger 	uint32_t iov_offload;
106b5bf7719SStephen Hemminger 	/* Number of NetQueue/VMQ Config'd. */
107b5bf7719SStephen Hemminger 	uint32_t netq_cnt;
108b5bf7719SStephen Hemminger 	uint32_t vf_cnt;		/* Num VF assigned to this PF. */
109b5bf7719SStephen Hemminger };
110b5bf7719SStephen Hemminger 
111b5bf7719SStephen Hemminger /*  Per PCI Function FCOE Statistics required from the driver */
112b5bf7719SStephen Hemminger struct fcoe_stats_info {
113b5bf7719SStephen Hemminger 	uint8_t version[12];		/* Function's Driver Version. */
114b5bf7719SStephen Hemminger 	uint8_t mac_local[8];	/* Locally Admin Addr. */
115b5bf7719SStephen Hemminger 	uint8_t mac_add1[8];		/* Additional Programmed MAC Addr 1. */
116b5bf7719SStephen Hemminger 	uint8_t mac_add2[8];		/* Additional Programmed MAC Addr 2. */
117b5bf7719SStephen Hemminger 	/* QoS Priority (per 802.1p). 0-7255 */
118b5bf7719SStephen Hemminger 	uint32_t qos_priority;
119b5bf7719SStephen Hemminger 	uint32_t txq_size;		/* FCoE TX Descriptors Queue Size. */
120b5bf7719SStephen Hemminger 	uint32_t rxq_size;		/* FCoE RX Descriptors Queue Size. */
121b5bf7719SStephen Hemminger 	/* FCoE TX Descriptor Queue Avg Depth. */
122b5bf7719SStephen Hemminger 	uint32_t txq_avg_depth;
123b5bf7719SStephen Hemminger 	/* FCoE RX Descriptors Queue Avg Depth. */
124b5bf7719SStephen Hemminger 	uint32_t rxq_avg_depth;
125b5bf7719SStephen Hemminger 	uint32_t rx_frames_lo;	/* FCoE RX Frames received. */
126b5bf7719SStephen Hemminger 	uint32_t rx_frames_hi;	/* FCoE RX Frames received. */
127b5bf7719SStephen Hemminger 	uint32_t rx_bytes_lo;	/* FCoE RX Bytes received. */
128b5bf7719SStephen Hemminger 	uint32_t rx_bytes_hi;	/* FCoE RX Bytes received. */
129b5bf7719SStephen Hemminger 	uint32_t tx_frames_lo;	/* FCoE TX Frames sent. */
130b5bf7719SStephen Hemminger 	uint32_t tx_frames_hi;	/* FCoE TX Frames sent. */
131b5bf7719SStephen Hemminger 	uint32_t tx_bytes_lo;	/* FCoE TX Bytes sent. */
132b5bf7719SStephen Hemminger 	uint32_t tx_bytes_hi;	/* FCoE TX Bytes sent. */
133b5bf7719SStephen Hemminger 	uint32_t rx_fcs_errors;	/* number of receive packets with FCS errors */
134b5bf7719SStephen Hemminger 	uint32_t rx_fc_crc_errors;	/* number of FC frames with CRC errors*/
135b5bf7719SStephen Hemminger 	uint32_t fip_login_failures;	/* number of FCoE/FIP Login failures */
136b5bf7719SStephen Hemminger };
137b5bf7719SStephen Hemminger 
138b5bf7719SStephen Hemminger /* Per PCI  Function iSCSI Statistics required from the driver*/
139b5bf7719SStephen Hemminger struct iscsi_stats_info {
140b5bf7719SStephen Hemminger 	uint8_t version[12];		/* Function's Driver Version. */
141b5bf7719SStephen Hemminger 	uint8_t mac_local[8];	/* Locally Admin iSCSI MAC Addr. */
142b5bf7719SStephen Hemminger 	uint8_t mac_add1[8];		/* Additional Programmed MAC Addr 1. */
143b5bf7719SStephen Hemminger 	/* QoS Priority (per 802.1p). 0-7255 */
144b5bf7719SStephen Hemminger 	uint32_t qos_priority;
145*0cb4150fSRasesh Mody #define ISCSI_QOS_PRIORITY_OFFSET	0
146*0cb4150fSRasesh Mody #define ISCSI_QOS_PRIORITY_MASK		(0xffff)
147*0cb4150fSRasesh Mody 
148*0cb4150fSRasesh Mody #define ISCSI_IP_ADDRESS_TYPE_OFFSET	30
149*0cb4150fSRasesh Mody #define ISCSI_IP_ADDRESS_TYPE_MASK	(3 << 30)
150*0cb4150fSRasesh Mody /* Driver does not have the IP address and type populated */
151*0cb4150fSRasesh Mody #define ISCSI_IP_ADDRESS_TYPE_NOT_SET	(0 << 30)
152*0cb4150fSRasesh Mody #define ISCSI_IP_ADDRESS_TYPE_IPV4	(1 << 30) /* IPV4 IP address set */
153*0cb4150fSRasesh Mody #define ISCSI_IP_ADDRESS_TYPE_IPV6	(2 << 30) /* IPV6 IP address set */
154b5bf7719SStephen Hemminger 
155b5bf7719SStephen Hemminger 	uint8_t initiator_name[64];	/* iSCSI Boot Initiator Node name. */
156b5bf7719SStephen Hemminger 
157b5bf7719SStephen Hemminger 	uint8_t ww_port_name[64];	/* iSCSI World wide port name */
158b5bf7719SStephen Hemminger 
159b5bf7719SStephen Hemminger 	uint8_t boot_target_name[64];/* iSCSI Boot Target Name. */
160b5bf7719SStephen Hemminger 
161b5bf7719SStephen Hemminger 	uint8_t boot_target_ip[16];	/* iSCSI Boot Target IP. */
162b5bf7719SStephen Hemminger 	uint32_t boot_target_portal;	/* iSCSI Boot Target Portal. */
163b5bf7719SStephen Hemminger 	uint8_t boot_init_ip[16];	/* iSCSI Boot Initiator IP Address. */
164b5bf7719SStephen Hemminger 	uint32_t max_frame_size;	/* Max Frame Size. bytes */
165b5bf7719SStephen Hemminger 	uint32_t txq_size;		/* PDU TX Descriptors Queue Size. */
166b5bf7719SStephen Hemminger 	uint32_t rxq_size;		/* PDU RX Descriptors Queue Size. */
167b5bf7719SStephen Hemminger 
168b5bf7719SStephen Hemminger 	uint32_t txq_avg_depth;	/*PDU TX Descriptor Queue Avg Depth. */
169b5bf7719SStephen Hemminger 	uint32_t rxq_avg_depth;	/*PDU RX Descriptors Queue Avg Depth. */
170b5bf7719SStephen Hemminger 	uint32_t rx_pdus_lo;		/* iSCSI PDUs received. */
171b5bf7719SStephen Hemminger 	uint32_t rx_pdus_hi;		/* iSCSI PDUs received. */
172b5bf7719SStephen Hemminger 
173b5bf7719SStephen Hemminger 	uint32_t rx_bytes_lo;	/* iSCSI RX Bytes received. */
174b5bf7719SStephen Hemminger 	uint32_t rx_bytes_hi;	/* iSCSI RX Bytes received. */
175b5bf7719SStephen Hemminger 	uint32_t tx_pdus_lo;		/* iSCSI PDUs sent. */
176b5bf7719SStephen Hemminger 	uint32_t tx_pdus_hi;		/* iSCSI PDUs sent. */
177b5bf7719SStephen Hemminger 
178b5bf7719SStephen Hemminger 	uint32_t tx_bytes_lo;	/* iSCSI PDU TX Bytes sent. */
179b5bf7719SStephen Hemminger 	uint32_t tx_bytes_hi;	/* iSCSI PDU TX Bytes sent. */
180b5bf7719SStephen Hemminger 	uint32_t pcp_prior_map_tbl;	/*C-PCP to S-PCP Priority MapTable.
181b5bf7719SStephen Hemminger 				9 nibbles, the position of each nibble
182b5bf7719SStephen Hemminger 				represents the C-PCP value, the value
183b5bf7719SStephen Hemminger 				of the nibble = S-PCP value.*/
184b5bf7719SStephen Hemminger };
185b5bf7719SStephen Hemminger 
186b5bf7719SStephen Hemminger union drv_info_to_mcp {
187b5bf7719SStephen Hemminger 	struct eth_stats_info		ether_stat;
188b5bf7719SStephen Hemminger 	struct fcoe_stats_info		fcoe_stat;
189b5bf7719SStephen Hemminger 	struct iscsi_stats_info		iscsi_stat;
190b5bf7719SStephen Hemminger };
191b5bf7719SStephen Hemminger 
192b5bf7719SStephen Hemminger #endif /* ECORE_MFW_REQ_H */
193