blob: 8fdf8b997e0f2c72569107ba4d5c0b107aa45b1a [file] [log] [blame]
Clement Courbet1e8fdbe2018-09-24 08:39:48 +00001set(TARGETS_TO_APPEND "")
2
Clement Courbet44b4c542018-06-19 11:28:59 +00003if (LLVM_TARGETS_TO_BUILD MATCHES "X86")
4 add_subdirectory(X86)
Clement Courbet1e8fdbe2018-09-24 08:39:48 +00005 set(TARGETS_TO_APPEND "${TARGETS_TO_APPEND} X86")
Clement Courbet44b4c542018-06-19 11:28:59 +00006endif()
John Brawnc4ed6002018-07-03 10:10:29 +00007if (LLVM_TARGETS_TO_BUILD MATCHES "AArch64")
8 add_subdirectory(AArch64)
Clement Courbet1e8fdbe2018-09-24 08:39:48 +00009 set(TARGETS_TO_APPEND "${TARGETS_TO_APPEND} AArch64")
John Brawnc4ed6002018-07-03 10:10:29 +000010endif()
Clement Courbet44b4c542018-06-19 11:28:59 +000011
Clement Courbet1e8fdbe2018-09-24 08:39:48 +000012set(LLVM_EXEGESIS_TARGETS "${LLVM_EXEGESIS_TARGETS} ${TARGETS_TO_APPEND}" PARENT_SCOPE)
13
Nico Weberb09a8c92018-09-15 19:04:27 +000014add_library(LLVMExegesis
15 STATIC
Clement Courbet37f0ca02018-05-15 12:08:00 +000016 Analysis.cpp
Clement Courbet0e69e2d2018-05-17 10:52:18 +000017 Assembler.cpp
Clement Courbetac74acd2018-04-04 11:37:06 +000018 BenchmarkResult.cpp
19 BenchmarkRunner.cpp
Clement Courbet96715412018-05-07 09:09:48 +000020 Clustering.cpp
Guillaume Chatelet7f8d3102018-09-26 11:57:24 +000021 CodeTemplate.cpp
Clement Courbetac74acd2018-04-04 11:37:06 +000022 Latency.cpp
23 LlvmState.cpp
Clement Courbet0e69e2d2018-05-17 10:52:18 +000024 MCInstrDescView.cpp
Clement Courbetac74acd2018-04-04 11:37:06 +000025 PerfHelper.cpp
Clement Courbet0e69e2d2018-05-17 10:52:18 +000026 RegisterAliasing.cpp
Clement Courbetd939f6d2018-09-13 07:40:53 +000027 SnippetGenerator.cpp
Guillaume Chateletcd488ef2018-09-17 11:09:32 +000028 RegisterValue.cpp
Clement Courbet44b4c542018-06-19 11:28:59 +000029 Target.cpp
Clement Courbetac74acd2018-04-04 11:37:06 +000030 Uops.cpp
Nico Weberb09a8c92018-09-15 19:04:27 +000031 )
Clement Courbetac74acd2018-04-04 11:37:06 +000032
Nico Weberb09a8c92018-09-15 19:04:27 +000033llvm_update_compile_flags(LLVMExegesis)
34llvm_map_components_to_libnames(libs
Clement Courbet908dd382018-04-04 12:58:41 +000035 Analysis
Clement Courbetac74acd2018-04-04 11:37:06 +000036 CodeGen
Clement Courbet908dd382018-04-04 12:58:41 +000037 Core
Clement Courbetac74acd2018-04-04 11:37:06 +000038 ExecutionEngine
Clement Courbet559d1e32018-05-15 07:40:21 +000039 GlobalISel
Clement Courbetac74acd2018-04-04 11:37:06 +000040 MC
Clement Courbet4273e1e2018-06-15 07:30:45 +000041 MCDisassembler
Clement Courbetac74acd2018-04-04 11:37:06 +000042 MCJIT
Clement Courbet908dd382018-04-04 12:58:41 +000043 Object
Clement Courbet4273e1e2018-06-15 07:30:45 +000044 ObjectYAML
Clement Courbetac74acd2018-04-04 11:37:06 +000045 Support
46 )
Nico Weberb09a8c92018-09-15 19:04:27 +000047
48if(LLVM_ENABLE_LIBPFM AND HAVE_LIBPFM)
49 list(APPEND libs pfm)
50endif()
51
52target_link_libraries(LLVMExegesis ${libs})
53set_target_properties(LLVMExegesis PROPERTIES FOLDER "Libraries")