Below is the file 'Makefile' from this revision. You can also download the file.

# 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"