mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2026-05-16 06:41:39 -04:00
devlink: Add resource scope filtering to resource dump
Allow filtering the resource dump to device-level or port-level
resources using the 'scope' option.
Example - dump only device-level resources:
$ devlink resource show scope dev
pci/0000:03:00.0:
name max_local_SFs size 128 unit entry dpipe_tables none
name max_external_SFs size 128 unit entry dpipe_tables none
pci/0000:03:00.1:
name max_local_SFs size 128 unit entry dpipe_tables none
name max_external_SFs size 128 unit entry dpipe_tables none
Example - dump only port-level resources:
$ devlink resource show scope port
pci/0000:03:00.0/196608:
name max_SFs size 128 unit entry dpipe_tables none
pci/0000:03:00.0/196609:
name max_SFs size 128 unit entry dpipe_tables none
pci/0000:03:00.1/196708:
name max_SFs size 128 unit entry dpipe_tables none
pci/0000:03:00.1/196709:
name max_SFs size 128 unit entry dpipe_tables none
Signed-off-by: Or Har-Toov <ohartoov@nvidia.com>
Reviewed-by: Moshe Shemesh <moshe@nvidia.com>
Signed-off-by: Tariq Toukan <tariqt@nvidia.com>
Link: https://patch.msgid.link/20260407194107.148063-11-tariqt@nvidia.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
This commit is contained in:
committed by
Jakub Kicinski
parent
170e160a0e
commit
1bc45341a6
@@ -157,6 +157,14 @@ definitions:
|
||||
entries:
|
||||
-
|
||||
name: entry
|
||||
-
|
||||
type: enum
|
||||
name: resource-scope
|
||||
entries:
|
||||
-
|
||||
name: dev
|
||||
-
|
||||
name: port
|
||||
-
|
||||
type: enum
|
||||
name: reload-action
|
||||
@@ -873,6 +881,16 @@ attribute-sets:
|
||||
doc: Unique devlink instance index.
|
||||
checks:
|
||||
max: u32-max
|
||||
-
|
||||
name: resource-scope-mask
|
||||
type: u32
|
||||
enum: resource-scope
|
||||
enum-as-flags: true
|
||||
doc: |
|
||||
Bitmask selecting which resource classes to include in a
|
||||
resource-dump response. Bit 0 (dev) selects device-level
|
||||
resources; bit 1 (port) selects port-level resources.
|
||||
When absent all classes are returned.
|
||||
-
|
||||
name: dl-dev-stats
|
||||
subset-of: devlink
|
||||
@@ -1775,7 +1793,11 @@ operations:
|
||||
- resource-list
|
||||
dump:
|
||||
request:
|
||||
attributes: *dev-id-attrs
|
||||
attributes:
|
||||
- bus-name
|
||||
- dev-name
|
||||
- index
|
||||
- resource-scope-mask
|
||||
reply: *resource-dump-reply
|
||||
|
||||
-
|
||||
|
||||
@@ -645,6 +645,7 @@ enum devlink_attr {
|
||||
DEVLINK_ATTR_PARAM_RESET_DEFAULT, /* flag */
|
||||
|
||||
DEVLINK_ATTR_INDEX, /* uint */
|
||||
DEVLINK_ATTR_RESOURCE_SCOPE_MASK, /* u32 */
|
||||
|
||||
/* Add new attributes above here, update the spec in
|
||||
* Documentation/netlink/specs/devlink.yaml and re-generate
|
||||
@@ -704,6 +705,16 @@ enum devlink_resource_unit {
|
||||
DEVLINK_RESOURCE_UNIT_ENTRY,
|
||||
};
|
||||
|
||||
enum devlink_resource_scope {
|
||||
DEVLINK_RESOURCE_SCOPE_DEV_BIT,
|
||||
DEVLINK_RESOURCE_SCOPE_PORT_BIT,
|
||||
};
|
||||
|
||||
#define DEVLINK_RESOURCE_SCOPE_DEV \
|
||||
_BITUL(DEVLINK_RESOURCE_SCOPE_DEV_BIT)
|
||||
#define DEVLINK_RESOURCE_SCOPE_PORT \
|
||||
_BITUL(DEVLINK_RESOURCE_SCOPE_PORT_BIT)
|
||||
|
||||
enum devlink_port_fn_attr_cap {
|
||||
DEVLINK_PORT_FN_ATTR_CAP_ROCE_BIT,
|
||||
DEVLINK_PORT_FN_ATTR_CAP_MIGRATABLE_BIT,
|
||||
|
||||
@@ -313,10 +313,11 @@ static const struct nla_policy devlink_resource_dump_do_nl_policy[DEVLINK_ATTR_I
|
||||
};
|
||||
|
||||
/* DEVLINK_CMD_RESOURCE_DUMP - dump */
|
||||
static const struct nla_policy devlink_resource_dump_dump_nl_policy[DEVLINK_ATTR_INDEX + 1] = {
|
||||
static const struct nla_policy devlink_resource_dump_dump_nl_policy[DEVLINK_ATTR_RESOURCE_SCOPE_MASK + 1] = {
|
||||
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||
[DEVLINK_ATTR_INDEX] = NLA_POLICY_FULL_RANGE(NLA_UINT, &devlink_attr_index_range),
|
||||
[DEVLINK_ATTR_RESOURCE_SCOPE_MASK] = NLA_POLICY_MASK(NLA_U32, 0x3),
|
||||
};
|
||||
|
||||
/* DEVLINK_CMD_RELOAD - do */
|
||||
@@ -974,7 +975,7 @@ const struct genl_split_ops devlink_nl_ops[75] = {
|
||||
.cmd = DEVLINK_CMD_RESOURCE_DUMP,
|
||||
.dumpit = devlink_nl_resource_dump_dumpit,
|
||||
.policy = devlink_resource_dump_dump_nl_policy,
|
||||
.maxattr = DEVLINK_ATTR_INDEX,
|
||||
.maxattr = DEVLINK_ATTR_RESOURCE_SCOPE_MASK,
|
||||
.flags = GENL_CMD_CAP_DUMP,
|
||||
},
|
||||
{
|
||||
|
||||
@@ -398,11 +398,25 @@ devlink_nl_resource_dump_one(struct sk_buff *skb, struct devlink *devlink,
|
||||
struct netlink_callback *cb, int flags)
|
||||
{
|
||||
struct devlink_nl_dump_state *state = devlink_dump_state(cb);
|
||||
const struct genl_info *info = genl_info_dump(cb);
|
||||
struct devlink_port *devlink_port;
|
||||
struct nlattr *scope_attr = NULL;
|
||||
unsigned long port_idx;
|
||||
u32 scope = 0;
|
||||
int err;
|
||||
|
||||
if (!state->port_ctx.index_valid) {
|
||||
if (info->attrs && info->attrs[DEVLINK_ATTR_RESOURCE_SCOPE_MASK]) {
|
||||
scope_attr = info->attrs[DEVLINK_ATTR_RESOURCE_SCOPE_MASK];
|
||||
scope = nla_get_u32(scope_attr);
|
||||
if (!scope) {
|
||||
NL_SET_ERR_MSG_ATTR(info->extack, scope_attr,
|
||||
"empty resource scope selection");
|
||||
return -EINVAL;
|
||||
}
|
||||
}
|
||||
|
||||
if (!state->port_ctx.index_valid &&
|
||||
(!scope || (scope & DEVLINK_RESOURCE_SCOPE_DEV))) {
|
||||
err = devlink_resource_dump_fill_one(skb, devlink, NULL,
|
||||
cb, flags, &state->idx);
|
||||
if (err)
|
||||
@@ -410,6 +424,8 @@ devlink_nl_resource_dump_one(struct sk_buff *skb, struct devlink *devlink,
|
||||
state->idx = 0;
|
||||
}
|
||||
|
||||
if (scope && !(scope & DEVLINK_RESOURCE_SCOPE_PORT))
|
||||
goto out;
|
||||
/* Check in case port was removed between dump callbacks. */
|
||||
if (state->port_ctx.index_valid &&
|
||||
!xa_load(&devlink->ports, state->port_ctx.index))
|
||||
@@ -425,6 +441,7 @@ devlink_nl_resource_dump_one(struct sk_buff *skb, struct devlink *devlink,
|
||||
}
|
||||
state->idx = 0;
|
||||
}
|
||||
out:
|
||||
state->port_ctx.index_valid = false;
|
||||
state->port_ctx.index = 0;
|
||||
return 0;
|
||||
|
||||
Reference in New Issue
Block a user