From: Yonghong Song <yonghong.song@linux.dev>
To: Dawei Feng <dawei.feng@seu.edu.cn>, martin.lau@linux.dev
Cc: emil@etsalapatis.com, ast@kernel.org, daniel@iogearbox.net,
andrii@kernel.org, eddyz87@gmail.com, memxor@gmail.com,
song@kernel.org, jolsa@kernel.org, kees@kernel.org,
joel.granados@kernel.org, bpf@vger.kernel.org,
linux-kernel@vger.kernel.org, linux-fsdevel@vger.kernel.org,
jianhao.xu@seu.edu.cn, Zilin Guan <zilin@seu.edu.cn>
Subject: Re: [PATCH v2 2/3] bpf: cgroup: NUL-terminate replaced sysctl value
Date: Mon, 1 Jun 2026 14:22:07 -0700 [thread overview]
Message-ID: <bf25d653-d856-4ad7-a751-b97d38f38892@linux.dev> (raw)
In-Reply-To: <20260529031026.2716641-3-dawei.feng@seu.edu.cn>
On 5/28/26 8:10 PM, Dawei Feng wrote:
> When writing to sysctls, proc_sys_call_handler() guarantees that the
> buffer passed to proc handlers is NUL-terminated. If
> bpf_sysctl_set_new_value() replaces the pending sysctl value, it can
> hand a replacement buffer directly to proc handlers. However, the
> helper currently copies only buf_len
> bytes into that buffer without appending a NUL terminator, leaving
> downstream parsers vulnerable to out-of-bounds access.
>
> Fix this by appending a '\0' after the replaced value to restore the
> expected sysctl semantics. Since the helper already rejects buf_len
> greater than PAGE_SIZE - 1, there is always room for the extra byte.
>
> Reproduced in a QEMU x86_64 guest booted with KASAN while exercising
> the sysctl replacement path with a cgroup/sysctl BPF program. The
> reproducer targets `/proc/sys/net/core/flow_limit_cpu_bitmap`, fills
> the original user write buffer with non-zero bytes, and overrides the
> sysctl value so the replacement buffer lacks a terminating NUL. Under
> that setup, the pre-fix kernel reported:
>
> BUG: KASAN: slab-out-of-bounds in strnchrnul+0x72/0x90
> Read of size 1 at addr ffff88800de57000 by task repro_patch3/66
> CPU: 0 UID: 0 PID: 66 Comm: repro_patch3 Not tainted 7.1.0-rc3-00269-g8370ca1f87cc #6 PREEMPT(lazy)
> Hardware name: QEMU Standard PC (i440FX + PIIX, 1996), BIOS 1.15.0-1 04/01/2014
> Call Trace:
> <TASK>
> dump_stack_lvl+0x68/0xa0
> print_report+0xcb/0x5e0
> ? __virt_addr_valid+0x21d/0x3f0
> ? strnchrnul+0x72/0x90
> ? strnchrnul+0x72/0x90
> kasan_report+0xca/0x100
> ? strnchrnul+0x72/0x90
> strnchrnul+0x72/0x90
> bitmap_parse+0x37/0x2e0
> flow_limit_cpu_sysctl+0xc6/0x840
> ? __pfx_flow_limit_cpu_sysctl+0x10/0x10
> ? __kvmalloc_node_noprof+0x5ba/0x870
> proc_sys_call_handler+0x31d/0x480
> ? __pfx_proc_sys_call_handler+0x10/0x10
> ? selinux_file_permission+0x39f/0x500
> ? lock_is_held_type+0x9e/0x120
> vfs_write+0x98e/0x1000
> ? kmem_cache_free+0x308/0x550
> ? __pfx_vfs_write+0x10/0x10
> ? __pfx_do_sys_openat2+0x10/0x10
> ksys_write+0xf2/0x1d0
> ? __pfx_ksys_write+0x10/0x10
> ? trace_irq_enable.constprop.0+0x110/0x140
> do_syscall_64+0x115/0x690
> entry_SYSCALL_64_after_hwframe+0x77/0x7f
> RIP: 0033:0x447f37
> Code: ff ff f7 d8 64 89 02 48 c7 c0 ff ff ff ff eb b7 0f 1f 00 f3 0f 1e fa 64 8b 04 25 18 00 00 00 85 c0 75 10 b8 01 00 00 00 0f 05 <48> 3d 00 f0 ff ff 77 51 c3 48 83 ec 28 48 89 54 24 18 48 89 74 24
> RSP: 002b:00007fff01ade608 EFLAGS: 00000246 ORIG_RAX: 0000000000000001
> RAX: ffffffffffffffda RBX: 0000000000000004 RCX: 0000000000447f37
> RDX: 0000000000001fff RSI: 00000000172b1780 RDI: 0000000000000005
> RBP: 00000000172b1780 R08: 00000000004ca1b0 R09: 00000000172b1780
> R10: 0000000000000000 R11: 0000000000000246 R12: 0000000000001fff
> R13: 0000000000000000 R14: 0000000000000005 R15: 0000000000000003
> </TASK>
> The buggy address is located 0 bytes to the right of
> allocated 4096-byte region [ffff88800de56000, ffff88800de57000)
The above log can be simplied.
>
> With this fix applied, rerunning the same sysctl-targeted path yields
> no corresponding KASAN reports.
>
> Signed-off-by: Zilin Guan <zilin@seu.edu.cn>
> Signed-off-by: Dawei Feng <dawei.feng@seu.edu.cn>
> ---
> kernel/bpf/cgroup.c | 1 +
> 1 file changed, 1 insertion(+)
>
> diff --git a/kernel/bpf/cgroup.c b/kernel/bpf/cgroup.c
> index faadcfb9b5e5..a0b5f8cd8b10 100644
> --- a/kernel/bpf/cgroup.c
> +++ b/kernel/bpf/cgroup.c
> @@ -2342,6 +2342,7 @@ BPF_CALL_3(bpf_sysctl_set_new_value, struct bpf_sysctl_kern *, ctx,
> return -E2BIG;
>
> memcpy(ctx->new_val, buf, buf_len);
> + ((char *)ctx->new_val)[buf_len] = '\0';
Does memcpy(ctx->new_val, buf, buf_len + 1) work?
> ctx->new_len = buf_len;
> ctx->new_updated = 1;
>
next prev parent reply other threads:[~2026-06-01 21:22 UTC|newest]
Thread overview: 18+ messages / expand[flat|nested] mbox.gz Atom feed top
2026-05-29 3:10 [PATCH v2 0/3] bpf: cgroup: fix sysctl new-value handling in __cgroup_bpf_run_filter_sysctl Dawei Feng
2026-05-29 3:10 ` [PATCH v2 1/3] bpf: cgroup: use kvfree() for replaced sysctl write buffer Dawei Feng
2026-05-29 4:45 ` Jiayuan Chen
2026-06-01 21:07 ` Yonghong Song
2026-05-29 3:10 ` [PATCH v2 2/3] bpf: cgroup: NUL-terminate replaced sysctl value Dawei Feng
2026-05-29 3:56 ` bot+bpf-ci
2026-06-01 21:22 ` Yonghong Song [this message]
2026-06-03 9:47 ` Dawei Feng
2026-06-03 10:01 ` Dawei Feng
2026-06-03 10:33 ` Dawei Feng
2026-05-29 3:10 ` [PATCH v2 3/3] bpf: cgroup: restore sysctl new-value replacement Dawei Feng
2026-05-29 3:56 ` bot+bpf-ci
2026-05-29 4:51 ` Jiayuan Chen
2026-05-29 6:34 ` sashiko-bot
2026-06-01 22:01 ` Yonghong Song
2026-05-29 4:44 ` [PATCH v2 0/3] bpf: cgroup: fix sysctl new-value handling in __cgroup_bpf_run_filter_sysctl Jiayuan Chen
2026-05-29 11:37 ` Dawei Feng
2026-05-29 16:45 ` Emil Tsalapatis
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=bf25d653-d856-4ad7-a751-b97d38f38892@linux.dev \
--to=yonghong.song@linux.dev \
--cc=andrii@kernel.org \
--cc=ast@kernel.org \
--cc=bpf@vger.kernel.org \
--cc=daniel@iogearbox.net \
--cc=dawei.feng@seu.edu.cn \
--cc=eddyz87@gmail.com \
--cc=emil@etsalapatis.com \
--cc=jianhao.xu@seu.edu.cn \
--cc=joel.granados@kernel.org \
--cc=jolsa@kernel.org \
--cc=kees@kernel.org \
--cc=linux-fsdevel@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=martin.lau@linux.dev \
--cc=memxor@gmail.com \
--cc=song@kernel.org \
--cc=zilin@seu.edu.cn \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox