[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <PSAPR06MB402186F56F858E16CB33081FDF7F9@PSAPR06MB4021.apcprd06.prod.outlook.com>
Date: Mon, 5 Sep 2022 07:12:01 +0000
From: 赵军奎 <bernard@...o.com>
To: Chengming Zhou <zhouchengming@...edance.com>
CC: "zhaojunkui2008@....com" <zhaojunkui2008@....com>,
Johannes Weiner <hannes@...xchg.org>,
Suren Baghdasaryan <surenb@...gle.com>,
Ingo Molnar <mingo@...hat.com>,
Peter Zijlstra <peterz@...radead.org>,
Juri Lelli <juri.lelli@...hat.com>,
Vincent Guittot <vincent.guittot@...aro.org>,
Dietmar Eggemann <dietmar.eggemann@....com>,
Steven Rostedt <rostedt@...dmis.org>,
Ben Segall <bsegall@...gle.com>, Mel Gorman <mgorman@...e.de>,
Daniel Bristot de Oliveira <bristot@...hat.com>,
Valentin Schneider <vschneid@...hat.com>,
"linux-kernel@...r.kernel.org" <linux-kernel@...r.kernel.org>
Subject: 答复: [PATCH] kernel/sched: fix KMSAN uninit-value error
Hi Chengming:
For KMSAN issue, syzbot does not support patch verification from Linux-main or Linux-next branch.
Currently, only Google's own kmsan.git can be used for KMSAN issue`s verification. The warning like this:
KMSAN bugs can only be tested on https://github.com/google/kmsan.git tree because KMSAN tool is not upstreamed yet.
See https://goo.gl/tpsmEJ#kmsan-bugs for details.
It seems that Google's code has not sync with the latest code of Linux-next.
This patch doesn't seem to be needed if the commit 2b97cf76289a has been submitted, thanks!
BR//Bernard
-----邮件原件-----
发件人: Chengming Zhou <zhouchengming@...edance.com>
发送时间: 2022年9月5日 14:42
收件人: 赵军奎 <bernard@...o.com>
抄送: zhaojunkui2008@....com; Johannes Weiner <hannes@...xchg.org>; Suren Baghdasaryan <surenb@...gle.com>; Ingo Molnar <mingo@...hat.com>; Peter Zijlstra <peterz@...radead.org>; Juri Lelli <juri.lelli@...hat.com>; Vincent Guittot <vincent.guittot@...aro.org>; Dietmar Eggemann <dietmar.eggemann@....com>; Steven Rostedt <rostedt@...dmis.org>; Ben Segall <bsegall@...gle.com>; Mel Gorman <mgorman@...e.de>; Daniel Bristot de Oliveira <bristot@...hat.com>; Valentin Schneider <vschneid@...hat.com>; linux-kernel@...r.kernel.org
主题: Re: [PATCH] kernel/sched: fix KMSAN uninit-value error
[You don't often get email from zhouchengming@...edance.com. Learn why this is important at https://aka.ms/LearnAboutSenderIdentification ]
On 2022/9/5 10:37, Bernard Zhao wrote:
> This patch try to fix syzbot error:
> =====================================================
> BUG: KMSAN: uninit-value in update_triggers kernel/sched/psi.c:525
> [inline]
> BUG: KMSAN: uninit-value in psi_poll_work kernel/sched/psi.c:626
> [inline]
> BUG: KMSAN: uninit-value in psi_poll_worker+0x972/0x16a0
> kernel/sched/psi.c:648
Hello,
Did you test with the latest PSI code using linux-next branch that include the commit 2b97cf76289a ("sched/psi: Zero the memory of struct psi_group")?
Thanks.
> update_triggers kernel/sched/psi.c:525 [inline] psi_poll_work
> kernel/sched/psi.c:626 [inline]
> psi_poll_worker+0x972/0x16a0 kernel/sched/psi.c:648
> kthread+0x31b/0x430 kernel/kthread.c:376
> ret_from_fork+0x1f/0x30
>
> Uninit was stored to memory at:
> collect_percpu_times+0x193d/0x19a0 kernel/sched/psi.c:355
> psi_poll_work kernel/sched/psi.c:604 [inline]
> psi_poll_worker+0x587/0x16a0 kernel/sched/psi.c:648
> kthread+0x31b/0x430 kernel/kthread.c:376
> ret_from_fork+0x1f/0x30
>
> Uninit was stored to memory at:
> collect_percpu_times+0x193d/0x19a0 kernel/sched/psi.c:355
> psi_poll_work kernel/sched/psi.c:604 [inline]
> psi_poll_worker+0x587/0x16a0 kernel/sched/psi.c:648
> kthread+0x31b/0x430 kernel/kthread.c:376
> ret_from_fork+0x1f/0x30
>
> Uninit was stored to memory at:
> collect_percpu_times+0x193d/0x19a0 kernel/sched/psi.c:355
> psi_poll_work kernel/sched/psi.c:604 [inline]
> psi_poll_worker+0x587/0x16a0 kernel/sched/psi.c:648
> kthread+0x31b/0x430 kernel/kthread.c:376
> ret_from_fork+0x1f/0x30
>
> Uninit was created at:
> slab_post_alloc_hook mm/slab.h:732 [inline] slab_alloc_node
> mm/slub.c:3258 [inline] slab_alloc mm/slub.c:3266 [inline]
> kmem_cache_alloc_trace+0x696/0xdf0 mm/slub.c:3297 kmalloc
> include/linux/slab.h:600 [inline]
> psi_cgroup_alloc+0x83/0x250 kernel/sched/psi.c:960 cgroup_create
> kernel/cgroup/cgroup.c:5430 [inline]
> cgroup_mkdir+0x10a3/0x3080 kernel/cgroup/cgroup.c:5550
> kernfs_iop_mkdir+0x2ba/0x520 fs/kernfs/dir.c:1185
> vfs_mkdir+0x62a/0x870 fs/namei.c:4013
> do_mkdirat+0x466/0x7b0 fs/namei.c:4038 __do_sys_mkdirat
> fs/namei.c:4053 [inline] __se_sys_mkdirat fs/namei.c:4051 [inline]
> __x64_sys_mkdirat+0xc4/0x120 fs/namei.c:4051
> do_syscall_x64 arch/x86/entry/common.c:50 [inline]
> do_syscall_64+0x3d/0xb0 arch/x86/entry/common.c:80
> entry_SYSCALL_64_after_hwframe+0x63/0xcd
>
> syzbot link:
> https://syzkaller.appspot.com/bug?id=d04c5407207d11e46007775517b977641
> 74bc45d
>
> Signed-off-by: Bernard Zhao <bernard@...o.com>
> ---
> kernel/sched/psi.c | 3 +++
> 1 file changed, 3 insertions(+)
>
> diff --git a/kernel/sched/psi.c b/kernel/sched/psi.c index
> ecb4b4ff4ce0..46f048121520 100644
> --- a/kernel/sched/psi.c
> +++ b/kernel/sched/psi.c
> @@ -195,6 +195,9 @@ static void group_init(struct psi_group *group)
> init_waitqueue_head(&group->poll_wait);
> timer_setup(&group->poll_timer, poll_timer_fn, 0);
> rcu_assign_pointer(group->poll_task, NULL);
> + memset(group->avg_total, 0, sizeof(group->avg_total));
> + memset(group->total, 0, sizeof(group->total));
> + memset(group->avg, 0, sizeof(group->avg));
> }
>
> void __init psi_init(void)
Powered by blists - more mailing lists