blob: 3ee7f346d465d87b6e14646a072aeb662edd387f [file] [log] [blame]
Jerome Forissier3521ef32022-11-03 17:32:47 +01001COMPILE_NS_USER ?= 64
2override COMPILE_NS_KERNEL := 64
3COMPILE_S_USER ?= 64
4COMPILE_S_KERNEL ?= 64
5
6include common.mk
7
8DEBUG ?= 1
9
10# Do not leave a partially downloaded binary in case wget fails midway
11.DELETE_ON_ERROR:
12
13################################################################################
14# Paths to git projects and various binaries
15################################################################################
16TF_A_PATH ?= $(ROOT)/trusted-firmware-a
17BINARIES_PATH ?= $(ROOT)/out
18UBOOT_PATH ?= $(ROOT)/u-boot
19UBOOT_BIN ?= $(UBOOT_PATH)/u-boot.bin
20ROOT_IMG ?= $(ROOT)/out-br/images/rootfs.ext2
21BOOT_IMG ?= $(ROOT)/out/rockpi4.img
22RKDEVELOPTOOL_PATH ?= $(ROOT)/rkdeveloptool
23RKDEVELOPTOOL_BIN ?= $(RKDEVELOPTOOL_PATH)/rkdeveloptool
24LOADER_BIN ?= $(BINARIES_PATH)/rk3399_loader_v1.20.119.bin
25
Jerome Forissier366accb2022-11-30 10:19:31 +000026LINUX_MODULES ?= n
27
28BR2_TARGET_ROOTFS_CPIO = n
29BR2_TARGET_ROOTFS_CPIO_GZIP = n
30BR2_TARGET_ROOTFS_EXT2 = y
31BR2_TARGET_GENERIC_GETTY_PORT = ttyS2
32ifeq ($(LINUX_MODULES),y)
33# If modules are installed...
34# ...enable automatic device detection and driver loading
35BR2_ROOTFS_DEVICE_CREATION_DYNAMIC_EUDEV = y
36# ...and configure eth0 automatically based on ifup helpers
37BR2_PACKAGE_IFUPDOWN_SCRIPTS = y
38BR2_SYSTEM_DHCP = eth0
39# An image with module takes more space
Jerome Forissier8f32e102023-02-14 08:46:36 +010040BR2_TARGET_ROOTFS_EXT2_SIZE = 384M
Jerome Forissierdddfd732023-01-05 16:23:57 +010041# Enable SSH daemon for remote login
42BR2_PACKAGE_OPENSSH = y
43BR2_PACKAGE_OPENSSH_SERVER = y
44BR2_ROOTFS_POST_BUILD_SCRIPT = $(ROOT)/build/br-ext/board/rockpi4/post-build.sh
Jerome Forissier366accb2022-11-30 10:19:31 +000045else
46BR2_TARGET_ROOTFS_EXT2_SIZE = 112M
47endif
Jerome Forissier3521ef32022-11-03 17:32:47 +010048
49################################################################################
50# Targets
51################################################################################
52
53all: boot-img
54
55clean: buildroot-clean
56
57include toolchain.mk
58
59################################################################################
60# Arm Trusted Firmware-A
61################################################################################
62TF_A_EXPORTS ?= CROSS_COMPILE="$(CCACHE)$(AARCH64_CROSS_COMPILE)" \
63 M0_CROSS_COMPILE="$(CCACHE)$(AARCH32_CROSS_COMPILE)"
64
65TF_A_DEBUG ?= $(DEBUG)
66ifeq ($(TF_A_DEBUG),0)
67TF_A_LOGLVL ?= 30
68TF_A_OUT = $(TF_A_PATH)/build/rk3399/release
69else
70TF_A_LOGLVL ?= 40
71TF_A_OUT = $(TF_A_PATH)/build/rk3399/debug
72endif
73
74TF_A_FLAGS ?= ARCH=aarch64 PLAT=rk3399 SPD=opteed DEBUG=$(TF_A_DEBUG) \
75 LOG_LEVEL=$(TF_A_LOGLVL)
76
77.PHONY: tfa
78tfa:
79 $(TF_A_EXPORTS) $(MAKE) -C $(TF_A_PATH) $(TF_A_FLAGS) bl31
80
81.PHONY: tfa-clean
82tfa-clean:
83 $(TF_A_EXPORTS) $(MAKE) -C $(TF_A_PATH) $(TF_A_FLAGS) clean
84
85clean: tfa-clean
86
87################################################################################
88# U-Boot
89################################################################################
90UBOOT_DEFCONFIG_FILES := $(UBOOT_PATH)/configs/rock-pi-4-rk3399_defconfig \
91 $(ROOT)/build/kconfigs/u-boot_rockpi4.conf
92
93UBOOT_FLAGS ?= CROSS_COMPILE=$(CROSS_COMPILE_NS_KERNEL) \
94 CC=$(CROSS_COMPILE_NS_KERNEL)gcc \
95 HOSTCC="$(CCACHE) gcc"
96
97UBOOT_EXPORTS ?= BL31=$(TF_A_OUT)/bl31/bl31.elf TEE=$(OPTEE_OS_BIN)
98
99u-boot-defconfig: $(UBOOT_PATH)/.config
100
101$(UBOOT_PATH)/.config: $(UBOOT_DEFCONFIG_FILES)
102 cd $(UBOOT_PATH) && \
103 scripts/kconfig/merge_config.sh $(UBOOT_DEFCONFIG_FILES)
104
105.PHONY: u-boot-defconfig
106
107.PHONY: u-boot
108u-boot: $(UBOOT_PATH)/.config optee-os tfa
109 $(UBOOT_EXPORTS) $(MAKE) -C $(UBOOT_PATH) $(UBOOT_FLAGS)
110
111.PHONY: u-boot-clean
112u-boot-clean:
113 $(UBOOT_EXPORTS) $(MAKE) -C $(UBOOT_PATH) $(UBOOT_FLAGS) distclean
114
115clean: u-boot-clean
116
117################################################################################
118# Linux kernel
119################################################################################
120LINUX_DEFCONFIG_COMMON_ARCH ?= arm64
121LINUX_DEFCONFIG_COMMON_FILES ?= $(LINUX_PATH)/arch/arm64/configs/defconfig \
122 $(CURDIR)/kconfigs/rockpi4.conf
123
124.PHONY: linux-defconfig
125linux-defconfig: $(LINUX_PATH)/.config
126
Jerome Forissier366accb2022-11-30 10:19:31 +0000127LINUX_COMMON_FLAGS += ARCH=arm64 Image rockchip/rk3399-rock-pi-4b.dtb \
128 $(if $(filter y,$(LINUX_MODULES)),modules)
Jerome Forissier3521ef32022-11-03 17:32:47 +0100129
130.PHONY: linux
131linux: linux-common
Jerome Forissier366accb2022-11-30 10:19:31 +0000132ifeq ($(LINUX_MODULES),y)
133 $(MAKE) -C $(LINUX_PATH) ARCH=arm64 modules_install \
134 INSTALL_MOD_PATH=$(BINARIES_PATH)/modules
135endif
Jerome Forissier3521ef32022-11-03 17:32:47 +0100136
137$(LINUX_PATH)/arch/arm64/boot/Image.gz: linux
138 gzip -c $(LINUX_PATH)/arch/arm64/boot/Image >$@
139
140.PHONY: linux-defconfig-clean
141linux-defconfig-clean: linux-defconfig-clean-common
142
143LINUX_CLEAN_COMMON_FLAGS += ARCH=arm64
144
145.PHONY: linux-clean
146linux-clean: linux-clean-common
147
148LINUX_CLEANER_COMMON_FLAGS += ARCH=arm64
149
150.PHONY: linux-cleaner
151linux-cleaner: linux-cleaner-common
152
153################################################################################
154# OP-TEE
155################################################################################
156OPTEE_OS_PLATFORM = rockchip-rk3399
157OPTEE_OS_COMMON_FLAGS += CFG_ENABLE_EMBEDDED_TESTS=y
158
159.PHONY: optee-os
160optee-os: optee-os-common
161
162.PHONY: optee-os-clean
163optee-os-clean: optee-os-clean-common
164
165clean: optee-os-clean
166
167################################################################################
168# Boot image, shall be copied to SD card
169################################################################################
Jerome Forissier1baec992022-11-29 17:34:53 +0100170
Jerome Forissier3521ef32022-11-03 17:32:47 +0100171# U-Boot offset comes from CONFIG_SYS_MMCSD_RAW_MODE_U_BOOT_SECTOR=0x4000
172# Partition no. 5 ends at 12288 + BR2_TARGET_ROOTFS_EXT2_SIZE (in kiB)
Jerome Forissier1baec992022-11-29 17:34:53 +0100173# File size needs to be slightly bigger to accomodate for whatever meta-data
174rootfs-size-kib := $(shell echo $(BR2_TARGET_ROOTFS_EXT2_SIZE) | sed 's/M/*1024/')
175p5-end-kib := $(shell echo $$((12288 + $(rootfs-size-kib))))
176img-size-kib := $(shell echo $$(($(p5-end-kib) + 1024)))
177
Jerome Forissier3521ef32022-11-03 17:32:47 +0100178.PHONY: boot-img
179boot-img: u-boot buildroot $(LINUX_PATH)/arch/arm64/boot/Image.gz
180 mkdir -p $(BINARIES_PATH)
181 rm -f $(BOOT_IMG)
Jerome Forissier1baec992022-11-29 17:34:53 +0100182 truncate -s $(img-size-kib)KiB $(BOOT_IMG)
Jerome Forissier3521ef32022-11-03 17:32:47 +0100183 parted -s $(BOOT_IMG) \
184 unit kiB \
185 mklabel gpt \
186 mkpart idbloader 32 4032 \
187 mkpart primary fat32 4032 4096 \
188 mkpart primary fat32 4096 8192 \
189 mkpart uboot 8192 12288 \
Jerome Forissier1baec992022-11-29 17:34:53 +0100190 mkpart root fat32 12288 $(p5-end-kib)
Jerome Forissier3521ef32022-11-03 17:32:47 +0100191 sgdisk -u 5:17d61bff-8fdc-4089-b675-9be21b9f6ac7 $(BOOT_IMG)
192 dd if=$(UBOOT_PATH)/idbloader.img of=$(BOOT_IMG) bs=1kiB seek=32 conv=notrunc
193 dd if=$(UBOOT_PATH)/u-boot.itb of=$(BOOT_IMG) bs=1kiB seek=8192 conv=notrunc
194 e2mkdir $(ROOT_IMG):/boot
195 e2cp $(LINUX_PATH)/arch/arm64/boot/Image.gz $(ROOT_IMG):/boot
196 e2cp $(LINUX_PATH)/arch/arm64/boot/dts/rockchip/rk3399-rock-pi-4b.dtb $(ROOT_IMG):/boot
Jerome Forissier366accb2022-11-30 10:19:31 +0000197ifeq ($(LINUX_MODULES),y)
198 find $(BINARIES_PATH)/modules -type f | while read f; do e2cp -a $$f $(ROOT_IMG):$$(echo $$f | sed s@$(BINARIES_PATH)/modules@@); done
199endif
Jerome Forissier3521ef32022-11-03 17:32:47 +0100200 dd if=$(ROOT_IMG) of=$(BOOT_IMG) bs=1kiB seek=12288 conv=notrunc
201
202.PHONY: boot-img-clean
203boot-img-clean:
204 rm -f $(BOOT_IMG)
205
206clean: boot-img-clean
207
208################################################################################
209# rkdeveloptool
210################################################################################
211
212$(RKDEVELOPTOOL_PATH)/Makefile:
213 cd $(RKDEVELOPTOOL_PATH) && \
214 autoreconf -i && \
215 ./configure CXXFLAGS=-Wno-format-truncation
216
217$(RKDEVELOPTOOL_BIN): $(RKDEVELOPTOOL_PATH)/Makefile
218 $(MAKE) -C $(RKDEVELOPTOOL_PATH)
219
220rkdeveloptool: $(RKDEVELOPTOOL_BIN)
221
222rkdeveloptool-clean:
223 $(MAKE) -C $(RKDEVELOPTOOL_PATH) clean
224
225rkdeveloptool-distclean:
226 $(MAKE) -C $(RKDEVELOPTOOL_PATH) clean
227
228clean: rkdeveloptool-clean
229
230$(LOADER_BIN):
231 cd $(BINARIES_PATH) && \
232 wget https://dl.radxa.com/rockpi/images/loader/$(notdir $(LOADER_BIN))
233
234################################################################################
235# Flash the image via USB onto the onboard eMMC
236################################################################################
237
238define flash-help
239 @echo
240 @echo "Please connect the board to the computer via a USB cable."
241 @echo "The cable must be connected to the upper USB 3 (blue) port."
242 @echo "Then press and hold the mask ROM button (first one on the left"
243 @echo "under the HDMI connector), apply power and release the button."
244 @echo "(More details at https://wiki.radxa.com/Rockpi4/dev/usb-install)"
245 @echo
246 @read -r -p "Press enter to continue, Ctrl-C to cancel:" dummy
247endef
248
249flash: $(BOOT_IMG) $(LOADER_BIN) $(RKDEVELOPTOOL_BIN)
250 $(call flash-help)
251 $(RKDEVELOPTOOL_BIN) db $(LOADER_BIN)
252 sleep 1
253 $(RKDEVELOPTOOL_BIN) wl 0 $(BOOT_IMG)
254
255nuke-emmc: $(LOADER_BIN) $(RKDEVELOPTOOL_BIN)
256 @echo
257 @echo "** WARNING: this command will make the onboard eMMC unbootable!"
258 @echo "It can be used to boot from the SD card again."
259 $(call flash-help)
260 dd if=/dev/zero of=$(BINARIES_PATH)/zero.img bs=1M count=64
261 $(RKDEVELOPTOOL_BIN) db $(LOADER_BIN)
262 sleep 1
263 $(RKDEVELOPTOOL_BIN) wl 0 $(BINARIES_PATH)/zero.img