Makefile.arm revision 1.7
11.7Smatt# $NetBSD: Makefile.arm,v 1.7 2001/10/17 23:21:44 matt 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.7Smatt 331.7Smatt.if $S == "../../../.." 341.7SmattS!= cd ../../../..; pwd 351.7Smatt.endif 361.1Smatt 371.1SmattARM32= $S/arch/arm32 381.6SchrisARM= $S/arch/arm 391.1SmattTHISARM= $S/arch/${TARGET_MACHINE} 401.1Smatt 411.1SmattHAVE_EGCS!= ${CC} --version | egrep "^(2\.[89]|egcs)" ; echo 421.1SmattINCLUDES= -I. -I./include -I$S/arch -I$S -nostdinc 431.1SmattCPPFLAGS= ${INCLUDES} ${IDENT} ${PARAM} \ 441.1Smatt -D_KERNEL -D_KERNEL_OPT -D${TARGET_MACHINE} 451.1SmattCWARNFLAGS?= -Werror -Wall -Wcomment -Wpointer-arith 461.1Smatt# XXX Delete -Wuninitialized for now, since the compiler doesn't 471.1Smatt# XXX always get it right. --thorpej 481.1SmattCWARNFLAGS+= -Wno-uninitialized 491.1Smatt.if (${HAVE_EGCS} != "") 501.1SmattCWARNFLAGS+= -Wno-main 511.1Smatt.endif 521.1SmattCFLAGS= ${DEBUG} ${COPTS} ${CWARNFLAGS} 531.1SmattAFLAGS= -x assembler-with-cpp -D_LOCORE 541.1Smatt 551.3SmattLOADADDRESS?= 0xF0000000 561.3SmattLINKENTRY?= -e start 571.4SmattLINKFLAGS= -Ttext ${LOADADDRESS} ${LINKENTRY} ${EXTRA_LINKFLAGS} 581.1SmattSTRIPFLAGS= -g 591.1Smatt 601.3Smatt.if exists($S/arch/${TARGET_MACHINE}/conf/Makefile.${TARGET_MACHINE}.inc) 611.3Smatt.include "$S/arch/${TARGET_MACHINE}/conf/Makefile.${TARGET_MACHINE}.inc" 621.1Smatt.endif 631.1Smatt 641.1Smatt%INCLUDES 651.1Smatt 661.1SmattHOSTED_CC= ${CC} 671.1SmattHOSTED_CPPFLAGS=${CPPFLAGS:S/^-nostdinc$//} 681.1SmattHOSTED_CFLAGS= ${CFLAGS} 691.1Smatt 701.1Smatt### find out what to use for libkern 711.1SmattKERN_AS= obj 721.1Smatt.include "$S/lib/libkern/Makefile.inc" 731.1Smatt.ifndef PROF 741.1SmattLIBKERN= ${KERNLIB} 751.1Smatt.else 761.1SmattLIBKERN= ${KERNLIB_PROF} 771.1Smatt.endif 781.1Smatt 791.1Smatt### find out what to use for libcompat 801.1Smatt.include "$S/compat/common/Makefile.inc" 811.1Smatt.ifndef PROF 821.1SmattLIBCOMPAT= ${COMPATLIB} 831.1Smatt.else 841.1SmattLIBCOMPAT= ${COMPATLIB_PROF} 851.1Smatt.endif 861.1Smatt 871.1Smatt# compile rules: rules are named ${TYPE}_${SUFFIX} where TYPE is NORMAL or 881.1Smatt# HOSTED}, and SUFFIX is the file suffix, capitalized (e.g. C for a .c file). 891.1Smatt 901.1SmattNORMAL_C= ${CC} ${CFLAGS} ${CPPFLAGS} ${PROF} -c $< 911.1SmattNOPROF_C= ${CC} ${CFLAGS} ${CPPFLAGS} -c $< 921.1SmattNORMAL_S= ${CC} ${AFLAGS} ${CPPFLAGS} -c $< 931.1Smatt 941.1SmattHOSTED_C= ${HOSTED_CC} ${HOSTED_CFLAGS} ${HOSTED_CPPFLAGS} -c $< 951.1Smatt 961.1Smatt%OBJS 971.1Smatt 981.1Smatt%CFILES 991.1Smatt 1001.1Smatt%SFILES 1011.1Smatt 1021.1Smatt# load lines for config "xxx" will be emitted as: 1031.1Smatt# xxx: ${SYSTEM_DEP} swapxxx.o 1041.1Smatt# ${SYSTEM_LD_HEAD} 1051.1Smatt# ${SYSTEM_LD} swapxxx.o 1061.1Smatt# ${SYSTEM_LD_TAIL} 1071.1SmattSYSTEM_OBJ= ${SYSTEM_FIRST_OBJ} locore.o \ 1081.1Smatt param.o ioconf.o ${OBJS} ${LIBCOMPAT} ${LIBKERN} 1091.1SmattSYSTEM_DEP= Makefile ${SYSTEM_OBJ} 1101.1SmattSYSTEM_LD_HEAD= rm -f $@ 1111.1SmattSYSTEM_LD= @echo ${LD} ${LINKFLAGS} -o $@ '$${SYSTEM_OBJ}' vers.o; \ 1121.1Smatt ${LD} ${LINKFLAGS} -o $@ ${SYSTEM_OBJ} vers.o 1131.1SmattSYSTEM_LD_TAIL= @${SIZE} $@; chmod 755 $@ 1141.1Smatt 1151.1SmattDEBUG?= 1161.1Smatt.if ${DEBUG} == "-g" 1171.1SmattLINKFLAGS+= -X 1181.1SmattSYSTEM_LD_TAIL+=; \ 1191.1Smatt echo mv -f $@ $@.gdb; mv -f $@ $@.gdb; \ 1201.1Smatt echo ${STRIP} ${STRIPFLAGS} -o $@ $@.gdb; \ 1211.1Smatt ${STRIP} ${STRIPFLAGS} -o $@ $@.gdb 1221.1Smatt.else 1231.1Smatt#LINKFLAGS+= -S 1241.5SchrisLINKFLAGS+= -X 1251.1Smatt.endif 1261.1Smatt 1271.1Smatt%LOAD 1281.1Smatt 1291.6Schrisassym.h: $S/kern/genassym.sh ${ARM}/arm32/genassym.cf 1301.1Smatt sh $S/kern/genassym.sh ${CC} ${CFLAGS} ${CPPFLAGS} ${PROF} \ 1311.6Schris < ${ARM}/arm32/genassym.cf > assym.h.tmp && \ 1321.1Smatt mv -f assym.h.tmp assym.h 1331.1Smatt 1341.1Smattparam.c: $S/conf/param.c 1351.1Smatt rm -f param.c 1361.1Smatt cp $S/conf/param.c . 1371.1Smatt 1381.1Smattparam.o: param.c Makefile 1391.1Smatt ${NORMAL_C} 1401.1Smatt 1411.1Smattioconf.o: ioconf.c 1421.1Smatt ${NORMAL_C} 1431.1Smatt 1441.1Smattnewvers: ${SYSTEM_DEP} ${SYSTEM_SWAP_DEP} 1451.1Smatt sh $S/conf/newvers.sh 1461.1Smatt ${CC} ${CFLAGS} ${CPPFLAGS} ${PROF} -c vers.c 1471.1Smatt 1481.1Smatt__CLEANKERNEL: .USE 1491.1Smatt @echo "${.TARGET}ing the kernel objects" 1501.1Smatt rm -f eddep *netbsd netbsd.gdb tags *.[io] [a-z]*.s \ 1511.1Smatt [Ee]rrs linterrs makelinks assym.h.tmp assym.h ${EXTRA_CLEAN} 1521.1Smatt 1531.1Smatt__CLEANDEPEND: .USE 1541.1Smatt rm -f .depend 1551.1Smatt 1561.1Smattclean: __CLEANKERNEL 1571.1Smatt 1581.1Smattcleandir distclean: __CLEANKERNEL __CLEANDEPEND 1591.1Smatt 1601.1Smattlint: 1611.1Smatt @lint -hbxncez -Dvolatile= ${CPPFLAGS} -UKGDB \ 1621.1Smatt ${ARM32}/arm32/Locore.c ${CFILES} \ 1631.1Smatt ioconf.c param.c | \ 1641.1Smatt grep -v 'static function .* unused' 1651.1Smatt 1661.1Smatttags: 1671.1Smatt @echo "see $S/kern/Makefile for tags" 1681.1Smatt 1691.1Smattlinks: 1701.1Smatt egrep '#if' ${CFILES} | sed -f $S/conf/defines | \ 1711.1Smatt sed -e 's/:.*//' -e 's/\.c/.o/' | sort -u > dontlink 1721.1Smatt echo ${CFILES} | tr -s ' ' '\12' | sed 's/\.c/.o/' | \ 1731.1Smatt sort -u | comm -23 - dontlink | \ 1741.1Smatt sed 's,../.*/\(.*.o\),rm -f \1; ln -s ../GENERIC/\1 \1,' > makelinks 1751.1Smatt sh makelinks && rm -f dontlink 1761.1Smatt 1771.6SchrisSRCS= ${ARM}/arm32/locore.S param.c ioconf.c ${CFILES} ${SFILES} \ 1781.1Smatt ${EXTRA_CFILES} ${EXTRA_SFILES} ${SYSTEM_FIRST_SFILE} 1791.1Smatt 1801.1Smattdepend: .depend 1811.1Smatt.depend: ${SRCS} assym.h param.c 1821.1Smatt ${MKDEP} ${AFLAGS} ${CPPFLAGS} ${SYSTEM_FIRST_SFILE} \ 1831.6Schris ${ARM}/arm32/locore.S ${EXTRA_SFILES} 1841.1Smatt ${MKDEP} -a ${CFLAGS} ${CPPFLAGS} param.c ioconf.c ${CFILES} \ 1851.1Smatt ${EXTRA_CFILES} 1861.1Smatt test -z "${SFILES}" || ${MKDEP} -a ${AFLAGS} ${CPPFLAGS} ${SFILES} 1871.1Smatt sh $S/kern/genassym.sh ${MKDEP} -f assym.dep ${CFLAGS} \ 1881.6Schris ${CPPFLAGS} < ${ARM}/arm32/genassym.cf 1891.1Smatt @sed -e 's/.*\.o:.*\.c/assym.h:/' < assym.dep >> .depend 1901.1Smatt @rm -f assym.dep 1911.1Smatt 1921.1Smattdependall: depend all 1931.1Smatt 1941.2Smatt.if !exists(include) 1951.1Smatt${OBJS} assym.h .depend: include-dir 1961.1Smattinclude-dir: 1971.1Smatt @rm -rf include 1981.1Smatt @mkdir -p include/arm 1991.1Smatt.if (${S} == "../../../..") 2001.1Smatt @(cd include/arm; ln -s ../../$S/arch/${TARGET_MACHINE}/include ${TARGET_MACHINE}) 2011.1Smatt @(cd include; ln -s ../$S/arch/arm/include machine) 2021.1Smatt.else 2031.1Smatt @ln -s $S/arch/${TARGET_MACHINE}/include include/arm/${TARGET_MACHINE} 2041.1Smatt @ln -s $S/arch/arm/include include/machine 2051.2Smatt.endif 2061.1Smatt.endif 2071.1Smatt 2081.1Smatt# depend on root or device configuration 2091.1Smattautoconf.o conf.o: Makefile 2101.1Smatt 2111.1Smatt# depend on network 2121.1Smattuipc_proto.o: Makefile 2131.1Smatt 2141.1Smatt# depend on maxusers 2151.1Smattassym.h: Makefile 2161.1Smatt 2171.1Smatt# depend on CPU configuration 2181.1Smattcpufunc.o cpufunc_asm.o: Makefile 2191.1Smatt 2201.1Smatt# depend on DIAGNOSTIC etc. 2211.1Smattcpuswitch.o fault.o machdep.o: Makefile 2221.1Smatt 2231.1Smatt.if defined(SYSTEM_FIRST_OBJ) 2241.1Smatt${SYSTEM_FIRST_OBJ}: ${SYSTEM_FIRST_SFILE} assym.h 2251.1Smatt ${NORMAL_S} 2261.1Smatt.endif 2271.1Smatt 2281.6Schrislocore.o: ${ARM}/arm32/locore.S assym.h 2291.1Smatt ${NORMAL_S} 2301.1Smatt 2311.1Smatt# The install target can be redefined by putting a 2321.1Smatt# install-kernel-${MACHINE_NAME} target into /etc/mk.conf 2331.1SmattMACHINE_NAME!= uname -n 2341.1Smattinstall: install-kernel-${MACHINE_NAME} 2351.1Smatt.if !target(install-kernel-${MACHINE_NAME}}) 2361.1Smattinstall-kernel-${MACHINE_NAME}: 2371.1Smatt rm -f /onetbsd 2381.1Smatt ln /netbsd /onetbsd 2391.1Smatt cp netbsd /nnetbsd 2401.1Smatt mv /nnetbsd /netbsd 2411.1Smatt.endif 2421.1Smatt 2431.1Smatt%RULES 244