2022-08-08 01:16:52 +00:00
|
|
|
cmake_minimum_required(VERSION 3.10)
|
|
|
|
|
|
|
|
enable_language(ASM)
|
|
|
|
|
2022-08-08 01:56:55 +00:00
|
|
|
project(benchmark)
|
2022-08-08 01:16:52 +00:00
|
|
|
|
|
|
|
set(TARGET_LDSCRIPT "${CMAKE_SOURCE_DIR}/stx7105.ld")
|
|
|
|
|
|
|
|
set(TARGET_SOURCES
|
2022-08-08 01:56:55 +00:00
|
|
|
"lib/coremark/core_list_join.c"
|
|
|
|
"lib/coremark/core_main.c"
|
|
|
|
"lib/coremark/core_matrix.c"
|
|
|
|
"lib/coremark/core_state.c"
|
|
|
|
"lib/coremark/core_util.c"
|
2022-08-08 01:16:52 +00:00
|
|
|
"lib/printf/printf.c"
|
2022-08-08 01:56:55 +00:00
|
|
|
"src/core_portme.c"
|
2022-08-08 01:16:52 +00:00
|
|
|
"src/stx7105_exc.c"
|
|
|
|
"src/stx7105_utils.c"
|
|
|
|
"startup_stx7105.S"
|
|
|
|
)
|
|
|
|
|
|
|
|
set(TARGET_INCLUDES
|
|
|
|
"include"
|
2022-08-08 01:56:55 +00:00
|
|
|
"lib/coremark"
|
2022-08-08 01:16:52 +00:00
|
|
|
"lib/printf"
|
|
|
|
)
|
|
|
|
|
2022-08-08 01:56:55 +00:00
|
|
|
set(TARGET_DEFS
|
2022-08-09 17:23:15 +00:00
|
|
|
"ITERATIONS=2000UL"
|
2022-08-08 01:56:55 +00:00
|
|
|
"PERFORMANCE_RUN=1"
|
|
|
|
)
|
|
|
|
|
2022-08-08 01:16:52 +00:00
|
|
|
set(TARGET_FLAGS_HARDWARE "-m4-300 -ml")
|
|
|
|
|
2022-08-09 17:23:15 +00:00
|
|
|
set(TARGET_MANUAL_OPTS "-fauto-inc-dec -fbranch-count-reg -fcombine-stack-adjustments -fcompare-elim -fcprop-registers -fdce -fdefer-pop -fdelayed-branch -fdse -fforward-propagate")
|
|
|
|
|
|
|
|
set(CMAKE_C_FLAGS_DEBUG "-DDEBUG -g -O0 ${TARGET_MANUAL_OPTS}")
|
|
|
|
set(CMAKE_CXX_FLAGS_DEBUG "-DDEBUG -g -O0 ${TARGET_MANUAL_OPTS}")
|
2022-08-08 01:16:52 +00:00
|
|
|
set(CMAKE_EXE_LINKER_FLAGS_DEBUG "")
|
|
|
|
|
|
|
|
set(CMAKE_C_FLAGS_RELEASE "-DNDEBUG -O2 -flto")
|
|
|
|
set(CMAKE_CXX_FLAGS_RELEASE "-DNDEBUG -O2 -flto")
|
|
|
|
set(CMAKE_EXE_LINKER_FLAGS_RELEASE "-flto")
|
|
|
|
|
|
|
|
set(CMAKE_C_FLAGS "${TARGET_FLAGS_HARDWARE} -Wall -ffunction-sections -fdata-sections")
|
|
|
|
set(CMAKE_CXX_FLAGS "${TARGET_FLAGS_HARDWARE} -Wall -ffunction-sections -fdata-sections")
|
2022-08-09 17:23:15 +00:00
|
|
|
set(CMAKE_EXE_LINKER_FLAGS "${TARGET_FLAGS_HARDWARE} -specs=nosys.specs -Wall -lc -lm -nostartfiles -Wl,--print-memory-usage -Wl,--gc-sections")
|
2022-08-08 01:16:52 +00:00
|
|
|
|
|
|
|
add_compile_definitions(${TARGET_DEFS})
|
|
|
|
include_directories(${TARGET_INCLUDES})
|
|
|
|
|
|
|
|
add_executable(${CMAKE_PROJECT_NAME}.elf ${TARGET_SOURCES})
|
|
|
|
target_link_options(${CMAKE_PROJECT_NAME}.elf
|
|
|
|
PRIVATE "-T${TARGET_LDSCRIPT}"
|
|
|
|
PRIVATE "-Wl,-Map=${CMAKE_PROJECT_NAME}.map"
|
|
|
|
)
|