161 lines
3.2 KiB
Text
161 lines
3.2 KiB
Text
|
|
######################################
|
||
|
|
# target
|
||
|
|
######################################
|
||
|
|
TARGET = mspm0_blinky
|
||
|
|
#PART = STM32G030xx
|
||
|
|
#PYOCD_TARGET = stm32g030f6px
|
||
|
|
|
||
|
|
|
||
|
|
######################################
|
||
|
|
# building variables
|
||
|
|
######################################
|
||
|
|
# debug build?
|
||
|
|
DEBUG = 1
|
||
|
|
# optimization for size
|
||
|
|
OPT = -Os
|
||
|
|
|
||
|
|
|
||
|
|
#######################################
|
||
|
|
# paths
|
||
|
|
#######################################
|
||
|
|
# Build path
|
||
|
|
BUILD_DIR = build
|
||
|
|
VND_DIR = ../../mspm0-sdk
|
||
|
|
|
||
|
|
######################################
|
||
|
|
# source
|
||
|
|
######################################
|
||
|
|
# C sources
|
||
|
|
C_SOURCES += \
|
||
|
|
$(VND_DIR)/source/ti/devices/msp/m0p/startup_system_files/gcc/startup_mspm0g350x_gcc.c \
|
||
|
|
ti_msp_dl_config.c \
|
||
|
|
src/main.c
|
||
|
|
|
||
|
|
|
||
|
|
# ASM sources
|
||
|
|
#ASM_SOURCES =
|
||
|
|
|
||
|
|
|
||
|
|
#######################################
|
||
|
|
# binaries
|
||
|
|
#######################################
|
||
|
|
PREFIX = arm-none-eabi-
|
||
|
|
|
||
|
|
CC = $(PREFIX)gcc
|
||
|
|
CP = $(PREFIX)objcopy
|
||
|
|
#SZ = $(PREFIX)size
|
||
|
|
|
||
|
|
BIN = $(CP) -O binary -S
|
||
|
|
|
||
|
|
#######################################
|
||
|
|
# CFLAGS
|
||
|
|
#######################################
|
||
|
|
|
||
|
|
ifeq ($(DEBUG), 1)
|
||
|
|
#DEBUG_FLAGS = -gdwarf-3
|
||
|
|
DEBUG_FLAGS = -g -gstrict-dwarf
|
||
|
|
endif
|
||
|
|
|
||
|
|
# cpu
|
||
|
|
CPU = \
|
||
|
|
-mcpu=cortex-m0plus \
|
||
|
|
-march=armv6-m \
|
||
|
|
-mthumb \
|
||
|
|
-std=c99 \
|
||
|
|
-mfloat-abi=soft \
|
||
|
|
|
||
|
|
DEFINES = -D__MSPM0G3507__
|
||
|
|
|
||
|
|
# fpu
|
||
|
|
FPU =
|
||
|
|
|
||
|
|
# float-abi
|
||
|
|
FLOAT-ABI =
|
||
|
|
|
||
|
|
# mcu
|
||
|
|
MCU = $(CPU) $(FPU) $(FLOAT-ABI)
|
||
|
|
|
||
|
|
# C includes
|
||
|
|
C_INCLUDES += \
|
||
|
|
-I. \
|
||
|
|
-Isrc/inc \
|
||
|
|
-I$(VND_DIR)/source/third_party/CMSIS/Core/Include \
|
||
|
|
-I$(VND_DIR)/source
|
||
|
|
|
||
|
|
# compile gcc flags
|
||
|
|
ADDN_CFLAGS = \
|
||
|
|
-Wall \
|
||
|
|
-fdata-sections \
|
||
|
|
-ffunction-sections
|
||
|
|
|
||
|
|
CFLAGS = $(MCU) $(ADDN_CFLAGS) $(C_INCLUDES) $(DEBUG_FLAGS) $(OPT) $(DEFINES)
|
||
|
|
|
||
|
|
|
||
|
|
# Generate dependency information
|
||
|
|
#CFLAGS += -MMD -MP -MF"$(@:%.o=%.d)"
|
||
|
|
|
||
|
|
|
||
|
|
#ASFLAGS = $(MCU) $(DEBUG_FLAGS) $(OPT) -Wa,--warn
|
||
|
|
|
||
|
|
#######################################
|
||
|
|
# LDFLAGS
|
||
|
|
#######################################
|
||
|
|
# link script
|
||
|
|
LDSCRIPT = device_linker.lds
|
||
|
|
|
||
|
|
LIBDIR =
|
||
|
|
LDFLAGS = \
|
||
|
|
$(MCU) \
|
||
|
|
"-L$(VND_DIR)/source/ti/driverlib/lib/gcc/m0p/mspm0g1x0x_g3x0x" \
|
||
|
|
-l:driverlib.a \
|
||
|
|
-T $(LDSCRIPT) \
|
||
|
|
-nostartfiles \
|
||
|
|
-Wl,-Map=$(BUILD_DIR)/$(TARGET).map \
|
||
|
|
-static \
|
||
|
|
-Wl,--gc-sections \
|
||
|
|
"-L/usr/lib/gcc/arm-none-eabi/14.2.1/thumb/nofp" \
|
||
|
|
-lgcc -lc -lm \
|
||
|
|
--specs=nano.specs \
|
||
|
|
--specs=nosys.specs \
|
||
|
|
-Wl,--print-memory-usage \
|
||
|
|
-Wl,--no-warn-rwx-segments
|
||
|
|
|
||
|
|
# default action: build all
|
||
|
|
all: $(BUILD_DIR)/$(TARGET).elf $(BUILD_DIR)/$(TARGET).bin
|
||
|
|
|
||
|
|
|
||
|
|
#######################################
|
||
|
|
# build the application
|
||
|
|
#######################################
|
||
|
|
# list of objects
|
||
|
|
OBJECTS = $(addprefix $(BUILD_DIR)/,$(notdir $(C_SOURCES:.c=.o)))
|
||
|
|
vpath %.c $(sort $(dir $(C_SOURCES)))
|
||
|
|
|
||
|
|
# list of ASM program objects
|
||
|
|
#OBJECTS += $(addprefix $(BUILD_DIR)/,$(notdir $(ASM_SOURCES:.s=.o)))
|
||
|
|
#vpath %.s $(sort $(dir $(ASM_SOURCES)))
|
||
|
|
|
||
|
|
$(BUILD_DIR)/%.o: %.c Makefile | $(BUILD_DIR)
|
||
|
|
$(CC) -c $(CFLAGS) -Wa,-a,-ad,-alms=$(BUILD_DIR)/$(notdir $(<:.c=.lst)) $< -o $@
|
||
|
|
|
||
|
|
#$(BUILD_DIR)/%.o: %.s Makefile | $(BUILD_DIR)
|
||
|
|
# $(CC) -c $(ASFLAGS) $< -o $@
|
||
|
|
|
||
|
|
#$(LUAOBJECTS) $(OBJECTS)
|
||
|
|
$(BUILD_DIR)/$(TARGET).elf: $(OBJECTS) Makefile
|
||
|
|
$(CC) $(OBJECTS) $(LDFLAGS) -o $@
|
||
|
|
|
||
|
|
$(BUILD_DIR)/%.bin: $(BUILD_DIR)/%.elf | $(BUILD_DIR)
|
||
|
|
$(BIN) $< $@
|
||
|
|
|
||
|
|
$(BUILD_DIR):
|
||
|
|
mkdir $@
|
||
|
|
|
||
|
|
#######################################
|
||
|
|
# clean up
|
||
|
|
#######################################
|
||
|
|
clean:
|
||
|
|
-rm -fR $(BUILD_DIR)
|
||
|
|
|
||
|
|
# *** EOF ***
|