From owner-cvs-src@FreeBSD.ORG Thu Apr 21 07:00:27 2005 Return-Path: Delivered-To: cvs-src@freebsd.org Received: from mx1.FreeBSD.org (mx1.freebsd.org [216.136.204.125]) by hub.freebsd.org (Postfix) with ESMTP id 453E116A4CE; Thu, 21 Apr 2005 07:00:27 +0000 (GMT) Received: from tigra.ip.net.ua (tigra.ip.net.ua [82.193.96.10]) by mx1.FreeBSD.org (Postfix) with ESMTP id 2FCF243D45; Thu, 21 Apr 2005 07:00:26 +0000 (GMT) (envelope-from ru@ip.net.ua) Received: from localhost (rocky.ip.net.ua [82.193.96.2]) by tigra.ip.net.ua (8.12.11/8.12.11) with ESMTP id j3L73V9L051074; Thu, 21 Apr 2005 10:03:31 +0300 (EEST) (envelope-from ru@ip.net.ua) Received: from tigra.ip.net.ua ([82.193.96.10]) by localhost (rocky.ipnet [82.193.96.2]) (amavisd-new, port 10024) with LMTP id 71714-07; Thu, 21 Apr 2005 10:00:16 +0300 (EEST) Received: from heffalump.ip.net.ua (heffalump.ip.net.ua [82.193.96.213]) by tigra.ip.net.ua (8.12.11/8.12.11) with ESMTP id j3L73TdY051061 (version=TLSv1/SSLv3 cipher=DHE-RSA-AES256-SHA bits=256 verify=NO); Thu, 21 Apr 2005 10:03:29 +0300 (EEST) (envelope-from ru@ip.net.ua) Received: (from ru@localhost) by heffalump.ip.net.ua (8.13.3/8.13.3) id j3L70C5R081309; Thu, 21 Apr 2005 10:00:12 +0300 (EEST) (envelope-from ru) Date: Thu, 21 Apr 2005 10:00:11 +0300 From: Ruslan Ermilov To: Bruce Evans Message-ID: <20050421070011.GA81229@ip.net.ua> References: <200504182110.j3ILAc8J031298@repoman.freebsd.org> <20050418.152011.74745144.imp@bsdimp.com> <20050419182938.GA27941@dragon.NUXI.org> <20050420055904.GA33015@ip.net.ua> <20050420161212.GA52582@dragon.NUXI.org> <20050421125501.W88810@delplex.bde.org> Mime-Version: 1.0 Content-Type: multipart/signed; micalg=pgp-sha1; protocol="application/pgp-signature"; boundary="n8g4imXOkfNTN/H1" Content-Disposition: inline In-Reply-To: <20050421125501.W88810@delplex.bde.org> User-Agent: Mutt/1.5.9i X-Virus-Scanned: by amavisd-new at ip.net.ua cc: cvs-all@FreeBSD.org cc: cvs-src@FreeBSD.org cc: src-committers@FreeBSD.org cc: Warner Losh cc: David O'Brien Subject: Re: cvs commit: src/sys/conf kmod.mk X-BeenThere: cvs-src@freebsd.org X-Mailman-Version: 2.1.1 Precedence: list List-Id: CVS commit messages for the src tree List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Thu, 21 Apr 2005 07:00:27 -0000 --n8g4imXOkfNTN/H1 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline Content-Transfer-Encoding: quoted-printable On Thu, Apr 21, 2005 at 01:35:44PM +1000, Bruce Evans wrote: > On Wed, 20 Apr 2005, David O'Brien wrote: >=20 > >On Wed, Apr 20, 2005 at 08:59:05AM +0300, Ruslan Ermilov wrote: > >>This is easily fixable: > >> > >> make cleandepend > >> make depend > >> make > > > >Then why does 'make kernel-depend' do 'rm -f .depend'? >=20 > It is because: > (1) ${DEPENDFILE} is misspelled ".depend" > (2) "rm -f depend; mv .newdep .depend" is safer, or just more familiar > to its author, or gives better error handling than > "mv -f .newdep .depend". >=20 > The "rm -f" for kernel-depend has nothing to do with removing .depend > before making dependencies or with the bug that initiated this thread. > Dependencies have been written to .newdep and the rm -f is just a safety > belt for moving the new dependencies to the usual place. >=20 > Writing dependencies to .newdep instead of directly to .depend avoids > various problems, probably including the one that initiated this thread. > I think it was intended to only fix the cosmetic problems of losing the > old .depend file and leaving a half-baked .depend file if the make depend > step is aborted, but it fixes the problem that initiated this thread as > a side effect. >=20 Yes (we discussed this long ago). > If everything used ${DEPENDFILE} correctly, then "${DEPENDFILE}=3D.newdep > ${MAKE} _kernel-depend" should just work -- in particular, the old > dependencies shouldn't get in the way. >=20 make(1) is who reads .depend, hence the added complexity. > kernel-depend doesn't use > ${DEPENDFILE}, but it ensures that the old dependencies don't get in > the way by moving them out of the way. From kern.post.mk: >=20 > % kernel-depend: > % rm -f .olddep > % if [ -f .depend ]; then mv .depend .olddep; fi >=20 > Perhaps this should use mv -f instead of a separate rm -f. >=20 No. We want to remove .olddep even if .depend doesn't exist. > % ${MAKE} _kernel-depend >=20 > Invoking a new make ensures that the old dependencies are not used > (since they have been moved out of the way). >=20 > %=20 > % # The argument list can be very long, so use make -V and xargs to > % # pass it to mkdep. > % _kernel-depend: assym.s vnode_if.h ${BEFORE_DEPEND} ${CFILES} \ > % ${SYSTEM_CFILES} ${GEN_CFILES} ${SFILES} \ > % ${MFILES:T:S/.m$/.h/} > % if [ -f .olddep ]; then mv .olddep .depend; fi >=20 > This step moves the old dependencies back, so that they will be there > if the make is aborted. They are harmless now since make has already > decided dependecies without the old ones being present. >=20 Correct. > % rm -f .newdep >=20 > If we used "${DEPENDFILE}=3D.newdep ${MAKE} _kernel-depend", then we would > have to do this step in kernel-depend instead of here and we wouldn't > have to move .depend out of the way there or move it back here. This > is simpler. >=20 > % ${MAKE} -V CFILES -V SYSTEM_CFILES -V GEN_CFILES | \ > % MKDEP_CPP=3D"${CC} -E" CC=3D"${CC}" xargs mkdep -a -f .newdep=20 > ${CFLAGS} > % ${MAKE} -V SFILES | \ > % MKDEP_CPP=3D"${CC} -E" xargs mkdep -a -f .newdep ${ASM_CFLAGS} >=20 > Normal mkdep stuff except it it is too specialized to be handled by the > general "make depend" rule. >=20 > % rm -f .depend > % mv .newdep .depend >=20 > Move stuff back as explained above. >=20 > %=20 > % kernel-cleandepend: > % rm -f .depend >=20 > A subtarget of the standard cleandepend target. cleandepend and its > parts should not be part of depend or clean. >=20 > >I'm sitting in the kernel directory, I expect the ways of building > >modules to be as close to building the kernel (which is just a special > >.ko) as possible. > > > >We've never documented that 'make cleandepend' is nearly a required step > >for 'make depend' to be dependable. >=20 > It is a bug that it is. The bug is apparently that kmod.mk or possibly > bsd.dep.mk is missing the move-depend-file-out-of-the way code in the > above. >=20 Speaking of kern.*.mk, I consider it a bug that "make depend" followed by "make depend" rebuilds the .depend file. We need to decide if we want this behavior or not, and if we do, we should behave similarly in other places too, i.e., bsd.dep.mk. I proposed the following: with NO_CLEAN builds, default to always regenerating .depend files (by moving the old .depend files out of the way like is done in kern.post.mk), but provide a mean to skip regenerating .depend files, NO_CLEANDEPEND. Cheers, --=20 Ruslan Ermilov ru@FreeBSD.org FreeBSD committer --n8g4imXOkfNTN/H1 Content-Type: application/pgp-signature Content-Disposition: inline -----BEGIN PGP SIGNATURE----- Version: GnuPG v1.4.0 (FreeBSD) iD8DBQFCZ097qRfpzJluFF4RAmnTAJ45lPj7DrDOYkwwQn7u65oXXH1O9ACfbzX8 Y4RcLs9esvTGzXnwV1qdqe0= =+CSP -----END PGP SIGNATURE----- --n8g4imXOkfNTN/H1--