summaryrefslogtreecommitdiff
path: root/src/clblast.cpp
diff options
context:
space:
mode:
authorCedric Nugteren <web@cedricnugteren.nl>2017-10-07 18:41:46 +0200
committerGitHub <noreply@github.com>2017-10-07 18:41:46 +0200
commitb2058320d12cbb3a250f62e9c85ff8c840659ee7 (patch)
treefd406dd26d17d5282e9864a3a8c7634b25e1cbfa /src/clblast.cpp
parent1009303717d1722fd01ef43d1a08ee9d0899ad41 (diff)
parent86b80cdc98a36e75023403ba6c54df9f5b94854f (diff)
Merge pull request #197 from CNugteren/single_temporary_gemm_buffer
Single temporary GEMM buffer
Diffstat (limited to 'src/clblast.cpp')
-rw-r--r--src/clblast.cpp9
1 files changed, 7 insertions, 2 deletions
diff --git a/src/clblast.cpp b/src/clblast.cpp
index bb338503..19d7ef0a 100644
--- a/src/clblast.cpp
+++ b/src/clblast.cpp
@@ -2497,8 +2497,13 @@ StatusCode OverrideParameters(const cl_device_id device, const std::string &kern
// Retrieves the current database values to verify whether the new ones are complete
auto in_cache = false;
- const auto current_database = DatabaseCache::Instance().Get(DatabaseKeyRef{platform_id, device, precision, kernel_name}, &in_cache);
- if (!in_cache) { return StatusCode::kInvalidOverrideKernel; }
+ auto current_database = DatabaseCache::Instance().Get(DatabaseKeyRef{platform_id, device, precision, kernel_name}, &in_cache);
+ if (!in_cache) {
+ log_debug("Searching database for kernel '" + kernel_name + "'");
+ current_database = Database(device_cpp, kernel_name, precision, {});
+ }
+
+ // Verifies the parameters size
const auto current_parameter_names = current_database.GetParameterNames();
if (current_parameter_names.size() != parameters.size()) {
return StatusCode::kMissingOverrideParameter;