Makefile revision 1.26
11.26Srin#	$NetBSD: Makefile,v 1.26 2021/02/25 03:42:14 rin Exp $
21.25Schristos
31.25Schristos.include <bsd.init.mk>
41.25Schristos.include <bsd.sys.mk>
51.1Smhitch
61.1Smhitch### what we need:
71.1Smhitch
81.25SchristosDIR_TOP=	${.CURDIR}/../../../../..
91.25SchristosDIR_SA = 	${DIR_TOP}/lib/libsa
101.25SchristosDIR_KERN=	${DIR_TOP}/lib/libkern
111.25SchristosDIR_KERN_MD=	${DIR_TOP}/lib/libkern/arch/$(MACHINE_ARCH)
121.25SchristosDIR_LIBC=	${DIR_TOP}/../common/lib/libc
131.10Sis
141.10Sis.PATH:  ${.CURDIR}/../boot $(DIR_SA) $(DIR_KERN) $(DIR_KERN_MD) \
151.10Sis	${DIR_LIBC}/gen ${DIR_LIBC}/arch/m68k/gen \
161.10Sis	${DIR_LIBC}/inet ${DIR_LIBC}/arch/m68k/inet \
171.10Sis	${DIR_LIBC}/quad ${DIR_LIBC}/arch/m68k/quad \
181.10Sis	${DIR_LIBC}/string ${DIR_LIBC}/arch/m68k/string
191.1Smhitch
201.25SchristosS=		${DIR_TOP}
211.1Smhitch
221.1Smhitch# prefer our assembler versions over assembler, and assembler over C:
231.1Smhitch
241.1Smhitch.SUFFIXES:
251.13Smrg.SUFFIXES: .out .o .po .pico .so .s .S .c .cc .C .f .y .l .ln .m4 .sh
261.1Smhitch
271.26Srin.ifdef BOOTXX_FFSV2
281.26SrinFILES=		bootxx_ffsv2
291.26SrinFSOBJS=		ffsv2.o
301.26SrinDEFS+=		-DBOOTXX_FFS_VERSION=2
311.26Srin.else
321.26SrinFILES=		bootxx_ffsv1 bootxx_fd
331.26SrinFSOBJS=		ufs.o ustarfs.o
341.26SrinDEFS+=		-DBOOTXX_FFS_VERSION=1
351.26Srin.endif
361.26Srin
371.1SmhitchBINDIR=/usr/mdec
381.1Smhitch
391.1SmhitchCOBJS = main.o console.o xd.o twiddle.o bzero.o gets.o
401.25SchristosCOBJS+=  lseek.o open.o vers.o read.o close.o dev.o errno.o
411.26SrinCOBJS+=  ${FSOBJS} panic.o files.o
421.1Smhitch
431.1SmhitchSOBJS = alloc.o ashrdi3.o ashldi3.o bcopy.o muldi3.o printf.o startit.o
441.1SmhitchSOBJS += strlen.o strcmp.o fstat.o
451.6SheSOBJS += libstubs.o memcmp.o memmove.o memset.o strncmp.o
461.1Smhitch
471.24SchristosOBJS+=	$(SOBJS) $(COBJS)
481.1Smhitch
491.26SrinDEFS+= -D_STANDALONE -DSA_EXEC_ANYOWNER -D_PRIMARY_BOOT -DSERCONSOLE
501.1Smhitch
511.1Smhitch.NOPATH: ${OBJS} x.out f.out libboot.a xxstart.o
521.1Smhitch
531.1Smhitch### main target: ###
541.1Smhitch
551.20Smattrealall: ${FILES}
561.1Smhitch
571.26SrinCLEANFILES += ${FILES} x.out f.out xxstart.o fdstart.o libboot.a
581.1Smhitch
591.25SchristosVERSIONFILE=${.CURDIR}/../boot/version
601.25SchristosVERSIONFLAGS+=-n
611.25Schristos.include "${S}/conf/newvers_stand.mk"
621.25Schristos
631.1Smhitch.include <bsd.prog.mk>
641.20Smatt.include <bsd.klinks.mk>
651.1Smhitch
661.1Smhitch### special  rules for bootblocks ###
671.1Smhitch
681.24SchristosINCPATH = -nostdinc -I${S} -I${S}/lib/libsa -I${.CURDIR}
691.1SmhitchINCPATH += -I${.CURDIR}/../boot -I${.CURDIR}/../../..
701.14SmrgINCPATH += -I${.CURDIR}/../elf2bb -I${.OBJDIR}
711.1Smhitch
721.1SmhitchAFLAGS += -m68030 -l
731.22SmartinCAFLAGS += -Wa,-l -Wa,-march=68030 -Wa,-mcpu=68030 ${INCPATH} -D_PRIMARY_BOOT
741.1Smhitch
751.19SjoergCOPTIM= -Os -fomit-frame-pointer -fcse-follow-jumps -fcse-skip-blocks
761.21SmlelstvCOPTIM+= -Wa,-l -m68060 -Wa,-mcpu=68030 -fno-unwind-tables
771.4SthorpejCFLAGS= -ffreestanding ${COPTIM} ${INCPATH} ${DEFS} -Wall #-Wstrict-prototypes
781.1Smhitch
791.8SlukemNETBSD_VERS!=	${HOST_SH} ${.CURDIR}/../../../../../conf/osrelease.sh
801.1SmhitchDEFS+=	-DNETBSD_VERS='"${NETBSD_VERS}"'
811.5Smhitch
821.5Smhitch# Use small daddr_t to avoid code bloat
831.5SmhitchDEFS+=	-D__daddr_t=int32_t
841.1Smhitch
851.1Smhitch.c.o:
861.20Smatt	${_MKTARGET_COMPILE}
871.1Smhitch	${CC} ${CFLAGS} -S $< -o $*.s
881.1Smhitch	${TXLT} < $*.s | ${AS} ${AFLAGS} -o $*.o
891.1Smhitch	rm $*.s
901.1Smhitch
911.20Smatt.s.o:
921.20Smatt	${_MKTARGET_COMPILE}
931.20Smatt	${CC} ${CAFLAGS} ${COPTS} -x assembler-with-cpp -o $@ -c $<
941.20Smatt
951.20Smatt.S.o:
961.20Smatt	${_MKTARGET_COMPILE}
971.20Smatt	${CC} ${CAFLAGS} ${COPTS} -x assembler-with-cpp -o $@ -c $<
981.1Smhitch
991.26Srinbootxx_ffsv1: x.out
1001.26Srin	${_MKTARGET_CREATE}
1011.26Srin	${RELOC2BB} x.out $@ || (${NM} -u x.out && false)
1021.26Srin
1031.26Srinbootxx_ffsv2: x.out
1041.20Smatt	${_MKTARGET_CREATE}
1051.17Smrg	${RELOC2BB} x.out $@ || (${NM} -u x.out && false)
1061.1Smhitch
1071.1Smhitchbootxx_fd: f.out
1081.20Smatt	${_MKTARGET_CREATE}
1091.17Smrg	${RELOC2BB} -F f.out $@ || (${NM} -u f.out && false)
1101.1Smhitch
1111.1Smhitchx.out: xxstart.o libboot.a
1121.20Smatt	${_MKTARGET_LINK}
1131.20Smatt	${LD} ${LDFLAGS} -r -dc -e start -o $@ $>
1141.1Smhitch	${SIZE} $@
1151.1Smhitch	${NM} -u $@
1161.1Smhitch
1171.1Smhitchf.out: fdstart.o libboot.a
1181.20Smatt	${_MKTARGET_LINK}
1191.20Smatt	${LD} ${LDFLAGS} -r -dc -e start -o $@ $>
1201.1Smhitch	${SIZE} $@
1211.1Smhitch	${NM} -u $@
1221.1Smhitch
1231.1Smhitchxxstart.o: ${.CURDIR}/../boot/bbstart.s
1241.20Smatt	${_MKTARGET_COMPILE}
1251.1Smhitch	${CC} ${CAFLAGS} ${COPTS} -x assembler-with-cpp \
1261.1Smhitch		-o $@ -c $>
1271.1Smhitch
1281.1Smhitchfdstart.o: ${.CURDIR}/../boot//bbstart.s
1291.20Smatt	${_MKTARGET_COMPILE}
1301.1Smhitch	${CC} -DAUTOLOAD=8192 ${CAFLAGS} ${COPTS} -x assembler-with-cpp \
1311.1Smhitch		-o $@ -c $>
1321.1Smhitch
1331.1Smhitchlibboot.a: ${OBJS}
1341.20Smatt	${_MKTARGET_BUILD}
1351.20Smatt	${AR} crs $@ $> && ${RANLIB} $@
1361.1Smhitch
1371.1Smhitch# make sure these are built:
1381.1Smhitch
1391.1Smhitch${COBJS}: ${TXLT}
1401.1Smhitch${FILES}: ${RELOC2BB}
1411.2Saymeric
1421.2Saymeric.include "${.CURDIR}/../Makefile.booters"
143