Joakim Bech | 427dd63 | 2015-05-04 15:52:33 +0200 | [diff] [blame] | 1 | ################################################################################ |
| 2 | # Toolchains |
| 3 | ################################################################################ |
Yunli Liu | 904f148 | 2021-01-22 11:08:08 +0800 | [diff] [blame] | 4 | SHELL = /bin/bash |
Joakim Bech | c960663 | 2017-01-27 11:50:49 +0100 | [diff] [blame] | 5 | ROOT ?= $(CURDIR)/.. |
Joakim Bech | 427dd63 | 2015-05-04 15:52:33 +0200 | [diff] [blame] | 6 | TOOLCHAIN_ROOT ?= $(ROOT)/toolchains |
Jens Wiklander | 68f7f8d | 2021-06-07 16:02:24 +0000 | [diff] [blame] | 7 | UNAME_M := $(shell uname -m) |
Alvin Chang | 344f771 | 2023-07-25 23:28:32 +0800 | [diff] [blame] | 8 | ARCH ?= arm |
Joakim Bech | 427dd63 | 2015-05-04 15:52:33 +0200 | [diff] [blame] | 9 | |
Joakim Bech | c960663 | 2017-01-27 11:50:49 +0100 | [diff] [blame] | 10 | # Download toolchain macro for saving some repetition |
| 11 | # $(1) is $AARCH.._PATH : i.e., path to the destination |
| 12 | # $(2) is $SRC_AARCH.._GCC : is the downloaded tar.gz file |
| 13 | # $(3) is $.._GCC_VERSION : the name of the file to download |
| 14 | define dltc |
| 15 | @if [ ! -d "$(1)" ]; then \ |
Joakim Bech | c960663 | 2017-01-27 11:50:49 +0100 | [diff] [blame] | 16 | echo "Downloading $(3) ..."; \ |
Aleksey Kazantsev | c551e2a | 2021-07-15 11:08:47 +0300 | [diff] [blame] | 17 | mkdir -p $(1); \ |
Jerome Forissier | 3408c89 | 2023-05-04 13:58:35 +0200 | [diff] [blame] | 18 | curl --retry 5 -k -s -S -L $(2) -o $(TOOLCHAIN_ROOT)/$(3).tar.xz || \ |
Aleksey Kazantsev | c551e2a | 2021-07-15 11:08:47 +0300 | [diff] [blame] | 19 | { rm -f $(TOOLCHAIN_ROOT)/$(3).tar.xz; cd $(TOOLCHAIN_ROOT) && rmdir $(1); echo Download failed; exit 1; }; \ |
| 20 | tar xf $(TOOLCHAIN_ROOT)/$(3).tar.xz -C $(1) --strip-components=1 || \ |
| 21 | { rm $(TOOLCHAIN_ROOT)/$(3).tar.xz; echo Downloaded file is damaged; \ |
| 22 | cd $(TOOLCHAIN_ROOT) && rm -rf $(1); exit 1; }; \ |
Alvin Chang | 4a1fef8 | 2023-05-17 00:18:01 +0800 | [diff] [blame] | 23 | (cd $(1)/bin && shopt -s nullglob && for f in *-none-linux*; do ln -s $$f $${f//-none} ; done;) \ |
Joakim Bech | c960663 | 2017-01-27 11:50:49 +0100 | [diff] [blame] | 24 | fi |
| 25 | endef |
| 26 | |
Sumit Garg | 495dc6a | 2021-12-23 14:45:36 +0530 | [diff] [blame] | 27 | # Build buildroot toolchain macro for saving some repetition |
| 28 | # $(1) is $ARCH : target architecture |
| 29 | # $(2) is $AARCH.._PATH : i.e., path to the destination |
| 30 | # $(3) & $(4) : parts of toolchain target triplet |
| 31 | define build_toolchain |
| 32 | @echo Building $1 toolchain |
| 33 | @mkdir -p ../out-$1-sdk $2 |
Imre Kis | dc34f49 | 2023-04-11 16:53:06 +0200 | [diff] [blame] | 34 | @(cd .. && $(PYTHON3) build/br-ext/scripts/make_def_config.py \ |
Sumit Garg | 495dc6a | 2021-12-23 14:45:36 +0530 | [diff] [blame] | 35 | --br buildroot --out out-$1-sdk --br-ext build/br-ext \ |
| 36 | --top-dir "$(ROOT)" \ |
| 37 | --br-defconfig build/br-ext/configs/sdk-$1 \ |
| 38 | --br-defconfig build/br-ext/configs/sdk-common \ |
| 39 | --make-cmd $(MAKE)) |
Jerome Forissier | 8016498 | 2022-08-03 14:59:39 +0000 | [diff] [blame] | 40 | +@$(MAKE) -C ../out-$1-sdk clean |
| 41 | +@$(MAKE) -C ../out-$1-sdk sdk |
Sumit Garg | 495dc6a | 2021-12-23 14:45:36 +0530 | [diff] [blame] | 42 | @tar xf ../out-$1-sdk/images/$3-buildroot-linux-$4_sdk-buildroot.tar.gz \ |
| 43 | -C $2 --strip-components=1 |
| 44 | @touch $2/.done |
| 45 | endef |
| 46 | |
| 47 | ifeq ($(UNAME_M),x86_64) |
Alvin Chang | 344f771 | 2023-07-25 23:28:32 +0800 | [diff] [blame] | 48 | ifeq ($(ARCH),arm) |
Sumit Garg | 495dc6a | 2021-12-23 14:45:36 +0530 | [diff] [blame] | 49 | AARCH32_PATH ?= $(TOOLCHAIN_ROOT)/aarch32 |
| 50 | AARCH32_CROSS_COMPILE ?= $(AARCH32_PATH)/bin/arm-linux-gnueabihf- |
Jerome Forissier | 19b7b07 | 2023-02-09 16:10:13 +0100 | [diff] [blame] | 51 | AARCH32_GCC_VERSION ?= arm-gnu-toolchain-11.3.rel1-x86_64-arm-none-linux-gnueabihf |
| 52 | SRC_AARCH32_GCC ?= https://developer.arm.com/-/media/Files/downloads/gnu/11.3.rel1/binrel/$(AARCH32_GCC_VERSION).tar.xz |
Sumit Garg | 495dc6a | 2021-12-23 14:45:36 +0530 | [diff] [blame] | 53 | |
| 54 | AARCH64_PATH ?= $(TOOLCHAIN_ROOT)/aarch64 |
| 55 | AARCH64_CROSS_COMPILE ?= $(AARCH64_PATH)/bin/aarch64-linux-gnu- |
Jerome Forissier | 19b7b07 | 2023-02-09 16:10:13 +0100 | [diff] [blame] | 56 | AARCH64_GCC_VERSION ?= arm-gnu-toolchain-11.3.rel1-x86_64-aarch64-none-linux-gnu |
| 57 | SRC_AARCH64_GCC ?= https://developer.arm.com/-/media/Files/downloads/gnu/11.3.rel1/binrel/$(AARCH64_GCC_VERSION).tar.xz |
Sumit Garg | 495dc6a | 2021-12-23 14:45:36 +0530 | [diff] [blame] | 58 | |
Joakim Bech | c960663 | 2017-01-27 11:50:49 +0100 | [diff] [blame] | 59 | .PHONY: toolchains |
Joakim Bech | 6a0fc2b | 2018-05-23 08:38:47 +0200 | [diff] [blame] | 60 | toolchains: aarch32 aarch64 |
Joakim Bech | 427dd63 | 2015-05-04 15:52:33 +0200 | [diff] [blame] | 61 | |
Joakim Bech | c960663 | 2017-01-27 11:50:49 +0100 | [diff] [blame] | 62 | .PHONY: aarch32 |
Joakim Bech | 42807a7 | 2017-01-27 10:43:28 +0100 | [diff] [blame] | 63 | aarch32: |
Joakim Bech | c960663 | 2017-01-27 11:50:49 +0100 | [diff] [blame] | 64 | $(call dltc,$(AARCH32_PATH),$(SRC_AARCH32_GCC),$(AARCH32_GCC_VERSION)) |
Joakim Bech | 427dd63 | 2015-05-04 15:52:33 +0200 | [diff] [blame] | 65 | |
Joakim Bech | c960663 | 2017-01-27 11:50:49 +0100 | [diff] [blame] | 66 | .PHONY: aarch64 |
Joakim Bech | 42807a7 | 2017-01-27 10:43:28 +0100 | [diff] [blame] | 67 | aarch64: |
Joakim Bech | c960663 | 2017-01-27 11:50:49 +0100 | [diff] [blame] | 68 | $(call dltc,$(AARCH64_PATH),$(SRC_AARCH64_GCC),$(AARCH64_GCC_VERSION)) |
Jerome Forissier | c3cd9f5 | 2020-05-25 18:47:00 +0200 | [diff] [blame] | 69 | |
Jerome Forissier | c09d34c | 2021-04-15 17:09:44 +0200 | [diff] [blame] | 70 | CLANG_VER ?= 12.0.0 |
Jerome Forissier | 0ae3f0a | 2021-04-15 17:09:44 +0200 | [diff] [blame] | 71 | CLANG_PATH ?= $(ROOT)/clang-$(CLANG_VER) |
Jerome Forissier | c3cd9f5 | 2020-05-25 18:47:00 +0200 | [diff] [blame] | 72 | |
| 73 | # Download the Clang compiler with LLVM tools and compiler-rt libraries |
| 74 | define dl-clang |
Jerome Forissier | 0ae3f0a | 2021-04-15 17:09:44 +0200 | [diff] [blame] | 75 | @if [ ! -d "$(2)" ]; then \ |
| 76 | ./get_clang.sh $(1) $(2); \ |
Jerome Forissier | c3cd9f5 | 2020-05-25 18:47:00 +0200 | [diff] [blame] | 77 | else \ |
Jerome Forissier | 0ae3f0a | 2021-04-15 17:09:44 +0200 | [diff] [blame] | 78 | echo "$(2) already exists"; \ |
Jerome Forissier | c3cd9f5 | 2020-05-25 18:47:00 +0200 | [diff] [blame] | 79 | fi |
| 80 | endef |
| 81 | |
| 82 | .PHONY: clang-toolchains |
| 83 | clang-toolchains: |
Jerome Forissier | 0ae3f0a | 2021-04-15 17:09:44 +0200 | [diff] [blame] | 84 | $(call dl-clang,$(CLANG_VER),$(CLANG_PATH)) |
Jens Wiklander | 68f7f8d | 2021-06-07 16:02:24 +0000 | [diff] [blame] | 85 | |
Alvin Chang | 344f771 | 2023-07-25 23:28:32 +0800 | [diff] [blame] | 86 | else ifeq ($(ARCH),riscv) |
Alvin Chang | 6902e46 | 2023-07-19 14:37:25 +0800 | [diff] [blame] | 87 | RISCV64_PATH ?= $(TOOLCHAIN_ROOT)/riscv64 |
| 88 | RISCV64_CROSS_COMPILE ?= $(RISCV64_PATH)/bin/riscv64-unknown-linux-gnu- |
| 89 | RISCV64_GCC_RELEASE_DATE ?= 2023.07.07 |
| 90 | RISCV64_GCC_VERSION ?= riscv64-glibc-ubuntu-22.04-gcc-nightly-$(RISCV64_GCC_RELEASE_DATE)-nightly |
| 91 | SRC_RISCV64_GCC ?= https://github.com/riscv-collab/riscv-gnu-toolchain/releases/download/$(RISCV64_GCC_RELEASE_DATE)/$(RISCV64_GCC_VERSION).tar.gz |
| 92 | |
| 93 | .PHONY: toolchains |
| 94 | toolchains: riscv64 |
| 95 | |
| 96 | .PHONY: riscv64 |
| 97 | riscv64: |
| 98 | $(call dltc,$(RISCV64_PATH),$(SRC_RISCV64_GCC),$(RISCV64_GCC_VERSION)) |
| 99 | |
| 100 | endif |
| 101 | |
Sumit Garg | 495dc6a | 2021-12-23 14:45:36 +0530 | [diff] [blame] | 102 | else ifeq ($(UNAME_M),aarch64) |
| 103 | |
| 104 | AARCH32_PATH ?= $(TOOLCHAIN_ROOT)/aarch32 |
| 105 | AARCH32_CROSS_COMPILE ?= $(AARCH32_PATH)/bin/arm-linux-gnueabihf- |
| 106 | AARCH32_GCC_VERSION ?= gcc-arm-10.2-2020.11-aarch64-arm-none-linux-gnueabihf |
| 107 | SRC_AARCH32_GCC ?= https://developer.arm.com/-/media/Files/downloads/gnu-a/10.2-2020.11/binrel/$(AARCH32_GCC_VERSION).tar.xz |
| 108 | |
| 109 | # There isn't any native aarch64 toolchain released from Arm and buildroot |
| 110 | # doesn't support distribution toolchain [1]. So we are left with no choice |
| 111 | # but to build buildroot toolchain from source and use it. |
| 112 | # |
| 113 | # [1] https://buildroot.org/downloads/manual/manual.html#_cross_compilation_toolchain |
| 114 | AARCH64_PATH ?= $(TOOLCHAIN_ROOT)/aarch64 |
| 115 | AARCH64_CROSS_COMPILE ?= $(AARCH64_PATH)/bin/aarch64-linux- |
| 116 | |
| 117 | .PHONY: toolchains |
| 118 | toolchains: aarch32 $(AARCH64_PATH)/.done |
| 119 | |
| 120 | .PHONY: aarch32 |
| 121 | aarch32: |
| 122 | $(call dltc,$(AARCH32_PATH),$(SRC_AARCH32_GCC),$(AARCH32_GCC_VERSION)) |
| 123 | |
| 124 | $(AARCH64_PATH)/.done: |
| 125 | $(call build_toolchain,aarch64,$(AARCH64_PATH),aarch64,gnu) |
| 126 | |
| 127 | else # $(UNAME_M) != x86_64 or $(UNAME_M) != aarch64 |
Jens Wiklander | 68f7f8d | 2021-06-07 16:02:24 +0000 | [diff] [blame] | 128 | AARCH32_PATH := $(TOOLCHAIN_ROOT)/aarch32 |
| 129 | AARCH32_CROSS_COMPILE := $(AARCH32_PATH)/bin/arm-linux- |
| 130 | AARCH64_PATH := $(TOOLCHAIN_ROOT)/aarch64 |
| 131 | AARCH64_CROSS_COMPILE := $(AARCH64_PATH)/bin/aarch64-linux- |
| 132 | |
| 133 | .PHONY: toolchains |
| 134 | toolchains: $(AARCH64_PATH)/.done $(AARCH32_PATH)/.done |
| 135 | |
Jens Wiklander | 68f7f8d | 2021-06-07 16:02:24 +0000 | [diff] [blame] | 136 | $(AARCH64_PATH)/.done: |
| 137 | $(call build_toolchain,aarch64,$(AARCH64_PATH),aarch64,gnu) |
| 138 | |
| 139 | $(AARCH32_PATH)/.done: |
| 140 | $(call build_toolchain,aarch32,$(AARCH32_PATH),arm,gnueabihf) |
| 141 | endif |