aboutsummaryrefslogtreecommitdiffstats
path: root/capstone/CMakeLists.txt
diff options
context:
space:
mode:
authorAngelos Mouzakitis <a.mouzakitis@virtualopensystems.com>2023-10-10 14:33:42 +0000
committerAngelos Mouzakitis <a.mouzakitis@virtualopensystems.com>2023-10-10 14:33:42 +0000
commitaf1a266670d040d2f4083ff309d732d648afba2a (patch)
tree2fc46203448ddcc6f81546d379abfaeb323575e9 /capstone/CMakeLists.txt
parente02cda008591317b1625707ff8e115a4841aa889 (diff)
Add submodule dependency filesHEADmaster
Change-Id: Iaf8d18082d3991dec7c0ebbea540f092188eb4ec
Diffstat (limited to 'capstone/CMakeLists.txt')
-rw-r--r--capstone/CMakeLists.txt708
1 files changed, 708 insertions, 0 deletions
diff --git a/capstone/CMakeLists.txt b/capstone/CMakeLists.txt
new file mode 100644
index 000000000..c83928f28
--- /dev/null
+++ b/capstone/CMakeLists.txt
@@ -0,0 +1,708 @@
+cmake_minimum_required(VERSION 2.6)
+project(capstone)
+
+set(VERSION_MAJOR 5)
+set(VERSION_MINOR 0)
+set(VERSION_PATCH 0)
+
+if(POLICY CMP0042)
+ # http://www.cmake.org/cmake/help/v3.0/policy/CMP0042.html
+ cmake_policy(SET CMP0042 NEW)
+endif(POLICY CMP0042)
+
+if (POLICY CMP0048)
+ # use old policy to honor version set using VERSION_* variables to preserve backwards
+ # compatibility. change OLD to NEW when minimum cmake version is updated to 3.* and
+ # set VERSION using project(capstone VERSION 4.0.0).
+ # http://www.cmake.org/cmake/help/v3.0/policy/CMP0048.html
+ cmake_policy (SET CMP0048 OLD)
+endif()
+
+# to configure the options specify them in in the command line or change them in the cmake UI.
+# Don't edit the makefile!
+option(CAPSTONE_BUILD_STATIC_RUNTIME "Embed static runtime" ON)
+option(CAPSTONE_BUILD_STATIC "Build static library" ON)
+option(CAPSTONE_BUILD_SHARED "Build shared library" ON)
+option(CAPSTONE_BUILD_DIET "Build diet library" OFF)
+option(CAPSTONE_BUILD_TESTS "Build tests" ON)
+option(CAPSTONE_BUILD_CSTOOL "Build cstool" ON)
+option(CAPSTONE_USE_DEFAULT_ALLOC "Use default memory allocation functions" ON)
+option(CAPSTONE_ARCHITECTURE_DEFAULT "Whether architectures are enabled by default" ON)
+option(CAPSTONE_DEBUG "Whether to enable extra debug assertions" OFF)
+
+set(SUPPORTED_ARCHITECTURES ARM ARM64 M68K MIPS PPC SPARC SYSZ XCORE X86 TMS320C64X M680X EVM MOS65XX WASM BPF RISCV)
+set(SUPPORTED_ARCHITECTURE_LABELS ARM ARM64 M68K MIPS PowerPC Sparc SystemZ XCore x86 TMS320C64x M680x EVM MOS65XX WASM BPF RISCV)
+
+list(LENGTH SUPPORTED_ARCHITECTURES count)
+math(EXPR count "${count}-1")
+# create options controlling whether support for a particular architecture is needed
+foreach(i RANGE ${count})
+ list(GET SUPPORTED_ARCHITECTURES ${i} supported_architecture)
+ list(GET SUPPORTED_ARCHITECTURE_LABELS ${i} supported_architecture_label)
+ option("CAPSTONE_${supported_architecture}_SUPPORT" "${supported_architecture_label} support" ${CAPSTONE_ARCHITECTURE_DEFAULT})
+endforeach(i)
+
+# propagate architecture support variables to preprocessor
+foreach(supported_architecture ${SUPPORTED_ARCHITECTURES})
+ set(option_name "CAPSTONE_${supported_architecture}_SUPPORT")
+ if(${option_name})
+ message("Enabling ${option_name}")
+ add_definitions("-D${option_name}")
+ endif()
+endforeach(supported_architecture)
+
+option(CAPSTONE_X86_REDUCE "x86 with reduce instruction sets to minimize library" OFF)
+option(CAPSTONE_X86_ATT_DISABLE "Disable x86 AT&T syntax" OFF)
+option(CAPSTONE_OSXKERNEL_SUPPORT "Support to embed Capstone into OS X Kernel extensions" OFF)
+
+if (MSVC)
+ set(CMAKE_CXX_FLAGS_RELEASE "${CMAKE_CXX_FLAGS_RELEASE} /MT")
+ set(CMAKE_CXX_FLAGS_DEBUG "${CMAKE_CXX_FLAGS_DEBUG} /MTd")
+endif ()
+
+enable_testing()
+
+if (CAPSTONE_BUILD_DIET)
+ add_definitions(-DCAPSTONE_DIET)
+endif ()
+
+if (CAPSTONE_USE_DEFAULT_ALLOC)
+ add_definitions(-DCAPSTONE_USE_SYS_DYN_MEM)
+endif ()
+
+if (CAPSTONE_X86_REDUCE)
+ add_definitions(-DCAPSTONE_X86_REDUCE)
+endif ()
+
+if (CAPSTONE_X86_ATT_DISABLE)
+ add_definitions(-DCAPSTONE_X86_ATT_DISABLE)
+endif ()
+
+if (CAPSTONE_DEBUG)
+ add_definitions(-DCAPSTONE_DEBUG)
+endif ()
+
+## sources
+set(SOURCES_ENGINE
+ cs.c
+ MCInst.c
+ MCInstrDesc.c
+ MCRegisterInfo.c
+ SStream.c
+ utils.c
+)
+set(HEADERS_ENGINE
+ cs_priv.h
+ LEB128.h
+ MathExtras.h
+ MCDisassembler.h
+ MCFixedLenDisassembler.h
+ MCInst.h
+ MCInstrDesc.h
+ MCRegisterInfo.h
+ SStream.h
+ utils.h
+ )
+
+set(HEADERS_COMMON
+ include/capstone/arm64.h
+ include/capstone/arm.h
+ include/capstone/capstone.h
+ include/capstone/evm.h
+ include/capstone/wasm.h
+ include/capstone/mips.h
+ include/capstone/ppc.h
+ include/capstone/x86.h
+ include/capstone/sparc.h
+ include/capstone/systemz.h
+ include/capstone/xcore.h
+ include/capstone/m68k.h
+ include/capstone/tms320c64x.h
+ include/capstone/m680x.h
+ include/capstone/mos65xx.h
+ include/capstone/bpf.h
+ include/capstone/riscv.h
+ include/capstone/platform.h
+ )
+
+set(TEST_SOURCES test_basic.c test_detail.c test_skipdata.c test_iter.c)
+
+## architecture support
+if (CAPSTONE_ARM_SUPPORT)
+ add_definitions(-DCAPSTONE_HAS_ARM)
+ set(SOURCES_ARM
+ arch/ARM/ARMDisassembler.c
+ arch/ARM/ARMInstPrinter.c
+ arch/ARM/ARMMapping.c
+ arch/ARM/ARMModule.c
+ )
+ set(HEADERS_ARM
+ arch/ARM/ARMAddressingModes.h
+ arch/ARM/ARMBaseInfo.h
+ arch/ARM/ARMDisassembler.h
+ arch/ARM/ARMInstPrinter.h
+ arch/ARM/ARMMapping.h
+ arch/ARM/ARMGenAsmWriter.inc
+ arch/ARM/ARMGenDisassemblerTables.inc
+ arch/ARM/ARMGenInstrInfo.inc
+ arch/ARM/ARMGenRegisterInfo.inc
+ arch/ARM/ARMGenSubtargetInfo.inc
+ arch/ARM/ARMMappingInsn.inc
+ arch/ARM/ARMMappingInsnOp.inc
+ arch/ARM/ARMGenRegisterName.inc
+ arch/ARM/ARMGenRegisterName_digit.inc
+ arch/ARM/ARMGenSystemRegister.inc
+ arch/ARM/ARMMappingInsnName.inc
+ )
+ set(TEST_SOURCES ${TEST_SOURCES} test_arm.c)
+endif ()
+
+if (CAPSTONE_ARM64_SUPPORT)
+ add_definitions(-DCAPSTONE_HAS_ARM64)
+ set(SOURCES_ARM64
+ arch/AArch64/AArch64BaseInfo.c
+ arch/AArch64/AArch64Disassembler.c
+ arch/AArch64/AArch64InstPrinter.c
+ arch/AArch64/AArch64Mapping.c
+ arch/AArch64/AArch64Module.c
+ )
+ set(HEADERS_ARM64
+ arch/AArch64/AArch64AddressingModes.h
+ arch/AArch64/AArch64BaseInfo.h
+ arch/AArch64/AArch64Disassembler.h
+ arch/AArch64/AArch64InstPrinter.h
+ arch/AArch64/AArch64Mapping.h
+ arch/AArch64/AArch64GenAsmWriter.inc
+ arch/AArch64/AArch64GenDisassemblerTables.inc
+ arch/AArch64/AArch64GenInstrInfo.inc
+ arch/AArch64/AArch64GenRegisterInfo.inc
+ arch/AArch64/AArch64GenRegisterName.inc
+ arch/AArch64/AArch64GenRegisterV.inc
+ arch/AArch64/AArch64GenSubtargetInfo.inc
+ arch/AArch64/AArch64GenSystemOperands.inc
+ arch/AArch64/AArch64GenSystemOperands_enum.inc
+ arch/AArch64/AArch64MappingInsn.inc
+ arch/AArch64/AArch64MappingInsnName.inc
+ arch/AArch64/AArch64MappingInsnOp.inc
+ )
+ set(TEST_SOURCES ${TEST_SOURCES} test_arm64.c)
+endif ()
+
+if (CAPSTONE_MIPS_SUPPORT)
+ add_definitions(-DCAPSTONE_HAS_MIPS)
+ set(SOURCES_MIPS
+ arch/Mips/MipsDisassembler.c
+ arch/Mips/MipsInstPrinter.c
+ arch/Mips/MipsMapping.c
+ arch/Mips/MipsModule.c
+ )
+ set(HEADERS_MIPS
+ arch/Mips/MipsDisassembler.h
+ arch/Mips/MipsGenAsmWriter.inc
+ arch/Mips/MipsGenDisassemblerTables.inc
+ arch/Mips/MipsGenInstrInfo.inc
+ arch/Mips/MipsGenRegisterInfo.inc
+ arch/Mips/MipsGenSubtargetInfo.inc
+ arch/Mips/MipsInstPrinter.h
+ arch/Mips/MipsMapping.h
+ arch/Mips/MipsMappingInsn.inc
+ )
+ set(HEADERS_MIPS
+ arch/Mips/MipsDisassembler.h
+ arch/Mips/MipsGenAsmWriter.inc
+ arch/Mips/MipsGenDisassemblerTables.inc
+ arch/Mips/MipsGenInstrInfo.inc
+ arch/Mips/MipsGenRegisterInfo.inc
+ arch/Mips/MipsGenSubtargetInfo.inc
+ arch/Mips/MipsInstPrinter.h
+ arch/Mips/MipsMapping.h
+ )
+ set(TEST_SOURCES ${TEST_SOURCES} test_mips.c)
+endif ()
+
+if (CAPSTONE_PPC_SUPPORT)
+ add_definitions(-DCAPSTONE_HAS_POWERPC)
+ set(SOURCES_PPC
+ arch/PowerPC/PPCDisassembler.c
+ arch/PowerPC/PPCInstPrinter.c
+ arch/PowerPC/PPCMapping.c
+ arch/PowerPC/PPCModule.c
+ )
+ set(HEADERS_PPC
+ arch/PowerPC/PPCDisassembler.h
+ arch/PowerPC/PPCGenAsmWriter.inc
+ arch/PowerPC/PPCInstPrinter.h
+ arch/PowerPC/PPCMapping.h
+ arch/PowerPC/PPCPredicates.h
+ arch/PowerPC/PPCGenAsmWriter.inc
+ arch/PowerPC/PPCGenRegisterName.inc
+ arch/PowerPC/PPCGenDisassemblerTables.inc
+ arch/PowerPC/PPCMappingInsn.inc
+ arch/PowerPC/PPCMappingInsnName.inc
+ arch/PowerPC/PPCGenSubtargetInfo.inc
+ arch/PowerPC/PPCGenRegisterInfo.inc
+ arch/PowerPC/PPCGenInstrInfo.inc
+ )
+ set(TEST_SOURCES ${TEST_SOURCES} test_ppc.c)
+endif ()
+
+if (CAPSTONE_X86_SUPPORT)
+ add_definitions(-DCAPSTONE_HAS_X86)
+ set(SOURCES_X86
+ arch/X86/X86Disassembler.c
+ arch/X86/X86DisassemblerDecoder.c
+ arch/X86/X86IntelInstPrinter.c
+ arch/X86/X86InstPrinterCommon.c
+ arch/X86/X86Mapping.c
+ arch/X86/X86Module.c
+ )
+ set(HEADERS_X86
+ arch/X86/X86BaseInfo.h
+ arch/X86/X86Disassembler.h
+ arch/X86/X86DisassemblerDecoder.h
+ arch/X86/X86DisassemblerDecoderCommon.h
+ arch/X86/X86GenAsmWriter.inc
+ arch/X86/X86GenAsmWriter1.inc
+ arch/X86/X86GenAsmWriter1_reduce.inc
+ arch/X86/X86GenAsmWriter_reduce.inc
+ arch/X86/X86GenDisassemblerTables.inc
+ arch/X86/X86GenDisassemblerTables_reduce.inc
+ arch/X86/X86GenInstrInfo.inc
+ arch/X86/X86GenInstrInfo_reduce.inc
+ arch/X86/X86GenRegisterInfo.inc
+ arch/X86/X86InstPrinter.h
+ arch/X86/X86Mapping.h
+ arch/X86/X86MappingInsn.inc
+ arch/X86/X86MappingInsnOp.inc
+ arch/X86/X86MappingInsnOp_reduce.inc
+ arch/X86/X86MappingInsn_reduce.inc
+ )
+ set(HEADERS_X86
+ arch/X86/X86BaseInfo.h
+ arch/X86/X86Disassembler.h
+ arch/X86/X86DisassemblerDecoder.h
+ arch/X86/X86DisassemblerDecoderCommon.h
+ arch/X86/X86GenAsmWriter.inc
+ arch/X86/X86GenAsmWriter1.inc
+ arch/X86/X86GenAsmWriter1_reduce.inc
+ arch/X86/X86GenAsmWriter_reduce.inc
+ arch/X86/X86GenDisassemblerTables.inc
+ arch/X86/X86GenDisassemblerTables_reduce.inc
+ arch/X86/X86GenInstrInfo.inc
+ arch/X86/X86GenInstrInfo_reduce.inc
+ arch/X86/X86GenRegisterInfo.inc
+ arch/X86/X86InstPrinter.h
+ arch/X86/X86Mapping.h
+ )
+ if (NOT CAPSTONE_BUILD_DIET)
+ set(SOURCES_X86 ${SOURCES_X86} arch/X86/X86ATTInstPrinter.c)
+ endif ()
+ set(TEST_SOURCES ${TEST_SOURCES} test_x86.c test_customized_mnem.c)
+endif ()
+
+if (CAPSTONE_SPARC_SUPPORT)
+ add_definitions(-DCAPSTONE_HAS_SPARC)
+ set(SOURCES_SPARC
+ arch/Sparc/SparcDisassembler.c
+ arch/Sparc/SparcInstPrinter.c
+ arch/Sparc/SparcMapping.c
+ arch/Sparc/SparcModule.c
+ )
+ set(HEADERS_SPARC
+ arch/Sparc/Sparc.h
+ arch/Sparc/SparcDisassembler.h
+ arch/Sparc/SparcGenAsmWriter.inc
+ arch/Sparc/SparcGenDisassemblerTables.inc
+ arch/Sparc/SparcGenInstrInfo.inc
+ arch/Sparc/SparcGenRegisterInfo.inc
+ arch/Sparc/SparcGenSubtargetInfo.inc
+ arch/Sparc/SparcInstPrinter.h
+ arch/Sparc/SparcMapping.h
+ arch/Sparc/SparcMappingInsn.inc
+ )
+ set(TEST_SOURCES ${TEST_SOURCES} test_sparc.c)
+endif ()
+
+if (CAPSTONE_SYSZ_SUPPORT)
+ add_definitions(-DCAPSTONE_HAS_SYSZ)
+ set(SOURCES_SYSZ
+ arch/SystemZ/SystemZDisassembler.c
+ arch/SystemZ/SystemZInstPrinter.c
+ arch/SystemZ/SystemZMapping.c
+ arch/SystemZ/SystemZModule.c
+ arch/SystemZ/SystemZMCTargetDesc.c
+ )
+ set(HEADERS_SYSZ
+ arch/SystemZ/SystemZDisassembler.h
+ arch/SystemZ/SystemZGenAsmWriter.inc
+ arch/SystemZ/SystemZGenDisassemblerTables.inc
+ arch/SystemZ/SystemZGenInsnNameMaps.inc
+ arch/SystemZ/SystemZGenInstrInfo.inc
+ arch/SystemZ/SystemZGenRegisterInfo.inc
+ arch/SystemZ/SystemZGenSubtargetInfo.inc
+ arch/SystemZ/SystemZInstPrinter.h
+ arch/SystemZ/SystemZMapping.h
+ arch/SystemZ/SystemZMappingInsn.inc
+ arch/SystemZ/SystemZMCTargetDesc.h
+ )
+ set(TEST_SOURCES ${TEST_SOURCES} test_systemz.c)
+endif ()
+
+if (CAPSTONE_XCORE_SUPPORT)
+ add_definitions(-DCAPSTONE_HAS_XCORE)
+ set(SOURCES_XCORE
+ arch/XCore/XCoreDisassembler.c
+ arch/XCore/XCoreInstPrinter.c
+ arch/XCore/XCoreMapping.c
+ arch/XCore/XCoreModule.c
+ )
+ set(HEADERS_XCORE
+ arch/XCore/XCoreDisassembler.h
+ arch/XCore/XCoreGenAsmWriter.inc
+ arch/XCore/XCoreGenDisassemblerTables.inc
+ arch/XCore/XCoreGenInstrInfo.inc
+ arch/XCore/XCoreGenRegisterInfo.inc
+ arch/XCore/XCoreInstPrinter.h
+ arch/XCore/XCoreMapping.h
+ arch/XCore/XCoreMappingInsn.inc
+ )
+ set(TEST_SOURCES ${TEST_SOURCES} test_xcore.c)
+endif ()
+
+if (CAPSTONE_M68K_SUPPORT)
+ add_definitions(-DCAPSTONE_HAS_M68K)
+ set(SOURCES_M68K
+ arch/M68K/M68KDisassembler.c
+ arch/M68K/M68KInstPrinter.c
+ arch/M68K/M68KModule.c
+ )
+ set(HEADERS_M68K
+ arch/M68K/M68KDisassembler.h
+ )
+ set(TEST_SOURCES ${TEST_SOURCES} test_m68k.c)
+endif ()
+
+if (CAPSTONE_TMS320C64X_SUPPORT)
+ add_definitions(-DCAPSTONE_HAS_TMS320C64X)
+ set(SOURCES_TMS320C64X
+ arch/TMS320C64x/TMS320C64xDisassembler.c
+ arch/TMS320C64x/TMS320C64xInstPrinter.c
+ arch/TMS320C64x/TMS320C64xMapping.c
+ arch/TMS320C64x/TMS320C64xModule.c
+ )
+ set(HEADERS_TMS320C64X
+ arch/TMS320C64x/TMS320C64xDisassembler.h
+ arch/TMS320C64x/TMS320C64xGenAsmWriter.inc
+ arch/TMS320C64x/TMS320C64xGenDisassemblerTables.inc
+ arch/TMS320C64x/TMS320C64xGenInstrInfo.inc
+ arch/TMS320C64x/TMS320C64xGenRegisterInfo.inc
+ arch/TMS320C64x/TMS320C64xInstPrinter.h
+ arch/TMS320C64x/TMS320C64xMapping.h
+ )
+ set(TEST_SOURCES ${TEST_SOURCES} test_tms320c64x.c)
+endif ()
+
+if (CAPSTONE_M680X_SUPPORT)
+ add_definitions(-DCAPSTONE_HAS_M680X)
+ set(SOURCES_M680X
+ arch/M680X/M680XDisassembler.c
+ arch/M680X/M680XInstPrinter.c
+ arch/M680X/M680XModule.c
+ )
+ set(HEADERS_M680X
+ arch/M680X/M680XInstPrinter.h
+ arch/M680X/M680XDisassembler.h
+ arch/M680X/M680XDisassemblerInternals.h
+ )
+ set(TEST_SOURCES ${TEST_SOURCES} test_m680x.c)
+endif ()
+
+if (CAPSTONE_EVM_SUPPORT)
+ add_definitions(-DCAPSTONE_HAS_EVM)
+ set(SOURCES_EVM
+ arch/EVM/EVMDisassembler.c
+ arch/EVM/EVMInstPrinter.c
+ arch/EVM/EVMMapping.c
+ arch/EVM/EVMModule.c
+ )
+ set(HEADERS_EVM
+ arch/EVM/EVMDisassembler.h
+ arch/EVM/EVMInstPrinter.h
+ arch/EVM/EVMMapping.h
+ arch/EVM/EVMMappingInsn.inc
+ )
+ set(TEST_SOURCES ${TEST_SOURCES} test_evm.c)
+endif ()
+
+if (CAPSTONE_WASM_SUPPORT)
+ add_definitions(-DCAPSTONE_HAS_WASM)
+ set(SOURCES_WASM
+ arch/WASM/WASMDisassembler.c
+ arch/WASM/WASMInstPrinter.c
+ arch/WASM/WASMMapping.c
+ arch/WASM/WASMModule.c
+ )
+ set(HEADERS_WASM
+ arch/WASM/WASMDisassembler.h
+ arch/WASM/WASMInstPrinter.h
+ arch/WASM/WASMMapping.h
+ )
+ set(TEST_SOURCES ${TEST_SOURCES} test_wasm.c)
+endif ()
+
+if (CAPSTONE_MOS65XX_SUPPORT)
+ add_definitions(-DCAPSTONE_HAS_MOS65XX)
+ set(SOURCES_MOS65XX
+ arch/MOS65XX/MOS65XXModule.c
+ arch/MOS65XX/MOS65XXDisassembler.c)
+ set(HEADERS_SOURCES_MOS65XX
+ arch/MOS65XX/MOS65XXDisassembler.h
+ )
+ set(TEST_SOURCES ${TEST_SOURCES} test_mos65xx.c)
+endif ()
+
+if (CAPSTONE_BPF_SUPPORT)
+ add_definitions(-DCAPSTONE_HAS_BPF)
+ set(SOURCES_BPF
+ arch/BPF/BPFDisassembler.c
+ arch/BPF/BPFInstPrinter.c
+ arch/BPF/BPFMapping.c
+ arch/BPF/BPFModule.c
+ )
+ set(HEADERS_BPF
+ arch/BPF/BPFConstants.h
+ arch/BPF/BPFDisassembler.h
+ arch/BPF/BPFInstPrinter.h
+ arch/BPF/BPFMapping.h
+ arch/BPF/BPFModule.h
+ )
+ set(TEST_SOURCES ${TEST_SOURCES} test_bpf.c)
+endif ()
+
+if (CAPSTONE_RISCV_SUPPORT)
+ add_definitions(-DCAPSTONE_HAS_RISCV)
+ set(SOURCES_RISCV
+ arch/RISCV/RISCVDisassembler.c
+ arch/RISCV/RISCVInstPrinter.c
+ arch/RISCV/RISCVMapping.c
+ arch/RISCV/RISCVModule.c
+ )
+ set(HEADERS_RISCV
+ arch/RISCV/RISCVBaseInfo.h
+ arch/RISCV/RISCVDisassembler.h
+ arch/RISCV/RISCVInstPrinter.h
+ arch/RISCV/RISCVMapping.h
+ arch/RISCV/RISCVModule.h
+ arch/RISCV/RISCVGenAsmWriter.inc
+ arch/RISCV/RISCVGenDisassemblerTables.inc
+ arch/RISCV/RISCVGenInsnNameMaps.inc
+ arch/RISCV/RISCVGenInstrInfo.inc
+ arch/RISCV/RISCVGenRegisterInfo.inc
+ arch/RISCV/RISCVGenSubtargetInfo.inc
+ arch/RISCV/RISCVMappingInsn.inc
+ )
+ set(TEST_SOURCES ${TEST_SOURCES} test_riscv.c)
+endif ()
+
+if (CAPSTONE_OSXKERNEL_SUPPORT)
+ add_definitions(-DCAPSTONE_HAS_OSXKERNEL)
+endif ()
+
+set(ALL_SOURCES
+ ${SOURCES_ENGINE}
+ ${SOURCES_ARM}
+ ${SOURCES_ARM64}
+ ${SOURCES_MIPS}
+ ${SOURCES_PPC}
+ ${SOURCES_X86}
+ ${SOURCES_SPARC}
+ ${SOURCES_SYSZ}
+ ${SOURCES_XCORE}
+ ${SOURCES_M68K}
+ ${SOURCES_TMS320C64X}
+ ${SOURCES_M680X}
+ ${SOURCES_EVM}
+ ${SOURCES_WASM}
+ ${SOURCES_MOS65XX}
+ ${SOURCES_BPF}
+ ${SOURCES_RISCV}
+ )
+
+set(ALL_HEADERS
+ ${HEADERS_COMMON}
+ ${HEADERS_ENGINE}
+ ${HEADERS_ARM}
+ ${HEADERS_ARM64}
+ ${HEADERS_MIPS}
+ ${HEADERS_PPC}
+ ${HEADERS_X86}
+ ${HEADERS_SPARC}
+ ${HEADERS_SYSZ}
+ ${HEADERS_XCORE}
+ ${HEADERS_M68K}
+ ${HEADERS_TMS320C64X}
+ ${HEADERS_M680X}
+ ${HEADERS_EVM}
+ ${HEADERS_WASM}
+ ${HEADERS_MOS65XX}
+ ${HEADERS_BPF}
+ ${HEADERS_RISCV}
+ )
+
+include_directories("${PROJECT_SOURCE_DIR}/include")
+
+## properties
+# version info
+set_property(GLOBAL PROPERTY VERSION ${VERSION_MAJOR}.${VERSION_MINOR}.${VERSION_PATCH})
+
+## targets
+if (CAPSTONE_BUILD_STATIC)
+ add_library(capstone-static STATIC ${ALL_SOURCES} ${ALL_HEADERS})
+ set_property(TARGET capstone-static PROPERTY OUTPUT_NAME capstone)
+ set(default-target capstone-static)
+endif ()
+
+# Force static runtime libraries
+if (CAPSTONE_BUILD_STATIC_RUNTIME)
+ FOREACH(flag
+ CMAKE_C_FLAGS_RELEASE CMAKE_C_FLAGS_RELWITHDEBINFO
+ CMAKE_C_FLAGS_DEBUG CMAKE_C_FLAGS_DEBUG_INIT
+ CMAKE_CXX_FLAGS_RELEASE CMAKE_CXX_FLAGS_RELWITHDEBINFO
+ CMAKE_CXX_FLAGS_DEBUG CMAKE_CXX_FLAGS_DEBUG_INIT)
+ if (MSVC)
+ STRING(REPLACE "/MD" "/MT" "${flag}" "${${flag}}")
+ SET("${flag}" "${${flag}} /EHsc")
+ endif (MSVC)
+ ENDFOREACH()
+endif ()
+
+if (CAPSTONE_BUILD_SHARED)
+ add_library(capstone-shared SHARED ${ALL_SOURCES} ${ALL_HEADERS})
+ set_property(TARGET capstone-shared PROPERTY OUTPUT_NAME capstone)
+ set_property(TARGET capstone-shared PROPERTY COMPILE_FLAGS -DCAPSTONE_SHARED)
+
+ if (MSVC)
+ set_target_properties(capstone-shared PROPERTIES IMPORT_SUFFIX _dll.lib)
+ else()
+ set_target_properties(capstone-shared PROPERTIES
+ VERSION ${VERSION_MAJOR}.${VERSION_MINOR}.${VERSION_PATCH}
+ SOVERSION ${VERSION_MAJOR})
+ endif ()
+
+ if(NOT DEFINED default-target) # honor `capstone-static` for tests first.
+ set(default-target capstone-shared)
+ add_definitions(-DCAPSTONE_SHARED)
+ endif ()
+endif ()
+
+if (CAPSTONE_BUILD_TESTS)
+ foreach (TSRC ${TEST_SOURCES})
+ STRING(REGEX REPLACE ".c$" "" TBIN ${TSRC})
+ add_executable(${TBIN} "tests/${TSRC}")
+ target_link_libraries(${TBIN} ${default-target})
+ add_test(NAME "capstone_${TBIN}" COMMAND ${TBIN})
+ endforeach ()
+ if (CAPSTONE_ARM_SUPPORT)
+ set(ARM_REGRESS_TEST test_arm_regression.c)
+ STRING(REGEX REPLACE ".c$" "" ARM_REGRESS_BIN ${ARM_REGRESS_TEST})
+ add_executable(${ARM_REGRESS_BIN} "suite/arm/${ARM_REGRESS_TEST}")
+ target_link_libraries(${ARM_REGRESS_BIN} ${default-target})
+ add_test(NAME "capstone_${ARM_REGRESS_BIN}" COMMAND ${ARM_REGRESS_BIN})
+ endif()
+ # fuzz target built with the tests
+ add_executable(fuzz_disasm suite/fuzz/onefile.c suite/fuzz/fuzz_disasm.c suite/fuzz/platform.c)
+ target_link_libraries(fuzz_disasm ${default-target})
+endif ()
+
+source_group("Source\\Engine" FILES ${SOURCES_ENGINE})
+source_group("Source\\ARM" FILES ${SOURCES_ARM})
+source_group("Source\\ARM64" FILES ${SOURCES_ARM64})
+source_group("Source\\Mips" FILES ${SOURCES_MIPS})
+source_group("Source\\PowerPC" FILES ${SOURCES_PPC})
+source_group("Source\\Sparc" FILES ${SOURCES_SPARC})
+source_group("Source\\SystemZ" FILES ${SOURCES_SYSZ})
+source_group("Source\\X86" FILES ${SOURCES_X86})
+source_group("Source\\XCore" FILES ${SOURCES_XCORE})
+source_group("Source\\M68K" FILES ${SOURCES_M68K})
+source_group("Source\\TMS320C64x" FILES ${SOURCES_TMS320C64X})
+source_group("Source\\M680X" FILES ${SOURCES_M680X})
+source_group("Source\\EVM" FILES ${SOURCES_EVM})
+source_group("Source\\WASM" FILES ${SOURCES_WASM})
+source_group("Source\\MOS65XX" FILES ${SOURCES_MOS65XX})
+source_group("Source\\BPF" FILES ${SOURCES_BPF})
+source_group("Source\\RISCV" FILES ${SOURCES_RISCV})
+
+source_group("Include\\Common" FILES ${HEADERS_COMMON})
+source_group("Include\\Engine" FILES ${HEADERS_ENGINE})
+source_group("Include\\ARM" FILES ${HEADERS_ARM})
+source_group("Include\\ARM64" FILES ${HEADERS_ARM64})
+source_group("Include\\Mips" FILES ${HEADERS_MIPS})
+source_group("Include\\PowerPC" FILES ${HEADERS_PPC})
+source_group("Include\\Sparc" FILES ${HEADERS_SPARC})
+source_group("Include\\SystemZ" FILES ${HEADERS_SYSZ})
+source_group("Include\\X86" FILES ${HEADERS_X86})
+source_group("Include\\XCore" FILES ${HEADERS_XCORE})
+source_group("Include\\M68K" FILES ${HEADERS_M68K})
+source_group("Include\\TMS320C64x" FILES ${HEADERS_TMS320C64X})
+source_group("Include\\M680X" FILES ${HEADERS_MC680X})
+source_group("Include\\EVM" FILES ${HEADERS_EVM})
+source_group("Include\\WASM" FILES ${HEADERS_WASM})
+source_group("Include\\MOS65XX" FILES ${HEADERS_MOS65XX})
+source_group("Include\\BPF" FILES ${HEADERS_BPF})
+source_group("Include\\RISCV" FILES ${HEADERS_RISCV})
+
+### test library 64bit routine:
+include("GNUInstallDirs")
+
+## installation
+install(FILES ${HEADERS_COMMON} DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}/capstone)
+configure_file(capstone.pc.in ${CMAKE_BINARY_DIR}/capstone.pc @ONLY)
+
+include(CMakePackageConfigHelpers)
+set(CAPSTONE_CMAKE_CONFIG_INSTALL_DIR "${CMAKE_INSTALL_LIBDIR}/cmake/capstone")
+configure_package_config_file(
+ capstone-config.cmake.in
+ ${CMAKE_CURRENT_BINARY_DIR}/capstone-config.cmake
+ INSTALL_DESTINATION ${CAPSTONE_CMAKE_CONFIG_INSTALL_DIR}
+)
+write_basic_package_version_file(
+ ${CMAKE_CURRENT_BINARY_DIR}/capstone-config-version.cmake
+ VERSION ${VERSION_MAJOR}.${VERSION_MINOR}.${VERSION_PATCH}
+ COMPATIBILITY SameMajorVersion
+)
+install(FILES
+ "${CMAKE_CURRENT_BINARY_DIR}/capstone-config.cmake"
+ "${CMAKE_CURRENT_BINARY_DIR}/capstone-config-version.cmake"
+ DESTINATION ${CAPSTONE_CMAKE_CONFIG_INSTALL_DIR}
+)
+
+if (CAPSTONE_BUILD_STATIC)
+ install(TARGETS capstone-static
+ EXPORT capstone-targets
+ RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR}
+ LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR}
+ ARCHIVE DESTINATION ${CMAKE_INSTALL_LIBDIR}
+ INCLUDES DESTINATION ${CMAKE_INSTALL_INCLUDEDIR})
+endif ()
+
+if (CAPSTONE_BUILD_SHARED)
+ install(TARGETS capstone-shared
+ EXPORT capstone-targets
+ RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR}
+ LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR}
+ ARCHIVE DESTINATION ${CMAKE_INSTALL_LIBDIR}
+ INCLUDES DESTINATION ${CMAKE_INSTALL_INCLUDEDIR})
+endif ()
+
+install(EXPORT capstone-targets
+ NAMESPACE capstone::
+ DESTINATION ${CAPSTONE_CMAKE_CONFIG_INSTALL_DIR})
+
+if (CAPSTONE_BUILD_SHARED AND CAPSTONE_BUILD_CSTOOL)
+FILE(GLOB CSTOOL_SRC cstool/*.c)
+add_executable(cstool ${CSTOOL_SRC})
+target_link_libraries(cstool ${default-target})
+
+install(TARGETS cstool DESTINATION ${CMAKE_INSTALL_BINDIR})
+install(FILES ${CMAKE_BINARY_DIR}/capstone.pc DESTINATION ${CMAKE_INSTALL_LIBDIR}/pkgconfig)
+endif ()