CVE-2026-31458 PUBLISHED

mm/damon/sysfs: check contexts->nr before accessing contexts_arr[0]

Assigner: Linux
Reserved: 09.03.2026 Published: 22.04.2026 Updated: 22.04.2026

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

mm/damon/sysfs: check contexts->nr before accessing contexts_arr[0]

Multiple sysfs command paths dereference contexts_arr[0] without first verifying that kdamond->contexts->nr == 1. A user can set nr_contexts to 0 via sysfs while DAMON is running, causing NULL pointer dereferences.

In more detail, the issue can be triggered by privileged users like below.

First, start DAMON and make contexts directory empty (kdamond->contexts->nr == 0).

<pre># damo start # cd /sys/kernel/mm/damon/admin/kdamonds/0 # echo 0 > contexts/nr_contexts </pre>

Then, each of below commands will cause the NULL pointer dereference.

<pre># echo update_schemes_stats > state # echo update_schemes_tried_regions > state # echo update_schemes_tried_bytes > state # echo update_schemes_effective_quotas > state # echo update_tuned_intervals > state </pre>

Guard all commands (except OFF) at the entry point of damon_sysfs_handle_cmd().

Product Status

Vendor Linux
Product Linux
Versions Default: unaffected
  • affected from 0ac32b8affb5a384253dbb8339bd2d0e91add0b7 to aba546061341b56e9ffb37e1eb661a3628b6ec12 (excl.)
  • affected from 0ac32b8affb5a384253dbb8339bd2d0e91add0b7 to 1e8da792672481d603fa7cd0d815577220a3ee27 (excl.)
  • affected from 0ac32b8affb5a384253dbb8339bd2d0e91add0b7 to 708033c231bd782858f4ddbb46ee874a5a5fbdab (excl.)
  • affected from 0ac32b8affb5a384253dbb8339bd2d0e91add0b7 to bbe03ad3fb9e714191757ca7b41582f930be7be2 (excl.)
  • affected from 0ac32b8affb5a384253dbb8339bd2d0e91add0b7 to 1bfe9fb5ed2667fb075682408b776b5273162615 (excl.)
Vendor Linux
Product Linux
Versions Default: affected
  • Version 5.18 is affected
  • unaffected from 0 to 5.18 (excl.)
  • unaffected from 6.6.131 to 6.6.* (incl.)
  • unaffected from 6.12.80 to 6.12.* (incl.)
  • unaffected from 6.18.21 to 6.18.* (incl.)
  • unaffected from 6.19.11 to 6.19.* (incl.)
  • unaffected from 7.0 to * (incl.)

References