From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S964921AbWFTEcb (ORCPT ); Tue, 20 Jun 2006 00:32:31 -0400 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S964918AbWFTEcb (ORCPT ); Tue, 20 Jun 2006 00:32:31 -0400 Received: from 1wt.eu ([62.212.114.60]:2569 "EHLO 1wt.eu") by vger.kernel.org with ESMTP id S964917AbWFTEca (ORCPT ); Tue, 20 Jun 2006 00:32:30 -0400 Date: Tue, 20 Jun 2006 06:28:02 +0200 From: Willy Tarreau To: David Luyer Cc: Samuel Thibault , "linux-os (Dick Johnson)" , linux-kernel@vger.kernel.org Subject: Re: emergency or init=/bin/sh mode and terminal signals Message-ID: <20060620042802.GI13255@w.ods.org> References: <20060619220920.GB5788@implementation.residence.ens-lyon.fr> Mime-Version: 1.0 Content-Type: text/plain; charset=iso-8859-1 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: User-Agent: Mutt/1.5.10i Sender: linux-kernel-owner@vger.kernel.org X-Mailing-List: linux-kernel@vger.kernel.org On Tue, Jun 20, 2006 at 10:02:23AM +1000, David Luyer wrote: > On 20/6/06 8:09 AM, "Samuel Thibault" wrote: > > linux-os (Dick Johnson), le Mon 19 Jun 2006 07:37:02 -0400, a écrit : > >> You can't allow some terminal input to affect init. It has been the > >> de facto standard in Unix, that the only time one should have a > >> controlling terminal is after somebody logs in and owns something to > >> control. > > > > Ok. The following still makes sense, doesn't it? (i.e. set a session for > > the emergency shell) > > > > --- linux-2.6.17-orig/init/main.c 2006-06-18 19:22:40.000000000 +0200 > > +++ linux-2.6.17-perso/init/main.c 2006-06-20 00:07:07.000000000 +0200 > > @@ -729,6 +729,11 @@ > > run_init_process("/sbin/init"); > > run_init_process("/etc/init"); > > run_init_process("/bin/init"); > > + > > + /* Set a session for the shell. */ > > + sys_setsid(); > > + sys_ioctl(0, TIOCSCTTY, 1); > > + > > run_init_process("/bin/sh"); > > > > panic("No init found. Try passing init= option to kernel."); > > What if people are booting via /bin/sh and then setting up > their custom chroot's and init(s), and don't want these init(s) to > be part of a session? > > It is also particularly possible for an embedded system to start > up via /bin/sh running /etc/profile rather than using an init type > program. > > Also, the above doesn't help people specifying "init=/bin/sh" on the > command line (as per the original post subject). The real solution > is for them to specify a different init= or run/exec something to set > up their tty and session once logged in. Then, I think that a solution which would fit everyone's needs would be to add a command line parameter (eg: "setsid=1") which will allow the two lines to be executed whatever the init or shell. This way, you want a session ? -> "init=/bin/sh setsid=1". Not particularly difficult to use and does not risk to break existing setups. > David. Cheers, Willy