Merge from vendor branch OPENSSH:
[dragonfly.git] / sys / boot / pc32 / boot2 / Makefile
1 # $FreeBSD: src/sys/boot/i386/boot2/Makefile,v 1.47 2003/06/26 03:51:57 peter Exp $
2 # $DragonFly: src/sys/boot/pc32/boot2/Makefile,v 1.11 2004/08/06 20:50:35 dillon Exp $
3
4 PROG=           boot2
5 NOMAN=
6 STRIP=
7 BINDIR?=        /boot
8 BINMODE=        444
9 CLEANFILES=     boot boot1 boot1.out boot1.o \
10                 boot2.ldr boot2.bin boot2.ld boot2.out boot2.o boot2.h \
11                 boot2.s sio.o
12
13 NM?=            nm
14 NXCFLAGS=
15 NXLDFLAGS=
16
17 .PATH: ${.CURDIR}/..
18
19 # A value of 0x80 enables LBA support.
20 B1FLAGS=        0x80
21
22 BOOT_COMCONSOLE_PORT?= 0x3f8
23 BOOT_COMCONSOLE_SPEED?= 9600
24 B2SIOFMT?=      0x3
25
26 .if exists(${.OBJDIR}/../btx)
27 BTX=    ${.OBJDIR}/../btx
28 .else
29 BTX=    ${.CURDIR}/../btx
30 .endif
31
32 # These origins are taken from bootasm.h.
33 #
34 REL1 = `${.OBJDIR}/bootasmdef.nx BOOT1_ORIGIN`
35 REL1D = `${.OBJDIR}/bootasmdef.nx -d BOOT1_ORIGIN`
36 ORG1 = `${.OBJDIR}/bootasmdef.nx MEM_BIOS_LADDR`
37 ORG1D = `${.OBJDIR}/bootasmdef.nx -d MEM_BIOS_LADDR`
38
39 # WARNING!  The ORG2 calculation is the origin of boot2.bin relative to 
40 # the start of the BTX *USER* address space, not the start of physical 
41 # memory.
42 #
43 ORG2=   `${.OBJDIR}/bootasmdef.nx BOOT2_VORIGIN`
44
45 # Decide Level of UFS support.  UFS1_AND_UFS2 doesn't fit.
46
47 # BOOT2_UFS?=   UFS2_ONLY
48 #BOOT2_UFS?=    UFS1_AND_UFS2
49 BOOT2_UFS?=     UFS1_ONLY
50
51 # gcc3.x
52 #       -fno-guess-branch-probability
53 #       -mno-align-long-strings
54 CFLAGS= -elf -ffreestanding -Os -fno-builtin -fno-stack-protector \
55         -fomit-frame-pointer \
56         -D${BOOT2_UFS} \
57         -I${.CURDIR}/../../common \
58         -I${.CURDIR}/../btx/lib -I. \
59         -Wall -Waggregate-return -Wbad-function-cast -Wcast-align \
60         -Wmissing-declarations -Wmissing-prototypes -Wnested-externs \
61         -Wpointer-arith -Wshadow -Wstrict-prototypes -Wwrite-strings
62
63 # -mrtd will produce bad code (missing stack pops) when combined with
64 # gcc-3.4's (default on) unit-at-a-time optimization.  See the code
65 # generated for 'xputc' as an example.
66 #
67 .if ${CCVER} == "gcc2"
68 CFLAGS+= -mrtd
69 .endif
70
71 # Unfortunately, unit-at-a-time creates other issues as well, as yet
72 # not tracked down, in boot2, so we have to turn it off.  Note that
73 # the problem has been narrowed down to the 'boot2' code.  The /boot/loader
74 # doesn't seem to have a problem.
75 #
76 .if ${CCVER} != "gcc2"
77 CFLAGS+= -fno-unit-at-a-time
78 .endif
79
80 LDFLAGS=-nostdlib -static -N --gc-sections
81
82 all: boot1 boot2 boot
83
84 boot: boot1 boot2
85         cat boot1 boot2 > boot
86
87 boot1: boot1.out
88         objcopy -S -O binary boot1.out ${.TARGET}
89
90 boot1.out: boot1.o bootasmdef.nx
91         ${LD} ${LDFLAGS} -e start -Ttext ${ORG1} -o ${.TARGET} boot1.o
92
93 boot1.o: boot1.S
94         ${CC} ${CFLAGS} -DFLAGS=${B1FLAGS} ${AFLAGS} \
95                 ${.IMPSRC} -o ${.TARGET} -c
96
97 boot2.o: boot2.c ${.CURDIR}/../../common/ufsread.c
98         ${CC} ${CFLAGS} -S -o boot2.s.tmp ${.IMPSRC}
99         sed -e '/align/d' -e '/nop/d' < boot2.s.tmp > boot2.s
100         rm -f boot2.s.tmp
101         ${AS} ${AFLAGS} -o boot2.o boot2.s
102
103 boot2.h: boot1.out bootasmdef.nx
104         @echo "NOTE: boot2 using xread from boot1 at ${REL1}"
105         ${NM} -t d ${.ALLSRC} | awk '/([0-9])+ T xread/ \
106                 { x = $$1 - ORG1; \
107                 printf("#define XREADORG %#x\n", REL1 + x) }' \
108                 ORG1=${ORG1D} REL1=${REL1D} > boot2.h
109
110 boot2: boot2.ldr boot2.bin ${BTX}/btx/btx
111         btxld -v -E ${ORG2} -f bin -b ${BTX}/btx/btx -l boot2.ldr \
112                 -o boot2.ld -P 1 boot2.bin
113         @ls -l boot2.ld | awk '{ x = 7680 - $$5; \
114                 print x " bytes available"; if (x < 0) exit 1 }'
115         dd if=boot2.ld of=${.TARGET} obs=7680 conv=osync 2>/dev/null
116
117 boot2.ldr:
118         dd if=/dev/zero of=${.TARGET} bs=512 count=1 2>/dev/null
119
120 boot2.bin: boot2.out
121         objcopy -S -O binary boot2.out ${.TARGET}
122
123 boot2.out: boot2.o sio.o
124         ${LD} ${LDFLAGS} -Ttext ${ORG2} -o ${.TARGET} \
125                 ${BTX}/lib/crt0.o ${.ALLSRC}
126
127 boot2.o: boot2.h
128
129 sio.o: sio.S
130         ${CC} -DSIOPRT=${BOOT_COMCONSOLE_PORT} -DSIOFMT=${B2SIOFMT} \
131                 -DSIOSPD=${BOOT_COMCONSOLE_SPEED} \
132                 ${AFLAGS} ${.IMPSRC} -o ${.TARGET} -c
133
134 install:
135         ${INSTALL} -o ${BINOWN} -g ${BINGRP} -m ${BINMODE} \
136                 boot ${DESTDIR}${BINDIR}/boot
137         ${INSTALL} -o ${BINOWN} -g ${BINGRP} -m ${BINMODE} \
138                 boot1 ${DESTDIR}${BINDIR}/boot1
139         ${INSTALL} -o ${BINOWN} -g ${BINGRP} -m ${BINMODE} \
140                 boot2 ${DESTDIR}${BINDIR}/boot2
141
142 .include <bsd.prog.mk>
143
144 .if defined(REALLY_AMD64)
145 boot2.o: machine
146
147 beforedepend ${OBJS}: machine
148
149 machine:
150         ln -sf ${.CURDIR}/../../../i386/include machine
151
152 CLEANFILES+=    machine
153 .endif
154
155 CLEANFILES+=    bootasmdef.nx
156