-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathMakefile
233 lines (197 loc) · 7.55 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
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
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
# SPDX-License-Identifier: BSD-2-Clause
#
# Copyright (c) 2022 Jonathan Armstrong. All rights reserved.
#
# Redistribution and use in source and binary forms, with or without
# modification, are permitted provided that the following conditions
# are met:
#
# 1. Redistributions of source code must retain the above copyright
# notice, this list of conditions and the following disclaimer.
#
# 2. Redistributions in binary form must reproduce the above copyright
# notice, this list of conditions and the following disclaimer in the
# documentation and/or other materials provided with the distribution.
#
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
# FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
# COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
# INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
# BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
# LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
# CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
# ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
# POSSIBILITY OF SUCH DAMAGE.
# Prerequisites --------------------------------------------------------
#
# Besides make, his project requires:
#
# - sdcc
# Usage ----------------------------------------------------------------
#
# Build executables:
# make
#
# Clean project (remove all build files):
# make clean
# Target MCU settings --------------------------------------------------
# uncomment only one target board
# FIXME: build all targets without need to modify makefile
# FIXME: it is possible to uncomment more than one line and it reassigns TARGET_BOARD which might confuse person
# sonoff black box
#TARGET_BOARD = EFM8BB1
# low cost development board
#TARGET_BOARD = EFM8BB1LCB
# sonoff white box
TARGET_BOARD = OB38S003
# catches undefined
ifndef TARGET_BOARD
$(error Please define TARGET_BOARD in makefile)
endif
# these are the maximum clock speeds
ifeq ($(TARGET_BOARD), EFM8BB1)
# for EFM8BB1 in Sonoff v2.0 receivers (black color box)
MCU_FREQ_KHZ = 24500
else ifeq ($(TARGET_BOARD), EFM8BB1LCB)
MCU_FREQ_KHZ = 24500
else ifeq ($(TARGET_BOARD), OB38S003)
# for OB38S003 used in Sonoff v2.2 receivers (white color box)
MCU_FREQ_KHZ = 16000
endif
# the EFM8BB1 has a lock byte and bootloader byte we may need to account for
MEMORY_SIZES = --iram-size 256 --xram-size 256 --code-size 8192
MEMORY_MODEL = --model-small
HAS_DUAL_DPTR = n
# generic source directory
SOURCE_DIR = src
# target specific sources
ifeq ($(TARGET_BOARD), EFM8BB1)
DRIVER_SRC_DIR = drivers/efm8bb1/src
else ifeq ($(TARGET_BOARD), EFM8BB1LCB)
DRIVER_SRC_DIR = drivers/efm8bb1/src
else ifeq ($(TARGET_BOARD), OB38S003)
DRIVER_SRC_DIR = drivers/ob38s003/src
endif
# generic includes
INCLUDE_DIR = inc/
# target specific includes
ifeq ($(TARGET_BOARD), EFM8BB1)
DRIVER_DIR = drivers/efm8bb1/inc
else ifeq ($(TARGET_BOARD), EFM8BB1LCB)
DRIVER_DIR = drivers/efm8bb1/inc
else ifeq ($(TARGET_BOARD), OB38S003)
DRIVER_DIR = drivers/ob38s003/inc
endif
# place intermediate build files here so other directories are not cluttered
OBJECT_DIR = object
# final location of built firmware
BUILD_DIR = build
# FIXME: pca_0 and wdt_0 are exclusively for portisch EFM8BB1
# so hardware abstraction from other hardware needs to be used eventually
# list of source files
SOURCES = \
$(SOURCE_DIR)/main_passthrough.c \
$(SOURCE_DIR)/main_portisch.c \
$(SOURCE_DIR)/main_rcswitch.c \
$(SOURCE_DIR)/portisch.c \
$(SOURCE_DIR)/portisch_serial.c \
$(SOURCE_DIR)/rcswitch.c \
$(SOURCE_DIR)/state_machine.c \
$(SOURCE_DIR)/uart.c \
$(DRIVER_SRC_DIR)/delay.c \
$(DRIVER_SRC_DIR)/hal.c \
$(DRIVER_SRC_DIR)/timer_interrupts.c
OBJECT_NAMES = \
$(notdir $(SOURCES:.c=.rel))
OBJECTS = \
$(patsubst %,$(OBJECT_DIR)/%,$(OBJECT_NAMES))
# intermediate object files
OBJECTS_PASSTHROUGH = \
$(OBJECT_DIR)/main_passthrough.rel \
$(OBJECT_DIR)/delay.rel \
$(OBJECT_DIR)/hal.rel
OBJECTS_RCSWITCH = \
$(OBJECT_DIR)/main_rcswitch.rel \
$(OBJECT_DIR)/rcswitch.rel \
$(OBJECT_DIR)/state_machine.rel \
$(OBJECT_DIR)/uart.rel \
$(OBJECT_DIR)/delay.rel \
$(OBJECT_DIR)/hal.rel \
$(OBJECT_DIR)/timer_interrupts.rel
OBJECTS_PORTISCH = \
$(OBJECT_DIR)/main_portisch.rel \
$(OBJECT_DIR)/portisch.rel \
$(OBJECT_DIR)/portisch_serial.rel \
$(OBJECT_DIR)/timer_interrupts.rel \
$(OBJECT_DIR)/uart.rel \
$(OBJECT_DIR)/hal.rel
# firmware names
TARGET_PASSTHROUGH = $(BUILD_DIR)/main_passthrough_$(TARGET_BOARD).ihx
TARGET_RCSWITCH = $(BUILD_DIR)/main_rcswitch_$(TARGET_BOARD).ihx
TARGET_PORTISCH = $(BUILD_DIR)/main_portisch_$(TARGET_BOARD).ihx
###########################################################
# Toolchain settings
###########################################################
TARGET_ARCH = -mmcs51
AS = sdas8051
CC = sdcc
ASFLAGS = -plosgffw
CPPFLAGS = $(PROJECT_FLAGS) -DTARGET_BOARD_$(TARGET_BOARD) -DMCU_FREQ=$(MCU_FREQ_KHZ)000UL -I$(INCLUDE_DIR) -I$(DRIVER_DIR)
CFLAGS = $(TARGET_ARCH) $(MEMORY_MODEL) $(CPPFLAGS)
LDFLAGS = $(TARGET_ARCH) $(MEMORY_MODEL) $(MEMORY_SIZES)
###########################################################
# Phony targets
###########################################################
.PHONY: all clean
all: $(TARGET_PASSTHROUGH) $(TARGET_PORTISCH) $(TARGET_RCSWITCH)
clean:
# it is safer to remove wildcard with file extension instead of the entire directory
# but can revisit this issue in the future (I think other projects just remove directory)
rm -f $(BUILD_DIR)/*.hex
rm -f $(BUILD_DIR)/*.ihx
rm -f $(BUILD_DIR)/*.lk
rm -f $(BUILD_DIR)/*.map
rm -f $(BUILD_DIR)/*.mem
rm -f $(OBJECT_DIR)/*.asm
rm -f $(OBJECT_DIR)/*.lst
rm -f $(OBJECT_DIR)/*.rel
rm -f $(OBJECT_DIR)/*.rst
rm -f $(OBJECT_DIR)/*.sym
###########################################################
# Build
# $@ is equal to the target (in this case %.rel)
# $^ is equal to the input (in this case %.c)
###########################################################
# basically the linking step
$(TARGET_PASSTHROUGH): $(OBJECTS_PASSTHROUGH)
@echo "Linking $^"
mkdir -p $(dir $@)
$(CC) $(LDFLAGS) -o $@ $^
# hex lines are a short, fixed length (compared with ihx) and therefore works with upload tools
packihx $@ > $(basename $@).hex
# unix style line endings (LF instead of LFCR) work with upload tools
dos2unix $(basename $@).hex
$(TARGET_RCSWITCH): $(OBJECTS_RCSWITCH)
@echo "Linking $^"
mkdir -p $(dir $@)
$(CC) $(LDFLAGS) -o $@ $^
packihx $@ > $(basename $@).hex
dos2unix $(basename $@).hex
$(TARGET_PORTISCH): $(OBJECTS_PORTISCH)
@echo "Linking $^"
mkdir -p $(dir $@)
$(CC) $(LDFLAGS) -o $@ $^
packihx $@ > $(basename $@).hex
dos2unix $(basename $@).hex
# basically the compilation step
$(OBJECT_DIR)/%.rel: $(SOURCE_DIR)/%.c
@echo "Compiling $^"
mkdir -p $(dir $@)
$(CC) $(CFLAGS) -c -o $@ $^
$(OBJECT_DIR)/%.rel: $(DRIVER_SRC_DIR)/%.c
@echo "Compiling $^"
mkdir -p $(dir $@)
$(CC) $(CFLAGS) -c -o $@ $^