Merge branch 'mellanox/mlx5-next' into rdma.git for/next
From the mlx5-next branch at git://git.kernel.org/pub/scm/linux/kernel/git/mellanox/linux Required for dependencies in following patches * branch 'mellanox/mlx5-next': net/mlx5: Add support in forward to namespace {IB/net}/mlx5: Simplify don't trap code net/mlx5: Replace zero-length array with flexible-array Signed-off-by: Jason Gunthorpe <jgg@mellanox.com>
This commit is contained in:
commit
10c2615513
|
@ -3699,12 +3699,13 @@ static struct mlx5_ib_flow_handler *_create_flow_rule(struct mlx5_ib_dev *dev,
|
|||
if (!dest_num)
|
||||
rule_dst = NULL;
|
||||
} else {
|
||||
if (flow_attr->flags & IB_FLOW_ATTR_FLAGS_DONT_TRAP)
|
||||
flow_act.action |=
|
||||
MLX5_FLOW_CONTEXT_ACTION_FWD_NEXT_PRIO;
|
||||
if (is_egress)
|
||||
flow_act.action |= MLX5_FLOW_CONTEXT_ACTION_ALLOW;
|
||||
else
|
||||
flow_act.action |=
|
||||
dest_num ? MLX5_FLOW_CONTEXT_ACTION_FWD_DEST :
|
||||
MLX5_FLOW_CONTEXT_ACTION_FWD_NEXT_PRIO;
|
||||
else if (dest_num)
|
||||
flow_act.action |= MLX5_FLOW_CONTEXT_ACTION_FWD_DEST;
|
||||
}
|
||||
|
||||
if ((spec->flow_context.flags & FLOW_CONTEXT_HAS_TAG) &&
|
||||
|
@ -3748,30 +3749,6 @@ static struct mlx5_ib_flow_handler *create_flow_rule(struct mlx5_ib_dev *dev,
|
|||
return _create_flow_rule(dev, ft_prio, flow_attr, dst, 0, NULL);
|
||||
}
|
||||
|
||||
static struct mlx5_ib_flow_handler *create_dont_trap_rule(struct mlx5_ib_dev *dev,
|
||||
struct mlx5_ib_flow_prio *ft_prio,
|
||||
struct ib_flow_attr *flow_attr,
|
||||
struct mlx5_flow_destination *dst)
|
||||
{
|
||||
struct mlx5_ib_flow_handler *handler_dst = NULL;
|
||||
struct mlx5_ib_flow_handler *handler = NULL;
|
||||
|
||||
handler = create_flow_rule(dev, ft_prio, flow_attr, NULL);
|
||||
if (!IS_ERR(handler)) {
|
||||
handler_dst = create_flow_rule(dev, ft_prio,
|
||||
flow_attr, dst);
|
||||
if (IS_ERR(handler_dst)) {
|
||||
mlx5_del_flow_rules(handler->rule);
|
||||
ft_prio->refcount--;
|
||||
kfree(handler);
|
||||
handler = handler_dst;
|
||||
} else {
|
||||
list_add(&handler_dst->list, &handler->list);
|
||||
}
|
||||
}
|
||||
|
||||
return handler;
|
||||
}
|
||||
enum {
|
||||
LEFTOVERS_MC,
|
||||
LEFTOVERS_UC,
|
||||
|
@ -3975,15 +3952,11 @@ static struct ib_flow *mlx5_ib_create_flow(struct ib_qp *qp,
|
|||
}
|
||||
|
||||
if (flow_attr->type == IB_FLOW_ATTR_NORMAL) {
|
||||
if (flow_attr->flags & IB_FLOW_ATTR_FLAGS_DONT_TRAP) {
|
||||
handler = create_dont_trap_rule(dev, ft_prio,
|
||||
flow_attr, dst);
|
||||
} else {
|
||||
underlay_qpn = (mqp->flags & IB_QP_CREATE_SOURCE_QPN) ?
|
||||
mqp->underlay_qpn : 0;
|
||||
handler = _create_flow_rule(dev, ft_prio, flow_attr,
|
||||
dst, underlay_qpn, ucmd);
|
||||
}
|
||||
underlay_qpn = (mqp->flags & IB_QP_CREATE_SOURCE_QPN) ?
|
||||
mqp->underlay_qpn :
|
||||
0;
|
||||
handler = _create_flow_rule(dev, ft_prio, flow_attr, dst,
|
||||
underlay_qpn, ucmd);
|
||||
} else if (flow_attr->type == IB_FLOW_ATTR_ALL_DEFAULT ||
|
||||
flow_attr->type == IB_FLOW_ATTR_MC_DEFAULT) {
|
||||
handler = create_leftovers_rule(dev, ft_prio, flow_attr,
|
||||
|
|
|
@ -254,7 +254,7 @@ static void del_sw_flow_group(struct fs_node *node);
|
|||
static void del_sw_fte(struct fs_node *node);
|
||||
static void del_sw_prio(struct fs_node *node);
|
||||
static void del_sw_ns(struct fs_node *node);
|
||||
/* Delete rule (destination) is special case that
|
||||
/* Delete rule (destination) is special case that
|
||||
* requires to lock the FTE for all the deletion process.
|
||||
*/
|
||||
static void del_sw_hw_rule(struct fs_node *node);
|
||||
|
@ -384,6 +384,12 @@ static struct fs_prio *find_prio(struct mlx5_flow_namespace *ns,
|
|||
return NULL;
|
||||
}
|
||||
|
||||
static bool is_fwd_next_action(u32 action)
|
||||
{
|
||||
return action & (MLX5_FLOW_CONTEXT_ACTION_FWD_NEXT_PRIO |
|
||||
MLX5_FLOW_CONTEXT_ACTION_FWD_NEXT_NS);
|
||||
}
|
||||
|
||||
static bool check_valid_spec(const struct mlx5_flow_spec *spec)
|
||||
{
|
||||
int i;
|
||||
|
@ -502,7 +508,7 @@ static void del_sw_hw_rule(struct fs_node *node)
|
|||
fs_get_obj(rule, node);
|
||||
fs_get_obj(fte, rule->node.parent);
|
||||
trace_mlx5_fs_del_rule(rule);
|
||||
if (rule->sw_action == MLX5_FLOW_CONTEXT_ACTION_FWD_NEXT_PRIO) {
|
||||
if (is_fwd_next_action(rule->sw_action)) {
|
||||
mutex_lock(&rule->dest_attr.ft->lock);
|
||||
list_del(&rule->next_ft);
|
||||
mutex_unlock(&rule->dest_attr.ft->lock);
|
||||
|
@ -826,6 +832,36 @@ static struct mlx5_flow_table *find_prev_chained_ft(struct fs_prio *prio)
|
|||
return find_closest_ft(prio, true);
|
||||
}
|
||||
|
||||
static struct fs_prio *find_fwd_ns_prio(struct mlx5_flow_root_namespace *root,
|
||||
struct mlx5_flow_namespace *ns)
|
||||
{
|
||||
struct mlx5_flow_namespace *root_ns = &root->ns;
|
||||
struct fs_prio *iter_prio;
|
||||
struct fs_prio *prio;
|
||||
|
||||
fs_get_obj(prio, ns->node.parent);
|
||||
list_for_each_entry(iter_prio, &root_ns->node.children, node.list) {
|
||||
if (iter_prio == prio &&
|
||||
!list_is_last(&prio->node.children, &iter_prio->node.list))
|
||||
return list_next_entry(iter_prio, node.list);
|
||||
}
|
||||
return NULL;
|
||||
}
|
||||
|
||||
static struct mlx5_flow_table *find_next_fwd_ft(struct mlx5_flow_table *ft,
|
||||
struct mlx5_flow_act *flow_act)
|
||||
{
|
||||
struct mlx5_flow_root_namespace *root = find_root(&ft->node);
|
||||
struct fs_prio *prio;
|
||||
|
||||
if (flow_act->action & MLX5_FLOW_CONTEXT_ACTION_FWD_NEXT_NS)
|
||||
prio = find_fwd_ns_prio(root, ft->ns);
|
||||
else
|
||||
fs_get_obj(prio, ft->node.parent);
|
||||
|
||||
return (prio) ? find_next_chained_ft(prio) : NULL;
|
||||
}
|
||||
|
||||
static int connect_fts_in_prio(struct mlx5_core_dev *dev,
|
||||
struct fs_prio *prio,
|
||||
struct mlx5_flow_table *ft)
|
||||
|
@ -976,6 +1012,10 @@ static int connect_fwd_rules(struct mlx5_core_dev *dev,
|
|||
list_splice_init(&old_next_ft->fwd_rules, &new_next_ft->fwd_rules);
|
||||
mutex_unlock(&old_next_ft->lock);
|
||||
list_for_each_entry(iter, &new_next_ft->fwd_rules, next_ft) {
|
||||
if ((iter->sw_action & MLX5_FLOW_CONTEXT_ACTION_FWD_NEXT_NS) &&
|
||||
iter->ft->ns == new_next_ft->ns)
|
||||
continue;
|
||||
|
||||
err = _mlx5_modify_rule_destination(iter, &dest);
|
||||
if (err)
|
||||
pr_err("mlx5_core: failed to modify rule to point on flow table %d\n",
|
||||
|
@ -1077,6 +1117,7 @@ static struct mlx5_flow_table *__mlx5_create_flow_table(struct mlx5_flow_namespa
|
|||
next_ft = unmanaged ? ft_attr->next_ft :
|
||||
find_next_chained_ft(fs_prio);
|
||||
ft->def_miss_action = ns->def_miss_action;
|
||||
ft->ns = ns;
|
||||
err = root->cmds->create_flow_table(root, ft, log_table_sz, next_ft);
|
||||
if (err)
|
||||
goto free_ft;
|
||||
|
@ -1899,48 +1940,59 @@ mlx5_add_flow_rules(struct mlx5_flow_table *ft,
|
|||
{
|
||||
struct mlx5_flow_root_namespace *root = find_root(&ft->node);
|
||||
static const struct mlx5_flow_spec zero_spec = {};
|
||||
struct mlx5_flow_destination gen_dest = {};
|
||||
struct mlx5_flow_destination *gen_dest = NULL;
|
||||
struct mlx5_flow_table *next_ft = NULL;
|
||||
struct mlx5_flow_handle *handle = NULL;
|
||||
u32 sw_action = flow_act->action;
|
||||
struct fs_prio *prio;
|
||||
int i;
|
||||
|
||||
if (!spec)
|
||||
spec = &zero_spec;
|
||||
|
||||
fs_get_obj(prio, ft->node.parent);
|
||||
if (flow_act->action == MLX5_FLOW_CONTEXT_ACTION_FWD_NEXT_PRIO) {
|
||||
if (!fwd_next_prio_supported(ft))
|
||||
return ERR_PTR(-EOPNOTSUPP);
|
||||
if (num_dest)
|
||||
return ERR_PTR(-EINVAL);
|
||||
mutex_lock(&root->chain_lock);
|
||||
next_ft = find_next_chained_ft(prio);
|
||||
if (next_ft) {
|
||||
gen_dest.type = MLX5_FLOW_DESTINATION_TYPE_FLOW_TABLE;
|
||||
gen_dest.ft = next_ft;
|
||||
dest = &gen_dest;
|
||||
num_dest = 1;
|
||||
flow_act->action = MLX5_FLOW_CONTEXT_ACTION_FWD_DEST;
|
||||
} else {
|
||||
mutex_unlock(&root->chain_lock);
|
||||
return ERR_PTR(-EOPNOTSUPP);
|
||||
}
|
||||
if (!is_fwd_next_action(sw_action))
|
||||
return _mlx5_add_flow_rules(ft, spec, flow_act, dest, num_dest);
|
||||
|
||||
if (!fwd_next_prio_supported(ft))
|
||||
return ERR_PTR(-EOPNOTSUPP);
|
||||
|
||||
mutex_lock(&root->chain_lock);
|
||||
next_ft = find_next_fwd_ft(ft, flow_act);
|
||||
if (!next_ft) {
|
||||
handle = ERR_PTR(-EOPNOTSUPP);
|
||||
goto unlock;
|
||||
}
|
||||
|
||||
gen_dest = kcalloc(num_dest + 1, sizeof(*dest),
|
||||
GFP_KERNEL);
|
||||
if (!gen_dest) {
|
||||
handle = ERR_PTR(-ENOMEM);
|
||||
goto unlock;
|
||||
}
|
||||
for (i = 0; i < num_dest; i++)
|
||||
gen_dest[i] = dest[i];
|
||||
gen_dest[i].type =
|
||||
MLX5_FLOW_DESTINATION_TYPE_FLOW_TABLE;
|
||||
gen_dest[i].ft = next_ft;
|
||||
dest = gen_dest;
|
||||
num_dest++;
|
||||
flow_act->action &= ~(MLX5_FLOW_CONTEXT_ACTION_FWD_NEXT_PRIO |
|
||||
MLX5_FLOW_CONTEXT_ACTION_FWD_NEXT_NS);
|
||||
flow_act->action |= MLX5_FLOW_CONTEXT_ACTION_FWD_DEST;
|
||||
handle = _mlx5_add_flow_rules(ft, spec, flow_act, dest, num_dest);
|
||||
if (IS_ERR(handle))
|
||||
goto unlock;
|
||||
|
||||
if (sw_action == MLX5_FLOW_CONTEXT_ACTION_FWD_NEXT_PRIO) {
|
||||
if (!IS_ERR_OR_NULL(handle) &&
|
||||
(list_empty(&handle->rule[0]->next_ft))) {
|
||||
mutex_lock(&next_ft->lock);
|
||||
list_add(&handle->rule[0]->next_ft,
|
||||
&next_ft->fwd_rules);
|
||||
mutex_unlock(&next_ft->lock);
|
||||
handle->rule[0]->sw_action = MLX5_FLOW_CONTEXT_ACTION_FWD_NEXT_PRIO;
|
||||
}
|
||||
mutex_unlock(&root->chain_lock);
|
||||
if (list_empty(&handle->rule[num_dest - 1]->next_ft)) {
|
||||
mutex_lock(&next_ft->lock);
|
||||
list_add(&handle->rule[num_dest - 1]->next_ft,
|
||||
&next_ft->fwd_rules);
|
||||
mutex_unlock(&next_ft->lock);
|
||||
handle->rule[num_dest - 1]->sw_action = sw_action;
|
||||
handle->rule[num_dest - 1]->ft = ft;
|
||||
}
|
||||
unlock:
|
||||
mutex_unlock(&root->chain_lock);
|
||||
kfree(gen_dest);
|
||||
return handle;
|
||||
}
|
||||
EXPORT_SYMBOL(mlx5_add_flow_rules);
|
||||
|
|
|
@ -138,6 +138,7 @@ struct fs_node {
|
|||
|
||||
struct mlx5_flow_rule {
|
||||
struct fs_node node;
|
||||
struct mlx5_flow_table *ft;
|
||||
struct mlx5_flow_destination dest_attr;
|
||||
/* next_ft should be accessed under chain_lock and only of
|
||||
* destination type is FWD_NEXT_fT.
|
||||
|
@ -175,6 +176,7 @@ struct mlx5_flow_table {
|
|||
u32 flags;
|
||||
struct rhltable fgs_hash;
|
||||
enum mlx5_flow_table_miss_action def_miss_action;
|
||||
struct mlx5_flow_namespace *ns;
|
||||
};
|
||||
|
||||
struct mlx5_ft_underlay_qp {
|
||||
|
|
|
@ -201,7 +201,7 @@ struct mlx5_rsc_debug {
|
|||
void *object;
|
||||
enum dbg_rsc_type type;
|
||||
struct dentry *root;
|
||||
struct mlx5_field_desc fields[0];
|
||||
struct mlx5_field_desc fields[];
|
||||
};
|
||||
|
||||
enum mlx5_dev_event {
|
||||
|
|
|
@ -42,6 +42,7 @@ enum {
|
|||
MLX5_FLOW_CONTEXT_ACTION_FWD_NEXT_PRIO = 1 << 16,
|
||||
MLX5_FLOW_CONTEXT_ACTION_ENCRYPT = 1 << 17,
|
||||
MLX5_FLOW_CONTEXT_ACTION_DECRYPT = 1 << 18,
|
||||
MLX5_FLOW_CONTEXT_ACTION_FWD_NEXT_NS = 1 << 19,
|
||||
};
|
||||
|
||||
enum {
|
||||
|
|
|
@ -1705,7 +1705,7 @@ struct mlx5_ifc_wq_bits {
|
|||
|
||||
u8 reserved_at_140[0x4c0];
|
||||
|
||||
struct mlx5_ifc_cmd_pas_bits pas[0];
|
||||
struct mlx5_ifc_cmd_pas_bits pas[];
|
||||
};
|
||||
|
||||
struct mlx5_ifc_rq_num_bits {
|
||||
|
@ -1923,7 +1923,7 @@ struct mlx5_ifc_resource_dump_menu_segment_bits {
|
|||
u8 reserved_at_20[0x10];
|
||||
u8 num_of_records[0x10];
|
||||
|
||||
struct mlx5_ifc_resource_dump_menu_record_bits record[0];
|
||||
struct mlx5_ifc_resource_dump_menu_record_bits record[];
|
||||
};
|
||||
|
||||
struct mlx5_ifc_resource_dump_resource_segment_bits {
|
||||
|
@ -1935,7 +1935,7 @@ struct mlx5_ifc_resource_dump_resource_segment_bits {
|
|||
|
||||
u8 index2[0x20];
|
||||
|
||||
u8 payload[0][0x20];
|
||||
u8 payload[][0x20];
|
||||
};
|
||||
|
||||
struct mlx5_ifc_resource_dump_terminate_segment_bits {
|
||||
|
@ -3012,7 +3012,7 @@ struct mlx5_ifc_flow_context_bits {
|
|||
|
||||
u8 reserved_at_1200[0x600];
|
||||
|
||||
union mlx5_ifc_dest_format_struct_flow_counter_list_auto_bits destination[0];
|
||||
union mlx5_ifc_dest_format_struct_flow_counter_list_auto_bits destination[];
|
||||
};
|
||||
|
||||
enum {
|
||||
|
@ -3305,7 +3305,7 @@ struct mlx5_ifc_rqtc_bits {
|
|||
|
||||
u8 reserved_at_e0[0x6a0];
|
||||
|
||||
struct mlx5_ifc_rq_num_bits rq_num[0];
|
||||
struct mlx5_ifc_rq_num_bits rq_num[];
|
||||
};
|
||||
|
||||
enum {
|
||||
|
@ -3417,7 +3417,7 @@ struct mlx5_ifc_nic_vport_context_bits {
|
|||
|
||||
u8 reserved_at_7e0[0x20];
|
||||
|
||||
u8 current_uc_mac_address[0][0x40];
|
||||
u8 current_uc_mac_address[][0x40];
|
||||
};
|
||||
|
||||
enum {
|
||||
|
@ -4340,7 +4340,7 @@ struct mlx5_ifc_query_xrc_srq_out_bits {
|
|||
|
||||
u8 reserved_at_280[0x600];
|
||||
|
||||
u8 pas[0][0x40];
|
||||
u8 pas[][0x40];
|
||||
};
|
||||
|
||||
struct mlx5_ifc_query_xrc_srq_in_bits {
|
||||
|
@ -4618,7 +4618,7 @@ struct mlx5_ifc_query_srq_out_bits {
|
|||
|
||||
u8 reserved_at_280[0x600];
|
||||
|
||||
u8 pas[0][0x40];
|
||||
u8 pas[][0x40];
|
||||
};
|
||||
|
||||
struct mlx5_ifc_query_srq_in_bits {
|
||||
|
@ -4829,7 +4829,7 @@ struct mlx5_ifc_query_qp_out_bits {
|
|||
|
||||
u8 reserved_at_800[0x80];
|
||||
|
||||
u8 pas[0][0x40];
|
||||
u8 pas[][0x40];
|
||||
};
|
||||
|
||||
struct mlx5_ifc_query_qp_in_bits {
|
||||
|
@ -5162,7 +5162,7 @@ struct mlx5_ifc_query_hca_vport_pkey_out_bits {
|
|||
|
||||
u8 reserved_at_40[0x40];
|
||||
|
||||
struct mlx5_ifc_pkey_bits pkey[0];
|
||||
struct mlx5_ifc_pkey_bits pkey[];
|
||||
};
|
||||
|
||||
struct mlx5_ifc_query_hca_vport_pkey_in_bits {
|
||||
|
@ -5198,7 +5198,7 @@ struct mlx5_ifc_query_hca_vport_gid_out_bits {
|
|||
u8 gids_num[0x10];
|
||||
u8 reserved_at_70[0x10];
|
||||
|
||||
struct mlx5_ifc_array128_auto_bits gid[0];
|
||||
struct mlx5_ifc_array128_auto_bits gid[];
|
||||
};
|
||||
|
||||
struct mlx5_ifc_query_hca_vport_gid_in_bits {
|
||||
|
@ -5466,7 +5466,7 @@ struct mlx5_ifc_query_flow_counter_out_bits {
|
|||
|
||||
u8 reserved_at_40[0x40];
|
||||
|
||||
struct mlx5_ifc_traffic_counter_bits flow_statistics[0];
|
||||
struct mlx5_ifc_traffic_counter_bits flow_statistics[];
|
||||
};
|
||||
|
||||
struct mlx5_ifc_query_flow_counter_in_bits {
|
||||
|
@ -5560,7 +5560,7 @@ struct mlx5_ifc_query_eq_out_bits {
|
|||
|
||||
u8 reserved_at_300[0x580];
|
||||
|
||||
u8 pas[0][0x40];
|
||||
u8 pas[][0x40];
|
||||
};
|
||||
|
||||
struct mlx5_ifc_query_eq_in_bits {
|
||||
|
@ -5585,7 +5585,7 @@ struct mlx5_ifc_packet_reformat_context_in_bits {
|
|||
u8 reserved_at_20[0x10];
|
||||
u8 reformat_data[2][0x8];
|
||||
|
||||
u8 more_reformat_data[0][0x8];
|
||||
u8 more_reformat_data[][0x8];
|
||||
};
|
||||
|
||||
struct mlx5_ifc_query_packet_reformat_context_out_bits {
|
||||
|
@ -5596,7 +5596,7 @@ struct mlx5_ifc_query_packet_reformat_context_out_bits {
|
|||
|
||||
u8 reserved_at_40[0xa0];
|
||||
|
||||
struct mlx5_ifc_packet_reformat_context_in_bits packet_reformat_context[0];
|
||||
struct mlx5_ifc_packet_reformat_context_in_bits packet_reformat_context[];
|
||||
};
|
||||
|
||||
struct mlx5_ifc_query_packet_reformat_context_in_bits {
|
||||
|
@ -5835,7 +5835,7 @@ struct mlx5_ifc_query_cq_out_bits {
|
|||
|
||||
u8 reserved_at_280[0x600];
|
||||
|
||||
u8 pas[0][0x40];
|
||||
u8 pas[][0x40];
|
||||
};
|
||||
|
||||
struct mlx5_ifc_query_cq_in_bits {
|
||||
|
@ -6442,7 +6442,7 @@ struct mlx5_ifc_modify_cq_in_bits {
|
|||
|
||||
u8 reserved_at_300[0x580];
|
||||
|
||||
u8 pas[0][0x40];
|
||||
u8 pas[][0x40];
|
||||
};
|
||||
|
||||
struct mlx5_ifc_modify_cong_status_out_bits {
|
||||
|
@ -6506,7 +6506,7 @@ struct mlx5_ifc_manage_pages_out_bits {
|
|||
|
||||
u8 reserved_at_60[0x20];
|
||||
|
||||
u8 pas[0][0x40];
|
||||
u8 pas[][0x40];
|
||||
};
|
||||
|
||||
enum {
|
||||
|
@ -6528,7 +6528,7 @@ struct mlx5_ifc_manage_pages_in_bits {
|
|||
|
||||
u8 input_num_entries[0x20];
|
||||
|
||||
u8 pas[0][0x40];
|
||||
u8 pas[][0x40];
|
||||
};
|
||||
|
||||
struct mlx5_ifc_mad_ifc_out_bits {
|
||||
|
@ -7483,7 +7483,7 @@ struct mlx5_ifc_create_xrc_srq_in_bits {
|
|||
|
||||
u8 reserved_at_300[0x580];
|
||||
|
||||
u8 pas[0][0x40];
|
||||
u8 pas[][0x40];
|
||||
};
|
||||
|
||||
struct mlx5_ifc_create_tis_out_bits {
|
||||
|
@ -7559,7 +7559,7 @@ struct mlx5_ifc_create_srq_in_bits {
|
|||
|
||||
u8 reserved_at_280[0x600];
|
||||
|
||||
u8 pas[0][0x40];
|
||||
u8 pas[][0x40];
|
||||
};
|
||||
|
||||
struct mlx5_ifc_create_sq_out_bits {
|
||||
|
@ -7720,7 +7720,7 @@ struct mlx5_ifc_create_qp_in_bits {
|
|||
u8 wq_umem_valid[0x1];
|
||||
u8 reserved_at_861[0x1f];
|
||||
|
||||
u8 pas[0][0x40];
|
||||
u8 pas[][0x40];
|
||||
};
|
||||
|
||||
struct mlx5_ifc_create_psv_out_bits {
|
||||
|
@ -7791,7 +7791,7 @@ struct mlx5_ifc_create_mkey_in_bits {
|
|||
|
||||
u8 reserved_at_320[0x560];
|
||||
|
||||
u8 klm_pas_mtt[0][0x20];
|
||||
u8 klm_pas_mtt[][0x20];
|
||||
};
|
||||
|
||||
enum {
|
||||
|
@ -7924,7 +7924,7 @@ struct mlx5_ifc_create_eq_in_bits {
|
|||
|
||||
u8 reserved_at_3c0[0x4c0];
|
||||
|
||||
u8 pas[0][0x40];
|
||||
u8 pas[][0x40];
|
||||
};
|
||||
|
||||
struct mlx5_ifc_create_dct_out_bits {
|
||||
|
@ -7981,7 +7981,7 @@ struct mlx5_ifc_create_cq_in_bits {
|
|||
u8 cq_umem_valid[0x1];
|
||||
u8 reserved_at_2e1[0x59f];
|
||||
|
||||
u8 pas[0][0x40];
|
||||
u8 pas[][0x40];
|
||||
};
|
||||
|
||||
struct mlx5_ifc_config_int_moderation_out_bits {
|
||||
|
@ -8337,7 +8337,7 @@ struct mlx5_ifc_access_register_out_bits {
|
|||
|
||||
u8 reserved_at_40[0x40];
|
||||
|
||||
u8 register_data[0][0x20];
|
||||
u8 register_data[][0x20];
|
||||
};
|
||||
|
||||
enum {
|
||||
|
@ -8357,7 +8357,7 @@ struct mlx5_ifc_access_register_in_bits {
|
|||
|
||||
u8 argument[0x20];
|
||||
|
||||
u8 register_data[0][0x20];
|
||||
u8 register_data[][0x20];
|
||||
};
|
||||
|
||||
struct mlx5_ifc_sltp_reg_bits {
|
||||
|
@ -9374,7 +9374,7 @@ struct mlx5_ifc_cmd_in_bits {
|
|||
u8 reserved_at_20[0x10];
|
||||
u8 op_mod[0x10];
|
||||
|
||||
u8 command[0][0x20];
|
||||
u8 command[][0x20];
|
||||
};
|
||||
|
||||
struct mlx5_ifc_cmd_if_box_bits {
|
||||
|
@ -9668,7 +9668,7 @@ struct mlx5_ifc_mcqi_reg_bits {
|
|||
u8 reserved_at_a0[0x10];
|
||||
u8 data_size[0x10];
|
||||
|
||||
union mlx5_ifc_mcqi_reg_data_bits data[0];
|
||||
union mlx5_ifc_mcqi_reg_data_bits data[];
|
||||
};
|
||||
|
||||
struct mlx5_ifc_mcc_reg_bits {
|
||||
|
@ -10254,7 +10254,7 @@ struct mlx5_ifc_umem_bits {
|
|||
|
||||
u8 num_of_mtt[0x40];
|
||||
|
||||
struct mlx5_ifc_mtt_bits mtt[0];
|
||||
struct mlx5_ifc_mtt_bits mtt[];
|
||||
};
|
||||
|
||||
struct mlx5_ifc_uctx_bits {
|
||||
|
@ -10379,7 +10379,7 @@ struct mlx5_ifc_mtrc_stdb_bits {
|
|||
u8 reserved_at_4[0x4];
|
||||
u8 read_size[0x18];
|
||||
u8 start_offset[0x20];
|
||||
u8 string_db_data[0];
|
||||
u8 string_db_data[];
|
||||
};
|
||||
|
||||
struct mlx5_ifc_mtrc_ctrl_bits {
|
||||
|
@ -10433,7 +10433,7 @@ struct mlx5_ifc_query_esw_functions_out_bits {
|
|||
struct mlx5_ifc_host_params_context_bits host_params_context;
|
||||
|
||||
u8 reserved_at_280[0x180];
|
||||
u8 host_sf_enable[0][0x40];
|
||||
u8 host_sf_enable[][0x40];
|
||||
};
|
||||
|
||||
struct mlx5_ifc_sf_partition_bits {
|
||||
|
@ -10453,7 +10453,7 @@ struct mlx5_ifc_query_sf_partitions_out_bits {
|
|||
|
||||
u8 reserved_at_60[0x20];
|
||||
|
||||
struct mlx5_ifc_sf_partition_bits sf_partition[0];
|
||||
struct mlx5_ifc_sf_partition_bits sf_partition[];
|
||||
};
|
||||
|
||||
struct mlx5_ifc_query_sf_partitions_in_bits {
|
||||
|
|
|
@ -410,7 +410,7 @@ struct mlx5_wqe_signature_seg {
|
|||
|
||||
struct mlx5_wqe_inline_seg {
|
||||
__be32 byte_count;
|
||||
__be32 data[0];
|
||||
__be32 data[];
|
||||
};
|
||||
|
||||
enum mlx5_sig_type {
|
||||
|
|
Loading…
Reference in a new issue