-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathCMakeLists.txt
More file actions
158 lines (128 loc) · 4.18 KB
/
CMakeLists.txt
File metadata and controls
158 lines (128 loc) · 4.18 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
cmake_minimum_required(VERSION 3.13)
set(CMAKE_C_STANDARD 23)
set(CMAKE_CXX_STANDARD 23)
set(CMAKE_C_STANDARD_REQUIRED ON)
set(OUTPUT_DIR "${CMAKE_SOURCE_DIR}/bin/")
set(CMAKE_ARCHIVE_OUTPUT_DIRECTORY "${OUTPUT_DIR}")
set(CMAKE_RUNTIME_OUTPUT_DIRECTORY "${OUTPUT_DIR}")
set(CMAKE_LIBRARY_OUTPUT_DIRECTORY "${OUTPUT_DIR}")
set(PICO_FLASH_SIZE_BYTES 16777216)
set(PICO_PLATFORM rp2350-arm-s)
set(PICO_BOARD WEACT_STUDIO_RP2350B_CORE)
option(VGA "Video output VGA" ON)
include($ENV{PICO_SDK_PATH}/external/pico_sdk_import.cmake)
project(RP8086 C CXX ASM)
SET(BUILD_NAME "${PROJECT_NAME}")
pico_sdk_init()
add_compile_options(
# -flto=auto
# -fwhole-program
# -ffunction-sections
# -fdata-sections
-Ofast
)
add_link_options(-flto -fwhole-program)
add_executable(${PROJECT_NAME}
src/main.c
src/cpu.c
src/cpu_bus.c
src/common.c
src/setup.c
)
if(VGA)
add_subdirectory(drivers/graphics)
add_subdirectory(drivers/vga-nextgen)
target_link_libraries(${PROJECT_NAME} PRIVATE vga-nextgen)
else ()
add_subdirectory(drivers/ntsc-tv)
endif ()
add_subdirectory(drivers/sdcard)
add_subdirectory(drivers/fatfs)
message(STATUS "VGA display enabled")
target_compile_definitions(${PROJECT_NAME} PRIVATE
VGA
VGA_BASE_PIN=30
SDCARD_PIN_SPI0_MISO=40
SDCARD_PIN_SPI0_CS=41
SDCARD_PIN_SPI0_SCK=42
SDCARD_PIN_SPI0_MOSI=43
PICO_FLASH_SIZE_BYTES=16777216
PICO_PRINTF_ALWAYS_INCLUDED=0
PICO_PANIC_FUNCTION=0
)
pico_generate_pio_header(${PROJECT_NAME}
${CMAKE_CURRENT_SOURCE_DIR}/src/i8086_bus.pio
OUTPUT_DIR ${CMAKE_CURRENT_SOURCE_DIR}/src/
)
if (DEBUG)
target_compile_definitions(${PROJECT_NAME} PRIVATE DEBUG=1)
pico_enable_stdio_uart(${PROJECT_NAME} 0)
pico_enable_stdio_usb(${PROJECT_NAME} 1)
set(BUILD_NAME "${BUILD_NAME}-DEBUG")
else ()
pico_enable_stdio_semihosting(${PROJECT_NAME} ENABLED)
set(FAMILY rp2350)
set(BOARD pico_sdk)
add_subdirectory(drivers/usbhid)
target_include_directories(${PROJECT_NAME} PRIVATE ./host/)
target_link_libraries(${PROJECT_NAME} PRIVATE
usbhid
tinyusb_host
tinyusb_board
pico_stdio_semihosting
)
endif ()
target_include_directories(${PROJECT_NAME} PRIVATE
${CMAKE_CURRENT_LIST_DIR}
)
target_link_libraries(${PROJECT_NAME} PRIVATE
sdcard
fatfs
graphics
pico_runtime
pico_stdlib
pico_stdio
pico_multicore
hardware_pio
hardware_pwm
)
pico_set_binary_type(${PROJECT_NAME} copy_to_ram)
pico_add_extra_outputs(${PROJECT_NAME})
# Post-build step: increment build number and copy firmware files with incremental suffix
add_custom_command(TARGET ${PROJECT_NAME} POST_BUILD
COMMAND ${CMAKE_COMMAND}
-DPROJECT_NAME=${BUILD_NAME}
-DOUTPUT_DIR=${OUTPUT_DIR}
-DBUILD_NUMBER_FILE=${CMAKE_SOURCE_DIR}/.build_number
-P ${CMAKE_SOURCE_DIR}/rename_with_build_number.cmake
COMMENT "Appending incremental build number to firmware filenames"
)
execute_process(
COMMAND git rev-parse --abbrev-ref HEAD
WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}
OUTPUT_VARIABLE GIT_BRANCH
OUTPUT_STRIP_TRAILING_WHITESPACE
)
execute_process(
COMMAND git rev-parse --short HEAD
WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}
OUTPUT_VARIABLE GIT_COMMIT_HASH
OUTPUT_STRIP_TRAILING_WHITESPACE
)
target_compile_definitions(${PROJECT_NAME} PRIVATE
PICO_BUILD_NAME="${BUILD_NAME}"
PICO_GIT_BRANCH="${GIT_BRANCH}"
PICO_GIT_COMMIT="${GIT_COMMIT_HASH}"
)
pico_set_program_name(${PROJECT_NAME} "${PROJECT_NAME}")
pico_set_program_version(${PROJECT_NAME} "${GIT_BRANCH} ${GIT_COMMIT_HASH}")
pico_set_linker_script(${PROJECT_NAME} "${CMAKE_SOURCE_DIR}/memmap.ld")
set_target_properties(${PROJECT_NAME} PROPERTIES OUTPUT_NAME "${BUILD_NAME}")
target_link_options(${PROJECT_NAME} PRIVATE
-Xlinker
--print-memory-usage
--data-sections
--function-sections
-fanalyzer
-Wl,--wrap=atexit,--wrap=abort,--strip-all,--gc-sections # size optimizations
)