1
0
Fork 0
mirror of https://github.com/immich-app/immich.git synced 2025-01-07 20:36:48 +01:00
immich/machine-learning/0001-fix-avoid-race-condition-for-rocm-conv-algo-caching.patch

26 lines
1,012 B
Diff
Raw Normal View History

2024-12-20 07:00:47 +01:00
From e267bc9bab8b3873dba57323ddcd9a9d09a1211e Mon Sep 17 00:00:00 2001
2024-12-20 02:33:31 +01:00
From: mertalev <101130780+mertalev@users.noreply.github.com>
2024-12-20 07:00:47 +01:00
Date: Fri, 20 Dec 2024 00:59:21 -0500
2024-12-20 02:33:31 +01:00
Subject: [PATCH] fix: avoid race condition for rocm conv algo caching
---
2024-12-20 07:00:47 +01:00
onnxruntime/core/providers/rocm/nn/conv.cc | 2 ++
1 file changed, 2 insertions(+)
2024-12-20 02:33:31 +01:00
diff --git a/onnxruntime/core/providers/rocm/nn/conv.cc b/onnxruntime/core/providers/rocm/nn/conv.cc
2024-12-20 07:00:47 +01:00
index d7f47d07a8..ec438287ac 100644
2024-12-20 02:33:31 +01:00
--- a/onnxruntime/core/providers/rocm/nn/conv.cc
+++ b/onnxruntime/core/providers/rocm/nn/conv.cc
@@ -278,6 +278,8 @@ Status Conv<T, NHWC>::UpdateState(OpKernelContext* context, bool bias_expected)
HIP_CALL_THROW(hipMemsetAsync(s_.b_zero, 0, malloc_size, Stream(context)));
}
+ // lock is needed to avoid race condition during algo search
2024-12-20 07:00:47 +01:00
+ std::lock_guard<OrtMutex> lock(s_.mutex);
2024-12-20 02:33:31 +01:00
if (!s_.cached_benchmark_fwd_results.contains(x_dims_miopen)) {
miopenConvAlgoPerf_t perf;
int algo_count = 1;
--
2.43.0