summaryrefslogtreecommitdiff
path: root/net
diff options
context:
space:
mode:
authorJakub Kicinski <kuba@kernel.org>2023-11-26 14:58:06 -0800
committerJakub Kicinski <kuba@kernel.org>2023-11-29 08:43:27 -0800
commitcbeb989e41f4094f54bec2cecce993f26f547bea (patch)
tree9b9f83c84586dd5d3d0ec913258b148eb8f0e17b /net
parent9870257a0a338cd8d6c1cddab74e703f490f6779 (diff)
downloadlwn-cbeb989e41f4094f54bec2cecce993f26f547bea.tar.gz
lwn-cbeb989e41f4094f54bec2cecce993f26f547bea.zip
ethtool: don't propagate EOPNOTSUPP from dumps
The default dump handler needs to clear ret before returning. Otherwise if the last interface returns an inconsequential error this error will propagate to user space. This may confuse user space (ethtool CLI seems to ignore it, but YNL doesn't). It will also terminate the dump early for mutli-skb dump, because netlink core treats EOPNOTSUPP as a real error. Fixes: 728480f12442 ("ethtool: default handlers for GET requests") Reviewed-by: Simon Horman <horms@kernel.org> Link: https://lore.kernel.org/r/20231126225806.2143528-1-kuba@kernel.org Signed-off-by: Jakub Kicinski <kuba@kernel.org>
Diffstat (limited to 'net')
-rw-r--r--net/ethtool/netlink.c1
1 files changed, 1 insertions, 0 deletions
diff --git a/net/ethtool/netlink.c b/net/ethtool/netlink.c
index 3bbd5afb7b31..fe3553f60bf3 100644
--- a/net/ethtool/netlink.c
+++ b/net/ethtool/netlink.c
@@ -505,6 +505,7 @@ static int ethnl_default_dumpit(struct sk_buff *skb,
ret = skb->len;
break;
}
+ ret = 0;
}
rtnl_unlock();