blob: dbb1503d2434d4f39f01b77961d3d296512da449 [file] [log] [blame]
telsoa01c577f2c2018-08-31 09:22:23 +01001//
2// Copyright © 2017 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
Narumol Prangnawaratac2770a2020-04-01 16:51:23 +01009#include <armnn/utility/Assert.hpp>
Matthew Bentham79bb6532022-02-11 08:29:42 +000010#include <armnn/utility/PolymorphicDowncast.hpp>
Narumol Prangnawaratac2770a2020-04-01 16:51:23 +010011
telsoa01c577f2c2018-08-31 09:22:23 +010012#include <memory>
13
telsoa01c577f2c2018-08-31 09:22:23 +010014namespace armnn
15{
Derek Lambertie4ba53a2018-10-01 09:28:57 +010016namespace
17{
18static thread_local auto g_Interceptor = std::make_shared<NeonInterceptorScheduler>(arm_compute::Scheduler::get());
19}
telsoa01c577f2c2018-08-31 09:22:23 +010020
21void NeonTimer::Start()
22{
23 m_Kernels.clear();
Narumol Prangnawaratac2770a2020-04-01 16:51:23 +010024 ARMNN_ASSERT(g_Interceptor->GetKernels() == nullptr);
Derek Lambertie4ba53a2018-10-01 09:28:57 +010025 g_Interceptor->SetKernels(&m_Kernels);
26
telsoa01c577f2c2018-08-31 09:22:23 +010027 m_RealSchedulerType = arm_compute::Scheduler::get_type();
28 //Note: We can't currently replace a custom scheduler
29 if(m_RealSchedulerType != arm_compute::Scheduler::Type::CUSTOM)
30 {
31 // Keep the real schedule and add NeonInterceptorScheduler as an interceptor
32 m_RealScheduler = &arm_compute::Scheduler::get();
Matthew Bentham79bb6532022-02-11 08:29:42 +000033 arm_compute::Scheduler::set(armnn::PolymorphicPointerDowncast<arm_compute::IScheduler>(g_Interceptor));
telsoa01c577f2c2018-08-31 09:22:23 +010034 }
35}
36
37void NeonTimer::Stop()
38{
39 // Restore real scheduler
Derek Lambertie4ba53a2018-10-01 09:28:57 +010040 g_Interceptor->SetKernels(nullptr);
telsoa01c577f2c2018-08-31 09:22:23 +010041 arm_compute::Scheduler::set(m_RealSchedulerType);
42 m_RealScheduler = nullptr;
43}
44
Kevin May251fd952022-10-05 14:42:55 +010045bool NeonTimer::HasKernelMeasurements() const
46{
47 return m_Kernels.size() > 0;
48}
49
telsoa01c577f2c2018-08-31 09:22:23 +010050std::vector<Measurement> NeonTimer::GetMeasurements() const
51{
52 std::vector<Measurement> measurements = m_Kernels;
53 unsigned int kernel_number = 0;
54 for (auto & kernel : measurements)
55 {
56 std::string kernelName = std::string(this->GetName()) + "/" + std::to_string(kernel_number++) + ": " + kernel
57 .m_Name;
58 kernel.m_Name = kernelName;
59 }
60 return measurements;
61}
62
63const char* NeonTimer::GetName() const
64{
65 return "NeonKernelTimer";
66}
67
68}