]> git.proxmox.com Git - efi-boot-shim.git/blame - Make.defaults
Force usage of newest revocations at build time
[efi-boot-shim.git] / Make.defaults
CommitLineData
031e5cce
SM
1
2# load the local configuration if it exists
3-include Make.local
8119f718 4-include $(TOPDIR)/Make.local
031e5cce 5
f892ac66
MTL
6COMPILER ?= gcc
7CC = $(CROSS_COMPILE)$(COMPILER)
031e5cce 8HOSTCC = $(COMPILER)
f892ac66
MTL
9LD = $(CROSS_COMPILE)ld
10OBJCOPY = $(CROSS_COMPILE)objcopy
031e5cce
SM
11DOS2UNIX ?= dos2unix
12D2UFLAGS ?= -r -l -F -f -n
f892ac66
MTL
13OPENSSL ?= openssl
14HEXDUMP ?= hexdump
15INSTALL ?= install
16PK12UTIL ?= pk12util
17CERTUTIL ?= certutil
18PESIGN ?= pesign
19SBSIGN ?= sbsign
20prefix ?= /usr
21prefix := $(abspath $(prefix))
22datadir ?= $(prefix)/share/
23PKGNAME ?= shim
24ESPROOTDIR ?= boot/efi/
25EFIBOOTDIR ?= $(ESPROOTDIR)EFI/BOOT/
26TARGETDIR ?= $(ESPROOTDIR)EFI/$(EFIDIR)/
27DATATARGETDIR ?= $(datadir)/$(PKGNAME)/$(VERSION)$(DASHRELEASE)/$(ARCH_SUFFIX)/
28DEBUGINFO ?= $(prefix)/lib/debug/
29DEBUGSOURCE ?= $(prefix)/src/debug/
30OSLABEL ?= $(EFIDIR)
31DEFAULT_LOADER ?= \\\\grub$(ARCH_SUFFIX).efi
32DASHJ ?= -j$(shell echo $$(($$(grep -c "^model name" /proc/cpuinfo) + 1)))
33
34ARCH ?= $(shell $(CC) -dumpmachine | cut -f1 -d- | sed s,i[3456789]86,ia32,)
35OBJCOPY_GTE224 = $(shell expr `$(OBJCOPY) --version |grep ^"GNU objcopy" | sed 's/^.*\((.*)\|version\) //g' | cut -f1-2 -d.` \>= 2.24)
031e5cce
SM
36OPTIMIZATIONS ?= -Os
37FA_OPTIMIZATIONS ?= -O2
38ifneq ($(FANALYZER),)
39override OPTIMIZATIONS := $(FA_OPTIMIZATIONS)
40override CCACHE_DISABLE := true
41endif
42export OPTIMIZATIONS
43ifneq ($(CCACHE_DISABLE),)
44export CCACHE_DISABLE
45endif
f892ac66
MTL
46
47SUBDIRS = $(TOPDIR)/Cryptlib $(TOPDIR)/lib
48
031e5cce
SM
49EFI_INCLUDE ?= $(TOPDIR)/gnu-efi/inc
50EFI_INCLUDES = -I$(EFI_INCLUDE) -I$(EFI_INCLUDE)/$(ARCH) -I$(EFI_INCLUDE)/protocol
51override EFI_INCLUDES := $(EFI_INCLUDES)
52EFI_CRT_OBJS = $(LOCAL_EFI_PATH)/crt0-efi-$(ARCH_GNUEFI).o
f892ac66
MTL
53EFI_LDS = $(TOPDIR)/elf_$(ARCH)_efi.lds
54
8529e0f7
SM
55CLANG_WARNINGS = -Wno-pointer-bool-conversion \
56 -Wno-unknown-attributes
57
58CLANG_BUGS = $(if $(findstring gcc,$(CC)),-maccumulate-outgoing-args,) \
59 $(if $(findstring clang,$(CC)),$(CLANG_WARNINGS))
f892ac66
MTL
60
61COMMIT_ID ?= $(shell if [ -e .git ] ; then git log -1 --pretty=format:%H ; elif [ -f commit ]; then cat commit ; else echo master; fi)
62
63ifeq ($(ARCH),x86_64)
64 ARCH_CFLAGS ?= -mno-mmx -mno-sse -mno-red-zone -nostdinc \
65 $(CLANG_BUGS) -m64 \
031e5cce
SM
66 -DMDE_CPU_X64 -DPAGE_SIZE=4096
67 ARCH_GNUEFI ?= x86_64
f892ac66
MTL
68 ARCH_SUFFIX ?= x64
69 ARCH_SUFFIX_UPPER ?= X64
70 ARCH_LDFLAGS ?=
71endif
72ifeq ($(ARCH),ia32)
73 ARCH_CFLAGS ?= -mno-mmx -mno-sse -mno-red-zone -nostdinc \
2dd2f760 74 $(CLANG_BUGS) -m32 -malign-double \
f892ac66 75 -DMDE_CPU_IA32 -DPAGE_SIZE=4096
031e5cce 76 ARCH_GNUEFI ?= ia32
f892ac66
MTL
77 ARCH_SUFFIX ?= ia32
78 ARCH_SUFFIX_UPPER ?= IA32
79 ARCH_LDFLAGS ?=
80 ARCH_CFLAGS ?= -m32
81endif
82ifeq ($(ARCH),aarch64)
83 ARCH_CFLAGS ?= -DMDE_CPU_AARCH64 -DPAGE_SIZE=4096 -mstrict-align
031e5cce 84 ARCH_GNUEFI ?= aarch64
f892ac66
MTL
85 ARCH_SUFFIX ?= aa64
86 ARCH_SUFFIX_UPPER ?= AA64
e6ace38a 87 ARCH_LDFLAGS ?=
f892ac66
MTL
88 ARCH_CFLAGS ?=
89endif
90ifeq ($(ARCH),arm)
031e5cce
SM
91 ARCH_CFLAGS ?= -DMDE_CPU_ARM -DPAGE_SIZE=4096 -mno-unaligned-access
92 ARCH_GNUEFI ?= arm
f892ac66
MTL
93 ARCH_SUFFIX ?= arm
94 ARCH_SUFFIX_UPPER ?= ARM
95 FORMAT := -O binary
96 SUBSYSTEM := 0xa
97 ARCH_LDFLAGS += --defsym=EFI_SUBSYSTEM=$(SUBSYSTEM)
98endif
99
031e5cce
SM
100DEFINES = -DDEFAULT_LOADER='L"$(DEFAULT_LOADER)"' \
101 -DDEFAULT_LOADER_CHAR='"$(DEFAULT_LOADER)"'
102
103INCLUDES = -nostdinc \
104 -I$(TOPDIR)/Cryptlib -I$(TOPDIR)/Cryptlib/Include \
105 -I$(EFI_INCLUDE) -I$(EFI_INCLUDE)/$(ARCH_GNUEFI) -I$(EFI_INCLUDE)/protocol \
106 -I$(TOPDIR)/include -iquote $(TOPDIR) -iquote $(shell pwd) \
107 -isystem $(TOPDIR)/include/system \
108 -isystem $(shell $(CC) $(ARCH_CFLAGS) -print-file-name=include)
109
110override DEFAULT_FEATUREFLAGS = \
111 -std=gnu11 \
112 -ggdb \
113 -ffreestanding \
114 $(shell $(CC) -fmacro-prefix-map=./=./ -E -x c /dev/null >/dev/null 2>&1 && echo -fmacro-prefix-map='$(TOPDIR)/=$(DEBUGSRC)') \
115 -fno-stack-protector \
116 -fno-strict-aliasing \
117 -fpic \
118 -fshort-wchar
119$(call update-variable,FEATUREFLAGS)
120$(call conditional-add-flag,$(FANALYZER),analyzer,FEATUREFLAGS,-fanalyzer)
121$(call conditional-add-flag,$(COLOR),diagnostics-color,FEATUREFLAGS,-fdiagnostics-color=always)
122
123override DEFAULT_WARNFLAGS = \
124 -Wall \
125 -Wextra \
126 -Wno-missing-field-initializers
127$(call update-variable,WARNFLAGS)
128
129override DEFAULT_WERRFLAGS = \
130 -Werror
131$(call update-variable,WERRFLAGS)
132
133CFLAGS = $(FEATUREFLAGS) \
134 $(OPTIMIZATIONS) \
135 $(WARNFLAGS) \
8529e0f7 136 $(if $(findstring clang,$(CC)),$(CLANG_WARNINGS)) \
031e5cce
SM
137 $(ARCH_CFLAGS) \
138 $(WERRFLAGS) \
139 $(INCLUDES) \
140 $(DEFINES)
f892ac66 141
fd2d9f03
SM
142POST_PROCESS_PE_FLAGS =
143
f892ac66 144ifneq ($(origin OVERRIDE_SECURITY_POLICY), undefined)
031e5cce 145 DEFINES += -DOVERRIDE_SECURITY_POLICY
f892ac66
MTL
146endif
147
031e5cce
SM
148ifneq ($(origin REQUIRE_TPM), undefined)
149 DEFINES += -DREQUIRE_TPM
f892ac66
MTL
150endif
151
031e5cce
SM
152ifneq ($(origin DISABLE_EBS_PROTECTION), undefined)
153 DEFINES += -DDISABLE_EBS_PROTECTION
f892ac66
MTL
154endif
155
8529e0f7
SM
156ifneq ($(origin DISABLE_REMOVABLE_LOAD_OPTIONS), undefined)
157 DEFINES += -DDISABLE_REMOVABLE_LOAD_OPTIONS
158endif
159
f892ac66
MTL
160LIB_GCC = $(shell $(CC) $(ARCH_CFLAGS) -print-libgcc-file-name)
161EFI_LIBS = -lefi -lgnuefi --start-group Cryptlib/libcryptlib.a Cryptlib/OpenSSL/libopenssl.a --end-group $(LIB_GCC)
162FORMAT ?= --target efi-app-$(ARCH)
031e5cce
SM
163LOCAL_EFI_PATH = gnu-efi/$(ARCH_GNUEFI)/gnuefi
164LIBDIR = gnu-efi/$(ARCH_GNUEFI)/lib
f892ac66
MTL
165
166MMSTEM ?= mm$(ARCH_SUFFIX)
167MMNAME = $(MMSTEM).efi
168MMSONAME = $(MMSTEM).so
169FBSTEM ?= fb$(ARCH_SUFFIX)
170FBNAME = $(FBSTEM).efi
171FBSONAME = $(FBSTEM).so
172SHIMSTEM ?= shim$(ARCH_SUFFIX)
173SHIMNAME = $(SHIMSTEM).efi
174SHIMSONAME = $(SHIMSTEM).so
175SHIMHASHNAME = $(SHIMSTEM).hash
176BOOTEFINAME ?= BOOT$(ARCH_SUFFIX_UPPER).EFI
177BOOTCSVNAME ?= BOOT$(ARCH_SUFFIX_UPPER).CSV
178
031e5cce
SM
179DEFINES += -DEFI_ARCH='L"$(ARCH_SUFFIX)"' \
180 -DDEBUGDIR='L"/usr/lib/debug/usr/share/shim/$(ARCH_SUFFIX)-$(VERSION)$(DASHRELEASE)/"'
f892ac66 181
031e5cce
SM
182ifneq ($(origin VENDOR_DB_FILE), undefined)
183DEFINES += -DVENDOR_DB_FILE=\"$(VENDOR_DB_FILE)\"
184endif
f892ac66 185ifneq ($(origin VENDOR_CERT_FILE), undefined)
031e5cce 186DEFINES += -DVENDOR_CERT_FILE=\"$(VENDOR_CERT_FILE)\"
f892ac66
MTL
187endif
188ifneq ($(origin VENDOR_DBX_FILE), undefined)
031e5cce
SM
189DEFINES += -DVENDOR_DBX_FILE=\"$(VENDOR_DBX_FILE)\"
190endif
fd2d9f03
SM
191ifneq ($(origin SBAT_AUTOMATIC_DATE), undefined)
192DEFINES += -DSBAT_AUTOMATIC_DATE=$(SBAT_AUTOMATIC_DATE)
193endif
031e5cce
SM
194
195LDFLAGS = --hash-style=sysv -nostdlib -znocombreloc -T $(EFI_LDS) -shared -Bsymbolic -L$(LOCAL_EFI_PATH) -L$(LIBDIR) -LCryptlib -LCryptlib/OpenSSL $(EFI_CRT_OBJS) --build-id=sha1 $(ARCH_LDFLAGS) --no-undefined
196
197ifneq ($(DEBUG),)
198export DEBUG
199endif
200ifneq ($(VERBOSE),)
201export VERBOSE
f892ac66
MTL
202endif
203
031e5cce 204# vim:filetype=make