Skip to content
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

[ORT 1.18.1 Release] Cherry pick 3rd round #21129

Merged
merged 10 commits into from
Jun 24, 2024

Conversation

yf711
Copy link
Contributor

@yf711 yf711 commented Jun 21, 2024

Description

Adding critical TensorRT EP support

Motivation and Context

chilo-ms and others added 7 commits June 20, 2024 17:23
This PR includes the weight-stripped engine feature (thanks @moraxu for
the #20214) which is the major feature for TRT 10 integration.

Two TRT EP options are added:

- `trt_weight_stripped_engine_enable`: Enable weight-stripped engine
build and refit.
- `trt_onnx_model_folder_path`: In the quick load case using embedded
engine model / EPContext mode, the original onnx filename is in the
node's attribute, and this option specifies the directory of that onnx
file if needed.

Normal weight-stripped engine workflow:

![image](https://github.com/microsoft/onnxruntime/assets/54722500/9f314865-cbda-4979-a7ac-b31c7a553b56)
Weight-stripped engine and quick load workflow:

![image](https://github.com/microsoft/onnxruntime/assets/54722500/9f31db51-a7a8-495b-ba25-54c7f904cbad)

see the doc [here
](https://onnxruntime.ai/docs/execution-providers/TensorRT-ExecutionProvider.html#tensorrt-ep-caches)for
more information about EPContext model.

---------

Co-authored-by: yf711 <[email protected]>
Co-authored-by: Ye Wang <[email protected]>
Co-authored-by: Michal Guzek <[email protected]>
Co-authored-by: pengwa <[email protected]>
Co-authored-by: wejoncy <[email protected]>
Co-authored-by: Yi Zhang <[email protected]>
Co-authored-by: Yi Zhang <[email protected]>
Co-authored-by: Pranav Sharma <[email protected]>
Co-authored-by: Adam Pocock <[email protected]>
Co-authored-by: cao lei <[email protected]>
Co-authored-by: Adrian Lizarraga <[email protected]>
Co-authored-by: inisis <[email protected]>
Co-authored-by: Jeff Bloomfield <[email protected]>
Co-authored-by: mo-ja <[email protected]>
Co-authored-by: kunal-vaishnavi <[email protected]>
Co-authored-by: Sumit Agarwal <[email protected]>
Co-authored-by: Atanas Dimitrov <[email protected]>
Co-authored-by: Justin Chu <[email protected]>
Co-authored-by: Yufeng Li <[email protected]>
Co-authored-by: Dhruv Matani <[email protected]>
Co-authored-by: Dhruv Matani <[email protected]>
Co-authored-by: wangshuai09 <[email protected]>
Co-authored-by: Xiaoyu <[email protected]>
Co-authored-by: Xu Xing <[email protected]>
Co-authored-by: Dmitri Smirnov <[email protected]>
Co-authored-by: Rachel Guo <[email protected]>
Co-authored-by: Sai Kishan Pampana <[email protected]>
Co-authored-by: rachguo <[email protected]>
Co-authored-by: Jian Chen <[email protected]>
Co-authored-by: Shubham Bhokare <[email protected]>
Co-authored-by: Yulong Wang <[email protected]>
Co-authored-by: Andrew Fantino <[email protected]>
Co-authored-by: Thomas Boby <[email protected]>
Co-authored-by: Tianlei Wu <[email protected]>
Co-authored-by: Scott McKay <[email protected]>
Co-authored-by: Michal Guzek <[email protected]>
Co-authored-by: George Wu <[email protected]>
### Description
<!-- Describe your changes. -->
- Introduce option `trt_engine_hw_compatible` to support engine hardware
compatibility for Ampere+ GPUs
- This enables `nvinfer1::HardwareCompatibilityLevel::kAMPERE_PLUS` flag
when generating engines
- This option has been validated on sm80/86 GPUs, as engine can be
reused across different ampere+ arch:
- Client side need to enable this option as well to leverage existing
sm80+ engines
- If this option is enabled by users which TRT<8.6 or sm<80, there will
be a warning showing this option not supported

Engine naming:
| When | `trt_engine_hw_compat=false` | `trt_engine_hw_compat=true` |
| -------------- |
------------------------------------------------------------ |
------------------------------------------------------------ |
| A100 (sm80) |
TensorrtExecutionProvider_TRTKernel_graph_torch-jit-export_9454133937466702238_0_0_sm**80**.engine
|
TensorrtExecutionProvider_TRTKernel_graph_torch-jit-export_9454133937466702238_0_0_sm**80+**.engine
|
| RTX3080 (sm86) |
TensorrtExecutionProvider_TRTKernel_graph_torch-jit-export_9454133937466702238_0_0_sm**86**.engine
|
TensorrtExecutionProvider_TRTKernel_graph_torch-jit-export_9454133937466702238_0_0_sm**80+**.engine
|


### 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. -->
Reference:
https://docs.nvidia.com/deeplearning/tensorrt/developer-guide/index.html#hardware-compat

---------

Co-authored-by: Chi Lo <[email protected]>
### Description
<!-- Describe your changes. -->
* Partially revert [previous
change](#19804), and
   * Redo concurrency_test_result parser outside of post.py
* Add support of syncing memtest result to db


### 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. -->
To fix the error when CI is running on two model groups.
- When running on two model groups, the [previous
change](#19804) wrongly
navigates two levels up in the directory after running one model group,
while one level is needed. After that, the script can't find another
model group.
- Running on one model group can't repro the issue
…TRT 10 (#20738)

TRT 10 now natively supports int64 tensor, so needs to updating the code
where binding the ORT kernel output with DDS int64 output.
…21101)

This PR is a duplicate of the
#21041
Create this PR in case the original one can't be updated for patch
release timeline.
@yf711 yf711 requested a review from a team as a code owner June 21, 2024 00:29
cmake/deps.txt Show resolved Hide resolved
@yf711 yf711 requested a review from a team as a code owner June 21, 2024 06:24
microsoft/STL#3824 introduces constexpr mutex.
An older version of msvcp140.dll will lead to ```A dynamic link library
(DLL) initialization routine failed```.

This error can be encountered if using conda Python since conda packages
msvc dlls and these are older right now.

This PR disables the constexpr mutex so that ort package can work with
older msvc dlls.

Thanks @snnn for the discovery.
@jywu-msft jywu-msft requested a review from chilo-ms June 22, 2024 03:56
@yf711 yf711 merged commit d0aee20 into rel-1.18.1 Jun 24, 2024
216 of 245 checks passed
@yf711 yf711 deleted the yifanl/round-3-cherry-pick-rel-1.18.1 branch June 24, 2024 17:02
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