From be3ebf6db06a374f32032a2755fa3beb59e892de Mon Sep 17 00:00:00 2001 From: Santiago Fernandez Madero Date: Mon, 3 Feb 2020 13:53:39 -0800 Subject: [PATCH] Link System.Globalization.Native into coreclr (#6928) * Link System.Globalization.Native into coreclr * Add more paths to coreclr subset filters * Fix linux build * PR Feedback * PR Feedback 2 * Fix build (pass -DREPO_ROOT_DIR only on coreclr atm), System.IO.Ports.Native needs to be built first * Remove version header file from static libs * Remove CORECLR_BUILD variable definition --- eng/pipelines/runtime.yml | 2 + src/coreclr/CMakeLists.txt | 2 + src/coreclr/build.cmd | 2 +- src/coreclr/build.sh | 2 +- .../src/dlls/mscoree/coreclr/CMakeLists.txt | 1 + .../src/libraries-native/CMakeLists.txt | 5 +++ .../CMakeLists.txt | 38 ++++++++++--------- .../CMakeLists.txt | 1 - .../System.IO.Ports.Native/CMakeLists.txt | 1 - .../Native/Unix/System.Native/CMakeLists.txt | 1 - .../System.Net.Security.Native/CMakeLists.txt | 1 - .../CMakeLists.txt | 1 - 12 files changed, 33 insertions(+), 24 deletions(-) create mode 100644 src/coreclr/src/libraries-native/CMakeLists.txt diff --git a/eng/pipelines/runtime.yml b/eng/pipelines/runtime.yml index e8003721c75e47..117601b565a8fa 100644 --- a/eng/pipelines/runtime.yml +++ b/eng/pipelines/runtime.yml @@ -56,6 +56,8 @@ jobs: - subset: coreclr include: - src/libraries/System.Private.CoreLib/* + - src/libraries/Native/Unix/System.Globalization.Native/* + - src/libraries/Native/Unix/Common/* exclude: - eng/Version.Details.xml - '*.md' diff --git a/src/coreclr/CMakeLists.txt b/src/coreclr/CMakeLists.txt index 30c01e5ac2459d..49046059eb2bd1 100644 --- a/src/coreclr/CMakeLists.txt +++ b/src/coreclr/CMakeLists.txt @@ -129,6 +129,8 @@ endif(CLR_CROSS_COMPONENTS_BUILD) #------------------- include(pgosupport.cmake) +add_subdirectory(src/libraries-native) + #----------------------------------------- # Add Projects # - project which require platform header not clr's diff --git a/src/coreclr/build.cmd b/src/coreclr/build.cmd index a524a808245275..7e8a3d74c61d2e 100644 --- a/src/coreclr/build.cmd +++ b/src/coreclr/build.cmd @@ -457,7 +457,7 @@ if %__BuildCrossArchNative% EQU 1 ( set __CMakeBinDir=%__CrossComponentBinDir% set "__CMakeBinDir=!__CMakeBinDir:\=/!" - set __ExtraCmakeArgs="-DCLR_CROSS_COMPONENTS_BUILD=1" "-DCLR_CMAKE_TARGET_ARCH=%__BuildArch%" "-DCLR_CMAKE_TARGET_OS=%__BuildOS%" "-DCLR_CMAKE_PGO_INSTRUMENT=%__PgoInstrument%" "-DCLR_CMAKE_OPTDATA_PATH=%__PgoOptDataPath%" "-DCLR_CMAKE_PGO_OPTIMIZE=%__PgoOptimize%" "-DCMAKE_SYSTEM_VERSION=10.0" "-DCLR_ENG_NATIVE_DIR=%__RepoRootDir%/eng/native" + set __ExtraCmakeArgs="-DCLR_CROSS_COMPONENTS_BUILD=1" "-DCLR_CMAKE_TARGET_ARCH=%__BuildArch%" "-DCLR_CMAKE_TARGET_OS=%__BuildOS%" "-DCLR_CMAKE_PGO_INSTRUMENT=%__PgoInstrument%" "-DCLR_CMAKE_OPTDATA_PATH=%__PgoOptDataPath%" "-DCLR_CMAKE_PGO_OPTIMIZE=%__PgoOptimize%" "-DCMAKE_SYSTEM_VERSION=10.0" "-DCLR_ENG_NATIVE_DIR=%__RepoRootDir%/eng/native" "-DCLR_REPO_ROOT_DIR=%__RepoRootDir%" call "%__SourceDir%\pal\tools\gen-buildsys.cmd" "%__ProjectDir%" "%__CrossCompIntermediatesDir%" %__VSVersion% %__CrossArch% !__ExtraCmakeArgs! if not !errorlevel! == 0 ( diff --git a/src/coreclr/build.sh b/src/coreclr/build.sh index 6d81c655130986..131fd7ca809f19 100755 --- a/src/coreclr/build.sh +++ b/src/coreclr/build.sh @@ -503,7 +503,7 @@ restore_optdata generate_event_logging # Build the coreclr (native) components. -__CMakeArgs="-DCLR_CMAKE_PGO_INSTRUMENT=$__PgoInstrument -DCLR_CMAKE_OPTDATA_PATH=$__PgoOptDataPath -DCLR_CMAKE_PGO_OPTIMIZE=$__PgoOptimize $__CMakeArgs" +__CMakeArgs="-DCLR_CMAKE_PGO_INSTRUMENT=$__PgoInstrument -DCLR_CMAKE_OPTDATA_PATH=$__PgoOptDataPath -DCLR_CMAKE_PGO_OPTIMIZE=$__PgoOptimize -DCLR_REPO_ROOT_DIR=\"$__RepoRootDir\" $__CMakeArgs" if [[ "$__SkipConfigure" == 0 && "$__CodeCoverage" == 1 ]]; then __CMakeArgs="-DCLR_CMAKE_ENABLE_CODE_COVERAGE=1 $__CMakeArgs" diff --git a/src/coreclr/src/dlls/mscoree/coreclr/CMakeLists.txt b/src/coreclr/src/dlls/mscoree/coreclr/CMakeLists.txt index efd7c60caa51cc..ca9d8cd835beb8 100644 --- a/src/coreclr/src/dlls/mscoree/coreclr/CMakeLists.txt +++ b/src/coreclr/src/dlls/mscoree/coreclr/CMakeLists.txt @@ -123,6 +123,7 @@ else() ${END_WHOLE_ARCHIVE} mscorrc_debug palrt + System.Globalization.Native-Static ) endif(WIN32) diff --git a/src/coreclr/src/libraries-native/CMakeLists.txt b/src/coreclr/src/libraries-native/CMakeLists.txt new file mode 100644 index 00000000000000..4835c645261e41 --- /dev/null +++ b/src/coreclr/src/libraries-native/CMakeLists.txt @@ -0,0 +1,5 @@ +set(CMAKE_INCLUDE_CURRENT_DIR ON) + +if(CLR_CMAKE_HOST_UNIX AND NOT CLR_CROSS_COMPONENTS_BUILD) + add_subdirectory(${CLR_REPO_ROOT_DIR}/src/libraries/Native/Unix/System.Globalization.Native System.Globalization.Native) +endif() diff --git a/src/libraries/Native/Unix/System.Globalization.Native/CMakeLists.txt b/src/libraries/Native/Unix/System.Globalization.Native/CMakeLists.txt index bef0bc6e6ed733..f6380c0b03af1c 100644 --- a/src/libraries/Native/Unix/System.Globalization.Native/CMakeLists.txt +++ b/src/libraries/Native/Unix/System.Globalization.Native/CMakeLists.txt @@ -58,23 +58,25 @@ set(NATIVEGLOBALIZATION_SOURCES ) include_directories(${UTYPES_H}) +include_directories("../Common") -add_library(System.Globalization.Native - SHARED - ${NATIVEGLOBALIZATION_SOURCES} - ${VERSION_FILE_PATH} -) +if (GEN_SHARED_LIB) + add_library(System.Globalization.Native + SHARED + ${NATIVEGLOBALIZATION_SOURCES} + ${VERSION_FILE_PATH} + ) -target_link_libraries(System.Globalization.Native - dl -) + target_link_libraries(System.Globalization.Native + dl + ) -install_library_and_symbols (System.Globalization.Native) + install_library_and_symbols (System.Globalization.Native) +endif() add_library(System.Globalization.Native-Static STATIC ${NATIVEGLOBALIZATION_SOURCES} - ${VERSION_FILE_PATH} ) # Disable the "lib" prefix and override default name @@ -84,11 +86,13 @@ set_target_properties(System.Globalization.Native-Static PROPERTIES OUTPUT_NAME install (TARGETS System.Globalization.Native-Static DESTINATION .) if(NOT CMAKE_SYSTEM_NAME STREQUAL Darwin) - add_custom_command(TARGET System.Globalization.Native POST_BUILD - COMMENT "Verifying System.Globalization.Native.so dependencies" - COMMAND ${CMAKE_CURRENT_SOURCE_DIR}/../verify-so.sh - $ - "Verification failed. System.Globalization.Native.so has undefined dependencies. These are likely ICU APIs that need to be added to icushim.h." - VERBATIM - ) + if (GEN_SHARED_LIB) + add_custom_command(TARGET System.Globalization.Native POST_BUILD + COMMENT "Verifying System.Globalization.Native.so dependencies" + COMMAND ${CMAKE_CURRENT_SOURCE_DIR}/../verify-so.sh + $ + "Verification failed. System.Globalization.Native.so has undefined dependencies. These are likely ICU APIs that need to be added to icushim.h." + VERBATIM + ) + endif() endif() diff --git a/src/libraries/Native/Unix/System.IO.Compression.Native/CMakeLists.txt b/src/libraries/Native/Unix/System.IO.Compression.Native/CMakeLists.txt index 0d5338beb85ced..2b04724e3be994 100644 --- a/src/libraries/Native/Unix/System.IO.Compression.Native/CMakeLists.txt +++ b/src/libraries/Native/Unix/System.IO.Compression.Native/CMakeLists.txt @@ -59,7 +59,6 @@ endif () add_library(System.IO.Compression.Native-Static STATIC ${NATIVECOMPRESSION_SOURCES} - ${VERSION_FILE_PATH} ) # Disable the "lib" prefix and override default name diff --git a/src/libraries/Native/Unix/System.IO.Ports.Native/CMakeLists.txt b/src/libraries/Native/Unix/System.IO.Ports.Native/CMakeLists.txt index cd524dda785624..5155a68a823e80 100644 --- a/src/libraries/Native/Unix/System.IO.Ports.Native/CMakeLists.txt +++ b/src/libraries/Native/Unix/System.IO.Ports.Native/CMakeLists.txt @@ -11,7 +11,6 @@ add_library(System.IO.Ports.Native-Static STATIC pal_termios.c pal_serial.c - ${VERSION_FILE_PATH} ) # Disable the "lib" prefix and override default name diff --git a/src/libraries/Native/Unix/System.Native/CMakeLists.txt b/src/libraries/Native/Unix/System.Native/CMakeLists.txt index 74214368eb23b4..82e4a84d9dc56d 100644 --- a/src/libraries/Native/Unix/System.Native/CMakeLists.txt +++ b/src/libraries/Native/Unix/System.Native/CMakeLists.txt @@ -60,7 +60,6 @@ endif () add_library(System.Native-Static STATIC ${NATIVE_SOURCES} - ${VERSION_FILE_PATH} ) # Disable the "lib" prefix and override default name diff --git a/src/libraries/Native/Unix/System.Net.Security.Native/CMakeLists.txt b/src/libraries/Native/Unix/System.Net.Security.Native/CMakeLists.txt index b7a822ac04d736..95c99012b71e79 100644 --- a/src/libraries/Native/Unix/System.Net.Security.Native/CMakeLists.txt +++ b/src/libraries/Native/Unix/System.Net.Security.Native/CMakeLists.txt @@ -34,7 +34,6 @@ add_library(System.Net.Security.Native add_library(System.Net.Security.Native-Static STATIC ${NATIVEGSS_SOURCES} - ${VERSION_FILE_PATH} ) # Disable the "lib" prefix and override default name diff --git a/src/libraries/Native/Unix/System.Security.Cryptography.Native.Apple/CMakeLists.txt b/src/libraries/Native/Unix/System.Security.Cryptography.Native.Apple/CMakeLists.txt index 6143c43e22b73c..4bf9929db36b23 100644 --- a/src/libraries/Native/Unix/System.Security.Cryptography.Native.Apple/CMakeLists.txt +++ b/src/libraries/Native/Unix/System.Security.Cryptography.Native.Apple/CMakeLists.txt @@ -30,7 +30,6 @@ add_library(System.Security.Cryptography.Native.Apple add_library(System.Security.Cryptography.Native.Apple-Static STATIC ${NATIVECRYPTO_SOURCES} - ${VERSION_FILE_PATH} ) # Disable the "lib" prefix.