[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20191004170411.GA31114@pc636>
Date: Fri, 4 Oct 2019 19:04:11 +0200
From: Uladzislau Rezki <urezki@...il.com>
To: Sebastian Andrzej Siewior <bigeasy@...utronix.de>
Cc: Uladzislau Rezki <urezki@...il.com>,
Daniel Wagner <dwagner@...e.de>, linux-mm@...ck.org,
linux-kernel@...r.kernel.org, linux-rt-users@...r.kernel.org,
Andrew Morton <akpm@...ux-foundation.org>
Subject: Re: [PATCH] mm: vmalloc: Use the vmap_area_lock to protect
ne_fit_preload_node
>
> You could have been migrated to another CPU while
> memory has been allocated.
>
That is true that we can migrate since we allow preemption
when allocate. But it does not really matter on which CPU an
allocation occurs and whether we migrate or not.
If we land on another CPU or still stay on the same, we will
check anyway one more time if it(another/same CPU) is preloaded
or not:
<snip>
preempt_disable();
if (__this_cpu_cmpxchg(ne_fit_preload_node, NULL, pva)
<snip>
if another, we can free the object allocated on previous step if
it already has it. If another CPU does not have it, save it in
ne_fit_preload_node for another current CPU to reuse later. Further
we can not migrate because of:
<snip>
spin_lock(&vmap_area_lock);
preempt_enable();
<snip>
--
Vlad Rezki
Powered by blists - more mailing lists