-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMakefile
87 lines (64 loc) · 1.31 KB
/
Makefile
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
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
################
# DEFINITIONS
################
# This will be the name of the executable
TARGET:=interleave_test
# Directories
OBJDIR:=build
SRCDIR:=src
BINDIR:=bin
# ANSI color codes
# Only used for fancy output
NO_COLOR=\x1b[0m
RED:=\x1b[31m
GREEN:=\x1b[32m
YELLOW:=\x1b[33m
################
# TOOLCHAIN
################
CC:=gcc
LD:=gcc
################
# FLAGS
################
INCLUDES:= -Iinc/
LIBS:=
CFLAGS:=-std=c99 -Wall $(INCLUDES)
LDFLAGS:=$(LIBS)
################
# FILES
################
CSRC:= $(addprefix $(SRCDIR)/, \
interleave.c \
interleave_test.c \
)
C_FILES := $(notdir $(CSRC))
C_PATHS := $(dir $(CSRC))
C_OBJS := $(addprefix $(OBJDIR)/, $(C_FILES:.c=.o))
OBJS = $(C_OBJS)
vpath %.c $(C_PATHS)
################
# BUILD RULES
################
.PHONY : all run clean purge
all : $(BINDIR)/$(TARGET)
TOTAL_IMAGES := 400
INTERLEAVED := 8
BIT_WIDTH := 28
run : $(BINDIR)/$(TARGET)
$(BINDIR)/$(TARGET) $(TOTAL_IMAGES) $(INTERLEAVED) $(BIT_WIDTH)
$(BINDIR)/$(TARGET) : $(OBJS) | $(BINDIR)
@echo "$(YELLOW)Linking target: $@$(NO_COLOR)"
$(LD) $(LDFLAGS) -o $@ $(OBJS)
$(OBJDIR)/%.o : %.c | $(OBJDIR)
@echo "$(YELLOW)Compiling source: $@$(NO_COLOR)"
$(CC) $(CFLAGS) -c $< -o $@
$(OBJDIR) :
mkdir $@
$(BINDIR) :
mkdir $@
clean :
-rm -rf $(OBJDIR)
-rm -rf $(BINDIR)
purge : clean
-rm -rf data