blob: 09c26b67226f8244ee7152a2bf424ef87790b165 [file] [log] [blame]
FinnWilliamsArmf6e534a2019-09-16 15:45:42 +01001//
2// Copyright © 2019 Arm Ltd. All rights reserved.
3// SPDX-License-Identifier: MIT
4//
Matteo Martincighe0e6efc2019-10-04 17:17:42 +01005
FinnWilliamsArmf6e534a2019-09-16 15:45:42 +01006#pragma once
7
8#include <cstdint>
9
10namespace armnn
11{
12
13namespace profiling
14{
15
16class IReadCounterValues
17{
18public:
FinnWilliamsArmf6e534a2019-09-16 15:45:42 +010019 virtual ~IReadCounterValues() {}
Matteo Martincigha84edee2019-10-02 12:50:57 +010020
Matteo Martincighe8485382019-10-10 14:08:21 +010021 virtual bool IsCounterRegistered(uint16_t counterUid) const = 0;
Matteo Martincigha84edee2019-10-02 12:50:57 +010022 virtual uint16_t GetCounterCount() const = 0;
Finn Williamsf3fcf322020-05-11 14:38:02 +010023 virtual uint32_t GetAbsoluteCounterValue(uint16_t counterUid) const = 0;
24 virtual uint32_t GetDeltaCounterValue(uint16_t counterUid) = 0;
FinnWilliamsArmf6e534a2019-09-16 15:45:42 +010025};
26
Matteo Martincigha84edee2019-10-02 12:50:57 +010027class IWriteCounterValues
FinnWilliamsArmf6e534a2019-09-16 15:45:42 +010028{
29public:
FinnWilliamsArmf6e534a2019-09-16 15:45:42 +010030 virtual ~IWriteCounterValues() {}
Matteo Martincigha84edee2019-10-02 12:50:57 +010031
32 virtual void SetCounterValue(uint16_t counterUid, uint32_t value) = 0;
33 virtual uint32_t AddCounterValue(uint16_t counterUid, uint32_t value) = 0;
34 virtual uint32_t SubtractCounterValue(uint16_t counterUid, uint32_t value) = 0;
35 virtual uint32_t IncrementCounterValue(uint16_t counterUid) = 0;
Matteo Martincigha84edee2019-10-02 12:50:57 +010036};
37
38class IReadWriteCounterValues : public IReadCounterValues, public IWriteCounterValues
39{
40public:
41 virtual ~IReadWriteCounterValues() {}
FinnWilliamsArmf6e534a2019-09-16 15:45:42 +010042};
43
44} // namespace profiling
45
46} // namespace armnn