-
Notifications
You must be signed in to change notification settings - Fork 3.5k
[DML] Restore compatibility with Windows Sdk 10.0.17134.0 (build 1809) #24950
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
Conversation
@microsoft-github-policy-service agree |
f69c1b9
to
242cb43
Compare
There was a problem hiding this 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 restores compatibility with Windows SDK 10.0.17134.0 by removing the direct dependency on dxcore.dll and conditionally enabling instrumentation on Windows. Key changes include updating preprocessor conditions for telemetry logging, dynamically loading dxcore.dll in the DML provider factory, and adjusting the CMake linking to remove dxcore.lib.
Reviewed Changes
Copilot reviewed 5 out of 5 changed files in this pull request and generated no comments.
Show a summary per file
File | Description |
---|---|
onnxruntime/core/session/provider_registration.cc | Modified preprocessor condition to enable logging only when instrument enabled |
onnxruntime/core/session/inference_session.cc | Adjusted instrumentation condition for session option tracing |
onnxruntime/core/providers/dml/dml_provider_factory.cc | Added dynamic dxcore.dll loading and function pointer handling; revised error handling |
onnxruntime/core/framework/execution_provider.cc | Wrapped tracing of provider options within instrumentation conditional |
cmake/onnxruntime_providers_dml.cmake | Removed explicit linking of dxcore.lib |
Comments suppressed due to low confidence (3)
onnxruntime/core/session/provider_registration.cc:135
- [nitpick] Ensure that the conditional instrumentation is intended only for builds with ONNXRUNTIME_ENABLE_INSTRUMENT defined and that this change is consistent with the logging strategy elsewhere in the code.
#if defined(_WIN32) && defined(ONNXRUNTIME_ENABLE_INSTRUMENT)
onnxruntime/core/providers/dml/dml_provider_factory.cc:313
- [nitpick] Consider revising the error message for clarity, as stating 'Expected on older Windows version' might be misinterpreted; clarifying when and why this failure is acceptable could improve debuggability.
ORT_THROW("Failed to load dxcore.dll. Expected on older Windows version that do not support dxcore.");
cmake/onnxruntime_providers_dml.cmake:62
- Verify that removing dxcore.lib from linking does not affect any fallback paths or runtime functionality that may expect dxcore symbols.
target_link_libraries(onnxruntime_providers_dml PRIVATE dxguid.lib d3d12.lib dxgi.lib)
triggering CI pipelines by close & reopen PR - |
/azp run Linux QNN CI Pipeline, Win_TRT_Minimal_CUDA_Test_CI, Windows ARM64 QNN CI Pipeline, Windows GPU Doc Gen CI Pipeline, Windows x64 QNN CI Pipeline |
Azure Pipelines successfully started running 5 pipeline(s). |
aa80b3a
to
7064fba
Compare
@fs-eire Sorry I messed up when rebasing from rel-1.22 to main. Should be ok now, can the checks be resumed? |
Commenter does not have sufficient privileges for PR 24950 in repo microsoft/onnxruntime |
/azp run Linux QNN CI Pipeline, Win_TRT_Minimal_CUDA_Test_CI, Windows ARM64 QNN CI Pipeline, Windows GPU Doc Gen CI Pipeline, Windows x64 QNN CI Pipeline |
Azure Pipelines successfully started running 5 pipeline(s). |
@fs-eire I was able to run this on a real (non VM) computer running Windows 10 Build 1809 and confirm that CPU, DirectML and OpenVino 2024.6 providers were properly working. |
…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>
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>
### 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>
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