blob: 38955943aae6322c066172a18fb916be41137d6e [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
David Monahande803072020-01-30 12:44:23 +00007#include <map>
8
Cathal Corbett5aa9fd72022-02-25 15:33:28 +00009namespace arm
David Monahande803072020-01-30 12:44:23 +000010{
Cathal Corbett5aa9fd72022-02-25 15:33:28 +000011namespace pipe
David Monahande803072020-01-30 12:44:23 +000012{
13
Jim Flynn8e0c7a62020-01-30 14:10:55 +000014class ICounterMappings
15{
16public:
Cathal Corbett6f073722022-03-04 12:11:09 +000017 virtual uint16_t GetGlobalId(uint16_t backendCounterId, const std::string& backendId) const = 0;
18 virtual const std::pair<uint16_t, std::string>& GetBackendId(uint16_t globalCounterId) const = 0;
Jim Flynn8e0c7a62020-01-30 14:10:55 +000019 virtual ~ICounterMappings() {}
20};
21
22class IRegisterCounterMapping
23{
24public:
25 virtual void RegisterMapping(uint16_t globalCounterId,
26 uint16_t backendCounterId,
Cathal Corbett6f073722022-03-04 12:11:09 +000027 const std::string& backendId) = 0;
Jim Flynn97897022020-02-02 12:52:59 +000028 virtual void Reset() = 0;
Jim Flynn8e0c7a62020-01-30 14:10:55 +000029 virtual ~IRegisterCounterMapping() {}
30};
31
32class CounterIdMap : public ICounterMappings, public IRegisterCounterMapping
David Monahande803072020-01-30 12:44:23 +000033{
34
35public:
Jim Flynn8e0c7a62020-01-30 14:10:55 +000036 CounterIdMap() = default;
37 virtual ~CounterIdMap() {}
38 void RegisterMapping(uint16_t globalCounterId,
39 uint16_t backendCounterId,
Cathal Corbett6f073722022-03-04 12:11:09 +000040 const std::string& backendId) override;
Jim Flynn97897022020-02-02 12:52:59 +000041 void Reset() override;
Cathal Corbett6f073722022-03-04 12:11:09 +000042 uint16_t GetGlobalId(uint16_t backendCounterId, const std::string& backendId) const override;
43 const std::pair<uint16_t, std::string>& GetBackendId(uint16_t globalCounterId) const override;
David Monahande803072020-01-30 12:44:23 +000044private:
Cathal Corbett6f073722022-03-04 12:11:09 +000045 std::map<uint16_t, std::pair<uint16_t, std::string>> m_GlobalCounterIdMap;
46 std::map<std::pair<uint16_t, std::string>, uint16_t> m_BackendCounterIdMap;
David Monahande803072020-01-30 12:44:23 +000047};
48
Cathal Corbett5aa9fd72022-02-25 15:33:28 +000049} // namespace pipe
50} // namespace arm