blob: 219edc9680936e437e350ba7a8f0e62ff54fbc39 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
|
//
// Copyright © 2017 Arm Ltd. All rights reserved.
// SPDX-License-Identifier: MIT
//
#include "NeonTimer.hpp"
#include "NeonInterceptorScheduler.hpp"
#include <memory>
#include <boost/assert.hpp>
#include <boost/format.hpp>
namespace armnn
{
namespace
{
static thread_local auto g_Interceptor = std::make_shared<NeonInterceptorScheduler>(arm_compute::Scheduler::get());
}
void NeonTimer::Start()
{
m_Kernels.clear();
BOOST_ASSERT(g_Interceptor->GetKernels() == nullptr);
g_Interceptor->SetKernels(&m_Kernels);
m_RealSchedulerType = arm_compute::Scheduler::get_type();
//Note: We can't currently replace a custom scheduler
if(m_RealSchedulerType != arm_compute::Scheduler::Type::CUSTOM)
{
// Keep the real schedule and add NeonInterceptorScheduler as an interceptor
m_RealScheduler = &arm_compute::Scheduler::get();
arm_compute::Scheduler::set(std::static_pointer_cast<arm_compute::IScheduler>(g_Interceptor));
}
}
void NeonTimer::Stop()
{
// Restore real scheduler
g_Interceptor->SetKernels(nullptr);
arm_compute::Scheduler::set(m_RealSchedulerType);
m_RealScheduler = nullptr;
}
std::vector<Measurement> NeonTimer::GetMeasurements() const
{
std::vector<Measurement> measurements = m_Kernels;
unsigned int kernel_number = 0;
for (auto & kernel : measurements)
{
std::string kernelName = std::string(this->GetName()) + "/" + std::to_string(kernel_number++) + ": " + kernel
.m_Name;
kernel.m_Name = kernelName;
}
return measurements;
}
const char* NeonTimer::GetName() const
{
return "NeonKernelTimer";
}
}
|