From owner-freebsd-hackers@FreeBSD.ORG Tue Aug 2 03:03:43 2005 Return-Path: X-Original-To: freebsd-hackers@freebsd.org Delivered-To: freebsd-hackers@freebsd.org Received: from mx1.FreeBSD.org (mx1.freebsd.org [216.136.204.125]) by hub.freebsd.org (Postfix) with ESMTP id 3746616A420 for ; Tue, 2 Aug 2005 03:03:43 +0000 (GMT) (envelope-from brdavis@odin.ac.hmc.edu) Received: from odin.ac.hmc.edu (Odin.AC.HMC.Edu [134.173.32.75]) by mx1.FreeBSD.org (Postfix) with ESMTP id 6628C43D4C for ; Tue, 2 Aug 2005 03:03:42 +0000 (GMT) (envelope-from brdavis@odin.ac.hmc.edu) Received: from odin.ac.hmc.edu (localhost.localdomain [127.0.0.1]) by odin.ac.hmc.edu (8.13.0/8.13.0) with ESMTP id j7233dKr004575; Mon, 1 Aug 2005 20:03:39 -0700 Received: (from brdavis@localhost) by odin.ac.hmc.edu (8.13.0/8.13.0/Submit) id j7233dbG004574; Mon, 1 Aug 2005 20:03:39 -0700 Date: Mon, 1 Aug 2005 20:03:39 -0700 From: Brooks Davis To: diz@linuxpowered.com Message-ID: <20050802030339.GA3993@odin.ac.hmc.edu> References: <64511.68.95.232.238.1122917387.squirrel@68.95.232.238> <20050801204038.GW62369@funkthat.com> <53362.68.95.232.238.1122950874.squirrel@68.95.232.238> Mime-Version: 1.0 Content-Type: multipart/signed; micalg=pgp-sha1; protocol="application/pgp-signature"; boundary="fUYQa+Pmc3FrFX/N" Content-Disposition: inline In-Reply-To: <53362.68.95.232.238.1122950874.squirrel@68.95.232.238> User-Agent: Mutt/1.4.1i X-Virus-Scanned: by amavisd-new X-Spam-Status: No, hits=0.0 required=8.0 tests=none autolearn=no version=2.63 X-Spam-Checker-Version: SpamAssassin 2.63 (2004-01-11) on odin.ac.hmc.edu Cc: freebsd-hackers@freebsd.org, John-Mark Gurney Subject: Re: [patch] rc.d cleanup X-BeenThere: freebsd-hackers@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: Technical Discussions relating to FreeBSD List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Tue, 02 Aug 2005 03:03:43 -0000 --fUYQa+Pmc3FrFX/N Content-Type: text/plain; charset=us-ascii Content-Disposition: inline Content-Transfer-Encoding: quoted-printable On Mon, Aug 01, 2005 at 09:47:54PM -0500, diz@linuxpowered.com wrote: > > diz@linuxpowered.com wrote this message on Mon, Aug 01, 2005 at 12:29 > > -0500: > >> This has the result of reducing the size of the shell code, and reduci= ng > > > > Unless you cross a fs frag (usually 1024 bytes), i.e. reduce the scripts > > by an average of 512bytes *per* script, you will see no disk space savi= ngs > > from these changes... considering that on my 5.4-R system over half > > (73 of 124) are under a frag in size, it isn't that much... > > > > One thing that would be really useful for rc.d system is a way to cache > > the ordering on boot... On a slow system like a 200mhz arm, the rc > > ordering can take a long while.... > > > > -- > > John-Mark Gurney Voice: +1 415 225 5579 > > > > "All that I will do, has been done, All that I have, has not." > > >=20 >=20 > Ok thanks for the dirrection. Ask and thy shall receive. well a quick hack > at least to implement cache of rcorder, although from my tests even on old > hardware rcorder is quick. I wrote this in (cring) the long-spelled out > way. Anyways... don't forget to add the essential rc.conf knobs for the > two variables shown bellow. >=20 > [root@:/etc]# diff -u rc rc.new > --- rc Sun Jul 31 17:45:19 2005 > +++ rc.new Mon Aug 1 21:42:12 2005 > @@ -72,7 +72,17 @@ >=20 > skip=3D"-s nostart" > [ `/sbin/sysctl -n security.jail.jailed` -eq 1 ] && skip=3D"$skip -s noj= ail" > -files=3D`rcorder ${skip} /etc/rc.d/* 2>/dev/null` > +# check for a rc.conf knob to check for existing cache, and skip the > rcorder part > +if checkyesno ${rc_cache_enable} ; then > + if [ -f ${rc_cache_file} ] ; then > + files=3D`cat ${rc_cache_file}` > + else > + files=3D`rcorder ${skip} /etc/rc.d/* 2>/dev/null` > + echo "${files}" > ${rc_cache_file} > + fi > +else > + files=3D`rcorder ${skip} /etc/rc.d/* 2>/dev/null` > +fi >=20 > for _rc_elem in ${files}; do > run_rc_script ${_rc_elem} ${_boot} I'm pretty sure you don't have access to the contents of /etc/rc.conf in this context. You would have to use another mechanism to control this feature. I'd be tempted to use the existance of a cache file (probably /etc/rcorder.cache since it can't be outside /) and simply require users to regenerate it externally when they upgrade (I'd probably add code to mergemaster to handle it like the various database files). Note that we may well break the ability to do this is easily in 7.0 if we end up supporting ordering of local scripts. -- Brooks --=20 Any statement of the form "X is the one, true Y" is FALSE. PGP fingerprint 655D 519C 26A7 82E7 2529 9BF0 5D8E 8BE9 F238 1AD4 --fUYQa+Pmc3FrFX/N Content-Type: application/pgp-signature Content-Disposition: inline -----BEGIN PGP SIGNATURE----- Version: GnuPG v1.2.1 (GNU/Linux) iD8DBQFC7uKKXY6L6fI4GtQRAi93AJ9g+Tookdh2yU9cKaBzvzuL7bCz3wCfb35n 3nmCh7TW4ZhS8cMvG46CZXA= =AHsp -----END PGP SIGNATURE----- --fUYQa+Pmc3FrFX/N--