devlink: send notifications only if there are listeners
authorJiri Pirko <jiri@nvidia.com>
Sat, 16 Dec 2023 12:29:55 +0000 (13:29 +0100)
committerPaolo Abeni <pabeni@redhat.com>
Tue, 19 Dec 2023 14:31:40 +0000 (15:31 +0100)
Introduce devlink_nl_notify_need() helper and using it to check at the
beginning of notification functions to avoid overhead of composing
notification messages in case nobody listens.

Signed-off-by: Jiri Pirko <jiri@nvidia.com>
Signed-off-by: Paolo Abeni <pabeni@redhat.com>
net/devlink/dev.c
net/devlink/devl_internal.h
net/devlink/health.c
net/devlink/linecard.c
net/devlink/param.c
net/devlink/port.c
net/devlink/rate.c
net/devlink/region.c
net/devlink/trap.c

index 3fe93c8a9fe2aedb19fdcd23316ed7e20e650aee..63fe3e02c928ca369a28529d5dfb6753c5626527 100644 (file)
@@ -204,6 +204,9 @@ static void devlink_notify(struct devlink *devlink, enum devlink_command cmd)
        WARN_ON(cmd != DEVLINK_CMD_NEW && cmd != DEVLINK_CMD_DEL);
        WARN_ON(!devl_is_registered(devlink));
 
+       if (!devlink_nl_notify_need(devlink))
+               return;
+
        msg = nlmsg_new(NLMSG_DEFAULT_SIZE, GFP_KERNEL);
        if (!msg)
                return;
@@ -999,7 +1002,7 @@ static void __devlink_flash_update_notify(struct devlink *devlink,
                cmd != DEVLINK_CMD_FLASH_UPDATE_END &&
                cmd != DEVLINK_CMD_FLASH_UPDATE_STATUS);
 
-       if (!devl_is_registered(devlink))
+       if (!devl_is_registered(devlink) || !devlink_nl_notify_need(devlink))
                return;
 
        msg = nlmsg_new(NLMSG_DEFAULT_SIZE, GFP_KERNEL);
index 59ae4761d10a7a82da5c637a70c12861e4c1c926..510990de094e998abdfe3b755c6699e584570507 100644 (file)
@@ -185,6 +185,12 @@ int devlink_nl_put_nested_handle(struct sk_buff *msg, struct net *net,
                                 struct devlink *devlink, int attrtype);
 int devlink_nl_msg_reply_and_new(struct sk_buff **msg, struct genl_info *info);
 
+static inline bool devlink_nl_notify_need(struct devlink *devlink)
+{
+       return genl_has_listeners(&devlink_nl_family, devlink_net(devlink),
+                                 DEVLINK_MCGRP_CONFIG);
+}
+
 /* Notify */
 void devlink_notify_register(struct devlink *devlink);
 void devlink_notify_unregister(struct devlink *devlink);
index 71ae121dc739dd878381a4b7a4035556aa4ff86a..0795dcf22ca83483aaa97017a8aabda0b7a21037 100644 (file)
@@ -496,6 +496,9 @@ static void devlink_recover_notify(struct devlink_health_reporter *reporter,
        WARN_ON(cmd != DEVLINK_CMD_HEALTH_REPORTER_RECOVER);
        ASSERT_DEVLINK_REGISTERED(devlink);
 
+       if (!devlink_nl_notify_need(devlink))
+               return;
+
        msg = nlmsg_new(NLMSG_DEFAULT_SIZE, GFP_KERNEL);
        if (!msg)
                return;
index 9d080ac1734bc2f449c648ca7e2b77ac6216f132..45b36975ee6f82452c38a6e73efb5208a7298508 100644 (file)
@@ -136,7 +136,7 @@ static void devlink_linecard_notify(struct devlink_linecard *linecard,
        WARN_ON(cmd != DEVLINK_CMD_LINECARD_NEW &&
                cmd != DEVLINK_CMD_LINECARD_DEL);
 
-       if (!__devl_is_registered(devlink))
+       if (!__devl_is_registered(devlink) || !devlink_nl_notify_need(devlink))
                return;
 
        msg = nlmsg_new(NLMSG_DEFAULT_SIZE, GFP_KERNEL);
index d74df09311a9a1f09aed7fea9e6bde23d3abb4d4..7516b524ffb760ca5eb6158977576b88d82f3d9e 100644 (file)
@@ -343,7 +343,7 @@ static void devlink_param_notify(struct devlink *devlink,
         * will replay the notifications if the params are added/removed
         * outside of the lifetime of the instance.
         */
-       if (!devl_is_registered(devlink))
+       if (!devl_is_registered(devlink) || !devlink_nl_notify_need(devlink))
                return;
 
        msg = nlmsg_new(NLMSG_DEFAULT_SIZE, GFP_KERNEL);
index f229a86992149f8170d401537e1a67c081ca5c49..32f4d0331e63d0439b11655e785936004d9848ca 100644 (file)
@@ -512,7 +512,7 @@ static void devlink_port_notify(struct devlink_port *devlink_port,
 
        WARN_ON(cmd != DEVLINK_CMD_PORT_NEW && cmd != DEVLINK_CMD_PORT_DEL);
 
-       if (!__devl_is_registered(devlink))
+       if (!__devl_is_registered(devlink) || !devlink_nl_notify_need(devlink))
                return;
 
        msg = nlmsg_new(NLMSG_DEFAULT_SIZE, GFP_KERNEL);
index e2190cf22bebccc597616bd015a8f51cadc50111..0371a2dd3e0a634d22503d7c2a7cb690d7eefb41 100644 (file)
@@ -146,7 +146,7 @@ static void devlink_rate_notify(struct devlink_rate *devlink_rate,
 
        WARN_ON(cmd != DEVLINK_CMD_RATE_NEW && cmd != DEVLINK_CMD_RATE_DEL);
 
-       if (!devl_is_registered(devlink))
+       if (!devl_is_registered(devlink) || !devlink_nl_notify_need(devlink))
                return;
 
        msg = nlmsg_new(NLMSG_DEFAULT_SIZE, GFP_KERNEL);
index b65181aa269aef01df55602d26de6d1f5e11f966..bf61312f64bdcf494901f222e80bf22afa008040 100644 (file)
@@ -235,7 +235,7 @@ static void devlink_nl_region_notify(struct devlink_region *region,
 
        WARN_ON(cmd != DEVLINK_CMD_REGION_NEW && cmd != DEVLINK_CMD_REGION_DEL);
 
-       if (!__devl_is_registered(devlink))
+       if (!__devl_is_registered(devlink) || !devlink_nl_notify_need(devlink))
                return;
 
        msg = devlink_nl_region_notify_build(region, snapshot, cmd, 0, 0);
index 908085e2c990b2eb62d85cc34b9d8cb56febc9cc..3ca1ca7e2e64ea773e57d1f31dbe0b58b16da78d 100644 (file)
@@ -1174,7 +1174,7 @@ devlink_trap_group_notify(struct devlink *devlink,
        WARN_ON_ONCE(cmd != DEVLINK_CMD_TRAP_GROUP_NEW &&
                     cmd != DEVLINK_CMD_TRAP_GROUP_DEL);
 
-       if (!devl_is_registered(devlink))
+       if (!devl_is_registered(devlink) || !devlink_nl_notify_need(devlink))
                return;
 
        msg = nlmsg_new(NLMSG_DEFAULT_SIZE, GFP_KERNEL);
@@ -1236,7 +1236,7 @@ static void devlink_trap_notify(struct devlink *devlink,
        WARN_ON_ONCE(cmd != DEVLINK_CMD_TRAP_NEW &&
                     cmd != DEVLINK_CMD_TRAP_DEL);
 
-       if (!devl_is_registered(devlink))
+       if (!devl_is_registered(devlink) || !devlink_nl_notify_need(devlink))
                return;
 
        msg = nlmsg_new(NLMSG_DEFAULT_SIZE, GFP_KERNEL);
@@ -1713,7 +1713,7 @@ devlink_trap_policer_notify(struct devlink *devlink,
        WARN_ON_ONCE(cmd != DEVLINK_CMD_TRAP_POLICER_NEW &&
                     cmd != DEVLINK_CMD_TRAP_POLICER_DEL);
 
-       if (!devl_is_registered(devlink))
+       if (!devl_is_registered(devlink) || !devlink_nl_notify_need(devlink))
                return;
 
        msg = nlmsg_new(NLMSG_DEFAULT_SIZE, GFP_KERNEL);