You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
o3de/Code/Tools/Standalone/Source/Driller/Profiler/ProfilerDataParser.cpp

262 lines
10 KiB
C++

/*
* All or portions of this file Copyright (c) Amazon.com, Inc. or its affiliates or
* its licensors.
*
* For complete copyright and license terms please see the LICENSE at the root of this
* distribution (the "License"). All use of this software is governed by the License,
* or, if provided, by the license below or the license accompanying this file. Do not
* remove or modify any license notices. This file is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
*
*/
#include "StandaloneTools_precompiled.h"
#include "ProfilerDataParser.h"
#include "ProfilerDataAggregator.hxx"
#include "ProfilerEvents.h"
namespace Driller
{
AZ::Debug::DrillerHandlerParser* ProfilerDrillerHandlerParser::OnEnterTag(AZ::u32 tagName)
{
AZ_Assert(m_data, "You must set a valid memory aggregator before we can process the data!");
if (tagName == AZ_CRC("NewRegister", 0xf0f2f287))
{
m_subTag = ST_NEW_REGSTER;
m_data->AddEvent(aznew ProfilerDrillerNewRegisterEvent());
return this;
}
else if (tagName == AZ_CRC("UpdateRegister", 0x6c00b890))
{
m_subTag = ST_UPDATE_REGSTER;
m_data->AddEvent(aznew ProfilerDrillerUpdateRegisterEvent());
return this;
}
else if (tagName == AZ_CRC("ThreadEnter", 0x60e4acfb))
{
m_subTag = ST_ENTER_THREAD;
m_data->AddEvent(aznew ProfilerDrillerEnterThreadEvent());
return this;
}
else if (tagName == AZ_CRC("OnThreadExit", 0x16042db9))
{
m_subTag = ST_EXIT_THREAD;
m_data->AddEvent(aznew ProfilerDrillerExitThreadEvent());
return this;
}
else if (tagName == AZ_CRC("RegisterSystem", 0x957739ef))
{
m_subTag = ST_REGISTER_SYSTEM;
m_data->AddEvent(aznew ProfilerDrillerRegisterSystemEvent());
return this;
}
else if (tagName == AZ_CRC("UnregisterSystem", 0xa20538e4))
{
m_subTag = ST_UNREGISTER_SYSTEM;
m_data->AddEvent(aznew ProfilerDrillerUnregisterSystemEvent());
return this;
}
else
{
m_subTag = ST_NONE;
}
return nullptr;
}
void ProfilerDrillerHandlerParser::OnExitTag(DrillerHandlerParser* handler, AZ::u32 tagName)
{
(void)tagName;
if (handler != nullptr)
{
if (m_subTag != ST_NONE)
{
m_data->OnEventLoaded(m_data->GetEvents().back());
m_subTag = ST_NONE; // we have only one level just go back to the default state
}
}
}
void ProfilerDrillerHandlerParser::OnData(const AZ::Debug::DrillerSAXParser::Data& dataNode)
{
AZ_Assert(m_data, "You must set a valid memory aggregator before we can process the data!");
switch (m_subTag)
{
case ST_NEW_REGSTER:
{
ProfilerDrillerNewRegisterEvent* event = static_cast<ProfilerDrillerNewRegisterEvent*>(m_data->GetEvents().back());
if (dataNode.m_name == AZ_CRC("Id", 0xbf396750))
{
dataNode.Read(event->m_registerInfo.m_id);
}
else if (dataNode.m_name == AZ_CRC("ThreadId", 0xd0fd9043))
{
dataNode.Read(event->m_registerInfo.m_threadId);
}
else if (dataNode.m_name == AZ_CRC("Name", 0x5e237e06))
{
event->m_registerInfo.m_name = dataNode.ReadPooledString();
}
else if (dataNode.m_name == AZ_CRC("Function", 0xcaae163d))
{
event->m_registerInfo.m_function = dataNode.ReadPooledString();
}
else if (dataNode.m_name == AZ_CRC("Line", 0xd114b4f6))
{
dataNode.Read(event->m_registerInfo.m_line);
}
else if (dataNode.m_name == AZ_CRC("SystemId", 0x0dfecf6f))
{
dataNode.Read(event->m_registerInfo.m_systemId);
}
else if (dataNode.m_name == AZ_CRC("Type", 0x8cde5729))
{
dataNode.Read(event->m_registerInfo.m_type);
}
else if (dataNode.m_name == AZ_CRC("Time", 0x6f949845))
{
dataNode.Read(event->m_registerData.m_timeData.m_time);
}
else if (dataNode.m_name == AZ_CRC("ChildrenTime", 0x46162d3f))
{
dataNode.Read(event->m_registerData.m_timeData.m_childrenTime);
}
else if (dataNode.m_name == AZ_CRC("Calls", 0xdaa35c8f))
{
dataNode.Read(event->m_registerData.m_timeData.m_calls);
}
else if (dataNode.m_name == AZ_CRC("ChildrenCalls", 0x6a5a4618))
{
dataNode.Read(event->m_registerData.m_timeData.m_childrenCalls);
}
else if (dataNode.m_name == AZ_CRC("ParentId", 0x856a684c))
{
dataNode.Read(event->m_registerData.m_timeData.m_lastParentRegisterId);
}
else if (dataNode.m_name == AZ_CRC("Value1", 0xa2756c5a))
{
dataNode.Read(event->m_registerData.m_valueData.m_value1);
}
else if (dataNode.m_name == AZ_CRC("Value2", 0x3b7c3de0))
{
dataNode.Read(event->m_registerData.m_valueData.m_value2);
}
else if (dataNode.m_name == AZ_CRC("Value3", 0x4c7b0d76))
{
dataNode.Read(event->m_registerData.m_valueData.m_value3);
}
else if (dataNode.m_name == AZ_CRC("Value4", 0xd21f98d5))
{
dataNode.Read(event->m_registerData.m_valueData.m_value4);
}
else if (dataNode.m_name == AZ_CRC("Value5", 0xa518a843))
{
dataNode.Read(event->m_registerData.m_valueData.m_value5);
}
} break;
case ST_UPDATE_REGSTER:
{
ProfilerDrillerUpdateRegisterEvent* event = static_cast<ProfilerDrillerUpdateRegisterEvent*>(m_data->GetEvents().back());
if (dataNode.m_name == AZ_CRC("Id", 0xbf396750))
{
dataNode.Read(event->m_registerId);
}
else if (dataNode.m_name == AZ_CRC("Time", 0x6f949845))
{
dataNode.Read(event->m_registerData.m_timeData.m_time);
}
else if (dataNode.m_name == AZ_CRC("ChildrenTime", 0x46162d3f))
{
dataNode.Read(event->m_registerData.m_timeData.m_childrenTime);
}
else if (dataNode.m_name == AZ_CRC("Calls", 0xdaa35c8f))
{
dataNode.Read(event->m_registerData.m_timeData.m_calls);
}
else if (dataNode.m_name == AZ_CRC("ChildrenCalls", 0x6a5a4618))
{
dataNode.Read(event->m_registerData.m_timeData.m_childrenCalls);
}
else if (dataNode.m_name == AZ_CRC("ParentId", 0x856a684c))
{
dataNode.Read(event->m_registerData.m_timeData.m_lastParentRegisterId);
}
else if (dataNode.m_name == AZ_CRC("Value1", 0xa2756c5a))
{
dataNode.Read(event->m_registerData.m_valueData.m_value1);
}
else if (dataNode.m_name == AZ_CRC("Value2", 0x3b7c3de0))
{
dataNode.Read(event->m_registerData.m_valueData.m_value2);
}
else if (dataNode.m_name == AZ_CRC("Value3", 0x4c7b0d76))
{
dataNode.Read(event->m_registerData.m_valueData.m_value3);
}
else if (dataNode.m_name == AZ_CRC("Value4", 0xd21f98d5))
{
dataNode.Read(event->m_registerData.m_valueData.m_value4);
}
else if (dataNode.m_name == AZ_CRC("Value5", 0xa518a843))
{
dataNode.Read(event->m_registerData.m_valueData.m_value5);
}
} break;
case ST_ENTER_THREAD:
{
ProfilerDrillerEnterThreadEvent* event = static_cast<ProfilerDrillerEnterThreadEvent*>(m_data->GetEvents().back());
if (dataNode.m_name == AZ_CRC("Id", 0xbf396750))
{
dataNode.Read(event->m_threadId);
}
else if (dataNode.m_name == AZ_CRC("Name", 0x5e237e06))
{
event->m_threadName = dataNode.ReadPooledString();
}
else if (dataNode.m_name == AZ_CRC("CpuId", 0xdf558508))
{
dataNode.Read(event->m_cpuId);
}
else if (dataNode.m_name == AZ_CRC("Priority", 0x62a6dc27))
{
dataNode.Read(event->m_priority);
}
else if (dataNode.m_name == AZ_CRC("StackSize", 0x9cfaf35b))
{
dataNode.Read(event->m_stackSize);
}
} break;
case ST_EXIT_THREAD:
{
ProfilerDrillerExitThreadEvent* event = static_cast<ProfilerDrillerExitThreadEvent*>(m_data->GetEvents().back());
if (dataNode.m_name == AZ_CRC("Id", 0xbf396750))
{
dataNode.Read(event->m_threadId);
}
} break;
case ST_REGISTER_SYSTEM:
{
ProfilerDrillerRegisterSystemEvent* event = static_cast<ProfilerDrillerRegisterSystemEvent*>(m_data->GetEvents().back());
if (dataNode.m_name == AZ_CRC("Id", 0xbf396750))
{
dataNode.Read(event->m_systemId);
}
else if (dataNode.m_name == AZ_CRC("Name", 0x5e237e06))
{
event->m_name = dataNode.ReadPooledString();
}
} break;
case ST_UNREGISTER_SYSTEM:
{
ProfilerDrillerUnregisterSystemEvent* event = static_cast<ProfilerDrillerUnregisterSystemEvent*>(m_data->GetEvents().back());
if (dataNode.m_name == AZ_CRC("Id", 0xbf396750))
{
dataNode.Read(event->m_systemId);
}
} break;
}
}
} // namespace Driller