[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <alpine.LFD.2.01.0910131548280.3404@localhost.localdomain>
Date:	Tue, 13 Oct 2009 15:54:45 -0700 (PDT)
From:	Linus Torvalds <torvalds@...ux-foundation.org>
To:	Alan Cox <alan@...rguk.ukuu.org.uk>
cc:	Boyan <btanastasov@...oo.co.uk>,
	Frédéric L. W. Meunier 
	<fredlwm@...il.com>, "Justin P. Mattock" <justinmattock@...il.com>,
	Nix <nix@...eri.org.uk>, Paul Fulghum <paulkf@...rogate.com>,
	"Rafael J. Wysocki" <rjw@...k.pl>,
	Linux Kernel Mailing List <linux-kernel@...r.kernel.org>,
	Kernel Testers List <kernel-testers@...r.kernel.org>,
	Dmitry Torokhov <dmitry.torokhov@...il.com>,
	Ed Tomlinson <edt@....ca>,
	OGAWA Hirofumi <hirofumi@...l.parknet.co.jp>
Subject: Re: [Bug #14388] keyboard under X with 2.6.31
On Tue, 13 Oct 2009, Alan Cox wrote:
> 
> I can't help feeling a mutex might be simpler. It would also then fix
> tiocsti() which is most definitely broken right now and documented as
> racing.
Hmm. Those tty's have too many different locks already.
But maybe we could just have one generic mutex, and use it for termios and 
IO locking. It makes perfect sense to serialize the ->receive_buf() code 
with any termios changes, since termios is what affects _how_ that 
->receive_buf() function works.
I do wonder why tiocsti() doesn't just use the tty buffering layer, 
though? Maybe that harks back to the whole "pty's did things differently" 
thing? Why does it go directly to ->receive_buf() in the first place?
And let's see if my patch even makes a difference. Maybe the breakage is 
somewhere else. The "oh, now we call flush_ldisc() from two different 
contexts" thing seems to be a promising lead, but ...
		Linus
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/
Powered by blists - more mailing lists