CVE-2021-47556 Information
Description
In the Linux kernel the following vulnerability has been resolved:
ethtool: ioctl: fix potential NULL deref in ethtool_set_coalesce()
ethtool_set_coalesce() now uses both the .get_coalesce() and .set_coalesce() callbacks. But the check for their availability is buggy so changing the coalesce settings on a device where the driver provides only one of the callbacks results in a NULL pointer dereference instead of an -EOPNOTSUPP.
Fix the condition so that the availability of both callbacks is ensured. This also matches the netlink code.
Note that reproducing this requires some effort - it only affects the legacy ioctl path and needs a specific combination of driver options:
- have .get_coalesce() and .coalesce_supported but no .set_coalesce() or
- have .set_coalesce() but no .get_coalesce(). Here eg. ethtool doesn’t cause the crash as it first attempts to call ethtool_get_coalesce() and bails out on error.
Reference
https://git.kernel.org/stable/c/abfdd9e2f0f9699015d72317f74154d3e53664e6 https://git.kernel.org/stable/c/0276af2176c78771da7f311621a25d7608045827
Share on: