Lines Matching refs:trap_item
7532 struct devlink_trap_item *trap_item; in devlink_trap_item_lookup() local
7534 list_for_each_entry(trap_item, &devlink->trap_list, list) { in devlink_trap_item_lookup()
7535 if (!strcmp(trap_item->trap->name, name)) in devlink_trap_item_lookup()
7536 return trap_item; in devlink_trap_item_lookup()
7654 const struct devlink_trap_item *trap_item) in devlink_trap_stats_put() argument
7663 trap_item->trap, in devlink_trap_stats_put()
7669 devlink_trap_stats_read(trap_item->stats, &stats); in devlink_trap_stats_put()
7698 const struct devlink_trap_item *trap_item, in devlink_nl_trap_fill() argument
7702 struct devlink_trap_group_item *group_item = trap_item->group_item; in devlink_nl_trap_fill()
7717 if (nla_put_string(msg, DEVLINK_ATTR_TRAP_NAME, trap_item->trap->name)) in devlink_nl_trap_fill()
7720 if (nla_put_u8(msg, DEVLINK_ATTR_TRAP_TYPE, trap_item->trap->type)) in devlink_nl_trap_fill()
7723 if (trap_item->trap->generic && in devlink_nl_trap_fill()
7727 if (nla_put_u8(msg, DEVLINK_ATTR_TRAP_ACTION, trap_item->action)) in devlink_nl_trap_fill()
7730 err = devlink_trap_metadata_put(msg, trap_item->trap); in devlink_nl_trap_fill()
7734 err = devlink_trap_stats_put(msg, devlink, trap_item); in devlink_nl_trap_fill()
7752 struct devlink_trap_item *trap_item; in devlink_nl_cmd_trap_get_doit() local
7759 trap_item = devlink_trap_item_get_from_info(devlink, info); in devlink_nl_cmd_trap_get_doit()
7760 if (!trap_item) { in devlink_nl_cmd_trap_get_doit()
7769 err = devlink_nl_trap_fill(msg, devlink, trap_item, in devlink_nl_cmd_trap_get_doit()
7785 struct devlink_trap_item *trap_item; in devlink_nl_cmd_trap_get_dumpit() local
7801 list_for_each_entry(trap_item, &devlink->trap_list, list) { in devlink_nl_cmd_trap_get_dumpit()
7806 err = devlink_nl_trap_fill(msg, devlink, trap_item, in devlink_nl_cmd_trap_get_dumpit()
7830 struct devlink_trap_item *trap_item, in __devlink_trap_action_set() argument
7836 if (trap_item->action != trap_action && in __devlink_trap_action_set()
7837 trap_item->trap->type != DEVLINK_TRAP_TYPE_DROP) { in __devlink_trap_action_set()
7842 err = devlink->ops->trap_action_set(devlink, trap_item->trap, in __devlink_trap_action_set()
7847 trap_item->action = trap_action; in __devlink_trap_action_set()
7853 struct devlink_trap_item *trap_item, in devlink_trap_action_set() argument
7868 return __devlink_trap_action_set(devlink, trap_item, trap_action, in devlink_trap_action_set()
7877 struct devlink_trap_item *trap_item; in devlink_nl_cmd_trap_set_doit() local
7882 trap_item = devlink_trap_item_get_from_info(devlink, info); in devlink_nl_cmd_trap_set_doit()
7883 if (!trap_item) { in devlink_nl_cmd_trap_set_doit()
7888 return devlink_trap_action_set(devlink, trap_item, info); in devlink_nl_cmd_trap_set_doit()
8064 struct devlink_trap_item *trap_item; in __devlink_trap_group_action_set() local
8073 list_for_each_entry(trap_item, &devlink->trap_list, list) { in __devlink_trap_group_action_set()
8074 if (strcmp(trap_item->group_item->group->name, group_name)) in __devlink_trap_group_action_set()
8076 if (trap_item->action != trap_action && in __devlink_trap_group_action_set()
8077 trap_item->trap->type != DEVLINK_TRAP_TYPE_DROP) in __devlink_trap_group_action_set()
8079 trap_item->action = trap_action; in __devlink_trap_group_action_set()
8085 list_for_each_entry(trap_item, &devlink->trap_list, list) { in __devlink_trap_group_action_set()
8086 if (strcmp(trap_item->group_item->group->name, group_name)) in __devlink_trap_group_action_set()
8088 err = __devlink_trap_action_set(devlink, trap_item, in __devlink_trap_group_action_set()
10860 struct devlink_trap_item *trap_item) in devlink_trap_item_group_link() argument
10862 u16 group_id = trap_item->trap->init_group_id; in devlink_trap_item_group_link()
10869 trap_item->group_item = group_item; in devlink_trap_item_group_link()
10875 const struct devlink_trap_item *trap_item, in devlink_trap_notify() argument
10888 err = devlink_nl_trap_fill(msg, devlink, trap_item, cmd, 0, 0, 0); in devlink_trap_notify()
10902 struct devlink_trap_item *trap_item; in devlink_trap_register() local
10908 trap_item = kzalloc(sizeof(*trap_item), GFP_KERNEL); in devlink_trap_register()
10909 if (!trap_item) in devlink_trap_register()
10912 trap_item->stats = netdev_alloc_pcpu_stats(struct devlink_stats); in devlink_trap_register()
10913 if (!trap_item->stats) { in devlink_trap_register()
10918 trap_item->trap = trap; in devlink_trap_register()
10919 trap_item->action = trap->init_action; in devlink_trap_register()
10920 trap_item->priv = priv; in devlink_trap_register()
10922 err = devlink_trap_item_group_link(devlink, trap_item); in devlink_trap_register()
10926 err = devlink->ops->trap_init(devlink, trap, trap_item); in devlink_trap_register()
10930 list_add_tail(&trap_item->list, &devlink->trap_list); in devlink_trap_register()
10931 devlink_trap_notify(devlink, trap_item, DEVLINK_CMD_TRAP_NEW); in devlink_trap_register()
10937 free_percpu(trap_item->stats); in devlink_trap_register()
10939 kfree(trap_item); in devlink_trap_register()
10946 struct devlink_trap_item *trap_item; in devlink_trap_unregister() local
10948 trap_item = devlink_trap_item_lookup(devlink, trap->name); in devlink_trap_unregister()
10949 if (WARN_ON_ONCE(!trap_item)) in devlink_trap_unregister()
10952 devlink_trap_notify(devlink, trap_item, DEVLINK_CMD_TRAP_DEL); in devlink_trap_unregister()
10953 list_del(&trap_item->list); in devlink_trap_unregister()
10955 devlink->ops->trap_fini(devlink, trap, trap_item); in devlink_trap_unregister()
10956 free_percpu(trap_item->stats); in devlink_trap_unregister()
10957 kfree(trap_item); in devlink_trap_unregister()
10963 struct devlink_trap_item *trap_item; in devlink_trap_disable() local
10965 trap_item = devlink_trap_item_lookup(devlink, trap->name); in devlink_trap_disable()
10966 if (WARN_ON_ONCE(!trap_item)) in devlink_trap_disable()
10971 trap_item->action = DEVLINK_TRAP_ACTION_DROP; in devlink_trap_disable()
11057 const struct devlink_trap_item *trap_item, in devlink_trap_report_metadata_set() argument
11061 metadata->trap_name = trap_item->trap->name; in devlink_trap_report_metadata_set()
11062 metadata->trap_group_name = trap_item->group_item->group->name; in devlink_trap_report_metadata_set()
11064 metadata->trap_type = trap_item->trap->type; in devlink_trap_report_metadata_set()
11085 struct devlink_trap_item *trap_item = trap_ctx; in devlink_trap_report() local
11087 devlink_trap_stats_update(trap_item->stats, skb->len); in devlink_trap_report()
11088 devlink_trap_stats_update(trap_item->group_item->stats, skb->len); in devlink_trap_report()
11093 devlink_trap_report_metadata_set(&metadata, trap_item, in devlink_trap_report()
11108 struct devlink_trap_item *trap_item = trap_ctx; in devlink_trap_ctx_priv() local
11110 return trap_item->priv; in devlink_trap_ctx_priv()