| Index: content/browser/tracing/tracing_controller_impl.cc
|
| diff --git a/content/browser/tracing/tracing_controller_impl.cc b/content/browser/tracing/tracing_controller_impl.cc
|
| index 684bea8ec49b574b7ce45586d9aee86388c0e645..438f1269ac73d969e0727c43ab01f06e3c3b940c 100644
|
| --- a/content/browser/tracing/tracing_controller_impl.cc
|
| +++ b/content/browser/tracing/tracing_controller_impl.cc
|
| @@ -12,6 +12,7 @@
|
| #include "base/sys_info.h"
|
| #include "base/trace_event/trace_event.h"
|
| #include "build/build_config.h"
|
| +#include "components/tracing/process_metrics_memory_dump_provider.h"
|
| #include "content/browser/tracing/file_tracing_provider_impl.h"
|
| #include "content/browser/tracing/power_tracing_agent.h"
|
| #include "content/browser/tracing/trace_message_filter.h"
|
| @@ -556,6 +557,13 @@ void TracingControllerImpl::AddTraceMessageFilter(
|
| return;
|
| }
|
|
|
| +#if defined(OS_LINUX)
|
| + // On Linux the browser process dumps process metrics for child process due to
|
| + // sandbox.
|
| + tracing::ProcessMetricsMemoryDumpProvider::RegisterForProcess(
|
| + trace_message_filter->peer_pid());
|
| +#endif
|
| +
|
| trace_message_filters_.insert(trace_message_filter);
|
| if (can_cancel_watch_event()) {
|
| trace_message_filter->SendSetWatchEvent(watch_category_name_,
|
| @@ -584,6 +592,11 @@ void TracingControllerImpl::RemoveTraceMessageFilter(
|
| return;
|
| }
|
|
|
| +#if defined(OS_LINUX)
|
| + tracing::ProcessMetricsMemoryDumpProvider::UnregisterForProcess(
|
| + trace_message_filter->peer_pid());
|
| +#endif
|
| +
|
| // If a filter is removed while a response from that filter is pending then
|
| // simulate the response. Otherwise the response count will be wrong and the
|
| // completion callback will never be executed.
|
|
|