summaryrefslogtreecommitdiff
path: root/controller/Makefile
blob: aedbfe406a5125f71554e0bcad6a4f4cdd40b362 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
# A spec for using Tivaware's makefiles

# Top-level concerns.
PROJECT = controller
MCU = TM4C123GH6PM

# Utilities.
CC = arm-none-eabi-gcc
LD = arm-none-eabi-ld
OBJCOPY = arm-none-eabi-objcopy
RM      = rm -rf
MKDIR   = @mkdir -p $(@D)

# Custom/TI/build resource locations.
SRCS = $(wildcard src/*.c) \
	$(wildcard libs/*.c)
OBJ = obj/
OBJS = $(addprefix $(OBJ),$(notdir $(SRCS:.c=.o)))
LD_SCRIPT = ld/$(MCU).ld
IPATH = /home/dnw/Code/TivaC/libs

# Flags.
CFLAGS = -mthumb -mcpu=cortex-m4 -mfpu=fpv4-sp-d16 -mfloat-abi=hard -ffunction-sections \
	-fdata-sections -MD  -std=c2x -Wall -Wextra -Werror -DPART_${MCU} -c -O0 -Dgcc -ggdb 
CFLAGS += ${patsubst %,-I%,${subst :, ,${IPATH}}} -iquote inc

# Compiler/standard resource locations.
LIBGCC := ${shell ${CC} ${CFLAGS} -print-libgcc-file-name}
LIBC := ${shell ${CC} ${CFLAGS} -print-file-name=libc_nano.a}
LIBM := ${shell ${CC} ${CFLAGS} -print-file-name=libm.a}
LIBG := ${shell ${CC} ${CFLAGS} -print-file-name=libg_nano.a}
LIBSTUB := ${shell ${CC} ${CFLAGS} -print-file-name=libnosys.a}
LIBDRIVER := /home/dnw/Code/TivaC/libs/driverlib/gcc/libdriver.a

# More flags.
LDFLAGS = -T $(LD_SCRIPT) --gc-sections  '${LIBM}' '${LIBGCC}' '${LIBDRIVER}' '${LIBC}' '${LIBSTUB}'


# Targets.
all: bin/$(PROJECT).bin

$(OBJ)%.o: src/%.c
	$(MKDIR)
	$(CC) -o $@ $^ $(CFLAGS)

$(OBJ)%.o: libs/%.c
	$(MKDIR)
	$(CC) -o $@ $^ $(CFLAGS)

$(info $$PROJECT is [${PROJECT}])
bin/$(PROJECT).elf: $(OBJS)
	$(MKDIR)
	$(LD) -o $@ $^ $(LDFLAGS)

bin/$(PROJECT).bin: bin/$(PROJECT).elf
	$(OBJCOPY) -O binary $< $@

clean:
	-$(RM) obj
	-$(RM) bin

.PHONY: all clean