Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1306)

Unified Diff: content/browser/process_resource_usage_impl.h

Issue 972083002: Report utility process JS memory in task manager. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@v8-pac-oop
Patch Set: Clean up. Created 5 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: content/browser/process_resource_usage_impl.h
diff --git a/content/browser/process_resource_usage_impl.h b/content/browser/process_resource_usage_impl.h
new file mode 100644
index 0000000000000000000000000000000000000000..890cf244c9f44ec875659b03468ca0c505351d6e
--- /dev/null
+++ b/content/browser/process_resource_usage_impl.h
@@ -0,0 +1,53 @@
+// 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.
+
+#ifndef CONTENT_BROWSER_PROCESS_RESOURCE_USAGE_IMPL_H_
+#define CONTENT_BROWSER_PROCESS_RESOURCE_USAGE_IMPL_H_
+
+#include "base/basictypes.h"
+#include "base/memory/scoped_ptr.h"
+#include "base/memory/weak_ptr.h"
+#include "base/message_loop/message_loop_proxy.h"
+#include "base/synchronization/lock.h"
+#include "content/public/browser/process_resource_usage.h"
+#include "content/public/common/resource_usage_reporter.mojom.h"
+
+namespace content {
+
ncarter (slow) 2015/05/01 21:16:52 Could you add a class comment that tries to answer
Anand Mistry (off Chromium) 2015/05/06 02:44:18 Expanded the class comment for the public interfac
ncarter (slow) 2015/05/07 20:12:43 Makes sense, thank you.
+class CONTENT_EXPORT ProcessResourceUsageImpl : public ProcessResourceUsage {
+ public:
+ // Must be called from the same thread that created |service|.
+ explicit ProcessResourceUsageImpl(ResourceUsageReporterPtr service);
+
+ // ProcessResourceUsage implementation. May be called from any thread.
+ void Refresh() override;
+ bool ReportsV8MemoryStats() const override;
+ size_t GetV8MemoryAllocated() const override;
+ size_t GetV8MemoryUsed() const override;
+
+ private:
+ class Client;
+
+ ~ProcessResourceUsageImpl() override;
+
+ // Data refresh callback. Will be run on |mojo_message_loop_|.
+ void OnRefreshDone(ResourceUsageDataPtr data);
+
+ // Accessed on any thread.
+ mutable base::Lock lock_;
ncarter (slow) 2015/05/01 21:16:52 What would this look like if we used PostTask inst
Anand Mistry (off Chromium) 2015/05/06 02:44:18 Done. It's cleaner, but requires some passing arou
+ ResourceUsageDataPtr stats_;
+
+ // Message loop the Mojo service is tied to. Mojo interfaces are
+ // thread-hostile and must always be accessed from the same thread.
+ scoped_refptr<base::MessageLoopProxy> mojo_message_loop_;
ncarter (slow) 2015/05/01 21:16:52 This is my first time looking at code that uses mo
Anand Mistry (off Chromium) 2015/05/05 04:11:21 Mojo hides all the IPC details, but it still expos
+
+ // All methods must be posted to |mojo_message_loop_|.
+ base::WeakPtr<Client> client_;
+
+ DISALLOW_COPY_AND_ASSIGN(ProcessResourceUsageImpl);
+};
+
+} // namespace content
+
+#endif // CONTENT_BROWSER_PROCESS_RESOURCE_USAGE_IMPL_H_

Powered by Google App Engine
This is Rietveld 408576698