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
86enum mlx5_ib_uapi_query_port_flags {
87 MLX5_IB_UAPI_QUERY_PORT_VPORT = 1 << 0,
88 MLX5_IB_UAPI_QUERY_PORT_VPORT_VHCA_ID = 1 << 1,
89 MLX5_IB_UAPI_QUERY_PORT_VPORT_STEERING_ICM_RX = 1 << 2,
90 MLX5_IB_UAPI_QUERY_PORT_VPORT_STEERING_ICM_TX = 1 << 3,
91 MLX5_IB_UAPI_QUERY_PORT_VPORT_REG_C0 = 1 << 4,
92 MLX5_IB_UAPI_QUERY_PORT_ESW_OWNER_VHCA_ID = 1 << 5,
93};
94
95struct mlx5_ib_uapi_reg {
96 __u32 value;
97 __u32 mask;
98};
99
100struct mlx5_ib_uapi_query_port {
101 __aligned_u64 flags;
102 __u16 vport;
103 __u16 vport_vhca_id;
104 __u16 esw_owner_vhca_id;
105 __u16 rsvd0;
106 __aligned_u64 vport_steering_icm_rx;
107 __aligned_u64 vport_steering_icm_tx;
108 struct mlx5_ib_uapi_reg reg_c0;
109};
110
111#endif
112
113