blob: e643014c972f283c1c037c5a2e656c8d891f12f6 [file] [log] [blame]
// Copyright 2017 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include <iosfwd>
#include <vector>
#include "base/values.h"
#include "chrome/common/profiling/memlog_stream.h"
#include "chrome/common/profiling/profiling_service.mojom.h"
#include "chrome/profiling/allocation_event.h"
#include "services/resource_coordinator/public/interfaces/memory_instrumentation/memory_instrumentation.mojom.h"
namespace profiling {
// Configuration passed to the export functions because they take many
// arguments. All parameters must be set.
struct ExportParams {
// Allocation events to export.
AllocationCountMap allocs;
// VM map of all regions in the process.
std::vector<memory_instrumentation::mojom::VmRegionPtr> maps;
// Map from context string to context ID. A reverse-mapping will tell you
// what the context_id in the allocation mean.
std::map<std::string, int> context_map;
// Some addresses represent strings rather than instruction pointers.
// The strings are assumed to already be escaped for JSON.
std::unordered_map<uint64_t, std::string> mapped_strings;
// The type of browser [browser, renderer, gpu] that is being heap-dumped.
mojom::ProcessType process_type = mojom::ProcessType::OTHER;
// Only allocations exceeding this size or count will be exported.
size_t min_size_threshold = 0;
size_t min_count_threshold = 0;
// Whether or not the paths should be stripped from mapped files. Doing so
// anonymizes the trace, since the paths could potentially contain a username.
// However, it prevents symbolization of locally built instances of Chrome.
bool strip_path_from_mapped_files = false;
// Creates a JSON string representing a JSON dictionary that contains memory
// maps and v2 format stack traces.
void ExportMemoryMapsAndV2StackTraceToJSON(const ExportParams& params,
std::ostream& out);
} // namespace profiling