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