Makefile.arm revision 1.6
11.6Schris# $NetBSD: Makefile.arm,v 1.6 2001/07/28 15:08:10 chris Exp $ 21.1Smatt 31.1Smatt# Makefile for NetBSD 41.1Smatt# 51.1Smatt# This makefile is constructed from a machine description: 61.1Smatt# config machineid 71.1Smatt# Most changes should be made in the machine description 81.1Smatt# /sys/arch/<arch>/conf/``machineid'' 91.1Smatt# after which you should do 101.1Smatt# config machineid 111.1Smatt# Machine generic makefile changes should be made in 121.1Smatt# /sys/arch/arm/conf/Makefile.arm 131.1Smatt# after which config should be rerun for all machines of that type. 141.1Smatt 151.1Smatt# DEBUG is set to -g if debugging. 161.1Smatt# PROF is set to -pg if profiling. 171.1Smatt 181.1SmattAR?= ar 191.1SmattAS?= as 201.1SmattCC?= cc 211.1SmattCPP?= cpp 221.1SmattLD?= ld 231.1SmattLORDER?=lorder 241.1SmattMKDEP?= mkdep 251.1SmattNM?= nm 261.1SmattRANLIB?=ranlib 271.1SmattSIZE?= size 281.1SmattSTRIP?= strip 291.1SmattTSORT?= tsort -q 301.1Smatt 311.1SmattCOPTS?= -O2 321.1Smatt 331.1SmattARM32= $S/arch/arm32 341.6SchrisARM= $S/arch/arm 351.1SmattTHISARM= $S/arch/${TARGET_MACHINE} 361.1Smatt 371.1SmattHAVE_EGCS!= ${CC} --version | egrep "^(2\.[89]|egcs)" ; echo 381.1SmattINCLUDES= -I. -I./include -I$S/arch -I$S -nostdinc 391.1SmattCPPFLAGS= ${INCLUDES} ${IDENT} ${PARAM} \ 401.1Smatt -D_KERNEL -D_KERNEL_OPT -D${TARGET_MACHINE} 411.1SmattCWARNFLAGS?= -Werror -Wall -Wcomment -Wpointer-arith 421.1Smatt# XXX Delete -Wuninitialized for now, since the compiler doesn't 431.1Smatt# XXX always get it right. --thorpej 441.1SmattCWARNFLAGS+= -Wno-uninitialized 451.1Smatt.if (${HAVE_EGCS} != "") 461.1SmattCWARNFLAGS+= -Wno-main 471.1Smatt.endif 481.1SmattCFLAGS= ${DEBUG} ${COPTS} ${CWARNFLAGS} 491.1SmattAFLAGS= -x assembler-with-cpp -D_LOCORE 501.1Smatt 511.3SmattLOADADDRESS?= 0xF0000000 521.3SmattLINKENTRY?= -e start 531.4SmattLINKFLAGS= -Ttext ${LOADADDRESS} ${LINKENTRY} ${EXTRA_LINKFLAGS} 541.1SmattSTRIPFLAGS= -g 551.1Smatt 561.3Smatt.if exists($S/arch/${TARGET_MACHINE}/conf/Makefile.${TARGET_MACHINE}.inc) 571.3Smatt.include "$S/arch/${TARGET_MACHINE}/conf/Makefile.${TARGET_MACHINE}.inc" 581.1Smatt.endif 591.1Smatt 601.1Smatt%INCLUDES 611.1Smatt 621.1SmattHOSTED_CC= ${CC} 631.1SmattHOSTED_CPPFLAGS=${CPPFLAGS:S/^-nostdinc$//} 641.1SmattHOSTED_CFLAGS= ${CFLAGS} 651.1Smatt 661.1Smatt### find out what to use for libkern 671.1SmattKERN_AS= obj 681.1Smatt.include "$S/lib/libkern/Makefile.inc" 691.1Smatt.ifndef PROF 701.1SmattLIBKERN= ${KERNLIB} 711.1Smatt.else 721.1SmattLIBKERN= ${KERNLIB_PROF} 731.1Smatt.endif 741.1Smatt 751.1Smatt### find out what to use for libcompat 761.1Smatt.include "$S/compat/common/Makefile.inc" 771.1Smatt.ifndef PROF 781.1SmattLIBCOMPAT= ${COMPATLIB} 791.1Smatt.else 801.1SmattLIBCOMPAT= ${COMPATLIB_PROF} 811.1Smatt.endif 821.1Smatt 831.1Smatt# compile rules: rules are named ${TYPE}_${SUFFIX} where TYPE is NORMAL or 841.1Smatt# HOSTED}, and SUFFIX is the file suffix, capitalized (e.g. C for a .c file). 851.1Smatt 861.1SmattNORMAL_C= ${CC} ${CFLAGS} ${CPPFLAGS} ${PROF} -c $< 871.1SmattNOPROF_C= ${CC} ${CFLAGS} ${CPPFLAGS} -c $< 881.1SmattNORMAL_S= ${CC} ${AFLAGS} ${CPPFLAGS} -c $< 891.1Smatt 901.1SmattHOSTED_C= ${HOSTED_CC} ${HOSTED_CFLAGS} ${HOSTED_CPPFLAGS} -c $< 911.1Smatt 921.1Smatt%OBJS 931.1Smatt 941.1Smatt%CFILES 951.1Smatt 961.1Smatt%SFILES 971.1Smatt 981.1Smatt# load lines for config "xxx" will be emitted as: 991.1Smatt# xxx: ${SYSTEM_DEP} swapxxx.o 1001.1Smatt# ${SYSTEM_LD_HEAD} 1011.1Smatt# ${SYSTEM_LD} swapxxx.o 1021.1Smatt# ${SYSTEM_LD_TAIL} 1031.1SmattSYSTEM_OBJ= ${SYSTEM_FIRST_OBJ} locore.o \ 1041.1Smatt param.o ioconf.o ${OBJS} ${LIBCOMPAT} ${LIBKERN} 1051.1SmattSYSTEM_DEP= Makefile ${SYSTEM_OBJ} 1061.1SmattSYSTEM_LD_HEAD= rm -f $@ 1071.1SmattSYSTEM_LD= @echo ${LD} ${LINKFLAGS} -o $@ '$${SYSTEM_OBJ}' vers.o; \ 1081.1Smatt ${LD} ${LINKFLAGS} -o $@ ${SYSTEM_OBJ} vers.o 1091.1SmattSYSTEM_LD_TAIL= @${SIZE} $@; chmod 755 $@ 1101.1Smatt 1111.1SmattDEBUG?= 1121.1Smatt.if ${DEBUG} == "-g" 1131.1SmattLINKFLAGS+= -X 1141.1SmattSYSTEM_LD_TAIL+=; \ 1151.1Smatt echo mv -f $@ $@.gdb; mv -f $@ $@.gdb; \ 1161.1Smatt echo ${STRIP} ${STRIPFLAGS} -o $@ $@.gdb; \ 1171.1Smatt ${STRIP} ${STRIPFLAGS} -o $@ $@.gdb 1181.1Smatt.else 1191.1Smatt#LINKFLAGS+= -S 1201.5SchrisLINKFLAGS+= -X 1211.1Smatt.endif 1221.1Smatt 1231.1Smatt%LOAD 1241.1Smatt 1251.6Schrisassym.h: $S/kern/genassym.sh ${ARM}/arm32/genassym.cf 1261.1Smatt sh $S/kern/genassym.sh ${CC} ${CFLAGS} ${CPPFLAGS} ${PROF} \ 1271.6Schris < ${ARM}/arm32/genassym.cf > assym.h.tmp && \ 1281.1Smatt mv -f assym.h.tmp assym.h 1291.1Smatt 1301.1Smattparam.c: $S/conf/param.c 1311.1Smatt rm -f param.c 1321.1Smatt cp $S/conf/param.c . 1331.1Smatt 1341.1Smattparam.o: param.c Makefile 1351.1Smatt ${NORMAL_C} 1361.1Smatt 1371.1Smattioconf.o: ioconf.c 1381.1Smatt ${NORMAL_C} 1391.1Smatt 1401.1Smattnewvers: ${SYSTEM_DEP} ${SYSTEM_SWAP_DEP} 1411.1Smatt sh $S/conf/newvers.sh 1421.1Smatt ${CC} ${CFLAGS} ${CPPFLAGS} ${PROF} -c vers.c 1431.1Smatt 1441.1Smatt__CLEANKERNEL: .USE 1451.1Smatt @echo "${.TARGET}ing the kernel objects" 1461.1Smatt rm -f eddep *netbsd netbsd.gdb tags *.[io] [a-z]*.s \ 1471.1Smatt [Ee]rrs linterrs makelinks assym.h.tmp assym.h ${EXTRA_CLEAN} 1481.1Smatt 1491.1Smatt__CLEANDEPEND: .USE 1501.1Smatt rm -f .depend 1511.1Smatt 1521.1Smattclean: __CLEANKERNEL 1531.1Smatt 1541.1Smattcleandir distclean: __CLEANKERNEL __CLEANDEPEND 1551.1Smatt 1561.1Smattlint: 1571.1Smatt @lint -hbxncez -Dvolatile= ${CPPFLAGS} -UKGDB \ 1581.1Smatt ${ARM32}/arm32/Locore.c ${CFILES} \ 1591.1Smatt ioconf.c param.c | \ 1601.1Smatt grep -v 'static function .* unused' 1611.1Smatt 1621.1Smatttags: 1631.1Smatt @echo "see $S/kern/Makefile for tags" 1641.1Smatt 1651.1Smattlinks: 1661.1Smatt egrep '#if' ${CFILES} | sed -f $S/conf/defines | \ 1671.1Smatt sed -e 's/:.*//' -e 's/\.c/.o/' | sort -u > dontlink 1681.1Smatt echo ${CFILES} | tr -s ' ' '\12' | sed 's/\.c/.o/' | \ 1691.1Smatt sort -u | comm -23 - dontlink | \ 1701.1Smatt sed 's,../.*/\(.*.o\),rm -f \1; ln -s ../GENERIC/\1 \1,' > makelinks 1711.1Smatt sh makelinks && rm -f dontlink 1721.1Smatt 1731.6SchrisSRCS= ${ARM}/arm32/locore.S param.c ioconf.c ${CFILES} ${SFILES} \ 1741.1Smatt ${EXTRA_CFILES} ${EXTRA_SFILES} ${SYSTEM_FIRST_SFILE} 1751.1Smatt 1761.1Smattdepend: .depend 1771.1Smatt.depend: ${SRCS} assym.h param.c 1781.1Smatt ${MKDEP} ${AFLAGS} ${CPPFLAGS} ${SYSTEM_FIRST_SFILE} \ 1791.6Schris ${ARM}/arm32/locore.S ${EXTRA_SFILES} 1801.1Smatt ${MKDEP} -a ${CFLAGS} ${CPPFLAGS} param.c ioconf.c ${CFILES} \ 1811.1Smatt ${EXTRA_CFILES} 1821.1Smatt test -z "${SFILES}" || ${MKDEP} -a ${AFLAGS} ${CPPFLAGS} ${SFILES} 1831.1Smatt sh $S/kern/genassym.sh ${MKDEP} -f assym.dep ${CFLAGS} \ 1841.6Schris ${CPPFLAGS} < ${ARM}/arm32/genassym.cf 1851.1Smatt @sed -e 's/.*\.o:.*\.c/assym.h:/' < assym.dep >> .depend 1861.1Smatt @rm -f assym.dep 1871.1Smatt 1881.1Smattdependall: depend all 1891.1Smatt 1901.2Smatt.if !exists(include) 1911.1Smatt${OBJS} assym.h .depend: include-dir 1921.1Smattinclude-dir: 1931.1Smatt @rm -rf include 1941.1Smatt @mkdir -p include/arm 1951.1Smatt.if (${S} == "../../../..") 1961.1Smatt @(cd include/arm; ln -s ../../$S/arch/${TARGET_MACHINE}/include ${TARGET_MACHINE}) 1971.1Smatt @(cd include; ln -s ../$S/arch/arm/include machine) 1981.1Smatt.else 1991.1Smatt @ln -s $S/arch/${TARGET_MACHINE}/include include/arm/${TARGET_MACHINE} 2001.1Smatt @ln -s $S/arch/arm/include include/machine 2011.2Smatt.endif 2021.1Smatt.endif 2031.1Smatt 2041.1Smatt# depend on root or device configuration 2051.1Smattautoconf.o conf.o: Makefile 2061.1Smatt 2071.1Smatt# depend on network 2081.1Smattuipc_proto.o: Makefile 2091.1Smatt 2101.1Smatt# depend on maxusers 2111.1Smattassym.h: Makefile 2121.1Smatt 2131.1Smatt# depend on CPU configuration 2141.1Smattcpufunc.o cpufunc_asm.o: Makefile 2151.1Smatt 2161.1Smatt# depend on DIAGNOSTIC etc. 2171.1Smattcpuswitch.o fault.o machdep.o: Makefile 2181.1Smatt 2191.1Smatt.if defined(SYSTEM_FIRST_OBJ) 2201.1Smatt${SYSTEM_FIRST_OBJ}: ${SYSTEM_FIRST_SFILE} assym.h 2211.1Smatt ${NORMAL_S} 2221.1Smatt.endif 2231.1Smatt 2241.6Schrislocore.o: ${ARM}/arm32/locore.S assym.h 2251.1Smatt ${NORMAL_S} 2261.1Smatt 2271.1Smatt# The install target can be redefined by putting a 2281.1Smatt# install-kernel-${MACHINE_NAME} target into /etc/mk.conf 2291.1SmattMACHINE_NAME!= uname -n 2301.1Smattinstall: install-kernel-${MACHINE_NAME} 2311.1Smatt.if !target(install-kernel-${MACHINE_NAME}}) 2321.1Smattinstall-kernel-${MACHINE_NAME}: 2331.1Smatt rm -f /onetbsd 2341.1Smatt ln /netbsd /onetbsd 2351.1Smatt cp netbsd /nnetbsd 2361.1Smatt mv /nnetbsd /netbsd 2371.1Smatt.endif 2381.1Smatt 2391.1Smatt%RULES 240