Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1756171AbaFQLcU (ORCPT ); Tue, 17 Jun 2014 07:32:20 -0400 Received: from mailout32.mail01.mtsvc.net ([216.70.64.70]:50156 "EHLO n23.mail01.mtsvc.net" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1754281AbaFQLcT (ORCPT ); Tue, 17 Jun 2014 07:32:19 -0400 Message-ID: <53A0273F.70400@hurleysoftware.com> Date: Tue, 17 Jun 2014 07:32:15 -0400 From: Peter Hurley User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:24.0) Gecko/20100101 Thunderbird/24.5.0 MIME-Version: 1.0 To: David Laight , Arnd Bergmann CC: "linuxppc-dev@lists.ozlabs.org" , Greg Kroah-Hartman , Karsten Keil , "linux-kernel@vger.kernel.org" , "linux-serial@vger.kernel.org" , One Thousand Gnomes Subject: Re: [PATCH tty-next 14/22] tty: Remove tty_wait_until_sent_from_close() References: <1402924639-5164-1-git-send-email-peter@hurleysoftware.com> <1402924639-5164-15-git-send-email-peter@hurleysoftware.com> <4575870.N9RCpZ4UMg@wuerfel> <53A01F02.7000202@hurleysoftware.com> <063D6719AE5E284EB5DD2968C1650D6D1725DAF6@AcuExch.aculab.com> In-Reply-To: <063D6719AE5E284EB5DD2968C1650D6D1725DAF6@AcuExch.aculab.com> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit X-Authenticated-User: 990527 peter@hurleysoftware.com X-MT-ID: 8FA290C2A27252AACF65DBC4A42F3CE3735FB2A4 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 06/17/2014 07:03 AM, David Laight wrote: > From: Peter Hurley > ... >>> I don't understand the second half of the changelog, it doesn't seem >>> to fit here: there deadlock that we are trying to avoid here happens >>> when the *same* tty needs the lock to complete the function that >>> sends the pending data. I don't think we do still do that any more, >>> but it doesn't seem related to the tty lock being system-wide or not. >> >> The tty lock is not used in the i/o path; it's purpose is to >> mutually exclude state changes in open(), close() and hangup(). >> >> The commit that added this [1] comments that _other_ ttys may wait >> for this tty to complete, and comments in the code note that this >> function should be removed when the system-wide tty mutex was removed >> (which happened with the commit noted in the changelog). > > What happens if another process tries to do a non-blocking open > while you are sleeping in close waiting for output to drain? > > Hopefully this returns before that data has drained. Good point. tty_open() should be trylocking both mutexes anyway in O_NONBLOCK. Regards, Peter Hurley -- 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/