-
Notifications
You must be signed in to change notification settings - Fork 18
Expand file tree
/
Copy pathCMakeLists.txt
More file actions
369 lines (330 loc) · 12.9 KB
/
CMakeLists.txt
File metadata and controls
369 lines (330 loc) · 12.9 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
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
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
if (NOT (DEFINED PICO_PLATFORM AND PICO_PLATFORM STREQUAL "host"))
# == DO NOT EDIT THE FOLLOWING LINES for the Raspberry Pi Pico VS Code Extension to work ==
if(WIN32)
set(USERHOME $ENV{USERPROFILE})
else()
set(USERHOME $ENV{HOME})
endif()
set(sdkVersion 2.2.0)
set(toolchainVersion 14_2_Rel1)
set(picotoolVersion 2.2.0)
set(picoVscode ${USERHOME}/.pico-sdk/cmake/pico-vscode.cmake)
if (EXISTS ${picoVscode})
include(${picoVscode})
endif()
# ====================================================================================
endif()
cmake_minimum_required(VERSION 3.13)
set(CMAKE_C_STANDARD 17)
set(CMAKE_CXX_STANDARD 20)
set(CMAKE_EXPORT_COMPILE_COMMANDS ON)
# Pull in Raspberry Pi Pico SDK (must be before project, but after PICO_BOARD)
include($ENV{PICO_SDK_PATH}/external/pico_sdk_import.cmake)
project(286 C CXX ASM)
SET(BUILD_NAME "${PROJECT_NAME}")
#set(MURM20 ON)
#set(m1p2launcher ON)
# CPU Configuration
set(CPU_FREQ_MHZ "500")
set(FLASH_FREQ_MHZ "100")
set(PSRAM_FREQ_MHZ "166")
# =========================
# OUTPUT DIRECTORIES
# =========================
set(OUTPUT_DIR "${CMAKE_SOURCE_DIR}/bin/${PICO_PLATFORM}/${CMAKE_BUILD_TYPE}")
set(CMAKE_ARCHIVE_OUTPUT_DIRECTORY "${OUTPUT_DIR}")
set(CMAKE_RUNTIME_OUTPUT_DIRECTORY "${OUTPUT_DIR}")
set(CMAKE_LIBRARY_OUTPUT_DIRECTORY "${OUTPUT_DIR}")
# =========================
# SOURCE FILES
# =========================
file(GLOB_RECURSE SRC "src/emulator/*.cpp" "src/emulator/*.c" "src/emu8950/*.c" "src/emu8950/*.cpp")
message(STATUS "Add source files:")
foreach (SRC_FILE IN LISTS SRC)
message(STATUS "${SRC_FILE}")
endforeach ()
message(STATUS "")
# =========================
# HOST BUILD (Windows/Linux)
# =========================
if (PICO_PLATFORM STREQUAL "host")
add_compile_options(-fms-extensions -O2)
if (WIN32)
add_executable(${PROJECT_NAME} ${SRC} src/win32-main.cpp src/WinMiniFB.c src/printf/printf.c)
target_link_libraries(${PROJECT_NAME} PRIVATE winmm)
else ()
# Linux build
add_executable(${PROJECT_NAME} ${SRC} src/linux-main.cpp src/LinuxMiniFB.c src/linux-audio.c src/printf/printf.c findfirst/findfirst.c findfirst/spec.c)
target_link_libraries(${PROJECT_NAME} PRIVATE X11 pthread)
target_include_directories(${PROJECT_NAME} PRIVATE src src/emu8950 src/printf findfirst/)
endif ()
target_include_directories(${PROJECT_NAME} PRIVATE src src/emu8950 src/printf)
else ()
#set(CMAKE_BUILD_TYPE "MinSizeRel") /// outside!
# =========================
# PICO BUILD CONFIGURATION
# =========================
#set(PICO_BOARD pico2 CACHE STRING "Board type") // should be early
pico_sdk_init()
# =========================
# BUILD OPTIONS
# =========================
# Display Options (mutually exclusive)
option(ENABLE_TFT "Enable TFT display output" OFF)
option(ENABLE_VGA "Enable VGA display output" OFF)
option(ENABLE_HDMI "Enable HDMI display output" OFF)
option(ENABLE_NTSC-TV "Enable NTSC TV output" OFF)
# Audio Options (mutually exclusive)
option(ENABLE_I2S_SOUND "Enable I2S audio output" OFF)
option(ENABLE_PWM_SOUND "Enable PWM audio output" OFF)
option(ENABLE_HARDWARE_SOUND "Enable hardware audio output" OFF)
# =========================
# VALIDATION
# =========================
# Validate display options
set(DISPLAY_COUNT 0)
if (ENABLE_TFT)
message(STATUS "TFT Enabled")
math(EXPR DISPLAY_COUNT "${DISPLAY_COUNT} + 1")
endif ()
if (ENABLE_VGA)
message(STATUS "VGA Enabled")
math(EXPR DISPLAY_COUNT "${DISPLAY_COUNT} + 1")
endif ()
if (ENABLE_HDMI)
IF(PICO_BOARD EQUAL "pico2")
set(CPU_FREQ_MHZ "504")
message(STATUS "HDMI enabled - CPU frequency locked to 504 MHz")
else ()
set(CPU_FREQ_MHZ "504")
message(STATUS "HDMI enabled - CPU frequency locked to 378 MHz")
endif ()
math(EXPR DISPLAY_COUNT "${DISPLAY_COUNT} + 1")
endif ()
if (ENABLE_NTSC-TV)
set(CPU_FREQ_MHZ "315")
message(STATUS "NTSC TV out enabled - CPU frequency locked to 315 MHz")
math(EXPR DISPLAY_COUNT "${DISPLAY_COUNT} + 1")
endif ()
if (DISPLAY_COUNT EQUAL 0)
message(FATAL_ERROR "At least one display option must be enabled")
elseif (DISPLAY_COUNT GREATER 1)
message(FATAL_ERROR "Only one display option can be enabled at a time")
endif ()
# Validate audio options
set(AUDIO_COUNT 0)
if (ENABLE_I2S_SOUND)
math(EXPR AUDIO_COUNT "${AUDIO_COUNT} + 1")
endif ()
if (ENABLE_PWM_SOUND)
math(EXPR AUDIO_COUNT "${AUDIO_COUNT} + 1")
endif ()
if (ENABLE_HARDWARE_SOUND)
math(EXPR AUDIO_COUNT "${AUDIO_COUNT} + 1")
endif ()
if (AUDIO_COUNT EQUAL 0)
message(FATAL_ERROR "At least one audio option must be enabled")
elseif (AUDIO_COUNT GREATER 1)
message(FATAL_ERROR "Only one audio option can be enabled at a time")
endif ()
# =========================
# BUILD NAME GENERATION
# =========================
set(BUILD_NAME "${PROJECT_NAME}")
# Add platform
if (PICO_PLATFORM STREQUAL "rp2040")
if (MURM20)
set(BUILD_NAME "m2p1-${BUILD_NAME}")
else ()
set(BUILD_NAME "m1p1-${BUILD_NAME}")
endif ()
else ()
if (MURM20)
set(BUILD_NAME "m2p2-${BUILD_NAME}")
else ()
set(BUILD_NAME "m1p2-${BUILD_NAME}")
endif ()
endif ()
# Add frequency
set(BUILD_NAME "${BUILD_NAME}-F${FLASH_FREQ_MHZ}-P${PSRAM_FREQ_MHZ}-${CPU_FREQ_MHZ}MHz")
# Add display type
if (ENABLE_TFT)
set(BUILD_NAME "${BUILD_NAME}-TFT")
elseif (ENABLE_NTSC-TV)
set(BUILD_NAME "${BUILD_NAME}-TV")
elseif (ENABLE_VGA)
set(BUILD_NAME "${BUILD_NAME}-VGA")
elseif (ENABLE_HDMI)
set(BUILD_NAME "${BUILD_NAME}-HDMI")
endif ()
# Add audio type
if (ENABLE_I2S_SOUND)
set(BUILD_NAME "${BUILD_NAME}-I2S")
elseif (ENABLE_PWM_SOUND)
set(BUILD_NAME "${BUILD_NAME}-PWM")
elseif (ENABLE_HARDWARE_SOUND)
set(BUILD_NAME "${BUILD_NAME}-HW")
endif ()
# =========================
# EXECUTABLE SETUP
# =========================
add_link_options(-flto -fwhole-program)
# -frename-registers -fno-tree-vectorize
add_compile_options(
-flto=auto
-frename-registers
-fomit-frame-pointer
-fwhole-program
# -ffreestanding // build issues with std::malloc/std::free in SDK 2.1+
-ffast-math
-ffunction-sections
-fdata-sections
-fms-extensions
-O2
)
add_executable(${PROJECT_NAME} ${SRC} src/pico-main.c src/printf/printf.c src/74hc595/74hc595.c)
target_include_directories(${PROJECT_NAME} PRIVATE src/74hc595 src src/emu8950 src/printf)
target_sources(${PROJECT_NAME} PRIVATE src/emu8950/slot_render_pico.S)
# =========================
# BOOT STAGE 2 CONFIGURATION
# =========================
pico_define_boot_stage2(slower_boot2 ${PICO_DEFAULT_BOOT_STAGE2_FILE})
if (PICO_PLATFORM STREQUAL "rp2040")
add_subdirectory(memops_opt)
target_link_libraries(${PROJECT_NAME} PRIVATE memops_opt)
target_compile_definitions(slower_boot2 PRIVATE PICO_FLASH_SPI_CLKDIV=4)
else ()
if (m1p2launcher)
if (MURM20)
set(BUILD_NAME "${BUILD_NAME}.m2p2")
else ()
set(BUILD_NAME "${BUILD_NAME}.m1p2")
endif ()
pico_set_linker_script(${PROJECT_NAME} "${CMAKE_SOURCE_DIR}/memmap12.ld")
else ()
pico_set_linker_script(${PROJECT_NAME} "${CMAKE_SOURCE_DIR}/memmap.ld")
endif ()
endif ()
set_target_properties(${PROJECT_NAME} PROPERTIES OUTPUT_NAME "${BUILD_NAME}")
target_link_options(${PROJECT_NAME} PRIVATE -Xlinker --print-memory-usage --data-sections --function-sections)
pico_set_program_name(286 "PC 8086/8088/186/286 emulator")
pico_set_program_version(${PROJECT_NAME} "1.1.0")
pico_set_boot_stage2(${PROJECT_NAME} slower_boot2)
# =========================
# SUBDIRECTORIES
# =========================
add_subdirectory(drivers/ps2)
add_subdirectory(drivers/fatfs)
add_subdirectory(drivers/sdcard)
add_subdirectory(drivers/audio)
add_subdirectory(drivers/psram)
add_subdirectory(drivers/nespad)
# Display drivers
if (ENABLE_TFT)
add_subdirectory(drivers/graphics)
add_subdirectory(drivers/st7789)
target_link_libraries(${PROJECT_NAME} PRIVATE st7789)
message(STATUS "TFT display enabled")
elseif (ENABLE_NTSC-TV)
add_subdirectory(drivers/ntsc-tv)
message(STATUS "NTSC TV out enabled")
elseif (ENABLE_VGA)
add_subdirectory(drivers/graphics)
add_subdirectory(drivers/vga-nextgen)
target_link_libraries(${PROJECT_NAME} PRIVATE vga-nextgen)
message(STATUS "VGA display enabled")
elseif (ENABLE_HDMI)
add_subdirectory(drivers/graphics)
add_subdirectory(drivers/hdmi)
target_link_libraries(${PROJECT_NAME} PRIVATE hdmi)
message(STATUS "HDMI display enabled")
endif ()
# =========================
# LIBRARIES
# =========================
target_link_libraries(${PROJECT_NAME} PRIVATE
ps2 sdcard audio graphics nespad psram
pico_runtime pico_stdlib pico_multicore
hardware_dma hardware_pio hardware_i2c hardware_exception
hardware_interp hardware_timer hardware_clocks hardware_pwm hardware_flash
-Wl,--wrap=atexit,--wrap=abort,--strip-all,--gc-sections # size optimizations
)
pico_set_printf_implementation(${PROJECT_NAME} none)
# =========================
# COMPILE DEFINITIONS
# =========================
target_compile_definitions(${PROJECT_NAME} PRIVATE
# Core definitions
PICO_PANIC_FUNCTION=
EMU8950_ASM=1
CPU_FREQ_MHZ=${CPU_FREQ_MHZ}
FLASH_FREQ_MHZ=${FLASH_FREQ_MHZ}
PSRAM_FREQ_MHZ=${PSRAM_FREQ_MHZ}
PICO_FLASH_SIZE_BYTES=16777216
# Display type
$<$<BOOL:${ENABLE_TFT}>:TFT>
$<$<BOOL:${ENABLE_VGA}>:VGA>
$<$<BOOL:${ENABLE_HDMI}>:HDMI>
$<$<BOOL:${ENABLE_NTSC-TV}>:NTSC>
# Audio type
$<$<BOOL:${ENABLE_I2S_SOUND}>:I2S_SOUND>
$<$<BOOL:${ENABLE_PWM_SOUND}>:PWM_SOUND>
$<$<BOOL:${ENABLE_HARDWARE_SOUND}>:HARDWARE_SOUND>
PSRAM
)
if (MURM20)
target_compile_definitions(${PROJECT_NAME} PRIVATE
MURM2=1
# Pin configurations
MOUSE_CLOCK_PIN=0 MOUSE_DATA_PIN=1
KBD_CLOCK_PIN=2 KBD_DATA_PIN=3
VGA_BASE_PIN=12 HDMI_BASE_PIN=12
TFT_CS_PIN=12 TFT_RST_PIN=14 TFT_LED_PIN=15 TFT_DC_PIN=16 TFT_DATA_PIN=18 TFT_CLK_PIN=19
SDCARD_PIN_SPI0_CS=5 SDCARD_PIN_SPI0_SCK=6 SDCARD_PIN_SPI0_MOSI=7 SDCARD_PIN_SPI0_MISO=4
PSRAM_SPINLOCK=1 PSRAM_ASYNC=1 PSRAM_PIN_CS=18 PSRAM_PIN_SCK=19 PSRAM_PIN_MOSI=20 PSRAM_PIN_MISO=21
USE_NESPAD NES_GPIO_CLK=20 NES_GPIO_DATA=21 NES_GPIO_LAT=26
CLOCK_PIN=27 PCM_PIN=22
PWM_BEEPER=9 PWM_LEFT_CHANNEL=10 PWM_RIGHT_CHANNEL=11
)
else ()
target_compile_definitions(${PROJECT_NAME} PRIVATE
# Pin configurations
MOUSE_CLOCK_PIN=14 MOUSE_DATA_PIN=15
KBD_CLOCK_PIN=0 KBD_DATA_PIN=1
VGA_BASE_PIN=6 HDMI_BASE_PIN=6
TFT_CS_PIN=6 TFT_RST_PIN=8 TFT_LED_PIN=9 TFT_DC_PIN=10 TFT_DATA_PIN=12 TFT_CLK_PIN=13
SDCARD_PIN_SPI0_CS=5 SDCARD_PIN_SPI0_SCK=2 SDCARD_PIN_SPI0_MOSI=3 SDCARD_PIN_SPI0_MISO=4
PSRAM_SPINLOCK=1 PSRAM_ASYNC=1 PSRAM_PIN_CS=18 PSRAM_PIN_SCK=19 PSRAM_PIN_MOSI=20 PSRAM_PIN_MISO=21
USE_NESPAD NES_GPIO_CLK=14 NES_GPIO_DATA=16 NES_GPIO_LAT=15
CLOCK_PIN=17 PCM_PIN=22
PWM_BEEPER=28 PWM_LEFT_CHANNEL=26 PWM_RIGHT_CHANNEL=27
)
endif ()
pico_add_extra_outputs(${PROJECT_NAME})
if (m1p2launcher)
add_custom_command(TARGET ${PROJECT_NAME} POST_BUILD
COMMAND ${CMAKE_COMMAND} -E rename
"${OUTPUT_DIR}/${BUILD_NAME}.uf2"
"${OUTPUT_DIR}/${BUILD_NAME}"
)
endif ()
endif ()
# =========================
# COMMON DEFINITIONS (HOST + PICO)
# =========================
target_compile_definitions(${PROJECT_NAME} PRIVATE
USE_EMU8950_OPL
EMU8950_SLOT_RENDER=1
EMU8950_NO_RATECONV=1
EMU8950_NO_WAVE_TABLE_MAP=1
EMU8950_NO_TLL=1
EMU8950_NO_FLOAT=1
EMU8950_NO_TIMER=1
EMU8950_NO_TEST_FLAG=1
EMU8950_SIMPLER_NOISE=1
EMU8950_SHORT_NOISE_UPDATE_CHECK=1
EMU8950_LINEAR_SKIP=1
EMU8950_LINEAR_END_OF_NOTE_OPTIMIZATION
EMU8950_NO_PERCUSSION_MODE=1
EMU8950_LINEAR=1
)