diff options
author | 2023-10-10 14:33:42 +0000 | |
---|---|---|
committer | 2023-10-10 14:33:42 +0000 | |
commit | af1a266670d040d2f4083ff309d732d648afba2a (patch) | |
tree | 2fc46203448ddcc6f81546d379abfaeb323575e9 /capstone/CMakeLists.txt | |
parent | e02cda008591317b1625707ff8e115a4841aa889 (diff) |
Change-Id: Iaf8d18082d3991dec7c0ebbea540f092188eb4ec
Diffstat (limited to 'capstone/CMakeLists.txt')
-rw-r--r-- | capstone/CMakeLists.txt | 708 |
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 () |