1 1.7 christos # $NetBSD: Makefile.booters,v 1.7 2017/04/08 19:53:20 christos Exp $ 2 1.1 pooka 3 1.6 christos NOMAN=1 4 1.5 christos .include <bsd.own.mk> 5 1.1 pooka 6 1.1 pooka # $S must correspond to the top of the 'sys' tree 7 1.1 pooka S= ${.CURDIR}/../../../.. 8 1.1 pooka 9 1.1 pooka BINMODE?= 444 10 1.1 pooka 11 1.1 pooka # XXX SHOULD NOT NEED TO DEFINE THESE! 12 1.1 pooka LIBCRT0= 13 1.4 tsutsui LIBCRTI= 14 1.1 pooka LIBC= 15 1.1 pooka LIBCRTBEGIN= 16 1.1 pooka LIBCRTEND= 17 1.1 pooka 18 1.1 pooka .PATH: ${.CURDIR}/../common 19 1.1 pooka AFLAGS+= -D_LOCORE -D_KERNEL -mno-abicalls 20 1.1 pooka # -I${.CURDIR}/../.. done by Makefile.inc 21 1.1 pooka CPPFLAGS+= -nostdinc -D_STANDALONE -DNO_ABICALLS -D_NO_PROM_DEFINES \ 22 1.1 pooka -I${.OBJDIR} -I${S} 23 1.1 pooka # compiler flags for smallest code size 24 1.3 christos CFLAGS= -ffreestanding -Os -mmemcpy -mno-abicalls -G 128 25 1.1 pooka LDBUG= -T $S/arch/mips/conf/stand.ldscript 26 1.1 pooka 27 1.1 pooka NETBSD_VERS!= ${HOST_SH} ${.CURDIR}/../../../../conf/osrelease.sh 28 1.1 pooka CPPFLAGS+= -DNETBSD_VERS='"${NETBSD_VERS}"' 29 1.1 pooka 30 1.1 pooka PRIMARY_LOAD_ADDRESS?= 0x80000000 31 1.1 pooka SECONDARY_LOAD_ADDRESS?=0x80000000 32 1.1 pooka 33 1.1 pooka NOMAN= # defined 34 1.1 pooka 35 1.1 pooka .if defined(PRIMARY_PROG) 36 1.1 pooka PROG= ${PRIMARY_PROG} 37 1.1 pooka SRCS = start.S bootxx.c 38 1.1 pooka SRCS+= devopen.c conf.c ace.c printf.c putchar.c 39 1.1 pooka 40 1.1 pooka LOAD_ADDRESS= ${PRIMARY_LOAD_ADDRESS} 41 1.1 pooka # Pick a number, any number... 42 1.1 pooka PRIMARY_MAX_TOTAL!= expr 16 \* 1024 43 1.1 pooka 44 1.1 pooka CPPFLAGS+= -DPRIMARY_BOOTBLOCK \ 45 1.1 pooka -DPRIMARY_LOAD_ADDRESS="${PRIMARY_LOAD_ADDRESS}" \ 46 1.1 pooka -DNO_GETCHAR \ 47 1.1 pooka -DLIBSA_NO_FS_SYMLINK -DLIBSA_NO_FS_WRITE \ 48 1.1 pooka -DLIBSA_NO_FS_CLOSE \ 49 1.1 pooka -DLIBSA_NO_DEV_CLOSE \ 50 1.1 pooka -DLIBSA_SINGLE_DEVICE=ace \ 51 1.1 pooka -D"aceioctl(x,y,z)=EINVAL" -D"aceclose(f)=0" \ 52 1.1 pooka -DLIBSA_NO_TWIDDLE \ 53 1.1 pooka -DLIBSA_NO_FD_CHECKING \ 54 1.1 pooka -DLIBSA_NO_RAW_ACCESS \ 55 1.1 pooka -DLIBSA_NO_DISKLABEL_MSGS \ 56 1.1 pooka -DALLOC_FIRST_FIT \ 57 1.1 pooka -DLIBSA_USE_MEMCPY -DLIBSA_USE_MEMSET 58 1.1 pooka 59 1.1 pooka CHECKSIZE_CMD?= SIZE=${SIZE} ${HOST_SH} ${.CURDIR}/../common/checksize.sh 60 1.1 pooka 61 1.1 pooka .elif defined(SECONDARY_PROG) 62 1.1 pooka PROG= ${SECONDARY_PROG} 63 1.1 pooka LOAD_ADDRESS= ${SECONDARY_LOAD_ADDRESS} 64 1.1 pooka CPPFLAGS+= -DSECONDARY_BOOTBLOCK -DHEAP_VARIABLE 65 1.7 christos 66 1.7 christos .include "${S}/conf/newvers_stand.mk" 67 1.1 pooka .else 68 1.1 pooka # XXX ? 69 1.1 pooka .endif 70 1.1 pooka 71 1.1 pooka ### find out what to use for libkern 72 1.1 pooka KERN_AS= library 73 1.1 pooka .include "${S}/lib/libkern/Makefile.inc" 74 1.1 pooka LIBKERN= ${KERNLIB} 75 1.1 pooka 76 1.1 pooka ### find out what to use for libz 77 1.1 pooka .if defined(PRIMARY_PROG) 78 1.1 pooka LIBZ= 79 1.1 pooka .else 80 1.1 pooka Z_AS= library 81 1.1 pooka .include "${S}/lib/libz/Makefile.inc" 82 1.1 pooka LIBZ= ${ZLIB} 83 1.1 pooka .endif 84 1.1 pooka 85 1.1 pooka ### find out what to use for libsa 86 1.1 pooka SA_AS= library 87 1.1 pooka .if defined(PRIMARY_PROG) 88 1.1 pooka SAMISCMAKEFLAGS+=SA_INCLUDE_NET=no 89 1.1 pooka .endif 90 1.1 pooka .if defined(SECONDARY_PROG) 91 1.1 pooka SAMISCMAKEFLAGS+=SA_USE_LOADFILE=yes SA_USE_CREAD=yes 92 1.1 pooka SAMISCMAKEFLAGS+=SA_INCLUDE_NET=yes 93 1.1 pooka .endif 94 1.1 pooka .include "${S}/lib/libsa/Makefile.inc" 95 1.1 pooka LIBSA= ${SALIB} 96 1.1 pooka 97 1.1 pooka LIBS= ${LIBSA} ${LIBZ} ${LIBSA} ${LIBKERN} 98 1.1 pooka 99 1.1 pooka .include <bsd.own.mk> 100 1.1 pooka 101 1.2 matt ${PROG}: ${OBJS} ${LIBS} 102 1.2 matt ${_MKTARGET_LINK} 103 1.1 pooka ${LD} -Map ${PROG}.map -N -x -Ttext ${LOAD_ADDRESS} \ 104 1.1 pooka ${LDBUG} -e start -o ${PROG}.elf ${OBJS} ${LIBS} 105 1.1 pooka @${SIZE} ${PROG}.elf 106 1.1 pooka .if defined(CHECKSIZE_CMD) 107 1.1 pooka @${CHECKSIZE_CMD} ${PROG}.elf ${PRIMARY_MAX_LOAD} ${PRIMARY_MAX_TOTAL} || \ 108 1.1 pooka (rm -f ${PROG}.elf ; false) 109 1.1 pooka .endif 110 1.1 pooka @${OBJCOPY} --output-target=binary ${PROG}.elf ${PROG}.bin 111 1.1 pooka dd if=${PROG}.bin of=${PROG} bs=512 conv=sync 112 1.1 pooka 113 1.1 pooka .include <bsd.prog.mk> 114 1.2 matt .include <bsd.klinks.mk> 115 1.1 pooka 116 1.1 pooka CLEANFILES+= ${PROG}.map 117 1.1 pooka 118 1.1 pooka cleandir distclean: cleanlibdir 119 1.1 pooka 120 1.1 pooka cleanlibdir: 121 1.1 pooka -rm -rf lib 122