net/virtio: fix incorrect cast of void *
[dpdk.git] / drivers / net / i40e / i40e_ethdev.h
index 9cd2795..cd67453 100644 (file)
@@ -260,6 +260,12 @@ enum i40e_flxpld_layer_idx {
 #define I40E_QOS_BW_WEIGHT_MIN 1
 /* The max bandwidth weight is 127. */
 #define I40E_QOS_BW_WEIGHT_MAX 127
+/* The max queue region index is 7. */
+#define I40E_REGION_MAX_INDEX 7
+
+#define I40E_MAX_PERCENT            100
+#define I40E_DEFAULT_DCB_APP_NUM    1
+#define I40E_DEFAULT_DCB_APP_PRIO   3
 
 /**
  * The overhead from MTU to max frame size.
@@ -479,6 +485,13 @@ struct i40e_gtp_ipv6_flow {
        struct rte_eth_ipv6_flow ip6;
 };
 
+/* A structure used to define the input for raw type flow */
+struct i40e_raw_flow {
+       uint16_t pctype;
+       void *packet;
+       uint32_t length;
+};
+
 /*
  * A union contains the inputs for all types of flow
  * items in flows need to be in big endian
@@ -496,6 +509,7 @@ union i40e_fdir_flow {
        struct i40e_gtp_flow       gtp_flow;
        struct i40e_gtp_ipv4_flow  gtp_ipv4_flow;
        struct i40e_gtp_ipv6_flow  gtp_ipv6_flow;
+       struct i40e_raw_flow       raw_flow;
 };
 
 enum i40e_fdir_ip_type {
@@ -513,6 +527,7 @@ struct i40e_fdir_flow_ext {
        bool inner_ip;   /* If there is inner ip */
        enum i40e_fdir_ip_type iip_type; /* ip type for inner ip */
        bool customized_pctype; /* If customized pctype is used */
+       bool pkt_template; /* If raw packet template is used */
 };
 
 /* A structure used to define the input for a flow director filter entry */
@@ -646,17 +661,49 @@ struct i40e_ethertype_rule {
        struct rte_hash *hash_table;
 };
 
+/* queue region info */
+struct i40e_queue_region_info {
+       /* the region id for this configuration */
+       uint8_t region_id;
+       /* the start queue index for this region */
+       uint8_t queue_start_index;
+       /* the total queue number of this queue region */
+       uint8_t queue_num;
+       /* the total number of user priority for this region */
+       uint8_t user_priority_num;
+       /* the packet's user priority for this region */
+       uint8_t user_priority[I40E_MAX_USER_PRIORITY];
+       /* the total number of flowtype for this region */
+       uint8_t flowtype_num;
+       /**
+        * the pctype or hardware flowtype of packet,
+        * the specific index for each type has been defined
+        * in file i40e_type.h as enum i40e_filter_pctype.
+        */
+       uint8_t hw_flowtype[I40E_FILTER_PCTYPE_MAX];
+};
+
+struct i40e_queue_regions {
+       /* the total number of queue region for this port */
+       uint16_t queue_region_number;
+       struct i40e_queue_region_info region[I40E_REGION_MAX_INDEX + 1];
+};
+
 /* Tunnel filter number HW supports */
 #define I40E_MAX_TUNNEL_FILTER_NUM 400
 
 #define I40E_AQC_REPLACE_CLOUD_CMD_INPUT_FV_TEID_WORD0 44
 #define I40E_AQC_REPLACE_CLOUD_CMD_INPUT_FV_TEID_WORD1 45
-#define I40E_AQC_ADD_CLOUD_TNL_TYPE_MPLSoUDP 8
-#define I40E_AQC_ADD_CLOUD_TNL_TYPE_MPLSoGRE 9
-#define I40E_AQC_ADD_CLOUD_FILTER_CUSTOM_QINQ 0x10
-#define I40E_AQC_ADD_CLOUD_FILTER_TEID_MPLSoUDP 0x11
-#define I40E_AQC_ADD_CLOUD_FILTER_TEID_MPLSoGRE 0x12
-#define I40E_AQC_ADD_L1_FILTER_TEID_MPLS 0x11
+#define I40E_AQC_ADD_CLOUD_TNL_TYPE_MPLSOUDP   8
+#define I40E_AQC_ADD_CLOUD_TNL_TYPE_MPLSOGRE   9
+#define I40E_AQC_ADD_CLOUD_FILTER_0X10         0x10
+#define I40E_AQC_ADD_CLOUD_FILTER_0X11         0x11
+#define I40E_AQC_ADD_CLOUD_FILTER_0X12         0x12
+#define I40E_AQC_ADD_L1_FILTER_0X11            0x11
+#define I40E_AQC_ADD_L1_FILTER_0X12            0x12
+#define I40E_AQC_ADD_L1_FILTER_0X13            0x13
+#define I40E_AQC_NEW_TR_21                     21
+#define I40E_AQC_NEW_TR_22                     22
 
 enum i40e_tunnel_iptype {
        I40E_TUNNEL_IPTYPE_IPV4,
@@ -704,6 +751,8 @@ enum i40e_tunnel_type {
        I40E_TUNNEL_TYPE_MPLSoUDP,
        I40E_TUNNEL_TYPE_MPLSoGRE,
        I40E_TUNNEL_TYPE_QINQ,
+       I40E_TUNNEL_TYPE_GTPC,
+       I40E_TUNNEL_TYPE_GTPU,
        I40E_TUNNEL_TYPE_MAX,
 };
 
@@ -896,6 +945,7 @@ struct i40e_pf {
        struct i40e_fdir_info fdir; /* flow director info */
        struct i40e_ethertype_rule ethertype; /* Ethertype filter rule */
        struct i40e_tunnel_rule tunnel; /* Tunnel filter rule */
+       struct i40e_queue_regions queue_region; /* queue region info */
        struct i40e_fc_conf fc_conf; /* Flow control conf */
        struct i40e_mirror_rule_list mirror_list;
        uint16_t nb_mirror_rule;   /* The number of mirror rules */
@@ -904,6 +954,7 @@ struct i40e_pf {
        bool floating_veb_list[I40E_MAX_VF];
        struct i40e_flow_list flow_list;
        bool mpls_replace_flag;  /* 1 - MPLS filter replace is done */
+       bool gtp_replace_flag;   /* 1 - GTP-C/U filter replace is done */
        bool qinq_replace_flag;  /* QINQ filter replace is done */
        struct i40e_tm_conf tm_conf;
 
@@ -1143,6 +1194,10 @@ struct i40e_customized_pctype*
 i40e_find_customized_pctype(struct i40e_pf *pf, uint8_t index);
 void i40e_update_customized_info(struct rte_eth_dev *dev, uint8_t *pkg,
                                 uint32_t pkg_size);
+int i40e_dcb_init_configure(struct rte_eth_dev *dev, bool sw_dcb);
+int i40e_flush_queue_region_all_conf(struct rte_eth_dev *dev,
+               struct i40e_hw *hw, struct i40e_pf *pf, uint16_t on);
+void i40e_init_queue_region_conf(struct rte_eth_dev *dev);
 
 #define I40E_DEV_TO_PCI(eth_dev) \
        RTE_DEV_TO_PCI((eth_dev)->device)