Skip to content

Commit 34f316e

Browse files
authored
Use common CLR_CMAKE_* variables in more places (#31659)
* Use common CLR_CMAKE_* variables in more places * Remove obsolete paragraph from README
1 parent d491056 commit 34f316e

File tree

102 files changed

+578
-585
lines changed

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

102 files changed

+578
-585
lines changed

eng/native/configureplatform.cmake

Lines changed: 75 additions & 48 deletions
Original file line numberDiff line numberDiff line change
@@ -1,20 +1,12 @@
11
include(CheckPIESupported)
22

3-
# All code we build should be compiled as position independent
4-
check_pie_supported(OUTPUT_VARIABLE PIE_SUPPORT_OUTPUT LANGUAGES CXX)
5-
if(NOT MSVC AND NOT CMAKE_CXX_LINK_PIE_SUPPORTED)
6-
message(WARNING "PIE is not supported at link time: ${PIE_SUPPORT_OUTPUT}.\n"
7-
"PIE link options will not be passed to linker.")
8-
endif()
9-
set(CMAKE_POSITION_INDEPENDENT_CODE ON)
10-
113
#----------------------------------------
124
# Detect and set platform variable names
135
# - for non-windows build platform & architecture is detected using inbuilt CMAKE variables and cross target component configure
146
# - for windows we use the passed in parameter to CMAKE to determine build arch
157
#----------------------------------------
168
set(CLR_CMAKE_HOST_OS ${CMAKE_SYSTEM_NAME})
17-
if(CMAKE_SYSTEM_NAME STREQUAL Linux)
9+
if(CLR_CMAKE_HOST_OS STREQUAL Linux)
1810
set(CLR_CMAKE_HOST_UNIX 1)
1911
if(CLR_CROSS_COMPONENTS_BUILD)
2012
# CMAKE_HOST_SYSTEM_PROCESSOR returns the value of `uname -p` on host.
@@ -42,6 +34,7 @@ if(CMAKE_SYSTEM_NAME STREQUAL Linux)
4234
set(CLR_CMAKE_HOST_UNIX_AMD64 1)
4335
elseif(CMAKE_SYSTEM_PROCESSOR STREQUAL armv7l)
4436
set(CLR_CMAKE_HOST_UNIX_ARM 1)
37+
set(CLR_CMAKE_HOST_UNIX_ARMV7L 1)
4538
elseif(CMAKE_SYSTEM_PROCESSOR STREQUAL arm)
4639
set(CLR_CMAKE_HOST_UNIX_ARM 1)
4740
elseif(CMAKE_SYSTEM_PROCESSOR STREQUAL aarch64)
@@ -72,54 +65,62 @@ if(CMAKE_SYSTEM_NAME STREQUAL Linux)
7265
elseif(CLR_CMAKE_LINUX_ID STREQUAL alpine)
7366
set(CLR_CMAKE_HOST_ALPINE_LINUX 1)
7467
set(CLR_CMAKE_HOST_OS ${CLR_CMAKE_LINUX_ID})
68+
elseif(CLR_CMAKE_LINUX_ID STREQUAL android)
69+
set(CLR_CMAKE_HOST_ANDROID 1)
70+
set(CLR_CMAKE_HOST_OS ${CLR_CMAKE_LINUX_ID})
7571
endif()
7672
endif(DEFINED CLR_CMAKE_LINUX_ID)
77-
endif(CMAKE_SYSTEM_NAME STREQUAL Linux)
73+
endif(CLR_CMAKE_HOST_OS STREQUAL Linux)
7874

79-
if(CMAKE_SYSTEM_NAME STREQUAL Darwin)
80-
set(CLR_CMAKE_HOST_UNIX 1)
81-
set(CLR_CMAKE_HOST_UNIX_AMD64 1)
82-
set(CLR_CMAKE_HOST_DARWIN 1)
83-
set(CMAKE_ASM_COMPILE_OBJECT "${CMAKE_C_COMPILER} <FLAGS> <DEFINES> <INCLUDES> -o <OBJECT> -c <SOURCE>")
84-
endif(CMAKE_SYSTEM_NAME STREQUAL Darwin)
85-
86-
if(CMAKE_SYSTEM_NAME STREQUAL FreeBSD)
87-
set(CLR_CMAKE_HOST_UNIX 1)
88-
set(CLR_CMAKE_HOST_UNIX_AMD64 1)
89-
set(CLR_CMAKE_HOST_FREEBSD 1)
90-
endif(CMAKE_SYSTEM_NAME STREQUAL FreeBSD)
75+
if(CLR_CMAKE_HOST_OS STREQUAL Darwin)
76+
set(CLR_CMAKE_HOST_UNIX 1)
77+
set(CLR_CMAKE_HOST_UNIX_AMD64 1)
78+
set(CLR_CMAKE_HOST_DARWIN 1)
79+
set(CMAKE_ASM_COMPILE_OBJECT "${CMAKE_C_COMPILER} <FLAGS> <DEFINES> <INCLUDES> -o <OBJECT> -c <SOURCE>")
80+
endif(CLR_CMAKE_HOST_OS STREQUAL Darwin)
9181

92-
if(CMAKE_SYSTEM_NAME STREQUAL OpenBSD)
93-
set(CLR_CMAKE_HOST_UNIX 1)
94-
set(CLR_CMAKE_HOST_UNIX_AMD64 1)
95-
set(CLR_CMAKE_HOST_OPENBSD 1)
96-
endif(CMAKE_SYSTEM_NAME STREQUAL OpenBSD)
82+
if(CLR_CMAKE_HOST_OS STREQUAL FreeBSD)
83+
set(CLR_CMAKE_HOST_UNIX 1)
84+
set(CLR_CMAKE_HOST_UNIX_AMD64 1)
85+
set(CLR_CMAKE_HOST_FREEBSD 1)
86+
endif(CLR_CMAKE_HOST_OS STREQUAL FreeBSD)
9787

98-
if(CMAKE_SYSTEM_NAME STREQUAL NetBSD)
99-
set(CLR_CMAKE_HOST_UNIX 1)
100-
set(CLR_CMAKE_HOST_UNIX_AMD64 1)
101-
set(CLR_CMAKE_HOST_NETBSD 1)
102-
endif(CMAKE_SYSTEM_NAME STREQUAL NetBSD)
88+
if(CLR_CMAKE_HOST_OS STREQUAL OpenBSD)
89+
set(CLR_CMAKE_HOST_UNIX 1)
90+
set(CLR_CMAKE_HOST_UNIX_AMD64 1)
91+
set(CLR_CMAKE_HOST_OPENBSD 1)
92+
endif(CLR_CMAKE_HOST_OS STREQUAL OpenBSD)
10393

104-
if(CMAKE_SYSTEM_NAME STREQUAL SunOS)
105-
set(CLR_CMAKE_HOST_UNIX 1)
106-
EXECUTE_PROCESS(
107-
COMMAND isainfo -n
108-
OUTPUT_VARIABLE SUNOS_NATIVE_INSTRUCTION_SET
109-
)
110-
if(SUNOS_NATIVE_INSTRUCTION_SET MATCHES "amd64")
94+
if(CLR_CMAKE_HOST_OS STREQUAL NetBSD)
95+
set(CLR_CMAKE_HOST_UNIX 1)
11196
set(CLR_CMAKE_HOST_UNIX_AMD64 1)
112-
set(CMAKE_SYSTEM_PROCESSOR "amd64")
113-
else()
114-
clr_unknown_arch()
115-
endif()
116-
set(CLR_CMAKE_HOST_SUNOS 1)
117-
endif(CMAKE_SYSTEM_NAME STREQUAL SunOS)
97+
set(CLR_CMAKE_HOST_NETBSD 1)
98+
endif(CLR_CMAKE_HOST_OS STREQUAL NetBSD)
11899

119-
if(CMAKE_SYSTEM_NAME STREQUAL Windows)
120-
set(CLR_CMAKE_HOST_OS Windows_NT)
121-
endif(CMAKE_SYSTEM_NAME STREQUAL Windows)
100+
if(CLR_CMAKE_HOST_OS STREQUAL SunOS)
101+
set(CLR_CMAKE_HOST_UNIX 1)
102+
EXECUTE_PROCESS(
103+
COMMAND isainfo -n
104+
OUTPUT_VARIABLE SUNOS_NATIVE_INSTRUCTION_SET)
122105

106+
if(SUNOS_NATIVE_INSTRUCTION_SET MATCHES "amd64")
107+
set(CLR_CMAKE_HOST_UNIX_AMD64 1)
108+
set(CMAKE_SYSTEM_PROCESSOR "amd64")
109+
else()
110+
clr_unknown_arch()
111+
endif()
112+
113+
set(CLR_CMAKE_HOST_SUNOS 1)
114+
endif(CLR_CMAKE_HOST_OS STREQUAL SunOS)
115+
116+
if(CLR_CMAKE_HOST_OS STREQUAL Windows)
117+
set(CLR_CMAKE_HOST_OS Windows_NT)
118+
set(CLR_CMAKE_HOST_WIN32 1)
119+
endif(CLR_CMAKE_HOST_OS STREQUAL Windows)
120+
121+
if(CLR_CMAKE_HOST_OS STREQUAL Emscripten)
122+
set(CLR_CMAKE_HOST_ARCH_WASM 1)
123+
endif(CLR_CMAKE_HOST_OS STREQUAL Emscripten)
123124

124125
#--------------------------------------------
125126
# This repo builds two set of binaries
@@ -135,6 +136,10 @@ endif(CMAKE_SYSTEM_NAME STREQUAL Windows)
135136
if(CLR_CMAKE_HOST_UNIX_ARM)
136137
set(CLR_CMAKE_HOST_ARCH_ARM 1)
137138
set(CLR_CMAKE_HOST_ARCH "arm")
139+
140+
if(CLR_CMAKE_HOST_HOST_ARMV7L)
141+
set(CLR_CMAKE_HOST_ARCH_ARMV7L 1)
142+
endif()
138143
elseif(CLR_CMAKE_HOST_UNIX_ARM64)
139144
set(CLR_CMAKE_HOST_ARCH_ARM64 1)
140145
set(CLR_CMAKE_HOST_ARCH "arm64")
@@ -206,6 +211,12 @@ if(CLR_CMAKE_TARGET_OS STREQUAL alpine)
206211
set(CLR_CMAKE_TARGET_ALPINE_LINUX 1)
207212
endif(CLR_CMAKE_TARGET_OS STREQUAL alpine)
208213

214+
if(CLR_CMAKE_TARGET_OS STREQUAL android)
215+
set(CLR_CMAKE_TARGET_UNIX 1)
216+
set(CLR_CMAKE_TARGET_LINUX 1)
217+
set(CLR_CMAKE_TARGET_ANDROID 1)
218+
endif(CLR_CMAKE_TARGET_OS STREQUAL android)
219+
209220
if(CLR_CMAKE_TARGET_OS STREQUAL Darwin)
210221
set(CLR_CMAKE_TARGET_UNIX 1)
211222
set(CLR_CMAKE_TARGET_DARWIN 1)
@@ -267,3 +278,19 @@ else()
267278
message(FATAL_ERROR "Invalid host and target os/arch combination. Host Arch: ${CLR_CMAKE_HOST_ARCH} Target Arch: ${CLR_CMAKE_TARGET_ARCH}")
268279
endif()
269280
endif()
281+
282+
if(NOT CLR_CMAKE_HOST_ARCH_WASM)
283+
# All code we build should be compiled as position independent
284+
get_property(languages GLOBAL PROPERTY ENABLED_LANGUAGES)
285+
if("CXX" IN_LIST languages)
286+
set(CLR_PIE_LANGUAGE CXX)
287+
else()
288+
set(CLR_PIE_LANGUAGE C)
289+
endif()
290+
check_pie_supported(OUTPUT_VARIABLE PIE_SUPPORT_OUTPUT LANGUAGES ${CLR_PIE_LANGUAGE})
291+
if(NOT MSVC AND NOT CMAKE_${CLR_PIE_LANGUAGE}_LINK_PIE_SUPPORTED)
292+
message(WARNING "PIE is not supported at link time: ${PIE_SUPPORT_OUTPUT}.\n"
293+
"PIE link options will not be passed to linker.")
294+
endif()
295+
set(CMAKE_POSITION_INDEPENDENT_CODE ON)
296+
endif(NOT CLR_CMAKE_HOST_ARCH_WASM)

src/coreclr/CMakeLists.txt

Lines changed: 13 additions & 11 deletions
Original file line numberDiff line numberDiff line change
@@ -5,13 +5,15 @@ cmake_policy(SET CMP0042 NEW)
55
# Set the project name
66
project(CoreCLR)
77

8+
include(${CLR_ENG_NATIVE_DIR}/configureplatform.cmake)
9+
810
# Include cmake functions
911
include(${CLR_ENG_NATIVE_DIR}/functions.cmake)
1012

11-
if (WIN32)
13+
if (CLR_CMAKE_HOST_WIN32)
1214
message(STATUS "VS_PLATFORM_TOOLSET is ${CMAKE_VS_PLATFORM_TOOLSET}")
1315
message(STATUS "VS_PLATFORM_NAME is ${CMAKE_VS_PLATFORM_NAME}")
14-
endif (WIN32)
16+
endif (CLR_CMAKE_HOST_WIN32)
1517

1618
# Set commonly used directory names
1719
set(CLR_DIR ${CMAKE_CURRENT_SOURCE_DIR})
@@ -34,8 +36,8 @@ OPTION(CLR_CMAKE_ENABLE_CODE_COVERAGE "Enable code coverage" OFF)
3436
OPTION(CLR_CMAKE_WARNINGS_ARE_ERRORS "Warnings are errors" ON)
3537

3638
# Ensure other tools are present
37-
if (WIN32)
38-
if(CLR_CMAKE_HOST_ARCH STREQUAL arm)
39+
if (CLR_CMAKE_HOST_WIN32)
40+
if(CLR_CMAKE_HOST_ARCH_ARM)
3941

4042
# Confirm that Windows SDK is present
4143
if(NOT DEFINED CMAKE_VS_WINDOWS_TARGET_PLATFORM_VERSION OR CMAKE_VS_WINDOWS_TARGET_PLATFORM_VERSION STREQUAL "" )
@@ -53,7 +55,7 @@ if (WIN32)
5355
# Enable generic assembly compilation to avoid CMake generate VS proj files that explicitly
5456
# use ml[64].exe as the assembler.
5557
enable_language(ASM)
56-
elseif(CLR_CMAKE_HOST_ARCH STREQUAL arm64)
58+
elseif(CLR_CMAKE_HOST_ARCH_ARM64)
5759

5860
# Confirm that Windows SDK is present
5961
if(NOT DEFINED CMAKE_VS_WINDOWS_TARGET_PLATFORM_VERSION OR CMAKE_VS_WINDOWS_TARGET_PLATFORM_VERSION STREQUAL "" )
@@ -81,7 +83,7 @@ if (WIN32)
8183
message(FATAL_ERROR "MC not found")
8284
endif()
8385

84-
else (WIN32)
86+
else (CLR_CMAKE_HOST_WIN32)
8587
enable_language(ASM)
8688

8789
# Ensure that awk is present
@@ -95,7 +97,7 @@ else (WIN32)
9597
# to prevent applications to create executable memory mappings.
9698
find_program(PAXCTL paxctl)
9799

98-
if (CMAKE_SYSTEM_NAME STREQUAL Darwin)
100+
if (CLR_CMAKE_HOST_DARWIN)
99101

100102
# Ensure that dsymutil and strip are present
101103
find_program(DSYMUTIL dsymutil)
@@ -109,7 +111,7 @@ else (WIN32)
109111
endif()
110112

111113
endif()
112-
endif(WIN32)
114+
endif(CLR_CMAKE_HOST_WIN32)
113115

114116
#----------------------------------------------------
115117
# Configure compiler settings for environment
@@ -146,7 +148,7 @@ add_subdirectory(src/pal/prebuilt/inc)
146148

147149
add_subdirectory(src/debug/debug-pal)
148150

149-
if(WIN32)
151+
if(CLR_CMAKE_TARGET_WIN32)
150152
add_subdirectory(src/gc/sample)
151153
endif()
152154

@@ -155,10 +157,10 @@ add_subdirectory(src/tools/crossgen2/jitinterface)
155157
# Above projects do not build with these compile options
156158
# All of the compiler options are specified in file compileoptions.cmake
157159
# Do not add any new options here. They should be added in compileoptions.cmake
158-
if(WIN32)
160+
if(CLR_CMAKE_HOST_WIN32)
159161
add_compile_options(/FIWarningControl.h) # force include of WarningControl.h
160162
add_compile_options(/Zl) # omit default library name in .OBJ
161-
endif(WIN32)
163+
endif(CLR_CMAKE_HOST_WIN32)
162164

163165
#--------------------------------
164166
# Definition directives

src/coreclr/clrdefinitions.cmake

Lines changed: 7 additions & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -6,7 +6,7 @@ set(PRERELEASE 1)
66

77
# Features we're currently flighting, but don't intend to ship in officially supported releases
88
if (PRERELEASE)
9-
add_definitions(-DFEATURE_UTF8STRING)
9+
add_definitions(-DFEATURE_UTF8STRING)
1010
# add_definitions(-DFEATURE_XXX)
1111
endif (PRERELEASE)
1212

@@ -22,11 +22,11 @@ if (CLR_CMAKE_TARGET_ARCH_ARM64)
2222
endif()
2323
add_definitions(-DFEATURE_MULTIREG_RETURN)
2424
elseif (CLR_CMAKE_TARGET_ARCH_ARM)
25-
if (WIN32 AND NOT DEFINED CLR_CROSS_COMPONENTS_BUILD)
25+
if (CLR_CMAKE_HOST_WIN32 AND NOT DEFINED CLR_CROSS_COMPONENTS_BUILD)
2626
# Set this to ensure we can use Arm SDK for Desktop binary linkage when doing native (Arm32) build
2727
add_definitions(-D_ARM_WINAPI_PARTITION_DESKTOP_SDK_AVAILABLE)
2828
add_definitions(-D_ARM_WORKAROUND_)
29-
endif (WIN32 AND NOT DEFINED CLR_CROSS_COMPONENTS_BUILD)
29+
endif (CLR_CMAKE_HOST_WIN32 AND NOT DEFINED CLR_CROSS_COMPONENTS_BUILD)
3030
add_definitions(-DFEATURE_EMULATE_SINGLESTEP)
3131
endif (CLR_CMAKE_TARGET_ARCH_ARM64)
3232

@@ -58,14 +58,14 @@ add_definitions(-DDEBUGGING_SUPPORTED)
5858
add_compile_definitions($<$<NOT:$<BOOL:$<TARGET_PROPERTY:DAC_COMPONENT>>>:PROFILING_SUPPORTED>)
5959
add_compile_definitions($<$<BOOL:$<TARGET_PROPERTY:DAC_COMPONENT>>:PROFILING_SUPPORTED_DATA>)
6060

61-
if(WIN32)
61+
if(CLR_CMAKE_HOST_WIN32)
6262
add_definitions(-DWIN32)
6363
add_definitions(-D_WIN32)
6464
add_definitions(-DWINVER=0x0602)
6565
add_definitions(-D_WIN32_WINNT=0x0602)
6666
add_definitions(-DWIN32_LEAN_AND_MEAN)
6767
add_definitions(-D_CRT_SECURE_NO_WARNINGS)
68-
endif(WIN32)
68+
endif(CLR_CMAKE_HOST_WIN32)
6969
if(CLR_CMAKE_TARGET_WIN32)
7070
if(CLR_CMAKE_TARGET_ARCH_AMD64 OR CLR_CMAKE_TARGET_ARCH_I386)
7171
# Only enable edit and continue on windows x86 and x64
@@ -134,9 +134,9 @@ if(CLR_CMAKE_TARGET_UNIX)
134134
add_definitions(-DFEATURE_EVENTSOURCE_XPLAT)
135135
endif(CLR_CMAKE_TARGET_UNIX)
136136
# NetBSD doesn't implement this feature
137-
if(NOT CMAKE_SYSTEM_NAME STREQUAL NetBSD)
137+
if(NOT CLR_CMAKE_TARGET_NETBSD)
138138
add_definitions(-DFEATURE_HIJACK)
139-
endif(NOT CMAKE_SYSTEM_NAME STREQUAL NetBSD)
139+
endif(NOT CLR_CMAKE_TARGET_NETBSD)
140140
add_definitions(-DFEATURE_ICASTABLE)
141141
if (CLR_CMAKE_TARGET_WIN32 AND (CLR_CMAKE_TARGET_ARCH_AMD64 OR CLR_CMAKE_TARGET_ARCH_I386 OR CLR_CMAKE_TARGET_ARCH_ARM64))
142142
add_definitions(-DFEATURE_INTEROP_DEBUGGING)

src/coreclr/configurecompiler.cmake

Lines changed: 2 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -10,7 +10,6 @@ cmake_policy(SET CMP0083 NEW)
1010

1111
include(CheckCXXCompilerFlag)
1212

13-
include(${CLR_ENG_NATIVE_DIR}/configureplatform.cmake)
1413
# "configureoptimization.cmake" must be included after CLR_CMAKE_HOST_UNIX has been set.
1514
include(${CMAKE_CURRENT_LIST_DIR}/configureoptimization.cmake)
1615

@@ -235,14 +234,14 @@ if (CLR_CMAKE_HOST_UNIX)
235234
endif(CLR_CMAKE_HOST_NETBSD)
236235
endif(CLR_CMAKE_HOST_UNIX)
237236

238-
if (WIN32)
237+
if (CLR_CMAKE_HOST_WIN32)
239238
add_definitions(-DHOST_WINDOWS)
240239

241240
# Define the CRT lib references that link into Desktop imports
242241
set(STATIC_MT_CRT_LIB "libcmt$<$<OR:$<CONFIG:Debug>,$<CONFIG:Checked>>:d>.lib")
243242
set(STATIC_MT_VCRT_LIB "libvcruntime$<$<OR:$<CONFIG:Debug>,$<CONFIG:Checked>>:d>.lib")
244243
set(STATIC_MT_CPP_LIB "libcpmt$<$<OR:$<CONFIG:Debug>,$<CONFIG:Checked>>:d>.lib")
245-
endif(WIN32)
244+
endif(CLR_CMAKE_HOST_WIN32)
246245

247246
# Architecture specific files folder name
248247
if (CLR_CMAKE_TARGET_ARCH_AMD64)

src/coreclr/configureoptimization.cmake

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,4 @@
1-
if(WIN32)
1+
if(CLR_CMAKE_HOST_WIN32)
22
add_compile_options($<$<CONFIG:Debug>:/Od>)
33
add_compile_options($<$<CONFIG:Checked>:/O1>)
44
add_compile_options($<$<CONFIG:Release>:/Ox>)

0 commit comments

Comments
 (0)