]> Pileus Git - ~andy/csm213a-hw/blob - common.mk
710c64504f16a2389493ef5b842450c150f71c0c
[~andy/csm213a-hw] / common.mk
1 # Settings
2 GDB      ?= arm-none-eabi-gdb
3 GAS      ?= arm-none-eabi-as
4 GCC      ?= arm-none-eabi-gcc
5 GXX      ?= arm-none-eabi-g++
6 GLD      ?= arm-none-eabi-gcc
7 OBJCOPY  ?= arm-none-eabi-objcopy
8
9 CFLAGS   ?= -Wall -Os -g --std=gnu99
10 CXXFLAGS ?= -Wall -Os -g --std=gnu++98
11
12 # Cross compiler flags
13 CPPFLAGS += -I$(MBED) -I$(MBED)/TARGET_KL46Z
14
15 CFLAGS   += -mthumb -mcpu=cortex-m0plus
16 CXXFLAGS += -mthumb -mcpu=cortex-m0plus -fno-exceptions
17
18 LDFLAGS  += --specs=nano.specs -Wl,--gc-sections \
19             -T$(MBED)/TARGET_KL46Z/TOOLCHAIN_GCC_ARM/MKL46Z4.ld \
20             -L$(MBED)/TARGET_KL46Z/TOOLCHAIN_GCC_ARM \
21             -Wl,--start-group -lmbed -lstartup -lio -lc_s -Wl,--end-group
22
23 # Targets
24 all: $(PROG).bin
25
26 info: all
27         @echo "LS   $(PROG).bin $(PROG).elf"
28         @ls -lh $(PROG).bin $(PROG).elf
29
30 install: all
31         @echo "INST $(PROG).bin"
32         @if [ -b /dev/sdb ]; then         \
33                 mount /mnt/usb;           \
34                 cp $(PROG).bin /mnt/usb;  \
35                 umount /mnt/usb;          \
36         else                              \
37                 echo Error: No USB found; \
38         fi
39
40 gdb: all
41         $(GDB) -ex 'target remote localhost:3333' $(PROG).elf
42
43 openocd: all
44         openocd -c 'adapter_khz 5000'         \
45                 -c 'gdb_memory_map disable'   \
46                 -s /usr/share/openocd/scripts \
47                 -f board/frdm-kl46z.cfg
48
49 clean:
50         @echo "RM   $(PROG).bin $(PROG).elf $(OBJS)"
51         @rm -f $(PROG).bin $(PROG).elf $(OBJS)
52
53 # Rules
54 %.o: %.c makefile ../common.mk ../config.mk
55         @echo "CC   $<"
56         @$(GCC) $(CFLAGS) $(CPPFLAGS) -c -o $@ $<
57
58 %.o: %.cc makefile ../common.mk ../config.mk
59         @echo "CXX  $<"
60         @$(GXX) $(CXXFLAGS) $(CPPFLAGS) -c -o $@ $<
61
62 $(PROG).elf: $(OBJS)
63         @echo "LD   $+"
64         @$(GLD) $(CFLAGS) -o $@ $^ $(LDFLAGS)
65
66 $(PROG).bin: $(PROG).elf
67         @echo "BIN  $+"
68         @$(OBJCOPY) -O binary $< $@