For a while I've been getting a build error on aicasm during the early
steps of the build.  Today I finally dug into it and discovered it's
because the build is using a mix of header files, some from /usr/include
on the build host, and some from obj/... for the target being built.  It
happens because dev/aic7xxx/aicasm/Makefile contains CFLAGS+= -I. and
the current directory when aicasm builds is obj/.../<kernconf>.  In my
case it was picking up machine/_types.h from objdir.

Apparently this is usually harmless, but if the build host system and
the target versions are far enough apart, or with a cross-build where
the host and target are different architectures, you can get problems.  

After a little digging, I just now discovered Marcel fixed this long ago
in r70000, but then it got undone in r236578 a couple months ago.  Is
there any reason not to restore Marcel's fix, such as with the attached
patch?

-- Ian


diff -r 00739d74c495 sys/dev/aic7xxx/aicasm/Makefile
--- sys/dev/aic7xxx/aicasm/Makefile	Sat Sep 14 09:55:04 2013 -0600
+++ sys/dev/aic7xxx/aicasm/Makefile	Sat Sep 14 11:44:09 2013 -0600
@@ -24,7 +24,8 @@ WARNS?=	5
 DEPENDFILE=	.depend_aicasm
 .endif
 
-CFLAGS+= -I.
+# Tool runs on the build host, must prefer /usr/include headers over obj/...
+CFLAGS+= -I/usr/include -I.
 .ifdef MAKESRCPATH
 CFLAGS+= -I${MAKESRCPATH}
 .endif
_______________________________________________
freebsd-current@freebsd.org mailing list
http://lists.freebsd.org/mailman/listinfo/freebsd-current
To unsubscribe, send any mail to "freebsd-current-unsubscr...@freebsd.org"

Reply via email to