New upstream version 17.11.4
[deb_dpdk.git] / drivers / net / bnxt / bnxt_vnic.h
index 9671ba4..f18fb0a 100644 (file)
@@ -42,28 +42,41 @@ struct bnxt_vnic_info {
        uint8_t         ff_pool_idx;
 
        uint16_t        fw_vnic_id; /* returned by Chimp during alloc */
-       uint16_t        fw_rss_cos_lb_ctx;
-       uint16_t        ctx_is_rss_cos_lb;
-#define MAX_NUM_TRAFFIC_CLASSES                8
-#define MAX_NUM_RSS_QUEUES_PER_VNIC    16
-#define MAX_QUEUES_PER_VNIC    (MAX_NUM_RSS_QUEUES_PER_VNIC + \
-                                MAX_NUM_TRAFFIC_CLASSES)
+       uint16_t        rss_rule;
        uint16_t        start_grp_id;
        uint16_t        end_grp_id;
-       uint16_t        fw_grp_ids[MAX_QUEUES_PER_VNIC];
+       uint16_t        *fw_grp_ids;
+       uint16_t        dflt_ring_grp;
+       uint16_t        mru;
        uint16_t        hash_type;
-       phys_addr_t     rss_table_dma_addr;
+       rte_iova_t      rss_table_dma_addr;
        uint16_t        *rss_table;
-       phys_addr_t     rss_hash_key_dma_addr;
+       rte_iova_t      rss_hash_key_dma_addr;
        void            *rss_hash_key;
+       rte_iova_t      mc_list_dma_addr;
+       char            *mc_list;
+       uint32_t        mc_addr_cnt;
+#define BNXT_MAX_MC_ADDRS              16
        uint32_t        flags;
 #define BNXT_VNIC_INFO_PROMISC                 (1 << 0)
 #define BNXT_VNIC_INFO_ALLMULTI                        (1 << 1)
+#define BNXT_VNIC_INFO_BCAST                   (1 << 2)
+#define BNXT_VNIC_INFO_UCAST                   (1 << 3)
+#define BNXT_VNIC_INFO_MCAST                   (1 << 4)
+#define BNXT_VNIC_INFO_TAGGED                  (1 << 5)
+#define BNXT_VNIC_INFO_UNTAGGED                        (1 << 6)
 
+       uint16_t        cos_rule;
+       uint16_t        lb_rule;
        bool            vlan_strip;
        bool            func_default;
+       bool            bd_stall;
+       bool            roce_dual;
+       bool            roce_only;
+       bool            rss_dflt_cr;
 
        STAILQ_HEAD(, bnxt_filter_info) filter;
+       STAILQ_HEAD(, rte_flow) flow_list;
 };
 
 struct bnxt;