net/bnxt: add a field for FW capabilities
[dpdk.git] / drivers / net / bnxt / bnxt.h
index 189f693..ab18e8a 100644 (file)
 #define BROADCOM_DEV_ID_57508          0x1750
 #define BROADCOM_DEV_ID_57504          0x1751
 #define BROADCOM_DEV_ID_57502          0x1752
+#define BROADCOM_DEV_ID_57508_MF1      0x1800
+#define BROADCOM_DEV_ID_57504_MF1      0x1801
+#define BROADCOM_DEV_ID_57502_MF1      0x1802
+#define BROADCOM_DEV_ID_57508_MF2      0x1803
+#define BROADCOM_DEV_ID_57504_MF2      0x1804
+#define BROADCOM_DEV_ID_57502_MF2      0x1805
 #define BROADCOM_DEV_ID_57500_VF1      0x1806
 #define BROADCOM_DEV_ID_57500_VF2      0x1807
 #define BROADCOM_DEV_ID_58802          0xd802
@@ -77,6 +83,9 @@
 #define BNXT_MAX_PKT_LEN       (BNXT_MAX_MTU + RTE_ETHER_HDR_LEN +\
                                 RTE_ETHER_CRC_LEN +\
                                 (BNXT_NUM_VLANS * VLAN_TAG_SIZE))
+/* FW adds extra 4 bytes for FCS */
+#define BNXT_VNIC_MRU(mtu)\
+       ((mtu) + RTE_ETHER_HDR_LEN + VLAN_TAG_SIZE * BNXT_NUM_VLANS)
 #define BNXT_VF_RSV_NUM_RSS_CTX        1
 #define BNXT_VF_RSV_NUM_L2_CTX 4
 /* TODO: For now, do not support VMDq/RFS on VFs. */
@@ -498,16 +507,13 @@ struct bnxt {
 #define BNXT_FLAG_STINGRAY             BIT(14)
 #define BNXT_FLAG_FW_RESET             BIT(15)
 #define BNXT_FLAG_FATAL_ERROR          BIT(16)
-#define BNXT_FLAG_FW_CAP_IF_CHANGE             BIT(17)
-#define BNXT_FLAG_IF_CHANGE_HOT_FW_RESET_DONE  BIT(18)
-#define BNXT_FLAG_FW_CAP_ERROR_RECOVERY                BIT(19)
-#define BNXT_FLAG_FW_HEALTH_CHECK_SCHEDULED    BIT(20)
-#define BNXT_FLAG_FW_CAP_ERR_RECOVER_RELOAD    BIT(21)
-#define BNXT_FLAG_EXT_STATS_SUPPORTED          BIT(22)
-#define BNXT_FLAG_NEW_RM                       BIT(23)
-#define BNXT_FLAG_INIT_DONE                    BIT(24)
-#define BNXT_FLAG_FW_CAP_ONE_STEP_TX_TS                BIT(25)
-#define BNXT_FLAG_ADV_FLOW_MGMT                        BIT(26)
+#define BNXT_FLAG_IF_CHANGE_HOT_FW_RESET_DONE  BIT(17)
+#define BNXT_FLAG_FW_HEALTH_CHECK_SCHEDULED    BIT(18)
+#define BNXT_FLAG_EXT_STATS_SUPPORTED          BIT(19)
+#define BNXT_FLAG_NEW_RM                       BIT(20)
+#define BNXT_FLAG_INIT_DONE                    BIT(21)
+#define BNXT_FLAG_FW_CAP_ONE_STEP_TX_TS                BIT(22)
+#define BNXT_FLAG_ADV_FLOW_MGMT                        BIT(23)
 #define BNXT_PF(bp)            (!((bp)->flags & BNXT_FLAG_VF))
 #define BNXT_VF(bp)            ((bp)->flags & BNXT_FLAG_VF)
 #define BNXT_NPAR(bp)          ((bp)->port_partition_type)
@@ -521,6 +527,12 @@ struct bnxt {
 #define BNXT_HAS_NQ(bp)                BNXT_CHIP_THOR(bp)
 #define BNXT_HAS_RING_GRPS(bp) (!BNXT_CHIP_THOR(bp))
 
+       uint32_t                fw_cap;
+#define BNXT_FW_CAP_HOT_RESET          BIT(0)
+#define BNXT_FW_CAP_IF_CHANGE          BIT(1)
+#define BNXT_FW_CAP_ERROR_RECOVERY     BIT(2)
+#define BNXT_FW_CAP_ERR_RECOVER_RELOAD BIT(3)
+
        uint32_t                flow_flags;
 #define BNXT_FLOW_FLAG_L2_HDR_SRC_FILTER_EN    BIT(0)
        pthread_mutex_t         flow_lock;
@@ -574,6 +586,7 @@ struct bnxt {
        void                            *hwrm_short_cmd_req_addr;
        rte_iova_t                      hwrm_short_cmd_req_dma_addr;
        rte_spinlock_t                  hwrm_lock;
+       pthread_mutex_t                 def_cp_lock;
        uint16_t                        max_req_len;
        uint16_t                        max_resp_len;
        uint16_t                        hwrm_max_ext_req_len;
@@ -598,6 +611,13 @@ struct bnxt {
        uint16_t                max_cp_rings;
        uint16_t                max_tx_rings;
        uint16_t                max_rx_rings;
+#define MAX_STINGRAY_RINGS             128U
+#define BNXT_MAX_RINGS(bp) \
+       (BNXT_STINGRAY(bp) ? RTE_MIN(RTE_MIN(bp->max_rx_rings, \
+                                            MAX_STINGRAY_RINGS), \
+                                    bp->max_stat_ctx) : \
+                               RTE_MIN(bp->max_rx_rings, bp->max_stat_ctx))
+
        uint16_t                max_nq_rings;
        uint16_t                max_l2_ctx;
        uint16_t                max_rx_em_flows;
@@ -635,6 +655,7 @@ struct bnxt {
        struct bnxt_error_recovery_info *recovery_info;
 };
 
+int bnxt_mtu_set_op(struct rte_eth_dev *eth_dev, uint16_t new_mtu);
 int bnxt_link_update_op(struct rte_eth_dev *eth_dev, int wait_to_complete);
 int bnxt_rcv_msg_from_vf(struct bnxt *bp, uint16_t vf_id, void *msg);
 int is_bnxt_in_error(struct bnxt *bp);