CVE-2025-21921 Information

Description

In the Linux kernel the following vulnerability has been resolved:

net: ethtool: netlink: Allow NULL nlattrs when getting a phy_device

ethnl_req_get_phydev() is used to lookup a phy_device in the case an ethtool netlink command targets a specific phydev within a netdev’s topology.

It takes as a parameter a const struct nlattr header that’s used for error handling :

   if (!phydev) 
           NL_SET_ERR_MSG_ATTR(extack header

o phy matching phyindex); return ERR_PTR(-ENODEV);

In the notify path after a ->set operation however there’s no request attributes available.

The typical callsite for the above function looks like:

phydev = ethnl_req_get_phydev(req_base tb[ETHTOOL_A_XXX_HEADER]
			      info->extack);

So when tb is NULL (such as in the ethnl notify path) we have a nice crash.

It turns out that there’s only the PLCA command that is in that case as the other phydev-specific commands don’t have a notification.

This commit fixes the crash by passing the cmd index and the nlattr array separately allowing NULL-checking it directly inside the helper.

Reference

https://git.kernel.org/stable/c/1f458fa42c29144cef280e05bc49fc21b873d897 https://git.kernel.org/stable/c/637399bf7e77797811adf340090b561a8f9d1213 https://git.kernel.org/stable/c/639c70352958735addbba5ae7dd65985da96e061

Share on: