diff options
author | Keith Davis <keith.davis@arm.com> | 2020-03-30 10:43:41 +0100 |
---|---|---|
committer | Finn Williams <Finn.Williams@arm.com> | 2020-04-02 16:56:24 +0100 |
commit | 33ed221e2e8e3a77b5f543061e0cce07b259fc64 (patch) | |
tree | 8467f2e4ce019bfa2837ae1030c321509414780c /src/profiling/ActivateTimelineReportingCommandHandler.cpp | |
parent | 0fe279bbf22fd2116b283b9df61076d526f115e4 (diff) | |
download | armnn-33ed221e2e8e3a77b5f543061e0cce07b259fc64.tar.gz |
IVGCVSW-4455 Add an Activate and Deactivate control packet to the protocol
* Add Activate/Deactivate command handlers
* Add IReportStructure, INotifyBackends single function interfaces
* Add overrided mechanism to report structure in Runtime.cpp
* Add overrided mechanism to notify backends in ProfilingService.cpp
* Add optional IReportStructure argument to ProfilingService constructor
for use in ActivateTimelineReportingCommandHandler
* Refactoring and tidying up indentation
* Removal of unused code in ProfilingUtils.cpp and ProfilingService.cpp
* Added GatordMock end to end test
* Fixed an issue with SendCounterPacket sending duplicate packets
* Fixed an issue with DirectoryCaptureCommandHandler handling of Optional
Signed-off-by: Keith Davis <keith.davis@arm.com>
Signed-off-by: Finn Williams <Finn.Williams@arm.com>
Change-Id: I5ef1b74171459bfc649861dedf99921d22c9e63f
Diffstat (limited to 'src/profiling/ActivateTimelineReportingCommandHandler.cpp')
-rw-r--r-- | src/profiling/ActivateTimelineReportingCommandHandler.cpp | 63 |
1 files changed, 63 insertions, 0 deletions
diff --git a/src/profiling/ActivateTimelineReportingCommandHandler.cpp b/src/profiling/ActivateTimelineReportingCommandHandler.cpp new file mode 100644 index 0000000000..d762efc277 --- /dev/null +++ b/src/profiling/ActivateTimelineReportingCommandHandler.cpp @@ -0,0 +1,63 @@ +// +// Copyright © 2020 Arm Ltd. All rights reserved. +// SPDX-License-Identifier: MIT +// + +#include "ActivateTimelineReportingCommandHandler.hpp" +#include "TimelineUtilityMethods.hpp" + +#include <armnn/Exceptions.hpp> +#include <boost/format.hpp> + +namespace armnn +{ + +namespace profiling +{ + +void ActivateTimelineReportingCommandHandler::operator()(const Packet& packet) +{ + ProfilingState currentState = m_StateMachine.GetCurrentState(); + + if (!m_ReportStructure.has_value()) + { + throw armnn::Exception(std::string("Profiling Service constructor must be initialised with an " + "IReportStructure argument in order to run timeline reporting")); + } + + switch ( currentState ) + { + case ProfilingState::Uninitialised: + case ProfilingState::NotConnected: + case ProfilingState::WaitingForAck: + throw RuntimeException(boost::str( + boost::format("Activate Timeline Reporting Command Handler invoked while in a wrong state: %1%") + % GetProfilingStateName(currentState))); + case ProfilingState::Active: + if ( !( packet.GetPacketFamily() == 0u && packet.GetPacketId() == 6u )) + { + throw armnn::Exception(std::string("Expected Packet family = 0, id = 6 but received family =") + + std::to_string(packet.GetPacketFamily()) + + " id = " + std::to_string(packet.GetPacketId())); + } + + m_SendTimelinePacket.SendTimelineMessageDirectoryPackage(); + + TimelineUtilityMethods::SendWellKnownLabelsAndEventClasses(m_SendTimelinePacket); + + m_TimelineReporting = true; + + m_ReportStructure.value().ReportStructure(); + + m_BackendNotifier.NotifyBackendsForTimelineReporting(); + + break; + default: + throw RuntimeException(boost::str(boost::format("Unknown profiling service state: %1%") + % static_cast<int>(currentState))); + } +} + +} // namespace profiling + +} // namespace armnn
\ No newline at end of file |