blob: d36115f029ba70d4d57067a206db23fb54bb17ea [file] [log] [blame]
Sridhar Parasuramfedf9ac2015-11-03 16:20:50 -08001UEFI_TOP_DIR := .
2
3ifndef $(BOOTLOADER_OUT)
4 BOOTLOADER_OUT := .
5endif
6export $(BOOTLOADER_OUT)
7
8BUILDDIR=$(shell pwd)
Prathyush Katukojwalaeec0cc62017-08-23 12:00:14 -07009export WRAPPER := $(BUILDDIR)/clang-wrapper.py
Jeevan Shriram4d4d5e62017-06-08 16:43:07 -070010
Sridhar Parasuramfedf9ac2015-11-03 16:20:50 -080011export CLANG35_BIN := $(CLANG_BIN)
Jeevan Shriramd29e4402017-11-06 14:04:11 -080012export CLANG35_GCC_TOOLCHAIN := $(CLANG35_GCC_TOOLCHAIN)
Sridhar Parasuramfedf9ac2015-11-03 16:20:50 -080013
Jeevan Shriram4d4d5e62017-06-08 16:43:07 -070014ifeq ($(TARGET_ARCHITECTURE),arm)
15export ARCHITECTURE := ARM
Jeevan Shriramd29e4402017-11-06 14:04:11 -080016export CLANG35_ARM_PREFIX := $(CLANG_PREFIX)
Jeevan Shriram4d4d5e62017-06-08 16:43:07 -070017else
18export ARCHITECTURE := AARCH64
Jeevan Shriramd29e4402017-11-06 14:04:11 -080019export CLANG35_AARCH64_PREFIX := $(CLANG_PREFIX)
Jeevan Shriram4d4d5e62017-06-08 16:43:07 -070020endif
21
Jeevan Shriramd29e4402017-11-06 14:04:11 -080022export BUILD_REPORT_DIR := $(BOOTLOADER_OUT)/build_report
23ANDROID_PRODUCT_OUT := $(BOOTLOADER_OUT)/Build
24
Sridhar Parasuramfedf9ac2015-11-03 16:20:50 -080025WORKSPACE=$(BUILDDIR)
26TARGET_TOOLS := CLANG35
27TARGET := DEBUG
28BUILD_ROOT := $(ANDROID_PRODUCT_OUT)/$(TARGET)_$(TARGET_TOOLS)
Channagoud Kadabi1ed4a152016-02-05 15:15:41 -080029EDK_TOOLS := $(BUILDDIR)/BaseTools
30EDK_TOOLS_BIN := $(EDK_TOOLS)/Source/C/bin
Sridhar Parasuramfedf9ac2015-11-03 16:20:50 -080031ABL_FV_IMG := $(BUILD_ROOT)/FV/abl.fv
32ABL_FV_ELF := $(BOOTLOADER_OUT)/../../abl.elf
lijuang4d342f62016-09-13 15:51:26 +080033SHELL:=/bin/bash
Sridhar Parasuramfedf9ac2015-11-03 16:20:50 -080034
Trilok Sonic1a2d142017-04-26 17:32:05 -070035# UEFI UBSAN Configuration
36# ENABLE_UEFI_UBSAN := true
37
38ifeq "$(ENABLE_UEFI_UBSAN)" "true"
39 UBSAN_GCC_FLAG_UNDEFINED := -fsanitize=undefined
40 UBSAN_GCC_FLAG_ALIGNMENT := -fno-sanitize=alignment
41else
42 UBSAN_GCC_FLAG_UNDEFINED :=
43 UBSAN_GCC_FLAG_ALIGNMENT :=
44endif
45
Jeevan Shriram90c404b2018-03-29 15:11:44 -070046ifeq ($(TARGET_ARCHITECTURE), arm)
Jeevan Shriram32541172017-12-02 10:19:23 -080047 LOAD_ADDRESS := 0X8FB00000
Jeevan Shriram995c2312017-10-10 14:25:00 -070048else
Jeevan Shriram32541172017-12-02 10:19:23 -080049 LOAD_ADDRESS := 0X9FA00000
Jeevan Shriram995c2312017-10-10 14:25:00 -070050endif
51
Jeevan Shriram90c404b2018-03-29 15:11:44 -070052ifeq ($(ENABLE_LE_VARIANT), true)
53 ENABLE_LE_VARIANT := 1
54else
55 ENABLE_LE_VARIANT := 0
56endif
57
Sridhar Parasuramfedf9ac2015-11-03 16:20:50 -080058.PHONY: all cleanall
59
60all: ABL_FV_ELF
61
62cleanall:
63 @. ./edksetup.sh BaseTools && \
Jeevan Shriram4d4d5e62017-06-08 16:43:07 -070064 build -p $(WORKSPACE)/QcomModulePkg/QcomModulePkg.dsc -a $(ARCHITECTURE) -t $(TARGET_TOOLS) -b $(TARGET) -j build_modulepkg.log cleanall
Sridhar Parasuramfedf9ac2015-11-03 16:20:50 -080065 rm -rf $(WORKSPACE)/QcomModulePkg/Bin64
66
Channagoud Kadabi1ed4a152016-02-05 15:15:41 -080067EDK_TOOLS_BIN:
Sridhar Parasuramfedf9ac2015-11-03 16:20:50 -080068 @. ./edksetup.sh BaseTools && \
Channagoud Kadabi1ed4a152016-02-05 15:15:41 -080069 $(MAKE) -C $(EDK_TOOLS) -j1
70
71ABL_FV_IMG: EDK_TOOLS_BIN
72 @. ./edksetup.sh BaseTools && \
Jeevan Shriram995c2312017-10-10 14:25:00 -070073 build -p $(WORKSPACE)/QcomModulePkg/QcomModulePkg.dsc \
74 -a $(ARCHITECTURE) \
75 -t $(TARGET_TOOLS) \
76 -b $(TARGET) \
77 -D ABL_OUT_DIR=$(ANDROID_PRODUCT_OUT) \
78 -D VERIFIED_BOOT=$(VERIFIED_BOOT) \
79 -D VERIFIED_BOOT_2=$(VERIFIED_BOOT_2) \
80 -D USER_BUILD_VARIANT=$(USER_BUILD_VARIANT) \
81 -D ENABLE_LE_VARIANT=$(ENABLE_LE_VARIANT) \
82 -D UBSAN_UEFI_GCC_FLAG_UNDEFINED=$(UBSAN_GCC_FLAG_UNDEFINED) \
83 -D UBSAN_UEFI_GCC_FLAG_ALIGNMENT=$(UBSAN_GCC_FLAG_ALIGNMENT) \
84 -j build_modulepkg.log $*
85
Sridhar Parasuramfedf9ac2015-11-03 16:20:50 -080086 cp $(BUILD_ROOT)/FV/FVMAIN_COMPACT.Fv $(ABL_FV_IMG)
87
88ABL_FV_ELF: ABL_FV_IMG
Jeevan Shriram19a53812017-06-14 15:39:48 -070089 python $(WORKSPACE)/QcomModulePkg/Tools/image_header.py $(ABL_FV_IMG) $(ABL_FV_ELF) $(LOAD_ADDRESS) elf 32