1*4ad79e13SYuval Mintz /* bnx2x_mfw_req.h: Qlogic Everest network driver. 22e499d3cSBarak Witkowski * 3247fa82bSYuval Mintz * Copyright (c) 2012-2013 Broadcom Corporation 4*4ad79e13SYuval Mintz * Copyright (c) 2014 QLogic Corporation 5*4ad79e13SYuval Mintz * All rights reserved 62e499d3cSBarak Witkowski * 72e499d3cSBarak Witkowski * This program is free software; you can redistribute it and/or modify 82e499d3cSBarak Witkowski * it under the terms of the GNU General Public License as published by 92e499d3cSBarak Witkowski * the Free Software Foundation. 102e499d3cSBarak Witkowski */ 112e499d3cSBarak Witkowski 122e499d3cSBarak Witkowski #ifndef BNX2X_MFW_REQ_H 132e499d3cSBarak Witkowski #define BNX2X_MFW_REQ_H 142e499d3cSBarak Witkowski 152e499d3cSBarak Witkowski #define PORT_0 0 162e499d3cSBarak Witkowski #define PORT_1 1 172e499d3cSBarak Witkowski #define PORT_MAX 2 182e499d3cSBarak Witkowski #define NVM_PATH_MAX 2 192e499d3cSBarak Witkowski 202e499d3cSBarak Witkowski /* FCoE capabilities required from the driver */ 212e499d3cSBarak Witkowski struct fcoe_capabilities { 222e499d3cSBarak Witkowski u32 capability1; 232e499d3cSBarak Witkowski /* Maximum number of I/Os per connection */ 242e499d3cSBarak Witkowski #define FCOE_IOS_PER_CONNECTION_MASK 0x0000ffff 252e499d3cSBarak Witkowski #define FCOE_IOS_PER_CONNECTION_SHIFT 0 262e499d3cSBarak Witkowski /* Maximum number of Logins per port */ 272e499d3cSBarak Witkowski #define FCOE_LOGINS_PER_PORT_MASK 0xffff0000 282e499d3cSBarak Witkowski #define FCOE_LOGINS_PER_PORT_SHIFT 16 292e499d3cSBarak Witkowski 302e499d3cSBarak Witkowski u32 capability2; 312e499d3cSBarak Witkowski /* Maximum number of exchanges */ 322e499d3cSBarak Witkowski #define FCOE_NUMBER_OF_EXCHANGES_MASK 0x0000ffff 332e499d3cSBarak Witkowski #define FCOE_NUMBER_OF_EXCHANGES_SHIFT 0 342e499d3cSBarak Witkowski /* Maximum NPIV WWN per port */ 352e499d3cSBarak Witkowski #define FCOE_NPIV_WWN_PER_PORT_MASK 0xffff0000 362e499d3cSBarak Witkowski #define FCOE_NPIV_WWN_PER_PORT_SHIFT 16 372e499d3cSBarak Witkowski 382e499d3cSBarak Witkowski u32 capability3; 392e499d3cSBarak Witkowski /* Maximum number of targets supported */ 402e499d3cSBarak Witkowski #define FCOE_TARGETS_SUPPORTED_MASK 0x0000ffff 412e499d3cSBarak Witkowski #define FCOE_TARGETS_SUPPORTED_SHIFT 0 422e499d3cSBarak Witkowski /* Maximum number of outstanding commands across all connections */ 432e499d3cSBarak Witkowski #define FCOE_OUTSTANDING_COMMANDS_MASK 0xffff0000 442e499d3cSBarak Witkowski #define FCOE_OUTSTANDING_COMMANDS_SHIFT 16 452e499d3cSBarak Witkowski 462e499d3cSBarak Witkowski u32 capability4; 472e499d3cSBarak Witkowski #define FCOE_CAPABILITY4_STATEFUL 0x00000001 482e499d3cSBarak Witkowski #define FCOE_CAPABILITY4_STATELESS 0x00000002 492e499d3cSBarak Witkowski #define FCOE_CAPABILITY4_CAPABILITIES_REPORTED_VALID 0x00000004 502e499d3cSBarak Witkowski }; 512e499d3cSBarak Witkowski 522e499d3cSBarak Witkowski struct glob_ncsi_oem_data { 532e499d3cSBarak Witkowski u32 driver_version; 542e499d3cSBarak Witkowski u32 unused[3]; 552e499d3cSBarak Witkowski struct fcoe_capabilities fcoe_features[NVM_PATH_MAX][PORT_MAX]; 562e499d3cSBarak Witkowski }; 572e499d3cSBarak Witkowski 582e499d3cSBarak Witkowski /* current drv_info version */ 592e499d3cSBarak Witkowski #define DRV_INFO_CUR_VER 2 602e499d3cSBarak Witkowski 612e499d3cSBarak Witkowski /* drv_info op codes supported */ 622e499d3cSBarak Witkowski enum drv_info_opcode { 632e499d3cSBarak Witkowski ETH_STATS_OPCODE, 642e499d3cSBarak Witkowski FCOE_STATS_OPCODE, 652e499d3cSBarak Witkowski ISCSI_STATS_OPCODE 662e499d3cSBarak Witkowski }; 672e499d3cSBarak Witkowski 682e499d3cSBarak Witkowski #define ETH_STAT_INFO_VERSION_LEN 12 692e499d3cSBarak Witkowski /* Per PCI Function Ethernet Statistics required from the driver */ 702e499d3cSBarak Witkowski struct eth_stats_info { 712e499d3cSBarak Witkowski /* Function's Driver Version. padded to 12 */ 722e499d3cSBarak Witkowski u8 version[ETH_STAT_INFO_VERSION_LEN]; 732e499d3cSBarak Witkowski /* Locally Admin Addr. BigEndian EIU48. Actual size is 6 bytes */ 742e499d3cSBarak Witkowski u8 mac_local[8]; 752e499d3cSBarak Witkowski u8 mac_add1[8]; /* Additional Programmed MAC Addr 1. */ 762e499d3cSBarak Witkowski u8 mac_add2[8]; /* Additional Programmed MAC Addr 2. */ 772e499d3cSBarak Witkowski u32 mtu_size; /* MTU Size. Note : Negotiated MTU */ 782e499d3cSBarak Witkowski u32 feature_flags; /* Feature_Flags. */ 792e499d3cSBarak Witkowski #define FEATURE_ETH_CHKSUM_OFFLOAD_MASK 0x01 802e499d3cSBarak Witkowski #define FEATURE_ETH_LSO_MASK 0x02 812e499d3cSBarak Witkowski #define FEATURE_ETH_BOOTMODE_MASK 0x1C 822e499d3cSBarak Witkowski #define FEATURE_ETH_BOOTMODE_SHIFT 2 832e499d3cSBarak Witkowski #define FEATURE_ETH_BOOTMODE_NONE (0x0 << 2) 842e499d3cSBarak Witkowski #define FEATURE_ETH_BOOTMODE_PXE (0x1 << 2) 852e499d3cSBarak Witkowski #define FEATURE_ETH_BOOTMODE_ISCSI (0x2 << 2) 862e499d3cSBarak Witkowski #define FEATURE_ETH_BOOTMODE_FCOE (0x3 << 2) 872e499d3cSBarak Witkowski #define FEATURE_ETH_TOE_MASK 0x20 882e499d3cSBarak Witkowski u32 lso_max_size; /* LSO MaxOffloadSize. */ 892e499d3cSBarak Witkowski u32 lso_min_seg_cnt; /* LSO MinSegmentCount. */ 902e499d3cSBarak Witkowski /* Num Offloaded Connections TCP_IPv4. */ 912e499d3cSBarak Witkowski u32 ipv4_ofld_cnt; 922e499d3cSBarak Witkowski /* Num Offloaded Connections TCP_IPv6. */ 932e499d3cSBarak Witkowski u32 ipv6_ofld_cnt; 942e499d3cSBarak Witkowski u32 promiscuous_mode; /* Promiscuous Mode. non-zero true */ 952e499d3cSBarak Witkowski u32 txq_size; /* TX Descriptors Queue Size */ 962e499d3cSBarak Witkowski u32 rxq_size; /* RX Descriptors Queue Size */ 972e499d3cSBarak Witkowski /* TX Descriptor Queue Avg Depth. % Avg Queue Depth since last poll */ 982e499d3cSBarak Witkowski u32 txq_avg_depth; 992e499d3cSBarak Witkowski /* RX Descriptors Queue Avg Depth. % Avg Queue Depth since last poll */ 1002e499d3cSBarak Witkowski u32 rxq_avg_depth; 1012e499d3cSBarak Witkowski /* IOV_Offload. 0=none; 1=MultiQueue, 2=VEB 3= VEPA*/ 1022e499d3cSBarak Witkowski u32 iov_offload; 1032e499d3cSBarak Witkowski /* Number of NetQueue/VMQ Config'd. */ 1042e499d3cSBarak Witkowski u32 netq_cnt; 1052e499d3cSBarak Witkowski u32 vf_cnt; /* Num VF assigned to this PF. */ 1062e499d3cSBarak Witkowski }; 1072e499d3cSBarak Witkowski 1082e499d3cSBarak Witkowski /* Per PCI Function FCOE Statistics required from the driver */ 1092e499d3cSBarak Witkowski struct fcoe_stats_info { 1102e499d3cSBarak Witkowski u8 version[12]; /* Function's Driver Version. */ 1112e499d3cSBarak Witkowski u8 mac_local[8]; /* Locally Admin Addr. */ 1122e499d3cSBarak Witkowski u8 mac_add1[8]; /* Additional Programmed MAC Addr 1. */ 1132e499d3cSBarak Witkowski u8 mac_add2[8]; /* Additional Programmed MAC Addr 2. */ 1142e499d3cSBarak Witkowski /* QoS Priority (per 802.1p). 0-7255 */ 1152e499d3cSBarak Witkowski u32 qos_priority; 1162e499d3cSBarak Witkowski u32 txq_size; /* FCoE TX Descriptors Queue Size. */ 1172e499d3cSBarak Witkowski u32 rxq_size; /* FCoE RX Descriptors Queue Size. */ 1182e499d3cSBarak Witkowski /* FCoE TX Descriptor Queue Avg Depth. */ 1192e499d3cSBarak Witkowski u32 txq_avg_depth; 1202e499d3cSBarak Witkowski /* FCoE RX Descriptors Queue Avg Depth. */ 1212e499d3cSBarak Witkowski u32 rxq_avg_depth; 1222e499d3cSBarak Witkowski u32 rx_frames_lo; /* FCoE RX Frames received. */ 1232e499d3cSBarak Witkowski u32 rx_frames_hi; /* FCoE RX Frames received. */ 1242e499d3cSBarak Witkowski u32 rx_bytes_lo; /* FCoE RX Bytes received. */ 1252e499d3cSBarak Witkowski u32 rx_bytes_hi; /* FCoE RX Bytes received. */ 1262e499d3cSBarak Witkowski u32 tx_frames_lo; /* FCoE TX Frames sent. */ 1272e499d3cSBarak Witkowski u32 tx_frames_hi; /* FCoE TX Frames sent. */ 1282e499d3cSBarak Witkowski u32 tx_bytes_lo; /* FCoE TX Bytes sent. */ 1292e499d3cSBarak Witkowski u32 tx_bytes_hi; /* FCoE TX Bytes sent. */ 1302e499d3cSBarak Witkowski }; 1312e499d3cSBarak Witkowski 1322e499d3cSBarak Witkowski /* Per PCI Function iSCSI Statistics required from the driver*/ 1332e499d3cSBarak Witkowski struct iscsi_stats_info { 1342e499d3cSBarak Witkowski u8 version[12]; /* Function's Driver Version. */ 1352e499d3cSBarak Witkowski u8 mac_local[8]; /* Locally Admin iSCSI MAC Addr. */ 1362e499d3cSBarak Witkowski u8 mac_add1[8]; /* Additional Programmed MAC Addr 1. */ 1372e499d3cSBarak Witkowski /* QoS Priority (per 802.1p). 0-7255 */ 1382e499d3cSBarak Witkowski u32 qos_priority; 1392e499d3cSBarak Witkowski u8 initiator_name[64]; /* iSCSI Boot Initiator Node name. */ 1402e499d3cSBarak Witkowski u8 ww_port_name[64]; /* iSCSI World wide port name */ 1412e499d3cSBarak Witkowski u8 boot_target_name[64];/* iSCSI Boot Target Name. */ 1422e499d3cSBarak Witkowski u8 boot_target_ip[16]; /* iSCSI Boot Target IP. */ 1432e499d3cSBarak Witkowski u32 boot_target_portal; /* iSCSI Boot Target Portal. */ 1442e499d3cSBarak Witkowski u8 boot_init_ip[16]; /* iSCSI Boot Initiator IP Address. */ 1452e499d3cSBarak Witkowski u32 max_frame_size; /* Max Frame Size. bytes */ 1462e499d3cSBarak Witkowski u32 txq_size; /* PDU TX Descriptors Queue Size. */ 1472e499d3cSBarak Witkowski u32 rxq_size; /* PDU RX Descriptors Queue Size. */ 1482e499d3cSBarak Witkowski u32 txq_avg_depth; /* PDU TX Descriptor Queue Avg Depth. */ 1492e499d3cSBarak Witkowski u32 rxq_avg_depth; /* PDU RX Descriptors Queue Avg Depth. */ 1502e499d3cSBarak Witkowski u32 rx_pdus_lo; /* iSCSI PDUs received. */ 1512e499d3cSBarak Witkowski u32 rx_pdus_hi; /* iSCSI PDUs received. */ 1522e499d3cSBarak Witkowski u32 rx_bytes_lo; /* iSCSI RX Bytes received. */ 1532e499d3cSBarak Witkowski u32 rx_bytes_hi; /* iSCSI RX Bytes received. */ 1542e499d3cSBarak Witkowski u32 tx_pdus_lo; /* iSCSI PDUs sent. */ 1552e499d3cSBarak Witkowski u32 tx_pdus_hi; /* iSCSI PDUs sent. */ 1562e499d3cSBarak Witkowski u32 tx_bytes_lo; /* iSCSI PDU TX Bytes sent. */ 1572e499d3cSBarak Witkowski u32 tx_bytes_hi; /* iSCSI PDU TX Bytes sent. */ 1582e499d3cSBarak Witkowski u32 pcp_prior_map_tbl; /* C-PCP to S-PCP Priority MapTable. 1592e499d3cSBarak Witkowski * 9 nibbles, the position of each nibble 1602e499d3cSBarak Witkowski * represents the C-PCP value, the value 1612e499d3cSBarak Witkowski * of the nibble = S-PCP value. 1622e499d3cSBarak Witkowski */ 1632e499d3cSBarak Witkowski }; 1642e499d3cSBarak Witkowski 1652e499d3cSBarak Witkowski union drv_info_to_mcp { 1662e499d3cSBarak Witkowski struct eth_stats_info ether_stat; 1672e499d3cSBarak Witkowski struct fcoe_stats_info fcoe_stat; 1682e499d3cSBarak Witkowski struct iscsi_stats_info iscsi_stat; 1692e499d3cSBarak Witkowski }; 1702e499d3cSBarak Witkowski #endif /* BNX2X_MFW_REQ_H */ 171