blob: 7a3c3614eec3f0dffda5997da74575a3b9fabc5b [file] [log] [blame]
David Monahande803072020-01-30 12:44:23 +00001//
2// Copyright © 2020 Arm Ltd. All rights reserved.
3// SPDX-License-Identifier: MIT
4//
5#pragma once
6
7#include "armnn/BackendId.hpp"
8#include <map>
9
Cathal Corbett5aa9fd72022-02-25 15:33:28 +000010namespace arm
David Monahande803072020-01-30 12:44:23 +000011{
Cathal Corbett5aa9fd72022-02-25 15:33:28 +000012namespace pipe
David Monahande803072020-01-30 12:44:23 +000013{
14
Jim Flynn8e0c7a62020-01-30 14:10:55 +000015class ICounterMappings
16{
17public:
18 virtual uint16_t GetGlobalId(uint16_t backendCounterId, const armnn::BackendId& backendId) const = 0;
19 virtual const std::pair<uint16_t, armnn::BackendId>& GetBackendId(uint16_t globalCounterId) const = 0;
20 virtual ~ICounterMappings() {}
21};
22
23class IRegisterCounterMapping
24{
25public:
26 virtual void RegisterMapping(uint16_t globalCounterId,
27 uint16_t backendCounterId,
28 const armnn::BackendId& backendId) = 0;
Jim Flynn97897022020-02-02 12:52:59 +000029 virtual void Reset() = 0;
Jim Flynn8e0c7a62020-01-30 14:10:55 +000030 virtual ~IRegisterCounterMapping() {}
31};
32
33class CounterIdMap : public ICounterMappings, public IRegisterCounterMapping
David Monahande803072020-01-30 12:44:23 +000034{
35
36public:
Jim Flynn8e0c7a62020-01-30 14:10:55 +000037 CounterIdMap() = default;
38 virtual ~CounterIdMap() {}
39 void RegisterMapping(uint16_t globalCounterId,
40 uint16_t backendCounterId,
41 const armnn::BackendId& backendId) override;
Jim Flynn97897022020-02-02 12:52:59 +000042 void Reset() override;
Jim Flynn8e0c7a62020-01-30 14:10:55 +000043 uint16_t GetGlobalId(uint16_t backendCounterId, const armnn::BackendId& backendId) const override;
44 const std::pair<uint16_t, armnn::BackendId>& GetBackendId(uint16_t globalCounterId) const override;
David Monahande803072020-01-30 12:44:23 +000045private:
46 std::map<uint16_t, std::pair<uint16_t, armnn::BackendId>> m_GlobalCounterIdMap;
47 std::map<std::pair<uint16_t, armnn::BackendId>, uint16_t> m_BackendCounterIdMap;
48};
49
Cathal Corbett5aa9fd72022-02-25 15:33:28 +000050} // namespace pipe
51} // namespace arm