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