-
Notifications
You must be signed in to change notification settings - Fork 0
/
makefile
86 lines (72 loc) · 2.67 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
##########################################################################
#
# Build variables
#
##########################################################################
BUILD_NAME = RV_SoC_c_demo
BUILD_DIR = ./build
BINARY_PATH = $(BUILD_DIR)/bin
##########################################################################
#
# Build system
#
##########################################################################
ifeq ($(OS), Windows_NT)
PRESET = C:\Windows\sysnative\wsl.exe bash -ic "
ENDSET = "
MKDIR = if not exist $(@D) mkdir $(subst /,\,$(@D))
else
MKDIR = @mkdir -p $(@D)
endif
##########################################################################
#
# Sources
#
##########################################################################
-include Makefile.include
##########################################################################
#
# Compiler definitions
#
##########################################################################
CPPCOMPILER = $(CROSS_COMPILE)g++
CCOMPILER = $(CROSS_COMPILE)gcc
ASSEMBLER = $(CROSS_COMPILE)as
LD = $(CROSS_COMPILE)g++
OBJCOPY = $(CROSS_COMPILE)objcopy
OBJDUMP = $(CROSS_COMPILE)objdump
SIZE = $(CROSS_COMPILE)size
##########################################################################
#
# Compiler flags
#
##########################################################################
OBJECTS = $(patsubst %.cpp, $(BUILD_DIR)/%.o,$(patsubst %.c, $(BUILD_DIR)/%.o, $(patsubst %.S, $(BUILD_DIR)/%.o, $(SRC))))
##########################################################################
#
# Make Targets
#
##########################################################################
all: $(BINARY_PATH)/$(BUILD_NAME).elf
$(BINARY_PATH)/$(BUILD_NAME).elf: $(OBJECTS)
@echo 'Building target: $@'
$(MKDIR)
$(PRESET) $(LD) $(OBJECTS) -T $(LINKER) $(LDFLAGS) -Wl,-Map=$(BINARY_PATH)/$(BUILD_NAME).map -o $@ $(ENDSET)
$(PRESET) $(OBJDUMP) --source --all-headers --demangle --line-numbers --wide "$(BINARY_PATH)/$(BUILD_NAME).elf" > "$(BINARY_PATH)/$(BUILD_NAME).lst" $(ENDSET)
$(PRESET) $(OBJCOPY) -O ihex "$(BINARY_PATH)/$(BUILD_NAME).elf" "$(BINARY_PATH)/$(BUILD_NAME).hex" $(ENDSET)
$(PRESET) $(SIZE) --format=berkeley "$(BINARY_PATH)/$(BUILD_NAME).elf" $(ENDSET)
$(BUILD_DIR)/%.o: %.cpp
@echo "Compiling Source $< into object $@"
$(MKDIR)
$(PRESET) $(CPPCOMPILER) $(CPLUSPLUSFLAGS) -c $< -o $@ $(ENDSET)
$(BUILD_DIR)/%.o: %.c
@echo "Compiling Source $< into object $@"
$(MKDIR)
$(PRESET) $(CCOMPILER) $(CFLAGS) -c $< -o $@ $(ENDSET)
$(BUILD_DIR)/%.o: %.S
@echo "Compiling Source $< into object $@"
$(MKDIR)
$(PRESET) $(CCOMPILER) $(CFLAGS) -c $< -o $@ $(ENDSET)
.PHONY: clean
clean:
$(PRESET) rm -r -f $(BUILD_DIR) all $(ENDSET)