1 1.2 wdk # $NetBSD: Makefile.booters,v 1.2 2000/09/26 09:11:04 wdk Exp $ 2 1.1 wdk 3 1.1 wdk S= ${.CURDIR}/../../../.. 4 1.1 wdk MIPS= ${S}/arch/mips 5 1.1 wdk MIPSCO= ${S}/arch/mipsco 6 1.1 wdk 7 1.1 wdk .PATH: ${.CURDIR}/../common 8 1.1 wdk 9 1.2 wdk .PHONY: machine-links 10 1.2 wdk beforedepend: machine-links 11 1.2 wdk machine-links: machine mipsco mips 12 1.2 wdk machine mipsco: 13 1.1 wdk -rm -f ${.TARGET} 14 1.1 wdk ln -s ${MIPSCO}/include ${.TARGET} 15 1.1 wdk 16 1.2 wdk mips: 17 1.1 wdk -rm -f ${.TARGET} 18 1.1 wdk ln -s ${MIPS}/include ${.TARGET} 19 1.1 wdk 20 1.2 wdk CLEANFILES+= machine mipsco mips 21 1.2 wdk 22 1.1 wdk BINMODE?= 444 23 1.1 wdk 24 1.1 wdk AFLAGS+= -D_LOCORE -D_KERNEL 25 1.1 wdk # -I${.CURDIR}/../.. done by Makefile.inc 26 1.1 wdk CPPFLAGS+= -nostdinc -D_STANDALONE -DNO_ABICALLS -D_NO_PROM_DEFINES 27 1.1 wdk CPPFLAGS+= -I${.OBJDIR} -I${S} 28 1.1 wdk # compiler flags for smallest code size 29 1.1 wdk CFLAGS= -Os -mmemcpy -mno-abicalls -G 128 30 1.1 wdk 31 1.1 wdk NETBSD_VERS!= sh ${S}/conf/osrelease.sh 32 1.1 wdk CPPFLAGS+= -DNETBSD_VERS='"${NETBSD_VERS}"' 33 1.1 wdk 34 1.1 wdk PRIMARY_LOAD_ADDRESS?= 0x80600000 35 1.1 wdk SECONDARY_LOAD_ADDRESS?=0x80610000 36 1.1 wdk 37 1.1 wdk PRIMARY_LDSCRIPT?= ${MIPSCO}/conf/stand.ldscript 38 1.1 wdk SECONDARY_LDSCRIPT?= ${MIPS}/conf/stand.ldscript.be 39 1.1 wdk 40 1.1 wdk .if defined(PRIMARY_PROG) 41 1.1 wdk PROG= ${PRIMARY_PROG} 42 1.1 wdk SRCS = start.S bootxx.c callvec.c 43 1.1 wdk SRCS+= devopen.c conf.c saio.c 44 1.1 wdk SRCS+= prom.S 45 1.1 wdk 46 1.1 wdk LOAD_ADDRESS= ${PRIMARY_LOAD_ADDRESS} 47 1.1 wdk LDSCRIPT= ${PRIMARY_LDSCRIPT} 48 1.1 wdk 49 1.1 wdk CPPFLAGS+= -DPRIMARY_BOOTBLOCK \ 50 1.1 wdk -DPRIMARY_LOAD_ADDRESS="${PRIMARY_LOAD_ADDRESS}" \ 51 1.1 wdk -DNO_GETCHAR \ 52 1.1 wdk -DLIBSA_NO_FS_SYMLINK -DLIBSA_NO_FS_WRITE \ 53 1.1 wdk -DLIBSA_NO_FS_CLOSE \ 54 1.1 wdk -DLIBSA_NO_DEV_CLOSE \ 55 1.1 wdk -DLIBSA_SINGLE_DEVICE=saio \ 56 1.1 wdk -D"saioioctl(x,y,z)=EINVAL" -D"saioclose(f)=0" \ 57 1.1 wdk -DLIBSA_NO_TWIDDLE \ 58 1.1 wdk -DLIBSA_NO_FD_CHECKING \ 59 1.1 wdk -DLIBSA_NO_DISKLABEL_MSGS \ 60 1.1 wdk -DLIBSA_NO_RAW_ACCESS \ 61 1.1 wdk -DALLOC_FIRST_FIT \ 62 1.1 wdk -DLIBSA_USE_MEMCPY -DLIBSA_USE_MEMSET 63 1.1 wdk 64 1.1 wdk 65 1.1 wdk CHECKSIZE_CMD?= SIZE=${SIZE} sh ${.CURDIR}/../common/checksize.sh 66 1.1 wdk 67 1.1 wdk .elif defined(SECONDARY_PROG) 68 1.1 wdk PROG= ${SECONDARY_PROG} 69 1.1 wdk LOAD_ADDRESS= ${SECONDARY_LOAD_ADDRESS} 70 1.1 wdk LDSCRIPT= ${SECONDARY_LDSCRIPT} 71 1.1 wdk CPPFLAGS+= -DSECONDARY_BOOTBLOCK 72 1.1 wdk SRCS+= vers.c 73 1.1 wdk CLEANFILES+= vers.c 74 1.1 wdk .else 75 1.1 wdk 76 1.1 wdk .endif 77 1.1 wdk 78 1.1 wdk ### find out what to use for libkern 79 1.1 wdk KERN_AS= library 80 1.1 wdk .include "${S}/lib/libkern/Makefile.inc" 81 1.1 wdk LIBKERN= ${KERNLIB} 82 1.1 wdk 83 1.1 wdk ### find out what to use for libz 84 1.1 wdk .if defined(PRIMARY_PROG) 85 1.1 wdk LIBZ= 86 1.1 wdk .else 87 1.1 wdk Z_AS= library 88 1.1 wdk .include "${S}/lib/libz/Makefile.inc" 89 1.1 wdk LIBZ= ${ZLIB} 90 1.1 wdk .endif 91 1.1 wdk 92 1.1 wdk ### find out what to use for libsa 93 1.1 wdk SA_AS= library 94 1.1 wdk .if defined(PRIMARY_PROG) 95 1.1 wdk SAMISCMAKEFLAGS+=SA_INCLUDE_NET=no 96 1.1 wdk .endif 97 1.1 wdk .if defined(SECONDARY_PROG) 98 1.1 wdk SAMISCMAKEFLAGS+=SA_USE_LOADFILE=yes SA_USE_CREAD=yes 99 1.1 wdk # for now: 100 1.1 wdk SAMISCMAKEFLAGS+=SA_INCLUDE_NET=no 101 1.1 wdk .endif 102 1.1 wdk .include "${S}/lib/libsa/Makefile.inc" 103 1.1 wdk LIBSA= ${SALIB} 104 1.1 wdk 105 1.1 wdk LIBS= ${LIBSA} ${LIBZ} ${LIBSA} ${LIBKERN} 106 1.1 wdk 107 1.1 wdk .PHONY: vers.c 108 1.1 wdk vers.c: ${.CURDIR}/version 109 1.1 wdk sh ${S}/conf/newvers_stand.sh -N ${.CURDIR}/version "mipsco" 110 1.1 wdk 111 1.2 wdk ${PROG}: machine-links ${LDSCRIPT} ${OBJS} ${LIBS} 112 1.1 wdk ${LD} -Map ${PROG}.map -N -x -Ttext ${LOAD_ADDRESS} -T ${LDSCRIPT} \ 113 1.1 wdk -e start -o ${PROG} ${OBJS} ${LIBS} 114 1.1 wdk @${SIZE} ${PROG} 115 1.2 wdk .if defined(PRIMARY_PROG) 116 1.2 wdk @mv ${PROG} ${PROG}.elf 117 1.2 wdk @objcopy --strip-all -O ecoff-bigmips -R .reginfo ${PROG}.elf ${PROG} 118 1.2 wdk .endif 119 1.1 wdk .if defined(CHECKSIZE_CMD) 120 1.2 wdk @${CHECKSIZE_CMD} ${PROG} ${PRIMARY_MAX_LOAD} || \ 121 1.1 wdk (rm -f ${PROG} ; false) 122 1.1 wdk .endif 123 1.1 wdk 124 1.1 wdk CLEANFILES+= ${PROG}.map 125 1.1 wdk 126 1.1 wdk cleandir distclean: cleanlibdir 127 1.1 wdk 128 1.1 wdk cleanlibdir: 129 1.1 wdk rm -rf lib 130 1.1 wdk 131 1.1 wdk .include <bsd.prog.mk> 132