From mboxrd@z Thu Jan 1 00:00:00 1970 From: Tejun Heo Subject: Re: [RFC PATCH 08/14] rcu: Convert RCU gp kthreads into kthread worker API Date: Tue, 28 Jul 2015 13:37:44 -0400 Message-ID: <20150728173744.GE5322@mtj.duckdns.org> References: <1438094371-8326-1-git-send-email-pmladek@suse.com> <1438094371-8326-9-git-send-email-pmladek@suse.com> Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii Return-path: Content-Disposition: inline In-Reply-To: <1438094371-8326-9-git-send-email-pmladek@suse.com> Sender: owner-linux-mm@kvack.org To: Petr Mladek Cc: Andrew Morton , Oleg Nesterov , Ingo Molnar , Peter Zijlstra , Steven Rostedt , "Paul E. McKenney" , Josh Triplett , Thomas Gleixner , Linus Torvalds , Jiri Kosina , Borislav Petkov , Michal Hocko , linux-mm@kvack.org, Vlastimil Babka , live-patching@vger.kernel.org, linux-api@vger.kernel.org, linux-kernel@vger.kernel.org List-Id: linux-api@vger.kernel.org On Tue, Jul 28, 2015 at 04:39:25PM +0200, Petr Mladek wrote: ... > -static int __noreturn rcu_gp_kthread(void *arg) > +static void rcu_gp_kthread_func(struct kthread_work *work) > { > int fqs_state; > int gf; > unsigned long j; > int ret; > - struct rcu_state *rsp = arg; > + struct rcu_state *rsp = container_of(work, struct rcu_state, gp_work); > struct rcu_node *rnp = rcu_get_root(rsp); > > - rcu_bind_gp_kthread(); > + /* Handle grace-period start. */ > for (;;) { > + trace_rcu_grace_period(rsp->name, > + READ_ONCE(rsp->gpnum), > + TPS("reqwait")); > + rsp->gp_state = RCU_GP_WAIT_GPS; > + wait_event_interruptible(rsp->gp_wq, > + READ_ONCE(rsp->gp_flags) & > + RCU_GP_FLAG_INIT); Same here. Why not convert the waker into a queueing event? > + /* Locking provides needed memory barrier. */ > + if (rcu_gp_init(rsp)) > + break; > + cond_resched_rcu_qs(); > + WRITE_ONCE(rsp->gp_activity, jiffies); > + WARN_ON(signal_pending(current)); > + trace_rcu_grace_period(rsp->name, > + READ_ONCE(rsp->gpnum), > + TPS("reqwaitsig")); > + } Thanks. -- tejun -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@kvack.org. For more info on Linux MM, see: http://www.linux-mm.org/ . Don't email: email@kvack.org