Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754865Ab0AUSMx (ORCPT ); Thu, 21 Jan 2010 13:12:53 -0500 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1753951Ab0AUSMw (ORCPT ); Thu, 21 Jan 2010 13:12:52 -0500 Received: from mgw1.diku.dk ([130.225.96.91]:33297 "EHLO mgw1.diku.dk" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S932118Ab0AUSMv (ORCPT ); Thu, 21 Jan 2010 13:12:51 -0500 Date: Thu, 21 Jan 2010 19:12:47 +0100 (CET) From: Julia Lawall To: Steven Rostedt Cc: LKML , kernel-janitors , Peter Zijlstra , Andrew Morton , linux-arch@vger.kernel.org, Greg KH , Andy Whitcroft , Benjamin Herrenschmidt , Paul Mackerras Subject: Re: Lots of bugs with current->state = TASK_*INTERRUPTIBLE In-Reply-To: <1264095094.31321.283.camel@gandalf.stny.rr.com> Message-ID: References: <1263932978.31321.53.camel@gandalf.stny.rr.com> <1263935333.4561.26.camel@frodo> <1264095094.31321.283.camel@gandalf.stny.rr.com> MIME-Version: 1.0 Content-Type: TEXT/PLAIN; charset=US-ASCII Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2298 Lines: 63 On Thu, 21 Jan 2010, Steven Rostedt wrote: > On Thu, 2010-01-21 at 11:47 +0100, Julia Lawall wrote: > > What about something like the following (drivers/macintosh/adb.c): > > > > add_wait_queue(&state->wait_queue, &wait); > > current->state = TASK_INTERRUPTIBLE; > > > > for (;;) { > > req = state->completed; > > if (req != NULL) > > state->completed = req->next; > > else if (atomic_read(&state->n_pending) == 0) > > ret = -EIO; > > if (req != NULL || ret != 0) > > break; > > > > if (file->f_flags & O_NONBLOCK) { > > ret = -EAGAIN; > > break; > > } > > if (signal_pending(current)) { > > ret = -ERESTARTSYS; > > break; > > } > > spin_unlock_irqrestore(&state->lock, flags); > > schedule(); > > spin_lock_irqsave(&state->lock, flags); > > } > > > > current->state = TASK_RUNNING; > > remove_wait_queue(&state->wait_queue, &wait); > > > > There is a call to schedule eventually after the first current->state > > assignment, but it is not right after. > > I looked at this code in a bit more detail. Seems that it does not need > the set_current_state(), because all activities between the state of the > task and the variables being checked (state->n_pending, et al) are under > the state->lock. > > But there should be a comment stating that above the assignment of > current->state. Something like: > > /* > * No need for the set_current_state() memory barrier since > * all checks between state and wakeups are done under the > * state->lock. > */ > current->state = TASK_INTERRUPTIBLE; > > > But I'd rather have the author of this code write that. As far as I can tell, state is something that is local to this driver. So is the point that a lock is taken, or that interrupts are turned off? julia -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/