CVE-2026-52955 PUBLISHED

libceph: Fix potential out-of-bounds access in crush_decode()

Assigner: Linux
Reserved: 09.06.2026 Published: 24.06.2026 Updated: 28.06.2026

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

libceph: Fix potential out-of-bounds access in crush_decode()

A message of type CEPH_MSG_OSD_MAP containing a crush map with at least one bucket has two fields holding the bucket algorithm. If the values in these two fields differ, an out-of-bounds access can occur. This is the case because the first algorithm field (alg) is used to allocate the correct amount of memory for a bucket of this type, while the second algorithm field inside the bucket (b->alg) is used in the subsequent processing.

This patch fixes the issue by adding a check that compares alg and b->alg and aborts the processing in case they differ. Furthermore, b->alg is set to 0 in this case, because the destruction of the crush map also uses this field to determine the bucket type, which can again result in an out-of-bounds access when trying to free the memory pointed to by the fields of the bucket. To correctly free the memory allocated for the bucket in such a case, the corresponding call to kfree is moved from the algorithm-specific crush_destroy_bucket functions to the generic crush_destroy_bucket().

Metrics

CVSS Vector: CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H
CVSS Score: 9.8

Product Status

Vendor Linux
Product Linux
Versions Default: unaffected
  • affected from 1da177e4c3f41524e886b7f1b8a0c1fc7321cac2 to 6e70ef53e818c53eab28d7b0026b7fd03dddaba5 (excl.)
  • affected from 1da177e4c3f41524e886b7f1b8a0c1fc7321cac2 to ebe76d58a48a48031b98543d86c4cd30a825b622 (excl.)
  • affected from 1da177e4c3f41524e886b7f1b8a0c1fc7321cac2 to 3f42508191e129ee6b5ea96578d5cab14f2a013a (excl.)
  • affected from 1da177e4c3f41524e886b7f1b8a0c1fc7321cac2 to ea0d42137f0c06da71e37ffc647aab4c5309599a (excl.)
  • affected from 1da177e4c3f41524e886b7f1b8a0c1fc7321cac2 to cceb10023e76bc89f3fe9238ebd0ccab0fc7c7c5 (excl.)
  • affected from 1da177e4c3f41524e886b7f1b8a0c1fc7321cac2 to 0f3604cbe4df14c5e58288ac9f57511e726a222d (excl.)
  • affected from 1da177e4c3f41524e886b7f1b8a0c1fc7321cac2 to fb176a99e4c1a5a8448a83d83d3606203ba81faa (excl.)
  • affected from 1da177e4c3f41524e886b7f1b8a0c1fc7321cac2 to 4c79fc2d598694bda845b46229c9d48b65042970 (excl.)
  • affected from 0 to 5.10.258 (excl.)
  • affected from 0 to 5.15.209 (excl.)
  • affected from 0 to 6.1.175 (excl.)
  • affected from 0 to 6.6.141 (excl.)
  • affected from 0 to 6.12.91 (excl.)
  • affected from 0 to 6.18.33 (excl.)
  • affected from 0 to 7.0.10 (excl.)
Vendor Linux
Product Linux
Versions Default: affected
  • unaffected from 5.10.258 to 5.10.* (incl.)
  • unaffected from 5.15.209 to 5.15.* (incl.)
  • unaffected from 6.1.175 to 6.1.* (incl.)
  • unaffected from 6.6.141 to 6.6.* (incl.)
  • unaffected from 6.12.91 to 6.12.* (incl.)
  • unaffected from 6.18.33 to 6.18.* (incl.)
  • unaffected from 7.0.10 to 7.0.* (incl.)
  • unaffected from 7.1 to * (incl.)

References