1 1.12 jmc # $NetBSD: Makefile,v 1.12 2004/06/21 18:20:09 jmc Exp $ 2 1.1 mrg 3 1.1 mrg CURDIR= ${.CURDIR} 4 1.1 mrg S= ${CURDIR}/../../../.. 5 1.1 mrg 6 1.1 mrg # 7 1.1 mrg # Override normal settings 8 1.1 mrg # 9 1.1 mrg 10 1.1 mrg WARNS= 0 11 1.1 mrg 12 1.1 mrg PROG?= ofwboot 13 1.1 mrg SRCS= srt0.s Locore.c boot.c ofdev.c alloc.c net.c netif_of.c vers.c 14 1.1 mrg .PATH: ${S}/arch/sparc64/sparc64 15 1.1 mrg 16 1.8 thorpej COPTS+= -ffreestanding 17 1.1 mrg CWARNFLAGS+= -Wno-main 18 1.2 mrg CFLAGS+= ${COPTS} ${CEXTRAFLAGS} 19 1.2 mrg CPPFLAGS+= -D_STANDALONE -DSUN4U 20 1.4 thorpej CPPFLAGS+= -DBOOT_ELF32 -DBOOT_ELF64 21 1.10 mrg CPPFLAGS+= -DNETBOOT 22 1.1 mrg #CPPFLAGS+= -DNETIF_DEBUG 23 1.10 mrg 24 1.10 mrg LINKS+= ${BINDIR}/ofwboot ${BINDIR}/ofwboot.net 25 1.1 mrg 26 1.5 tv NOMAN= # defined 27 1.1 mrg STRIPFLAG= 28 1.1 mrg BINMODE= 444 29 1.1 mrg 30 1.1 mrg NEWVERSWHAT= "OpenFirmware Boot" 31 1.1 mrg 32 1.1 mrg # 33 1.1 mrg # Elf64 defaults to 1MB 34 1.1 mrg # 35 1.1 mrg # We may get address conflicts with other bootloaders, say 36 1.1 mrg # Sun's ufsboot, so we'll pick a reasonably empty address. 37 1.1 mrg # 38 1.1 mrg RELOC= 800000 39 1.1 mrg 40 1.1 mrg ENTRY= _start 41 1.1 mrg 42 1.11 martin CLEANFILES+= vers.c sparc64 sparc machine 43 1.1 mrg 44 1.1 mrg CPPFLAGS+= -I${CURDIR}/../../.. -I${CURDIR}/../../../.. -I${CURDIR} -I. 45 1.1 mrg CPPFLAGS+= -DRELOC=0x${RELOC} 46 1.1 mrg 47 1.1 mrg # 48 1.1 mrg # XXXXX FIXME 49 1.1 mrg # 50 1.1 mrg CPPFLAGS+= -DSPARC_BOOT_AOUT 51 1.1 mrg CPPFLAGS+= -DSPARC_BOOT_ELF 52 1.1 mrg CPPFLAGS+= -DSPARC_BOOT_UFS 53 1.1 mrg CPPFLAGS+= -DSPARC_BOOT_NFS 54 1.1 mrg #CPPFLAGS+= -DSPARC_BOOT_HSFS 55 1.1 mrg 56 1.1 mrg ### find out what to use for libkern 57 1.1 mrg KERN_AS= library 58 1.1 mrg .include "${S}/lib/libkern/Makefile.inc" 59 1.1 mrg LIBKERN= ${KERNLIB} 60 1.1 mrg 61 1.1 mrg ### find out what to use for libz 62 1.1 mrg Z_AS= library 63 1.1 mrg .include "${S}/lib/libz/Makefile.inc" 64 1.1 mrg LIBZ= ${ZLIB} 65 1.1 mrg 66 1.1 mrg ### find out what to use for libsa 67 1.1 mrg SA_AS= library 68 1.1 mrg SAMISCMAKEFLAGS= SA_USE_CREAD=yes 69 1.1 mrg .include "${S}/lib/libsa/Makefile.inc" 70 1.1 mrg LIBSA= ${SALIB} 71 1.1 mrg 72 1.11 martin .NOPATH: machine sparc64 sparc 73 1.11 martin ${SRCS}: machine sparc64 sparc 74 1.1 mrg 75 1.1 mrg machine: 76 1.1 mrg rm -f machine 77 1.2 mrg ln -s sparc64 machine 78 1.1 mrg 79 1.2 mrg sparc64: 80 1.2 mrg rm -f sparc64 81 1.2 mrg ln -s ${.CURDIR}/../../../sparc64/include sparc64 82 1.7 nakayama 83 1.11 martin sparc: 84 1.11 martin rm -f sparc 85 1.11 martin ln -s ${.CURDIR}/../../../sparc/include sparc 86 1.11 martin 87 1.7 nakayama cleandir distclean: cleanlibdir 88 1.7 nakayama 89 1.7 nakayama cleanlibdir: 90 1.12 jmc -rm -rf lib 91 1.1 mrg 92 1.1 mrg vers.c: version 93 1.9 lukem ${HOST_SH} ${S}/conf/newvers_stand.sh ${CURDIR}/version "sparc64" ${NEWVERSWHAT} 94 1.1 mrg 95 1.1 mrg .if CROSS 96 1.1 mrg ${PROG}: ${OBJS} ${LIBSA} ${LIBZ} ${LIBKERN} 97 1.1 mrg ${LD} -N -p -Ttext ${RELOC} -e ${ENTRY} >lderr -o ${PROG} \ 98 1.1 mrg ${OBJS} -L${SADST} -lsa -L${ZDST} -lz -L${KERNDST} -lkern # solaris linker 99 1.1 mrg .else 100 1.1 mrg ${PROG}: ${OBJS} ${LIBSA} ${LIBZ} ${LIBKERN} 101 1.1 mrg ${LD} -X -N -Ttext ${RELOC} -e ${ENTRY} -o ${PROG} \ 102 1.1 mrg ${OBJS} ${LIBSA} ${LIBZ} ${LIBKERN} # native linker 103 1.1 mrg .endif 104 1.1 mrg 105 1.1 mrg .include <bsd.prog.mk> 106 1.1 mrg 107 1.2 mrg .if ${MACHINE_ARCH} == "sparc64" 108 1.2 mrg AFLAGS+= -Wa,-Av9a 109 1.2 mrg CEXTRAFLAGS?= -D_LP64 110 1.2 mrg .else 111 1.2 mrg AFLAGS+= -Wa,-Av8plusa 112 1.2 mrg .endif 113 1.2 mrg 114 1.1 mrg .if CROSS 115 1.2 mrg AFLAGS+= -x assembler-with-cpp -traditional-cpp -D_LOCORE -D__ELF__ 116 1.2 mrg CEXTRAFLAGS?= -D_LP64 117 1.1 mrg .else 118 1.2 mrg AFLAGS+= -x assembler-with-cpp -traditional-cpp -D_LOCORE -D__ELF__ ${CEXTRAFLAGS} 119 1.1 mrg .endif 120 1.2 mrg 121 1.1 mrg NORMAL_S= ${CC} ${AFLAGS} ${CPPFLAGS} -c $< 122 1.1 mrg srt0.o: srt0.s 123 1.1 mrg ${NORMAL_S} 124 1.1 mrg 125 1.1 mrg # Explicit dependency for this. 126 1.1 mrg boot.o: boot.c elfXX_exec.c 127