mirror of
https://gitea.osmocom.org/sim-card/simtrace2.git
synced 2026-03-16 21:28:33 +03:00
DFU flashing of apps sometimes aborts, and although rare this leads to broken devices if no boot button or serial/jtag access exists, because the bootloader will keep trying to start a half-flashed app that then crashes at some point. The easiest fix that works with existing bootloaders is to prepend a small 512 byte stub that calculcates the crc and compares it with the crc calculated at build time, and then either starts the actual app, or sets the dfu flag and resets. This ensures we either have a working, running app, or end up in the bootloader, ready to flash again. For obvious reasons this only applies to dfu apps, and not to flash targets like the actual bootloader itself. Change-Id: Id6df0486c8b779889d21800dc2441b3aa9af8a5f
328 lines
12 KiB
Makefile
328 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)
|
|
#-------------------------------------------------------------------------------
|
|
# 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
|