]> git.proxmox.com Git - mirror_edk2.git/blame - ArmPlatformPkg/Scripts/Makefile
ArmPlatformPkg/NorFlashDxe: prepare for devicepath format change
[mirror_edk2.git] / ArmPlatformPkg / Scripts / Makefile
CommitLineData
e349327f 1#/* @file\r
b330087b 2# Copyright (c) 2011-2015, ARM Limited. All rights reserved.\r
e349327f 3# \r
4# This program and the accompanying materials \r
5# are licensed and made available under the terms and conditions of the BSD License \r
6# which accompanies this distribution. The full text of the license may be found at \r
7# http://opensource.org/licenses/bsd-license.php \r
8#\r
9# THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, \r
10# WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. \r
11#\r
12#*/\r
13\r
e01b4a8a 14# Define the following variable to specify an alternative toolchain to the one located in your PATH:\r
e349327f 15# - RVCT_TOOLS_PATH: for RVCT and RVCTLINUX toolchains\r
e349327f 16\r
17EDK2_TOOLCHAIN ?= RVCTLINUX\r
18EDK2_ARCH ?= ARM\r
19EDK2_BUILD ?= DEBUG\r
20\r
21ifeq ($(EDK2_DSC),"")\r
22 $(error The Makfile macro 'EDK2_DSC' must be defined with an EDK2 DSC file.)\r
23endif\r
b330087b
OM
24ifeq ("$(EDK2_DSC)","ArmPlatformPkg/ArmVExpressPkg/ArmVExpress-FVP-AArch64.dsc")\r
25 BUILD_FIP=1\r
26 BUILD_PATH=$(WORKSPACE)/Build/ArmVExpress-FVP-AArch64\r
27 UEFI_BIN=FVP_AARCH64_EFI.fd\r
28endif\r
e349327f 29\r
30ifeq ("$(OS)","Windows_NT")\r
25328e43 31export WORKSPACE?=$(PWD)\r
32export EDK_TOOLS_PATH ?= $(WORKSPACE)\BaseTools\r
e349327f 33endif\r
34\r
35SHELL := /bin/bash\r
36SILENT ?= @\r
37ECHO ?= echo\r
38MAKE ?= make -i -k\r
39RM ?= rm -f\r
40\r
41.PHONY: all clean\r
42\r
43EDK2_CONF = Conf/BuildEnv.sh Conf/build_rule.txt Conf/target.txt Conf/tools_def.txt\r
44\r
b330087b
OM
45#\r
46# FIP Support\r
47#\r
48ifeq ($(BUILD_FIP),"1")\r
49 ifeq ($(FIP_BIN),"")\r
50 $(info Define location of the FIP to automatically update the package after building UEFI.)\r
51 endif\r
52endif\r
53\r
e349327f 54all: $(EDK2_CONF)\r
55ifeq ("$(OS)","Windows_NT")\r
25328e43 56 build -a $(EDK2_ARCH) -p $(EDK2_DSC) -t $(EDK2_TOOLCHAIN) -b $(EDK2_BUILD) $(EDK2_MACROS)\r
e349327f 57else\r
3f3659e2 58 . ./edksetup.sh; build -a $(EDK2_ARCH) -p $(EDK2_DSC) -t $(EDK2_TOOLCHAIN) -b $(EDK2_BUILD) $(EDK2_MACROS)\r
e349327f 59endif\r
b330087b
OM
60ifeq ("$(BUILD_FIP)","1")\r
61ifneq ($(FIP_BIN),"")\r
62 $(SILENT)which fip_create ; \\r
63 if [ $$? -ne 0 ]; then \\r
64 $(ECHO) "Warning: 'fip_create' tool is not in the PATH. The UEFI binary will not be added in the Firmware Image Package (FIP)."; \\r
65 else \\r
66 fip_create --bl33 $(BUILD_PATH)/$(EDK2_BUILD)_$(EDK2_TOOLCHAIN)/FV/$(UEFI_BIN) --dump $(FIP_BIN); \\r
67 fi\r
68endif\r
69endif\r
e349327f 70\r
71$(EDK2_CONF):\r
72ifeq ("$(OS)","Windows_NT")\r
73 copy $(EDK_TOOLS_PATH)\Conf\build_rule.template Conf\build_rule.txt\r
74 copy $(EDK_TOOLS_PATH)\Conf\FrameworkDatabase.template Conf\FrameworkDatabase.txt\r
75 copy $(EDK_TOOLS_PATH)\Conf\target.template Conf\target.txt\r
76 copy $(EDK_TOOLS_PATH)\Conf\tools_def.template Conf\tools_def.txt\r
77else\r
3f3659e2 78 . ./edksetup.sh; $(MAKE) -C BaseTools\r
e349327f 79endif\r
80\r
81clean:\r
82ifeq ("$(OS)","Windows_NT")\r
25328e43 83 build -a $(EDK2_ARCH) -p $(EDK2_DSC) -t $(EDK2_TOOLCHAIN) -b $(EDK2_BUILD) $(EDK2_MACROS) cleanall\r
e349327f 84else\r
3f3659e2 85 . ./edksetup.sh; build -a $(EDK2_ARCH) -p $(EDK2_DSC) -t $(EDK2_TOOLCHAIN) -b $(EDK2_BUILD) $(EDK2_MACROS) cleanall; \\r
e349327f 86 rm -Rf $(EDK2_CONF) Conf/.cache\r
87endif\r