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