1 ################################################################################
2 # Configure toolchain paths
3 ################################################################################
4 # This section applies to all broader set of boards with SOCs beyond TDA class
5 # in Processor SDK RTOS release
6 PDK_VERSION_STR=_$(PDK_SOC)_$(PDK_VERSION)
7 ifeq ($(PDK_VERSION),)
8 PDK_VERSION_STR=
9 endif
11 #Tool versions for non-TDA builds
12 GCC_CROSS_TOOL_PREFIX=arm-none-eabi-
13 GCC_CROSS_TOOL_TAG=7-2018-q2-update
14 GCC_ARCH64_VERSION=9.2-2019.12
15 GCC_ARCH64_BIN_PREFIX_STR=aarch64-none-elf
16 CGT_VERSION=8.3.2
17 BIOS_VERSION=6_82_00_16
18 XDC_VERSION=3_61_00_16_core
20 CGT_C7X_VERSION=1.3.0.STS
21 CGT_ARM_VERSION=20.2.0.LTS
22 GCC_VERSION_HARDLIB=7.3.1
24 CGT_ARP32_VERSION=1.0.8
25 CG_XML_VERSION=2.61.00
27 ifeq ($(BOARD),$(filter $(BOARD), tpr12_evm))
28 BIOS_VERSION=6_82_00_16
29 XDC_VERSION=3_61_00_16_core
30 CGT_VERSION=8.3.3
31 CGT_ARM_VERSION=18.12.5.LTS
32 endif
34 ifeq ($(BOARD),$(filter $(BOARD), am64x_evm))
35 BIOS_VERSION=6_83_00_01_eng
36 XDC_VERSION=3_61_00_16_core
37 GCC_ARCH64_VERSION=7.2.1-2017.11
38 GCC_ARCH64_BIN_PREFIX_STR=aarch64-elf
39 CGT_ARM_VERSION=18.12.5.LTS
40 endif
42 EDMA_VERSION=2_12_05_30E
43 SECDEV_VERSION=01_06_00_05
44 CGT_PRU_VERSION=2.3.2
46 #Hardcode IPC version if it is not set already
47 IPC_VERSION=3_50_04_08
48 NDK_VERSION=3_61_01_01
49 NS_VERSION=2_60_01_06
51 ifeq ($(BOARD),$(filter $(BOARD), am65xx_evm am65xx_idk j721e_evm j7200_evm))
52 NDK_VERSION=3_75_01_01
53 NS_VERSION=2_75_00_17
54 endif
56 UIA_VERSION=2_30_01_02
57 XDAIS_VERSION=7_24_00_04
58 AER_VERSION=17_0_0_0
60 # C674x DSP libraries sould be used for OMAPL13x platform
61 ifeq ($(SOC),$(filter $(SOC), omapl137 omapl138))
62 DSPLIB_VERSION ?= c674x_3_4_0_4
63 IMGLIB_VERSION ?= c674x_3_1_1_0
64 MATHLIB_VERSION ?= c674x_3_1_2_4
65 else
66 DSPLIB_VERSION ?= c66x_3_4_0_4
67 IMGLIB_VERSION ?= c66x_3_1_1_0
68 MATHLIB_VERSION ?= c66x_3_1_2_4
69 endif
71 export GCC_FLOAT_PATH ?= HARD
73 ################################################################################
74 # Dependent toolchain paths variables
75 ################################################################################
76 # Version of GCC
77 GCC_VERSION=$(GCC_CROSS_TOOL_PREFIX)$(GCC_CROSS_TOOL_TAG)
78 GCC_VERSION_ARM_A15=$(GCC_CROSS_TOOL_PREFIX)$(GCC_CROSS_TOOL_TAG)
79 export GCC_VERSION_ARM_A8=$(GCC_CROSS_TOOL_PREFIX)$(GCC_CROSS_TOOL_TAG)
80 export GCC_VERSION_ARM_A9=$(GCC_CROSS_TOOL_PREFIX)$(GCC_CROSS_TOOL_TAG)
81 export CROSS_TOOL_PRFX ?= $(GCC_CROSS_TOOL_PREFIX)
82 export C6X_GEN_INSTALL_PATH ?= $(TOOLS_INSTALL_PATH)/ti-cgt-c6000_$(CGT_VERSION)
83 export C7X_GEN_INSTALL_PATH ?= $(TOOLS_INSTALL_PATH)/ti-cgt-c7000_$(CGT_C7X_VERSION)
84 export CL_PRU_INSTALL_PATH ?= $(TOOLS_INSTALL_PATH)/ti-cgt-pru_$(CGT_PRU_VERSION)
85 export TOOLCHAIN_PATH_A8 ?= $(TOOLS_INSTALL_PATH)/gcc-$(GCC_VERSION_ARM_A8)
86 export TOOLCHAIN_PATH_A9 ?= $(TOOLS_INSTALL_PATH)/gcc-$(GCC_VERSION_ARM_A9)
87 export TOOLCHAIN_PATH_Arm9 ?= $(TOOLS_INSTALL_PATH)/ti-cgt-arm_$(CGT_ARM_VERSION)
88 export TOOLCHAIN_PATH_A15 ?= $(TOOLS_INSTALL_PATH)/gcc-$(GCC_VERSION_ARM_A15)
89 ifeq ($(OS),Windows_NT)
90 #Paths for windows machine
91 export TOOLCHAIN_PATH_GCC_ARCH64 ?= $(TOOLS_INSTALL_PATH)/gcc-arm-$(GCC_ARCH64_VERSION)-mingw-w64-i686-aarch64-none-elf
92 else
93 #Paths for linux machine
94 export TOOLCHAIN_PATH_GCC_ARCH64 ?= $(TOOLS_INSTALL_PATH)/gcc-arm-$(GCC_ARCH64_VERSION)-x86_64-aarch64-none-elf
95 endif
97 ifeq ($(BOARD),$(filter $(BOARD), am64x_evm))
98 ifeq ($(OS),Windows_NT)
99 #Paths for windows machine
100 export TOOLCHAIN_PATH_GCC_ARCH64 ?= $(TOOLS_INSTALL_PATH)/gcc-linaro-$(GCC_ARCH64_VERSION)-mingw-w64-i686-aarch64-elf
101 else
102 #Paths for linux machine
103 export TOOLCHAIN_PATH_GCC_ARCH64 ?= $(TOOLS_INSTALL_PATH)/gcc-linaro-$(GCC_ARCH64_VERSION)-x86_64-aarch64-elf
104 endif
105 endif
107 export GCC_ARCH64_BIN_PREFIX ?= $(GCC_ARCH64_BIN_PREFIX_STR)
109 ifeq ($(BOARD),$(filter $(BOARD), am64x_evm))
110 ifeq ($(OS),Windows_NT)
111 #Paths for windows machine
112 export TOOLCHAIN_PATH_GCC_ARCH64 ?= $(TOOLS_INSTALL_PATH)/gcc-linaro-$(GCC_ARCH64_VERSION)-mingw-w64-i686-aarch64-elf
113 else
114 #Paths for linux machine
115 export TOOLCHAIN_PATH_GCC_ARCH64 ?= $(TOOLS_INSTALL_PATH)/gcc-linaro-$(GCC_ARCH64_VERSION)-x86_64-aarch64-elf
116 endif
117 endif
119 export GCC_ARCH64_BIN_PREFIX ?= $(GCC_ARCH64_BIN_PREFIX_STR)
121 export TOOLCHAIN_PATH_QNX_A72 ?= $(QNX_HOST)/usr/bin
122 export TOOLCHAIN_PATH_A53 ?= $(TOOLCHAIN_PATH_GCC_ARCH64)
123 export TOOLCHAIN_PATH_A72 ?= $(TOOLCHAIN_PATH_GCC_ARCH64)
124 export TOOLCHAIN_PATH_EVE ?= $(TOOLS_INSTALL_PATH)/arp32_$(CGT_ARP32_VERSION)
125 export TOOLCHAIN_PATH_M4 ?= $(TOOLS_INSTALL_PATH)/ti-cgt-arm_$(CGT_ARM_VERSION)
126 export TOOLCHAIN_PATH_R5 ?= $(TOOLS_INSTALL_PATH)/ti-cgt-arm_$(CGT_ARM_VERSION)
127 export BIOS_INSTALL_PATH ?= $(SDK_INSTALL_PATH)/bios_$(BIOS_VERSION)
128 export DSPLIB_INSTALL_PATH ?= $(SDK_INSTALL_PATH)/dsplib_$(DSPLIB_VERSION)
129 export EDMA3LLD_BIOS6_INSTALLDIR ?= $(SDK_INSTALL_PATH)/edma3_lld_$(EDMA_VERSION)
130 export IMGLIB_INSTALL_PATH ?= $(SDK_INSTALL_PATH)/imglib_$(IMGLIB_VERSION)
131 export IPC_INSTALL_PATH ?= $(SDK_INSTALL_PATH)/ipc_$(IPC_VERSION)
132 export MATHLIB_INSTALL_PATH ?= $(SDK_INSTALL_PATH)/mathlib_$(MATHLIB_VERSION)
133 export NDK_INSTALL_PATH ?= $(SDK_INSTALL_PATH)/ndk_$(NDK_VERSION)
134 export NS_INSTALL_PATH ?= $(SDK_INSTALL_PATH)/ns_$(NS_VERSION)
135 export PDK_INSTALL_PATH ?= $(SDK_INSTALL_PATH)/pdk$(PDK_VERSION_STR)/packages
136 export UIA_INSTALL_PATH ?= $(SDK_INSTALL_PATH)/uia_$(UIA_VERSION)
137 export XDC_INSTALL_PATH ?= $(SDK_INSTALL_PATH)/xdctools_$(XDC_VERSION)
138 export UTILS_INSTALL_DIR ?= $(XDC_INSTALL_PATH)/bin
139 export RADARLINK_INSTALL_PATH ?= $(SDK_INSTALL_PATH)/$(mmwavelink_version)
140 export CG_XML_BIN_INSTALL_PATH ?= $(SDK_INSTALL_PATH)/cg_xml_$(CG_XML_VERSION)/bin
141 export TI_SECURE_DEV_PKG ?= $(SDK_INSTALL_PATH)/proc-sdk-secdev_$(SECDEV_VERSION)
142 export XDAIS_INSTALL_PATH ?= $(SDK_INSTALL_PATH)/xdais_$(XDAIS_VERSION)
143 export AER_INSTALL_PATH ?= $(SDK_INSTALL_PATH)/aer_c64Px_obj_$(AER_VERSION)
144 export GCC_ARM_NONE_TOOLCHAIN ?= $(SDK_INSTALL_PATH)/gcc-$(GCC_CROSS_TOOL_PREFIX)$(GCC_CROSS_TOOL_TAG)
145 export TI_CGT6x_INSTALL_DIR ?= $(SDK_INSTALL_PATH)/c6000_7.4.16
146 export M4_TOOLCHAIN_INSTALL_DIR ?= $(TOOLCHAIN_PATH_M4)
148 ifeq ($(SOC),$(filter $(SOC), am335x))
149 export HARDLIB_PATH ?= $(TOOLCHAIN_PATH_A8)/lib/gcc/arm-none-eabi/$(GCC_VERSION_HARDLIB)/hard
150 export FPULIB_PATH ?= $(TOOLCHAIN_PATH_A8)/lib/gcc/arm-none-eabi/$(GCC_VERSION_FPULIB)/fpu
151 else ifeq ($(SOC),$(filter $(SOC), am437x))
152 export HARDLIB_PATH ?= $(TOOLCHAIN_PATH_A9)/lib/gcc/arm-none-eabi/$(GCC_VERSION_HARDLIB)/hard
153 export FPULIB_PATH ?= $(TOOLCHAIN_PATH_A9)/lib/gcc/arm-none-eabi/$(GCC_VERSION_FPULIB)/fpu
154 else
155 export HARDLIB_PATH ?= $(TOOLCHAIN_PATH_A15)/lib/gcc/arm-none-eabi/$(GCC_VERSION_HARDLIB)/hard
156 export FPULIB_PATH ?= $(TOOLCHAIN_PATH_A15)/lib/gcc/arm-none-eabi/$(GCC_VERSION_FPULIB)/fpu
157 endif
159 # Utilities directory. This is required only if the build machine is Windows.
160 # - specify the installation directory of utility which supports POSIX commands
161 # (eg: Cygwin installation or MSYS installation).
162 # This could be in CCS install directory as in c:/ti/ccsv<ver>/utils/cygwin or
163 # the XDC install bin folder represented by $(UTILS_INSTALL_DIR)
164 ifeq ($(OS),Windows_NT)
165 export utils_PATH ?= $(UTILS_INSTALL_DIR)
166 endif