blob: 932dc87a1867c14137bb4bcbf6ac3586292c66ab [file] [log] [blame]
Christina Quastc8ae58b2014-11-28 11:02:16 +01001# ----------------------------------------------------------------------------
2# ATMEL Microcontroller Software Support
3# ----------------------------------------------------------------------------
4# Copyright (c) 2010, Atmel Corporation
5#
6# All rights reserved.
7#
8# Redistribution and use in source and binary forms, with or without
9# modification, are permitted provided that the following conditions are met:
10#
11# - Redistributions of source code must retain the above copyright notice,
12# this list of conditions and the disclaimer below.
13#
14# Atmel's name may not be used to endorse or promote products derived from
15# this software without specific prior written permission.
16#
17# DISCLAIMER: THIS SOFTWARE IS PROVIDED BY ATMEL "AS IS" AND ANY EXPRESS OR
18# IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
19# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT ARE
20# DISCLAIMED. IN NO EVENT SHALL ATMEL BE LIABLE FOR ANY DIRECT, INDIRECT,
21# INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
22# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,
23# OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
24# LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
25# NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
26# EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27# ----------------------------------------------------------------------------
28
29# Makefile for compiling the Getting Started with SAM3S Microcontrollers project
30
31#-------------------------------------------------------------------------------
32# User-modifiable options
33#-------------------------------------------------------------------------------
34
35# Chip & board used for compilation
36# (can be overriden by adding CHIP=chip and BOARD=board to the command-line)
37CHIP = sam3s2
38BOARD = simtrace
39
40# Defines which are the available memory targets for the SAM3S-EK board.
41MEMORIES = flash
42
43# Trace level used for compilation
44# (can be overriden by adding TRACE_LEVEL=#number to the command-line)
45# TRACE_LEVEL_DEBUG 5
46# TRACE_LEVEL_INFO 4
47# TRACE_LEVEL_WARNING 3
48# TRACE_LEVEL_ERROR 2
49# TRACE_LEVEL_FATAL 1
50# TRACE_LEVEL_NO_TRACE 0
Christina Quast33864fa2015-02-27 13:41:34 +010051TRACE_LEVEL = 1
Christina Quast32906bb2015-02-24 11:35:19 +010052#FIXME: Remove this variable
53NOAUTOCALLBACK=no
Christina Quastc8ae58b2014-11-28 11:02:16 +010054
Christina Quastce8fa7e2015-03-13 13:09:51 +010055#CFLAGS+=-DUSB_NO_DEBUG=1
56
Christina Quastc8ae58b2014-11-28 11:02:16 +010057# Optimization level, put in comment for debugging
58OPTIMIZATION = -O0
59
60# Output file basename
61OUTPUT = project
62
63# Output directories
64BIN = bin
65OBJ = obj
66
67#-------------------------------------------------------------------------------
68# Tools
69#-------------------------------------------------------------------------------
70
Christina Quast96493612015-01-03 22:22:36 +010071AT91LIB_USB_COMMON_CORE_PATH = atmel_softpack_libraries/usb/common/core
72AT91LIB_USB_CORE_PATH = atmel_softpack_libraries/usb/device/core
Christina Quast96493612015-01-03 22:22:36 +010073
Christina Quastc8ae58b2014-11-28 11:02:16 +010074# Tool suffix when cross-compiling
75CROSS_COMPILE = arm-none-eabi-
76
Christina Quastf1192c62014-12-05 13:03:27 +010077LIBC_PATH=../Baselibc
78
Christina Quastc8ae58b2014-11-28 11:02:16 +010079LIBS = -Wl,--start-group -lgcc -lc -Wl,--end-group
80#LIB_PATH+=-L=/lib/thumb2
81#LIB_PATH+=-L=/../lib/gcc/arm-none-eabi/4.4.1/thumb2
Christina Quast99f9f7b2014-12-13 13:30:31 +010082LIB += -L=$(LIBC_PATH)/include -lc
Christina Quastc8ae58b2014-11-28 11:02:16 +010083
84# Compilation tools
85CC = $(CROSS_COMPILE)gcc
86LD = $(CROSS_COMPILE)ld
87SIZE = $(CROSS_COMPILE)size
88STRIP = $(CROSS_COMPILE)strip
89OBJCOPY = $(CROSS_COMPILE)objcopy
90GDB = $(CROSS_COMPILE)gdb
91NM = $(CROSS_COMPILE)nm
92
93# Flags
Christina Quast96493612015-01-03 22:22:36 +010094INCLUDES_USB = -Iatmel_softpack_libraries/usb/include
Christina Quast96493612015-01-03 22:22:36 +010095
Christina Quast32906bb2015-02-24 11:35:19 +010096INCLUDES = -Iinclude_board -Iinclude_sam3s -Iinclude -Isimtrace
Christina Quastc8ae58b2014-11-28 11:02:16 +010097INCLUDES += -Icmsis
Christina Quastf1192c62014-12-05 13:03:27 +010098INCLUDES += -I$(LIBC_PATH)/include
Christina Quast96493612015-01-03 22:22:36 +010099INCLUDES += $(INCLUDES_USB)
Christina Quastc8ae58b2014-11-28 11:02:16 +0100100#INCLUDES += -I$(LIBRARIES)
101
Christina Quast32906bb2015-02-24 11:35:19 +0100102CFLAGS += -Wall -Wchar-subscripts -Wcomment -Wimplicit-int #-Wformat=2
Christina Quastc8ae58b2014-11-28 11:02:16 +0100103CFLAGS += -Werror-implicit-function-declaration -Wmain -Wparentheses
Christina Quast96493612015-01-03 22:22:36 +0100104CFLAGS += -Wsequence-point -Wreturn-type -Wswitch -Wtrigraphs #-Wunused
Christina Quastc8ae58b2014-11-28 11:02:16 +0100105CFLAGS += -Wuninitialized -Wunknown-pragmas -Wfloat-equal -Wundef
106CFLAGS += -Wshadow -Wpointer-arith -Wbad-function-cast -Wwrite-strings
107CFLAGS += -Wsign-compare -Waggregate-return
Christina Quast87d141e2015-01-27 14:56:33 +0100108CFLAGS += -Wformat
Christina Quast96493612015-01-03 22:22:36 +0100109CFLAGS += -Wmissing-format-attribute -Wno-deprecated-declarations
Christina Quast87d141e2015-01-27 14:56:33 +0100110CFLAGS += #-Wpacked
Christina Quast96493612015-01-03 22:22:36 +0100111CFLAGS += -Wredundant-decls -Wnested-externs -Winline #-Wlong-long
Christina Quastc8ae58b2014-11-28 11:02:16 +0100112CFLAGS += -Wunreachable-code
113CFLAGS += -Wcast-align
Christina Quast99f9f7b2014-12-13 13:30:31 +0100114CFLAGS += -std=c11
Christina Quast87d141e2015-01-27 14:56:33 +0100115CFLAGS += -Wmissing-noreturn
116#CFLAGS += -Wconversion
Christina Quastd20f26d2015-01-27 14:40:31 +0100117# Disable unused variable warnings
118CFLAGS += -Wno-unused-but-set-variable -Wno-unused-variable
Christina Quast87d141e2015-01-27 14:56:33 +0100119CFLAGS += -Wno-suggest-attribute=noreturn
Christina Quastc8ae58b2014-11-28 11:02:16 +0100120
121# To reduce application size use only integer printf function.
Christina Quast96493612015-01-03 22:22:36 +0100122#CFLAGS += -Dprintf=iprintf
Christina Quastc8ae58b2014-11-28 11:02:16 +0100123
124# -mlong-calls -Wall
125#CFLAGS += -save-temps -fverbose-asm
126#CFLAGS += -Wa,-a,-ad
127CFLAGS += --param max-inline-insns-single=500 -mcpu=cortex-m3 -mthumb # -mfix-cortex-m3-ldrd
128CFLAGS += -ffunction-sections -g $(OPTIMIZATION) $(INCLUDES) -D$(CHIP) -DTRACE_LEVEL=$(TRACE_LEVEL)
129ASFLAGS = -mcpu=cortex-m3 -mthumb -Wall -g $(OPTIMIZATION) $(INCLUDES) -D$(CHIP) -D__ASSEMBLY__
Christina Quastf1192c62014-12-05 13:03:27 +0100130LDFLAGS = -mcpu=cortex-m3 -mthumb -Wl,--cref -Wl,--check-sections -Wl,--gc-sections -Wl,--entry=ResetException -Wl,--unresolved-symbols=report-all -Wl,--warn-common -Wl,--warn-section-align -Wl,--warn-unresolved-symbols $(LIB)
Christina Quastc8ae58b2014-11-28 11:02:16 +0100131#LD_OPTIONAL=-Wl,--print-gc-sections -Wl,--stats
132
133#-------------------------------------------------------------------------------
134# Files
135#-------------------------------------------------------------------------------
136
137# Directories where source files can be found
138
Christina Quast6838fb62015-03-10 15:25:51 +0100139USB_PATHS = $(AT91LIB_USB_CORE_PATH) $(AT91LIB_USB_COMMON_CORE_PATH)
Christina Quast32906bb2015-02-24 11:35:19 +0100140VPATH += src_board src_sam3s cmsis $(USB_PATHS) simtrace
Christina Quastc8ae58b2014-11-28 11:02:16 +0100141
142# Objects built from C source files
143C_CMSIS = core_cm3.o
144C_LOWLEVEL = board_cstartup_gnu.o board_lowlevel.o syscalls.o exceptions.o
Christina Quast531d10b2015-03-19 19:27:04 +0100145C_LIBLEVEL = spi.o pio.o pmc.o usart.o pio_it.o pio_capture.o uart_console.o iso7816_4.o wdt.o led.o tc.o
Christina Quast96493612015-01-03 22:22:36 +0100146C_CCID = cciddriver.o USBD.o USBDDriver.o USBD_HAL.o USBRequests.o USBDCallbacks.o USBDescriptors.o USBDDriverCallbacks.o
Christina Quast531d10b2015-03-19 19:27:04 +0100147C_SIMTRACE = simtrace_iso7816.o usb.o ccid.o sniffer.o phone.o tc_etu.o
Christina Quastc8ae58b2014-11-28 11:02:16 +0100148C_APPLEVEL = main.o
Christina Quastf5462b42015-02-25 18:47:45 +0100149C_OBJECTS = $(C_CMSIS) $(C_LOWLEVEL) $(C_LIBLEVEL) $(C_APPLEVEL) $(C_CCID) $(C_SIMTRACE)
Christina Quastc8ae58b2014-11-28 11:02:16 +0100150
151# Append OBJ and BIN directories to output filename
152OUTPUT := $(BIN)/$(OUTPUT)
153
154#-------------------------------------------------------------------------------
155# Rules
156#-------------------------------------------------------------------------------
157
158all: $(BIN) $(OBJ) $(MEMORIES)
159
160$(BIN) $(OBJ):
161 mkdir $@
162
163define RULES
164C_OBJECTS_$(1) = $(addprefix $(OBJ)/$(1)_, $(C_OBJECTS))
165ASM_OBJECTS_$(1) = $(addprefix $(OBJ)/$(1)_, $(ASM_OBJECTS))
166
167$(1): $$(ASM_OBJECTS_$(1)) $$(C_OBJECTS_$(1))
168 @$(CC) $(LDFLAGS) $(LD_OPTIONAL) -T"$$@.ld" -Wl,-Map,$(OUTPUT)-$$@.map -o $(OUTPUT)-$$@.elf $$^ $(LIBS)
169 $(NM) $(OUTPUT)-$$@.elf >$(OUTPUT)-$$@.elf.txt
170 $(OBJCOPY) -O binary $(OUTPUT)-$$@.elf $(OUTPUT)-$$@.bin
171 $(SIZE) $$^ $(OUTPUT)-$$@.elf
172
173$$(C_OBJECTS_$(1)): $(OBJ)/$(1)_%.o: %.c Makefile $(OBJ) $(BIN)
174 @echo [COMPILING $$@]
Christina Quastd20f26d2015-01-27 14:40:31 +0100175 $(CC) $(CFLAGS) -D$(1) -Wa,-ahlms=$(BIN)/$$*.lst -c -o $$@ $$<
Christina Quastc8ae58b2014-11-28 11:02:16 +0100176
177$$(ASM_OBJECTS_$(1)): $(OBJ)/$(1)_%.o: %.S Makefile $(OBJ) $(BIN)
178 @echo [ASSEMBLING $$@]
179 @$(CC) $(ASFLAGS) -D$(1) -c -o $$@ $$<
180
181debug_$(1): $(1)
182 $(GDB) -x "$(BOARD_LIB)/resources/gcc/$(BOARD)_$(1).gdb" -ex "reset" -readnow -se $(OUTPUT)-$(1).elf
183endef
184
185$(foreach MEMORY, $(MEMORIES), $(eval $(call RULES,$(MEMORY))))
186
187program:
Christina Quast8be71e42014-12-02 13:06:01 +0100188 openocd -f /home/chrysh/ba_thesis/thesis/openocd/openocd.cfg -c "init" -c "halt" -c "flash write_bank 0 ./bin/project-flash.bin 0" -c "reset" -c "shutdown"
Christina Quastc8ae58b2014-11-28 11:02:16 +0100189
190clean:
191 -rm -fR $(OBJ)/*.o $(BIN)/*.bin $(BIN)/*.elf $(BIN)/*.elf.txt $(BIN)/*.map $(BIN)/*.lst
192
193rmbak:
194 -rm *~ $(BIN)/*~