Makefile.booters revision 1.9
11.9Sjmc#	$NetBSD: Makefile.booters,v 1.9 2004/06/21 18:20:08 jmc Exp $
21.7Slukem
31.7Slukem.include <bsd.sys.mk>		# for HOST_SH
41.1Swdk
51.1SwdkS=	${.CURDIR}/../../../..
61.1SwdkMIPS=	${S}/arch/mips
71.1SwdkMIPSCO=	${S}/arch/mipsco
81.1Swdk
91.1Swdk.PATH:	${.CURDIR}/../common
101.1Swdk
111.5SwdkBINMODE?= 444
121.6Ssimonb
131.6Ssimonb# XXX SHOULD NOT NEED TO DEFINE THESE!
141.6SsimonbLIBCRT0=
151.6SsimonbLIBC=
161.6SsimonbLIBCRTBEGIN=
171.6SsimonbLIBCRTEND=
181.5Swdk
191.2Swdk.PHONY:		machine-links
201.5Swdkbeforedepend: machine-links
211.5Swdk
221.2Swdkmachine-links:	machine mipsco mips
231.2Swdkmachine mipsco:
241.1Swdk	-rm -f ${.TARGET}
251.1Swdk	ln -s ${MIPSCO}/include ${.TARGET}
261.1Swdk
271.2Swdkmips:
281.1Swdk	-rm -f ${.TARGET}
291.1Swdk	ln -s ${MIPS}/include ${.TARGET}
301.1Swdk
311.2SwdkCLEANFILES+=	machine mipsco mips
321.2Swdk
331.5Swdkrealall: machine-links ${PROG}
341.1Swdk
351.5SwdkAFLAGS+=	-D_LOCORE -D_KERNEL -DASSEMBLER -mno-abicalls
361.1Swdk# -I${.CURDIR}/../.. done by Makefile.inc
371.1SwdkCPPFLAGS+=	-nostdinc -D_STANDALONE -DNO_ABICALLS -D_NO_PROM_DEFINES
381.1SwdkCPPFLAGS+=	-I${.OBJDIR} -I${S}
391.1Swdk# compiler flags for smallest code size
401.5Swdk#CFLAGS=		-Os -mmemcpy -mno-abicalls -G 128
411.5SwdkCFLAGS=		-Os -mmemcpy -ffreestanding -mno-abicalls -msoft-float -G 128
421.4SsimonbOFORMAT=	--oformat elf32-bigmips
431.1Swdk
441.7SlukemNETBSD_VERS!=	${HOST_SH} ${S}/conf/osrelease.sh
451.1SwdkCPPFLAGS+=	-DNETBSD_VERS='"${NETBSD_VERS}"'
461.1Swdk
471.1SwdkPRIMARY_LOAD_ADDRESS?=	0x80600000
481.1SwdkSECONDARY_LOAD_ADDRESS?=0x80610000
491.1Swdk
501.5SwdkLDSCRIPT?=	${MIPSCO}/conf/stand.ldscript
511.1Swdk
521.1Swdk.if defined(PRIMARY_PROG)
531.1SwdkPROG=		${PRIMARY_PROG}
541.1SwdkSRCS =		start.S bootxx.c callvec.c
551.1SwdkSRCS+=		devopen.c conf.c saio.c
561.1SwdkSRCS+=		prom.S
571.1Swdk
581.1SwdkLOAD_ADDRESS=	${PRIMARY_LOAD_ADDRESS}
591.1Swdk
601.1SwdkCPPFLAGS+=	-DPRIMARY_BOOTBLOCK \
611.1Swdk		-DPRIMARY_LOAD_ADDRESS="${PRIMARY_LOAD_ADDRESS}" \
621.1Swdk		-DNO_GETCHAR \
631.1Swdk		-DLIBSA_NO_FS_SYMLINK -DLIBSA_NO_FS_WRITE \
641.1Swdk		-DLIBSA_NO_FS_CLOSE \
651.1Swdk		-DLIBSA_NO_DEV_CLOSE \
661.1Swdk		-DLIBSA_SINGLE_DEVICE=saio \
671.1Swdk		-D"saioioctl(x,y,z)=EINVAL" -D"saioclose(f)=0" \
681.1Swdk		-DLIBSA_NO_TWIDDLE \
691.1Swdk		-DLIBSA_NO_FD_CHECKING \
701.1Swdk		-DLIBSA_NO_DISKLABEL_MSGS \
711.1Swdk		-DLIBSA_NO_RAW_ACCESS \
721.1Swdk		-DALLOC_FIRST_FIT \
731.1Swdk		-DLIBSA_USE_MEMCPY -DLIBSA_USE_MEMSET
741.1Swdk
751.1Swdk
761.7SlukemCHECKSIZE_CMD?=	SIZE=${SIZE} ${HOST_SH} ${.CURDIR}/../common/checksize.sh
771.1Swdk
781.8SsimonbSTRIPSECTIONS?= -R .reginfo -R .mdebug.abi32 -R .comment -R .pdr
791.8Ssimonb
801.1Swdk.elif defined(SECONDARY_PROG)
811.1SwdkPROG=		${SECONDARY_PROG}
821.1SwdkLOAD_ADDRESS=	${SECONDARY_LOAD_ADDRESS}
831.1SwdkCPPFLAGS+=	-DSECONDARY_BOOTBLOCK
841.1SwdkSRCS+=	vers.c
851.1SwdkCLEANFILES+= vers.c
861.1Swdk.else
871.1Swdk
881.1Swdk.endif
891.1Swdk
901.1Swdk### find out what to use for libkern
911.1SwdkKERN_AS=	library
921.1Swdk.include "${S}/lib/libkern/Makefile.inc"
931.1SwdkLIBKERN=	${KERNLIB}
941.1Swdk
951.1Swdk### find out what to use for libz
961.1Swdk.if defined(PRIMARY_PROG)
971.1SwdkLIBZ=
981.1Swdk.else
991.1SwdkZ_AS=		library
1001.1Swdk.include "${S}/lib/libz/Makefile.inc"
1011.1SwdkLIBZ=		${ZLIB}
1021.1Swdk.endif
1031.1Swdk
1041.1Swdk### find out what to use for libsa
1051.1SwdkSA_AS=		library
1061.1Swdk.if defined(PRIMARY_PROG)
1071.1SwdkSAMISCMAKEFLAGS+=SA_INCLUDE_NET=no
1081.1Swdk.endif
1091.1Swdk.if defined(SECONDARY_PROG)
1101.1SwdkSAMISCMAKEFLAGS+=SA_USE_LOADFILE=yes SA_USE_CREAD=yes
1111.1Swdk# for now:
1121.1SwdkSAMISCMAKEFLAGS+=SA_INCLUDE_NET=no
1131.1Swdk.endif
1141.1Swdk.include "${S}/lib/libsa/Makefile.inc"
1151.1SwdkLIBSA=		${SALIB}
1161.1Swdk
1171.1SwdkLIBS=		${LIBSA} ${LIBZ} ${LIBSA} ${LIBKERN}
1181.1Swdk
1191.1Swdk.PHONY: vers.c
1201.1Swdkvers.c: ${.CURDIR}/version
1211.7Slukem	${HOST_SH} ${S}/conf/newvers_stand.sh -N ${.CURDIR}/version "mipsco"
1221.1Swdk
1231.2Swdk${PROG}: machine-links ${LDSCRIPT} ${OBJS} ${LIBS}
1241.4Ssimonb	${LD} ${OFORMAT} -Map ${PROG}.map -N -x -Ttext ${LOAD_ADDRESS} \
1251.4Ssimonb	    -T ${LDSCRIPT} -e start -o ${PROG} ${OBJS} ${LIBS}
1261.1Swdk	@${SIZE} ${PROG}
1271.2Swdk.if defined(PRIMARY_PROG)
1281.5Swdk	mv ${PROG} ${PROG}.elf
1291.8Ssimonb	${OBJCOPY} --strip-all -O ecoff-bigmips ${STRIPSECTIONS} \
1301.8Ssimonb	    ${PROG}.elf ${PROG}
1311.2Swdk.endif
1321.1Swdk.if defined(CHECKSIZE_CMD)
1331.2Swdk	@${CHECKSIZE_CMD} ${PROG} ${PRIMARY_MAX_LOAD} || \
1341.1Swdk	    (rm -f ${PROG} ; false)
1351.1Swdk.endif
1361.1Swdk
1371.5SwdkCLEANFILES+=	${PROG}.map ${PROG}.elf
1381.1Swdk
1391.1Swdkcleandir distclean: cleanlibdir
1401.1Swdk
1411.1Swdkcleanlibdir:
1421.9Sjmc	-rm -rf lib
1431.1Swdk
1441.1Swdk.include <bsd.prog.mk>
1451.5Swdk
1461.5Swdk/usr/lib/crt0.o:
1471.5Swdk	true
148