-
Notifications
You must be signed in to change notification settings - Fork 10
Expand file tree
/
Copy pathefr32_wisun.target
More file actions
204 lines (164 loc) · 6.12 KB
/
efr32_wisun.target
File metadata and controls
204 lines (164 loc) · 6.12 KB
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
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
####################################################################
# User Makefile #
# This will not be overwritten. Edit as desired. #
####################################################################
.SUFFIXES: # ignore builtin rules
.PHONY: all debug release clean pre-build post-build
# Default goal
all: debug
####################################################################
# Definitions #
####################################################################
# Values set by the initial generation
PROJECTNAME = csmp_agent_lib_efr32_wisun
ARM_GCC_DIR_WIN =
ARM_GCC_DIR_OSX =
ARM_GCC_DIR_LINUX =
POST_BUILD_EXE_WIN =
POST_BUILD_EXE_OSX =
POST_BUILD_EXE_LINUX =
# Pre-defined definitions in this file
ifeq ($(OS),Windows_NT)
ARM_GCC_DIR ?= $(ARM_GCC_DIR_WIN)
POST_BUILD_EXE ?= $(POST_BUILD_EXE_WIN)
else
UNAME_S := $(shell uname -s)
ifeq ($(UNAME_S),Darwin)
ARM_GCC_DIR ?= $(ARM_GCC_DIR_OSX)
POST_BUILD_EXE ?= $(POST_BUILD_EXE_OSX)
else
ARM_GCC_DIR ?= $(ARM_GCC_DIR_LINUX)
POST_BUILD_EXE ?= $(POST_BUILD_EXE_LINUX)
endif
endif
# Command output is hidden by default, it can be enabled by
# setting VERBOSE=true on the commandline.
ifeq ($(VERBOSE),)
ECHO = @
endif
# Build Directories
BUILD_DIR = build
LST_DIR = lst
ifneq ($(filter $(MAKECMDGOALS),release),)
OUTPUT_DIR = $(BUILD_DIR)/release
else
OUTPUT_DIR = $(BUILD_DIR)/debug
endif
CSMP_AGENT_DIRs += $(shell find ./src -maxdepth 3 -type d)
# Values that should be appended by the sub-makefiles
CXX_SOURCE_FILES =
ASM_SOURCE_FILES =
LIBS =
C_DEFS = -DOSAL_EFR32_WISUN
ASM_DEFS =
INCLUDES += $(foreach dir, $(CSMP_AGENT_DIRs), -I $(dir))
INCLUDES += -Iinclude\
-Iosal \
-Iosal/efr32_wisun
C_FLAGS += -Wno-missing-braces
C_FLAGS_DEBUG =
C_FLAGS_RELEASE =
CXX_FLAGS =
CXX_FLAGS_DEBUG =
CXX_FLAGS_RELEASE =
ASM_FLAGS =
ASM_FLAGS_DEBUG =
ASM_FLAGS_RELEASE =
LD_FLAGS =
OBJS =
####################################################################
# Definitions of toolchain. #
# You might need to do changes to match your system setup #
####################################################################
AR = "$(ARM_GCC_DIR)/bin/arm-none-eabi-gcc-ar"
CC = "$(ARM_GCC_DIR)/bin/arm-none-eabi-gcc"
CXX = "$(ARM_GCC_DIR)/bin/arm-none-eabi-g++"
OBJCOPY = "$(ARM_GCC_DIR)/bin/arm-none-eabi-objcopy"
LD = "$(ARM_GCC_DIR)/bin/arm-none-eabi-gcc"
####################################################################
# Include sub-makefiles #
# Define a makefile here to add files/settings to the build. #
####################################################################
-include Vendors/Silabs/efr32_wisun.mak
#Set source files
C_SOURCE_FILES = $(foreach dir, $(CSMP_AGENT_DIRs), $(wildcard $(dir)/*.c))
C_SOURCE_FILES += osal/efr32_wisun/osal_efr32_wisun.c
OBJS =
####################################################################
# Rules #
####################################################################
# -MMD : Don't generate dependencies on system header files.
# -MP : Add phony targets, useful when a h-file is removed from a project.
# -MF : Specify a file to write the dependencies to.
DEPFLAGS = -MMD -MP -MF $(@:.o=.d)
CSOURCES = $(notdir $(C_SOURCE_FILES))
CXXSOURCES = $(notdir $(filter %.cpp, $(CXX_SOURCE_FILES)))
CCSOURCES = $(notdir $(filter %.cc, $(CXX_SOURCE_FILES)))
ASMSOURCES_s = $(notdir $(filter %.s, $(ASM_SOURCE_FILES)))
ASMSOURCES_S = $(notdir $(filter %.S, $(ASM_SOURCE_FILES)))
COBJS = $(addprefix $(OUTPUT_DIR)/,$(CSOURCES:.c=.o))
CXXOBJS = $(addprefix $(OUTPUT_DIR)/,$(CXXSOURCES:.cpp=.o))
CCOBJS = $(addprefix $(OUTPUT_DIR)/,$(CCSOURCES:.cc=.o))
ASMOBJS_s = $(addprefix $(OUTPUT_DIR)/,$(ASMSOURCES_s:.s=.o))
ASMOBJS_S = $(addprefix $(OUTPUT_DIR)/,$(ASMSOURCES_S:.S=.o))
OBJS += $(COBJS) $(CXXOBJS) $(CCOBJS) $(ASMOBJS_s) $(ASMOBJS_S)
CDEPS += $(addprefix $(OUTPUT_DIR)/,$(CSOURCES:.c=.d))
CXXDEPS += $(addprefix $(OUTPUT_DIR)/,$(CXXSOURCES:.cpp=.d))
CXXDEPS += $(addprefix $(OUTPUT_DIR)/,$(CCSOURCES:.cc=.d))
ASMDEPS_s += $(addprefix $(OUTPUT_DIR)/,$(ASMSOURCES_s:.s=.d))
ASMDEPS_S += $(addprefix $(OUTPUT_DIR)/,$(ASMSOURCES_S:.S=.d))
C_PATHS = $(subst \,/,$(sort $(dir $(C_SOURCE_FILES))))
CXX_PATHS = $(subst \,/,$(sort $(dir $(CXX_SOURCE_FILES))))
ASM_PATHS = $(subst \,/,$(sort $(dir $(ASM_SOURCE_FILES))))
vpath %.c $(C_PATHS)
vpath %.cpp $(CXX_PATHS)
vpath %.cc $(CXX_PATHS)
vpath %.s $(ASM_PATHS)
vpath %.S $(ASM_PATHS)
override CFLAGS = $(C_FLAGS) $(C_DEFS) $(INCLUDES) $(DEPFLAGS)
override CXXFLAGS = $(CXX_FLAGS) $(C_DEFS) $(INCLUDES) $(DEPFLAGS)
override ASMFLAGS = $(ASM_FLAGS) $(ASM_DEFS) $(INCLUDES) $(DEPFLAGS)
# Rule Definitions
debug: C_FLAGS += $(C_FLAGS_DEBUG)
debug: CXX_FLAGS += $(CXX_FLAGS_DEBUG)
debug: ASM_FLAGS += $(ASM_FLAGS_DEBUG)
debug: | pre-build $(PROJECTNAME).a post-build
release: C_FLAGS += $(C_FLAGS_RELEASE)
release: CXX_FLAGS += $(CXX_FLAGS_RELEASE)
release: ASM_FLAGS += $(ASM_FLAGS_RELEASE)
release: | pre-build $(PROJECTNAME).a post-build
# include auto-generated dependency files (explicit rules)
ifneq (clean,$(findstring clean, $(MAKECMDGOALS)))
-include $(CDEPS)
-include $(CXXDEPS)
-include $(ASMDEPS_s)
-include $(ASMDEPS_S)
endif
$(PROJECTNAME).a: $(OBJS) $(LIB_FILES)
@echo 'Building $(PROJECTNAME).a'
@$(AR) rc $@ $^
@echo 'Done.'
$(OBJS):
$(OUTPUT_DIR)/%.o: %.c
@echo 'Building $<'
@mkdir -p $(@D)
$(ECHO)$(CC) $(CFLAGS) -c -o $@ $<
$(OUTPUT_DIR)/%.o: %.cpp
@echo 'Building $<'
@mkdir -p $(@D)
$(ECHO)$(CXX) $(CXXFLAGS) -c -o $@ $<
$(OUTPUT_DIR)/%.o: %.cc
@echo 'Building $<'
@mkdir -p $(@D)
$(ECHO)$(CXX) $(CXXFLAGS) -c -o $@ $<
$(OUTPUT_DIR)/%.o: %.s
@echo 'Building $<'
@mkdir -p $(@D)
$(ECHO)$(CC) $(ASMFLAGS) -c -o $@ $<
$(OUTPUT_DIR)/%.o: %.S
@echo 'Building $<'
@mkdir -p $(@D)
$(ECHO)$(CC) $(ASMFLAGS) -c -o $@ $<
clean:
$(RM) -rf $(BUILD_DIR)
$(RM) $(PROJECTNAME).a