Skip to content

cgroup/rstat: validate cpu before css_rstat_cpu() access#839

Open
blktests-ci[bot] wants to merge 1 commit into
linus-master_basefrom
series/1095775=>linus-master
Open

cgroup/rstat: validate cpu before css_rstat_cpu() access#839
blktests-ci[bot] wants to merge 1 commit into
linus-master_basefrom
series/1095775=>linus-master

Conversation

@blktests-ci
Copy link
Copy Markdown

@blktests-ci blktests-ci Bot commented May 16, 2026

Pull request for series with
subject: cgroup/rstat: validate cpu before css_rstat_cpu() access
version: 2
url: https://patchwork.kernel.org/project/linux-block/list/?series=1095775

css_rstat_updated() is exposed as a BPF kfunc and accepts a
caller-provided cpu argument. The function uses cpu for per-cpu rstat
lookups without checking whether it refers to a valid possible CPU.

A BPF iter/cgroup program with CAP_BPF and CAP_PERFMON can pass an
invalid cpu value. On an unfixed UBSCAN_BOUNDS test kernel, cpu ==
0x7fffffff triggers:

  UBSAN: array-index-out-of-bounds in kernel/cgroup/rstat.c:31:9
  index 2147483647 is out of range for type 'long unsigned int [64]'
  Call Trace:
    css_rstat_updated
    bpf_iter_run_prog
    cgroup_iter_seq_show
    bpf_seq_read

Add cpu validation to the BPF-facing css_rstat_updated() kfunc and
move the common implementation to __css_rstat_updated() for in-kernel
callers.

Fixes: a319185 ("cgroup: bpf: enable bpf programs to integrate with rstat")
Signed-off-by: Qing Ming <a0yami@mailbox.org>
@blktests-ci
Copy link
Copy Markdown
Author

blktests-ci Bot commented May 16, 2026

Upstream branch: 70eda68
series: https://patchwork.kernel.org/project/linux-block/list/?series=1095775
version: 2

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Projects

None yet

Development

Successfully merging this pull request may close these issues.

0 participants