Jerome Forissier | 3521ef3 | 2022-11-03 17:32:47 +0100 | [diff] [blame] | 1 | COMPILE_NS_USER ?= 64 |
| 2 | override COMPILE_NS_KERNEL := 64 |
| 3 | COMPILE_S_USER ?= 64 |
| 4 | COMPILE_S_KERNEL ?= 64 |
| 5 | |
| 6 | include common.mk |
| 7 | |
| 8 | DEBUG ?= 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 | ################################################################################ |
| 16 | TF_A_PATH ?= $(ROOT)/trusted-firmware-a |
| 17 | BINARIES_PATH ?= $(ROOT)/out |
| 18 | UBOOT_PATH ?= $(ROOT)/u-boot |
| 19 | UBOOT_BIN ?= $(UBOOT_PATH)/u-boot.bin |
| 20 | ROOT_IMG ?= $(ROOT)/out-br/images/rootfs.ext2 |
| 21 | BOOT_IMG ?= $(ROOT)/out/rockpi4.img |
| 22 | RKDEVELOPTOOL_PATH ?= $(ROOT)/rkdeveloptool |
| 23 | RKDEVELOPTOOL_BIN ?= $(RKDEVELOPTOOL_PATH)/rkdeveloptool |
| 24 | LOADER_BIN ?= $(BINARIES_PATH)/rk3399_loader_v1.20.119.bin |
| 25 | |
| 26 | BR2_TARGET_ROOTFS_CPIO=n |
| 27 | BR2_TARGET_ROOTFS_CPIO_GZIP=n |
| 28 | BR2_TARGET_ROOTFS_EXT2=y |
| 29 | BR2_TARGET_ROOTFS_EXT2_SIZE=112M |
| 30 | BR2_TARGET_GENERIC_GETTY_PORT=ttyS2 |
| 31 | |
| 32 | ################################################################################ |
| 33 | # Targets |
| 34 | ################################################################################ |
| 35 | |
| 36 | all: boot-img |
| 37 | |
| 38 | clean: buildroot-clean |
| 39 | |
| 40 | include toolchain.mk |
| 41 | |
| 42 | ################################################################################ |
| 43 | # Arm Trusted Firmware-A |
| 44 | ################################################################################ |
| 45 | TF_A_EXPORTS ?= CROSS_COMPILE="$(CCACHE)$(AARCH64_CROSS_COMPILE)" \ |
| 46 | M0_CROSS_COMPILE="$(CCACHE)$(AARCH32_CROSS_COMPILE)" |
| 47 | |
| 48 | TF_A_DEBUG ?= $(DEBUG) |
| 49 | ifeq ($(TF_A_DEBUG),0) |
| 50 | TF_A_LOGLVL ?= 30 |
| 51 | TF_A_OUT = $(TF_A_PATH)/build/rk3399/release |
| 52 | else |
| 53 | TF_A_LOGLVL ?= 40 |
| 54 | TF_A_OUT = $(TF_A_PATH)/build/rk3399/debug |
| 55 | endif |
| 56 | |
| 57 | TF_A_FLAGS ?= ARCH=aarch64 PLAT=rk3399 SPD=opteed DEBUG=$(TF_A_DEBUG) \ |
| 58 | LOG_LEVEL=$(TF_A_LOGLVL) |
| 59 | |
| 60 | .PHONY: tfa |
| 61 | tfa: |
| 62 | $(TF_A_EXPORTS) $(MAKE) -C $(TF_A_PATH) $(TF_A_FLAGS) bl31 |
| 63 | |
| 64 | .PHONY: tfa-clean |
| 65 | tfa-clean: |
| 66 | $(TF_A_EXPORTS) $(MAKE) -C $(TF_A_PATH) $(TF_A_FLAGS) clean |
| 67 | |
| 68 | clean: tfa-clean |
| 69 | |
| 70 | ################################################################################ |
| 71 | # U-Boot |
| 72 | ################################################################################ |
| 73 | UBOOT_DEFCONFIG_FILES := $(UBOOT_PATH)/configs/rock-pi-4-rk3399_defconfig \ |
| 74 | $(ROOT)/build/kconfigs/u-boot_rockpi4.conf |
| 75 | |
| 76 | UBOOT_FLAGS ?= CROSS_COMPILE=$(CROSS_COMPILE_NS_KERNEL) \ |
| 77 | CC=$(CROSS_COMPILE_NS_KERNEL)gcc \ |
| 78 | HOSTCC="$(CCACHE) gcc" |
| 79 | |
| 80 | UBOOT_EXPORTS ?= BL31=$(TF_A_OUT)/bl31/bl31.elf TEE=$(OPTEE_OS_BIN) |
| 81 | |
| 82 | u-boot-defconfig: $(UBOOT_PATH)/.config |
| 83 | |
| 84 | $(UBOOT_PATH)/.config: $(UBOOT_DEFCONFIG_FILES) |
| 85 | cd $(UBOOT_PATH) && \ |
| 86 | scripts/kconfig/merge_config.sh $(UBOOT_DEFCONFIG_FILES) |
| 87 | |
| 88 | .PHONY: u-boot-defconfig |
| 89 | |
| 90 | .PHONY: u-boot |
| 91 | u-boot: $(UBOOT_PATH)/.config optee-os tfa |
| 92 | $(UBOOT_EXPORTS) $(MAKE) -C $(UBOOT_PATH) $(UBOOT_FLAGS) |
| 93 | |
| 94 | .PHONY: u-boot-clean |
| 95 | u-boot-clean: |
| 96 | $(UBOOT_EXPORTS) $(MAKE) -C $(UBOOT_PATH) $(UBOOT_FLAGS) distclean |
| 97 | |
| 98 | clean: u-boot-clean |
| 99 | |
| 100 | ################################################################################ |
| 101 | # Linux kernel |
| 102 | ################################################################################ |
| 103 | LINUX_DEFCONFIG_COMMON_ARCH ?= arm64 |
| 104 | LINUX_DEFCONFIG_COMMON_FILES ?= $(LINUX_PATH)/arch/arm64/configs/defconfig \ |
| 105 | $(CURDIR)/kconfigs/rockpi4.conf |
| 106 | |
| 107 | .PHONY: linux-defconfig |
| 108 | linux-defconfig: $(LINUX_PATH)/.config |
| 109 | |
| 110 | LINUX_COMMON_FLAGS += ARCH=arm64 Image rockchip/rk3399-rock-pi-4b.dtb |
| 111 | |
| 112 | .PHONY: linux |
| 113 | linux: linux-common |
| 114 | |
| 115 | $(LINUX_PATH)/arch/arm64/boot/Image.gz: linux |
| 116 | gzip -c $(LINUX_PATH)/arch/arm64/boot/Image >$@ |
| 117 | |
| 118 | .PHONY: linux-defconfig-clean |
| 119 | linux-defconfig-clean: linux-defconfig-clean-common |
| 120 | |
| 121 | LINUX_CLEAN_COMMON_FLAGS += ARCH=arm64 |
| 122 | |
| 123 | .PHONY: linux-clean |
| 124 | linux-clean: linux-clean-common |
| 125 | |
| 126 | LINUX_CLEANER_COMMON_FLAGS += ARCH=arm64 |
| 127 | |
| 128 | .PHONY: linux-cleaner |
| 129 | linux-cleaner: linux-cleaner-common |
| 130 | |
| 131 | ################################################################################ |
| 132 | # OP-TEE |
| 133 | ################################################################################ |
| 134 | OPTEE_OS_PLATFORM = rockchip-rk3399 |
| 135 | OPTEE_OS_COMMON_FLAGS += CFG_ENABLE_EMBEDDED_TESTS=y |
| 136 | |
| 137 | .PHONY: optee-os |
| 138 | optee-os: optee-os-common |
| 139 | |
| 140 | .PHONY: optee-os-clean |
| 141 | optee-os-clean: optee-os-clean-common |
| 142 | |
| 143 | clean: optee-os-clean |
| 144 | |
| 145 | ################################################################################ |
| 146 | # Boot image, shall be copied to SD card |
| 147 | ################################################################################ |
| 148 | # U-Boot offset comes from CONFIG_SYS_MMCSD_RAW_MODE_U_BOOT_SECTOR=0x4000 |
| 149 | # Partition no. 5 ends at 12288 + BR2_TARGET_ROOTFS_EXT2_SIZE (in kiB) |
| 150 | .PHONY: boot-img |
| 151 | boot-img: u-boot buildroot $(LINUX_PATH)/arch/arm64/boot/Image.gz |
| 152 | mkdir -p $(BINARIES_PATH) |
| 153 | rm -f $(BOOT_IMG) |
| 154 | truncate -s 128MiB $(BOOT_IMG) |
| 155 | parted -s $(BOOT_IMG) \ |
| 156 | unit kiB \ |
| 157 | mklabel gpt \ |
| 158 | mkpart idbloader 32 4032 \ |
| 159 | mkpart primary fat32 4032 4096 \ |
| 160 | mkpart primary fat32 4096 8192 \ |
| 161 | mkpart uboot 8192 12288 \ |
| 162 | mkpart root fat32 12288 126976 |
| 163 | sgdisk -u 5:17d61bff-8fdc-4089-b675-9be21b9f6ac7 $(BOOT_IMG) |
| 164 | dd if=$(UBOOT_PATH)/idbloader.img of=$(BOOT_IMG) bs=1kiB seek=32 conv=notrunc |
| 165 | dd if=$(UBOOT_PATH)/u-boot.itb of=$(BOOT_IMG) bs=1kiB seek=8192 conv=notrunc |
| 166 | e2mkdir $(ROOT_IMG):/boot |
| 167 | e2cp $(LINUX_PATH)/arch/arm64/boot/Image.gz $(ROOT_IMG):/boot |
| 168 | e2cp $(LINUX_PATH)/arch/arm64/boot/dts/rockchip/rk3399-rock-pi-4b.dtb $(ROOT_IMG):/boot |
| 169 | dd if=$(ROOT_IMG) of=$(BOOT_IMG) bs=1kiB seek=12288 conv=notrunc |
| 170 | |
| 171 | .PHONY: boot-img-clean |
| 172 | boot-img-clean: |
| 173 | rm -f $(BOOT_IMG) |
| 174 | |
| 175 | clean: boot-img-clean |
| 176 | |
| 177 | ################################################################################ |
| 178 | # rkdeveloptool |
| 179 | ################################################################################ |
| 180 | |
| 181 | $(RKDEVELOPTOOL_PATH)/Makefile: |
| 182 | cd $(RKDEVELOPTOOL_PATH) && \ |
| 183 | autoreconf -i && \ |
| 184 | ./configure CXXFLAGS=-Wno-format-truncation |
| 185 | |
| 186 | $(RKDEVELOPTOOL_BIN): $(RKDEVELOPTOOL_PATH)/Makefile |
| 187 | $(MAKE) -C $(RKDEVELOPTOOL_PATH) |
| 188 | |
| 189 | rkdeveloptool: $(RKDEVELOPTOOL_BIN) |
| 190 | |
| 191 | rkdeveloptool-clean: |
| 192 | $(MAKE) -C $(RKDEVELOPTOOL_PATH) clean |
| 193 | |
| 194 | rkdeveloptool-distclean: |
| 195 | $(MAKE) -C $(RKDEVELOPTOOL_PATH) clean |
| 196 | |
| 197 | clean: rkdeveloptool-clean |
| 198 | |
| 199 | $(LOADER_BIN): |
| 200 | cd $(BINARIES_PATH) && \ |
| 201 | wget https://dl.radxa.com/rockpi/images/loader/$(notdir $(LOADER_BIN)) |
| 202 | |
| 203 | ################################################################################ |
| 204 | # Flash the image via USB onto the onboard eMMC |
| 205 | ################################################################################ |
| 206 | |
| 207 | define flash-help |
| 208 | @echo |
| 209 | @echo "Please connect the board to the computer via a USB cable." |
| 210 | @echo "The cable must be connected to the upper USB 3 (blue) port." |
| 211 | @echo "Then press and hold the mask ROM button (first one on the left" |
| 212 | @echo "under the HDMI connector), apply power and release the button." |
| 213 | @echo "(More details at https://wiki.radxa.com/Rockpi4/dev/usb-install)" |
| 214 | @echo |
| 215 | @read -r -p "Press enter to continue, Ctrl-C to cancel:" dummy |
| 216 | endef |
| 217 | |
| 218 | flash: $(BOOT_IMG) $(LOADER_BIN) $(RKDEVELOPTOOL_BIN) |
| 219 | $(call flash-help) |
| 220 | $(RKDEVELOPTOOL_BIN) db $(LOADER_BIN) |
| 221 | sleep 1 |
| 222 | $(RKDEVELOPTOOL_BIN) wl 0 $(BOOT_IMG) |
| 223 | |
| 224 | nuke-emmc: $(LOADER_BIN) $(RKDEVELOPTOOL_BIN) |
| 225 | @echo |
| 226 | @echo "** WARNING: this command will make the onboard eMMC unbootable!" |
| 227 | @echo "It can be used to boot from the SD card again." |
| 228 | $(call flash-help) |
| 229 | dd if=/dev/zero of=$(BINARIES_PATH)/zero.img bs=1M count=64 |
| 230 | $(RKDEVELOPTOOL_BIN) db $(LOADER_BIN) |
| 231 | sleep 1 |
| 232 | $(RKDEVELOPTOOL_BIN) wl 0 $(BINARIES_PATH)/zero.img |