Makefile.booters revision 1.23
1# $NetBSD: Makefile.booters,v 1.23 2016/09/18 14:39:15 christos Exp $ 2 3NOMAN= # defined 4NOPIE= # defined 5 6.include <bsd.init.mk> 7 8S= ${.CURDIR}/../../../.. 9MIPS= ${S}/arch/mips 10MIPSCO= ${S}/arch/mipsco 11 12.PATH: ${.CURDIR}/../common 13 14BINMODE?= 444 15 16# XXX SHOULD NOT NEED TO DEFINE THESE! 17LIBCRT0= 18LIBCRTI= 19LIBC= 20LIBCRTBEGIN= 21LIBCRTEND= 22 23realall: ${PROG} 24 25AFLAGS+= -D_LOCORE -D_KERNEL -DASSEMBLER -mno-abicalls 26# -I${.CURDIR}/../.. done by Makefile.inc 27CPPFLAGS+= -nostdinc -D_STANDALONE -DNO_ABICALLS -D_NO_PROM_DEFINES 28CPPFLAGS+= -I${.OBJDIR} -I${S} 29# compiler flags for smallest code size 30#CFLAGS= -Os -mmemcpy -mno-abicalls -G 128 31CFLAGS= -Os -mmemcpy -ffreestanding -mno-abicalls -msoft-float -G 128 32CFLAGS+= -Wall -Wmissing-prototypes -Wstrict-prototypes -Wpointer-arith 33 34NETBSD_VERS!= ${HOST_SH} ${S}/conf/osrelease.sh 35CPPFLAGS+= -DNETBSD_VERS='"${NETBSD_VERS}"' 36 37PRIMARY_LOAD_ADDRESS?= 0x80600000 38SECONDARY_LOAD_ADDRESS?=0x80610000 39 40LDSCRIPT?= ${MIPSCO}/conf/stand.ldscript 41 42.include <bsd.own.mk> 43 44.if defined(PRIMARY_PROG) 45PROG= ${PRIMARY_PROG} 46SRCS = start.S bootxx.c callvec.c 47SRCS+= devopen.c conf.c saio.c 48SRCS+= prom.S 49 50LOAD_ADDRESS= ${PRIMARY_LOAD_ADDRESS} 51 52CPPFLAGS+= -DPRIMARY_BOOTBLOCK \ 53 -DPRIMARY_LOAD_ADDRESS="${PRIMARY_LOAD_ADDRESS}" \ 54 -DNO_GETCHAR \ 55 -DLIBSA_NO_FS_SYMLINK -DLIBSA_NO_FS_WRITE \ 56 -DLIBSA_NO_FS_CLOSE \ 57 -DLIBSA_NO_DEV_CLOSE \ 58 -DLIBSA_NO_DEV_IOCTL \ 59 -DLIBSA_SINGLE_DEVICE=saio \ 60 -D"saioioctl(x,y,z)=EINVAL" -D"saioclose(f)=0" \ 61 -DLIBSA_NO_TWIDDLE \ 62 -DLIBSA_NO_FD_CHECKING \ 63 -DLIBSA_NO_DISKLABEL_MSGS \ 64 -DLIBSA_NO_RAW_ACCESS \ 65 -DALLOC_FIRST_FIT 66 67 68CHECKSIZE_CMD?= SIZE=${SIZE} ${HOST_SH} ${.CURDIR}/../common/checksize.sh 69 70STRIPSECTIONS?= -R .reginfo -R .mdebug.abi32 -R .comment -R .pdr \ 71 -R .MIPS.abiflags -R .gnu.attributes 72 73.elif defined(SECONDARY_PROG) 74PROG= ${SECONDARY_PROG} 75LOAD_ADDRESS= ${SECONDARY_LOAD_ADDRESS} 76CPPFLAGS+= -DSECONDARY_BOOTBLOCK 77SRCS+= vers.c 78CLEANFILES+= vers.c 79.else 80 81.endif 82 83### find out what to use for libkern 84KERN_AS= library 85.include "${S}/lib/libkern/Makefile.inc" 86LIBKERN= ${KERNLIB} 87 88### find out what to use for libz 89.if defined(PRIMARY_PROG) 90LIBZ= 91.else 92Z_AS= library 93.include "${S}/lib/libz/Makefile.inc" 94LIBZ= ${ZLIB} 95.endif 96 97### find out what to use for libsa 98SA_AS= library 99.if defined(PRIMARY_PROG) 100SAMISCMAKEFLAGS+=SA_INCLUDE_NET=no 101.endif 102.if defined(SECONDARY_PROG) 103SAMISCMAKEFLAGS+=SA_USE_LOADFILE=yes SA_USE_CREAD=yes 104# for now: 105SAMISCMAKEFLAGS+=SA_INCLUDE_NET=no 106.endif 107.include "${S}/lib/libsa/Makefile.inc" 108LIBSA= ${SALIB} 109 110LIBS= ${LIBSA} ${LIBZ} ${LIBSA} ${LIBKERN} 111 112.PHONY: vers.c 113vers.c: ${.CURDIR}/version 114 ${HOST_SH} ${S}/conf/newvers_stand.sh ${${MKREPRO} == "yes" :?:-D} \ 115 -N ${.CURDIR}/version "mipsco" 116 117${PROG}: ${LDSCRIPT} ${OBJS} ${LIBS} 118 ${_MKTARGET_LINK} 119 ${LD} ${OFORMAT} -Map ${PROG}.map -N -x -Ttext ${LOAD_ADDRESS} \ 120 -T ${LDSCRIPT} -e start -o ${PROG} ${OBJS} ${LIBS} 121 @${SIZE} ${PROG} 122.if defined(PRIMARY_PROG) 123 mv ${PROG} ${PROG}.elf 124 ${OBJCOPY} --strip-all -O ecoff-bigmips ${STRIPSECTIONS} \ 125 ${PROG}.elf ${PROG} 126.endif 127.if defined(CHECKSIZE_CMD) 128 @${CHECKSIZE_CMD} ${PROG} ${PRIMARY_MAX_LOAD} || \ 129 (rm -f ${PROG} ; false) 130.endif 131 132CLEANFILES+= ${PROG}.map ${PROG}.elf 133 134cleandir distclean: .WAIT cleanlibdir 135 136cleanlibdir: 137 -rm -rf lib 138 139.include <bsd.prog.mk> 140.include <bsd.klinks.mk> 141