Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1755454AbZDUO13 (ORCPT ); Tue, 21 Apr 2009 10:27:29 -0400 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1755181AbZDUO1H (ORCPT ); Tue, 21 Apr 2009 10:27:07 -0400 Received: from mx3.mail.elte.hu ([157.181.1.138]:57355 "EHLO mx3.mail.elte.hu" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1754901AbZDUO1F (ORCPT ); Tue, 21 Apr 2009 10:27:05 -0400 Date: Tue, 21 Apr 2009 16:26:27 +0200 From: Ingo Molnar To: Jamie Lokier Cc: Arjan van de Ven , David VomLehn , "H. Peter Anvin" , Thomas Gleixner , Linus Torvalds , Linux Kernel Mailing List , Linux USB Mailing List , Linux Embedded Mailing List , Andrew Morton Subject: Re: Wait for console to become available, v3.2 Message-ID: <20090421142627.GA18129@elte.hu> References: <20090420234006.GA1958@cuplxvomd02.corp.sa.net> <20090421064346.GB8020@elte.hu> <20090421063549.3b71881d@infradead.org> <20090421135034.GA30114@elte.hu> <20090421140533.GA6375@shareable.org> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20090421140533.GA6375@shareable.org> User-Agent: Mutt/1.5.18 (2008-05-17) X-ELTE-VirusStatus: clean X-ELTE-SpamScore: -1.5 X-ELTE-SpamLevel: X-ELTE-SpamCheck: no X-ELTE-SpamVersion: ELTE 2.0 X-ELTE-SpamCheck-Details: score=-1.5 required=5.9 tests=BAYES_00 autolearn=no SpamAssassin version=3.2.3 -1.5 BAYES_00 BODY: Bayesian spam probability is 0 to 1% [score: 0.0000] Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2893 Lines: 69 * Jamie Lokier wrote: > Ingo Molnar wrote: > > * Arjan van de Ven wrote: > > > But more importantly... USB *CANNOT* do this fundamental > > > operation. USB does not have the capability to know when you have > > > seen all devices that are connected. Devices just show up a random > > > amount of time after you turn the power on for the bus.... there's > > > no "and now we've seen all" operation. > > > > Yes - and this is fundamentally true of any hotplug bus design. > > It's not fundamental, for devices you know are plugged in at boot. > All it takes is for the bus to support a synchronous "enumerate > all" procedure. That _could_ involve a timeout, but there are > better ways. But not for USB. > > > What i'm saying is: instead of "wait 2000 msecs, maybe it works > > out" hack, there should be a proper sleep+event based approach > > to the same. With perhaps a _timeout_ for the "no console > > arrived" negative case as well. (which timeout can be set to > > zero in the "I _know_ there's no console around".) > > Isn't the proposed code doing exactly that? It sleeps waiting for > a console, with a timeout of X msecs. If a console arrives before > that, doesn't it wake immediately? Yes - except that the timeout is aspecific. I.e. we'll time out even if the delay happens not due to a device arriving too late (or not arriving at all), but due to some earlier init step taking an unexpectedly long time. > > Do you see the fundamental design difference between the two > > solutions? > > The only difference I see is: If you asked for a USB console, the > timeout should begin relative to when the USB host driver kicks > the bus, not the first /dev/console open. > > Conceptually the timeout is a USB characteristic, not a generic > console one. > > For other (non-USB) devices which might take a while to > initialise, it should work as you describe. E.g. an ethernet TCP > console should register ("i'm trying to give you a console") > followed by ("got it") or ("failed, carry on without me"). I guess we could live with this one too but still it feels wrong to me. It would be much better to push the decision to time out into individual console drivers. Also, if we end up doing this - the patch, as proposed right now, appears to add a default 1000 msecs sleep to every __tty_open() call: +config PRINTK_CONSOLE_WAIT + int "Default number of milliseconds to wait for console device" + default 1000 Does this only delay init during a console-less bootup - or are there other later apps that might trigger the delay? Ingo -- 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/