You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
110 lines
3.2 KiB
110 lines
3.2 KiB
4 months ago
|
# arguments checking
|
||
|
if(NOT COMPILER)
|
||
|
message(FATAL_ERROR "Require COMPILER to be defined")
|
||
|
endif(NOT COMPILER)
|
||
|
|
||
|
if(NOT RUNTIME)
|
||
|
message(FATAL_ERROR "Require RUNTIME to be defined")
|
||
|
endif(NOT RUNTIME)
|
||
|
|
||
|
if(NOT TEST_DIR)
|
||
|
message(FATAL_ERROR "Require TEST_DIR to be defined")
|
||
|
endif(NOT TEST_DIR)
|
||
|
|
||
|
if(NOT TEST_NAME)
|
||
|
message(FATAL_ERROR "Require TEST_NAME to be defined")
|
||
|
endif(NOT TEST_NAME)
|
||
|
|
||
|
# Sources
|
||
|
set(TEST_SRC "${TEST_DIR}/${TEST_NAME}.sy")
|
||
|
|
||
|
if(EXISTS "${TEST_DIR}/${TEST_NAME}.in")
|
||
|
set(TEST_INS "${TEST_DIR}/${TEST_NAME}.in")
|
||
|
else(EXISTS "${TEST_DIR}/${TEST_NAME}.in")
|
||
|
set(TEST_INS "/dev/null")
|
||
|
endif(EXISTS "${TEST_DIR}/${TEST_NAME}.in")
|
||
|
|
||
|
set(RUNTIME_LIB "${RUNTIME}/libsysy.a")
|
||
|
|
||
|
# Generated
|
||
|
set(TEST_ASM "${TEST_NAME}.s")
|
||
|
set(TEST_EXE "${TEST_NAME}")
|
||
|
set(TEST_OUT "${TEST_NAME}_rv.out")
|
||
|
configure_file("${TEST_DIR}/${TEST_NAME}.out" "${TEST_NAME}.ref" NEWLINE_STYLE LF)
|
||
|
set(TEST_REF "${TEST_NAME}.ref")
|
||
|
|
||
|
# SysY to RISC-V Assembly
|
||
|
execute_process(
|
||
|
COMMAND
|
||
|
${COMPILER} -S ${TEST_SRC} -O1
|
||
|
WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
|
||
|
OUTPUT_FILE ${TEST_ASM}
|
||
|
ERROR_VARIABLE TEST_ERR
|
||
|
RESULT_VARIABLE TEST_RET
|
||
|
)
|
||
|
|
||
|
if(TEST_RET)
|
||
|
message(SEND_ERROR "Failed: SysY Compiler Error in ${TEST_SRC}: ${TEST_ERR}")
|
||
|
file(READ "${TEST_SRC}" TEST_SRC_CONTENT)
|
||
|
message(NOTICE "Source File:\n ${TEST_SRC_CONTENT}")
|
||
|
return()
|
||
|
endif(TEST_RET)
|
||
|
|
||
|
# GCC Assemble and Link
|
||
|
execute_process(
|
||
|
COMMAND
|
||
|
riscv64-linux-gnu-gcc "${CMAKE_CURRENT_BINARY_DIR}/${TEST_ASM}" "${RUNTIME_LIB}" -march=rv64gc -static -o "${CMAKE_CURRENT_BINARY_DIR}/${TEST_EXE}"
|
||
|
WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
|
||
|
ERROR_VARIABLE TEST_ERR
|
||
|
RESULT_VARIABLE TEST_RET
|
||
|
)
|
||
|
|
||
|
if(TEST_RET)
|
||
|
message(SEND_ERROR "Failed: GCC Assemble and Link Error in ${TEST_SRC}: ${TEST_ERR}")
|
||
|
# file(READ "${TEST_ASM}" TEST_ASM_CONTENT)
|
||
|
message(NOTICE "Generated Assmebly:\n ${TEST_ASM_CONTENT}")
|
||
|
return()
|
||
|
endif(TEST_RET)
|
||
|
|
||
|
# Run the executable with qemu
|
||
|
execute_process(
|
||
|
COMMAND
|
||
|
qemu-riscv64 ${TEST_EXE} -M sifive_u -smp 5 -m 2G
|
||
|
WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
|
||
|
INPUT_FILE ${TEST_INS}
|
||
|
OUTPUT_VARIABLE TEST_OUT_CONTENT
|
||
|
ERROR_VARIABLE TEST_ERR
|
||
|
RESULT_VARIABLE TEST_RET
|
||
|
TIMEOUT 60
|
||
|
)
|
||
|
|
||
|
# Append EOF LR, if not presented
|
||
|
if(TEST_OUT_CONTENT)
|
||
|
string(LENGTH "${TEST_OUT_CONTENT}" TEST_OUT_LEN)
|
||
|
math(EXPR TEST_OUT_LAST "${TEST_OUT_LEN} - 1")
|
||
|
string(SUBSTRING "${TEST_OUT_CONTENT}" ${TEST_OUT_LAST} 1 LAST_CHAR)
|
||
|
|
||
|
if(NOT "${LAST_CHAR}" STREQUAL "\n")
|
||
|
# If it's not, append a newline to var
|
||
|
set(TEST_OUT_CONTENT "${TEST_OUT_CONTENT}\n")
|
||
|
endif()
|
||
|
endif(TEST_OUT_CONTENT)
|
||
|
|
||
|
set(TEST_OUT_CONTENT "${TEST_OUT_CONTENT}${TEST_RET}\n")
|
||
|
file(WRITE "${TEST_OUT}" "${TEST_OUT_CONTENT}")
|
||
|
|
||
|
execute_process(
|
||
|
COMMAND "${CMAKE_COMMAND}" -E compare_files "${TEST_OUT}" "${TEST_REF}"
|
||
|
RESULT_VARIABLE TEST_RESULT
|
||
|
)
|
||
|
|
||
|
if(TEST_RESULT)
|
||
|
# get_filename_component(TESTNAME "${TEST_ARGS}" NAME)
|
||
|
# file(RENAME "${TEST_OUTPUT}" "${CMAKE_BINARY_DIR}/${TESTNAME}.out")
|
||
|
# file(WRITE "${CMAKE_BINARY_DIR}/${TESTNAME}.err" ${TEST_ERROR})
|
||
|
message(SEND_ERROR "Failed: The output of ${TEST_NAME} did not match ${TEST_REF}")
|
||
|
file(READ ${TEST_REF} TEST_REF_CONTENT)
|
||
|
message(NOTICE "Expected Output: ${TEST_REF_CONTENT}")
|
||
|
message(NOTICE "Auctual Output: ${TEST_OUT_CONTENT}")
|
||
|
return()
|
||
|
endif(TEST_RESULT)
|