blob: d6e73e13959200b2ed8b080d99f61e36f1087d1f [file] [log] [blame]
Victor Chongbadc7922015-12-08 17:23:20 +00001################################################################################
Pascal Brandefe56592016-03-03 10:46:52 +01002# Following variables defines how the NS_USER (Non Secure User - Client
3# Application), NS_KERNEL (Non Secure Kernel), S_KERNEL (Secure Kernel) and
4# S_USER (Secure User - TA) are compiled
Victor Chongbadc7922015-12-08 17:23:20 +00005################################################################################
Pascal Brandefe56592016-03-03 10:46:52 +01006COMPILE_NS_USER ?= 64
7override COMPILE_NS_KERNEL := 64
8COMPILE_S_USER ?= 32
9COMPILE_S_KERNEL ?= 64
Victor Chong24475982015-12-02 07:18:13 +000010
Michalis Pappas41963c62019-04-23 11:43:14 +020011# Normal/secure world console UARTs: 3, 2, or 0 [default 3]
Victor Chong13cad772015-12-05 00:35:19 +090012CFG_NW_CONSOLE_UART ?= 3
13CFG_SW_CONSOLE_UART ?= 3
14
Victor Chong310ca4d2017-01-22 07:00:19 +000015# eMMC flash size: 8 or 4 GB [default 8]
16CFG_FLASH_SIZE ?= 8
17
Victor Chongbadc7922015-12-08 17:23:20 +000018################################################################################
19# Includes
20################################################################################
Victor Chong7a716512017-09-11 15:18:44 +010021include common.mk
Pascal Brandd6536da2015-09-01 10:38:43 +020022
23################################################################################
Joakim Bech427dd632015-05-04 15:52:33 +020024# Paths to git projects and various binaries
25################################################################################
Victor Chongdf54b112019-08-11 15:58:12 +010026TF_A_PATH ?= $(ROOT)/trusted-firmware-a
Victor Chong5f085e22017-09-15 07:30:21 +010027ATF_FB_PATH ?= $(ROOT)/atf-fastboot
Joakim Bech427dd632015-05-04 15:52:33 +020028ifeq ($(DEBUG),1)
Victor Chong371d7c22019-08-08 17:17:14 +010029TF_A_BUILD ?= debug
Victor Chong5f085e22017-09-15 07:30:21 +010030ATF_FB_BUILD ?= debug
Joakim Bech427dd632015-05-04 15:52:33 +020031else
Victor Chong371d7c22019-08-08 17:17:14 +010032TF_A_BUILD ?= release
Victor Chong5f085e22017-09-15 07:30:21 +010033ATF_FB_BUILD ?= release
Joakim Bech427dd632015-05-04 15:52:33 +020034endif
35
Victor Chong2e845ef2019-06-08 16:02:53 +010036EDK2_PATH ?= $(ROOT)/edk2
Joakim Bech427dd632015-05-04 15:52:33 +020037ifeq ($(DEBUG),1)
Joakim Bech427dd632015-05-04 15:52:33 +020038EDK2_BUILD ?= DEBUG
39else
Joakim Bech427dd632015-05-04 15:52:33 +020040EDK2_BUILD ?= RELEASE
41endif
Victor Chong2e845ef2019-06-08 16:02:53 +010042EDK2_BIN ?= $(EDK2_PATH)/Build/HiKey/$(EDK2_BUILD)_$(EDK2_TOOLCHAIN)/FV/BL33_AP_UEFI.fd
Victor Chongbf8160a2017-09-15 07:38:23 +010043OPENPLATPKG_PATH ?= $(ROOT)/OpenPlatformPkg
Joakim Bech427dd632015-05-04 15:52:33 +020044
Victor Chong24475982015-12-02 07:18:13 +000045OUT_PATH ?=$(ROOT)/out
Victor Chongbf8160a2017-09-15 07:38:23 +010046MCUIMAGE_BIN ?= $(OPENPLATPKG_PATH)/Platforms/Hisilicon/HiKey/Binary/mcuimage.bin
Victor Chong4ded6452017-09-15 07:21:53 +010047BOOT_IMG ?=$(ROOT)/out/boot-fat.uefi.img
48NVME_IMG ?=$(ROOT)/out/nvme.img
Victor Chong24475982015-12-02 07:18:13 +000049GRUB_PATH ?=$(ROOT)/grub
Victor Chong4ded6452017-09-15 07:21:53 +010050LLOADER_PATH ?=$(ROOT)/l-loader
Victor Chong24475982015-12-02 07:18:13 +000051PATCHES_PATH ?=$(ROOT)/patches_hikey
Joakim Bech427dd632015-05-04 15:52:33 +020052
53################################################################################
Joakim Bech427dd632015-05-04 15:52:33 +020054# Targets
55################################################################################
Victor Chong4ded6452017-09-15 07:21:53 +010056.PHONY: all
Victor Chong86840a42017-10-28 13:01:33 +010057all: prepare arm-tf boot-img lloader nvme
Joakim Bech427dd632015-05-04 15:52:33 +020058
Victor Chong4ded6452017-09-15 07:21:53 +010059.PHONY: clean
Jens Wiklander797ea982018-02-05 13:08:49 +010060clean: arm-tf-clean atf-fb-clean buildroot-clean edk2-clean linux-clean \
61 optee-os-clean boot-img-clean lloader-clean grub-clean
Joakim Bech427dd632015-05-04 15:52:33 +020062
Victor Chong4ded6452017-09-15 07:21:53 +010063.PHONY: cleaner
Jens Wiklander797ea982018-02-05 13:08:49 +010064cleaner: clean prepare-cleaner buildroot-cleaner linux-cleaner \
Igor Opaniuk584efe52017-08-07 01:41:48 +030065 nvme-cleaner grub-cleaner
Joakim Bech427dd632015-05-04 15:52:33 +020066
Victor Chong7a716512017-09-11 15:18:44 +010067include toolchain.mk
Joakim Bech427dd632015-05-04 15:52:33 +020068
Victor Chong4ded6452017-09-15 07:21:53 +010069.PHONY: prepare
Victor Chong24475982015-12-02 07:18:13 +000070prepare:
Victor Chong4ded6452017-09-15 07:21:53 +010071 mkdir -p $(OUT_PATH)
Joakim Bech427dd632015-05-04 15:52:33 +020072
Victor Chong24475982015-12-02 07:18:13 +000073.PHONY: prepare-cleaner
74prepare-cleaner:
75 rm -rf $(ROOT)/out
Joakim Bech427dd632015-05-04 15:52:33 +020076
77################################################################################
78# ARM Trusted Firmware
79################################################################################
Victor Chong371d7c22019-08-08 17:17:14 +010080TF_A_EXPORTS ?= \
Pascal Brandb130ea22015-10-13 13:18:36 +020081 CROSS_COMPILE="$(CCACHE)$(AARCH64_CROSS_COMPILE)"
82
Victor Chong371d7c22019-08-08 17:17:14 +010083TF_A_FLAGS ?= \
Victor Chong18814ff2017-09-15 08:02:29 +010084 BL32=$(OPTEE_OS_HEADER_V2_BIN) \
85 BL32_EXTRA1=$(OPTEE_OS_PAGER_V2_BIN) \
86 BL32_EXTRA2=$(OPTEE_OS_PAGEABLE_V2_BIN) \
Joakim Bech427dd632015-05-04 15:52:33 +020087 BL33=$(EDK2_BIN) \
Victor Chong18814ff2017-09-15 08:02:29 +010088 SCP_BL2=$(MCUIMAGE_BIN) \
Pascal Brandb130ea22015-10-13 13:18:36 +020089 DEBUG=$(DEBUG) \
90 PLAT=hikey \
91 SPD=opteed
Joakim Bech427dd632015-05-04 15:52:33 +020092
Victor Chong371d7c22019-08-08 17:17:14 +010093TF_A_CONSOLE_UART ?= $(CFG_SW_CONSOLE_UART)
94ifeq ($(TF_A_CONSOLE_UART),0)
95 TF_A_FLAGS += CONSOLE_BASE=PL011_UART0_BASE \
Victor Chong13cad772015-12-05 00:35:19 +090096 CRASH_CONSOLE_BASE=PL011_UART0_BASE
97endif
Victor Chong371d7c22019-08-08 17:17:14 +010098ifeq ($(TF_A_CONSOLE_UART),2)
99 TF_A_FLAGS += CONSOLE_BASE=PL011_UART2_BASE \
Michalis Pappas41963c62019-04-23 11:43:14 +0200100 CRASH_CONSOLE_BASE=PL011_UART2_BASE
101endif
Victor Chong13cad772015-12-05 00:35:19 +0900102
Victor Chong4ded6452017-09-15 07:21:53 +0100103.PHONY: arm-tf
Victor Chong24475982015-12-02 07:18:13 +0000104arm-tf: optee-os edk2
Victor Chong371d7c22019-08-08 17:17:14 +0100105 $(TF_A_EXPORTS) $(MAKE) -C $(TF_A_PATH) $(TF_A_FLAGS) all fip
Pascal Brandb130ea22015-10-13 13:18:36 +0200106
Victor Chong24475982015-12-02 07:18:13 +0000107.PHONY: arm-tf-clean
Joakim Bech427dd632015-05-04 15:52:33 +0200108arm-tf-clean:
Victor Chong371d7c22019-08-08 17:17:14 +0100109 $(TF_A_EXPORTS) $(MAKE) -C $(TF_A_PATH) $(TF_A_FLAGS) clean
Joakim Bech427dd632015-05-04 15:52:33 +0200110
111################################################################################
Joakim Bech427dd632015-05-04 15:52:33 +0200112# EDK2 / Tianocore
113################################################################################
Victor Chongbf8160a2017-09-15 07:38:23 +0100114EDK2_ARCH ?= AARCH64
115EDK2_DSC ?= OpenPlatformPkg/Platforms/Hisilicon/HiKey/HiKey.dsc
116EDK2_TOOLCHAIN ?= GCC49
Victor Chong13cad772015-12-05 00:35:19 +0900117
118EDK2_CONSOLE_UART ?= $(CFG_NW_CONSOLE_UART)
119ifeq ($(EDK2_CONSOLE_UART),0)
Victor Chongbf8160a2017-09-15 07:38:23 +0100120 EDK2_BUILDFLAGS += -DSERIAL_BASE=0xF8015000
Victor Chong13cad772015-12-05 00:35:19 +0900121endif
Michalis Pappas41963c62019-04-23 11:43:14 +0200122ifeq ($(EDK2_CONSOLE_UART),2)
123 EDK2_BUILDFLAGS += -DSERIAL_BASE=0xF7112000
124endif
Victor Chong13cad772015-12-05 00:35:19 +0900125
Pascal Brand9a0f50f2015-09-08 15:34:17 +0200126define edk2-call
Joakim Bech1bcac042018-05-23 08:36:25 +0200127 $(EDK2_TOOLCHAIN)_$(EDK2_ARCH)_PREFIX=$(AARCH64_CROSS_COMPILE) \
Victor Chongbf8160a2017-09-15 07:38:23 +0100128 build -n `getconf _NPROCESSORS_ONLN` -a $(EDK2_ARCH) \
129 -t $(EDK2_TOOLCHAIN) -p $(EDK2_DSC) \
130 -b $(EDK2_BUILD) $(EDK2_BUILDFLAGS)
Joakim Bech427dd632015-05-04 15:52:33 +0200131endef
132
Victor Chongbf8160a2017-09-15 07:38:23 +0100133.PHONY: edk2
134edk2:
135 cd $(EDK2_PATH) && rm -rf OpenPlatformPkg && \
136 ln -s $(OPENPLATPKG_PATH)
137 set -e && cd $(EDK2_PATH) && source edksetup.sh && \
Jerome Forissier1dde8bd2020-01-07 18:10:03 +0100138 $(MAKE) -j1 -C $(EDK2_PATH)/BaseTools \
139 BUILD_CC="gcc $(call cc-option,gcc,-Wno-error=stringop-truncation,)" && \
Victor Chongbf8160a2017-09-15 07:38:23 +0100140 $(call edk2-call)
Joakim Bech427dd632015-05-04 15:52:33 +0200141
Joakim Bech7f43b922015-10-01 07:24:00 -0700142.PHONY: edk2-clean
Victor Chongbf8160a2017-09-15 07:38:23 +0100143edk2-clean:
144 set -e && cd $(EDK2_PATH) && source edksetup.sh && \
145 $(call edk2-call) cleanall && \
146 $(MAKE) -j1 -C $(EDK2_PATH)/BaseTools clean
147 rm -rf $(EDK2_PATH)/Build
148 rm -rf $(EDK2_PATH)/Conf/.cache
149 rm -f $(EDK2_PATH)/Conf/build_rule.txt
150 rm -f $(EDK2_PATH)/Conf/target.txt
151 rm -f $(EDK2_PATH)/Conf/tools_def.txt
Joakim Bech427dd632015-05-04 15:52:33 +0200152
153################################################################################
154# Linux kernel
155################################################################################
Jerome Forissiere1002382015-11-26 11:36:00 +0100156LINUX_DEFCONFIG_COMMON_ARCH ?= arm64
157LINUX_DEFCONFIG_COMMON_FILES ?= $(LINUX_PATH)/arch/arm64/configs/defconfig \
Victor Chong24475982015-12-02 07:18:13 +0000158 $(CURDIR)/kconfigs/hikey.conf \
159 $(PATCHES_PATH)/kernel_config/usb_net_dm9601.conf \
160 $(PATCHES_PATH)/kernel_config/ftrace.conf
Joakim Bech427dd632015-05-04 15:52:33 +0200161
Victor Chong4ded6452017-09-15 07:21:53 +0100162.PHONY: linux-defconfig
Joakim Bech427dd632015-05-04 15:52:33 +0200163linux-defconfig: $(LINUX_PATH)/.config
164
Victor Chong4ded6452017-09-15 07:21:53 +0100165.PHONY: linux-gen_init_cpio
Joakim Bech427dd632015-05-04 15:52:33 +0200166linux-gen_init_cpio: linux-defconfig
Victor Chong24475982015-12-02 07:18:13 +0000167 $(MAKE) -C $(LINUX_PATH)/usr \
Pascal Brande3d85982015-09-10 17:20:42 +0200168 CROSS_COMPILE=$(CROSS_COMPILE_NS_KERNEL) \
Joakim Bech427dd632015-05-04 15:52:33 +0200169 ARCH=arm64 \
170 LOCALVERSION= \
171 gen_init_cpio
172
Victor Chong4ded6452017-09-15 07:21:53 +0100173LINUX_COMMON_FLAGS += ARCH=arm64 Image modules hisilicon/hi6220-hikey.dtb
Joakim Bech427dd632015-05-04 15:52:33 +0200174
Victor Chong4ded6452017-09-15 07:21:53 +0100175.PHONY: linux
Pascal Brande3d85982015-09-10 17:20:42 +0200176linux: linux-common
177
Joakim Bech7f43b922015-10-01 07:24:00 -0700178.PHONY: linux-defconfig-clean
Pascal Brande3d85982015-09-10 17:20:42 +0200179linux-defconfig-clean: linux-defconfig-clean-common
Joakim Bech427dd632015-05-04 15:52:33 +0200180
Pascal Brande3d85982015-09-10 17:20:42 +0200181LINUX_CLEAN_COMMON_FLAGS += ARCH=arm64
Joakim Bech427dd632015-05-04 15:52:33 +0200182
Joakim Bech7f43b922015-10-01 07:24:00 -0700183.PHONY: linux-clean
Pascal Brande3d85982015-09-10 17:20:42 +0200184linux-clean: linux-clean-common
185
186LINUX_CLEANER_COMMON_FLAGS += ARCH=arm64
187
Joakim Bech7f43b922015-10-01 07:24:00 -0700188.PHONY: linux-cleaner
Pascal Brande3d85982015-09-10 17:20:42 +0200189linux-cleaner: linux-cleaner-common
Joakim Bech427dd632015-05-04 15:52:33 +0200190
191################################################################################
192# OP-TEE
193################################################################################
Victor Chong4ded6452017-09-15 07:21:53 +0100194OPTEE_OS_COMMON_FLAGS += PLATFORM=hikey \
195 CFG_CONSOLE_UART=$(CFG_SW_CONSOLE_UART)
Victor Chong13cad772015-12-05 00:35:19 +0900196OPTEE_OS_CLEAN_COMMON_FLAGS += PLATFORM=hikey
197
Victor Chong4ded6452017-09-15 07:21:53 +0100198.PHONY: optee-os
Jerome Forissierae45fbf2015-09-04 09:40:17 +0200199optee-os: optee-os-common
Joakim Bech427dd632015-05-04 15:52:33 +0200200
Joakim Bech7f43b922015-10-01 07:24:00 -0700201.PHONY: optee-os-clean
Jerome Forissierae45fbf2015-09-04 09:40:17 +0200202optee-os-clean: optee-os-clean-common
Joakim Bech427dd632015-05-04 15:52:33 +0200203
Victor Chong24475982015-12-02 07:18:13 +0000204################################################################################
205# grub
206################################################################################
207grub-flags := CC="$(CCACHE)gcc" \
208 TARGET_CC="$(AARCH64_CROSS_COMPILE)gcc" \
209 TARGET_OBJCOPY="$(AARCH64_CROSS_COMPILE)objcopy" \
210 TARGET_NM="$(AARCH64_CROSS_COMPILE)nm" \
211 TARGET_RANLIB="$(AARCH64_CROSS_COMPILE)ranlib" \
Jens Wiklander3b5d8f02018-06-27 09:16:24 +0200212 TARGET_STRIP="$(AARCH64_CROSS_COMPILE)strip" \
213 --disable-werror
Victor Chong24475982015-12-02 07:18:13 +0000214
Victor Chongc97d49a2017-09-15 08:06:41 +0100215GRUB_MODULES += boot chain configfile efinet ext2 fat gettext \
216 help linux loadenv lsefi normal part_gpt \
217 part_msdos read search search_fs_file search_fs_uuid \
218 search_label terminal terminfo tftp time
219
220$(GRUB_PATH)/configure: $(GRUB_PATH)/configure.ac
221 cd $(GRUB_PATH) && ./autogen.sh
222
223$(GRUB_PATH)/Makefile: $(GRUB_PATH)/configure
224 cd $(GRUB_PATH) && ./configure --target=aarch64 --enable-boot-time $(grub-flags)
225
Victor Chong24475982015-12-02 07:18:13 +0000226.PHONY: grub
Victor Chongc97d49a2017-09-15 08:06:41 +0100227grub: prepare $(GRUB_PATH)/Makefile
Victor Chong24475982015-12-02 07:18:13 +0000228 $(MAKE) -C $(GRUB_PATH); \
Victor Chongc97d49a2017-09-15 08:06:41 +0100229 cd $(GRUB_PATH) && ./grub-mkimage \
Victor Chong24475982015-12-02 07:18:13 +0000230 --verbose \
231 --output=$(OUT_PATH)/grubaa64.efi \
232 --config=$(PATCHES_PATH)/grub/grub.configfile \
233 --format=arm64-efi \
234 --directory=grub-core \
235 --prefix=/boot/grub \
Victor Chongc97d49a2017-09-15 08:06:41 +0100236 $(GRUB_MODULES)
Victor Chong24475982015-12-02 07:18:13 +0000237
238.PHONY: grub-clean
239grub-clean:
Victor Chong4ded6452017-09-15 07:21:53 +0100240 if [ -e $(GRUB_PATH)/Makefile ]; then $(MAKE) -C $(GRUB_PATH) clean; fi
Victor Chong24475982015-12-02 07:18:13 +0000241 rm -f $(OUT_PATH)/grubaa64.efi
242
243.PHONY: grub-cleaner
244grub-cleaner: grub-clean
Victor Chong4ded6452017-09-15 07:21:53 +0100245 if [ -e $(GRUB_PATH)/Makefile ]; then $(MAKE) -C $(GRUB_PATH) distclean; fi
Victor Chong24475982015-12-02 07:18:13 +0000246 rm -f $(GRUB_PATH)/configure
Joakim Bech427dd632015-05-04 15:52:33 +0200247
248################################################################################
249# Boot Image
250################################################################################
Victor Chong4ded6452017-09-15 07:21:53 +0100251ifeq ($(CFG_NW_CONSOLE_UART),3)
Victor Chong13cad772015-12-05 00:35:19 +0900252GRUBCFG = $(PATCHES_PATH)/grub/grub_uart3.cfg
Michalis Pappas41963c62019-04-23 11:43:14 +0200253else ifeq ($(CFG_NW_CONSOLE_UART),2)
254GRUBCFG = $(PATCHES_PATH)/grub/grub_uart2.cfg
Victor Chong13cad772015-12-05 00:35:19 +0900255else
256GRUBCFG = $(PATCHES_PATH)/grub/grub_uart0.cfg
257endif
258
Victor Chong4ded6452017-09-15 07:21:53 +0100259.PHONY: boot-img
Jens Wiklander797ea982018-02-05 13:08:49 +0100260boot-img: linux buildroot edk2 grub
David Brownce9024e2016-06-16 13:15:49 -0600261 rm -f $(BOOT_IMG)
262 mformat -i $(BOOT_IMG) -n 64 -h 255 -T 131072 -v "BOOT IMG" -C ::
Victor Chong4ded6452017-09-15 07:21:53 +0100263 mcopy -i $(BOOT_IMG) $(LINUX_PATH)/arch/arm64/boot/Image ::
264 mcopy -i $(BOOT_IMG) $(LINUX_PATH)/arch/arm64/boot/dts/hisilicon/hi6220-hikey.dtb ::
David Brownce9024e2016-06-16 13:15:49 -0600265 mmd -i $(BOOT_IMG) ::/EFI
266 mmd -i $(BOOT_IMG) ::/EFI/BOOT
267 mcopy -i $(BOOT_IMG) $(OUT_PATH)/grubaa64.efi ::/EFI/BOOT/
268 mcopy -i $(BOOT_IMG) $(GRUBCFG) ::/EFI/BOOT/grub.cfg
Jens Wiklander797ea982018-02-05 13:08:49 +0100269 mcopy -i $(BOOT_IMG) $(ROOT)/out-br/images/rootfs.cpio.gz ::/initrd.img
Victor Chongbf8160a2017-09-15 07:38:23 +0100270 mcopy -i $(BOOT_IMG) $(EDK2_PATH)/Build/HiKey/$(EDK2_BUILD)_$(EDK2_TOOLCHAIN)/$(EDK2_ARCH)/AndroidFastbootApp.efi ::/EFI/BOOT/fastboot.efi
Joakim Bech427dd632015-05-04 15:52:33 +0200271
Joakim Bech7f43b922015-10-01 07:24:00 -0700272.PHONY: boot-img-clean
Joakim Bech427dd632015-05-04 15:52:33 +0200273boot-img-clean:
274 rm -f $(BOOT_IMG)
275
276################################################################################
Victor Chong5f085e22017-09-15 07:30:21 +0100277# atf-fastboot
278################################################################################
279ATF_FB_EXPORTS ?= \
280 CROSS_COMPILE="$(CCACHE)$(AARCH64_CROSS_COMPILE)"
281
282ATF_FB_FLAGS ?= \
283 DEBUG=$(DEBUG) \
284 PLAT=hikey
285
286.PHONY: atf-fb
287atf-fb:
288 $(ATF_FB_EXPORTS) $(MAKE) -C $(ATF_FB_PATH) $(ATF_FB_FLAGS)
289
290.PHONY: atf-fb-clean
291atf-fb-clean:
292 $(ATF_FB_EXPORTS) $(MAKE) -C $(ATF_FB_PATH) $(ATF_FB_FLAGS) clean
293
294################################################################################
Joakim Bech427dd632015-05-04 15:52:33 +0200295# l-loader
296################################################################################
Victor Chong9860c922017-09-29 18:25:37 +0100297.PHONY: lloader
Jens Wiklanderd3c32a02017-10-09 13:01:46 +0200298lloader: arm-tf atf-fb
Victor Chong861a8462017-09-15 08:17:24 +0100299 cd $(LLOADER_PATH) && \
Victor Chong371d7c22019-08-08 17:17:14 +0100300 ln -sf $(TF_A_PATH)/build/hikey/$(TF_A_BUILD)/bl1.bin && \
301 ln -sf $(TF_A_PATH)/build/hikey/$(TF_A_BUILD)/bl2.bin && \
Victor Chong861a8462017-09-15 08:17:24 +0100302 ln -sf $(ATF_FB_PATH)/build/hikey/$(ATF_FB_BUILD)/bl1.bin fastboot.bin && \
Victor Chong1a163012019-06-08 16:22:35 +0100303 $(MAKE) hikey PTABLE_LST="linux-8g linux-4g" CROSS_COMPILE="$(CCACHE)$(AARCH32_CROSS_COMPILE)"
Joakim Bech427dd632015-05-04 15:52:33 +0200304
Joakim Bech7f43b922015-10-01 07:24:00 -0700305.PHONY: lloader-clean
Victor Chong9860c922017-09-29 18:25:37 +0100306lloader-clean:
307 $(MAKE) -C $(LLOADER_PATH) hikey-clean
Joakim Bech7f43b922015-10-01 07:24:00 -0700308
309################################################################################
310# nvme image
Victor Chongba98b302017-09-12 18:16:17 +0100311#
312# nvme partition is used to store UEFI non-volatile variables,
313# but nvme image is currently an empty list
Joakim Bech7f43b922015-10-01 07:24:00 -0700314################################################################################
315.PHONY: nvme
Victor Chong24475982015-12-02 07:18:13 +0000316nvme: prepare
Victor Chongba98b302017-09-12 18:16:17 +0100317ifeq ("$(wildcard $(NVME_IMG))","")
318 dd if=/dev/zero of=$(NVME_IMG) bs=1K count=128
319endif
Joakim Bech7f43b922015-10-01 07:24:00 -0700320
321.PHONY: nvme-cleaner
322nvme-cleaner:
323 rm -f $(NVME_IMG)
324
325################################################################################
326# Flash
327################################################################################
Joakim Bech4eaf9b22016-01-18 13:31:45 +0100328define flash_help
Victor Chong4ded6452017-09-15 07:21:53 +0100329 @read -r -p "1. Connect USB OTG cable, the micro USB cable (press enter)" dummy
330 @read -r -p "2. Connect HiKey to power up (press enter)" dummy
Joakim Bech4eaf9b22016-01-18 13:31:45 +0100331endef
332
333.PHONY: recovery
334recovery:
335 @echo "Enter recovery mode to flash a new bootloader"
Jerome Forissiereebcdbe2016-06-22 14:46:30 +0200336 @echo
337 @echo "Make sure udev permissions are set appropriately:"
338 @echo " # /etc/udev/rules.d/hikey.rules"
339 @echo ' SUBSYSTEM=="usb", ATTRS{idVendor}=="18d1", ATTRS{idProduct}=="d00d", MODE="0666"'
340 @echo ' SUBSYSTEM=="usb", ATTRS{idVendor}=="12d1", MODE="0666", ENV{ID_MM_DEVICE_IGNORE}="1"'
341 @echo
Victor Chong4ded6452017-09-15 07:21:53 +0100342 @echo "Set jumpers as follows:"
Joakim Bech4eaf9b22016-01-18 13:31:45 +0100343 @echo "Jumper 1-2: Closed (Auto power up = Boot up when power is applied)"
344 @echo " 3-4: Closed (Boot Select = Recovery: program eMMC from USB OTG)"
Victor Chong4ded6452017-09-15 07:21:53 +0100345 @echo " 5-6: Open (GPIO3-1 = High: UEFI runs normally)"
346 @read -r -p "Press enter to continue" dummy
347 @echo
Joakim Bech4eaf9b22016-01-18 13:31:45 +0100348 $(call flash_help)
Victor Chong4ded6452017-09-15 07:21:53 +0100349 @echo
Victor Chongf9f39122018-03-09 06:54:53 +0000350 python $(ROOT)/burn-boot/hisi-idt.py --img1=$(LLOADER_PATH)/recovery.bin
351 fastboot flash loader $(LLOADER_PATH)/l-loader.bin
Victor Chong4ded6452017-09-15 07:21:53 +0100352 @echo
353 @echo "3. Wait until you see the (UART) message"
Victor Chongf9f39122018-03-09 06:54:53 +0000354 @echo " \"Enter fastboot mode...\""
Joakim Bech4eaf9b22016-01-18 13:31:45 +0100355 @$(MAKE) --no-print flash FROM_RECOVERY=1
356
Joakim Bech7f43b922015-10-01 07:24:00 -0700357.PHONY: flash
358flash:
Joakim Bech4eaf9b22016-01-18 13:31:45 +0100359ifneq ($(FROM_RECOVERY),1)
360 @echo "Flash binaries using fastboot"
Victor Chong4ded6452017-09-15 07:21:53 +0100361 @echo
362 @echo "Set jumpers as follows:"
Joakim Bech4eaf9b22016-01-18 13:31:45 +0100363 @echo "Jumper 1-2: Closed (Auto power up = Boot up when power is applied)"
Victor Chong4ded6452017-09-15 07:21:53 +0100364 @echo " 3-4: Open (Boot Select = Boot from eMMC)"
Joakim Bech4eaf9b22016-01-18 13:31:45 +0100365 @echo " 5-6: Closed (GPIO3-1 = Low: UEFI runs Fastboot app)"
Victor Chong4ded6452017-09-15 07:21:53 +0100366 @read -r -p "Press enter to continue" dummy
367 @echo
Joakim Bech4eaf9b22016-01-18 13:31:45 +0100368 $(call flash_help)
369 @echo "3. Wait until you see the (UART) message"
370 @echo " \"Android Fastboot mode - version x.x Press any key to quit.\""
Joakim Bech4eaf9b22016-01-18 13:31:45 +0100371endif
Victor Chong4ded6452017-09-15 07:21:53 +0100372 @read -r -p "Then press enter to continue flashing" dummy
373 @echo
Victor Chong1a163012019-06-08 16:22:35 +0100374 fastboot flash ptable $(LLOADER_PATH)/ptable-linux-$(CFG_FLASH_SIZE)g.img
Victor Chong371d7c22019-08-08 17:17:14 +0100375 fastboot flash fastboot $(TF_A_PATH)/build/hikey/$(TF_A_BUILD)/fip.bin
Joakim Bech7f43b922015-10-01 07:24:00 -0700376 fastboot flash nvme $(NVME_IMG)
377 fastboot flash boot $(BOOT_IMG)