From 12f2b8c316155660f1e612fe7e8fab7861decc03 Mon Sep 17 00:00:00 2001 From: Gian Marco Iodice Date: Thu, 13 Feb 2020 12:27:37 +0000 Subject: COMPMID-3202: Add support for Valhall architecture in GEMM Change-Id: I2cd0b5ee0ae2e3c65a04c7be70478b0452e55132 Signed-off-by: Gian Marco Iodice Reviewed-on: https://review.mlplatform.org/c/ml/ComputeLibrary/+/2730 Tested-by: Arm Jenkins Reviewed-by: Georgios Pinitas Comments-Addressed: Arm Jenkins --- .../reshaped/CLGEMMReshapedKernelConfiguration.h | 24 +++++++++++++++------- 1 file changed, 17 insertions(+), 7 deletions(-) (limited to 'arm_compute/core/CL/gemm/reshaped/CLGEMMReshapedKernelConfiguration.h') 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 @@ -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 create(GPUTarget arch) + static std::unique_ptr 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(arch); + switch(get_arch_from_target(gpu)) + { + case GPUTarget::MIDGARD: + case GPUTarget::BIFROST: + return support::cpp14::make_unique(gpu); + break; + case GPUTarget::VALHALL: + return support::cpp14::make_unique(gpu); + break; + default: + ARM_COMPUTE_ERROR("Not supported GPU target"); + } } }; } // namespace cl_gemm -- cgit v1.2.1