1 1.1.8.2 bouyer # $NetBSD: Makefile,v 1.1.8.2 2000/11/20 19:58:51 bouyer Exp $ 2 1.1.8.2 bouyer 3 1.1.8.2 bouyer ### what we need: 4 1.1.8.2 bouyer 5 1.1.8.2 bouyer DIR_TOP= ${.CURDIR}/../../../../.. 6 1.1.8.2 bouyer DIR_SA = ${DIR_TOP}/lib/libsa 7 1.1.8.2 bouyer DIR_KERN= ${DIR_TOP}/lib/libkern 8 1.1.8.2 bouyer DIR_KERN_MD= ${DIR_TOP}/lib/libkern/arch/$(MACHINE_ARCH) 9 1.1.8.2 bouyer DIR_BOOT= ${.CURDIR}/../boot 10 1.1.8.2 bouyer 11 1.1.8.2 bouyer .PATH: $(DIR_SA) $(DIR_KERN) $(DIR_KERN_MD) $(DIR_BOOT) 12 1.1.8.2 bouyer 13 1.1.8.2 bouyer # prefer our assembler versions over assembler, and assembler over C: 14 1.1.8.2 bouyer 15 1.1.8.2 bouyer .SUFFIXES: 16 1.1.8.2 bouyer .SUFFIXES: .out .o .po .so .s .S .c .cc .C .f .y .l .ln .m4 .sh 17 1.1.8.2 bouyer 18 1.1.8.2 bouyer FILES= xxppcboot fdppcboot 19 1.1.8.2 bouyer BINDIR=/usr/mdec 20 1.1.8.2 bouyer 21 1.1.8.2 bouyer COBJS = main.o console.o xd.o twiddle.o bzero.o gets.o 22 1.1.8.2 bouyer COBJS+= lseek.o open.o read.o close.o dev.o errno.o 23 1.1.8.2 bouyer COBJS+= ufs.o ppcstart.o 24 1.1.8.2 bouyer 25 1.1.8.2 bouyer SOBJS = alloc.o ashrdi3.o bcopy.o muldi3.o printf.o 26 1.1.8.2 bouyer SOBJS += strlen.o strcmp.o 27 1.1.8.2 bouyer SOBJS += libstubs.o 28 1.1.8.2 bouyer 29 1.1.8.2 bouyer OBJS= $(SOBJS) $(COBJS) 30 1.1.8.2 bouyer 31 1.1.8.2 bouyer DEFS = -DPPCBOOTER -D_STANDALONE -DINSECURE -DDEBUG_MEMORY_LIST 32 1.1.8.2 bouyer 33 1.1.8.2 bouyer ### main target: ### 34 1.1.8.2 bouyer 35 1.1.8.2 bouyer all: ${FILES} 36 1.1.8.2 bouyer 37 1.1.8.2 bouyer .include <bsd.prog.mk> 38 1.1.8.2 bouyer 39 1.1.8.2 bouyer ### special rules for bootblocks ### 40 1.1.8.2 bouyer 41 1.1.8.2 bouyer INCPATH = -I${DIR_TOP} -I${DIR_TOP}/lib/libsa -I${DIR_BOOT} -I${.CURDIR} -I${.CURDIR}/../../.. -I${.CURDIR}/../aout2bb -I${.OBJDIR} 42 1.1.8.2 bouyer 43 1.1.8.2 bouyer AFLAGS += -m68030 -l 44 1.1.8.2 bouyer CAFLAGS += -Wa,-l -Wa,-m68030 ${INCPATH} 45 1.1.8.2 bouyer 46 1.1.8.2 bouyer COPTIM= -O -fomit-frame-pointer -fcse-follow-jumps -fcse-skip-blocks -Wa,-l -m68060 -Wa,-m68030 47 1.1.8.2 bouyer CFLAGS= ${COPTIM} ${INCPATH} ${DEFS} -Wall #-Wstrict-prototypes 48 1.1.8.2 bouyer 49 1.1.8.2 bouyer .c.o: 50 1.1.8.2 bouyer ${CC} ${CFLAGS} -S $< -o $*.s 51 1.1.8.2 bouyer ${TXLT} < $*.s | ${AS} ${AFLAGS} -o $*.o 52 1.1.8.2 bouyer rm $*.s 53 1.1.8.2 bouyer 54 1.1.8.2 bouyer .s.o: ; ${CC} ${CAFLAGS} ${COPTS} -x assembler-with-cpp -o $@ -c $< 55 1.1.8.2 bouyer 56 1.1.8.2 bouyer .S.o: ; ${CC} ${CAFLAGS} ${COPTS} -x assembler-with-cpp -o $@ -c $< 57 1.1.8.2 bouyer 58 1.1.8.2 bouyer CLEANFILES += xxppcboot fdppcboot x.out f.out xxstart.o fdstart.o libboot.a 59 1.1.8.2 bouyer 60 1.1.8.2 bouyer xxppcboot: x.out 61 1.1.8.2 bouyer ${AOUT2BB} x.out $@ || nm -u x.out 62 1.1.8.2 bouyer 63 1.1.8.2 bouyer fdppcboot: f.out 64 1.1.8.2 bouyer ${AOUT2BB} f.out $@ || nm -u f.out 65 1.1.8.2 bouyer 66 1.1.8.2 bouyer x.out: xxstart.o libboot.a 67 1.1.8.2 bouyer ${LD} ${LDFLAGS} -r -dc -e _start -o $@ $> 68 1.1.8.2 bouyer size $@ 69 1.1.8.2 bouyer nm -u $@ 70 1.1.8.2 bouyer 71 1.1.8.2 bouyer f.out: fdstart.o libboot.a 72 1.1.8.2 bouyer ${LD} ${LDFLAGS} -r -dc -e _start -o $@ $> 73 1.1.8.2 bouyer size $@ 74 1.1.8.2 bouyer nm -u $@ 75 1.1.8.2 bouyer 76 1.1.8.2 bouyer xxstart.o: ${DIR_BOOT}/bbstart.s 77 1.1.8.2 bouyer ${CC} ${CAFLAGS} ${COPTS} -x assembler-with-cpp \ 78 1.1.8.2 bouyer -o $@ -c $> 79 1.1.8.2 bouyer 80 1.1.8.2 bouyer fdstart.o: ${DIR_BOOT}/bbstart.s 81 1.1.8.2 bouyer ${CC} -DAUTOLOAD=8192 ${CAFLAGS} ${COPTS} -x assembler-with-cpp \ 82 1.1.8.2 bouyer -o $@ -c $> 83 1.1.8.2 bouyer 84 1.1.8.2 bouyer PPCCC=powerpc-netbsd-gcc 85 1.1.8.2 bouyer PPCAS=powerpc-netbsd-as 86 1.1.8.2 bouyer PPCLD=powerpc-netbsd-ld 87 1.1.8.2 bouyer PPCOD=powerpc-netbsd-objdump 88 1.1.8.2 bouyer 89 1.1.8.2 bouyer CLEANFILES += kickstart.o kickstart.bin kickstart68.c 90 1.1.8.2 bouyer 91 1.1.8.2 bouyer ppcstart.o: kickstart68.c 92 1.1.8.2 bouyer 93 1.1.8.2 bouyer kickstart68.c: kickstart.bin hex2c.awk 94 1.1.8.2 bouyer hexdump kickstart.bin | awk -f ${.CURDIR}/hex2c.awk > $@ 95 1.1.8.2 bouyer 96 1.1.8.2 bouyer kickstart.bin: kickstart.o 97 1.1.8.2 bouyer $(PPCLD) -Ttext=0xfff00100 -o$@ --oformat binary $? 98 1.1.8.2 bouyer 99 1.1.8.2 bouyer kickstart.o: kickstart.S 100 1.1.8.2 bouyer $(PPCCC) -DDEBUG $(COPTS) -x assembler-with-cpp -c $? 101 1.1.8.2 bouyer 102 1.1.8.2 bouyer kickstart.lis: kickstart.o 103 1.1.8.2 bouyer $(PPCOD) --disassemble-all kickstart.o 104 1.1.8.2 bouyer 105 1.1.8.2 bouyer libboot.a: ${OBJS} 106 1.1.8.2 bouyer ${AR} r $@ $> && ${RANLIB} $@ 107 1.1.8.2 bouyer 108 1.1.8.2 bouyer # make sure these are built: 109 1.1.8.2 bouyer 110 1.1.8.2 bouyer ${COBJS}: ${TXLT} 111 1.1.8.2 bouyer ${FILES}: ${AOUT2BB} 112