【问题标题】:CMake zlib build on WindowsCMake zlib 在 Windows 上构建
【发布时间】:2015-06-12 20:22:05
【问题描述】:

我正在尝试使用 CMake 为 Windows 构建 zlib 1.2.8,但我遇到了不知道如何修复的构建错误。 这是我的 CMake GUI:

这会生成没有错误,但是当我构建生成的解决方案时。我收到此错误:

2>----- 构建开始:项目:zlib,配置:Release x64 ------
2> 创建库 C:/Users/erik/Documents/zlib/1.2.8/project/zlib-1.2.8-vc10/Release/zlib.lib 和对象 C:/Users/erik/Documents/zlib/1.2.8 /project/zlib-1.2.8-vc10/Release/zlib.exp
2> inflate.obj : 错误 LNK2019: 函数 inflate 中引用的未解析外部符号 inflate_fast
2>infback.obj : 错误 LNK2001: 无法解析的外部符号 inflate_fast
2>C:\Users\erik\Documents\zlib\1.2.8\project\zlib-1.2.8-vc10\Release\zlib.dll : 致命错误 LNK1120: 1 unresolved externals

我不知道如何解决这个问题,所以我很感激任何帮助。

【问题讨论】:

  • 查看 CMakeLists.txt 文件,我不确定 CMake 的问题出在哪里。您可以尝试在“contrib/vstudio/vc10”目录中构建贡献的“zlibvc.sln”Visual Studio 解决方案作为可能的补救措施。所有三个目标似乎都有 Release、ReleaseWithoutAsm 和 Debug 配置:Win32 (x86)、x64 和 Itanium。哦,在“win32”目录中还有一个名为“Makefile.msc”的 Nmake 文件,您可以从 Visual Studio 命令提示符构建它。
  • 你可以下载一个预编译版本的zlib。以防万一。

标签: c++ c windows cmake zlib


【解决方案1】:

根据https://wiki.apache.org/httpd/Win64Compilation 一个非常相似的错误意味着:

这意味着您在 -DASMV -DASMINF 或您的 OBJ="inffasx64.obj gvmat64.obj inffas8664.obj" 中有错字,因为 inflate_fast 是在 inffas8664.c 中定义的。


我能够通过一个简单的方式成功构建:

mkdir C:\Builds\zlib; cd C:\Builds\zlib
cmake -G "Visual Studio 12 2013" -A x64 D:\Downloads\zlib-1.2.8\
cmake --build .

我查看了我的 cmake 缓存,发现 AMD64 设置为 false,这与您的 cmake-gui 窗口显示的不同。将其设置为 true 会导致我出现各种构建错误,尽管不是您显示的错误。

CMakeLists.txt 说这个选项是为了启用 AMD64 程序集实现。不这样做似乎是最简单的解决方案。

【讨论】:

  • 取消选中 AMD64 似乎有效。我的印象是,为了构建 64 位,必须对其进行检查。
  • @elveatles 使用 CMake 指定 64 位构建的方式是特定于生成器的,不应依赖于项目。 (AMD64 不是“内置”cmake 变量之一,它是 zlib 项目的自定义);使用 Visual Studio 生成器,您可以使用 -A x64 将平台设置为 x64。使用 Ninja,您只需使用 64 位工具链配置运行 cmake 的 shell。例如。从 Visual Studio 64 位命令行运行 CMake -G Ninja。
  • 注意:这只是一个解决方法。请检查我的答案。
【解决方案2】:

您需要 contrib\masmx64\inffas8664.c 包含在 Visual Studio 项目文件中。 此文件包含inflate_fast 函数,该函数调用相应的asm 函数。

【讨论】:

  • 你知道为什么默认不包含吗?
  • 我不知道。但是'contrib'意味着它不是由zlib作者维护的,我认为。
  • 你说得对。你可以在我的回答中找到原因
【解决方案3】:

日期:201808042018 年 8 月 4 日th

在使用汇编加速器时,我发现该问题在(当前)最新版本上可以重现:v1.2.11 ([GitHub]: madler/zlib - A massively spiffy yet delicately unobtrusive compression library (http://zlib.net))。

此错误仅发生(显然,OSWin,构建工具链:VStudio 并启用了组装加速) 为:

  • CMake 构建(OK "${ZLIB_SRC_DIR}/win32/Makefile.msc"
  • x64 (AMD64) 架构(OK 适用于 x86

下面是解压时的“callstack”(top -> down相当于outer -> inner)。

  • 正常情况:

    1. inflate (inflate.c)
    2. inflate_fast (inffast.c)
    3. ...
  • 汇编案例:

    1. inflate (inflate.c)
    2. inflate_fast (contrib/masmx64/inffast8664.c)
    3. inffas8664fnc (contrib/masmx64/inffasx64.asm)
    4. ...

问题:

#2. 丢失("${ZLIB_SRC_DIR}/CMakeLists.txt"inffast8664 一无所知.c),所以链断了,导致库无效。

解决办法:

CMakeLists.txt 知道该文件,即添加:

set(ZLIB_SRCS
    ${ZLIB_SRCS}
    contrib/masmx64/inffas8664.c
)

~#158(由if(MSVC)elseif (AMD64) 条件句括起来)。


同时发布完整的更改。

zlib-1.2.11-msvc_x64_asm_speedups.diff

--- CMakeLists.txt.orig 2017-01-15 08:29:40.000000000 +0200
+++ CMakeLists.txt  2018-09-03 13:41:00.314805100 +0300
@@ -79,10 +79,10 @@
 endif()

 set(ZLIB_PC ${CMAKE_CURRENT_BINARY_DIR}/zlib.pc)
-configure_file( ${CMAKE_CURRENT_SOURCE_DIR}/zlib.pc.cmakein
-       ${ZLIB_PC} @ONLY)
-configure_file(    ${CMAKE_CURRENT_SOURCE_DIR}/zconf.h.cmakein
-       ${CMAKE_CURRENT_BINARY_DIR}/zconf.h @ONLY)
+configure_file(${CMAKE_CURRENT_SOURCE_DIR}/zlib.pc.cmakein
+        ${ZLIB_PC} @ONLY)
+configure_file(${CMAKE_CURRENT_SOURCE_DIR}/zconf.h.cmakein
+        ${CMAKE_CURRENT_BINARY_DIR}/zconf.h @ONLY)
 include_directories(${CMAKE_CURRENT_BINARY_DIR} ${CMAKE_SOURCE_DIR})


@@ -136,30 +136,34 @@
         set(ZLIB_ASMS contrib/amd64/amd64-match.S)
     endif ()

-   if(ZLIB_ASMS)
-       add_definitions(-DASMV)
-       set_source_files_properties(${ZLIB_ASMS} PROPERTIES LANGUAGE C COMPILE_FLAGS -DNO_UNDERLINE)
-   endif()
+    if(ZLIB_ASMS)
+        add_definitions(-DASMV)
+        set_source_files_properties(${ZLIB_ASMS} PROPERTIES LANGUAGE C COMPILE_FLAGS -DNO_UNDERLINE)
+    endif()
 endif()

 if(MSVC)
     if(ASM686)
-       ENABLE_LANGUAGE(ASM_MASM)
+        ENABLE_LANGUAGE(ASM_MASM)
         set(ZLIB_ASMS
-           contrib/masmx86/inffas32.asm
-           contrib/masmx86/match686.asm
-       )
+            contrib/masmx86/inffas32.asm
+            contrib/masmx86/match686.asm
+        )
     elseif (AMD64)
-       ENABLE_LANGUAGE(ASM_MASM)
+        ENABLE_LANGUAGE(ASM_MASM)
         set(ZLIB_ASMS
-           contrib/masmx64/gvmat64.asm
-           contrib/masmx64/inffasx64.asm
-       )
+            contrib/masmx64/gvmat64.asm
+            contrib/masmx64/inffasx64.asm
+        )
+        set(ZLIB_SRCS
+            ${ZLIB_SRCS}
+            contrib/masmx64/inffas8664.c
+        )
     endif()

-   if(ZLIB_ASMS)
-       add_definitions(-DASMV -DASMINF)
-   endif()
+    if(ZLIB_ASMS)
+        add_definitions(-DASMV -DASMINF)
+    endif()
 endif()

 # parse the full version number from zlib.h and include in ZLIB_FULL_VERSION

以上是一个差异。请参阅[SO]: Run/Debug a Django application's UnitTests from the mouse right click context menu in PyCharm Community Edition? (@CristiFati's answer)Patching utrunner 部分)了解如何在 Win 上应用补丁(基本上,以 one 开头的每一行+" 符号进入,以 一个 "-" 符号开头的每一行都退出)。我正在使用 Cygwinbtw
我也将此补丁提交给 [GitHub]: madler/zlib - Ms VisualStudio - Assembler speedups on x64,但我不确定它的命运,因为有超过 100 个拉取请求待定。

输出

e:\Work\Dev\StackOverflow\q029505121\build\x64>"c:\Install\Google\Android_SDK\cmake\3.6.4111459\bin\cmake.exe" -G "NMake Makefiles" -DAMD64=ON "e:\Work\Dev\StackOverflow\q029505121\src\zlib-1.2.11"
-- The C compiler identification is MSVC 19.0.24215.1
-- Check for working C compiler: C:/Install/x86/Microsoft/Visual Studio Community/2015/VC/bin/amd64/cl.exe
-- Check for working C compiler: C:/Install/x86/Microsoft/Visual Studio Community/2015/VC/bin/amd64/cl.exe -- works
-- Detecting C compiler ABI info
-- Detecting C compiler ABI info - done
-- Looking for sys/types.h
-- Looking for sys/types.h - found
-- Looking for stdint.h
-- Looking for stdint.h - found
-- Looking for stddef.h
-- Looking for stddef.h - found
-- Check size of off64_t
-- Check size of off64_t - failed
-- Looking for fseeko
-- Looking for fseeko - not found
-- Looking for unistd.h
-- Looking for unistd.h - not found
-- Renaming
--     E:/Work/Dev/StackOverflow/q029505121/src/zlib-1.2.11/zconf.h
-- to 'zconf.h.included' because this file is included with zlib
-- but CMake generates it automatically in the build directory.
-- The ASM_MASM compiler identification is MSVC
-- Found assembler: C:/Install/x86/Microsoft/Visual Studio Community/2015/VC/bin/amd64/ml64.exe
-- Configuring done
-- Generating done
-- Build files have been written to: E:/Work/Dev/StackOverflow/q029505121/build/x64

e:\Work\Dev\StackOverflow\q029505121\build\x64>"c:\Install\Google\Android_SDK\cmake\3.6.4111459\bin\cmake.exe" --build . --target zlibstatic
Scanning dependencies of target zlibstatic
[  5%] Building C object CMakeFiles/zlibstatic.dir/adler32.obj
adler32.c
[ 10%] Building C object CMakeFiles/zlibstatic.dir/compress.obj
compress.c
[ 15%] Building C object CMakeFiles/zlibstatic.dir/crc32.obj
crc32.c
[ 21%] Building C object CMakeFiles/zlibstatic.dir/deflate.obj
deflate.c
Assembler code may have bugs -- use at your own risk
[ 26%] Building C object CMakeFiles/zlibstatic.dir/gzclose.obj
gzclose.c
[ 31%] Building C object CMakeFiles/zlibstatic.dir/gzlib.obj
gzlib.c
[ 36%] Building C object CMakeFiles/zlibstatic.dir/gzread.obj
gzread.c
[ 42%] Building C object CMakeFiles/zlibstatic.dir/gzwrite.obj
gzwrite.c
[ 47%] Building C object CMakeFiles/zlibstatic.dir/inflate.obj
inflate.c
[ 52%] Building C object CMakeFiles/zlibstatic.dir/infback.obj
infback.c
[ 57%] Building C object CMakeFiles/zlibstatic.dir/inftrees.obj
inftrees.c
[ 63%] Building C object CMakeFiles/zlibstatic.dir/inffast.obj
inffast.c
Assembler code may have bugs -- use at your own risk
[ 68%] Building C object CMakeFiles/zlibstatic.dir/trees.obj
trees.c
[ 73%] Building C object CMakeFiles/zlibstatic.dir/uncompr.obj
uncompr.c
[ 78%] Building C object CMakeFiles/zlibstatic.dir/zutil.obj
zutil.c
[ 84%] Building C object CMakeFiles/zlibstatic.dir/contrib/masmx64/inffas8664.obj
inffas8664.c
[ 89%] Building ASM_MASM object CMakeFiles/zlibstatic.dir/contrib/masmx64/gvmat64.obj
Microsoft (R) Macro Assembler (x64) Version 14.00.24210.0
Copyright (C) Microsoft Corporation.  All rights reserved.

 Assembling: E:\Work\Dev\StackOverflow\q029505121\src\zlib-1.2.11\contrib\masmx64\gvmat64.asm
[ 94%] Building ASM_MASM object CMakeFiles/zlibstatic.dir/contrib/masmx64/inffasx64.obj
Microsoft (R) Macro Assembler (x64) Version 14.00.24210.0
Copyright (C) Microsoft Corporation.  All rights reserved.

 Assembling: E:\Work\Dev\StackOverflow\q029505121\src\zlib-1.2.11\contrib\masmx64\inffasx64.asm
[100%] Linking C static library zlibstatic.lib
[100%] Built target zlibstatic

注意事项

  • 我正在使用 VStudio 2015
  • 关于上述输出:
    • 为了使输出尽可能小,我只构建 static 版本
      • 出于同样的原因(也为了将其保留为文本),我正在为 "NMake Makefiles"cmdline构建)
    • inffas8664.c 正在构建中(接近尾声)
  • 您还可以禁用汇编器加速(通过 cmake-gui 中的取消选中 AMD64),但这会只是一种解决方法
  • 我做了一些粗略的测试(到目前为止,我并没有声称这些结果是普遍的),并且汇编器实现相对于标准版本(Debug 版本)的性能改进是(a下面的百分比是执行相同操作所用时间的比率(有/没有)加速):
    • 压缩:~86%
    • 解压:~62%



更新#0

([GitHub]: madler/zlib - ASM zlib build on Windows gives erroneous results (@madler's comment)) 声明:

正在使用什么汇编代码? zlib 的 contrib 目录中有一些。顺便说一句,contrib 目录中的东西不是 zlib 的一部分。它只是为了方便而存在,并且由那些第三方贡献者支持(或不支持)。我要做的只是从下一个发行版中删除有问题的代码。

编译警告也是如此(每个人都必须看到(并且很可能被忽略)):

Assembler code may have bugs -- use at your own risk

显然,汇编加速和 VStudio 不能很好地配合。此外,在 x86 上存在几个问题:

修复这些后,一切正常,性能提升类似于x64

【讨论】:

    猜你喜欢
    • 2020-02-08
    • 2015-06-11
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2018-12-23
    • 2018-03-15
    • 2021-11-15
    • 2021-11-27
    相关资源
    最近更新 更多