xref: /netbsd-src/sys/arch/x68k/stand/xxboot/Makefile.xxboot (revision 479d8f7d843cc1b22d497efdf1f27a50ee8418d4)
1#	$NetBSD: Makefile.xxboot,v 1.3 2014/08/08 15:20:10 isaki Exp $
2
3NOMAN=		# defined
4
5.include <bsd.own.mk>
6
7BOOT=	$(DEV)boot_$(FS)
8VERSIONFILE=	${.CURDIR}/../version
9VERSION!=	${TOOL_AWK} -F: '$$1 ~ /^[0-9.]*$$/ { it = $$1; } \
10			END { print it }' ${VERSIONFILE}
11NEWVERSWHAT=	"${BOOT}"
12
13# text and bss addresses in hex
14TEXT=		0f0000		# Primary (me)
15TEXTDATASIZE=	  2000		# 8KB for UFS at maximum
16		  		# 30KB (=(16-1)*2048) for ISO9660 at max.
17BOOT_TEXT=	006000		# Secondary (/boot)
18
19PROG=		$(BOOT)
20BINDIR=		/usr/mdec
21STRIPFLAG=
22BINMODE=	444
23
24S=		${.CURDIR}/../../../../..
25M=		$S/arch/x68k
26.PATH:		${.CURDIR}/..
27SRCS=	boot.S bootmain.c conf.c consio1.c $(DEVDRV).c
28
29SRCS+=		vers.c
30CLEANFILES+=	vers.c
31vers.c:	${VERSIONFILE}
32	${_MKTARGET_CREATE}
33	${HOST_SH} ${S}/conf/newvers_stand.sh ${.ALLSRC} ${MACHINE} ${NEWVERSWHAT}
34
35CFLAGS=	-Os -fomit-frame-pointer -fno-unwind-tables
36#CFLAGS+= -Wall
37CPPFLAGS+= -D_STANDALONE
38CPPFLAGS+= -DTEXTADDR="0x$(TEXT)" -DBOOT_TEXTADDR="0x$(BOOT_TEXT)"
39CPPFLAGS+= -DTDSIZE="0x$(TEXTDATASIZE)"
40CPPFLAGS+= -DPROG=\"$(PROG)\" -DBOOT_VERS=\"$(VERSION)\"
41CPPFLAGS+= -DBOOT_STAGE1 $(BOOTCPPFLAGS)
42CPPFLAGS+= -nostdinc -I${.OBJDIR} -I${S}
43CPPFLAGS+= -I$M/stand/libiocs -I$M/stand/libsa -I$M/stand/common
44AFLAGS=	   ${CFLAGS:M-[ID]*}
45.if ${OBJECT_FMT} == "ELF"
46LINKFLAGS=   -n -Bstatic -T ${.CURDIR}/../xxboot.ldscript -M
47LINKFLAGS+=  -noinhibit-exec	# XXX
48.else
49LINKFLAGS=   -n -Bstatic -Ttext ${TEXT} -M
50.endif
51LIBIOCS!= cd $M/stand/libiocs && ${PRINTOBJDIR}
52LIBSA!=	  cd $M/stand/libsa && ${PRINTOBJDIR}
53LDLIBS=	  -L${LIBSA}/lib/sa -lsa -L ${LIBSA}/lib/kern -lkern
54LDLIBS+=  -L${LIBIOCS} -liocs
55
56.PATH: $S/lib/libsa
57CPPFLAGS+= -DLIBSA_SINGLE_FILESYSTEM=$(FS)
58CPPFLAGS+= -DLIBSA_SINGLE_DEVICE=$(DEV)
59CPPFLAGS+= -DLIBSA_NO_TWIDDLE -DLIBSA_NO_FD_CHECKING -DLIBSA_NO_RAW_ACCESS -DLIBSA_NO_FS_WRITE
60SRCS+=	open.c close.c read.c lseek.c loadfile.c loadfile_aout.c alloc.c
61SRCS+=  $(FS).c
62
63.PATH: $M/stand/common
64SRCS+=	exec_image.S
65
66.include "${.CURDIR}/../../Makefile.booters"
67
68CLEANFILES+=	${PROG}.x $(PROG).map ${PROG}
69
70
71${PROG}: $(OBJS)
72	${_MKTARGET_LINK}
73	$(LD) $(LINKFLAGS) -o ${PROG} $(OBJS) $(LDLIBS) > $(PROG).map
74	@grep first_kbyte $(PROG).map
75.if ${OBJECT_FMT} == "ELF"
76	@if [ `(echo ibase=16; 						   \
77	    ${TOOL_SED} -n						   \
78		's/^.*0x\([0-9a-f]*\).* first_kbyte$$/\1-$(TEXT)-400/p'    \
79		$(PROG).map | 						   \
80	    tr a-f A-F) | bc` -gt 0 ]; 					   \
81	then echo '$(BOOT): first_kbyte exceeds the first killobyte';	   \
82	    rm $(PROG) ; exit 1; 					   \
83	fi
84	@if [ `(echo ibase=16; 						   \
85	    ${TOOL_SED} -n						   \
86		's/^.*0x\([0-9a-f]*\).* _edata *= *\.$$/\1-$(TEXT)-$(TEXTDATASIZE)/p' \
87		$(PROG).map | 						   \
88	    tr a-f A-F) | bc` -gt 0 ]; 					   \
89	then echo '$(BOOT): text+data is too large';			   \
90	    rm $(PROG) ; exit 1; 					   \
91	fi
92.else
93	mv $(PROG) $(PROG).x
94	$(OBJCOPY) -I a.out-m68k-netbsd -O binary $(PROG).x $(PROG)
95	@rm -f $(PROG).x
96	@if [ `(echo ibase=16; 						   \
97	    ${TOOL_SED} -n						   \
98		's/  first_kbyte:.*0x\(.*\),.*$$/\1-$(TEXT)-400/p'	   \
99		$(PROG).map | 						   \
100	    tr a-f A-F) | bc` -gt 0 ]; 					   \
101	then echo '$(BOOT): first_kbyte exceeds the first killobyte';	   \
102	    rm $(PROG) ; exit 1; 					   \
103	fi
104	@if [ `(echo ibase=16; 						   \
105	    ${TOOL_SED} -n						   \
106		's/  _edata:.*0x\(.*\),.*$$/\1-$(TEXT)-$(TEXTDATASIZE)/p'  \
107		$(PROG).map | 						   \
108	    tr a-f A-F) | bc` -gt 0 ]; 					   \
109	then echo '$(BOOT): text+data is too large';			   \
110	    rm $(PROG) ; exit 1; 					   \
111	fi
112.endif
113	${TOUCHPROG}
114
115.include <bsd.prog.mk>
116