1
0
mirror of https://github.com/rene-dev/stmbl.git synced 2025-01-02 05:52:28 +00:00
stmbl/context_switch/Makefile

74 lines
2.0 KiB
Makefile
Raw Permalink Normal View History

2014-03-29 03:12:44 +00:00
# put your *.o targets here, make should handle the rest!
SRCS = main.c stm32f4xx_it.c system_stm32f4xx.c stlinky.c printf.c scanf.c param.c stm32_ub_dac_dma.c setup.c stm32_ub_encoder_tim3.c
#SRCS = main.c system.c
# all the files will be generated with this name (main.elf, main.bin, main.hex, etc)
PROJ_NAME=main
# Put your stlink folder here so make burn will work.
#STLINK=/mnt/share/Programming/embedded/stm32/stlink
# that's it, no need to change anything below this line!
###################################################
STLINK=/Users/crinq/Documents/sandbox/stlink/
CC=/Volumes/cross/gcc-arm-none-eabi-4_7-2013q3/bin/arm-none-eabi-gcc
OBJCOPY=/Volumes/cross/gcc-arm-none-eabi-4_7-2013q3/bin/arm-none-eabi-objcopy
SYMBOLS=/Volumes/cross/gcc-arm-none-eabi-4_7-2013q3/bin/arm-none-eabi-nm
CFLAGS = -g -Wall -Tstm32_flash.ld -std=gnu99
CFLAGS += -mlittle-endian -mthumb -mcpu=cortex-m4 -mthumb-interwork -nostartfiles
CFLAGS += -mfloat-abi=hard -mfpu=fpv4-sp-d16 -nostartfiles -fsingle-precision-constant
###################################################
vpath %.c src
vpath %.a lib
ROOT=$(shell pwd)
CFLAGS += -Iinc -Ilib -Ilib/inc
CFLAGS += -Ilib/inc/core -Ilib/inc/peripherals
SRCS += lib/startup_stm32f4xx.s # add startup file to build
OBJS = $(SRCS:.c=.o)
###################################################
.PHONY: lib proj
all: lib proj
again: clean all
# Flash the STM32F4
burn: main.elf
$(STLINK)st-flash --reset write $(PROJ_NAME).bin 0x8000000
# Create tags; assumes ctags exists
ctags:
ctags -R --exclude=*cm0.h --exclude=*cm3.h .
lib:
$(MAKE) -C lib
proj: $(PROJ_NAME).elf
term: $(PROJ_NAME).elf
$(STLINK)st-term `$(SYMBOLS) main.elf | grep stlinky_term | awk '{print $$1}'`
$(PROJ_NAME).elf: $(SRCS)
$(CC) $(CFLAGS) $^ -o $@ -Llib -lstm32f4
$(OBJCOPY) -O ihex $(PROJ_NAME).elf $(PROJ_NAME).hex
$(OBJCOPY) -O binary $(PROJ_NAME).elf $(PROJ_NAME).bin
clean:
rm -f *.o *.i
rm -f $(PROJ_NAME).elf
rm -f $(PROJ_NAME).hex
rm -f $(PROJ_NAME).bin