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 | |
Sumit Garg | 857eaa0 | 2024-01-25 11:43:29 +0530 | [diff] [blame^] | 59 | RUST_TOOLCHAIN_PATH ?= $(TOOLCHAIN_ROOT)/rust |
| 60 | |
Joakim Bech | c960663 | 2017-01-27 11:50:49 +0100 | [diff] [blame] | 61 | .PHONY: toolchains |
Sumit Garg | 857eaa0 | 2024-01-25 11:43:29 +0530 | [diff] [blame^] | 62 | toolchains: aarch32-toolchain aarch64-toolchain rust-toolchain |
Joakim Bech | 427dd63 | 2015-05-04 15:52:33 +0200 | [diff] [blame] | 63 | |
Sumit Garg | 5045891 | 2024-01-25 11:37:50 +0530 | [diff] [blame] | 64 | .PHONY: aarch32-toolchain |
| 65 | aarch32-toolchain: |
Joakim Bech | c960663 | 2017-01-27 11:50:49 +0100 | [diff] [blame] | 66 | $(call dltc,$(AARCH32_PATH),$(SRC_AARCH32_GCC),$(AARCH32_GCC_VERSION)) |
Joakim Bech | 427dd63 | 2015-05-04 15:52:33 +0200 | [diff] [blame] | 67 | |
Sumit Garg | 5045891 | 2024-01-25 11:37:50 +0530 | [diff] [blame] | 68 | .PHONY: aarch64-toolchain |
| 69 | aarch64-toolchain: |
Joakim Bech | c960663 | 2017-01-27 11:50:49 +0100 | [diff] [blame] | 70 | $(call dltc,$(AARCH64_PATH),$(SRC_AARCH64_GCC),$(AARCH64_GCC_VERSION)) |
Jerome Forissier | c3cd9f5 | 2020-05-25 18:47:00 +0200 | [diff] [blame] | 71 | |
Sumit Garg | 857eaa0 | 2024-01-25 11:43:29 +0530 | [diff] [blame^] | 72 | # Download the Rust toolchain |
| 73 | define dl-rust-toolchain |
| 74 | @if [ ! -d "$(1)" ]; then \ |
| 75 | mkdir -p $(1) && \ |
| 76 | export RUSTUP_HOME=$(1)/.rustup && \ |
| 77 | export CARGO_HOME=$(1)/.cargo && \ |
| 78 | curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh -s -- -y --no-modify-path && \ |
| 79 | source "$(1)/.cargo/env" && \ |
| 80 | rustup target install aarch64-unknown-linux-gnu && \ |
| 81 | rustup target install arm-unknown-linux-gnueabihf && \ |
| 82 | rustup default nightly-2023-12-18; \ |
| 83 | fi |
| 84 | endef |
| 85 | |
| 86 | .PHONY: rust-toolchain |
| 87 | rust-toolchain: |
| 88 | $(call dl-rust-toolchain,$(RUST_TOOLCHAIN_PATH)) |
| 89 | |
Jerome Forissier | c09d34c | 2021-04-15 17:09:44 +0200 | [diff] [blame] | 90 | CLANG_VER ?= 12.0.0 |
Jerome Forissier | 0ae3f0a | 2021-04-15 17:09:44 +0200 | [diff] [blame] | 91 | CLANG_PATH ?= $(ROOT)/clang-$(CLANG_VER) |
Jerome Forissier | c3cd9f5 | 2020-05-25 18:47:00 +0200 | [diff] [blame] | 92 | |
| 93 | # Download the Clang compiler with LLVM tools and compiler-rt libraries |
| 94 | define dl-clang |
Jerome Forissier | 0ae3f0a | 2021-04-15 17:09:44 +0200 | [diff] [blame] | 95 | @if [ ! -d "$(2)" ]; then \ |
| 96 | ./get_clang.sh $(1) $(2); \ |
Jerome Forissier | c3cd9f5 | 2020-05-25 18:47:00 +0200 | [diff] [blame] | 97 | else \ |
Jerome Forissier | 0ae3f0a | 2021-04-15 17:09:44 +0200 | [diff] [blame] | 98 | echo "$(2) already exists"; \ |
Jerome Forissier | c3cd9f5 | 2020-05-25 18:47:00 +0200 | [diff] [blame] | 99 | fi |
| 100 | endef |
| 101 | |
| 102 | .PHONY: clang-toolchains |
| 103 | clang-toolchains: |
Jerome Forissier | 0ae3f0a | 2021-04-15 17:09:44 +0200 | [diff] [blame] | 104 | $(call dl-clang,$(CLANG_VER),$(CLANG_PATH)) |
Jens Wiklander | 68f7f8d | 2021-06-07 16:02:24 +0000 | [diff] [blame] | 105 | |
Alvin Chang | 344f771 | 2023-07-25 23:28:32 +0800 | [diff] [blame] | 106 | else ifeq ($(ARCH),riscv) |
Alvin Chang | 6902e46 | 2023-07-19 14:37:25 +0800 | [diff] [blame] | 107 | RISCV64_PATH ?= $(TOOLCHAIN_ROOT)/riscv64 |
| 108 | RISCV64_CROSS_COMPILE ?= $(RISCV64_PATH)/bin/riscv64-unknown-linux-gnu- |
| 109 | RISCV64_GCC_RELEASE_DATE ?= 2023.07.07 |
| 110 | RISCV64_GCC_VERSION ?= riscv64-glibc-ubuntu-22.04-gcc-nightly-$(RISCV64_GCC_RELEASE_DATE)-nightly |
| 111 | SRC_RISCV64_GCC ?= https://github.com/riscv-collab/riscv-gnu-toolchain/releases/download/$(RISCV64_GCC_RELEASE_DATE)/$(RISCV64_GCC_VERSION).tar.gz |
| 112 | |
| 113 | .PHONY: toolchains |
Sumit Garg | 5045891 | 2024-01-25 11:37:50 +0530 | [diff] [blame] | 114 | toolchains: riscv64-toolchain |
Alvin Chang | 6902e46 | 2023-07-19 14:37:25 +0800 | [diff] [blame] | 115 | |
Sumit Garg | 5045891 | 2024-01-25 11:37:50 +0530 | [diff] [blame] | 116 | .PHONY: riscv64-toolchain |
| 117 | riscv64-toolchain: |
Alvin Chang | 6902e46 | 2023-07-19 14:37:25 +0800 | [diff] [blame] | 118 | $(call dltc,$(RISCV64_PATH),$(SRC_RISCV64_GCC),$(RISCV64_GCC_VERSION)) |
| 119 | |
| 120 | endif |
| 121 | |
Sumit Garg | 495dc6a | 2021-12-23 14:45:36 +0530 | [diff] [blame] | 122 | else ifeq ($(UNAME_M),aarch64) |
| 123 | |
| 124 | AARCH32_PATH ?= $(TOOLCHAIN_ROOT)/aarch32 |
| 125 | AARCH32_CROSS_COMPILE ?= $(AARCH32_PATH)/bin/arm-linux-gnueabihf- |
| 126 | AARCH32_GCC_VERSION ?= gcc-arm-10.2-2020.11-aarch64-arm-none-linux-gnueabihf |
| 127 | SRC_AARCH32_GCC ?= https://developer.arm.com/-/media/Files/downloads/gnu-a/10.2-2020.11/binrel/$(AARCH32_GCC_VERSION).tar.xz |
| 128 | |
| 129 | # There isn't any native aarch64 toolchain released from Arm and buildroot |
| 130 | # doesn't support distribution toolchain [1]. So we are left with no choice |
| 131 | # but to build buildroot toolchain from source and use it. |
| 132 | # |
| 133 | # [1] https://buildroot.org/downloads/manual/manual.html#_cross_compilation_toolchain |
| 134 | AARCH64_PATH ?= $(TOOLCHAIN_ROOT)/aarch64 |
| 135 | AARCH64_CROSS_COMPILE ?= $(AARCH64_PATH)/bin/aarch64-linux- |
| 136 | |
| 137 | .PHONY: toolchains |
Sumit Garg | 5045891 | 2024-01-25 11:37:50 +0530 | [diff] [blame] | 138 | toolchains: aarch32-toolchain $(AARCH64_PATH)/.done |
Sumit Garg | 495dc6a | 2021-12-23 14:45:36 +0530 | [diff] [blame] | 139 | |
Sumit Garg | 5045891 | 2024-01-25 11:37:50 +0530 | [diff] [blame] | 140 | .PHONY: aarch32-toolchain |
| 141 | aarch32-toolchain: |
Sumit Garg | 495dc6a | 2021-12-23 14:45:36 +0530 | [diff] [blame] | 142 | $(call dltc,$(AARCH32_PATH),$(SRC_AARCH32_GCC),$(AARCH32_GCC_VERSION)) |
| 143 | |
| 144 | $(AARCH64_PATH)/.done: |
| 145 | $(call build_toolchain,aarch64,$(AARCH64_PATH),aarch64,gnu) |
| 146 | |
| 147 | else # $(UNAME_M) != x86_64 or $(UNAME_M) != aarch64 |
Jens Wiklander | 68f7f8d | 2021-06-07 16:02:24 +0000 | [diff] [blame] | 148 | AARCH32_PATH := $(TOOLCHAIN_ROOT)/aarch32 |
| 149 | AARCH32_CROSS_COMPILE := $(AARCH32_PATH)/bin/arm-linux- |
| 150 | AARCH64_PATH := $(TOOLCHAIN_ROOT)/aarch64 |
| 151 | AARCH64_CROSS_COMPILE := $(AARCH64_PATH)/bin/aarch64-linux- |
| 152 | |
| 153 | .PHONY: toolchains |
| 154 | toolchains: $(AARCH64_PATH)/.done $(AARCH32_PATH)/.done |
| 155 | |
Jens Wiklander | 68f7f8d | 2021-06-07 16:02:24 +0000 | [diff] [blame] | 156 | $(AARCH64_PATH)/.done: |
| 157 | $(call build_toolchain,aarch64,$(AARCH64_PATH),aarch64,gnu) |
| 158 | |
| 159 | $(AARCH32_PATH)/.done: |
| 160 | $(call build_toolchain,aarch32,$(AARCH32_PATH),arm,gnueabihf) |
| 161 | endif |