|
|
|
# Makefile
|
|
|
|
|
|
|
|
NAME=quad
|
|
|
|
|
|
|
|
SSRCS=crt0.s
|
|
|
|
CSRCS=main.c i2c.c wmp.c timer.c interrupt.c uart.c event.c matrix.c dcm.c
|
|
|
|
CSRCS+=fisqrt.c stick.c trig.c motor.c led.c watchdog.c panic.c status.c
|
|
|
|
CSRCS+=thrust.c
|
|
|
|
|
|
|
|
#PROJOPTS=-DUSE_UART -DSEND_DCM -DSTICK_DEBUG_CALIBRATE
|
|
|
|
PROJOPTS=-DTIMER_CPPM
|
|
|
|
|
|
|
|
COPTIM?=-O1
|
|
|
|
CFLAGS=-march=armv4t -msoft-float $(COPTIM) -Wall -Werror -Wextra $(PROJOPTS)
|
|
|
|
|
|
|
|
LDSCRIPT=lpc2103_flash.ld
|
|
|
|
|
|
|
|
# To build with the Clang Static Analyzer, use
|
|
|
|
# scan-build --use-cc=arm-elf-gcc make
|
|
|
|
# And uncomment the following line:
|
|
|
|
CC=arm-elf-gcc
|
|
|
|
|
|
|
|
OBJCOPY=arm-elf-objcopy
|
|
|
|
LINT=splint
|
|
|
|
LINTFLAGS=-booltype bool -nolib +charint
|
|
|
|
|
|
|
|
CLEANOBJS=$(OBJS) $(NAME).hex $(NAME).elf $(NAME).bin $(NAME).map .depend
|
|
|
|
|
|
|
|
all: $(NAME).bin
|
|
|
|
|
|
|
|
|
|
|
|
# In theory, nothing below here needs touching for as long as all of the
|
|
|
|
# sources are in a single directory.
|
|
|
|
|
|
|
|
COBJS=$(CSRCS:.c=.o)
|
|
|
|
SOBJS=$(SSRCS:.s=.o)
|
|
|
|
OBJS=$(SOBJS) $(COBJS)
|
|
|
|
|
|
|
|
.SUFFIXES: .elf .hex .bin
|
|
|
|
|
|
|
|
$(OBJS): Makefile
|
|
|
|
|
|
|
|
$(NAME).elf: $(OBJS)
|
|
|
|
$(CC) $(CFLAGS) -nostdlib -nostartfiles -T $(LDSCRIPT) -Wl,-Map -Wl,$(NAME).map -o $(NAME).elf $(OBJS) -lgcc
|
|
|
|
|
|
|
|
run: $(NAME).hex
|
|
|
|
$(FLASHER) -hex -term -control $(NAME).hex $(PORT) $(SPEED) $(OSC)
|
|
|
|
|
|
|
|
.elf.hex:
|
|
|
|
$(OBJCOPY) -O ihex ${.IMPSRC} ${.TARGET}
|
|
|
|
|
|
|
|
.hex.bin:
|
|
|
|
$(OBJCOPY) -I ihex -O binary ${.IMPSRC} ${.TARGET}
|
|
|
|
|
|
|
|
clean:
|
|
|
|
rm -rf $(CLEANOBJS)
|
|
|
|
|
|
|
|
depend:
|
|
|
|
$(CC) -MM $(CFLAGS) -nostdlib -nostartfiles $(CSRCS) >.depend
|
|
|
|
|
|
|
|
lint:
|
|
|
|
$(LINT) $(LINTFLAGS) $(CSRCS)
|
|
|
|
|
|
|
|
.sinclude ".depend"
|