blob: cce7184c462c1fc9f376f38a6506b0f8fc4394e3 [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>
Cathal Corbett3464ba12022-03-04 11:36:39 +00008#include <string>
David Monahande803072020-01-30 12:44:23 +00009
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:
Cathal Corbett6f073722022-03-04 12:11:09 +000018 virtual uint16_t GetGlobalId(uint16_t backendCounterId, const std::string& backendId) const = 0;
19 virtual const std::pair<uint16_t, std::string>& GetBackendId(uint16_t globalCounterId) const = 0;
Jim Flynn8e0c7a62020-01-30 14:10:55 +000020 virtual ~ICounterMappings() {}
21};
22
23class IRegisterCounterMapping
24{
25public:
26 virtual void RegisterMapping(uint16_t globalCounterId,
27 uint16_t backendCounterId,
Cathal Corbett6f073722022-03-04 12:11:09 +000028 const std::string& 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,
Cathal Corbett6f073722022-03-04 12:11:09 +000041 const std::string& backendId) override;
Jim Flynn97897022020-02-02 12:52:59 +000042 void Reset() override;
Cathal Corbett6f073722022-03-04 12:11:09 +000043 uint16_t GetGlobalId(uint16_t backendCounterId, const std::string& backendId) const override;
44 const std::pair<uint16_t, std::string>& GetBackendId(uint16_t globalCounterId) const override;
David Monahande803072020-01-30 12:44:23 +000045private:
Cathal Corbett6f073722022-03-04 12:11:09 +000046 std::map<uint16_t, std::pair<uint16_t, std::string>> m_GlobalCounterIdMap;
47 std::map<std::pair<uint16_t, std::string>, uint16_t> m_BackendCounterIdMap;
David Monahande803072020-01-30 12:44:23 +000048};
49
Cathal Corbett5aa9fd72022-02-25 15:33:28 +000050} // namespace pipe
51} // namespace arm