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# 48530d68baSNigel CroxonINSTALLROOT := / 49530d68baSNigel CroxonPREFIX := /usr/local 50*63a9a4d4SCallum FarmerEXEC_PREFIX := $(PREFIX) 51*63a9a4d4SCallum FarmerLIBDIR := $(EXEC_PREFIX)/lib 52*63a9a4d4SCallum FarmerINCLUDEDIR := $(PREFIX)/include 53530d68baSNigel CroxonINSTALL := install 54530d68baSNigel Croxon 55530d68baSNigel Croxon# Compilation tools 56530d68baSNigel CroxonHOSTCC := $(prefix)gcc 57530d68baSNigel CroxonCC := $(prefix)$(CROSS_COMPILE)gcc 58530d68baSNigel CroxonAS := $(prefix)$(CROSS_COMPILE)as 59530d68baSNigel CroxonLD := $(prefix)$(CROSS_COMPILE)ld 60530d68baSNigel CroxonAR := $(prefix)$(CROSS_COMPILE)ar 61530d68baSNigel CroxonRANLIB := $(prefix)$(CROSS_COMPILE)ranlib 62530d68baSNigel CroxonOBJCOPY := $(prefix)$(CROSS_COMPILE)objcopy 63530d68baSNigel Croxon 64530d68baSNigel Croxon 65530d68baSNigel Croxon# Host/target identification 66530d68baSNigel CroxonOS := $(shell uname -s) 6744267b59SBen WolsiefferHOSTARCH ?= $(shell $(HOSTCC) -dumpmachine | cut -f1 -d- | sed -e s,i[3456789]86,ia32, -e 's,armv[67].*,arm,' ) 6844267b59SBen WolsiefferARCH ?= $(shell $(HOSTCC) -dumpmachine | cut -f1 -d- | sed -e s,i[3456789]86,ia32, -e 's,armv[67].*,arm,' ) 69530d68baSNigel Croxon 70530d68baSNigel Croxon# Get ARCH from the compiler if cross compiling 71530d68baSNigel Croxonifneq ($(CROSS_COMPILE),) 7244267b59SBen Wolsieffer override ARCH := $(shell $(CC) -dumpmachine | cut -f1 -d-| sed -e s,i[3456789]86,ia32, -e 's,armv[67].*,arm,' ) 73530d68baSNigel Croxonendif 74530d68baSNigel Croxon 75530d68baSNigel Croxon# FreeBSD (and possibly others) reports amd64 instead of x86_64 76530d68baSNigel Croxonifeq ($(ARCH),amd64) 77530d68baSNigel Croxon override ARCH := x86_64 78530d68baSNigel Croxonendif 79530d68baSNigel Croxon 80530d68baSNigel Croxon# 81ce7098fbSNigel Croxon# Where to build the package 82ce7098fbSNigel Croxon# 83ce7098fbSNigel CroxonOBJDIR := $(TOPDIR)/$(ARCH) 84ce7098fbSNigel Croxon 85ce7098fbSNigel Croxon# 86530d68baSNigel Croxon# Variables below derived from variables above 87530d68baSNigel Croxon# 88530d68baSNigel Croxon 89530d68baSNigel Croxon# Arch-specific compilation flags 90530d68baSNigel CroxonCPPFLAGS += -DCONFIG_$(ARCH) 91530d68baSNigel Croxon 92be57aadbSPeter JonesCFLAGS += -Wno-error=pragmas 93be57aadbSPeter Jones 94530d68baSNigel Croxonifeq ($(ARCH),ia64) 95530d68baSNigel Croxon CFLAGS += -mfixed-range=f32-f127 96530d68baSNigel Croxonendif 97530d68baSNigel Croxon 98530d68baSNigel Croxonifeq ($(ARCH),ia32) 99530d68baSNigel Croxon CFLAGS += -mno-mmx -mno-sse 100530d68baSNigel Croxon ifeq ($(HOSTARCH),x86_64) 101530d68baSNigel Croxon ARCH3264 = -m32 102530d68baSNigel Croxon endif 103530d68baSNigel Croxonendif 104530d68baSNigel Croxon 105530d68baSNigel Croxonifeq ($(ARCH),x86_64) 106530d68baSNigel Croxon GCCVERSION := $(shell $(CC) -dumpversion | cut -f1 -d.) 107530d68baSNigel Croxon GCCMINOR := $(shell $(CC) -dumpversion | cut -f2 -d.) 108787cb7fcSNigel Croxon USING_CLANG := $(shell $(CC) -v 2>&1 | grep -q 'clang version' && echo clang) 109530d68baSNigel Croxon 110530d68baSNigel Croxon # Rely on GCC MS ABI support? 111530d68baSNigel Croxon GCCNEWENOUGH := $(shell ( [ $(GCCVERSION) -gt "4" ] \ 112530d68baSNigel Croxon || ( [ $(GCCVERSION) -eq "4" ] \ 113530d68baSNigel Croxon && [ $(GCCMINOR) -ge "7" ] ) ) \ 114530d68baSNigel Croxon && echo 1) 115530d68baSNigel Croxon ifeq ($(GCCNEWENOUGH),1) 116530d68baSNigel Croxon CPPFLAGS += -DGNU_EFI_USE_MS_ABI -maccumulate-outgoing-args --std=c11 117787cb7fcSNigel Croxon else ifeq ($(USING_CLANG),clang) 118787cb7fcSNigel Croxon CPPFLAGS += -DGNU_EFI_USE_MS_ABI --std=c11 119530d68baSNigel Croxon endif 120530d68baSNigel Croxon 121b2c4db06SNigel Croxon CFLAGS += -mno-red-zone 122530d68baSNigel Croxon ifeq ($(HOSTARCH),ia32) 123530d68baSNigel Croxon ARCH3264 = -m64 124530d68baSNigel Croxon endif 125530d68baSNigel Croxonendif 126530d68baSNigel Croxon 12799d94682SNigel Croxonifneq (,$(filter $(ARCH),ia32 x86_64)) 12899d94682SNigel Croxon # Disable AVX, if the compiler supports that. 12999d94682SNigel Croxon CC_CAN_DISABLE_AVX=$(shell $(CC) -Werror -c -o /dev/null -xc -mno-avx - </dev/null >/dev/null 2>&1 && echo 1) 13099d94682SNigel Croxon ifeq ($(CC_CAN_DISABLE_AVX), 1) 13199d94682SNigel Croxon CFLAGS += -mno-avx 13299d94682SNigel Croxon endif 13399d94682SNigel Croxonendif 13499d94682SNigel Croxon 1353f234f5bSNigel Croxonifeq ($(ARCH),mips64el) 1363f234f5bSNigel Croxon CFLAGS += -march=mips64r2 1373f234f5bSNigel Croxon ARCH3264 = -mabi=64 1383f234f5bSNigel Croxonendif 1393f234f5bSNigel Croxon 140530d68baSNigel Croxon# 141530d68baSNigel Croxon# Set HAVE_EFI_OBJCOPY if objcopy understands --target efi-[app|bsdrv|rtdrv], 142530d68baSNigel Croxon# otherwise we need to compose the PE/COFF header using the assembler 143530d68baSNigel Croxon# 144530d68baSNigel Croxonifneq ($(ARCH),arm) 1453f234f5bSNigel Croxonifneq ($(ARCH),mips64el) 146b95f138fSHeinrich Schuchardtifneq ($(ARCH),riscv64) 147e7db4418Szhoumingtaoifneq ($(ARCH),loongarch64) 148530d68baSNigel Croxonexport HAVE_EFI_OBJCOPY=y 149530d68baSNigel Croxonendif 150530d68baSNigel Croxonendif 1513f234f5bSNigel Croxonendif 152b95f138fSHeinrich Schuchardtendif 153530d68baSNigel Croxon 154530d68baSNigel Croxonifneq ($(ARCH),arm) 155530d68baSNigel Croxonexport LIBGCC=$(shell $(CC) $(ARCH3264) -print-libgcc-file-name) 156530d68baSNigel Croxonendif 157530d68baSNigel Croxon 158530d68baSNigel Croxonifeq ($(ARCH),arm) 159530d68baSNigel CroxonCFLAGS += -marm 160530d68baSNigel Croxonendif 161530d68baSNigel Croxon 16204e6df70SCallum Farmerifeq ($(ARCH),aarch64) 16304e6df70SCallum FarmerLDFLAGS += -z common-page-size=4096 16404e6df70SCallum FarmerLDFLAGS += -z max-page-size=4096 16504e6df70SCallum Farmerendif 16604e6df70SCallum Farmer 167530d68baSNigel Croxon# Generic compilation flags 168530d68baSNigel CroxonINCDIR += -I$(SRCDIR) -I$(TOPDIR)/inc -I$(TOPDIR)/inc/$(ARCH) \ 169530d68baSNigel Croxon -I$(TOPDIR)/inc/protocol 170530d68baSNigel Croxon 171368cdf12SPeter Jones# Only enable -fPIE for non MinGW compilers (unneeded on MinGW) 17250b88377SNigel CroxonGCCMACHINE := $(shell $(CC) -dumpmachine) 17350b88377SNigel Croxonifneq (mingw32,$(findstring mingw32, $(GCCMACHINE))) 174368cdf12SPeter Jones CFLAGS += -fPIE 17550b88377SNigel Croxonendif 17650b88377SNigel Croxon 177530d68baSNigel Croxonifeq (FreeBSD, $(findstring FreeBSD, $(OS))) 17850b88377SNigel CroxonCFLAGS += $(ARCH3264) -g -O2 -Wall -Wextra -Werror \ 179a213b514SNigel Croxon -fshort-wchar -fno-strict-aliasing \ 180530d68baSNigel Croxon -ffreestanding -fno-stack-protector 181530d68baSNigel Croxonelse 182b9c4b23dSPeter JonesCFLAGS += $(ARCH3264) -g -O2 -Wall -Wextra -Wno-pointer-sign -Werror \ 183a213b514SNigel Croxon -fshort-wchar -fno-strict-aliasing \ 184f0bf464aSPeter Jones -ffreestanding -fno-stack-protector -fno-stack-check \ 185f0bf464aSPeter Jones -fno-stack-check \ 186f0bf464aSPeter Jones $(if $(findstring gcc,$(CC)),-fno-merge-all-constants,) 187530d68baSNigel Croxonendif 188530d68baSNigel Croxon 189656e495dSPeter JonesARFLAGS := rDv 190530d68baSNigel CroxonASFLAGS += $(ARCH3264) 19111a459baSNigel CroxonLDFLAGS += -nostdlib --warn-common --no-undefined --fatal-warnings \ 19211a459baSNigel Croxon --build-id=sha1 193