blob: 215ae343d6e29ce6041ed36f7cc8746865742176 [file] [log] [blame]
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +00001//
Jim Flynn6398a982020-05-27 17:05:21 +01002// Copyright © 2019 Arm Ltd and Contributors. All rights reserved.
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +00003// SPDX-License-Identifier: MIT
4//
5
Jim Flynn34430252022-03-04 15:03:58 +00006#include <ArmNNProfilingServiceInitialiser.hpp>
Jim Flynn4c9ed1d2022-01-23 23:57:20 +00007#include "ProfilingOptionsConverter.hpp"
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +00008#include "ProfilingTestUtils.hpp"
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +00009
10#include <armnn/Descriptors.hpp>
Jim Flynn34430252022-03-04 15:03:58 +000011#include <armnn/profiling/ArmNNProfiling.hpp>
Matthew Sloyan371b70e2020-09-11 10:14:57 +010012
Jim Flynn3e9bc192022-03-23 23:01:26 +000013#include <client/src/ProfilingService.hpp>
14#include <client/src/ProfilingUtils.hpp>
Sadik Armaganea41b572020-03-19 18:16:46 +000015
Jim Flynn6730fe92022-03-10 22:57:47 +000016#include <common/include/Assert.hpp>
Nikhil Raj77fe76b2021-06-09 14:55:32 +010017#include <common/include/LabelsAndEventClasses.hpp>
Jim Flynn75c14f42022-03-10 22:05:42 +000018#include <common/include/NumericCast.hpp>
Jim Flynn77b284e2022-03-13 20:53:35 +000019#include <common/include/Processes.hpp>
Jim Flynn9c85b412022-03-16 00:27:43 +000020#include <common/include/Threads.hpp>
Nikhil Raj77fe76b2021-06-09 14:55:32 +010021
Sadik Armagana097d2a2021-11-24 15:47:28 +000022#include <TestUtils.hpp>
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +000023
Sadik Armagan1625efc2021-06-10 18:24:34 +010024#include <doctest/doctest.h>
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +000025
Finn Williamsa0de0562020-04-22 12:27:37 +010026uint32_t GetStreamMetaDataPacketSize()
27{
28 uint32_t sizeUint32 = sizeof(uint32_t);
29 uint32_t payloadSize = 0;
Jim Flynn9c85b412022-03-16 00:27:43 +000030 payloadSize += arm::pipe::numeric_cast<uint32_t>(arm::pipe::ARMNN_SOFTWARE_INFO.size()) + 1;
31 payloadSize += arm::pipe::numeric_cast<uint32_t>(arm::pipe::ARMNN_HARDWARE_VERSION.size()) + 1;
32 payloadSize += arm::pipe::numeric_cast<uint32_t>(arm::pipe::ARMNN_SOFTWARE_VERSION.size()) + 1;
Jim Flynn75c14f42022-03-10 22:05:42 +000033 payloadSize += arm::pipe::numeric_cast<uint32_t>(GetProcessName().size()) + 1;
Finn Williamsa0de0562020-04-22 12:27:37 +010034
35 // Add packetVersionEntries
Jim Flynn83d08a92020-07-09 13:48:16 +010036 payloadSize += 13 * 2 * sizeUint32;
Finn Williamsa0de0562020-04-22 12:27:37 +010037 // Add packetVersionCountSize
38 payloadSize += sizeUint32;
39
40 uint32_t headerSize = 2 * sizeUint32;
41 uint32_t bodySize = 10 * sizeUint32;
42
43 return headerSize + bodySize + payloadSize;
44}
45
Jan Eilersf78c7672020-07-01 18:09:39 +010046std::vector<BackendId> GetSuitableBackendRegistered()
47{
48 std::vector<BackendId> suitableBackends;
49 if (BackendRegistryInstance().IsBackendRegistered(GetComputeDeviceAsCString(armnn::Compute::CpuRef)))
50 {
51 suitableBackends.push_back(armnn::Compute::CpuRef);
52 }
53 if (BackendRegistryInstance().IsBackendRegistered(GetComputeDeviceAsCString(armnn::Compute::CpuAcc)))
54 {
55 suitableBackends.push_back(armnn::Compute::CpuAcc);
56 }
57 if (BackendRegistryInstance().IsBackendRegistered(GetComputeDeviceAsCString(armnn::Compute::GpuAcc)))
58 {
59 suitableBackends.push_back(armnn::Compute::GpuAcc);
60 }
61 return suitableBackends;
62}
63
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +000064inline unsigned int OffsetToNextWord(unsigned int numberOfBytes)
65{
66 unsigned int uint32_t_size = sizeof(uint32_t);
67
68 unsigned int remainder = numberOfBytes % uint32_t_size;
69 if (remainder == 0)
70 {
71 return numberOfBytes;
72 }
73
74 return numberOfBytes + uint32_t_size - remainder;
75}
76
Keith Davis97da5e22020-03-05 16:25:28 +000077void VerifyTimelineHeaderBinary(const unsigned char* readableData,
78 unsigned int& offset,
79 uint32_t packetDataLength)
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +000080{
Jim Flynn6730fe92022-03-10 22:57:47 +000081 ARM_PIPE_ASSERT(readableData);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +000082
83 // Utils
84 unsigned int uint32_t_size = sizeof(uint32_t);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +000085
Keith Davis97da5e22020-03-05 16:25:28 +000086 // Check the TimelineEventClassBinaryPacket header
Finn Williams0a336dc2020-05-11 15:39:58 +010087 uint32_t timelineBinaryPacketHeaderWord0 = ReadUint32(readableData, offset);
88 uint32_t timelineBinaryPacketFamily = (timelineBinaryPacketHeaderWord0 >> 26) & 0x0000003F;
89 uint32_t timelineBinaryPacketClass = (timelineBinaryPacketHeaderWord0 >> 19) & 0x0000007F;
90 uint32_t timelineBinaryPacketType = (timelineBinaryPacketHeaderWord0 >> 16) & 0x00000007;
91 uint32_t timelineBinaryPacketStreamId = (timelineBinaryPacketHeaderWord0 >> 0) & 0x00000007;
Sadik Armagan1625efc2021-06-10 18:24:34 +010092 CHECK(timelineBinaryPacketFamily == 1);
93 CHECK(timelineBinaryPacketClass == 0);
94 CHECK(timelineBinaryPacketType == 1);
95 CHECK(timelineBinaryPacketStreamId == 0);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +000096 offset += uint32_t_size;
Finn Williams0a336dc2020-05-11 15:39:58 +010097 uint32_t timelineBinaryPacketHeaderWord1 = ReadUint32(readableData, offset);
98 uint32_t timelineBinaryPacketSequenceNumber = (timelineBinaryPacketHeaderWord1 >> 24) & 0x00000001;
99 uint32_t timelineBinaryPacketDataLength = (timelineBinaryPacketHeaderWord1 >> 0) & 0x00FFFFFF;
Sadik Armagan1625efc2021-06-10 18:24:34 +0100100 CHECK(timelineBinaryPacketSequenceNumber == 0);
101 CHECK(timelineBinaryPacketDataLength == packetDataLength);
Keith Davis97da5e22020-03-05 16:25:28 +0000102 offset += uint32_t_size;
103}
104
Jim Flynndecd08b2022-03-13 22:35:46 +0000105ProfilingGuid VerifyTimelineLabelBinaryPacketData(arm::pipe::Optional<ProfilingGuid> guid,
Jim Flynn6398a982020-05-27 17:05:21 +0100106 const std::string& label,
107 const unsigned char* readableData,
108 unsigned int& offset)
Keith Davis97da5e22020-03-05 16:25:28 +0000109{
Jim Flynn6730fe92022-03-10 22:57:47 +0000110 ARM_PIPE_ASSERT(readableData);
Keith Davis97da5e22020-03-05 16:25:28 +0000111
112 // Utils
113 unsigned int uint32_t_size = sizeof(uint32_t);
114 unsigned int uint64_t_size = sizeof(uint64_t);
Jim Flynn75c14f42022-03-10 22:05:42 +0000115 unsigned int label_size = arm::pipe::numeric_cast<unsigned int>(label.size());
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000116
117 // Check the decl id
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000118 uint32_t eventClassDeclId = ReadUint32(readableData, offset);
Sadik Armagan1625efc2021-06-10 18:24:34 +0100119 CHECK(eventClassDeclId == 0);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000120
121 // Check the profiling GUID
122 offset += uint32_t_size;
123 uint64_t readProfilingGuid = ReadUint64(readableData, offset);
124 if (guid.has_value())
125 {
Sadik Armagan1625efc2021-06-10 18:24:34 +0100126 CHECK(readProfilingGuid == guid.value());
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000127 }
128 else
129 {
Jim Flynn34430252022-03-04 15:03:58 +0000130 ArmNNProfilingServiceInitialiser initialiser;
Jim Flynn9c85b412022-03-16 00:27:43 +0000131 ProfilingService profilingService(arm::pipe::MAX_ARMNN_COUNTER,
132 initialiser,
133 arm::pipe::ARMNN_SOFTWARE_INFO,
134 arm::pipe::ARMNN_SOFTWARE_VERSION,
135 arm::pipe::ARMNN_HARDWARE_VERSION);
Sadik Armagan1625efc2021-06-10 18:24:34 +0100136 CHECK(readProfilingGuid == profilingService.GetStaticId(label));
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000137 }
138
139 // Check the SWTrace label
140 offset += uint64_t_size;
141 uint32_t swTraceLabelLength = ReadUint32(readableData, offset);
Sadik Armagan1625efc2021-06-10 18:24:34 +0100142 CHECK(swTraceLabelLength == label_size + 1); // Label length including the null-terminator
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000143 offset += uint32_t_size;
Sadik Armagan1625efc2021-06-10 18:24:34 +0100144 CHECK(std::memcmp(readableData + offset, // Offset to the label in the buffer
Keith Davis97da5e22020-03-05 16:25:28 +0000145 label.data(), // The original label
146 swTraceLabelLength - 1) == 0); // The length of the label
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000147
148 // SWTrace strings are written in blocks of words, so the offset has to be updated to the next whole word
149 offset += OffsetToNextWord(swTraceLabelLength);
Jim Flynn6398a982020-05-27 17:05:21 +0100150
151 ProfilingGuid labelGuid(readProfilingGuid);
152 return labelGuid;
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000153}
154
Keith Davis97da5e22020-03-05 16:25:28 +0000155void VerifyTimelineEventClassBinaryPacketData(ProfilingGuid guid,
Jim Flynn1892d212020-05-26 21:10:49 +0100156 ProfilingGuid nameGuid,
Keith Davis97da5e22020-03-05 16:25:28 +0000157 const unsigned char* readableData,
158 unsigned int& offset)
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000159{
Jim Flynn6730fe92022-03-10 22:57:47 +0000160 ARM_PIPE_ASSERT(readableData);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000161
162 // Utils
163 unsigned int uint32_t_size = sizeof(uint32_t);
164 unsigned int uint64_t_size = sizeof(uint64_t);
165
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000166 // Check the decl id
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000167 uint32_t eventClassDeclId = ReadUint32(readableData, offset);
Sadik Armagan1625efc2021-06-10 18:24:34 +0100168 CHECK(eventClassDeclId == 2);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000169
170 // Check the profiling GUID
171 offset += uint32_t_size;
172 uint64_t readProfilingGuid = ReadUint64(readableData, offset);
Sadik Armagan1625efc2021-06-10 18:24:34 +0100173 CHECK(readProfilingGuid == guid);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000174
Jim Flynn1892d212020-05-26 21:10:49 +0100175 offset += uint64_t_size;
176 uint64_t readProfiilngNameGuid = ReadUint64(readableData, offset);
Sadik Armagan1625efc2021-06-10 18:24:34 +0100177 CHECK(readProfiilngNameGuid == nameGuid);
Jim Flynn1892d212020-05-26 21:10:49 +0100178
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000179 // Update the offset to allow parsing to be continued after this function returns
180 offset += uint64_t_size;
181}
182
Keith Davis97da5e22020-03-05 16:25:28 +0000183void VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType relationshipType,
Jim Flynndecd08b2022-03-13 22:35:46 +0000184 arm::pipe::Optional<ProfilingGuid> relationshipGuid,
185 arm::pipe::Optional<ProfilingGuid> headGuid,
186 arm::pipe::Optional<ProfilingGuid> tailGuid,
187 arm::pipe::Optional<ProfilingGuid> attributeGuid,
Jim Flynn6398a982020-05-27 17:05:21 +0100188 const unsigned char* readableData,
189 unsigned int& offset)
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000190{
Jim Flynn6730fe92022-03-10 22:57:47 +0000191 ARM_PIPE_ASSERT(readableData);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000192
193 uint32_t relationshipTypeUint = 0;
194 switch (relationshipType)
195 {
196 case ProfilingRelationshipType::RetentionLink:
197 relationshipTypeUint = 0;
198 break;
199 case ProfilingRelationshipType::ExecutionLink:
200 relationshipTypeUint = 1;
201 break;
202 case ProfilingRelationshipType::DataLink:
203 relationshipTypeUint = 2;
204 break;
205 case ProfilingRelationshipType::LabelLink:
206 relationshipTypeUint = 3;
207 break;
208 default:
Sadik Armagan1625efc2021-06-10 18:24:34 +0100209 FAIL("Unknown relationship type");
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000210 }
211
212 // Utils
213 unsigned int uint32_t_size = sizeof(uint32_t);
214 unsigned int uint64_t_size = sizeof(uint64_t);
215
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000216 // Check the decl id
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000217 uint32_t eventClassDeclId = ReadUint32(readableData, offset);
Sadik Armagan1625efc2021-06-10 18:24:34 +0100218 CHECK(eventClassDeclId == 3);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000219
220 // Check the relationship type
221 offset += uint32_t_size;
222 uint32_t readRelationshipTypeUint = ReadUint32(readableData, offset);
Sadik Armagan1625efc2021-06-10 18:24:34 +0100223 CHECK(readRelationshipTypeUint == relationshipTypeUint);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000224
225 // Check the relationship GUID
226 offset += uint32_t_size;
227 uint64_t readRelationshipGuid = ReadUint64(readableData, offset);
228 if (relationshipGuid.has_value())
229 {
Sadik Armagan1625efc2021-06-10 18:24:34 +0100230 CHECK(readRelationshipGuid == relationshipGuid.value());
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000231 }
232 else
233 {
Sadik Armagan1625efc2021-06-10 18:24:34 +0100234 CHECK(readRelationshipGuid != ProfilingGuid(0));
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000235 }
236
Jim Flynn6398a982020-05-27 17:05:21 +0100237 // Check the head GUID of the relationship
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000238 offset += uint64_t_size;
239 uint64_t readHeadRelationshipGuid = ReadUint64(readableData, offset);
240 if (headGuid.has_value())
241 {
Sadik Armagan1625efc2021-06-10 18:24:34 +0100242 CHECK(readHeadRelationshipGuid == headGuid.value());
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000243 }
244 else
245 {
Sadik Armagan1625efc2021-06-10 18:24:34 +0100246 CHECK(readHeadRelationshipGuid != ProfilingGuid(0));
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000247 }
248
Jim Flynn6398a982020-05-27 17:05:21 +0100249 // Check the tail GUID of the relationship
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000250 offset += uint64_t_size;
251 uint64_t readTailRelationshipGuid = ReadUint64(readableData, offset);
252 if (tailGuid.has_value())
253 {
Sadik Armagan1625efc2021-06-10 18:24:34 +0100254 CHECK(readTailRelationshipGuid == tailGuid.value());
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000255 }
256 else
257 {
Sadik Armagan1625efc2021-06-10 18:24:34 +0100258 CHECK(readTailRelationshipGuid != ProfilingGuid(0));
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000259 }
260
Jim Flynn6398a982020-05-27 17:05:21 +0100261 // Check the attribute GUID of the relationship
Finn Williams0a336dc2020-05-11 15:39:58 +0100262 offset += uint64_t_size;
263 uint64_t readAttributeRelationshipGuid = ReadUint64(readableData, offset);
264 if (attributeGuid.has_value())
265 {
Sadik Armagan1625efc2021-06-10 18:24:34 +0100266 CHECK(readAttributeRelationshipGuid == attributeGuid.value());
Finn Williams0a336dc2020-05-11 15:39:58 +0100267 }
268 else
269 {
Sadik Armagan1625efc2021-06-10 18:24:34 +0100270 CHECK(readAttributeRelationshipGuid == ProfilingGuid(0));
Finn Williams0a336dc2020-05-11 15:39:58 +0100271 }
272
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000273 // Update the offset to allow parsing to be continued after this function returns
274 offset += uint64_t_size;
275}
276
Jim Flynndecd08b2022-03-13 22:35:46 +0000277ProfilingGuid VerifyTimelineEntityBinaryPacketData(arm::pipe::Optional<ProfilingGuid> guid,
Jim Flynn6398a982020-05-27 17:05:21 +0100278 const unsigned char* readableData,
279 unsigned int& offset)
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000280{
Jim Flynn6730fe92022-03-10 22:57:47 +0000281 ARM_PIPE_ASSERT(readableData);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000282
283 // Utils
284 unsigned int uint32_t_size = sizeof(uint32_t);
285 unsigned int uint64_t_size = sizeof(uint64_t);
286
287 // Reading TimelineEntityClassBinaryPacket
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000288 // Check the decl_id
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000289 uint32_t entityDeclId = ReadUint32(readableData, offset);
Sadik Armagan1625efc2021-06-10 18:24:34 +0100290 CHECK(entityDeclId == 1);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000291
292 // Check the profiling GUID
293 offset += uint32_t_size;
294 uint64_t readProfilingGuid = ReadUint64(readableData, offset);
295
296 if (guid.has_value())
297 {
Sadik Armagan1625efc2021-06-10 18:24:34 +0100298 CHECK(readProfilingGuid == guid.value());
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000299 }
300 else
301 {
Sadik Armagan1625efc2021-06-10 18:24:34 +0100302 CHECK(readProfilingGuid != ProfilingGuid(0));
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000303 }
304
305 offset += uint64_t_size;
Jim Flynn6398a982020-05-27 17:05:21 +0100306
307 ProfilingGuid entityGuid(readProfilingGuid);
308 return entityGuid;
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000309}
310
Jim Flynndecd08b2022-03-13 22:35:46 +0000311ProfilingGuid VerifyTimelineEventBinaryPacket(arm::pipe::Optional<uint64_t> timestamp,
312 arm::pipe::Optional<int> threadId,
313 arm::pipe::Optional<ProfilingGuid> eventGuid,
Jim Flynn6398a982020-05-27 17:05:21 +0100314 const unsigned char* readableData,
315 unsigned int& offset)
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000316{
Jim Flynn6730fe92022-03-10 22:57:47 +0000317 ARM_PIPE_ASSERT(readableData);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000318
319 // Utils
320 unsigned int uint32_t_size = sizeof(uint32_t);
321 unsigned int uint64_t_size = sizeof(uint64_t);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000322
323 // Reading TimelineEventBinaryPacket
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000324 // Check the decl_id
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000325 uint32_t entityDeclId = ReadUint32(readableData, offset);
Sadik Armagan1625efc2021-06-10 18:24:34 +0100326 CHECK(entityDeclId == 4);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000327
328 // Check the timestamp
329 offset += uint32_t_size;
330 uint64_t readTimestamp = ReadUint64(readableData, offset);
331 if (timestamp.has_value())
332 {
Sadik Armagan1625efc2021-06-10 18:24:34 +0100333 CHECK(readTimestamp == timestamp.value());
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000334 }
335 else
336 {
Sadik Armagan1625efc2021-06-10 18:24:34 +0100337 CHECK(readTimestamp != 0);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000338 }
339
340 // Check the thread id
341 offset += uint64_t_size;
Colm Donelan5bb3d8a2020-05-12 16:36:46 +0100342 std::vector<uint8_t> readThreadId(ThreadIdSize, 0);
343 ReadBytes(readableData, offset, ThreadIdSize, readThreadId.data());
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000344 if (threadId.has_value())
345 {
Sadik Armagan1625efc2021-06-10 18:24:34 +0100346 CHECK(readThreadId == threadId.value());
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000347 }
348 else
349 {
Jim Flynn9c85b412022-03-16 00:27:43 +0000350 CHECK(readThreadId == arm::pipe::GetCurrentThreadId());
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000351 }
352
353 // Check the event GUID
Colm Donelan5bb3d8a2020-05-12 16:36:46 +0100354 offset += ThreadIdSize;
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000355 uint64_t readEventGuid = ReadUint64(readableData, offset);
356 if (eventGuid.has_value())
357 {
Sadik Armagan1625efc2021-06-10 18:24:34 +0100358 CHECK(readEventGuid == eventGuid.value());
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000359 }
360 else
361 {
Sadik Armagan1625efc2021-06-10 18:24:34 +0100362 CHECK(readEventGuid != ProfilingGuid(0));
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000363 }
364
365 offset += uint64_t_size;
Jim Flynn6398a982020-05-27 17:05:21 +0100366
367 ProfilingGuid eventid(readEventGuid);
368 return eventid;
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000369}
370
371void VerifyPostOptimisationStructureTestImpl(armnn::BackendId backendId)
372{
373 using namespace armnn;
374
375 // Create runtime in which test will run
376 armnn::IRuntime::CreationOptions options;
377 options.m_ProfilingOptions.m_EnableProfiling = true;
Keith Davis33ed2212020-03-30 10:43:41 +0100378 options.m_ProfilingOptions.m_TimelineEnabled = true;
Kevin Mayd92a6e42021-02-04 10:27:41 +0000379 armnn::RuntimeImpl runtime(options);
Jim Flynn4c9ed1d2022-01-23 23:57:20 +0000380 GetProfilingService(&runtime).ResetExternalProfilingOptions(
381 ConvertExternalProfilingOptions(options.m_ProfilingOptions), false);
Keith Davis33ed2212020-03-30 10:43:41 +0100382
Jim Flynn34430252022-03-04 15:03:58 +0000383 ArmNNProfilingServiceInitialiser initialiser;
384 ProfilingServiceRuntimeHelper profilingServiceHelper(
385 arm::pipe::MAX_ARMNN_COUNTER, initialiser, GetProfilingService(&runtime));
Keith Davis33ed2212020-03-30 10:43:41 +0100386 profilingServiceHelper.ForceTransitionToState(ProfilingState::NotConnected);
387 profilingServiceHelper.ForceTransitionToState(ProfilingState::WaitingForAck);
388 profilingServiceHelper.ForceTransitionToState(ProfilingState::Active);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000389
390 // build up the structure of the network
391 INetworkPtr net(INetwork::Create());
392
393 // Convolution details
394 TensorInfo inputInfo({ 1, 2, 5, 1 }, DataType::Float32);
Cathal Corbett5b8093c2021-10-22 11:12:07 +0100395 TensorInfo weightInfo({ 3, 2, 3, 1 }, DataType::Float32, 0.0f, 0, true);
396 TensorInfo biasInfo({ 3 }, DataType::Float32, 0.0f, 0, true);
Keith Davis97da5e22020-03-05 16:25:28 +0000397 TensorInfo outputInfo({ 1, 3, 7, 1 }, DataType::Float32);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000398 std::vector<float> weightsData{
Keith Davis97da5e22020-03-05 16:25:28 +0000399 1.0f, 0.0f, 0.0f,
400 0.0f, 2.0f, -1.5f,
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000401
Keith Davis97da5e22020-03-05 16:25:28 +0000402 0.0f, 0.0f, 0.0f,
403 0.2f, 0.2f, 0.2f,
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000404
Keith Davis97da5e22020-03-05 16:25:28 +0000405 0.5f, 0.0f, 0.5f,
406 0.0f, -1.0f, 0.0f
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000407 };
408 ConstTensor weights(weightInfo, weightsData);
409
Jim Flynndecd08b2022-03-13 22:35:46 +0000410 armnn::Optional<ConstTensor> optionalBiases;
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000411 std::vector<float> biasesData{ 1.0f, 0.0f, 0.0f };
412 ConstTensor biases(biasInfo, biasesData);
Jim Flynndecd08b2022-03-13 22:35:46 +0000413 optionalBiases = armnn::Optional<ConstTensor>(biases);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000414
415 // Input layer
416 IConnectableLayer* input = net->AddInputLayer(0, "input");
417
418 // Convolution2d layer
419 Convolution2dDescriptor conv2dDesc;
Keith Davis97da5e22020-03-05 16:25:28 +0000420 conv2dDesc.m_StrideX = 1;
421 conv2dDesc.m_StrideY = 1;
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000422 conv2dDesc.m_PadLeft = 0;
423 conv2dDesc.m_PadRight = 0;
424 conv2dDesc.m_PadTop = 2;
425 conv2dDesc.m_PadBottom = 2;
426 conv2dDesc.m_BiasEnabled = true;
Keith Davis721e6292022-05-17 10:06:53 +0100427
428 IConnectableLayer* conv2d = net->AddConvolution2dLayer(conv2dDesc);
429
430 armnn::IConnectableLayer* weightsLayer = net->AddConstantLayer(weights, "Weights");
431 armnn::IConnectableLayer* biasLayer = net->AddConstantLayer(biases, "Bias");
432
433 weightsLayer->GetOutputSlot(0).SetTensorInfo(weightInfo);
434 weightsLayer->GetOutputSlot(0).Connect(conv2d->GetInputSlot(1u));
435
436 biasLayer->GetOutputSlot(0).SetTensorInfo(biasInfo);
437 biasLayer->GetOutputSlot(0).Connect(conv2d->GetInputSlot(2u));
438
Mike Kelly07810fc2020-11-12 10:58:48 +0000439 // Abs layer
440 armnn::ElementwiseUnaryDescriptor absDesc;
441 armnn::IConnectableLayer* const abs = net->AddElementwiseUnaryLayer(absDesc, "abs");
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000442
443 // Output layer
444 IConnectableLayer* output = net->AddOutputLayer(0, "output");
445
446 input->GetOutputSlot(0).Connect(conv2d->GetInputSlot(0));
Mike Kelly07810fc2020-11-12 10:58:48 +0000447 conv2d->GetOutputSlot(0).Connect(abs->GetInputSlot(0));
448 abs->GetOutputSlot(0).Connect(output->GetInputSlot(0));
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000449
450 input->GetOutputSlot(0).SetTensorInfo(inputInfo);
451 conv2d->GetOutputSlot(0).SetTensorInfo(outputInfo);
Mike Kelly07810fc2020-11-12 10:58:48 +0000452 abs->GetOutputSlot(0).SetTensorInfo(outputInfo);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000453
454 // optimize the network
455 std::vector<armnn::BackendId> backends = { backendId };
Sadik Armagan3184c902020-03-18 10:57:30 +0000456 IOptimizedNetworkPtr optNet = Optimize(*net, backends, runtime.GetDeviceSpec());
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000457
458 ProfilingGuid optNetGuid = optNet->GetGuid();
459
460 // Load it into the runtime. It should success.
461 armnn::NetworkId netId;
Sadik Armagan1625efc2021-06-10 18:24:34 +0100462 CHECK(runtime.LoadNetwork(netId, std::move(optNet)) == Status::Success);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000463
Cathal Corbett5aa9fd72022-02-25 15:33:28 +0000464 BufferManager& bufferManager = profilingServiceHelper.GetProfilingBufferManager();
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000465 auto readableBuffer = bufferManager.GetReadableBuffer();
466
Jim Flynnf7713212020-07-14 09:50:59 +0100467 // Profiling is enabled, the post-optimisation structure should be created
Sadik Armagan1625efc2021-06-10 18:24:34 +0100468 CHECK(readableBuffer != nullptr);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000469 unsigned int size = readableBuffer->GetSize();
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000470
471 const unsigned char* readableData = readableBuffer->GetReadableData();
Sadik Armagan1625efc2021-06-10 18:24:34 +0100472 CHECK(readableData != nullptr);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000473
474 unsigned int offset = 0;
475
Keith Davis97da5e22020-03-05 16:25:28 +0000476 // Verify Header
Jim Flynnf7713212020-07-14 09:50:59 +0100477 VerifyTimelineHeaderBinary(readableData, offset, size - 8);
Keith Davis97da5e22020-03-05 16:25:28 +0000478
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000479 // Post-optimisation network
480 // Network entity
Keith Davis97da5e22020-03-05 16:25:28 +0000481 VerifyTimelineEntityBinaryPacketData(optNetGuid, readableData, offset);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000482
483 // Entity - Type relationship
Keith Davis97da5e22020-03-05 16:25:28 +0000484 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::LabelLink,
Jim Flynndecd08b2022-03-13 22:35:46 +0000485 arm::pipe::EmptyOptional(),
Keith Davis97da5e22020-03-05 16:25:28 +0000486 optNetGuid,
Jim Flynn6398a982020-05-27 17:05:21 +0100487 LabelsAndEventClasses::NETWORK_GUID,
Keith Davis97da5e22020-03-05 16:25:28 +0000488 LabelsAndEventClasses::TYPE_GUID,
489 readableData,
490 offset);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000491
Jim Flynnf7713212020-07-14 09:50:59 +0100492 // Network - START OF LIFE
Jim Flynndecd08b2022-03-13 22:35:46 +0000493 ProfilingGuid networkSolEventGuid = VerifyTimelineEventBinaryPacket(arm::pipe::EmptyOptional(),
494 arm::pipe::EmptyOptional(),
495 arm::pipe::EmptyOptional(),
Jim Flynnf7713212020-07-14 09:50:59 +0100496 readableData,
497 offset);
Jim Flynnf7713212020-07-14 09:50:59 +0100498
499 // Network - START OF LIFE event relationship
500 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::ExecutionLink,
Jim Flynndecd08b2022-03-13 22:35:46 +0000501 arm::pipe::EmptyOptional(),
Jim Flynnf7713212020-07-14 09:50:59 +0100502 optNetGuid,
503 networkSolEventGuid,
504 LabelsAndEventClasses::ARMNN_PROFILING_SOL_EVENT_CLASS,
505 readableData,
506 offset);
Jim Flynnf7713212020-07-14 09:50:59 +0100507
508 // Process ID Label
Jim Flynn9c85b412022-03-16 00:27:43 +0000509 int processID = arm::pipe::GetCurrentProcessId();
Jim Flynnf7713212020-07-14 09:50:59 +0100510 std::stringstream ss;
511 ss << processID;
512 std::string processIdLabel = ss.str();
Jim Flynndecd08b2022-03-13 22:35:46 +0000513 VerifyTimelineLabelBinaryPacketData(
514 arm::pipe::EmptyOptional(), processIdLabel, readableData, offset);
Jim Flynnf7713212020-07-14 09:50:59 +0100515
516 // Entity - Process ID relationship
517 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::LabelLink,
Jim Flynndecd08b2022-03-13 22:35:46 +0000518 arm::pipe::EmptyOptional(),
Jim Flynnf7713212020-07-14 09:50:59 +0100519 optNetGuid,
Jim Flynndecd08b2022-03-13 22:35:46 +0000520 arm::pipe::EmptyOptional(),
Jim Flynnf7713212020-07-14 09:50:59 +0100521 LabelsAndEventClasses::PROCESS_ID_GUID,
522 readableData,
523 offset);
Jim Flynnf7713212020-07-14 09:50:59 +0100524
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000525 // Input layer
526 // Input layer entity
Keith Davis97da5e22020-03-05 16:25:28 +0000527 VerifyTimelineEntityBinaryPacketData(input->GetGuid(), readableData, offset);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000528 // Name Entity
Jim Flynndecd08b2022-03-13 22:35:46 +0000529 ProfilingGuid inputLabelGuid = VerifyTimelineLabelBinaryPacketData(
530 arm::pipe::EmptyOptional(), "input", readableData, offset);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000531
532 // Entity - Name relationship
Keith Davis97da5e22020-03-05 16:25:28 +0000533 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::LabelLink,
Jim Flynndecd08b2022-03-13 22:35:46 +0000534 arm::pipe::EmptyOptional(),
Keith Davis97da5e22020-03-05 16:25:28 +0000535 input->GetGuid(),
Jim Flynn6398a982020-05-27 17:05:21 +0100536 inputLabelGuid,
Finn Williams0a336dc2020-05-11 15:39:58 +0100537 LabelsAndEventClasses::NAME_GUID,
Keith Davis97da5e22020-03-05 16:25:28 +0000538 readableData,
539 offset);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000540
541 // Entity - Type relationship
Keith Davis97da5e22020-03-05 16:25:28 +0000542 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::LabelLink,
Jim Flynndecd08b2022-03-13 22:35:46 +0000543 arm::pipe::EmptyOptional(),
Keith Davis97da5e22020-03-05 16:25:28 +0000544 input->GetGuid(),
Jim Flynn6398a982020-05-27 17:05:21 +0100545 LabelsAndEventClasses::LAYER_GUID,
Finn Williams0a336dc2020-05-11 15:39:58 +0100546 LabelsAndEventClasses::TYPE_GUID,
Keith Davis97da5e22020-03-05 16:25:28 +0000547 readableData,
548 offset);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000549
550 // Network - Input layer relationship
Keith Davis97da5e22020-03-05 16:25:28 +0000551 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::RetentionLink,
Jim Flynndecd08b2022-03-13 22:35:46 +0000552 arm::pipe::EmptyOptional(),
Keith Davis97da5e22020-03-05 16:25:28 +0000553 optNetGuid,
554 input->GetGuid(),
Jim Flynn6398a982020-05-27 17:05:21 +0100555 LabelsAndEventClasses::CHILD_GUID,
Keith Davis97da5e22020-03-05 16:25:28 +0000556 readableData,
557 offset);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000558
Keith Davisb4dd5cc2022-04-07 11:32:00 +0100559 // Weights layer
560 // We will not check the GUID from the packets since we haven't direct access to the layer
561 // The GUID will change depending on the number of tests ran since we do are not explicitly resetting the
562 // ProfilingGuid counter at the beginning of this test
563
564
565 // Weights layer entity
566 VerifyTimelineEntityBinaryPacketData( arm::pipe::EmptyOptional(), readableData, offset);
567
568 // Name entity
569 ProfilingGuid weightsNameLabelGuid = VerifyTimelineLabelBinaryPacketData(
570 arm::pipe::EmptyOptional(), "Weights", readableData, offset);
571
572 // Entity - Name relationship
573 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::LabelLink,
574 arm::pipe::EmptyOptional(),
575 arm::pipe::EmptyOptional(),
576 weightsNameLabelGuid,
577 LabelsAndEventClasses::NAME_GUID,
578 readableData,
579 offset);
580
581 // Entity - Type relationship
582 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::LabelLink,
583 arm::pipe::EmptyOptional(),
584 arm::pipe::EmptyOptional(),
585 LabelsAndEventClasses::LAYER_GUID,
586 LabelsAndEventClasses::TYPE_GUID,
587 readableData,
588 offset);
589
590 // Network - Weights layer relationship
591 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::RetentionLink,
592 arm::pipe::EmptyOptional(),
593 optNetGuid,
594 arm::pipe::EmptyOptional(),
595 LabelsAndEventClasses::CHILD_GUID,
596 readableData,
597 offset);
598
599 // Weights workload
600 // Weights workload entity
601 ProfilingGuid weightsWorkloadGuid = VerifyTimelineEntityBinaryPacketData(
602 arm::pipe::EmptyOptional(), readableData, offset);
603
604 // Entity - Type relationship
605 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::LabelLink,
606 arm::pipe::EmptyOptional(),
607 weightsWorkloadGuid,
608 LabelsAndEventClasses::WORKLOAD_GUID,
609 LabelsAndEventClasses::TYPE_GUID,
610 readableData,
611 offset);
612
613 // BackendId entity
614 ProfilingGuid backendIdLabelGuid = VerifyTimelineLabelBinaryPacketData(
615 arm::pipe::EmptyOptional(), backendId.Get(), readableData, offset);
616
617 // Entity - BackendId relationship
618 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::LabelLink,
619 arm::pipe::EmptyOptional(),
620 weightsWorkloadGuid,
621 backendIdLabelGuid,
622 LabelsAndEventClasses::BACKENDID_GUID,
623 readableData,
624 offset);
625
626
627 // Weights layer - Weights workload relationship
628 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::RetentionLink,
629 arm::pipe::EmptyOptional(),
630 arm::pipe::EmptyOptional(),
631 weightsWorkloadGuid,
632 LabelsAndEventClasses::CHILD_GUID,
633 readableData,
634 offset);
635
636 // Bias layer
637 // We will not check the GUID from the packets since we haven't direct access to the layer
638 // The GUID will change depending on the number of tests ran since we do are not explicitly resetting the
639 // ProfilingGuid counter at the beginning of this test
640
641 // Bias layer entity
642 VerifyTimelineEntityBinaryPacketData(arm::pipe::EmptyOptional(), readableData, offset);
643
644 // Name entity
645 ProfilingGuid biasNameLabelGuid = VerifyTimelineLabelBinaryPacketData(
646 arm::pipe::EmptyOptional(), "Bias", readableData, offset);
647
648 // Entity - Name relationship
649 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::LabelLink,
650 arm::pipe::EmptyOptional(),
651 arm::pipe::EmptyOptional(),
652 biasNameLabelGuid,
653 LabelsAndEventClasses::NAME_GUID,
654 readableData,
655 offset);
656
657 // Entity - Type relationship
658 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::LabelLink,
659 arm::pipe::EmptyOptional(),
660 arm::pipe::EmptyOptional(),
661 LabelsAndEventClasses::LAYER_GUID,
662 LabelsAndEventClasses::TYPE_GUID,
663 readableData,
664 offset);
665
666 // Network - Bias layer relationship
667 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::RetentionLink,
668 arm::pipe::EmptyOptional(),
669 optNetGuid,
670 arm::pipe::EmptyOptional(),
671 LabelsAndEventClasses::CHILD_GUID,
672 readableData,
673 offset);
674
675 // Bias workload
676 // Bias workload entity
677 ProfilingGuid biasWorkloadGuid = VerifyTimelineEntityBinaryPacketData(
678 arm::pipe::EmptyOptional(), readableData, offset);
679
680 // Entity - Type relationship
681 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::LabelLink,
682 arm::pipe::EmptyOptional(),
683 biasWorkloadGuid,
684 LabelsAndEventClasses::WORKLOAD_GUID,
685 LabelsAndEventClasses::TYPE_GUID,
686 readableData,
687 offset);
688
689 // BackendId entity
690 backendIdLabelGuid = VerifyTimelineLabelBinaryPacketData(
691 arm::pipe::EmptyOptional(), backendId.Get(), readableData, offset);
692
693 // Entity - BackendId relationship
694 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::LabelLink,
695 arm::pipe::EmptyOptional(),
696 biasWorkloadGuid,
697 backendIdLabelGuid,
698 LabelsAndEventClasses::BACKENDID_GUID,
699 readableData,
700 offset);
701
702
703 // Bias layer - Bias workload relationship
704 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::RetentionLink,
705 arm::pipe::EmptyOptional(),
706 arm::pipe::EmptyOptional(),
707 biasWorkloadGuid,
708 LabelsAndEventClasses::CHILD_GUID,
709 readableData,
710 offset);
711
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000712 // Conv2d layer
713 // Conv2d layer entity
Keith Davis97da5e22020-03-05 16:25:28 +0000714 VerifyTimelineEntityBinaryPacketData(conv2d->GetGuid(), readableData, offset);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000715
716 // Name entity
Jim Flynn6398a982020-05-27 17:05:21 +0100717 ProfilingGuid conv2dNameLabelGuid = VerifyTimelineLabelBinaryPacketData(
Jim Flynndecd08b2022-03-13 22:35:46 +0000718 arm::pipe::EmptyOptional(), "<Unnamed>", readableData, offset);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000719
720 // Entity - Name relationship
Keith Davis97da5e22020-03-05 16:25:28 +0000721 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::LabelLink,
Jim Flynndecd08b2022-03-13 22:35:46 +0000722 arm::pipe::EmptyOptional(),
Keith Davis97da5e22020-03-05 16:25:28 +0000723 conv2d->GetGuid(),
Jim Flynn6398a982020-05-27 17:05:21 +0100724 conv2dNameLabelGuid,
Keith Davis97da5e22020-03-05 16:25:28 +0000725 LabelsAndEventClasses::NAME_GUID,
726 readableData,
727 offset);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000728
729 // Entity - Type relationship
Keith Davis97da5e22020-03-05 16:25:28 +0000730 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::LabelLink,
Jim Flynndecd08b2022-03-13 22:35:46 +0000731 arm::pipe::EmptyOptional(),
Keith Davis97da5e22020-03-05 16:25:28 +0000732 conv2d->GetGuid(),
Jim Flynn6398a982020-05-27 17:05:21 +0100733 LabelsAndEventClasses::LAYER_GUID,
Keith Davis97da5e22020-03-05 16:25:28 +0000734 LabelsAndEventClasses::TYPE_GUID,
735 readableData,
736 offset);
Finn Williams0a336dc2020-05-11 15:39:58 +0100737
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000738 // Network - Conv2d layer relationship
Keith Davis97da5e22020-03-05 16:25:28 +0000739 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::RetentionLink,
Jim Flynndecd08b2022-03-13 22:35:46 +0000740 arm::pipe::EmptyOptional(),
Keith Davis97da5e22020-03-05 16:25:28 +0000741 optNetGuid,
742 conv2d->GetGuid(),
Jim Flynn6398a982020-05-27 17:05:21 +0100743 LabelsAndEventClasses::CHILD_GUID,
Keith Davis97da5e22020-03-05 16:25:28 +0000744 readableData,
745 offset);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000746
747 // Input layer - Conv2d layer relationship
Keith Davis97da5e22020-03-05 16:25:28 +0000748 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::RetentionLink,
Jim Flynndecd08b2022-03-13 22:35:46 +0000749 arm::pipe::EmptyOptional(),
Keith Davis97da5e22020-03-05 16:25:28 +0000750 input->GetGuid(),
751 conv2d->GetGuid(),
Keith Davis97da5e22020-03-05 16:25:28 +0000752 LabelsAndEventClasses::CONNECTION_GUID,
Keith Davis97da5e22020-03-05 16:25:28 +0000753 readableData,
754 offset);
Finn Williams0a336dc2020-05-11 15:39:58 +0100755
Keith Davisb4dd5cc2022-04-07 11:32:00 +0100756 // Weights layer - Conv2d layer relationship
757 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::RetentionLink,
758 arm::pipe::EmptyOptional(),
759 arm::pipe::EmptyOptional(),
760 conv2d->GetGuid(),
761 LabelsAndEventClasses::CONNECTION_GUID,
762 readableData,
763 offset);
764
765 // Bias layer - Conv2d layer relationship
766 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::RetentionLink,
767 arm::pipe::EmptyOptional(),
768 arm::pipe::EmptyOptional(),
769 conv2d->GetGuid(),
770 LabelsAndEventClasses::CONNECTION_GUID,
771 readableData,
772 offset);
773
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000774 // Conv2d workload
775 // Conv2d workload entity
Jim Flynndecd08b2022-03-13 22:35:46 +0000776 ProfilingGuid conv2DWorkloadGuid = VerifyTimelineEntityBinaryPacketData(
777 arm::pipe::EmptyOptional(), readableData, offset);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000778
779 // Entity - Type relationship
Keith Davis97da5e22020-03-05 16:25:28 +0000780 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::LabelLink,
Jim Flynndecd08b2022-03-13 22:35:46 +0000781 arm::pipe::EmptyOptional(),
Jim Flynn6398a982020-05-27 17:05:21 +0100782 conv2DWorkloadGuid,
783 LabelsAndEventClasses::WORKLOAD_GUID,
Keith Davis97da5e22020-03-05 16:25:28 +0000784 LabelsAndEventClasses::TYPE_GUID,
785 readableData,
786 offset);
Finn Williams0a336dc2020-05-11 15:39:58 +0100787
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000788 // BackendId entity
Keith Davisb4dd5cc2022-04-07 11:32:00 +0100789 backendIdLabelGuid = VerifyTimelineLabelBinaryPacketData(
Jim Flynndecd08b2022-03-13 22:35:46 +0000790 arm::pipe::EmptyOptional(), backendId.Get(), readableData, offset);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000791
792 // Entity - BackendId relationship
Keith Davis97da5e22020-03-05 16:25:28 +0000793 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::LabelLink,
Jim Flynndecd08b2022-03-13 22:35:46 +0000794 arm::pipe::EmptyOptional(),
Jim Flynn6398a982020-05-27 17:05:21 +0100795 conv2DWorkloadGuid,
796 backendIdLabelGuid,
Keith Davis97da5e22020-03-05 16:25:28 +0000797 LabelsAndEventClasses::BACKENDID_GUID,
798 readableData,
799 offset);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000800
Finn Williams0a336dc2020-05-11 15:39:58 +0100801
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000802 // Conv2d layer - Conv2d workload relationship
Keith Davis97da5e22020-03-05 16:25:28 +0000803 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::RetentionLink,
Jim Flynndecd08b2022-03-13 22:35:46 +0000804 arm::pipe::EmptyOptional(),
Keith Davis97da5e22020-03-05 16:25:28 +0000805 conv2d->GetGuid(),
Jim Flynn6398a982020-05-27 17:05:21 +0100806 conv2DWorkloadGuid,
807 LabelsAndEventClasses::CHILD_GUID,
Keith Davis97da5e22020-03-05 16:25:28 +0000808 readableData,
809 offset);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000810
Mike Kelly07810fc2020-11-12 10:58:48 +0000811 // Abs layer
812 // Abs layer entity
813 VerifyTimelineEntityBinaryPacketData(abs->GetGuid(), readableData, offset);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000814
815 // Name entity
Mike Kelly07810fc2020-11-12 10:58:48 +0000816 ProfilingGuid absLabelGuid = VerifyTimelineLabelBinaryPacketData(
Jim Flynndecd08b2022-03-13 22:35:46 +0000817 arm::pipe::EmptyOptional(), "abs", readableData, offset);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000818
819 // Entity - Name relationship
Keith Davis97da5e22020-03-05 16:25:28 +0000820 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::LabelLink,
Jim Flynndecd08b2022-03-13 22:35:46 +0000821 arm::pipe::EmptyOptional(),
Mike Kelly07810fc2020-11-12 10:58:48 +0000822 abs->GetGuid(),
823 absLabelGuid,
Keith Davis97da5e22020-03-05 16:25:28 +0000824 LabelsAndEventClasses::NAME_GUID,
825 readableData,
826 offset);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000827
828 // Entity - Type relationship
Keith Davis97da5e22020-03-05 16:25:28 +0000829 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::LabelLink,
Jim Flynndecd08b2022-03-13 22:35:46 +0000830 arm::pipe::EmptyOptional(),
Mike Kelly07810fc2020-11-12 10:58:48 +0000831 abs->GetGuid(),
Jim Flynn6398a982020-05-27 17:05:21 +0100832 LabelsAndEventClasses::LAYER_GUID,
Keith Davis97da5e22020-03-05 16:25:28 +0000833 LabelsAndEventClasses::TYPE_GUID,
834 readableData,
835 offset);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000836
Mike Kelly07810fc2020-11-12 10:58:48 +0000837 // Network - Abs layer relationship
Keith Davis97da5e22020-03-05 16:25:28 +0000838 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::RetentionLink,
Jim Flynndecd08b2022-03-13 22:35:46 +0000839 arm::pipe::EmptyOptional(),
Keith Davis97da5e22020-03-05 16:25:28 +0000840 optNetGuid,
Mike Kelly07810fc2020-11-12 10:58:48 +0000841 abs->GetGuid(),
Jim Flynn6398a982020-05-27 17:05:21 +0100842 LabelsAndEventClasses::CHILD_GUID,
Keith Davis97da5e22020-03-05 16:25:28 +0000843 readableData,
844 offset);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000845
Mike Kelly07810fc2020-11-12 10:58:48 +0000846 // Conv2d layer - Abs layer relationship
Keith Davis97da5e22020-03-05 16:25:28 +0000847 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::RetentionLink,
Jim Flynndecd08b2022-03-13 22:35:46 +0000848 arm::pipe::EmptyOptional(),
Keith Davis97da5e22020-03-05 16:25:28 +0000849 conv2d->GetGuid(),
Mike Kelly07810fc2020-11-12 10:58:48 +0000850 abs->GetGuid(),
Keith Davis97da5e22020-03-05 16:25:28 +0000851 LabelsAndEventClasses::CONNECTION_GUID,
Keith Davis97da5e22020-03-05 16:25:28 +0000852 readableData,
853 offset);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000854
Mike Kelly07810fc2020-11-12 10:58:48 +0000855 // Abs workload
856 // Abs workload entity
Jim Flynndecd08b2022-03-13 22:35:46 +0000857 ProfilingGuid absWorkloadGuid = VerifyTimelineEntityBinaryPacketData(
858 arm::pipe::EmptyOptional(), readableData, offset);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000859
860 // Entity - Type relationship
Keith Davis97da5e22020-03-05 16:25:28 +0000861 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::LabelLink,
Jim Flynndecd08b2022-03-13 22:35:46 +0000862 arm::pipe::EmptyOptional(),
Mike Kelly07810fc2020-11-12 10:58:48 +0000863 absWorkloadGuid,
Jim Flynn6398a982020-05-27 17:05:21 +0100864 LabelsAndEventClasses::WORKLOAD_GUID,
Keith Davis97da5e22020-03-05 16:25:28 +0000865 LabelsAndEventClasses::TYPE_GUID,
866 readableData,
867 offset);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000868
869 // BackendId entity
Jim Flynndecd08b2022-03-13 22:35:46 +0000870 VerifyTimelineLabelBinaryPacketData(arm::pipe::EmptyOptional(), backendId.Get(), readableData, offset);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000871
872 // Entity - BackendId relationship
Keith Davis97da5e22020-03-05 16:25:28 +0000873 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::LabelLink,
Jim Flynndecd08b2022-03-13 22:35:46 +0000874 arm::pipe::EmptyOptional(),
Mike Kelly07810fc2020-11-12 10:58:48 +0000875 absWorkloadGuid,
Jim Flynn6398a982020-05-27 17:05:21 +0100876 backendIdLabelGuid,
Keith Davis97da5e22020-03-05 16:25:28 +0000877 LabelsAndEventClasses::BACKENDID_GUID,
878 readableData,
879 offset);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000880
Mike Kelly07810fc2020-11-12 10:58:48 +0000881 // Abs layer - Abs workload relationship
Keith Davis97da5e22020-03-05 16:25:28 +0000882 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::RetentionLink,
Jim Flynndecd08b2022-03-13 22:35:46 +0000883 arm::pipe::EmptyOptional(),
Mike Kelly07810fc2020-11-12 10:58:48 +0000884 abs->GetGuid(),
885 absWorkloadGuid,
Jim Flynn6398a982020-05-27 17:05:21 +0100886 LabelsAndEventClasses::CHILD_GUID,
Keith Davis97da5e22020-03-05 16:25:28 +0000887 readableData,
888 offset);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000889
890 // Output layer
891 // Output layer entity
Keith Davis97da5e22020-03-05 16:25:28 +0000892 VerifyTimelineEntityBinaryPacketData(output->GetGuid(), readableData, offset);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000893
894 // Name entity
Jim Flynn6398a982020-05-27 17:05:21 +0100895 ProfilingGuid outputLabelGuid = VerifyTimelineLabelBinaryPacketData(
Jim Flynndecd08b2022-03-13 22:35:46 +0000896 arm::pipe::EmptyOptional(), "output", readableData, offset);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000897
898 // Entity - Name relationship
Keith Davis97da5e22020-03-05 16:25:28 +0000899 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::LabelLink,
Jim Flynndecd08b2022-03-13 22:35:46 +0000900 arm::pipe::EmptyOptional(),
Keith Davis97da5e22020-03-05 16:25:28 +0000901 output->GetGuid(),
Jim Flynn6398a982020-05-27 17:05:21 +0100902 outputLabelGuid,
Keith Davis97da5e22020-03-05 16:25:28 +0000903 LabelsAndEventClasses::NAME_GUID,
904 readableData,
905 offset);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000906
907 // Entity - Type relationship
Keith Davis97da5e22020-03-05 16:25:28 +0000908 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::LabelLink,
Jim Flynndecd08b2022-03-13 22:35:46 +0000909 arm::pipe::EmptyOptional(),
Keith Davis97da5e22020-03-05 16:25:28 +0000910 output->GetGuid(),
Jim Flynn6398a982020-05-27 17:05:21 +0100911 LabelsAndEventClasses::LAYER_GUID,
Keith Davis97da5e22020-03-05 16:25:28 +0000912 LabelsAndEventClasses::TYPE_GUID,
913 readableData,
914 offset);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000915
916 // Network - Output layer relationship
Keith Davis97da5e22020-03-05 16:25:28 +0000917 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::RetentionLink,
Jim Flynndecd08b2022-03-13 22:35:46 +0000918 arm::pipe::EmptyOptional(),
Keith Davis97da5e22020-03-05 16:25:28 +0000919 optNetGuid,
920 output->GetGuid(),
Jim Flynn6398a982020-05-27 17:05:21 +0100921 LabelsAndEventClasses::CHILD_GUID,
Keith Davis97da5e22020-03-05 16:25:28 +0000922 readableData,
923 offset);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000924
Mike Kelly07810fc2020-11-12 10:58:48 +0000925 // Abs layer - Output layer relationship
Keith Davis97da5e22020-03-05 16:25:28 +0000926 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::RetentionLink,
Jim Flynndecd08b2022-03-13 22:35:46 +0000927 arm::pipe::EmptyOptional(),
Mike Kelly07810fc2020-11-12 10:58:48 +0000928 abs->GetGuid(),
Keith Davis97da5e22020-03-05 16:25:28 +0000929 output->GetGuid(),
Keith Davis97da5e22020-03-05 16:25:28 +0000930 LabelsAndEventClasses::CONNECTION_GUID,
Keith Davis97da5e22020-03-05 16:25:28 +0000931 readableData,
932 offset);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000933
934 bufferManager.MarkRead(readableBuffer);
Narumol Prangnawarataa68e012019-11-29 17:17:43 +0000935
936 // Creates structures for input & output.
937 std::vector<float> inputData(inputInfo.GetNumElements());
938 std::vector<float> outputData(outputInfo.GetNumElements());
939
Cathal Corbett5b8093c2021-10-22 11:12:07 +0100940 TensorInfo inputTensorInfo = runtime.GetInputTensorInfo(netId, 0);
941 inputTensorInfo.SetConstant(true);
Narumol Prangnawarataa68e012019-11-29 17:17:43 +0000942 InputTensors inputTensors
Keith Davis97da5e22020-03-05 16:25:28 +0000943 {
Cathal Corbett5b8093c2021-10-22 11:12:07 +0100944 {0, ConstTensor(inputTensorInfo, inputData.data())}
Keith Davis97da5e22020-03-05 16:25:28 +0000945 };
Narumol Prangnawarataa68e012019-11-29 17:17:43 +0000946 OutputTensors outputTensors
Keith Davis97da5e22020-03-05 16:25:28 +0000947 {
Sadik Armagan3184c902020-03-18 10:57:30 +0000948 {0, Tensor(runtime.GetOutputTensorInfo(netId, 0), outputData.data())}
Keith Davis97da5e22020-03-05 16:25:28 +0000949 };
Narumol Prangnawarataa68e012019-11-29 17:17:43 +0000950
951 // Does the inference.
Sadik Armagan3184c902020-03-18 10:57:30 +0000952 runtime.EnqueueWorkload(netId, inputTensors, outputTensors);
Narumol Prangnawarataa68e012019-11-29 17:17:43 +0000953
Finn Williamsb6a402f2020-03-24 13:46:22 +0000954 // Get readable buffer for input workload
955 auto inputReadableBuffer = bufferManager.GetReadableBuffer();
Sadik Armagan1625efc2021-06-10 18:24:34 +0100956 CHECK(inputReadableBuffer != nullptr);
David Monahan6198fe02019-12-02 08:35:43 +0000957
Narumol Prangnawarataa68e012019-11-29 17:17:43 +0000958 // Get readable buffer for output workload
959 auto outputReadableBuffer = bufferManager.GetReadableBuffer();
Sadik Armagan1625efc2021-06-10 18:24:34 +0100960 CHECK(outputReadableBuffer != nullptr);
Narumol Prangnawarataa68e012019-11-29 17:17:43 +0000961
Finn Williamsb6a402f2020-03-24 13:46:22 +0000962 // Get readable buffer for inference timeline
963 auto inferenceReadableBuffer = bufferManager.GetReadableBuffer();
Sadik Armagan1625efc2021-06-10 18:24:34 +0100964 CHECK(inferenceReadableBuffer != nullptr);
Narumol Prangnawarataa68e012019-11-29 17:17:43 +0000965
966 // Validate input workload data
967 size = inputReadableBuffer->GetSize();
Sadik Armagan1625efc2021-06-10 18:24:34 +0100968 CHECK(size == 164);
Narumol Prangnawarataa68e012019-11-29 17:17:43 +0000969
970 readableData = inputReadableBuffer->GetReadableData();
Sadik Armagan1625efc2021-06-10 18:24:34 +0100971 CHECK(readableData != nullptr);
Narumol Prangnawarataa68e012019-11-29 17:17:43 +0000972
973 offset = 0;
974
Keith Davis97da5e22020-03-05 16:25:28 +0000975 // Verify Header
Finn Williams0a336dc2020-05-11 15:39:58 +0100976 VerifyTimelineHeaderBinary(readableData, offset, 156);
Keith Davis97da5e22020-03-05 16:25:28 +0000977
Narumol Prangnawarataa68e012019-11-29 17:17:43 +0000978 // Input workload
979 // Input workload entity
Jim Flynndecd08b2022-03-13 22:35:46 +0000980 ProfilingGuid inputWorkloadGuid = VerifyTimelineEntityBinaryPacketData(
981 arm::pipe::EmptyOptional(), readableData, offset);
Narumol Prangnawarataa68e012019-11-29 17:17:43 +0000982
983 // Entity - Type relationship
Keith Davis97da5e22020-03-05 16:25:28 +0000984 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::LabelLink,
Jim Flynndecd08b2022-03-13 22:35:46 +0000985 arm::pipe::EmptyOptional(),
Jim Flynn6398a982020-05-27 17:05:21 +0100986 inputWorkloadGuid,
987 LabelsAndEventClasses::WORKLOAD_GUID,
Keith Davis97da5e22020-03-05 16:25:28 +0000988 LabelsAndEventClasses::TYPE_GUID,
989 readableData,
990 offset);
Narumol Prangnawarataa68e012019-11-29 17:17:43 +0000991
992 // BackendId entity
Jim Flynndecd08b2022-03-13 22:35:46 +0000993 VerifyTimelineLabelBinaryPacketData(arm::pipe::EmptyOptional(), backendId.Get(), readableData, offset);
Narumol Prangnawarataa68e012019-11-29 17:17:43 +0000994
995 // Entity - BackendId relationship
Keith Davis97da5e22020-03-05 16:25:28 +0000996 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::LabelLink,
Jim Flynndecd08b2022-03-13 22:35:46 +0000997 arm::pipe::EmptyOptional(),
Jim Flynn6398a982020-05-27 17:05:21 +0100998 inputWorkloadGuid,
999 backendIdLabelGuid,
Keith Davis97da5e22020-03-05 16:25:28 +00001000 LabelsAndEventClasses::BACKENDID_GUID,
1001 readableData,
1002 offset);
Narumol Prangnawarataa68e012019-11-29 17:17:43 +00001003
1004 // Input layer - Input workload relationship
Keith Davis97da5e22020-03-05 16:25:28 +00001005 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::RetentionLink,
Jim Flynndecd08b2022-03-13 22:35:46 +00001006 arm::pipe::EmptyOptional(),
Keith Davis97da5e22020-03-05 16:25:28 +00001007 input->GetGuid(),
Jim Flynn6398a982020-05-27 17:05:21 +01001008 inputWorkloadGuid,
1009 LabelsAndEventClasses::CHILD_GUID,
Keith Davis97da5e22020-03-05 16:25:28 +00001010 readableData,
1011 offset);
Narumol Prangnawarataa68e012019-11-29 17:17:43 +00001012
1013 bufferManager.MarkRead(inputReadableBuffer);
1014
1015 // Validate output workload data
1016 size = outputReadableBuffer->GetSize();
Sadik Armagan1625efc2021-06-10 18:24:34 +01001017 CHECK(size == 164);
Narumol Prangnawarataa68e012019-11-29 17:17:43 +00001018
1019 readableData = outputReadableBuffer->GetReadableData();
Sadik Armagan1625efc2021-06-10 18:24:34 +01001020 CHECK(readableData != nullptr);
Narumol Prangnawarataa68e012019-11-29 17:17:43 +00001021
1022 offset = 0;
1023
Keith Davis97da5e22020-03-05 16:25:28 +00001024 // Verify Header
Finn Williams0a336dc2020-05-11 15:39:58 +01001025 VerifyTimelineHeaderBinary(readableData, offset, 156);
Keith Davis97da5e22020-03-05 16:25:28 +00001026
Narumol Prangnawarataa68e012019-11-29 17:17:43 +00001027 // Output workload
1028 // Output workload entity
Jim Flynndecd08b2022-03-13 22:35:46 +00001029 ProfilingGuid outputWorkloadGuid = VerifyTimelineEntityBinaryPacketData(
1030 arm::pipe::EmptyOptional(), readableData, offset);
Narumol Prangnawarataa68e012019-11-29 17:17:43 +00001031
1032 // Entity - Type relationship
Keith Davis97da5e22020-03-05 16:25:28 +00001033 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::LabelLink,
Jim Flynndecd08b2022-03-13 22:35:46 +00001034 arm::pipe::EmptyOptional(),
Jim Flynn6398a982020-05-27 17:05:21 +01001035 outputWorkloadGuid,
1036 LabelsAndEventClasses::WORKLOAD_GUID,
Keith Davis97da5e22020-03-05 16:25:28 +00001037 LabelsAndEventClasses::TYPE_GUID,
1038 readableData,
1039 offset);
Narumol Prangnawarataa68e012019-11-29 17:17:43 +00001040
1041 // BackendId entity
Jim Flynndecd08b2022-03-13 22:35:46 +00001042 VerifyTimelineLabelBinaryPacketData(arm::pipe::EmptyOptional(), backendId.Get(), readableData, offset);
Narumol Prangnawarataa68e012019-11-29 17:17:43 +00001043
1044 // Entity - BackendId relationship
Keith Davis97da5e22020-03-05 16:25:28 +00001045 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::LabelLink,
Jim Flynndecd08b2022-03-13 22:35:46 +00001046 arm::pipe::EmptyOptional(),
Jim Flynn6398a982020-05-27 17:05:21 +01001047 outputWorkloadGuid,
1048 backendIdLabelGuid,
Keith Davis97da5e22020-03-05 16:25:28 +00001049 LabelsAndEventClasses::BACKENDID_GUID,
1050 readableData,
1051 offset);
Narumol Prangnawarataa68e012019-11-29 17:17:43 +00001052
1053 // Output layer - Output workload relationship
Keith Davis97da5e22020-03-05 16:25:28 +00001054 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::RetentionLink,
Jim Flynndecd08b2022-03-13 22:35:46 +00001055 arm::pipe::EmptyOptional(),
Keith Davis97da5e22020-03-05 16:25:28 +00001056 output->GetGuid(),
Jim Flynn6398a982020-05-27 17:05:21 +01001057 outputWorkloadGuid,
1058 LabelsAndEventClasses::CHILD_GUID,
Keith Davis97da5e22020-03-05 16:25:28 +00001059 readableData,
1060 offset);
Narumol Prangnawarataa68e012019-11-29 17:17:43 +00001061
1062 bufferManager.MarkRead(outputReadableBuffer);
David Monahan6198fe02019-12-02 08:35:43 +00001063
1064 // Validate inference data
1065 size = inferenceReadableBuffer->GetSize();
Jan Eilersa10e2a22020-03-26 12:04:54 +00001066
Keith Davisb4dd5cc2022-04-07 11:32:00 +01001067 CHECK(size == 1748 + 10 * ThreadIdSize);
David Monahan6198fe02019-12-02 08:35:43 +00001068
1069 readableData = inferenceReadableBuffer->GetReadableData();
Sadik Armagan1625efc2021-06-10 18:24:34 +01001070 CHECK(readableData != nullptr);
David Monahan6198fe02019-12-02 08:35:43 +00001071
1072 offset = 0;
1073
Keith Davis97da5e22020-03-05 16:25:28 +00001074 // Verify Header
Keith Davisb4dd5cc2022-04-07 11:32:00 +01001075 VerifyTimelineHeaderBinary(readableData, offset, 1740 + 10 * ThreadIdSize);
Keith Davis97da5e22020-03-05 16:25:28 +00001076
David Monahan6198fe02019-12-02 08:35:43 +00001077 // Inference timeline trace
1078 // Inference entity
Jim Flynndecd08b2022-03-13 22:35:46 +00001079 ProfilingGuid inferenceGuid = VerifyTimelineEntityBinaryPacketData(
1080 arm::pipe::EmptyOptional(), readableData, offset);
David Monahan6198fe02019-12-02 08:35:43 +00001081
1082 // Entity - Type relationship
Keith Davis97da5e22020-03-05 16:25:28 +00001083 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::LabelLink,
Jim Flynndecd08b2022-03-13 22:35:46 +00001084 arm::pipe::EmptyOptional(),
Jim Flynn6398a982020-05-27 17:05:21 +01001085 inferenceGuid,
Keith Davis97da5e22020-03-05 16:25:28 +00001086 LabelsAndEventClasses::INFERENCE_GUID,
Keith Davis97da5e22020-03-05 16:25:28 +00001087 LabelsAndEventClasses::TYPE_GUID,
1088 readableData,
1089 offset);
David Monahan6198fe02019-12-02 08:35:43 +00001090
1091 // Network - Inference relationship
Keith Davis97da5e22020-03-05 16:25:28 +00001092 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::RetentionLink,
Jim Flynndecd08b2022-03-13 22:35:46 +00001093 arm::pipe::EmptyOptional(),
Keith Davis97da5e22020-03-05 16:25:28 +00001094 optNetGuid,
Jim Flynn6398a982020-05-27 17:05:21 +01001095 inferenceGuid,
1096 LabelsAndEventClasses::EXECUTION_OF_GUID,
Keith Davis97da5e22020-03-05 16:25:28 +00001097 readableData,
1098 offset);
David Monahan6198fe02019-12-02 08:35:43 +00001099
1100 // Start Inference life
1101 // Event packet - timeline, threadId, eventGuid
Jim Flynn6398a982020-05-27 17:05:21 +01001102 ProfilingGuid inferenceEventGuid = VerifyTimelineEventBinaryPacket(
Jim Flynndecd08b2022-03-13 22:35:46 +00001103 arm::pipe::EmptyOptional(), arm::pipe::EmptyOptional(), arm::pipe::EmptyOptional(), readableData, offset);
David Monahan6198fe02019-12-02 08:35:43 +00001104
1105 // Inference - event relationship
Keith Davis97da5e22020-03-05 16:25:28 +00001106 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::ExecutionLink,
Jim Flynndecd08b2022-03-13 22:35:46 +00001107 arm::pipe::EmptyOptional(),
Jim Flynn6398a982020-05-27 17:05:21 +01001108 inferenceGuid,
1109 inferenceEventGuid,
Keith Davis97da5e22020-03-05 16:25:28 +00001110 LabelsAndEventClasses::ARMNN_PROFILING_SOL_EVENT_CLASS,
1111 readableData,
1112 offset);
David Monahan6198fe02019-12-02 08:35:43 +00001113
1114 // Execution
1115 // Input workload execution
1116 // Input workload execution entity
Jim Flynn6398a982020-05-27 17:05:21 +01001117 ProfilingGuid inputWorkloadExecutionGuid = VerifyTimelineEntityBinaryPacketData(
Jim Flynndecd08b2022-03-13 22:35:46 +00001118 arm::pipe::EmptyOptional(), readableData, offset);
David Monahan6198fe02019-12-02 08:35:43 +00001119
1120 // Entity - Type relationship
Keith Davis97da5e22020-03-05 16:25:28 +00001121 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::LabelLink,
Jim Flynndecd08b2022-03-13 22:35:46 +00001122 arm::pipe::EmptyOptional(),
Jim Flynn6398a982020-05-27 17:05:21 +01001123 inputWorkloadExecutionGuid,
Keith Davis97da5e22020-03-05 16:25:28 +00001124 LabelsAndEventClasses::WORKLOAD_EXECUTION_GUID,
Keith Davis97da5e22020-03-05 16:25:28 +00001125 LabelsAndEventClasses::TYPE_GUID,
1126 readableData,
1127 offset);
David Monahan6198fe02019-12-02 08:35:43 +00001128
1129 // Inference - Workload execution relationship
Keith Davis97da5e22020-03-05 16:25:28 +00001130 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::RetentionLink,
Jim Flynndecd08b2022-03-13 22:35:46 +00001131 arm::pipe::EmptyOptional(),
Jim Flynn6398a982020-05-27 17:05:21 +01001132 inferenceGuid,
1133 inputWorkloadExecutionGuid,
1134 LabelsAndEventClasses::CHILD_GUID,
Keith Davis97da5e22020-03-05 16:25:28 +00001135 readableData,
1136 offset);
David Monahan6198fe02019-12-02 08:35:43 +00001137
1138 // Workload - Workload execution relationship
Keith Davis97da5e22020-03-05 16:25:28 +00001139 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::RetentionLink,
Jim Flynndecd08b2022-03-13 22:35:46 +00001140 arm::pipe::EmptyOptional(),
Jim Flynn6398a982020-05-27 17:05:21 +01001141 inputWorkloadGuid,
1142 inputWorkloadExecutionGuid,
1143 LabelsAndEventClasses::EXECUTION_OF_GUID,
Keith Davis97da5e22020-03-05 16:25:28 +00001144 readableData,
1145 offset);
David Monahan6198fe02019-12-02 08:35:43 +00001146
1147 // Start Input workload execution life
1148 // Event packet - timeline, threadId, eventGuid
Jim Flynn6398a982020-05-27 17:05:21 +01001149 ProfilingGuid inputWorkloadExecutionSOLEventId = VerifyTimelineEventBinaryPacket(
Jim Flynndecd08b2022-03-13 22:35:46 +00001150 arm::pipe::EmptyOptional(), arm::pipe::EmptyOptional(), arm::pipe::EmptyOptional(), readableData, offset);
David Monahan6198fe02019-12-02 08:35:43 +00001151
1152 // Input workload execution - event relationship
Keith Davis97da5e22020-03-05 16:25:28 +00001153 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::ExecutionLink,
Jim Flynndecd08b2022-03-13 22:35:46 +00001154 arm::pipe::EmptyOptional(),
Jim Flynn6398a982020-05-27 17:05:21 +01001155 inputWorkloadExecutionGuid,
1156 inputWorkloadExecutionSOLEventId,
Keith Davis97da5e22020-03-05 16:25:28 +00001157 LabelsAndEventClasses::ARMNN_PROFILING_SOL_EVENT_CLASS,
1158 readableData,
1159 offset);
David Monahan6198fe02019-12-02 08:35:43 +00001160
1161 // End of Input workload execution life
1162 // Event packet - timeline, threadId, eventGuid
Jim Flynn6398a982020-05-27 17:05:21 +01001163 ProfilingGuid inputWorkloadExecutionEOLEventId = VerifyTimelineEventBinaryPacket(
Jim Flynndecd08b2022-03-13 22:35:46 +00001164 arm::pipe::EmptyOptional(), arm::pipe::EmptyOptional(), arm::pipe::EmptyOptional(), readableData, offset);
David Monahan6198fe02019-12-02 08:35:43 +00001165
1166 // Input workload execution - event relationship
Keith Davis97da5e22020-03-05 16:25:28 +00001167 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::ExecutionLink,
Jim Flynndecd08b2022-03-13 22:35:46 +00001168 arm::pipe::EmptyOptional(),
Jim Flynn6398a982020-05-27 17:05:21 +01001169 inputWorkloadExecutionGuid,
1170 inputWorkloadExecutionEOLEventId,
Keith Davis97da5e22020-03-05 16:25:28 +00001171 LabelsAndEventClasses::ARMNN_PROFILING_EOL_EVENT_CLASS,
1172 readableData,
1173 offset);
David Monahan6198fe02019-12-02 08:35:43 +00001174
Keith Davisb4dd5cc2022-04-07 11:32:00 +01001175 // Weights workload execution
1176 // Weights workload execution entity
1177 ProfilingGuid weightsWorkloadExecutionGuid = VerifyTimelineEntityBinaryPacketData(
1178 arm::pipe::EmptyOptional(), readableData, offset);
1179
1180 // Entity - Type relationship
1181 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::LabelLink,
1182 arm::pipe::EmptyOptional(),
1183 weightsWorkloadExecutionGuid,
1184 LabelsAndEventClasses::WORKLOAD_EXECUTION_GUID,
1185 LabelsAndEventClasses::TYPE_GUID,
1186 readableData,
1187 offset);
1188
1189 // Inference - Workload execution relationship
1190 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::RetentionLink,
1191 arm::pipe::EmptyOptional(),
1192 inferenceGuid,
1193 weightsWorkloadExecutionGuid,
1194 LabelsAndEventClasses::CHILD_GUID,
1195 readableData,
1196 offset);
1197
1198 // Workload - Workload execution relationship
1199 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::RetentionLink,
1200 arm::pipe::EmptyOptional(),
1201 weightsWorkloadGuid,
1202 weightsWorkloadExecutionGuid,
1203 LabelsAndEventClasses::EXECUTION_OF_GUID,
1204 readableData,
1205 offset);
1206
1207 // Start Weights workload execution life
1208 // Event packet - timeline, threadId, eventGuid
1209 ProfilingGuid weightsWorkloadExecutionSOLEventGuid = VerifyTimelineEventBinaryPacket(
1210 arm::pipe::EmptyOptional(), arm::pipe::EmptyOptional(), arm::pipe::EmptyOptional(), readableData, offset);
1211
1212 // Weights workload execution - event relationship
1213 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::ExecutionLink,
1214 arm::pipe::EmptyOptional(),
1215 weightsWorkloadExecutionGuid,
1216 weightsWorkloadExecutionSOLEventGuid,
1217 LabelsAndEventClasses::ARMNN_PROFILING_SOL_EVENT_CLASS,
1218 readableData,
1219 offset);
1220
1221 // End of Weights workload execution life
1222 // Event packet - timeline, threadId, eventGuid
1223 ProfilingGuid weightsWorkloadExecutionEOLEventGuid = VerifyTimelineEventBinaryPacket(
1224 arm::pipe::EmptyOptional(), arm::pipe::EmptyOptional(), arm::pipe::EmptyOptional(), readableData, offset);
1225
1226 // Weights workload execution - event relationship
1227 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::ExecutionLink,
1228 arm::pipe::EmptyOptional(),
1229 weightsWorkloadExecutionGuid,
1230 weightsWorkloadExecutionEOLEventGuid,
1231 LabelsAndEventClasses::ARMNN_PROFILING_EOL_EVENT_CLASS,
1232 readableData,
1233 offset);
1234
1235 // Bias workload execution
1236 // Bias workload execution entity
1237 ProfilingGuid biasWorkloadExecutionGuid = VerifyTimelineEntityBinaryPacketData(
1238 arm::pipe::EmptyOptional(), readableData, offset);
1239
1240 // Entity - Type relationship
1241 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::LabelLink,
1242 arm::pipe::EmptyOptional(),
1243 biasWorkloadExecutionGuid,
1244 LabelsAndEventClasses::WORKLOAD_EXECUTION_GUID,
1245 LabelsAndEventClasses::TYPE_GUID,
1246 readableData,
1247 offset);
1248
1249 // Inference - Workload execution relationship
1250 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::RetentionLink,
1251 arm::pipe::EmptyOptional(),
1252 inferenceGuid,
1253 biasWorkloadExecutionGuid,
1254 LabelsAndEventClasses::CHILD_GUID,
1255 readableData,
1256 offset);
1257
1258 // Workload - Workload execution relationship
1259 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::RetentionLink,
1260 arm::pipe::EmptyOptional(),
1261 biasWorkloadGuid,
1262 biasWorkloadExecutionGuid,
1263 LabelsAndEventClasses::EXECUTION_OF_GUID,
1264 readableData,
1265 offset);
1266
1267 // Start Bias workload execution life
1268 // Event packet - timeline, threadId, eventGuid
1269 ProfilingGuid biasWorkloadExecutionSOLEventGuid = VerifyTimelineEventBinaryPacket(
1270 arm::pipe::EmptyOptional(), arm::pipe::EmptyOptional(), arm::pipe::EmptyOptional(), readableData, offset);
1271
1272 // Bias workload execution - event relationship
1273 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::ExecutionLink,
1274 arm::pipe::EmptyOptional(),
1275 biasWorkloadExecutionGuid,
1276 biasWorkloadExecutionSOLEventGuid,
1277 LabelsAndEventClasses::ARMNN_PROFILING_SOL_EVENT_CLASS,
1278 readableData,
1279 offset);
1280
1281 // End of Bias workload execution life
1282 // Event packet - timeline, threadId, eventGuid
1283 ProfilingGuid biasWorkloadExecutionEOLEventGuid = VerifyTimelineEventBinaryPacket(
1284 arm::pipe::EmptyOptional(), arm::pipe::EmptyOptional(), arm::pipe::EmptyOptional(), readableData, offset);
1285
1286 // Bias workload execution - event relationship
1287 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::ExecutionLink,
1288 arm::pipe::EmptyOptional(),
1289 biasWorkloadExecutionGuid,
1290 biasWorkloadExecutionEOLEventGuid,
1291 LabelsAndEventClasses::ARMNN_PROFILING_EOL_EVENT_CLASS,
1292 readableData,
1293 offset);
1294
David Monahan6198fe02019-12-02 08:35:43 +00001295 // Conv2d workload execution
1296 // Conv2d workload execution entity
Jim Flynn6398a982020-05-27 17:05:21 +01001297 ProfilingGuid conv2DWorkloadExecutionGuid = VerifyTimelineEntityBinaryPacketData(
Jim Flynndecd08b2022-03-13 22:35:46 +00001298 arm::pipe::EmptyOptional(), readableData, offset);
David Monahan6198fe02019-12-02 08:35:43 +00001299
1300 // Entity - Type relationship
Keith Davis97da5e22020-03-05 16:25:28 +00001301 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::LabelLink,
Jim Flynndecd08b2022-03-13 22:35:46 +00001302 arm::pipe::EmptyOptional(),
Jim Flynn6398a982020-05-27 17:05:21 +01001303 conv2DWorkloadExecutionGuid,
Keith Davis97da5e22020-03-05 16:25:28 +00001304 LabelsAndEventClasses::WORKLOAD_EXECUTION_GUID,
Keith Davis97da5e22020-03-05 16:25:28 +00001305 LabelsAndEventClasses::TYPE_GUID,
1306 readableData,
1307 offset);
David Monahan6198fe02019-12-02 08:35:43 +00001308
1309 // Inference - Workload execution relationship
Keith Davis97da5e22020-03-05 16:25:28 +00001310 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::RetentionLink,
Jim Flynndecd08b2022-03-13 22:35:46 +00001311 arm::pipe::EmptyOptional(),
Jim Flynn6398a982020-05-27 17:05:21 +01001312 inferenceGuid,
1313 conv2DWorkloadExecutionGuid,
1314 LabelsAndEventClasses::CHILD_GUID,
Keith Davis97da5e22020-03-05 16:25:28 +00001315 readableData,
1316 offset);
David Monahan6198fe02019-12-02 08:35:43 +00001317
1318 // Workload - Workload execution relationship
Keith Davis97da5e22020-03-05 16:25:28 +00001319 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::RetentionLink,
Jim Flynndecd08b2022-03-13 22:35:46 +00001320 arm::pipe::EmptyOptional(),
Jim Flynn6398a982020-05-27 17:05:21 +01001321 conv2DWorkloadGuid,
1322 conv2DWorkloadExecutionGuid,
1323 LabelsAndEventClasses::EXECUTION_OF_GUID,
Keith Davis97da5e22020-03-05 16:25:28 +00001324 readableData,
1325 offset);
David Monahan6198fe02019-12-02 08:35:43 +00001326
1327 // Start Conv2d workload execution life
1328 // Event packet - timeline, threadId, eventGuid
Jim Flynn6398a982020-05-27 17:05:21 +01001329 ProfilingGuid conv2DWorkloadExecutionSOLEventGuid = VerifyTimelineEventBinaryPacket(
Jim Flynndecd08b2022-03-13 22:35:46 +00001330 arm::pipe::EmptyOptional(), arm::pipe::EmptyOptional(), arm::pipe::EmptyOptional(), readableData, offset);
David Monahan6198fe02019-12-02 08:35:43 +00001331
1332 // Conv2d workload execution - event relationship
Keith Davis97da5e22020-03-05 16:25:28 +00001333 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::ExecutionLink,
Jim Flynndecd08b2022-03-13 22:35:46 +00001334 arm::pipe::EmptyOptional(),
Jim Flynn6398a982020-05-27 17:05:21 +01001335 conv2DWorkloadExecutionGuid,
1336 conv2DWorkloadExecutionSOLEventGuid,
Keith Davis97da5e22020-03-05 16:25:28 +00001337 LabelsAndEventClasses::ARMNN_PROFILING_SOL_EVENT_CLASS,
1338 readableData,
1339 offset);
David Monahan6198fe02019-12-02 08:35:43 +00001340
1341 // End of Conv2d workload execution life
1342 // Event packet - timeline, threadId, eventGuid
Jim Flynn6398a982020-05-27 17:05:21 +01001343 ProfilingGuid conv2DWorkloadExecutionEOLEventGuid = VerifyTimelineEventBinaryPacket(
Jim Flynndecd08b2022-03-13 22:35:46 +00001344 arm::pipe::EmptyOptional(), arm::pipe::EmptyOptional(), arm::pipe::EmptyOptional(), readableData, offset);
David Monahan6198fe02019-12-02 08:35:43 +00001345
1346 // Conv2d workload execution - event relationship
Keith Davis97da5e22020-03-05 16:25:28 +00001347 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::ExecutionLink,
Jim Flynndecd08b2022-03-13 22:35:46 +00001348 arm::pipe::EmptyOptional(),
Jim Flynn6398a982020-05-27 17:05:21 +01001349 conv2DWorkloadExecutionGuid,
1350 conv2DWorkloadExecutionEOLEventGuid,
Keith Davis97da5e22020-03-05 16:25:28 +00001351 LabelsAndEventClasses::ARMNN_PROFILING_EOL_EVENT_CLASS,
1352 readableData,
1353 offset);
David Monahan6198fe02019-12-02 08:35:43 +00001354
Mike Kelly07810fc2020-11-12 10:58:48 +00001355 // Abs workload execution
1356 // Abs workload execution entity
1357 ProfilingGuid absWorkloadExecutionGuid = VerifyTimelineEntityBinaryPacketData(
Jim Flynndecd08b2022-03-13 22:35:46 +00001358 arm::pipe::EmptyOptional(), readableData, offset);
David Monahan6198fe02019-12-02 08:35:43 +00001359
1360 // Entity - Type relationship
Keith Davis97da5e22020-03-05 16:25:28 +00001361 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::LabelLink,
Jim Flynndecd08b2022-03-13 22:35:46 +00001362 arm::pipe::EmptyOptional(),
Mike Kelly07810fc2020-11-12 10:58:48 +00001363 absWorkloadExecutionGuid,
Keith Davis97da5e22020-03-05 16:25:28 +00001364 LabelsAndEventClasses::WORKLOAD_EXECUTION_GUID,
Keith Davis97da5e22020-03-05 16:25:28 +00001365 LabelsAndEventClasses::TYPE_GUID,
1366 readableData,
1367 offset);
David Monahan6198fe02019-12-02 08:35:43 +00001368
1369 // Inference - Workload execution relationship
Keith Davis97da5e22020-03-05 16:25:28 +00001370 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::RetentionLink,
Jim Flynndecd08b2022-03-13 22:35:46 +00001371 arm::pipe::EmptyOptional(),
Jim Flynn6398a982020-05-27 17:05:21 +01001372 inferenceGuid,
Mike Kelly07810fc2020-11-12 10:58:48 +00001373 absWorkloadExecutionGuid,
Jim Flynn6398a982020-05-27 17:05:21 +01001374 LabelsAndEventClasses::CHILD_GUID,
Keith Davis97da5e22020-03-05 16:25:28 +00001375 readableData,
1376 offset);
David Monahan6198fe02019-12-02 08:35:43 +00001377
1378 // Workload - Workload execution relationship
Keith Davis97da5e22020-03-05 16:25:28 +00001379 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::RetentionLink,
Jim Flynndecd08b2022-03-13 22:35:46 +00001380 arm::pipe::EmptyOptional(),
Mike Kelly07810fc2020-11-12 10:58:48 +00001381 absWorkloadGuid,
1382 absWorkloadExecutionGuid,
Jim Flynn6398a982020-05-27 17:05:21 +01001383 LabelsAndEventClasses::EXECUTION_OF_GUID,
Keith Davis97da5e22020-03-05 16:25:28 +00001384 readableData,
1385 offset);
David Monahan6198fe02019-12-02 08:35:43 +00001386
Mike Kelly07810fc2020-11-12 10:58:48 +00001387 // Start Abs workload execution life
David Monahan6198fe02019-12-02 08:35:43 +00001388 // Event packet - timeline, threadId, eventGuid
Mike Kelly07810fc2020-11-12 10:58:48 +00001389 ProfilingGuid absWorkloadExecutionSOLEventGuid = VerifyTimelineEventBinaryPacket(
Jim Flynndecd08b2022-03-13 22:35:46 +00001390 arm::pipe::EmptyOptional(), arm::pipe::EmptyOptional(), arm::pipe::EmptyOptional(), readableData, offset);
David Monahan6198fe02019-12-02 08:35:43 +00001391
Mike Kelly07810fc2020-11-12 10:58:48 +00001392 // Abs workload execution - event relationship
Keith Davis97da5e22020-03-05 16:25:28 +00001393 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::ExecutionLink,
Jim Flynndecd08b2022-03-13 22:35:46 +00001394 arm::pipe::EmptyOptional(),
Mike Kelly07810fc2020-11-12 10:58:48 +00001395 absWorkloadExecutionGuid,
1396 absWorkloadExecutionSOLEventGuid,
Keith Davis97da5e22020-03-05 16:25:28 +00001397 LabelsAndEventClasses::ARMNN_PROFILING_SOL_EVENT_CLASS,
1398 readableData,
1399 offset);
David Monahan6198fe02019-12-02 08:35:43 +00001400
Mike Kelly07810fc2020-11-12 10:58:48 +00001401 // End of Abs workload execution life
David Monahan6198fe02019-12-02 08:35:43 +00001402 // Event packet - timeline, threadId, eventGuid
Mike Kelly07810fc2020-11-12 10:58:48 +00001403 ProfilingGuid absWorkloadExecutionEOLEventGuid = VerifyTimelineEventBinaryPacket(
Jim Flynndecd08b2022-03-13 22:35:46 +00001404 arm::pipe::EmptyOptional(), arm::pipe::EmptyOptional(), arm::pipe::EmptyOptional(), readableData, offset);
David Monahan6198fe02019-12-02 08:35:43 +00001405
Mike Kelly07810fc2020-11-12 10:58:48 +00001406 // Abs workload execution - event relationship
Keith Davis97da5e22020-03-05 16:25:28 +00001407 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::ExecutionLink,
Jim Flynndecd08b2022-03-13 22:35:46 +00001408 arm::pipe::EmptyOptional(),
Mike Kelly07810fc2020-11-12 10:58:48 +00001409 absWorkloadExecutionGuid,
1410 absWorkloadExecutionEOLEventGuid,
Keith Davis97da5e22020-03-05 16:25:28 +00001411 LabelsAndEventClasses::ARMNN_PROFILING_EOL_EVENT_CLASS,
1412 readableData,
1413 offset);
David Monahan6198fe02019-12-02 08:35:43 +00001414
1415 // Output workload execution
1416 // Output workload execution entity
Jim Flynn6398a982020-05-27 17:05:21 +01001417 ProfilingGuid outputWorkloadExecutionGuid = VerifyTimelineEntityBinaryPacketData(
Jim Flynndecd08b2022-03-13 22:35:46 +00001418 arm::pipe::EmptyOptional(), readableData, offset);
David Monahan6198fe02019-12-02 08:35:43 +00001419
1420 // Entity - Type relationship
Keith Davis97da5e22020-03-05 16:25:28 +00001421 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::LabelLink,
Jim Flynndecd08b2022-03-13 22:35:46 +00001422 arm::pipe::EmptyOptional(),
Jim Flynn6398a982020-05-27 17:05:21 +01001423 outputWorkloadExecutionGuid,
Keith Davis97da5e22020-03-05 16:25:28 +00001424 LabelsAndEventClasses::WORKLOAD_EXECUTION_GUID,
Keith Davis97da5e22020-03-05 16:25:28 +00001425 LabelsAndEventClasses::TYPE_GUID,
1426 readableData,
1427 offset);
David Monahan6198fe02019-12-02 08:35:43 +00001428
1429 // Inference - Workload execution relationship
Keith Davis97da5e22020-03-05 16:25:28 +00001430 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::RetentionLink,
Jim Flynndecd08b2022-03-13 22:35:46 +00001431 arm::pipe::EmptyOptional(),
Jim Flynn6398a982020-05-27 17:05:21 +01001432 inferenceGuid,
1433 outputWorkloadExecutionGuid,
1434 LabelsAndEventClasses::CHILD_GUID,
Keith Davis97da5e22020-03-05 16:25:28 +00001435 readableData,
1436 offset);
David Monahan6198fe02019-12-02 08:35:43 +00001437
1438 // Workload - Workload execution relationship
Keith Davis97da5e22020-03-05 16:25:28 +00001439 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::RetentionLink,
Jim Flynndecd08b2022-03-13 22:35:46 +00001440 arm::pipe::EmptyOptional(),
Jim Flynn6398a982020-05-27 17:05:21 +01001441 outputWorkloadGuid,
1442 outputWorkloadExecutionGuid,
1443 LabelsAndEventClasses::EXECUTION_OF_GUID,
Keith Davis97da5e22020-03-05 16:25:28 +00001444 readableData,
1445 offset);
David Monahan6198fe02019-12-02 08:35:43 +00001446
1447 // Start Output workload execution life
1448 // Event packet - timeline, threadId, eventGuid
Jim Flynn6398a982020-05-27 17:05:21 +01001449 ProfilingGuid outputWorkloadExecutionSOLEventGuid = VerifyTimelineEventBinaryPacket(
Jim Flynndecd08b2022-03-13 22:35:46 +00001450 arm::pipe::EmptyOptional(), arm::pipe::EmptyOptional(), arm::pipe::EmptyOptional(), readableData, offset);
David Monahan6198fe02019-12-02 08:35:43 +00001451
1452 // Output workload execution - event relationship
Keith Davis97da5e22020-03-05 16:25:28 +00001453 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::ExecutionLink,
Jim Flynndecd08b2022-03-13 22:35:46 +00001454 arm::pipe::EmptyOptional(),
Jim Flynn6398a982020-05-27 17:05:21 +01001455 outputWorkloadExecutionGuid,
1456 outputWorkloadExecutionSOLEventGuid,
Keith Davis97da5e22020-03-05 16:25:28 +00001457 LabelsAndEventClasses::ARMNN_PROFILING_SOL_EVENT_CLASS,
1458 readableData,
1459 offset);
David Monahan6198fe02019-12-02 08:35:43 +00001460
1461 // End of Normalize workload execution life
1462 // Event packet - timeline, threadId, eventGuid
Jim Flynn6398a982020-05-27 17:05:21 +01001463 ProfilingGuid outputWorkloadExecutionEOLEventGuid = VerifyTimelineEventBinaryPacket(
Jim Flynndecd08b2022-03-13 22:35:46 +00001464 arm::pipe::EmptyOptional(), arm::pipe::EmptyOptional(), arm::pipe::EmptyOptional(), readableData, offset);
David Monahan6198fe02019-12-02 08:35:43 +00001465
1466 // Output workload execution - event relationship
Keith Davis97da5e22020-03-05 16:25:28 +00001467 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::ExecutionLink,
Jim Flynndecd08b2022-03-13 22:35:46 +00001468 arm::pipe::EmptyOptional(),
Jim Flynn6398a982020-05-27 17:05:21 +01001469 outputWorkloadExecutionGuid,
1470 outputWorkloadExecutionEOLEventGuid,
Keith Davis97da5e22020-03-05 16:25:28 +00001471 LabelsAndEventClasses::ARMNN_PROFILING_EOL_EVENT_CLASS,
1472 readableData,
1473 offset);
David Monahan6198fe02019-12-02 08:35:43 +00001474
1475 // End of Inference life
1476 // Event packet - timeline, threadId, eventGuid
Jim Flynn6398a982020-05-27 17:05:21 +01001477 ProfilingGuid inferenceEOLEventGuid = VerifyTimelineEventBinaryPacket(
Jim Flynndecd08b2022-03-13 22:35:46 +00001478 arm::pipe::EmptyOptional(), arm::pipe::EmptyOptional(), arm::pipe::EmptyOptional(), readableData, offset);
David Monahan6198fe02019-12-02 08:35:43 +00001479
1480 // Inference - event relationship
Keith Davis97da5e22020-03-05 16:25:28 +00001481 VerifyTimelineRelationshipBinaryPacketData(ProfilingRelationshipType::ExecutionLink,
Jim Flynndecd08b2022-03-13 22:35:46 +00001482 arm::pipe::EmptyOptional(),
Jim Flynn6398a982020-05-27 17:05:21 +01001483 inferenceGuid,
1484 inferenceEOLEventGuid,
Keith Davis97da5e22020-03-05 16:25:28 +00001485 LabelsAndEventClasses::ARMNN_PROFILING_EOL_EVENT_CLASS,
1486 readableData,
1487 offset);
David Monahan6198fe02019-12-02 08:35:43 +00001488
1489 bufferManager.MarkRead(inferenceReadableBuffer);
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +00001490}
Jim Flynn6398a982020-05-27 17:05:21 +01001491
Jim Flynn6398a982020-05-27 17:05:21 +01001492bool CompareOutput(std::vector<std::string> output, std::vector<std::string> expectedOutput)
1493{
1494 if (output.size() != expectedOutput.size())
1495 {
1496 std::cerr << "output has [" << output.size() << "] lines, expected was ["
1497 << expectedOutput.size() << "] lines" << std::endl;
1498 std::cerr << std::endl << "actual" << std::endl << std::endl;
1499 for (auto line : output)
1500 {
1501 std::cerr << line << std::endl;
1502 }
1503 std::cerr << std::endl << "expected" << std::endl << std::endl;
1504 for (auto line : expectedOutput)
1505 {
1506 std::cerr << line << std::endl;
1507 }
1508 return false;
1509 }
1510 bool bRet = true;
1511 for (unsigned long i = 0; i < output.size(); ++i)
1512 {
1513 if (output[i] != expectedOutput[i])
1514 {
1515 bRet = false;
1516 std::cerr << i << ": actual [" << output[i] << "] expected [" << expectedOutput[i] << "]" << std::endl;
1517 }
1518 }
1519 return bRet;
1520}