diff options
Diffstat (limited to 'arm_compute/core/CL/gemm/native/CLGEMMNativeKernelConfiguration.h')
-rw-r--r-- | arm_compute/core/CL/gemm/native/CLGEMMNativeKernelConfiguration.h | 24 |
1 files changed, 17 insertions, 7 deletions
diff --git a/arm_compute/core/CL/gemm/native/CLGEMMNativeKernelConfiguration.h b/arm_compute/core/CL/gemm/native/CLGEMMNativeKernelConfiguration.h index 834afa37ce..fced41b261 100644 --- a/arm_compute/core/CL/gemm/native/CLGEMMNativeKernelConfiguration.h +++ b/arm_compute/core/CL/gemm/native/CLGEMMNativeKernelConfiguration.h @@ -1,5 +1,5 @@ /* - * Copyright (c) 2019 ARM Limited. + * Copyright (c) 2019-2020 ARM Limited. * * SPDX-License-Identifier: MIT * @@ -26,6 +26,7 @@ #include "arm_compute/core/CL/ICLGEMMKernelConfiguration.h" #include "arm_compute/core/CL/gemm/native/CLGEMMNativeKernelConfigurationBifrost.h" +#include "arm_compute/core/CL/gemm/native/CLGEMMNativeKernelConfigurationValhall.h" #include <memory> @@ -37,17 +38,26 @@ namespace cl_gemm class CLGEMMNativeKernelConfigurationFactory final { public: - /** Static method to construct CLGEMMNative kernel object accordingly with the GPU architecture + /** Static method to construct CLGEMMNative kernel object accordingly with the GPU target * - * @param[in] arch GPU target + * @param[in] gpu GPU target * * @return CLGEMMNative kernel configuration class */ - static std::unique_ptr<ICLGEMMKernelConfiguration> create(GPUTarget arch) + static std::unique_ptr<ICLGEMMKernelConfiguration> create(GPUTarget gpu) { - // Note: At the moment we only support Bifrost architecture. However, we should have a dedicated path for each GPU architecture - // using get_arch_from_target(arch) - return support::cpp14::make_unique<CLGEMMNativeKernelConfigurationBifrost>(arch); + switch(get_arch_from_target(gpu)) + { + case GPUTarget::MIDGARD: + case GPUTarget::BIFROST: + return support::cpp14::make_unique<CLGEMMNativeKernelConfigurationBifrost>(gpu); + break; + case GPUTarget::VALHALL: + return support::cpp14::make_unique<CLGEMMNativeKernelConfigurationValhall>(gpu); + break; + default: + ARM_COMPUTE_ERROR("Not supported GPU target"); + } } }; } // namespace cl_gemm |