diff options
author | Jim Flynn <jim.flynn@arm.com> | 2020-07-20 16:57:44 +0100 |
---|---|---|
committer | Jim Flynn <jim.flynn@arm.com> | 2020-07-29 15:35:15 +0100 |
commit | bbfe603e5ae42317a2b67d713d00882bea341c88 (patch) | |
tree | 8d8a78d6836384fb92fb9741c865443624dfec68 /profiling/common/src/CommandHandlerRegistry.cpp | |
parent | a9c2ce123a6a5a68728d040a0323c482bbe46903 (diff) | |
download | armnn-bbfe603e5ae42317a2b67d713d00882bea341c88.tar.gz |
IVGCVSW-5166 Pull out the common and server side code into standalone libraries
Change-Id: I180f84c493a9b2be4b93b25d312ebdd9e71b1735
Signed-off-by: Jim Flynn <jim.flynn@arm.com>
Diffstat (limited to 'profiling/common/src/CommandHandlerRegistry.cpp')
-rw-r--r-- | profiling/common/src/CommandHandlerRegistry.cpp | 61 |
1 files changed, 61 insertions, 0 deletions
diff --git a/profiling/common/src/CommandHandlerRegistry.cpp b/profiling/common/src/CommandHandlerRegistry.cpp new file mode 100644 index 0000000000..324737eda5 --- /dev/null +++ b/profiling/common/src/CommandHandlerRegistry.cpp @@ -0,0 +1,61 @@ +// +// Copyright © 2017 Arm Ltd and Contributors. All rights reserved. +// SPDX-License-Identifier: MIT +// + + +#include <common/include/Assert.hpp> +#include <common/include/CommandHandlerRegistry.hpp> + +#include <sstream> + +namespace arm +{ + +namespace pipe +{ + +void CommandHandlerRegistry::RegisterFunctor(CommandHandlerFunctor* functor, + uint32_t familyId, + uint32_t packetId, + uint32_t version) +{ + ARM_PIPE_ASSERT_MSG(functor, "Provided functor should not be a nullptr"); + + CommandHandlerKey key(familyId, packetId, version); + registry[key] = functor; +} + +void CommandHandlerRegistry::RegisterFunctor(CommandHandlerFunctor* functor) +{ + ARM_PIPE_ASSERT_MSG(functor, "Provided functor should not be a nullptr"); + + RegisterFunctor(functor, functor->GetFamilyId(), functor->GetPacketId(), functor->GetVersion()); +} + +CommandHandlerFunctor* CommandHandlerRegistry::GetFunctor(uint32_t familyId,uint32_t packetId, uint32_t version) const +{ + CommandHandlerKey key(familyId, packetId, version); + + // Check that the requested key exists + if (registry.find(key) == registry.end()) + { + std::stringstream ss; + ss << "Functor with requested PacketId=" << packetId << " and Version=" << version << " does not exist"; + throw ProfilingException(ss.str()); + } + + CommandHandlerFunctor* commandHandlerFunctor = registry.at(key); + if (commandHandlerFunctor == nullptr) + { + std::stringstream ss; + ss << "Invalid functor registered for PacketId=" << packetId << " and Version=" << version; + throw ProfilingException(ss.str()); + } + + return commandHandlerFunctor; +} + +} // namespace pipe + +} // namespace arm |