> -----Original Message-----
> From: Dietmar Eggemann [mailto:dietmar.eggem...@arm.com]
> Sent: Monday, February 1, 2021 10:54 PM
> To: Valentin Schneider <valentin.schnei...@arm.com>;
> linux-kernel@vger.kernel.org
> Cc: mi...@kernel.org; pet...@infradead.org; vincent.guit...@linaro.org;
> morten.rasmus...@arm.com; mgor...@suse.de; Song Bao Hua (Barry Song)
> <song.bao....@hisilicon.com>
> Subject: Re: [PATCH 1/1] sched/topology: Make sched_init_numa() use a set for
> the deduplicating sort
> 
> On 22/01/2021 13:39, Valentin Schneider wrote:
> 
> [...]
> 
> > @@ -1705,7 +1702,7 @@ void sched_init_numa(void)
> >     /* Compute default topology size */
> >     for (i = 0; sched_domain_topology[i].mask; i++);
> >
> > -   tl = kzalloc((i + level + 1) *
> > +   tl = kzalloc((i + nr_levels) *
> >                     sizeof(struct sched_domain_topology_level), GFP_KERNEL);
> >     if (!tl)
> >             return;
> 
> This hunk creates issues during startup on my Arm64 juno board on 
> tip/sched/core.

I also reported this kernel panic here:
https://lore.kernel.org/lkml/bfb703294b234e1e926a68fcb73db...@hisilicon.com/#t

> 
> ---8<---
> 
> From: Dietmar Eggemann <dietmar.eggem...@arm.com>
> Date: Mon, 1 Feb 2021 09:58:04 +0100
> Subject: [PATCH] sched/topology: Fix sched_domain_topology_level alloc in
>  sched_init_numa
> 
> Commit "sched/topology: Make sched_init_numa() use a set for the
> deduplicating sort" allocates 'i + nr_levels (level)' instead of
> 'i + nr_levels + 1' sched_domain_topology_level.
> 
> This led to an Oops (on Arm64 juno with CONFIG_SCHED_DEBUG):
> 
> sched_init_domains
>   build_sched_domains()
>     __free_domain_allocs()
>       __sdt_free() {
>       ...
>         for_each_sd_topology(tl)
>         ...
>           sd = *per_cpu_ptr(sdd->sd, j); <--
>         ...
>       }
> 
> Signed-off-by: Dietmar Eggemann <dietmar.eggem...@arm.com>
> ---

This patch also resolved my panic. So:

Tested-by: Barry Song <song.bao....@hisilicon.com>

Thanks
Barry

Reply via email to