<table border="1" cellspacing="0" cellpadding="8">
<tr>
<th>Issue</th>
<td>
<a href=https://github.com/llvm/llvm-project/issues/88876>88876</a>
</td>
</tr>
<tr>
<th>Summary</th>
<td>
[OpenMP] CMake fails to install .dll.lib on MSVC
</td>
</tr>
<tr>
<th>Labels</th>
<td>
new issue
</td>
</tr>
<tr>
<th>Assignees</th>
<td>
</td>
</tr>
<tr>
<th>Reporter</th>
<td>
valgur
</td>
</tr>
</table>
<pre>
When building OpenMP as a standalone with MSVC, `libomp.dll.lib` gets built as the import library, but CMake tries to install `libomp.lib` and fails.
OS: Windows 11
Compiler: Visual Studio 2022 / MSVC 19.38
CMake: both 3.21 and 3.29 fail
Configuration: x64 Release
Source version: openmp-18.1.3.src.tar.xz and cmake-18.1.3.src.tar.xz, but fails with v17 as well and older ones fail due to other reasons
Abbreviated build log:
```
$ cmake -B build src -G "Visual Studio 17 2022" -DCMAKE_TOOLCHAIN_FILE="build/generators/conan_toolchain.cmake" -DCMAKE_POLICY_DEFAULT_CMP0091=NEW
$ cmake --build build --config Release
MSBuild version 17.8.3+195e7f5a3 for .NET Framework
Generating libomp.def
Creating library build/runtime/src/Release/libomp.dll.lib and object build/runtime/src/Release/libomp.dll.exp
omp.vcxproj -> build\runtime\src\Release\libomp.dll
Generating libomp.imp.def
$ cmake --install build --config Release --prefix package
-- Installing: package/bin/libomp.dll
CMake Error at runtime/src/cmake_install.cmake:51 (file):
file INSTALL cannot find
"build/runtime/src/Release/libomp.lib":
File exists.
```
`cmake_toolchain.cmake`:
```cmake
set(BUILD_SHARED_LIBS ON)
set(OPENMP_STANDALONE_BUILD ON)
set(LIBOMP_ENABLE_SHARED ON)
set(LIBOMP_INSTALL_ALIASES OFF)
set(LIBOMP_OMPT_SUPPORT OFF)
set(OPENMP_ENABLE_LIBOMPTARGET OFF)
set(OPENMP_MSVC_NAME_SCHEME ON) # Fails with ON as well
```
Related to this PR on Conan Center Index: https://github.com/conan-io/conan-center-index/pull/22353
I wonder what I'm doing wrong since it seems unlikely for such a basic error to have persisted for so many versions? I did not find any similar issues or PRs either.
----
There are two potential fixes that I can suggest.
1. Keep the `.dll.lib` suffix and fix the installed file name:
https://github.com/llvm/llvm-project/blob/llvmorg-18.1.3/openmp/runtime/src/CMakeLists.txt#L306
```patch
--- openmp/runtime/src/CMakeLists.txt
+++ openmp/runtime/src/CMakeLists.txt
@@ -315,7 +315,7 @@
# making it a .txt which CMAKE will filter out from the librarian (a .cpp will make lib.exe punt trying to resolve the .def symbols)
add_library(${LIBOMP_IMP_LIB_TARGET} STATIC kmp_dummy.txt)
set_target_properties(${LIBOMP_IMP_LIB_TARGET} PROPERTIES
- PREFIX "" SUFFIX "" OUTPUT_NAME "${LIBOMP_IMP_LIB_FILE}" LINKER_LANGUAGE ${LIBOMP_LINKER_LANGUAGE}
+ PREFIX "" SUFFIX "" OUTPUT_NAME "${LIBOMP_GENERATED_IMP_LIB_FILENAME}" LINKER_LANGUAGE ${LIBOMP_LINKER_LANGUAGE}
STATIC_LIBRARY_OPTIONS "${CMAKE_LINK_DEF_FILE_FLAG}${CMAKE_CURRENT_BINARY_DIR}/${LIBOMPIMP_GENERATED_DEF_FILE}")
add_dependencies(${LIBOMP_IMP_LIB_TARGET} libompimp-needed-def-file)
add_dependencies(omp ${LIBOMP_IMP_LIB_TARGET})
```
2. Change the suffix to `.lib` to match the installed file name:
https://github.com/llvm/llvm-project/blob/llvmorg-18.1.3/openmp/runtime/src/CMakeLists.txt#L267
```patch
--- openmp/runtime/src/CMakeLists.txt
+++ openmp/runtime/src/CMakeLists.txt
@@ -276,7 +276,7 @@
endif()
else()
set(LIBOMP_IMP_LIB_FILE ${LIBOMP_LIB_NAME}${CMAKE_IMPORT_LIBRARY_SUFFIX})
- set(LIBOMP_GENERATED_IMP_LIB_FILENAME ${LIBOMP_LIB_FILE}${CMAKE_STATIC_LIBRARY_SUFFIX})
+ set(LIBOMP_GENERATED_IMP_LIB_FILENAME ${LIBOMP_LIB_NAME}${CMAKE_STATIC_LIBRARY_SUFFIX})
endif()
set_target_properties(omp PROPERTIES
VERSION ${LIBOMP_VERSION_MAJOR}.${LIBOMP_VERSION_MINOR} # uses /version flag
```
</pre>
<img width="1px" height="1px" alt="" src="http://email.email.llvm.org/o/eJzMWFtz4rgS_jXOS5ddWOb6kAcDdsZnuBWQmbNPLtkWoI0suSQ5l_PrT0m2CZDMzM7uy1IpAlL3162-fGqMlaJHTsi9M5g6g_kdrvVJyPtnzI61vMtE8Xb__UQ4ZDVlBeVHWFeELzeAFWBQGvMCM8EJvFB9guXu28xBM3CGPUYzUVZewZjHaOYMe3AkWlkYbZT1iQAtKyE1MJpJLN-MYlZrmC3xEwEtKVGgBVCuNGbsArPFw7yAA6ZMeU5v7vTC5n29c4IQvlNeiBcFvt-szkRZUUak2ftGVY0Z7HRdUAGohxA4KLa-gz_xgnGrYtww8pnQJwg85FuLgYcm1mwHzA_0WEusqeBG-nXYhy1hBCvSSOxELXMCz0SqVkRUhJeV64893ws8JXNPY-m9_s_i5yV-Ih_3uuDYAzfBfvZHJpAvhDGrKVhBJAhOlJWCoiYmfkKfiARJsBJcXUYqzDJJninWpGiyC0wcnaDddYa99q_5ivqNa-BOW2klc3AfwEHoOqL-yAbVQQjc-WwZfo3S_Xq9mH0Jk1UaJ4vICeYOQhbEQfGRcCKxFlI5KM4FxzzVQrD8hCn3rMlLpM16kcz-SOdRHD4u9ulsuen1Jr4TzFfR9w-euo2jzbvr5jZX19lZ7qZ2t00P-CNv7AUOmvqTARkdBjiAg5DgraI9xBKX5EXIp0YVHhrPTVN01U4O7Z55zSQ575oCh-7IsuaalsRBsZK5g-LOIxRfd02T1uxPkuvf0yWvVeeHWXrOXysp_gTXCaIWaDDrgAYzAzSYdUCD2TtQB_LxpPTytB8D3zXt56EH160kOdBXqHD-hI9tLlwXkkaPclOI510UZ5RfnfCiRSGSUkjAGm5DY51JW1faUgrCgQ8OGh8oIw6anMsdwKxAstrtw8UCcsy50HCgvGj3Lyr2lykwBIXQBXZssMkrVfpMVjftNew13t6W_rD3sSObHbumiHbQePqYLObp7ku4jebpIpnuYL0yh7sQWW-i1XKT7vbhah4u1qsotUofBRfJdL3cpNEqnC6iFvOHUm240nCRhLtoB-s4_lxwvdzs093jZrPe7j-Rar1rjTY6-3D7EP1E2PB1ugqXUbqbfYmWUeMkOCiA-J0k16uOIz-Pu33fEmZZUAvQJ6pgswXBYWa4CGaEayIh4QV5NTV50rpSJicoNuRF9anOvFyUHXm5VJw_5lbXpVYXxVXNmINihIJBcGk-gRfBDXe_nLCGxEGjEgphmu1FCn4ERXlOgGpQhJQKas7oE2FvlphUnZ8AQ4YVzYHYTtACTviZQGUoTZlzWUEBJeZvHdEpJ4ghgYIW0BU6mG1FS8qwBKpUTRQICZutAkLNJXJ1z7qu615-35-IJIAlAf0ioBKacE0xgwN9Nfe4PZlpK1D18UiUbsF8D74SUtlxwBn2LucFVR8MRdhrnr42A0PTy-ZIpqM4Lsm5PX6SGMaeu3-uIUKSa8MpTGTtqpDH9sp1UNxcz5_0uaWbhW1i_aodFCyC3vCmrCqs89M5QvBXsVoCnTZ_v6nW7zn9HriBP3DQbAQOmp4_2q2LK8l0R4mfTG1RDRgMCrycaH4Ce7_CC2UmZ8zUvDDzhhSlDX1zh1HMDXti8PKqaoQt4zOaeeSVQFVzDVq-GQNagCRKsGdiAcx1AeqtzART544GXBTpef4bO6jvjKYduSw3hgrShgic0Rx2-3CfzOCprNKiLsu3Jg0dlCI61VgeiU4rKSoiNSXq16Cb7XoTbfdJtGvTBu1rs43i5L-G-M0AsnuML76tH_ebx72ln2bpExN21BmZUQcWyeprtE0X4erhMXwwKhfyN5tGpSuHf-rKQ7SKtuE-ml85ZUT_iWOdV20-DO423P6Rrjf7ZL3avXvRjGwGxgxs1nYaL8IHa_xdYPa43UarfTpNVgZmnmytQHzpTHJ1mg6tOcV1NRWkIrwgPP9L2W9ubFpWLiekIIVbkIPbDQc_BBVlBT8HPqvfXDjIg9kJ82PTEy3FaWG5r-U9bZha56d_JeOh4ejfw3hoNOwY7_zxlvEIL-jB1kGXT8LMrHaxYF7XY81Fs9y2xDQ9t897BSdLM9icG6Fp0MsqcK8N_LgvP5o71_m7uZu--2jORPRvG_zkfL80-Gmgf0TIpntuWdcm4Vu03SXr1bVL7WK6DP-zNsTgfb6brOyuveFqRZT5Td_9qDswfLyp2rviPigmwQTfkXt_5AdoOAyG_t3pHg0CMswzP5_0x8VwcMj8PgqKYNTr9ckhz_AdvUc91O_1_aHv-xN_4KHBIBsTNJmMJxM_G_Wdfo-UmDLP9Jkn5PHODlP34_F4NLxjOCNM2actCHHy0kxahsUG8zt5bzs2q4_K6feYrfoziqaa2cc0zRMYZzBvH5U0zwQuHpWcfz8Kbh9r3NWS3f82WzQjoINi6_j_AwAA__9wsHWI">