Lines Matching refs:trap_item
88 struct devlink_trap_item *trap_item; in devlink_trap_item_lookup() local
90 list_for_each_entry(trap_item, &devlink->trap_list, list) { in devlink_trap_item_lookup()
91 if (!strcmp(trap_item->trap->name, name)) in devlink_trap_item_lookup()
92 return trap_item; in devlink_trap_item_lookup()
212 const struct devlink_trap_item *trap_item) in devlink_trap_stats_put() argument
221 trap_item->trap, in devlink_trap_stats_put()
227 devlink_trap_stats_read(trap_item->stats, &stats); in devlink_trap_stats_put()
258 const struct devlink_trap_item *trap_item, in devlink_nl_trap_fill() argument
262 struct devlink_trap_group_item *group_item = trap_item->group_item; in devlink_nl_trap_fill()
277 if (nla_put_string(msg, DEVLINK_ATTR_TRAP_NAME, trap_item->trap->name)) in devlink_nl_trap_fill()
280 if (nla_put_u8(msg, DEVLINK_ATTR_TRAP_TYPE, trap_item->trap->type)) in devlink_nl_trap_fill()
283 if (trap_item->trap->generic && in devlink_nl_trap_fill()
287 if (nla_put_u8(msg, DEVLINK_ATTR_TRAP_ACTION, trap_item->action)) in devlink_nl_trap_fill()
290 err = devlink_trap_metadata_put(msg, trap_item->trap); in devlink_nl_trap_fill()
294 err = devlink_trap_stats_put(msg, devlink, trap_item); in devlink_nl_trap_fill()
311 struct devlink_trap_item *trap_item; in devlink_nl_trap_get_doit() local
318 trap_item = devlink_trap_item_get_from_info(devlink, info); in devlink_nl_trap_get_doit()
319 if (!trap_item) { in devlink_nl_trap_get_doit()
328 err = devlink_nl_trap_fill(msg, devlink, trap_item, in devlink_nl_trap_get_doit()
346 struct devlink_trap_item *trap_item; in devlink_nl_trap_get_dump_one() local
350 list_for_each_entry(trap_item, &devlink->trap_list, list) { in devlink_nl_trap_get_dump_one()
355 err = devlink_nl_trap_fill(msg, devlink, trap_item, in devlink_nl_trap_get_dump_one()
375 struct devlink_trap_item *trap_item, in __devlink_trap_action_set() argument
381 if (trap_item->action != trap_action && in __devlink_trap_action_set()
382 trap_item->trap->type != DEVLINK_TRAP_TYPE_DROP) { in __devlink_trap_action_set()
387 err = devlink->ops->trap_action_set(devlink, trap_item->trap, in __devlink_trap_action_set()
392 trap_item->action = trap_action; in __devlink_trap_action_set()
398 struct devlink_trap_item *trap_item, in devlink_trap_action_set() argument
413 return __devlink_trap_action_set(devlink, trap_item, trap_action, in devlink_trap_action_set()
421 struct devlink_trap_item *trap_item; in devlink_nl_cmd_trap_set_doit() local
426 trap_item = devlink_trap_item_get_from_info(devlink, info); in devlink_nl_cmd_trap_set_doit()
427 if (!trap_item) { in devlink_nl_cmd_trap_set_doit()
432 return devlink_trap_action_set(devlink, trap_item, info); in devlink_nl_cmd_trap_set_doit()
592 struct devlink_trap_item *trap_item; in __devlink_trap_group_action_set() local
601 list_for_each_entry(trap_item, &devlink->trap_list, list) { in __devlink_trap_group_action_set()
602 if (strcmp(trap_item->group_item->group->name, group_name)) in __devlink_trap_group_action_set()
604 if (trap_item->action != trap_action && in __devlink_trap_group_action_set()
605 trap_item->trap->type != DEVLINK_TRAP_TYPE_DROP) in __devlink_trap_group_action_set()
607 trap_item->action = trap_action; in __devlink_trap_group_action_set()
613 list_for_each_entry(trap_item, &devlink->trap_list, list) { in __devlink_trap_group_action_set()
614 if (strcmp(trap_item->group_item->group->name, group_name)) in __devlink_trap_group_action_set()
616 err = __devlink_trap_action_set(devlink, trap_item, in __devlink_trap_group_action_set()
1215 struct devlink_trap_item *trap_item) in devlink_trap_item_group_link() argument
1217 u16 group_id = trap_item->trap->init_group_id; in devlink_trap_item_group_link()
1224 trap_item->group_item = group_item; in devlink_trap_item_group_link()
1230 const struct devlink_trap_item *trap_item, in devlink_trap_notify() argument
1245 err = devlink_nl_trap_fill(msg, devlink, trap_item, cmd, 0, 0, 0); in devlink_trap_notify()
1257 struct devlink_trap_item *trap_item; in devlink_traps_notify_register() local
1259 list_for_each_entry(trap_item, &devlink->trap_list, list) in devlink_traps_notify_register()
1260 devlink_trap_notify(devlink, trap_item, DEVLINK_CMD_TRAP_NEW); in devlink_traps_notify_register()
1265 struct devlink_trap_item *trap_item; in devlink_traps_notify_unregister() local
1267 list_for_each_entry_reverse(trap_item, &devlink->trap_list, list) in devlink_traps_notify_unregister()
1268 devlink_trap_notify(devlink, trap_item, DEVLINK_CMD_TRAP_DEL); in devlink_traps_notify_unregister()
1275 struct devlink_trap_item *trap_item; in devlink_trap_register() local
1281 trap_item = kzalloc(sizeof(*trap_item), GFP_KERNEL); in devlink_trap_register()
1282 if (!trap_item) in devlink_trap_register()
1285 trap_item->stats = netdev_alloc_pcpu_stats(struct devlink_stats); in devlink_trap_register()
1286 if (!trap_item->stats) { in devlink_trap_register()
1291 trap_item->trap = trap; in devlink_trap_register()
1292 trap_item->action = trap->init_action; in devlink_trap_register()
1293 trap_item->priv = priv; in devlink_trap_register()
1295 err = devlink_trap_item_group_link(devlink, trap_item); in devlink_trap_register()
1299 err = devlink->ops->trap_init(devlink, trap, trap_item); in devlink_trap_register()
1303 list_add_tail(&trap_item->list, &devlink->trap_list); in devlink_trap_register()
1304 devlink_trap_notify(devlink, trap_item, DEVLINK_CMD_TRAP_NEW); in devlink_trap_register()
1310 free_percpu(trap_item->stats); in devlink_trap_register()
1312 kfree(trap_item); in devlink_trap_register()
1319 struct devlink_trap_item *trap_item; in devlink_trap_unregister() local
1321 trap_item = devlink_trap_item_lookup(devlink, trap->name); in devlink_trap_unregister()
1322 if (WARN_ON_ONCE(!trap_item)) in devlink_trap_unregister()
1325 devlink_trap_notify(devlink, trap_item, DEVLINK_CMD_TRAP_DEL); in devlink_trap_unregister()
1326 list_del(&trap_item->list); in devlink_trap_unregister()
1328 devlink->ops->trap_fini(devlink, trap, trap_item); in devlink_trap_unregister()
1329 free_percpu(trap_item->stats); in devlink_trap_unregister()
1330 kfree(trap_item); in devlink_trap_unregister()
1336 struct devlink_trap_item *trap_item; in devlink_trap_disable() local
1338 trap_item = devlink_trap_item_lookup(devlink, trap->name); in devlink_trap_disable()
1339 if (WARN_ON_ONCE(!trap_item)) in devlink_trap_disable()
1344 trap_item->action = DEVLINK_TRAP_ACTION_DROP; in devlink_trap_disable()
1469 const struct devlink_trap_item *trap_item, in devlink_trap_report_metadata_set() argument
1473 metadata->trap_name = trap_item->trap->name; in devlink_trap_report_metadata_set()
1474 metadata->trap_group_name = trap_item->group_item->group->name; in devlink_trap_report_metadata_set()
1476 metadata->trap_type = trap_item->trap->type; in devlink_trap_report_metadata_set()
1497 struct devlink_trap_item *trap_item = trap_ctx; in devlink_trap_report() local
1499 devlink_trap_stats_update(trap_item->stats, skb->len); in devlink_trap_report()
1500 devlink_trap_stats_update(trap_item->group_item->stats, skb->len); in devlink_trap_report()
1505 devlink_trap_report_metadata_set(&metadata, trap_item, in devlink_trap_report()
1520 struct devlink_trap_item *trap_item = trap_ctx; in devlink_trap_ctx_priv() local
1522 return trap_item->priv; in devlink_trap_ctx_priv()