blob: c07beafedf2e0fb6e2a0b938baedebcf12042b2b [file] [log] [blame]
Jim Flynnbbfe6032020-07-20 16:57:44 +01001//
2// Copyright © 2020 Arm Ltd and Contributors. All rights reserved.
3// SPDX-License-Identifier: MIT
4//
5#pragma once
6
Jim Flynnc454ac92022-03-16 18:43:18 +00007#include "ICounterDirectory.hpp"
8
Jim Flynnbbfe6032020-07-20 16:57:44 +01009#include <cstdint>
10#include <string>
11
12namespace arm
13{
14
15namespace pipe
16{
17void ReadBytes(const unsigned char* buffer, unsigned int offset, unsigned int valueSize, uint8_t outValue[]);
18
19uint64_t ReadUint64(unsigned const char* buffer, unsigned int offset);
20
21uint32_t ReadUint32(unsigned const char* buffer, unsigned int offset);
22
23uint16_t ReadUint16(unsigned const char* buffer, unsigned int offset);
24
25uint8_t ReadUint8(unsigned const char* buffer, unsigned int offset);
26
27void WriteBytes(unsigned char* buffer, unsigned int offset, const void* value, unsigned int valueSize);
28
29void WriteUint64(unsigned char* buffer, unsigned int offset, uint64_t value);
30
31void WriteUint32(unsigned char* buffer, unsigned int offset, uint32_t value);
32
33void WriteUint16(unsigned char* buffer, unsigned int offset, uint16_t value);
34
35void WriteUint8(unsigned char* buffer, unsigned int offset, uint8_t value);
36
37std::string CentreAlignFormatting(const std::string& stringToPass, const int spacingWidth);
38
Jim Flynnc454ac92022-03-16 18:43:18 +000039void PrintCounterDirectory(ICounterDirectory& counterDirectory);
40
41uint16_t GetNextUid(bool peekOnly = false);
42
43 std::vector<uint16_t> GetNextCounterUids(uint16_t firstUid, uint16_t cores);
44
Jim Flynnbbfe6032020-07-20 16:57:44 +010045} // namespace pipe
Jim Flynnc454ac92022-03-16 18:43:18 +000046} // namespace arm