DPDK  19.05.0
rte_pmd_i40e.h
Go to the documentation of this file.
1 /* SPDX-License-Identifier: BSD-3-Clause
2  * Copyright(c) 2017 Intel Corporation
3  */
4 
5 #ifndef _PMD_I40E_H_
6 #define _PMD_I40E_H_
7 
17 #include <rte_ethdev_driver.h>
18 
27 };
28 
33  uint16_t vfid;
34  uint16_t msg_type;
35  uint16_t retval;
36  void *msg;
37  uint16_t msglen;
38 };
39 
44  RTE_PMD_I40E_PKG_OP_UNDEFINED = 0,
48  RTE_PMD_I40E_PKG_OP_MAX = 32
49 };
50 
55  RTE_PMD_I40E_PKG_INFO_UNDEFINED = 0,
56  RTE_PMD_I40E_PKG_INFO_GLOBAL_HEADER,
57  RTE_PMD_I40E_PKG_INFO_GLOBAL_NOTES_SIZE,
58  RTE_PMD_I40E_PKG_INFO_GLOBAL_NOTES,
59  RTE_PMD_I40E_PKG_INFO_GLOBAL_MAX = 1024,
60  RTE_PMD_I40E_PKG_INFO_HEADER,
61  RTE_PMD_I40E_PKG_INFO_DEVID_NUM,
62  RTE_PMD_I40E_PKG_INFO_DEVID_LIST,
63  RTE_PMD_I40E_PKG_INFO_PROTOCOL_NUM,
64  RTE_PMD_I40E_PKG_INFO_PROTOCOL_LIST,
65  RTE_PMD_I40E_PKG_INFO_PCTYPE_NUM,
66  RTE_PMD_I40E_PKG_INFO_PCTYPE_LIST,
67  RTE_PMD_I40E_PKG_INFO_PTYPE_NUM,
68  RTE_PMD_I40E_PKG_INFO_PTYPE_LIST,
69  RTE_PMD_I40E_PKG_INFO_MAX = (int)0xFFFFFFFF
70 };
71 
76  RTE_PMD_I40E_RSS_QUEUE_REGION_UNDEFINED,
97  RTE_PMD_I40E_RSS_QUEUE_REGION_INFO_GET,
98  RTE_PMD_I40E_RSS_QUEUE_REGION_OP_MAX
99 };
100 
101 #define RTE_PMD_I40E_DDP_NAME_SIZE 32
102 #define RTE_PMD_I40E_PCTYPE_MAX 64
103 #define RTE_PMD_I40E_REGION_MAX_NUM 8
104 #define RTE_PMD_I40E_MAX_USER_PRIORITY 8
105 
111  uint8_t major;
112  uint8_t minor;
113  uint8_t update;
114  uint8_t draft;
115 };
116 
121  uint32_t vendor_dev_id;
122  uint32_t sub_vendor_dev_id;
123 };
124 
129  uint32_t track_id;
130  struct rte_pmd_i40e_ddp_version version;
131  uint8_t owner;
132  uint8_t reserved[7];
133  uint8_t name[RTE_PMD_I40E_DDP_NAME_SIZE];
134 };
135 
136 #define RTE_PMD_I40E_DDP_OWNER_UNKNOWN 0xFF
137 
142  uint32_t p_count;
143  struct rte_pmd_i40e_profile_info p_info[1];
144 };
145 
146 #define RTE_PMD_I40E_PROTO_NUM 6
147 #define RTE_PMD_I40E_PROTO_UNUSED 0xFF
148 
153  uint8_t proto_id;
154  char name[RTE_PMD_I40E_DDP_NAME_SIZE];
155 };
156 
161  uint8_t ptype_id;
162  uint8_t protocols[RTE_PMD_I40E_PROTO_NUM];
163 };
164 
170 #define RTE_PMD_I40E_PTYPE_USER_DEFINE_MASK 0x80000000
171 
172 struct rte_pmd_i40e_ptype_mapping {
173  uint16_t hw_ptype;
174  uint32_t sw_ptype;
175 };
176 
182  uint8_t region_id;
187  uint8_t hw_flowtype;
191  uint8_t queue_num;
193  uint8_t user_priority;
194 };
195 
196 /* queue region info */
197 struct rte_pmd_i40e_queue_region_info {
199  uint8_t region_id;
201  uint8_t queue_start_index;
203  uint8_t queue_num;
205  uint8_t user_priority_num;
207  uint8_t user_priority[RTE_PMD_I40E_MAX_USER_PRIORITY];
209  uint8_t flowtype_num;
215  uint8_t hw_flowtype[RTE_PMD_I40E_PCTYPE_MAX];
216 };
217 
218 struct rte_pmd_i40e_queue_regions {
220  uint16_t queue_region_number;
221  struct rte_pmd_i40e_queue_region_info
222  region[RTE_PMD_I40E_REGION_MAX_NUM];
223 };
224 
229  RTE_PMD_I40E_PKT_TEMPLATE_ACCEPT,
230  RTE_PMD_I40E_PKT_TEMPLATE_REJECT,
231  RTE_PMD_I40E_PKT_TEMPLATE_PASSTHRU,
232 };
233 
247 };
248 
254  uint16_t rx_queue;
264  uint8_t flex_off;
265 };
266 
272  uint16_t pctype;
274  void *packet;
276  uint32_t length;
277 };
278 
289  uint32_t soft_id;
290 };
291 
292 enum rte_pmd_i40e_inset_type {
293  INSET_NONE = 0,
294  INSET_HASH,
295  INSET_FDIR,
296  INSET_FDIR_FLX,
297 };
298 
299 struct rte_pmd_i40e_inset_mask {
300  uint8_t field_idx;
301  uint16_t mask;
302 };
303 
304 struct rte_pmd_i40e_inset {
305  uint64_t inset;
306  struct rte_pmd_i40e_inset_mask mask[2];
307 };
308 
325  uint16_t port,
326  const struct rte_pmd_i40e_pkt_template_conf *conf,
327  uint8_t add);
328 
341 int rte_pmd_i40e_ping_vfs(uint16_t port, uint16_t vf);
342 
359  uint16_t vf_id,
360  uint8_t on);
361 
378  uint16_t vf_id,
379  uint8_t on);
380 
395  uint8_t on);
396 
413  uint16_t vf_id,
414  uint8_t on);
415 
432  uint16_t vf_id,
433  uint8_t on);
434 
455 int rte_pmd_i40e_set_vf_mac_addr(uint16_t port, uint16_t vf_id,
456  struct ether_addr *mac_addr);
457 
472 int
473 rte_pmd_i40e_remove_vf_mac_addr(uint16_t port, uint16_t vf_id,
474  struct ether_addr *mac_addr);
475 
492 int
493 rte_pmd_i40e_set_vf_vlan_stripq(uint16_t port, uint16_t vf, uint8_t on);
494 
511 int rte_pmd_i40e_set_vf_vlan_insert(uint16_t port, uint16_t vf_id,
512  uint16_t vlan_id);
513 
530 int rte_pmd_i40e_set_vf_broadcast(uint16_t port, uint16_t vf_id,
531  uint8_t on);
532 
549 int rte_pmd_i40e_set_vf_vlan_tag(uint16_t port, uint16_t vf_id, uint8_t on);
550 
570 int rte_pmd_i40e_set_vf_vlan_filter(uint16_t port, uint16_t vlan_id,
571  uint64_t vf_mask, uint8_t on);
572 
595 int rte_pmd_i40e_get_vf_stats(uint16_t port,
596  uint16_t vf_id,
597  struct rte_eth_stats *stats);
598 
611 int rte_pmd_i40e_reset_vf_stats(uint16_t port,
612  uint16_t vf_id);
613 
636 int rte_pmd_i40e_set_vf_max_bw(uint16_t port,
637  uint16_t vf_id,
638  uint32_t bw);
639 
662  uint16_t vf_id,
663  uint8_t tc_num,
664  uint8_t *bw_weight);
665 
687  uint16_t vf_id,
688  uint8_t tc_no,
689  uint32_t bw);
690 
704 int rte_pmd_i40e_set_tc_strict_prio(uint16_t port, uint8_t tc_map);
705 
725 int rte_pmd_i40e_process_ddp_package(uint16_t port, uint8_t *buff,
726  uint32_t size,
727  enum rte_pmd_i40e_package_op op);
728 
746 int rte_pmd_i40e_get_ddp_info(uint8_t *pkg, uint32_t pkg_size,
747  uint8_t *info, uint32_t size,
748  enum rte_pmd_i40e_package_info type);
749 
763 int rte_pmd_i40e_get_ddp_list(uint16_t port, uint8_t *buff, uint32_t size);
764 
783  uint16_t port,
784  struct rte_pmd_i40e_ptype_mapping *mapping_items,
785  uint16_t count,
786  uint8_t exclusive);
787 
796 
814  uint16_t port,
815  struct rte_pmd_i40e_ptype_mapping *mapping_items,
816  uint16_t size,
817  uint16_t *count,
818  uint8_t valid_only);
819 
835  uint32_t target,
836  uint8_t mask,
837  uint32_t pkt_type);
838 
856 int rte_pmd_i40e_add_vf_mac_addr(uint16_t port, uint16_t vf_id,
857  struct ether_addr *mac_addr);
858 
859 #define RTE_PMD_I40E_PCTYPE_MAX 64
860 #define RTE_PMD_I40E_FLOW_TYPE_MAX 64
861 
862 struct rte_pmd_i40e_flow_type_mapping {
863  uint16_t flow_type;
864  uint64_t pctype;
865 };
866 
885  uint16_t port,
886  struct rte_pmd_i40e_flow_type_mapping *mapping_items,
887  uint16_t count,
888  uint8_t exclusive);
889 
902  uint16_t port,
903  struct rte_pmd_i40e_flow_type_mapping *mapping_items);
904 
913 
927  const struct ether_addr *vf_mac);
928 
940 int rte_pmd_i40e_rss_queue_region_conf(uint16_t port_id,
941  enum rte_pmd_i40e_queue_region_op op_type, void *arg);
942 
943 int rte_pmd_i40e_cfg_hash_inset(uint16_t port,
944  uint64_t pctype, uint64_t inset);
945 
963 int rte_pmd_i40e_inset_get(uint16_t port, uint8_t pctype,
964  struct rte_pmd_i40e_inset *inset,
965  enum rte_pmd_i40e_inset_type inset_type);
966 
984 int rte_pmd_i40e_inset_set(uint16_t port, uint8_t pctype,
985  struct rte_pmd_i40e_inset *inset,
986  enum rte_pmd_i40e_inset_type inset_type);
987 
999 static inline int
1000 rte_pmd_i40e_inset_field_get(uint64_t inset, uint8_t field_idx)
1001 {
1002  uint8_t bit_idx;
1003 
1004  if (field_idx > 63)
1005  return 0;
1006 
1007  bit_idx = 63 - field_idx;
1008  if (inset & (1ULL << bit_idx))
1009  return 1;
1010 
1011  return 0;
1012 }
1013 
1025 static inline int
1026 rte_pmd_i40e_inset_field_set(uint64_t *inset, uint8_t field_idx)
1027 {
1028  uint8_t bit_idx;
1029 
1030  if (field_idx > 63)
1031  return -1;
1032 
1033  bit_idx = 63 - field_idx;
1034  *inset = *inset | (1ULL << bit_idx);
1035 
1036  return 0;
1037 }
1038 
1050 static inline int
1051 rte_pmd_i40e_inset_field_clear(uint64_t *inset, uint8_t field_idx)
1052 {
1053  uint8_t bit_idx;
1054 
1055  if (field_idx > 63)
1056  return -1;
1057 
1058  bit_idx = 63 - field_idx;
1059  *inset = *inset & ~(1ULL << bit_idx);
1060 
1061  return 0;
1062 }
1063 
1064 #endif /* _PMD_I40E_H_ */