diff options
author | Cedric Nugteren <web@cedricnugteren.nl> | 2017-10-07 18:41:46 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-10-07 18:41:46 +0200 |
commit | b2058320d12cbb3a250f62e9c85ff8c840659ee7 (patch) | |
tree | fd406dd26d17d5282e9864a3a8c7634b25e1cbfa /src/clblast.cpp | |
parent | 1009303717d1722fd01ef43d1a08ee9d0899ad41 (diff) | |
parent | 86b80cdc98a36e75023403ba6c54df9f5b94854f (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.cpp | 9 |
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; |