1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33#ifndef MLX5_USER_IOCTL_VERBS_H
34#define MLX5_USER_IOCTL_VERBS_H
35
36#include <linux/types.h>
37
38enum mlx5_ib_uapi_flow_action_flags {
39 MLX5_IB_UAPI_FLOW_ACTION_FLAGS_REQUIRE_METADATA = 1 << 0,
40};
41
42enum mlx5_ib_uapi_flow_table_type {
43 MLX5_IB_UAPI_FLOW_TABLE_TYPE_NIC_RX = 0x0,
44 MLX5_IB_UAPI_FLOW_TABLE_TYPE_NIC_TX = 0x1,
45 MLX5_IB_UAPI_FLOW_TABLE_TYPE_FDB = 0x2,
46 MLX5_IB_UAPI_FLOW_TABLE_TYPE_RDMA_RX = 0x3,
47 MLX5_IB_UAPI_FLOW_TABLE_TYPE_RDMA_TX = 0x4,
48};
49
50enum mlx5_ib_uapi_flow_action_packet_reformat_type {
51 MLX5_IB_UAPI_FLOW_ACTION_PACKET_REFORMAT_TYPE_L2_TUNNEL_TO_L2 = 0x0,
52 MLX5_IB_UAPI_FLOW_ACTION_PACKET_REFORMAT_TYPE_L2_TO_L2_TUNNEL = 0x1,
53 MLX5_IB_UAPI_FLOW_ACTION_PACKET_REFORMAT_TYPE_L3_TUNNEL_TO_L2 = 0x2,
54 MLX5_IB_UAPI_FLOW_ACTION_PACKET_REFORMAT_TYPE_L2_TO_L3_TUNNEL = 0x3,
55};
56
57struct mlx5_ib_uapi_devx_async_cmd_hdr {
58 __aligned_u64 wr_id;
59 __u8 out_data[];
60};
61
62enum mlx5_ib_uapi_dm_type {
63 MLX5_IB_UAPI_DM_TYPE_MEMIC,
64 MLX5_IB_UAPI_DM_TYPE_STEERING_SW_ICM,
65 MLX5_IB_UAPI_DM_TYPE_HEADER_MODIFY_SW_ICM,
66};
67
68enum mlx5_ib_uapi_devx_create_event_channel_flags {
69 MLX5_IB_UAPI_DEVX_CR_EV_CH_FLAGS_OMIT_DATA = 1 << 0,
70};
71
72struct mlx5_ib_uapi_devx_async_event_hdr {
73 __aligned_u64 cookie;
74 __u8 out_data[];
75};
76
77enum mlx5_ib_uapi_pp_alloc_flags {
78 MLX5_IB_UAPI_PP_ALLOC_FLAGS_DEDICATED_INDEX = 1 << 0,
79};
80
81enum mlx5_ib_uapi_uar_alloc_type {
82 MLX5_IB_UAPI_UAR_ALLOC_TYPE_BF = 0x0,
83 MLX5_IB_UAPI_UAR_ALLOC_TYPE_NC = 0x1,
84};
85
86#endif
87
88