810c7e87c1f0cd37872cedff09e4f2f8ebaa859c
[fw/openocd] / contrib / loaders / flash / stmqspi / Makefile
1 BIN2C = ../../../../src/helper/bin2char.sh
2
3 SRCS=stmqspi_erase_check.S stmqspi_crc32.S stmqspi_read.S stmqspi_write.S \
4      stmoctospi_erase_check.S stmoctospi_crc32.S stmoctospi_read.S stmoctospi_write.S
5 OBJS=$(patsubst %.S,%.inc,$(SRCS))
6
7 CROSS_COMPILE ?= arm-none-eabi-
8
9 CC=$(CROSS_COMPILE)gcc
10 OBJCOPY=$(CROSS_COMPILE)objcopy
11 OBJDUMP=$(CROSS_COMPILE)objdump
12 LD=$(CROSS_COMPILE)ld
13
14 all: $(OBJS)
15
16 %.o: %.S Makefile
17         $(CC) -Wall -Werror -Wa,-adhlmn -o $@ -c $< > $(@:.o=.lst)
18         @enscript -Easm -T 4 -G -o - $(@:.o=.lst) | ps2pdf - $(@:.o=.pdf) || true
19
20 %.elf: %.o
21         $(LD) -s -defsym=_start=0 -o $@ $<
22
23 %.bin: %.elf
24         $(OBJCOPY) -S -O binary $< $@
25
26 %.inc: %.bin
27         $(BIN2C) < $< > $@
28
29 clean:
30         -rm -f *.o *.elf *.lst *.pdf *.bin *.inc
31
32 .PHONY: all clean
33
34 .INTERMEDIATE: $(patsubst %.S,%.o,$(SRCS)) $(patsubst %.S,%.elf,$(SRCS)) $(patsubst %.S,%.bin,$(SRCS))