mirror of
https://github.com/Ai-Thinker-Open/Ai-Thinker-Open_RTL8710BX_ALIOS_SDK.git
synced 2025-01-30 00:45:22 +00:00
93 lines
3.7 KiB
Makefile
93 lines
3.7 KiB
Makefile
ifneq ($(filter $(HOST_ARCH), linux),)
|
|
|
|
TOOLCHAIN_PATH :=
|
|
|
|
PATH := $(PATH):/bin:/usr/bin:/usr/local/bin
|
|
CC := $(TOOLCHAIN_PATH)$(TOOLCHAIN_PREFIX)gcc
|
|
CXX := $(TOOLCHAIN_PATH)$(TOOLCHAIN_PREFIX)g++
|
|
AS := $(CC)
|
|
AR := $(TOOLCHAIN_PATH)$(TOOLCHAIN_PREFIX)ar
|
|
LD := $(TOOLCHAIN_PATH)$(TOOLCHAIN_PREFIX)ld
|
|
OPTIONS_IN_FILE_OPTION := @
|
|
|
|
export PATH
|
|
ADD_COMPILER_SPECIFIC_STANDARD_CFLAGS = $(1) $(if $(filter yes,$(MXCHIP_INTERNAL) $(TESTER)),-Werror)
|
|
ADD_COMPILER_SPECIFIC_STANDARD_CXXFLAGS = $(1) $(if $(filter yes,$(MXCHIP_INTERNAL) $(TESTER)),-Werror)
|
|
ADD_COMPILER_SPECIFIC_STANDARD_ADMFLAGS = $(1)
|
|
COMPILER_SPECIFIC_OPTIMIZED_CFLAGS := -Os
|
|
COMPILER_SPECIFIC_UNOPTIMIZED_CFLAGS := -O0
|
|
COMPILER_SPECIFIC_PEDANTIC_CFLAGS := $(COMPILER_SPECIFIC_STANDARD_CFLAGS)
|
|
COMPILER_SPECIFIC_ARFLAGS_CREATE := -rcs
|
|
COMPILER_SPECIFIC_ARFLAGS_ADD := -rcs
|
|
COMPILER_SPECIFIC_ARFLAGS_VERBOSE := -v
|
|
|
|
#debug: no optimize and log enable
|
|
COMPILER_SPECIFIC_DEBUG_CFLAGS := -DDEBUG -ggdb $(COMPILER_SPECIFIC_UNOPTIMIZED_CFLAGS)
|
|
COMPILER_SPECIFIC_DEBUG_CXXFLAGS := -DDEBUG -ggdb $(COMPILER_SPECIFIC_UNOPTIMIZED_CFLAGS)
|
|
COMPILER_SPECIFIC_DEBUG_ASFLAGS := -DDEBUG=1
|
|
COMPILER_SPECIFIC_DEBUG_LDFLAGS := -Wl,--gc-sections -Wl,--cref
|
|
|
|
#release_log: optimize but log enable
|
|
COMPILER_SPECIFIC_RELEASE_LOG_CFLAGS := -ggdb $(COMPILER_SPECIFIC_OPTIMIZED_CFLAGS)
|
|
COMPILER_SPECIFIC_RELEASE_LOG_CXXFLAGS := -ggdb $(COMPILER_SPECIFIC_OPTIMIZED_CFLAGS)
|
|
COMPILER_SPECIFIC_RELEASE_LOG_ASFLAGS :=
|
|
COMPILER_SPECIFIC_RELEASE_LOG_LDFLAGS := -Wl,--gc-sections -Wl,$(COMPILER_SPECIFIC_OPTIMIZED_CFLAGS) -Wl,--cref
|
|
|
|
#release: optimize and log disable
|
|
COMPILER_SPECIFIC_RELEASE_CFLAGS := -DNDEBUG $(COMPILER_SPECIFIC_OPTIMIZED_CFLAGS)
|
|
COMPILER_SPECIFIC_RELEASE_CXXFLAGS := -DNDEBUG $(COMPILER_SPECIFIC_OPTIMIZED_CFLAGS)
|
|
COMPILER_SPECIFIC_RELEASE_ASFLAGS :=
|
|
COMPILER_SPECIFIC_RELEASE_LDFLAGS := -Wl,--gc-sections -Wl,$(COMPILER_SPECIFIC_OPTIMIZED_CFLAGS) -Wl,--cref
|
|
|
|
COMPILER_SPECIFIC_DEPS_FLAG := -MD
|
|
COMPILER_SPECIFIC_COMP_ONLY_FLAG := -c
|
|
COMPILER_SPECIFIC_LINK_MAP = -Wl,-Map,$(1)
|
|
COMPILER_SPECIFIC_LINK_FILES = -Wl,--start-group $(1) -Wl,--end-group
|
|
COMPILER_SPECIFIC_LINK_SCRIPT_DEFINE_OPTION =
|
|
COMPILER_SPECIFIC_LINK_SCRIPT =
|
|
LINKER := $(CC)
|
|
LINK_SCRIPT_SUFFIX := .ld
|
|
TOOLCHAIN_NAME := GCC
|
|
|
|
ENDIAN_CFLAGS_LITTLE := -mlittle-endian
|
|
ENDIAN_CXXFLAGS_LITTLE := -mlittle-endian
|
|
ENDIAN_ASMFLAGS_LITTLE :=
|
|
ENDIAN_LDFLAGS_LITTLE := -mlittle-endian
|
|
CLIB_LDFLAGS_NANO := --specs=nano.specs
|
|
CLIB_LDFLAGS_NANO_FLOAT:= --specs=nano.specs -u _printf_float
|
|
|
|
# Chip specific flags for GCC
|
|
|
|
CPU_CFLAGS :=
|
|
CPU_CXXFLAGS :=
|
|
CPU_ASMFLAGS :=
|
|
CPU_LDFLAGS :=
|
|
CLIB_LDFLAGS_NANO +=
|
|
CLIB_LDFLAGS_NANO_FLOAT +=
|
|
|
|
# $(1) is map file, $(2) is CSV output file
|
|
COMPILER_SPECIFIC_MAPFILE_TO_CSV = $(PYTHON) $(MAPFILE_PARSER) $(1) > $(2)
|
|
|
|
MAPFILE_PARSER :=$(MAKEFILES_PATH)/scripts/map_parse_gcc.py
|
|
|
|
# $(1) is map file, $(2) is CSV output file
|
|
COMPILER_SPECIFIC_MAPFILE_DISPLAY_SUMMARY = $(PYTHON) $(MAPFILE_PARSER) $(1)
|
|
|
|
KILL_OPENOCD_SCRIPT := $(MAKEFILES_PATH)/scripts/kill_openocd.py
|
|
|
|
KILL_OPENOCD = $(PYTHON) $(KILL_OPENOCD_SCRIPT)
|
|
|
|
OBJDUMP := "$(TOOLCHAIN_PATH)$(TOOLCHAIN_PREFIX)objdump$(EXECUTABLE_SUFFIX)"
|
|
OBJCOPY := "$(TOOLCHAIN_PATH)$(TOOLCHAIN_PREFIX)objcopy$(EXECUTABLE_SUFFIX)"
|
|
STRIP := "$(TOOLCHAIN_PATH)$(TOOLCHAIN_PREFIX)strip$(EXECUTABLE_SUFFIX)"
|
|
NM := "$(TOOLCHAIN_PATH)$(TOOLCHAIN_PREFIX)nm$(EXECUTABLE_SUFFIX)"
|
|
|
|
STRIP_OUTPUT_PREFIX := -o
|
|
OBJCOPY_BIN_FLAGS := -O binary -R .eh_frame -R .init -R .fini -R .comment -R .ARM.attributes
|
|
OBJCOPY_HEX_FLAGS := -O ihex -R .eh_frame -R .init -R .fini -R .comment -R .ARM.attributes
|
|
|
|
LINK_OUTPUT_SUFFIX :=.elf
|
|
BIN_OUTPUT_SUFFIX :=.bin
|
|
HEX_OUTPUT_SUFFIX :=.hex
|
|
|
|
endif
|