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