Line 1... |
Line 1... |
# makfile configuration
|
# makfile configuration
|
NAME = hw_uart
|
NAME = hw_uart
|
OBJECTS = main.o
|
OBJECTS = main.o cprintf.o
|
|
|
CFLAGS = -O2 -Wall -g -mcpu=430 -mivcnt=16 -mmpy=16 # 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=16bit
|
|
else
|
|
CFLAGS = -D PFX_MSP430 $(PORT_CFLAGS) ${WARNINGS} -g -mcpu=430 -mmpy=16 -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 download-jtag download-bsl dist
|
|
|
.PHONY: all FORCE clean download 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
|
|
|
#confgigure the next line if you want to use the serial download
|
#confgigure the next line if you want to use the serial download
|
download: download-uart
|
download: download-uart
|
#download: download-jtag
|
|
#download: download-bsl
|
|
|
|
#additional rules for files
|
#additional rules for files
|
${NAME}.elf: ${OBJECTS}
|
${NAME}.elf: ${OBJECTS}
|
${CC} -Tlinker.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 *.o
|
rm -f ${NAME}.elf ${NAME}.a43 ${NAME}.lst ${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
|
|
|
#dummy target as dependecy if something has to be build everytime
|
#dummy target as dependecy if something has to be build everytime
|
FORCE:
|
FORCE:
|
|
|
#project dependencies
|
#project dependencies
|
main.o: main.c hardware.h
|
main.o: main.c hardware.h
|
|
cprintf.o: cprintf.c cprintf.h
|