aboutsummaryrefslogtreecommitdiffstats
path: root/contrib/libs/ibdrv/impl.cpp
diff options
context:
space:
mode:
authorthegeorg <thegeorg@yandex-team.com>2023-07-18 14:04:56 +0300
committerthegeorg <thegeorg@yandex-team.com>2023-07-18 14:04:56 +0300
commite6faf2d02c5150afa1653e6232678b23b68fe534 (patch)
tree1c4c68662b38947880e788869399acd1a202d106 /contrib/libs/ibdrv/impl.cpp
parent8c8a4c1d7d49f7f55e2d3b30f638b53b7c890273 (diff)
downloadydb-e6faf2d02c5150afa1653e6232678b23b68fe534.tar.gz
Allow using ibdrv interface in opensource apps
Diffstat (limited to 'contrib/libs/ibdrv/impl.cpp')
-rw-r--r--contrib/libs/ibdrv/impl.cpp630
1 files changed, 630 insertions, 0 deletions
diff --git a/contrib/libs/ibdrv/impl.cpp b/contrib/libs/ibdrv/impl.cpp
new file mode 100644
index 0000000000..82660fae82
--- /dev/null
+++ b/contrib/libs/ibdrv/impl.cpp
@@ -0,0 +1,630 @@
+#include "symbols.h"
+
+#include <util/generic/yexception.h>
+
+template <typename Method, typename... Args>
+static auto Call(Method* m, Args&&... args) {
+ Y_ENSURE(m);
+ return m(std::forward<Args>(args)...);
+}
+
+// verbs
+
+Y_HIDDEN
+int ibv_modify_qp(struct ibv_qp *qp, struct ibv_qp_attr *attr, int attr_mask) {
+ return Call(IBSym()->ibv_modify_qp, qp, attr, attr_mask);
+}
+
+Y_HIDDEN
+struct ibv_ah *ibv_create_ah(struct ibv_pd *pd, struct ibv_ah_attr *attr) {
+ return Call(IBSym()->ibv_create_ah, pd, attr);
+}
+
+Y_HIDDEN
+struct ibv_cq *ibv_create_cq(struct ibv_context *context, int cqe, void *cq_context, struct ibv_comp_channel *channel, int comp_vector) {
+ return Call(IBSym()->ibv_create_cq, context, cqe, cq_context, channel, comp_vector);
+}
+
+Y_HIDDEN
+int ibv_destroy_ah(struct ibv_ah *ah) {
+ return Call(IBSym()->ibv_destroy_ah, ah);
+}
+
+Y_HIDDEN
+struct ibv_qp *ibv_create_qp(struct ibv_pd *pd, struct ibv_qp_init_attr *qp_init_attr) {
+ return Call(IBSym()->ibv_create_qp, pd, qp_init_attr);
+}
+
+Y_HIDDEN
+int ibv_fork_init() {
+ return Call(IBSym()->ibv_fork_init);
+}
+
+Y_HIDDEN
+struct ibv_context *ibv_open_device(struct ibv_device *device) {
+ return Call(IBSym()->ibv_open_device, device);
+}
+
+Y_HIDDEN
+int ibv_close_device(struct ibv_context *context) {
+ return Call(IBSym()->ibv_close_device, context);
+}
+
+Y_HIDDEN
+struct ibv_pd *ibv_alloc_pd(struct ibv_context *context) {
+ return Call(IBSym()->ibv_alloc_pd, context);
+}
+
+Y_HIDDEN
+int ibv_dealloc_pd(struct ibv_pd *pd) {
+ return Call(IBSym()->ibv_dealloc_pd, pd);
+}
+
+Y_HIDDEN
+void ibv_free_device_list(struct ibv_device **list) {
+ return Call(IBSym()->ibv_free_device_list, list);
+}
+
+Y_HIDDEN
+int ibv_query_device(struct ibv_context *context, struct ibv_device_attr *device_attr) {
+ return Call(IBSym()->ibv_query_device, context, device_attr);
+}
+
+Y_HIDDEN
+struct ibv_device **ibv_get_device_list(int *num_devices) {
+ return Call(IBSym()->ibv_get_device_list, num_devices);
+}
+
+Y_HIDDEN
+int ibv_destroy_qp(struct ibv_qp *qp) {
+ return Call(IBSym()->ibv_destroy_qp, qp);
+}
+
+Y_HIDDEN
+struct ibv_srq *ibv_create_srq(struct ibv_pd *pd, struct ibv_srq_init_attr *srq_init_attr) {
+ return Call(IBSym()->ibv_create_srq, pd, srq_init_attr);
+}
+
+Y_HIDDEN
+int ibv_destroy_srq(struct ibv_srq *srq) {
+ return Call(IBSym()->ibv_destroy_srq, srq);
+}
+
+Y_HIDDEN
+int ibv_init_ah_from_wc(struct ibv_context *context, uint8_t port_num, struct ibv_wc *wc, struct ibv_grh *grh, struct ibv_ah_attr *ah_attr) {
+ return Call(IBSym()->ibv_init_ah_from_wc, context, port_num, wc, grh, ah_attr);
+}
+
+Y_HIDDEN
+struct ibv_mr *ibv_reg_mr(struct ibv_pd *pd, void *addr, size_t length, int access) {
+ return Call(IBSym()->ibv_reg_mr, pd, addr, length, access);
+}
+
+Y_HIDDEN
+struct ibv_mr *ibv_reg_mr_iova2(struct ibv_pd *pd, void *addr, size_t length, uint64_t iova, unsigned int access) {
+ return Call(IBSym()->ibv_reg_mr_iova2, pd, addr, length, iova, access);
+}
+
+Y_HIDDEN
+int ibv_dereg_mr(struct ibv_mr *mr) {
+ return Call(IBSym()->ibv_dereg_mr, mr);
+}
+
+Y_HIDDEN
+int ibv_destroy_cq(struct ibv_cq *cq) {
+ return Call(IBSym()->ibv_destroy_cq, cq);
+}
+
+Y_HIDDEN
+int ibv_query_gid(struct ibv_context *context, uint8_t port_num, int index, union ibv_gid *gid) {
+ return Call(IBSym()->ibv_query_gid, context, port_num, index, gid);
+}
+
+Y_HIDDEN
+int ibv_query_port(struct ibv_context *context, uint8_t port_num, struct _compat_ibv_port_attr *port_attr) {
+ return Call(IBSym()->ibv_query_port, context, port_num, port_attr);
+}
+
+Y_HIDDEN
+const char *ibv_wc_status_str(enum ibv_wc_status status) {
+ return Call(IBSym()->ibv_wc_status_str, status);
+}
+
+Y_HIDDEN
+const char *ibv_get_device_name(struct ibv_device *device) {
+ return Call(IBSym()->ibv_get_device_name, device);
+}
+
+Y_HIDDEN
+int ibv_get_async_event(struct ibv_context *context, struct ibv_async_event *event) {
+ return Call(IBSym()->ibv_get_async_event, context, event);
+}
+
+Y_HIDDEN
+const char *ibv_event_type_str(enum ibv_event_type event) {
+ return Call(IBSym()->ibv_event_type_str, event);
+}
+
+Y_HIDDEN
+int ibv_query_qp(struct ibv_qp *qp, struct ibv_qp_attr *attr, int attr_mask, struct ibv_qp_init_attr *init_attr) {
+ return Call(IBSym()->ibv_query_qp, qp, attr, attr_mask, init_attr);
+}
+
+Y_HIDDEN
+int ibv_resize_cq(struct ibv_cq *cq, int cqe) {
+ return Call(IBSym()->ibv_resize_cq, cq, cqe);
+}
+
+Y_HIDDEN
+void ibv_ack_async_event(struct ibv_async_event *event) {
+ return Call(IBSym()->ibv_ack_async_event, event);
+}
+
+Y_HIDDEN
+struct ibv_comp_channel *ibv_create_comp_channel(struct ibv_context *context) {
+ return Call(IBSym()->ibv_create_comp_channel, context);
+}
+
+Y_HIDDEN
+int ibv_destroy_comp_channel(struct ibv_comp_channel *channel) {
+ return Call(IBSym()->ibv_destroy_comp_channel, channel);
+}
+
+Y_HIDDEN
+int ibv_get_cq_event(struct ibv_comp_channel *channel, struct ibv_cq **cq, void **cq_context) {
+ return Call(IBSym()->ibv_get_cq_event, channel, cq, cq_context);
+}
+
+Y_HIDDEN
+void ibv_ack_cq_events(struct ibv_cq *cq, unsigned int nevents) {
+ return Call(IBSym()->ibv_ack_cq_events, cq, nevents);
+}
+
+Y_HIDDEN
+const char *ibv_port_state_str(enum ibv_port_state port_state) {
+ return Call(IBSym()->ibv_port_state_str, port_state);
+}
+
+// rdma
+
+Y_HIDDEN
+int rdma_ack_cm_event(struct rdma_cm_event *event) {
+ return Call(RDSym()->rdma_ack_cm_event, event);
+}
+
+Y_HIDDEN
+int rdma_get_cm_event(struct rdma_event_channel *channel, struct rdma_cm_event **event) {
+ return Call(RDSym()->rdma_get_cm_event, channel, event);
+}
+
+Y_HIDDEN
+int rdma_create_qp(struct rdma_cm_id *id, struct ibv_pd *pd, struct ibv_qp_init_attr *qp_init_attr) {
+ return Call(RDSym()->rdma_create_qp, id, pd, qp_init_attr);
+}
+
+Y_HIDDEN
+struct rdma_event_channel *rdma_create_event_channel() {
+ return Call(RDSym()->rdma_create_event_channel);
+}
+
+Y_HIDDEN
+int rdma_create_id(struct rdma_event_channel *channel, struct rdma_cm_id **id, void *context, enum rdma_port_space ps) {
+ return Call(RDSym()->rdma_create_id, channel, id, context, ps);
+}
+
+Y_HIDDEN
+int rdma_resolve_addr(struct rdma_cm_id *id, struct sockaddr *src_addr, struct sockaddr *dst_addr, int timeout_ms) {
+ return Call(RDSym()->rdma_resolve_addr, id, src_addr, dst_addr, timeout_ms);
+}
+
+Y_HIDDEN
+int rdma_resolve_route(struct rdma_cm_id *id, int timeout_ms) {
+ return Call(RDSym()->rdma_resolve_route, id, timeout_ms);
+}
+
+Y_HIDDEN
+int rdma_bind_addr(struct rdma_cm_id *id, struct sockaddr *addr) {
+ return Call(RDSym()->rdma_bind_addr, id, addr);
+}
+
+Y_HIDDEN
+int rdma_listen(struct rdma_cm_id *id, int backlog) {
+ return Call(RDSym()->rdma_listen, id, backlog);
+}
+
+Y_HIDDEN
+int rdma_accept(struct rdma_cm_id *id, struct rdma_conn_param *conn_param) {
+ return Call(RDSym()->rdma_accept, id, conn_param);
+}
+
+Y_HIDDEN
+int rdma_connect(struct rdma_cm_id *id, struct rdma_conn_param *conn_param) {
+ return Call(RDSym()->rdma_connect, id, conn_param);
+}
+
+Y_HIDDEN
+int rdma_disconnect(struct rdma_cm_id *id) {
+ return Call(RDSym()->rdma_disconnect, id);
+}
+
+Y_HIDDEN
+int rdma_set_option(struct rdma_cm_id *id, int level, int optname, void *optval, size_t optlen) {
+ return Call(RDSym()->rdma_set_option, id, level, optname, optval, optlen);
+}
+
+Y_HIDDEN
+int rdma_destroy_id(struct rdma_cm_id *id) {
+ return Call(RDSym()->rdma_destroy_id, id);
+}
+
+Y_HIDDEN
+void rdma_destroy_qp(struct rdma_cm_id *id) {
+ return Call(RDSym()->rdma_destroy_qp, id);
+}
+
+Y_HIDDEN
+struct ibv_context **rdma_get_devices(int *num_devices) {
+ return Call(RDSym()->rdma_get_devices, num_devices);
+}
+
+Y_HIDDEN
+void rdma_free_devices(struct ibv_context **list) {
+ return Call(RDSym()->rdma_free_devices, list);
+}
+
+Y_HIDDEN
+void rdma_destroy_event_channel(struct rdma_event_channel *channel) {
+ return Call(RDSym()->rdma_destroy_event_channel, channel);
+}
+
+Y_HIDDEN
+int rdma_reject(struct rdma_cm_id *id, const void *private_data, uint8_t private_data_len) {
+ return Call(RDSym()->rdma_reject, id, private_data, private_data_len);
+}
+
+Y_HIDDEN
+uint16_t rdma_get_dst_port(struct rdma_cm_id *id) {
+ return Call(RDSym()->rdma_get_dst_port, id);
+}
+
+Y_HIDDEN
+uint16_t rdma_get_src_port(struct rdma_cm_id *id) {
+ return Call(RDSym()->rdma_get_src_port, id);
+}
+
+Y_HIDDEN
+int rdma_getaddrinfo(const char *node, const char *service, const struct rdma_addrinfo *hints, struct rdma_addrinfo **res) {
+ return Call(RDSym()->rdma_getaddrinfo, node, service, hints, res);
+}
+
+Y_HIDDEN
+void rdma_freeaddrinfo(struct rdma_addrinfo *res) {
+ return Call(RDSym()->rdma_freeaddrinfo, res);
+}
+
+// mlx5
+
+Y_HIDDEN
+struct mlx5dv_var *mlx5dv_alloc_var(struct ibv_context *context, uint32_t flags) {
+ return Call(M5Sym()->mlx5dv_alloc_var, context, flags);
+}
+
+Y_HIDDEN
+struct ibv_cq_ex *mlx5dv_create_cq(struct ibv_context *context, struct ibv_cq_init_attr_ex *cq_attr, struct mlx5dv_cq_init_attr *mlx5_cq_attr) {
+ return Call(M5Sym()->mlx5dv_create_cq, context, cq_attr, mlx5_cq_attr);
+}
+
+Y_HIDDEN
+struct ibv_flow *mlx5dv_create_flow(struct mlx5dv_flow_matcher *matcher, struct mlx5dv_flow_match_parameters *match_value, size_t num_actions, struct mlx5dv_flow_action_attr actions_attr[]) {
+ return Call(M5Sym()->mlx5dv_create_flow, matcher, match_value, num_actions, actions_attr);
+}
+
+Y_HIDDEN
+struct mlx5dv_flow_matcher *mlx5dv_create_flow_matcher(struct ibv_context *context, struct mlx5dv_flow_matcher_attr *matcher_attr) {
+ return Call(M5Sym()->mlx5dv_create_flow_matcher, context, matcher_attr);
+}
+
+Y_HIDDEN
+struct ibv_qp *mlx5dv_create_qp(struct ibv_context *context, struct ibv_qp_init_attr_ex *qp_attr, struct mlx5dv_qp_init_attr *mlx5_qp_attr) {
+ return Call(M5Sym()->mlx5dv_create_qp, context, qp_attr, mlx5_qp_attr);
+}
+
+Y_HIDDEN
+struct ibv_wq *mlx5dv_create_wq(struct ibv_context *context, struct ibv_wq_init_attr *wq_init_attr, struct mlx5dv_wq_init_attr *mlx5_wq_attr) {
+ return Call(M5Sym()->mlx5dv_create_wq, context, wq_init_attr, mlx5_wq_attr);
+}
+
+Y_HIDDEN
+int mlx5dv_destroy_flow_matcher(struct mlx5dv_flow_matcher *matcher) {
+ return Call(M5Sym()->mlx5dv_destroy_flow_matcher, matcher);
+}
+
+Y_HIDDEN
+struct mlx5dv_devx_uar *mlx5dv_devx_alloc_uar(struct ibv_context *context, uint32_t flags) {
+ return Call(M5Sym()->mlx5dv_devx_alloc_uar, context, flags);
+}
+
+Y_HIDDEN
+struct mlx5dv_devx_cmd_comp *mlx5dv_devx_create_cmd_comp(struct ibv_context *context) {
+ return Call(M5Sym()->mlx5dv_devx_create_cmd_comp, context);
+}
+
+Y_HIDDEN
+struct mlx5dv_devx_event_channel *mlx5dv_devx_create_event_channel(struct ibv_context *context, enum mlx5dv_devx_create_event_channel_flags flags) {
+ return Call(M5Sym()->mlx5dv_devx_create_event_channel, context, flags);
+}
+
+Y_HIDDEN
+void mlx5dv_devx_destroy_cmd_comp(struct mlx5dv_devx_cmd_comp *cmd_comp) {
+ return Call(M5Sym()->mlx5dv_devx_destroy_cmd_comp, cmd_comp);
+}
+
+Y_HIDDEN
+void mlx5dv_devx_destroy_event_channel(struct mlx5dv_devx_event_channel *event_channel) {
+ return Call(M5Sym()->mlx5dv_devx_destroy_event_channel, event_channel);
+}
+
+Y_HIDDEN
+void mlx5dv_devx_free_uar(struct mlx5dv_devx_uar *devx_uar) {
+ return Call(M5Sym()->mlx5dv_devx_free_uar, devx_uar);
+}
+
+Y_HIDDEN
+int mlx5dv_devx_general_cmd(struct ibv_context *context, const void *in, size_t inlen, void *out, size_t outlen) {
+ return Call(M5Sym()->mlx5dv_devx_general_cmd, context, in, inlen, out, outlen);
+}
+
+Y_HIDDEN
+int mlx5dv_devx_get_async_cmd_comp(struct mlx5dv_devx_cmd_comp *cmd_comp, struct mlx5dv_devx_async_cmd_hdr *cmd_resp, size_t cmd_resp_len) {
+ return Call(M5Sym()->mlx5dv_devx_get_async_cmd_comp, cmd_comp, cmd_resp, cmd_resp_len);
+}
+
+Y_HIDDEN
+ssize_t mlx5dv_devx_get_event(struct mlx5dv_devx_event_channel *event_channel, struct mlx5dv_devx_async_event_hdr *event_data, size_t event_resp_len) {
+ return Call(M5Sym()->mlx5dv_devx_get_event, event_channel, event_data, event_resp_len);
+}
+
+Y_HIDDEN
+struct mlx5dv_devx_obj *mlx5dv_devx_obj_create(struct ibv_context *context, const void *in, size_t inlen, void *out, size_t outlen) {
+ return Call(M5Sym()->mlx5dv_devx_obj_create, context, in, inlen, out, outlen);
+}
+
+Y_HIDDEN
+int mlx5dv_devx_obj_destroy(struct mlx5dv_devx_obj *obj) {
+ return Call(M5Sym()->mlx5dv_devx_obj_destroy, obj);
+}
+
+Y_HIDDEN
+int mlx5dv_devx_obj_modify(struct mlx5dv_devx_obj *obj, const void *in, size_t inlen, void *out, size_t outlen) {
+ return Call(M5Sym()->mlx5dv_devx_obj_modify, obj, in, inlen, out, outlen);
+}
+
+Y_HIDDEN
+int mlx5dv_devx_obj_query(struct mlx5dv_devx_obj *obj, const void *in, size_t inlen, void *out, size_t outlen) {
+ return Call(M5Sym()->mlx5dv_devx_obj_query, obj, in, inlen, out, outlen);
+}
+
+Y_HIDDEN
+int mlx5dv_devx_obj_query_async(struct mlx5dv_devx_obj *obj, const void *in, size_t inlen, size_t outlen, uint64_t wr_id, struct mlx5dv_devx_cmd_comp *cmd_comp) {
+ return Call(M5Sym()->mlx5dv_devx_obj_query_async, obj, in, inlen, outlen, wr_id, cmd_comp);
+}
+
+Y_HIDDEN
+int mlx5dv_devx_qp_query(struct ibv_qp *qp, const void *in, size_t inlen, void *out, size_t outlen) {
+ return Call(M5Sym()->mlx5dv_devx_qp_query, qp, in, inlen, out, outlen);
+}
+
+Y_HIDDEN
+int mlx5dv_devx_query_eqn(struct ibv_context *context, uint32_t vector, uint32_t *eqn) {
+ return Call(M5Sym()->mlx5dv_devx_query_eqn, context, vector, eqn);
+}
+
+Y_HIDDEN
+int mlx5dv_devx_subscribe_devx_event(struct mlx5dv_devx_event_channel *event_channel, struct mlx5dv_devx_obj *obj, uint16_t events_sz, uint16_t events_num[], uint64_t cookie) {
+ return Call(M5Sym()->mlx5dv_devx_subscribe_devx_event, event_channel, obj, events_sz, events_num, cookie);
+}
+
+Y_HIDDEN
+int mlx5dv_devx_subscribe_devx_event_fd(struct mlx5dv_devx_event_channel *event_channel, int fd, struct mlx5dv_devx_obj *obj, uint16_t event_num) {
+ return Call(M5Sym()->mlx5dv_devx_subscribe_devx_event_fd, event_channel, fd, obj, event_num);
+}
+
+Y_HIDDEN
+int mlx5dv_devx_umem_dereg(struct mlx5dv_devx_umem *umem) {
+ return Call(M5Sym()->mlx5dv_devx_umem_dereg, umem);
+}
+
+Y_HIDDEN
+struct mlx5dv_devx_umem *mlx5dv_devx_umem_reg(struct ibv_context *ctx, void *addr, size_t size, uint32_t access) {
+ return Call(M5Sym()->mlx5dv_devx_umem_reg, ctx, addr, size, access);
+}
+
+Y_HIDDEN
+struct mlx5dv_dr_action *mlx5dv_dr_action_create_aso(struct mlx5dv_dr_domain *domain, struct mlx5dv_devx_obj *devx_obj, uint32_t offset, uint32_t flags, uint8_t return_reg_c) {
+ return Call(M5Sym()->mlx5dv_dr_action_create_aso, domain, devx_obj, offset, flags, return_reg_c);
+}
+
+Y_HIDDEN
+struct mlx5dv_dr_action *mlx5dv_dr_action_create_default_miss(void) {
+ return Call(M5Sym()->mlx5dv_dr_action_create_default_miss);
+}
+
+Y_HIDDEN
+struct mlx5dv_dr_action *mlx5dv_dr_action_create_dest_array(struct mlx5dv_dr_domain *domain, size_t num_dest, struct mlx5dv_dr_action_dest_attr *dests[]) {
+ return Call(M5Sym()->mlx5dv_dr_action_create_dest_array, domain, num_dest, dests);
+}
+
+Y_HIDDEN
+struct mlx5dv_dr_action *mlx5dv_dr_action_create_dest_devx_tir(struct mlx5dv_devx_obj *devx_obj) {
+ return Call(M5Sym()->mlx5dv_dr_action_create_dest_devx_tir, devx_obj);
+}
+
+Y_HIDDEN
+struct mlx5dv_dr_action *mlx5dv_dr_action_create_dest_ib_port(struct mlx5dv_dr_domain *domain, uint32_t ib_port) {
+ return Call(M5Sym()->mlx5dv_dr_action_create_dest_ib_port, domain, ib_port);
+}
+
+Y_HIDDEN
+struct mlx5dv_dr_action *mlx5dv_dr_action_create_dest_ibv_qp(struct ibv_qp *ibqp) {
+ return Call(M5Sym()->mlx5dv_dr_action_create_dest_ibv_qp, ibqp);
+}
+
+Y_HIDDEN
+struct mlx5dv_dr_action *mlx5dv_dr_action_create_dest_table(struct mlx5dv_dr_table *table) {
+ return Call(M5Sym()->mlx5dv_dr_action_create_dest_table, table);
+}
+
+Y_HIDDEN
+struct mlx5dv_dr_action *mlx5dv_dr_action_create_dest_vport(struct mlx5dv_dr_domain *domain, uint32_t vport) {
+ return Call(M5Sym()->mlx5dv_dr_action_create_dest_vport, domain, vport);
+}
+
+Y_HIDDEN
+struct mlx5dv_dr_action *mlx5dv_dr_action_create_drop(void) {
+ return Call(M5Sym()->mlx5dv_dr_action_create_drop);
+}
+
+Y_HIDDEN
+struct mlx5dv_dr_action *mlx5dv_dr_action_create_flow_counter(struct mlx5dv_devx_obj *devx_obj, uint32_t offset) {
+ return Call(M5Sym()->mlx5dv_dr_action_create_flow_counter, devx_obj, offset);
+}
+
+Y_HIDDEN
+struct mlx5dv_dr_action *mlx5dv_dr_action_create_flow_meter(struct mlx5dv_dr_flow_meter_attr *attr) {
+ return Call(M5Sym()->mlx5dv_dr_action_create_flow_meter, attr);
+}
+
+Y_HIDDEN
+struct mlx5dv_dr_action *mlx5dv_dr_action_create_flow_sampler(struct mlx5dv_dr_flow_sampler_attr *attr) {
+ return Call(M5Sym()->mlx5dv_dr_action_create_flow_sampler, attr);
+}
+
+Y_HIDDEN
+struct mlx5dv_dr_action *mlx5dv_dr_action_create_modify_header(struct mlx5dv_dr_domain *domain, uint32_t flags, size_t actions_sz, __be64 actions[]) {
+ return Call(M5Sym()->mlx5dv_dr_action_create_modify_header, domain, flags, actions_sz, actions);
+}
+
+Y_HIDDEN
+struct mlx5dv_dr_action *mlx5dv_dr_action_create_packet_reformat(struct mlx5dv_dr_domain *domain, uint32_t flags, enum mlx5dv_flow_action_packet_reformat_type reformat_type, size_t data_sz, void *data) {
+ return Call(M5Sym()->mlx5dv_dr_action_create_packet_reformat, domain, flags, reformat_type, data_sz, data);
+}
+
+Y_HIDDEN
+struct mlx5dv_dr_action *mlx5dv_dr_action_create_pop_vlan(void) {
+ return Call(M5Sym()->mlx5dv_dr_action_create_pop_vlan);
+}
+
+Y_HIDDEN
+struct mlx5dv_dr_action *mlx5dv_dr_action_create_push_vlan(struct mlx5dv_dr_domain *domain, __be32 vlan_hdr) {
+ return Call(M5Sym()->mlx5dv_dr_action_create_push_vlan, domain, vlan_hdr);
+}
+
+Y_HIDDEN
+struct mlx5dv_dr_action *mlx5dv_dr_action_create_tag(uint32_t tag_value) {
+ return Call(M5Sym()->mlx5dv_dr_action_create_tag, tag_value);
+}
+
+Y_HIDDEN
+int mlx5dv_dr_action_destroy(struct mlx5dv_dr_action *action) {
+ return Call(M5Sym()->mlx5dv_dr_action_destroy, action);
+}
+
+Y_HIDDEN
+int mlx5dv_dr_action_modify_flow_meter(struct mlx5dv_dr_action *action, struct mlx5dv_dr_flow_meter_attr *attr, __be64 modify_field_select) {
+ return Call(M5Sym()->mlx5dv_dr_action_modify_flow_meter, action, attr, modify_field_select);
+}
+
+Y_HIDDEN
+struct mlx5dv_dr_domain *mlx5dv_dr_domain_create(struct ibv_context *ctx, enum mlx5dv_dr_domain_type type) {
+ return Call(M5Sym()->mlx5dv_dr_domain_create, ctx, type);
+}
+
+Y_HIDDEN
+int mlx5dv_dr_domain_destroy(struct mlx5dv_dr_domain *domain) {
+ return Call(M5Sym()->mlx5dv_dr_domain_destroy, domain);
+}
+
+Y_HIDDEN
+void mlx5dv_dr_domain_set_reclaim_device_memory(struct mlx5dv_dr_domain *dmn, bool enable) {
+ return Call(M5Sym()->mlx5dv_dr_domain_set_reclaim_device_memory, dmn, enable);
+}
+
+Y_HIDDEN
+int mlx5dv_dr_domain_sync(struct mlx5dv_dr_domain *domain, uint32_t flags) {
+ return Call(M5Sym()->mlx5dv_dr_domain_sync, domain, flags);
+}
+
+Y_HIDDEN
+struct mlx5dv_dr_matcher *mlx5dv_dr_matcher_create(struct mlx5dv_dr_table *table, uint16_t priority, uint8_t match_criteria_enable, struct mlx5dv_flow_match_parameters *mask) {
+ return Call(M5Sym()->mlx5dv_dr_matcher_create, table, priority, match_criteria_enable, mask);
+}
+
+Y_HIDDEN
+int mlx5dv_dr_matcher_destroy(struct mlx5dv_dr_matcher *matcher) {
+ return Call(M5Sym()->mlx5dv_dr_matcher_destroy, matcher);
+}
+
+Y_HIDDEN
+struct mlx5dv_dr_rule *mlx5dv_dr_rule_create(struct mlx5dv_dr_matcher *matcher, struct mlx5dv_flow_match_parameters *value, size_t num_actions, struct mlx5dv_dr_action *actions[]) {
+ return Call(M5Sym()->mlx5dv_dr_rule_create, matcher, value, num_actions, actions);
+}
+
+Y_HIDDEN
+int mlx5dv_dr_rule_destroy(struct mlx5dv_dr_rule *rule) {
+ return Call(M5Sym()->mlx5dv_dr_rule_destroy, rule);
+}
+
+Y_HIDDEN
+struct mlx5dv_dr_table *mlx5dv_dr_table_create(struct mlx5dv_dr_domain *domain, uint32_t level) {
+ return Call(M5Sym()->mlx5dv_dr_table_create, domain, level);
+}
+
+Y_HIDDEN
+int mlx5dv_dr_table_destroy(struct mlx5dv_dr_table *table) {
+ return Call(M5Sym()->mlx5dv_dr_table_destroy, table);
+}
+
+Y_HIDDEN
+int mlx5dv_dump_dr_domain(FILE *fout, struct mlx5dv_dr_domain *domain) {
+ return Call(M5Sym()->mlx5dv_dump_dr_domain, fout, domain);
+}
+
+Y_HIDDEN
+void mlx5dv_free_var(struct mlx5dv_var *dv_var) {
+ return Call(M5Sym()->mlx5dv_free_var, dv_var);
+}
+
+Y_HIDDEN
+int mlx5dv_init_obj(struct mlx5dv_obj *obj, uint64_t obj_type) {
+ return Call(M5Sym()->mlx5dv_init_obj, obj, obj_type);
+}
+
+Y_HIDDEN
+struct ibv_context *mlx5dv_open_device(struct ibv_device *device, struct mlx5dv_context_attr *attr) {
+ return Call(M5Sym()->mlx5dv_open_device, device, attr);
+}
+
+Y_HIDDEN
+struct mlx5dv_pp *mlx5dv_pp_alloc(struct ibv_context *context, size_t pp_context_sz, const void *pp_context, uint32_t flags) {
+ return Call(M5Sym()->mlx5dv_pp_alloc, context, pp_context_sz, pp_context, flags);
+}
+
+Y_HIDDEN
+void mlx5dv_pp_free(struct mlx5dv_pp *pp) {
+ return Call(M5Sym()->mlx5dv_pp_free, pp);
+}
+
+Y_HIDDEN
+int mlx5dv_query_device(struct ibv_context *ctx_in, struct mlx5dv_context *attrs_out) {
+ return Call(M5Sym()->mlx5dv_query_device, ctx_in, attrs_out);
+}
+
+Y_HIDDEN
+int mlx5dv_query_devx_port(struct ibv_context *ctx, uint32_t port_num, struct mlx5dv_devx_port *mlx5_devx_port) {
+ return Call(M5Sym()->mlx5dv_query_devx_port, ctx, port_num, mlx5_devx_port);
+}
+
+Y_HIDDEN
+int mlx5dv_set_context_attr(struct ibv_context *context, enum mlx5dv_set_ctx_attr_type type, void *attr) {
+ return Call(M5Sym()->mlx5dv_set_context_attr, context, type, attr);
+}