14 # Disable warnings that are currently incompatible with the zfs boot code
15 CWARNFLAGS.zfs_module.c += -Wno-array-bounds
16 CWARNFLAGS.zfs_module.c += -Wno-cast-align
17 CWARNFLAGS.zfs_module.c += -Wno-cast-qual
18 CWARNFLAGS.zfs_module.c += -Wno-missing-prototypes
19 CWARNFLAGS.zfs_module.c += -Wno-sign-compare
20 CWARNFLAGS.zfs_module.c += -Wno-unused-parameter
21 CWARNFLAGS.zfs_module.c += -Wno-unused-function
22 CWARNFLAGS.skein.c += -Wno-cast-align
23 .if ${COMPILER_TYPE} == "clang"
24 CWARNFLAGS.skein.c += -Wno-missing-variable-declarations
25 .else if ${COMPILER_TYPE} == "gcc"
26 CWARNFLAGS.skein.c += -Wno-missing-declarations
30 # architecture-specific loader code
31 SRCS= boot1.c self_reloc.c start.S ufs_module.c
34 SRCS+= skein.c skein_block.c
35 # Do not unroll skein loops, reduce code size
36 CFLAGS+= -DSKEIN_LOOP=111
37 .PATH: ${.CURDIR}/../../../crypto/skein
40 .if ${COMPILER_TYPE} == "gcc" && ${COMPILER_VERSION} > 40201
41 CWARNFLAGS.self_reloc.c+= -Wno-error=maybe-uninitialized
45 CFLAGS+= -I${.CURDIR}/../include
46 CFLAGS+= -I${.CURDIR}/../include/${MACHINE}
47 CFLAGS+= -I${.CURDIR}/../../../contrib/dev/acpica/include
48 CFLAGS+= -I${.CURDIR}/../../..
49 CFLAGS+= -DEFI_UFS_BOOT
55 CFLAGS+= -I${.CURDIR}/../../zfs/
56 CFLAGS+= -I${.CURDIR}/../../../cddl/boot/zfs/
57 CFLAGS+= -I${.CURDIR}/../../../crypto/skein
58 CFLAGS+= -DEFI_ZFS_BOOT
61 # Always add MI sources and REGULAR efi loader bits
62 .PATH: ${.CURDIR}/../loader/arch/${MACHINE}
63 .PATH: ${.CURDIR}/../loader
64 .PATH: ${.CURDIR}/../../common
65 CFLAGS+= -I${.CURDIR}/../../common
67 FILES= boot1.efi boot1.efifat
68 FILESMODE_boot1.efi= ${BINMODE}
70 LDSCRIPT= ${.CURDIR}/../loader/arch/${MACHINE}/ldscript.${MACHINE}
71 LDFLAGS+= -Wl,-T${LDSCRIPT} -Wl,-Bsymbolic -shared
73 .if ${MACHINE_CPUARCH} == "aarch64"
74 CFLAGS+= -mgeneral-regs-only
76 .if ${MACHINE_CPUARCH} == "amd64" || ${MACHINE_CPUARCH} == "i386"
78 LDFLAGS+= -Wl,-znocombreloc
82 # Add libstand for the runtime functions used by the compiler - for example
83 # __aeabi_* (arm) or __divdi3 (i386).
84 # as well as required string and memory functions for all platforms.
94 .if ${MACHINE_CPUARCH} == "amd64"
95 EFI_TARGET= efi-app-x86_64
96 .elif ${MACHINE_CPUARCH} == "i386"
97 EFI_TARGET= efi-app-ia32
102 # Arbitrarily set the PE/COFF header timestamps to 1 Jan 2016 00:00:00
103 # for build reproducibility.
104 SOURCE_DATE_EPOCH?=1451606400
106 if ${NM} ${.ALLSRC} | grep ' U '; then \
107 echo "Undefined symbols in ${.ALLSRC}"; \
110 SOURCE_DATE_EPOCH=${SOURCE_DATE_EPOCH} \
111 ${OBJCOPY} -j .peheader -j .text -j .sdata -j .data \
112 -j .dynamic -j .dynsym -j .rel.dyn \
113 -j .rela.dyn -j .reloc -j .eh_frame \
114 --output-target=${EFI_TARGET} ${.ALLSRC} ${.TARGET}
116 boot1.o: ${.CURDIR}/../../common/ufsread.c
118 # The following inserts our objects into a template FAT file system
119 # created by generate-fat.sh
121 .include "${.CURDIR}/Makefile.fat"
122 BOOT1_MAXSIZE?= 131072
124 boot1.efifat: boot1.efi
125 @set -- `ls -l ${.ALLSRC}`; \
126 x=$$(($$5-${BOOT1_MAXSIZE})); \
127 if [ $$x -ge 0 ]; then \
128 echo "boot1 $$x bytes too large; regenerate FAT templates?" >&2 ;\
132 uudecode ${.CURDIR}/fat-${MACHINE}.tmpl.bz2.uu
133 mv fat-${MACHINE}.tmpl.bz2 ${.TARGET}.bz2
134 bzip2 -f -d ${.TARGET}.bz2
135 ${DD} if=${.ALLSRC} of=${.TARGET} seek=${BOOT1_OFFSET} conv=notrunc
137 CLEANFILES= boot1.efi boot1.efifat
139 .include <bsd.prog.mk>
141 beforedepend ${OBJS}: machine
146 ln -sf ${.CURDIR}/../../../${MACHINE}/include machine
148 .if ${MACHINE_CPUARCH} == "amd64" || ${MACHINE_CPUARCH} == "i386"
149 beforedepend ${OBJS}: x86
153 ln -sf ${.CURDIR}/../../../x86/include x86