CVE-2026-45981 PUBLISHED

s390/cio: Fix device lifecycle handling in css_alloc_subchannel()

Assigner: Linux
Reserved: 13.05.2026 Published: 27.05.2026 Updated: 27.05.2026

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

s390/cio: Fix device lifecycle handling in css_alloc_subchannel()

css_alloc_subchannel() calls device_initialize() before setting up the DMA masks. If dma_set_coherent_mask() or dma_set_mask() fails, the error path frees the subchannel structure directly, bypassing the device model reference counting.

Once device_initialize() has been called, the embedded struct device must be released via put_device(), allowing the release callback to free the container structure.

Fix the error path by dropping the initial device reference with put_device() instead of calling kfree() directly.

This ensures correct device lifetime handling and avoids potential use-after-free or double-free issues.

Product Status

Vendor Linux
Product Linux
Versions Default: unaffected
  • affected from e5dcf0025d7af58f525590ac86ac27cb44714e8d to 2b2ad7ad4a28ffdb9f94e6d979b88a5b12b71681 (excl.)
  • affected from e5dcf0025d7af58f525590ac86ac27cb44714e8d to b1d4e6fb241672850296956c4d782a69363a3807 (excl.)
  • affected from e5dcf0025d7af58f525590ac86ac27cb44714e8d to fd295a75d828c11acfcc6869c2a12cdaaf9b7722 (excl.)
  • affected from e5dcf0025d7af58f525590ac86ac27cb44714e8d to abb6e07f46a740cda4f07d1b561ae4eaa7a1df42 (excl.)
  • affected from e5dcf0025d7af58f525590ac86ac27cb44714e8d to f96c5ccf95ae5f27218c1ce2d6a3ad2d3e105424 (excl.)
  • affected from e5dcf0025d7af58f525590ac86ac27cb44714e8d to 6715560527e343a387e4a0d2e6c401748e89fa55 (excl.)
  • affected from e5dcf0025d7af58f525590ac86ac27cb44714e8d to c35cfbb5341ba05ad1b4476ffc3c21cc3ff8f603 (excl.)
  • affected from e5dcf0025d7af58f525590ac86ac27cb44714e8d to f65c75b0b9b5a390bc3beadcde0a6fbc3ad118f7 (excl.)
Vendor Linux
Product Linux
Versions Default: affected
  • Version 3.10 is affected
  • unaffected from 0 to 3.10 (excl.)
  • unaffected from 5.10.252 to 5.10.* (incl.)
  • unaffected from 5.15.202 to 5.15.* (incl.)
  • unaffected from 6.1.165 to 6.1.* (incl.)
  • unaffected from 6.6.128 to 6.6.* (incl.)
  • unaffected from 6.12.75 to 6.12.* (incl.)
  • unaffected from 6.18.14 to 6.18.* (incl.)
  • unaffected from 6.19.4 to 6.19.* (incl.)
  • unaffected from 7.0 to * (incl.)

References