From owner-freebsd-current Tue Apr 2 22:15:53 2002 Delivered-To: freebsd-current@freebsd.org Received: from rwcrmhc54.attbi.com (rwcrmhc54.attbi.com [216.148.227.87]) by hub.freebsd.org (Postfix) with ESMTP id 9A85637B4C2 for ; Tue, 2 Apr 2002 22:15:32 -0800 (PST) Received: from peter3.wemm.org ([12.232.27.13]) by rwcrmhc54.attbi.com (InterMail vM.4.01.03.27 201-229-121-127-20010626) with ESMTP id <20020403061532.BOVY15826.rwcrmhc54.attbi.com@peter3.wemm.org> for ; Wed, 3 Apr 2002 06:15:32 +0000 Received: from overcee.wemm.org (overcee.wemm.org [10.0.0.3]) by peter3.wemm.org (8.11.0/8.11.0) with ESMTP id g336FVx33129 for ; Tue, 2 Apr 2002 22:15:31 -0800 (PST) (envelope-from peter@wemm.org) Received: from wemm.org (localhost [127.0.0.1]) by overcee.wemm.org (Postfix) with ESMTP id B07353808; Tue, 2 Apr 2002 22:15:31 -0800 (PST) (envelope-from peter@wemm.org) X-Mailer: exmh version 2.5 07/13/2001 with nmh-1.0.4 To: cjclark@alum.mit.edu Cc: Terry Lambert , freebsd-current@FreeBSD.ORG, Emiel Kollof Subject: Re: kldxref problem In-Reply-To: <20020402215950.H52193@blossom.cjclark.org> Date: Tue, 02 Apr 2002 22:15:31 -0800 From: Peter Wemm Message-Id: <20020403061531.B07353808@overcee.wemm.org> Sender: owner-freebsd-current@FreeBSD.ORG Precedence: bulk List-ID: List-Archive: (Web Archive) List-Help: (List Instructions) List-Subscribe: List-Unsubscribe: X-Loop: FreeBSD.ORG "Crist J. Clark" wrote: > On Tue, Apr 02, 2002 at 04:45:13PM -0800, Peter Wemm wrote: > > "Crist J. Clark" wrote: > > > On Mon, Apr 01, 2002 at 03:07:46PM -0800, Terry Lambert wrote: > > > > "Crist J. Clark" wrote: > > > > > This whole argument ignores what the real problem is. The really > > > > > correct way to handle this is to use the kldxref(8) built in the > > > > > 'buildworld' phase. (It's bad form to be using any executables from > > > > > the base system if we have a full object tree.) Actually using the on e > > > > > in /usr/obj/usr/src/usr.sbin/kldxref seems pretty ugly. The better > > > > > thing to do is to have a version in /usr/obj/usr/src//usr/sbin > > > > > by making it a crosstool. The failure should not be ignored in this > > > > > case. > > > > > > > > Uh, that doesn't work incredibly well when the machine you > > > > are on is an x86, and the machine that the buildworld targets > > > > is, say, the Alpha. > > > > > > > > This came up in the first place because it's a cross-envrionment > > > > issue that needs resolving. The "workaround" exists because the > > > > workaround cops out on the cross-environment part of the process > > > > and spits out the warnming, instead. > > > > > > An 'installworld' doesn't even come close to working in a cross > > > environment for a whole variety of reasons, so I don't see the > > > relevance. > > > > It used to. If it no longer works, it should be fixed. I partially do thi s > > for cross-architecture builds quite often where the target system is NFS > > mounted somewhere. > > If it ever worked, without actually digging into the history, I would > guess that it was because it only used existing binaries in the host > environment to run the install. However, now a (somewhat half-baked) > effort is made to use newly built tools to do the install, rather than > the ones already on the host. It has worked several times, because I remember it turned up a gcc bug in the cross compiled gcc binaries. Specifically, if you did a 'make buildworld TARGET_ARCH=alpha', the compiler would generate invalid code unless you also used -O0. But it did work. I also recall somebody fixed it again relatively recently. > But that's somewhat of a digression. 'installkernel' will work in the > cross-platform case. It doesn't try to use build tools, but the tools > in the system. Using buildkernel/installkernel is your biggest mistake. It is no secret what I think of those two targets. > > kldxref however, does not have any cross capability, and is just a hint > > mechanism even then. It is not essential to run it. > > I don't think it is essential either, but it does break module > auto-loading until someone does run it. And this whole thread started > because people don't think the error message is asthetically pleasing. > > But to hopefully put an end to some of the idle chatter here, here are > patches to build a working kldxref(8) on 4-STABLE and 5-CURRENT in the > the cross-tool phase. The 'installkernel' of a 5-CURRENT build on > 4-STABLE system should not error on kldxref(8). > > Yes, it is a kludge. Comments? The patch is better than nothing, but do not include this part: > Index: src/sys/modules/Makefile > =================================================================== > RCS file: /export/freebsd/ncvs/src/sys/modules/Makefile,v > retrieving revision 1.236 > diff -u -r1.236 Makefile > --- src/sys/modules/Makefile 21 Mar 2002 09:15:38 -0000 1.236 > +++ src/sys/modules/Makefile 3 Apr 2002 01:57:18 -0000 > @@ -184,7 +184,7 @@ > .if !defined(NO_XREF) > .MAKEFLAGS:= ${.MAKEFLAGS} -DNO_XREF > afterinstall: > - -kldxref ${DESTDIR}${KMODDIR} > + kldxref ${DESTDIR}${KMODDIR} > .endif It should not be a kill-the-build event if the optional tool fails. Cheers, -Peter -- Peter Wemm - peter@wemm.org; peter@FreeBSD.org; peter@yahoo-inc.com "All of this is for nothing if we don't go to the stars" - JMS/B5 To Unsubscribe: send mail to majordomo@FreeBSD.org with "unsubscribe freebsd-current" in the body of the message