1530d68baSNigel Croxon# -*- makefile -*- 2530d68baSNigel Croxon# Copyright (c) 1999-2007 Hewlett-Packard Development Company, L.P. 3530d68baSNigel Croxon# Contributed by David Mosberger <davidm@hpl.hp.com> 4530d68baSNigel Croxon# Contributed by Stephane Eranian <eranian@hpl.hp.com> 5530d68baSNigel Croxon# 6530d68baSNigel Croxon# All rights reserved. 7530d68baSNigel Croxon# 8530d68baSNigel Croxon# Redistribution and use in source and binary forms, with or without 9530d68baSNigel Croxon# modification, are permitted provided that the following conditions 10530d68baSNigel Croxon# are met: 11530d68baSNigel Croxon# 12530d68baSNigel Croxon# * Redistributions of source code must retain the above copyright 13530d68baSNigel Croxon# notice, this list of conditions and the following disclaimer. 14530d68baSNigel Croxon# * Redistributions in binary form must reproduce the above 15530d68baSNigel Croxon# copyright notice, this list of conditions and the following 16530d68baSNigel Croxon# disclaimer in the documentation and/or other materials 17530d68baSNigel Croxon# provided with the distribution. 18530d68baSNigel Croxon# * Neither the name of Hewlett-Packard Co. nor the names of its 19530d68baSNigel Croxon# contributors may be used to endorse or promote products derived 20530d68baSNigel Croxon# from this software without specific prior written permission. 21530d68baSNigel Croxon# 22530d68baSNigel Croxon# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND 23530d68baSNigel Croxon# CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, 24530d68baSNigel Croxon# INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF 25530d68baSNigel Croxon# MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE 26530d68baSNigel Croxon# DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS 27530d68baSNigel Croxon# BE LIABLE FOR ANYDIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, 28530d68baSNigel Croxon# OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, 29530d68baSNigel Croxon# PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR 30530d68baSNigel Croxon# PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 31530d68baSNigel Croxon# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR 32530d68baSNigel Croxon# TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF 33530d68baSNigel Croxon# THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 34530d68baSNigel Croxon# SUCH DAMAGE. 35530d68baSNigel Croxon# 36530d68baSNigel Croxon 37530d68baSNigel CroxonTOPDIR := $(shell if [ "$$PWD" != "" ]; then echo $$PWD; else pwd; fi) 38530d68baSNigel Croxon 39530d68baSNigel Croxon# 40530d68baSNigel Croxon# Variables below overridable from command-line: 41530d68baSNigel Croxon# make VARNAME=value ... 42530d68baSNigel Croxon# 43530d68baSNigel Croxon 44530d68baSNigel Croxon# 45530d68baSNigel Croxon# Where to install the package. GNU-EFI will create and access 46530d68baSNigel Croxon# lib and include under the root 47530d68baSNigel Croxon# 48*4ee8cf56SPeter JonesDESTDIR ?= / 49*4ee8cf56SPeter Jonesifeq ($(origin INSTALLROOT),undefined) 50*4ee8cf56SPeter JonesINSTALLROOT = $(DESTDIR) 51*4ee8cf56SPeter Jonesendif 52*4ee8cf56SPeter Jones 53*4ee8cf56SPeter Jonesempty := 54*4ee8cf56SPeter Jonesspace := $(empty) $(empty) 55*4ee8cf56SPeter Jonesstripped = $(subst $(space),/,$(strip $(subst /,$(space),$(1)))) 56*4ee8cf56SPeter Jonesunstripped = $(subst $(space),/,$(subst /,$(space),$(1))) 57*4ee8cf56SPeter Jonesis_absolute = $(subst $(call stripped,$(1)),$(empty),$(call unstripped,$(1))) 58*4ee8cf56SPeter Jones 59*4ee8cf56SPeter Jonesoverride INSTALLROOT:=$(if $(call is_absolute,$(INSTALLROOT)),,$(TOPDIR)/)$(INSTALLROOT) 60*4ee8cf56SPeter Jones 61530d68baSNigel CroxonPREFIX := /usr/local 62530d68baSNigel CroxonLIBDIR := $(PREFIX)/lib 63530d68baSNigel CroxonINSTALL := install 64530d68baSNigel Croxon 65530d68baSNigel Croxon# Compilation tools 66530d68baSNigel CroxonHOSTCC := $(prefix)gcc 67530d68baSNigel CroxonCC := $(prefix)$(CROSS_COMPILE)gcc 68530d68baSNigel CroxonAS := $(prefix)$(CROSS_COMPILE)as 69530d68baSNigel CroxonLD := $(prefix)$(CROSS_COMPILE)ld 70530d68baSNigel CroxonAR := $(prefix)$(CROSS_COMPILE)ar 71530d68baSNigel CroxonRANLIB := $(prefix)$(CROSS_COMPILE)ranlib 72530d68baSNigel CroxonOBJCOPY := $(prefix)$(CROSS_COMPILE)objcopy 73530d68baSNigel Croxon 74530d68baSNigel Croxon 75530d68baSNigel Croxon# Host/target identification 76530d68baSNigel CroxonOS := $(shell uname -s) 7744267b59SBen WolsiefferHOSTARCH ?= $(shell $(HOSTCC) -dumpmachine | cut -f1 -d- | sed -e s,i[3456789]86,ia32, -e 's,armv[67].*,arm,' ) 7844267b59SBen WolsiefferARCH ?= $(shell $(HOSTCC) -dumpmachine | cut -f1 -d- | sed -e s,i[3456789]86,ia32, -e 's,armv[67].*,arm,' ) 79530d68baSNigel Croxon 80530d68baSNigel Croxon# Get ARCH from the compiler if cross compiling 81530d68baSNigel Croxonifneq ($(CROSS_COMPILE),) 8244267b59SBen Wolsieffer override ARCH := $(shell $(CC) -dumpmachine | cut -f1 -d-| sed -e s,i[3456789]86,ia32, -e 's,armv[67].*,arm,' ) 83530d68baSNigel Croxonendif 84530d68baSNigel Croxon 85530d68baSNigel Croxon# FreeBSD (and possibly others) reports amd64 instead of x86_64 86530d68baSNigel Croxonifeq ($(ARCH),amd64) 87530d68baSNigel Croxon override ARCH := x86_64 88530d68baSNigel Croxonendif 89530d68baSNigel Croxon 90530d68baSNigel Croxon# 91ce7098fbSNigel Croxon# Where to build the package 92ce7098fbSNigel Croxon# 93ce7098fbSNigel CroxonOBJDIR := $(TOPDIR)/$(ARCH) 94ce7098fbSNigel Croxon 95ce7098fbSNigel Croxon# 96530d68baSNigel Croxon# Variables below derived from variables above 97530d68baSNigel Croxon# 98530d68baSNigel Croxon 99530d68baSNigel Croxon# Arch-specific compilation flags 100530d68baSNigel CroxonCPPFLAGS += -DCONFIG_$(ARCH) 101530d68baSNigel Croxon 102be57aadbSPeter JonesCFLAGS += -Wno-error=pragmas 103be57aadbSPeter Jones 104530d68baSNigel Croxonifeq ($(ARCH),ia64) 105530d68baSNigel Croxon CFLAGS += -mfixed-range=f32-f127 106530d68baSNigel Croxonendif 107530d68baSNigel Croxon 108530d68baSNigel Croxonifeq ($(ARCH),ia32) 109530d68baSNigel Croxon CFLAGS += -mno-mmx -mno-sse 110530d68baSNigel Croxon ifeq ($(HOSTARCH),x86_64) 111530d68baSNigel Croxon ARCH3264 = -m32 112530d68baSNigel Croxon endif 113530d68baSNigel Croxonendif 114530d68baSNigel Croxon 115530d68baSNigel Croxonifeq ($(ARCH),x86_64) 116530d68baSNigel Croxon GCCVERSION := $(shell $(CC) -dumpversion | cut -f1 -d.) 117530d68baSNigel Croxon GCCMINOR := $(shell $(CC) -dumpversion | cut -f2 -d.) 118787cb7fcSNigel Croxon USING_CLANG := $(shell $(CC) -v 2>&1 | grep -q 'clang version' && echo clang) 119530d68baSNigel Croxon 120530d68baSNigel Croxon # Rely on GCC MS ABI support? 121530d68baSNigel Croxon GCCNEWENOUGH := $(shell ( [ $(GCCVERSION) -gt "4" ] \ 122530d68baSNigel Croxon || ( [ $(GCCVERSION) -eq "4" ] \ 123530d68baSNigel Croxon && [ $(GCCMINOR) -ge "7" ] ) ) \ 124530d68baSNigel Croxon && echo 1) 125530d68baSNigel Croxon ifeq ($(GCCNEWENOUGH),1) 126530d68baSNigel Croxon CPPFLAGS += -DGNU_EFI_USE_MS_ABI -maccumulate-outgoing-args --std=c11 127787cb7fcSNigel Croxon else ifeq ($(USING_CLANG),clang) 128787cb7fcSNigel Croxon CPPFLAGS += -DGNU_EFI_USE_MS_ABI --std=c11 129530d68baSNigel Croxon endif 130530d68baSNigel Croxon 131b2c4db06SNigel Croxon CFLAGS += -mno-red-zone 132530d68baSNigel Croxon ifeq ($(HOSTARCH),ia32) 133530d68baSNigel Croxon ARCH3264 = -m64 134530d68baSNigel Croxon endif 135530d68baSNigel Croxonendif 136530d68baSNigel Croxon 13799d94682SNigel Croxonifneq (,$(filter $(ARCH),ia32 x86_64)) 13899d94682SNigel Croxon # Disable AVX, if the compiler supports that. 13999d94682SNigel Croxon CC_CAN_DISABLE_AVX=$(shell $(CC) -Werror -c -o /dev/null -xc -mno-avx - </dev/null >/dev/null 2>&1 && echo 1) 14099d94682SNigel Croxon ifeq ($(CC_CAN_DISABLE_AVX), 1) 14199d94682SNigel Croxon CFLAGS += -mno-avx 14299d94682SNigel Croxon endif 14399d94682SNigel Croxonendif 14499d94682SNigel Croxon 1453f234f5bSNigel Croxonifeq ($(ARCH),mips64el) 1463f234f5bSNigel Croxon CFLAGS += -march=mips64r2 1473f234f5bSNigel Croxon ARCH3264 = -mabi=64 1483f234f5bSNigel Croxonendif 1493f234f5bSNigel Croxon 150530d68baSNigel Croxon# 151530d68baSNigel Croxon# Set HAVE_EFI_OBJCOPY if objcopy understands --target efi-[app|bsdrv|rtdrv], 152530d68baSNigel Croxon# otherwise we need to compose the PE/COFF header using the assembler 153530d68baSNigel Croxon# 154530d68baSNigel Croxonifneq ($(ARCH),arm) 1553f234f5bSNigel Croxonifneq ($(ARCH),mips64el) 156b95f138fSHeinrich Schuchardtifneq ($(ARCH),riscv64) 157e7db4418Szhoumingtaoifneq ($(ARCH),loongarch64) 158530d68baSNigel Croxonexport HAVE_EFI_OBJCOPY=y 159530d68baSNigel Croxonendif 160530d68baSNigel Croxonendif 1613f234f5bSNigel Croxonendif 162b95f138fSHeinrich Schuchardtendif 163530d68baSNigel Croxon 164530d68baSNigel Croxonifneq ($(ARCH),arm) 165530d68baSNigel Croxonexport LIBGCC=$(shell $(CC) $(ARCH3264) -print-libgcc-file-name) 166530d68baSNigel Croxonendif 167530d68baSNigel Croxon 168530d68baSNigel Croxonifeq ($(ARCH),arm) 169530d68baSNigel CroxonCFLAGS += -marm 170530d68baSNigel Croxonendif 171530d68baSNigel Croxon 17204e6df70SCallum Farmerifeq ($(ARCH),aarch64) 17304e6df70SCallum FarmerLDFLAGS += -z common-page-size=4096 17404e6df70SCallum FarmerLDFLAGS += -z max-page-size=4096 17504e6df70SCallum Farmerendif 17604e6df70SCallum Farmer 177530d68baSNigel Croxon# Generic compilation flags 178530d68baSNigel CroxonINCDIR += -I$(SRCDIR) -I$(TOPDIR)/inc -I$(TOPDIR)/inc/$(ARCH) \ 179530d68baSNigel Croxon -I$(TOPDIR)/inc/protocol 180530d68baSNigel Croxon 181368cdf12SPeter Jones# Only enable -fPIE for non MinGW compilers (unneeded on MinGW) 18250b88377SNigel CroxonGCCMACHINE := $(shell $(CC) -dumpmachine) 18350b88377SNigel Croxonifneq (mingw32,$(findstring mingw32, $(GCCMACHINE))) 184368cdf12SPeter Jones CFLAGS += -fPIE 18550b88377SNigel Croxonendif 18650b88377SNigel Croxon 187530d68baSNigel Croxonifeq (FreeBSD, $(findstring FreeBSD, $(OS))) 18850b88377SNigel CroxonCFLAGS += $(ARCH3264) -g -O2 -Wall -Wextra -Werror \ 189a213b514SNigel Croxon -fshort-wchar -fno-strict-aliasing \ 190530d68baSNigel Croxon -ffreestanding -fno-stack-protector 191530d68baSNigel Croxonelse 192b9c4b23dSPeter JonesCFLAGS += $(ARCH3264) -g -O2 -Wall -Wextra -Wno-pointer-sign -Werror \ 193a213b514SNigel Croxon -fshort-wchar -fno-strict-aliasing \ 194f0bf464aSPeter Jones -ffreestanding -fno-stack-protector -fno-stack-check \ 195f0bf464aSPeter Jones -fno-stack-check \ 196f0bf464aSPeter Jones $(if $(findstring gcc,$(CC)),-fno-merge-all-constants,) 197530d68baSNigel Croxonendif 198530d68baSNigel Croxon 199656e495dSPeter JonesARFLAGS := rDv 200530d68baSNigel CroxonASFLAGS += $(ARCH3264) 20111a459baSNigel CroxonLDFLAGS += -nostdlib --warn-common --no-undefined --fatal-warnings \ 20211a459baSNigel Croxon --build-id=sha1 203