| Index: components/tracing/graphics_memory_dump_provider_android.cc
|
| diff --git a/components/tracing/graphics_memory_dump_provider_android.cc b/components/tracing/graphics_memory_dump_provider_android.cc
|
| deleted file mode 100644
|
| index 26b578561a6130f3c6b1fa3eb0b4aa520e85d700..0000000000000000000000000000000000000000
|
| --- a/components/tracing/graphics_memory_dump_provider_android.cc
|
| +++ /dev/null
|
| @@ -1,147 +0,0 @@
|
| -// 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 "components/tracing/graphics_memory_dump_provider_android.h"
|
| -
|
| -#include <fcntl.h>
|
| -#include <stdint.h>
|
| -#include <string.h>
|
| -#include <sys/socket.h>
|
| -#include <sys/time.h>
|
| -#include <sys/types.h>
|
| -#include <sys/un.h>
|
| -
|
| -#include "base/files/scoped_file.h"
|
| -#include "base/macros.h"
|
| -#include "base/posix/eintr_wrapper.h"
|
| -#include "base/strings/string_number_conversions.h"
|
| -#include "base/strings/string_piece.h"
|
| -#include "base/strings/string_tokenizer.h"
|
| -#include "base/trace_event/process_memory_dump.h"
|
| -#include "base/trace_event/process_memory_totals.h"
|
| -
|
| -using base::trace_event::MemoryAllocatorDump;
|
| -
|
| -namespace tracing {
|
| -
|
| -// static
|
| -const char GraphicsMemoryDumpProvider::kDumpBaseName[] =
|
| - "gpu/android_memtrack/";
|
| -
|
| -// static
|
| -GraphicsMemoryDumpProvider* GraphicsMemoryDumpProvider::GetInstance() {
|
| - return base::Singleton<
|
| - GraphicsMemoryDumpProvider,
|
| - base::LeakySingletonTraits<GraphicsMemoryDumpProvider>>::get();
|
| -}
|
| -
|
| -bool GraphicsMemoryDumpProvider::OnMemoryDump(
|
| - const base::trace_event::MemoryDumpArgs& args,
|
| - base::trace_event::ProcessMemoryDump* pmd) {
|
| - if (args.level_of_detail !=
|
| - base::trace_event::MemoryDumpLevelOfDetail::DETAILED)
|
| - return true; // Dump on detailed memory dumps only.
|
| -
|
| - const char kAbstractSocketName[] = "chrome_tracing_memtrack_helper";
|
| - struct sockaddr_un addr;
|
| -
|
| - const int sock = socket(AF_UNIX, SOCK_SEQPACKET, 0);
|
| - if (sock == -1)
|
| - return false;
|
| - // Ensures that sock is always closed, even in case of early returns.
|
| - base::ScopedFD sock_closer(sock);
|
| -
|
| - // Set recv() timeout to 250 ms.
|
| - struct timeval tv;
|
| - tv.tv_sec = 0;
|
| - tv.tv_usec = 250000;
|
| - setsockopt(sock, SOL_SOCKET, SO_RCVTIMEO, &tv, sizeof(tv));
|
| -
|
| - // Connect to the UNIX abstract (i.e. no physical filesystem link) socket.
|
| - memset(&addr, 0, sizeof(addr));
|
| - addr.sun_family = AF_UNIX;
|
| - strncpy(&addr.sun_path[1], kAbstractSocketName, sizeof(addr.sun_path) - 2);
|
| -
|
| - if (connect(sock, reinterpret_cast<struct sockaddr*>(&addr), sizeof(addr))) {
|
| - LOG(WARNING) << "Could not connect to the memtrack_helper daemon. Please "
|
| - "build memtrack_helper, adb push to the device and run it "
|
| - "before starting the trace to get graphics memory data.";
|
| - return false;
|
| - }
|
| -
|
| - // Check that the socket is owned by root (the memtrack_helper) process and
|
| - // not an (untrusted) user process.
|
| - struct ucred cred;
|
| - socklen_t cred_len = sizeof(cred);
|
| - if (getsockopt(sock, SOL_SOCKET, SO_PEERCRED, &cred, &cred_len) < 0 ||
|
| - (static_cast<unsigned>(cred_len) < sizeof(cred)) ||
|
| - cred.uid != 0 /* root */) {
|
| - LOG(WARNING) << "Untrusted (!= root) memtrack_helper daemon detected.";
|
| - return false;
|
| - }
|
| -
|
| - // Send the trace(PID) request.
|
| - char buf[4096];
|
| - const int buf_pid_len = snprintf(buf, sizeof(buf) - 1, "%d", getpid());
|
| - if (HANDLE_EINTR(send(sock, buf, buf_pid_len + 1, 0)) <= 0)
|
| - return false;
|
| -
|
| - // The response consists of a few lines, each one with a key value pair. E.g.:
|
| - // graphics_total 10616832
|
| - // graphics_pss 10616832
|
| - // gl_total 17911808
|
| - // gl_pss 17911808
|
| - ssize_t rsize;
|
| - if ((rsize = HANDLE_EINTR(recv(sock, buf, sizeof(buf), 0))) <= 0)
|
| - return false;
|
| -
|
| - buf[sizeof(buf) - 1] = '\0';
|
| - ParseResponseAndAddToDump(buf, static_cast<size_t>(rsize), pmd);
|
| - return true;
|
| -}
|
| -
|
| -void GraphicsMemoryDumpProvider::ParseResponseAndAddToDump(
|
| - const char* response,
|
| - size_t length,
|
| - base::trace_event::ProcessMemoryDump* pmd) {
|
| - base::CStringTokenizer tokenizer(response, response + length, " \n");
|
| - while (true) {
|
| - if (!tokenizer.GetNext())
|
| - break;
|
| - base::StringPiece row_name = tokenizer.token_piece();
|
| - if (!tokenizer.GetNext())
|
| - break;
|
| - base::StringPiece value_str = tokenizer.token_piece();
|
| - int64_t value;
|
| - if (!base::StringToInt64(value_str, &value) || value < 0)
|
| - continue; // Skip invalid or negative values.
|
| -
|
| - // Turn entries like graphics_total into a row named "graphics" and
|
| - // column named "total".
|
| - std::string column_name = "memtrack_";
|
| - size_t key_split_point = row_name.find_last_of('_');
|
| - if (key_split_point > 0 && key_split_point < row_name.size() - 1) {
|
| - row_name.substr(key_split_point + 1).AppendToString(&column_name);
|
| - row_name = row_name.substr(0, key_split_point);
|
| - } else {
|
| - column_name += "unknown";
|
| - }
|
| -
|
| - // Append a row to the memory dump.
|
| - std::string dump_name;
|
| - dump_name.reserve(arraysize(kDumpBaseName) + row_name.size() + 1);
|
| - dump_name.assign(kDumpBaseName);
|
| - row_name.AppendToString(&dump_name);
|
| - MemoryAllocatorDump* mad = pmd->GetOrCreateAllocatorDump(dump_name);
|
| - const auto& long_lived_column_name = key_names_.insert(column_name).first;
|
| - mad->AddScalar(long_lived_column_name->c_str(),
|
| - MemoryAllocatorDump::kUnitsBytes, value);
|
| - }
|
| -}
|
| -
|
| -GraphicsMemoryDumpProvider::GraphicsMemoryDumpProvider() {}
|
| -
|
| -GraphicsMemoryDumpProvider::~GraphicsMemoryDumpProvider() {}
|
| -
|
| -} // namespace tracing
|
|
|