Makefile.hpcarm revision 1.11
11.11Sthorpej# $NetBSD: Makefile.hpcarm,v 1.11 2001/11/27 00:25:32 thorpej Exp $ 21.1Sichiro 31.1Sichiro# Makefile for NetBSD 41.1Sichiro# 51.1Sichiro# This makefile is constructed from a machine description: 61.1Sichiro# config machineid 71.1Sichiro# Most changes should be made in the machine description 81.1Sichiro# /sys/arch/hpcarm/conf/``machineid'' 91.1Sichiro# after which you should do 101.1Sichiro# config machineid 111.1Sichiro# Machine generic makefile changes should be made in 121.1Sichiro# /sys/arch/hpcarm/conf/Makefile.hpcarm 131.1Sichiro# after which config should be rerun for all machines of that type. 141.6Sthorpej 151.8SthorpejMACHINE_ARCH=arm 161.7SjmcUSETOOLS?= no 171.5Sthorpej 181.5Sthorpej.include <bsd.own.mk> 191.1Sichiro 201.1Sichiro# DEBUG is set to -g if debugging. 211.1Sichiro# PROF is set to -pg if profiling. 221.1Sichiro 231.1SichiroAR?= ar 241.1SichiroAS?= as 251.1SichiroCC?= cc 261.1SichiroCPP?= cpp 271.1SichiroLD?= ld 281.1SichiroLORDER?=lorder 291.1SichiroMKDEP?= mkdep 301.1SichiroNM?= nm 311.1SichiroRANLIB?=ranlib 321.1SichiroSIZE?= size 331.1SichiroSTRIP?= strip 341.1SichiroTSORT?= tsort -q 351.1Sichiro 361.1SichiroCOPTS?= -O2 371.1Sichiro 381.1Sichiro# source tree is located via $S relative to the compilation directory 391.1Sichiro.ifndef S 401.1SichiroS!= cd ../../../..; pwd 411.1Sichiro.endif 421.11SthorpejARM= $S/arch/arm 431.1SichiroHPCARM= $S/arch/hpcarm 441.1Sichiro 451.9SlukemHAVE_EGCS!= ${CC} --version | egrep "^(2\.[89]|egcs)" ; echo 461.1SichiroINCLUDES= -I. -I$S/arch -I$S -nostdinc 471.2SmrgCPPFLAGS= ${INCLUDES} ${IDENT} ${PARAM} -D_KERNEL -D_KERNEL_OPT -Dhpcarm -Darm32 481.1SichiroCWARNFLAGS?= -Werror -Wall -Wcomment -Wpointer-arith 491.1Sichiro# XXX Delete -Wuninitialized for now, since the compiler doesn't 501.9Slukem# XXX always get it right. --thorpej 511.1SichiroCWARNFLAGS+= -Wno-uninitialized 521.1Sichiro.if (${HAVE_EGCS} != "") 531.1SichiroCWARNFLAGS+= -Wno-main 541.1Sichiro.endif 551.1SichiroCFLAGS= ${DEBUG} ${COPTS} ${CWARNFLAGS} 561.1SichiroAFLAGS= -x assembler-with-cpp -D_LOCORE 571.4StoshiiLINKFLAGS= -Ttext C0040000 -e start 581.1SichiroSTRIPFLAGS= -g 591.1Sichiro 601.11SthorpejGENASSYM_EXTRAS+= ${HPCARM}/hpcarm/genassym.cf 611.11Sthorpej 621.1Sichiro%INCLUDES 631.1Sichiro 641.1SichiroHOSTED_CC= ${CC} 651.1SichiroHOSTED_CPPFLAGS=${CPPFLAGS:S/^-nostdinc$//} 661.1SichiroHOSTED_CFLAGS= ${CFLAGS} 671.1Sichiro 681.1Sichiro### find out what to use for libkern 691.1SichiroKERN_AS= obj 701.1Sichiro.include "$S/lib/libkern/Makefile.inc" 711.1Sichiro.ifndef PROF 721.1SichiroLIBKERN= ${KERNLIB} 731.1Sichiro.else 741.1SichiroLIBKERN= ${KERNLIB_PROF} 751.1Sichiro.endif 761.1Sichiro 771.1Sichiro### find out what to use for libcompat 781.1Sichiro.include "$S/compat/common/Makefile.inc" 791.1Sichiro.ifndef PROF 801.1SichiroLIBCOMPAT= ${COMPATLIB} 811.1Sichiro.else 821.1SichiroLIBCOMPAT= ${COMPATLIB_PROF} 831.1Sichiro.endif 841.1Sichiro 851.1Sichiro# compile rules: rules are named ${TYPE}_${SUFFIX} where TYPE is NORMAL or 861.1Sichiro# HOSTED}, and SUFFIX is the file suffix, capitalized (e.g. C for a .c file). 871.1Sichiro 881.1SichiroNORMAL_C= ${CC} ${CFLAGS} ${CPPFLAGS} ${PROF} -c $< 891.1SichiroNOPROF_C= ${CC} ${CFLAGS} ${CPPFLAGS} -c $< 901.1SichiroNORMAL_S= ${CC} ${AFLAGS} ${CPPFLAGS} -c $< 911.1Sichiro 921.1SichiroHOSTED_C= ${HOSTED_CC} ${HOSTED_CFLAGS} ${HOSTED_CPPFLAGS} -c $< 931.1Sichiro 941.1Sichiro%OBJS 951.1Sichiro 961.1Sichiro%CFILES 971.1Sichiro 981.1Sichiro%SFILES 991.1Sichiro 1001.1Sichiro# load lines for config "xxx" will be emitted as: 1011.1Sichiro# xxx: ${SYSTEM_DEP} swapxxx.o 1021.1Sichiro# ${SYSTEM_LD_HEAD} 1031.1Sichiro# ${SYSTEM_LD} swapxxx.o 1041.1Sichiro# ${SYSTEM_LD_TAIL} 1051.1SichiroSYSTEM_OBJ= locore.o \ 1061.1Sichiro param.o ioconf.o ${OBJS} ${LIBCOMPAT} ${LIBKERN} 1071.1SichiroSYSTEM_DEP= Makefile ${SYSTEM_OBJ} 1081.1SichiroSYSTEM_LD_HEAD= rm -f $@ 1091.1SichiroSYSTEM_LD= @echo ${LD} ${LINKFLAGS} -o $@ '$${SYSTEM_OBJ}' vers.o; \ 1101.1Sichiro ${LD} ${LINKFLAGS} -o $@ ${SYSTEM_OBJ} vers.o 1111.1SichiroSYSTEM_LD_TAIL= @${SIZE} $@; chmod 755 $@ 1121.1Sichiro 1131.1SichiroDEBUG?= 1141.1Sichiro.if ${DEBUG} == "-g" 1151.1SichiroLINKFLAGS+= -X 1161.1SichiroSYSTEM_LD_TAIL+=; \ 1171.1Sichiro echo mv -f $@ $@.gdb; mv -f $@ $@.gdb; \ 1181.1Sichiro echo ${STRIP} ${STRIPFLAGS} -o $@ $@.gdb; \ 1191.1Sichiro ${STRIP} ${STRIPFLAGS} -o $@ $@.gdb 1201.1Sichiro.else 1211.1Sichiro#LINKFLAGS+= -S 1221.3StoshiiLINKFLAGS+= -X 1231.1Sichiro.endif 1241.1Sichiro 1251.1Sichiro%LOAD 1261.1Sichiro 1271.11Sthorpejassym.h: $S/kern/genassym.sh ${ARM}/arm32/genassym.cf 1281.11Sthorpej cat ${ARM}/arm32/genassym.cf ${GENASSYM_EXTRAS} | \ 1291.10Sthorpej sh $S/kern/genassym.sh ${CC} ${CFLAGS} ${CPPFLAGS} ${PROF} \ 1301.10Sthorpej > assym.h.tmp && \ 1311.1Sichiro mv -f assym.h.tmp assym.h 1321.1Sichiro 1331.1Sichiroparam.c: $S/conf/param.c 1341.1Sichiro rm -f param.c 1351.1Sichiro cp $S/conf/param.c . 1361.1Sichiro 1371.1Sichiroparam.o: param.c Makefile 1381.1Sichiro ${NORMAL_C} 1391.1Sichiro 1401.1Sichiroioconf.o: ioconf.c 1411.1Sichiro ${NORMAL_C} 1421.1Sichiro 1431.1Sichironewvers: ${SYSTEM_DEP} ${SYSTEM_SWAP_DEP} 1441.1Sichiro sh $S/conf/newvers.sh 1451.1Sichiro ${CC} ${CFLAGS} ${CPPFLAGS} ${PROF} -c vers.c 1461.1Sichiro 1471.1Sichiro__CLEANKERNEL: .USE 1481.1Sichiro @echo "${.TARGET}ing the kernel objects" 1491.1Sichiro rm -f eddep *netbsd netbsd.gdb tags *.[io] [a-z]*.s \ 1501.1Sichiro [Ee]rrs linterrs makelinks assym.h.tmp assym.h modedefs.c 1511.1Sichiro 1521.1Sichiro__CLEANDEPEND: .USE 1531.1Sichiro rm -f .depend 1541.1Sichiro 1551.1Sichiroclean: __CLEANKERNEL 1561.1Sichiro 1571.1Sichirocleandir distclean: __CLEANKERNEL __CLEANDEPEND 1581.1Sichiro 1591.1Sichirolint: 1601.1Sichiro @lint -hbxncez -Dvolatile= ${CPPFLAGS} -UKGDB \ 1611.1Sichiro ${HPCARM}/hpcarm/Locore.c ${CFILES} \ 1621.1Sichiro ioconf.c param.c | \ 1631.1Sichiro grep -v 'static function .* unused' 1641.1Sichiro 1651.1Sichirotags: 1661.1Sichiro @echo "see $S/kern/Makefile for tags" 1671.1Sichiro 1681.1Sichirolinks: 1691.1Sichiro egrep '#if' ${CFILES} | sed -f $S/conf/defines | \ 1701.1Sichiro sed -e 's/:.*//' -e 's/\.c/.o/' | sort -u > dontlink 1711.1Sichiro echo ${CFILES} | tr -s ' ' '\12' | sed 's/\.c/.o/' | \ 1721.1Sichiro sort -u | comm -23 - dontlink | \ 1731.1Sichiro sed 's,../.*/\(.*.o\),rm -f \1; ln -s ../GENERIC/\1 \1,' > makelinks 1741.1Sichiro sh makelinks && rm -f dontlink 1751.1Sichiro 1761.1SichiroSRCS= ${HPCARM}/hpcarm/locore.S param.c ioconf.c ${CFILES} ${SFILES} 1771.1Sichirodepend: .depend 1781.1Sichiro.depend: ${SRCS} assym.h param.c 1791.1Sichiro ${MKDEP} ${AFLAGS} ${CPPFLAGS} ${HPCARM}/hpcarm/locore.S 1801.1Sichiro ${MKDEP} -a ${CFLAGS} ${CPPFLAGS} param.c ioconf.c ${CFILES} 1811.1Sichiro test -z "${SFILES}" || ${MKDEP} -a ${AFLAGS} ${CPPFLAGS} ${SFILES} 1821.1Sichiro sh $S/kern/genassym.sh ${MKDEP} -f assym.dep ${CFLAGS} \ 1831.1Sichiro ${CPPFLAGS} < ${HPCARM}/hpcarm/genassym.cf 1841.1Sichiro @sed -e 's/.*\.o:.*\.c/assym.h:/' < assym.dep >> .depend 1851.1Sichiro @rm -f assym.dep 1861.1Sichiro 1871.1Sichirodependall: depend all 1881.1Sichiro 1891.1Sichiro 1901.1Sichiro# depend on root or device configuration 1911.1Sichiroautoconf.o conf.o: Makefile 1921.9Slukem 1931.1Sichiro# depend on network 1941.9Slukemuipc_proto.o: Makefile 1951.1Sichiro 1961.1Sichiro# depend on maxusers 1971.1Sichiroassym.h: Makefile 1981.1Sichiro 1991.9Slukem# depend on CPU configuration 2001.1Sichirocpufunc.o cpufunc_asm.o: Makefile 2011.1Sichiro 2021.1Sichiro# depend on DIAGNOSTIC etc. 2031.1Sichirocpuswitch.o fault.o machdep.o: Makefile 2041.1Sichiro 2051.1Sichiro 2061.1Sichirolocore.o: ${HPCARM}/hpcarm/locore.S assym.h 2071.1Sichiro ${NORMAL_S} 2081.1Sichiro 2091.1Sichiro# The install target can be redefined by putting a 2101.1Sichiro# install-kernel-${MACHINE_NAME} target into /etc/mk.conf 2111.1SichiroMACHINE_NAME!= uname -n 2121.1Sichiroinstall: install-kernel-${MACHINE_NAME} 2131.1Sichiro.if !target(install-kernel-${MACHINE_NAME}}) 2141.1Sichiroinstall-kernel-${MACHINE_NAME}: 2151.1Sichiro rm -f /onetbsd 2161.1Sichiro ln /netbsd /onetbsd 2171.1Sichiro cp netbsd /nnetbsd 2181.1Sichiro mv /nnetbsd /netbsd 2191.1Sichiro.endif 2201.1Sichiro 2211.1Sichiro%RULES 222