CVE-2026-46088 PUBLISHED

ALSA: control: Validate buf_len before strnlen() in snd_ctl_elem_init_enum_names()

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

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

ALSA: control: Validate buf_len before strnlen() in snd_ctl_elem_init_enum_names()

snd_ctl_elem_init_enum_names() advances pointer p through the names buffer while decrementing buf_len. If buf_len reaches zero but items remain, the next iteration calls strnlen(p, 0).

While strnlen(p, 0) returns 0 and would hit the existing name_len == 0 error path, CONFIG_FORTIFY_SOURCE's fortified strnlen() first checks maxlen against __builtin_dynamic_object_size(). When Clang loses track of p's object size inside the loop, this triggers a BRK exception panic before the return value is examined.

Add a buf_len == 0 guard at the loop entry to prevent calling fortified strnlen() on an exhausted buffer.

Found by kernel fuzz testing through Xiaomi Smartphone.

Product Status

Vendor Linux
Product Linux
Versions Default: unaffected
  • affected from 8d448162bda5ae3b5ecb26fe50c8fbbeae99faa4 to 1fbe46d2b72754d8bd580e13e59ccb5d3d0e8cb0 (excl.)
  • affected from 8d448162bda5ae3b5ecb26fe50c8fbbeae99faa4 to 8ba0214c3dd32b8ec652947e3f2bc5b8f6e6be9e (excl.)
  • affected from 8d448162bda5ae3b5ecb26fe50c8fbbeae99faa4 to 654c818a69c21d2bea4e8fd9eae7da865df9a5c8 (excl.)
  • affected from 8d448162bda5ae3b5ecb26fe50c8fbbeae99faa4 to 82012fd3e78a14360fbc2f1a7491589896704f97 (excl.)
  • affected from 8d448162bda5ae3b5ecb26fe50c8fbbeae99faa4 to e0da8a8cac74f4b9f577979d131f0d2b88a84487 (excl.)
Vendor Linux
Product Linux
Versions Default: affected
  • Version 3.2 is affected
  • unaffected from 0 to 3.2 (excl.)
  • unaffected from 6.6.140 to 6.6.* (incl.)
  • unaffected from 6.12.86 to 6.12.* (incl.)
  • unaffected from 6.18.27 to 6.18.* (incl.)
  • unaffected from 7.0.4 to 7.0.* (incl.)
  • unaffected from 7.1-rc1 to * (incl.)

References