1 1.3.2.2 skrll # $NetBSD: Makefile.bootprogs,v 1.3.2.2 2017/08/28 17:51:36 skrll Exp $ 2 1.3.2.2 skrll 3 1.3.2.2 skrll NOSSP=yes 4 1.3.2.2 skrll NOPIE=yes 5 1.3.2.2 skrll 6 1.3.2.2 skrll .include <bsd.own.mk> 7 1.3.2.2 skrll .include <bsd.klinks.mk> 8 1.3.2.2 skrll 9 1.3.2.2 skrll S= ${.CURDIR}/../../../../.. 10 1.3.2.2 skrll COMMON= ${.CURDIR}/../common 11 1.3.2.2 skrll 12 1.3.2.2 skrll .PATH: ${COMMON} 13 1.3.2.2 skrll 14 1.3.2.2 skrll STRIPFLAG= 15 1.3.2.2 skrll BINMODE= 444 16 1.3.2.2 skrll 17 1.3.2.2 skrll # XXX SHOULD NOT NEED TO DEFINE THESE! 18 1.3.2.2 skrll LIBCRT0= 19 1.3.2.2 skrll LIBCRTI= 20 1.3.2.2 skrll LIBC= 21 1.3.2.2 skrll LIBCRTBEGIN= 22 1.3.2.2 skrll LIBCRTEND= 23 1.3.2.2 skrll 24 1.3.2.2 skrll STRIP?= strip 25 1.3.2.2 skrll 26 1.3.2.2 skrll CHECKSIZE_CMD= SIZE=${SIZE} ${HOST_SH} ${COMMON}/checksize.sh 27 1.3.2.2 skrll 28 1.3.2.2 skrll AFLAGS+= -DASSEMBLER -D_LOCORE -mno-abicalls -mips64 29 1.3.2.2 skrll # -I${.CURDIR}/../.. done by Makefile.inc 30 1.3.2.2 skrll CPPFLAGS+= -nostdinc -I${.OBJDIR} -D_STANDALONE -I${S} 31 1.3.2.2 skrll CFLAGS= -Os -g -ffreestanding -mno-abicalls -msoft-float -G 0 32 1.3.2.2 skrll CFLAGS+= -mips64 33 1.3.2.2 skrll CFLAGS+= -Werror ${CWARNFLAGS} 34 1.3.2.2 skrll 35 1.3.2.2 skrll NETBSD_VERS!=${HOST_SH} ${S}/conf/osrelease.sh 36 1.3.2.2 skrll CPPFLAGS+= -DNETBSD_VERS='"${NETBSD_VERS}"' 37 1.3.2.2 skrll 38 1.3.2.2 skrll CWARNFLAGS+= -Wno-main 39 1.3.2.2 skrll CWARNFLAGS+= -Wall -Wmissing-prototypes -Wstrict-prototypes -Wpointer-arith 40 1.3.2.2 skrll CWARNFLAGS+= -Wno-pointer-sign 41 1.3.2.2 skrll 42 1.3.2.2 skrll VERSIONFLAGS+=-n 43 1.3.2.2 skrll .include "${S}/conf/newvers_stand.mk" 44 1.3.2.2 skrll 45 1.3.2.2 skrll # 46 1.3.2.2 skrll # Refer to CFE documentation for a description of these regions. 47 1.3.2.2 skrll # 48 1.3.2.2 skrll 49 1.3.2.2 skrll REGION1_START= 0x20000000 # "Region 1 start" 50 1.3.2.2 skrll REGION1_SIZE!= expr 256 \* 1024 # 256k 51 1.3.2.2 skrll 52 1.3.2.2 skrll LDSCRIPT= ${COMMON}/boot.ldscript 53 1.3.2.2 skrll 54 1.3.2.2 skrll # our memory lauout: 55 1.3.2.2 skrll 56 1.3.2.2 skrll # 'unified' boot loaders (e.g. netboot) can consume all of region 57 1.3.2.2 skrll # 1 for their text+data, or text+data+bss. 58 1.3.2.2 skrll 59 1.3.2.2 skrll UNIFIED_LOAD_ADDRESS= ${REGION1_START} 60 1.3.2.2 skrll UNIFIED_MAX_LOAD!= expr ${REGION1_SIZE} 61 1.3.2.2 skrll UNIFIED_MAX_TOTAL!= expr ${REGION1_SIZE} 62 1.3.2.2 skrll 63 1.3.2.2 skrll #UNIFIED_HEAP_START= right after secondary bss 64 1.3.2.2 skrll UNIFIED_HEAP_LIMIT= (${REGION1_START} + ${REGION1_SIZE}) 65 1.3.2.2 skrll 66 1.3.2.2 skrll # two-stage boot loaders must share region 1. The first stage 67 1.3.2.2 skrll # loads into the lowest portion, and uses the higest portion 68 1.3.2.2 skrll # for its heap. The second stage loads in between the primary image 69 1.3.2.2 skrll # and the heap, and can reuse the memory after it (i.e. the primary's 70 1.3.2.2 skrll # heap) for its own heap. 71 1.3.2.2 skrll 72 1.3.2.2 skrll PRIMARY_LOAD_ADDRESS= ${REGION1_START} 73 1.3.2.2 skrll #PRIMARY_MAX_LOAD= booter dependent, no more than ${PRIMARY_MAX_TOTAL} 74 1.3.2.2 skrll PRIMARY_MAX_TOTAL!= expr 16 \* 1024 75 1.3.2.2 skrll 76 1.3.2.2 skrll # XXX SECONDARY_LOAD_ADDRESS should be 77 1.3.2.2 skrll # XXX (${PRIMARY_LOAD_ADDRESS} + ${PRIMARY_MAX_TOTAL}) bt there's no easy 78 1.3.2.2 skrll # XXX way to do that calculation and 'ld' wants a single number. 79 1.3.2.2 skrll SECONDARY_LOAD_ADDRESS= 0x20004000 # XXX 80 1.3.2.2 skrll SECONDARY_MAX_LOAD!= expr 112 \* 1024 81 1.3.2.2 skrll SECONDARY_MAX_TOTAL!= expr ${REGION1_SIZE} - ${PRIMARY_MAX_TOTAL} 82 1.3.2.2 skrll 83 1.3.2.2 skrll PRIMARY_HEAP_START= (${SECONDARY_LOAD_ADDRESS} + ${SECONDARY_MAX_LOAD}) 84 1.3.2.2 skrll PRIMARY_HEAP_LIMIT= (${REGION1_START} + ${REGION1_SIZE}) 85 1.3.2.2 skrll 86 1.3.2.2 skrll #SECONDARY_HEAP_START= right after secondary bss 87 1.3.2.2 skrll SECONDARY_HEAP_LIMIT= (${REGION1_START} + ${REGION1_SIZE}) 88 1.3.2.2 skrll 89 1.3.2.2 skrll # standalone programs are like kernels. They load at 90 1.3.2.2 skrll # 0xfffffc0000300000 and can use the rest of memory. 91 1.3.2.2 skrll 92 1.3.2.2 skrll STANDPROG_LOAD_ADDRESS= 0xfffffc0000300000 93 1.3.2.2 skrll 94 1.3.2.2 skrll 95 1.3.2.2 skrll FILE_FORMAT_CPPFLAGS= -DBOOT_ELF 96 1.3.2.2 skrll 97 1.3.2.2 skrll UNIFIED_CPPFLAGS= -DUNIFIED_BOOTBLOCK \ 98 1.3.2.2 skrll -DHEAP_LIMIT="${UNIFIED_HEAP_LIMIT}" \ 99 1.3.2.2 skrll ${FILE_FORMAT_CPPFLAGS} 100 1.3.2.2 skrll 101 1.3.2.2 skrll PRIMARY_CPPFLAGS= -DPRIMARY_BOOTBLOCK \ 102 1.3.2.2 skrll -DSECONDARY_LOAD_ADDRESS="${SECONDARY_LOAD_ADDRESS}" \ 103 1.3.2.2 skrll -DSECONDARY_MAX_LOAD="${SECONDARY_MAX_LOAD}" \ 104 1.3.2.2 skrll -DHEAP_LIMIT="${PRIMARY_HEAP_LIMIT}" \ 105 1.3.2.2 skrll -DHEAP_START="${PRIMARY_HEAP_START}" 106 1.3.2.2 skrll 107 1.3.2.2 skrll SECONDARY_CPPFLAGS= -DSECONDARY_BOOTBLOCK \ 108 1.3.2.2 skrll -DHEAP_LIMIT="${SECONDARY_HEAP_LIMIT}" \ 109 1.3.2.2 skrll ${FILE_FORMAT_CPPFLAGS} 110 1.3.2.2 skrll 111 1.3.2.2 skrll STANDPROG_CPPFLAGS= -DSTANDALONE_PROGRAM 112 1.3.2.2 skrll 113 1.3.2.2 skrll .include <bsd.prog.mk> 114 1.3.2.2 skrll 115 1.3.2.2 skrll ### find out what to use for libkern 116 1.3.2.2 skrll KERN_AS= library 117 1.3.2.2 skrll .include "${S}/lib/libkern/Makefile.inc" 118 1.3.2.2 skrll LIBKERN= ${KERNLIB} 119 1.3.2.2 skrll 120 1.3.2.2 skrll ### find out what to use for libz 121 1.3.2.2 skrll Z_AS= library 122 1.3.2.2 skrll .include "${S}/lib/libz/Makefile.inc" 123 1.3.2.2 skrll LIBZ= ${ZLIB} 124 1.3.2.2 skrll 125 1.3.2.2 skrll ### find out what to use for libsa 126 1.3.2.2 skrll SA_AS= library 127 1.3.2.2 skrll SAMISCMAKEFLAGS+="SA_USE_LOADFILE=yes" 128 1.3.2.2 skrll .include "${S}/lib/libsa/Makefile.inc" 129 1.3.2.2 skrll LIBSA= ${SALIB} 130 1.3.2.2 skrll 131 1.3.2.2 skrll /usr/lib/crt0.o: 132 1.3.2.2 skrll true 133 1.3.2.2 skrll 134 1.3.2.2 skrll /usr/lib/crtbegin.o: 135 1.3.2.2 skrll true 136 1.3.2.2 skrll 137 1.3.2.2 skrll /usr/lib/crtend.o: 138 1.3.2.2 skrll true 139 1.3.2.2 skrll 140 1.3.2.2 skrll cleandir: .WAIT cleandirlocal 141 1.3.2.2 skrll cleandirlocal: 142 1.3.2.2 skrll -rm -rf lib 143