aboutsummaryrefslogtreecommitdiffstats
path: root/src/simulator/Makefile
blob: 6593f73c8b011464d16bb1d1abdad5270ec3fa41 (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
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
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
######## Build options ########

verbose = 0

######## Build setup ########

# SRCROOT should always be the current directory
SRCROOT         = $(CURDIR)

# .o directory
ODIR            = obj

# Source VPATHS
VPATH           += $(SRCROOT)/Source
VPATH	        += $(SRCROOT)/Source/portable/MemMang
VPATH	        += $(SRCROOT)/Source/portable/GCC/POSIX
VPATH			+= $(SRCROOT)/src/Core
VPATH			+= $(SRCROOT)/src/GPIO
VPATH			+= $(SRCROOT)/src/GPS

# FreeRTOS Objects
C_FILES			+= croutine.c
C_FILES			+= event_groups.c
C_FILES			+= list.c
C_FILES			+= queue.c
C_FILES			+= tasks.c
C_FILES			+= timers.c

# portable Objects
C_FILES			+= heap_3.c
C_FILES			+= port.c

# common Objects
COMMON_SOURCE_LIST=$(shell cat ../common/sourcelist.txt)
C_FILES+=$(COMMON_SOURCE_LIST:%.c=../common/%.c)

# Main Object
SRC_SOURCES+=$(shell find -L src/ -name '*.c')
C_FILES			+= $(SRC_SOURCES)

# Include Paths
INCLUDES        += -I$(SRCROOT)/Source/include
INCLUDES        += -I$(SRCROOT)/Source/portable/GCC/POSIX/
INCLUDES        += -I$(SRCROOT)/src/Core
INCLUDES        += -I$(SRCROOT)/../common/includes/
INCLUDES        += -I$(SRCROOT)

# Generate OBJS names
OBJS = $(patsubst %.c,%.o,$(C_FILES))

######## C Flags ########

# Warnings
CWARNS += -W
CWARNS += -Wall
# CWARNS += -Werror
# CWARNS += -Wextra
# CWARNS += -Wformat
# CWARNS += -Wmissing-braces
# CWARNS += -Wno-cast-align
# CWARNS += -Wparentheses
# CWARNS += -Wshadow
# CWARNS += -Wno-sign-compare
# CWARNS += -Wswitch
# CWARNS += -Wuninitialized
# CWARNS += -Wunknown-pragmas
# CWARNS += -Wunused-function
# CWARNS += -Wunused-label
# CWARNS += -Wunused-parameter
# CWARNS += -Wunused-value
# CWARNS += -Wunused-variable
# CWARNS += -Wmissing-prototypes
#
CFLAGS += -m32
CFLAGS += -DDEBUG=1
CFLAGS += -g -DUSE_STDIO=1 -D__GCC_POSIX__=1 -lX11 -lm -lGL -lm -lGLU -lpulse-simple -lpulse
ifneq ($(shell uname), Darwin)
CFLAGS += -pthread
endif

# MAX_NUMBER_OF_TASKS = max pthreads used in the POSIX port. 
# Default value is 64 (_POSIX_THREAD_THREADS_MAX), the minimum number required by POSIX.
CFLAGS += -DMAX_NUMBER_OF_TASKS=300 -DSIMULATOR

CFLAGS += $(INCLUDES) $(CWARNS) -O2

######## Makefile targets ########

# Rules
.PHONY : all
all: vc.h setup FreeRTOS-Sim

.PHONY : setup
setup:
# Make obj directory
	@mkdir -p $(ODIR)

# Fix to place .o files in ODIR
_OBJS = $(patsubst %,$(ODIR)/%,$(OBJS))

dir_guard=@mkdir -p $(@D)

$(ODIR)/%.o: %.c
	$(dir_guard)
# If verbose, print gcc execution, else hide
ifeq ($(verbose),1)
	@echo ">> Compiling $<"
	$(CC) $(CFLAGS) -c -o $@ $<
else
	@echo ">> Compiling $(notdir $<)"
	@$(CC) $(CFLAGS) -c -o $@ $<
endif


vc.h: ../../.git/logs/HEAD
	echo "// This file is generated by Makefile." > vc.h
	echo "// Do not edit this file!" >> vc.h
	git log -1 --format="format:#define GIT_VERSION \"%h\"" >> vc.h
	echo >> vc.h
	echo >> vc.h

FreeRTOS-Sim: $(_OBJS)
	@echo ">> Linking $@..."
ifeq ($(verbose),1)
	$(CC) $(CFLAGS) $^ $(LINKFLAGS) $(LIBS) -o $@
else
	@$(CC) $(CFLAGS) $^ $(LINKFLAGS) $(LIBS) -o $@
endif

	@echo "-------------------------"
	@echo "BUILD COMPLETE: $@"
	@echo "-------------------------"

.PHONY : clean
clean:
	@-rm -rf $(ODIR) FreeRTOS-Sim
	@echo "--------------"
	@echo "CLEAN COMPLETE"
	@echo "--------------"