blob: 1079a0d57c46f4ecfdfb7321f19170678005d444 [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>
10
telsoa01c577f2c2018-08-31 09:22:23 +010011#include <memory>
12
telsoa01c577f2c2018-08-31 09:22:23 +010013#include <boost/format.hpp>
14
15namespace armnn
16{
Derek Lambertie4ba53a2018-10-01 09:28:57 +010017namespace
18{
19static thread_local auto g_Interceptor = std::make_shared<NeonInterceptorScheduler>(arm_compute::Scheduler::get());
20}
telsoa01c577f2c2018-08-31 09:22:23 +010021
22void NeonTimer::Start()
23{
24 m_Kernels.clear();
Narumol Prangnawaratac2770a2020-04-01 16:51:23 +010025 ARMNN_ASSERT(g_Interceptor->GetKernels() == nullptr);
Derek Lambertie4ba53a2018-10-01 09:28:57 +010026 g_Interceptor->SetKernels(&m_Kernels);
27
telsoa01c577f2c2018-08-31 09:22:23 +010028 m_RealSchedulerType = arm_compute::Scheduler::get_type();
29 //Note: We can't currently replace a custom scheduler
30 if(m_RealSchedulerType != arm_compute::Scheduler::Type::CUSTOM)
31 {
32 // Keep the real schedule and add NeonInterceptorScheduler as an interceptor
33 m_RealScheduler = &arm_compute::Scheduler::get();
Derek Lambertie4ba53a2018-10-01 09:28:57 +010034 arm_compute::Scheduler::set(std::static_pointer_cast<arm_compute::IScheduler>(g_Interceptor));
telsoa01c577f2c2018-08-31 09:22:23 +010035 }
36}
37
38void NeonTimer::Stop()
39{
40 // Restore real scheduler
Derek Lambertie4ba53a2018-10-01 09:28:57 +010041 g_Interceptor->SetKernels(nullptr);
telsoa01c577f2c2018-08-31 09:22:23 +010042 arm_compute::Scheduler::set(m_RealSchedulerType);
43 m_RealScheduler = nullptr;
44}
45
46std::vector<Measurement> NeonTimer::GetMeasurements() const
47{
48 std::vector<Measurement> measurements = m_Kernels;
49 unsigned int kernel_number = 0;
50 for (auto & kernel : measurements)
51 {
52 std::string kernelName = std::string(this->GetName()) + "/" + std::to_string(kernel_number++) + ": " + kernel
53 .m_Name;
54 kernel.m_Name = kernelName;
55 }
56 return measurements;
57}
58
59const char* NeonTimer::GetName() const
60{
61 return "NeonKernelTimer";
62}
63
64}