Makefile.luna68k revision 1.11
11.11Sjmc#	$NetBSD: Makefile.luna68k,v 1.11 2001/10/26 06:45:37 jmc Exp $
21.1Snisimura
31.1Snisimura# Makefile for NetBSD
41.1Snisimura#
51.1Snisimura# This makefile is constructed from a machine description:
61.1Snisimura#	config machineid
71.1Snisimura# Most changes should be made in the machine description
81.1Snisimura#	/sys/arch/luna68k/conf/``machineid''
91.1Snisimura# after which you should do
101.1Snisimura#	config machineid
111.1Snisimura# Machine generic makefile changes should be made in
121.1Snisimura#	/sys/arch/luna68k/conf/Makefile.luna68k
131.1Snisimura# after which config should be rerun for all machines of that type.
141.10Sthorpej
151.10SthorpejMACHINE_ARCH=m68k
161.11SjmcUSETOOLS?=	no
171.11Sjmc
181.11Sjmc.include <bsd.own.mk>
191.1Snisimura
201.1Snisimura# DEBUG is set to -g if debugging.
211.1Snisimura# PROF is set to -pg if profiling.
221.1Snisimura
231.1SnisimuraAR?=	ar
241.1SnisimuraAS?=	as
251.1SnisimuraCC?=	cc
261.1SnisimuraCPP?=	cpp
271.1SnisimuraLD?=	ld
281.1SnisimuraLORDER?=lorder
291.1SnisimuraMKDEP?=	mkdep
301.1SnisimuraNM?=	nm
311.1SnisimuraRANLIB?=ranlib
321.1SnisimuraSIZE?=	size
331.5StsutsuiSTRIP?=	strip
341.1SnisimuraTSORT?=	tsort -q
351.1SnisimuraOBJCOPY?= objcopy
361.1Snisimura
371.1SnisimuraCOPTS?= -O2
381.1Snisimura
391.1Snisimura# source tree is located via $S relative to the compilation directory
401.1Snisimura.ifndef S
411.1SnisimuraS!=	cd ../../../..; pwd
421.1Snisimura.endif
431.1SnisimuraLUNA68K=$S/arch/luna68k
441.1Snisimura
451.1Snisimura# Override CPP defaults entirely, so cross-compilation works.
461.1Snisimura# Keep -nostdinc before all -I flags, similar for -undef ...
471.6SthorpejHAVE_EGCS!=	${CC} --version | egrep "^(2\.[89]|egcs)" ; echo 
481.1SnisimuraINCLUDES=	-nostdinc -I. -I$S/arch -I$S
491.9SmrgCPPFLAGS=	${INCLUDES} ${IDENT} ${PARAM} -D_KERNEL -D_KERNEL_OPT -Dluna68k
501.6SthorpejCWARNFLAGS?=	-Werror -Wall -Wstrict-prototypes -Wmissing-prototypes \
511.6Sthorpej		-Wpointer-arith
521.6Sthorpej# XXX Delete -Wuninitialized for now, since the compiler doesn't
531.6Sthorpej# XXX always get it right.  --thorpej 
541.6SthorpejCWARNFLAGS+=    -Wno-uninitialized
551.6Sthorpej.if (${HAVE_EGCS} != "")
561.1SnisimuraCWARNFLAGS+=	-Wno-main
571.1Snisimura.endif
581.1SnisimuraCFLAGS=		${DEBUG} ${COPTS} ${CWARNFLAGS} -msoft-float
591.1SnisimuraAFLAGS=		-x assembler-with-cpp -traditional-cpp -D_LOCORE
601.1SnisimuraLINKFLAGS=	-N -Ttext 0xc000 -e start
611.2StsutsuiSTRIPFLAGS=	-g
621.1Snisimura
631.1Snisimura%INCLUDES
641.1Snisimura
651.1SnisimuraHOSTED_CC=	${CC}
661.1SnisimuraHOSTED_CPPFLAGS=${CPPFLAGS:S/^-nostdinc$//}
671.1SnisimuraHOSTED_CFLAGS=	${CFLAGS}
681.1Snisimura
691.1Snisimura### find out what to use for libkern
701.1Snisimura.include "$S/lib/libkern/Makefile.inc"
711.1Snisimura.ifndef PROF
721.1SnisimuraLIBKERN=	${KERNLIB}
731.1Snisimura.else
741.1SnisimuraLIBKERN=	${KERNLIB_PROF}
751.1Snisimura.endif
761.1Snisimura
771.1Snisimura### find out what to use for libcompat
781.1Snisimura.include "$S/compat/common/Makefile.inc"
791.1Snisimura.ifndef PROF
801.1SnisimuraLIBCOMPAT=	${COMPATLIB}
811.1Snisimura.else
821.1SnisimuraLIBCOMPAT=	${COMPATLIB_PROF}
831.1Snisimura.endif
841.1Snisimura
851.1Snisimura### for the Motorola 68040 Floating Point Software Product
861.1Snisimura# .include "$S/arch/m68k/fpsp/Makefile.inc"
871.1Snisimura
881.1Snisimura# compile rules: rules are named ${TYPE}_${SUFFIX} where TYPE is NORMAL or
891.1Snisimura# HOSTED}, and SUFFIX is the file suffix, capitalized (e.g. C for a .c file).
901.1Snisimura
911.1SnisimuraNORMAL_C=	${CC} ${CFLAGS} ${CPPFLAGS} ${PROF} -c $<
921.1SnisimuraNOPROF_C=	${CC} ${CFLAGS} ${CPPFLAGS} -c $<
931.1SnisimuraNORMAL_S=	${CC} ${AFLAGS} ${CPPFLAGS} -c $<
941.1Snisimura
951.1SnisimuraHOSTED_C=	${HOSTED_CC} ${HOSTED_CFLAGS} ${HOSTED_CPPFLAGS} -c $<
961.1Snisimura
971.1Snisimura%OBJS
981.1Snisimura
991.1Snisimura%CFILES
1001.1Snisimura
1011.1Snisimura%SFILES
1021.1Snisimura
1031.1Snisimura# load lines for config "xxx" will be emitted as:
1041.1Snisimura# xxx: ${SYSTEM_DEP} swapxxx.o
1051.1Snisimura#	${SYSTEM_LD_HEAD}
1061.1Snisimura#	${SYSTEM_LD} swapxxx.o
1071.1Snisimura#	${SYSTEM_LD_TAIL}
1081.1SnisimuraSYSTEM_OBJ=	locore.o ${FPSP} \
1091.1Snisimura		param.o ioconf.o ${OBJS} ${LIBCOMPAT} ${LIBKERN}
1101.1SnisimuraSYSTEM_DEP=	Makefile ${SYSTEM_OBJ}
1111.1SnisimuraSYSTEM_LD_HEAD=	@rm -f $@
1121.1SnisimuraSYSTEM_LD=	@echo ${LD} ${LINKFLAGS} -o $@ '$${SYSTEM_OBJ}' vers.o; \
1131.1Snisimura		${LD} ${LINKFLAGS} -o $@ ${SYSTEM_OBJ} vers.o
1141.1SnisimuraSYSTEM_LD_TAIL=	@${SIZE} $@; chmod 755 $@
1151.1Snisimura
1161.1SnisimuraDEBUG?=
1171.1Snisimura.if ${DEBUG} == "-g"
1181.1SnisimuraLINKFLAGS+=	-X
1191.1SnisimuraSYSTEM_LD_TAIL+=; \
1201.1Snisimura		echo mv -f $@ $@.gdb; mv -f $@ $@.gdb; \
1211.5Stsutsui		echo ${STRIP} ${STRIPFLAGS} -o $@ $@.gdb; \
1221.5Stsutsui		${STRIP} ${STRIPFLAGS} -o $@ $@.gdb
1231.1Snisimura.else
1241.1SnisimuraLINKFLAGS+=	-S
1251.1Snisimura.endif
1261.1Snisimura
1271.1Snisimura%LOAD
1281.1Snisimura
1291.1Snisimuraassym.h: $S/kern/genassym.sh ${LUNA68K}/luna68k/genassym.cf
1301.1Snisimura	sh $S/kern/genassym.sh ${CC} ${CFLAGS} ${CPPFLAGS} ${PROF} \
1311.1Snisimura	    < ${LUNA68K}/luna68k/genassym.cf > assym.h.tmp && \
1321.1Snisimura	mv -f assym.h.tmp assym.h
1331.1Snisimura
1341.1Snisimuraparam.c: $S/conf/param.c
1351.1Snisimura	rm -f param.c
1361.1Snisimura	cp $S/conf/param.c .
1371.1Snisimura
1381.1Snisimuraparam.o: param.c Makefile
1391.1Snisimura	${NORMAL_C}
1401.1Snisimura
1411.1Snisimuraioconf.o: ioconf.c
1421.1Snisimura	${NORMAL_C}
1431.1Snisimura
1441.1Snisimuranewvers: ${SYSTEM_DEP} ${SYSTEM_SWAP_DEP}
1451.1Snisimura	sh $S/conf/newvers.sh
1461.1Snisimura	${CC} ${CFLAGS} ${CPPFLAGS} ${PROF} -c vers.c
1471.1Snisimura
1481.1Snisimura__CLEANKERNEL: .USE
1491.1Snisimura	@echo "${.TARGET}ing the kernel objects"
1501.1Snisimura	rm -f eddep *netbsd netbsd.gdb tags *.[io] [a-z]*.s \
1511.1Snisimura	    [Ee]rrs linterrs makelinks assym.h.tmp assym.h
1521.1Snisimura
1531.1Snisimura__CLEANDEPEND: .USE
1541.1Snisimura	rm -f .depend
1551.1Snisimura
1561.1Snisimuraclean: __CLEANKERNEL
1571.1Snisimura
1581.1Snisimuracleandir distclean: __CLEANKERNEL __CLEANDEPEND
1591.1Snisimura
1601.1Snisimuralint:
1611.1Snisimura	@lint -hbxncez -Dvolatile= ${CPPFLAGS} -UKGDB \
1621.1Snisimura	    ${CFILES} ioconf.c param.c | \
1631.1Snisimura	    grep -v 'static function .* unused'
1641.1Snisimura
1651.1Snisimuratags:
1661.1Snisimura	@echo "see $S/kern/Makefile for tags"
1671.1Snisimura
1681.1Snisimuralinks:
1691.1Snisimura	egrep '#if' ${CFILES} | sed -f $S/conf/defines | \
1701.1Snisimura	  sed -e 's/:.*//' -e 's/\.c/.o/' | sort -u > dontlink
1711.1Snisimura	echo ${CFILES} | tr -s ' ' '\12' | sed 's/\.c/.o/' | \
1721.1Snisimura	  sort -u | comm -23 - dontlink | \
1731.1Snisimura	  sed 's,../.*/\(.*.o\),rm -f \1; ln -s ../GENERIC/\1 \1,' > makelinks
1741.1Snisimura	sh makelinks && rm -f dontlink
1751.1Snisimura
1761.1SnisimuraSRCS=	${LUNA68K}/luna68k/locore.s \
1771.1Snisimura	param.c ioconf.c ${CFILES} ${SFILES}
1781.1Snisimuradepend: .depend
1791.1Snisimura.depend: ${SRCS} assym.h param.c
1801.1Snisimura	${MKDEP} ${AFLAGS} ${CPPFLAGS} ${LUNA68K}/luna68k/locore.s
1811.1Snisimura	${MKDEP} -a ${CFLAGS} ${CPPFLAGS} param.c ioconf.c ${CFILES}
1821.1Snisimura	sh $S/kern/genassym.sh ${MKDEP} -f assym.dep ${CFLAGS} \
1831.1Snisimura	  ${CPPFLAGS} < ${LUNA68K}/luna68k/genassym.cf
1841.1Snisimura	@sed -e 's/.*\.o:.*\.c/assym.h:/' < assym.dep >> .depend
1851.1Snisimura	@rm -f assym.dep
1861.4Stron
1871.4Strondependall: depend all
1881.4Stron
1891.1Snisimura
1901.1Snisimura# depend on root or device configuration
1911.1Snisimuraautoconf.o conf.o: Makefile
1921.1Snisimura 
1931.1Snisimura# depend on network or filesystem configuration 
1941.1Snisimurauipc_proto.o vfs_conf.o: Makefile 
1951.1Snisimura
1961.1Snisimura# depend on maxusers
1971.1Snisimuramachdep.o: Makefile
1981.1Snisimura
1991.1Snisimura# depend on CPU configuration 
2001.1Snisimuramachdep.c trap.o: Makefile
2011.1Snisimura
2021.1Snisimuralocore.o: ${LUNA68K}/luna68k/locore.s assym.h
2031.1Snisimura	${NORMAL_S}
2041.7Shubertf
2051.7Shubertf# The install target can be redefined by putting a
2061.7Shubertf# install-kernel-${MACHINE_NAME} target into /etc/mk.conf
2071.7ShubertfMACHINE_NAME!=  uname -n
2081.7Shubertfinstall: install-kernel-${MACHINE_NAME}
2091.7Shubertf.if !target(install-kernel-${MACHINE_NAME}})
2101.7Shubertfinstall-kernel-${MACHINE_NAME}:
2111.7Shubertf	rm -f /onetbsd
2121.7Shubertf	ln /netbsd /onetbsd
2131.7Shubertf	cp netbsd /nnetbsd
2141.7Shubertf	mv /nnetbsd /netbsd
2151.7Shubertf.endif
2161.1Snisimura
2171.1Snisimura%RULES
218