-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathMakefile
198 lines (160 loc) · 5.2 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
TARGET := ServiceME
# We make the following assumptions on Windows:
# arm-none-eabi gcc and binutils are compiled for Windows,
# so if you are using Cygwin, we will need path translations
# NUVOSDK must be lazily evaluated, so that we can later
# change EVICSDK when building include paths.
# Small fix to bug where cygpath -w mistranslates paths with mixed slashes (/, \)
EVICSDK := $(subst \,/,$(EVICSDK))
NUVOSDK = $(EVICSDK)/nuvoton-sdk/Library
OBJS := $(NUVOSDK)/Device/Nuvoton/M451Series/Source/system_M451Series.o \
$(NUVOSDK)/StdDriver/src/clk.o \
$(NUVOSDK)/StdDriver/src/fmc.o \
$(NUVOSDK)/StdDriver/src/gpio.o \
$(NUVOSDK)/StdDriver/src/spi.o \
$(NUVOSDK)/StdDriver/src/sys.o \
$(NUVOSDK)/StdDriver/src/timer.o \
$(NUVOSDK)/StdDriver/src/rtc.o \
$(NUVOSDK)/StdDriver/src/usbd.o \
$(NUVOSDK)/StdDriver/src/eadc.o \
$(NUVOSDK)/StdDriver/src/pwm.o \
$(NUVOSDK)/StdDriver/src/wdt.o \
$(NUVOSDK)/StdDriver/src/uart.o \
$(NUVOSDK)/StdDriver/src/crc.o
MYEVIC_OBJS := src/myevic.o \
src/main.o \
src/myprintf.o \
src/dataflash.o \
src/timers.o \
src/megpio.o \
src/meusbd.o \
src/vcom.o
AEABI_OBJS := src/aeabi/aeabi_memset-thumb2.o \
src/aeabi/aeabi_memclr.o
OUTDIR := bin
DOCDIR := doc
CPU := cortex-m4
FPU := fpv4-sp-d16
# We need to find out if on cygwin or not
ifeq ($(OS),Windows_NT)
ifeq (, $(findstring cygwin, $(shell gcc -dumpmachine)))
WIN_CYG := 0
else
WIN_CYG := 1
endif
endif
ifeq ($(shell $(CC) -v 2>&1 | grep -c "clang version"), 1)
CC_IS_CLANG := 1
endif
ifeq ($(ARMGCC),)
ARMGCC := $(shell cd $(shell arm-none-eabi-gcc --print-search-dir | grep 'libraries' | \
tr '=$(if $(filter Windows_NT,$(OS)),;,:)' '\n' | \
grep -E '/arm-none-eabi/lib/?$$' | head -1)/../.. && pwd)
endif
ifeq ($(OS),Windows_NT)
# Always fix binutils path
ifneq ($(ARMGCC),)
# If using cygwin, use cygpath
ifeq ($(WIN_CYG),1)
ARMGCC := $(shell cygpath -w $(ARMGCC))
endif
endif
ifndef CC_IS_CLANG
NEED_FIXPATH := 1
endif
endif
ifneq ($(ARMGCC),)
ifdef CC_IS_CLANG
CFLAGS += -target armv7em-none-eabi -fshort-enums
AEABI_COUNT := $(shell arm-none-eabi-nm -g $(ARMGCC)/arm-none-eabi/lib/armv7e-m/libc.a | grep -Ec 'T __aeabi_mem(set|clr)[48]?$$')
ifeq ($(AEABI_COUNT), 0)
# __aeabi_memset* and __aeabi_memclr* are not exported by libc
# We provide our own implementations
OBJS += $(AEABI_OBJS)
else ifneq ($(AEABI_COUNT), 6)
# Only part of __aeabi_memset* and __aeabi_memclr* are exported by libc
# This should never happen, bail out in env_check
AEABI_ERROR := 1
endif
else
CC := arm-none-eabi-gcc
endif
ifdef NEED_FIXPATH
ifeq ($(WIN_CYG), 0)
OBJS_FIXPATH := $(OBJS)
else
OBJS_FIXPATH := $(shell cygpath -w $(OBJS))
EVICSDK := $(shell cygpath -w $(EVICSDK))
endif
else
OBJS_FIXPATH := $(OBJS)
endif
endif
ifeq ($(WIN_CYG),0)
SDKTAG := $(shell git describe --abbrev --dirty --always --tags 2> NUL ) # Fix for Windows w/o cygwin (NUL instead of /dev/null)
else
SDKTAG := $(shell git describe --abbrev --dirty --always --tags 2> /dev/null )
endif
ifeq ($(SDKTAG),)
SDKTAG := unknown
endif
AS := arm-none-eabi-as
LD := arm-none-eabi-ld
AR := arm-none-eabi-ar
OBJCOPY := arm-none-eabi-objcopy
INCDIRS := $(foreach d,$(shell arm-none-eabi-gcc -x c -v -E /dev/null 2>&1 | sed -n -e '/<\.\.\.>/,/End/ p' | tail -n +2 | head -n -1 | sed 's/^\s*//'),-I$d) \
-I$(NUVOSDK)/CMSIS/Include \
-I$(NUVOSDK)/Device/Nuvoton/M451Series/Include \
-I$(NUVOSDK)/StdDriver/inc \
-Iinc \
-Isrc
INCDIRS += -I$(ARMGCC)/arm-none-eabi/include
GCC_VERSION := $(shell arm-none-eabi-gcc -dumpversion)
LIBDIRS := -L$(ARMGCC)/arm-none-eabi/lib \
-L$(ARMGCC)/arm-none-eabi/newlib \
-L$(ARMGCC)/lib/arm-none-eabi/newlib \
-L$(ARMGCC)/gcc/arm-none-eabi/$(GCC_VERSION) \
-L$(ARMGCC)/lib/gcc/arm-none-eabi/$(GCC_VERSION)
CFLAGS += -Wall -mcpu=$(CPU) -mfpu=$(FPU) -mthumb -Os -fdata-sections -ffunction-sections -std=c99
CFLAGS += -fno-builtin-printf
CFLAGS += $(INCDIRS)
ASFLAGS := -mcpu=$(CPU) -mfpu=$(FPU)
ASFLAGS += $(INCDIRS)
LINKSCRIPT := linker.ld
LDFLAGS += -u __aeabi_uldivmod
LDFLAGS += $(LIBDIRS)
LDFLAGS += -gc-sections -nostdlib -nostartfiles -T$(LINKSCRIPT)
#LDFLAGS += --verbose --cref -Map=blah.map
SRCDIR = src
INCDIR = inc
OBJDIR = src
BINDIR = bin
INCLUDEH := $(wildcard $(INCDIR)/*.h)
INCLUDES := $(wildcard $(SRCDIR)/*.s)
all: env_check $(TARGET).bin
$(OBJS_FIXPATH): %.o: %.c
$(CC) $(CFLAGS) -c $< -o $@
%.o: %.c $(INCLUDEH)
$(CC) $(CFLAGS) -c $< -o $@
%.o: %.s $(INCLUDES)
$(CC) $(CFLAGS) -c $< -o $@
$(TARGET)_dec.bin: $(OBJS_FIXPATH) $(MYEVIC_OBJS)
test -d $(OUTDIR) || mkdir $(OUTDIR)
$(LD) --start-group $(LIBS) $(OBJS_FIXPATH) $(MYEVIC_OBJS) --end-group $(LDFLAGS) -o $(OUTDIR)/$(TARGET).elf
$(OBJCOPY) -O binary -j .text -j .data $(OUTDIR)/$(TARGET).elf $(OUTDIR)/$(TARGET)_dec.bin
export LC_ALL=C.UTF-8
export LANG=C.UTF-8
$(TARGET).bin: $(TARGET)_dec.bin
# evic convert $(OUTDIR)/$(TARGET)_dec.bin -o $(OUTDIR)/$(TARGET).bin
docs:
doxygen
clean:
rm -rf $(OBJS) $(MYEVIC_OBJS) $(AEABI_OBJS) $(OUTDIR)/$(TARGET).bin $(OUTDIR) $(DOCDIR)
env_check:
ifeq ($(ARMGCC),)
$(error You must set the ARMGCC environment variable)
endif
ifneq ($(AEABI_ERROR),)
$(error Your libc is exporting only part of __aeabi symbols)
endif
.PHONY: all clean docs env_check gen_tag