// // Copyright © 2019 Arm Ltd. All rights reserved. // SPDX-License-Identifier: MIT // #include "ConnectionAcknowledgedCommandHandler.hpp" #include #include namespace armnn { namespace profiling { void ConnectionAcknowledgedCommandHandler::operator()(const Packet& packet) { ProfilingState currentState = m_StateMachine.GetCurrentState(); switch (currentState) { case ProfilingState::Uninitialised: case ProfilingState::NotConnected: throw RuntimeException(boost::str(boost::format("Connection Acknowledged Command Handler invoked while in an " "wrong state: %1%") % GetProfilingStateName(currentState))); case ProfilingState::WaitingForAck: // Process the packet if (!(packet.GetPacketFamily() == 0u && packet.GetPacketId() == 1u)) { throw armnn::InvalidArgumentException(boost::str(boost::format("Expected Packet family = 0, id = 1 but " "received family = %1%, id = %2%") % packet.GetPacketFamily() % packet.GetPacketId())); } // Once a Connection Acknowledged packet has been received, move to the Active state immediately m_StateMachine.TransitionToState(ProfilingState::Active); // Send all the packet required for the handshake with the external profiling service m_SendCounterPacket.SendStreamMetaDataPacket(); m_SendCounterPacket.SendCounterDirectoryPacket(m_CounterDirectory); m_SendTimelinePacket.SendTimelineMessageDirectoryPackage(); // Notify the Send Thread that new data is available in the Counter Stream Buffer m_SendCounterPacket.SetReadyToRead(); break; case ProfilingState::Active: return; // NOP default: throw RuntimeException(boost::str(boost::format("Unknown profiling service state: %1%") % static_cast(currentState))); } } } // namespace profiling } // namespace armnn