diff options
Diffstat (limited to 'stand/efi/libefi/Makefile')
-rw-r--r-- | stand/efi/libefi/Makefile | 57 |
1 files changed, 57 insertions, 0 deletions
diff --git a/stand/efi/libefi/Makefile b/stand/efi/libefi/Makefile new file mode 100644 index 000000000000..e0ffd7b80f62 --- /dev/null +++ b/stand/efi/libefi/Makefile @@ -0,0 +1,57 @@ +# $FreeBSD$ + +.include <bsd.init.mk> + +.if ${MK_FORTH} != "no" +.include "${BOOTSRC}/ficl.mk" +.endif + +LIB= efi +INTERNALLIB= +WARNS?= 2 + +SRCS= delay.c devpath.c efi_console.c efichar.c efinet.c efipart.c env.c errno.c \ + handles.c wchar.c libefi.c efi_driver_utils.c efizfs.c devicename.c + +.if ${MACHINE_CPUARCH} == "amd64" || ${MACHINE_CPUARCH} == "i386" +SRCS+= time.c +.elif ${MACHINE_CPUARCH} == "aarch64" || ${MACHINE_CPUARCH} == "arm" +SRCS+= time_event.c +.endif + +# We implement a slightly non-standard %S in that it always takes a +# CHAR16 that's common in UEFI-land instead of a wchar_t. This only +# seems to matter on arm64 where wchar_t defaults to an int instead +# of a short. There's no good cast to use here so just ignore the +# warnings for now. +CWARNFLAGS.efinet.c+= -Wno-format +CWARNFLAGS.efipart.c+= -Wno-format +CWARNFLAGS.env.c+= -Wno-format + +.if ${MACHINE_CPUARCH} == "aarch64" +CFLAGS+= -mgeneral-regs-only +.endif +.if ${MACHINE_ARCH} == "amd64" +CFLAGS+= -fPIC -mno-red-zone +.endif +CFLAGS+= -I${EFIINC} +CFLAGS+= -I${EFIINCMD} +.if ${MK_ZFS} != "no" +CFLAGS+= -I${ZFSSRC} +CFLAGS+= -DEFI_ZFS_BOOT +.endif + +# Pick up the bootstrap header for some interface items +CFLAGS+= -I${LDRSRC} + +# Handle FreeBSD specific %b and %D printf format specifiers +CFLAGS+= ${FORMAT_EXTENSIONS} + +# Do not use TERM_EMU on arm and arm64 as it doesn't behave well with serial console +.if ${MACHINE_CPUARCH} != "arm" && ${MACHINE_CPUARCH} != "aarch64" +CFLAGS+= -DTERM_EMU +.endif + +CFLAGS+= -DLIBEFI + +.include <bsd.lib.mk> |