]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
netdev: let netlink core handle -EMSGSIZE errors
authorJakub Kicinski <kuba@kernel.org>
Sun, 3 Mar 2024 05:24:07 +0000 (21:24 -0800)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Sat, 13 Apr 2024 11:10:02 +0000 (13:10 +0200)
[ Upstream commit 0b11b1c5c320555483e8a94c44549db24c289987 ]

Previous change added -EMSGSIZE handling to af_netlink, we don't
have to hide these errors any longer.

Theoretically the error handling changes from:
 if (err == -EMSGSIZE)
to
 if (err == -EMSGSIZE && skb->len)

everywhere, but in practice it doesn't matter.
All messages fit into NLMSG_GOODSIZE, so overflow of an empty
skb cannot happen.

Reviewed-by: Eric Dumazet <edumazet@google.com>
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
Reviewed-by: Ido Schimmel <idosch@nvidia.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Signed-off-by: Sasha Levin <sashal@kernel.org>
net/core/netdev-genl.c
net/core/page_pool_user.c

index fd98936da3aec01d467d087fdde89156a32fcde7..918b109e0cf40c7722615843b6315a69a150c07a 100644 (file)
@@ -152,10 +152,7 @@ int netdev_nl_dev_get_dumpit(struct sk_buff *skb, struct netlink_callback *cb)
        }
        rtnl_unlock();
 
-       if (err != -EMSGSIZE)
-               return err;
-
-       return skb->len;
+       return err;
 }
 
 static int
@@ -287,10 +284,7 @@ int netdev_nl_napi_get_dumpit(struct sk_buff *skb, struct netlink_callback *cb)
        }
        rtnl_unlock();
 
-       if (err != -EMSGSIZE)
-               return err;
-
-       return skb->len;
+       return err;
 }
 
 static int
@@ -463,10 +457,7 @@ int netdev_nl_queue_get_dumpit(struct sk_buff *skb, struct netlink_callback *cb)
        }
        rtnl_unlock();
 
-       if (err != -EMSGSIZE)
-               return err;
-
-       return skb->len;
+       return err;
 }
 
 static int netdev_genl_netdevice_event(struct notifier_block *nb,
index 278294aca66ababdf5f7d383833ff5496255b274..3a3277ba167b18f5366fd0ba833cd6b393d73afe 100644 (file)
@@ -103,8 +103,6 @@ out:
        mutex_unlock(&page_pools_lock);
        rtnl_unlock();
 
-       if (skb->len && err == -EMSGSIZE)
-               return skb->len;
        return err;
 }