# $NetBSD: bsd.sys.mk,v 1.104 2003/10/21 10:01:22 lukem Exp $ # # Build definitions used for NetBSD source tree builds. .if !defined(_BSD_SYS_MK_) _BSD_SYS_MK_=1 MAKEVERBOSE?= 2 .if ${MAKEVERBOSE} == 0 _MKMSG= @\# _MKSHMSG= : echo _MKSHECHO= : echo .elif ${MAKEVERBOSE} == 1 _MKMSG= @echo ' ' _MKSHMSG= echo ' ' _MKSHECHO= : echo .else # MAKEVERBOSE == 2 ? _MKMSG= @echo '\# ' _MKSHMSG= echo '\# ' _MKSHECHO= echo .endif _MKMSG_BUILD= ${_MKMSG} " build " _MKMSG_CREATE= ${_MKMSG} " create " _MKMSG_COMPILE= ${_MKMSG} "compile " _MKMSG_FORMAT= ${_MKMSG} " format " _MKMSG_INSTALL= ${_MKMSG} "install " _MKMSG_LINK= ${_MKMSG} " link " _MKMSG_LEX= ${_MKMSG} " lex " _MKMSG_REMOVE= ${_MKMSG} " remove " _MKMSG_YACC= ${_MKMSG} " yacc " _MKTARGET_BUILD= ${_MKMSG_BUILD} ${.TARGET} _MKTARGET_CREATE= ${_MKMSG_CREATE} ${.TARGET} _MKTARGET_COMPILE= ${_MKMSG_COMPILE} ${.TARGET} _MKTARGET_FORMAT= ${_MKMSG_FORMAT} ${.TARGET} _MKTARGET_INSTALL= ${_MKMSG_INSTALL} ${.TARGET} _MKTARGET_LINK= ${_MKMSG_LINK} ${.TARGET} _MKTARGET_LEX= ${_MKMSG_LEX} ${.TARGET} _MKTARGET_REMOVE= ${_MKMSG_REMOVE} ${.TARGET} _MKTARGET_YACC= ${_MKMSG_YACC} ${.TARGET} .if defined(WARNS) .if ${WARNS} > 0 CFLAGS+= -Wall -Wstrict-prototypes -Wmissing-prototypes -Wpointer-arith #CFLAGS+= -Wmissing-declarations -Wredundant-decls -Wnested-externs # Add -Wno-sign-compare. -Wsign-compare is included in -Wall as of GCC 3.3, # but our sources aren't up for it yet. Also, add -Wno-traditional because # gcc includes #elif in the warnings, which is 'this code will not compile # in a traditional environment' warning, as opposed to 'this code behaves # differently in traditional and ansi environments' which is the warning # we wanted, and now we don't get anymore. CFLAGS+= -Wno-sign-compare -Wno-traditional # XXX Delete -Wuninitialized by default for now -- the compiler doesn't # XXX always get it right. CFLAGS+= -Wno-uninitialized .endif .if ${WARNS} > 1 CFLAGS+= -Wreturn-type -Wswitch -Wshadow .endif .if ${WARNS} > 2 CFLAGS+= -Wcast-qual -Wwrite-strings .endif .endif .if defined(WFORMAT) && defined(FORMAT_AUDIT) .if ${WFORMAT} > 1 CFLAGS+= -Wnetbsd-format-audit -Wno-format-extra-args .endif .endif CPPFLAGS+= ${AUDIT:D-D__AUDIT__} CFLAGS+= ${CWARNFLAGS} ${NOGCCERROR:D:U-Werror} LINTFLAGS+= ${DESTDIR:D-d ${DESTDIR}/usr/include} .if defined(MKSOFTFLOAT) && (${MKSOFTFLOAT} != "no") COPTS+= -msoft-float FOPTS+= -msoft-float .endif .if defined(MKIEEEFP) && (${MKIEEEFP} != "no") .if ${MACHINE_ARCH} == "alpha" CFLAGS+= -mieee FFLAGS+= -mieee .endif .endif .if ${MACHINE} == "sparc64" && ${MACHINE_ARCH} == "sparc" CFLAGS+= -Wa,-Av8plus .endif CFLAGS+= ${CPUFLAGS} # Helpers for cross-compiling HOST_CC?= cc HOST_CFLAGS?= -O HOST_COMPILE.c?=${HOST_CC} ${HOST_CFLAGS} ${HOST_CPPFLAGS} -c HOST_LINK.c?= ${HOST_CC} ${HOST_CFLAGS} ${HOST_CPPFLAGS} ${HOST_LDFLAGS} HOST_CXX?= c++ HOST_CXXFLAGS?= -O HOST_CPP?= cpp HOST_CPPFLAGS?= HOST_LD?= ld HOST_LDFLAGS?= HOST_AR?= ar HOST_RANLIB?= ranlib .if !empty(HOST_CYGWIN) HOST_SH?= /usr/bin/bash .else HOST_SH?= sh .endif ELF2ECOFF?= elf2ecoff MKDEP?= mkdep OBJCOPY?= objcopy STRIP?= strip TOOL_ASN1_COMPILE?= asn1_compile TOOL_CAP_MKDB?= cap_mkdb TOOL_CAT?= cat TOOL_CKSUM?= cksum TOOL_COMPILE_ET?= compile_et TOOL_CONFIG?= config TOOL_CRUNCHGEN?= crunchgen TOOL_CTAGS?= ctags TOOL_DB?= db TOOL_EQN?= eqn TOOL_FGEN?= fgen TOOL_GENCAT?= gencat TOOL_GROFF?= groff TOOL_HEXDUMP?= hexdump TOOL_INDXBIB?= indxbib TOOL_INSTALLBOOT?= installboot TOOL_INSTALL_INFO?= install-info TOOL_M4?= m4 TOOL_MAKEFS?= makefs TOOL_MAKEINFO?= makeinfo TOOL_MAKEWHATIS?= /usr/libexec/makewhatis TOOL_MDSETIMAGE?= mdsetimage TOOL_MENUC?= menuc TOOL_MKCSMAPPER?= mkcsmapper TOOL_MKESDB?= mkesdb TOOL_MKLOCALE?= mklocale TOOL_MKMAGIC?= file TOOL_MKTEMP?= mktemp TOOL_MSGC?= msgc TOOL_MTREE?= mtree TOOL_PAX?= pax TOOL_PIC?= pic TOOL_PREPMKBOOTIMAGE?= prep-mkbootimage TOOL_PWD_MKDB?= pwd_mkdb TOOL_REFER?= refer TOOL_ROFF_ASCII?= nroff TOOL_ROFF_DVI?= ${TOOL_GROFF} -Tdvi TOOL_ROFF_HTML?= ${TOOL_GROFF} -Tlatin1 -mdoc2html TOOL_ROFF_PS?= ${TOOL_GROFF} -Tps TOOL_ROFF_RAW?= ${TOOL_GROFF} -Z TOOL_RPCGEN?= rpcgen TOOL_SOELIM?= soelim TOOL_STAT?= stat TOOL_SUNLABEL?= sunlabel TOOL_TBL?= tbl TOOL_UUDECODE?= uudecode TOOL_VGRIND?= vgrind -f TOOL_ZIC?= zic .SUFFIXES: .c .cc .cpp .cxx .C .m .o .ln .lo .s .S .l .y ${YHEADER:D.h} # C .c: ${_MKTARGET_COMPILE} ${LINK.c} ${COPTS.${.IMPSRC:T}} ${CPUFLAGS.${.IMPSRC:T}} ${CPPFLAGS.${.IMPSRC:T}} -o ${.TARGET} ${.IMPSRC} ${LDLIBS} .c.o: ${_MKTARGET_COMPILE} ${COMPILE.c} ${COPTS.${.IMPSRC:T}} ${CPUFLAGS.${.IMPSRC:T}} ${CPPFLAGS.${.IMPSRC:T}} ${.IMPSRC} .c.ln: ${_MKTARGET_COMPILE} ${LINT} ${LINTFLAGS} ${CPPFLAGS:M-[IDU]*} ${CPPFLAGS.${.IMPSRC:T}:M-[IDU]*} -i ${.IMPSRC} # C++ .cc .cpp .cxx .C: ${_MKTARGET_COMPILE} ${LINK.cc} ${COPTS.${.IMPSRC:T}} ${CPUFLAGS.${.IMPSRC:T}} ${CPPFLAGS.${.IMPSRC:T}} -o ${.TARGET} ${.IMPSRC} ${LDLIBS} .cc.o .cpp.o .cxx.o .C.o: ${_MKTARGET_COMPILE} ${COMPILE.cc} ${COPTS.${.IMPSRC:T}} ${CPUFLAGS.${.IMPSRC:T}} ${CPPFLAGS.${.IMPSRC:T}} ${.IMPSRC} # Objective C # (Defined here rather than in because `.m' is not just # used for Objective C source) .m: ${_MKTARGET_COMPILE} ${LINK.m} -o ${.TARGET} ${.IMPSRC} ${LDLIBS} .m.o: ${_MKTARGET_COMPILE} ${COMPILE.m} ${.IMPSRC} # Host-compiled C objects # The intermediate step is necessary for Sun CC, which objects to calling # object files anything but *.o .c.lo: ${_MKTARGET_COMPILE} ${HOST_COMPILE.c} -o ${.TARGET}.o ${.IMPSRC} mv ${.TARGET}.o ${.TARGET} # Assembly .s: ${_MKTARGET_COMPILE} ${LINK.s} ${COPTS.${.IMPSRC:T}} ${CPUFLAGS.${.IMPSRC:T}} ${CPPFLAGS.${.IMPSRC:T}} -o ${.TARGET} ${.IMPSRC} ${LDLIBS} .s.o: ${_MKTARGET_COMPILE} ${COMPILE.s} ${COPTS.${.IMPSRC:T}} ${CPUFLAGS.${.IMPSRC:T}} ${CPPFLAGS.${.IMPSRC:T}} ${.IMPSRC} .S: ${_MKTARGET_COMPILE} ${LINK.S} ${COPTS.${.IMPSRC:T}} ${CPUFLAGS.${.IMPSRC:T}} ${CPPFLAGS.${.IMPSRC:T}} -o ${.TARGET} ${.IMPSRC} ${LDLIBS} .S.o: ${_MKTARGET_COMPILE} ${COMPILE.S} ${COPTS.${.IMPSRC:T}} ${CPUFLAGS.${.IMPSRC:T}} ${CPPFLAGS.${.IMPSRC:T}} ${.IMPSRC} # Lex LPREFIX?= yy LFLAGS+= -P${LPREFIX} .l.o: # remove to force use of .l.c->.c.o transforms .l: ${_MKTARGET_LEX} ${LEX.l} -o${.TARGET:R}.${LPREFIX}.c ${.IMPSRC} ${LINK.c} ${COPTS.${.IMPSRC:T}} ${CPUFLAGS.${.IMPSRC:T}} ${CPPFLAGS.${.IMPSRC:T}} -o ${.TARGET} ${.TARGET:R}.${LPREFIX}.c ${LDLIBS} -ll rm -f ${.TARGET:R}.${LPREFIX}.c .l.c: ${_MKTARGET_LEX} ${LEX.l} -o${.TARGET} ${.IMPSRC} # Yacc YFLAGS+= ${YPREFIX:D-p${YPREFIX}} ${YHEADER:D-d} .y.o: # remove to force use of .y.c->.c.o transforms .y: ${_MKTARGET_YACC} ${YACC.y} -b ${.TARGET:R} ${.IMPSRC} ${LINK.c} ${COPTS.${.IMPSRC:T}} ${CPUFLAGS.${.IMPSRC:T}} ${CPPFLAGS.${.IMPSRC:T}} -o ${.TARGET} ${.TARGET:R}.tab.c ${LDLIBS} rm -f ${.TARGET:R}.tab.[ch] .y.c: ${_MKTARGET_YACC} ${YACC.y} -o ${.TARGET} ${.IMPSRC} .ifdef YHEADER .y.h: ${.TARGET:.h=.c} .endif .endif # !defined(_BSD_SYS_MK_)