Add exporter for Chrome's trace profiler from chunk metadata.

This commit is contained in:
baldurk
2017-11-24 11:37:30 +00:00
parent e08e5f0692
commit cba76414e1
4 changed files with 94 additions and 0 deletions
+1
View File
@@ -133,6 +133,7 @@ set(sources
serialise/rdcfile.cpp
serialise/rdcfile.h
serialise/codecs/xml_codec.cpp
serialise/codecs/chrome_json_codec.cpp
serialise/comp_io_tests.cpp
serialise/serialiser_tests.cpp
serialise/streamio_tests.cpp
+1
View File
@@ -396,6 +396,7 @@
<ClCompile Include="replay\replay_driver.cpp" />
<ClCompile Include="replay\replay_output.cpp" />
<ClCompile Include="replay\replay_controller.cpp" />
<ClCompile Include="serialise\codecs\chrome_json_codec.cpp" />
<ClCompile Include="serialise\codecs\xml_codec.cpp" />
<ClCompile Include="serialise\comp_io_tests.cpp" />
<ClCompile Include="serialise\lz4io.cpp" />
+3
View File
@@ -632,6 +632,9 @@
<ClCompile Include="serialise\serialiser_tests.cpp">
<Filter>Common\Serialise</Filter>
</ClCompile>
<ClCompile Include="serialise\codecs\chrome_json_codec.cpp">
<Filter>Common\Serialise\Codecs</Filter>
</ClCompile>
</ItemGroup>
<ItemGroup>
<None Include="os\win32\comexport.def">
@@ -0,0 +1,89 @@
/******************************************************************************
* The MIT License (MIT)
*
* Copyright (c) 2017 Baldur Karlsson
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in
* all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
* THE SOFTWARE.
******************************************************************************/
#include <utility>
#include "common/common.h"
#include "serialise/rdcfile.h"
ReplayStatus exportChrome(const char *filename, const RDCFile &rdc, const SDFile &structData,
float *progress)
{
FILE *f = FileIO::fopen(filename, "w");
if(!f)
return ReplayStatus::FileIOFailed;
std::string str;
// add header, customise this as needed.
str = R"({
"displayTimeUnit": "ns",
"traceEvents": [)";
const char *category = "Initialisation";
// stupid JSON not allowing trailing ,s :(
bool first = true;
for(const SDChunk *chunk : structData.chunks)
{
if(chunk->metadata.chunkID == (uint32_t)SystemChunk::FirstDriverChunk + 1)
category = "Frame Capture";
if(!first)
str += ",";
first = false;
const char *fmt = R"(
{ "name": "%s", "cat": "%s", "ph": "B", "ts": %llu, "pid": 5, "tid": %u },
{ "ph": "E", "ts": %llu, "pid": 5, "tid": %u })";
if(chunk->metadata.durationMicro == 0)
{
fmt = R"(
{ "name": "%s", "cat": "%s", "ph": "i", "ts": %llu, "pid": 5, "tid": %u })";
}
str += StringFormat::Fmt(
fmt, chunk->name.c_str(), category, chunk->metadata.timestampMicro, chunk->metadata.threadID,
chunk->metadata.timestampMicro + chunk->metadata.durationMicro, chunk->metadata.threadID);
}
// end trace events
str += "\n ]\n}";
FileIO::fwrite(str.data(), 1, str.size(), f);
FileIO::fclose(f);
return ReplayStatus::Succeeded;
}
static ConversionRegistration XMLConversionRegistration("chrome.json", R"(Chrome profiler JSON.
Exports the chunk threadID, timestamp and duration data to a JSON format that can be loaded by
chrome's profiler at chrome://tracing
)",
&exportChrome);