net/mlx5: accelerate DV flow counter transactions
[dpdk.git] / drivers / net / mlx5 / mlx5_glue.h
index 32487ea..18b1ce6 100644 (file)
@@ -61,6 +61,12 @@ enum mlx5dv_flow_table_type { flow_table_type = 0, };
 
 #ifndef HAVE_IBV_DEVX_OBJ
 struct mlx5dv_devx_obj;
+struct mlx5dv_devx_umem;
+#endif
+
+#ifndef HAVE_MLX5DV_DR
+enum  mlx5dv_dr_domain_type { unused, };
+struct mlx5dv_dr_domain;
 #endif
 
 /* LIB_GLUE_VERSION must be updated every time this structure is modified. */
@@ -78,6 +84,8 @@ struct mlx5_glue {
        int (*query_device_ex)(struct ibv_context *context,
                               const struct ibv_query_device_ex_input *input,
                               struct ibv_device_attr_ex *attr);
+       int (*query_rt_values_ex)(struct ibv_context *context,
+                              struct ibv_values_ex *values);
        int (*query_port)(struct ibv_context *context, uint8_t port_num,
                          struct ibv_port_attr *port_attr);
        struct ibv_comp_channel *(*create_comp_channel)
@@ -140,6 +148,14 @@ struct mlx5_glue {
                               struct ibv_async_event *event);
        const char *(*port_state_str)(enum ibv_port_state port_state);
        struct ibv_cq *(*cq_ex_to_cq)(struct ibv_cq_ex *cq);
+       void *(*dr_create_flow_action_dest_flow_tbl)(void *tbl);
+       void *(*dr_create_flow_action_dest_vport)(void *domain, uint32_t vport);
+       void *(*dr_create_flow_action_drop)();
+       void *(*dr_create_flow_tbl)(void *domain, uint32_t level);
+       int (*dr_destroy_flow_tbl)(void *tbl);
+       void *(*dr_create_domain)(struct ibv_context *ctx,
+                                 enum mlx5dv_dr_domain_type domain);
+       int (*dr_destroy_domain)(void *domain);
        struct ibv_cq_ex *(*dv_create_cq)
                (struct ibv_context *context,
                 struct ibv_cq_init_attr_ex *cq_attr,
@@ -158,23 +174,27 @@ struct mlx5_glue {
                (struct ibv_context *context,
                 struct ibv_qp_init_attr_ex *qp_init_attr_ex,
                 struct mlx5dv_qp_init_attr *dv_qp_init_attr);
-       struct mlx5dv_flow_matcher *(*dv_create_flow_matcher)
+       void *(*dv_create_flow_matcher)
                (struct ibv_context *context,
-                struct mlx5dv_flow_matcher_attr *matcher_attr);
-       int (*dv_destroy_flow_matcher)(struct mlx5dv_flow_matcher *matcher);
-       struct ibv_flow *(*dv_create_flow)(struct mlx5dv_flow_matcher *matcher,
-                         struct mlx5dv_flow_match_parameters *match_value,
+                struct mlx5dv_flow_matcher_attr *matcher_attr,
+                void *tbl);
+       void *(*dv_create_flow)(void *matcher, void *match_value,
                          size_t num_actions, void *actions[]);
        void *(*dv_create_flow_action_counter)(void *obj, uint32_t  offset);
        void *(*dv_create_flow_action_dest_ibv_qp)(void *qp);
        void *(*dv_create_flow_action_modify_header)
-               (struct ibv_context *ctx, size_t actions_sz, uint64_t actions[],
-                enum mlx5dv_flow_table_type ft_type);
+               (struct ibv_context *ctx, enum mlx5dv_flow_table_type ft_type,
+                void *domain, uint64_t flags, size_t actions_sz,
+                uint64_t actions[]);
        void *(*dv_create_flow_action_packet_reformat)
-               (struct ibv_context *ctx, size_t data_sz, void *data,
+               (struct ibv_context *ctx,
                 enum mlx5dv_flow_action_packet_reformat_type reformat_type,
-                enum mlx5dv_flow_table_type ft_type);
+                enum mlx5dv_flow_table_type ft_type,
+                struct mlx5dv_dr_domain *domain,
+                uint32_t flags, size_t data_sz, void *data);
        void *(*dv_create_flow_action_tag)(uint32_t tag);
+       int (*dv_destroy_flow)(void *flow);
+       int (*dv_destroy_flow_matcher)(void *matcher);
        struct ibv_context *(*dv_open_device)(struct ibv_device *device);
        struct mlx5dv_devx_obj *(*devx_obj_create)
                                        (struct ibv_context *ctx,
@@ -190,6 +210,10 @@ struct mlx5_glue {
        int (*devx_general_cmd)(struct ibv_context *context,
                                const void *in, size_t inlen,
                                void *out, size_t outlen);
+       struct mlx5dv_devx_umem *(*devx_umem_reg)(struct ibv_context *context,
+                                                 void *addr, size_t size,
+                                                 uint32_t access);
+       int (*devx_umem_dereg)(struct mlx5dv_devx_umem *dv_devx_umem);
 };
 
 const struct mlx5_glue *mlx5_glue;