blob: 88d8cb02e9dda9a10d23e89c0013f0cfa35e74f5 [file] [log] [blame]
telsoa01c577f2c2018-08-31 09:22:23 +01001//
Colm Donelanb4ef1632024-02-01 15:00:43 +00002// Copyright © 2017, 2024 Arm Ltd. All rights reserved.
David Beckecb56cd2018-09-05 12:52:57 +01003// SPDX-License-Identifier: MIT
telsoa01c577f2c2018-08-31 09:22:23 +01004//
5
6#include "NeonTimer.hpp"
7#include "NeonInterceptorScheduler.hpp"
8
Matthew Bentham79bb6532022-02-11 08:29:42 +00009#include <armnn/utility/PolymorphicDowncast.hpp>
Narumol Prangnawaratac2770a2020-04-01 16:51:23 +010010
telsoa01c577f2c2018-08-31 09:22:23 +010011#include <memory>
12
telsoa01c577f2c2018-08-31 09:22:23 +010013namespace armnn
14{
Derek Lambertie4ba53a2018-10-01 09:28:57 +010015namespace
16{
17static thread_local auto g_Interceptor = std::make_shared<NeonInterceptorScheduler>(arm_compute::Scheduler::get());
18}
telsoa01c577f2c2018-08-31 09:22:23 +010019
20void NeonTimer::Start()
21{
22 m_Kernels.clear();
Colm Donelanb4ef1632024-02-01 15:00:43 +000023 if (g_Interceptor->GetKernels() != nullptr)
24 {
25 throw RuntimeException("This NeonTimer instance has already been started.");
26 }
Derek Lambertie4ba53a2018-10-01 09:28:57 +010027 g_Interceptor->SetKernels(&m_Kernels);
28
telsoa01c577f2c2018-08-31 09:22:23 +010029 m_RealSchedulerType = arm_compute::Scheduler::get_type();
30 //Note: We can't currently replace a custom scheduler
31 if(m_RealSchedulerType != arm_compute::Scheduler::Type::CUSTOM)
32 {
33 // Keep the real schedule and add NeonInterceptorScheduler as an interceptor
34 m_RealScheduler = &arm_compute::Scheduler::get();
Matthew Bentham79bb6532022-02-11 08:29:42 +000035 arm_compute::Scheduler::set(armnn::PolymorphicPointerDowncast<arm_compute::IScheduler>(g_Interceptor));
telsoa01c577f2c2018-08-31 09:22:23 +010036 }
37}
38
39void NeonTimer::Stop()
40{
41 // Restore real scheduler
Derek Lambertie4ba53a2018-10-01 09:28:57 +010042 g_Interceptor->SetKernels(nullptr);
telsoa01c577f2c2018-08-31 09:22:23 +010043 arm_compute::Scheduler::set(m_RealSchedulerType);
44 m_RealScheduler = nullptr;
45}
46
Kevin May251fd952022-10-05 14:42:55 +010047bool NeonTimer::HasKernelMeasurements() const
48{
49 return m_Kernels.size() > 0;
50}
51
telsoa01c577f2c2018-08-31 09:22:23 +010052std::vector<Measurement> NeonTimer::GetMeasurements() const
53{
54 std::vector<Measurement> measurements = m_Kernels;
55 unsigned int kernel_number = 0;
56 for (auto & kernel : measurements)
57 {
58 std::string kernelName = std::string(this->GetName()) + "/" + std::to_string(kernel_number++) + ": " + kernel
59 .m_Name;
60 kernel.m_Name = kernelName;
61 }
62 return measurements;
63}
64
65const char* NeonTimer::GetName() const
66{
67 return "NeonKernelTimer";
68}
69
70}