view BSDmakefile @ 1:7a08db98ae8b

Split out compile flags for easier editing. Allow toolchain suffixes (needed for when arm-elf works). Add debug target.
author Daniel O'Connor <darius@dons.net.au>
date Sat, 08 Oct 2011 20:33:47 +1030
parents c59513fd84fb
children 74e9b3baac1e
line wrap: on
line source

PROG=		main

SRCS=		main.c \
		comm.c \
		syscalls.c \
		startup_stm32f10x_md_mthomas.c \
		core_cm3.c \
		system_stm32f10x.c \
		stm32f10x_usart.c \
		stm32f10x_flash.c \
		stm32f10x_gpio.c \
		stm32f10x_rcc.c \
		stm32f10x_spi.c \
		stm32f10x_rtc.c \
		stm32f10x_bkp.c \
		stm32f10x_pwr.c \
		stm32f10x_dma.c \
		stm32f10x_tim.c \
		misc.c

# Linker file
LINKFILE=	${.CURDIR}/STM32F10x_512k_64k_flash.ld

# Set CPU type
COMMONFLAGS=	-mcpu=cortex-m3
# Enable thumb code (since the Cortex M3 only does thumb)
COMMONFLAGS+=	-mthumb
# Debugging & optimisation
COMMONFLAGS+= -g -Os
# Put functions & data in individual sections to allow the linker to optimise (breaks debugging apparently)
#COMMONFLAGS+=	-ffunction-sections -fdata-sections
# We aren't using exceptions
COMMONFLAGS+=	-fno-exceptions

CFLAGS+=	-I ${.CURDIR}

# Set device type
CFLAGS+=	-DSTM32F10X_MD
# Set clocks
CFLAGS+=	-DHSE_VALUE=8000000UL -DSYSCLK_FREQ_72MHz=72000000 
# Enable STM peripheral drivers
CFLAGS+=	-DUSE_STDPERIPH_DRIVER
# Enable startup delay
#CFLAGS+=	-DSTARTUP_DELAY
# Vector table in flash
CFLAGS+=	-DVECT_TAB_FLASH 
# Enable warnings (disable char-subscripts otherwise ctypes.h generates warnings
CFLAGS+=	-Wall -Wextra -pedantic -Wimplicit -Wcast-align -Wpointer-arith -Wredundant-decls -Wshadow -Wcast-qual -Wcast-align -Wnested-externs -Wno-char-subscripts -std=gnu99

LDFLAGS= 	-nostartfiles -Wl,--gc-sections -lc -lm -lgcc

# Location of STM32 library bits
STMLIB=		${.CURDIR}/libs/STM32F10x_StdPeriph_Lib_V3.5.0
PERIPHDIR=	${STMLIB}/Libraries/STM32F10x_StdPeriph_Driver
COREDIR=	${STMLIB}/Libraries/CMSIS/CM3/CoreSupport
SYSDIR=		${STMLIB}/Libraries/CMSIS/CM3/DeviceSupport/ST/STM32F10x

CFLAGS+=	-I ${PERIPHDIR}/inc
CFLAGS+=	-I ${SYSDIR}
CFLAGS+=	-I ${COREDIR}

.PATH:		${PERIPHDIR}/src
.PATH:		${COREDIR}
.PATH:		${SYSDIR}

debug:
	${GDB} --eval-command="target remote 10.211.55.3:61234" --eval-command "load" ${PROG}.elf

.include "${.CURDIR}/BSDmakefile.arm"