| Index: base/trace_event/memory_allocator_dump.cc
|
| diff --git a/base/trace_event/memory_allocator_dump.cc b/base/trace_event/memory_allocator_dump.cc
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..604af7a284dc9233417805f9b757ee34eb01dce7
|
| --- /dev/null
|
| +++ b/base/trace_event/memory_allocator_dump.cc
|
| @@ -0,0 +1,91 @@
|
| +// Copyright 2015 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 "base/trace_event/memory_allocator_dump.h"
|
| +
|
| +#include "base/format_macros.h"
|
| +#include "base/strings/stringprintf.h"
|
| +#include "base/trace_event/memory_allocator_attributes.h"
|
| +#include "base/trace_event/memory_dump_manager.h"
|
| +#include "base/trace_event/memory_dump_provider.h"
|
| +#include "base/trace_event/trace_event_argument.h"
|
| +#include "base/values.h"
|
| +
|
| +namespace base {
|
| +namespace trace_event {
|
| +
|
| +MemoryAllocatorDump::MemoryAllocatorDump(const std::string& name,
|
| + MemoryAllocatorDump* parent)
|
| + : name_(name),
|
| + parent_(parent),
|
| + physical_size_in_bytes_(0),
|
| + allocated_objects_count_(0),
|
| + allocated_objects_size_in_bytes_(0) {
|
| + // Dots are not allowed in the name as the underlying base::DictionaryValue
|
| + // would treat them magically and split in sub-nodes, which is not intended.
|
| + DCHECK_EQ(std::string::npos, name.find_first_of('.'));
|
| +}
|
| +
|
| +MemoryAllocatorDump::~MemoryAllocatorDump() {
|
| +}
|
| +
|
| +void MemoryAllocatorDump::SetExtraAttribute(const std::string& name,
|
| + int value) {
|
| + extra_attributes_.SetInteger(name, value);
|
| +}
|
| +
|
| +int MemoryAllocatorDump::GetExtraIntegerAttribute(
|
| + const std::string& name) const {
|
| + bool res;
|
| + int value = -1;
|
| + res = extra_attributes_.GetInteger(name, &value);
|
| + DCHECK(res) << "Allocator attribute '" << name << "' not found";
|
| + return value;
|
| +}
|
| +
|
| +void MemoryAllocatorDump::AsValueInto(TracedValue* value) const {
|
| + static const char kHexFmt[] = "%" PRIx64;
|
| +
|
| + value->BeginDictionary(name_.c_str());
|
| +
|
| + value->SetString("parent", parent_ ? parent_->name_ : "");
|
| + value->SetString("physical_size_in_bytes",
|
| + StringPrintf(kHexFmt, physical_size_in_bytes_));
|
| + value->SetString("allocated_objects_count",
|
| + StringPrintf(kHexFmt, allocated_objects_count_));
|
| + value->SetString("allocated_objects_size_in_bytes",
|
| + StringPrintf(kHexFmt, allocated_objects_size_in_bytes_));
|
| +
|
| + // Copy all the extra attributes.
|
| + const MemoryDumpProvider* mdp =
|
| + MemoryDumpManager::GetInstance()->dump_provider_currently_active();
|
| + const MemoryAllocatorDeclaredAttributes& extra_attributes_types =
|
| + mdp->allocator_attributes();
|
| +
|
| + value->BeginDictionary("args");
|
| + for (DictionaryValue::Iterator it(extra_attributes_); !it.IsAtEnd();
|
| + it.Advance()) {
|
| + const std::string& attr_name = it.key();
|
| + const Value& attr_value = it.value();
|
| + value->BeginDictionary(attr_name.c_str());
|
| + value->SetValue("value", attr_value.DeepCopy());
|
| +
|
| + auto attr_it = extra_attributes_types.find(attr_name);
|
| + DCHECK(attr_it != extra_attributes_types.end())
|
| + << "Allocator attribute " << attr_name
|
| + << " not declared for the dumper " << mdp->GetFriendlyName();
|
| +
|
| + // TODO(primiano): the "type" should be dumped just once, not repeated on
|
| + // on every event. The ability of doing so depends on crbug.com/466121.
|
| + value->SetString("type", attr_it->second.type);
|
| +
|
| + value->EndDictionary(); // "arg_name": { "type": "...", "value": "..." }
|
| + }
|
| + value->EndDictionary(); // "args": {}
|
| +
|
| + value->EndDictionary(); // "allocator name": {}
|
| +}
|
| +
|
| +} // namespace trace_event
|
| +} // namespace base
|
|
|