Commit 216ba9f4 authored by Jiri Pirko's avatar Jiri Pirko Committed by Jakub Kicinski

devlink: move port_del() to devlink_port_ops

Move port_del() from devlink_ops into newly introduced devlink_port_ops.
Signed-off-by: default avatarJiri Pirko <jiri@nvidia.com>
Signed-off-by: default avatarJakub Kicinski <kuba@kernel.org>
parent 216aa67f
...@@ -320,7 +320,6 @@ static const struct devlink_ops mlx5_devlink_ops = { ...@@ -320,7 +320,6 @@ static const struct devlink_ops mlx5_devlink_ops = {
#endif #endif
#ifdef CONFIG_MLX5_SF_MANAGER #ifdef CONFIG_MLX5_SF_MANAGER
.port_new = mlx5_devlink_sf_port_new, .port_new = mlx5_devlink_sf_port_new,
.port_del = mlx5_devlink_sf_port_del,
#endif #endif
.flash_update = mlx5_devlink_flash_update, .flash_update = mlx5_devlink_flash_update,
.info_get = mlx5_devlink_info_get, .info_get = mlx5_devlink_info_get,
......
...@@ -145,6 +145,9 @@ struct devlink_port *mlx5_esw_offloads_devlink_port(struct mlx5_eswitch *esw, u1 ...@@ -145,6 +145,9 @@ struct devlink_port *mlx5_esw_offloads_devlink_port(struct mlx5_eswitch *esw, u1
} }
static const struct devlink_port_ops mlx5_esw_dl_sf_port_ops = { static const struct devlink_port_ops mlx5_esw_dl_sf_port_ops = {
#ifdef CONFIG_MLX5_SF_MANAGER
.port_del = mlx5_devlink_sf_port_del,
#endif
.port_fn_hw_addr_get = mlx5_devlink_port_fn_hw_addr_get, .port_fn_hw_addr_get = mlx5_devlink_port_fn_hw_addr_get,
.port_fn_hw_addr_set = mlx5_devlink_port_fn_hw_addr_set, .port_fn_hw_addr_set = mlx5_devlink_port_fn_hw_addr_set,
.port_fn_roce_get = mlx5_devlink_port_fn_roce_get, .port_fn_roce_get = mlx5_devlink_port_fn_roce_get,
......
...@@ -1447,23 +1447,6 @@ struct devlink_ops { ...@@ -1447,23 +1447,6 @@ struct devlink_ops {
int (*port_new)(struct devlink *devlink, int (*port_new)(struct devlink *devlink,
const struct devlink_port_new_attrs *attrs, const struct devlink_port_new_attrs *attrs,
struct netlink_ext_ack *extack); struct netlink_ext_ack *extack);
/**
* port_del() - Delete a port function
* @devlink: Devlink instance
* @port: The devlink port
* @extack: extack for reporting error messages
*
* Devlink core will call this device driver function upon user request
* to delete a previously created port function
*
* Notes:
* - On success, drivers must unregister the corresponding devlink
* port
*
* Return: 0 on success, negative value otherwise.
*/
int (*port_del)(struct devlink *devlink, struct devlink_port *port,
struct netlink_ext_ack *extack);
/** /**
* Rate control callbacks. * Rate control callbacks.
...@@ -1560,6 +1543,9 @@ void devlink_free(struct devlink *devlink); ...@@ -1560,6 +1543,9 @@ void devlink_free(struct devlink *devlink);
* @port_unsplit: Callback used to unsplit the port group back into * @port_unsplit: Callback used to unsplit the port group back into
* a single port. * a single port.
* @port_type_set: Callback used to set a type of a port. * @port_type_set: Callback used to set a type of a port.
* @port_del: Callback used to delete selected port along with related function.
* Devlink core calls this upon user request to delete
* a port previously created by devlink_ops->port_new().
* @port_fn_hw_addr_get: Callback used to set port function's hardware address. * @port_fn_hw_addr_get: Callback used to set port function's hardware address.
* Should be used by device drivers to report * Should be used by device drivers to report
* the hardware address of a function managed * the hardware address of a function managed
...@@ -1602,6 +1588,8 @@ struct devlink_port_ops { ...@@ -1602,6 +1588,8 @@ struct devlink_port_ops {
struct netlink_ext_ack *extack); struct netlink_ext_ack *extack);
int (*port_type_set)(struct devlink_port *devlink_port, int (*port_type_set)(struct devlink_port *devlink_port,
enum devlink_port_type port_type); enum devlink_port_type port_type);
int (*port_del)(struct devlink *devlink, struct devlink_port *port,
struct netlink_ext_ack *extack);
int (*port_fn_hw_addr_get)(struct devlink_port *port, u8 *hw_addr, int (*port_fn_hw_addr_get)(struct devlink_port *port, u8 *hw_addr,
int *hw_addr_len, int *hw_addr_len,
struct netlink_ext_ack *extack); struct netlink_ext_ack *extack);
......
...@@ -1348,7 +1348,7 @@ static int devlink_nl_cmd_port_new_doit(struct sk_buff *skb, ...@@ -1348,7 +1348,7 @@ static int devlink_nl_cmd_port_new_doit(struct sk_buff *skb,
struct devlink_port_new_attrs new_attrs = {}; struct devlink_port_new_attrs new_attrs = {};
struct devlink *devlink = info->user_ptr[0]; struct devlink *devlink = info->user_ptr[0];
if (!devlink->ops->port_new || !devlink->ops->port_del) if (!devlink->ops->port_new)
return -EOPNOTSUPP; return -EOPNOTSUPP;
if (!info->attrs[DEVLINK_ATTR_PORT_FLAVOUR] || if (!info->attrs[DEVLINK_ATTR_PORT_FLAVOUR] ||
...@@ -1387,10 +1387,10 @@ static int devlink_nl_cmd_port_del_doit(struct sk_buff *skb, ...@@ -1387,10 +1387,10 @@ static int devlink_nl_cmd_port_del_doit(struct sk_buff *skb,
struct netlink_ext_ack *extack = info->extack; struct netlink_ext_ack *extack = info->extack;
struct devlink *devlink = info->user_ptr[0]; struct devlink *devlink = info->user_ptr[0];
if (!devlink->ops->port_del) if (!devlink_port->ops->port_del)
return -EOPNOTSUPP; return -EOPNOTSUPP;
return devlink->ops->port_del(devlink, devlink_port, extack); return devlink_port->ops->port_del(devlink, devlink_port, extack);
} }
static int static int
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment