-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathCMakeLists.txt
157 lines (137 loc) · 3.76 KB
/
CMakeLists.txt
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
#
# Root CMakeLists.txt
#
cmake_minimum_required (VERSION 3.15)
project(BareMetal_WCH_V307_RISC-V ASM C CXX)
set(CMAKE_CXX_STANDARD_REQUIRED ON)
set(CMAKE_EXPORT_COMPILE_COMMANDS ON)
set(CMAKE_C_STANDARD 11)
set(CMAKE_CXX_STANDARD 20)
set(DEPLOY_DIR "${CMAKE_CURRENT_BINARY_DIR}")
set(EXECUTABLE_NAME "${CMAKE_PROJECT_NAME}")
set(EXECUTABLE_FORMAT elf)
set(EXECUTABLE "${EXECUTABLE_NAME}.${EXECUTABLE_FORMAT}")
set(SRC_DIR "${CMAKE_SOURCE_DIR}/Code")
set(LD_SCRIPT "${SRC_DIR}/Memory_Map.ld")
set(MAP_FILE "${DEPLOY_DIR}/${EXECUTABLE_NAME}.map")
# Set default build type if not defined
if(NOT CMAKE_BUILD_TYPE)
set(CMAKE_BUILD_TYPE Release)
endif()
# Listed flags
# Architecture
set(ARCH_FLAGS_LIST
-march=rv32imafc
-mabi=ilp32f
-msmall-data-limit=0
-falign-functions=4
)
# Optimization
set(OPT_RELEASE_FLAGS_LIST
-O2
-fno-reorder-blocks-and-partition
-fno-reorder-functions
)
set(OPT_DEBUG_FLAGS_LIST
-O0
)
if(CMAKE_BUILD_TYPE MATCHES Release)
set(OPT_FLAGS_LIST ${OPT_RELEASE_FLAGS_LIST})
else()
set(OPT_FLAGS_LIST ${OPT_DEBUG_FLAGS_LIST})
endif()
# C flags
set(C_FLAGS_LIST
${OPT_FLAG_LIST}
${ARCH_FLAGS_LIST}
-ffast-math
-g3
-Wconversion
-Wsign-conversion
-Wunused-parameter
-Wuninitialized
-Wmissing-declarations
-Wshadow
-Wunreachable-code
-Wmissing-include-dirs
-Wall
-Wextra
-fomit-frame-pointer
-gdwarf-2
-fomit-frame-pointer
-fsingle-precision-constant
)
# C++ flags
set(CXX_FLAGS_LIST
${C_FLAGS_LIST}
-fno-exceptions
-fno-rtti
-fno-use-cxa-atexit
-fno-nonansi-builtins
-fno-threadsafe-statics
-fno-enforce-eh-specs
-ftemplate-depth=128
-Wzero-as-null-pointer-constant
)
# Assembler flags
set(ASM_FLAGS_LIST
-march=rv32imafc
-alh
)
# LD flags
set(LD_FLAGS_LIST
-nostartfiles
-nostdlib
-Wl,-T ${LD_SCRIPT}
-Wl,--print-memory-usage
-Wl,--print-map
-Wl,-Map="${MAP_FILE}"
)
# Concatenate listed flags so that they can be parsed when assigned to CMAKE_<X>_FLAGS symbols
string(REPLACE ";" " " C_FLAGS "${C_FLAGS_LIST}")
string(REPLACE ";" " " CXX_FLAGS "${CXX_FLAGS_LIST}")
string(REPLACE ";" " " ASM_FLAGS "${ASM_FLAGS_LIST}")
string(REPLACE ";" " " LD_FLAGS "${LD_FLAGS_LIST}")
# Bind toolchain defintions
set(CMAKE_ASM_COMPILER ${CPP})
set(CMAKE_C_COMPILER ${CC})
set(CMAKE_CXX_COMPILER ${CPP})
set(CMAKE_ASM_FLAGS "${CXX_FLAGS}")
set(CMAKE_C_FLAGS "${C_FLAGS}")
set(CMAKE_CXX_FLAGS "${CXX_FLAGS}")
set(CMAKE_EXE_LINKER_FLAGS "${LD_FLAGS}")
set(CMAKE_VERBOSE_MAKEFILE OFF) # Set it to ON to have verbose build output
# Construct executable
add_executable(${EXECUTABLE}
${SRC_DIR}/Mcal/Mcu.c
${SRC_DIR}/Mcal/Port.c
${SRC_DIR}/Mcal/SysTick.c
${SRC_DIR}/Startup/boot.s
${SRC_DIR}/Startup/intvect.c
${SRC_DIR}/Startup/Startup.c
${SRC_DIR}/Appli/main.c
)
target_include_directories(${EXECUTABLE}
PRIVATE
${SRC_DIR}
${SRC_DIR}/Mcal
)
target_link_libraries(${EXECUTABLE}
PRIVATE
)
target_link_directories(${EXECUTABLE}
PRIVATE
)
target_link_options(${EXECUTABLE}
PRIVATE
)
# Post build commands
add_custom_command(TARGET ${EXECUTABLE} POST_BUILD COMMAND ${OBJCOPY} -Oihex ${DEPLOY_DIR}/${EXECUTABLE} ${DEPLOY_DIR}/${EXECUTABLE_NAME}.hex)
add_custom_command(TARGET ${EXECUTABLE} POST_BUILD COMMAND ${OBJCOPY} -Obinary ${DEPLOY_DIR}/${EXECUTABLE} ${DEPLOY_DIR}/${EXECUTABLE_NAME}.bin)
add_custom_command(TARGET ${EXECUTABLE} POST_BUILD COMMAND ${OBJDUMP} -d ${DEPLOY_DIR}/${EXECUTABLE} > ${DEPLOY_DIR}/${EXECUTABLE_NAME}.disa)
add_custom_command(TARGET ${EXECUTABLE} POST_BUILD COMMAND ${SIZE} --format=berkeley ${DEPLOY_DIR}/${EXECUTABLE})
# Print build info
message("=====================================")
message("Project: ${CMAKE_PROJECT_NAME}")
message("Build type: ${CMAKE_BUILD_TYPE}")
message("=====================================")