CVE-2026-22995 PUBLISHED

ublk: fix use-after-free in ublk_partition_scan_work

Assigner: Linux
Reserved: 13.01.2026 Published: 23.01.2026 Updated: 23.01.2026

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

ublk: fix use-after-free in ublk_partition_scan_work

A race condition exists between the async partition scan work and device teardown that can lead to a use-after-free of ub->ub_disk:

  1. ublk_ctrl_start_dev() schedules partition_scan_work after add_disk()
  2. ublk_stop_dev() calls ublk_stop_dev_unlocked() which does:
  3. del_gendisk(ub->ub_disk)
  4. ublk_detach_disk() sets ub->ub_disk = NULL
  5. put_disk() which may free the disk
  6. The worker ublk_partition_scan_work() then dereferences ub->ub_disk leading to UAF

Fix this by using ublk_get_disk()/ublk_put_disk() in the worker to hold a reference to the disk during the partition scan. The spinlock in ublk_get_disk() synchronizes with ublk_detach_disk() ensuring the worker either gets a valid reference or sees NULL and exits early.

Also change flush_work() to cancel_work_sync() to avoid running the partition scan work unnecessarily when the disk is already detached.

Product Status

Vendor Linux
Product Linux
Versions Default: unaffected
  • affected from 63dfbcd59b4b823eac4441efff10b1c303c8f49f to 72e28774e9644c2bdbb4920842fbf77103a15a85 (excl.)
  • affected from 7fc4da6a304bdcd3de14fc946dc2c19437a9cc5a to f0d385f6689f37a2828c686fb279121df006b4cb (excl.)
Vendor Linux
Product Linux
Versions Default: affected
  • Version 6.19-rc4 is affected
  • unaffected from 0 to 6.19-rc4 (excl.)
  • unaffected from 6.18.6 to 6.18.* (incl.)
  • unaffected from 6.19-rc5 to * (incl.)

References