]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/blob - stand/efi/loader/Makefile
zfs: add an option to the bootloader to rewind the ZFS checkpoint
[FreeBSD/FreeBSD.git] / stand / efi / loader / Makefile
1 # $FreeBSD$
2
3 LOADER_NET_SUPPORT?=    yes
4 LOADER_MSDOS_SUPPORT?=  yes
5 LOADER_UFS_SUPPORT?=    yes
6 LOADER_CD9660_SUPPORT?= no
7 LOADER_EXT2FS_SUPPORT?= no
8
9 .include <bsd.init.mk>
10
11 LOADER?=        loader_${LOADER_INTERP}
12 PROG=           ${LOADER}.sym
13 INTERNALPROG=
14 WARNS?=         3
15
16 # architecture-specific loader code
17 SRCS=   autoload.c \
18         bootinfo.c \
19         conf.c \
20         copy.c \
21         efi_main.c \
22         framebuffer.c \
23         main.c \
24         self_reloc.c \
25         vers.c
26
27 CFLAGS+=        -I${.CURDIR}/../loader
28 .if ${MK_LOADER_ZFS} != "no"
29 CFLAGS+=        -I${ZFSSRC}
30 CFLAGS+=        -DEFI_ZFS_BOOT
31 HAVE_ZFS=       yes
32 .endif
33
34 # We implement a slightly non-standard %S in that it always takes a
35 # CHAR16 that's common in UEFI-land instead of a wchar_t. This only
36 # seems to matter on arm64 where wchar_t defaults to an int instead
37 # of a short. There's no good cast to use here so just ignore the
38 # warnings for now.
39 CWARNFLAGS.main.c+=     -Wno-format
40
41 .PATH: ${.CURDIR}/../loader
42 .PATH: ${.CURDIR}/../loader/arch/${MACHINE}
43 .include "${.CURDIR}/../loader/arch/${MACHINE}/Makefile.inc"
44
45 CFLAGS+=        -I${.CURDIR}
46 CFLAGS+=        -I${.CURDIR}/arch/${MACHINE}
47 CFLAGS+=        -I${EFISRC}/include
48 CFLAGS+=        -I${EFISRC}/include/${MACHINE}
49 CFLAGS+=        -I${SYSDIR}/contrib/dev/acpica/include
50 CFLAGS+=        -I${BOOTSRC}/i386/libi386
51 CFLAGS+=        -DEFI
52
53 .if defined(HAVE_FDT) && ${MK_FDT} != "no"
54 .include        "${BOOTSRC}/fdt.mk"
55 LIBEFI_FDT=     ${BOOTOBJ}/efi/fdt/libefi_fdt.a
56 .endif
57
58 # Include bcache code.
59 HAVE_BCACHE=    yes
60
61 .if defined(EFI_STAGING_SIZE)
62 CFLAGS+=        -DEFI_STAGING_SIZE=${EFI_STAGING_SIZE}
63 .endif
64
65 .if ${MK_LOADER_EFI_SECUREBOOT} != "no"
66 CFLAGS+= -DEFI_SECUREBOOT
67 .endif
68
69 NEWVERSWHAT=    "EFI loader" ${MACHINE}
70 VERSION_FILE=   ${.CURDIR}/../loader/version
71
72 # Always add MI sources
73 .include        "${BOOTSRC}/loader.mk"
74
75 FILES+= ${LOADER}.efi
76 FILESMODE_${LOADER}.efi=        ${BINMODE}
77
78 .if ${LOADER_INTERP} == ${LOADER_DEFAULT_INTERP}
79 LINKS+=         ${BINDIR}/${LOADER}.efi ${BINDIR}/loader.efi
80 .endif
81
82 LDSCRIPT=       ${.CURDIR}/../loader/arch/${MACHINE}/ldscript.${MACHINE}
83 LDFLAGS+=       -Wl,-T${LDSCRIPT},-Bsymbolic,-znotext -shared
84
85 CLEANFILES+=    loader.efi
86
87 ${LOADER}.efi: ${PROG}
88         if ${NM} ${.ALLSRC} | grep ' U '; then \
89                 echo "Undefined symbols in ${.ALLSRC}"; \
90                 exit 1; \
91         fi
92         SOURCE_DATE_EPOCH=${SOURCE_DATE_EPOCH} \
93         ${OBJCOPY} -j .peheader -j .text -j .sdata -j .data \
94                 -j .dynamic -j .dynsym -j .rel.dyn \
95                 -j .rela.dyn -j .reloc -j .eh_frame -j set_Xcommand_set \
96                 -j set_Xficl_compile_set \
97                 --output-target=${EFI_TARGET} ${.ALLSRC} ${.TARGET}
98
99 LIBEFI=         ${BOOTOBJ}/efi/libefi/libefi.a
100
101 DPADD=          ${LDR_INTERP} ${LIBEFI} ${LIBFDT} ${LIBEFI_FDT} ${LIBSA} ${LDSCRIPT}
102 LDADD=          ${LDR_INTERP} ${LIBEFI} ${LIBFDT} ${LIBEFI_FDT} ${LIBSA}
103
104 .include <bsd.prog.mk>