aboutsummaryrefslogblamecommitdiff
path: root/makefiles/toolchain_gnu-arm-eabi.mk
blob: 0a1ee18e944ec0d3d740b63ab42bf63982a113e6 (plain) (tree)
1
2
3
4
5
6



                                                  
                                
 




























                                                                           
                                           


                                                         


                                                                       


                                               
                               






                                                        

































                                                                                                   
                                                                                 









                                                      

                                                          







                                                      

                                                          



                                                      

                                                          









                                                                                 






                                                 


                                              

                          
                           






                                                       
                           





                                                          
                           





                                                   
                           





                                                                  
                           





                                           
                           
                                                                                                




                                                 
                           

                                       
#
# Definitions for a generic GNU ARM-EABI toolchain
#

#$(info TOOLCHAIN  gnu-arm-eabi)

CROSSDEV		 = arm-none-eabi-

CC			 = $(CROSSDEV)gcc
CXX			 = $(CROSSDEV)g++
CPP			 = $(CROSSDEV)gcc -E
LD			 = $(CROSSDEV)ld
AR			 = $(CROSSDEV)ar rcs
NM			 = $(CROSSDEV)nm
OBJCOPY			 = $(CROSSDEV)objcopy
OBJDUMP			 = $(CROSSDEV)objdump

# XXX this is pulled pretty directly from the fmu Make.defs - needs cleanup

MAXOPTIMIZATION		 = -O3

# base CPU flags
ARCHCPUFLAGS_CORTEXM4F	 = -mcpu=cortex-m4 \
			   -mthumb \
			   -march=armv7e-m \
			   -mfpu=fpv4-sp-d16 \
			   -mfloat-abi=hard

ARCHCPUFLAGS_CORTEXM4	 = -mcpu=cortex-m4 \
			   -mthumb \
			   -march=armv7e-m \
			   -mfloat-abi=soft

ARCHCPUFLAGS_CORTEXM3	 = -mcpu=cortex-m3 \
			   -mthumb \
			   -march=armv7-m \
			   -mfloat-abi=soft

ARCHCPUFLAGS		 = $(ARCHCPUFLAGS_$(CONFIG_ARCH))
ifeq ($(ARCHCPUFLAGS),)
$(error Must set CONFIG_ARCH to one of CORTEXM4F, CORTEXM4 or CORTEXM3)
endif

# optimisation flags
ARCHOPTIMIZATION	 = $(MAXOPTIMIZATION) \
			   -g \
			   -fno-strict-aliasing \
			   -fno-strength-reduce \
			   -fomit-frame-pointer \
   			   -funsafe-math-optimizations \
   			   -fno-builtin-printf \
   			   -ffunction-sections \
   			   -fdata-sections

# enable precise stack overflow tracking
# note - requires corresponding support in NuttX
INSTRUMENTATIONDEFINES	 = -finstrument-functions \
			   -ffixed-r10

ARCHCFLAGS		 = -std=gnu99
ARCHCXXFLAGS		 = -fno-exceptions -fno-rtti -std=gnu++0x
ARCHWARNINGS		 = -Wall \
			   -Wextra \
			   -Wdouble-promotion \
			   -Wshadow \
			   -Wfloat-equal \
			   -Wframe-larger-than=1024 \
			   -Wpointer-arith \
			   -Wlogical-op \
			   -Wmissing-declarations \
			   -Wpacked \
			   -Wno-unused-parameter
#   -Wcast-qual  - generates spurious noreturn attribute warnings, try again later
#   -Wconversion - would be nice, but too many "risky-but-safe" conversions in the code
#   -Wcast-align - would help catch bad casts in some cases, but generates too many false positives

ARCHCWARNINGS		 = $(ARCHWARNINGS) \
			   -Wbad-function-cast \
			   -Wstrict-prototypes \
			   -Wold-style-declaration \
			   -Wmissing-parameter-type \
			   -Wmissing-prototypes \
			   -Wnested-externs \
			   -Wunsuffixed-float-constants
ARCHWARNINGSXX		 = $(ARCHWARNINGS)

# pull in *just* libm from the toolchain ... this is grody
LIBM			:= $(shell $(CC) $(ARCHCPUFLAGS) -print-file-name=libm.a)
EXTRA_LIBS		+= $(LIBM)

CFLAGS			 = $(ARCHCFLAGS) \
			   $(ARCHCWARNINGS) \
			   $(ARCHOPTIMIZATION) \
			   $(ARCHCPUFLAGS) \
			   $(ARCHINCLUDES) \
			   $(INSTRUMENTATIONDEFINES) \
			   $(ARCHDEFINES) \
			   $(EXTRADEFINES) \
			   -fno-common \
			   $(addprefix -I,$(INCLUDE_DIRS))

CXXFLAGS		 = $(ARCHCXXFLAGS) \
			   $(ARCHWARNINGSXX) \
			   $(ARCHOPTIMIZATION) \
			   $(ARCHCPUFLAGS) \
			   $(ARCHXXINCLUDES) \
			   $(INSTRUMENTATIONDEFINES) \
			   $(ARCHDEFINES) \
			   $(EXTRADEFINES) \
			   $(addprefix -I,$(INCLUDE_DIRS))

CPPFLAGS		 = $(ARCHINCLUDES) \
			   $(INSTRUMENTATIONDEFINES) \
			   $(ARCHDEFINES) \
			   $(EXTRADEFINES) \
			   $(addprefix -I,$(INCLUDE_DIRS))

AFLAGS			 = $(CFLAGS) -D__ASSEMBLY__

LDFLAGS			+= --warn-common \
			   --gc-sections \
			   -T $(LDSCRIPT) \
			   $(addprefix -L,$(LIB_DIRS))

LIBGCC			:= $(shell $(CC) $(ARCHCPUFLAGS) -print-libgcc-file-name)

# files that the final link depends on
# XXX add libraries that we know about here...
LINK_DEPS		+= $(LDSCRIPT)

# files to include to get automated dependencies
DEP_INCLUDES		 = $(subst .o,.d,$(OBJS))

# compile C source $1 to object $2
# as a side-effect, generate a dependency file
define COMPILE
	@echo "CC <- $1"
	@echo "CC   -> $2"
	@mkdir -p $(dir $2)
	$(Q) $(CC) -MD -c $(CFLAGS) $(abspath $1) -o $2
endef

# compile C++ source $1 to $2
# as a side-effect, generate a dependency file
define COMPILEXX
	@echo "CXX: $1"
	@mkdir -p $(dir $2)
	$(Q) $(CXX) -MD -c $(CXXFLAGS) $(abspath $1) -o $2
endef

# assemble $1 into $2
define ASSEMBLE
	@echo "AS: $1"
	@mkdir -p $(dir $2)
	$(Q) $(CC) -c $(AFLAGS) $(abspath $1) -o $2
endef

# produce partially-linked $1 from files in $2
define PRELINK
	@echo "PRELINK: $1"
	@mkdir -p $(dir $1)
	$(Q) $(LD) -Ur -o $1 $2 && $(OBJCOPY) --localize-hidden $1
endef

# update the archive $1 with the files in $2
define ARCHIVE
	@echo "AR: $2"
	@mkdir -p $(dir $1)
	$(Q) $(AR) $1 $2
endef

# Link the objects in $2 into the binary $1
define LINK
	@echo "LINK: $1"
	@mkdir -p $(dir $1)
	$(Q) $(LD) $(LDFLAGS) -o $1 --start-group $2 $(LIBS) $(EXTRA_LIBS) $(LIBGCC) --end-group
endef

# convert $1 from a linked object to a raw binary
define SYM_TO_BIN
	@echo "BIN: $2"
	@mkdir -p $(dir $2)
	$(Q) $(OBJCOPY) -O binary $1 $2
endef