Search code examples
visual-c++msvcrtcrt

Upgrading to Universal CRT-how can I get rid of a dependency on vcruntime140.dll and msvcp140.dll?


I have a project that I'm trying to get updated to the universal CRT, and I'm still seeing a dependency on vcruntime140.dll and msvcp140.dll, which I think should have been replaced with a ucrtbase.dll, as well as api-ms-win-crt* dlls.

I've already checked out this response here, and this blog post, which explain things pretty well, but still no luck. Here's what I've changed:

  • Platform Toolset: Visual Studio 2019 (v142)
  • Windows SDK version: 10.0 (latest installed version)
  • Additional include directories: added $(UniversalCRT_IncludePath)
  • Additional library directories: added $(UniversalCRT_LibraryPath_x86)

I also updated my linker dependencies to this set:

  • ucrt.lib
  • vcruntime.lib
  • msvcrt.lib
  • user32.lib
  • advapi32.lib
  • Wsock32.lib
  • Crypt32.lib
  • ws2_32.lib

But when I run dumpbin /dependents mydll.dll

File Type: DLL

Image has the following dependencies:

api-ms-win-crt-string-l1-1-0.dll
api-ms-win-crt-heap-l1-1-0.dll
api-ms-win-crt-runtime-l1-1-0.dll
api-ms-win-crt-stdio-l1-1-0.dll
api-ms-win-crt-filesystem-l1-1-0.dll
api-ms-win-crt-convert-l1-1-0.dll
api-ms-win-crt-time-l1-1-0.dll
api-ms-win-crt-environment-l1-1-0.dll
api-ms-win-crt-utility-l1-1-0.dll
VCRUNTIME140.dll
USER32.dll
ADVAPI32.dll
WSOCK32.dll
CRYPT32.dll
WS2_32.dll
MSVCP140.dll
bcrypt.dll
KERNEL32.dll

Summary

    E000 .data
   66000 .rdata
    E000 .reloc
    1000 .rsrc
  14A000 .text

Is there something else I'm missing to be able to drop the dependency on the specific CRT version?


Solution

  • I've done some more digging, and found this page that says the following:

    Starting in Visual Studio 2015, the CRT has been refactored into new binaries. The Universal CRT (UCRT) contains the functions and globals exported by the standard C99 CRT library. The UCRT is now a Windows component, and ships as part of Windows 10.

    Great, that's what I expected. Just below though is this:

    The vcruntime library contains Visual C++ CRT implementation-specific code, such as exception handling and debugging support, runtime checks and type information, implementation details and certain extended library functions. This library is specific to the version of the compiler used.

    Which implies that there is still a non-universal VC++ dependency that gets linked in by VS. To me, this implies that a dependency-free DLL doesn't really exist (at least not something built with VC++), since you'll always have a vcruntime dependency.

    There is always the option of static linking (/MT), but in my case, I'm also looking at a DLL that has /clr, and the two options are mutually exclusive. Application local deployment (just copy vcruntime140.dll with the binaries) also seems to work, and may be the best option for something that I want to be a portable/xcopy deployment.

    I'm going to mark this as an answer for now, but if there's a way around this, I'd be interested in seeing it.