blob: 6963dd00c7dea475c54058102a5c40ac25a154af [file] [log] [blame]
//
// Copyright © 2019 Arm Ltd and Contributors. All rights reserved.
// SPDX-License-Identifier: MIT
//
#include <common/include/CommonProfilingUtils.hpp>
#include <common/include/SwTrace.hpp>
#include <server/include/timelineDecoder/TimelineCaptureCommandHandler.hpp>
#include <server/include/timelineDecoder/TimelineDirectoryCaptureCommandHandler.hpp>
#include <iostream>
#include <string>
namespace arm
{
namespace pipe
{
void TimelineDirectoryCaptureCommandHandler::ParseData(const arm::pipe::Packet& packet)
{
uint32_t offset = 0;
if (packet.GetLength() < 8)
{
return;
}
const unsigned char* data = packet.GetData();
m_SwTraceHeader.m_StreamVersion = ReadUint8(data, offset);
offset += uint8_t_size;
m_SwTraceHeader.m_PointerBytes = ReadUint8(data, offset);
offset += uint8_t_size;
m_SwTraceHeader.m_ThreadIdBytes = ReadUint8(data, offset);
offset += uint8_t_size;
uint32_t numberOfDeclarations = arm::pipe::ReadUint32(data, offset);
offset += uint32_t_size;
for (uint32_t declaration = 0; declaration < numberOfDeclarations; ++declaration)
{
m_SwTraceMessages.push_back(arm::pipe::ReadSwTraceMessage(data, offset, packet.GetLength()));
}
m_TimelineCaptureCommandHandler.SetThreadIdSize(m_SwTraceHeader.m_ThreadIdBytes);
}
void TimelineDirectoryCaptureCommandHandler::Print()
{
std::string header;
header.append(arm::pipe::CentreAlignFormatting("decl_id", 12));
header.append(" | ");
header.append(arm::pipe::CentreAlignFormatting("decl_name", 20));
header.append(" | ");
header.append(arm::pipe::CentreAlignFormatting("ui_name", 20));
header.append(" | ");
header.append(arm::pipe::CentreAlignFormatting("arg_types", 16));
header.append(" | ");
header.append(arm::pipe::CentreAlignFormatting("arg_names", 80));
header.append("\n");
std::cout << "\n" << "\n";
std::cout << arm::pipe::CentreAlignFormatting("SW DIRECTORY", static_cast<int>(header.size()));
std::cout << "\n";
std::cout << std::string(header.size(), '=') << "\n";
std::cout << header;
for (const auto& swTraceMessage : m_SwTraceMessages)
{
std::string body;
body.append(arm::pipe::CentreAlignFormatting(std::to_string(swTraceMessage.m_Id), 12));
body.append(" | ");
body.append(arm::pipe::CentreAlignFormatting(swTraceMessage.m_Name, 20));
body.append(" | ");
body.append(arm::pipe::CentreAlignFormatting(swTraceMessage.m_UiName, 20));
body.append(" | ");
std::string argTypes;
for (auto argType: swTraceMessage.m_ArgTypes)
{
argTypes += argType;
argTypes += " ";
}
body.append(arm::pipe::CentreAlignFormatting(argTypes, 16));
body.append(" | ");
std::string argNames;
for (auto argName: swTraceMessage.m_ArgNames)
{
argNames += argName + " ";
}
body.append(arm::pipe::CentreAlignFormatting(argNames, 80));
body.append("\n");
std::cout << std::string(body.size(), '-') << "\n";
std::cout << body;
}
}
void TimelineDirectoryCaptureCommandHandler::operator()(const arm::pipe::Packet& packet)
{
ParseData(packet);
if (!m_QuietOperation)
{
Print();
}
}
} //namespace pipe
} //namespace arm