[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <20200801000223.GU9247@paulmck-ThinkPad-P72>
Date: Fri, 31 Jul 2020 17:02:23 -0700
From: "Paul E. McKenney" <paulmck@...nel.org>
To: Matthew Wilcox <willy@...radead.org>
Cc: Andrew Morton <akpm@...ux-foundation.org>, cl@...ux.com,
penberg@...nel.org, rientjes@...gle.com, iamjoonsoo.kim@....com,
hannes@...xchg.org, urezki@...il.com, linux-kernel@...r.kernel.org,
linux-mm@...ck.org
Subject: Re: Raw spinlocks and memory allocation
On Fri, Jul 31, 2020 at 11:47:38PM +0100, Matthew Wilcox wrote:
> On Fri, Jul 31, 2020 at 03:30:16PM -0700, Paul E. McKenney wrote:
> > On Fri, Jul 31, 2020 at 02:29:19PM -0700, Andrew Morton wrote:
> > > On Fri, 31 Jul 2020 14:24:57 -0700 "Paul E. McKenney" <paulmck@...nel.org> wrote:
> > >
> > > > The reason for this restriction is that in -rt, the spin_lock(&zone->lock)
> > > > in rmqueue_bulk() can sleep.
> > >
> > > So if there is runtime overhead, this overhead could be restricted to
> > > -rt kernels with suitable ifdefs?
> >
> > In theory, yes. In practice, with CONFIG_PROVE_RAW_LOCK_NESTING=y,
> > lockdep will complain regardless of -rt or not.
>
> On non-RT, we could make that lock a raw spinlock. On RT, we could
> decline to take the lock. We'd need to abstract the spin_lock() away
> behind zone_lock(zone), but that should be OK.
>
> But let's see if we need to do that.
Fair enough!
Thanx, Paul
Powered by blists - more mailing lists