int err;
 
        WARN_ON(cmd != DEVLINK_CMD_NEW && cmd != DEVLINK_CMD_DEL);
+       WARN_ON(!xa_get_mark(&devlinks, devlink->index, DEVLINK_REGISTERED));
 
        msg = nlmsg_new(NLMSG_DEFAULT_SIZE, GFP_KERNEL);
        if (!msg)
 static void devlink_port_notify(struct devlink_port *devlink_port,
                                enum devlink_command cmd)
 {
+       struct devlink *devlink = devlink_port->devlink;
        struct sk_buff *msg;
        int err;
 
        WARN_ON(cmd != DEVLINK_CMD_PORT_NEW && cmd != DEVLINK_CMD_PORT_DEL);
 
+       if (!xa_get_mark(&devlinks, devlink->index, DEVLINK_REGISTERED))
+               return;
+
        msg = nlmsg_new(NLMSG_DEFAULT_SIZE, GFP_KERNEL);
        if (!msg)
                return;
                return;
        }
 
-       genlmsg_multicast_netns(&devlink_nl_family,
-                               devlink_net(devlink_port->devlink), msg, 0,
-                               DEVLINK_MCGRP_CONFIG, GFP_KERNEL);
+       genlmsg_multicast_netns(&devlink_nl_family, devlink_net(devlink), msg,
+                               0, DEVLINK_MCGRP_CONFIG, GFP_KERNEL);
 }
 
 static void devlink_rate_notify(struct devlink_rate *devlink_rate,
                                enum devlink_command cmd)
 {
+       struct devlink *devlink = devlink_rate->devlink;
        struct sk_buff *msg;
        int err;
 
        WARN_ON(cmd != DEVLINK_CMD_RATE_NEW && cmd != DEVLINK_CMD_RATE_DEL);
+       WARN_ON(!xa_get_mark(&devlinks, devlink->index, DEVLINK_REGISTERED));
 
        msg = nlmsg_new(NLMSG_DEFAULT_SIZE, GFP_KERNEL);
        if (!msg)
                return;
        }
 
-       genlmsg_multicast_netns(&devlink_nl_family,
-                               devlink_net(devlink_rate->devlink), msg, 0,
-                               DEVLINK_MCGRP_CONFIG, GFP_KERNEL);
+       genlmsg_multicast_netns(&devlink_nl_family, devlink_net(devlink), msg,
+                               0, DEVLINK_MCGRP_CONFIG, GFP_KERNEL);
 }
 
 static int devlink_nl_cmd_rate_get_dumpit(struct sk_buff *msg,
        WARN_ON(cmd != DEVLINK_CMD_FLASH_UPDATE &&
                cmd != DEVLINK_CMD_FLASH_UPDATE_END &&
                cmd != DEVLINK_CMD_FLASH_UPDATE_STATUS);
+       WARN_ON(!xa_get_mark(&devlinks, devlink->index, DEVLINK_REGISTERED));
 
        msg = nlmsg_new(NLMSG_DEFAULT_SIZE, GFP_KERNEL);
        if (!msg)
                                     struct devlink_snapshot *snapshot,
                                     enum devlink_command cmd)
 {
+       struct devlink *devlink = region->devlink;
        struct sk_buff *msg;
 
        WARN_ON(cmd != DEVLINK_CMD_REGION_NEW && cmd != DEVLINK_CMD_REGION_DEL);
+       WARN_ON(!xa_get_mark(&devlinks, devlink->index, DEVLINK_REGISTERED));
 
        msg = devlink_nl_region_notify_build(region, snapshot, cmd, 0, 0);
        if (IS_ERR(msg))
                return;
 
-       genlmsg_multicast_netns(&devlink_nl_family,
-                               devlink_net(region->devlink), msg, 0,
-                               DEVLINK_MCGRP_CONFIG, GFP_KERNEL);
+       genlmsg_multicast_netns(&devlink_nl_family, devlink_net(devlink), msg,
+                               0, DEVLINK_MCGRP_CONFIG, GFP_KERNEL);
 }
 
 /**
 static void devlink_recover_notify(struct devlink_health_reporter *reporter,
                                   enum devlink_command cmd)
 {
+       struct devlink *devlink = reporter->devlink;
        struct sk_buff *msg;
        int err;
 
        WARN_ON(cmd != DEVLINK_CMD_HEALTH_REPORTER_RECOVER);
+       WARN_ON(!xa_get_mark(&devlinks, devlink->index, DEVLINK_REGISTERED));
 
        msg = nlmsg_new(NLMSG_DEFAULT_SIZE, GFP_KERNEL);
        if (!msg)
                return;
        }
 
-       genlmsg_multicast_netns(&devlink_nl_family,
-                               devlink_net(reporter->devlink),
-                               msg, 0, DEVLINK_MCGRP_CONFIG, GFP_KERNEL);
+       genlmsg_multicast_netns(&devlink_nl_family, devlink_net(devlink), msg,
+                               0, DEVLINK_MCGRP_CONFIG, GFP_KERNEL);
 }
 
 void
 }
 EXPORT_SYMBOL_GPL(devlink_alloc_ns);
 
+static void
+devlink_trap_policer_notify(struct devlink *devlink,
+                           const struct devlink_trap_policer_item *policer_item,
+                           enum devlink_command cmd);
+static void
+devlink_trap_group_notify(struct devlink *devlink,
+                         const struct devlink_trap_group_item *group_item,
+                         enum devlink_command cmd);
+static void devlink_trap_notify(struct devlink *devlink,
+                               const struct devlink_trap_item *trap_item,
+                               enum devlink_command cmd);
+
+static void devlink_notify_register(struct devlink *devlink)
+{
+       struct devlink_trap_policer_item *policer_item;
+       struct devlink_trap_group_item *group_item;
+       struct devlink_trap_item *trap_item;
+       struct devlink_port *devlink_port;
+
+       devlink_notify(devlink, DEVLINK_CMD_NEW);
+       list_for_each_entry(devlink_port, &devlink->port_list, list)
+               devlink_port_notify(devlink_port, DEVLINK_CMD_PORT_NEW);
+
+       list_for_each_entry(policer_item, &devlink->trap_policer_list, list)
+               devlink_trap_policer_notify(devlink, policer_item,
+                                           DEVLINK_CMD_TRAP_POLICER_NEW);
+
+       list_for_each_entry(group_item, &devlink->trap_group_list, list)
+               devlink_trap_group_notify(devlink, group_item,
+                                         DEVLINK_CMD_TRAP_GROUP_NEW);
+
+       list_for_each_entry(trap_item, &devlink->trap_list, list)
+               devlink_trap_notify(devlink, trap_item, DEVLINK_CMD_TRAP_NEW);
+
+       devlink_params_publish(devlink);
+}
+
+static void devlink_notify_unregister(struct devlink *devlink)
+{
+       struct devlink_trap_policer_item *policer_item;
+       struct devlink_trap_group_item *group_item;
+       struct devlink_trap_item *trap_item;
+       struct devlink_port *devlink_port;
+
+       devlink_params_unpublish(devlink);
+
+       list_for_each_entry_reverse(trap_item, &devlink->trap_list, list)
+               devlink_trap_notify(devlink, trap_item, DEVLINK_CMD_TRAP_DEL);
+
+       list_for_each_entry_reverse(group_item, &devlink->trap_group_list, list)
+               devlink_trap_group_notify(devlink, group_item,
+                                         DEVLINK_CMD_TRAP_GROUP_DEL);
+       list_for_each_entry_reverse(policer_item, &devlink->trap_policer_list,
+                                   list)
+               devlink_trap_policer_notify(devlink, policer_item,
+                                           DEVLINK_CMD_TRAP_POLICER_DEL);
+
+       list_for_each_entry_reverse(devlink_port, &devlink->port_list, list)
+               devlink_port_notify(devlink_port, DEVLINK_CMD_PORT_DEL);
+       devlink_notify(devlink, DEVLINK_CMD_DEL);
+}
+
 /**
  *     devlink_register - Register devlink instance
  *
 {
        mutex_lock(&devlink_mutex);
        xa_set_mark(&devlinks, devlink->index, DEVLINK_REGISTERED);
-       devlink_notify(devlink, DEVLINK_CMD_NEW);
+       devlink_notify_register(devlink);
        mutex_unlock(&devlink_mutex);
 }
 EXPORT_SYMBOL_GPL(devlink_register);
        mutex_lock(&devlink_mutex);
        WARN_ON(devlink_reload_supported(devlink->ops) &&
                devlink->reload_enabled);
-       devlink_notify(devlink, DEVLINK_CMD_DEL);
+       devlink_notify_unregister(devlink);
        xa_clear_mark(&devlinks, devlink->index, DEVLINK_REGISTERED);
        mutex_unlock(&devlink_mutex);
 }
 {
        struct devlink_param_item *param_item;
 
+       if (!xa_get_mark(&devlinks, devlink->index, DEVLINK_REGISTERED))
+               return;
+
        list_for_each_entry(param_item, &devlink->param_list, list) {
                if (param_item->published)
                        continue;
 
        WARN_ON_ONCE(cmd != DEVLINK_CMD_TRAP_GROUP_NEW &&
                     cmd != DEVLINK_CMD_TRAP_GROUP_DEL);
+       if (!xa_get_mark(&devlinks, devlink->index, DEVLINK_REGISTERED))
+               return;
 
        msg = nlmsg_new(NLMSG_DEFAULT_SIZE, GFP_KERNEL);
        if (!msg)
 
        WARN_ON_ONCE(cmd != DEVLINK_CMD_TRAP_NEW &&
                     cmd != DEVLINK_CMD_TRAP_DEL);
+       if (!xa_get_mark(&devlinks, devlink->index, DEVLINK_REGISTERED))
+               return;
 
        msg = nlmsg_new(NLMSG_DEFAULT_SIZE, GFP_KERNEL);
        if (!msg)
 
        WARN_ON_ONCE(cmd != DEVLINK_CMD_TRAP_POLICER_NEW &&
                     cmd != DEVLINK_CMD_TRAP_POLICER_DEL);
+       if (!xa_get_mark(&devlinks, devlink->index, DEVLINK_REGISTERED))
+               return;
 
        msg = nlmsg_new(NLMSG_DEFAULT_SIZE, GFP_KERNEL);
        if (!msg)