Aron Virginas-Tar | 4e5fc1f | 2019-08-22 18:10:52 +0100 | [diff] [blame] | 1 | // |
Jim Flynn | bbfe603 | 2020-07-20 16:57:44 +0100 | [diff] [blame] | 2 | // Copyright © 2017 Arm Ltd and Contributors. All rights reserved. |
Aron Virginas-Tar | 4e5fc1f | 2019-08-22 18:10:52 +0100 | [diff] [blame] | 3 | // SPDX-License-Identifier: MIT |
| 4 | // |
| 5 | |
| 6 | #pragma once |
| 7 | |
Matteo Martincigh | 6db5f20 | 2019-09-05 12:02:04 +0100 | [diff] [blame] | 8 | #include "ICounterDirectory.hpp" |
Jim Flynn | 9789702 | 2020-02-02 12:52:59 +0000 | [diff] [blame] | 9 | #include "ICounterRegistry.hpp" |
Matteo Martincigh | 6db5f20 | 2019-09-05 12:02:04 +0100 | [diff] [blame] | 10 | |
Aron Virginas-Tar | 4e5fc1f | 2019-08-22 18:10:52 +0100 | [diff] [blame] | 11 | #include <string> |
Matteo Martincigh | 6db5f20 | 2019-09-05 12:02:04 +0100 | [diff] [blame] | 12 | #include <unordered_set> |
| 13 | #include <unordered_map> |
| 14 | |
Jim Flynn | 75c14f4 | 2022-03-10 22:05:42 +0000 | [diff] [blame] | 15 | #include <common/include/NumericCast.hpp> |
Aron Virginas-Tar | 4e5fc1f | 2019-08-22 18:10:52 +0100 | [diff] [blame] | 16 | |
Cathal Corbett | 5aa9fd7 | 2022-02-25 15:33:28 +0000 | [diff] [blame] | 17 | namespace arm |
Aron Virginas-Tar | 4e5fc1f | 2019-08-22 18:10:52 +0100 | [diff] [blame] | 18 | { |
| 19 | |
Cathal Corbett | 5aa9fd7 | 2022-02-25 15:33:28 +0000 | [diff] [blame] | 20 | namespace pipe |
Aron Virginas-Tar | 4e5fc1f | 2019-08-22 18:10:52 +0100 | [diff] [blame] | 21 | { |
| 22 | |
Jim Flynn | 9789702 | 2020-02-02 12:52:59 +0000 | [diff] [blame] | 23 | class CounterDirectory final : public ICounterDirectory, public ICounterRegistry |
Matteo Martincigh | 149528e | 2019-09-05 12:02:04 +0100 | [diff] [blame] | 24 | { |
| 25 | public: |
Matteo Martincigh | 6db5f20 | 2019-09-05 12:02:04 +0100 | [diff] [blame] | 26 | CounterDirectory() = default; |
Aron Virginas-Tar | 4e5fc1f | 2019-08-22 18:10:52 +0100 | [diff] [blame] | 27 | ~CounterDirectory() = default; |
| 28 | |
Matteo Martincigh | 6db5f20 | 2019-09-05 12:02:04 +0100 | [diff] [blame] | 29 | // Register profiling objects |
Sadik Armagan | 4c99899 | 2020-02-25 12:44:44 +0000 | [diff] [blame] | 30 | const Category* RegisterCategory (const std::string& categoryName) override; |
Matteo Martincigh | 6db5f20 | 2019-09-05 12:02:04 +0100 | [diff] [blame] | 31 | const Device* RegisterDevice (const std::string& deviceName, |
| 32 | uint16_t cores = 0, |
Jim Flynn | decd08b | 2022-03-13 22:35:46 +0000 | [diff] [blame] | 33 | const arm::pipe::Optional<std::string>& parentCategoryName |
| 34 | = arm::pipe::EmptyOptional()) override; |
Matteo Martincigh | 6db5f20 | 2019-09-05 12:02:04 +0100 | [diff] [blame] | 35 | const CounterSet* RegisterCounterSet(const std::string& counterSetName, |
| 36 | uint16_t count = 0, |
Jim Flynn | decd08b | 2022-03-13 22:35:46 +0000 | [diff] [blame] | 37 | const arm::pipe::Optional<std::string>& parentCategoryName |
| 38 | = arm::pipe::EmptyOptional()) override; |
Cathal Corbett | 6f07372 | 2022-03-04 12:11:09 +0000 | [diff] [blame] | 39 | const Counter* RegisterCounter(const std::string& backendId, |
Jim Flynn | decd08b | 2022-03-13 22:35:46 +0000 | [diff] [blame] | 40 | const uint16_t uid, |
| 41 | const std::string& parentCategoryName, |
| 42 | uint16_t counterClass, |
| 43 | uint16_t interpolation, |
| 44 | double multiplier, |
| 45 | const std::string& name, |
| 46 | const std::string& description, |
| 47 | const arm::pipe::Optional<std::string>& units = arm::pipe::EmptyOptional(), |
| 48 | const arm::pipe::Optional<uint16_t>& numberOfCores = arm::pipe::EmptyOptional(), |
| 49 | const arm::pipe::Optional<uint16_t>& deviceUid = arm::pipe::EmptyOptional(), |
| 50 | const arm::pipe::Optional<uint16_t>& counterSetUid = arm::pipe::EmptyOptional()) override; |
Aron Virginas-Tar | 4e5fc1f | 2019-08-22 18:10:52 +0100 | [diff] [blame] | 51 | |
Matteo Martincigh | 6db5f20 | 2019-09-05 12:02:04 +0100 | [diff] [blame] | 52 | // Getters for counts |
Jim Flynn | 75c14f4 | 2022-03-10 22:05:42 +0000 | [diff] [blame] | 53 | uint16_t GetCategoryCount() const override { return arm::pipe::numeric_cast<uint16_t>(m_Categories.size()); } |
| 54 | uint16_t GetDeviceCount() const override { return arm::pipe::numeric_cast<uint16_t>(m_Devices.size()); } |
| 55 | uint16_t GetCounterSetCount() const override { return arm::pipe::numeric_cast<uint16_t>(m_CounterSets.size()); } |
| 56 | uint16_t GetCounterCount() const override { return arm::pipe::numeric_cast<uint16_t>(m_Counters.size()); } |
Aron Virginas-Tar | 4e5fc1f | 2019-08-22 18:10:52 +0100 | [diff] [blame] | 57 | |
Matteo Martincigh | 6db5f20 | 2019-09-05 12:02:04 +0100 | [diff] [blame] | 58 | // Getters for collections |
| 59 | const Categories& GetCategories() const override { return m_Categories; } |
| 60 | const Devices& GetDevices() const override { return m_Devices; } |
| 61 | const CounterSets& GetCounterSets() const override { return m_CounterSets; } |
| 62 | const Counters& GetCounters() const override { return m_Counters; } |
Aron Virginas-Tar | 4e5fc1f | 2019-08-22 18:10:52 +0100 | [diff] [blame] | 63 | |
Matteo Martincigh | 6db5f20 | 2019-09-05 12:02:04 +0100 | [diff] [blame] | 64 | // Getters for profiling objects |
| 65 | const Category* GetCategory(const std::string& name) const override; |
| 66 | const Device* GetDevice(uint16_t uid) const override; |
| 67 | const CounterSet* GetCounterSet(uint16_t uid) const override; |
| 68 | const Counter* GetCounter(uint16_t uid) const override; |
Aron Virginas-Tar | 4e5fc1f | 2019-08-22 18:10:52 +0100 | [diff] [blame] | 69 | |
Matteo Martincigh | a84edee | 2019-10-02 12:50:57 +0100 | [diff] [blame] | 70 | // Queries for profiling objects |
| 71 | bool IsCategoryRegistered(const std::string& categoryName) const; |
| 72 | bool IsDeviceRegistered(uint16_t deviceUid) const; |
| 73 | bool IsDeviceRegistered(const std::string& deviceName) const; |
| 74 | bool IsCounterSetRegistered(uint16_t counterSetUid) const; |
| 75 | bool IsCounterSetRegistered(const std::string& counterSetName) const; |
| 76 | bool IsCounterRegistered(uint16_t counterUid) const; |
| 77 | bool IsCounterRegistered(const std::string& counterName) const; |
| 78 | |
| 79 | // Clears all the counter directory contents |
| 80 | void Clear(); |
| 81 | |
Aron Virginas-Tar | 4e5fc1f | 2019-08-22 18:10:52 +0100 | [diff] [blame] | 82 | private: |
Matteo Martincigh | 6db5f20 | 2019-09-05 12:02:04 +0100 | [diff] [blame] | 83 | // The profiling collections owned by the counter directory |
| 84 | Categories m_Categories; |
| 85 | Devices m_Devices; |
| 86 | CounterSets m_CounterSets; |
| 87 | Counters m_Counters; |
Aron Virginas-Tar | 4e5fc1f | 2019-08-22 18:10:52 +0100 | [diff] [blame] | 88 | |
Matteo Martincigh | 6db5f20 | 2019-09-05 12:02:04 +0100 | [diff] [blame] | 89 | // Helper functions |
| 90 | CategoriesIt FindCategory(const std::string& categoryName) const; |
| 91 | DevicesIt FindDevice(uint16_t deviceUid) const; |
| 92 | DevicesIt FindDevice(const std::string& deviceName) const; |
| 93 | CounterSetsIt FindCounterSet(uint16_t counterSetUid) const; |
| 94 | CounterSetsIt FindCounterSet(const std::string& counterSetName) const; |
| 95 | CountersIt FindCounter(uint16_t counterUid) const; |
Matteo Martincigh | a84edee | 2019-10-02 12:50:57 +0100 | [diff] [blame] | 96 | CountersIt FindCounter(const std::string& counterName) const; |
Jim Flynn | decd08b | 2022-03-13 22:35:46 +0000 | [diff] [blame] | 97 | uint16_t GetNumberOfCores(const arm::pipe::Optional<uint16_t>& numberOfCores, |
Sadik Armagan | 4c99899 | 2020-02-25 12:44:44 +0000 | [diff] [blame] | 98 | uint16_t deviceUid); |
Aron Virginas-Tar | 4e5fc1f | 2019-08-22 18:10:52 +0100 | [diff] [blame] | 99 | }; |
| 100 | |
Cathal Corbett | 5aa9fd7 | 2022-02-25 15:33:28 +0000 | [diff] [blame] | 101 | } // namespace pipe |
Aron Virginas-Tar | 4e5fc1f | 2019-08-22 18:10:52 +0100 | [diff] [blame] | 102 | |
Cathal Corbett | 5aa9fd7 | 2022-02-25 15:33:28 +0000 | [diff] [blame] | 103 | } // namespace arm |