Skip site navigation (1)Skip section navigation (2)
Date:      Thu, 21 Apr 2005 10:00:11 +0300
From:      Ruslan Ermilov <ru@FreeBSD.org>
To:        Bruce Evans <bde@zeta.org.au>
Cc:        David O'Brien <obrien@FreeBSD.org>
Subject:   Re: cvs commit: src/sys/conf kmod.mk
Message-ID:  <20050421070011.GA81229@ip.net.ua>
In-Reply-To: <20050421125501.W88810@delplex.bde.org>
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>

next in thread | previous in thread | raw e-mail | index | archive | help

--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--



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20050421070011.GA81229>