CVE-2026-31582

Updated on 24 Apr 2026

Severity

7.8 High severity

Details

CVSS score
7.8
CVSS vector
CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:U/C:H/I:H/A:H

Overview

About vulnerability

In the Linux kernel, the following vulnerability has been resolved:

hwmon: (powerz) Fix use-after-free on USB disconnect

After powerz_disconnect() frees the URB and releases the mutex, a subsequent powerz_read() call can acquire the mutex and call powerz_read_data(), which dereferences the freed URB pointer.

Fix by:

  • Setting priv->urb to NULL in powerz_disconnect() so that powerz_read_data() can detect the disconnected state.
  • Adding a !priv->urb check at the start of powerz_read_data() to return -ENODEV on a disconnected device.
  • Moving usb_set_intfdata() before hwmon registration so the disconnect handler can always find the priv pointer.

Details

Affected packages:
linux-hwe @ 4.15.0 (+15 more)

In the Linux kernel, the following vulnerability has been resolved:

hwmon: (powerz) Fix use-after-free on USB disconnect

After powerz_disconnect() frees the URB and releases the mutex, a subsequent powerz_read() call can acquire the mutex and call powerz_read_data(), which dereferences the freed URB pointer.

Fix by:

  • Setting priv->urb to NULL in powerz_disconnect() so that powerz_read_data() can detect the disconnected state.
  • Adding a !priv->urb check at the start of powerz_read_data() to return -ENODEV on a disconnected device.
  • Moving usb_set_intfdata() before hwmon registration so the disconnect handler can always find the priv pointer.

Fixes