diff options
author | Gian Marco Iodice <gianmarco.iodice@arm.com> | 2020-02-13 12:27:37 +0000 |
---|---|---|
committer | Georgios Pinitas <georgios.pinitas@arm.com> | 2020-02-26 11:06:48 +0000 |
commit | 12f2b8c316155660f1e612fe7e8fab7861decc03 (patch) | |
tree | 2bab7a855ce2f52b7e9a59fc60c5e032a7b95176 /arm_compute/core/CL/gemm/reshaped/CLGEMMReshapedKernelConfiguration.h | |
parent | e620a83da59b9f835642d1dd0b68663556dbf379 (diff) | |
download | ComputeLibrary-12f2b8c316155660f1e612fe7e8fab7861decc03.tar.gz |
COMPMID-3202: Add support for Valhall architecture in GEMM
Change-Id: I2cd0b5ee0ae2e3c65a04c7be70478b0452e55132
Signed-off-by: Gian Marco Iodice <gianmarco.iodice@arm.com>
Reviewed-on: https://review.mlplatform.org/c/ml/ComputeLibrary/+/2730
Tested-by: Arm Jenkins <bsgcomp@arm.com>
Reviewed-by: Georgios Pinitas <georgios.pinitas@arm.com>
Comments-Addressed: Arm Jenkins <bsgcomp@arm.com>
Diffstat (limited to 'arm_compute/core/CL/gemm/reshaped/CLGEMMReshapedKernelConfiguration.h')
-rw-r--r-- | arm_compute/core/CL/gemm/reshaped/CLGEMMReshapedKernelConfiguration.h | 24 |
1 files changed, 17 insertions, 7 deletions
diff --git a/arm_compute/core/CL/gemm/reshaped/CLGEMMReshapedKernelConfiguration.h b/arm_compute/core/CL/gemm/reshaped/CLGEMMReshapedKernelConfiguration.h index 42a4ac1275..e960d64964 100644 --- a/arm_compute/core/CL/gemm/reshaped/CLGEMMReshapedKernelConfiguration.h +++ b/arm_compute/core/CL/gemm/reshaped/CLGEMMReshapedKernelConfiguration.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/reshaped/CLGEMMReshapedKernelConfigurationBifrost.h" +#include "arm_compute/core/CL/gemm/reshaped/CLGEMMReshapedKernelConfigurationValhall.h" #include <memory> @@ -37,17 +38,26 @@ namespace cl_gemm class CLGEMMReshapedKernelConfigurationFactory final { public: - /** Static method to call the CLGEMMReshaped kernel configuration class accordingly with the GPU architecture + /** Static method to call the CLGEMMReshaped kernel configuration class accordingly with the GPU target * - * @param[in] arch GPU target + * @param[in] gpu GPU target * * @return CLGEMMReshaped 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<CLGEMMReshapedKernelConfigurationBifrost>(arch); + switch(get_arch_from_target(gpu)) + { + case GPUTarget::MIDGARD: + case GPUTarget::BIFROST: + return support::cpp14::make_unique<CLGEMMReshapedKernelConfigurationBifrost>(gpu); + break; + case GPUTarget::VALHALL: + return support::cpp14::make_unique<CLGEMMReshapedKernelConfigurationValhall>(gpu); + break; + default: + ARM_COMPUTE_ERROR("Not supported GPU target"); + } } }; } // namespace cl_gemm |