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()
210 const struct devlink_trap_item *trap_item) in devlink_trap_stats_put() argument
219 trap_item->trap, in devlink_trap_stats_put()
225 devlink_trap_stats_read(trap_item->stats, &stats); in devlink_trap_stats_put()
253 const struct devlink_trap_item *trap_item, in devlink_nl_trap_fill() argument
257 struct devlink_trap_group_item *group_item = trap_item->group_item; in devlink_nl_trap_fill()
272 if (nla_put_string(msg, DEVLINK_ATTR_TRAP_NAME, trap_item->trap->name)) in devlink_nl_trap_fill()
275 if (nla_put_u8(msg, DEVLINK_ATTR_TRAP_TYPE, trap_item->trap->type)) in devlink_nl_trap_fill()
278 if (trap_item->trap->generic && in devlink_nl_trap_fill()
282 if (nla_put_u8(msg, DEVLINK_ATTR_TRAP_ACTION, trap_item->action)) in devlink_nl_trap_fill()
285 err = devlink_trap_metadata_put(msg, trap_item->trap); in devlink_nl_trap_fill()
289 err = devlink_trap_stats_put(msg, devlink, trap_item); in devlink_nl_trap_fill()
306 struct devlink_trap_item *trap_item; in devlink_nl_trap_get_doit() local
313 trap_item = devlink_trap_item_get_from_info(devlink, info); in devlink_nl_trap_get_doit()
314 if (!trap_item) { in devlink_nl_trap_get_doit()
323 err = devlink_nl_trap_fill(msg, devlink, trap_item, in devlink_nl_trap_get_doit()
341 struct devlink_trap_item *trap_item; in devlink_nl_trap_get_dump_one() local
345 list_for_each_entry(trap_item, &devlink->trap_list, list) { in devlink_nl_trap_get_dump_one()
350 err = devlink_nl_trap_fill(msg, devlink, trap_item, in devlink_nl_trap_get_dump_one()
370 struct devlink_trap_item *trap_item, in __devlink_trap_action_set() argument
376 if (trap_item->action != trap_action && in __devlink_trap_action_set()
377 trap_item->trap->type != DEVLINK_TRAP_TYPE_DROP) { in __devlink_trap_action_set()
382 err = devlink->ops->trap_action_set(devlink, trap_item->trap, in __devlink_trap_action_set()
387 trap_item->action = trap_action; in __devlink_trap_action_set()
393 struct devlink_trap_item *trap_item, in devlink_trap_action_set() argument
408 return __devlink_trap_action_set(devlink, trap_item, trap_action, in devlink_trap_action_set()
416 struct devlink_trap_item *trap_item; in devlink_nl_trap_set_doit() local
421 trap_item = devlink_trap_item_get_from_info(devlink, info); in devlink_nl_trap_set_doit()
422 if (!trap_item) { in devlink_nl_trap_set_doit()
427 return devlink_trap_action_set(devlink, trap_item, info); in devlink_nl_trap_set_doit()
587 struct devlink_trap_item *trap_item; in __devlink_trap_group_action_set() local
596 list_for_each_entry(trap_item, &devlink->trap_list, list) { in __devlink_trap_group_action_set()
597 if (strcmp(trap_item->group_item->group->name, group_name)) in __devlink_trap_group_action_set()
599 if (trap_item->action != trap_action && in __devlink_trap_group_action_set()
600 trap_item->trap->type != DEVLINK_TRAP_TYPE_DROP) in __devlink_trap_group_action_set()
602 trap_item->action = trap_action; in __devlink_trap_group_action_set()
608 list_for_each_entry(trap_item, &devlink->trap_list, list) { in __devlink_trap_group_action_set()
609 if (strcmp(trap_item->group_item->group->name, group_name)) in __devlink_trap_group_action_set()
611 err = __devlink_trap_action_set(devlink, trap_item, in __devlink_trap_group_action_set()
1208 struct devlink_trap_item *trap_item) in devlink_trap_item_group_link() argument
1210 u16 group_id = trap_item->trap->init_group_id; in devlink_trap_item_group_link()
1217 trap_item->group_item = group_item; in devlink_trap_item_group_link()
1223 const struct devlink_trap_item *trap_item, in devlink_trap_notify() argument
1239 err = devlink_nl_trap_fill(msg, devlink, trap_item, cmd, 0, 0, 0); in devlink_trap_notify()
1250 struct devlink_trap_item *trap_item; in devlink_traps_notify_register() local
1252 list_for_each_entry(trap_item, &devlink->trap_list, list) in devlink_traps_notify_register()
1253 devlink_trap_notify(devlink, trap_item, DEVLINK_CMD_TRAP_NEW); in devlink_traps_notify_register()
1258 struct devlink_trap_item *trap_item; in devlink_traps_notify_unregister() local
1260 list_for_each_entry_reverse(trap_item, &devlink->trap_list, list) in devlink_traps_notify_unregister()
1261 devlink_trap_notify(devlink, trap_item, DEVLINK_CMD_TRAP_DEL); in devlink_traps_notify_unregister()
1268 struct devlink_trap_item *trap_item; in devlink_trap_register() local
1274 trap_item = kzalloc(sizeof(*trap_item), GFP_KERNEL); in devlink_trap_register()
1275 if (!trap_item) in devlink_trap_register()
1278 trap_item->stats = netdev_alloc_pcpu_stats(struct devlink_stats); in devlink_trap_register()
1279 if (!trap_item->stats) { in devlink_trap_register()
1284 trap_item->trap = trap; in devlink_trap_register()
1285 trap_item->action = trap->init_action; in devlink_trap_register()
1286 trap_item->priv = priv; in devlink_trap_register()
1288 err = devlink_trap_item_group_link(devlink, trap_item); in devlink_trap_register()
1292 err = devlink->ops->trap_init(devlink, trap, trap_item); in devlink_trap_register()
1296 list_add_tail(&trap_item->list, &devlink->trap_list); in devlink_trap_register()
1297 devlink_trap_notify(devlink, trap_item, DEVLINK_CMD_TRAP_NEW); in devlink_trap_register()
1303 free_percpu(trap_item->stats); in devlink_trap_register()
1305 kfree(trap_item); in devlink_trap_register()
1312 struct devlink_trap_item *trap_item; in devlink_trap_unregister() local
1314 trap_item = devlink_trap_item_lookup(devlink, trap->name); in devlink_trap_unregister()
1315 if (WARN_ON_ONCE(!trap_item)) in devlink_trap_unregister()
1318 devlink_trap_notify(devlink, trap_item, DEVLINK_CMD_TRAP_DEL); in devlink_trap_unregister()
1319 list_del(&trap_item->list); in devlink_trap_unregister()
1321 devlink->ops->trap_fini(devlink, trap, trap_item); in devlink_trap_unregister()
1322 free_percpu(trap_item->stats); in devlink_trap_unregister()
1323 kfree(trap_item); in devlink_trap_unregister()
1329 struct devlink_trap_item *trap_item; in devlink_trap_disable() local
1331 trap_item = devlink_trap_item_lookup(devlink, trap->name); in devlink_trap_disable()
1332 if (WARN_ON_ONCE(!trap_item)) in devlink_trap_disable()
1337 trap_item->action = DEVLINK_TRAP_ACTION_DROP; in devlink_trap_disable()
1462 const struct devlink_trap_item *trap_item, in devlink_trap_report_metadata_set() argument
1466 metadata->trap_name = trap_item->trap->name; in devlink_trap_report_metadata_set()
1467 metadata->trap_group_name = trap_item->group_item->group->name; in devlink_trap_report_metadata_set()
1469 metadata->trap_type = trap_item->trap->type; in devlink_trap_report_metadata_set()
1490 struct devlink_trap_item *trap_item = trap_ctx; in devlink_trap_report() local
1492 devlink_trap_stats_update(trap_item->stats, skb->len); in devlink_trap_report()
1493 devlink_trap_stats_update(trap_item->group_item->stats, skb->len); in devlink_trap_report()
1498 devlink_trap_report_metadata_set(&metadata, trap_item, in devlink_trap_report()
1513 struct devlink_trap_item *trap_item = trap_ctx; in devlink_trap_ctx_priv() local
1515 return trap_item->priv; in devlink_trap_ctx_priv()