mirror of https://gerrit.osmocom.org/simtrace2
335 lines
12 KiB
Makefile
335 lines
12 KiB
Makefile
# ----------------------------------------------------------------------------
|
|
# ATMEL Microcontroller Software Support
|
|
# ----------------------------------------------------------------------------
|
|
# Copyright (c) 2010, Atmel Corporation
|
|
#
|
|
# All rights reserved.
|
|
#
|
|
# Redistribution and use in source and binary forms, with or without
|
|
# modification, are permitted provided that the following conditions are met:
|
|
#
|
|
# - Redistributions of source code must retain the above copyright notice,
|
|
# this list of conditions and the disclaimer below.
|
|
#
|
|
# Atmel's name may not be used to endorse or promote products derived from
|
|
# this software without specific prior written permission.
|
|
#
|
|
# DISCLAIMER: THIS SOFTWARE IS PROVIDED BY ATMEL "AS IS" AND ANY EXPRESS OR
|
|
# IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
|
|
# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT ARE
|
|
# DISCLAIMED. IN NO EVENT SHALL ATMEL 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.
|
|
# ----------------------------------------------------------------------------
|
|
|
|
# Makefile for compiling the Getting Started with SAM3S Microcontrollers project
|
|
|
|
GIT_VERSION=$(shell $(TOP)/git-version-gen $(TOP)/.tarball-version)
|
|
|
|
CFLAGS = \
|
|
-Werror=format-security \
|
|
-Wformat \
|
|
-g \
|
|
$(NULL)
|
|
|
|
#-------------------------------------------------------------------------------
|
|
# User-modifiable options
|
|
#-------------------------------------------------------------------------------
|
|
|
|
# verbosity
|
|
V ?= 0
|
|
ifneq ("$(V)","0")
|
|
SILENT :=
|
|
else
|
|
SILENT := @
|
|
endif
|
|
|
|
# Chip & board used for compilation
|
|
# (can be overriden by adding CHIP=chip and BOARD=board to the command-line)
|
|
CHIP ?= sam3s4
|
|
BOARD ?= qmod
|
|
APP ?= dfu
|
|
|
|
# Defines which are the available memory targets for the SAM3S-EK board.
|
|
ifeq ($(APP), dfu)
|
|
MEMORIES ?= flash
|
|
TRACE_LEVEL ?= 0
|
|
else
|
|
MEMORIES ?= dfu
|
|
endif
|
|
|
|
# Output directories and filename
|
|
OUTPUT = $(BOARD)-$(APP)
|
|
BIN = bin
|
|
OBJ = obj/$(BOARD)
|
|
|
|
#-------------------------------------------------------------------------------
|
|
# Tools
|
|
#-------------------------------------------------------------------------------
|
|
|
|
AT91LIB = ./atmel_softpack_libraries
|
|
|
|
AT91LIB_USB_COMMON_CORE_PATH = $(AT91LIB)/usb/common/core
|
|
AT91LIB_USB_CORE_PATH = $(AT91LIB)/usb/device/core
|
|
AT91LIB_USB_DFU_PATH = $(AT91LIB)/usb/device/dfu
|
|
|
|
# Tool suffix when cross-compiling
|
|
CROSS_COMPILE = arm-none-eabi-
|
|
|
|
USE_CLANG ?= 0
|
|
ifneq ("$(USE_CLANG)","0")
|
|
# --target=thumbv7m-none-eabi
|
|
CC = clang
|
|
LD = ld.lld
|
|
SIZE = llvm-size
|
|
LIBS = -nostdlib
|
|
else
|
|
CC = $(CROSS_COMPILE)gcc
|
|
LD = $(CROSS_COMPILE)ld
|
|
SIZE = $(CROSS_COMPILE)size
|
|
LIBS = -Wl,--start-group -lgcc -Wl,--end-group -nostdlib
|
|
endif
|
|
|
|
STRIP = $(CROSS_COMPILE)strip
|
|
OBJCOPY = $(CROSS_COMPILE)objcopy
|
|
GDB = $(CROSS_COMPILE)gdb
|
|
NM = $(CROSS_COMPILE)nm
|
|
|
|
TOP=..
|
|
|
|
#-------------------------------------------------------------------------------
|
|
# Files
|
|
#-------------------------------------------------------------------------------
|
|
|
|
# Directories where source files can be found
|
|
|
|
USB_PATHS = $(AT91LIB_USB_CORE_PATH) $(AT91LIB_USB_DFU_PATH) $(AT91LIB_USB_COMMON_CORE_PATH)
|
|
|
|
VPATH += $(USB_PATHS)
|
|
VPATH += $(AT91LIB)/libchip_sam3s/source/ $(AT91LIB)/libchip_sam3s/cmsis
|
|
VPATH += libboard/common/source libboard/$(BOARD)/source
|
|
VPATH += libcommon/source
|
|
VPATH += libosmocore/source
|
|
VPATH += apps/$(APP)
|
|
|
|
# Objects built from C source files
|
|
C_OSMOCORE = $(notdir $(wildcard libosmocore/source/*.c))
|
|
C_LIBCHIP = $(notdir $(wildcard $(AT91LIB)/libchip_sam3s/source/*.c) $(wildcard $(AT91LIB)/libchip_sam3s/cmsis/*.c))
|
|
|
|
C_LIBUSB = USBDescriptors.c USBRequests.c USBD.c USBDCallbacks.c USBDDriver.c USBDDriverCallbacks.c
|
|
C_LIBUSB_RT = dfu.c dfu_runtime.c
|
|
C_LIBUSB_DFU = dfu.c dfu_desc.c dfu_driver.c
|
|
C_LIBCOMMON = string.c stdio.c fputs.c usb_buf.c ringbuffer.c pseudo_talloc.c host_communication.c \
|
|
main_common.c stack_check.c crcstub.c
|
|
|
|
C_BOARD = $(notdir $(wildcard libboard/common/source/*.c))
|
|
C_BOARD += $(notdir $(wildcard libboard/$(BOARD)/source/*.c))
|
|
|
|
C_APPLEVEL = $(notdir $(wildcard apps/$(APP)/*.c))
|
|
|
|
C_FILES = $(C_OSMOCORE) $(C_LIBCHIP) $(C_LIBUSB) $(C_LIBCOMMON) $(C_BOARD) $(C_APPLEVEL)
|
|
|
|
-include apps/$(APP)/Makefile
|
|
|
|
C_OBJECTS = $(C_FILES:%.c=%.o)
|
|
|
|
# Trace level used for compilation
|
|
# (can be overriden by adding TRACE_LEVEL=#number to the command-line)
|
|
# TRACE_LEVEL_DEBUG 5
|
|
# TRACE_LEVEL_INFO 4
|
|
# TRACE_LEVEL_WARNING 3
|
|
# TRACE_LEVEL_ERROR 2
|
|
# TRACE_LEVEL_FATAL 1
|
|
# TRACE_LEVEL_NO_TRACE 0
|
|
TRACE_LEVEL ?= 4
|
|
|
|
# allow asserting the peer SAM3S ERASE signal to completely erase the flash
|
|
# only applicable for qmod board
|
|
ALLOW_PEER_ERASE?=0
|
|
|
|
#CFLAGS+=-DUSB_NO_DEBUG=1
|
|
|
|
# Optimization level, put in comment for debugging
|
|
ifneq ("$(USE_CLANG)","0")
|
|
OPTIMIZATION ?= -Oz
|
|
else
|
|
OPTIMIZATION ?= -Os
|
|
endif
|
|
|
|
# Flags
|
|
INCLUDES_USB = -I$(AT91LIB)/usb/include -I$(AT91LIB)
|
|
|
|
INCLUDES = $(INCLUDES_USB)
|
|
INCLUDES += -I$(AT91LIB)/libchip_sam3s -I$(AT91LIB)/libchip_sam3s/include
|
|
INCLUDES += -I$(AT91LIB)/libchip_sam3s/cmsis
|
|
INCLUDES += -Ilibboard/common/include -Ilibboard/$(BOARD)/include
|
|
INCLUDES += -Ilibcommon/include
|
|
INCLUDES += -Ilibosmocore/include
|
|
INCLUDES += -Isrc_simtrace -Iinclude
|
|
INCLUDES += -Iapps/$(APP)
|
|
|
|
ifneq ("$(USE_CLANG)","0")
|
|
CFLAGS += -Wno-unknown-warning-option -Wno-empty-body -fno-exceptions -fno-unwind-tables --config armv7em_soft_nofp_nosys
|
|
else
|
|
CFLAGS += -Wno-suggest-attribute=noreturn --param max-inline-insns-single=500
|
|
endif
|
|
CFLAGS += -Wall -Wchar-subscripts -Wcomment -Wimplicit-int -Wformat=2
|
|
CFLAGS += -Werror-implicit-function-declaration -Wmain -Wparentheses
|
|
CFLAGS += -Wsequence-point -Wreturn-type -Wswitch -Wtrigraphs #-Wunused
|
|
CFLAGS += -Wuninitialized -Wunknown-pragmas -Wfloat-equal #-Wundef
|
|
CFLAGS += -Wshadow -Wpointer-arith -Wbad-function-cast -Wwrite-strings
|
|
CFLAGS += -Waggregate-return #-Wsign-compare
|
|
CFLAGS += -Wmissing-format-attribute -Wno-deprecated-declarations
|
|
CFLAGS += #-Wpacked
|
|
CFLAGS += -Wredundant-decls -Wnested-externs #-Winline -Wlong-long
|
|
CFLAGS += -Wunreachable-code
|
|
#CFLAGS += -Wcast-align
|
|
#CFLAGS += -std=c11
|
|
#CFLAGS += -Wmissing-noreturn
|
|
#CFLAGS += -Wconversion
|
|
CFLAGS += -Wno-unused-but-set-variable -Wno-unused-variable
|
|
|
|
|
|
# -mlong-calls -Wall
|
|
#CFLAGS += -save-temps -fverbose-asm
|
|
#CFLAGS += -Wa,-a,-ad
|
|
CFLAGS += -D__ARM -fno-builtin
|
|
CFLAGS += -mcpu=cortex-m3 -mthumb # -mfix-cortex-m3-ldrd
|
|
CFLAGS += -ffunction-sections -g $(OPTIMIZATION) $(INCLUDES) -D$(CHIP) -DTRACE_LEVEL=$(TRACE_LEVEL) -DALLOW_PEER_ERASE=$(ALLOW_PEER_ERASE)
|
|
CFLAGS += -DGIT_VERSION=\"$(GIT_VERSION)\"
|
|
CFLAGS += -DBOARD=\"$(BOARD)\" -DBOARD_$(BOARD)
|
|
CFLAGS += -DAPPLICATION=\"$(APP)\" -DAPPLICATION_$(APP)
|
|
|
|
# Disable stack protector by default (OS#5081)
|
|
ifeq ($(STACK_PROTECTOR), 1)
|
|
CFLAGS += -fstack-protector
|
|
else
|
|
CFLAGS += -fno-stack-protector
|
|
endif
|
|
|
|
ASFLAGS = -mcpu=cortex-m3 -mthumb -Wall -g $(OPTIMIZATION) $(INCLUDES) -D$(CHIP) -D__ASSEMBLY__
|
|
LDFLAGS = -mcpu=cortex-m3 -mthumb -Wl,--check-sections -Wl,--gc-sections -Wl,--entry=ResetException -Wl,--unresolved-symbols=report-all -Wl,--warn-common -Wl,--no-undefined $(LIB)
|
|
ifeq ("$(USE_CLANG)","0")
|
|
LDFLAGS += -Wl,--warn-section-align -Wl,--print-memory-usage
|
|
endif
|
|
#LD_OPTIONAL=-Wl,--print-gc-sections -Wl,--stats
|
|
|
|
# Append BIN directories to output filename
|
|
OUTPUT := $(BIN)/$(OUTPUT)
|
|
|
|
#-------------------------------------------------------------------------------
|
|
# Rules
|
|
#-------------------------------------------------------------------------------
|
|
|
|
all: $(BIN) $(OBJ) $(MEMORIES)
|
|
|
|
combined: $(OUTPUT)-combined.bin
|
|
|
|
$(BIN)/$(BOARD)-dfu-flash-padded.bin: $(BIN)/$(BOARD)-dfu-flash.bin
|
|
dd if=/dev/zero bs=16384 count=1 of=$@
|
|
dd if=$< conv=notrunc of=$@
|
|
|
|
$(OUTPUT)-combined.bin: $(BIN)/$(BOARD)-dfu-flash-padded.bin $(OUTPUT)-dfu.bin
|
|
cat $^ > $@
|
|
|
|
$(BIN) $(OBJ): apps/$(APP)/usb_strings_generated.h misc/crctool
|
|
mkdir -p $@
|
|
|
|
usbstring/usbstring: usbstring/usbstring.c
|
|
gcc $^ -o $@
|
|
|
|
misc/crctool: misc/crctool.c
|
|
gcc $^ -o $@
|
|
|
|
.PHONY: apps/$(APP)/usb_strings.txt.patched
|
|
apps/$(APP)/usb_strings.txt.patched: apps/$(APP)/usb_strings.txt
|
|
sed "s/PRODUCT_STRING/$(shell cat libboard/$(BOARD)/product_string.txt)/" $< > $@
|
|
|
|
apps/$(APP)/usb_strings_generated.h: apps/$(APP)/usb_strings.txt.patched usbstring/usbstring
|
|
cat $< | usbstring/usbstring > $@
|
|
|
|
define RULES
|
|
C_OBJECTS_$(1) = $(addprefix $(OBJ)/$(1)_, $(C_OBJECTS))
|
|
ASM_OBJECTS_$(1) = $(addprefix $(OBJ)/$(1)_, $(ASM_OBJECTS))
|
|
EXTRA_OBJECTS_$(1) = $(addprefix $(OBJ)/$(1)_, $(EXTRA_OBJECTS))
|
|
|
|
build_$(1): $$(ASM_OBJECTS_$(1)) $$(C_OBJECTS_$(1)) $$(EXTRA_OBJECTS_$(1))
|
|
$(SILENT)$(CC) $(CFLAGS) $(LDFLAGS) $(LD_OPTIONAL) -T"libboard/common/resources/$(CHIP)/$(1).ld" -Wl,-Map,$(OUTPUT)-$(1).map -o $(OUTPUT)-$(1).elf $$^ $(LIBS)
|
|
$(SILENT)$(NM) $(OUTPUT)-$(1).elf >$(OUTPUT)-$(1).elf.txt
|
|
$(SILENT)$(OBJCOPY) -O binary $(OUTPUT)-$(1).elf $(OUTPUT)-$(1).bin
|
|
|
|
$$(C_OBJECTS_$(1)): $(OBJ)/$(1)_%.o: %.c Makefile $(OBJ) $(BIN)
|
|
@echo [COMPILING $$<]
|
|
$(SILENT)$(CC) $(CFLAGS) -DENVIRONMENT_$(1) -DENVIRONMENT=\"$(1)\" -c -o $$@ $$<
|
|
|
|
$$(ASM_OBJECTS_$(1)): $(OBJ)/$(1)_%.o: %.S Makefile $(OBJ) $(BIN)
|
|
@echo [ASSEMBLING $$@]
|
|
$(SILENT)$(CC) $(ASFLAGS) -DENVIRONMENT_$(1) -DENVIRONMENT=\"$(1)\" -c -o $$@ $$<
|
|
|
|
endef
|
|
|
|
ALL_MEMORIES = flash ram
|
|
$(foreach MEMORY, $(ALL_MEMORIES), $(eval $(call RULES,$(MEMORY))))
|
|
|
|
# files with those names do exist..
|
|
.PHONY: dfu
|
|
dfu: $(OUTPUT)-dfu.bin
|
|
.PHONY: ram
|
|
ram: build_ram
|
|
.PHONY: flash
|
|
flash: build_flash
|
|
#alternate way of embedding: obj file
|
|
#ifeq ($(APP), dfu)
|
|
# $(info bootloader bin file to obj..)
|
|
# $(SILENT)$(OBJCOPY) --rename-section .data=.fwupdate -I binary -O elf32-littlearm bin/$(BOARD)-dfu-flash.bin $(OBJ)/flash_fwupdate.o
|
|
#endif
|
|
|
|
C_OBJECTS_dfu = $(addprefix $(OBJ)/dfu_, $(C_OBJECTS))
|
|
ASM_OBJECTS_dfu = $(addprefix $(OBJ)/dfu_, $(ASM_OBJECTS))
|
|
EXTRA_OBJECTS_dfu = $(addprefix $(OBJ)/dfu_, $(EXTRA_OBJECTS))
|
|
|
|
$(OUTPUT)-dfu.bin: $(OUTPUT)-dfu_nocrcstub.bin
|
|
$(info updating app with crc..)
|
|
$(SILENT)cp $< $@.temp
|
|
$(SILENT)misc/crctool 512 $@.temp
|
|
$(SILENT)mv $@.temp $@
|
|
|
|
$(OUTPUT)-dfu_nocrcstub.bin: $(OUTPUT)-dfu_nocrcstub.elf
|
|
ifeq ($(APP), blupdate)
|
|
$(info updating updater section with padded bootloader file..)
|
|
$(SILENT)dd status=none if=/dev/zero bs=16384 count=1 of=$(BIN)/$(BOARD)-dfu-flash-padded.bin
|
|
$(SILENT)dd status=none if=$(BIN)/$(BOARD)-dfu-flash.bin conv=notrunc of=$(BIN)/$(BOARD)-dfu-flash-padded.bin
|
|
$(SILENT)$(OBJCOPY) --update-section .blupdate=bin/$(BOARD)-dfu-flash-padded.bin $<
|
|
endif
|
|
$(SILENT)$(OBJCOPY) -O binary $< $@
|
|
|
|
$(OUTPUT)-dfu_nocrcstub.elf: $(ASM_OBJECTS_dfu) $(C_OBJECTS_dfu) $(EXTRA_OBJECTS_dfu)
|
|
$(SILENT)$(CC) $(CFLAGS) $(LDFLAGS) $(LD_OPTIONAL) -T"libboard/common/resources/$(CHIP)/dfu.ld" -Wl,-Map,$(OUTPUT)-dfu_nocrcstub.map -o $@ $^ $(LIBS)
|
|
$(SILENT)$(NM) $@ >$@.txt
|
|
|
|
$(C_OBJECTS_dfu): $(OBJ)/dfu_%.o: %.c Makefile $(OBJ) $(BIN)
|
|
@echo [COMPILING $<]
|
|
$(SILENT)$(CC) $(CFLAGS) -DENVIRONMENT_dfu -DENVIRONMENT=\"dfu\" -c -o $@ $<
|
|
|
|
$(ASM_OBJECTS_dfu): $(OBJ)/dfu_%.o: %.S Makefile $(OBJ) $(BIN)
|
|
@echo [ASSEMBLING $@]
|
|
$(SILENT)$(CC) $(ASFLAGS) -DENVIRONMENT_dfu -DENVIRONMENT=\"dfu\" -c -o$@ $<
|
|
|
|
|
|
SERIAL ?= /dev/ttyUSB0
|
|
log:
|
|
stty -F $(SERIAL) 921600
|
|
lsof $(SERIAL) && echo "log is already opened" || ( sed -u "s/\r//" $(SERIAL) | ts )
|
|
|
|
clean:
|
|
-rm -f apps/$(APP)/usb_strings.txt.patched
|
|
-rm -fR $(OBJ)/*.o $(BIN)/*.bin $(BIN)/*.elf $(BIN)/*.elf.txt $(BIN)/*.map $(BIN)/*.lst `find . -name \*.p`
|
|
|
|
install:
|
|
mkdir -p $(DESTDIR)/usr/share/simtrace2
|
|
cp $(BIN)/*.bin $(BIN)/*.elf $(BIN)/*.elf.txt $(BIN)/*.map $(DESTDIR)/usr/share/simtrace2
|