2013-07-18 23:20:47 +02:00
|
|
|
############################################################################
|
|
|
|
# arch/arm/src/armv7-a/Toolchain.defs
|
|
|
|
#
|
2019-03-19 23:56:04 +01:00
|
|
|
# Copyright (C) 2013, 2019 Gregory Nutt. All rights reserved.
|
2013-07-18 23:20:47 +02:00
|
|
|
# Author: Gregory Nutt <gnutt@nuttx.org>
|
|
|
|
#
|
|
|
|
# Redistribution and use in source and binary forms, with or without
|
|
|
|
# modification, are permitted provided that the following conditions
|
|
|
|
# are met:
|
|
|
|
#
|
|
|
|
# 1. Redistributions of source code must retain the above copyright
|
|
|
|
# notice, this list of conditions and the following disclaimer.
|
|
|
|
# 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
# notice, this list of conditions and the following disclaimer in
|
|
|
|
# the documentation and/or other materials provided with the
|
|
|
|
# distribution.
|
|
|
|
# 3. Neither the name NuttX nor the names of its contributors may be
|
|
|
|
# used to endorse or promote products derived from this software
|
|
|
|
# without specific prior written permission.
|
|
|
|
#
|
|
|
|
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
|
|
# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
|
|
# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
|
|
|
|
# FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
|
|
|
|
# COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|
|
|
# INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
|
|
|
# BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
|
|
|
|
# OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
|
|
|
|
# AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
|
|
# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
|
|
|
|
# ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
|
|
# POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
#
|
|
|
|
############################################################################
|
|
|
|
|
|
|
|
# Setup for the selected toolchain
|
|
|
|
|
|
|
|
#
|
|
|
|
# Select and allow the selected toolchain to be overridden by a command-line
|
|
|
|
#selection.
|
|
|
|
#
|
|
|
|
|
|
|
|
ifeq ($(filter y, \
|
|
|
|
$(CONFIG_ARMV7A_TOOLCHAIN_BUILDROOT) \
|
|
|
|
),y)
|
|
|
|
CONFIG_ARMV7A_TOOLCHAIN ?= BUILDROOT
|
|
|
|
endif
|
|
|
|
|
|
|
|
ifeq ($(filter y, \
|
|
|
|
$(CONFIG_ARMV7A_TOOLCHAIN_CODESOURCERYL) \
|
|
|
|
),y)
|
|
|
|
CONFIG_ARMV7A_TOOLCHAIN ?= CODESOURCERYL
|
|
|
|
endif
|
|
|
|
|
|
|
|
ifeq ($(filter y, \
|
|
|
|
$(CONFIG_ARMV7A_TOOLCHAIN_CODESOURCERYW) \
|
|
|
|
),y)
|
|
|
|
CONFIG_ARMV7A_TOOLCHAIN ?= CODESOURCERYW
|
|
|
|
endif
|
|
|
|
|
|
|
|
ifeq ($(filter y, \
|
|
|
|
$(CONFIG_ARMV7A_TOOLCHAIN_DEVKITARM) \
|
|
|
|
),y)
|
|
|
|
CONFIG_ARMV7A_TOOLCHAIN ?= DEVKITARM
|
|
|
|
endif
|
|
|
|
|
|
|
|
ifeq ($(filter y, \
|
|
|
|
$(CONFIG_ARMV7A_TOOLCHAIN_GNU_EABIL) \
|
|
|
|
),y)
|
|
|
|
CONFIG_ARMV7A_TOOLCHAIN ?= GNU_EABIL
|
|
|
|
endif
|
|
|
|
|
|
|
|
ifeq ($(filter y, \
|
|
|
|
$(CONFIG_ARMV7A_TOOLCHAIN_GNU_EABIW) \
|
|
|
|
),y)
|
|
|
|
CONFIG_ARMV7A_TOOLCHAIN ?= GNU_EABIW
|
|
|
|
endif
|
|
|
|
|
|
|
|
#
|
|
|
|
# Supported toolchains
|
|
|
|
#
|
|
|
|
# Each toolchain definition should set:
|
|
|
|
#
|
|
|
|
# CROSSDEV The GNU toolchain triple (command prefix)
|
|
|
|
# ARCROSSDEV If required, an alternative prefix used when
|
|
|
|
# invoking ar and nm.
|
|
|
|
# ARCHCPUFLAGS CPU-specific flags selecting the instruction set
|
|
|
|
# FPU options, etc.
|
|
|
|
# MAXOPTIMIZATION The maximum optimization level that results in
|
|
|
|
# reliable code generation.
|
|
|
|
#
|
|
|
|
|
2019-03-19 18:51:29 +01:00
|
|
|
ifeq ($(CONFIG_ARM_THUMB),y)
|
|
|
|
ARCHCPUFLAGS += -mthumb
|
|
|
|
endif
|
2019-03-19 23:56:04 +01:00
|
|
|
|
2019-03-19 18:51:29 +01:00
|
|
|
ifeq ($(CONFIG_ARCH_FPU),y)
|
|
|
|
ARCHCPUFLAGS += -mfloat-abi=hard
|
|
|
|
endif
|
2019-03-19 23:56:04 +01:00
|
|
|
|
2019-03-19 18:51:29 +01:00
|
|
|
ifeq ($(CONFIG_ARCH_CORTEXA5),y)
|
|
|
|
ARCHCPUFLAGS += -mcpu=cortex-a5
|
2019-03-20 15:17:38 +01:00
|
|
|
else ifeq ($(CONFIG_ARCH_CORTEXA7),y)
|
2019-03-19 18:51:29 +01:00
|
|
|
ARCHCPUFLAGS += -mcpu=cortex-a7
|
2019-03-20 15:17:38 +01:00
|
|
|
else ifeq ($(CONFIG_ARCH_CORTEXA8),y)
|
2019-03-19 18:51:29 +01:00
|
|
|
ARCHCPUFLAGS += -mcpu=cortex-a8
|
2019-03-20 15:17:38 +01:00
|
|
|
else ifeq ($(CONFIG_ARCH_CORTEXA9),y)
|
2019-03-19 18:51:29 +01:00
|
|
|
ARCHCPUFLAGS += -mcpu=cortex-a9
|
|
|
|
endif
|
|
|
|
|
2014-01-24 14:45:35 +01:00
|
|
|
ifeq ($(CONFIG_DEBUG_CUSTOMOPT),y)
|
|
|
|
MAXOPTIMIZATION := $(CONFIG_DEBUG_OPTLEVEL)
|
|
|
|
endif
|
|
|
|
|
2015-12-27 01:13:01 +01:00
|
|
|
ifeq ($(CONFIG_ENDIAN_BIG),y)
|
|
|
|
TARGET_ARCH := armeb
|
|
|
|
else
|
|
|
|
TARGET_ARCH := arm
|
|
|
|
endif
|
|
|
|
|
2013-07-18 23:20:47 +02:00
|
|
|
# NuttX buildroot under Linux or Cygwin
|
|
|
|
|
|
|
|
ifeq ($(CONFIG_ARMV7A_TOOLCHAIN),BUILDROOT)
|
|
|
|
ifeq ($(CONFIG_ARMV7A_OABI_TOOLCHAIN),y)
|
2015-12-27 01:13:01 +01:00
|
|
|
CROSSDEV ?= $(TARGET_ARCH)-nuttx-elf-
|
|
|
|
ARCROSSDEV ?= $(TARGET_ARCH)-nuttx-elf-
|
2013-07-18 23:20:47 +02:00
|
|
|
else
|
2015-12-27 01:13:01 +01:00
|
|
|
CROSSDEV ?= $(TARGET_ARCH)-nuttx-eabi-
|
|
|
|
ARCROSSDEV ?= $(TARGET_ARCH)-nuttx-eabi-
|
2013-07-18 23:20:47 +02:00
|
|
|
endif
|
2014-01-24 14:45:35 +01:00
|
|
|
MAXOPTIMIZATION ?= -Os
|
2013-07-18 23:20:47 +02:00
|
|
|
endif
|
|
|
|
|
|
|
|
# CodeSourcery under Linux
|
|
|
|
|
|
|
|
ifeq ($(CONFIG_ARMV7A_TOOLCHAIN),CODESOURCERYL)
|
2015-12-27 01:13:01 +01:00
|
|
|
CROSSDEV ?= $(TARGET_ARCH)-none-eabi-
|
|
|
|
ARCROSSDEV ?= $(TARGET_ARCH)-none-eabi-
|
2014-01-24 14:45:35 +01:00
|
|
|
MAXOPTIMIZATION ?= -O2
|
2013-07-18 23:20:47 +02:00
|
|
|
endif
|
|
|
|
|
|
|
|
# CodeSourcery under Windows
|
|
|
|
|
|
|
|
ifeq ($(CONFIG_ARMV7A_TOOLCHAIN),CODESOURCERYW)
|
2015-12-27 01:13:01 +01:00
|
|
|
CROSSDEV ?= $(TARGET_ARCH)-none-eabi-
|
|
|
|
ARCROSSDEV ?= $(TARGET_ARCH)-none-eabi-
|
2014-01-24 14:45:35 +01:00
|
|
|
MAXOPTIMIZATION ?= -O2
|
2016-01-09 23:34:33 +01:00
|
|
|
ifeq ($(CONFIG_WINDOWS_CYGWIN),y)
|
2013-07-18 23:20:47 +02:00
|
|
|
WINTOOL = y
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
|
|
|
# devkitARM under Windows
|
|
|
|
|
|
|
|
ifeq ($(CONFIG_ARMV7A_TOOLCHAIN),DEVKITARM)
|
2015-12-27 01:13:01 +01:00
|
|
|
CROSSDEV ?= $(TARGET_ARCH)-eabi-
|
|
|
|
ARCROSSDEV ?= $(TARGET_ARCH)-eabi-
|
2016-01-09 23:34:33 +01:00
|
|
|
ifeq ($(CONFIG_WINDOWS_CYGWIN),y)
|
2013-07-18 23:20:47 +02:00
|
|
|
WINTOOL = y
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
2020-04-26 04:44:18 +02:00
|
|
|
# Generic GNU EABI toolchain on macOS, Linux or any typical Posix system
|
2013-07-18 23:20:47 +02:00
|
|
|
|
|
|
|
ifeq ($(CONFIG_ARMV7A_TOOLCHAIN),GNU_EABIL)
|
2015-12-27 01:13:01 +01:00
|
|
|
CROSSDEV ?= $(TARGET_ARCH)-none-eabi-
|
|
|
|
ARCROSSDEV ?= $(TARGET_ARCH)-none-eabi-
|
2014-01-24 14:45:35 +01:00
|
|
|
MAXOPTIMIZATION ?= -Os
|
2013-07-18 23:20:47 +02:00
|
|
|
endif
|
|
|
|
|
|
|
|
# Generic GNU EABI toolchain under Windows
|
|
|
|
|
|
|
|
ifeq ($(CONFIG_ARMV7A_TOOLCHAIN),GNU_EABIW)
|
2015-12-27 01:13:01 +01:00
|
|
|
CROSSDEV ?= $(TARGET_ARCH)-none-eabi-
|
|
|
|
ARCROSSDEV ?= $(TARGET_ARCH)-none-eabi-
|
2014-01-24 14:45:35 +01:00
|
|
|
MAXOPTIMIZATION ?= -Os
|
2016-01-09 23:34:33 +01:00
|
|
|
ifeq ($(CONFIG_WINDOWS_CYGWIN),y)
|
2013-07-18 23:20:47 +02:00
|
|
|
WINTOOL = y
|
|
|
|
endif
|
|
|
|
endif
|