Finn Williams | e63a026 | 2019-10-22 10:30:49 +0100 | [diff] [blame] | 1 | // |
Kevin May | c135179 | 2020-07-28 11:29:04 +0100 | [diff] [blame] | 2 | // Copyright © 2019 Arm Ltd and Contributors. All rights reserved. |
Finn Williams | e63a026 | 2019-10-22 10:30:49 +0100 | [diff] [blame] | 3 | // SPDX-License-Identifier: MIT |
| 4 | // |
| 5 | |
Jim Flynn | bbfe603 | 2020-07-20 16:57:44 +0100 | [diff] [blame] | 6 | #include <common/include/CommonProfilingUtils.hpp> |
| 7 | #include <common/include/SwTrace.hpp> |
| 8 | #include <server/include/timelineDecoder/TimelineCaptureCommandHandler.hpp> |
| 9 | #include <server/include/timelineDecoder/TimelineDirectoryCaptureCommandHandler.hpp> |
Finn Williams | e63a026 | 2019-10-22 10:30:49 +0100 | [diff] [blame] | 10 | |
| 11 | #include <iostream> |
| 12 | #include <string> |
| 13 | |
Jim Flynn | bbfe603 | 2020-07-20 16:57:44 +0100 | [diff] [blame] | 14 | namespace arm |
Finn Williams | e63a026 | 2019-10-22 10:30:49 +0100 | [diff] [blame] | 15 | { |
| 16 | |
Jim Flynn | bbfe603 | 2020-07-20 16:57:44 +0100 | [diff] [blame] | 17 | namespace pipe |
Finn Williams | e63a026 | 2019-10-22 10:30:49 +0100 | [diff] [blame] | 18 | { |
| 19 | |
Jim Flynn | bbfe603 | 2020-07-20 16:57:44 +0100 | [diff] [blame] | 20 | void TimelineDirectoryCaptureCommandHandler::ParseData(const arm::pipe::Packet& packet) |
Finn Williams | e63a026 | 2019-10-22 10:30:49 +0100 | [diff] [blame] | 21 | { |
| 22 | uint32_t offset = 0; |
| 23 | |
| 24 | if (packet.GetLength() < 8) |
| 25 | { |
| 26 | return; |
| 27 | } |
| 28 | |
| 29 | const unsigned char* data = packet.GetData(); |
| 30 | |
Matteo Martincigh | 34a407d | 2019-11-06 15:30:54 +0000 | [diff] [blame] | 31 | m_SwTraceHeader.m_StreamVersion = ReadUint8(data, offset); |
| 32 | offset += uint8_t_size; |
| 33 | m_SwTraceHeader.m_PointerBytes = ReadUint8(data, offset); |
| 34 | offset += uint8_t_size; |
| 35 | m_SwTraceHeader.m_ThreadIdBytes = ReadUint8(data, offset); |
| 36 | offset += uint8_t_size; |
| 37 | |
Jim Flynn | bbfe603 | 2020-07-20 16:57:44 +0100 | [diff] [blame] | 38 | uint32_t numberOfDeclarations = arm::pipe::ReadUint32(data, offset); |
Finn Williams | e63a026 | 2019-10-22 10:30:49 +0100 | [diff] [blame] | 39 | offset += uint32_t_size; |
| 40 | |
Matteo Martincigh | 34a407d | 2019-11-06 15:30:54 +0000 | [diff] [blame] | 41 | for (uint32_t declaration = 0; declaration < numberOfDeclarations; ++declaration) |
Finn Williams | e63a026 | 2019-10-22 10:30:49 +0100 | [diff] [blame] | 42 | { |
Jim Flynn | bbfe603 | 2020-07-20 16:57:44 +0100 | [diff] [blame] | 43 | m_SwTraceMessages.push_back(arm::pipe::ReadSwTraceMessage(data, offset, packet.GetLength())); |
Finn Williams | e63a026 | 2019-10-22 10:30:49 +0100 | [diff] [blame] | 44 | } |
Finn Williams | e6a2ccd | 2020-02-27 16:21:41 +0000 | [diff] [blame] | 45 | |
| 46 | m_TimelineCaptureCommandHandler.SetThreadIdSize(m_SwTraceHeader.m_ThreadIdBytes); |
Finn Williams | e63a026 | 2019-10-22 10:30:49 +0100 | [diff] [blame] | 47 | } |
| 48 | |
| 49 | void TimelineDirectoryCaptureCommandHandler::Print() |
| 50 | { |
| 51 | std::string header; |
| 52 | |
Jim Flynn | bbfe603 | 2020-07-20 16:57:44 +0100 | [diff] [blame] | 53 | header.append(arm::pipe::CentreAlignFormatting("decl_id", 12)); |
Finn Williams | e63a026 | 2019-10-22 10:30:49 +0100 | [diff] [blame] | 54 | header.append(" | "); |
Jim Flynn | bbfe603 | 2020-07-20 16:57:44 +0100 | [diff] [blame] | 55 | header.append(arm::pipe::CentreAlignFormatting("decl_name", 20)); |
Finn Williams | e63a026 | 2019-10-22 10:30:49 +0100 | [diff] [blame] | 56 | header.append(" | "); |
Jim Flynn | bbfe603 | 2020-07-20 16:57:44 +0100 | [diff] [blame] | 57 | header.append(arm::pipe::CentreAlignFormatting("ui_name", 20)); |
Finn Williams | e63a026 | 2019-10-22 10:30:49 +0100 | [diff] [blame] | 58 | header.append(" | "); |
Jim Flynn | bbfe603 | 2020-07-20 16:57:44 +0100 | [diff] [blame] | 59 | header.append(arm::pipe::CentreAlignFormatting("arg_types", 16)); |
Finn Williams | e63a026 | 2019-10-22 10:30:49 +0100 | [diff] [blame] | 60 | header.append(" | "); |
Jim Flynn | bbfe603 | 2020-07-20 16:57:44 +0100 | [diff] [blame] | 61 | header.append(arm::pipe::CentreAlignFormatting("arg_names", 80)); |
Finn Williams | e63a026 | 2019-10-22 10:30:49 +0100 | [diff] [blame] | 62 | header.append("\n"); |
| 63 | |
| 64 | std::cout << "\n" << "\n"; |
Jim Flynn | bbfe603 | 2020-07-20 16:57:44 +0100 | [diff] [blame] | 65 | std::cout << arm::pipe::CentreAlignFormatting("SW DIRECTORY", static_cast<int>(header.size())); |
Finn Williams | e63a026 | 2019-10-22 10:30:49 +0100 | [diff] [blame] | 66 | std::cout << "\n"; |
| 67 | std::cout << std::string(header.size(), '=') << "\n"; |
| 68 | |
Matteo Martincigh | 34a407d | 2019-11-06 15:30:54 +0000 | [diff] [blame] | 69 | std::cout << header; |
Finn Williams | e63a026 | 2019-10-22 10:30:49 +0100 | [diff] [blame] | 70 | |
Matteo Martincigh | 34a407d | 2019-11-06 15:30:54 +0000 | [diff] [blame] | 71 | for (const auto& swTraceMessage : m_SwTraceMessages) |
Finn Williams | e63a026 | 2019-10-22 10:30:49 +0100 | [diff] [blame] | 72 | { |
| 73 | std::string body; |
| 74 | |
Jim Flynn | bbfe603 | 2020-07-20 16:57:44 +0100 | [diff] [blame] | 75 | body.append(arm::pipe::CentreAlignFormatting(std::to_string(swTraceMessage.m_Id), 12)); |
Finn Williams | e63a026 | 2019-10-22 10:30:49 +0100 | [diff] [blame] | 76 | body.append(" | "); |
Jim Flynn | bbfe603 | 2020-07-20 16:57:44 +0100 | [diff] [blame] | 77 | body.append(arm::pipe::CentreAlignFormatting(swTraceMessage.m_Name, 20)); |
Finn Williams | e63a026 | 2019-10-22 10:30:49 +0100 | [diff] [blame] | 78 | body.append(" | "); |
Jim Flynn | bbfe603 | 2020-07-20 16:57:44 +0100 | [diff] [blame] | 79 | body.append(arm::pipe::CentreAlignFormatting(swTraceMessage.m_UiName, 20)); |
Finn Williams | e63a026 | 2019-10-22 10:30:49 +0100 | [diff] [blame] | 80 | body.append(" | "); |
| 81 | |
| 82 | std::string argTypes; |
Matteo Martincigh | 34a407d | 2019-11-06 15:30:54 +0000 | [diff] [blame] | 83 | for (auto argType: swTraceMessage.m_ArgTypes) |
Finn Williams | e63a026 | 2019-10-22 10:30:49 +0100 | [diff] [blame] | 84 | { |
| 85 | argTypes += argType; |
| 86 | argTypes += " "; |
| 87 | } |
Jim Flynn | bbfe603 | 2020-07-20 16:57:44 +0100 | [diff] [blame] | 88 | body.append(arm::pipe::CentreAlignFormatting(argTypes, 16)); |
Finn Williams | e63a026 | 2019-10-22 10:30:49 +0100 | [diff] [blame] | 89 | body.append(" | "); |
| 90 | |
| 91 | std::string argNames; |
Matteo Martincigh | 34a407d | 2019-11-06 15:30:54 +0000 | [diff] [blame] | 92 | for (auto argName: swTraceMessage.m_ArgNames) |
Finn Williams | e63a026 | 2019-10-22 10:30:49 +0100 | [diff] [blame] | 93 | { |
| 94 | argNames += argName + " "; |
| 95 | } |
Jim Flynn | bbfe603 | 2020-07-20 16:57:44 +0100 | [diff] [blame] | 96 | body.append(arm::pipe::CentreAlignFormatting(argNames, 80)); |
Finn Williams | e63a026 | 2019-10-22 10:30:49 +0100 | [diff] [blame] | 97 | |
| 98 | body.append("\n"); |
| 99 | |
| 100 | std::cout << std::string(body.size(), '-') << "\n"; |
| 101 | |
Matteo Martincigh | 34a407d | 2019-11-06 15:30:54 +0000 | [diff] [blame] | 102 | std::cout << body; |
Finn Williams | e63a026 | 2019-10-22 10:30:49 +0100 | [diff] [blame] | 103 | } |
| 104 | } |
| 105 | |
Jim Flynn | bbfe603 | 2020-07-20 16:57:44 +0100 | [diff] [blame] | 106 | void TimelineDirectoryCaptureCommandHandler::operator()(const arm::pipe::Packet& packet) |
Finn Williams | e63a026 | 2019-10-22 10:30:49 +0100 | [diff] [blame] | 107 | { |
| 108 | ParseData(packet); |
| 109 | |
Matteo Martincigh | 34a407d | 2019-11-06 15:30:54 +0000 | [diff] [blame] | 110 | if (!m_QuietOperation) |
Finn Williams | e63a026 | 2019-10-22 10:30:49 +0100 | [diff] [blame] | 111 | { |
| 112 | Print(); |
| 113 | } |
| 114 | } |
| 115 | |
Jim Flynn | bbfe603 | 2020-07-20 16:57:44 +0100 | [diff] [blame] | 116 | } //namespace pipe |
| 117 | } //namespace arm |