2021-01-30 11:25:14 +00:00
|
|
|
enable_language(ASM_NASM)
|
|
|
|
if(NOT CMAKE_ASM_NASM_COMPILER_LOADED)
|
|
|
|
error("Failed to find NASM compatible assembler!")
|
|
|
|
endif()
|
2019-07-13 09:41:34 +00:00
|
|
|
|
|
|
|
# Careful. Globbing can't see changes to the contents of files
|
|
|
|
# Need to do a fresh clean to see changes
|
2020-03-04 01:11:24 +00:00
|
|
|
file(GLOB_RECURSE ASM_SOURCES CONFIGURE_DEPENDS *.asm)
|
2019-07-13 09:41:34 +00:00
|
|
|
|
|
|
|
set(ASM_DEPENDS "")
|
2022-06-30 20:55:38 +00:00
|
|
|
|
|
|
|
execute_process(COMMAND "python3" "${CMAKE_SOURCE_DIR}/Scripts/ClassifyCPU.py"
|
|
|
|
OUTPUT_STRIP_TRAILING_WHITESPACE
|
|
|
|
OUTPUT_VARIABLE CPU_CLASS)
|
|
|
|
|
2019-07-13 09:41:34 +00:00
|
|
|
foreach(ASM_SRC ${ASM_SOURCES})
|
2020-06-11 00:39:08 +00:00
|
|
|
file(RELATIVE_PATH REL_ASM ${CMAKE_SOURCE_DIR} ${ASM_SRC})
|
|
|
|
file(RELATIVE_PATH REL_TEST_ASM ${CMAKE_CURRENT_SOURCE_DIR} ${ASM_SRC})
|
2019-07-13 09:41:34 +00:00
|
|
|
get_filename_component(ASM_NAME ${ASM_SRC} NAME)
|
2020-06-11 00:39:08 +00:00
|
|
|
get_filename_component(ASM_DIR "${REL_ASM}" DIRECTORY)
|
|
|
|
set(OUTPUT_ASM_FOLDER "${CMAKE_BINARY_DIR}/${ASM_DIR}")
|
|
|
|
|
|
|
|
# Generate build directory
|
2022-06-14 22:10:29 +00:00
|
|
|
file(MAKE_DIRECTORY "${OUTPUT_ASM_FOLDER}")
|
2019-07-13 09:41:34 +00:00
|
|
|
|
|
|
|
# Generate a temporary file
|
2020-06-11 00:39:08 +00:00
|
|
|
set(ASM_TMP "${ASM_NAME}_TMP.asm")
|
|
|
|
set(TMP_FILE "${OUTPUT_ASM_FOLDER}/${ASM_TMP}")
|
|
|
|
|
2019-07-13 09:41:34 +00:00
|
|
|
add_custom_command(OUTPUT ${TMP_FILE}
|
|
|
|
DEPENDS "${ASM_SRC}"
|
|
|
|
COMMAND "cp" ARGS "${ASM_SRC}" "${TMP_FILE}"
|
|
|
|
COMMAND "sed" ARGS "-i" "-e" "\'1s;^;BITS 64\\n;\'" "-e" "\'\$\$a\\ret\\n\'" "${TMP_FILE}"
|
|
|
|
)
|
|
|
|
|
2020-06-11 00:39:08 +00:00
|
|
|
set(OUTPUT_NAME "${OUTPUT_ASM_FOLDER}/${ASM_NAME}.bin")
|
|
|
|
set(OUTPUT_CONFIG_NAME "${OUTPUT_ASM_FOLDER}/${ASM_NAME}.config.bin")
|
2019-07-13 09:41:34 +00:00
|
|
|
|
|
|
|
add_custom_command(OUTPUT ${OUTPUT_NAME}
|
|
|
|
DEPENDS "${TMP_FILE}"
|
2020-06-11 00:39:08 +00:00
|
|
|
COMMAND "nasm" ARGS "${TMP_FILE}" "-o" "${OUTPUT_NAME}")
|
2019-07-13 09:41:34 +00:00
|
|
|
|
|
|
|
add_custom_command(OUTPUT ${OUTPUT_CONFIG_NAME}
|
|
|
|
DEPENDS "${ASM_SRC}"
|
2020-06-10 20:47:52 +00:00
|
|
|
DEPENDS "${CMAKE_SOURCE_DIR}/Scripts/json_asm_config_parse.py"
|
2020-08-20 11:33:14 +00:00
|
|
|
DEPENDS "${CMAKE_SOURCE_DIR}/Scripts/json_config_parse.py"
|
2020-06-11 00:39:08 +00:00
|
|
|
COMMAND "python3" ARGS "${CMAKE_SOURCE_DIR}/Scripts/json_asm_config_parse.py" "${ASM_SRC}" "${OUTPUT_CONFIG_NAME}")
|
2019-07-13 09:41:34 +00:00
|
|
|
|
|
|
|
list(APPEND ASM_DEPENDS "${OUTPUT_NAME};${OUTPUT_CONFIG_NAME}")
|
|
|
|
|
2020-09-23 18:07:25 +00:00
|
|
|
# Format is "<Test Arguments>" "<Test Name>" "<Test Type>"
|
2019-11-16 02:04:10 +00:00
|
|
|
set(TEST_ARGS
|
2021-03-27 01:04:17 +00:00
|
|
|
"--no-silent -g -c irjit -n 1 --no-multiblock" "jit_1" "jit"
|
|
|
|
"--no-silent -g -c irjit -n 500 --no-multiblock" "jit_500" "jit"
|
|
|
|
"--no-silent -g -c irjit -n 500 --multiblock" "jit_500_m" "jit"
|
2020-03-17 21:40:28 +00:00
|
|
|
)
|
2022-02-11 20:55:10 +00:00
|
|
|
if (ENABLE_INTERPRETER)
|
|
|
|
list(APPEND TEST_ARGS
|
|
|
|
"--no-silent -g -c irint -n 1 --no-multiblock" "int_1" "int"
|
|
|
|
"--no-silent -g -c irint -n 500 --no-multiblock" "int_500" "int"
|
|
|
|
"--no-silent -g -c irint -n 500 --multiblock" "int_500_m" "int"
|
|
|
|
)
|
|
|
|
endif()
|
|
|
|
|
2022-09-08 02:12:46 +00:00
|
|
|
if (ENABLE_VIXL_SIMULATOR)
|
|
|
|
set(CPU_CLASS Simulator)
|
|
|
|
else()
|
|
|
|
if (_M_X86_64)
|
|
|
|
list(APPEND TEST_ARGS
|
|
|
|
"--no-silent -g -c host" "host" "host"
|
|
|
|
)
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
|
2020-03-17 21:40:28 +00:00
|
|
|
list(LENGTH TEST_ARGS ARG_COUNT)
|
|
|
|
math(EXPR ARG_COUNT "${ARG_COUNT}-1")
|
2020-09-23 18:07:25 +00:00
|
|
|
foreach(Index RANGE 0 ${ARG_COUNT} 3)
|
2020-03-17 21:40:28 +00:00
|
|
|
math(EXPR TEST_NAME_INDEX "${Index}+1")
|
2020-09-23 18:07:25 +00:00
|
|
|
math(EXPR TEST_TYPE_INDEX "${Index}+2")
|
2019-11-16 02:04:10 +00:00
|
|
|
|
2020-03-17 21:40:28 +00:00
|
|
|
list(GET TEST_ARGS ${Index} ARGS)
|
|
|
|
list(GET TEST_ARGS ${TEST_NAME_INDEX} TEST_DESC)
|
2020-09-23 18:07:25 +00:00
|
|
|
list(GET TEST_ARGS ${TEST_TYPE_INDEX} TEST_TYPE)
|
2020-03-17 21:40:28 +00:00
|
|
|
|
2020-06-11 00:39:08 +00:00
|
|
|
set(TEST_NAME "${TEST_DESC}/Test_${REL_TEST_ASM}")
|
2019-11-16 02:04:10 +00:00
|
|
|
string(REPLACE " " ";" ARGS_LIST ${ARGS})
|
2020-09-15 21:33:16 +00:00
|
|
|
|
|
|
|
if (TEST_NAME MATCHES "SelfModifyingCode")
|
2021-03-29 07:24:53 +00:00
|
|
|
list(APPEND ARGS_LIST "--smcchecks=full")
|
2020-09-15 21:33:16 +00:00
|
|
|
endif()
|
|
|
|
|
2019-11-16 02:04:10 +00:00
|
|
|
add_test(NAME ${TEST_NAME}
|
2020-03-16 19:35:09 +00:00
|
|
|
COMMAND "python3" "${CMAKE_SOURCE_DIR}/Scripts/testharness_runner.py"
|
|
|
|
"${CMAKE_SOURCE_DIR}/unittests/ASM/Known_Failures"
|
2022-10-23 03:29:51 +00:00
|
|
|
"${CMAKE_SOURCE_DIR}/unittests/ASM/Known_Failures_${TEST_TYPE}"
|
2020-05-28 22:09:51 +00:00
|
|
|
"${CMAKE_SOURCE_DIR}/unittests/ASM/Disabled_Tests"
|
2020-09-23 18:07:25 +00:00
|
|
|
"${CMAKE_SOURCE_DIR}/unittests/ASM/Disabled_Tests_${TEST_TYPE}"
|
2022-06-30 20:55:38 +00:00
|
|
|
"${CMAKE_SOURCE_DIR}/unittests/ASM/Disabled_Tests_${CPU_CLASS}"
|
2020-06-11 00:39:08 +00:00
|
|
|
"Test_${REL_TEST_ASM}"
|
2020-03-16 19:35:09 +00:00
|
|
|
"${CMAKE_BINARY_DIR}/Bin/TestHarnessRunner"
|
|
|
|
${ARGS_LIST} "${OUTPUT_NAME}" "${OUTPUT_CONFIG_NAME}")
|
2019-11-16 02:04:10 +00:00
|
|
|
# This will cause the ASM tests to fail if it can't find the TestHarness or ASMN files
|
|
|
|
# Prety crap way to work around the fact that tests can't have a build dependency in a different directory
|
|
|
|
# Just make sure to independently run `make all` then `make test`
|
|
|
|
set_property(TEST ${TEST_NAME} APPEND PROPERTY DEPENDS "${CMAKE_BINARY_DIR}/Bin/TestHarnessRunner")
|
|
|
|
set_property(TEST ${TEST_NAME} APPEND PROPERTY DEPENDS "${OUTPUT_NAME}")
|
|
|
|
set_property(TEST ${TEST_NAME} APPEND PROPERTY DEPENDS "${OUTPUT_CONFIG_NAME}")
|
|
|
|
endforeach()
|
2019-07-13 09:41:34 +00:00
|
|
|
|
|
|
|
endforeach()
|
|
|
|
|
|
|
|
add_custom_target(asm_files ALL
|
|
|
|
DEPENDS "${ASM_DEPENDS}")
|
2020-05-09 02:28:59 +00:00
|
|
|
|
|
|
|
execute_process(COMMAND "nproc" OUTPUT_VARIABLE CORES)
|
|
|
|
string(STRIP ${CORES} CORES)
|
|
|
|
|
|
|
|
add_custom_target(
|
|
|
|
asm_tests
|
|
|
|
WORKING_DIRECTORY "${CMAKE_BINARY_DIR}"
|
|
|
|
USES_TERMINAL
|
2021-01-09 17:26:15 +00:00
|
|
|
COMMAND "ctest" "--timeout" "302" "-j${CORES}" "-R" "\.*.asm$$")
|