Makefile.next68k revision 1.22
11.22Slukem# $NetBSD: Makefile.next68k,v 1.22 2001/11/20 12:56:35 lukem Exp $ 21.1Sdbj 31.1Sdbj# Makefile for NetBSD 41.1Sdbj# 51.1Sdbj# This makefile is constructed from a machine description: 61.1Sdbj# config machineid 71.1Sdbj# Most changes should be made in the machine description 81.1Sdbj# /sys/arch/next68k/conf/``machineid'' 91.1Sdbj# after which you should do 101.1Sdbj# config machineid 111.1Sdbj# Machine generic makefile changes should be made in 121.1Sdbj# /sys/arch/next68k/conf/Makefile.next68k 131.1Sdbj# after which config should be rerun for all machines of that type. 141.20Sthorpej 151.20SthorpejMACHINE_ARCH=m68k 161.21SjmcUSETOOLS?= no 171.21Sjmc 181.21Sjmc.include <bsd.own.mk> 191.1Sdbj 201.1Sdbj# DEBUG is set to -g if debugging. 211.1Sdbj# PROF is set to -pg if profiling. 221.1Sdbj 231.1SdbjAR?= ar 241.1SdbjAS?= as 251.1SdbjCC?= cc 261.1SdbjCPP?= cpp 271.1SdbjLD?= ld 281.1SdbjLORDER?=lorder 291.1SdbjMKDEP?= mkdep 301.1SdbjNM?= nm 311.1SdbjRANLIB?=ranlib 321.1SdbjSIZE?= size 331.14StsutsuiSTRIP?= strip 341.1SdbjTSORT?= tsort -q 351.1Sdbj 361.10SdbjCOPTS?= -O2 371.1Sdbj 381.1Sdbj# source tree is located via $S relative to the compilation directory 391.1Sdbj.ifndef S 401.1SdbjS!= cd ../../../..; pwd 411.1Sdbj.endif 421.1SdbjNEXT68K= $S/arch/next68k 431.1Sdbj 441.22SlukemHAVE_EGCS!= ${CC} --version | egrep "^(2\.[89]|egcs)" ; echo 451.1SdbjINCLUDES= -I. -I$S/arch -I$S -nostdinc 461.19SmrgCPPFLAGS= ${INCLUDES} ${IDENT} ${PARAM} -D_KERNEL -D_KERNEL_OPT -Dnext68k 471.18SchsCWARNFLAGS= -Wall -Werror -Wstrict-prototypes -Wmissing-prototypes \ 481.6Saugustss -Wpointer-arith 491.15Sthorpej# XXX Delete -Wuninitialized for now, since the compiler doesn't 501.22Slukem# XXX always get it right. --thorpej 511.15SthorpejCWARNFLAGS+= -Wno-uninitialized 521.15Sthorpej.if (${HAVE_EGCS} != "") 531.5SdbjCWARNFLAGS+= -Wno-main 541.5Sdbj.endif 551.1SdbjCFLAGS= ${DEBUG} ${COPTS} ${CWARNFLAGS} -msoft-float 561.1SdbjAFLAGS= -x assembler-with-cpp -traditional-cpp -D_LOCORE 571.10SdbjLINKFLAGS= -n -Ttext 0 -e start 581.11StsutsuiSTRIPFLAGS= -g 591.8Smrg 601.8Smrg%INCLUDES 611.1Sdbj 621.10SdbjHOSTED_CC= ${CC} 631.10SdbjHOSTED_CPPFLAGS=${CPPFLAGS:S/^-nostdinc$//} 641.10SdbjHOSTED_CFLAGS= ${CFLAGS} 651.10Sdbj 661.10Sdbj### find out what to use for libkern 671.4SdrochnerKERN_AS= obj 681.1Sdbj.include "$S/lib/libkern/Makefile.inc" 691.1Sdbj.ifndef PROF 701.10SdbjLIBKERN= ${KERNLIB} 711.1Sdbj.else 721.10SdbjLIBKERN= ${KERNLIB_PROF} 731.1Sdbj.endif 741.1Sdbj 751.1Sdbj### Find out what to use for libcompat. 761.1Sdbj.include "$S/compat/common/Makefile.inc" 771.1Sdbj.ifndef PROF 781.10SdbjLIBCOMPAT= ${COMPATLIB} 791.1Sdbj.else 801.10SdbjLIBCOMPAT= ${COMPATLIB_PROF} 811.1Sdbj.endif 821.1Sdbj 831.1Sdbj### for the Motorola 68040 Floating Point Software Product 841.1Sdbj.include "$S/arch/m68k/fpsp/Makefile.inc" 851.1Sdbj 861.1Sdbj# compile rules: rules are named ${TYPE}_${SUFFIX} where TYPE is NORMAL or 871.1Sdbj# HOSTED}, and SUFFIX is the file suffix, capitalized (e.g. C for a .c file). 881.1Sdbj 891.1SdbjNORMAL_C= ${CC} ${CFLAGS} ${CPPFLAGS} ${PROF} -c $< 901.10SdbjNOPROF_C= ${CC} ${CFLAGS} ${CPPFLAGS} -c $< 911.1SdbjNORMAL_S= ${CC} ${AFLAGS} ${CPPFLAGS} -c $< 921.10Sdbj 931.10SdbjHOSTED_C= ${HOSTED_CC} ${HOSTED_CFLAGS} ${HOSTED_CPPFLAGS} -c $< 941.1Sdbj 951.1Sdbj%OBJS 961.1Sdbj 971.1Sdbj%CFILES 981.1Sdbj 991.1Sdbj%SFILES 1001.1Sdbj 1011.1Sdbj# load lines for config "xxx" will be emitted as: 1021.1Sdbj# xxx: ${SYSTEM_DEP} swapxxx.o 1031.1Sdbj# ${SYSTEM_LD_HEAD} 1041.1Sdbj# ${SYSTEM_LD} swapxxx.o 1051.1Sdbj# ${SYSTEM_LD_TAIL} 1061.1SdbjSYSTEM_OBJ= locore.o ${FPSP} \ 1071.4Sdrochner param.o ioconf.o ${OBJS} ${LIBCOMPAT} ${LIBKERN} 1081.1SdbjSYSTEM_DEP= Makefile ${SYSTEM_OBJ} 1091.1SdbjSYSTEM_LD_HEAD= @rm -f $@ 1101.1SdbjSYSTEM_LD= @echo ${LD} ${LINKFLAGS} -o $@ '$${SYSTEM_OBJ}' vers.o; \ 1111.1Sdbj ${LD} ${LINKFLAGS} -o $@ ${SYSTEM_OBJ} vers.o 1121.1SdbjSYSTEM_LD_TAIL= @${SIZE} $@; chmod 755 $@ 1131.1Sdbj 1141.1SdbjDEBUG?= 1151.1Sdbj.if ${DEBUG} == "-g" 1161.1SdbjLINKFLAGS+= -X 1171.1SdbjSYSTEM_LD_TAIL+=; \ 1181.9Scgd echo mv -f $@ $@.gdb; mv -f $@ $@.gdb; \ 1191.14Stsutsui echo ${STRIP} ${STRIPFLAGS} -o $@ $@.gdb; \ 1201.14Stsutsui ${STRIP} ${STRIPFLAGS} -o $@ $@.gdb 1211.1Sdbj.else 1221.1SdbjLINKFLAGS+= -S 1231.1Sdbj.endif 1241.1Sdbj 1251.1Sdbj%LOAD 1261.1Sdbj 1271.1Sdbjassym.h: $S/kern/genassym.sh ${NEXT68K}/next68k/genassym.cf 1281.1Sdbj sh $S/kern/genassym.sh ${CC} ${CFLAGS} ${CPPFLAGS} ${PROF} \ 1291.1Sdbj < ${NEXT68K}/next68k/genassym.cf > assym.h.tmp && \ 1301.1Sdbj mv -f assym.h.tmp assym.h 1311.1Sdbj 1321.1Sdbjparam.c: $S/conf/param.c 1331.1Sdbj rm -f param.c 1341.1Sdbj cp $S/conf/param.c . 1351.1Sdbj 1361.1Sdbjparam.o: param.c Makefile 1371.1Sdbj ${NORMAL_C} 1381.1Sdbj 1391.1Sdbjioconf.o: ioconf.c 1401.1Sdbj ${NORMAL_C} 1411.1Sdbj 1421.1Sdbjnewvers: ${SYSTEM_DEP} ${SYSTEM_SWAP_DEP} 1431.1Sdbj sh $S/conf/newvers.sh 1441.1Sdbj ${CC} ${CFLAGS} ${CPPFLAGS} ${PROF} -c vers.c 1451.1Sdbj 1461.1Sdbj__CLEANKERNEL: .USE 1471.1Sdbj @echo "${.TARGET}ing the kernel objects" 1481.1Sdbj rm -f eddep *netbsd netbsd.gdb tags *.[io] [a-z]*.s \ 1491.1Sdbj [Ee]rrs linterrs makelinks assym.h.tmp assym.h 1501.1Sdbj 1511.1Sdbj__CLEANDEPEND: .USE 1521.1Sdbj rm -f .depend 1531.1Sdbj 1541.1Sdbjclean: __CLEANKERNEL 1551.1Sdbj 1561.3Slukemcleandir distclean: __CLEANKERNEL __CLEANDEPEND 1571.1Sdbj 1581.1Sdbjlint: 1591.1Sdbj @lint -hbxncez -Dvolatile= ${CPPFLAGS} -UKGDB \ 1601.1Sdbj ${CFILES} ioconf.c param.c | \ 1611.1Sdbj grep -v 'static function .* unused' 1621.1Sdbj 1631.1Sdbjtags: 1641.1Sdbj @echo "see $S/kern/Makefile for tags" 1651.1Sdbj 1661.1Sdbjlinks: 1671.1Sdbj egrep '#if' ${CFILES} | sed -f $S/conf/defines | \ 1681.1Sdbj sed -e 's/:.*//' -e 's/\.c/.o/' | sort -u > dontlink 1691.1Sdbj echo ${CFILES} | tr -s ' ' '\12' | sed 's/\.c/.o/' | \ 1701.1Sdbj sort -u | comm -23 - dontlink | \ 1711.1Sdbj sed 's,../.*/\(.*.o\),rm -f \1; ln -s ../GENERIC/\1 \1,' > makelinks 1721.1Sdbj sh makelinks && rm -f dontlink 1731.1Sdbj 1741.1SdbjSRCS= ${NEXT68K}/next68k/locore.s \ 1751.1Sdbj param.c ioconf.c ${CFILES} ${SFILES} 1761.1Sdbjdepend: .depend 1771.1Sdbj.depend: ${SRCS} assym.h param.c 1781.1Sdbj ${MKDEP} ${AFLAGS} ${CPPFLAGS} ${NEXT68K}/next68k/locore.s 1791.1Sdbj ${MKDEP} -a ${CFLAGS} ${CPPFLAGS} param.c ioconf.c ${CFILES} 1801.1Sdbj ${MKDEP} -a ${AFLAGS} ${CPPFLAGS} ${SFILES} 1811.1Sdbj sh $S/kern/genassym.sh ${MKDEP} -f assym.dep ${CFLAGS} \ 1821.1Sdbj ${CPPFLAGS} < ${NEXT68K}/next68k/genassym.cf 1831.1Sdbj @sed -e 's/.*\.o:.*\.c/assym.h:/' < assym.dep >> .depend 1841.1Sdbj @rm -f assym.dep 1851.13Stron 1861.13Strondependall: depend all 1871.1Sdbj 1881.1Sdbj 1891.1Sdbj# depend on root or device configuration 1901.1Sdbjautoconf.o conf.o: Makefile 1911.22Slukem 1921.22Slukem# depend on network or filesystem configuration 1931.22Slukemuipc_proto.o vfs_conf.o: Makefile 1941.1Sdbj 1951.1Sdbj# depend on maxusers 1961.1Sdbjgenassym.o machdep.o: Makefile 1971.1Sdbj 1981.22Slukem# depend on CPU configuration 1991.1Sdbjlocore.o pmap.o trap.o: Makefile 2001.1Sdbj 2011.1Sdbj 2021.1Sdbjlocore.o: ${NEXT68K}/next68k/locore.s assym.h 2031.1Sdbj ${NORMAL_S} 2041.16Shubertf 2051.16Shubertf# The install target can be redefined by putting a 2061.16Shubertf# install-kernel-${MACHINE_NAME} target into /etc/mk.conf 2071.16ShubertfMACHINE_NAME!= uname -n 2081.16Shubertfinstall: install-kernel-${MACHINE_NAME} 2091.16Shubertf.if !target(install-kernel-${MACHINE_NAME}}) 2101.16Shubertfinstall-kernel-${MACHINE_NAME}: 2111.16Shubertf rm -f /onetbsd 2121.16Shubertf ln /netbsd /onetbsd 2131.16Shubertf cp netbsd /nnetbsd 2141.16Shubertf mv /nnetbsd /netbsd 2151.16Shubertf.endif 2161.1Sdbj 2171.1Sdbj%RULES 218