| [Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
 Re: [RFC PATCH 03/30] Lazy percpu counters
 
To: Kent Overstreet <kent.overstreet@xxxxxxxxx>From: Peter Zijlstra <peterz@xxxxxxxxxxxxx>Date: Thu, 1 Sep 2022 20:59:20 +0200Cc: Suren Baghdasaryan <surenb@xxxxxxxxxx>, akpm@xxxxxxxxxxxxxxxxxxxx,	mhocko@xxxxxxxx, vbabka@xxxxxxx, hannes@xxxxxxxxxxx,	roman.gushchin@xxxxxxxxx, mgorman@xxxxxxx, dave@xxxxxxxxxxxx,	willy@xxxxxxxxxxxxx, liam.howlett@xxxxxxxxxx, void@xxxxxxxxxxxxx,	juri.lelli@xxxxxxxxxx, ldufour@xxxxxxxxxxxxx, peterx@xxxxxxxxxx,	david@xxxxxxxxxx, axboe@xxxxxxxxx, mcgrof@xxxxxxxxxx,	masahiroy@xxxxxxxxxx, nathan@xxxxxxxxxx, changbin.du@xxxxxxxxx,	ytcoode@xxxxxxxxx, vincent.guittot@xxxxxxxxxx,	dietmar.eggemann@xxxxxxx, rostedt@xxxxxxxxxxx, bsegall@xxxxxxxxxx,	bristot@xxxxxxxxxx, vschneid@xxxxxxxxxx, cl@xxxxxxxxx,	penberg@xxxxxxxxxx, iamjoonsoo.kim@xxxxxxx, 42.hyeyoo@xxxxxxxxx,	glider@xxxxxxxxxx, elver@xxxxxxxxxx, dvyukov@xxxxxxxxxx,	shakeelb@xxxxxxxxxx, songmuchun@xxxxxxxxxxxxx, arnd@xxxxxxxx,	jbaron@xxxxxxxxxx, rientjes@xxxxxxxxxx, minchan@xxxxxxxxxx,	kaleshsingh@xxxxxxxxxx, kernel-team@xxxxxxxxxxx, linux-mm@xxxxxxxxx,	iommu@xxxxxxxxxxxxxxx, kasan-dev@xxxxxxxxxxxxxxxx,	io-uring@xxxxxxxxxxxxxxx, linux-arch@xxxxxxxxxxxxxxx,	xen-devel@xxxxxxxxxxxxxxxxxxxx, linux-bcache@xxxxxxxxxxxxxxx,	linux-modules@xxxxxxxxxxxxxxx, linux-kernel@xxxxxxxxxxxxxxxDelivery-date: Thu, 01 Sep 2022 19:00:23 +0000List-id: Xen developer discussion <xen-devel.lists.xenproject.org> 
 On Thu, Sep 01, 2022 at 10:32:19AM -0400, Kent Overstreet wrote:
> On Thu, Sep 01, 2022 at 08:51:31AM +0200, Peter Zijlstra wrote:
> > On Tue, Aug 30, 2022 at 02:48:52PM -0700, Suren Baghdasaryan wrote:
> > > +static void lazy_percpu_counter_switch_to_pcpu(struct 
> > > raw_lazy_percpu_counter *c)
> > > +{
> > > + u64 __percpu *pcpu_v = alloc_percpu_gfp(u64, GFP_ATOMIC|__GFP_NOWARN);
> > 
> > Realize that this is incorrect when used under a raw_spinlock_t.
> 
> Can you elaborate?
required lock order: raw_spinlock_t < spinlock_t < mutex
allocators lives at spinlock_t.
Also see CONFIG_PROVE_RAW_LOCK_NESTING and there might be a document
mentioning all this somewhere.
Additionally, this (obviously) also isn't NMI safe.
 |