Hi, Marco, On Wed, Jul 19, 2023 at 6:55 PM Marco Elver <elver@xxxxxxxxxx> wrote: > > On Wed, 19 Jul 2023 at 10:28, Enze Li <lienze@xxxxxxxxxx> wrote: > > > > The LoongArch architecture is different from other architectures. > > It needs to update __kfence_pool during arch_kfence_init_pool. > > > > This patch modifies the assignment location of the local variable addr > > in the kfence_init_pool function to support the case of updating > > __kfence_pool in arch_kfence_init_pool. > > > > Signed-off-by: Enze Li <lienze@xxxxxxxxxx> > > I think it's fair to allow this use case. > > However, please make sure that when your arch_kfence_init_pool() > fails, it is still possible to free the memblock allocated memory > properly. > > Acked-by: Marco Elver <elver@xxxxxxxxxx> Does Acked-by means this patch can go through loongarch tree together with other patches? If this patch should go through kfence tree, then the others should wait for some time. Huacai > > > --- > > mm/kfence/core.c | 5 +++-- > > 1 file changed, 3 insertions(+), 2 deletions(-) > > > > diff --git a/mm/kfence/core.c b/mm/kfence/core.c > > index dad3c0eb70a0..e124ffff489f 100644 > > --- a/mm/kfence/core.c > > +++ b/mm/kfence/core.c > > @@ -566,13 +566,14 @@ static void rcu_guarded_free(struct rcu_head *h) > > */ > > static unsigned long kfence_init_pool(void) > > { > > - unsigned long addr = (unsigned long)__kfence_pool; > > + unsigned long addr; > > struct page *pages; > > int i; > > > > if (!arch_kfence_init_pool()) > > - return addr; > > + return (unsigned long)__kfence_pool; > > > > + addr = (unsigned long)__kfence_pool; > > pages = virt_to_page(__kfence_pool); > > > > /* > > -- > > 2.34.1 > >