-
Notifications
You must be signed in to change notification settings - Fork 643
deps: swap in zlib-ng for zlib with ENABLE_ZLIBNG=1 #4639
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
base: main
Are you sure you want to change the base?
Changes from 1 commit
096508a
f7a5231
72e8a29
34ed8b0
bd02b23
06988f1
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -3,36 +3,131 @@ | |
# https://github.com/AcademySoftwareFoundation/OpenImageIO | ||
|
||
###################################################################### | ||
# ZLIB by hand! | ||
# ZLIB / ZLIB-NG by hand! | ||
###################################################################### | ||
|
||
set_cache (ZLIB_BUILD_VERSION 1.3.1 "ZLIB version for local builds") | ||
set (ZLIB_GIT_REPOSITORY "https://github.com/madler/zlib") | ||
set (ZLIB_GIT_TAG "v${ZLIB_BUILD_VERSION}") | ||
# This script builds either zlib or zlib-ng (in compatibility mode) from source. | ||
|
||
set_cache (ZLIB_BUILD_SHARED_LIBS ${LOCAL_BUILD_SHARED_LIBS_DEFAULT} | ||
DOC "Should execute a local ZLIB build, if necessary, build shared libraries" ADVANCED) | ||
# Zlib-ng is a fork of zlib that is actively maintained and has some | ||
# performance improvments over the original zlib which pertain to | ||
# PNG and WebP plugin performance (on Windows, in particular). | ||
|
||
# By default, we build zlib-ng in zlib API compatibility mode. This | ||
# allows OIIO and its dependencies to use zlib-ng v2.2.4 as a drop-in | ||
# replacement for zlib v1.3.1. | ||
|
||
# Please note -- this means that `find_package(ZLIB)` will recognize zlib-ng | ||
# as zlib, and set ZLIB_VERSION = "1.3.1" (instead of zlib-ng's version) | ||
|
||
|
||
# There are two ways to build against zlib instead of zlib-ng: | ||
|
||
# 1. At build time, set `ENABLE_ZLIBNG=OFF` to | ||
# to build with the original zlib (defaults to ON). | ||
|
||
# 2. When using the `checked_find_package` macro, require a version | ||
# less than 2.0.0, e.g. `find_package(ZLIB 1.3.1 REQUIRED)`. | ||
|
||
|
||
set (ZLIB_VERSION_LATEST "1.3.1") | ||
set (ZLIBNG_VERSION_LATEST "2.2.4") | ||
|
||
# By default, we build zlib-ng in compatibility mode. | ||
# Set ENABLE_ZLIBNG=OFF to build the original zlib. | ||
check_is_enabled(ZLIBNG ENABLE_ZLIBNG) | ||
|
||
|
||
# Set the version to build; note that 1.x versions will build the original zlib, | ||
# while 2.x or later will build zlib-ng. | ||
if (ENABLE_ZLIBNG) | ||
set_cache (ZLIB_BUILD_VERSION ${ZLIBNG_VERSION_LATEST} "ZLIB or ZLIB-NG version for local builds") | ||
else () | ||
set_cache (ZLIB_BUILD_VERSION ${ZLIB_VERSION_LATEST} "ZLIB or ZLIB-NG version for local builds") | ||
endif () | ||
|
||
|
||
# Choose the git repository, tag format, and extra arguments based on version. | ||
# For now, we're assuming that the original zlib will never reach version 2.0, | ||
# so anything greater than or equal to 2.0 is zlib-ng. | ||
if (ZLIB_BUILD_VERSION VERSION_LESS "2.0.0") | ||
# Original zlib: use the 'v' prefix in the tag. | ||
set (ZLIB_GIT_REPOSITORY "https://github.com/madler/zlib") | ||
set (ZLIB_GIT_TAG "v${ZLIB_BUILD_VERSION}") | ||
set (ZLIB_BUILD_OPTIONS "") | ||
set (ZLIBNG_USED FALSE) | ||
if (ENABLE_ZLIBNG) | ||
message (STATUS "Building zlib version ${ZLIB_BUILD_VERSION}, even though ENABLE_ZLIBNG=${ENABLE_ZLIBNG}") | ||
message (STATUS "If you believe this is a mistake, check usages of `checked_find_package(ZLIB ...)` in the code base.") | ||
message (STATUS "See src/cmake/build_ZLIB.cmake for more details.") | ||
else () | ||
message (STATUS "Building zlib version ${ZLIB_BUILD_VERSION}") | ||
endif () | ||
else () | ||
# zlib-ng: omit the 'v' prefix for the git tag and enable compatibility mode. | ||
set (ZLIB_GIT_REPOSITORY "https://github.com/zlib-ng/zlib-ng") | ||
set (ZLIB_GIT_TAG "${ZLIB_BUILD_VERSION}") | ||
set (ZLIB_BUILD_OPTIONS "-DZLIB_COMPAT=ON;-DWITH_GTEST=OFF;-DWITH_GZFILEOP=OFF;-DZLIBNG_ENABLE_TESTS=OFF;-DZLIB_ENABLE_TESTS=OFF") | ||
set (ZLIBNG_USED TRUE) | ||
message (STATUS "Building zlib-ng version ${ZLIB_BUILD_VERSION}") | ||
endif () | ||
|
||
|
||
set_cache (ZLIB_BUILD_SHARED_LIBS OFF | ||
DOC "Should execute a local ZLIB build, if necessary, build shared libraries" ADVANCED) | ||
Comment on lines
+75
to
+76
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Concern: by building zlib-ng as a static library, won't that prevent it from being used by libpng, which is where much of the benefit of the faster zlib implementation would come from? Any static libraries we incorporate into libOpenImageIO have their symbols hidden by default, specifically so nothing else we link will find those symbols. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Oh yeah? You'd definitely know better than I; I only barely understand what I'm doing! But yes, we specifically want PNG to find and use zlib-ng; the rest doesn't really matter. I was hoping by placing the local build prefix at the front of CMAKE_PREFIX_PATH, and passing CMAKE_IGNORE_PATH to child build processes, that would coerce the PNG build process to find and link zlib-ng before any other zlibs. I'll should turn on shared libs and turn off plugin bundling to see what's actually happening... There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Hmmm, I see what you mean. I'm honestly not sure. You might be right that it could be picked up by libpng and other dependencies IF we build them ourselves. But I think the usual case is that some/most/all of the dependencies are already built. One possibility is that we should build statically, but expose the symbols by adding them to the global list in hidesymbols.map, so that libpng and others will find them inside our library at actual load time. We may need to also modify libOpenImageIO/CMakeLists where we have But once we expose them, they might be picked up by anything that links us as a dependency, too, depending on the link order. So, for example, an app that itself uses zlib and OIIO might end up itself using zlib-ng inadvertently. Is that always ok? Maybe it's fine, I just think we need to be confident that this is the behavior we want. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Hmm. Very interesting. If the zlib-ng documentation is to be believed, I would imagine we'd want this behavior; but I don't feel qualified to so say so for sure... Would exposing zlib-ng-compatibility-mode symbols in OIIO impose unexpected constraints or build-time requirements on building apps linking libraries that themselves link OIIO? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Update: @joaovbs96 tested one of the Windows bdist artifacts produced by the last Wheels run for this thread, and has confirmed PNG write speed improvements consistent with having linked against zlib-ng instead of zlib -- in his use case (which inspired this PR), write times for very large PNGs decreased from ~20s to ~8s. |
||
|
||
string (MAKE_C_IDENTIFIER ${ZLIB_BUILD_VERSION} ZLIB_VERSION_IDENT) | ||
|
||
build_dependency_with_cmake(ZLIB | ||
build_dependency_with_cmake (ZLIB | ||
VERSION ${ZLIB_BUILD_VERSION} | ||
GIT_REPOSITORY ${ZLIB_GIT_REPOSITORY} | ||
GIT_TAG ${ZLIB_GIT_TAG} | ||
CMAKE_ARGS | ||
-D BUILD_SHARED_LIBS=${ZLIB_BUILD_SHARED_LIBS} | ||
-D CMAKE_POSITION_INDEPENDENT_CODE=ON | ||
-D CMAKE_INSTALL_LIBDIR=lib | ||
${ZLIB_BUILD_OPTIONS} | ||
) | ||
|
||
# Set some things up that we'll need for a subsequent find_package to work | ||
set (ZLIB_ROOT ${ZLIB_LOCAL_INSTALL_DIR}) | ||
|
||
# Signal to caller that we need to find again at the installed location | ||
set (ZLIB_REFIND TRUE) | ||
set (ZLIB_VERSION ${ZLIB_BUILD_VERSION}) | ||
set (ZLIB_REFIND_VERSION ${ZLIB_BUILD_VERSION}) | ||
|
||
if (ZLIB_BUILD_SHARED_LIBS) | ||
install_local_dependency_libs (ZLIB ZLIB) | ||
if (ZLIBNG_USED) | ||
# zlib-ng provides a CMake config file, so we can use find_package directly. | ||
find_package (ZLIB CONFIG REQUIRED HINTS ${ZLIB_LOCAL_INSTALL_DIR} NO_DEFAULT_PATH) | ||
|
||
# First, locate the directory containing zlib.h. | ||
find_path (ZLIB_INCLUDE_DIR | ||
NAMES zlib.h | ||
HINTS ${ZLIB_ROOT}/include | ||
) | ||
|
||
if (NOT ZLIB_INCLUDE_DIR) | ||
message (FATAL_ERROR "Could not locate zlib-ng include directory.") | ||
endif () | ||
|
||
message (STATUS "Found zlib-ng header directory: ${ZLIB_INCLUDE_DIR}") | ||
|
||
# Read the contents of zlib.h | ||
file (READ "${ZLIB_INCLUDE_DIR}/zlib.h" ZLIB_HEADER_CONTENT) | ||
|
||
# Use a regular expression to search for the ZLIB_VERSION macro. | ||
# This regex looks for a line like: #define ZLIB_VERSION "1.3.1.zlib-ng" | ||
string (REGEX MATCH "#[ \t]*define[ \t]+ZLIB_VERSION[ \t]+\"([^\"]+)\"" _match "${ZLIB_HEADER_CONTENT}") | ||
|
||
if (_match) | ||
# The first capture group is stored in CMAKE_MATCH_1. | ||
set (ZLIB_VERSION "${CMAKE_MATCH_1}") | ||
endif () | ||
|
||
|
||
else () | ||
# Vanilla ZLIB doesn't ship with a CMake config file, so we'll just "refind" it with the | ||
# usual arguments. | ||
set (ZLIB_REFIND TRUE) | ||
set (ZLIB_REFIND_VERSION ${ZLIB_BUILD_VERSION}) | ||
endif () | ||
|
||
if (ZLIB_BUILD_SHARED_LIBS) | ||
install_local_dependency_libs(ZLIB ZLIB) | ||
endif() |
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -37,7 +37,15 @@ include (FindThreads) | |
# Dependencies for required formats and features. These are so critical | ||
# that we will not complete the build if they are not found. | ||
|
||
checked_find_package (ZLIB REQUIRED) # Needed by several packages | ||
check_is_enabled(ZLIBNG ENABLE_ZLIBNG) | ||
if (ENABLE_ZLIBNG) | ||
checked_find_package (ZLIB REQUIRED | ||
VERSION_MIN 2.2.4 # ZLIB-NG | ||
BUILD_LOCAL missing | ||
|
||
) | ||
else () | ||
checked_find_package (ZLIB REQUIRED) # Needed by several packages | ||
endif () | ||
|
||
# Help set up this target for libtiff config file when using static libtiff | ||
if (NOT TARGET CMath::CMath) | ||
|
Uh oh!
There was an error while loading. Please reload this page.