net/mlx5: Declare more strictly devlink encap mode
Devlink has UAPI declaration for encap mode, so there is no need to be loose on the data get/set by drivers. Update call sites to use enum devlink_eswitch_encap_mode instead of plain u8. Suggested-by: Parav Pandit <parav@mellanox.com> Signed-off-by: Leon Romanovsky <leonro@mellanox.com> Acked-by: Jiri Pirko <jiri@mellanox.com> Reviewed-by: Parav Pandit <parav@mellanox.com> Reviewed-by: Petr Vorel <pvorel@suse.cz>
This commit is contained in:
Родитель
1f8a7bee27
Коммит
98fdbea550
|
@ -176,7 +176,7 @@ struct mlx5_esw_offload {
|
||||||
const struct mlx5_eswitch_rep_ops *rep_ops[NUM_REP_TYPES];
|
const struct mlx5_eswitch_rep_ops *rep_ops[NUM_REP_TYPES];
|
||||||
u8 inline_mode;
|
u8 inline_mode;
|
||||||
u64 num_flows;
|
u64 num_flows;
|
||||||
u8 encap;
|
enum devlink_eswitch_encap_mode encap;
|
||||||
};
|
};
|
||||||
|
|
||||||
/* E-Switch MC FDB table hash node */
|
/* E-Switch MC FDB table hash node */
|
||||||
|
@ -357,9 +357,11 @@ int mlx5_devlink_eswitch_inline_mode_set(struct devlink *devlink, u8 mode,
|
||||||
struct netlink_ext_ack *extack);
|
struct netlink_ext_ack *extack);
|
||||||
int mlx5_devlink_eswitch_inline_mode_get(struct devlink *devlink, u8 *mode);
|
int mlx5_devlink_eswitch_inline_mode_get(struct devlink *devlink, u8 *mode);
|
||||||
int mlx5_eswitch_inline_mode_get(struct mlx5_eswitch *esw, int nvfs, u8 *mode);
|
int mlx5_eswitch_inline_mode_get(struct mlx5_eswitch *esw, int nvfs, u8 *mode);
|
||||||
int mlx5_devlink_eswitch_encap_mode_set(struct devlink *devlink, u8 encap,
|
int mlx5_devlink_eswitch_encap_mode_set(struct devlink *devlink,
|
||||||
|
enum devlink_eswitch_encap_mode encap,
|
||||||
struct netlink_ext_ack *extack);
|
struct netlink_ext_ack *extack);
|
||||||
int mlx5_devlink_eswitch_encap_mode_get(struct devlink *devlink, u8 *encap);
|
int mlx5_devlink_eswitch_encap_mode_get(struct devlink *devlink,
|
||||||
|
enum devlink_eswitch_encap_mode *encap);
|
||||||
void *mlx5_eswitch_get_uplink_priv(struct mlx5_eswitch *esw, u8 rep_type);
|
void *mlx5_eswitch_get_uplink_priv(struct mlx5_eswitch *esw, u8 rep_type);
|
||||||
|
|
||||||
int mlx5_eswitch_add_vlan_action(struct mlx5_eswitch *esw,
|
int mlx5_eswitch_add_vlan_action(struct mlx5_eswitch *esw,
|
||||||
|
|
|
@ -2160,7 +2160,8 @@ out:
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int mlx5_devlink_eswitch_encap_mode_set(struct devlink *devlink, u8 encap,
|
int mlx5_devlink_eswitch_encap_mode_set(struct devlink *devlink,
|
||||||
|
enum devlink_eswitch_encap_mode encap,
|
||||||
struct netlink_ext_ack *extack)
|
struct netlink_ext_ack *extack)
|
||||||
{
|
{
|
||||||
struct mlx5_core_dev *dev = devlink_priv(devlink);
|
struct mlx5_core_dev *dev = devlink_priv(devlink);
|
||||||
|
@ -2209,7 +2210,8 @@ int mlx5_devlink_eswitch_encap_mode_set(struct devlink *devlink, u8 encap,
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
int mlx5_devlink_eswitch_encap_mode_get(struct devlink *devlink, u8 *encap)
|
int mlx5_devlink_eswitch_encap_mode_get(struct devlink *devlink,
|
||||||
|
enum devlink_eswitch_encap_mode *encap)
|
||||||
{
|
{
|
||||||
struct mlx5_core_dev *dev = devlink_priv(devlink);
|
struct mlx5_core_dev *dev = devlink_priv(devlink);
|
||||||
struct mlx5_eswitch *esw = dev->priv.eswitch;
|
struct mlx5_eswitch *esw = dev->priv.eswitch;
|
||||||
|
|
|
@ -530,8 +530,10 @@ struct devlink_ops {
|
||||||
int (*eswitch_inline_mode_get)(struct devlink *devlink, u8 *p_inline_mode);
|
int (*eswitch_inline_mode_get)(struct devlink *devlink, u8 *p_inline_mode);
|
||||||
int (*eswitch_inline_mode_set)(struct devlink *devlink, u8 inline_mode,
|
int (*eswitch_inline_mode_set)(struct devlink *devlink, u8 inline_mode,
|
||||||
struct netlink_ext_ack *extack);
|
struct netlink_ext_ack *extack);
|
||||||
int (*eswitch_encap_mode_get)(struct devlink *devlink, u8 *p_encap_mode);
|
int (*eswitch_encap_mode_get)(struct devlink *devlink,
|
||||||
int (*eswitch_encap_mode_set)(struct devlink *devlink, u8 encap_mode,
|
enum devlink_eswitch_encap_mode *p_encap_mode);
|
||||||
|
int (*eswitch_encap_mode_set)(struct devlink *devlink,
|
||||||
|
enum devlink_eswitch_encap_mode encap_mode,
|
||||||
struct netlink_ext_ack *extack);
|
struct netlink_ext_ack *extack);
|
||||||
int (*info_get)(struct devlink *devlink, struct devlink_info_req *req,
|
int (*info_get)(struct devlink *devlink, struct devlink_info_req *req,
|
||||||
struct netlink_ext_ack *extack);
|
struct netlink_ext_ack *extack);
|
||||||
|
|
|
@ -1552,7 +1552,8 @@ static int devlink_nl_eswitch_fill(struct sk_buff *msg, struct devlink *devlink,
|
||||||
u32 seq, int flags)
|
u32 seq, int flags)
|
||||||
{
|
{
|
||||||
const struct devlink_ops *ops = devlink->ops;
|
const struct devlink_ops *ops = devlink->ops;
|
||||||
u8 inline_mode, encap_mode;
|
enum devlink_eswitch_encap_mode encap_mode;
|
||||||
|
u8 inline_mode;
|
||||||
void *hdr;
|
void *hdr;
|
||||||
int err = 0;
|
int err = 0;
|
||||||
u16 mode;
|
u16 mode;
|
||||||
|
@ -1628,7 +1629,8 @@ static int devlink_nl_cmd_eswitch_set_doit(struct sk_buff *skb,
|
||||||
{
|
{
|
||||||
struct devlink *devlink = info->user_ptr[0];
|
struct devlink *devlink = info->user_ptr[0];
|
||||||
const struct devlink_ops *ops = devlink->ops;
|
const struct devlink_ops *ops = devlink->ops;
|
||||||
u8 inline_mode, encap_mode;
|
enum devlink_eswitch_encap_mode encap_mode;
|
||||||
|
u8 inline_mode;
|
||||||
int err = 0;
|
int err = 0;
|
||||||
u16 mode;
|
u16 mode;
|
||||||
|
|
||||||
|
|
Загрузка…
Ссылка в новой задаче