dynarmic/src/CMakeLists.txt

296 lines
11 KiB
Text
Raw Normal View History

add_library(dynarmic
2018-01-04 21:12:02 +00:00
../include/dynarmic/A32/a32.h
../include/dynarmic/A32/config.h
2018-01-04 21:12:02 +00:00
../include/dynarmic/A32/coprocessor.h
../include/dynarmic/A32/coprocessor_util.h
../include/dynarmic/A32/disassembler.h
2018-06-05 12:25:16 +01:00
../include/dynarmic/A64/a64.h
../include/dynarmic/A64/config.h
2018-06-05 12:27:37 +01:00
../include/dynarmic/A64/exclusive_monitor.h
common/assert.h
common/bit_util.h
common/cast_util.h
common/common_types.h
common/crypto/aes.cpp
common/crypto/aes.h
common/crypto/crc32.cpp
common/crypto/crc32.h
common/crypto/sm4.cpp
common/crypto/sm4.h
2018-07-17 19:53:21 +01:00
common/fp/fpcr.h
2018-06-26 20:51:25 +01:00
common/fp/fpsr.h
2018-07-23 16:22:16 +01:00
common/fp/fused.cpp
common/fp/fused.h
common/fp/info.h
common/fp/mantissa_util.h
2018-06-29 19:34:46 +01:00
common/fp/op.h
common/fp/op/FPConvert.cpp
common/fp/op/FPConvert.h
2018-07-23 16:22:16 +01:00
common/fp/op/FPMulAdd.cpp
common/fp/op/FPMulAdd.h
2018-07-25 18:36:40 +01:00
common/fp/op/FPRecipEstimate.cpp
common/fp/op/FPRecipEstimate.h
common/fp/op/FPRecipExponent.cpp
common/fp/op/FPRecipExponent.h
common/fp/op/FPRecipStepFused.cpp
common/fp/op/FPRecipStepFused.h
2018-07-16 13:48:30 +01:00
common/fp/op/FPRoundInt.cpp
common/fp/op/FPRoundInt.h
2018-07-22 18:18:22 +01:00
common/fp/op/FPRSqrtEstimate.cpp
common/fp/op/FPRSqrtEstimate.h
2018-07-23 22:02:12 +01:00
common/fp/op/FPRSqrtStepFused.cpp
common/fp/op/FPRSqrtStepFused.h
2018-07-16 12:51:36 +01:00
common/fp/op/FPToFixed.cpp
common/fp/op/FPToFixed.h
2018-06-27 13:51:39 +01:00
common/fp/process_exception.cpp
common/fp/process_exception.h
2018-07-16 13:48:13 +01:00
common/fp/process_nan.cpp
common/fp/process_nan.h
2018-06-26 15:10:44 +01:00
common/fp/rounding_mode.h
2018-06-27 13:52:20 +01:00
common/fp/unpacked.cpp
common/fp/unpacked.h
2018-06-26 20:54:42 +01:00
common/fp/util.h
common/intrusive_list.h
2016-08-24 20:07:08 +01:00
common/iterator_util.h
common/llvm_disassemble.cpp
common/llvm_disassemble.h
common/macro_util.h
common/math_util.cpp
common/math_util.h
2018-01-01 15:23:56 +00:00
common/memory_pool.cpp
common/memory_pool.h
2018-07-15 14:25:31 +01:00
common/mp/append.h
common/mp/bind.h
common/mp/cartesian_product.h
common/mp/concat.h
common/mp/fapply.h
common/mp/fmap.h
2018-07-25 11:28:36 +01:00
common/mp/function_info.h
2018-07-15 14:25:31 +01:00
common/mp/list.h
common/mp/lut.h
common/mp/to_tuple.h
common/mp/vlift.h
common/mp/vllift.h
common/safe_ops.h
common/scope_exit.h
common/string_util.h
common/u128.cpp
common/u128.h
common/variant_util.h
2018-01-01 15:23:56 +00:00
frontend/A32/decoder/arm.h
frontend/A32/decoder/arm.inc
2018-01-01 15:23:56 +00:00
frontend/A32/decoder/thumb16.h
frontend/A32/decoder/thumb32.h
frontend/A32/decoder/vfp2.h
frontend/A32/decoder/vfp2.inc
2018-01-01 15:23:56 +00:00
frontend/A32/disassembler/disassembler.h
frontend/A32/disassembler/disassembler_arm.cpp
frontend/A32/disassembler/disassembler_thumb.cpp
frontend/A32/FPSCR.h
2018-01-01 15:47:56 +00:00
frontend/A32/ir_emitter.cpp
frontend/A32/ir_emitter.h
2018-01-01 15:23:56 +00:00
frontend/A32/location_descriptor.cpp
frontend/A32/location_descriptor.h
frontend/A32/PSR.h
frontend/A32/translate/translate.cpp
frontend/A32/translate/translate.h
frontend/A32/translate/translate_arm.cpp
frontend/A32/translate/translate_arm/branch.cpp
frontend/A32/translate/translate_arm/coprocessor.cpp
frontend/A32/translate/translate_arm/data_processing.cpp
frontend/A32/translate/translate_arm/exception_generating.cpp
frontend/A32/translate/translate_arm/extension.cpp
frontend/A32/translate/translate_arm/load_store.cpp
frontend/A32/translate/translate_arm/misc.cpp
frontend/A32/translate/translate_arm/multiply.cpp
frontend/A32/translate/translate_arm/packing.cpp
frontend/A32/translate/translate_arm/parallel.cpp
frontend/A32/translate/translate_arm/reversal.cpp
frontend/A32/translate/translate_arm/saturated.cpp
frontend/A32/translate/translate_arm/status_register_access.cpp
frontend/A32/translate/translate_arm/synchronization.cpp
frontend/A32/translate/translate_arm/translate_arm.h
frontend/A32/translate/translate_arm/vfp2.cpp
frontend/A32/translate/translate_thumb.cpp
frontend/A32/types.cpp
frontend/A32/types.h
2018-01-04 23:05:27 +00:00
frontend/A64/decoder/a64.h
frontend/A64/decoder/a64.inc
2018-01-04 23:05:27 +00:00
frontend/A64/imm.h
2018-01-07 00:11:57 +00:00
frontend/A64/ir_emitter.cpp
frontend/A64/ir_emitter.h
2018-01-04 23:05:27 +00:00
frontend/A64/location_descriptor.cpp
frontend/A64/location_descriptor.h
2018-01-07 13:42:11 +00:00
frontend/A64/translate/impl/branch.cpp
2018-01-07 00:11:57 +00:00
frontend/A64/translate/impl/data_processing_addsub.cpp
2018-01-17 00:10:28 +00:00
frontend/A64/translate/impl/data_processing_bitfield.cpp
2018-02-04 23:08:16 +00:00
frontend/A64/translate/impl/data_processing_conditional_compare.cpp
2018-01-18 11:37:17 +00:00
frontend/A64/translate/impl/data_processing_conditional_select.cpp
2018-01-25 12:51:45 -05:00
frontend/A64/translate/impl/data_processing_crc32.cpp
2018-01-07 12:52:12 +00:00
frontend/A64/translate/impl/data_processing_logical.cpp
2018-01-23 09:51:57 -05:00
frontend/A64/translate/impl/data_processing_multiply.cpp
2018-01-07 11:41:17 +00:00
frontend/A64/translate/impl/data_processing_pcrel.cpp
frontend/A64/translate/impl/data_processing_register.cpp
frontend/A64/translate/impl/data_processing_shift.cpp
2018-01-08 22:03:03 +00:00
frontend/A64/translate/impl/exception_generating.cpp
2018-02-02 22:25:51 +00:00
frontend/A64/translate/impl/floating_point_compare.cpp
2018-02-05 12:25:04 +00:00
frontend/A64/translate/impl/floating_point_conditional_compare.cpp
2018-02-04 13:40:37 +00:00
frontend/A64/translate/impl/floating_point_conditional_select.cpp
2018-06-05 12:25:16 +01:00
frontend/A64/translate/impl/floating_point_conversion_fixed_point.cpp
frontend/A64/translate/impl/floating_point_conversion_integer.cpp
frontend/A64/translate/impl/floating_point_data_processing_one_register.cpp
2018-06-06 20:03:12 +01:00
frontend/A64/translate/impl/floating_point_data_processing_three_register.cpp
frontend/A64/translate/impl/floating_point_data_processing_two_register.cpp
2018-01-07 00:11:57 +00:00
frontend/A64/translate/impl/impl.cpp
2018-01-04 23:05:27 +00:00
frontend/A64/translate/impl/impl.h
frontend/A64/translate/impl/load_store_exclusive.cpp
2018-01-10 01:13:23 +00:00
frontend/A64/translate/impl/load_store_load_literal.cpp
frontend/A64/translate/impl/load_store_multiple_structures.cpp
frontend/A64/translate/impl/load_store_no_allocate_pair.cpp
2018-01-10 01:13:23 +00:00
frontend/A64/translate/impl/load_store_register_immediate.cpp
2018-01-10 02:05:08 +00:00
frontend/A64/translate/impl/load_store_register_pair.cpp
frontend/A64/translate/impl/load_store_register_register_offset.cpp
frontend/A64/translate/impl/load_store_register_unprivileged.cpp
frontend/A64/translate/impl/load_store_single_structure.cpp
2018-01-15 21:47:28 +00:00
frontend/A64/translate/impl/move_wide.cpp
2018-07-13 21:01:57 -04:00
frontend/A64/translate/impl/simd_across_lanes.cpp
2018-01-30 07:56:18 -05:00
frontend/A64/translate/impl/simd_aes.cpp
2018-01-24 12:00:56 +00:00
frontend/A64/translate/impl/simd_copy.cpp
2018-01-25 21:28:03 -05:00
frontend/A64/translate/impl/simd_crypto_four_register.cpp
2018-04-08 20:49:43 -04:00
frontend/A64/translate/impl/simd_crypto_three_register.cpp
2018-04-02 22:10:28 +01:00
frontend/A64/translate/impl/simd_extract.cpp
frontend/A64/translate/impl/simd_modified_immediate.cpp
2018-02-04 22:29:14 -05:00
frontend/A64/translate/impl/simd_permute.cpp
2018-02-18 23:55:38 +00:00
frontend/A64/translate/impl/simd_scalar_pairwise.cpp
2018-04-12 09:40:44 -04:00
frontend/A64/translate/impl/simd_scalar_shift_by_immediate.cpp
frontend/A64/translate/impl/simd_scalar_three_same.cpp
frontend/A64/translate/impl/simd_scalar_two_register_misc.cpp
frontend/A64/translate/impl/simd_scalar_x_indexed_element.cpp
frontend/A64/translate/impl/simd_sha.cpp
2018-04-03 08:12:13 -04:00
frontend/A64/translate/impl/simd_sha512.cpp
2018-02-10 09:49:55 +00:00
frontend/A64/translate/impl/simd_shift_by_immediate.cpp
2018-08-18 21:09:12 +01:00
frontend/A64/translate/impl/simd_table_lookup.cpp
2018-04-02 21:15:51 +01:00
frontend/A64/translate/impl/simd_three_different.cpp
2018-01-21 17:45:43 +00:00
frontend/A64/translate/impl/simd_three_same.cpp
frontend/A64/translate/impl/simd_three_same_extra.cpp
frontend/A64/translate/impl/simd_two_register_misc.cpp
2018-04-18 21:39:03 +01:00
frontend/A64/translate/impl/simd_vector_x_indexed_element.cpp
2018-02-11 22:53:46 +00:00
frontend/A64/translate/impl/sys_dc.cpp
frontend/A64/translate/impl/system.cpp
2019-03-06 17:38:15 -05:00
frontend/A64/translate/impl/system_flag_format.cpp
2019-03-06 13:56:04 -05:00
frontend/A64/translate/impl/system_flag_manipulation.cpp
2018-01-04 23:05:27 +00:00
frontend/A64/translate/translate.cpp
frontend/A64/translate/translate.h
frontend/A64/types.cpp
frontend/A64/types.h
frontend/decoder/decoder_detail.h
frontend/decoder/matcher.h
2018-01-01 15:23:56 +00:00
frontend/ir/basic_block.cpp
frontend/ir/basic_block.h
frontend/ir/cond.h
2018-01-01 15:23:56 +00:00
frontend/ir/ir_emitter.cpp
frontend/ir/ir_emitter.h
2018-01-01 15:23:56 +00:00
frontend/ir/location_descriptor.cpp
frontend/ir/location_descriptor.h
2018-01-01 15:23:56 +00:00
frontend/ir/microinstruction.cpp
frontend/ir/microinstruction.h
2018-01-01 15:23:56 +00:00
frontend/ir/opcodes.cpp
frontend/ir/opcodes.h
frontend/ir/opcodes.inc
frontend/ir/terminal.h
frontend/ir/type.cpp
frontend/ir/type.h
2018-01-01 15:23:56 +00:00
frontend/ir/value.cpp
frontend/ir/value.h
2018-01-10 19:24:19 +00:00
ir_opt/a32_constant_memory_reads_pass.cpp
ir_opt/a32_get_set_elimination_pass.cpp
2018-02-11 22:53:46 +00:00
ir_opt/a64_callback_config_pass.cpp
ir_opt/a64_get_set_elimination_pass.cpp
ir_opt/a64_merge_interpret_blocks.cpp
2018-01-01 15:23:56 +00:00
ir_opt/constant_propagation_pass.cpp
ir_opt/dead_code_elimination_pass.cpp
ir_opt/passes.h
2018-01-01 15:23:56 +00:00
ir_opt/verification_pass.cpp
)
if (ARCHITECTURE_x86_64)
target_sources(dynarmic PRIVATE
backend/x64/a32_emit_x64.cpp
backend/x64/a32_emit_x64.h
backend/x64/a32_interface.cpp
backend/x64/a32_jitstate.cpp
backend/x64/a32_jitstate.h
backend/x64/a64_emit_x64.cpp
backend/x64/a64_emit_x64.h
backend/x64/a64_exclusive_monitor.cpp
backend/x64/a64_interface.cpp
backend/x64/a64_jitstate.cpp
backend/x64/a64_jitstate.h
backend/x64/abi.cpp
backend/x64/abi.h
backend/x64/block_of_code.cpp
backend/x64/block_of_code.h
backend/x64/block_range_information.cpp
backend/x64/block_range_information.h
backend/x64/callback.cpp
backend/x64/callback.h
backend/x64/constant_pool.cpp
backend/x64/constant_pool.h
backend/x64/devirtualize.h
backend/x64/emit_x64.cpp
backend/x64/emit_x64.h
backend/x64/emit_x64_aes.cpp
backend/x64/emit_x64_crc32.cpp
backend/x64/emit_x64_data_processing.cpp
backend/x64/emit_x64_floating_point.cpp
backend/x64/emit_x64_packed.cpp
backend/x64/emit_x64_saturation.cpp
backend/x64/emit_x64_sm4.cpp
backend/x64/emit_x64_vector.cpp
backend/x64/emit_x64_vector_floating_point.cpp
backend/x64/hostloc.cpp
backend/x64/hostloc.h
backend/x64/jitstate_info.h
backend/x64/oparg.h
2018-07-27 12:42:10 +01:00
backend/x64/perf_map.cpp
backend/x64/perf_map.h
backend/x64/reg_alloc.cpp
backend/x64/reg_alloc.h
)
if (WIN32)
target_sources(dynarmic PRIVATE backend/x64/exception_handler_windows.cpp)
else()
target_sources(dynarmic PRIVATE backend/x64/exception_handler_generic.cpp)
endif()
else()
message(FATAL_ERROR "Unsupported architecture")
endif()
2016-08-25 18:22:08 +01:00
include(CreateDirectoryGroups)
create_target_directory_groups(dynarmic)
2016-08-25 18:22:08 +01:00
target_include_directories(dynarmic
PUBLIC ../include
PRIVATE .)
target_compile_options(dynarmic PRIVATE ${DYNARMIC_CXX_FLAGS})
target_link_libraries(dynarmic
PUBLIC
boost
PRIVATE
2017-08-27 14:50:19 -04:00
fmt::fmt
xbyak
$<$<BOOL:DYNARMIC_USE_LLVM>:${llvm_libs}>
)
if (DYNARMIC_ENABLE_CPU_FEATURE_DETECTION)
target_compile_definitions(dynarmic PRIVATE DYNARMIC_ENABLE_CPU_FEATURE_DETECTION=1)
endif()
if (DYNARMIC_ENABLE_NO_EXECUTE_SUPPORT)
target_compile_definitions(dynarmic PRIVATE DYNARMIC_ENABLE_NO_EXECUTE_SUPPORT=1)
endif()
2016-08-25 17:21:19 -04:00
if (CMAKE_SYSTEM_NAME STREQUAL "Windows")
target_compile_definitions(dynarmic PRIVATE FMT_USE_WINDOWS_H=0)
endif()
export(TARGETS dynarmic boost fmt xbyak FILE "dynarmic-config.cmake")