[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-Id: <20220818130042.535762-5-jiri@resnulli.us>
Date: Thu, 18 Aug 2022 15:00:42 +0200
From: Jiri Pirko <jiri@...nulli.us>
To: netdev@...r.kernel.org
Cc: davem@...emloft.net, kuba@...nel.org, idosch@...dia.com,
pabeni@...hat.com, edumazet@...gle.com, saeedm@...dia.com,
jacob.e.keller@...el.com, vikas.gupta@...adcom.com,
gospo@...adcom.com
Subject: [patch net-next 4/4] net: devlink: expose default flash update target
From: Jiri Pirko <jiri@...dia.com>
Allow driver to mark certain version obtained by info_get() op as
"flash update default". Expose this information to user which allows him
to understand what version is going to be affected if he does flash
update without specifying the component. Implement this in netdevsim.
Example:
$ devlink dev info
netdevsim/netdevsim10:
driver netdevsim
versions:
running:
fw.mgmt 10.20.30
fw 11.22.33
flash_components:
fw.mgmt
flash_update_default fw
Signed-off-by: Jiri Pirko <jiri@...dia.com>
---
drivers/net/netdevsim/dev.c | 3 ++-
include/net/devlink.h | 3 +++
include/uapi/linux/devlink.h | 1 +
net/core/devlink.c | 12 ++++++++++++
4 files changed, 18 insertions(+), 1 deletion(-)
diff --git a/drivers/net/netdevsim/dev.c b/drivers/net/netdevsim/dev.c
index 97281b6aa41f..f999b9477a26 100644
--- a/drivers/net/netdevsim/dev.c
+++ b/drivers/net/netdevsim/dev.c
@@ -995,7 +995,8 @@ static int nsim_dev_info_get(struct devlink *devlink,
if (err)
return err;
- return devlink_info_version_running_put(req, "fw", "11.22.33");
+ return devlink_info_version_running_put_ext(req, "fw", "11.22.33",
+ DEVLINK_INFO_VERSION_TYPE_FLASH_UPDATE_DEFAULT);
}
#define NSIM_DEV_FLASH_SIZE 500000
diff --git a/include/net/devlink.h b/include/net/devlink.h
index 9bf4f03feca6..bfe988a56067 100644
--- a/include/net/devlink.h
+++ b/include/net/devlink.h
@@ -1719,6 +1719,9 @@ enum devlink_info_version_type {
DEVLINK_INFO_VERSION_TYPE_COMPONENT, /* May be used as flash update
* component by name.
*/
+ DEVLINK_INFO_VERSION_TYPE_FLASH_UPDATE_DEFAULT, /* Is default flash
+ * update target.
+ */
};
int devlink_info_version_fixed_put(struct devlink_info_req *req,
diff --git a/include/uapi/linux/devlink.h b/include/uapi/linux/devlink.h
index 7f2874189188..01e348177f60 100644
--- a/include/uapi/linux/devlink.h
+++ b/include/uapi/linux/devlink.h
@@ -608,6 +608,7 @@ enum devlink_attr {
DEVLINK_ATTR_SELFTESTS, /* nested */
DEVLINK_ATTR_INFO_VERSION_IS_COMPONENT, /* u8 0 or 1 */
+ DEVLINK_ATTR_INFO_VERSION_IS_FLASH_UPDATE_DEFAULT, /* u8 0 or 1 */
/* add new attributes above here, update the policy in devlink.c */
diff --git a/net/core/devlink.c b/net/core/devlink.c
index 23a5fd92ecaa..de583fb2ed12 100644
--- a/net/core/devlink.c
+++ b/net/core/devlink.c
@@ -4748,6 +4748,7 @@ struct devlink_info_req {
enum devlink_info_version_type version_type,
void *version_cb_priv);
void *version_cb_priv;
+ unsigned int flash_update_default_count;
};
struct devlink_flash_component_lookup_ctx {
@@ -6656,6 +6657,12 @@ static int devlink_info_version_put(struct devlink_info_req *req, int attr,
if (!req->msg)
return 0;
+ if (version_type == DEVLINK_INFO_VERSION_TYPE_FLASH_UPDATE_DEFAULT) {
+ if (WARN_ON(req->flash_update_default_count++))
+ /* Max one flash update default is allowed. */
+ return -EINVAL;
+ }
+
nest = nla_nest_start_noflag(req->msg, attr);
if (!nest)
return -EMSGSIZE;
@@ -6675,6 +6682,11 @@ static int devlink_info_version_put(struct devlink_info_req *req, int attr,
if (err)
goto nla_put_failure;
+ err = nla_put_u8(req->msg, DEVLINK_ATTR_INFO_VERSION_IS_FLASH_UPDATE_DEFAULT,
+ version_type == DEVLINK_INFO_VERSION_TYPE_FLASH_UPDATE_DEFAULT);
+ if (err)
+ goto nla_put_failure;
+
nla_nest_end(req->msg, nest);
return 0;
--
2.37.1
Powered by blists - more mailing lists