From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754916Ab2AYPwQ (ORCPT ); Wed, 25 Jan 2012 10:52:16 -0500 Received: from mx1.redhat.com ([209.132.183.28]:32352 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752918Ab2AYPwP (ORCPT ); Wed, 25 Jan 2012 10:52:15 -0500 Date: Wed, 25 Jan 2012 16:45:47 +0100 From: Oleg Nesterov To: Peter Zijlstra Cc: Ingo Molnar , Yasunori Goto , Thomas Gleixner , Hiroyuki KAMEZAWA , Motohiro Kosaki , Linux Kernel ML Subject: Re: [BUG] TASK_DEAD task is able to be woken up in special condition Message-ID: <20120125154547.GA6671@redhat.com> References: <20120116205140.6120.E1E9C6FF@jp.fujitsu.com> <1326721082.2442.234.camel@twins> <20120117174031.3118.E1E9C6FF@jp.fujitsu.com> <20120117090605.GD7612@elte.hu> <20120117151242.GA13290@redhat.com> <20120118094219.GE5842@elte.hu> <20120118142005.GB10105@redhat.com> <1327400349.2614.10.camel@laptop> <1327402527.2614.17.camel@laptop> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <1327402527.2614.17.camel@laptop> User-Agent: Mutt/1.5.18 (2008-05-17) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 01/24, Peter Zijlstra wrote: > > On Tue, 2012-01-24 at 11:19 +0100, Peter Zijlstra wrote: > > On Wed, 2012-01-18 at 15:20 +0100, Oleg Nesterov wrote: > > > do_exit() is different because it can not handle the spurious wakeup. > > > Well, may be we can? we can simply do > > > > > > for (;;) { > > > tsk->state = TASK_DEAD; > > > schedule(); > > > } > > > > > > __schedule() can't race with ttwu() once it takes rq->lock. If the > > > exiting task is deactivated, finish_task_switch() will see EXIT_DEAD. > > > > TASK_DEAD, right? Yes, but... I simply can't understand what I was thinking about. And probably I missed something again, but I think this can't work. Afaics, this can only help to prevent the race with ttwu_remote() doing ttwu_do_wakeup() under rq->lock. But we still can race with the !p->on_rq case which sets TASK_WAKING. It can do this after finish_task_switch() observes TASK_DEAD and does put_task_struct(). > I think Yasunori-San's patch isn't > sufficient, note how the p->state = TASK_RUNNING in ttwu_do_wakeup() can > happen outside of p->pi_lock when the task gets queued on a remote cpu. Hmm, really? I am not sure, but I do not trust myself. To simplify, you mean that mb(); unlock_wait(pi_lock); tsk->state = TASK_DEAD; can change ->state from TASK_WAKING to TASK_DEAD, right? Is this really possible? ttwu() ensures p->on_rq == F in this case. Oleg.