Line 1... |
Line 1... |
# makfile configuration
|
# makfile configuration
|
NAME = spacewar
|
NAME = spacewar
|
OBJECTS = bzsin.o cline.o compar.o explode.o hardware.o main.o point.o reset.o rocket1.o rocket2.o score.o update.o
|
OBJECTS = bzsin.o cline.o compar.o explode.o hardware.o main.o point.o reset.o rocket1.o rocket2.o score.o update.o
|
|
|
CFLAGS = -O2 -Wall -g -mcpu=430 -mivcnt=16 -mmpy=none # Uniarch flags
|
# Compiler performance option (-Os / -O2 / -O3)
|
|
PORT_CFLAGS = -O2
|
|
|
#switch the compiler (for the internal make rules)
|
# Choose GCC toolchain prefix ('msp430' for MSPGCC / 'msp430-elf' for GCC RedHat/TI)
|
CC = msp430-gcc
|
ifndef MSPGCC_PFX
|
|
MSPGCC_PFX = msp430-elf
|
|
endif
|
|
|
|
# disable some warnings specific to the Dhrystone code
|
|
WARNINGS = -Wall
|
|
|
|
# Select flags depending on selected toolchain
|
|
ifeq ($(MSPGCC_PFX),msp430-elf)
|
|
INCDIR = -I /cad/ti/gcc/include
|
|
CFLAGS = -D PFX_MSP430_ELF $(INCDIR) $(PORT_CFLAGS) ${WARNINGS} -g -mcpu=msp430 -mhwmult=none
|
|
else
|
|
CFLAGS = -D PFX_MSP430 $(PORT_CFLAGS) ${WARNINGS} -g -mcpu=430 -mmpy=none -mivcnt=16
|
|
endif
|
|
|
|
# Toolchain executables
|
|
CC = ${MSPGCC_PFX}-gcc
|
|
OBJCOPY = ${MSPGCC_PFX}-objcopy
|
|
OBJDUMP = ${MSPGCC_PFX}-objdump
|
|
OBJSIZE = ${MSPGCC_PFX}-size
|
|
|
|
.PHONY: all FORCE clean download dist
|
.PHONY: all FORCE clean download download-jtag download-bsl dist
|
|
|
|
#all should be the first target. it's built when make is runwithout args
|
#all should be the first target. it's built when make is runwithout args
|
all: ${NAME}.elf ${NAME}.a43 ${NAME}.lst
|
all: ${NAME}.elf ${NAME}.a43 ${NAME}.lst ${NAME}.size
|
|
|
#serial download
|
#serial download
|
download: download-uart
|
download: download-uart
|
|
|
#additional rules for files
|
#additional rules for files
|
${NAME}.elf: ${OBJECTS}
|
${NAME}.elf: ${OBJECTS}
|
${CC} -T linker.x -o $@ ${OBJECTS}
|
${CC} ${CFLAGS} -T linker.${MSPGCC_PFX}.x -o $@ ${OBJECTS}
|
|
|
${NAME}.a43: ${NAME}.elf
|
${NAME}.a43: ${NAME}.elf
|
msp430-objcopy -O ihex $^ $@
|
${OBJCOPY} -O ihex $^ $@
|
|
|
${NAME}.lst: ${NAME}.elf
|
${NAME}.lst: ${NAME}.elf
|
msp430-objdump -dSt $^ >$@
|
${OBJDUMP} -dSt $^ >$@
|
|
|
download-jtag: all
|
|
msp430-jtag -e ${NAME}.elf
|
|
|
|
download-bsl: all
|
${NAME}.size: ${NAME}.elf
|
msp430-bsl -e ${NAME}.elf
|
${OBJSIZE} $^ >$@
|
|
|
download-uart: all
|
download-uart: all
|
openmsp430-loader.tcl -device /dev/ttyUSB0 -baudrate 115200 ${NAME}.elf
|
openmsp430-loader.tcl -device /dev/ttyUSB0 -baudrate 115200 ${NAME}.elf
|
|
|
clean:
|
clean:
|
rm -f ${NAME} ${NAME}.a43 ${NAME}.lst ${NAME}.elf *.o
|
rm -f ${NAME} ${NAME}.a43 ${NAME}.lst ${NAME}.elf ${NAME}.size *.o
|
|
|
#backup archive
|
#backup archive
|
dist:
|
dist:
|
tar czf dist.tgz *.c *.h *.txt makefile
|
tar czf dist.tgz *.c *.h *.txt makefile
|
|
|