mirrored from https://swiftshader.googlesource.com/SwiftShader
-
Notifications
You must be signed in to change notification settings - Fork 294
/
CMakeLists.txt
127 lines (117 loc) · 3.5 KB
/
CMakeLists.txt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
# Copyright 2020 The SwiftShader Authors. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
set(ROOT_PROJECT_COMPILE_OPTIONS
${SWIFTSHADER_COMPILE_OPTIONS}
${WARNINGS_AS_ERRORS}
)
set(SUBZERO_SRC_FILES
src/IceAssembler.cpp
src/IceCfg.cpp
src/IceCfgNode.cpp
src/IceClFlags.cpp
src/IceELFObjectWriter.cpp
src/IceELFSection.cpp
src/IceFixups.cpp
src/IceGlobalContext.cpp
src/IceGlobalInits.cpp
src/IceInst.cpp
src/IceInstrumentation.cpp
src/IceIntrinsics.cpp
src/IceLiveness.cpp
src/IceLoopAnalyzer.cpp
src/IceMangling.cpp
src/IceMemory.cpp
src/IceOperand.cpp
src/IceRangeSpec.cpp
src/IceRegAlloc.cpp
src/IceRevision.cpp
src/IceSwitchLowering.cpp
src/IceTargetLowering.cpp
src/IceThreading.cpp
src/IceTimerTree.cpp
src/IceTypes.cpp
src/IceVariableSplitting.cpp
)
if(ARCH STREQUAL "x86_64")
list(APPEND SUBZERO_SRC_FILES
src/IceAssemblerX8664.cpp
src/IceInstX8664.cpp
src/IceTargetLoweringX8664.cpp
)
set(SUBZERO_TARGET_CPU X8664)
elseif(ARCH STREQUAL "x86")
list(APPEND SUBZERO_SRC_FILES
src/IceAssemblerX8632.cpp
src/IceInstX8632.cpp
src/IceTargetLoweringX8632.cpp
)
set(SUBZERO_TARGET_CPU X8632)
elseif(ARCH STREQUAL "arm")
list(APPEND SUBZERO_SRC_FILES
src/IceAssemblerARM32.cpp
src/IceInstARM32.cpp
src/IceTargetLoweringARM32.cpp
)
set(SUBZERO_TARGET_CPU ARM32)
elseif(ARCH STREQUAL "mipsel")
list(APPEND SUBZERO_SRC_FILES
src/IceAssemblerMIPS32.cpp
src/IceInstMIPS32.cpp
src/IceTargetLoweringMIPS32.cpp
)
set(SUBZERO_TARGET_CPU MIPS32)
else()
message(WARNING "Architecture '${ARCH}' not supported by Subzero")
endif()
if(WIN32)
list(APPEND SUBZERO_COMPILE_OPTIONS
"/wd4146" # unary minus operator applied to unsigned type, result still unsigned
"/wd4334" # ''operator' : result of 32-bit shift implicitly converted to 64 bits (was 64-bit shift intended?)
"/wd4996" # The POSIX name for this item is deprecated. Instead, use the ISO C and C++ conformant name: new_name.
)
endif()
add_library(subzero STATIC EXCLUDE_FROM_ALL
${SUBZERO_SRC_FILES}
)
set_target_properties(subzero PROPERTIES
POSITION_INDEPENDENT_CODE 1
)
target_include_directories(subzero
PUBLIC
# Add lib root as include dir, so client code can do #include "src/..."
# TODO: Split out headers into separate 'include' directory.
"."
"pnacl-llvm/include"
)
target_compile_options(subzero
PRIVATE
${ROOT_PROJECT_COMPILE_OPTIONS}
${SUBZERO_COMPILE_OPTIONS}
)
target_compile_definitions(subzero
PUBLIC
"SZTARGET=${SUBZERO_TARGET_CPU}"
"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"
)
target_link_libraries(subzero
PUBLIC
llvm-subzero
)