918314631b
gpt and zfs boot blocks are not nearly as size-constrained as boot2 from which they inherited their current optimization and anti-optimization options. As such the current options do not provide any benefit, but make debugging of the code much harder. Also, it has been demonstrated that combination of -mrtd and -fno-unit-at-a-time may result in mis-compilation of the boot code with the current base gcc. Additionally, intermediate assembly file filtering is removed for zfsboot. The new boot blocks are all compile- and boot- tested using qemu. gptzfsboot is tested with real hardware. Reported by: Peter Jeremy <peterjeremy@acm.org> [miscompilation] Discussed with: bde, jhb Tested by: Sebastian Chmielewski <chmielsster@gmail.com> [gptzfsboot] Approved by: re (kib) MFC after: 3 weeks
93 lines
2.3 KiB
Makefile
93 lines
2.3 KiB
Makefile
# $FreeBSD$
|
|
|
|
.PATH: ${.CURDIR}/../boot2 ${.CURDIR}/../common ${.CURDIR}/../../common
|
|
|
|
FILES= zfsboot
|
|
|
|
NM?= nm
|
|
|
|
BOOT_COMCONSOLE_PORT?= 0x3f8
|
|
BOOT_COMCONSOLE_SPEED?= 9600
|
|
B2SIOFMT?= 0x3
|
|
|
|
REL1= 0x700
|
|
ORG1= 0x7c00
|
|
ORG2= 0x2000
|
|
|
|
CFLAGS= -DBOOTPROG=\"zfsboot\" \
|
|
-O1 \
|
|
-DBOOT2 \
|
|
-DSIOPRT=${BOOT_COMCONSOLE_PORT} \
|
|
-DSIOFMT=${B2SIOFMT} \
|
|
-DSIOSPD=${BOOT_COMCONSOLE_SPEED} \
|
|
-I${.CURDIR}/../../common \
|
|
-I${.CURDIR}/../common \
|
|
-I${.CURDIR}/../../zfs \
|
|
-I${.CURDIR}/../../../cddl/boot/zfs \
|
|
-I${.CURDIR}/../btx/lib -I. \
|
|
-I${.CURDIR}/../boot2 \
|
|
-Wall -Waggregate-return -Wbad-function-cast -Wcast-align \
|
|
-Wmissing-declarations -Wmissing-prototypes -Wnested-externs \
|
|
-Wpointer-arith -Wshadow -Wstrict-prototypes -Wwrite-strings \
|
|
-Winline --param max-inline-insns-single=100
|
|
|
|
.if ${CC:T:Mclang} == "clang"
|
|
# XXX: clang integrated-as doesn't grok .codeNN directives yet
|
|
CFLAGS+= ${.IMPSRC:T:Mzfsldr.S:C/^.+$/-no-integrated-as/}
|
|
.endif
|
|
|
|
LDFLAGS=-static -N --gc-sections
|
|
|
|
# Pick up ../Makefile.inc early.
|
|
.include <bsd.init.mk>
|
|
|
|
CLEANFILES= zfsboot
|
|
|
|
zfsboot: zfsboot1 zfsboot2
|
|
cat zfsboot1 zfsboot2 > zfsboot
|
|
|
|
CLEANFILES+= zfsboot1 zfsldr.out zfsldr.o
|
|
|
|
zfsboot1: zfsldr.out
|
|
objcopy -S -O binary zfsldr.out ${.TARGET}
|
|
|
|
zfsldr.out: zfsldr.o
|
|
${LD} ${LDFLAGS} -e start -Ttext ${ORG1} -o ${.TARGET} zfsldr.o
|
|
|
|
CLEANFILES+= zfsboot2 zfsboot.ld zfsboot.ldr zfsboot.bin zfsboot.out \
|
|
zfsboot.o zfsboot.s zfsboot.s.tmp sio.o cons.o drv.o util.o
|
|
|
|
# We currently allow 65536 bytes for zfsboot - in practice it could be
|
|
# any size up to 3.5Mb but keeping it fixed size simplifies zfsldr.
|
|
#
|
|
BOOT2SIZE= 65536
|
|
|
|
zfsboot2: zfsboot.ld
|
|
@set -- `ls -l zfsboot.ld`; x=$$((${BOOT2SIZE}-$$5)); \
|
|
echo "$$x bytes available"; test $$x -ge 0
|
|
dd if=zfsboot.ld of=${.TARGET} obs=${BOOT2SIZE} conv=osync
|
|
|
|
zfsboot.ld: zfsboot.ldr zfsboot.bin ${BTXKERN}
|
|
btxld -v -E ${ORG2} -f bin -b ${BTXKERN} -l zfsboot.ldr \
|
|
-o ${.TARGET} -P 1 zfsboot.bin
|
|
|
|
zfsboot.ldr:
|
|
cp /dev/null ${.TARGET}
|
|
|
|
zfsboot.bin: zfsboot.out
|
|
objcopy -S -O binary zfsboot.out ${.TARGET}
|
|
|
|
zfsboot.out: ${BTXCRT} zfsboot.o sio.o drv.o cons.o util.o
|
|
${LD} ${LDFLAGS} -Ttext ${ORG2} -o ${.TARGET} ${.ALLSRC} ${LIBSTAND}
|
|
|
|
SRCS= zfsboot.c
|
|
|
|
.if ${MACHINE_CPUARCH} == "amd64"
|
|
beforedepend zfsboot.o: machine
|
|
CLEANFILES+= machine
|
|
machine:
|
|
ln -sf ${.CURDIR}/../../../i386/include machine
|
|
.endif
|
|
|
|
.include <bsd.prog.mk>
|