11.28Srin#	$NetBSD: Makefile,v 1.28 2022/04/29 07:45:20 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.27SrinCOBJS = main.o console.o xd.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.28SrinDEFS+=	-D_STANDALONE -DSA_EXEC_ANYOWNER -DSA_HARDCODED_SECSIZE \
501.28Srin	-D_PRIMARY_BOOT -DSERCONSOLE
511.1Smhitch
521.1Smhitch.NOPATH: ${OBJS} x.out f.out libboot.a xxstart.o
531.1Smhitch
541.1Smhitch### main target: ###
551.1Smhitch
561.20Smattrealall: ${FILES}
571.1Smhitch
581.26SrinCLEANFILES += ${FILES} x.out f.out xxstart.o fdstart.o libboot.a
591.1Smhitch
601.25SchristosVERSIONFILE=${.CURDIR}/../boot/version
611.25SchristosVERSIONFLAGS+=-n
621.25Schristos.include "${S}/conf/newvers_stand.mk"
631.25Schristos
641.1Smhitch.include <bsd.prog.mk>
651.20Smatt.include <bsd.klinks.mk>
661.1Smhitch
671.1Smhitch### special  rules for bootblocks ###
681.1Smhitch
691.24SchristosINCPATH = -nostdinc -I${S} -I${S}/lib/libsa -I${.CURDIR}
701.1SmhitchINCPATH += -I${.CURDIR}/../boot -I${.CURDIR}/../../..
711.14SmrgINCPATH += -I${.CURDIR}/../elf2bb -I${.OBJDIR}
721.1Smhitch
731.1SmhitchAFLAGS += -m68030 -l
741.22SmartinCAFLAGS += -Wa,-l -Wa,-march=68030 -Wa,-mcpu=68030 ${INCPATH} -D_PRIMARY_BOOT
751.1Smhitch
761.19SjoergCOPTIM= -Os -fomit-frame-pointer -fcse-follow-jumps -fcse-skip-blocks
771.21SmlelstvCOPTIM+= -Wa,-l -m68060 -Wa,-mcpu=68030 -fno-unwind-tables
781.4SthorpejCFLAGS= -ffreestanding ${COPTIM} ${INCPATH} ${DEFS} -Wall #-Wstrict-prototypes
791.1Smhitch
801.8SlukemNETBSD_VERS!=	${HOST_SH} ${.CURDIR}/../../../../../conf/osrelease.sh
811.1SmhitchDEFS+=	-DNETBSD_VERS='"${NETBSD_VERS}"'
821.5Smhitch
831.5Smhitch# Use small daddr_t to avoid code bloat
841.5SmhitchDEFS+=	-D__daddr_t=int32_t
851.1Smhitch
861.1Smhitch.c.o:
871.20Smatt	${_MKTARGET_COMPILE}
881.1Smhitch	${CC} ${CFLAGS} -S $< -o $*.s
891.1Smhitch	${TXLT} < $*.s | ${AS} ${AFLAGS} -o $*.o
901.1Smhitch	rm $*.s
911.1Smhitch
921.20Smatt.s.o:
931.20Smatt	${_MKTARGET_COMPILE}
941.20Smatt	${CC} ${CAFLAGS} ${COPTS} -x assembler-with-cpp -o $@ -c $<
951.20Smatt
961.20Smatt.S.o:
971.20Smatt	${_MKTARGET_COMPILE}
981.20Smatt	${CC} ${CAFLAGS} ${COPTS} -x assembler-with-cpp -o $@ -c $<
991.1Smhitch
1001.26Srinbootxx_ffsv1: x.out
1011.26Srin	${_MKTARGET_CREATE}
1021.26Srin	${RELOC2BB} x.out $@ || (${NM} -u x.out && false)
1031.26Srin
1041.26Srinbootxx_ffsv2: x.out
1051.20Smatt	${_MKTARGET_CREATE}
1061.17Smrg	${RELOC2BB} x.out $@ || (${NM} -u x.out && false)
1071.1Smhitch
1081.1Smhitchbootxx_fd: f.out
1091.20Smatt	${_MKTARGET_CREATE}
1101.17Smrg	${RELOC2BB} -F f.out $@ || (${NM} -u f.out && false)
1111.1Smhitch
1121.1Smhitchx.out: xxstart.o libboot.a
1131.20Smatt	${_MKTARGET_LINK}
1141.20Smatt	${LD} ${LDFLAGS} -r -dc -e start -o $@ $>
1151.1Smhitch	${SIZE} $@
1161.1Smhitch	${NM} -u $@
1171.1Smhitch
1181.1Smhitchf.out: fdstart.o libboot.a
1191.20Smatt	${_MKTARGET_LINK}
1201.20Smatt	${LD} ${LDFLAGS} -r -dc -e start -o $@ $>
1211.1Smhitch	${SIZE} $@
1221.1Smhitch	${NM} -u $@
1231.1Smhitch
1241.1Smhitchxxstart.o: ${.CURDIR}/../boot/bbstart.s
1251.20Smatt	${_MKTARGET_COMPILE}
1261.1Smhitch	${CC} ${CAFLAGS} ${COPTS} -x assembler-with-cpp \
1271.1Smhitch		-o $@ -c $>
1281.1Smhitch
1291.1Smhitchfdstart.o: ${.CURDIR}/../boot//bbstart.s
1301.20Smatt	${_MKTARGET_COMPILE}
1311.1Smhitch	${CC} -DAUTOLOAD=8192 ${CAFLAGS} ${COPTS} -x assembler-with-cpp \
1321.1Smhitch		-o $@ -c $>
1331.1Smhitch
1341.1Smhitchlibboot.a: ${OBJS}
1351.20Smatt	${_MKTARGET_BUILD}
1361.20Smatt	${AR} crs $@ $> && ${RANLIB} $@
1371.1Smhitch
1381.1Smhitch# make sure these are built:
1391.1Smhitch
1401.1Smhitch${COBJS}: ${TXLT}
1411.1Smhitch${FILES}: ${RELOC2BB}
1421.2Saymeric
1431.2Saymeric.include "${.CURDIR}/../Makefile.booters"
144