KEMBAR78
Weaken dxcore dependency by skottmckay · Pull Request #24845 · microsoft/onnxruntime · GitHub
Skip to content

Conversation

@skottmckay
Copy link
Contributor

Description

Do a manual load of dxcore.dll so that old Windows versions are still supported.

Motivation and Context

#24771

@skottmckay skottmckay requested a review from Copilot May 23, 2025 03:14
Copy link
Contributor

Copilot AI left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Pull Request Overview

This PR adjusts the dxcore dependency by manually loading dxcore.dll to support older Windows versions without a hard dependency on the library.

  • Dynamically loads dxcore.dll using LoadLibraryExW in device_discovery.cc.
  • Replaces the static linking of dxcore.lib in the CMake configuration to avoid a mandatory dependency.

Reviewed Changes

Copilot reviewed 2 out of 2 changed files in this pull request and generated 1 comment.

File Description
onnxruntime/core/platform/windows/device_discovery.cc Implements dynamic loading and function pointer retrieval for dxcore.dll with proper cleanup.
cmake/onnxruntime_common.cmake Removes static linking of dxcore.lib for MSVC platforms.

@skottmckay skottmckay requested a review from snnn May 23, 2025 03:16
skottmckay and others added 2 commits May 23, 2025 13:20
Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
ashrit-ms
ashrit-ms previously approved these changes May 23, 2025
snnn
snnn previously approved these changes May 23, 2025
@skottmckay skottmckay dismissed stale reviews from snnn and ashrit-ms via 6592c61 May 27, 2025 09:53
@JulienMaille
Copy link
Contributor

JulienMaille commented May 30, 2025

Does this mean that after the merge the minimum build would go from 10.0.22621 (22H2) back to 10.0.19041 (20H1)?

Also what about this other dxcore.lib dependency?

target_link_libraries(onnxruntime_providers_dml PRIVATE dxguid.lib d3d12.lib dxgi.lib dxcore.lib)

@skottmckay
Copy link
Contributor Author

Does this mean that after the merge the minimum build would go from 10.0.22621 (22H2) back to 10.0.19041 (20H1)?

IIUC dxcore was added in 10.0.19041 so this should support versions prior to that by making it an optional runtime dependency. I believe Windows Server 2019 uses 10.0.17763 and the intention of this change is for device discovery to not fail on that.

Also what about this other dxcore.lib dependency?

target_link_libraries(onnxruntime_providers_dml PRIVATE dxguid.lib d3d12.lib dxgi.lib dxcore.lib)

That's for the DML execution provider. If you're building with that you have a hard dependency on dxcore being available.

@skottmckay skottmckay merged commit 4a3b63f into main Jun 2, 2025
87 of 88 checks passed
@skottmckay skottmckay deleted the skottmckay/WeakenDxCoreDependency branch June 2, 2025 07:26
@JulienMaille
Copy link
Contributor

That's for the DML execution provider. If you're building with that you have a hard dependency on dxcore being available.

Can you elaborate on this? I thought ONNXRuntime used to be working fine on 10.0.17763 several versions ago. Why is dxcore mandatory for DML?

@snnn
Copy link
Member

snnn commented Jun 2, 2025

ONNX Runtime has multiple execution providers and multiple packages. For example, if you want to use onnxruntime-gpu python package from pypi.org, you should have CUDA. If you want to use onnxruntime-directml python package from pypi.org, you should the directml DLLs. If you just want to use the default CPU provider, you don't need to have these dependencies.

@JulienMaille
Copy link
Contributor

@snnn Thanks, I get that. But it seems you can have DML on old SDKs as long as you distribute directML.dll. dxcore.dll is only used to enumerate devices, it's not mandatory to run inference.
The doc states https://onnxruntime.ai/docs/get-started/with-cpp.html#builds

Artifact Description Supported Platforms
Microsoft.ML.OnnxRuntime.DirectML GPU - DirectML (Release) Windows 10 1709+

And Win10 1709 doesn't come with dxcore.dll AFAIK
I'm currently trying to compile 1.22.0 with an old SDK to support this theory, I can submit my patches as PR when confirmed.

@snnn
Copy link
Member

snnn commented Jun 3, 2025

So, your goal is to run the DirectML EP down to Windows 10 1709?

@JulienMaille
Copy link
Contributor

@snnn Actually down to Windows 10 1809 would be enough. I will try to find a computer and install this Win10 build on it, tight now I only tested in a VM
image

fs-eire pushed a commit that referenced this pull request Jun 6, 2025
### Description
The motivation is to allow Windows 10 LTSC 2019 (currently the only LTSC
supported until 2029) to run ONNXRuntime and the DML provider.
Inspired by #24845 to
remove dxcore.dll dependency.

Currently confirmed to work in a VM.
Real tests on hardware with DML compatible devices will be performed
very soon

---------

Co-authored-by: Julien Maille <julien.maille@data-pixel.com>
javier-intel pushed a commit to intel/onnxruntime that referenced this pull request Jun 15, 2025
### Description
<!-- Describe your changes. -->
Do a manual load of dxcore.dll so that old Windows versions are still
supported.

### Motivation and Context
<!-- - Why is this change required? What problem does it solve?
- If it fixes an open issue, please link to the issue here. -->
microsoft#24771

---------

Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
javier-intel pushed a commit to intel/onnxruntime that referenced this pull request Jun 15, 2025
…24950)

### Description
The motivation is to allow Windows 10 LTSC 2019 (currently the only LTSC
supported until 2029) to run ONNXRuntime and the DML provider.
Inspired by microsoft#24845 to
remove dxcore.dll dependency.

Currently confirmed to work in a VM.
Real tests on hardware with DML compatible devices will be performed
very soon

---------

Co-authored-by: Julien Maille <julien.maille@data-pixel.com>
vraspar pushed a commit that referenced this pull request Jun 23, 2025
### Description
<!-- Describe your changes. -->
Do a manual load of dxcore.dll so that old Windows versions are still
supported.

### Motivation and Context
<!-- - Why is this change required? What problem does it solve?
- If it fixes an open issue, please link to the issue here. -->
#24771

---------

Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
vraspar pushed a commit that referenced this pull request Jun 23, 2025
The motivation is to allow Windows 10 LTSC 2019 (currently the only LTSC
supported until 2029) to run ONNXRuntime and the DML provider.
Inspired by #24845 to
remove dxcore.dll dependency.

Currently confirmed to work in a VM.
Real tests on hardware with DML compatible devices will be performed
very soon

---------

Co-authored-by: Julien Maille <julien.maille@data-pixel.com>
jywu-msft pushed a commit that referenced this pull request Jun 27, 2025
### Description

Cherry pick the following into
[rel-1.22.1](https://github.com/microsoft/onnxruntime/tree/rel-1.22.1)

- (#24884 )
- (#24845 )
- (#24950 )
- (#24534)
- (#24889 )

- bump version to 1.22.1 and update DirectML package version to 1.22.1
in CI pipeline

---------

Co-authored-by: Prathik Rao <prathik.rao@gmail.com>
Co-authored-by: Yulong Wang <7679871+fs-eire@users.noreply.github.com>
Co-authored-by: Scott McKay <skottmckay@gmail.com>
Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
Co-authored-by: Julien <182520+JulienMaille@users.noreply.github.com>
Co-authored-by: Julien Maille <julien.maille@data-pixel.com>
Co-authored-by: Changming Sun <chasun@microsoft.com>
@aseovic
Copy link

aseovic commented Jul 23, 2025

Are there plans to release Java ONNX Runtime with this fix to Maven Central?

The latest version I see there is 1.22.0, which fails during initialization on Windows Server 2019:

03:04:23 Caused by: java.lang.ExceptionInInitializerError: Exception java.lang.UnsatisfiedLinkError: C:\Users\ci\AppData\Local\Temp\onnxruntime-java8448688778529667369\onnxruntime.dll: Can't find dependent libraries [in thread "main"]
03:04:23 	at java.base/jdk.internal.loader.NativeLibraries.load(Native Method)
03:04:23 	at java.base/jdk.internal.loader.NativeLibraries$NativeLibraryImpl.open(NativeLibraries.java:321)
03:04:23 	at java.base/jdk.internal.loader.NativeLibraries.loadLibrary(NativeLibraries.java:187)
03:04:23 	at java.base/jdk.internal.loader.NativeLibraries.loadLibrary(NativeLibraries.java:129)
03:04:23 	at java.base/java.lang.ClassLoader.loadLibrary(ClassLoader.java:2245)
03:04:23 	at java.base/java.lang.Runtime.load0(Runtime.java:767)
03:04:23 	at java.base/java.lang.System.load(System.java:1624)
03:04:23 	at ai.onnxruntime.OnnxRuntime.load(OnnxRuntime.java:387)
03:04:23 	at ai.onnxruntime.OnnxRuntime.init(OnnxRuntime.java:166)
03:04:23 	at ai.onnxruntime.OrtEnvironment.<clinit>(OrtEnvironment.java:34)

@fs-eire
Copy link
Contributor

fs-eire commented Jul 23, 2025

This will be included in the incoming 1.23.0 release

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

7 participants