Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1755223Ab0K2Ww7 (ORCPT ); Mon, 29 Nov 2010 17:52:59 -0500 Received: from kroah.org ([198.145.64.141]:47616 "EHLO coco.kroah.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753218Ab0K2Ww6 (ORCPT ); Mon, 29 Nov 2010 17:52:58 -0500 Date: Mon, 29 Nov 2010 14:47:53 -0800 From: Greg KH To: Jiri Slaby Cc: gregkh@suse.de, slapin@ossfans.org, linux-kernel@vger.kernel.org, jirislaby@gmail.com, Alan Cox Subject: Re: [PATCH 1/2] TTY: ldisc, fix open flag handling Message-ID: <20101129224753.GB15321@kroah.com> References: <4CED9498.9080900@suse.cz> <1290641275-21726-1-git-send-email-jslaby@suse.cz> <20101129215030.GC9830@kroah.com> <4CF42C29.4040702@suse.cz> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <4CF42C29.4040702@suse.cz> User-Agent: Mutt/1.5.20 (2009-06-14) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2416 Lines: 63 On Mon, Nov 29, 2010 at 11:41:45PM +0100, Jiri Slaby wrote: > On 11/29/2010 10:50 PM, Greg KH wrote: > > On Thu, Nov 25, 2010 at 12:27:54AM +0100, Jiri Slaby wrote: > >> When a concrete ldisc open fails in tty_ldisc_open, we forget to clear > >> TTY_LDISC_OPEN. This causes a false warning on the next ldisc open: > >> WARNING: at drivers/char/tty_ldisc.c:445 tty_ldisc_open+0x26/0x38() > >> Hardware name: System Product Name > >> Modules linked in: ... > >> Pid: 5251, comm: a.out Tainted: G W 2.6.32-5-686 #1 > >> Call Trace: > >> [] ? warn_slowpath_common+0x5e/0x8a > >> [] ? warn_slowpath_null+0xa/0xc > >> [] ? tty_ldisc_open+0x26/0x38 > >> [] ? tty_set_ldisc+0x218/0x304 > >> ... > >> > >> So clear the bit when failing... > >> > >> Introduced in c65c9bc3efa (tty: rewrite the ldisc locking) back in > >> 2.6.31-rc1. > >> > >> Signed-off-by: Jiri Slaby > >> Cc: Alan Cox > >> Reported-by: Sergey Lapin > >> Tested-by: Sergey Lapin > > > > Is this still needed, or can I just use your: > > [PATCH v2 1/2] TTY: don't allow reopen when ldisc is changing > > patch instead? > > This patch is still needed, it fixes a fail path. Ok, thanks. > Other than that there are 3 races in 2.6.36, one of them is introduced > in 2.6.36, the rest in 2.6.32. For each bug there is a single patch I sent: > * TTY: open/hangup race fixup > - introduced in 2.6.36 > - open vs hangup race > * TTY: don't allow reopen when ldisc is changing > - tiocsetd vs open race > * TTY: ldisc, fix open flag handling > - this you are asking about > - when ldisc->open fails, we blow up Good, I have these three ready to go to Linus now. > * Char: TTY, restore tty_ldisc_wait_idle > - this is in 37-rc2 already > - multiple opens followed by tiocsetd blows the machine up > > All of them are stable candidates (but I would give them some time in > HEAD to see if something breaks, since I opened a can of worms). The > first one is applicable only to 2.6.36 indeed. Thanks for the details, much appreciated, as are your patches :) greg k-h -- 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/