-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathCMakeLists.txt
74 lines (57 loc) · 2.34 KB
/
CMakeLists.txt
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
cmake_minimum_required (VERSION 3.18)
project (CRV)
list(APPEND CMAKE_MODULE_PATH "${CMAKE_CURRENT_LIST_DIR}/cmake/modules")
set(CMAKE_C_STANDARD 11)
set(CMAKE_C_STANDARD_REQUIRED TRUE)
add_compile_options(-Werror=switch)
set (riscv_opcodes ${CMAKE_BINARY_DIR}/riscv-opcodes-master)
set (riscv_opcodes_zip ${CMAKE_BINARY_DIR}/riscv-opcodes.zip)
if (NOT EXISTS ${riscv_opcodes_zip})
message("Downloading riscv-opcodes")
file(DOWNLOAD "https://github.com/riscv/riscv-opcodes/archive/refs/heads/master.zip" ${riscv_opcodes_zip})
else()
message("riscv-opcodes already downloaded")
endif()
if (NOT EXISTS ${riscv_opcodes})
message("Extracting riscv-opcodes")
file(ARCHIVE_EXTRACT
INPUT ${riscv_opcodes_zip})
else()
message("riscv-opcodes already extracted")
endif()
set(gen_emitters_script ${CMAKE_CURRENT_SOURCE_DIR}/scripts/gen-emitters.py)
set(generated_emitters_header_dir ${CMAKE_CURRENT_BINARY_DIR})
set(generated_emitters_header ${generated_emitters_header_dir}/crv_emitters.h)
find_package(Python 3.6 REQUIRED)
add_custom_command(
OUTPUT ${generated_emitters_header}
COMMAND ${Python_EXECUTABLE} ${gen_emitters_script}
--license ${CMAKE_CURRENT_LIST_DIR}/LICENSE
--output ${generated_emitters_header}
--opcodes ${riscv_opcodes}
DEPENDS ${gen_emitters_script}
)
set(crv_sources src/crv.c)
set(crv_headers src/crv.h src/crv_constants.h ${generated_emitters_header})
add_library(crv_static STATIC ${crv_sources} ${crv_headers})
target_include_directories(crv_static PUBLIC ${generated_emitters_header_dir})
add_library(crv SHARED ${crv_sources} ${crv_headers})
target_include_directories(crv PUBLIC ${generated_emitters_header_dir})
install(TARGETS crv crv_static
DESTINATION lib)
install(FILES ${crv_headers}
DESTINATION include)
install(FILES ${crv_sources}
DESTINATION src)
add_executable(test test/test.c)
target_include_directories(test PUBLIC src)
target_link_libraries(test crv_static)
add_executable(test_functioncall test/test_functioncall.c)
target_include_directories(test_functioncall PUBLIC src)
target_link_libraries(test_functioncall crv_static)
find_package(Capstone)
if(Capstone_FOUND)
target_link_libraries(test ${Capstone_LIBRARIES})
target_include_directories(test PRIVATE ${Capstone_INCLUDE_DIRS})
target_compile_definitions(test PRIVATE HAVE_CAPSTONE)
endif()