blob: 5b498b30870d977abf3a0f112ebbf93d0d3901ad [file] [log] [blame]
Nicolas Capensdf782a72019-05-18 00:36:52 -04001cmake_minimum_required(VERSION 3.6.3)
Corentin Wallez0866b292015-12-09 13:49:40 -05002
Ben Clayton30b6b592019-08-07 15:04:11 +01003project(SwiftShader C CXX ASM)
Corentin Wallez0866b292015-12-09 13:49:40 -05004
Nicolas Capens4c9f04b2019-01-31 22:09:03 -05005# On Windows we use custom solution and project files, except for certain third-
6# party projects which use CMake-generated ones. They are manually (re)generated
7# and made path relative using build/cmake.sh, so they can be checked into the
8# repository. Therefore they should not be auto-regenerated and left using
9# absolute paths by CMake's ZERO_CHECK.
10if(WIN32)
11 # Disable automatically regenerating project files on CMakeLists.txt changes.
12 set(CMAKE_SUPPRESS_REGENERATION true)
13endif()
14
Corentin Wallez0866b292015-12-09 13:49:40 -050015###########################################################
16# Detect system
17###########################################################
18
Nicolas Capens6f422092015-12-23 15:12:45 -050019if(CMAKE_SYSTEM_NAME MATCHES "Linux")
Corentin Wallez0866b292015-12-09 13:49:40 -050020 set(LINUX ON)
Stephen Whitee6ab01f2019-04-04 14:31:25 -040021elseif(CMAKE_SYSTEM_NAME MATCHES "Android")
22 set(ANDROID ON)
23 set(CMAKE_CXX_FLAGS "-DANDROID_NDK_BUILD")
Corentin Wallez0866b292015-12-09 13:49:40 -050024elseif(WIN32)
25elseif(APPLE)
26else()
27 message(FATAL_ERROR "Platform is not supported")
28endif()
29
Nicolas Capens30cd7d42017-04-25 15:17:25 -040030if(CMAKE_SYSTEM_PROCESSOR MATCHES "arm" OR CMAKE_SYSTEM_PROCESSOR MATCHES "aarch")
31 if(CMAKE_SIZEOF_VOID_P EQUAL 8)
32 set(ARCH "aarch64")
33 else()
34 set(ARCH "arm")
35 endif()
Gordana Cmiljanovic082dfec2018-10-19 11:36:15 +020036elseif(CMAKE_SYSTEM_PROCESSOR MATCHES "mips*")
37 if(CMAKE_SIZEOF_VOID_P EQUAL 8)
38 set(ARCH "mips64el")
39 else()
40 set(ARCH "mipsel")
41 endif()
Colin Samplesf63a3ab2019-06-13 12:53:09 -040042elseif(CMAKE_SYSTEM_PROCESSOR MATCHES "ppc*")
43 if(CMAKE_SIZEOF_VOID_P EQUAL 8)
44 set(ARCH "ppc64le")
45 else()
46 message(FATAL_ERROR "Architecture is not supported")
47 endif()
Corentin Wallez0866b292015-12-09 13:49:40 -050048else()
Nicolas Capens30cd7d42017-04-25 15:17:25 -040049 if(CMAKE_SIZEOF_VOID_P EQUAL 8)
50 set(ARCH "x86_64")
51 else()
52 set(ARCH "x86")
53 endif()
Corentin Wallez0866b292015-12-09 13:49:40 -050054endif()
55
Nicolas Capens007c6c52017-06-09 11:21:48 -040056set(CMAKE_MACOSX_RPATH ON)
57
Nicolas Capensd7a21cc2018-09-11 13:09:28 -040058if ((CMAKE_GENERATOR MATCHES "Visual Studio") AND (CMAKE_GENERATOR_TOOLSET STREQUAL ""))
59 message(WARNING "Visual Studio generators use the x86 host compiler by "
60 "default, even for 64-bit targets. This can result in linker "
61 "instability and out of memory errors. To use the 64-bit "
62 "host compiler, pass -Thost=x64 on the CMake command line.")
63endif()
64
Ben Clayton4901ffd2019-06-27 10:39:07 +010065# Use CCache if available
66find_program(CCACHE_FOUND ccache)
67if(CCACHE_FOUND)
68 message(STATUS "Using ccache")
69 set_property(GLOBAL PROPERTY RULE_LAUNCH_COMPILE ccache)
70 set_property(GLOBAL PROPERTY RULE_LAUNCH_LINK ccache)
71endif(CCACHE_FOUND)
72
Corentin Wallez0866b292015-12-09 13:49:40 -050073###########################################################
Ben Claytona9af8832019-08-14 13:09:43 +010074# Host libraries
75###########################################################
76
77find_library(X11 X11)
78find_library(XCB xcb)
79
80###########################################################
Nicolas Capens18b8d682017-07-25 15:31:45 -040081# Options
82###########################################################
83
84if(NOT CMAKE_BUILD_TYPE)
85 set(CMAKE_BUILD_TYPE "Release" CACHE STRING "The type of build: Debug Release MinSizeRel RelWithDebInfo." FORCE)
86endif()
87set_property(CACHE CMAKE_BUILD_TYPE PROPERTY STRINGS Debug Release MinSizeRel RelWithDebInfo)
88
89option(BUILD_EGL "Build the EGL library" 1)
Nicolas Capens18b8d682017-07-25 15:31:45 -040090option(BUILD_GLESv2 "Build the OpenGL ES 2 library" 1)
91option(BUILD_GLES_CM "Build the OpenGL ES 1.1 library" 1)
Chris Forbes3d27f2e2018-09-26 09:24:39 -070092option(BUILD_VULKAN "Build the Vulkan library" 1)
Nicolas Capens18b8d682017-07-25 15:31:45 -040093
94option(USE_GROUP_SOURCES "Group the source files in a folder tree for Visual Studio" 1)
95
96option(BUILD_SAMPLES "Build sample programs" 1)
97option(BUILD_TESTS "Build test programs" 1)
98
Antonio Maioranof448d8e2019-04-26 16:19:16 -040099option(MSAN "Build with memory sanitizer" 0)
100option(ASAN "Build with address sanitizer" 0)
101option(TSAN "Build with thread sanitizer" 0)
102option(UBSAN "Build with undefined behavior sanitizer" 0)
Ben Claytonb51a6f02019-07-05 15:32:19 +0100103option(WARNINGS_AS_ERRORS "Treat all warnings as errors" 1)
Antonio Maioranof448d8e2019-04-26 16:19:16 -0400104option(DCHECK_ALWAYS_ON "Check validation macros even in release builds" 0)
105option(REACTOR_EMIT_DEBUG_INFO "Emit debug info for JIT functions" 0)
106option(REACTOR_EMIT_PRINT_LOCATION "Emit printing of location info for JIT functions" 0)
Ben Clayton5375f472019-06-24 13:33:11 +0100107option(REACTOR_VERIFY_LLVM_IR "Check reactor-generated LLVM IR is valid even in release builds" 0)
Nicolas Capensbf8fd5b2018-06-21 00:42:00 -0400108
Ben Claytone693b622019-09-05 12:48:37 +0100109set(BUILD_MARL ${BUILD_VULKAN})
110
Nicolas Capens5f8a16a2019-08-15 10:36:13 -0400111set(DEFAULT_REACTOR_BACKEND "LLVM")
Nicolas Capens18b8d682017-07-25 15:31:45 -0400112
Nicolas Capens3957b7f2018-10-15 12:54:41 -0400113set(REACTOR_BACKEND ${DEFAULT_REACTOR_BACKEND} CACHE STRING "JIT compiler back-end used by Reactor")
Nicolas Capens18b8d682017-07-25 15:31:45 -0400114set_property(CACHE REACTOR_BACKEND PROPERTY STRINGS LLVM Subzero)
115
116# LLVM disallows calling cmake . from the main LLVM dir, the reason is that
117# it builds header files that could overwrite the orignal ones. Here we
118# want to include LLVM as a subdirectory and even though it wouldn't cause
119# the problem, if cmake . is called from the main dir, the condition that
Erwin Jansend46faeb2018-11-19 16:01:37 -0800120# LLVM checkes, "CMAKE_CURRENT_SOURCE_DIR == CMAKE_CURRENT_BINARY_DIR" will be true. So we
Nicolas Capens18b8d682017-07-25 15:31:45 -0400121# disallow it ourselves too to. In addition if there are remining CMakeFiles
122# and CMakeCache in the directory, cmake .. from a subdirectory will still
123# try to build from the main directory so we instruct users to delete these
124# files when they get the error.
Erwin Jansend46faeb2018-11-19 16:01:37 -0800125if(CMAKE_CURRENT_SOURCE_DIR STREQUAL CMAKE_CURRENT_BINARY_DIR)
Nicolas Capens18b8d682017-07-25 15:31:45 -0400126 message(FATAL_ERROR "In source builds are not allowed by LLVM, please create a build/ directory and build from there. You may have to delete the CMakeCache.txt file and CMakeFiles directory that are next to the CMakeLists.txt.")
127endif()
128
129set_property(GLOBAL PROPERTY USE_FOLDERS ON)
130
131###########################################################
Nicolas Capensfe5861b2018-08-03 16:01:48 -0400132# Initialize submodules
133###########################################################
134
Dan Sinclair6480d4e2019-03-11 10:48:19 -0400135if (NOT TARGET gtest)
136 if(NOT EXISTS ${CMAKE_CURRENT_SOURCE_DIR}/third_party/googletest/.git)
137 message(WARNING "
138 third_party/googletest submodule missing.
139 Running 'git submodule update --init' to download it:
140 ")
Nicolas Capensfe5861b2018-08-03 16:01:48 -0400141
Dan Sinclair6480d4e2019-03-11 10:48:19 -0400142 execute_process(COMMAND git submodule update --init)
143 endif()
Nicolas Capensfe5861b2018-08-03 16:01:48 -0400144endif()
145
Ben Clayton755467c2019-03-23 11:57:02 +0000146if (NOT TARGET libbacktrace)
147 if(NOT EXISTS ${CMAKE_CURRENT_SOURCE_DIR}/third_party/libbacktrace/src/.git)
148 message(WARNING "
149 third_party/libbacktrace/src submodule missing.
150 Running 'git submodule update --init' to download it:
151 ")
152
153 execute_process(COMMAND git submodule update --init)
154 endif()
155endif()
156
Antonio Maiorano8b321d12019-05-27 16:15:34 -0400157# Boost is downloaded if necessary
158
159# From https://www.boost.org/users/download/
160set(BOOST_VER 1.70.0)
161set(BOOST_HASH_TARGZ "882b48708d211a5f48e60b0124cf5863c1534cd544ecd0664bb534a4b5d506e9")
162set(BOOST_HASH_ZIP "48f379b2e90dd1084429aae87d6bdbde9670139fa7569ee856c8c86dd366039d")
163
164string(REPLACE "." "_" BOOST_VER_FNAME ${BOOST_VER})
165set(BOOST_THIRD_PARTY_DIR ${CMAKE_CURRENT_SOURCE_DIR}/third_party/boost_${BOOST_VER_FNAME})
166
167function(DownloadBoost)
168 if (LINUX)
169 set(BOOST_EXT "tar.gz")
170 set(BOOST_HASH ${BOOST_HASH_TARGZ})
171 else()
172 set(BOOST_EXT "zip")
173 set(BOOST_HASH ${BOOST_HASH_ZIP})
174 endif()
175
176 # Note: bintray.com has rate limiting, so use the sourceforge mirror
177 # set(BOOST_URL https://dl.bintray.com/boostorg/release/${BOOST_VER}/source/boost_${BOOST_VER_FNAME}.${BOOST_EXT})
178 set(BOOST_URL https://iweb.dl.sourceforge.net/project/boost/boost/${BOOST_VER}/boost_${BOOST_VER_FNAME}.${BOOST_EXT})
179
180 if (NOT TARGET Boost::boost)
181 if(NOT EXISTS ${BOOST_THIRD_PARTY_DIR})
182 message(WARNING "
183 third_party/boost is missing.
184 Downloading and extracting boost:
185 ")
186
187 set(BOOST_ARCHIVE ${CMAKE_BINARY_DIR}/temp/boost_archive)
188 message(STATUS "Downloading ${BOOST_URL} to ${BOOST_ARCHIVE}...")
189 file(DOWNLOAD ${BOOST_URL} ${BOOST_ARCHIVE} EXPECTED_HASH SHA256=${BOOST_HASH})
190 message(STATUS "Extracting ${BOOST_ARCHIVE} to ${BOOST_THIRD_PARTY_DIR}...")
191 execute_process(
192 WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}/third_party
193 COMMAND cmake -E tar xf ${BOOST_ARCHIVE}
194 )
195 endif()
196 endif()
197endfunction()
198
Nicolas Capensfe5861b2018-08-03 16:01:48 -0400199###########################################################
Corentin Wallez0866b292015-12-09 13:49:40 -0500200# Convenience macros
201###########################################################
202
203# Recursively calls source_group on the files of the directory
204# so that Visual Studio has the files in a folder tree
205macro(group_all_sources directory)
Erwin Jansend46faeb2018-11-19 16:01:37 -0800206 file(GLOB files RELATIVE ${CMAKE_CURRENT_SOURCE_DIR}/${directory} ${CMAKE_CURRENT_SOURCE_DIR}/${directory}/*)
Corentin Wallez0866b292015-12-09 13:49:40 -0500207 foreach(file ${files})
Erwin Jansend46faeb2018-11-19 16:01:37 -0800208 if(IS_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}/${directory}/${file})
Corentin Wallez0866b292015-12-09 13:49:40 -0500209 group_all_sources(${directory}/${file})
210 else()
211 string(REPLACE "/" "\\" groupname ${directory})
Erwin Jansend46faeb2018-11-19 16:01:37 -0800212 source_group(${groupname} FILES ${CMAKE_CURRENT_SOURCE_DIR}/${directory}/${file})
Corentin Wallez0866b292015-12-09 13:49:40 -0500213 endif()
214 endforeach()
215endmacro()
216
217# Takes target library and a directory where the export map is
218# and add the linker options so that only the API symbols are
219# exported.
Nicolas Capens499bb762018-06-29 13:30:57 -0400220macro(set_shared_library_export_map TARGET DIR)
Corentin Wallez0866b292015-12-09 13:49:40 -0500221 if(MSVC)
Nicolas Capens499bb762018-06-29 13:30:57 -0400222 set_property(TARGET ${TARGET} APPEND_STRING PROPERTY LINK_FLAGS " /DEF:\"${DIR}/${TARGET}.def\"")
Ben Clayton8565e772019-06-10 11:58:37 +0100223 elseif(APPLE)
224 # The exported symbols list only exports the API functions and
225 # hides all the others.
226 set_property(TARGET ${TARGET} APPEND_STRING PROPERTY LINK_FLAGS "-exported_symbols_list ${DIR}/${TARGET}.exports")
227 set_property(TARGET ${TARGET} APPEND_STRING PROPERTY LINK_DEPENDS "${DIR}/${TARGET}.exports;")
228 # Don't allow undefined symbols, unless it's a Sanitizer build.
229 if(NOT MSAN AND NOT ASAN AND NOT TSAN AND NOT UBSAN)
230 set_property(TARGET ${TARGET} APPEND_STRING PROPERTY LINK_FLAGS " -Wl,-undefined,error")
231 endif()
Corentin Wallez27654c22015-12-09 15:22:08 -0500232 elseif(LINUX)
Corentin Wallez0866b292015-12-09 13:49:40 -0500233 # The version script only exports the API functions and
Nicolas Capens499bb762018-06-29 13:30:57 -0400234 # hides all the others.
235 set_property(TARGET ${TARGET} APPEND_STRING PROPERTY LINK_FLAGS " -Wl,--version-script=${DIR}/${TARGET}.lds")
236 set_property(TARGET ${TARGET} APPEND_STRING PROPERTY LINK_DEPENDS "${DIR}/${TARGET}.lds;")
Nicolas Capensbf8fd5b2018-06-21 00:42:00 -0400237
Nicolas Capens517a57f2018-06-29 13:30:57 -0400238 # Don't allow symbols to be overridden by another module.
239 set_property(TARGET ${TARGET} APPEND_STRING PROPERTY COMPILE_FLAGS " -fvisibility=protected")
240
Gordana Cmiljanovic20622c02018-11-05 15:00:11 +0100241 if(ARCH STREQUAL "mipsel" OR ARCH STREQUAL "mips64el")
Gordana Cmiljanovic082dfec2018-10-19 11:36:15 +0200242 # MIPS supports sysv hash-style only.
243 set_property(TARGET ${TARGET} APPEND_STRING PROPERTY LINK_FLAGS " -Wl,--hash-style=sysv")
244 else()
245 # Both hash-style are needed, because we want both gold and
246 # GNU ld to be able to read our libraries.
247 set_property(TARGET ${TARGET} APPEND_STRING PROPERTY LINK_FLAGS " -Wl,--hash-style=both")
248 endif()
Nicolas Capens499bb762018-06-29 13:30:57 -0400249
250 # Gc sections is used in combination with each functions being
251 # in its own section, to reduce the binary size.
252 set_property(TARGET ${TARGET} APPEND_STRING PROPERTY LINK_FLAGS " -Wl,--gc-sections")
253
254 # Don't allow undefined symbols, unless it's a Sanitizer build.
Nicolas Capensbf8fd5b2018-06-21 00:42:00 -0400255 if(NOT MSAN AND NOT ASAN AND NOT TSAN AND NOT UBSAN)
256 set_property(TARGET ${TARGET} APPEND_STRING PROPERTY LINK_FLAGS " -Wl,--no-undefined")
257 endif()
Corentin Wallez0866b292015-12-09 13:49:40 -0500258 endif()
259endmacro()
260
261if(USE_GROUP_SOURCES)
262 group_all_sources(src)
263endif()
264
265###########################################################
266# Directories
267###########################################################
268
Erwin Jansend46faeb2018-11-19 16:01:37 -0800269set(SOURCE_DIR ${CMAKE_CURRENT_SOURCE_DIR}/src)
Corentin Wallez0866b292015-12-09 13:49:40 -0500270set(OPENGL_DIR ${SOURCE_DIR}/OpenGL)
271set(OPENGL_COMPILER_DIR ${OPENGL_DIR}/compiler)
Chris Forbes3d27f2e2018-09-26 09:24:39 -0700272set(VULKAN_DIR ${SOURCE_DIR}/Vulkan)
Ben Clayton5875be52019-04-11 14:57:40 -0400273set(LLVM_DIR ${CMAKE_CURRENT_SOURCE_DIR}/third_party/llvm-7.0/llvm)
274set(LLVM_CONFIG_DIR ${CMAKE_CURRENT_SOURCE_DIR}/third_party/llvm-7.0/configs)
Ben Claytonac07ed82019-03-26 14:17:41 +0000275set(LIBBACKTRACE_DIR ${CMAKE_CURRENT_SOURCE_DIR}/third_party/libbacktrace/src)
276set(LIBBACKTRACE_CONFIG_DIR ${CMAKE_CURRENT_SOURCE_DIR}/third_party/libbacktrace/config)
277set(LIBBACKTRACE_INCLUDE_DIR ${CMAKE_CURRENT_SOURCE_DIR}/third_party/libbacktrace/src)
Ben Claytone693b622019-09-05 12:48:37 +0100278set(MARL_INCLUDE_DIR ${CMAKE_CURRENT_SOURCE_DIR}/third_party/marl/include)
Erwin Jansend46faeb2018-11-19 16:01:37 -0800279set(SUBZERO_DIR ${CMAKE_CURRENT_SOURCE_DIR}/third_party/subzero)
280set(SUBZERO_LLVM_DIR ${CMAKE_CURRENT_SOURCE_DIR}/third_party/llvm-subzero)
281set(TESTS_DIR ${CMAKE_CURRENT_SOURCE_DIR}/tests)
282set(HELLO2_DIR ${CMAKE_CURRENT_SOURCE_DIR}/third_party/PowerVR_SDK/Examples/Beginner/01_HelloAPI/OGLES2)
Corentin Wallez0866b292015-12-09 13:49:40 -0500283
284###########################################################
285# Compile flags
286###########################################################
287
Ben Clayton4ceb77d2019-04-24 12:09:59 +0100288# Flags for project code (non 3rd party)
289set(SWIFTSHADER_COMPILE_OPTIONS "")
290
Nicolas Capens6f422092015-12-23 15:12:45 -0500291macro(set_cpp_flag FLAG)
292 if(${ARGC} GREATER 1)
293 set(CMAKE_CXX_FLAGS_${ARGV1} "${CMAKE_CXX_FLAGS_${ARGV1}} ${FLAG}")
Corentin Wallez0866b292015-12-09 13:49:40 -0500294 else()
Nicolas Capens6f422092015-12-23 15:12:45 -0500295 set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${FLAG}")
Corentin Wallez0866b292015-12-09 13:49:40 -0500296 endif()
297endmacro()
298
Ben Clayton48c8a182019-05-21 20:00:20 +0100299macro(set_linker_flag FLAG)
300 if(${ARGC} GREATER 1)
301 set(CMAKE_EXE_LINKER_FLAGS ${ARGV1} "${CMAKE_EXE_LINKER_FLAGS ${ARGV1}} ${FLAG}")
302 else()
303 set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} ${FLAG}")
304 endif()
305endmacro()
306
Corentin Wallez0866b292015-12-09 13:49:40 -0500307if(MSVC)
308 set_cpp_flag("/MP")
309 add_definitions(-D_CRT_SECURE_NO_WARNINGS)
Antonio Maiorano5bce1f42019-05-10 16:03:49 -0400310 add_definitions(-D_SCL_SECURE_NO_WARNINGS)
Nicolas Capens4c9f04b2019-01-31 22:09:03 -0500311 add_definitions(-D_SBCS) # Single Byte Character Set (ASCII)
Ben Clayton30b6b592019-08-07 15:04:11 +0100312 add_definitions(-D_ENABLE_EXTENDED_ALIGNED_STORAGE) # Disable MSVC warnings about std::aligned_storage being broken before VS 2017 15.8
Antonio Maiorano5bce1f42019-05-10 16:03:49 -0400313
314 if(WARNINGS_AS_ERRORS)
315 set_cpp_flag("/WX") # Treat all warnings as errors
316 endif()
317
318 # Disable specific warnings
319 # TODO: Not all of these should be disabled, but for now, we want a warning-free msvc build. Remove these one by one
320 # and fix the actual warnings in code.
321 list(APPEND SWIFTSHADER_COMPILE_OPTIONS
322 "/wd4005" # 'identifier' : macro redefinition
323 "/wd4018" # 'expression' : signed/unsigned mismatch
Ben Clayton4d4a1902019-05-15 11:15:42 +0100324 "/wd4065" # switch statement contains 'default' but no 'case' labels
Antonio Maiorano5bce1f42019-05-10 16:03:49 -0400325 "/wd4141" # 'modifier' : used more than once
326 "/wd4146" # unary minus operator applied to unsigned type, result still unsigned
327 "/wd4244" # 'conversion' conversion from 'type1' to 'type2', possible loss of data
328 "/wd4267" # 'var' : conversion from 'size_t' to 'type', possible loss of data
329 "/wd4291" # 'void X new(size_t,unsigned int,unsigned int)': no matching operator delete found; memory will not be freed if initialization throws an exception
330 "/wd4309" # 'conversion' : truncation of constant value
331 "/wd4624" # 'derived class' : destructor was implicitly defined as deleted because a base class destructor is inaccessible or deleted
332 "/wd4800" # 'type' : forcing value to bool 'true' or 'false' (performance warning)
333 "/wd4838" # conversion from 'type_1' to 'type_2' requires a narrowing conversion
334 "/wd5030" # attribute 'attribute' is not recognized
335 "/wd5038" # data member 'member1' will be initialized after data member 'member2' data member 'member' will be initialized after base class 'base_class'
336 )
337
338 # Treat specific warnings as errors
339 list(APPEND SWIFTSHADER_COMPILE_OPTIONS
340 "/we4018" # 'expression' : signed/unsigned mismatch
Antonio Maiorano23da0732019-05-14 22:32:16 -0400341 "/we4471" # 'enumeration': a forward declaration of an unscoped enumeration must have an underlying type (int assumed)
Antonio Maiorano5bce1f42019-05-10 16:03:49 -0400342 "/we4838" # conversion from 'type_1' to 'type_2' requires a narrowing conversion
343 "/we5038" # data member 'member1' will be initialized after data member 'member2' data member 'member' will be initialized after base class 'base_class'
344 )
345
Corentin Wallez0866b292015-12-09 13:49:40 -0500346else()
Chris Forbesef4ab0f2019-01-18 08:11:03 -0800347 set_cpp_flag("--std=c++11")
Ben Clayton09a7f452019-04-25 15:22:43 +0100348 set_cpp_flag("-fno-exceptions")
349
Ben Clayton4ceb77d2019-04-24 12:09:59 +0100350 list(APPEND SWIFTSHADER_COMPILE_OPTIONS
Ben Clayton4ceb77d2019-04-24 12:09:59 +0100351 "-Wall"
Ben Clayton8a983f72019-06-18 17:56:36 +0100352 "-Wreorder"
353 "-Wsign-compare"
354 "-Wmissing-braces"
Ben Clayton4ceb77d2019-04-24 12:09:59 +0100355 )
Corentin Wallez0866b292015-12-09 13:49:40 -0500356
Ben Clayton5e828762019-04-24 19:16:52 +0100357 if(CMAKE_CXX_COMPILER_ID MATCHES "Clang")
Ben Clayton4ceb77d2019-04-24 12:09:59 +0100358 list(APPEND SWIFTSHADER_COMPILE_OPTIONS
Ben Clayton8a983f72019-06-18 17:56:36 +0100359 "-Wunused-lambda-capture"
360 "-Wstring-conversion"
361 "-Wextra-semi"
362 "-Wignored-qualifiers"
Nicolas Capens67180a02019-06-17 15:27:03 -0400363 # Silence errors caused by unknown warnings when building with older
364 # versions of Clang. This demands checking that warnings added above
365 # are spelled correctly and work as intended!
366 "-Wno-unknown-warning-option"
Ben Clayton4ceb77d2019-04-24 12:09:59 +0100367 )
Nicolas Capens825d3442018-11-06 23:50:05 -0500368 endif()
369
Corentin Wallez0866b292015-12-09 13:49:40 -0500370 # Remove xor, and, or and friends from the list of keywords, they are used
371 # by Reactor
Ben Clayton4ceb77d2019-04-24 12:09:59 +0100372 list(APPEND SWIFTSHADER_COMPILE_OPTIONS
373 "-fno-operator-names"
374 )
Corentin Wallez0866b292015-12-09 13:49:40 -0500375
376 # LLVM headers requires these flags to be set
377 set_cpp_flag("-D__STDC_CONSTANT_MACROS -D__STDC_LIMIT_MACROS")
378
Nicolas Capens499bb762018-06-29 13:30:57 -0400379 if(ARCH STREQUAL "x86")
Corentin Wallez0866b292015-12-09 13:49:40 -0500380 set_cpp_flag("-m32")
381 set_cpp_flag("-msse2")
Nicolas Capens0424edc2018-01-03 14:06:30 -0500382 set_cpp_flag("-mfpmath=sse")
383 set_cpp_flag("-march=pentium4")
384 set_cpp_flag("-mtune=generic")
Corentin Wallez0866b292015-12-09 13:49:40 -0500385 endif()
Nicolas Capens499bb762018-06-29 13:30:57 -0400386 if(ARCH STREQUAL "x86_64")
Corentin Wallez0866b292015-12-09 13:49:40 -0500387 set_cpp_flag("-m64")
388 set_cpp_flag("-fPIC")
Nicolas Capens0424edc2018-01-03 14:06:30 -0500389 set_cpp_flag("-march=x86-64")
390 set_cpp_flag("-mtune=generic")
Corentin Wallez0866b292015-12-09 13:49:40 -0500391 endif()
Gordana Cmiljanovic082dfec2018-10-19 11:36:15 +0200392 if(ARCH STREQUAL "mipsel")
393 set_cpp_flag("-march=mips32r2")
394 set_cpp_flag("-fPIC")
395 set_cpp_flag("-mhard-float")
396 set_cpp_flag("-mfp32")
397 endif()
Gordana Cmiljanovic20622c02018-11-05 15:00:11 +0100398 if(ARCH STREQUAL "mips64el")
399 set_cpp_flag("-march=mips64r2")
400 set_cpp_flag("-mabi=64")
401 set_cpp_flag("-fPIC")
402 endif()
Nicolas Capens499bb762018-06-29 13:30:57 -0400403
Corentin Wallez0866b292015-12-09 13:49:40 -0500404 # Use -g3 to have even more debug info
405 set_cpp_flag("-g -g3" DEBUG)
406 set_cpp_flag("-g -g3" RELWITHDEBINFO)
Ben Clayton09a91e42019-02-05 17:58:38 +0000407 if(NOT CMAKE_CXX_COMPILER_ID MATCHES "Clang")
408 # Treated as an unused argument with clang
409 set_cpp_flag("-s" RELEASE)
410 endif()
Corentin Wallez0866b292015-12-09 13:49:40 -0500411
Ben Clayton7aafb272019-02-19 17:08:56 +0000412 if(WARNINGS_AS_ERRORS)
413 set_cpp_flag("-Werror") # Treat all warnings as errors
414 endif()
415
Ben Claytonf1172912019-02-26 16:52:12 +0000416 if(DCHECK_ALWAYS_ON)
Ben Clayton4ceb77d2019-04-24 12:09:59 +0100417 list(APPEND SWIFTSHADER_COMPILE_OPTIONS "-DDCHECK_ALWAYS_ON")
Ben Claytonf1172912019-02-26 16:52:12 +0000418 endif()
419
Ben Clayton0eee3322019-02-19 17:08:14 +0000420 # Disable pedanitc warnings
421 if(CMAKE_CXX_COMPILER_ID MATCHES "GNU")
Ben Clayton4ceb77d2019-04-24 12:09:59 +0100422 list(APPEND SWIFTSHADER_COMPILE_OPTIONS
423 "-Wno-ignored-attributes" # ignoring attributes on template argument 'X'
424 "-Wno-attributes" # 'X' attribute ignored
425 "-Wno-strict-aliasing" # dereferencing type-punned pointer will break strict-aliasing rules
426 "-Wno-comment" # multi-line comment
427 )
Ben Clayton0eee3322019-02-19 17:08:14 +0000428 elseif(CMAKE_CXX_COMPILER_ID MATCHES "Clang")
Ben Clayton4ceb77d2019-04-24 12:09:59 +0100429 list(APPEND SWIFTSHADER_COMPILE_OPTIONS
430 "-Wno-unneeded-internal-declaration" # function 'X' is not needed and will not be emitted
431 "-Wno-unused-private-field" # private field 'offset' is not used - TODO: Consider enabling this once Vulkan is further implemented.
432 "-Wno-comment" # multi-line comment
433 "-Wno-undefined-var-template" # instantiation of variable 'X' required here, but no definition is available
434 )
Ben Clayton0eee3322019-02-19 17:08:14 +0000435 endif()
436
Corentin Wallez0866b292015-12-09 13:49:40 -0500437 # For distribution it is more important to be slim than super optimized
Alexis Hetu2c0546d2017-05-24 11:16:26 -0400438 set_cpp_flag("-Os" RELEASE)
439 set_cpp_flag("-Os" RELWITHDEBINFO)
Corentin Wallez0866b292015-12-09 13:49:40 -0500440
441 set_cpp_flag("-DNDEBUG" RELEASE)
442 set_cpp_flag("-DNDEBUG" RELWITHDEBINFO)
443 set_cpp_flag("-DANGLE_DISABLE_TRACE" RELEASE)
444 set_cpp_flag("-DANGLE_DISABLE_TRACE" RELWITHDEBINFO)
445
446 # Put each variable and function in its own section so that when linking
447 # with -gc-sections unused functions and variables are removed.
448 set_cpp_flag("-ffunction-sections" RELEASE)
449 set_cpp_flag("-fdata-sections" RELEASE)
450 set_cpp_flag("-fomit-frame-pointer" RELEASE)
Nicolas Capensbf8fd5b2018-06-21 00:42:00 -0400451
Ben Claytondae97922019-05-17 12:09:31 +0100452 if(MSAN)
453 set_cpp_flag("-fsanitize=memory")
Ben Clayton48c8a182019-05-21 20:00:20 +0100454 set_linker_flag("-fsanitize=memory")
Ben Claytondae97922019-05-17 12:09:31 +0100455 elseif(ASAN)
456 set_cpp_flag("-fsanitize=address")
Ben Clayton48c8a182019-05-21 20:00:20 +0100457 set_linker_flag("-fsanitize=address")
Ben Claytondae97922019-05-17 12:09:31 +0100458 elseif(TSAN)
459 set_cpp_flag("-fsanitize=thread")
Ben Clayton48c8a182019-05-21 20:00:20 +0100460 set_linker_flag("-fsanitize=thread")
Ben Claytondae97922019-05-17 12:09:31 +0100461 elseif(UBSAN)
462 set_cpp_flag("-fsanitize=undefined")
Ben Clayton48c8a182019-05-21 20:00:20 +0100463 set_linker_flag("-fsanitize=undefined")
Nicolas Capensbf8fd5b2018-06-21 00:42:00 -0400464 endif()
Corentin Wallez0866b292015-12-09 13:49:40 -0500465endif()
466
Antonio Maioranof448d8e2019-04-26 16:19:16 -0400467if(REACTOR_EMIT_PRINT_LOCATION)
468 # This feature depends on REACTOR_EMIT_DEBUG_INFO, so enable it
469 set(REACTOR_EMIT_DEBUG_INFO "On")
470 list(APPEND SWIFTSHADER_COMPILE_OPTIONS "-DENABLE_RR_EMIT_PRINT_LOCATION")
471endif()
472
473if(REACTOR_EMIT_DEBUG_INFO)
474 message(WARNING "REACTOR_EMIT_DEBUG_INFO is enabled. This will likely affect performance.")
475 list(APPEND SWIFTSHADER_COMPILE_OPTIONS "-DENABLE_RR_DEBUG_INFO")
476endif()
477
Ben Clayton5375f472019-06-24 13:33:11 +0100478if(REACTOR_VERIFY_LLVM_IR)
479 list(APPEND SWIFTSHADER_COMPILE_OPTIONS "-DENABLE_RR_LLVM_IR_VERIFICATION")
480endif()
481
Nicolas Capensbf8fd5b2018-06-21 00:42:00 -0400482if(WIN32)
Corentin Wallez0866b292015-12-09 13:49:40 -0500483 add_definitions(-DWINVER=0x501 -DNOMINMAX -DSTRICT)
Nicolas Capens6f422092015-12-23 15:12:45 -0500484 set(CMAKE_FIND_LIBRARY_PREFIXES ${CMAKE_FIND_LIBRARY_PREFIXES} "" "lib")
Corentin Wallez0866b292015-12-09 13:49:40 -0500485endif()
486
Corentin Wallez0866b292015-12-09 13:49:40 -0500487###########################################################
488# LLVM
489###########################################################
490
Logan Chien0eedc8c2018-08-21 09:34:28 +0800491set(LLVM_LIST
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400492 ${LLVM_DIR}/lib/Analysis/AliasAnalysis.cpp
493 ${LLVM_DIR}/lib/Analysis/AliasAnalysisSummary.cpp
494 ${LLVM_DIR}/lib/Analysis/AliasSetTracker.cpp
495 ${LLVM_DIR}/lib/Analysis/AssumptionCache.cpp
496 ${LLVM_DIR}/lib/Analysis/BasicAliasAnalysis.cpp
497 ${LLVM_DIR}/lib/Analysis/BlockFrequencyInfo.cpp
498 ${LLVM_DIR}/lib/Analysis/BlockFrequencyInfoImpl.cpp
499 ${LLVM_DIR}/lib/Analysis/BranchProbabilityInfo.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400500 ${LLVM_DIR}/lib/Analysis/CallGraph.cpp
501 ${LLVM_DIR}/lib/Analysis/CallGraphSCCPass.cpp
502 ${LLVM_DIR}/lib/Analysis/CaptureTracking.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +0100503 ${LLVM_DIR}/lib/Analysis/CFG.cpp
504 ${LLVM_DIR}/lib/Analysis/CFLAndersAliasAnalysis.cpp
505 ${LLVM_DIR}/lib/Analysis/CFLSteensAliasAnalysis.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400506 ${LLVM_DIR}/lib/Analysis/CmpInstAnalysis.cpp
507 ${LLVM_DIR}/lib/Analysis/CodeMetrics.cpp
508 ${LLVM_DIR}/lib/Analysis/ConstantFolding.cpp
509 ${LLVM_DIR}/lib/Analysis/DemandedBits.cpp
510 ${LLVM_DIR}/lib/Analysis/DependenceAnalysis.cpp
511 ${LLVM_DIR}/lib/Analysis/DivergenceAnalysis.cpp
512 ${LLVM_DIR}/lib/Analysis/DominanceFrontier.cpp
513 ${LLVM_DIR}/lib/Analysis/EHPersonalities.cpp
514 ${LLVM_DIR}/lib/Analysis/GlobalsModRef.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400515 ${LLVM_DIR}/lib/Analysis/InlineCost.cpp
516 ${LLVM_DIR}/lib/Analysis/InstructionSimplify.cpp
517 ${LLVM_DIR}/lib/Analysis/IteratedDominanceFrontier.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +0100518 ${LLVM_DIR}/lib/Analysis/IVUsers.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400519 ${LLVM_DIR}/lib/Analysis/LazyBlockFrequencyInfo.cpp
520 ${LLVM_DIR}/lib/Analysis/LazyBranchProbabilityInfo.cpp
521 ${LLVM_DIR}/lib/Analysis/LazyValueInfo.cpp
522 ${LLVM_DIR}/lib/Analysis/Loads.cpp
523 ${LLVM_DIR}/lib/Analysis/LoopAnalysisManager.cpp
524 ${LLVM_DIR}/lib/Analysis/LoopInfo.cpp
525 ${LLVM_DIR}/lib/Analysis/LoopPass.cpp
526 ${LLVM_DIR}/lib/Analysis/MemoryBuiltins.cpp
527 ${LLVM_DIR}/lib/Analysis/MemoryDependenceAnalysis.cpp
528 ${LLVM_DIR}/lib/Analysis/MemoryLocation.cpp
529 ${LLVM_DIR}/lib/Analysis/MemorySSA.cpp
Ben Clayton1c82c7b2019-04-30 12:49:27 +0100530 ${LLVM_DIR}/lib/Analysis/MemorySSAUpdater.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400531 ${LLVM_DIR}/lib/Analysis/MustExecute.cpp
532 ${LLVM_DIR}/lib/Analysis/ObjCARCAliasAnalysis.cpp
533 ${LLVM_DIR}/lib/Analysis/ObjCARCAnalysisUtils.cpp
534 ${LLVM_DIR}/lib/Analysis/ObjCARCInstKind.cpp
535 ${LLVM_DIR}/lib/Analysis/OptimizationRemarkEmitter.cpp
536 ${LLVM_DIR}/lib/Analysis/OrderedBasicBlock.cpp
537 ${LLVM_DIR}/lib/Analysis/PHITransAddr.cpp
538 ${LLVM_DIR}/lib/Analysis/PhiValues.cpp
539 ${LLVM_DIR}/lib/Analysis/PostDominators.cpp
540 ${LLVM_DIR}/lib/Analysis/ProfileSummaryInfo.cpp
541 ${LLVM_DIR}/lib/Analysis/PtrUseVisitor.cpp
542 ${LLVM_DIR}/lib/Analysis/ScalarEvolution.cpp
543 ${LLVM_DIR}/lib/Analysis/ScalarEvolutionAliasAnalysis.cpp
544 ${LLVM_DIR}/lib/Analysis/ScalarEvolutionExpander.cpp
545 ${LLVM_DIR}/lib/Analysis/ScalarEvolutionNormalization.cpp
546 ${LLVM_DIR}/lib/Analysis/ScopedNoAliasAA.cpp
547 ${LLVM_DIR}/lib/Analysis/TargetLibraryInfo.cpp
548 ${LLVM_DIR}/lib/Analysis/TargetTransformInfo.cpp
549 ${LLVM_DIR}/lib/Analysis/TypeBasedAliasAnalysis.cpp
550 ${LLVM_DIR}/lib/Analysis/ValueLattice.cpp
551 ${LLVM_DIR}/lib/Analysis/ValueLatticeUtils.cpp
552 ${LLVM_DIR}/lib/Analysis/ValueTracking.cpp
553 ${LLVM_DIR}/lib/Analysis/VectorUtils.cpp
554 ${LLVM_DIR}/lib/AsmParser/LLLexer.cpp
555 ${LLVM_DIR}/lib/AsmParser/LLParser.cpp
556 ${LLVM_DIR}/lib/AsmParser/Parser.cpp
557 ${LLVM_DIR}/lib/BinaryFormat/Dwarf.cpp
558 ${LLVM_DIR}/lib/BinaryFormat/Magic.cpp
559 ${LLVM_DIR}/lib/BinaryFormat/Wasm.cpp
560 ${LLVM_DIR}/lib/Bitcode/Reader/BitcodeReader.cpp
561 ${LLVM_DIR}/lib/Bitcode/Reader/BitstreamReader.cpp
562 ${LLVM_DIR}/lib/Bitcode/Reader/MetadataLoader.cpp
563 ${LLVM_DIR}/lib/Bitcode/Reader/ValueList.cpp
564 ${LLVM_DIR}/lib/CodeGen/AggressiveAntiDepBreaker.cpp
565 ${LLVM_DIR}/lib/CodeGen/AllocationOrder.cpp
566 ${LLVM_DIR}/lib/CodeGen/Analysis.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400567 ${LLVM_DIR}/lib/CodeGen/AsmPrinter/AccelTable.cpp
568 ${LLVM_DIR}/lib/CodeGen/AsmPrinter/AddressPool.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +0100569 ${LLVM_DIR}/lib/CodeGen/AsmPrinter/ARMException.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400570 ${LLVM_DIR}/lib/CodeGen/AsmPrinter/AsmPrinter.cpp
571 ${LLVM_DIR}/lib/CodeGen/AsmPrinter/AsmPrinterDwarf.cpp
572 ${LLVM_DIR}/lib/CodeGen/AsmPrinter/AsmPrinterInlineAsm.cpp
573 ${LLVM_DIR}/lib/CodeGen/AsmPrinter/CodeViewDebug.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400574 ${LLVM_DIR}/lib/CodeGen/AsmPrinter/DbgValueHistoryCalculator.cpp
575 ${LLVM_DIR}/lib/CodeGen/AsmPrinter/DebugHandlerBase.cpp
576 ${LLVM_DIR}/lib/CodeGen/AsmPrinter/DebugLocStream.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +0100577 ${LLVM_DIR}/lib/CodeGen/AsmPrinter/DIE.cpp
578 ${LLVM_DIR}/lib/CodeGen/AsmPrinter/DIEHash.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400579 ${LLVM_DIR}/lib/CodeGen/AsmPrinter/DwarfCFIException.cpp
580 ${LLVM_DIR}/lib/CodeGen/AsmPrinter/DwarfCompileUnit.cpp
581 ${LLVM_DIR}/lib/CodeGen/AsmPrinter/DwarfDebug.cpp
582 ${LLVM_DIR}/lib/CodeGen/AsmPrinter/DwarfExpression.cpp
583 ${LLVM_DIR}/lib/CodeGen/AsmPrinter/DwarfFile.cpp
584 ${LLVM_DIR}/lib/CodeGen/AsmPrinter/DwarfStringPool.cpp
585 ${LLVM_DIR}/lib/CodeGen/AsmPrinter/DwarfUnit.cpp
586 ${LLVM_DIR}/lib/CodeGen/AsmPrinter/EHStreamer.cpp
587 ${LLVM_DIR}/lib/CodeGen/AsmPrinter/WinCFGuard.cpp
588 ${LLVM_DIR}/lib/CodeGen/AsmPrinter/WinException.cpp
589 ${LLVM_DIR}/lib/CodeGen/AtomicExpandPass.cpp
590 ${LLVM_DIR}/lib/CodeGen/BasicTargetTransformInfo.cpp
591 ${LLVM_DIR}/lib/CodeGen/BranchFolding.cpp
592 ${LLVM_DIR}/lib/CodeGen/BranchRelaxation.cpp
593 ${LLVM_DIR}/lib/CodeGen/BreakFalseDeps.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400594 ${LLVM_DIR}/lib/CodeGen/CalcSpillWeights.cpp
595 ${LLVM_DIR}/lib/CodeGen/CallingConvLower.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +0100596 ${LLVM_DIR}/lib/CodeGen/CFIInstrInserter.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400597 ${LLVM_DIR}/lib/CodeGen/CodeGen.cpp
598 ${LLVM_DIR}/lib/CodeGen/CodeGenPrepare.cpp
599 ${LLVM_DIR}/lib/CodeGen/CriticalAntiDepBreaker.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400600 ${LLVM_DIR}/lib/CodeGen/DeadMachineInstructionElim.cpp
601 ${LLVM_DIR}/lib/CodeGen/DetectDeadLanes.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +0100602 ${LLVM_DIR}/lib/CodeGen/DFAPacketizer.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400603 ${LLVM_DIR}/lib/CodeGen/DwarfEHPrepare.cpp
604 ${LLVM_DIR}/lib/CodeGen/EarlyIfConversion.cpp
605 ${LLVM_DIR}/lib/CodeGen/EdgeBundles.cpp
606 ${LLVM_DIR}/lib/CodeGen/ExecutionDomainFix.cpp
607 ${LLVM_DIR}/lib/CodeGen/ExpandISelPseudos.cpp
608 ${LLVM_DIR}/lib/CodeGen/ExpandMemCmp.cpp
609 ${LLVM_DIR}/lib/CodeGen/ExpandPostRAPseudos.cpp
610 ${LLVM_DIR}/lib/CodeGen/ExpandReductions.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400611 ${LLVM_DIR}/lib/CodeGen/FaultMaps.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +0100612 ${LLVM_DIR}/lib/CodeGen/FEntryInserter.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400613 ${LLVM_DIR}/lib/CodeGen/FuncletLayout.cpp
614 ${LLVM_DIR}/lib/CodeGen/GCMetadata.cpp
615 ${LLVM_DIR}/lib/CodeGen/GCMetadataPrinter.cpp
616 ${LLVM_DIR}/lib/CodeGen/GCRootLowering.cpp
617 ${LLVM_DIR}/lib/CodeGen/GCStrategy.cpp
618 ${LLVM_DIR}/lib/CodeGen/GlobalISel/CallLowering.cpp
619 ${LLVM_DIR}/lib/CodeGen/GlobalISel/GlobalISel.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400620 ${LLVM_DIR}/lib/CodeGen/GlobalISel/InstructionSelect.cpp
621 ${LLVM_DIR}/lib/CodeGen/GlobalISel/InstructionSelector.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +0100622 ${LLVM_DIR}/lib/CodeGen/GlobalISel/IRTranslator.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400623 ${LLVM_DIR}/lib/CodeGen/GlobalISel/LegalityPredicates.cpp
624 ${LLVM_DIR}/lib/CodeGen/GlobalISel/LegalizeMutations.cpp
625 ${LLVM_DIR}/lib/CodeGen/GlobalISel/Legalizer.cpp
626 ${LLVM_DIR}/lib/CodeGen/GlobalISel/LegalizerHelper.cpp
627 ${LLVM_DIR}/lib/CodeGen/GlobalISel/LegalizerInfo.cpp
628 ${LLVM_DIR}/lib/CodeGen/GlobalISel/Localizer.cpp
629 ${LLVM_DIR}/lib/CodeGen/GlobalISel/MachineIRBuilder.cpp
630 ${LLVM_DIR}/lib/CodeGen/GlobalISel/RegBankSelect.cpp
631 ${LLVM_DIR}/lib/CodeGen/GlobalISel/RegisterBank.cpp
632 ${LLVM_DIR}/lib/CodeGen/GlobalISel/RegisterBankInfo.cpp
633 ${LLVM_DIR}/lib/CodeGen/GlobalISel/Utils.cpp
634 ${LLVM_DIR}/lib/CodeGen/IfConversion.cpp
635 ${LLVM_DIR}/lib/CodeGen/ImplicitNullChecks.cpp
636 ${LLVM_DIR}/lib/CodeGen/IndirectBrExpandPass.cpp
637 ${LLVM_DIR}/lib/CodeGen/InlineSpiller.cpp
638 ${LLVM_DIR}/lib/CodeGen/InterferenceCache.cpp
639 ${LLVM_DIR}/lib/CodeGen/InterleavedAccessPass.cpp
640 ${LLVM_DIR}/lib/CodeGen/IntrinsicLowering.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400641 ${LLVM_DIR}/lib/CodeGen/LatencyPriorityQueue.cpp
642 ${LLVM_DIR}/lib/CodeGen/LazyMachineBlockFrequencyInfo.cpp
643 ${LLVM_DIR}/lib/CodeGen/LexicalScopes.cpp
644 ${LLVM_DIR}/lib/CodeGen/LiveDebugValues.cpp
645 ${LLVM_DIR}/lib/CodeGen/LiveDebugVariables.cpp
646 ${LLVM_DIR}/lib/CodeGen/LiveInterval.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400647 ${LLVM_DIR}/lib/CodeGen/LiveIntervals.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +0100648 ${LLVM_DIR}/lib/CodeGen/LiveIntervalUnion.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400649 ${LLVM_DIR}/lib/CodeGen/LivePhysRegs.cpp
650 ${LLVM_DIR}/lib/CodeGen/LiveRangeCalc.cpp
651 ${LLVM_DIR}/lib/CodeGen/LiveRangeEdit.cpp
652 ${LLVM_DIR}/lib/CodeGen/LiveRangeShrink.cpp
653 ${LLVM_DIR}/lib/CodeGen/LiveRegMatrix.cpp
654 ${LLVM_DIR}/lib/CodeGen/LiveRegUnits.cpp
655 ${LLVM_DIR}/lib/CodeGen/LiveStacks.cpp
656 ${LLVM_DIR}/lib/CodeGen/LiveVariables.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +0100657 ${LLVM_DIR}/lib/CodeGen/LLVMTargetMachine.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400658 ${LLVM_DIR}/lib/CodeGen/LocalStackSlotAllocation.cpp
659 ${LLVM_DIR}/lib/CodeGen/LoopTraversal.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400660 ${LLVM_DIR}/lib/CodeGen/LowerEmuTLS.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +0100661 ${LLVM_DIR}/lib/CodeGen/LowLevelType.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400662 ${LLVM_DIR}/lib/CodeGen/MachineBasicBlock.cpp
663 ${LLVM_DIR}/lib/CodeGen/MachineBlockFrequencyInfo.cpp
664 ${LLVM_DIR}/lib/CodeGen/MachineBlockPlacement.cpp
665 ${LLVM_DIR}/lib/CodeGen/MachineBranchProbabilityInfo.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400666 ${LLVM_DIR}/lib/CodeGen/MachineCombiner.cpp
667 ${LLVM_DIR}/lib/CodeGen/MachineCopyPropagation.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +0100668 ${LLVM_DIR}/lib/CodeGen/MachineCSE.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400669 ${LLVM_DIR}/lib/CodeGen/MachineDominanceFrontier.cpp
670 ${LLVM_DIR}/lib/CodeGen/MachineDominators.cpp
671 ${LLVM_DIR}/lib/CodeGen/MachineFrameInfo.cpp
672 ${LLVM_DIR}/lib/CodeGen/MachineFunction.cpp
673 ${LLVM_DIR}/lib/CodeGen/MachineFunctionPass.cpp
674 ${LLVM_DIR}/lib/CodeGen/MachineFunctionPrinterPass.cpp
675 ${LLVM_DIR}/lib/CodeGen/MachineInstr.cpp
676 ${LLVM_DIR}/lib/CodeGen/MachineInstrBundle.cpp
677 ${LLVM_DIR}/lib/CodeGen/MachineLICM.cpp
678 ${LLVM_DIR}/lib/CodeGen/MachineLoopInfo.cpp
679 ${LLVM_DIR}/lib/CodeGen/MachineModuleInfo.cpp
680 ${LLVM_DIR}/lib/CodeGen/MachineModuleInfoImpls.cpp
681 ${LLVM_DIR}/lib/CodeGen/MachineOperand.cpp
682 ${LLVM_DIR}/lib/CodeGen/MachineOptimizationRemarkEmitter.cpp
683 ${LLVM_DIR}/lib/CodeGen/MachineOutliner.cpp
684 ${LLVM_DIR}/lib/CodeGen/MachinePassRegistry.cpp
685 ${LLVM_DIR}/lib/CodeGen/MachinePipeliner.cpp
686 ${LLVM_DIR}/lib/CodeGen/MachinePostDominators.cpp
687 ${LLVM_DIR}/lib/CodeGen/MachineRegionInfo.cpp
688 ${LLVM_DIR}/lib/CodeGen/MachineRegisterInfo.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400689 ${LLVM_DIR}/lib/CodeGen/MachineScheduler.cpp
690 ${LLVM_DIR}/lib/CodeGen/MachineSink.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +0100691 ${LLVM_DIR}/lib/CodeGen/MachineSSAUpdater.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400692 ${LLVM_DIR}/lib/CodeGen/MachineTraceMetrics.cpp
693 ${LLVM_DIR}/lib/CodeGen/MachineVerifier.cpp
694 ${LLVM_DIR}/lib/CodeGen/MacroFusion.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +0100695 ${LLVM_DIR}/lib/CodeGen/MIRCanonicalizerPass.cpp
696 ${LLVM_DIR}/lib/CodeGen/MIRPrinter.cpp
697 ${LLVM_DIR}/lib/CodeGen/MIRPrintingPass.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400698 ${LLVM_DIR}/lib/CodeGen/OptimizePHIs.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400699 ${LLVM_DIR}/lib/CodeGen/PatchableFunction.cpp
700 ${LLVM_DIR}/lib/CodeGen/PeepholeOptimizer.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +0100701 ${LLVM_DIR}/lib/CodeGen/PHIElimination.cpp
702 ${LLVM_DIR}/lib/CodeGen/PHIEliminationUtils.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400703 ${LLVM_DIR}/lib/CodeGen/PostRAHazardRecognizer.cpp
704 ${LLVM_DIR}/lib/CodeGen/PostRASchedulerList.cpp
705 ${LLVM_DIR}/lib/CodeGen/PreISelIntrinsicLowering.cpp
706 ${LLVM_DIR}/lib/CodeGen/ProcessImplicitDefs.cpp
707 ${LLVM_DIR}/lib/CodeGen/PrologEpilogInserter.cpp
708 ${LLVM_DIR}/lib/CodeGen/PseudoSourceValue.cpp
709 ${LLVM_DIR}/lib/CodeGen/ReachingDefAnalysis.cpp
710 ${LLVM_DIR}/lib/CodeGen/RegAllocBase.cpp
711 ${LLVM_DIR}/lib/CodeGen/RegAllocBasic.cpp
712 ${LLVM_DIR}/lib/CodeGen/RegAllocFast.cpp
713 ${LLVM_DIR}/lib/CodeGen/RegAllocGreedy.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400714 ${LLVM_DIR}/lib/CodeGen/RegisterClassInfo.cpp
715 ${LLVM_DIR}/lib/CodeGen/RegisterCoalescer.cpp
716 ${LLVM_DIR}/lib/CodeGen/RegisterPressure.cpp
717 ${LLVM_DIR}/lib/CodeGen/RegisterScavenging.cpp
718 ${LLVM_DIR}/lib/CodeGen/RegisterUsageInfo.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +0100719 ${LLVM_DIR}/lib/CodeGen/RegUsageInfoCollector.cpp
720 ${LLVM_DIR}/lib/CodeGen/RegUsageInfoPropagate.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400721 ${LLVM_DIR}/lib/CodeGen/RenameIndependentSubregs.cpp
722 ${LLVM_DIR}/lib/CodeGen/ResetMachineFunctionPass.cpp
723 ${LLVM_DIR}/lib/CodeGen/SafeStack.cpp
724 ${LLVM_DIR}/lib/CodeGen/SafeStackColoring.cpp
725 ${LLVM_DIR}/lib/CodeGen/SafeStackLayout.cpp
726 ${LLVM_DIR}/lib/CodeGen/ScalarizeMaskedMemIntrin.cpp
727 ${LLVM_DIR}/lib/CodeGen/ScheduleDAG.cpp
728 ${LLVM_DIR}/lib/CodeGen/ScheduleDAGInstrs.cpp
729 ${LLVM_DIR}/lib/CodeGen/ScheduleDAGPrinter.cpp
730 ${LLVM_DIR}/lib/CodeGen/ScoreboardHazardRecognizer.cpp
731 ${LLVM_DIR}/lib/CodeGen/SelectionDAG/DAGCombiner.cpp
732 ${LLVM_DIR}/lib/CodeGen/SelectionDAG/FastISel.cpp
733 ${LLVM_DIR}/lib/CodeGen/SelectionDAG/FunctionLoweringInfo.cpp
734 ${LLVM_DIR}/lib/CodeGen/SelectionDAG/InstrEmitter.cpp
735 ${LLVM_DIR}/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp
736 ${LLVM_DIR}/lib/CodeGen/SelectionDAG/LegalizeFloatTypes.cpp
737 ${LLVM_DIR}/lib/CodeGen/SelectionDAG/LegalizeIntegerTypes.cpp
738 ${LLVM_DIR}/lib/CodeGen/SelectionDAG/LegalizeTypes.cpp
739 ${LLVM_DIR}/lib/CodeGen/SelectionDAG/LegalizeTypesGeneric.cpp
740 ${LLVM_DIR}/lib/CodeGen/SelectionDAG/LegalizeVectorOps.cpp
741 ${LLVM_DIR}/lib/CodeGen/SelectionDAG/LegalizeVectorTypes.cpp
742 ${LLVM_DIR}/lib/CodeGen/SelectionDAG/ResourcePriorityQueue.cpp
743 ${LLVM_DIR}/lib/CodeGen/SelectionDAG/ScheduleDAGRRList.cpp
744 ${LLVM_DIR}/lib/CodeGen/SelectionDAG/ScheduleDAGSDNodes.cpp
745 ${LLVM_DIR}/lib/CodeGen/SelectionDAG/ScheduleDAGVLIW.cpp
746 ${LLVM_DIR}/lib/CodeGen/SelectionDAG/SelectionDAG.cpp
747 ${LLVM_DIR}/lib/CodeGen/SelectionDAG/SelectionDAGAddressAnalysis.cpp
748 ${LLVM_DIR}/lib/CodeGen/SelectionDAG/SelectionDAGBuilder.cpp
749 ${LLVM_DIR}/lib/CodeGen/SelectionDAG/SelectionDAGDumper.cpp
750 ${LLVM_DIR}/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp
751 ${LLVM_DIR}/lib/CodeGen/SelectionDAG/SelectionDAGPrinter.cpp
752 ${LLVM_DIR}/lib/CodeGen/SelectionDAG/SelectionDAGTargetInfo.cpp
753 ${LLVM_DIR}/lib/CodeGen/SelectionDAG/StatepointLowering.cpp
754 ${LLVM_DIR}/lib/CodeGen/SelectionDAG/TargetLowering.cpp
755 ${LLVM_DIR}/lib/CodeGen/ShadowStackGCLowering.cpp
756 ${LLVM_DIR}/lib/CodeGen/ShrinkWrap.cpp
757 ${LLVM_DIR}/lib/CodeGen/SjLjEHPrepare.cpp
758 ${LLVM_DIR}/lib/CodeGen/SlotIndexes.cpp
759 ${LLVM_DIR}/lib/CodeGen/SpillPlacement.cpp
760 ${LLVM_DIR}/lib/CodeGen/SplitKit.cpp
761 ${LLVM_DIR}/lib/CodeGen/StackColoring.cpp
762 ${LLVM_DIR}/lib/CodeGen/StackMapLivenessAnalysis.cpp
763 ${LLVM_DIR}/lib/CodeGen/StackMaps.cpp
764 ${LLVM_DIR}/lib/CodeGen/StackProtector.cpp
765 ${LLVM_DIR}/lib/CodeGen/StackSlotColoring.cpp
766 ${LLVM_DIR}/lib/CodeGen/TailDuplication.cpp
767 ${LLVM_DIR}/lib/CodeGen/TailDuplicator.cpp
768 ${LLVM_DIR}/lib/CodeGen/TargetFrameLoweringImpl.cpp
769 ${LLVM_DIR}/lib/CodeGen/TargetInstrInfo.cpp
770 ${LLVM_DIR}/lib/CodeGen/TargetLoweringBase.cpp
771 ${LLVM_DIR}/lib/CodeGen/TargetLoweringObjectFileImpl.cpp
772 ${LLVM_DIR}/lib/CodeGen/TargetOptionsImpl.cpp
773 ${LLVM_DIR}/lib/CodeGen/TargetPassConfig.cpp
774 ${LLVM_DIR}/lib/CodeGen/TargetRegisterInfo.cpp
775 ${LLVM_DIR}/lib/CodeGen/TargetSchedule.cpp
776 ${LLVM_DIR}/lib/CodeGen/TargetSubtargetInfo.cpp
777 ${LLVM_DIR}/lib/CodeGen/TwoAddressInstructionPass.cpp
778 ${LLVM_DIR}/lib/CodeGen/UnreachableBlockElim.cpp
779 ${LLVM_DIR}/lib/CodeGen/ValueTypes.cpp
780 ${LLVM_DIR}/lib/CodeGen/VirtRegMap.cpp
781 ${LLVM_DIR}/lib/CodeGen/WasmEHPrepare.cpp
782 ${LLVM_DIR}/lib/CodeGen/WinEHPrepare.cpp
783 ${LLVM_DIR}/lib/CodeGen/XRayInstrumentation.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400784 ${LLVM_DIR}/lib/DebugInfo/CodeView/CodeViewError.cpp
785 ${LLVM_DIR}/lib/DebugInfo/CodeView/CodeViewRecordIO.cpp
786 ${LLVM_DIR}/lib/DebugInfo/CodeView/ContinuationRecordBuilder.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +0100787 ${LLVM_DIR}/lib/DebugInfo/CodeView/CVTypeVisitor.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400788 ${LLVM_DIR}/lib/DebugInfo/CodeView/Formatters.cpp
789 ${LLVM_DIR}/lib/DebugInfo/CodeView/GlobalTypeTableBuilder.cpp
790 ${LLVM_DIR}/lib/DebugInfo/CodeView/Line.cpp
791 ${LLVM_DIR}/lib/DebugInfo/CodeView/RecordName.cpp
792 ${LLVM_DIR}/lib/DebugInfo/CodeView/RecordSerialization.cpp
793 ${LLVM_DIR}/lib/DebugInfo/CodeView/SimpleTypeSerializer.cpp
794 ${LLVM_DIR}/lib/DebugInfo/CodeView/SymbolRecordMapping.cpp
795 ${LLVM_DIR}/lib/DebugInfo/CodeView/TypeDumpVisitor.cpp
796 ${LLVM_DIR}/lib/DebugInfo/CodeView/TypeHashing.cpp
797 ${LLVM_DIR}/lib/DebugInfo/CodeView/TypeIndex.cpp
798 ${LLVM_DIR}/lib/DebugInfo/CodeView/TypeIndexDiscovery.cpp
799 ${LLVM_DIR}/lib/DebugInfo/CodeView/TypeRecordMapping.cpp
800 ${LLVM_DIR}/lib/DebugInfo/CodeView/TypeTableCollection.cpp
801 ${LLVM_DIR}/lib/ExecutionEngine/ExecutionEngine.cpp
802 ${LLVM_DIR}/lib/ExecutionEngine/GDBRegistrationListener.cpp
803 ${LLVM_DIR}/lib/ExecutionEngine/Orc/Core.cpp
804 ${LLVM_DIR}/lib/ExecutionEngine/Orc/Legacy.cpp
805 ${LLVM_DIR}/lib/ExecutionEngine/Orc/OrcError.cpp
806 ${LLVM_DIR}/lib/ExecutionEngine/RuntimeDyld/JITSymbol.cpp
807 ${LLVM_DIR}/lib/ExecutionEngine/RuntimeDyld/RTDyldMemoryManager.cpp
808 ${LLVM_DIR}/lib/ExecutionEngine/RuntimeDyld/RuntimeDyld.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400809 ${LLVM_DIR}/lib/ExecutionEngine/RuntimeDyld/RuntimeDyldChecker.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +0100810 ${LLVM_DIR}/lib/ExecutionEngine/RuntimeDyld/RuntimeDyldCOFF.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400811 ${LLVM_DIR}/lib/ExecutionEngine/RuntimeDyld/RuntimeDyldELF.cpp
812 ${LLVM_DIR}/lib/ExecutionEngine/RuntimeDyld/RuntimeDyldMachO.cpp
813 ${LLVM_DIR}/lib/ExecutionEngine/RuntimeDyld/Targets/RuntimeDyldELFMips.cpp
814 ${LLVM_DIR}/lib/ExecutionEngine/SectionMemoryManager.cpp
815 ${LLVM_DIR}/lib/ExecutionEngine/TargetSelect.cpp
816 ${LLVM_DIR}/lib/IR/AsmWriter.cpp
817 ${LLVM_DIR}/lib/IR/Attributes.cpp
818 ${LLVM_DIR}/lib/IR/AutoUpgrade.cpp
819 ${LLVM_DIR}/lib/IR/BasicBlock.cpp
820 ${LLVM_DIR}/lib/IR/Comdat.cpp
821 ${LLVM_DIR}/lib/IR/ConstantFold.cpp
822 ${LLVM_DIR}/lib/IR/ConstantRange.cpp
823 ${LLVM_DIR}/lib/IR/Constants.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400824 ${LLVM_DIR}/lib/IR/DataLayout.cpp
825 ${LLVM_DIR}/lib/IR/DebugInfo.cpp
826 ${LLVM_DIR}/lib/IR/DebugInfoMetadata.cpp
827 ${LLVM_DIR}/lib/IR/DebugLoc.cpp
828 ${LLVM_DIR}/lib/IR/DiagnosticHandler.cpp
829 ${LLVM_DIR}/lib/IR/DiagnosticInfo.cpp
830 ${LLVM_DIR}/lib/IR/DiagnosticPrinter.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +0100831 ${LLVM_DIR}/lib/IR/DIBuilder.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400832 ${LLVM_DIR}/lib/IR/Dominators.cpp
833 ${LLVM_DIR}/lib/IR/Function.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400834 ${LLVM_DIR}/lib/IR/Globals.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +0100835 ${LLVM_DIR}/lib/IR/GVMaterializer.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400836 ${LLVM_DIR}/lib/IR/InlineAsm.cpp
837 ${LLVM_DIR}/lib/IR/Instruction.cpp
838 ${LLVM_DIR}/lib/IR/Instructions.cpp
839 ${LLVM_DIR}/lib/IR/IntrinsicInst.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +0100840 ${LLVM_DIR}/lib/IR/IRBuilder.cpp
841 ${LLVM_DIR}/lib/IR/IRPrintingPasses.cpp
842 ${LLVM_DIR}/lib/IR/LegacyPassManager.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400843 ${LLVM_DIR}/lib/IR/LLVMContext.cpp
844 ${LLVM_DIR}/lib/IR/LLVMContextImpl.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400845 ${LLVM_DIR}/lib/IR/Mangler.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +0100846 ${LLVM_DIR}/lib/IR/MDBuilder.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400847 ${LLVM_DIR}/lib/IR/Metadata.cpp
848 ${LLVM_DIR}/lib/IR/Module.cpp
849 ${LLVM_DIR}/lib/IR/Operator.cpp
850 ${LLVM_DIR}/lib/IR/OptBisect.cpp
851 ${LLVM_DIR}/lib/IR/Pass.cpp
852 ${LLVM_DIR}/lib/IR/PassManager.cpp
853 ${LLVM_DIR}/lib/IR/PassRegistry.cpp
854 ${LLVM_DIR}/lib/IR/ProfileSummary.cpp
855 ${LLVM_DIR}/lib/IR/Statepoint.cpp
856 ${LLVM_DIR}/lib/IR/Type.cpp
857 ${LLVM_DIR}/lib/IR/TypeFinder.cpp
858 ${LLVM_DIR}/lib/IR/Use.cpp
859 ${LLVM_DIR}/lib/IR/User.cpp
860 ${LLVM_DIR}/lib/IR/Value.cpp
861 ${LLVM_DIR}/lib/IR/ValueSymbolTable.cpp
862 ${LLVM_DIR}/lib/IR/Verifier.cpp
863 ${LLVM_DIR}/lib/MC/ELFObjectWriter.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +0100864 ${LLVM_DIR}/lib/MC/MachObjectWriter.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400865 ${LLVM_DIR}/lib/MC/MCAsmBackend.cpp
866 ${LLVM_DIR}/lib/MC/MCAsmInfo.cpp
867 ${LLVM_DIR}/lib/MC/MCAsmInfoCOFF.cpp
868 ${LLVM_DIR}/lib/MC/MCAsmInfoDarwin.cpp
869 ${LLVM_DIR}/lib/MC/MCAsmInfoELF.cpp
870 ${LLVM_DIR}/lib/MC/MCAsmMacro.cpp
871 ${LLVM_DIR}/lib/MC/MCAsmStreamer.cpp
872 ${LLVM_DIR}/lib/MC/MCAssembler.cpp
873 ${LLVM_DIR}/lib/MC/MCCodeEmitter.cpp
874 ${LLVM_DIR}/lib/MC/MCCodePadder.cpp
875 ${LLVM_DIR}/lib/MC/MCCodeView.cpp
876 ${LLVM_DIR}/lib/MC/MCContext.cpp
877 ${LLVM_DIR}/lib/MC/MCDisassembler/MCRelocationInfo.cpp
878 ${LLVM_DIR}/lib/MC/MCDwarf.cpp
879 ${LLVM_DIR}/lib/MC/MCELFObjectTargetWriter.cpp
880 ${LLVM_DIR}/lib/MC/MCELFStreamer.cpp
881 ${LLVM_DIR}/lib/MC/MCExpr.cpp
882 ${LLVM_DIR}/lib/MC/MCFragment.cpp
883 ${LLVM_DIR}/lib/MC/MCInst.cpp
884 ${LLVM_DIR}/lib/MC/MCInstPrinter.cpp
885 ${LLVM_DIR}/lib/MC/MCInstrAnalysis.cpp
886 ${LLVM_DIR}/lib/MC/MCInstrDesc.cpp
887 ${LLVM_DIR}/lib/MC/MCLinkerOptimizationHint.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400888 ${LLVM_DIR}/lib/MC/MCMachObjectTargetWriter.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +0100889 ${LLVM_DIR}/lib/MC/MCMachOStreamer.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400890 ${LLVM_DIR}/lib/MC/MCNullStreamer.cpp
891 ${LLVM_DIR}/lib/MC/MCObjectFileInfo.cpp
892 ${LLVM_DIR}/lib/MC/MCObjectStreamer.cpp
893 ${LLVM_DIR}/lib/MC/MCObjectWriter.cpp
894 ${LLVM_DIR}/lib/MC/MCParser/AsmLexer.cpp
895 ${LLVM_DIR}/lib/MC/MCParser/AsmParser.cpp
896 ${LLVM_DIR}/lib/MC/MCParser/COFFAsmParser.cpp
897 ${LLVM_DIR}/lib/MC/MCParser/DarwinAsmParser.cpp
898 ${LLVM_DIR}/lib/MC/MCParser/ELFAsmParser.cpp
899 ${LLVM_DIR}/lib/MC/MCParser/MCAsmLexer.cpp
900 ${LLVM_DIR}/lib/MC/MCParser/MCAsmParser.cpp
901 ${LLVM_DIR}/lib/MC/MCParser/MCAsmParserExtension.cpp
902 ${LLVM_DIR}/lib/MC/MCParser/MCTargetAsmParser.cpp
903 ${LLVM_DIR}/lib/MC/MCRegisterInfo.cpp
904 ${LLVM_DIR}/lib/MC/MCSchedule.cpp
905 ${LLVM_DIR}/lib/MC/MCSection.cpp
906 ${LLVM_DIR}/lib/MC/MCSectionCOFF.cpp
907 ${LLVM_DIR}/lib/MC/MCSectionELF.cpp
908 ${LLVM_DIR}/lib/MC/MCSectionMachO.cpp
909 ${LLVM_DIR}/lib/MC/MCSectionWasm.cpp
910 ${LLVM_DIR}/lib/MC/MCStreamer.cpp
911 ${LLVM_DIR}/lib/MC/MCSubtargetInfo.cpp
912 ${LLVM_DIR}/lib/MC/MCSymbol.cpp
913 ${LLVM_DIR}/lib/MC/MCSymbolELF.cpp
914 ${LLVM_DIR}/lib/MC/MCTargetOptions.cpp
915 ${LLVM_DIR}/lib/MC/MCValue.cpp
916 ${LLVM_DIR}/lib/MC/MCWasmStreamer.cpp
917 ${LLVM_DIR}/lib/MC/MCWin64EH.cpp
918 ${LLVM_DIR}/lib/MC/MCWinCOFFStreamer.cpp
919 ${LLVM_DIR}/lib/MC/MCWinEH.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400920 ${LLVM_DIR}/lib/MC/StringTableBuilder.cpp
921 ${LLVM_DIR}/lib/MC/SubtargetFeature.cpp
922 ${LLVM_DIR}/lib/MC/WasmObjectWriter.cpp
923 ${LLVM_DIR}/lib/MC/WinCOFFObjectWriter.cpp
924 ${LLVM_DIR}/lib/Object/Archive.cpp
925 ${LLVM_DIR}/lib/Object/Binary.cpp
926 ${LLVM_DIR}/lib/Object/COFFObjectFile.cpp
927 ${LLVM_DIR}/lib/Object/ELF.cpp
928 ${LLVM_DIR}/lib/Object/ELFObjectFile.cpp
929 ${LLVM_DIR}/lib/Object/Error.cpp
930 ${LLVM_DIR}/lib/Object/IRObjectFile.cpp
931 ${LLVM_DIR}/lib/Object/IRSymtab.cpp
932 ${LLVM_DIR}/lib/Object/MachOObjectFile.cpp
933 ${LLVM_DIR}/lib/Object/MachOUniversal.cpp
934 ${LLVM_DIR}/lib/Object/ModuleSymbolTable.cpp
935 ${LLVM_DIR}/lib/Object/ObjectFile.cpp
936 ${LLVM_DIR}/lib/Object/RecordStreamer.cpp
937 ${LLVM_DIR}/lib/Object/SymbolicFile.cpp
938 ${LLVM_DIR}/lib/Object/WasmObjectFile.cpp
939 ${LLVM_DIR}/lib/Object/WindowsResource.cpp
940 ${LLVM_DIR}/lib/ProfileData/InstrProf.cpp
941 ${LLVM_DIR}/lib/Support/APFloat.cpp
942 ${LLVM_DIR}/lib/Support/APInt.cpp
Nicolas Capens8c7da802019-04-29 11:52:35 -0400943 ${LLVM_DIR}/lib/Support/APSInt.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400944 ${LLVM_DIR}/lib/Support/ARMAttributeParser.cpp
945 ${LLVM_DIR}/lib/Support/ARMBuildAttrs.cpp
Colin Samplesf63a3ab2019-06-13 12:53:09 -0400946 ${LLVM_DIR}/lib/Support/Atomic.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400947 ${LLVM_DIR}/lib/Support/BinaryStreamError.cpp
948 ${LLVM_DIR}/lib/Support/BinaryStreamReader.cpp
949 ${LLVM_DIR}/lib/Support/BinaryStreamRef.cpp
950 ${LLVM_DIR}/lib/Support/BinaryStreamWriter.cpp
951 ${LLVM_DIR}/lib/Support/BlockFrequency.cpp
952 ${LLVM_DIR}/lib/Support/BranchProbability.cpp
953 ${LLVM_DIR}/lib/Support/Chrono.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +0100954 ${LLVM_DIR}/lib/Support/circular_raw_ostream.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400955 ${LLVM_DIR}/lib/Support/CodeGenCoverage.cpp
956 ${LLVM_DIR}/lib/Support/CommandLine.cpp
957 ${LLVM_DIR}/lib/Support/Compression.cpp
958 ${LLVM_DIR}/lib/Support/ConvertUTF.cpp
959 ${LLVM_DIR}/lib/Support/ConvertUTFWrapper.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400960 ${LLVM_DIR}/lib/Support/DataExtractor.cpp
961 ${LLVM_DIR}/lib/Support/Debug.cpp
962 ${LLVM_DIR}/lib/Support/DebugCounter.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +0100963 ${LLVM_DIR}/lib/Support/DJB.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400964 ${LLVM_DIR}/lib/Support/DynamicLibrary.cpp
965 ${LLVM_DIR}/lib/Support/Errno.cpp
966 ${LLVM_DIR}/lib/Support/Error.cpp
967 ${LLVM_DIR}/lib/Support/ErrorHandling.cpp
968 ${LLVM_DIR}/lib/Support/FoldingSet.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400969 ${LLVM_DIR}/lib/Support/FormattedStream.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +0100970 ${LLVM_DIR}/lib/Support/FormatVariadic.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400971 ${LLVM_DIR}/lib/Support/GraphWriter.cpp
972 ${LLVM_DIR}/lib/Support/Hashing.cpp
973 ${LLVM_DIR}/lib/Support/Host.cpp
974 ${LLVM_DIR}/lib/Support/IntEqClasses.cpp
975 ${LLVM_DIR}/lib/Support/IntervalMap.cpp
976 ${LLVM_DIR}/lib/Support/JamCRC.cpp
977 ${LLVM_DIR}/lib/Support/KnownBits.cpp
978 ${LLVM_DIR}/lib/Support/LEB128.cpp
979 ${LLVM_DIR}/lib/Support/LineIterator.cpp
980 ${LLVM_DIR}/lib/Support/Locale.cpp
981 ${LLVM_DIR}/lib/Support/LowLevelType.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400982 ${LLVM_DIR}/lib/Support/ManagedStatic.cpp
983 ${LLVM_DIR}/lib/Support/MathExtras.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +0100984 ${LLVM_DIR}/lib/Support/MD5.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400985 ${LLVM_DIR}/lib/Support/Memory.cpp
986 ${LLVM_DIR}/lib/Support/MemoryBuffer.cpp
987 ${LLVM_DIR}/lib/Support/Mutex.cpp
988 ${LLVM_DIR}/lib/Support/NativeFormatting.cpp
989 ${LLVM_DIR}/lib/Support/Path.cpp
990 ${LLVM_DIR}/lib/Support/PrettyStackTrace.cpp
991 ${LLVM_DIR}/lib/Support/Process.cpp
992 ${LLVM_DIR}/lib/Support/Program.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400993 ${LLVM_DIR}/lib/Support/RandomNumberGenerator.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +0100994 ${LLVM_DIR}/lib/Support/raw_ostream.cpp
995 ${LLVM_DIR}/lib/Support/regcomp.c
996 ${LLVM_DIR}/lib/Support/regerror.c
Nicolas Capens9ac24a92019-04-29 10:45:56 -0400997 ${LLVM_DIR}/lib/Support/Regex.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +0100998 ${LLVM_DIR}/lib/Support/regexec.c
999 ${LLVM_DIR}/lib/Support/regfree.c
1000 ${LLVM_DIR}/lib/Support/regstrlcpy.c
1001 ${LLVM_DIR}/lib/Support/RWMutex.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -04001002 ${LLVM_DIR}/lib/Support/ScaledNumber.cpp
1003 ${LLVM_DIR}/lib/Support/ScopedPrinter.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +01001004 ${LLVM_DIR}/lib/Support/SHA1.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -04001005 ${LLVM_DIR}/lib/Support/Signals.cpp
1006 ${LLVM_DIR}/lib/Support/SmallPtrSet.cpp
1007 ${LLVM_DIR}/lib/Support/SmallVector.cpp
1008 ${LLVM_DIR}/lib/Support/SourceMgr.cpp
1009 ${LLVM_DIR}/lib/Support/Statistic.cpp
1010 ${LLVM_DIR}/lib/Support/StringExtras.cpp
1011 ${LLVM_DIR}/lib/Support/StringMap.cpp
1012 ${LLVM_DIR}/lib/Support/StringRef.cpp
1013 ${LLVM_DIR}/lib/Support/StringSaver.cpp
1014 ${LLVM_DIR}/lib/Support/TargetParser.cpp
1015 ${LLVM_DIR}/lib/Support/TargetRegistry.cpp
1016 ${LLVM_DIR}/lib/Support/Threading.cpp
1017 ${LLVM_DIR}/lib/Support/Timer.cpp
1018 ${LLVM_DIR}/lib/Support/ToolOutputFile.cpp
1019 ${LLVM_DIR}/lib/Support/Triple.cpp
1020 ${LLVM_DIR}/lib/Support/Twine.cpp
1021 ${LLVM_DIR}/lib/Support/Unicode.cpp
1022 ${LLVM_DIR}/lib/Support/UnicodeCaseFold.cpp
1023 ${LLVM_DIR}/lib/Support/Valgrind.cpp
1024 ${LLVM_DIR}/lib/Support/YAMLParser.cpp
1025 ${LLVM_DIR}/lib/Support/YAMLTraits.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -04001026 ${LLVM_DIR}/lib/Target/TargetLoweringObjectFile.cpp
1027 ${LLVM_DIR}/lib/Target/TargetMachine.cpp
Ben Clayton1c82c7b2019-04-30 12:49:27 +01001028 ${LLVM_DIR}/lib/Transforms/Coroutines/CoroCleanup.cpp
1029 ${LLVM_DIR}/lib/Transforms/Coroutines/CoroEarly.cpp
1030 ${LLVM_DIR}/lib/Transforms/Coroutines/CoroElide.cpp
1031 ${LLVM_DIR}/lib/Transforms/Coroutines/CoroFrame.cpp
1032 ${LLVM_DIR}/lib/Transforms/Coroutines/CoroSplit.cpp
1033 ${LLVM_DIR}/lib/Transforms/Coroutines/Coroutines.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -04001034 ${LLVM_DIR}/lib/Transforms/InstCombine/InstCombineAddSub.cpp
1035 ${LLVM_DIR}/lib/Transforms/InstCombine/InstCombineAndOrXor.cpp
1036 ${LLVM_DIR}/lib/Transforms/InstCombine/InstCombineCalls.cpp
1037 ${LLVM_DIR}/lib/Transforms/InstCombine/InstCombineCasts.cpp
1038 ${LLVM_DIR}/lib/Transforms/InstCombine/InstCombineCompares.cpp
1039 ${LLVM_DIR}/lib/Transforms/InstCombine/InstCombineLoadStoreAlloca.cpp
1040 ${LLVM_DIR}/lib/Transforms/InstCombine/InstCombineMulDivRem.cpp
1041 ${LLVM_DIR}/lib/Transforms/InstCombine/InstCombinePHI.cpp
1042 ${LLVM_DIR}/lib/Transforms/InstCombine/InstCombineSelect.cpp
1043 ${LLVM_DIR}/lib/Transforms/InstCombine/InstCombineShifts.cpp
1044 ${LLVM_DIR}/lib/Transforms/InstCombine/InstCombineSimplifyDemanded.cpp
1045 ${LLVM_DIR}/lib/Transforms/InstCombine/InstCombineVectorOps.cpp
1046 ${LLVM_DIR}/lib/Transforms/InstCombine/InstructionCombining.cpp
Ben Clayton1c82c7b2019-04-30 12:49:27 +01001047 ${LLVM_DIR}/lib/Transforms/IPO/BarrierNoopPass.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -04001048 ${LLVM_DIR}/lib/Transforms/Scalar/ADCE.cpp
1049 ${LLVM_DIR}/lib/Transforms/Scalar/ConstantHoisting.cpp
1050 ${LLVM_DIR}/lib/Transforms/Scalar/DeadStoreElimination.cpp
Ben Clayton1c82c7b2019-04-30 12:49:27 +01001051 ${LLVM_DIR}/lib/Transforms/Scalar/EarlyCSE.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -04001052 ${LLVM_DIR}/lib/Transforms/Scalar/GVN.cpp
1053 ${LLVM_DIR}/lib/Transforms/Scalar/LICM.cpp
Colin Samplesf63a3ab2019-06-13 12:53:09 -04001054 ${LLVM_DIR}/lib/Transforms/Scalar/LoopDataPrefetch.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -04001055 ${LLVM_DIR}/lib/Transforms/Scalar/LoopStrengthReduce.cpp
1056 ${LLVM_DIR}/lib/Transforms/Scalar/MergeICmps.cpp
1057 ${LLVM_DIR}/lib/Transforms/Scalar/PartiallyInlineLibCalls.cpp
1058 ${LLVM_DIR}/lib/Transforms/Scalar/Reassociate.cpp
1059 ${LLVM_DIR}/lib/Transforms/Scalar/SCCP.cpp
Colin Samplesf63a3ab2019-06-13 12:53:09 -04001060 ${LLVM_DIR}/lib/Transforms/Scalar/SeparateConstOffsetFromGEP.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -04001061 ${LLVM_DIR}/lib/Transforms/Scalar/SimplifyCFGPass.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +01001062 ${LLVM_DIR}/lib/Transforms/Scalar/SROA.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -04001063 ${LLVM_DIR}/lib/Transforms/Utils/BasicBlockUtils.cpp
1064 ${LLVM_DIR}/lib/Transforms/Utils/BreakCriticalEdges.cpp
1065 ${LLVM_DIR}/lib/Transforms/Utils/BuildLibCalls.cpp
1066 ${LLVM_DIR}/lib/Transforms/Utils/BypassSlowDivision.cpp
1067 ${LLVM_DIR}/lib/Transforms/Utils/CloneFunction.cpp
1068 ${LLVM_DIR}/lib/Transforms/Utils/DemoteRegToStack.cpp
1069 ${LLVM_DIR}/lib/Transforms/Utils/EntryExitInstrumenter.cpp
1070 ${LLVM_DIR}/lib/Transforms/Utils/EscapeEnumerator.cpp
1071 ${LLVM_DIR}/lib/Transforms/Utils/InlineFunction.cpp
1072 ${LLVM_DIR}/lib/Transforms/Utils/LCSSA.cpp
1073 ${LLVM_DIR}/lib/Transforms/Utils/Local.cpp
1074 ${LLVM_DIR}/lib/Transforms/Utils/LoopSimplify.cpp
1075 ${LLVM_DIR}/lib/Transforms/Utils/LoopUtils.cpp
1076 ${LLVM_DIR}/lib/Transforms/Utils/LowerInvoke.cpp
1077 ${LLVM_DIR}/lib/Transforms/Utils/OrderedInstructions.cpp
1078 ${LLVM_DIR}/lib/Transforms/Utils/PromoteMemoryToRegister.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -04001079 ${LLVM_DIR}/lib/Transforms/Utils/SimplifyCFG.cpp
1080 ${LLVM_DIR}/lib/Transforms/Utils/SimplifyLibCalls.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +01001081 ${LLVM_DIR}/lib/Transforms/Utils/SSAUpdater.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -04001082 ${LLVM_DIR}/lib/Transforms/Utils/SymbolRewriter.cpp
Nicolas Capens9ac24a92019-04-29 10:45:56 -04001083 ${LLVM_DIR}/lib/Transforms/Utils/ValueMapper.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +01001084 ${LLVM_DIR}/lib/Transforms/Utils/VNCoercion.cpp
Ben Clayton1c82c7b2019-04-30 12:49:27 +01001085 ${LLVM_DIR}/../stubs/Stubs.cpp
Logan Chien0eedc8c2018-08-21 09:34:28 +08001086)
1087
Nicolas Capens7d0b8a32018-10-30 16:36:52 -04001088if(ARCH STREQUAL "x86" OR ARCH STREQUAL "x86_64")
1089 list(APPEND LLVM_LIST
1090 ${LLVM_DIR}/lib/Target/X86/AsmParser/X86AsmInstrumentation.cpp
1091 ${LLVM_DIR}/lib/Target/X86/AsmParser/X86AsmParser.cpp
1092 ${LLVM_DIR}/lib/Target/X86/InstPrinter/X86ATTInstPrinter.cpp
1093 ${LLVM_DIR}/lib/Target/X86/InstPrinter/X86InstComments.cpp
1094 ${LLVM_DIR}/lib/Target/X86/InstPrinter/X86InstPrinterCommon.cpp
1095 ${LLVM_DIR}/lib/Target/X86/InstPrinter/X86IntelInstPrinter.cpp
1096 ${LLVM_DIR}/lib/Target/X86/MCTargetDesc/X86AsmBackend.cpp
1097 ${LLVM_DIR}/lib/Target/X86/MCTargetDesc/X86ELFObjectWriter.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +01001098 ${LLVM_DIR}/lib/Target/X86/MCTargetDesc/X86MachObjectWriter.cpp
Nicolas Capens7d0b8a32018-10-30 16:36:52 -04001099 ${LLVM_DIR}/lib/Target/X86/MCTargetDesc/X86MCAsmInfo.cpp
1100 ${LLVM_DIR}/lib/Target/X86/MCTargetDesc/X86MCCodeEmitter.cpp
1101 ${LLVM_DIR}/lib/Target/X86/MCTargetDesc/X86MCTargetDesc.cpp
Nicolas Capens7d0b8a32018-10-30 16:36:52 -04001102 ${LLVM_DIR}/lib/Target/X86/MCTargetDesc/X86WinCOFFObjectWriter.cpp
1103 ${LLVM_DIR}/lib/Target/X86/MCTargetDesc/X86WinCOFFStreamer.cpp
1104 ${LLVM_DIR}/lib/Target/X86/MCTargetDesc/X86WinCOFFTargetStreamer.cpp
1105 ${LLVM_DIR}/lib/Target/X86/ShadowCallStack.cpp
1106 ${LLVM_DIR}/lib/Target/X86/TargetInfo/X86TargetInfo.cpp
1107 ${LLVM_DIR}/lib/Target/X86/Utils/X86ShuffleDecode.cpp
1108 ${LLVM_DIR}/lib/Target/X86/X86AsmPrinter.cpp
1109 ${LLVM_DIR}/lib/Target/X86/X86AvoidStoreForwardingBlocks.cpp
1110 ${LLVM_DIR}/lib/Target/X86/X86CallFrameOptimization.cpp
Nicolas Capens7d0b8a32018-10-30 16:36:52 -04001111 ${LLVM_DIR}/lib/Target/X86/X86CallingConv.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +01001112 ${LLVM_DIR}/lib/Target/X86/X86CallLowering.cpp
Nicolas Capens7d0b8a32018-10-30 16:36:52 -04001113 ${LLVM_DIR}/lib/Target/X86/X86CmovConversion.cpp
1114 ${LLVM_DIR}/lib/Target/X86/X86DomainReassignment.cpp
1115 ${LLVM_DIR}/lib/Target/X86/X86EvexToVex.cpp
1116 ${LLVM_DIR}/lib/Target/X86/X86ExpandPseudo.cpp
1117 ${LLVM_DIR}/lib/Target/X86/X86FastISel.cpp
1118 ${LLVM_DIR}/lib/Target/X86/X86FixupBWInsts.cpp
1119 ${LLVM_DIR}/lib/Target/X86/X86FixupLEAs.cpp
1120 ${LLVM_DIR}/lib/Target/X86/X86FixupSetCC.cpp
1121 ${LLVM_DIR}/lib/Target/X86/X86FlagsCopyLowering.cpp
1122 ${LLVM_DIR}/lib/Target/X86/X86FloatingPoint.cpp
1123 ${LLVM_DIR}/lib/Target/X86/X86FrameLowering.cpp
Nicolas Capens7d0b8a32018-10-30 16:36:52 -04001124 ${LLVM_DIR}/lib/Target/X86/X86IndirectBranchTracking.cpp
1125 ${LLVM_DIR}/lib/Target/X86/X86InstrFMA3Info.cpp
1126 ${LLVM_DIR}/lib/Target/X86/X86InstrFoldTables.cpp
1127 ${LLVM_DIR}/lib/Target/X86/X86InstrInfo.cpp
1128 ${LLVM_DIR}/lib/Target/X86/X86InstructionSelector.cpp
1129 ${LLVM_DIR}/lib/Target/X86/X86InterleavedAccess.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +01001130 ${LLVM_DIR}/lib/Target/X86/X86ISelDAGToDAG.cpp
1131 ${LLVM_DIR}/lib/Target/X86/X86ISelLowering.cpp
Nicolas Capens7d0b8a32018-10-30 16:36:52 -04001132 ${LLVM_DIR}/lib/Target/X86/X86LegalizerInfo.cpp
Nicolas Capens7d0b8a32018-10-30 16:36:52 -04001133 ${LLVM_DIR}/lib/Target/X86/X86MachineFunctionInfo.cpp
1134 ${LLVM_DIR}/lib/Target/X86/X86MacroFusion.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +01001135 ${LLVM_DIR}/lib/Target/X86/X86MCInstLower.cpp
Nicolas Capens7d0b8a32018-10-30 16:36:52 -04001136 ${LLVM_DIR}/lib/Target/X86/X86OptimizeLEAs.cpp
1137 ${LLVM_DIR}/lib/Target/X86/X86PadShortFunction.cpp
1138 ${LLVM_DIR}/lib/Target/X86/X86RegisterBankInfo.cpp
1139 ${LLVM_DIR}/lib/Target/X86/X86RegisterInfo.cpp
1140 ${LLVM_DIR}/lib/Target/X86/X86RetpolineThunks.cpp
1141 ${LLVM_DIR}/lib/Target/X86/X86SelectionDAGInfo.cpp
1142 ${LLVM_DIR}/lib/Target/X86/X86ShuffleDecodeConstantPool.cpp
1143 ${LLVM_DIR}/lib/Target/X86/X86SpeculativeLoadHardening.cpp
1144 ${LLVM_DIR}/lib/Target/X86/X86Subtarget.cpp
1145 ${LLVM_DIR}/lib/Target/X86/X86TargetMachine.cpp
1146 ${LLVM_DIR}/lib/Target/X86/X86TargetObjectFile.cpp
1147 ${LLVM_DIR}/lib/Target/X86/X86TargetTransformInfo.cpp
1148 ${LLVM_DIR}/lib/Target/X86/X86VZeroUpper.cpp
1149 ${LLVM_DIR}/lib/Target/X86/X86WinAllocaExpander.cpp
1150 ${LLVM_DIR}/lib/Target/X86/X86WinEHState.cpp
1151 )
1152elseif(ARCH STREQUAL "mipsel" OR ARCH STREQUAL "mips64el")
1153 list(APPEND LLVM_LIST
1154 ${LLVM_DIR}/lib/Target/Mips/AsmParser/MipsAsmParser.cpp
1155 ${LLVM_DIR}/lib/Target/Mips/InstPrinter/MipsInstPrinter.cpp
1156 ${LLVM_DIR}/lib/Target/Mips/MCTargetDesc/MipsABIFlagsSection.cpp
1157 ${LLVM_DIR}/lib/Target/Mips/MCTargetDesc/MipsABIInfo.cpp
1158 ${LLVM_DIR}/lib/Target/Mips/MCTargetDesc/MipsAsmBackend.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +01001159 ${LLVM_DIR}/lib/Target/Mips/MCTargetDesc/MipsELFObjectWriter.cpp
Nicolas Capens7d0b8a32018-10-30 16:36:52 -04001160 ${LLVM_DIR}/lib/Target/Mips/MCTargetDesc/MipsELFStreamer.cpp
1161 ${LLVM_DIR}/lib/Target/Mips/MCTargetDesc/MipsMCAsmInfo.cpp
1162 ${LLVM_DIR}/lib/Target/Mips/MCTargetDesc/MipsMCCodeEmitter.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +01001163 ${LLVM_DIR}/lib/Target/Mips/MCTargetDesc/MipsMCExpr.cpp
Nicolas Capens7d0b8a32018-10-30 16:36:52 -04001164 ${LLVM_DIR}/lib/Target/Mips/MCTargetDesc/MipsMCTargetDesc.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +01001165 ${LLVM_DIR}/lib/Target/Mips/MCTargetDesc/MipsNaClELFStreamer.cpp
Nicolas Capens7d0b8a32018-10-30 16:36:52 -04001166 ${LLVM_DIR}/lib/Target/Mips/MCTargetDesc/MipsOptionRecord.cpp
1167 ${LLVM_DIR}/lib/Target/Mips/MCTargetDesc/MipsTargetStreamer.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +01001168 ${LLVM_DIR}/lib/Target/Mips/MicroMipsSizeReduction.cpp
Nicolas Capens7d0b8a32018-10-30 16:36:52 -04001169 ${LLVM_DIR}/lib/Target/Mips/Mips16FrameLowering.cpp
1170 ${LLVM_DIR}/lib/Target/Mips/Mips16HardFloat.cpp
1171 ${LLVM_DIR}/lib/Target/Mips/Mips16HardFloatInfo.cpp
1172 ${LLVM_DIR}/lib/Target/Mips/Mips16InstrInfo.cpp
1173 ${LLVM_DIR}/lib/Target/Mips/Mips16ISelDAGToDAG.cpp
1174 ${LLVM_DIR}/lib/Target/Mips/Mips16ISelLowering.cpp
1175 ${LLVM_DIR}/lib/Target/Mips/Mips16RegisterInfo.cpp
1176 ${LLVM_DIR}/lib/Target/Mips/MipsAnalyzeImmediate.cpp
1177 ${LLVM_DIR}/lib/Target/Mips/MipsAsmPrinter.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +01001178 ${LLVM_DIR}/lib/Target/Mips/MipsBranchExpansion.cpp
Nicolas Capens7d0b8a32018-10-30 16:36:52 -04001179 ${LLVM_DIR}/lib/Target/Mips/MipsCallLowering.cpp
1180 ${LLVM_DIR}/lib/Target/Mips/MipsCCState.cpp
1181 ${LLVM_DIR}/lib/Target/Mips/MipsConstantIslandPass.cpp
1182 ${LLVM_DIR}/lib/Target/Mips/MipsDelaySlotFiller.cpp
1183 ${LLVM_DIR}/lib/Target/Mips/MipsExpandPseudo.cpp
1184 ${LLVM_DIR}/lib/Target/Mips/MipsFastISel.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +01001185 ${LLVM_DIR}/lib/Target/Mips/MipsFrameLowering.cpp
Nicolas Capens7d0b8a32018-10-30 16:36:52 -04001186 ${LLVM_DIR}/lib/Target/Mips/MipsInstrInfo.cpp
1187 ${LLVM_DIR}/lib/Target/Mips/MipsInstructionSelector.cpp
1188 ${LLVM_DIR}/lib/Target/Mips/MipsISelDAGToDAG.cpp
1189 ${LLVM_DIR}/lib/Target/Mips/MipsISelLowering.cpp
Nicolas Capens7d0b8a32018-10-30 16:36:52 -04001190 ${LLVM_DIR}/lib/Target/Mips/MipsLegalizerInfo.cpp
Nicolas Capens7d0b8a32018-10-30 16:36:52 -04001191 ${LLVM_DIR}/lib/Target/Mips/MipsMachineFunction.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +01001192 ${LLVM_DIR}/lib/Target/Mips/MipsMCInstLower.cpp
Nicolas Capens7d0b8a32018-10-30 16:36:52 -04001193 ${LLVM_DIR}/lib/Target/Mips/MipsModuleISelDAGToDAG.cpp
1194 ${LLVM_DIR}/lib/Target/Mips/MipsOptimizePICCall.cpp
1195 ${LLVM_DIR}/lib/Target/Mips/MipsOs16.cpp
1196 ${LLVM_DIR}/lib/Target/Mips/MipsRegisterBankInfo.cpp
1197 ${LLVM_DIR}/lib/Target/Mips/MipsRegisterInfo.cpp
1198 ${LLVM_DIR}/lib/Target/Mips/MipsSEFrameLowering.cpp
1199 ${LLVM_DIR}/lib/Target/Mips/MipsSEInstrInfo.cpp
1200 ${LLVM_DIR}/lib/Target/Mips/MipsSEISelDAGToDAG.cpp
1201 ${LLVM_DIR}/lib/Target/Mips/MipsSEISelLowering.cpp
1202 ${LLVM_DIR}/lib/Target/Mips/MipsSERegisterInfo.cpp
1203 ${LLVM_DIR}/lib/Target/Mips/MipsSubtarget.cpp
1204 ${LLVM_DIR}/lib/Target/Mips/MipsTargetMachine.cpp
1205 ${LLVM_DIR}/lib/Target/Mips/MipsTargetObjectFile.cpp
Nicolas Capens7d0b8a32018-10-30 16:36:52 -04001206 ${LLVM_DIR}/lib/Target/Mips/TargetInfo/MipsTargetInfo.cpp
1207 )
1208elseif(ARCH STREQUAL "aarch64")
1209 list(APPEND LLVM_LIST
Ben Clayton77d42cd2019-06-11 16:19:16 +01001210 ${LLVM_DIR}/lib/CodeGen/GlobalMerge.cpp
1211 ${LLVM_DIR}/lib/CodeGen/RegAllocPBQP.cpp
1212 ${LLVM_DIR}/lib/MC/ConstantPools.cpp
Nicolas Capens7d0b8a32018-10-30 16:36:52 -04001213 ${LLVM_DIR}/lib/Target/AArch64/AArch64A53Fix835769.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +01001214 ${LLVM_DIR}/lib/Target/AArch64/AArch64A57FPLoadBalancing.cpp
1215 ${LLVM_DIR}/lib/Target/AArch64/AArch64AdvSIMDScalarPass.cpp
1216 ${LLVM_DIR}/lib/Target/AArch64/AArch64AsmPrinter.cpp
Nicolas Capens7d0b8a32018-10-30 16:36:52 -04001217 ${LLVM_DIR}/lib/Target/AArch64/AArch64CallLowering.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +01001218 ${LLVM_DIR}/lib/Target/AArch64/AArch64CleanupLocalDynamicTLSPass.cpp
1219 ${LLVM_DIR}/lib/Target/AArch64/AArch64CollectLOH.cpp
1220 ${LLVM_DIR}/lib/Target/AArch64/AArch64CondBrTuning.cpp
1221 ${LLVM_DIR}/lib/Target/AArch64/AArch64ConditionalCompares.cpp
Nicolas Capens7d0b8a32018-10-30 16:36:52 -04001222 ${LLVM_DIR}/lib/Target/AArch64/AArch64ConditionOptimizer.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +01001223 ${LLVM_DIR}/lib/Target/AArch64/AArch64DeadRegisterDefinitionsPass.cpp
1224 ${LLVM_DIR}/lib/Target/AArch64/AArch64ExpandPseudoInsts.cpp
1225 ${LLVM_DIR}/lib/Target/AArch64/AArch64FalkorHWPFFix.cpp
1226 ${LLVM_DIR}/lib/Target/AArch64/AArch64FastISel.cpp
1227 ${LLVM_DIR}/lib/Target/AArch64/AArch64FrameLowering.cpp
1228 ${LLVM_DIR}/lib/Target/AArch64/AArch64InstrInfo.cpp
1229 ${LLVM_DIR}/lib/Target/AArch64/AArch64InstructionSelector.cpp
1230 ${LLVM_DIR}/lib/Target/AArch64/AArch64ISelDAGToDAG.cpp
1231 ${LLVM_DIR}/lib/Target/AArch64/AArch64ISelLowering.cpp
1232 ${LLVM_DIR}/lib/Target/AArch64/AArch64LegalizerInfo.cpp
1233 ${LLVM_DIR}/lib/Target/AArch64/AArch64LoadStoreOptimizer.cpp
1234 ${LLVM_DIR}/lib/Target/AArch64/AArch64MacroFusion.cpp
1235 ${LLVM_DIR}/lib/Target/AArch64/AArch64MCInstLower.cpp
1236 ${LLVM_DIR}/lib/Target/AArch64/AArch64PBQPRegAlloc.cpp
1237 ${LLVM_DIR}/lib/Target/AArch64/AArch64PromoteConstant.cpp
1238 ${LLVM_DIR}/lib/Target/AArch64/AArch64RedundantCopyElimination.cpp
1239 ${LLVM_DIR}/lib/Target/AArch64/AArch64RegisterBankInfo.cpp
1240 ${LLVM_DIR}/lib/Target/AArch64/AArch64RegisterInfo.cpp
1241 ${LLVM_DIR}/lib/Target/AArch64/AArch64SelectionDAGInfo.cpp
1242 ${LLVM_DIR}/lib/Target/AArch64/AArch64SIMDInstrOpt.cpp
1243 ${LLVM_DIR}/lib/Target/AArch64/AArch64StorePairSuppress.cpp
1244 ${LLVM_DIR}/lib/Target/AArch64/AArch64Subtarget.cpp
1245 ${LLVM_DIR}/lib/Target/AArch64/AArch64TargetMachine.cpp
1246 ${LLVM_DIR}/lib/Target/AArch64/AArch64TargetObjectFile.cpp
1247 ${LLVM_DIR}/lib/Target/AArch64/AArch64TargetTransformInfo.cpp
1248 ${LLVM_DIR}/lib/Target/AArch64/AsmParser/AArch64AsmParser.cpp
Nicolas Capens7d0b8a32018-10-30 16:36:52 -04001249 ${LLVM_DIR}/lib/Target/AArch64/Disassembler/AArch64Disassembler.cpp
1250 ${LLVM_DIR}/lib/Target/AArch64/Disassembler/AArch64ExternalSymbolizer.cpp
Nicolas Capens7d0b8a32018-10-30 16:36:52 -04001251 ${LLVM_DIR}/lib/Target/AArch64/InstPrinter/AArch64InstPrinter.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +01001252 ${LLVM_DIR}/lib/Target/AArch64/MCTargetDesc/AArch64AsmBackend.cpp
1253 ${LLVM_DIR}/lib/Target/AArch64/MCTargetDesc/AArch64ELFObjectWriter.cpp
1254 ${LLVM_DIR}/lib/Target/AArch64/MCTargetDesc/AArch64ELFStreamer.cpp
1255 ${LLVM_DIR}/lib/Target/AArch64/MCTargetDesc/AArch64MachObjectWriter.cpp
1256 ${LLVM_DIR}/lib/Target/AArch64/MCTargetDesc/AArch64MCAsmInfo.cpp
1257 ${LLVM_DIR}/lib/Target/AArch64/MCTargetDesc/AArch64MCCodeEmitter.cpp
1258 ${LLVM_DIR}/lib/Target/AArch64/MCTargetDesc/AArch64MCExpr.cpp
1259 ${LLVM_DIR}/lib/Target/AArch64/MCTargetDesc/AArch64MCTargetDesc.cpp
1260 ${LLVM_DIR}/lib/Target/AArch64/MCTargetDesc/AArch64TargetStreamer.cpp
1261 ${LLVM_DIR}/lib/Target/AArch64/MCTargetDesc/AArch64WinCOFFObjectWriter.cpp
1262 ${LLVM_DIR}/lib/Target/AArch64/MCTargetDesc/AArch64WinCOFFStreamer.cpp
1263 ${LLVM_DIR}/lib/Target/AArch64/TargetInfo/AArch64TargetInfo.cpp
1264 ${LLVM_DIR}/lib/Target/AArch64/Utils/AArch64BaseInfo.cpp
Ben Clayton77d42cd2019-06-11 16:19:16 +01001265 ${LLVM_DIR}/lib/Transforms/Scalar/LoopDataPrefetch.cpp
1266 ${LLVM_DIR}/lib/Transforms/Scalar/SeparateConstOffsetFromGEP.cpp
Nicolas Capens7d0b8a32018-10-30 16:36:52 -04001267 )
1268elseif(ARCH STREQUAL "arm")
1269 list(APPEND LLVM_LIST
Ben Claytonc8740e02019-06-11 16:16:48 +01001270 ${LLVM_DIR}/lib/Target/ARM/A15SDOptimizer.cpp
1271 ${LLVM_DIR}/lib/Target/ARM/ARMAsmPrinter.cpp
1272 ${LLVM_DIR}/lib/Target/ARM/ARMBaseInstrInfo.cpp
Nicolas Capens7d0b8a32018-10-30 16:36:52 -04001273 ${LLVM_DIR}/lib/Target/ARM/ARMBaseRegisterInfo.cpp
1274 ${LLVM_DIR}/lib/Target/ARM/ARMCallLowering.cpp
Nicolas Capens7d0b8a32018-10-30 16:36:52 -04001275 ${LLVM_DIR}/lib/Target/ARM/ARMCodeGenPrepare.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +01001276 ${LLVM_DIR}/lib/Target/ARM/ARMComputeBlockSize.cpp
1277 ${LLVM_DIR}/lib/Target/ARM/ARMConstantIslandPass.cpp
1278 ${LLVM_DIR}/lib/Target/ARM/ARMConstantPoolValue.cpp
1279 ${LLVM_DIR}/lib/Target/ARM/ARMExpandPseudoInsts.cpp
1280 ${LLVM_DIR}/lib/Target/ARM/ARMFastISel.cpp
1281 ${LLVM_DIR}/lib/Target/ARM/ARMFrameLowering.cpp
1282 ${LLVM_DIR}/lib/Target/ARM/ARMHazardRecognizer.cpp
1283 ${LLVM_DIR}/lib/Target/ARM/ARMInstrInfo.cpp
1284 ${LLVM_DIR}/lib/Target/ARM/ARMInstructionSelector.cpp
1285 ${LLVM_DIR}/lib/Target/ARM/ARMISelDAGToDAG.cpp
1286 ${LLVM_DIR}/lib/Target/ARM/ARMISelLowering.cpp
Nicolas Capens7d0b8a32018-10-30 16:36:52 -04001287 ${LLVM_DIR}/lib/Target/ARM/ARMLegalizerInfo.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +01001288 ${LLVM_DIR}/lib/Target/ARM/ARMLoadStoreOptimizer.cpp
1289 ${LLVM_DIR}/lib/Target/ARM/ARMMachineFunctionInfo.cpp
1290 ${LLVM_DIR}/lib/Target/ARM/ARMMacroFusion.cpp
1291 ${LLVM_DIR}/lib/Target/ARM/ARMMCInstLower.cpp
Nicolas Capens7d0b8a32018-10-30 16:36:52 -04001292 ${LLVM_DIR}/lib/Target/ARM/ARMOptimizeBarriersPass.cpp
Ben Claytonc8740e02019-06-11 16:16:48 +01001293 ${LLVM_DIR}/lib/Target/ARM/ARMParallelDSP.cpp
1294 ${LLVM_DIR}/lib/Target/ARM/ARMRegisterBankInfo.cpp
1295 ${LLVM_DIR}/lib/Target/ARM/ARMRegisterInfo.cpp
1296 ${LLVM_DIR}/lib/Target/ARM/ARMSelectionDAGInfo.cpp
1297 ${LLVM_DIR}/lib/Target/ARM/ARMSubtarget.cpp
1298 ${LLVM_DIR}/lib/Target/ARM/ARMTargetMachine.cpp
1299 ${LLVM_DIR}/lib/Target/ARM/ARMTargetObjectFile.cpp
1300 ${LLVM_DIR}/lib/Target/ARM/ARMTargetTransformInfo.cpp
1301 ${LLVM_DIR}/lib/Target/ARM/AsmParser/ARMAsmParser.cpp
1302 ${LLVM_DIR}/lib/Target/ARM/Disassembler/ARMDisassembler.cpp
1303 ${LLVM_DIR}/lib/Target/ARM/InstPrinter/ARMInstPrinter.cpp
1304 ${LLVM_DIR}/lib/Target/ARM/MCTargetDesc/ARMAsmBackend.cpp
1305 ${LLVM_DIR}/lib/Target/ARM/MCTargetDesc/ARMELFObjectWriter.cpp
1306 ${LLVM_DIR}/lib/Target/ARM/MCTargetDesc/ARMELFStreamer.cpp
1307 ${LLVM_DIR}/lib/Target/ARM/MCTargetDesc/ARMMachObjectWriter.cpp
1308 ${LLVM_DIR}/lib/Target/ARM/MCTargetDesc/ARMMachORelocationInfo.cpp
1309 ${LLVM_DIR}/lib/Target/ARM/MCTargetDesc/ARMMCAsmInfo.cpp
1310 ${LLVM_DIR}/lib/Target/ARM/MCTargetDesc/ARMMCCodeEmitter.cpp
1311 ${LLVM_DIR}/lib/Target/ARM/MCTargetDesc/ARMMCExpr.cpp
1312 ${LLVM_DIR}/lib/Target/ARM/MCTargetDesc/ARMMCTargetDesc.cpp
1313 ${LLVM_DIR}/lib/Target/ARM/MCTargetDesc/ARMTargetStreamer.cpp
1314 ${LLVM_DIR}/lib/Target/ARM/MCTargetDesc/ARMUnwindOpAsm.cpp
1315 ${LLVM_DIR}/lib/Target/ARM/MCTargetDesc/ARMWinCOFFObjectWriter.cpp
1316 ${LLVM_DIR}/lib/Target/ARM/MCTargetDesc/ARMWinCOFFStreamer.cpp
1317 ${LLVM_DIR}/lib/Target/ARM/MLxExpansionPass.cpp
1318 ${LLVM_DIR}/lib/Target/ARM/TargetInfo/ARMTargetInfo.cpp
1319 ${LLVM_DIR}/lib/Target/ARM/Thumb1FrameLowering.cpp
1320 ${LLVM_DIR}/lib/Target/ARM/Thumb1InstrInfo.cpp
1321 ${LLVM_DIR}/lib/Target/ARM/Thumb2InstrInfo.cpp
1322 ${LLVM_DIR}/lib/Target/ARM/Thumb2ITBlockPass.cpp
1323 ${LLVM_DIR}/lib/Target/ARM/Thumb2SizeReduction.cpp
1324 ${LLVM_DIR}/lib/Target/ARM/ThumbRegisterInfo.cpp
1325 ${LLVM_DIR}/lib/Target/ARM/Utils/ARMBaseInfo.cpp
Nicolas Capens7d0b8a32018-10-30 16:36:52 -04001326 )
Colin Samplesf63a3ab2019-06-13 12:53:09 -04001327elseif(ARCH STREQUAL "ppc64le")
1328 list(APPEND LLVM_LIST
1329 ${LLVM_DIR}/lib/Target/PowerPC/AsmParser/PPCAsmParser.cpp
1330 ${LLVM_DIR}/lib/Target/PowerPC/Disassembler/PPCDisassembler.cpp
1331 ${LLVM_DIR}/lib/Target/PowerPC/InstPrinter/PPCInstPrinter.cpp
1332 ${LLVM_DIR}/lib/Target/PowerPC/MCTargetDesc/PPCAsmBackend.cpp
1333 ${LLVM_DIR}/lib/Target/PowerPC/MCTargetDesc/PPCELFObjectWriter.cpp
1334 ${LLVM_DIR}/lib/Target/PowerPC/MCTargetDesc/PPCMachObjectWriter.cpp
1335 ${LLVM_DIR}/lib/Target/PowerPC/MCTargetDesc/PPCMCAsmInfo.cpp
1336 ${LLVM_DIR}/lib/Target/PowerPC/MCTargetDesc/PPCMCCodeEmitter.cpp
1337 ${LLVM_DIR}/lib/Target/PowerPC/MCTargetDesc/PPCMCExpr.cpp
1338 ${LLVM_DIR}/lib/Target/PowerPC/MCTargetDesc/PPCMCTargetDesc.cpp
1339 ${LLVM_DIR}/lib/Target/PowerPC/MCTargetDesc/PPCPredicates.cpp
1340 ${LLVM_DIR}/lib/Target/PowerPC/PPCAsmPrinter.cpp
1341 ${LLVM_DIR}/lib/Target/PowerPC/PPCBoolRetToInt.cpp
1342 ${LLVM_DIR}/lib/Target/PowerPC/PPCBranchCoalescing.cpp
1343 ${LLVM_DIR}/lib/Target/PowerPC/PPCBranchSelector.cpp
1344 ${LLVM_DIR}/lib/Target/PowerPC/PPCCCState.cpp
1345 ${LLVM_DIR}/lib/Target/PowerPC/PPCCTRLoops.cpp
1346 ${LLVM_DIR}/lib/Target/PowerPC/PPCEarlyReturn.cpp
1347 ${LLVM_DIR}/lib/Target/PowerPC/PPCExpandISEL.cpp
1348 ${LLVM_DIR}/lib/Target/PowerPC/PPCFastISel.cpp
1349 ${LLVM_DIR}/lib/Target/PowerPC/PPCFrameLowering.cpp
1350 ${LLVM_DIR}/lib/Target/PowerPC/PPCHazardRecognizers.cpp
1351 ${LLVM_DIR}/lib/Target/PowerPC/PPCInstrInfo.cpp
1352 ${LLVM_DIR}/lib/Target/PowerPC/PPCISelDAGToDAG.cpp
1353 ${LLVM_DIR}/lib/Target/PowerPC/PPCISelLowering.cpp
1354 ${LLVM_DIR}/lib/Target/PowerPC/PPCLoopPreIncPrep.cpp
1355 ${LLVM_DIR}/lib/Target/PowerPC/PPCMachineFunctionInfo.cpp
1356 ${LLVM_DIR}/lib/Target/PowerPC/PPCMCInstLower.cpp
1357 ${LLVM_DIR}/lib/Target/PowerPC/PPCMIPeephole.cpp
1358 ${LLVM_DIR}/lib/Target/PowerPC/PPCPreEmitPeephole.cpp
1359 ${LLVM_DIR}/lib/Target/PowerPC/PPCQPXLoadSplat.cpp
1360 ${LLVM_DIR}/lib/Target/PowerPC/PPCReduceCRLogicals.cpp
1361 ${LLVM_DIR}/lib/Target/PowerPC/PPCRegisterInfo.cpp
1362 ${LLVM_DIR}/lib/Target/PowerPC/PPCSubtarget.cpp
1363 ${LLVM_DIR}/lib/Target/PowerPC/PPCTargetMachine.cpp
1364 ${LLVM_DIR}/lib/Target/PowerPC/PPCTargetObjectFile.cpp
1365 ${LLVM_DIR}/lib/Target/PowerPC/PPCTargetTransformInfo.cpp
1366 ${LLVM_DIR}/lib/Target/PowerPC/PPCTLSDynamicCall.cpp
1367 ${LLVM_DIR}/lib/Target/PowerPC/PPCTOCRegDeps.cpp
1368 ${LLVM_DIR}/lib/Target/PowerPC/PPCVSXCopy.cpp
1369 ${LLVM_DIR}/lib/Target/PowerPC/PPCVSXFMAMutate.cpp
1370 ${LLVM_DIR}/lib/Target/PowerPC/PPCVSXSwapRemoval.cpp
1371 ${LLVM_DIR}/lib/Target/PowerPC/TargetInfo/PowerPCTargetInfo.cpp
1372 )
Ben Claytonac07ed82019-03-26 14:17:41 +00001373endif()
1374
1375if(REACTOR_EMIT_DEBUG_INFO)
1376 list(APPEND LLVM_LIST
1377 ${LLVM_DIR}/lib/Demangle/ItaniumDemangle.cpp
1378 )
1379endif(REACTOR_EMIT_DEBUG_INFO)
Nicolas Capens7d0b8a32018-10-30 16:36:52 -04001380
Logan Chien0eedc8c2018-08-21 09:34:28 +08001381set(LLVM_INCLUDE_DIR "")
1382
1383if(WIN32)
Nicolas Capensd7a21cc2018-09-11 13:09:28 -04001384 list(APPEND LLVM_INCLUDE_DIR ${LLVM_CONFIG_DIR}/windows/include)
Logan Chien0eedc8c2018-08-21 09:34:28 +08001385elseif(LINUX)
1386 list(APPEND LLVM_INCLUDE_DIR ${LLVM_CONFIG_DIR}/linux/include)
Ben Claytonac07ed82019-03-26 14:17:41 +00001387 list(APPEND LIBBACKTRACE_INCLUDE_DIR ${LIBBACKTRACE_CONFIG_DIR}/linux/include)
Logan Chien0eedc8c2018-08-21 09:34:28 +08001388elseif(APPLE)
Nicolas Capens2337f062018-10-30 13:49:46 -04001389 list(APPEND LLVM_INCLUDE_DIR ${LLVM_CONFIG_DIR}/darwin/include)
Ben Claytonac07ed82019-03-26 14:17:41 +00001390 list(APPEND LIBBACKTRACE_INCLUDE_DIR ${LIBBACKTRACE_CONFIG_DIR}/darwin/include)
Stephen Whitee6ab01f2019-04-04 14:31:25 -04001391elseif(ANDROID)
1392 list(APPEND LLVM_INCLUDE_DIR ${LLVM_CONFIG_DIR}/android/include)
Ben Claytonac07ed82019-03-26 14:17:41 +00001393 list(APPEND LIBBACKTRACE_INCLUDE_DIR ${LIBBACKTRACE_CONFIG_DIR}/android/include)
Logan Chien0eedc8c2018-08-21 09:34:28 +08001394endif()
1395
1396list(APPEND LLVM_INCLUDE_DIR
1397 ${LLVM_DIR}/include
Logan Chien009fecb2018-08-21 15:14:16 +08001398 ${LLVM_DIR}/lib/Target/AArch64
1399 ${LLVM_DIR}/lib/Target/ARM
Gordana Cmiljanovic082dfec2018-10-19 11:36:15 +02001400 ${LLVM_DIR}/lib/Target/Mips
Colin Samplesf63a3ab2019-06-13 12:53:09 -04001401 ${LLVM_DIR}/lib/Target/PowerPC
Logan Chien0eedc8c2018-08-21 09:34:28 +08001402 ${LLVM_DIR}/lib/Target/X86
1403 ${LLVM_CONFIG_DIR}/common/include
1404 ${LLVM_CONFIG_DIR}/common/lib/IR
Logan Chien009fecb2018-08-21 15:14:16 +08001405 ${LLVM_CONFIG_DIR}/common/lib/Target/AArch64
1406 ${LLVM_CONFIG_DIR}/common/lib/Target/ARM
Gordana Cmiljanovic082dfec2018-10-19 11:36:15 +02001407 ${LLVM_CONFIG_DIR}/common/lib/Target/Mips
Colin Samplesf63a3ab2019-06-13 12:53:09 -04001408 ${LLVM_CONFIG_DIR}/common/lib/Target/PowerPC
Logan Chien0eedc8c2018-08-21 09:34:28 +08001409 ${LLVM_CONFIG_DIR}/common/lib/Target/X86
1410 ${LLVM_CONFIG_DIR}/common/lib/Transforms/InstCombine
1411)
1412
Ben Clayton81be8c62019-02-26 16:50:31 +00001413# Suppress known LLVM warnings
Ben Clayton4ceb77d2019-04-24 12:09:59 +01001414set(LLVM_COMPILE_OPTIONS)
Ben Clayton81be8c62019-02-26 16:50:31 +00001415if(CMAKE_CXX_COMPILER_ID MATCHES "GNU")
Ben Clayton4ceb77d2019-04-24 12:09:59 +01001416 list(APPEND LLVM_COMPILE_OPTIONS
Ben Clayton81be8c62019-02-26 16:50:31 +00001417 "-Wno-noexcept-type" # mangled name for ‘X’ will change in C++17 because the exception specification is part of a function type
1418 "-Wno-maybe-uninitialized" # ‘X’ may be used uninitialized in this function
1419 "-Wno-unused-but-set-variable" # variable ‘X’ set but not used
1420 )
Nicolas Capens6d874f02019-06-26 10:31:47 -04001421 if(CMAKE_CXX_COMPILER_VERSION VERSION_GREATER_EQUAL 8)
1422 list(APPEND LLVM_COMPILE_OPTIONS
1423 "-Wno-class-memaccess" # memset/memcmp used on non-trivial class object
Chris Forbes23742c02019-08-21 12:30:06 -07001424 "-Wno-attributes" # declared inline but not inline
Nicolas Capens6d874f02019-06-26 10:31:47 -04001425 )
1426 endif()
Ben Claytonedd7d412019-04-14 08:41:27 -04001427elseif(CMAKE_CXX_COMPILER_ID MATCHES "MSVC")
Antonio Maiorano5bce1f42019-05-10 16:03:49 -04001428 list(APPEND LLVM_COMPILE_OPTIONS
Ben Claytonedd7d412019-04-14 08:41:27 -04001429 "/wd4141" # 'inline': used more than once
1430 "/wd4146" # unary minus operator applied to unsigned type, result still unsigned
1431 "/wd4244" # 'X': conversion from 'uint64_t' to 'const unsigned int', possible loss of data
1432 "/wd4267" # 'X': conversion from 'size_t' to 'unsigned int', possible loss of data
1433 "/wd4291" # 'void X new(size_t,unsigned int,unsigned int)': no matching operator delete found; memory will not be freed if initialization throws an exception
1434 "/wd4319" # 'X': zero extending 'unsigned int' to 'uint64_t' of greater size
1435 "/wd4624" # 'X': destructor was implicitly defined as deleted
1436 "/wd4805" # 'X': unsafe mix of type 'unsigned int' and type 'bool' in operation
1437 "/wd4996" # 'X': Call to 'Y' with parameters that may be unsafe - this call relies on the caller to check that the passed values are correct.
1438 )
Ben Clayton81be8c62019-02-26 16:50:31 +00001439endif()
Ben Clayton81be8c62019-02-26 16:50:31 +00001440
Nicolas Capens5a105bc2015-12-22 22:04:28 -05001441add_library(llvm STATIC ${LLVM_LIST})
Corentin Wallez0866b292015-12-09 13:49:40 -05001442set_target_properties(llvm PROPERTIES
1443 POSITION_INDEPENDENT_CODE 1
1444 INCLUDE_DIRECTORIES "${LLVM_INCLUDE_DIR}"
Ben Clayton4ceb77d2019-04-24 12:09:59 +01001445 COMPILE_OPTIONS "${LLVM_COMPILE_OPTIONS}"
Nicolas Capensf53adbd2017-01-06 12:47:46 -05001446 COMPILE_DEFINITIONS "__STDC_CONSTANT_MACROS; __STDC_LIMIT_MACROS;"
Corentin Wallez0866b292015-12-09 13:49:40 -05001447 FOLDER "LLVM"
1448)
1449
Ben Clayton8f71f732019-02-01 09:38:45 +00001450# Add required libraries for LLVM
1451if(LINUX)
1452 target_link_libraries(llvm dl)
1453endif(LINUX)
1454
Corentin Wallez0866b292015-12-09 13:49:40 -05001455###########################################################
Nicolas Capensf53adbd2017-01-06 12:47:46 -05001456# Subzero
1457###########################################################
1458
Nicolas Capens26690ed2017-03-31 10:34:20 -04001459if(${REACTOR_BACKEND} STREQUAL "Subzero")
1460 set(SUBZERO_LIST
1461 ${SUBZERO_DIR}/src/IceAssembler.cpp
1462 ${SUBZERO_DIR}/src/IceCfg.cpp
1463 ${SUBZERO_DIR}/src/IceCfgNode.cpp
1464 ${SUBZERO_DIR}/src/IceClFlags.cpp
1465 ${SUBZERO_DIR}/src/IceELFObjectWriter.cpp
1466 ${SUBZERO_DIR}/src/IceELFSection.cpp
1467 ${SUBZERO_DIR}/src/IceFixups.cpp
1468 ${SUBZERO_DIR}/src/IceGlobalContext.cpp
1469 ${SUBZERO_DIR}/src/IceGlobalInits.cpp
1470 ${SUBZERO_DIR}/src/IceInst.cpp
1471 ${SUBZERO_DIR}/src/IceInstrumentation.cpp
1472 ${SUBZERO_DIR}/src/IceIntrinsics.cpp
1473 ${SUBZERO_DIR}/src/IceLiveness.cpp
1474 ${SUBZERO_DIR}/src/IceLoopAnalyzer.cpp
1475 ${SUBZERO_DIR}/src/IceMangling.cpp
1476 ${SUBZERO_DIR}/src/IceMemory.cpp
1477 ${SUBZERO_DIR}/src/IceOperand.cpp
1478 ${SUBZERO_DIR}/src/IceRangeSpec.cpp
1479 ${SUBZERO_DIR}/src/IceRegAlloc.cpp
1480 ${SUBZERO_DIR}/src/IceRevision.cpp
1481 ${SUBZERO_DIR}/src/IceRNG.cpp
1482 ${SUBZERO_DIR}/src/IceSwitchLowering.cpp
1483 ${SUBZERO_DIR}/src/IceTargetLowering.cpp
Nicolas Capens26690ed2017-03-31 10:34:20 -04001484 ${SUBZERO_DIR}/src/IceThreading.cpp
1485 ${SUBZERO_DIR}/src/IceTimerTree.cpp
1486 ${SUBZERO_DIR}/src/IceTypes.cpp
1487 ${SUBZERO_DIR}/src/IceVariableSplitting.cpp
Nicolas Capensf53adbd2017-01-06 12:47:46 -05001488 )
Nicolas Capens26690ed2017-03-31 10:34:20 -04001489
Nicolas Capens75753f92018-10-02 15:01:30 -04001490 # FIXME: Shouldn't depend on external source files directly.
1491 list(APPEND SUBZERO_LIST
1492 ${SOURCE_DIR}/Common/Memory.cpp
1493 )
1494
Nicolas Capens30cd7d42017-04-25 15:17:25 -04001495 if(ARCH STREQUAL "x86_64")
Nicolas Capens26690ed2017-03-31 10:34:20 -04001496 list(APPEND SUBZERO_LIST
Nicolas Capens30cd7d42017-04-25 15:17:25 -04001497 ${SUBZERO_DIR}/src/IceTargetLoweringX86.cpp
Nicolas Capens26690ed2017-03-31 10:34:20 -04001498 ${SUBZERO_DIR}/src/IceInstX8664.cpp
1499 ${SUBZERO_DIR}/src/IceTargetLoweringX8664.cpp
1500 )
1501 set(SUBZERO_TARGET X8664)
Nicolas Capens30cd7d42017-04-25 15:17:25 -04001502 elseif(ARCH STREQUAL "x86")
Nicolas Capens26690ed2017-03-31 10:34:20 -04001503 list(APPEND SUBZERO_LIST
Nicolas Capens30cd7d42017-04-25 15:17:25 -04001504 ${SUBZERO_DIR}/src/IceTargetLoweringX86.cpp
Nicolas Capens26690ed2017-03-31 10:34:20 -04001505 ${SUBZERO_DIR}/src/IceInstX8632.cpp
1506 ${SUBZERO_DIR}/src/IceTargetLoweringX8632.cpp
1507 )
1508 set(SUBZERO_TARGET X8632)
Nicolas Capens30cd7d42017-04-25 15:17:25 -04001509 elseif(ARCH STREQUAL "arm")
1510 list(APPEND SUBZERO_LIST
1511 ${SUBZERO_DIR}/src/IceAssemblerARM32.cpp
1512 ${SUBZERO_DIR}/src/IceInstARM32.cpp
1513 ${SUBZERO_DIR}/src/IceTargetLoweringARM32.cpp
1514 )
1515 set(SUBZERO_TARGET ARM32)
Gordana Cmiljanovic082dfec2018-10-19 11:36:15 +02001516 elseif(ARCH STREQUAL "mipsel")
1517 list(APPEND SUBZERO_LIST
1518 ${SUBZERO_DIR}/src/IceAssemblerMIPS32.cpp
1519 ${SUBZERO_DIR}/src/IceInstMIPS32.cpp
1520 ${SUBZERO_DIR}/src/IceTargetLoweringMIPS32.cpp
1521 )
1522 set(SUBZERO_TARGET MIPS32)
Nicolas Capens30cd7d42017-04-25 15:17:25 -04001523 else()
1524 message(FATAL_ERROR "Architecture '${ARCH}' not supported by Subzero")
Nicolas Capens26690ed2017-03-31 10:34:20 -04001525 endif()
1526
1527 file(GLOB_RECURSE SUBZERO_DEPENDENCIES_LIST
1528 ${SUBZERO_LLVM_DIR}/*.cpp
1529 ${SUBZERO_LLVM_DIR}/*.c
1530 ${SUBZERO_LLVM_DIR}/*.h
Nicolas Capensf53adbd2017-01-06 12:47:46 -05001531 )
Nicolas Capensf53adbd2017-01-06 12:47:46 -05001532
Nicolas Capens26690ed2017-03-31 10:34:20 -04001533 set(SUBZERO_REACTOR_LIST
Nicolas Capensb6d4ce32019-03-12 23:00:24 -04001534 ${SOURCE_DIR}/Reactor/Reactor.cpp
Antonio Maioranof448d8e2019-04-26 16:19:16 -04001535 ${SOURCE_DIR}/Reactor/Reactor.hpp
Nicolas Capens26690ed2017-03-31 10:34:20 -04001536 ${SOURCE_DIR}/Reactor/SubzeroReactor.cpp
Nicolas Capens26690ed2017-03-31 10:34:20 -04001537 ${SOURCE_DIR}/Reactor/Optimizer.cpp
1538 ${SOURCE_DIR}/Reactor/Nucleus.hpp
1539 ${SOURCE_DIR}/Reactor/Routine.hpp
Nicolas Capensc07dc4b2018-08-06 14:20:45 -04001540 ${SOURCE_DIR}/Reactor/Debug.cpp
1541 ${SOURCE_DIR}/Reactor/Debug.hpp
Nicolas Capens1a3ce872018-10-10 10:42:36 -04001542 ${SOURCE_DIR}/Reactor/ExecutableMemory.cpp
1543 ${SOURCE_DIR}/Reactor/ExecutableMemory.hpp
Nicolas Capens26690ed2017-03-31 10:34:20 -04001544 )
Nicolas Capensf53adbd2017-01-06 12:47:46 -05001545
Nicolas Capens26690ed2017-03-31 10:34:20 -04001546 set(SUBZERO_INCLUDE_DIR
1547 ${SUBZERO_DIR}/
1548 ${SUBZERO_LLVM_DIR}/include/
1549 ${SUBZERO_DIR}/pnacl-llvm/include/
Nicolas Capensc07dc4b2018-08-06 14:20:45 -04001550 )
Nicolas Capensf53adbd2017-01-06 12:47:46 -05001551
Nicolas Capens26690ed2017-03-31 10:34:20 -04001552 if(WIN32)
1553 list(APPEND SUBZERO_INCLUDE_DIR ${SUBZERO_LLVM_DIR}/build/Windows/include/)
1554 elseif(LINUX)
1555 list(APPEND SUBZERO_INCLUDE_DIR ${SUBZERO_LLVM_DIR}/build/Linux/include/)
1556 elseif(APPLE)
1557 list(APPEND SUBZERO_INCLUDE_DIR ${SUBZERO_LLVM_DIR}/build/MacOS/include/)
1558 endif()
Nicolas Capensf53adbd2017-01-06 12:47:46 -05001559
Antonio Maiorano5bce1f42019-05-10 16:03:49 -04001560 if(WIN32)
1561 list(APPEND SUBZERO_COMPILE_OPTIONS
1562 "/wd4334" # ''operator' : result of 32-bit shift implicitly converted to 64 bits (was 64-bit shift intended?)
1563 "/wd4996" # The POSIX name for this item is deprecated. Instead, use the ISO C and C++ conformant name: new_name.
1564 )
1565 endif()
1566
Nicolas Capens26690ed2017-03-31 10:34:20 -04001567 add_library(ReactorSubzero STATIC
1568 ${SUBZERO_LIST}
1569 ${SUBZERO_DEPENDENCIES_LIST}
1570 ${SUBZERO_REACTOR_LIST}
1571 )
Nicolas Capens26690ed2017-03-31 10:34:20 -04001572 set_target_properties(ReactorSubzero PROPERTIES
1573 POSITION_INDEPENDENT_CODE 1
1574 INCLUDE_DIRECTORIES "${SUBZERO_INCLUDE_DIR}"
Antonio Maiorano5bce1f42019-05-10 16:03:49 -04001575 COMPILE_OPTIONS "${SUBZERO_COMPILE_OPTIONS};${SWIFTSHADER_COMPILE_OPTIONS}"
Nicolas Capens26690ed2017-03-31 10:34:20 -04001576 COMPILE_DEFINITIONS "SZTARGET=${SUBZERO_TARGET}; ALLOW_DUMP=0; ALLOW_TIMERS=0; ALLOW_LLVM_CL=0; ALLOW_LLVM_IR=0; ALLOW_LLVM_IR_AS_INPUT=0; ALLOW_MINIMAL_BUILD=0; ALLOW_WASM=0; ICE_THREAD_LOCAL_HACK=0;"
1577 FOLDER "Subzero"
1578 )
Nicolas Capensf53adbd2017-01-06 12:47:46 -05001579
Nicolas Capens26690ed2017-03-31 10:34:20 -04001580 if(WIN32)
1581 target_compile_definitions(ReactorSubzero PRIVATE SUBZERO_USE_MICROSOFT_ABI)
1582 endif()
Nicolas Capens19291ef2017-01-09 13:35:14 -05001583endif()
1584
Nicolas Capensf53adbd2017-01-06 12:47:46 -05001585###########################################################
Corentin Wallez0866b292015-12-09 13:49:40 -05001586# Include Directories
1587###########################################################
1588
1589set(COMMON_INCLUDE_DIR
1590 ${SOURCE_DIR}
Erwin Jansend46faeb2018-11-19 16:01:37 -08001591 ${CMAKE_CURRENT_SOURCE_DIR}/include
Corentin Wallez0866b292015-12-09 13:49:40 -05001592 ${LLVM_INCLUDE_DIR}
Ben Claytonac07ed82019-03-26 14:17:41 +00001593 ${LIBBACKTRACE_INCLUDE_DIR}
Corentin Wallez0866b292015-12-09 13:49:40 -05001594)
1595set(OPENGL_INCLUDE_DIR
1596 ${OPENGL_DIR}
Corentin Wallez0866b292015-12-09 13:49:40 -05001597 ${COMMON_INCLUDE_DIR}
1598)
1599
Chris Forbes3d27f2e2018-09-26 09:24:39 -07001600set(VULKAN_INCLUDE_DIR
Chris Forbes3d27f2e2018-09-26 09:24:39 -07001601 ${COMMON_INCLUDE_DIR}
Ben Claytone693b622019-09-05 12:48:37 +01001602 ${MARL_INCLUDE_DIR}
Chris Forbes3d27f2e2018-09-26 09:24:39 -07001603)
1604
Corentin Wallez0866b292015-12-09 13:49:40 -05001605###########################################################
1606# File Lists
1607###########################################################
1608
1609file(GLOB_RECURSE SWIFTSHADER_LIST
1610 ${SOURCE_DIR}/Common/*.cpp
1611 ${SOURCE_DIR}/Common/*.h
1612 ${SOURCE_DIR}/Common/*.hpp
1613 ${SOURCE_DIR}/Renderer/*.cpp
1614 ${SOURCE_DIR}/Renderer/*.h
1615 ${SOURCE_DIR}/Renderer/*.hpp
1616 ${SOURCE_DIR}/Shader/*.cpp
1617 ${SOURCE_DIR}/Shader/*.h
1618 ${SOURCE_DIR}/Shader/*.hpp
1619)
1620list(APPEND SWIFTSHADER_LIST
1621 ${SOURCE_DIR}/Main/Config.cpp
1622 ${SOURCE_DIR}/Main/Config.hpp
Corentin Wallez0866b292015-12-09 13:49:40 -05001623 ${SOURCE_DIR}/Main/FrameBuffer.cpp
1624 ${SOURCE_DIR}/Main/FrameBuffer.hpp
Corentin Wallez0866b292015-12-09 13:49:40 -05001625 ${SOURCE_DIR}/Main/SwiftConfig.cpp
1626 ${SOURCE_DIR}/Main/SwiftConfig.hpp
1627)
1628list(REMOVE_ITEM SWIFTSHADER_LIST
1629 ${SOURCE_DIR}/Common/DebugAndroid.cpp
1630 ${SOURCE_DIR}/Common/DebugAndroid.hpp
1631 ${SOURCE_DIR}/Common/GrallocAndroid.cpp
1632 ${SOURCE_DIR}/Common/GrallocAndroid.hpp
1633)
1634
Ben Claytonac07ed82019-03-26 14:17:41 +00001635if(REACTOR_EMIT_DEBUG_INFO)
1636 set(LIBBACKTRACE_LIST
1637 ${LIBBACKTRACE_DIR}/atomic.c
1638 ${LIBBACKTRACE_DIR}/backtrace.c
1639 ${LIBBACKTRACE_DIR}/backtrace.h
1640 ${LIBBACKTRACE_DIR}/dwarf.c
1641 ${LIBBACKTRACE_DIR}/fileline.c
1642 ${LIBBACKTRACE_DIR}/filenames.h
1643 ${LIBBACKTRACE_DIR}/internal.h
1644 ${LIBBACKTRACE_DIR}/mmap.c
1645 ${LIBBACKTRACE_DIR}/mmapio.c
1646 ${LIBBACKTRACE_DIR}/posix.c
1647 ${LIBBACKTRACE_DIR}/print.c
1648 ${LIBBACKTRACE_DIR}/simple.c
1649 ${LIBBACKTRACE_DIR}/sort.c
1650 ${LIBBACKTRACE_DIR}/state.c
1651 ${LIBBACKTRACE_INCLUDE_DIR}/backtrace-supported.h
1652 ${LIBBACKTRACE_INCLUDE_DIR}/config.h
1653 )
1654
1655 if(WIN32)
1656 list(APPEND LIBBACKTRACE_LIST ${LIBBACKTRACE_DIR}/pecoff.c)
1657 elseif(LINUX)
1658 list(APPEND LIBBACKTRACE_LIST ${LIBBACKTRACE_DIR}/elf.c)
1659 elseif(APPLE)
1660 message(FATAL_ERROR "libbacktrace does not support mach-o yet")
1661 endif()
1662endif(REACTOR_EMIT_DEBUG_INFO)
1663
Nicolas Capensf53adbd2017-01-06 12:47:46 -05001664set(REACTOR_LLVM_LIST
Nicolas Capensb6d4ce32019-03-12 23:00:24 -04001665 ${SOURCE_DIR}/Reactor/Reactor.cpp
Antonio Maioranof448d8e2019-04-26 16:19:16 -04001666 ${SOURCE_DIR}/Reactor/Reactor.hpp
Nicolas Capens5763d172016-09-26 13:44:20 -04001667 ${SOURCE_DIR}/Reactor/LLVMReactor.cpp
Ben Claytonac07ed82019-03-26 14:17:41 +00001668 ${SOURCE_DIR}/Reactor/LLVMReactor.hpp
1669 ${SOURCE_DIR}/Reactor/LLVMReactorDebugInfo.cpp
1670 ${SOURCE_DIR}/Reactor/LLVMReactorDebugInfo.hpp
Corentin Wallez0866b292015-12-09 13:49:40 -05001671 ${SOURCE_DIR}/Reactor/Nucleus.hpp
Corentin Wallez0866b292015-12-09 13:49:40 -05001672 ${SOURCE_DIR}/Reactor/Routine.hpp
Nicolas Capensc07dc4b2018-08-06 14:20:45 -04001673 ${SOURCE_DIR}/Reactor/CPUID.cpp
1674 ${SOURCE_DIR}/Reactor/CPUID.hpp
1675 ${SOURCE_DIR}/Reactor/Debug.cpp
1676 ${SOURCE_DIR}/Reactor/Debug.hpp
Nicolas Capens1a3ce872018-10-10 10:42:36 -04001677 ${SOURCE_DIR}/Reactor/ExecutableMemory.cpp
1678 ${SOURCE_DIR}/Reactor/ExecutableMemory.hpp
Corentin Wallez0866b292015-12-09 13:49:40 -05001679)
1680
1681file(GLOB_RECURSE EGL_LIST
1682 ${OPENGL_DIR}/libEGL/*.cpp
1683 ${OPENGL_DIR}/libEGL/*.h
1684 ${OPENGL_DIR}/libEGL/*.hpp
1685 ${OPENGL_DIR}/common/Object.cpp
1686 ${OPENGL_DIR}/common/Object.hpp
1687 ${OPENGL_DIR}/common/debug.cpp
1688 ${OPENGL_DIR}/common/debug.h
Chris Forbesf8374cf2018-12-06 13:25:59 -08001689 ${SOURCE_DIR}/Common/SharedLibrary.cpp
1690 ${SOURCE_DIR}/Common/SharedLibrary.hpp
Erwin Jansend46faeb2018-11-19 16:01:37 -08001691 ${CMAKE_CURRENT_SOURCE_DIR}/include/*.h
Corentin Wallez0866b292015-12-09 13:49:40 -05001692)
1693
Corentin Wallez0866b292015-12-09 13:49:40 -05001694file(GLOB_RECURSE GLES2_LIST
1695 ${OPENGL_DIR}/libGLESv2/*.cpp
1696 ${OPENGL_DIR}/libGLESv2/*.h
1697 ${OPENGL_DIR}/libGLESv2/*.hpp
Nicolas Capens681d97b2016-05-17 16:02:32 -04001698 ${OPENGL_DIR}/common/*.cpp
1699 ${OPENGL_DIR}/common/*.h
1700 ${OPENGL_DIR}/common/*.hpp
Chris Forbesf8374cf2018-12-06 13:25:59 -08001701 ${SOURCE_DIR}/Common/SharedLibrary.cpp
1702 ${SOURCE_DIR}/Common/SharedLibrary.hpp
Erwin Jansend46faeb2018-11-19 16:01:37 -08001703 ${CMAKE_CURRENT_SOURCE_DIR}/include/KHR/*.h
1704 ${CMAKE_CURRENT_SOURCE_DIR}/include/GLES2/*.h
1705 ${CMAKE_CURRENT_SOURCE_DIR}/include/GLES3/*.h
Corentin Wallez0866b292015-12-09 13:49:40 -05001706)
1707
1708file(GLOB_RECURSE GLES_CM_LIST
1709 ${OPENGL_DIR}/libGLES_CM/*.cpp
1710 ${OPENGL_DIR}/libGLES_CM/*.h
1711 ${OPENGL_DIR}/libGLES_CM/*.hpp
Nicolas Capens681d97b2016-05-17 16:02:32 -04001712 ${OPENGL_DIR}/common/*.cpp
1713 ${OPENGL_DIR}/common/*.h
1714 ${OPENGL_DIR}/common/*.hpp
Chris Forbesf8374cf2018-12-06 13:25:59 -08001715 ${SOURCE_DIR}/Common/SharedLibrary.cpp
1716 ${SOURCE_DIR}/Common/SharedLibrary.hpp
Erwin Jansend46faeb2018-11-19 16:01:37 -08001717 ${CMAKE_CURRENT_SOURCE_DIR}/include/KHR/*.h
1718 ${CMAKE_CURRENT_SOURCE_DIR}/include/GLES/*.h
Corentin Wallez0866b292015-12-09 13:49:40 -05001719)
1720
1721file(GLOB_RECURSE OPENGL_COMPILER_LIST
1722 ${OPENGL_COMPILER_DIR}/*.cpp
1723 ${OPENGL_COMPILER_DIR}/*.h
1724 ${OPENGL_COMPILER_DIR}/*.hpp
1725)
1726file(GLOB_RECURSE OPENGL_COMPILER_OS_SPECIFIC_LIST
1727 ${OPENGL_COMPILER_DIR}/ossource*.cpp
1728 ${OPENGL_COMPILER_DIR}/ossource*.h
1729 ${OPENGL_COMPILER_DIR}/ossource*.hpp
1730)
1731list(REMOVE_ITEM OPENGL_COMPILER_LIST ${OPENGL_COMPILER_OS_SPECIFIC_LIST})
1732
Chris Forbes3d27f2e2018-09-26 09:24:39 -07001733file(GLOB_RECURSE VULKAN_LIST
1734 ${VULKAN_DIR}/*.cpp
1735 ${VULKAN_DIR}/*.h
Alexis Hetue70c3512018-10-17 13:18:04 -04001736 ${VULKAN_DIR}/*.hpp
Ben Claytoneea9d352019-08-29 01:05:14 +01001737 ${SOURCE_DIR}/System/Build.hpp
Alexis Hetuc0f92f22018-11-15 16:25:38 -05001738 ${SOURCE_DIR}/System/CPUID.cpp
1739 ${SOURCE_DIR}/System/CPUID.hpp
1740 ${SOURCE_DIR}/System/Configurator.cpp
1741 ${SOURCE_DIR}/System/Configurator.hpp
Chris Forbesc730c382018-12-05 16:48:33 -08001742 ${SOURCE_DIR}/System/Debug.cpp
1743 ${SOURCE_DIR}/System/Debug.hpp
Alexis Hetuc0f92f22018-11-15 16:25:38 -05001744 ${SOURCE_DIR}/System/Half.cpp
1745 ${SOURCE_DIR}/System/Half.hpp
1746 ${SOURCE_DIR}/System/Math.cpp
1747 ${SOURCE_DIR}/System/Math.hpp
1748 ${SOURCE_DIR}/System/Memory.cpp
1749 ${SOURCE_DIR}/System/Memory.hpp
Alexis Hetuc0f92f22018-11-15 16:25:38 -05001750 ${SOURCE_DIR}/System/Socket.cpp
1751 ${SOURCE_DIR}/System/Socket.hpp
Ben Claytoned01f2c2019-05-20 10:42:35 +01001752 ${SOURCE_DIR}/System/Synchronization.hpp
Alexis Hetuc0f92f22018-11-15 16:25:38 -05001753 ${SOURCE_DIR}/System/Timer.cpp
1754 ${SOURCE_DIR}/System/Timer.hpp
1755 ${SOURCE_DIR}/Device/*.cpp
1756 ${SOURCE_DIR}/Device/*.hpp
1757 ${SOURCE_DIR}/Pipeline/*.cpp
1758 ${SOURCE_DIR}/Pipeline/*.hpp
Hernan Liatisc6eb41b2019-02-22 11:12:59 -08001759 ${SOURCE_DIR}/WSI/VkSurfaceKHR.cpp
1760 ${SOURCE_DIR}/WSI/VkSurfaceKHR.hpp
Hernan Liatisc7943e92019-02-25 19:29:54 -08001761 ${SOURCE_DIR}/WSI/VkSwapchainKHR.cpp
1762 ${SOURCE_DIR}/WSI/VkSwapchainKHR.hpp
Erwin Jansend46faeb2018-11-19 16:01:37 -08001763 ${CMAKE_CURRENT_SOURCE_DIR}/include/vulkan/*.h}
Chris Forbes3d27f2e2018-09-26 09:24:39 -07001764)
1765
David 'Digit' Turnerc9fa9fe2019-08-13 19:05:01 +02001766if (LINUX OR ANDROID)
1767 list(APPEND VULKAN_LIST
1768 ${SOURCE_DIR}/System/Linux/MemFd.cpp
1769 ${SOURCE_DIR}/System/Linux/MemFd.hpp)
1770endif(LINUX OR ANDROID)
1771
Corentin Wallez0866b292015-12-09 13:49:40 -05001772###########################################################
1773# Append OS specific files to lists
1774###########################################################
1775
1776if(WIN32)
1777 list(APPEND SWIFTSHADER_LIST
1778 ${SOURCE_DIR}/Main/FrameBufferDD.cpp
1779 ${SOURCE_DIR}/Main/FrameBufferDD.hpp
1780 ${SOURCE_DIR}/Main/FrameBufferGDI.cpp
1781 ${SOURCE_DIR}/Main/FrameBufferGDI.hpp
1782 ${SOURCE_DIR}/Main/FrameBufferWin.cpp
1783 ${SOURCE_DIR}/Main/FrameBufferWin.hpp
Corentin Wallez0866b292015-12-09 13:49:40 -05001784 )
1785 list(APPEND OPENGL_COMPILER_LIST ${OPENGL_COMPILER_DIR}/ossource_win.cpp)
1786 list(APPEND EGL_LIST ${OPENGL_DIR}/libEGL/libEGL.rc)
Corentin Wallez0866b292015-12-09 13:49:40 -05001787 list(APPEND GLES2_LIST ${OPENGL_DIR}/libGLESv2/libGLESv2.rc)
1788 list(APPEND GLES_CM_LIST ${OPENGL_DIR}/libGLES_CM/libGLES_CM.rc)
Nicolas Capensd3545372019-08-09 13:59:18 -04001789 list(APPEND VULKAN_LIST
1790 ${VULKAN_DIR}/Vulkan.rc
1791 ${SOURCE_DIR}/WSI/Win32SurfaceKHR.cpp
1792 ${SOURCE_DIR}/WSI/Win32SurfaceKHR.hpp
1793 )
Corentin Wallez0866b292015-12-09 13:49:40 -05001794elseif(LINUX)
1795 list(APPEND SWIFTSHADER_LIST
1796 ${SOURCE_DIR}/Main/FrameBufferX11.cpp
1797 ${SOURCE_DIR}/Main/FrameBufferX11.hpp
Nicolas Capens681d97b2016-05-17 16:02:32 -04001798 ${SOURCE_DIR}/Common/SharedLibrary.hpp
1799 ${SOURCE_DIR}/Main/libX11.cpp
1800 ${SOURCE_DIR}/Main/libX11.hpp
1801 )
1802 list(APPEND EGL_LIST
1803 ${SOURCE_DIR}/Common/SharedLibrary.hpp
Corentin Wallez0866b292015-12-09 13:49:40 -05001804 ${SOURCE_DIR}/Main/libX11.cpp
1805 ${SOURCE_DIR}/Main/libX11.hpp
1806 )
1807 list(APPEND OPENGL_COMPILER_LIST
1808 ${OPENGL_COMPILER_DIR}/ossource_posix.cpp
1809 )
Hernan Liatisc6eb41b2019-02-22 11:12:59 -08001810
Ben Claytona9af8832019-08-14 13:09:43 +01001811 if(X11)
1812 list(APPEND VULKAN_LIST
1813 ${SOURCE_DIR}/WSI/XlibSurfaceKHR.cpp
1814 ${SOURCE_DIR}/WSI/XlibSurfaceKHR.hpp
1815 ${SOURCE_DIR}/WSI/libX11.cpp
1816 ${SOURCE_DIR}/WSI/libX11.hpp
1817 )
1818 endif(X11)
1819
1820 if(XCB)
1821 list(APPEND VULKAN_LIST
1822 ${SOURCE_DIR}/WSI/XcbSurfaceKHR.cpp
1823 ${SOURCE_DIR}/WSI/XcbSurfaceKHR.hpp
1824 )
1825 endif(XCB)
1826
Corentin Wallez27654c22015-12-09 15:22:08 -05001827elseif(APPLE)
1828 list(APPEND SWIFTSHADER_LIST
1829 ${SOURCE_DIR}/Main/FrameBufferOSX.mm
1830 ${SOURCE_DIR}/Main/FrameBufferOSX.hpp
1831 )
Corentin Wallezcd0a4572015-12-10 15:59:28 -05001832 list(APPEND EGL_LIST
1833 ${OPENGL_DIR}/libEGL/OSXUtils.mm
1834 ${OPENGL_DIR}/libEGL/OSXUtils.hpp
1835 )
Corentin Wallez27654c22015-12-09 15:22:08 -05001836 list(APPEND OPENGL_COMPILER_LIST
1837 ${OPENGL_COMPILER_DIR}/ossource_posix.cpp
1838 )
Alexis Hetu0662a4a2019-07-08 15:06:40 -04001839
1840 list(APPEND VULKAN_LIST
1841 ${SOURCE_DIR}/WSI/MacOSSurfaceMVK.mm
1842 ${SOURCE_DIR}/WSI/MacOSSurfaceMVK.h
1843 )
Stephen Whitee6ab01f2019-04-04 14:31:25 -04001844elseif(ANDROID)
1845 list(APPEND SWIFTSHADER_LIST
1846 ${SOURCE_DIR}/Main/FrameBufferAndroid.cpp
1847 ${SOURCE_DIR}/Main/FrameBufferAndroid.hpp
1848 )
1849 list(APPEND OPENGL_COMPILER_LIST
1850 ${OPENGL_COMPILER_DIR}/ossource_posix.cpp
1851 )
Corentin Wallez0866b292015-12-09 13:49:40 -05001852endif()
1853
1854if(WIN32)
1855 set(OS_LIBS odbc32 odbccp32 WS2_32 dxguid)
1856elseif(LINUX)
Nicolas Capens681d97b2016-05-17 16:02:32 -04001857 set(OS_LIBS dl pthread)
Corentin Wallezcd0a4572015-12-10 15:59:28 -05001858elseif(APPLE)
1859 find_library(COCOA_FRAMEWORK Cocoa)
1860 find_library(QUARTZ_FRAMEWORK Quartz)
Alexis Hetud23cf632018-04-10 10:48:42 -04001861 find_library(CORE_FOUNDATION_FRAMEWORK CoreFoundation)
1862 find_library(IOSURFACE_FRAMEWORK IOSurface)
1863 set(OS_LIBS "${COCOA_FRAMEWORK}" "${QUARTZ_FRAMEWORK}" "${CORE_FOUNDATION_FRAMEWORK}" "${IOSURFACE_FRAMEWORK}")
Corentin Wallez0866b292015-12-09 13:49:40 -05001864endif()
1865
1866###########################################################
Nicolas Capens5a105bc2015-12-22 22:04:28 -05001867# SwiftShader Targets
Corentin Wallez0866b292015-12-09 13:49:40 -05001868###########################################################
1869
1870add_library(SwiftShader STATIC ${SWIFTSHADER_LIST})
1871set_target_properties(SwiftShader PROPERTIES
1872 INCLUDE_DIRECTORIES "${COMMON_INCLUDE_DIR}"
1873 POSITION_INDEPENDENT_CODE 1
1874 FOLDER "Core"
Ben Clayton4ceb77d2019-04-24 12:09:59 +01001875 COMPILE_OPTIONS "${SWIFTSHADER_COMPILE_OPTIONS}"
Nicolas Capens506cc5e2017-07-24 11:30:55 -04001876 COMPILE_DEFINITIONS "NO_SANITIZE_FUNCTION=;"
Corentin Wallez0866b292015-12-09 13:49:40 -05001877)
1878target_link_libraries(SwiftShader ${OS_LIBS})
1879
Ben Claytonb99bc1f2019-04-15 13:56:08 -04001880if(${REACTOR_BACKEND} STREQUAL "LLVM")
1881 add_library(ReactorLLVM STATIC ${REACTOR_LLVM_LIST})
1882 set_target_properties(ReactorLLVM PROPERTIES
1883 INCLUDE_DIRECTORIES "${COMMON_INCLUDE_DIR}"
Ben Claytonac07ed82019-03-26 14:17:41 +00001884 POSITION_INDEPENDENT_CODE 1
1885 FOLDER "Core"
Ben Clayton09a7f452019-04-25 15:22:43 +01001886 COMPILE_OPTIONS "${SWIFTSHADER_COMPILE_OPTIONS}"
Ben Claytonac07ed82019-03-26 14:17:41 +00001887 )
Ben Claytonb99bc1f2019-04-15 13:56:08 -04001888 target_link_libraries(ReactorLLVM llvm ${OS_LIBS})
Ben Claytonac07ed82019-03-26 14:17:41 +00001889
Ben Claytonb99bc1f2019-04-15 13:56:08 -04001890 if(REACTOR_EMIT_DEBUG_INFO)
Antonio Maioranof448d8e2019-04-26 16:19:16 -04001891 if(WIN32)
1892 # Boost stacktrace uses COM on Windows.
1893 # On Windows, cache COM instances in TLS for performance.
Antonio Maiorano8b321d12019-05-27 16:15:34 -04001894 target_compile_definitions(ReactorLLVM PRIVATE BOOST_STACKTRACE_USE_WINDBG_CACHED)
Antonio Maioranof448d8e2019-04-26 16:19:16 -04001895 else()
1896 # Boost stacktrace uses libbacktrace
Antonio Maiorano8b321d12019-05-27 16:15:34 -04001897 target_compile_definitions(ReactorLLVM PRIVATE BOOST_STACKTRACE_USE_BACKTRACE)
Antonio Maioranof448d8e2019-04-26 16:19:16 -04001898
1899 # Boost stacktrace uses exceptions, so force enable it
1900 set_cpp_flag("-fexceptions")
1901
1902 add_library(Libbacktrace STATIC ${LIBBACKTRACE_LIST})
1903 set_target_properties(Libbacktrace PROPERTIES
1904 INCLUDE_DIRECTORIES "${LIBBACKTRACE_INCLUDE_DIR}"
1905 POSITION_INDEPENDENT_CODE 1
1906 FOLDER "Core"
1907 )
1908 target_link_libraries(Libbacktrace ${OS_LIBS})
1909 target_link_libraries(ReactorLLVM Libbacktrace)
1910 endif()
Antonio Maiorano8b321d12019-05-27 16:15:34 -04001911
1912 # Download boost and use it
1913 DownloadBoost()
1914 set(BOOST_INCLUDEDIR ${BOOST_THIRD_PARTY_DIR})
1915 find_package(Boost REQUIRED)
1916 target_link_libraries(ReactorLLVM Boost::boost)
1917
Ben Claytonb99bc1f2019-04-15 13:56:08 -04001918 endif(REACTOR_EMIT_DEBUG_INFO)
1919
Nicolas Capensf53adbd2017-01-06 12:47:46 -05001920 set(Reactor ReactorLLVM)
1921elseif(${REACTOR_BACKEND} STREQUAL "Subzero")
1922 set(Reactor ReactorSubzero)
1923else()
1924 message(FATAL_ERROR "REACTOR_BACKEND must be 'LLVM' or 'Subzero'")
1925endif()
Corentin Wallez0866b292015-12-09 13:49:40 -05001926
Corentin Wallez0866b292015-12-09 13:49:40 -05001927add_library(GLCompiler STATIC ${OPENGL_COMPILER_LIST})
1928set_target_properties(GLCompiler PROPERTIES
1929 INCLUDE_DIRECTORIES "${OPENGL_INCLUDE_DIR}"
1930 POSITION_INDEPENDENT_CODE 1
1931 FOLDER "OpenGL"
Ben Clayton4ceb77d2019-04-24 12:09:59 +01001932 COMPILE_OPTIONS "${SWIFTSHADER_COMPILE_OPTIONS}"
Corentin Wallez0866b292015-12-09 13:49:40 -05001933)
1934target_link_libraries(GLCompiler ${OS_LIBS})
1935
Nicolas Capens6f422092015-12-23 15:12:45 -05001936if(CMAKE_SIZEOF_VOID_P EQUAL 8)
1937 set(LIB_PREFIX "lib64")
1938else()
1939 set(LIB_PREFIX "lib")
1940endif()
1941
Corentin Wallez0866b292015-12-09 13:49:40 -05001942if(BUILD_EGL)
1943 add_library(libEGL SHARED ${EGL_LIST})
1944 set_target_properties(libEGL PROPERTIES
1945 INCLUDE_DIRECTORIES "${OPENGL_INCLUDE_DIR}"
1946 FOLDER "OpenGL"
Ben Clayton4ceb77d2019-04-24 12:09:59 +01001947 COMPILE_OPTIONS "${SWIFTSHADER_COMPILE_OPTIONS}"
Antonio Maioranob0a68ed2019-04-26 15:34:22 -04001948 COMPILE_DEFINITIONS "EGL_EGLEXT_PROTOTYPES; EGLAPI=; NO_SANITIZE_FUNCTION=;$<$<CONFIG:Debug>:DEBUGGER_WAIT_DIALOG>"
Corentin Wallez0866b292015-12-09 13:49:40 -05001949 PREFIX ""
1950 )
Nicolas Capensd3545372019-08-09 13:59:18 -04001951 if(LINUX)
Ben Claytona9af8832019-08-14 13:09:43 +01001952 if(X11)
1953 set_property(TARGET libEGL APPEND PROPERTY COMPILE_DEFINITIONS "USE_X11=1")
1954 endif(X11)
Nicolas Capensd3545372019-08-09 13:59:18 -04001955 endif()
Stephen Whitee6ab01f2019-04-04 14:31:25 -04001956 if (ANDROID)
1957 set_target_properties(libEGL PROPERTIES SUFFIX "_swiftshader.so")
1958 endif ()
Nicolas Capens499bb762018-06-29 13:30:57 -04001959 set_shared_library_export_map(libEGL ${SOURCE_DIR}/OpenGL/libEGL)
Corentin Wallez0866b292015-12-09 13:49:40 -05001960 target_link_libraries(libEGL ${OS_LIBS})
Nicolas Capens6f422092015-12-23 15:12:45 -05001961 add_custom_command(
1962 TARGET libEGL
1963 POST_BUILD
1964 COMMAND ${CMAKE_COMMAND} -E make_directory $<TARGET_FILE_DIR:libEGL>/translator
1965 COMMAND ${CMAKE_COMMAND} -E copy $<TARGET_FILE:libEGL> $<TARGET_FILE_DIR:libEGL>/translator/${LIB_PREFIX}EGL_translator${CMAKE_SHARED_LIBRARY_SUFFIX}
Dan Sinclair1b8cd2d2019-03-14 10:51:05 -04001966 COMMAND ${CMAKE_COMMAND} -E make_directory ${CMAKE_BINARY_DIR}/${CMAKE_SYSTEM_NAME}/
1967 COMMAND ${CMAKE_COMMAND} -E copy $<TARGET_FILE:libEGL> ${CMAKE_BINARY_DIR}/${CMAKE_SYSTEM_NAME}/
Nicolas Capens6f422092015-12-23 15:12:45 -05001968 )
Corentin Wallez0866b292015-12-09 13:49:40 -05001969endif()
1970
Corentin Wallez0866b292015-12-09 13:49:40 -05001971if(BUILD_GLESv2)
1972 add_library(libGLESv2 SHARED ${GLES2_LIST})
1973 set_target_properties(libGLESv2 PROPERTIES
1974 INCLUDE_DIRECTORIES "${OPENGL_INCLUDE_DIR}"
1975 FOLDER "OpenGL"
Ben Clayton4ceb77d2019-04-24 12:09:59 +01001976 COMPILE_OPTIONS "${SWIFTSHADER_COMPILE_OPTIONS}"
Nicolas Capens8e6ed2e2018-05-31 16:21:02 -04001977 COMPILE_DEFINITIONS "GL_GLEXT_PROTOTYPES; GL_API=; GL_APICALL=; GLAPI=; NO_SANITIZE_FUNCTION=;"
Corentin Wallez0866b292015-12-09 13:49:40 -05001978 PREFIX ""
1979 )
Stephen Whitee6ab01f2019-04-04 14:31:25 -04001980 if (ANDROID)
1981 set_target_properties(libGLESv2 PROPERTIES SUFFIX "_swiftshader.so")
1982 endif ()
Nicolas Capens499bb762018-06-29 13:30:57 -04001983 set_shared_library_export_map(libGLESv2 ${SOURCE_DIR}/OpenGL/libGLESv2)
Nicolas Capensf53adbd2017-01-06 12:47:46 -05001984 target_link_libraries(libGLESv2 SwiftShader ${Reactor} GLCompiler ${OS_LIBS})
Nicolas Capens6f422092015-12-23 15:12:45 -05001985 add_custom_command(
1986 TARGET libGLESv2
1987 POST_BUILD
1988 COMMAND ${CMAKE_COMMAND} -E make_directory $<TARGET_FILE_DIR:libGLESv2>/translator
1989 COMMAND ${CMAKE_COMMAND} -E copy $<TARGET_FILE:libGLESv2> $<TARGET_FILE_DIR:libGLESv2>/translator/${LIB_PREFIX}GLES_V2_translator${CMAKE_SHARED_LIBRARY_SUFFIX}
Dan Sinclair1b8cd2d2019-03-14 10:51:05 -04001990 COMMAND ${CMAKE_COMMAND} -E make_directory ${CMAKE_BINARY_DIR}/${CMAKE_SYSTEM_NAME}/
1991 COMMAND ${CMAKE_COMMAND} -E copy $<TARGET_FILE:libGLESv2> ${CMAKE_BINARY_DIR}/${CMAKE_SYSTEM_NAME}/
Nicolas Capens6f422092015-12-23 15:12:45 -05001992 )
Corentin Wallez0866b292015-12-09 13:49:40 -05001993endif()
1994
1995if(BUILD_GLES_CM)
1996 add_library(libGLES_CM SHARED ${GLES_CM_LIST})
1997 set_target_properties(libGLES_CM PROPERTIES
1998 INCLUDE_DIRECTORIES "${OPENGL_INCLUDE_DIR}"
1999 FOLDER "OpenGL"
Ben Clayton4ceb77d2019-04-24 12:09:59 +01002000 COMPILE_OPTIONS "${SWIFTSHADER_COMPILE_OPTIONS}"
Nicolas Capens8e6ed2e2018-05-31 16:21:02 -04002001 COMPILE_DEFINITIONS "GL_GLEXT_PROTOTYPES; EGLAPI=; GL_API=; GL_APICALL=; GLAPI=;"
Corentin Wallez0866b292015-12-09 13:49:40 -05002002 PREFIX ""
2003 )
Stephen Whitee6ab01f2019-04-04 14:31:25 -04002004 if (ANDROID)
2005 set_target_properties(libGLES_CM PROPERTIES SUFFIX "_swiftshader.so")
2006 endif ()
Nicolas Capens499bb762018-06-29 13:30:57 -04002007 set_shared_library_export_map(libGLES_CM ${SOURCE_DIR}/OpenGL/libGLES_CM)
Nicolas Capensf53adbd2017-01-06 12:47:46 -05002008 target_link_libraries(libGLES_CM SwiftShader ${Reactor} GLCompiler ${OS_LIBS})
Nicolas Capens6f422092015-12-23 15:12:45 -05002009 add_custom_command(
2010 TARGET libGLES_CM
2011 POST_BUILD
2012 COMMAND ${CMAKE_COMMAND} -E make_directory $<TARGET_FILE_DIR:libGLES_CM>/translator
2013 COMMAND ${CMAKE_COMMAND} -E copy $<TARGET_FILE:libGLES_CM> $<TARGET_FILE_DIR:libGLES_CM>/translator/${LIB_PREFIX}GLES_CM_translator${CMAKE_SHARED_LIBRARY_SUFFIX}
2014 )
Corentin Wallez0866b292015-12-09 13:49:40 -05002015endif()
2016
Ben Claytone693b622019-09-05 12:48:37 +01002017if(BUILD_MARL)
Ben Claytone693b622019-09-05 12:48:37 +01002018 add_subdirectory(third_party/marl)
2019endif(BUILD_MARL)
2020
Chris Forbes3d27f2e2018-09-26 09:24:39 -07002021if(BUILD_VULKAN)
Dan Sinclair6480d4e2019-03-11 10:48:19 -04002022 if (NOT TARGET SPIRV-Tools)
2023 # This variable is also used by SPIRV-Tools to locate SPIRV-Headers
2024 set(SPIRV-Headers_SOURCE_DIR "${CMAKE_CURRENT_SOURCE_DIR}/third_party/SPIRV-Headers")
2025 list(APPEND VULKAN_INCLUDE_DIR "${SPIRV-Headers_SOURCE_DIR}/include")
Nicolas Capens4e9f5772019-01-31 15:17:13 -05002026
Dan Sinclair6480d4e2019-03-11 10:48:19 -04002027 add_subdirectory(third_party/SPIRV-Tools)
2028 endif()
Nicolas Capens4c9f04b2019-01-31 22:09:03 -05002029
Nicolas Capens2c99cf62019-08-28 15:36:19 -04002030 add_library(vk_swiftshader SHARED ${VULKAN_LIST})
2031
2032 set_target_properties(vk_swiftshader PROPERTIES
Chris Forbes3d27f2e2018-09-26 09:24:39 -07002033 INCLUDE_DIRECTORIES "${VULKAN_INCLUDE_DIR}"
2034 FOLDER "Vulkan"
Ben Clayton4ceb77d2019-04-24 12:09:59 +01002035 COMPILE_OPTIONS "${SWIFTSHADER_COMPILE_OPTIONS}"
Saman Samif4d2a442019-05-21 15:04:41 -04002036 COMPILE_DEFINITIONS "VK_EXPORT=;NO_SANITIZE_FUNCTION=;$<$<CONFIG:Debug>:DEBUGGER_WAIT_DIALOG>"
Chris Forbes3d27f2e2018-09-26 09:24:39 -07002037 )
Nicolas Capensd3545372019-08-09 13:59:18 -04002038
2039 if(WIN32)
Nicolas Capens2c99cf62019-08-28 15:36:19 -04002040 set_property(TARGET vk_swiftshader APPEND
Nicolas Capensd3545372019-08-09 13:59:18 -04002041 PROPERTY COMPILE_DEFINITIONS "VK_USE_PLATFORM_WIN32_KHR")
2042 elseif(LINUX)
Ben Claytona9af8832019-08-14 13:09:43 +01002043 if(X11)
Nicolas Capens2c99cf62019-08-28 15:36:19 -04002044 set_property(TARGET vk_swiftshader APPEND
Ben Claytona9af8832019-08-14 13:09:43 +01002045 PROPERTY COMPILE_DEFINITIONS "VK_USE_PLATFORM_XLIB_KHR")
2046 endif(X11)
2047 if(XCB)
Nicolas Capens2c99cf62019-08-28 15:36:19 -04002048 set_property(TARGET vk_swiftshader APPEND
Ben Claytona9af8832019-08-14 13:09:43 +01002049 PROPERTY COMPILE_DEFINITIONS "VK_USE_PLATFORM_XCB_KHR")
2050 endif(XCB)
Nicolas Capensd3545372019-08-09 13:59:18 -04002051 elseif(APPLE)
Nicolas Capens2c99cf62019-08-28 15:36:19 -04002052 set_property(TARGET vk_swiftshader APPEND
Nicolas Capensd3545372019-08-09 13:59:18 -04002053 PROPERTY COMPILE_DEFINITIONS "VK_USE_PLATFORM_MACOS_MVK")
2054 endif()
2055
Nicolas Capens2c99cf62019-08-28 15:36:19 -04002056 set_shared_library_export_map(vk_swiftshader ${SOURCE_DIR}/Vulkan)
Ben Claytone693b622019-09-05 12:48:37 +01002057 target_link_libraries(vk_swiftshader ${Reactor} marl ${OS_LIBS} SPIRV-Tools SPIRV-Tools-opt)
Chris Forbes3d27f2e2018-09-26 09:24:39 -07002058 add_custom_command(
Nicolas Capens2c99cf62019-08-28 15:36:19 -04002059 TARGET vk_swiftshader
Chris Forbes3d27f2e2018-09-26 09:24:39 -07002060 POST_BUILD
Nicolas Capens2c99cf62019-08-28 15:36:19 -04002061 COMMAND ${CMAKE_COMMAND} -E make_directory $<TARGET_FILE_DIR:vk_swiftshader>/translator
2062 COMMAND ${CMAKE_COMMAND} -E copy $<TARGET_FILE:vk_swiftshader> $<TARGET_FILE_DIR:vk_swiftshader>/translator/${LIB_PREFIX}Vulkan_translator${CMAKE_SHARED_LIBRARY_SUFFIX}
Dan Sinclair1b8cd2d2019-03-14 10:51:05 -04002063 COMMAND ${CMAKE_COMMAND} -E make_directory ${CMAKE_BINARY_DIR}/${CMAKE_SYSTEM_NAME}/
Nicolas Capens2c99cf62019-08-28 15:36:19 -04002064 COMMAND ${CMAKE_COMMAND} -E copy $<TARGET_FILE:vk_swiftshader> ${CMAKE_BINARY_DIR}/${CMAKE_SYSTEM_NAME}/
Chris Forbes3d27f2e2018-09-26 09:24:39 -07002065 )
Paul Thomsona0b3a022019-06-24 17:16:55 +01002066
2067 # The vk_swiftshader_icd.json manifest file will point to ICD_LIBRARY_PATH.
2068 # Set ICD_LIBRARY_PATH to be a relative path similar to "./libvk_swiftshader.so", so both files can be moved.
2069 # A relative path is relative to the manifest file.
Nicolas Capens2c99cf62019-08-28 15:36:19 -04002070 set(ICD_LIBRARY_PATH "${CMAKE_SHARED_LIBRARY_PREFIX}vk_swiftshader${CMAKE_SHARED_LIBRARY_SUFFIX}")
Paul Thomsona0b3a022019-06-24 17:16:55 +01002071 if(WIN32)
2072 # The path is output to a JSON file, which requires backslashes to be escaped.
Ben Claytone671a692019-07-29 13:03:42 +01002073 set(ICD_LIBRARY_PATH ".\\\\${ICD_LIBRARY_PATH}")
Paul Thomsona0b3a022019-06-24 17:16:55 +01002074 else()
2075 set(ICD_LIBRARY_PATH "./${ICD_LIBRARY_PATH}")
2076 endif()
Ben Claytond9ce2582019-02-06 11:54:15 +00002077 configure_file(
2078 "${VULKAN_DIR}/vk_swiftshader_icd.json.tmpl"
Dan Sinclair1b8cd2d2019-03-14 10:51:05 -04002079 "${CMAKE_BINARY_DIR}/${CMAKE_SYSTEM_NAME}/vk_swiftshader_icd.json")
Chris Forbes3d27f2e2018-09-26 09:24:39 -07002080endif()
2081
Corentin Wallez0866b292015-12-09 13:49:40 -05002082###########################################################
Nicolas Capensf53adbd2017-01-06 12:47:46 -05002083# Sample programs
Corentin Wallez0866b292015-12-09 13:49:40 -05002084###########################################################
2085
Nicolas Capensf53adbd2017-01-06 12:47:46 -05002086if(BUILD_SAMPLES)
2087 if(WIN32)
2088 add_executable(OGLES2HelloAPI ${HELLO2_DIR}/OGLES2HelloAPI_Windows.cpp)
2089 set_target_properties(OGLES2HelloAPI PROPERTIES
Erwin Jansend46faeb2018-11-19 16:01:37 -08002090 INCLUDE_DIRECTORIES "${CMAKE_CURRENT_SOURCE_DIR}/include"
Ben Clayton4ceb77d2019-04-24 12:09:59 +01002091 COMPILE_OPTIONS "${SWIFTSHADER_COMPILE_OPTIONS}"
Nicolas Capensf53adbd2017-01-06 12:47:46 -05002092 COMPILE_DEFINITIONS "GL_GLEXT_PROTOTYPES"
2093 FOLDER "Samples"
2094 )
2095 target_link_libraries(OGLES2HelloAPI libEGL libGLESv2)
2096 set_property(TARGET OGLES2HelloAPI APPEND_STRING PROPERTY LINK_FLAGS "/SUBSYSTEM:WINDOWS")
2097 set(CMAKE_DEFAULT_STARTUP_PROJECT OGLES2HelloAPI)
2098 elseif(LINUX)
Chinmay Garde204ec082016-08-10 17:01:21 -07002099 add_executable(OGLES2HelloAPI ${HELLO2_DIR}/OGLES2HelloAPI_LinuxX11.cpp)
Nicolas Capensb94a2fc2016-10-26 16:57:35 -04002100 set_target_properties(OGLES2HelloAPI PROPERTIES
Erwin Jansend46faeb2018-11-19 16:01:37 -08002101 INCLUDE_DIRECTORIES "${CMAKE_CURRENT_SOURCE_DIR}/include"
Ben Clayton4ceb77d2019-04-24 12:09:59 +01002102 COMPILE_OPTIONS "${SWIFTSHADER_COMPILE_OPTIONS}"
Nicolas Capensb94a2fc2016-10-26 16:57:35 -04002103 COMPILE_DEFINITIONS "GL_GLEXT_PROTOTYPES"
2104 )
Ben Claytona9af8832019-08-14 13:09:43 +01002105 target_link_libraries(OGLES2HelloAPI dl ${X11} libEGL libGLESv2) # Explicitly link our "lib*" targets, not the platform provided "EGL" and "GLESv2"
Chinmay Garde204ec082016-08-10 17:01:21 -07002106 elseif(APPLE)
2107 add_executable(OGLES2HelloAPI MACOSX_BUNDLE
2108 ${HELLO2_DIR}/OGLES2HelloAPI_OSX.mm
2109 ${HELLO2_DIR}/Build/OSX/en.lproj/MainMenu.xib
2110 )
2111 set_target_properties(OGLES2HelloAPI PROPERTIES
Erwin Jansend46faeb2018-11-19 16:01:37 -08002112 INCLUDE_DIRECTORIES "${CMAKE_CURRENT_SOURCE_DIR}/include"
Ben Clayton4ceb77d2019-04-24 12:09:59 +01002113 COMPILE_OPTIONS "${SWIFTSHADER_COMPILE_OPTIONS};-Wno-deprecated-declarations" # 'NSTitledWindowMask', 'NSClosableWindowMask' is deprecated
Chinmay Garde204ec082016-08-10 17:01:21 -07002114 COMPILE_DEFINITIONS "GL_GLEXT_PROTOTYPES"
2115 MACOSX_BUNDLE_INFO_PLIST "${HELLO2_DIR}/Build/OSX/Info.plist"
2116 )
2117 target_link_libraries(OGLES2HelloAPI libEGL libGLESv2 ${OS_LIBS})
2118 set_source_files_properties(${HELLO2_DIR}/Build/OSX/en.lproj/MainMenu.xib PROPERTIES
2119 MACOSX_PACKAGE_LOCATION "Resources"
2120 )
2121 endif()
Corentin Wallez0866b292015-12-09 13:49:40 -05002122endif()
Nicolas Capens16594842017-04-26 10:01:37 -04002123
Nicolas Capensc07dc4b2018-08-06 14:20:45 -04002124if(BUILD_TESTS)
2125 set(REACTOR_UNIT_TESTS_LIST
2126 ${SOURCE_DIR}/Reactor/ReactorUnitTests.cpp
Erwin Jansend46faeb2018-11-19 16:01:37 -08002127 ${CMAKE_CURRENT_SOURCE_DIR}/third_party/googletest/googletest/src/gtest-all.cc
Nicolas Capens16594842017-04-26 10:01:37 -04002128 )
2129
Nicolas Capensc07dc4b2018-08-06 14:20:45 -04002130 set(REACTOR_UNIT_TESTS_INCLUDE_DIR
Erwin Jansend46faeb2018-11-19 16:01:37 -08002131 ${CMAKE_CURRENT_SOURCE_DIR}/third_party/googletest/googletest/include
2132 ${CMAKE_CURRENT_SOURCE_DIR}/third_party/googletest/googletest/
Nicolas Capens16594842017-04-26 10:01:37 -04002133 )
2134
Nicolas Capensc07dc4b2018-08-06 14:20:45 -04002135 add_executable(ReactorUnitTests ${REACTOR_UNIT_TESTS_LIST})
2136 set_target_properties(ReactorUnitTests PROPERTIES
2137 INCLUDE_DIRECTORIES "${REACTOR_UNIT_TESTS_INCLUDE_DIR}"
Ben Clayton4ceb77d2019-04-24 12:09:59 +01002138 COMPILE_OPTIONS "${SWIFTSHADER_COMPILE_OPTIONS}"
Nicolas Capens16594842017-04-26 10:01:37 -04002139 FOLDER "Tests"
2140 )
Nicolas Capensc07dc4b2018-08-06 14:20:45 -04002141
2142 if(NOT WIN32 AND ${REACTOR_BACKEND} STREQUAL "Subzero")
2143 target_link_libraries(ReactorUnitTests ${Reactor} pthread dl)
Nicolas Capens16594842017-04-26 10:01:37 -04002144 else()
Nicolas Capensc07dc4b2018-08-06 14:20:45 -04002145 target_link_libraries(ReactorUnitTests ${Reactor})
Nicolas Capens16594842017-04-26 10:01:37 -04002146 endif()
2147endif()
Nicolas Capens39760e12018-06-04 15:55:45 -04002148
2149if(BUILD_TESTS)
Ben Claytoneba396c2019-04-07 12:42:43 +01002150 set(GLES_UNITTESTS_LIST
Erwin Jansend46faeb2018-11-19 16:01:37 -08002151 ${CMAKE_CURRENT_SOURCE_DIR}/tests/GLESUnitTests/main.cpp
2152 ${CMAKE_CURRENT_SOURCE_DIR}/tests/GLESUnitTests/unittests.cpp
2153 ${CMAKE_CURRENT_SOURCE_DIR}/third_party/googletest/googletest/src/gtest-all.cc
Nicolas Capens39760e12018-06-04 15:55:45 -04002154 )
2155
Ben Claytoneba396c2019-04-07 12:42:43 +01002156 set(GLES_UNITTESTS_INCLUDE_DIR
Erwin Jansend46faeb2018-11-19 16:01:37 -08002157 ${CMAKE_CURRENT_SOURCE_DIR}/third_party/googletest/googletest/include/
2158 ${CMAKE_CURRENT_SOURCE_DIR}/third_party/googletest/googlemock/include/
2159 ${CMAKE_CURRENT_SOURCE_DIR}/third_party/googletest/googletest/
2160 ${CMAKE_CURRENT_SOURCE_DIR}/include/
Nicolas Capens39760e12018-06-04 15:55:45 -04002161 )
2162
Ben Claytoneba396c2019-04-07 12:42:43 +01002163 add_executable(gles-unittests ${GLES_UNITTESTS_LIST})
2164 set_target_properties(gles-unittests PROPERTIES
2165 INCLUDE_DIRECTORIES "${GLES_UNITTESTS_INCLUDE_DIR}"
Nicolas Capens39760e12018-06-04 15:55:45 -04002166 FOLDER "Tests"
Ben Clayton4ceb77d2019-04-24 12:09:59 +01002167 COMPILE_OPTIONS "${SWIFTSHADER_COMPILE_OPTIONS}"
Nicolas Capens39760e12018-06-04 15:55:45 -04002168 COMPILE_DEFINITIONS "STANDALONE"
2169 )
2170
Ben Claytoneba396c2019-04-07 12:42:43 +01002171 target_link_libraries(gles-unittests libEGL libGLESv2 ${OS_LIBS})
Stephen Whitee6ab01f2019-04-04 14:31:25 -04002172 if(ANDROID)
Ben Claytoneba396c2019-04-07 12:42:43 +01002173 target_link_libraries(gles-unittests -landroid)
Stephen Whitee6ab01f2019-04-04 14:31:25 -04002174 endif()
Ben Clayton30b6b592019-08-07 15:04:11 +01002175endif(BUILD_TESTS)
2176
Ben Claytond6c61362019-08-14 18:16:01 +01002177if(BUILD_TESTS)
Ben Claytond6c61362019-08-14 18:16:01 +01002178 # Math unit tests
Nicolas Capens5c09b6a2019-08-07 11:13:03 -04002179 set(MATH_UNITTESTS_LIST
2180 ${CMAKE_CURRENT_SOURCE_DIR}/tests/MathUnitTests/main.cpp
2181 ${CMAKE_CURRENT_SOURCE_DIR}/tests/MathUnitTests/unittests.cpp
2182 ${CMAKE_CURRENT_SOURCE_DIR}/third_party/googletest/googletest/src/gtest-all.cc
2183 )
2184
2185 set(MATH_UNITTESTS_INCLUDE_DIR
2186 ${CMAKE_CURRENT_SOURCE_DIR}/third_party/googletest/googletest/include/
2187 ${CMAKE_CURRENT_SOURCE_DIR}/third_party/googletest/googlemock/include/
2188 ${CMAKE_CURRENT_SOURCE_DIR}/third_party/googletest/googletest/
2189 ${CMAKE_CURRENT_SOURCE_DIR}/src/
2190 )
2191
2192 add_executable(math-unittests ${MATH_UNITTESTS_LIST})
2193 set_target_properties(math-unittests PROPERTIES
2194 INCLUDE_DIRECTORIES "${MATH_UNITTESTS_INCLUDE_DIR}"
2195 FOLDER "Tests"
2196 COMPILE_OPTIONS "${SWIFTSHADER_COMPILE_OPTIONS}"
2197 )
2198
2199 if(NOT WIN32)
2200 target_link_libraries(math-unittests pthread)
2201 endif()
2202endif()
2203
Ben Clayton654540e2019-02-01 13:08:23 +00002204if(BUILD_TESTS AND BUILD_VULKAN)
Ben Claytoneba396c2019-04-07 12:42:43 +01002205 set(VK_UNITTESTS_LIST
Ben Claytonabb57852019-03-01 14:33:35 +00002206 ${CMAKE_CURRENT_SOURCE_DIR}/tests/VulkanUnitTests/Device.cpp
Ben Clayton654540e2019-02-01 13:08:23 +00002207 ${CMAKE_CURRENT_SOURCE_DIR}/tests/VulkanUnitTests/Driver.cpp
2208 ${CMAKE_CURRENT_SOURCE_DIR}/tests/VulkanUnitTests/main.cpp
2209 ${CMAKE_CURRENT_SOURCE_DIR}/tests/VulkanUnitTests/unittests.cpp
2210 ${CMAKE_CURRENT_SOURCE_DIR}/third_party/googletest/googletest/src/gtest-all.cc
2211 )
2212
Ben Claytoneba396c2019-04-07 12:42:43 +01002213 set(VK_UNITTESTS_INCLUDE_DIR
Ben Clayton654540e2019-02-01 13:08:23 +00002214 ${CMAKE_CURRENT_SOURCE_DIR}/third_party/googletest/googletest/include/
2215 ${CMAKE_CURRENT_SOURCE_DIR}/third_party/googletest/googlemock/include/
2216 ${CMAKE_CURRENT_SOURCE_DIR}/third_party/googletest/googletest/
Ben Claytonabb57852019-03-01 14:33:35 +00002217 ${CMAKE_CURRENT_SOURCE_DIR}/third_party/SPIRV-Tools/include
Ben Clayton654540e2019-02-01 13:08:23 +00002218 ${CMAKE_CURRENT_SOURCE_DIR}/include/
2219 )
2220
Ben Claytoneba396c2019-04-07 12:42:43 +01002221 add_executable(vk-unittests ${VK_UNITTESTS_LIST})
Nicolas Capens2c99cf62019-08-28 15:36:19 -04002222 add_dependencies(vk-unittests vk_swiftshader)
2223
Ben Clayton654540e2019-02-01 13:08:23 +00002224 set_target_properties(vk-unittests PROPERTIES
Ben Claytoneba396c2019-04-07 12:42:43 +01002225 INCLUDE_DIRECTORIES "${VK_UNITTESTS_INCLUDE_DIR}"
Ben Clayton654540e2019-02-01 13:08:23 +00002226 FOLDER "Tests"
Ben Clayton4ceb77d2019-04-24 12:09:59 +01002227 COMPILE_OPTIONS "${SWIFTSHADER_COMPILE_OPTIONS}"
Ben Clayton654540e2019-02-01 13:08:23 +00002228 COMPILE_DEFINITIONS "STANDALONE"
2229 )
2230
Ben Claytonabb57852019-03-01 14:33:35 +00002231 target_link_libraries(vk-unittests ${OS_LIBS} SPIRV-Tools)
Ben Clayton30b6b592019-08-07 15:04:11 +01002232endif(BUILD_TESTS AND BUILD_VULKAN)