blob: 45cad7b2c6db847f10a372293a9eca20a2496f6e [file] [log] [blame]
David Monahande803072020-01-30 12:44:23 +00001//
Pablo Marquez Tello1bf35f52023-03-31 15:57:43 +01002// Copyright © 2020,2023 Arm Ltd and Contributors. All rights reserved.
David Monahande803072020-01-30 12:44:23 +00003// SPDX-License-Identifier: MIT
4//
5#pragma once
6
Pablo Marquez Tello1bf35f52023-03-31 15:57:43 +01007#include <cstdint>
David Monahande803072020-01-30 12:44:23 +00008#include <map>
Cathal Corbett3464ba12022-03-04 11:36:39 +00009#include <string>
David Monahande803072020-01-30 12:44:23 +000010
Cathal Corbett5aa9fd72022-02-25 15:33:28 +000011namespace arm
David Monahande803072020-01-30 12:44:23 +000012{
Cathal Corbett5aa9fd72022-02-25 15:33:28 +000013namespace pipe
David Monahande803072020-01-30 12:44:23 +000014{
15
Jim Flynn8e0c7a62020-01-30 14:10:55 +000016class ICounterMappings
17{
18public:
Cathal Corbett6f073722022-03-04 12:11:09 +000019 virtual uint16_t GetGlobalId(uint16_t backendCounterId, const std::string& backendId) const = 0;
20 virtual const std::pair<uint16_t, std::string>& GetBackendId(uint16_t globalCounterId) const = 0;
Jim Flynn8e0c7a62020-01-30 14:10:55 +000021 virtual ~ICounterMappings() {}
22};
23
24class IRegisterCounterMapping
25{
26public:
27 virtual void RegisterMapping(uint16_t globalCounterId,
28 uint16_t backendCounterId,
Cathal Corbett6f073722022-03-04 12:11:09 +000029 const std::string& backendId) = 0;
Jim Flynn97897022020-02-02 12:52:59 +000030 virtual void Reset() = 0;
Jim Flynn8e0c7a62020-01-30 14:10:55 +000031 virtual ~IRegisterCounterMapping() {}
32};
33
34class CounterIdMap : public ICounterMappings, public IRegisterCounterMapping
David Monahande803072020-01-30 12:44:23 +000035{
36
37public:
Jim Flynn8e0c7a62020-01-30 14:10:55 +000038 CounterIdMap() = default;
39 virtual ~CounterIdMap() {}
40 void RegisterMapping(uint16_t globalCounterId,
41 uint16_t backendCounterId,
Cathal Corbett6f073722022-03-04 12:11:09 +000042 const std::string& backendId) override;
Jim Flynn97897022020-02-02 12:52:59 +000043 void Reset() override;
Cathal Corbett6f073722022-03-04 12:11:09 +000044 uint16_t GetGlobalId(uint16_t backendCounterId, const std::string& backendId) const override;
45 const std::pair<uint16_t, std::string>& GetBackendId(uint16_t globalCounterId) const override;
David Monahande803072020-01-30 12:44:23 +000046private:
Cathal Corbett6f073722022-03-04 12:11:09 +000047 std::map<uint16_t, std::pair<uint16_t, std::string>> m_GlobalCounterIdMap;
48 std::map<std::pair<uint16_t, std::string>, uint16_t> m_BackendCounterIdMap;
David Monahande803072020-01-30 12:44:23 +000049};
50
Cathal Corbett5aa9fd72022-02-25 15:33:28 +000051} // namespace pipe
52} // namespace arm