Merge branch 'devlink-finish-conversion-to-generated-split_ops'
Jiri Pirko says: ==================== devlink: finish conversion to generated split_ops This patchset converts the remaining genetlink commands to generated split_ops and removes the existing small_ops arrays entirely alongside with shared netlink attribute policy. Patches #1-#6 are just small preparations and small fixes on multiple places. Note that couple of patches contain the "Fixes" tag but no need to put them into -net tree. Patch #7 is a simple rename preparation Patch #8 is the main one in this set and adds actual definitions of cmds in to yaml file. Patches #9-#10 finalize the change removing bits that are no longer in use. ==================== Link: https://lore.kernel.org/r/20231021112711.660606-1-jiri@resnulli.us Signed-off-by: Jakub Kicinski <kuba@kernel.org>
This commit is contained in:
commit
4fb56e3e92
@ -192,7 +192,7 @@ properties:
|
|||||||
type: string
|
type: string
|
||||||
type: &attr-type
|
type: &attr-type
|
||||||
description: The netlink attribute type
|
description: The netlink attribute type
|
||||||
enum: [ unused, pad, flag, binary,
|
enum: [ unused, pad, flag, binary, bitfield32,
|
||||||
uint, sint, u8, u16, u32, u64, s32, s64,
|
uint, sint, u8, u16, u32, u64, s32, s64,
|
||||||
string, nest, array-nest, nest-type-value ]
|
string, nest, array-nest, nest-type-value ]
|
||||||
doc:
|
doc:
|
||||||
|
File diff suppressed because it is too large
Load Diff
@ -182,7 +182,7 @@ members
|
|||||||
|
|
||||||
- ``name`` - The attribute name of the struct member
|
- ``name`` - The attribute name of the struct member
|
||||||
- ``type`` - One of the scalar types ``u8``, ``u16``, ``u32``, ``u64``, ``s8``,
|
- ``type`` - One of the scalar types ``u8``, ``u16``, ``u32``, ``u64``, ``s8``,
|
||||||
``s16``, ``s32``, ``s64``, ``string`` or ``binary``.
|
``s16``, ``s32``, ``s64``, ``string``, ``binary`` or ``bitfield32``.
|
||||||
- ``byte-order`` - ``big-endian`` or ``little-endian``
|
- ``byte-order`` - ``big-endian`` or ``little-endian``
|
||||||
- ``doc``, ``enum``, ``enum-as-flags``, ``display-hint`` - Same as for
|
- ``doc``, ``enum``, ``enum-as-flags``, ``display-hint`` - Same as for
|
||||||
:ref:`attribute definitions <attribute_properties>`
|
:ref:`attribute definitions <attribute_properties>`
|
||||||
|
@ -265,7 +265,7 @@ enum {
|
|||||||
* Documentation/networking/devlink/devlink-flash.rst
|
* Documentation/networking/devlink/devlink-flash.rst
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
enum {
|
enum devlink_flash_overwrite {
|
||||||
DEVLINK_FLASH_OVERWRITE_SETTINGS_BIT,
|
DEVLINK_FLASH_OVERWRITE_SETTINGS_BIT,
|
||||||
DEVLINK_FLASH_OVERWRITE_IDENTIFIERS_BIT,
|
DEVLINK_FLASH_OVERWRITE_IDENTIFIERS_BIT,
|
||||||
|
|
||||||
|
@ -492,7 +492,7 @@ free_msg:
|
|||||||
return -EMSGSIZE;
|
return -EMSGSIZE;
|
||||||
}
|
}
|
||||||
|
|
||||||
int devlink_nl_cmd_reload(struct sk_buff *skb, struct genl_info *info)
|
int devlink_nl_reload_doit(struct sk_buff *skb, struct genl_info *info)
|
||||||
{
|
{
|
||||||
struct devlink *devlink = info->user_ptr[0];
|
struct devlink *devlink = info->user_ptr[0];
|
||||||
enum devlink_reload_action action;
|
enum devlink_reload_action action;
|
||||||
@ -658,7 +658,7 @@ nla_put_failure:
|
|||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
int devlink_nl_cmd_eswitch_get_doit(struct sk_buff *skb, struct genl_info *info)
|
int devlink_nl_eswitch_get_doit(struct sk_buff *skb, struct genl_info *info)
|
||||||
{
|
{
|
||||||
struct devlink *devlink = info->user_ptr[0];
|
struct devlink *devlink = info->user_ptr[0];
|
||||||
struct sk_buff *msg;
|
struct sk_buff *msg;
|
||||||
@ -679,7 +679,7 @@ int devlink_nl_cmd_eswitch_get_doit(struct sk_buff *skb, struct genl_info *info)
|
|||||||
return genlmsg_reply(msg, info);
|
return genlmsg_reply(msg, info);
|
||||||
}
|
}
|
||||||
|
|
||||||
int devlink_nl_cmd_eswitch_set_doit(struct sk_buff *skb, struct genl_info *info)
|
int devlink_nl_eswitch_set_doit(struct sk_buff *skb, struct genl_info *info)
|
||||||
{
|
{
|
||||||
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;
|
||||||
@ -1108,7 +1108,7 @@ static int devlink_flash_component_get(struct devlink *devlink,
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int devlink_nl_cmd_flash_update(struct sk_buff *skb, struct genl_info *info)
|
int devlink_nl_flash_update_doit(struct sk_buff *skb, struct genl_info *info)
|
||||||
{
|
{
|
||||||
struct nlattr *nla_overwrite_mask, *nla_file_name;
|
struct nlattr *nla_overwrite_mask, *nla_file_name;
|
||||||
struct devlink_flash_update_params params = {};
|
struct devlink_flash_update_params params = {};
|
||||||
@ -1351,7 +1351,7 @@ static const struct nla_policy devlink_selftest_nl_policy[DEVLINK_ATTR_SELFTEST_
|
|||||||
[DEVLINK_ATTR_SELFTEST_ID_FLASH] = { .type = NLA_FLAG },
|
[DEVLINK_ATTR_SELFTEST_ID_FLASH] = { .type = NLA_FLAG },
|
||||||
};
|
};
|
||||||
|
|
||||||
int devlink_nl_cmd_selftests_run(struct sk_buff *skb, struct genl_info *info)
|
int devlink_nl_selftests_run_doit(struct sk_buff *skb, struct genl_info *info)
|
||||||
{
|
{
|
||||||
struct nlattr *tb[DEVLINK_ATTR_SELFTEST_ID_MAX + 1];
|
struct nlattr *tb[DEVLINK_ATTR_SELFTEST_ID_MAX + 1];
|
||||||
struct devlink *devlink = info->user_ptr[0];
|
struct devlink *devlink = info->user_ptr[0];
|
||||||
|
@ -227,67 +227,3 @@ int devlink_rate_nodes_check(struct devlink *devlink, u16 mode,
|
|||||||
|
|
||||||
/* Linecards */
|
/* Linecards */
|
||||||
unsigned int devlink_linecard_index(struct devlink_linecard *linecard);
|
unsigned int devlink_linecard_index(struct devlink_linecard *linecard);
|
||||||
|
|
||||||
/* Devlink nl cmds */
|
|
||||||
int devlink_nl_cmd_reload(struct sk_buff *skb, struct genl_info *info);
|
|
||||||
int devlink_nl_cmd_eswitch_get_doit(struct sk_buff *skb, struct genl_info *info);
|
|
||||||
int devlink_nl_cmd_eswitch_set_doit(struct sk_buff *skb, struct genl_info *info);
|
|
||||||
int devlink_nl_cmd_flash_update(struct sk_buff *skb, struct genl_info *info);
|
|
||||||
int devlink_nl_cmd_selftests_run(struct sk_buff *skb, struct genl_info *info);
|
|
||||||
int devlink_nl_cmd_port_set_doit(struct sk_buff *skb, struct genl_info *info);
|
|
||||||
int devlink_nl_cmd_port_split_doit(struct sk_buff *skb, struct genl_info *info);
|
|
||||||
int devlink_nl_cmd_port_unsplit_doit(struct sk_buff *skb,
|
|
||||||
struct genl_info *info);
|
|
||||||
int devlink_nl_cmd_port_new_doit(struct sk_buff *skb, struct genl_info *info);
|
|
||||||
int devlink_nl_cmd_port_del_doit(struct sk_buff *skb, struct genl_info *info);
|
|
||||||
int devlink_nl_cmd_sb_pool_set_doit(struct sk_buff *skb, struct genl_info *info);
|
|
||||||
int devlink_nl_cmd_sb_port_pool_set_doit(struct sk_buff *skb,
|
|
||||||
struct genl_info *info);
|
|
||||||
int devlink_nl_cmd_sb_tc_pool_bind_set_doit(struct sk_buff *skb,
|
|
||||||
struct genl_info *info);
|
|
||||||
int devlink_nl_cmd_sb_occ_snapshot_doit(struct sk_buff *skb,
|
|
||||||
struct genl_info *info);
|
|
||||||
int devlink_nl_cmd_sb_occ_max_clear_doit(struct sk_buff *skb,
|
|
||||||
struct genl_info *info);
|
|
||||||
int devlink_nl_cmd_dpipe_table_get(struct sk_buff *skb, struct genl_info *info);
|
|
||||||
int devlink_nl_cmd_dpipe_entries_get(struct sk_buff *skb,
|
|
||||||
struct genl_info *info);
|
|
||||||
int devlink_nl_cmd_dpipe_headers_get(struct sk_buff *skb,
|
|
||||||
struct genl_info *info);
|
|
||||||
int devlink_nl_cmd_dpipe_table_counters_set(struct sk_buff *skb,
|
|
||||||
struct genl_info *info);
|
|
||||||
int devlink_nl_cmd_resource_set(struct sk_buff *skb, struct genl_info *info);
|
|
||||||
int devlink_nl_cmd_resource_dump(struct sk_buff *skb, struct genl_info *info);
|
|
||||||
int devlink_nl_cmd_param_set_doit(struct sk_buff *skb, struct genl_info *info);
|
|
||||||
int devlink_nl_cmd_port_param_get_dumpit(struct sk_buff *msg,
|
|
||||||
struct netlink_callback *cb);
|
|
||||||
int devlink_nl_cmd_port_param_get_doit(struct sk_buff *skb,
|
|
||||||
struct genl_info *info);
|
|
||||||
int devlink_nl_cmd_port_param_set_doit(struct sk_buff *skb,
|
|
||||||
struct genl_info *info);
|
|
||||||
int devlink_nl_cmd_region_new(struct sk_buff *skb, struct genl_info *info);
|
|
||||||
int devlink_nl_cmd_region_del(struct sk_buff *skb, struct genl_info *info);
|
|
||||||
int devlink_nl_cmd_region_read_dumpit(struct sk_buff *skb,
|
|
||||||
struct netlink_callback *cb);
|
|
||||||
int devlink_nl_cmd_health_reporter_set_doit(struct sk_buff *skb,
|
|
||||||
struct genl_info *info);
|
|
||||||
int devlink_nl_cmd_health_reporter_recover_doit(struct sk_buff *skb,
|
|
||||||
struct genl_info *info);
|
|
||||||
int devlink_nl_cmd_health_reporter_diagnose_doit(struct sk_buff *skb,
|
|
||||||
struct genl_info *info);
|
|
||||||
int devlink_nl_cmd_health_reporter_dump_get_dumpit(struct sk_buff *skb,
|
|
||||||
struct netlink_callback *cb);
|
|
||||||
int devlink_nl_cmd_health_reporter_dump_clear_doit(struct sk_buff *skb,
|
|
||||||
struct genl_info *info);
|
|
||||||
int devlink_nl_cmd_health_reporter_test_doit(struct sk_buff *skb,
|
|
||||||
struct genl_info *info);
|
|
||||||
int devlink_nl_cmd_trap_set_doit(struct sk_buff *skb, struct genl_info *info);
|
|
||||||
int devlink_nl_cmd_trap_group_set_doit(struct sk_buff *skb,
|
|
||||||
struct genl_info *info);
|
|
||||||
int devlink_nl_cmd_trap_policer_set_doit(struct sk_buff *skb,
|
|
||||||
struct genl_info *info);
|
|
||||||
int devlink_nl_cmd_rate_set_doit(struct sk_buff *skb, struct genl_info *info);
|
|
||||||
int devlink_nl_cmd_rate_new_doit(struct sk_buff *skb, struct genl_info *info);
|
|
||||||
int devlink_nl_cmd_rate_del_doit(struct sk_buff *skb, struct genl_info *info);
|
|
||||||
int devlink_nl_cmd_linecard_set_doit(struct sk_buff *skb,
|
|
||||||
struct genl_info *info);
|
|
||||||
|
@ -289,7 +289,7 @@ err_table_put:
|
|||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
int devlink_nl_cmd_dpipe_table_get(struct sk_buff *skb, struct genl_info *info)
|
int devlink_nl_dpipe_table_get_doit(struct sk_buff *skb, struct genl_info *info)
|
||||||
{
|
{
|
||||||
struct devlink *devlink = info->user_ptr[0];
|
struct devlink *devlink = info->user_ptr[0];
|
||||||
const char *table_name = NULL;
|
const char *table_name = NULL;
|
||||||
@ -562,8 +562,8 @@ send_done:
|
|||||||
return genlmsg_reply(dump_ctx.skb, info);
|
return genlmsg_reply(dump_ctx.skb, info);
|
||||||
}
|
}
|
||||||
|
|
||||||
int devlink_nl_cmd_dpipe_entries_get(struct sk_buff *skb,
|
int devlink_nl_dpipe_entries_get_doit(struct sk_buff *skb,
|
||||||
struct genl_info *info)
|
struct genl_info *info)
|
||||||
{
|
{
|
||||||
struct devlink *devlink = info->user_ptr[0];
|
struct devlink *devlink = info->user_ptr[0];
|
||||||
struct devlink_dpipe_table *table;
|
struct devlink_dpipe_table *table;
|
||||||
@ -712,8 +712,8 @@ err_table_put:
|
|||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
int devlink_nl_cmd_dpipe_headers_get(struct sk_buff *skb,
|
int devlink_nl_dpipe_headers_get_doit(struct sk_buff *skb,
|
||||||
struct genl_info *info)
|
struct genl_info *info)
|
||||||
{
|
{
|
||||||
struct devlink *devlink = info->user_ptr[0];
|
struct devlink *devlink = info->user_ptr[0];
|
||||||
|
|
||||||
@ -746,8 +746,8 @@ static int devlink_dpipe_table_counters_set(struct devlink *devlink,
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int devlink_nl_cmd_dpipe_table_counters_set(struct sk_buff *skb,
|
int devlink_nl_dpipe_table_counters_set_doit(struct sk_buff *skb,
|
||||||
struct genl_info *info)
|
struct genl_info *info)
|
||||||
{
|
{
|
||||||
struct devlink *devlink = info->user_ptr[0];
|
struct devlink *devlink = info->user_ptr[0];
|
||||||
const char *table_name;
|
const char *table_name;
|
||||||
|
@ -452,8 +452,8 @@ int devlink_nl_health_reporter_get_dumpit(struct sk_buff *skb,
|
|||||||
devlink_nl_health_reporter_get_dump_one);
|
devlink_nl_health_reporter_get_dump_one);
|
||||||
}
|
}
|
||||||
|
|
||||||
int devlink_nl_cmd_health_reporter_set_doit(struct sk_buff *skb,
|
int devlink_nl_health_reporter_set_doit(struct sk_buff *skb,
|
||||||
struct genl_info *info)
|
struct genl_info *info)
|
||||||
{
|
{
|
||||||
struct devlink *devlink = info->user_ptr[0];
|
struct devlink *devlink = info->user_ptr[0];
|
||||||
struct devlink_health_reporter *reporter;
|
struct devlink_health_reporter *reporter;
|
||||||
@ -655,8 +655,8 @@ devlink_health_reporter_state_update(struct devlink_health_reporter *reporter,
|
|||||||
}
|
}
|
||||||
EXPORT_SYMBOL_GPL(devlink_health_reporter_state_update);
|
EXPORT_SYMBOL_GPL(devlink_health_reporter_state_update);
|
||||||
|
|
||||||
int devlink_nl_cmd_health_reporter_recover_doit(struct sk_buff *skb,
|
int devlink_nl_health_reporter_recover_doit(struct sk_buff *skb,
|
||||||
struct genl_info *info)
|
struct genl_info *info)
|
||||||
{
|
{
|
||||||
struct devlink *devlink = info->user_ptr[0];
|
struct devlink *devlink = info->user_ptr[0];
|
||||||
struct devlink_health_reporter *reporter;
|
struct devlink_health_reporter *reporter;
|
||||||
@ -1108,8 +1108,8 @@ nla_put_failure:
|
|||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
int devlink_nl_cmd_health_reporter_diagnose_doit(struct sk_buff *skb,
|
int devlink_nl_health_reporter_diagnose_doit(struct sk_buff *skb,
|
||||||
struct genl_info *info)
|
struct genl_info *info)
|
||||||
{
|
{
|
||||||
struct devlink *devlink = info->user_ptr[0];
|
struct devlink *devlink = info->user_ptr[0];
|
||||||
struct devlink_health_reporter *reporter;
|
struct devlink_health_reporter *reporter;
|
||||||
@ -1163,8 +1163,8 @@ devlink_health_reporter_get_from_cb_lock(struct netlink_callback *cb)
|
|||||||
return reporter;
|
return reporter;
|
||||||
}
|
}
|
||||||
|
|
||||||
int devlink_nl_cmd_health_reporter_dump_get_dumpit(struct sk_buff *skb,
|
int devlink_nl_health_reporter_dump_get_dumpit(struct sk_buff *skb,
|
||||||
struct netlink_callback *cb)
|
struct netlink_callback *cb)
|
||||||
{
|
{
|
||||||
struct devlink_nl_dump_state *state = devlink_dump_state(cb);
|
struct devlink_nl_dump_state *state = devlink_dump_state(cb);
|
||||||
struct devlink_health_reporter *reporter;
|
struct devlink_health_reporter *reporter;
|
||||||
@ -1202,8 +1202,8 @@ unlock:
|
|||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
int devlink_nl_cmd_health_reporter_dump_clear_doit(struct sk_buff *skb,
|
int devlink_nl_health_reporter_dump_clear_doit(struct sk_buff *skb,
|
||||||
struct genl_info *info)
|
struct genl_info *info)
|
||||||
{
|
{
|
||||||
struct devlink *devlink = info->user_ptr[0];
|
struct devlink *devlink = info->user_ptr[0];
|
||||||
struct devlink_health_reporter *reporter;
|
struct devlink_health_reporter *reporter;
|
||||||
@ -1219,8 +1219,8 @@ int devlink_nl_cmd_health_reporter_dump_clear_doit(struct sk_buff *skb,
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int devlink_nl_cmd_health_reporter_test_doit(struct sk_buff *skb,
|
int devlink_nl_health_reporter_test_doit(struct sk_buff *skb,
|
||||||
struct genl_info *info)
|
struct genl_info *info)
|
||||||
{
|
{
|
||||||
struct devlink *devlink = info->user_ptr[0];
|
struct devlink *devlink = info->user_ptr[0];
|
||||||
struct devlink_health_reporter *reporter;
|
struct devlink_health_reporter *reporter;
|
||||||
|
@ -369,8 +369,7 @@ out:
|
|||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
int devlink_nl_cmd_linecard_set_doit(struct sk_buff *skb,
|
int devlink_nl_linecard_set_doit(struct sk_buff *skb, struct genl_info *info)
|
||||||
struct genl_info *info)
|
|
||||||
{
|
{
|
||||||
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];
|
||||||
|
@ -13,75 +13,6 @@ static const struct genl_multicast_group devlink_nl_mcgrps[] = {
|
|||||||
[DEVLINK_MCGRP_CONFIG] = { .name = DEVLINK_GENL_MCGRP_CONFIG_NAME },
|
[DEVLINK_MCGRP_CONFIG] = { .name = DEVLINK_GENL_MCGRP_CONFIG_NAME },
|
||||||
};
|
};
|
||||||
|
|
||||||
static const struct nla_policy devlink_nl_policy[DEVLINK_ATTR_MAX + 1] = {
|
|
||||||
[DEVLINK_ATTR_UNSPEC] = { .strict_start_type =
|
|
||||||
DEVLINK_ATTR_TRAP_POLICER_ID },
|
|
||||||
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING },
|
|
||||||
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING },
|
|
||||||
[DEVLINK_ATTR_PORT_INDEX] = { .type = NLA_U32 },
|
|
||||||
[DEVLINK_ATTR_PORT_TYPE] = NLA_POLICY_RANGE(NLA_U16, DEVLINK_PORT_TYPE_AUTO,
|
|
||||||
DEVLINK_PORT_TYPE_IB),
|
|
||||||
[DEVLINK_ATTR_PORT_SPLIT_COUNT] = { .type = NLA_U32 },
|
|
||||||
[DEVLINK_ATTR_SB_INDEX] = { .type = NLA_U32 },
|
|
||||||
[DEVLINK_ATTR_SB_POOL_INDEX] = { .type = NLA_U16 },
|
|
||||||
[DEVLINK_ATTR_SB_POOL_TYPE] = { .type = NLA_U8 },
|
|
||||||
[DEVLINK_ATTR_SB_POOL_SIZE] = { .type = NLA_U32 },
|
|
||||||
[DEVLINK_ATTR_SB_POOL_THRESHOLD_TYPE] = { .type = NLA_U8 },
|
|
||||||
[DEVLINK_ATTR_SB_THRESHOLD] = { .type = NLA_U32 },
|
|
||||||
[DEVLINK_ATTR_SB_TC_INDEX] = { .type = NLA_U16 },
|
|
||||||
[DEVLINK_ATTR_ESWITCH_MODE] = NLA_POLICY_RANGE(NLA_U16, DEVLINK_ESWITCH_MODE_LEGACY,
|
|
||||||
DEVLINK_ESWITCH_MODE_SWITCHDEV),
|
|
||||||
[DEVLINK_ATTR_ESWITCH_INLINE_MODE] = { .type = NLA_U8 },
|
|
||||||
[DEVLINK_ATTR_ESWITCH_ENCAP_MODE] = { .type = NLA_U8 },
|
|
||||||
[DEVLINK_ATTR_DPIPE_TABLE_NAME] = { .type = NLA_NUL_STRING },
|
|
||||||
[DEVLINK_ATTR_DPIPE_TABLE_COUNTERS_ENABLED] = { .type = NLA_U8 },
|
|
||||||
[DEVLINK_ATTR_RESOURCE_ID] = { .type = NLA_U64},
|
|
||||||
[DEVLINK_ATTR_RESOURCE_SIZE] = { .type = NLA_U64},
|
|
||||||
[DEVLINK_ATTR_PARAM_NAME] = { .type = NLA_NUL_STRING },
|
|
||||||
[DEVLINK_ATTR_PARAM_TYPE] = { .type = NLA_U8 },
|
|
||||||
[DEVLINK_ATTR_PARAM_VALUE_CMODE] = { .type = NLA_U8 },
|
|
||||||
[DEVLINK_ATTR_REGION_NAME] = { .type = NLA_NUL_STRING },
|
|
||||||
[DEVLINK_ATTR_REGION_SNAPSHOT_ID] = { .type = NLA_U32 },
|
|
||||||
[DEVLINK_ATTR_REGION_CHUNK_ADDR] = { .type = NLA_U64 },
|
|
||||||
[DEVLINK_ATTR_REGION_CHUNK_LEN] = { .type = NLA_U64 },
|
|
||||||
[DEVLINK_ATTR_HEALTH_REPORTER_NAME] = { .type = NLA_NUL_STRING },
|
|
||||||
[DEVLINK_ATTR_HEALTH_REPORTER_GRACEFUL_PERIOD] = { .type = NLA_U64 },
|
|
||||||
[DEVLINK_ATTR_HEALTH_REPORTER_AUTO_RECOVER] = { .type = NLA_U8 },
|
|
||||||
[DEVLINK_ATTR_FLASH_UPDATE_FILE_NAME] = { .type = NLA_NUL_STRING },
|
|
||||||
[DEVLINK_ATTR_FLASH_UPDATE_COMPONENT] = { .type = NLA_NUL_STRING },
|
|
||||||
[DEVLINK_ATTR_FLASH_UPDATE_OVERWRITE_MASK] =
|
|
||||||
NLA_POLICY_BITFIELD32(DEVLINK_SUPPORTED_FLASH_OVERWRITE_SECTIONS),
|
|
||||||
[DEVLINK_ATTR_TRAP_NAME] = { .type = NLA_NUL_STRING },
|
|
||||||
[DEVLINK_ATTR_TRAP_ACTION] = { .type = NLA_U8 },
|
|
||||||
[DEVLINK_ATTR_TRAP_GROUP_NAME] = { .type = NLA_NUL_STRING },
|
|
||||||
[DEVLINK_ATTR_NETNS_PID] = { .type = NLA_U32 },
|
|
||||||
[DEVLINK_ATTR_NETNS_FD] = { .type = NLA_U32 },
|
|
||||||
[DEVLINK_ATTR_NETNS_ID] = { .type = NLA_U32 },
|
|
||||||
[DEVLINK_ATTR_HEALTH_REPORTER_AUTO_DUMP] = { .type = NLA_U8 },
|
|
||||||
[DEVLINK_ATTR_TRAP_POLICER_ID] = { .type = NLA_U32 },
|
|
||||||
[DEVLINK_ATTR_TRAP_POLICER_RATE] = { .type = NLA_U64 },
|
|
||||||
[DEVLINK_ATTR_TRAP_POLICER_BURST] = { .type = NLA_U64 },
|
|
||||||
[DEVLINK_ATTR_PORT_FUNCTION] = { .type = NLA_NESTED },
|
|
||||||
[DEVLINK_ATTR_RELOAD_ACTION] = NLA_POLICY_RANGE(NLA_U8, DEVLINK_RELOAD_ACTION_DRIVER_REINIT,
|
|
||||||
DEVLINK_RELOAD_ACTION_MAX),
|
|
||||||
[DEVLINK_ATTR_RELOAD_LIMITS] = NLA_POLICY_BITFIELD32(DEVLINK_RELOAD_LIMITS_VALID_MASK),
|
|
||||||
[DEVLINK_ATTR_PORT_FLAVOUR] = { .type = NLA_U16 },
|
|
||||||
[DEVLINK_ATTR_PORT_PCI_PF_NUMBER] = { .type = NLA_U16 },
|
|
||||||
[DEVLINK_ATTR_PORT_PCI_SF_NUMBER] = { .type = NLA_U32 },
|
|
||||||
[DEVLINK_ATTR_PORT_CONTROLLER_NUMBER] = { .type = NLA_U32 },
|
|
||||||
[DEVLINK_ATTR_RATE_TYPE] = { .type = NLA_U16 },
|
|
||||||
[DEVLINK_ATTR_RATE_TX_SHARE] = { .type = NLA_U64 },
|
|
||||||
[DEVLINK_ATTR_RATE_TX_MAX] = { .type = NLA_U64 },
|
|
||||||
[DEVLINK_ATTR_RATE_NODE_NAME] = { .type = NLA_NUL_STRING },
|
|
||||||
[DEVLINK_ATTR_RATE_PARENT_NODE_NAME] = { .type = NLA_NUL_STRING },
|
|
||||||
[DEVLINK_ATTR_LINECARD_INDEX] = { .type = NLA_U32 },
|
|
||||||
[DEVLINK_ATTR_LINECARD_TYPE] = { .type = NLA_NUL_STRING },
|
|
||||||
[DEVLINK_ATTR_SELFTESTS] = { .type = NLA_NESTED },
|
|
||||||
[DEVLINK_ATTR_RATE_TX_PRIORITY] = { .type = NLA_U32 },
|
|
||||||
[DEVLINK_ATTR_RATE_TX_WEIGHT] = { .type = NLA_U32 },
|
|
||||||
[DEVLINK_ATTR_REGION_DIRECT] = { .type = NLA_FLAG },
|
|
||||||
};
|
|
||||||
|
|
||||||
int devlink_nl_put_nested_handle(struct sk_buff *msg, struct net *net,
|
int devlink_nl_put_nested_handle(struct sk_buff *msg, struct net *net,
|
||||||
struct devlink *devlink, int attrtype)
|
struct devlink *devlink, int attrtype)
|
||||||
{
|
{
|
||||||
@ -191,7 +122,7 @@ unlock:
|
|||||||
int devlink_nl_pre_doit(const struct genl_split_ops *ops,
|
int devlink_nl_pre_doit(const struct genl_split_ops *ops,
|
||||||
struct sk_buff *skb, struct genl_info *info)
|
struct sk_buff *skb, struct genl_info *info)
|
||||||
{
|
{
|
||||||
return __devlink_nl_pre_doit(skb, info, ops->internal_flags);
|
return __devlink_nl_pre_doit(skb, info, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
int devlink_nl_pre_doit_port(const struct genl_split_ops *ops,
|
int devlink_nl_pre_doit_port(const struct genl_split_ops *ops,
|
||||||
@ -287,269 +218,12 @@ int devlink_nl_dumpit(struct sk_buff *msg, struct netlink_callback *cb,
|
|||||||
return devlink_nl_inst_iter_dumpit(msg, cb, flags, dump_one);
|
return devlink_nl_inst_iter_dumpit(msg, cb, flags, dump_one);
|
||||||
}
|
}
|
||||||
|
|
||||||
static const struct genl_small_ops devlink_nl_small_ops[40] = {
|
|
||||||
{
|
|
||||||
.cmd = DEVLINK_CMD_PORT_SET,
|
|
||||||
.validate = GENL_DONT_VALIDATE_STRICT | GENL_DONT_VALIDATE_DUMP,
|
|
||||||
.doit = devlink_nl_cmd_port_set_doit,
|
|
||||||
.flags = GENL_ADMIN_PERM,
|
|
||||||
.internal_flags = DEVLINK_NL_FLAG_NEED_PORT,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.cmd = DEVLINK_CMD_RATE_SET,
|
|
||||||
.doit = devlink_nl_cmd_rate_set_doit,
|
|
||||||
.flags = GENL_ADMIN_PERM,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.cmd = DEVLINK_CMD_RATE_NEW,
|
|
||||||
.doit = devlink_nl_cmd_rate_new_doit,
|
|
||||||
.flags = GENL_ADMIN_PERM,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.cmd = DEVLINK_CMD_RATE_DEL,
|
|
||||||
.doit = devlink_nl_cmd_rate_del_doit,
|
|
||||||
.flags = GENL_ADMIN_PERM,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.cmd = DEVLINK_CMD_PORT_SPLIT,
|
|
||||||
.validate = GENL_DONT_VALIDATE_STRICT | GENL_DONT_VALIDATE_DUMP,
|
|
||||||
.doit = devlink_nl_cmd_port_split_doit,
|
|
||||||
.flags = GENL_ADMIN_PERM,
|
|
||||||
.internal_flags = DEVLINK_NL_FLAG_NEED_PORT,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.cmd = DEVLINK_CMD_PORT_UNSPLIT,
|
|
||||||
.validate = GENL_DONT_VALIDATE_STRICT | GENL_DONT_VALIDATE_DUMP,
|
|
||||||
.doit = devlink_nl_cmd_port_unsplit_doit,
|
|
||||||
.flags = GENL_ADMIN_PERM,
|
|
||||||
.internal_flags = DEVLINK_NL_FLAG_NEED_PORT,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.cmd = DEVLINK_CMD_PORT_NEW,
|
|
||||||
.doit = devlink_nl_cmd_port_new_doit,
|
|
||||||
.flags = GENL_ADMIN_PERM,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.cmd = DEVLINK_CMD_PORT_DEL,
|
|
||||||
.doit = devlink_nl_cmd_port_del_doit,
|
|
||||||
.flags = GENL_ADMIN_PERM,
|
|
||||||
.internal_flags = DEVLINK_NL_FLAG_NEED_PORT,
|
|
||||||
},
|
|
||||||
|
|
||||||
{
|
|
||||||
.cmd = DEVLINK_CMD_LINECARD_SET,
|
|
||||||
.doit = devlink_nl_cmd_linecard_set_doit,
|
|
||||||
.flags = GENL_ADMIN_PERM,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.cmd = DEVLINK_CMD_SB_POOL_SET,
|
|
||||||
.validate = GENL_DONT_VALIDATE_STRICT | GENL_DONT_VALIDATE_DUMP,
|
|
||||||
.doit = devlink_nl_cmd_sb_pool_set_doit,
|
|
||||||
.flags = GENL_ADMIN_PERM,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.cmd = DEVLINK_CMD_SB_PORT_POOL_SET,
|
|
||||||
.validate = GENL_DONT_VALIDATE_STRICT | GENL_DONT_VALIDATE_DUMP,
|
|
||||||
.doit = devlink_nl_cmd_sb_port_pool_set_doit,
|
|
||||||
.flags = GENL_ADMIN_PERM,
|
|
||||||
.internal_flags = DEVLINK_NL_FLAG_NEED_PORT,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.cmd = DEVLINK_CMD_SB_TC_POOL_BIND_SET,
|
|
||||||
.validate = GENL_DONT_VALIDATE_STRICT | GENL_DONT_VALIDATE_DUMP,
|
|
||||||
.doit = devlink_nl_cmd_sb_tc_pool_bind_set_doit,
|
|
||||||
.flags = GENL_ADMIN_PERM,
|
|
||||||
.internal_flags = DEVLINK_NL_FLAG_NEED_PORT,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.cmd = DEVLINK_CMD_SB_OCC_SNAPSHOT,
|
|
||||||
.validate = GENL_DONT_VALIDATE_STRICT | GENL_DONT_VALIDATE_DUMP,
|
|
||||||
.doit = devlink_nl_cmd_sb_occ_snapshot_doit,
|
|
||||||
.flags = GENL_ADMIN_PERM,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.cmd = DEVLINK_CMD_SB_OCC_MAX_CLEAR,
|
|
||||||
.validate = GENL_DONT_VALIDATE_STRICT | GENL_DONT_VALIDATE_DUMP,
|
|
||||||
.doit = devlink_nl_cmd_sb_occ_max_clear_doit,
|
|
||||||
.flags = GENL_ADMIN_PERM,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.cmd = DEVLINK_CMD_ESWITCH_GET,
|
|
||||||
.validate = GENL_DONT_VALIDATE_STRICT | GENL_DONT_VALIDATE_DUMP,
|
|
||||||
.doit = devlink_nl_cmd_eswitch_get_doit,
|
|
||||||
.flags = GENL_ADMIN_PERM,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.cmd = DEVLINK_CMD_ESWITCH_SET,
|
|
||||||
.validate = GENL_DONT_VALIDATE_STRICT | GENL_DONT_VALIDATE_DUMP,
|
|
||||||
.doit = devlink_nl_cmd_eswitch_set_doit,
|
|
||||||
.flags = GENL_ADMIN_PERM,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.cmd = DEVLINK_CMD_DPIPE_TABLE_GET,
|
|
||||||
.validate = GENL_DONT_VALIDATE_STRICT | GENL_DONT_VALIDATE_DUMP,
|
|
||||||
.doit = devlink_nl_cmd_dpipe_table_get,
|
|
||||||
/* can be retrieved by unprivileged users */
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.cmd = DEVLINK_CMD_DPIPE_ENTRIES_GET,
|
|
||||||
.validate = GENL_DONT_VALIDATE_STRICT | GENL_DONT_VALIDATE_DUMP,
|
|
||||||
.doit = devlink_nl_cmd_dpipe_entries_get,
|
|
||||||
/* can be retrieved by unprivileged users */
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.cmd = DEVLINK_CMD_DPIPE_HEADERS_GET,
|
|
||||||
.validate = GENL_DONT_VALIDATE_STRICT | GENL_DONT_VALIDATE_DUMP,
|
|
||||||
.doit = devlink_nl_cmd_dpipe_headers_get,
|
|
||||||
/* can be retrieved by unprivileged users */
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.cmd = DEVLINK_CMD_DPIPE_TABLE_COUNTERS_SET,
|
|
||||||
.validate = GENL_DONT_VALIDATE_STRICT | GENL_DONT_VALIDATE_DUMP,
|
|
||||||
.doit = devlink_nl_cmd_dpipe_table_counters_set,
|
|
||||||
.flags = GENL_ADMIN_PERM,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.cmd = DEVLINK_CMD_RESOURCE_SET,
|
|
||||||
.validate = GENL_DONT_VALIDATE_STRICT | GENL_DONT_VALIDATE_DUMP,
|
|
||||||
.doit = devlink_nl_cmd_resource_set,
|
|
||||||
.flags = GENL_ADMIN_PERM,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.cmd = DEVLINK_CMD_RESOURCE_DUMP,
|
|
||||||
.validate = GENL_DONT_VALIDATE_STRICT | GENL_DONT_VALIDATE_DUMP,
|
|
||||||
.doit = devlink_nl_cmd_resource_dump,
|
|
||||||
/* can be retrieved by unprivileged users */
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.cmd = DEVLINK_CMD_RELOAD,
|
|
||||||
.validate = GENL_DONT_VALIDATE_STRICT | GENL_DONT_VALIDATE_DUMP,
|
|
||||||
.doit = devlink_nl_cmd_reload,
|
|
||||||
.flags = GENL_ADMIN_PERM,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.cmd = DEVLINK_CMD_PARAM_SET,
|
|
||||||
.validate = GENL_DONT_VALIDATE_STRICT | GENL_DONT_VALIDATE_DUMP,
|
|
||||||
.doit = devlink_nl_cmd_param_set_doit,
|
|
||||||
.flags = GENL_ADMIN_PERM,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.cmd = DEVLINK_CMD_PORT_PARAM_GET,
|
|
||||||
.validate = GENL_DONT_VALIDATE_STRICT | GENL_DONT_VALIDATE_DUMP,
|
|
||||||
.doit = devlink_nl_cmd_port_param_get_doit,
|
|
||||||
.dumpit = devlink_nl_cmd_port_param_get_dumpit,
|
|
||||||
.internal_flags = DEVLINK_NL_FLAG_NEED_PORT,
|
|
||||||
/* can be retrieved by unprivileged users */
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.cmd = DEVLINK_CMD_PORT_PARAM_SET,
|
|
||||||
.validate = GENL_DONT_VALIDATE_STRICT | GENL_DONT_VALIDATE_DUMP,
|
|
||||||
.doit = devlink_nl_cmd_port_param_set_doit,
|
|
||||||
.flags = GENL_ADMIN_PERM,
|
|
||||||
.internal_flags = DEVLINK_NL_FLAG_NEED_PORT,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.cmd = DEVLINK_CMD_REGION_NEW,
|
|
||||||
.validate = GENL_DONT_VALIDATE_STRICT | GENL_DONT_VALIDATE_DUMP,
|
|
||||||
.doit = devlink_nl_cmd_region_new,
|
|
||||||
.flags = GENL_ADMIN_PERM,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.cmd = DEVLINK_CMD_REGION_DEL,
|
|
||||||
.validate = GENL_DONT_VALIDATE_STRICT | GENL_DONT_VALIDATE_DUMP,
|
|
||||||
.doit = devlink_nl_cmd_region_del,
|
|
||||||
.flags = GENL_ADMIN_PERM,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.cmd = DEVLINK_CMD_REGION_READ,
|
|
||||||
.validate = GENL_DONT_VALIDATE_STRICT |
|
|
||||||
GENL_DONT_VALIDATE_DUMP_STRICT,
|
|
||||||
.dumpit = devlink_nl_cmd_region_read_dumpit,
|
|
||||||
.flags = GENL_ADMIN_PERM,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.cmd = DEVLINK_CMD_HEALTH_REPORTER_SET,
|
|
||||||
.validate = GENL_DONT_VALIDATE_STRICT | GENL_DONT_VALIDATE_DUMP,
|
|
||||||
.doit = devlink_nl_cmd_health_reporter_set_doit,
|
|
||||||
.flags = GENL_ADMIN_PERM,
|
|
||||||
.internal_flags = DEVLINK_NL_FLAG_NEED_DEVLINK_OR_PORT,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.cmd = DEVLINK_CMD_HEALTH_REPORTER_RECOVER,
|
|
||||||
.validate = GENL_DONT_VALIDATE_STRICT | GENL_DONT_VALIDATE_DUMP,
|
|
||||||
.doit = devlink_nl_cmd_health_reporter_recover_doit,
|
|
||||||
.flags = GENL_ADMIN_PERM,
|
|
||||||
.internal_flags = DEVLINK_NL_FLAG_NEED_DEVLINK_OR_PORT,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.cmd = DEVLINK_CMD_HEALTH_REPORTER_DIAGNOSE,
|
|
||||||
.validate = GENL_DONT_VALIDATE_STRICT | GENL_DONT_VALIDATE_DUMP,
|
|
||||||
.doit = devlink_nl_cmd_health_reporter_diagnose_doit,
|
|
||||||
.flags = GENL_ADMIN_PERM,
|
|
||||||
.internal_flags = DEVLINK_NL_FLAG_NEED_DEVLINK_OR_PORT,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.cmd = DEVLINK_CMD_HEALTH_REPORTER_DUMP_GET,
|
|
||||||
.validate = GENL_DONT_VALIDATE_STRICT |
|
|
||||||
GENL_DONT_VALIDATE_DUMP_STRICT,
|
|
||||||
.dumpit = devlink_nl_cmd_health_reporter_dump_get_dumpit,
|
|
||||||
.flags = GENL_ADMIN_PERM,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.cmd = DEVLINK_CMD_HEALTH_REPORTER_DUMP_CLEAR,
|
|
||||||
.validate = GENL_DONT_VALIDATE_STRICT | GENL_DONT_VALIDATE_DUMP,
|
|
||||||
.doit = devlink_nl_cmd_health_reporter_dump_clear_doit,
|
|
||||||
.flags = GENL_ADMIN_PERM,
|
|
||||||
.internal_flags = DEVLINK_NL_FLAG_NEED_DEVLINK_OR_PORT,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.cmd = DEVLINK_CMD_HEALTH_REPORTER_TEST,
|
|
||||||
.validate = GENL_DONT_VALIDATE_STRICT | GENL_DONT_VALIDATE_DUMP,
|
|
||||||
.doit = devlink_nl_cmd_health_reporter_test_doit,
|
|
||||||
.flags = GENL_ADMIN_PERM,
|
|
||||||
.internal_flags = DEVLINK_NL_FLAG_NEED_DEVLINK_OR_PORT,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.cmd = DEVLINK_CMD_FLASH_UPDATE,
|
|
||||||
.validate = GENL_DONT_VALIDATE_STRICT | GENL_DONT_VALIDATE_DUMP,
|
|
||||||
.doit = devlink_nl_cmd_flash_update,
|
|
||||||
.flags = GENL_ADMIN_PERM,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.cmd = DEVLINK_CMD_TRAP_SET,
|
|
||||||
.doit = devlink_nl_cmd_trap_set_doit,
|
|
||||||
.flags = GENL_ADMIN_PERM,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.cmd = DEVLINK_CMD_TRAP_GROUP_SET,
|
|
||||||
.doit = devlink_nl_cmd_trap_group_set_doit,
|
|
||||||
.flags = GENL_ADMIN_PERM,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.cmd = DEVLINK_CMD_TRAP_POLICER_SET,
|
|
||||||
.doit = devlink_nl_cmd_trap_policer_set_doit,
|
|
||||||
.flags = GENL_ADMIN_PERM,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.cmd = DEVLINK_CMD_SELFTESTS_RUN,
|
|
||||||
.doit = devlink_nl_cmd_selftests_run,
|
|
||||||
.flags = GENL_ADMIN_PERM,
|
|
||||||
},
|
|
||||||
/* -- No new ops here! Use split ops going forward! -- */
|
|
||||||
};
|
|
||||||
|
|
||||||
struct genl_family devlink_nl_family __ro_after_init = {
|
struct genl_family devlink_nl_family __ro_after_init = {
|
||||||
.name = DEVLINK_GENL_NAME,
|
.name = DEVLINK_GENL_NAME,
|
||||||
.version = DEVLINK_GENL_VERSION,
|
.version = DEVLINK_GENL_VERSION,
|
||||||
.maxattr = DEVLINK_ATTR_MAX,
|
|
||||||
.policy = devlink_nl_policy,
|
|
||||||
.netnsok = true,
|
.netnsok = true,
|
||||||
.parallel_ops = true,
|
.parallel_ops = true,
|
||||||
.pre_doit = devlink_nl_pre_doit,
|
|
||||||
.post_doit = devlink_nl_post_doit,
|
|
||||||
.module = THIS_MODULE,
|
.module = THIS_MODULE,
|
||||||
.small_ops = devlink_nl_small_ops,
|
|
||||||
.n_small_ops = ARRAY_SIZE(devlink_nl_small_ops),
|
|
||||||
.split_ops = devlink_nl_ops,
|
.split_ops = devlink_nl_ops,
|
||||||
.n_split_ops = ARRAY_SIZE(devlink_nl_ops),
|
.n_split_ops = ARRAY_SIZE(devlink_nl_ops),
|
||||||
.resv_start_op = DEVLINK_CMD_SELFTESTS_RUN + 1,
|
.resv_start_op = DEVLINK_CMD_SELFTESTS_RUN + 1,
|
||||||
|
@ -10,6 +10,18 @@
|
|||||||
|
|
||||||
#include <uapi/linux/devlink.h>
|
#include <uapi/linux/devlink.h>
|
||||||
|
|
||||||
|
/* Common nested types */
|
||||||
|
const struct nla_policy devlink_dl_port_function_nl_policy[DEVLINK_PORT_FN_ATTR_CAPS + 1] = {
|
||||||
|
[DEVLINK_PORT_FUNCTION_ATTR_HW_ADDR] = { .type = NLA_BINARY, },
|
||||||
|
[DEVLINK_PORT_FN_ATTR_STATE] = NLA_POLICY_MAX(NLA_U8, 1),
|
||||||
|
[DEVLINK_PORT_FN_ATTR_OPSTATE] = NLA_POLICY_MAX(NLA_U8, 1),
|
||||||
|
[DEVLINK_PORT_FN_ATTR_CAPS] = NLA_POLICY_BITFIELD32(3),
|
||||||
|
};
|
||||||
|
|
||||||
|
const struct nla_policy devlink_dl_selftest_id_nl_policy[DEVLINK_ATTR_SELFTEST_ID_FLASH + 1] = {
|
||||||
|
[DEVLINK_ATTR_SELFTEST_ID_FLASH] = { .type = NLA_FLAG, },
|
||||||
|
};
|
||||||
|
|
||||||
/* DEVLINK_CMD_GET - do */
|
/* DEVLINK_CMD_GET - do */
|
||||||
static const struct nla_policy devlink_get_nl_policy[DEVLINK_ATTR_DEV_NAME + 1] = {
|
static const struct nla_policy devlink_get_nl_policy[DEVLINK_ATTR_DEV_NAME + 1] = {
|
||||||
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
@ -29,6 +41,48 @@ static const struct nla_policy devlink_port_get_dump_nl_policy[DEVLINK_ATTR_DEV_
|
|||||||
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/* DEVLINK_CMD_PORT_SET - do */
|
||||||
|
static const struct nla_policy devlink_port_set_nl_policy[DEVLINK_ATTR_PORT_FUNCTION + 1] = {
|
||||||
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_PORT_INDEX] = { .type = NLA_U32, },
|
||||||
|
[DEVLINK_ATTR_PORT_TYPE] = NLA_POLICY_MAX(NLA_U16, 3),
|
||||||
|
[DEVLINK_ATTR_PORT_FUNCTION] = NLA_POLICY_NESTED(devlink_dl_port_function_nl_policy),
|
||||||
|
};
|
||||||
|
|
||||||
|
/* DEVLINK_CMD_PORT_NEW - do */
|
||||||
|
static const struct nla_policy devlink_port_new_nl_policy[DEVLINK_ATTR_PORT_PCI_SF_NUMBER + 1] = {
|
||||||
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_PORT_INDEX] = { .type = NLA_U32, },
|
||||||
|
[DEVLINK_ATTR_PORT_FLAVOUR] = NLA_POLICY_MAX(NLA_U16, 7),
|
||||||
|
[DEVLINK_ATTR_PORT_PCI_PF_NUMBER] = { .type = NLA_U16, },
|
||||||
|
[DEVLINK_ATTR_PORT_PCI_SF_NUMBER] = { .type = NLA_U32, },
|
||||||
|
[DEVLINK_ATTR_PORT_CONTROLLER_NUMBER] = { .type = NLA_U32, },
|
||||||
|
};
|
||||||
|
|
||||||
|
/* DEVLINK_CMD_PORT_DEL - do */
|
||||||
|
static const struct nla_policy devlink_port_del_nl_policy[DEVLINK_ATTR_PORT_INDEX + 1] = {
|
||||||
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_PORT_INDEX] = { .type = NLA_U32, },
|
||||||
|
};
|
||||||
|
|
||||||
|
/* DEVLINK_CMD_PORT_SPLIT - do */
|
||||||
|
static const struct nla_policy devlink_port_split_nl_policy[DEVLINK_ATTR_PORT_SPLIT_COUNT + 1] = {
|
||||||
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_PORT_INDEX] = { .type = NLA_U32, },
|
||||||
|
[DEVLINK_ATTR_PORT_SPLIT_COUNT] = { .type = NLA_U32, },
|
||||||
|
};
|
||||||
|
|
||||||
|
/* DEVLINK_CMD_PORT_UNSPLIT - do */
|
||||||
|
static const struct nla_policy devlink_port_unsplit_nl_policy[DEVLINK_ATTR_PORT_INDEX + 1] = {
|
||||||
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_PORT_INDEX] = { .type = NLA_U32, },
|
||||||
|
};
|
||||||
|
|
||||||
/* DEVLINK_CMD_SB_GET - do */
|
/* DEVLINK_CMD_SB_GET - do */
|
||||||
static const struct nla_policy devlink_sb_get_do_nl_policy[DEVLINK_ATTR_SB_INDEX + 1] = {
|
static const struct nla_policy devlink_sb_get_do_nl_policy[DEVLINK_ATTR_SB_INDEX + 1] = {
|
||||||
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
@ -56,6 +110,16 @@ static const struct nla_policy devlink_sb_pool_get_dump_nl_policy[DEVLINK_ATTR_D
|
|||||||
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/* DEVLINK_CMD_SB_POOL_SET - do */
|
||||||
|
static const struct nla_policy devlink_sb_pool_set_nl_policy[DEVLINK_ATTR_SB_POOL_THRESHOLD_TYPE + 1] = {
|
||||||
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_SB_INDEX] = { .type = NLA_U32, },
|
||||||
|
[DEVLINK_ATTR_SB_POOL_INDEX] = { .type = NLA_U16, },
|
||||||
|
[DEVLINK_ATTR_SB_POOL_THRESHOLD_TYPE] = NLA_POLICY_MAX(NLA_U8, 1),
|
||||||
|
[DEVLINK_ATTR_SB_POOL_SIZE] = { .type = NLA_U32, },
|
||||||
|
};
|
||||||
|
|
||||||
/* DEVLINK_CMD_SB_PORT_POOL_GET - do */
|
/* DEVLINK_CMD_SB_PORT_POOL_GET - do */
|
||||||
static const struct nla_policy devlink_sb_port_pool_get_do_nl_policy[DEVLINK_ATTR_SB_POOL_INDEX + 1] = {
|
static const struct nla_policy devlink_sb_port_pool_get_do_nl_policy[DEVLINK_ATTR_SB_POOL_INDEX + 1] = {
|
||||||
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
@ -71,6 +135,16 @@ static const struct nla_policy devlink_sb_port_pool_get_dump_nl_policy[DEVLINK_A
|
|||||||
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/* DEVLINK_CMD_SB_PORT_POOL_SET - do */
|
||||||
|
static const struct nla_policy devlink_sb_port_pool_set_nl_policy[DEVLINK_ATTR_SB_THRESHOLD + 1] = {
|
||||||
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_PORT_INDEX] = { .type = NLA_U32, },
|
||||||
|
[DEVLINK_ATTR_SB_INDEX] = { .type = NLA_U32, },
|
||||||
|
[DEVLINK_ATTR_SB_POOL_INDEX] = { .type = NLA_U16, },
|
||||||
|
[DEVLINK_ATTR_SB_THRESHOLD] = { .type = NLA_U32, },
|
||||||
|
};
|
||||||
|
|
||||||
/* DEVLINK_CMD_SB_TC_POOL_BIND_GET - do */
|
/* DEVLINK_CMD_SB_TC_POOL_BIND_GET - do */
|
||||||
static const struct nla_policy devlink_sb_tc_pool_bind_get_do_nl_policy[DEVLINK_ATTR_SB_TC_INDEX + 1] = {
|
static const struct nla_policy devlink_sb_tc_pool_bind_get_do_nl_policy[DEVLINK_ATTR_SB_TC_INDEX + 1] = {
|
||||||
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
@ -87,6 +161,100 @@ static const struct nla_policy devlink_sb_tc_pool_bind_get_dump_nl_policy[DEVLIN
|
|||||||
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/* DEVLINK_CMD_SB_TC_POOL_BIND_SET - do */
|
||||||
|
static const struct nla_policy devlink_sb_tc_pool_bind_set_nl_policy[DEVLINK_ATTR_SB_TC_INDEX + 1] = {
|
||||||
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_PORT_INDEX] = { .type = NLA_U32, },
|
||||||
|
[DEVLINK_ATTR_SB_INDEX] = { .type = NLA_U32, },
|
||||||
|
[DEVLINK_ATTR_SB_POOL_INDEX] = { .type = NLA_U16, },
|
||||||
|
[DEVLINK_ATTR_SB_POOL_TYPE] = NLA_POLICY_MAX(NLA_U8, 1),
|
||||||
|
[DEVLINK_ATTR_SB_TC_INDEX] = { .type = NLA_U16, },
|
||||||
|
[DEVLINK_ATTR_SB_THRESHOLD] = { .type = NLA_U32, },
|
||||||
|
};
|
||||||
|
|
||||||
|
/* DEVLINK_CMD_SB_OCC_SNAPSHOT - do */
|
||||||
|
static const struct nla_policy devlink_sb_occ_snapshot_nl_policy[DEVLINK_ATTR_SB_INDEX + 1] = {
|
||||||
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_SB_INDEX] = { .type = NLA_U32, },
|
||||||
|
};
|
||||||
|
|
||||||
|
/* DEVLINK_CMD_SB_OCC_MAX_CLEAR - do */
|
||||||
|
static const struct nla_policy devlink_sb_occ_max_clear_nl_policy[DEVLINK_ATTR_SB_INDEX + 1] = {
|
||||||
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_SB_INDEX] = { .type = NLA_U32, },
|
||||||
|
};
|
||||||
|
|
||||||
|
/* DEVLINK_CMD_ESWITCH_GET - do */
|
||||||
|
static const struct nla_policy devlink_eswitch_get_nl_policy[DEVLINK_ATTR_DEV_NAME + 1] = {
|
||||||
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
};
|
||||||
|
|
||||||
|
/* DEVLINK_CMD_ESWITCH_SET - do */
|
||||||
|
static const struct nla_policy devlink_eswitch_set_nl_policy[DEVLINK_ATTR_ESWITCH_ENCAP_MODE + 1] = {
|
||||||
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_ESWITCH_MODE] = NLA_POLICY_MAX(NLA_U16, 1),
|
||||||
|
[DEVLINK_ATTR_ESWITCH_INLINE_MODE] = NLA_POLICY_MAX(NLA_U16, 3),
|
||||||
|
[DEVLINK_ATTR_ESWITCH_ENCAP_MODE] = NLA_POLICY_MAX(NLA_U8, 1),
|
||||||
|
};
|
||||||
|
|
||||||
|
/* DEVLINK_CMD_DPIPE_TABLE_GET - do */
|
||||||
|
static const struct nla_policy devlink_dpipe_table_get_nl_policy[DEVLINK_ATTR_DPIPE_TABLE_NAME + 1] = {
|
||||||
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_DPIPE_TABLE_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
};
|
||||||
|
|
||||||
|
/* DEVLINK_CMD_DPIPE_ENTRIES_GET - do */
|
||||||
|
static const struct nla_policy devlink_dpipe_entries_get_nl_policy[DEVLINK_ATTR_DPIPE_TABLE_NAME + 1] = {
|
||||||
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_DPIPE_TABLE_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
};
|
||||||
|
|
||||||
|
/* DEVLINK_CMD_DPIPE_HEADERS_GET - do */
|
||||||
|
static const struct nla_policy devlink_dpipe_headers_get_nl_policy[DEVLINK_ATTR_DEV_NAME + 1] = {
|
||||||
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
};
|
||||||
|
|
||||||
|
/* DEVLINK_CMD_DPIPE_TABLE_COUNTERS_SET - do */
|
||||||
|
static const struct nla_policy devlink_dpipe_table_counters_set_nl_policy[DEVLINK_ATTR_DPIPE_TABLE_COUNTERS_ENABLED + 1] = {
|
||||||
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_DPIPE_TABLE_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_DPIPE_TABLE_COUNTERS_ENABLED] = { .type = NLA_U8, },
|
||||||
|
};
|
||||||
|
|
||||||
|
/* DEVLINK_CMD_RESOURCE_SET - do */
|
||||||
|
static const struct nla_policy devlink_resource_set_nl_policy[DEVLINK_ATTR_RESOURCE_SIZE + 1] = {
|
||||||
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_RESOURCE_ID] = { .type = NLA_U64, },
|
||||||
|
[DEVLINK_ATTR_RESOURCE_SIZE] = { .type = NLA_U64, },
|
||||||
|
};
|
||||||
|
|
||||||
|
/* DEVLINK_CMD_RESOURCE_DUMP - do */
|
||||||
|
static const struct nla_policy devlink_resource_dump_nl_policy[DEVLINK_ATTR_DEV_NAME + 1] = {
|
||||||
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
};
|
||||||
|
|
||||||
|
/* DEVLINK_CMD_RELOAD - do */
|
||||||
|
static const struct nla_policy devlink_reload_nl_policy[DEVLINK_ATTR_RELOAD_LIMITS + 1] = {
|
||||||
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_RELOAD_ACTION] = NLA_POLICY_RANGE(NLA_U8, 1, 2),
|
||||||
|
[DEVLINK_ATTR_RELOAD_LIMITS] = NLA_POLICY_BITFIELD32(6),
|
||||||
|
[DEVLINK_ATTR_NETNS_PID] = { .type = NLA_U32, },
|
||||||
|
[DEVLINK_ATTR_NETNS_FD] = { .type = NLA_U32, },
|
||||||
|
[DEVLINK_ATTR_NETNS_ID] = { .type = NLA_U32, },
|
||||||
|
};
|
||||||
|
|
||||||
/* DEVLINK_CMD_PARAM_GET - do */
|
/* DEVLINK_CMD_PARAM_GET - do */
|
||||||
static const struct nla_policy devlink_param_get_do_nl_policy[DEVLINK_ATTR_PARAM_NAME + 1] = {
|
static const struct nla_policy devlink_param_get_do_nl_policy[DEVLINK_ATTR_PARAM_NAME + 1] = {
|
||||||
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
@ -100,6 +268,15 @@ static const struct nla_policy devlink_param_get_dump_nl_policy[DEVLINK_ATTR_DEV
|
|||||||
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/* DEVLINK_CMD_PARAM_SET - do */
|
||||||
|
static const struct nla_policy devlink_param_set_nl_policy[DEVLINK_ATTR_PARAM_VALUE_CMODE + 1] = {
|
||||||
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_PARAM_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_PARAM_TYPE] = { .type = NLA_U8, },
|
||||||
|
[DEVLINK_ATTR_PARAM_VALUE_CMODE] = NLA_POLICY_MAX(NLA_U8, 2),
|
||||||
|
};
|
||||||
|
|
||||||
/* DEVLINK_CMD_REGION_GET - do */
|
/* DEVLINK_CMD_REGION_GET - do */
|
||||||
static const struct nla_policy devlink_region_get_do_nl_policy[DEVLINK_ATTR_REGION_NAME + 1] = {
|
static const struct nla_policy devlink_region_get_do_nl_policy[DEVLINK_ATTR_REGION_NAME + 1] = {
|
||||||
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
@ -114,6 +291,50 @@ static const struct nla_policy devlink_region_get_dump_nl_policy[DEVLINK_ATTR_DE
|
|||||||
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/* DEVLINK_CMD_REGION_NEW - do */
|
||||||
|
static const struct nla_policy devlink_region_new_nl_policy[DEVLINK_ATTR_REGION_SNAPSHOT_ID + 1] = {
|
||||||
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_PORT_INDEX] = { .type = NLA_U32, },
|
||||||
|
[DEVLINK_ATTR_REGION_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_REGION_SNAPSHOT_ID] = { .type = NLA_U32, },
|
||||||
|
};
|
||||||
|
|
||||||
|
/* DEVLINK_CMD_REGION_DEL - do */
|
||||||
|
static const struct nla_policy devlink_region_del_nl_policy[DEVLINK_ATTR_REGION_SNAPSHOT_ID + 1] = {
|
||||||
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_PORT_INDEX] = { .type = NLA_U32, },
|
||||||
|
[DEVLINK_ATTR_REGION_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_REGION_SNAPSHOT_ID] = { .type = NLA_U32, },
|
||||||
|
};
|
||||||
|
|
||||||
|
/* DEVLINK_CMD_REGION_READ - dump */
|
||||||
|
static const struct nla_policy devlink_region_read_nl_policy[DEVLINK_ATTR_REGION_DIRECT + 1] = {
|
||||||
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_PORT_INDEX] = { .type = NLA_U32, },
|
||||||
|
[DEVLINK_ATTR_REGION_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_REGION_SNAPSHOT_ID] = { .type = NLA_U32, },
|
||||||
|
[DEVLINK_ATTR_REGION_DIRECT] = { .type = NLA_FLAG, },
|
||||||
|
[DEVLINK_ATTR_REGION_CHUNK_ADDR] = { .type = NLA_U64, },
|
||||||
|
[DEVLINK_ATTR_REGION_CHUNK_LEN] = { .type = NLA_U64, },
|
||||||
|
};
|
||||||
|
|
||||||
|
/* DEVLINK_CMD_PORT_PARAM_GET - do */
|
||||||
|
static const struct nla_policy devlink_port_param_get_nl_policy[DEVLINK_ATTR_PORT_INDEX + 1] = {
|
||||||
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_PORT_INDEX] = { .type = NLA_U32, },
|
||||||
|
};
|
||||||
|
|
||||||
|
/* DEVLINK_CMD_PORT_PARAM_SET - do */
|
||||||
|
static const struct nla_policy devlink_port_param_set_nl_policy[DEVLINK_ATTR_PORT_INDEX + 1] = {
|
||||||
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_PORT_INDEX] = { .type = NLA_U32, },
|
||||||
|
};
|
||||||
|
|
||||||
/* DEVLINK_CMD_INFO_GET - do */
|
/* DEVLINK_CMD_INFO_GET - do */
|
||||||
static const struct nla_policy devlink_info_get_nl_policy[DEVLINK_ATTR_DEV_NAME + 1] = {
|
static const struct nla_policy devlink_info_get_nl_policy[DEVLINK_ATTR_DEV_NAME + 1] = {
|
||||||
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
@ -135,6 +356,58 @@ static const struct nla_policy devlink_health_reporter_get_dump_nl_policy[DEVLIN
|
|||||||
[DEVLINK_ATTR_PORT_INDEX] = { .type = NLA_U32, },
|
[DEVLINK_ATTR_PORT_INDEX] = { .type = NLA_U32, },
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/* DEVLINK_CMD_HEALTH_REPORTER_SET - do */
|
||||||
|
static const struct nla_policy devlink_health_reporter_set_nl_policy[DEVLINK_ATTR_HEALTH_REPORTER_AUTO_DUMP + 1] = {
|
||||||
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_PORT_INDEX] = { .type = NLA_U32, },
|
||||||
|
[DEVLINK_ATTR_HEALTH_REPORTER_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_HEALTH_REPORTER_GRACEFUL_PERIOD] = { .type = NLA_U64, },
|
||||||
|
[DEVLINK_ATTR_HEALTH_REPORTER_AUTO_RECOVER] = { .type = NLA_U8, },
|
||||||
|
[DEVLINK_ATTR_HEALTH_REPORTER_AUTO_DUMP] = { .type = NLA_U8, },
|
||||||
|
};
|
||||||
|
|
||||||
|
/* DEVLINK_CMD_HEALTH_REPORTER_RECOVER - do */
|
||||||
|
static const struct nla_policy devlink_health_reporter_recover_nl_policy[DEVLINK_ATTR_HEALTH_REPORTER_NAME + 1] = {
|
||||||
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_PORT_INDEX] = { .type = NLA_U32, },
|
||||||
|
[DEVLINK_ATTR_HEALTH_REPORTER_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
};
|
||||||
|
|
||||||
|
/* DEVLINK_CMD_HEALTH_REPORTER_DIAGNOSE - do */
|
||||||
|
static const struct nla_policy devlink_health_reporter_diagnose_nl_policy[DEVLINK_ATTR_HEALTH_REPORTER_NAME + 1] = {
|
||||||
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_PORT_INDEX] = { .type = NLA_U32, },
|
||||||
|
[DEVLINK_ATTR_HEALTH_REPORTER_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
};
|
||||||
|
|
||||||
|
/* DEVLINK_CMD_HEALTH_REPORTER_DUMP_GET - dump */
|
||||||
|
static const struct nla_policy devlink_health_reporter_dump_get_nl_policy[DEVLINK_ATTR_HEALTH_REPORTER_NAME + 1] = {
|
||||||
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_PORT_INDEX] = { .type = NLA_U32, },
|
||||||
|
[DEVLINK_ATTR_HEALTH_REPORTER_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
};
|
||||||
|
|
||||||
|
/* DEVLINK_CMD_HEALTH_REPORTER_DUMP_CLEAR - do */
|
||||||
|
static const struct nla_policy devlink_health_reporter_dump_clear_nl_policy[DEVLINK_ATTR_HEALTH_REPORTER_NAME + 1] = {
|
||||||
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_PORT_INDEX] = { .type = NLA_U32, },
|
||||||
|
[DEVLINK_ATTR_HEALTH_REPORTER_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
};
|
||||||
|
|
||||||
|
/* DEVLINK_CMD_FLASH_UPDATE - do */
|
||||||
|
static const struct nla_policy devlink_flash_update_nl_policy[DEVLINK_ATTR_FLASH_UPDATE_OVERWRITE_MASK + 1] = {
|
||||||
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_FLASH_UPDATE_FILE_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_FLASH_UPDATE_COMPONENT] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_FLASH_UPDATE_OVERWRITE_MASK] = NLA_POLICY_BITFIELD32(3),
|
||||||
|
};
|
||||||
|
|
||||||
/* DEVLINK_CMD_TRAP_GET - do */
|
/* DEVLINK_CMD_TRAP_GET - do */
|
||||||
static const struct nla_policy devlink_trap_get_do_nl_policy[DEVLINK_ATTR_TRAP_NAME + 1] = {
|
static const struct nla_policy devlink_trap_get_do_nl_policy[DEVLINK_ATTR_TRAP_NAME + 1] = {
|
||||||
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
@ -148,6 +421,14 @@ static const struct nla_policy devlink_trap_get_dump_nl_policy[DEVLINK_ATTR_DEV_
|
|||||||
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/* DEVLINK_CMD_TRAP_SET - do */
|
||||||
|
static const struct nla_policy devlink_trap_set_nl_policy[DEVLINK_ATTR_TRAP_ACTION + 1] = {
|
||||||
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_TRAP_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_TRAP_ACTION] = NLA_POLICY_MAX(NLA_U8, 2),
|
||||||
|
};
|
||||||
|
|
||||||
/* DEVLINK_CMD_TRAP_GROUP_GET - do */
|
/* DEVLINK_CMD_TRAP_GROUP_GET - do */
|
||||||
static const struct nla_policy devlink_trap_group_get_do_nl_policy[DEVLINK_ATTR_TRAP_GROUP_NAME + 1] = {
|
static const struct nla_policy devlink_trap_group_get_do_nl_policy[DEVLINK_ATTR_TRAP_GROUP_NAME + 1] = {
|
||||||
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
@ -161,6 +442,15 @@ static const struct nla_policy devlink_trap_group_get_dump_nl_policy[DEVLINK_ATT
|
|||||||
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/* DEVLINK_CMD_TRAP_GROUP_SET - do */
|
||||||
|
static const struct nla_policy devlink_trap_group_set_nl_policy[DEVLINK_ATTR_TRAP_POLICER_ID + 1] = {
|
||||||
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_TRAP_GROUP_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_TRAP_ACTION] = NLA_POLICY_MAX(NLA_U8, 2),
|
||||||
|
[DEVLINK_ATTR_TRAP_POLICER_ID] = { .type = NLA_U32, },
|
||||||
|
};
|
||||||
|
|
||||||
/* DEVLINK_CMD_TRAP_POLICER_GET - do */
|
/* DEVLINK_CMD_TRAP_POLICER_GET - do */
|
||||||
static const struct nla_policy devlink_trap_policer_get_do_nl_policy[DEVLINK_ATTR_TRAP_POLICER_ID + 1] = {
|
static const struct nla_policy devlink_trap_policer_get_do_nl_policy[DEVLINK_ATTR_TRAP_POLICER_ID + 1] = {
|
||||||
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
@ -174,6 +464,23 @@ static const struct nla_policy devlink_trap_policer_get_dump_nl_policy[DEVLINK_A
|
|||||||
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/* DEVLINK_CMD_TRAP_POLICER_SET - do */
|
||||||
|
static const struct nla_policy devlink_trap_policer_set_nl_policy[DEVLINK_ATTR_TRAP_POLICER_BURST + 1] = {
|
||||||
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_TRAP_POLICER_ID] = { .type = NLA_U32, },
|
||||||
|
[DEVLINK_ATTR_TRAP_POLICER_RATE] = { .type = NLA_U64, },
|
||||||
|
[DEVLINK_ATTR_TRAP_POLICER_BURST] = { .type = NLA_U64, },
|
||||||
|
};
|
||||||
|
|
||||||
|
/* DEVLINK_CMD_HEALTH_REPORTER_TEST - do */
|
||||||
|
static const struct nla_policy devlink_health_reporter_test_nl_policy[DEVLINK_ATTR_HEALTH_REPORTER_NAME + 1] = {
|
||||||
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_PORT_INDEX] = { .type = NLA_U32, },
|
||||||
|
[DEVLINK_ATTR_HEALTH_REPORTER_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
};
|
||||||
|
|
||||||
/* DEVLINK_CMD_RATE_GET - do */
|
/* DEVLINK_CMD_RATE_GET - do */
|
||||||
static const struct nla_policy devlink_rate_get_do_nl_policy[DEVLINK_ATTR_RATE_NODE_NAME + 1] = {
|
static const struct nla_policy devlink_rate_get_do_nl_policy[DEVLINK_ATTR_RATE_NODE_NAME + 1] = {
|
||||||
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
@ -188,6 +495,37 @@ static const struct nla_policy devlink_rate_get_dump_nl_policy[DEVLINK_ATTR_DEV_
|
|||||||
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/* DEVLINK_CMD_RATE_SET - do */
|
||||||
|
static const struct nla_policy devlink_rate_set_nl_policy[DEVLINK_ATTR_RATE_TX_WEIGHT + 1] = {
|
||||||
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_RATE_NODE_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_RATE_TX_SHARE] = { .type = NLA_U64, },
|
||||||
|
[DEVLINK_ATTR_RATE_TX_MAX] = { .type = NLA_U64, },
|
||||||
|
[DEVLINK_ATTR_RATE_TX_PRIORITY] = { .type = NLA_U32, },
|
||||||
|
[DEVLINK_ATTR_RATE_TX_WEIGHT] = { .type = NLA_U32, },
|
||||||
|
[DEVLINK_ATTR_RATE_PARENT_NODE_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
};
|
||||||
|
|
||||||
|
/* DEVLINK_CMD_RATE_NEW - do */
|
||||||
|
static const struct nla_policy devlink_rate_new_nl_policy[DEVLINK_ATTR_RATE_TX_WEIGHT + 1] = {
|
||||||
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_RATE_NODE_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_RATE_TX_SHARE] = { .type = NLA_U64, },
|
||||||
|
[DEVLINK_ATTR_RATE_TX_MAX] = { .type = NLA_U64, },
|
||||||
|
[DEVLINK_ATTR_RATE_TX_PRIORITY] = { .type = NLA_U32, },
|
||||||
|
[DEVLINK_ATTR_RATE_TX_WEIGHT] = { .type = NLA_U32, },
|
||||||
|
[DEVLINK_ATTR_RATE_PARENT_NODE_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
};
|
||||||
|
|
||||||
|
/* DEVLINK_CMD_RATE_DEL - do */
|
||||||
|
static const struct nla_policy devlink_rate_del_nl_policy[DEVLINK_ATTR_RATE_NODE_NAME + 1] = {
|
||||||
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_RATE_NODE_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
};
|
||||||
|
|
||||||
/* DEVLINK_CMD_LINECARD_GET - do */
|
/* DEVLINK_CMD_LINECARD_GET - do */
|
||||||
static const struct nla_policy devlink_linecard_get_do_nl_policy[DEVLINK_ATTR_LINECARD_INDEX + 1] = {
|
static const struct nla_policy devlink_linecard_get_do_nl_policy[DEVLINK_ATTR_LINECARD_INDEX + 1] = {
|
||||||
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
@ -201,14 +539,29 @@ static const struct nla_policy devlink_linecard_get_dump_nl_policy[DEVLINK_ATTR_
|
|||||||
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/* DEVLINK_CMD_LINECARD_SET - do */
|
||||||
|
static const struct nla_policy devlink_linecard_set_nl_policy[DEVLINK_ATTR_LINECARD_TYPE + 1] = {
|
||||||
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_LINECARD_INDEX] = { .type = NLA_U32, },
|
||||||
|
[DEVLINK_ATTR_LINECARD_TYPE] = { .type = NLA_NUL_STRING, },
|
||||||
|
};
|
||||||
|
|
||||||
/* DEVLINK_CMD_SELFTESTS_GET - do */
|
/* DEVLINK_CMD_SELFTESTS_GET - do */
|
||||||
static const struct nla_policy devlink_selftests_get_nl_policy[DEVLINK_ATTR_DEV_NAME + 1] = {
|
static const struct nla_policy devlink_selftests_get_nl_policy[DEVLINK_ATTR_DEV_NAME + 1] = {
|
||||||
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/* DEVLINK_CMD_SELFTESTS_RUN - do */
|
||||||
|
static const struct nla_policy devlink_selftests_run_nl_policy[DEVLINK_ATTR_SELFTESTS + 1] = {
|
||||||
|
[DEVLINK_ATTR_BUS_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_DEV_NAME] = { .type = NLA_NUL_STRING, },
|
||||||
|
[DEVLINK_ATTR_SELFTESTS] = NLA_POLICY_NESTED(devlink_dl_selftest_id_nl_policy),
|
||||||
|
};
|
||||||
|
|
||||||
/* Ops table for devlink */
|
/* Ops table for devlink */
|
||||||
const struct genl_split_ops devlink_nl_ops[32] = {
|
const struct genl_split_ops devlink_nl_ops[73] = {
|
||||||
{
|
{
|
||||||
.cmd = DEVLINK_CMD_GET,
|
.cmd = DEVLINK_CMD_GET,
|
||||||
.validate = GENL_DONT_VALIDATE_STRICT,
|
.validate = GENL_DONT_VALIDATE_STRICT,
|
||||||
@ -242,6 +595,56 @@ const struct genl_split_ops devlink_nl_ops[32] = {
|
|||||||
.maxattr = DEVLINK_ATTR_DEV_NAME,
|
.maxattr = DEVLINK_ATTR_DEV_NAME,
|
||||||
.flags = GENL_CMD_CAP_DUMP,
|
.flags = GENL_CMD_CAP_DUMP,
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
.cmd = DEVLINK_CMD_PORT_SET,
|
||||||
|
.validate = GENL_DONT_VALIDATE_STRICT,
|
||||||
|
.pre_doit = devlink_nl_pre_doit_port,
|
||||||
|
.doit = devlink_nl_port_set_doit,
|
||||||
|
.post_doit = devlink_nl_post_doit,
|
||||||
|
.policy = devlink_port_set_nl_policy,
|
||||||
|
.maxattr = DEVLINK_ATTR_PORT_FUNCTION,
|
||||||
|
.flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DO,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.cmd = DEVLINK_CMD_PORT_NEW,
|
||||||
|
.validate = GENL_DONT_VALIDATE_STRICT,
|
||||||
|
.pre_doit = devlink_nl_pre_doit,
|
||||||
|
.doit = devlink_nl_port_new_doit,
|
||||||
|
.post_doit = devlink_nl_post_doit,
|
||||||
|
.policy = devlink_port_new_nl_policy,
|
||||||
|
.maxattr = DEVLINK_ATTR_PORT_PCI_SF_NUMBER,
|
||||||
|
.flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DO,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.cmd = DEVLINK_CMD_PORT_DEL,
|
||||||
|
.validate = GENL_DONT_VALIDATE_STRICT,
|
||||||
|
.pre_doit = devlink_nl_pre_doit_port,
|
||||||
|
.doit = devlink_nl_port_del_doit,
|
||||||
|
.post_doit = devlink_nl_post_doit,
|
||||||
|
.policy = devlink_port_del_nl_policy,
|
||||||
|
.maxattr = DEVLINK_ATTR_PORT_INDEX,
|
||||||
|
.flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DO,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.cmd = DEVLINK_CMD_PORT_SPLIT,
|
||||||
|
.validate = GENL_DONT_VALIDATE_STRICT,
|
||||||
|
.pre_doit = devlink_nl_pre_doit_port,
|
||||||
|
.doit = devlink_nl_port_split_doit,
|
||||||
|
.post_doit = devlink_nl_post_doit,
|
||||||
|
.policy = devlink_port_split_nl_policy,
|
||||||
|
.maxattr = DEVLINK_ATTR_PORT_SPLIT_COUNT,
|
||||||
|
.flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DO,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.cmd = DEVLINK_CMD_PORT_UNSPLIT,
|
||||||
|
.validate = GENL_DONT_VALIDATE_STRICT,
|
||||||
|
.pre_doit = devlink_nl_pre_doit_port,
|
||||||
|
.doit = devlink_nl_port_unsplit_doit,
|
||||||
|
.post_doit = devlink_nl_post_doit,
|
||||||
|
.policy = devlink_port_unsplit_nl_policy,
|
||||||
|
.maxattr = DEVLINK_ATTR_PORT_INDEX,
|
||||||
|
.flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DO,
|
||||||
|
},
|
||||||
{
|
{
|
||||||
.cmd = DEVLINK_CMD_SB_GET,
|
.cmd = DEVLINK_CMD_SB_GET,
|
||||||
.validate = GENL_DONT_VALIDATE_STRICT,
|
.validate = GENL_DONT_VALIDATE_STRICT,
|
||||||
@ -276,6 +679,16 @@ const struct genl_split_ops devlink_nl_ops[32] = {
|
|||||||
.maxattr = DEVLINK_ATTR_DEV_NAME,
|
.maxattr = DEVLINK_ATTR_DEV_NAME,
|
||||||
.flags = GENL_CMD_CAP_DUMP,
|
.flags = GENL_CMD_CAP_DUMP,
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
.cmd = DEVLINK_CMD_SB_POOL_SET,
|
||||||
|
.validate = GENL_DONT_VALIDATE_STRICT,
|
||||||
|
.pre_doit = devlink_nl_pre_doit,
|
||||||
|
.doit = devlink_nl_sb_pool_set_doit,
|
||||||
|
.post_doit = devlink_nl_post_doit,
|
||||||
|
.policy = devlink_sb_pool_set_nl_policy,
|
||||||
|
.maxattr = DEVLINK_ATTR_SB_POOL_THRESHOLD_TYPE,
|
||||||
|
.flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DO,
|
||||||
|
},
|
||||||
{
|
{
|
||||||
.cmd = DEVLINK_CMD_SB_PORT_POOL_GET,
|
.cmd = DEVLINK_CMD_SB_PORT_POOL_GET,
|
||||||
.validate = GENL_DONT_VALIDATE_STRICT,
|
.validate = GENL_DONT_VALIDATE_STRICT,
|
||||||
@ -293,6 +706,16 @@ const struct genl_split_ops devlink_nl_ops[32] = {
|
|||||||
.maxattr = DEVLINK_ATTR_DEV_NAME,
|
.maxattr = DEVLINK_ATTR_DEV_NAME,
|
||||||
.flags = GENL_CMD_CAP_DUMP,
|
.flags = GENL_CMD_CAP_DUMP,
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
.cmd = DEVLINK_CMD_SB_PORT_POOL_SET,
|
||||||
|
.validate = GENL_DONT_VALIDATE_STRICT,
|
||||||
|
.pre_doit = devlink_nl_pre_doit_port,
|
||||||
|
.doit = devlink_nl_sb_port_pool_set_doit,
|
||||||
|
.post_doit = devlink_nl_post_doit,
|
||||||
|
.policy = devlink_sb_port_pool_set_nl_policy,
|
||||||
|
.maxattr = DEVLINK_ATTR_SB_THRESHOLD,
|
||||||
|
.flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DO,
|
||||||
|
},
|
||||||
{
|
{
|
||||||
.cmd = DEVLINK_CMD_SB_TC_POOL_BIND_GET,
|
.cmd = DEVLINK_CMD_SB_TC_POOL_BIND_GET,
|
||||||
.validate = GENL_DONT_VALIDATE_STRICT,
|
.validate = GENL_DONT_VALIDATE_STRICT,
|
||||||
@ -310,6 +733,126 @@ const struct genl_split_ops devlink_nl_ops[32] = {
|
|||||||
.maxattr = DEVLINK_ATTR_DEV_NAME,
|
.maxattr = DEVLINK_ATTR_DEV_NAME,
|
||||||
.flags = GENL_CMD_CAP_DUMP,
|
.flags = GENL_CMD_CAP_DUMP,
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
.cmd = DEVLINK_CMD_SB_TC_POOL_BIND_SET,
|
||||||
|
.validate = GENL_DONT_VALIDATE_STRICT,
|
||||||
|
.pre_doit = devlink_nl_pre_doit_port,
|
||||||
|
.doit = devlink_nl_sb_tc_pool_bind_set_doit,
|
||||||
|
.post_doit = devlink_nl_post_doit,
|
||||||
|
.policy = devlink_sb_tc_pool_bind_set_nl_policy,
|
||||||
|
.maxattr = DEVLINK_ATTR_SB_TC_INDEX,
|
||||||
|
.flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DO,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.cmd = DEVLINK_CMD_SB_OCC_SNAPSHOT,
|
||||||
|
.validate = GENL_DONT_VALIDATE_STRICT,
|
||||||
|
.pre_doit = devlink_nl_pre_doit,
|
||||||
|
.doit = devlink_nl_sb_occ_snapshot_doit,
|
||||||
|
.post_doit = devlink_nl_post_doit,
|
||||||
|
.policy = devlink_sb_occ_snapshot_nl_policy,
|
||||||
|
.maxattr = DEVLINK_ATTR_SB_INDEX,
|
||||||
|
.flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DO,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.cmd = DEVLINK_CMD_SB_OCC_MAX_CLEAR,
|
||||||
|
.validate = GENL_DONT_VALIDATE_STRICT,
|
||||||
|
.pre_doit = devlink_nl_pre_doit,
|
||||||
|
.doit = devlink_nl_sb_occ_max_clear_doit,
|
||||||
|
.post_doit = devlink_nl_post_doit,
|
||||||
|
.policy = devlink_sb_occ_max_clear_nl_policy,
|
||||||
|
.maxattr = DEVLINK_ATTR_SB_INDEX,
|
||||||
|
.flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DO,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.cmd = DEVLINK_CMD_ESWITCH_GET,
|
||||||
|
.validate = GENL_DONT_VALIDATE_STRICT,
|
||||||
|
.pre_doit = devlink_nl_pre_doit,
|
||||||
|
.doit = devlink_nl_eswitch_get_doit,
|
||||||
|
.post_doit = devlink_nl_post_doit,
|
||||||
|
.policy = devlink_eswitch_get_nl_policy,
|
||||||
|
.maxattr = DEVLINK_ATTR_DEV_NAME,
|
||||||
|
.flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DO,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.cmd = DEVLINK_CMD_ESWITCH_SET,
|
||||||
|
.validate = GENL_DONT_VALIDATE_STRICT,
|
||||||
|
.pre_doit = devlink_nl_pre_doit,
|
||||||
|
.doit = devlink_nl_eswitch_set_doit,
|
||||||
|
.post_doit = devlink_nl_post_doit,
|
||||||
|
.policy = devlink_eswitch_set_nl_policy,
|
||||||
|
.maxattr = DEVLINK_ATTR_ESWITCH_ENCAP_MODE,
|
||||||
|
.flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DO,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.cmd = DEVLINK_CMD_DPIPE_TABLE_GET,
|
||||||
|
.validate = GENL_DONT_VALIDATE_STRICT,
|
||||||
|
.pre_doit = devlink_nl_pre_doit,
|
||||||
|
.doit = devlink_nl_dpipe_table_get_doit,
|
||||||
|
.post_doit = devlink_nl_post_doit,
|
||||||
|
.policy = devlink_dpipe_table_get_nl_policy,
|
||||||
|
.maxattr = DEVLINK_ATTR_DPIPE_TABLE_NAME,
|
||||||
|
.flags = GENL_CMD_CAP_DO,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.cmd = DEVLINK_CMD_DPIPE_ENTRIES_GET,
|
||||||
|
.validate = GENL_DONT_VALIDATE_STRICT,
|
||||||
|
.pre_doit = devlink_nl_pre_doit,
|
||||||
|
.doit = devlink_nl_dpipe_entries_get_doit,
|
||||||
|
.post_doit = devlink_nl_post_doit,
|
||||||
|
.policy = devlink_dpipe_entries_get_nl_policy,
|
||||||
|
.maxattr = DEVLINK_ATTR_DPIPE_TABLE_NAME,
|
||||||
|
.flags = GENL_CMD_CAP_DO,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.cmd = DEVLINK_CMD_DPIPE_HEADERS_GET,
|
||||||
|
.validate = GENL_DONT_VALIDATE_STRICT,
|
||||||
|
.pre_doit = devlink_nl_pre_doit,
|
||||||
|
.doit = devlink_nl_dpipe_headers_get_doit,
|
||||||
|
.post_doit = devlink_nl_post_doit,
|
||||||
|
.policy = devlink_dpipe_headers_get_nl_policy,
|
||||||
|
.maxattr = DEVLINK_ATTR_DEV_NAME,
|
||||||
|
.flags = GENL_CMD_CAP_DO,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.cmd = DEVLINK_CMD_DPIPE_TABLE_COUNTERS_SET,
|
||||||
|
.validate = GENL_DONT_VALIDATE_STRICT,
|
||||||
|
.pre_doit = devlink_nl_pre_doit,
|
||||||
|
.doit = devlink_nl_dpipe_table_counters_set_doit,
|
||||||
|
.post_doit = devlink_nl_post_doit,
|
||||||
|
.policy = devlink_dpipe_table_counters_set_nl_policy,
|
||||||
|
.maxattr = DEVLINK_ATTR_DPIPE_TABLE_COUNTERS_ENABLED,
|
||||||
|
.flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DO,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.cmd = DEVLINK_CMD_RESOURCE_SET,
|
||||||
|
.validate = GENL_DONT_VALIDATE_STRICT,
|
||||||
|
.pre_doit = devlink_nl_pre_doit,
|
||||||
|
.doit = devlink_nl_resource_set_doit,
|
||||||
|
.post_doit = devlink_nl_post_doit,
|
||||||
|
.policy = devlink_resource_set_nl_policy,
|
||||||
|
.maxattr = DEVLINK_ATTR_RESOURCE_SIZE,
|
||||||
|
.flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DO,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.cmd = DEVLINK_CMD_RESOURCE_DUMP,
|
||||||
|
.validate = GENL_DONT_VALIDATE_STRICT,
|
||||||
|
.pre_doit = devlink_nl_pre_doit,
|
||||||
|
.doit = devlink_nl_resource_dump_doit,
|
||||||
|
.post_doit = devlink_nl_post_doit,
|
||||||
|
.policy = devlink_resource_dump_nl_policy,
|
||||||
|
.maxattr = DEVLINK_ATTR_DEV_NAME,
|
||||||
|
.flags = GENL_CMD_CAP_DO,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.cmd = DEVLINK_CMD_RELOAD,
|
||||||
|
.validate = GENL_DONT_VALIDATE_STRICT,
|
||||||
|
.pre_doit = devlink_nl_pre_doit,
|
||||||
|
.doit = devlink_nl_reload_doit,
|
||||||
|
.post_doit = devlink_nl_post_doit,
|
||||||
|
.policy = devlink_reload_nl_policy,
|
||||||
|
.maxattr = DEVLINK_ATTR_RELOAD_LIMITS,
|
||||||
|
.flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DO,
|
||||||
|
},
|
||||||
{
|
{
|
||||||
.cmd = DEVLINK_CMD_PARAM_GET,
|
.cmd = DEVLINK_CMD_PARAM_GET,
|
||||||
.validate = GENL_DONT_VALIDATE_STRICT,
|
.validate = GENL_DONT_VALIDATE_STRICT,
|
||||||
@ -327,6 +870,16 @@ const struct genl_split_ops devlink_nl_ops[32] = {
|
|||||||
.maxattr = DEVLINK_ATTR_DEV_NAME,
|
.maxattr = DEVLINK_ATTR_DEV_NAME,
|
||||||
.flags = GENL_CMD_CAP_DUMP,
|
.flags = GENL_CMD_CAP_DUMP,
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
.cmd = DEVLINK_CMD_PARAM_SET,
|
||||||
|
.validate = GENL_DONT_VALIDATE_STRICT,
|
||||||
|
.pre_doit = devlink_nl_pre_doit,
|
||||||
|
.doit = devlink_nl_param_set_doit,
|
||||||
|
.post_doit = devlink_nl_post_doit,
|
||||||
|
.policy = devlink_param_set_nl_policy,
|
||||||
|
.maxattr = DEVLINK_ATTR_PARAM_VALUE_CMODE,
|
||||||
|
.flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DO,
|
||||||
|
},
|
||||||
{
|
{
|
||||||
.cmd = DEVLINK_CMD_REGION_GET,
|
.cmd = DEVLINK_CMD_REGION_GET,
|
||||||
.validate = GENL_DONT_VALIDATE_STRICT,
|
.validate = GENL_DONT_VALIDATE_STRICT,
|
||||||
@ -344,6 +897,60 @@ const struct genl_split_ops devlink_nl_ops[32] = {
|
|||||||
.maxattr = DEVLINK_ATTR_DEV_NAME,
|
.maxattr = DEVLINK_ATTR_DEV_NAME,
|
||||||
.flags = GENL_CMD_CAP_DUMP,
|
.flags = GENL_CMD_CAP_DUMP,
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
.cmd = DEVLINK_CMD_REGION_NEW,
|
||||||
|
.validate = GENL_DONT_VALIDATE_STRICT,
|
||||||
|
.pre_doit = devlink_nl_pre_doit_port_optional,
|
||||||
|
.doit = devlink_nl_region_new_doit,
|
||||||
|
.post_doit = devlink_nl_post_doit,
|
||||||
|
.policy = devlink_region_new_nl_policy,
|
||||||
|
.maxattr = DEVLINK_ATTR_REGION_SNAPSHOT_ID,
|
||||||
|
.flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DO,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.cmd = DEVLINK_CMD_REGION_DEL,
|
||||||
|
.validate = GENL_DONT_VALIDATE_STRICT,
|
||||||
|
.pre_doit = devlink_nl_pre_doit_port_optional,
|
||||||
|
.doit = devlink_nl_region_del_doit,
|
||||||
|
.post_doit = devlink_nl_post_doit,
|
||||||
|
.policy = devlink_region_del_nl_policy,
|
||||||
|
.maxattr = DEVLINK_ATTR_REGION_SNAPSHOT_ID,
|
||||||
|
.flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DO,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.cmd = DEVLINK_CMD_REGION_READ,
|
||||||
|
.validate = GENL_DONT_VALIDATE_DUMP_STRICT,
|
||||||
|
.dumpit = devlink_nl_region_read_dumpit,
|
||||||
|
.policy = devlink_region_read_nl_policy,
|
||||||
|
.maxattr = DEVLINK_ATTR_REGION_DIRECT,
|
||||||
|
.flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DUMP,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.cmd = DEVLINK_CMD_PORT_PARAM_GET,
|
||||||
|
.validate = GENL_DONT_VALIDATE_STRICT,
|
||||||
|
.pre_doit = devlink_nl_pre_doit_port,
|
||||||
|
.doit = devlink_nl_port_param_get_doit,
|
||||||
|
.post_doit = devlink_nl_post_doit,
|
||||||
|
.policy = devlink_port_param_get_nl_policy,
|
||||||
|
.maxattr = DEVLINK_ATTR_PORT_INDEX,
|
||||||
|
.flags = GENL_CMD_CAP_DO,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.cmd = DEVLINK_CMD_PORT_PARAM_GET,
|
||||||
|
.validate = GENL_DONT_VALIDATE_DUMP_STRICT,
|
||||||
|
.dumpit = devlink_nl_port_param_get_dumpit,
|
||||||
|
.flags = GENL_CMD_CAP_DUMP,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.cmd = DEVLINK_CMD_PORT_PARAM_SET,
|
||||||
|
.validate = GENL_DONT_VALIDATE_STRICT,
|
||||||
|
.pre_doit = devlink_nl_pre_doit_port,
|
||||||
|
.doit = devlink_nl_port_param_set_doit,
|
||||||
|
.post_doit = devlink_nl_post_doit,
|
||||||
|
.policy = devlink_port_param_set_nl_policy,
|
||||||
|
.maxattr = DEVLINK_ATTR_PORT_INDEX,
|
||||||
|
.flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DO,
|
||||||
|
},
|
||||||
{
|
{
|
||||||
.cmd = DEVLINK_CMD_INFO_GET,
|
.cmd = DEVLINK_CMD_INFO_GET,
|
||||||
.validate = GENL_DONT_VALIDATE_STRICT,
|
.validate = GENL_DONT_VALIDATE_STRICT,
|
||||||
@ -377,6 +984,64 @@ const struct genl_split_ops devlink_nl_ops[32] = {
|
|||||||
.maxattr = DEVLINK_ATTR_PORT_INDEX,
|
.maxattr = DEVLINK_ATTR_PORT_INDEX,
|
||||||
.flags = GENL_CMD_CAP_DUMP,
|
.flags = GENL_CMD_CAP_DUMP,
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
.cmd = DEVLINK_CMD_HEALTH_REPORTER_SET,
|
||||||
|
.validate = GENL_DONT_VALIDATE_STRICT,
|
||||||
|
.pre_doit = devlink_nl_pre_doit_port_optional,
|
||||||
|
.doit = devlink_nl_health_reporter_set_doit,
|
||||||
|
.post_doit = devlink_nl_post_doit,
|
||||||
|
.policy = devlink_health_reporter_set_nl_policy,
|
||||||
|
.maxattr = DEVLINK_ATTR_HEALTH_REPORTER_AUTO_DUMP,
|
||||||
|
.flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DO,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.cmd = DEVLINK_CMD_HEALTH_REPORTER_RECOVER,
|
||||||
|
.validate = GENL_DONT_VALIDATE_STRICT,
|
||||||
|
.pre_doit = devlink_nl_pre_doit_port_optional,
|
||||||
|
.doit = devlink_nl_health_reporter_recover_doit,
|
||||||
|
.post_doit = devlink_nl_post_doit,
|
||||||
|
.policy = devlink_health_reporter_recover_nl_policy,
|
||||||
|
.maxattr = DEVLINK_ATTR_HEALTH_REPORTER_NAME,
|
||||||
|
.flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DO,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.cmd = DEVLINK_CMD_HEALTH_REPORTER_DIAGNOSE,
|
||||||
|
.validate = GENL_DONT_VALIDATE_STRICT,
|
||||||
|
.pre_doit = devlink_nl_pre_doit_port_optional,
|
||||||
|
.doit = devlink_nl_health_reporter_diagnose_doit,
|
||||||
|
.post_doit = devlink_nl_post_doit,
|
||||||
|
.policy = devlink_health_reporter_diagnose_nl_policy,
|
||||||
|
.maxattr = DEVLINK_ATTR_HEALTH_REPORTER_NAME,
|
||||||
|
.flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DO,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.cmd = DEVLINK_CMD_HEALTH_REPORTER_DUMP_GET,
|
||||||
|
.validate = GENL_DONT_VALIDATE_DUMP_STRICT,
|
||||||
|
.dumpit = devlink_nl_health_reporter_dump_get_dumpit,
|
||||||
|
.policy = devlink_health_reporter_dump_get_nl_policy,
|
||||||
|
.maxattr = DEVLINK_ATTR_HEALTH_REPORTER_NAME,
|
||||||
|
.flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DUMP,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.cmd = DEVLINK_CMD_HEALTH_REPORTER_DUMP_CLEAR,
|
||||||
|
.validate = GENL_DONT_VALIDATE_STRICT,
|
||||||
|
.pre_doit = devlink_nl_pre_doit_port_optional,
|
||||||
|
.doit = devlink_nl_health_reporter_dump_clear_doit,
|
||||||
|
.post_doit = devlink_nl_post_doit,
|
||||||
|
.policy = devlink_health_reporter_dump_clear_nl_policy,
|
||||||
|
.maxattr = DEVLINK_ATTR_HEALTH_REPORTER_NAME,
|
||||||
|
.flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DO,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.cmd = DEVLINK_CMD_FLASH_UPDATE,
|
||||||
|
.validate = GENL_DONT_VALIDATE_STRICT,
|
||||||
|
.pre_doit = devlink_nl_pre_doit,
|
||||||
|
.doit = devlink_nl_flash_update_doit,
|
||||||
|
.post_doit = devlink_nl_post_doit,
|
||||||
|
.policy = devlink_flash_update_nl_policy,
|
||||||
|
.maxattr = DEVLINK_ATTR_FLASH_UPDATE_OVERWRITE_MASK,
|
||||||
|
.flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DO,
|
||||||
|
},
|
||||||
{
|
{
|
||||||
.cmd = DEVLINK_CMD_TRAP_GET,
|
.cmd = DEVLINK_CMD_TRAP_GET,
|
||||||
.validate = GENL_DONT_VALIDATE_STRICT,
|
.validate = GENL_DONT_VALIDATE_STRICT,
|
||||||
@ -394,6 +1059,16 @@ const struct genl_split_ops devlink_nl_ops[32] = {
|
|||||||
.maxattr = DEVLINK_ATTR_DEV_NAME,
|
.maxattr = DEVLINK_ATTR_DEV_NAME,
|
||||||
.flags = GENL_CMD_CAP_DUMP,
|
.flags = GENL_CMD_CAP_DUMP,
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
.cmd = DEVLINK_CMD_TRAP_SET,
|
||||||
|
.validate = GENL_DONT_VALIDATE_STRICT,
|
||||||
|
.pre_doit = devlink_nl_pre_doit,
|
||||||
|
.doit = devlink_nl_trap_set_doit,
|
||||||
|
.post_doit = devlink_nl_post_doit,
|
||||||
|
.policy = devlink_trap_set_nl_policy,
|
||||||
|
.maxattr = DEVLINK_ATTR_TRAP_ACTION,
|
||||||
|
.flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DO,
|
||||||
|
},
|
||||||
{
|
{
|
||||||
.cmd = DEVLINK_CMD_TRAP_GROUP_GET,
|
.cmd = DEVLINK_CMD_TRAP_GROUP_GET,
|
||||||
.validate = GENL_DONT_VALIDATE_STRICT,
|
.validate = GENL_DONT_VALIDATE_STRICT,
|
||||||
@ -411,6 +1086,16 @@ const struct genl_split_ops devlink_nl_ops[32] = {
|
|||||||
.maxattr = DEVLINK_ATTR_DEV_NAME,
|
.maxattr = DEVLINK_ATTR_DEV_NAME,
|
||||||
.flags = GENL_CMD_CAP_DUMP,
|
.flags = GENL_CMD_CAP_DUMP,
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
.cmd = DEVLINK_CMD_TRAP_GROUP_SET,
|
||||||
|
.validate = GENL_DONT_VALIDATE_STRICT,
|
||||||
|
.pre_doit = devlink_nl_pre_doit,
|
||||||
|
.doit = devlink_nl_trap_group_set_doit,
|
||||||
|
.post_doit = devlink_nl_post_doit,
|
||||||
|
.policy = devlink_trap_group_set_nl_policy,
|
||||||
|
.maxattr = DEVLINK_ATTR_TRAP_POLICER_ID,
|
||||||
|
.flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DO,
|
||||||
|
},
|
||||||
{
|
{
|
||||||
.cmd = DEVLINK_CMD_TRAP_POLICER_GET,
|
.cmd = DEVLINK_CMD_TRAP_POLICER_GET,
|
||||||
.validate = GENL_DONT_VALIDATE_STRICT,
|
.validate = GENL_DONT_VALIDATE_STRICT,
|
||||||
@ -428,6 +1113,26 @@ const struct genl_split_ops devlink_nl_ops[32] = {
|
|||||||
.maxattr = DEVLINK_ATTR_DEV_NAME,
|
.maxattr = DEVLINK_ATTR_DEV_NAME,
|
||||||
.flags = GENL_CMD_CAP_DUMP,
|
.flags = GENL_CMD_CAP_DUMP,
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
.cmd = DEVLINK_CMD_TRAP_POLICER_SET,
|
||||||
|
.validate = GENL_DONT_VALIDATE_STRICT,
|
||||||
|
.pre_doit = devlink_nl_pre_doit,
|
||||||
|
.doit = devlink_nl_trap_policer_set_doit,
|
||||||
|
.post_doit = devlink_nl_post_doit,
|
||||||
|
.policy = devlink_trap_policer_set_nl_policy,
|
||||||
|
.maxattr = DEVLINK_ATTR_TRAP_POLICER_BURST,
|
||||||
|
.flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DO,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.cmd = DEVLINK_CMD_HEALTH_REPORTER_TEST,
|
||||||
|
.validate = GENL_DONT_VALIDATE_STRICT,
|
||||||
|
.pre_doit = devlink_nl_pre_doit_port_optional,
|
||||||
|
.doit = devlink_nl_health_reporter_test_doit,
|
||||||
|
.post_doit = devlink_nl_post_doit,
|
||||||
|
.policy = devlink_health_reporter_test_nl_policy,
|
||||||
|
.maxattr = DEVLINK_ATTR_HEALTH_REPORTER_NAME,
|
||||||
|
.flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DO,
|
||||||
|
},
|
||||||
{
|
{
|
||||||
.cmd = DEVLINK_CMD_RATE_GET,
|
.cmd = DEVLINK_CMD_RATE_GET,
|
||||||
.validate = GENL_DONT_VALIDATE_STRICT,
|
.validate = GENL_DONT_VALIDATE_STRICT,
|
||||||
@ -445,6 +1150,36 @@ const struct genl_split_ops devlink_nl_ops[32] = {
|
|||||||
.maxattr = DEVLINK_ATTR_DEV_NAME,
|
.maxattr = DEVLINK_ATTR_DEV_NAME,
|
||||||
.flags = GENL_CMD_CAP_DUMP,
|
.flags = GENL_CMD_CAP_DUMP,
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
.cmd = DEVLINK_CMD_RATE_SET,
|
||||||
|
.validate = GENL_DONT_VALIDATE_STRICT,
|
||||||
|
.pre_doit = devlink_nl_pre_doit,
|
||||||
|
.doit = devlink_nl_rate_set_doit,
|
||||||
|
.post_doit = devlink_nl_post_doit,
|
||||||
|
.policy = devlink_rate_set_nl_policy,
|
||||||
|
.maxattr = DEVLINK_ATTR_RATE_TX_WEIGHT,
|
||||||
|
.flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DO,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.cmd = DEVLINK_CMD_RATE_NEW,
|
||||||
|
.validate = GENL_DONT_VALIDATE_STRICT,
|
||||||
|
.pre_doit = devlink_nl_pre_doit,
|
||||||
|
.doit = devlink_nl_rate_new_doit,
|
||||||
|
.post_doit = devlink_nl_post_doit,
|
||||||
|
.policy = devlink_rate_new_nl_policy,
|
||||||
|
.maxattr = DEVLINK_ATTR_RATE_TX_WEIGHT,
|
||||||
|
.flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DO,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
.cmd = DEVLINK_CMD_RATE_DEL,
|
||||||
|
.validate = GENL_DONT_VALIDATE_STRICT,
|
||||||
|
.pre_doit = devlink_nl_pre_doit,
|
||||||
|
.doit = devlink_nl_rate_del_doit,
|
||||||
|
.post_doit = devlink_nl_post_doit,
|
||||||
|
.policy = devlink_rate_del_nl_policy,
|
||||||
|
.maxattr = DEVLINK_ATTR_RATE_NODE_NAME,
|
||||||
|
.flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DO,
|
||||||
|
},
|
||||||
{
|
{
|
||||||
.cmd = DEVLINK_CMD_LINECARD_GET,
|
.cmd = DEVLINK_CMD_LINECARD_GET,
|
||||||
.validate = GENL_DONT_VALIDATE_STRICT,
|
.validate = GENL_DONT_VALIDATE_STRICT,
|
||||||
@ -462,6 +1197,16 @@ const struct genl_split_ops devlink_nl_ops[32] = {
|
|||||||
.maxattr = DEVLINK_ATTR_DEV_NAME,
|
.maxattr = DEVLINK_ATTR_DEV_NAME,
|
||||||
.flags = GENL_CMD_CAP_DUMP,
|
.flags = GENL_CMD_CAP_DUMP,
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
.cmd = DEVLINK_CMD_LINECARD_SET,
|
||||||
|
.validate = GENL_DONT_VALIDATE_STRICT,
|
||||||
|
.pre_doit = devlink_nl_pre_doit,
|
||||||
|
.doit = devlink_nl_linecard_set_doit,
|
||||||
|
.post_doit = devlink_nl_post_doit,
|
||||||
|
.policy = devlink_linecard_set_nl_policy,
|
||||||
|
.maxattr = DEVLINK_ATTR_LINECARD_TYPE,
|
||||||
|
.flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DO,
|
||||||
|
},
|
||||||
{
|
{
|
||||||
.cmd = DEVLINK_CMD_SELFTESTS_GET,
|
.cmd = DEVLINK_CMD_SELFTESTS_GET,
|
||||||
.validate = GENL_DONT_VALIDATE_STRICT,
|
.validate = GENL_DONT_VALIDATE_STRICT,
|
||||||
@ -478,4 +1223,14 @@ const struct genl_split_ops devlink_nl_ops[32] = {
|
|||||||
.dumpit = devlink_nl_selftests_get_dumpit,
|
.dumpit = devlink_nl_selftests_get_dumpit,
|
||||||
.flags = GENL_CMD_CAP_DUMP,
|
.flags = GENL_CMD_CAP_DUMP,
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
.cmd = DEVLINK_CMD_SELFTESTS_RUN,
|
||||||
|
.validate = GENL_DONT_VALIDATE_STRICT,
|
||||||
|
.pre_doit = devlink_nl_pre_doit,
|
||||||
|
.doit = devlink_nl_selftests_run_doit,
|
||||||
|
.post_doit = devlink_nl_post_doit,
|
||||||
|
.policy = devlink_selftests_run_nl_policy,
|
||||||
|
.maxattr = DEVLINK_ATTR_SELFTESTS,
|
||||||
|
.flags = GENL_ADMIN_PERM | GENL_CMD_CAP_DO,
|
||||||
|
},
|
||||||
};
|
};
|
||||||
|
@ -11,8 +11,12 @@
|
|||||||
|
|
||||||
#include <uapi/linux/devlink.h>
|
#include <uapi/linux/devlink.h>
|
||||||
|
|
||||||
|
/* Common nested types */
|
||||||
|
extern const struct nla_policy devlink_dl_port_function_nl_policy[DEVLINK_PORT_FN_ATTR_CAPS + 1];
|
||||||
|
extern const struct nla_policy devlink_dl_selftest_id_nl_policy[DEVLINK_ATTR_SELFTEST_ID_FLASH + 1];
|
||||||
|
|
||||||
/* Ops table for devlink */
|
/* Ops table for devlink */
|
||||||
extern const struct genl_split_ops devlink_nl_ops[32];
|
extern const struct genl_split_ops devlink_nl_ops[73];
|
||||||
|
|
||||||
int devlink_nl_pre_doit(const struct genl_split_ops *ops, struct sk_buff *skb,
|
int devlink_nl_pre_doit(const struct genl_split_ops *ops, struct sk_buff *skb,
|
||||||
struct genl_info *info);
|
struct genl_info *info);
|
||||||
@ -30,25 +34,61 @@ int devlink_nl_get_dumpit(struct sk_buff *skb, struct netlink_callback *cb);
|
|||||||
int devlink_nl_port_get_doit(struct sk_buff *skb, struct genl_info *info);
|
int devlink_nl_port_get_doit(struct sk_buff *skb, struct genl_info *info);
|
||||||
int devlink_nl_port_get_dumpit(struct sk_buff *skb,
|
int devlink_nl_port_get_dumpit(struct sk_buff *skb,
|
||||||
struct netlink_callback *cb);
|
struct netlink_callback *cb);
|
||||||
|
int devlink_nl_port_set_doit(struct sk_buff *skb, struct genl_info *info);
|
||||||
|
int devlink_nl_port_new_doit(struct sk_buff *skb, struct genl_info *info);
|
||||||
|
int devlink_nl_port_del_doit(struct sk_buff *skb, struct genl_info *info);
|
||||||
|
int devlink_nl_port_split_doit(struct sk_buff *skb, struct genl_info *info);
|
||||||
|
int devlink_nl_port_unsplit_doit(struct sk_buff *skb, struct genl_info *info);
|
||||||
int devlink_nl_sb_get_doit(struct sk_buff *skb, struct genl_info *info);
|
int devlink_nl_sb_get_doit(struct sk_buff *skb, struct genl_info *info);
|
||||||
int devlink_nl_sb_get_dumpit(struct sk_buff *skb, struct netlink_callback *cb);
|
int devlink_nl_sb_get_dumpit(struct sk_buff *skb, struct netlink_callback *cb);
|
||||||
int devlink_nl_sb_pool_get_doit(struct sk_buff *skb, struct genl_info *info);
|
int devlink_nl_sb_pool_get_doit(struct sk_buff *skb, struct genl_info *info);
|
||||||
int devlink_nl_sb_pool_get_dumpit(struct sk_buff *skb,
|
int devlink_nl_sb_pool_get_dumpit(struct sk_buff *skb,
|
||||||
struct netlink_callback *cb);
|
struct netlink_callback *cb);
|
||||||
|
int devlink_nl_sb_pool_set_doit(struct sk_buff *skb, struct genl_info *info);
|
||||||
int devlink_nl_sb_port_pool_get_doit(struct sk_buff *skb,
|
int devlink_nl_sb_port_pool_get_doit(struct sk_buff *skb,
|
||||||
struct genl_info *info);
|
struct genl_info *info);
|
||||||
int devlink_nl_sb_port_pool_get_dumpit(struct sk_buff *skb,
|
int devlink_nl_sb_port_pool_get_dumpit(struct sk_buff *skb,
|
||||||
struct netlink_callback *cb);
|
struct netlink_callback *cb);
|
||||||
|
int devlink_nl_sb_port_pool_set_doit(struct sk_buff *skb,
|
||||||
|
struct genl_info *info);
|
||||||
int devlink_nl_sb_tc_pool_bind_get_doit(struct sk_buff *skb,
|
int devlink_nl_sb_tc_pool_bind_get_doit(struct sk_buff *skb,
|
||||||
struct genl_info *info);
|
struct genl_info *info);
|
||||||
int devlink_nl_sb_tc_pool_bind_get_dumpit(struct sk_buff *skb,
|
int devlink_nl_sb_tc_pool_bind_get_dumpit(struct sk_buff *skb,
|
||||||
struct netlink_callback *cb);
|
struct netlink_callback *cb);
|
||||||
|
int devlink_nl_sb_tc_pool_bind_set_doit(struct sk_buff *skb,
|
||||||
|
struct genl_info *info);
|
||||||
|
int devlink_nl_sb_occ_snapshot_doit(struct sk_buff *skb,
|
||||||
|
struct genl_info *info);
|
||||||
|
int devlink_nl_sb_occ_max_clear_doit(struct sk_buff *skb,
|
||||||
|
struct genl_info *info);
|
||||||
|
int devlink_nl_eswitch_get_doit(struct sk_buff *skb, struct genl_info *info);
|
||||||
|
int devlink_nl_eswitch_set_doit(struct sk_buff *skb, struct genl_info *info);
|
||||||
|
int devlink_nl_dpipe_table_get_doit(struct sk_buff *skb,
|
||||||
|
struct genl_info *info);
|
||||||
|
int devlink_nl_dpipe_entries_get_doit(struct sk_buff *skb,
|
||||||
|
struct genl_info *info);
|
||||||
|
int devlink_nl_dpipe_headers_get_doit(struct sk_buff *skb,
|
||||||
|
struct genl_info *info);
|
||||||
|
int devlink_nl_dpipe_table_counters_set_doit(struct sk_buff *skb,
|
||||||
|
struct genl_info *info);
|
||||||
|
int devlink_nl_resource_set_doit(struct sk_buff *skb, struct genl_info *info);
|
||||||
|
int devlink_nl_resource_dump_doit(struct sk_buff *skb, struct genl_info *info);
|
||||||
|
int devlink_nl_reload_doit(struct sk_buff *skb, struct genl_info *info);
|
||||||
int devlink_nl_param_get_doit(struct sk_buff *skb, struct genl_info *info);
|
int devlink_nl_param_get_doit(struct sk_buff *skb, struct genl_info *info);
|
||||||
int devlink_nl_param_get_dumpit(struct sk_buff *skb,
|
int devlink_nl_param_get_dumpit(struct sk_buff *skb,
|
||||||
struct netlink_callback *cb);
|
struct netlink_callback *cb);
|
||||||
|
int devlink_nl_param_set_doit(struct sk_buff *skb, struct genl_info *info);
|
||||||
int devlink_nl_region_get_doit(struct sk_buff *skb, struct genl_info *info);
|
int devlink_nl_region_get_doit(struct sk_buff *skb, struct genl_info *info);
|
||||||
int devlink_nl_region_get_dumpit(struct sk_buff *skb,
|
int devlink_nl_region_get_dumpit(struct sk_buff *skb,
|
||||||
struct netlink_callback *cb);
|
struct netlink_callback *cb);
|
||||||
|
int devlink_nl_region_new_doit(struct sk_buff *skb, struct genl_info *info);
|
||||||
|
int devlink_nl_region_del_doit(struct sk_buff *skb, struct genl_info *info);
|
||||||
|
int devlink_nl_region_read_dumpit(struct sk_buff *skb,
|
||||||
|
struct netlink_callback *cb);
|
||||||
|
int devlink_nl_port_param_get_doit(struct sk_buff *skb, struct genl_info *info);
|
||||||
|
int devlink_nl_port_param_get_dumpit(struct sk_buff *skb,
|
||||||
|
struct netlink_callback *cb);
|
||||||
|
int devlink_nl_port_param_set_doit(struct sk_buff *skb, struct genl_info *info);
|
||||||
int devlink_nl_info_get_doit(struct sk_buff *skb, struct genl_info *info);
|
int devlink_nl_info_get_doit(struct sk_buff *skb, struct genl_info *info);
|
||||||
int devlink_nl_info_get_dumpit(struct sk_buff *skb,
|
int devlink_nl_info_get_dumpit(struct sk_buff *skb,
|
||||||
struct netlink_callback *cb);
|
struct netlink_callback *cb);
|
||||||
@ -56,24 +96,46 @@ int devlink_nl_health_reporter_get_doit(struct sk_buff *skb,
|
|||||||
struct genl_info *info);
|
struct genl_info *info);
|
||||||
int devlink_nl_health_reporter_get_dumpit(struct sk_buff *skb,
|
int devlink_nl_health_reporter_get_dumpit(struct sk_buff *skb,
|
||||||
struct netlink_callback *cb);
|
struct netlink_callback *cb);
|
||||||
|
int devlink_nl_health_reporter_set_doit(struct sk_buff *skb,
|
||||||
|
struct genl_info *info);
|
||||||
|
int devlink_nl_health_reporter_recover_doit(struct sk_buff *skb,
|
||||||
|
struct genl_info *info);
|
||||||
|
int devlink_nl_health_reporter_diagnose_doit(struct sk_buff *skb,
|
||||||
|
struct genl_info *info);
|
||||||
|
int devlink_nl_health_reporter_dump_get_dumpit(struct sk_buff *skb,
|
||||||
|
struct netlink_callback *cb);
|
||||||
|
int devlink_nl_health_reporter_dump_clear_doit(struct sk_buff *skb,
|
||||||
|
struct genl_info *info);
|
||||||
|
int devlink_nl_flash_update_doit(struct sk_buff *skb, struct genl_info *info);
|
||||||
int devlink_nl_trap_get_doit(struct sk_buff *skb, struct genl_info *info);
|
int devlink_nl_trap_get_doit(struct sk_buff *skb, struct genl_info *info);
|
||||||
int devlink_nl_trap_get_dumpit(struct sk_buff *skb,
|
int devlink_nl_trap_get_dumpit(struct sk_buff *skb,
|
||||||
struct netlink_callback *cb);
|
struct netlink_callback *cb);
|
||||||
|
int devlink_nl_trap_set_doit(struct sk_buff *skb, struct genl_info *info);
|
||||||
int devlink_nl_trap_group_get_doit(struct sk_buff *skb, struct genl_info *info);
|
int devlink_nl_trap_group_get_doit(struct sk_buff *skb, struct genl_info *info);
|
||||||
int devlink_nl_trap_group_get_dumpit(struct sk_buff *skb,
|
int devlink_nl_trap_group_get_dumpit(struct sk_buff *skb,
|
||||||
struct netlink_callback *cb);
|
struct netlink_callback *cb);
|
||||||
|
int devlink_nl_trap_group_set_doit(struct sk_buff *skb, struct genl_info *info);
|
||||||
int devlink_nl_trap_policer_get_doit(struct sk_buff *skb,
|
int devlink_nl_trap_policer_get_doit(struct sk_buff *skb,
|
||||||
struct genl_info *info);
|
struct genl_info *info);
|
||||||
int devlink_nl_trap_policer_get_dumpit(struct sk_buff *skb,
|
int devlink_nl_trap_policer_get_dumpit(struct sk_buff *skb,
|
||||||
struct netlink_callback *cb);
|
struct netlink_callback *cb);
|
||||||
|
int devlink_nl_trap_policer_set_doit(struct sk_buff *skb,
|
||||||
|
struct genl_info *info);
|
||||||
|
int devlink_nl_health_reporter_test_doit(struct sk_buff *skb,
|
||||||
|
struct genl_info *info);
|
||||||
int devlink_nl_rate_get_doit(struct sk_buff *skb, struct genl_info *info);
|
int devlink_nl_rate_get_doit(struct sk_buff *skb, struct genl_info *info);
|
||||||
int devlink_nl_rate_get_dumpit(struct sk_buff *skb,
|
int devlink_nl_rate_get_dumpit(struct sk_buff *skb,
|
||||||
struct netlink_callback *cb);
|
struct netlink_callback *cb);
|
||||||
|
int devlink_nl_rate_set_doit(struct sk_buff *skb, struct genl_info *info);
|
||||||
|
int devlink_nl_rate_new_doit(struct sk_buff *skb, struct genl_info *info);
|
||||||
|
int devlink_nl_rate_del_doit(struct sk_buff *skb, struct genl_info *info);
|
||||||
int devlink_nl_linecard_get_doit(struct sk_buff *skb, struct genl_info *info);
|
int devlink_nl_linecard_get_doit(struct sk_buff *skb, struct genl_info *info);
|
||||||
int devlink_nl_linecard_get_dumpit(struct sk_buff *skb,
|
int devlink_nl_linecard_get_dumpit(struct sk_buff *skb,
|
||||||
struct netlink_callback *cb);
|
struct netlink_callback *cb);
|
||||||
|
int devlink_nl_linecard_set_doit(struct sk_buff *skb, struct genl_info *info);
|
||||||
int devlink_nl_selftests_get_doit(struct sk_buff *skb, struct genl_info *info);
|
int devlink_nl_selftests_get_doit(struct sk_buff *skb, struct genl_info *info);
|
||||||
int devlink_nl_selftests_get_dumpit(struct sk_buff *skb,
|
int devlink_nl_selftests_get_dumpit(struct sk_buff *skb,
|
||||||
struct netlink_callback *cb);
|
struct netlink_callback *cb);
|
||||||
|
int devlink_nl_selftests_run_doit(struct sk_buff *skb, struct genl_info *info);
|
||||||
|
|
||||||
#endif /* _LINUX_DEVLINK_GEN_H */
|
#endif /* _LINUX_DEVLINK_GEN_H */
|
||||||
|
@ -581,7 +581,7 @@ static int __devlink_nl_cmd_param_set_doit(struct devlink *devlink,
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int devlink_nl_cmd_param_set_doit(struct sk_buff *skb, struct genl_info *info)
|
int devlink_nl_param_set_doit(struct sk_buff *skb, struct genl_info *info)
|
||||||
{
|
{
|
||||||
struct devlink *devlink = info->user_ptr[0];
|
struct devlink *devlink = info->user_ptr[0];
|
||||||
|
|
||||||
@ -589,22 +589,22 @@ int devlink_nl_cmd_param_set_doit(struct sk_buff *skb, struct genl_info *info)
|
|||||||
info, DEVLINK_CMD_PARAM_NEW);
|
info, DEVLINK_CMD_PARAM_NEW);
|
||||||
}
|
}
|
||||||
|
|
||||||
int devlink_nl_cmd_port_param_get_dumpit(struct sk_buff *msg,
|
int devlink_nl_port_param_get_dumpit(struct sk_buff *msg,
|
||||||
struct netlink_callback *cb)
|
struct netlink_callback *cb)
|
||||||
{
|
{
|
||||||
NL_SET_ERR_MSG(cb->extack, "Port params are not supported");
|
NL_SET_ERR_MSG(cb->extack, "Port params are not supported");
|
||||||
return msg->len;
|
return msg->len;
|
||||||
}
|
}
|
||||||
|
|
||||||
int devlink_nl_cmd_port_param_get_doit(struct sk_buff *skb,
|
int devlink_nl_port_param_get_doit(struct sk_buff *skb,
|
||||||
struct genl_info *info)
|
struct genl_info *info)
|
||||||
{
|
{
|
||||||
NL_SET_ERR_MSG(info->extack, "Port params are not supported");
|
NL_SET_ERR_MSG(info->extack, "Port params are not supported");
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
int devlink_nl_cmd_port_param_set_doit(struct sk_buff *skb,
|
int devlink_nl_port_param_set_doit(struct sk_buff *skb,
|
||||||
struct genl_info *info)
|
struct genl_info *info)
|
||||||
{
|
{
|
||||||
NL_SET_ERR_MSG(info->extack, "Port params are not supported");
|
NL_SET_ERR_MSG(info->extack, "Port params are not supported");
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
@ -772,7 +772,7 @@ static int devlink_port_function_set(struct devlink_port *port,
|
|||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
int devlink_nl_cmd_port_set_doit(struct sk_buff *skb, struct genl_info *info)
|
int devlink_nl_port_set_doit(struct sk_buff *skb, struct genl_info *info)
|
||||||
{
|
{
|
||||||
struct devlink_port *devlink_port = info->user_ptr[1];
|
struct devlink_port *devlink_port = info->user_ptr[1];
|
||||||
int err;
|
int err;
|
||||||
@ -798,7 +798,7 @@ int devlink_nl_cmd_port_set_doit(struct sk_buff *skb, struct genl_info *info)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int devlink_nl_cmd_port_split_doit(struct sk_buff *skb, struct genl_info *info)
|
int devlink_nl_port_split_doit(struct sk_buff *skb, struct genl_info *info)
|
||||||
{
|
{
|
||||||
struct devlink_port *devlink_port = info->user_ptr[1];
|
struct devlink_port *devlink_port = info->user_ptr[1];
|
||||||
struct devlink *devlink = info->user_ptr[0];
|
struct devlink *devlink = info->user_ptr[0];
|
||||||
@ -829,8 +829,7 @@ int devlink_nl_cmd_port_split_doit(struct sk_buff *skb, struct genl_info *info)
|
|||||||
info->extack);
|
info->extack);
|
||||||
}
|
}
|
||||||
|
|
||||||
int devlink_nl_cmd_port_unsplit_doit(struct sk_buff *skb,
|
int devlink_nl_port_unsplit_doit(struct sk_buff *skb, struct genl_info *info)
|
||||||
struct genl_info *info)
|
|
||||||
{
|
{
|
||||||
struct devlink_port *devlink_port = info->user_ptr[1];
|
struct devlink_port *devlink_port = info->user_ptr[1];
|
||||||
struct devlink *devlink = info->user_ptr[0];
|
struct devlink *devlink = info->user_ptr[0];
|
||||||
@ -840,7 +839,7 @@ int devlink_nl_cmd_port_unsplit_doit(struct sk_buff *skb,
|
|||||||
return devlink_port->ops->port_unsplit(devlink, devlink_port, info->extack);
|
return devlink_port->ops->port_unsplit(devlink, devlink_port, info->extack);
|
||||||
}
|
}
|
||||||
|
|
||||||
int devlink_nl_cmd_port_new_doit(struct sk_buff *skb, struct genl_info *info)
|
int devlink_nl_port_new_doit(struct sk_buff *skb, struct genl_info *info)
|
||||||
{
|
{
|
||||||
struct netlink_ext_ack *extack = info->extack;
|
struct netlink_ext_ack *extack = info->extack;
|
||||||
struct devlink_port_new_attrs new_attrs = {};
|
struct devlink_port_new_attrs new_attrs = {};
|
||||||
@ -904,7 +903,7 @@ err_out_port_del:
|
|||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
int devlink_nl_cmd_port_del_doit(struct sk_buff *skb, struct genl_info *info)
|
int devlink_nl_port_del_doit(struct sk_buff *skb, struct genl_info *info)
|
||||||
{
|
{
|
||||||
struct devlink_port *devlink_port = info->user_ptr[1];
|
struct devlink_port *devlink_port = info->user_ptr[1];
|
||||||
struct netlink_ext_ack *extack = info->extack;
|
struct netlink_ext_ack *extack = info->extack;
|
||||||
|
@ -458,7 +458,7 @@ static bool devlink_rate_set_ops_supported(const struct devlink_ops *ops,
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
int devlink_nl_cmd_rate_set_doit(struct sk_buff *skb, struct genl_info *info)
|
int devlink_nl_rate_set_doit(struct sk_buff *skb, struct genl_info *info)
|
||||||
{
|
{
|
||||||
struct devlink *devlink = info->user_ptr[0];
|
struct devlink *devlink = info->user_ptr[0];
|
||||||
struct devlink_rate *devlink_rate;
|
struct devlink_rate *devlink_rate;
|
||||||
@ -480,7 +480,7 @@ int devlink_nl_cmd_rate_set_doit(struct sk_buff *skb, struct genl_info *info)
|
|||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
int devlink_nl_cmd_rate_new_doit(struct sk_buff *skb, struct genl_info *info)
|
int devlink_nl_rate_new_doit(struct sk_buff *skb, struct genl_info *info)
|
||||||
{
|
{
|
||||||
struct devlink *devlink = info->user_ptr[0];
|
struct devlink *devlink = info->user_ptr[0];
|
||||||
struct devlink_rate *rate_node;
|
struct devlink_rate *rate_node;
|
||||||
@ -536,7 +536,7 @@ err_strdup:
|
|||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
int devlink_nl_cmd_rate_del_doit(struct sk_buff *skb, struct genl_info *info)
|
int devlink_nl_rate_del_doit(struct sk_buff *skb, struct genl_info *info)
|
||||||
{
|
{
|
||||||
struct devlink *devlink = info->user_ptr[0];
|
struct devlink *devlink = info->user_ptr[0];
|
||||||
struct devlink_rate *rate_node;
|
struct devlink_rate *rate_node;
|
||||||
|
@ -588,7 +588,7 @@ int devlink_nl_region_get_dumpit(struct sk_buff *skb,
|
|||||||
return devlink_nl_dumpit(skb, cb, devlink_nl_region_get_dump_one);
|
return devlink_nl_dumpit(skb, cb, devlink_nl_region_get_dump_one);
|
||||||
}
|
}
|
||||||
|
|
||||||
int devlink_nl_cmd_region_del(struct sk_buff *skb, struct genl_info *info)
|
int devlink_nl_region_del_doit(struct sk_buff *skb, struct genl_info *info)
|
||||||
{
|
{
|
||||||
struct devlink *devlink = info->user_ptr[0];
|
struct devlink *devlink = info->user_ptr[0];
|
||||||
struct devlink_snapshot *snapshot;
|
struct devlink_snapshot *snapshot;
|
||||||
@ -633,7 +633,7 @@ int devlink_nl_cmd_region_del(struct sk_buff *skb, struct genl_info *info)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int devlink_nl_cmd_region_new(struct sk_buff *skb, struct genl_info *info)
|
int devlink_nl_region_new_doit(struct sk_buff *skb, struct genl_info *info)
|
||||||
{
|
{
|
||||||
struct devlink *devlink = info->user_ptr[0];
|
struct devlink *devlink = info->user_ptr[0];
|
||||||
struct devlink_snapshot *snapshot;
|
struct devlink_snapshot *snapshot;
|
||||||
@ -863,8 +863,8 @@ devlink_region_direct_fill(void *cb_priv, u8 *chunk, u32 chunk_size,
|
|||||||
curr_offset, chunk_size, chunk);
|
curr_offset, chunk_size, chunk);
|
||||||
}
|
}
|
||||||
|
|
||||||
int devlink_nl_cmd_region_read_dumpit(struct sk_buff *skb,
|
int devlink_nl_region_read_dumpit(struct sk_buff *skb,
|
||||||
struct netlink_callback *cb)
|
struct netlink_callback *cb)
|
||||||
{
|
{
|
||||||
const struct genl_dumpit_info *info = genl_dumpit_info(cb);
|
const struct genl_dumpit_info *info = genl_dumpit_info(cb);
|
||||||
struct devlink_nl_dump_state *state = devlink_dump_state(cb);
|
struct devlink_nl_dump_state *state = devlink_dump_state(cb);
|
||||||
|
@ -105,7 +105,7 @@ devlink_resource_validate_size(struct devlink_resource *resource, u64 size,
|
|||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
int devlink_nl_cmd_resource_set(struct sk_buff *skb, struct genl_info *info)
|
int devlink_nl_resource_set_doit(struct sk_buff *skb, struct genl_info *info)
|
||||||
{
|
{
|
||||||
struct devlink *devlink = info->user_ptr[0];
|
struct devlink *devlink = info->user_ptr[0];
|
||||||
struct devlink_resource *resource;
|
struct devlink_resource *resource;
|
||||||
@ -285,7 +285,7 @@ err_resource_put:
|
|||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
int devlink_nl_cmd_resource_dump(struct sk_buff *skb, struct genl_info *info)
|
int devlink_nl_resource_dump_doit(struct sk_buff *skb, struct genl_info *info)
|
||||||
{
|
{
|
||||||
struct devlink *devlink = info->user_ptr[0];
|
struct devlink *devlink = info->user_ptr[0];
|
||||||
|
|
||||||
|
@ -413,7 +413,7 @@ static int devlink_sb_pool_set(struct devlink *devlink, unsigned int sb_index,
|
|||||||
return -EOPNOTSUPP;
|
return -EOPNOTSUPP;
|
||||||
}
|
}
|
||||||
|
|
||||||
int devlink_nl_cmd_sb_pool_set_doit(struct sk_buff *skb, struct genl_info *info)
|
int devlink_nl_sb_pool_set_doit(struct sk_buff *skb, struct genl_info *info)
|
||||||
{
|
{
|
||||||
struct devlink *devlink = info->user_ptr[0];
|
struct devlink *devlink = info->user_ptr[0];
|
||||||
enum devlink_sb_threshold_type threshold_type;
|
enum devlink_sb_threshold_type threshold_type;
|
||||||
@ -621,8 +621,8 @@ static int devlink_sb_port_pool_set(struct devlink_port *devlink_port,
|
|||||||
return -EOPNOTSUPP;
|
return -EOPNOTSUPP;
|
||||||
}
|
}
|
||||||
|
|
||||||
int devlink_nl_cmd_sb_port_pool_set_doit(struct sk_buff *skb,
|
int devlink_nl_sb_port_pool_set_doit(struct sk_buff *skb,
|
||||||
struct genl_info *info)
|
struct genl_info *info)
|
||||||
{
|
{
|
||||||
struct devlink_port *devlink_port = info->user_ptr[1];
|
struct devlink_port *devlink_port = info->user_ptr[1];
|
||||||
struct devlink *devlink = info->user_ptr[0];
|
struct devlink *devlink = info->user_ptr[0];
|
||||||
@ -861,8 +861,8 @@ static int devlink_sb_tc_pool_bind_set(struct devlink_port *devlink_port,
|
|||||||
return -EOPNOTSUPP;
|
return -EOPNOTSUPP;
|
||||||
}
|
}
|
||||||
|
|
||||||
int devlink_nl_cmd_sb_tc_pool_bind_set_doit(struct sk_buff *skb,
|
int devlink_nl_sb_tc_pool_bind_set_doit(struct sk_buff *skb,
|
||||||
struct genl_info *info)
|
struct genl_info *info)
|
||||||
{
|
{
|
||||||
struct devlink_port *devlink_port = info->user_ptr[1];
|
struct devlink_port *devlink_port = info->user_ptr[1];
|
||||||
struct devlink *devlink = info->user_ptr[0];
|
struct devlink *devlink = info->user_ptr[0];
|
||||||
@ -900,8 +900,7 @@ int devlink_nl_cmd_sb_tc_pool_bind_set_doit(struct sk_buff *skb,
|
|||||||
pool_index, threshold, info->extack);
|
pool_index, threshold, info->extack);
|
||||||
}
|
}
|
||||||
|
|
||||||
int devlink_nl_cmd_sb_occ_snapshot_doit(struct sk_buff *skb,
|
int devlink_nl_sb_occ_snapshot_doit(struct sk_buff *skb, struct genl_info *info)
|
||||||
struct genl_info *info)
|
|
||||||
{
|
{
|
||||||
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;
|
||||||
@ -916,8 +915,8 @@ int devlink_nl_cmd_sb_occ_snapshot_doit(struct sk_buff *skb,
|
|||||||
return -EOPNOTSUPP;
|
return -EOPNOTSUPP;
|
||||||
}
|
}
|
||||||
|
|
||||||
int devlink_nl_cmd_sb_occ_max_clear_doit(struct sk_buff *skb,
|
int devlink_nl_sb_occ_max_clear_doit(struct sk_buff *skb,
|
||||||
struct genl_info *info)
|
struct genl_info *info)
|
||||||
{
|
{
|
||||||
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;
|
||||||
|
@ -414,7 +414,7 @@ static int devlink_trap_action_set(struct devlink *devlink,
|
|||||||
info->extack);
|
info->extack);
|
||||||
}
|
}
|
||||||
|
|
||||||
int devlink_nl_cmd_trap_set_doit(struct sk_buff *skb, struct genl_info *info)
|
int devlink_nl_trap_set_doit(struct sk_buff *skb, struct genl_info *info)
|
||||||
{
|
{
|
||||||
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];
|
||||||
@ -684,8 +684,7 @@ static int devlink_trap_group_set(struct devlink *devlink,
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int devlink_nl_cmd_trap_group_set_doit(struct sk_buff *skb,
|
int devlink_nl_trap_group_set_doit(struct sk_buff *skb, struct genl_info *info)
|
||||||
struct genl_info *info)
|
|
||||||
{
|
{
|
||||||
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];
|
||||||
@ -926,8 +925,8 @@ devlink_trap_policer_set(struct devlink *devlink,
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int devlink_nl_cmd_trap_policer_set_doit(struct sk_buff *skb,
|
int devlink_nl_trap_policer_set_doit(struct sk_buff *skb,
|
||||||
struct genl_info *info)
|
struct genl_info *info)
|
||||||
{
|
{
|
||||||
struct devlink_trap_policer_item *policer_item;
|
struct devlink_trap_policer_item *policer_item;
|
||||||
struct netlink_ext_ack *extack = info->extack;
|
struct netlink_ext_ack *extack = info->extack;
|
||||||
|
@ -225,7 +225,8 @@ static void genl_op_from_split(struct genl_op_iter *iter)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (i + cnt < family->n_split_ops &&
|
if (i + cnt < family->n_split_ops &&
|
||||||
family->split_ops[i + cnt].flags & GENL_CMD_CAP_DUMP) {
|
family->split_ops[i + cnt].flags & GENL_CMD_CAP_DUMP &&
|
||||||
|
(!cnt || family->split_ops[i + cnt].cmd == iter->doit.cmd)) {
|
||||||
iter->dumpit = family->split_ops[i + cnt];
|
iter->dumpit = family->split_ops[i + cnt];
|
||||||
genl_op_fill_in_reject_policy_split(family, &iter->dumpit);
|
genl_op_fill_in_reject_policy_split(family, &iter->dumpit);
|
||||||
cnt++;
|
cnt++;
|
||||||
|
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
@ -379,6 +379,12 @@ int ynl_attr_validate(struct ynl_parse_arg *yarg, const struct nlattr *attr)
|
|||||||
yerr(yarg->ys, YNL_ERROR_ATTR_INVALID,
|
yerr(yarg->ys, YNL_ERROR_ATTR_INVALID,
|
||||||
"Invalid attribute (string %s)", policy->name);
|
"Invalid attribute (string %s)", policy->name);
|
||||||
return -1;
|
return -1;
|
||||||
|
case YNL_PT_BITFIELD32:
|
||||||
|
if (len == sizeof(struct nla_bitfield32))
|
||||||
|
break;
|
||||||
|
yerr(yarg->ys, YNL_ERROR_ATTR_INVALID,
|
||||||
|
"Invalid attribute (bitfield32 %s)", policy->name);
|
||||||
|
return -1;
|
||||||
default:
|
default:
|
||||||
yerr(yarg->ys, YNL_ERROR_ATTR_INVALID,
|
yerr(yarg->ys, YNL_ERROR_ATTR_INVALID,
|
||||||
"Invalid attribute (unknown %s)", policy->name);
|
"Invalid attribute (unknown %s)", policy->name);
|
||||||
|
@ -135,6 +135,7 @@ enum ynl_policy_type {
|
|||||||
YNL_PT_U64,
|
YNL_PT_U64,
|
||||||
YNL_PT_UINT,
|
YNL_PT_UINT,
|
||||||
YNL_PT_NUL_STR,
|
YNL_PT_NUL_STR,
|
||||||
|
YNL_PT_BITFIELD32,
|
||||||
};
|
};
|
||||||
|
|
||||||
struct ynl_policy_attr {
|
struct ynl_policy_attr {
|
||||||
|
@ -478,6 +478,8 @@ class YnlFamily(SpecFamily):
|
|||||||
elif attr['type'] in NlAttr.type_formats:
|
elif attr['type'] in NlAttr.type_formats:
|
||||||
format = NlAttr.get_format(attr['type'], attr.byte_order)
|
format = NlAttr.get_format(attr['type'], attr.byte_order)
|
||||||
attr_payload = format.pack(int(value))
|
attr_payload = format.pack(int(value))
|
||||||
|
elif attr['type'] in "bitfield32":
|
||||||
|
attr_payload = struct.pack("II", int(value["value"]), int(value["selector"]))
|
||||||
else:
|
else:
|
||||||
raise Exception(f'Unknown type at {space} {name} {value} {attr["type"]}')
|
raise Exception(f'Unknown type at {space} {name} {value} {attr["type"]}')
|
||||||
|
|
||||||
@ -545,14 +547,19 @@ class YnlFamily(SpecFamily):
|
|||||||
decoded = attr.as_auto_scalar(attr_spec['type'], attr_spec.byte_order)
|
decoded = attr.as_auto_scalar(attr_spec['type'], attr_spec.byte_order)
|
||||||
elif attr_spec["type"] in NlAttr.type_formats:
|
elif attr_spec["type"] in NlAttr.type_formats:
|
||||||
decoded = attr.as_scalar(attr_spec['type'], attr_spec.byte_order)
|
decoded = attr.as_scalar(attr_spec['type'], attr_spec.byte_order)
|
||||||
|
if 'enum' in attr_spec:
|
||||||
|
decoded = self._decode_enum(decoded, attr_spec)
|
||||||
elif attr_spec["type"] == 'array-nest':
|
elif attr_spec["type"] == 'array-nest':
|
||||||
decoded = self._decode_array_nest(attr, attr_spec)
|
decoded = self._decode_array_nest(attr, attr_spec)
|
||||||
|
elif attr_spec["type"] == 'bitfield32':
|
||||||
|
value, selector = struct.unpack("II", attr.raw)
|
||||||
|
if 'enum' in attr_spec:
|
||||||
|
value = self._decode_enum(value, attr_spec)
|
||||||
|
selector = self._decode_enum(selector, attr_spec)
|
||||||
|
decoded = {"value": value, "selector": selector}
|
||||||
else:
|
else:
|
||||||
raise Exception(f'Unknown {attr_spec["type"]} with name {attr_spec["name"]}')
|
raise Exception(f'Unknown {attr_spec["type"]} with name {attr_spec["name"]}')
|
||||||
|
|
||||||
if 'enum' in attr_spec:
|
|
||||||
decoded = self._decode_enum(decoded, attr_spec)
|
|
||||||
|
|
||||||
if not attr_spec.is_multi:
|
if not attr_spec.is_multi:
|
||||||
rsp[attr_spec['name']] = decoded
|
rsp[attr_spec['name']] = decoded
|
||||||
elif attr_spec.name in rsp:
|
elif attr_spec.name in rsp:
|
||||||
|
@ -488,6 +488,31 @@ class TypeBinary(Type):
|
|||||||
f'memcpy({member}, {self.c_name}, {presence}_len);']
|
f'memcpy({member}, {self.c_name}, {presence}_len);']
|
||||||
|
|
||||||
|
|
||||||
|
class TypeBitfield32(Type):
|
||||||
|
def _complex_member_type(self, ri):
|
||||||
|
return "struct nla_bitfield32"
|
||||||
|
|
||||||
|
def _attr_typol(self):
|
||||||
|
return f'.type = YNL_PT_BITFIELD32, '
|
||||||
|
|
||||||
|
def _attr_policy(self, policy):
|
||||||
|
if not 'enum' in self.attr:
|
||||||
|
raise Exception('Enum required for bitfield32 attr')
|
||||||
|
enum = self.family.consts[self.attr['enum']]
|
||||||
|
mask = enum.get_mask(as_flags=True)
|
||||||
|
return f"NLA_POLICY_BITFIELD32({mask})"
|
||||||
|
|
||||||
|
def attr_put(self, ri, var):
|
||||||
|
line = f"mnl_attr_put(nlh, {self.enum_name}, sizeof(struct nla_bitfield32), &{var}->{self.c_name})"
|
||||||
|
self._attr_put_line(ri, var, line)
|
||||||
|
|
||||||
|
def _attr_get(self, ri, var):
|
||||||
|
return f"memcpy(&{var}->{self.c_name}, mnl_attr_get_payload(attr), sizeof(struct nla_bitfield32));", None, None
|
||||||
|
|
||||||
|
def _setter_lines(self, ri, member, presence):
|
||||||
|
return [f"memcpy(&{member}, {self.c_name}, sizeof(struct nla_bitfield32));"]
|
||||||
|
|
||||||
|
|
||||||
class TypeNest(Type):
|
class TypeNest(Type):
|
||||||
def _complex_member_type(self, ri):
|
def _complex_member_type(self, ri):
|
||||||
return self.nested_struct_type
|
return self.nested_struct_type
|
||||||
@ -786,6 +811,8 @@ class AttrSet(SpecAttrSet):
|
|||||||
t = TypeString(self.family, self, elem, value)
|
t = TypeString(self.family, self, elem, value)
|
||||||
elif elem['type'] == 'binary':
|
elif elem['type'] == 'binary':
|
||||||
t = TypeBinary(self.family, self, elem, value)
|
t = TypeBinary(self.family, self, elem, value)
|
||||||
|
elif elem['type'] == 'bitfield32':
|
||||||
|
t = TypeBitfield32(self.family, self, elem, value)
|
||||||
elif elem['type'] == 'nest':
|
elif elem['type'] == 'nest':
|
||||||
t = TypeNest(self.family, self, elem, value)
|
t = TypeNest(self.family, self, elem, value)
|
||||||
elif elem['type'] == 'array-nest':
|
elif elem['type'] == 'array-nest':
|
||||||
@ -1085,10 +1112,13 @@ class RenderInfo:
|
|||||||
|
|
||||||
# 'do' and 'dump' response parsing is identical
|
# 'do' and 'dump' response parsing is identical
|
||||||
self.type_consistent = True
|
self.type_consistent = True
|
||||||
if op_mode != 'do' and 'dump' in op and 'do' in op:
|
if op_mode != 'do' and 'dump' in op:
|
||||||
if ('reply' in op['do']) != ('reply' in op["dump"]):
|
if 'do' in op:
|
||||||
self.type_consistent = False
|
if ('reply' in op['do']) != ('reply' in op["dump"]):
|
||||||
elif 'reply' in op['do'] and op["do"]["reply"] != op["dump"]["reply"]:
|
self.type_consistent = False
|
||||||
|
elif 'reply' in op['do'] and op["do"]["reply"] != op["dump"]["reply"]:
|
||||||
|
self.type_consistent = False
|
||||||
|
else:
|
||||||
self.type_consistent = False
|
self.type_consistent = False
|
||||||
|
|
||||||
self.attr_set = attr_set
|
self.attr_set = attr_set
|
||||||
@ -2414,6 +2444,16 @@ def render_user_family(family, cw, prototype):
|
|||||||
cw.block_end(line=';')
|
cw.block_end(line=';')
|
||||||
|
|
||||||
|
|
||||||
|
def family_contains_bitfield32(family):
|
||||||
|
for _, attr_set in family.attr_sets.items():
|
||||||
|
if attr_set.subset_of:
|
||||||
|
continue
|
||||||
|
for _, attr in attr_set.items():
|
||||||
|
if attr.type == "bitfield32":
|
||||||
|
return True
|
||||||
|
return False
|
||||||
|
|
||||||
|
|
||||||
def find_kernel_root(full_path):
|
def find_kernel_root(full_path):
|
||||||
sub_path = ''
|
sub_path = ''
|
||||||
while True:
|
while True:
|
||||||
@ -2499,6 +2539,8 @@ def main():
|
|||||||
cw.p('#include <string.h>')
|
cw.p('#include <string.h>')
|
||||||
if args.header:
|
if args.header:
|
||||||
cw.p('#include <linux/types.h>')
|
cw.p('#include <linux/types.h>')
|
||||||
|
if family_contains_bitfield32(parsed):
|
||||||
|
cw.p('#include <linux/netlink.h>')
|
||||||
else:
|
else:
|
||||||
cw.p(f'#include "{parsed.name}-user.h"')
|
cw.p(f'#include "{parsed.name}-user.h"')
|
||||||
cw.p('#include "ynl.h"')
|
cw.p('#include "ynl.h"')
|
||||||
|
Loading…
Reference in New Issue
Block a user