| OLD | NEW |
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #ifndef CHROME_BROWSER_PROCESS_RESOURCE_USAGE_H_ | 5 #ifndef CHROME_BROWSER_PROCESS_RESOURCE_USAGE_H_ |
| 6 #define CHROME_BROWSER_PROCESS_RESOURCE_USAGE_H_ | 6 #define CHROME_BROWSER_PROCESS_RESOURCE_USAGE_H_ |
| 7 | 7 |
| 8 #include <stddef.h> | 8 #include <stddef.h> |
| 9 | 9 |
| 10 #include <deque> | 10 #include <deque> |
| 11 | 11 |
| 12 #include "base/callback.h" | 12 #include "base/callback.h" |
| 13 #include "base/macros.h" | 13 #include "base/macros.h" |
| 14 #include "base/threading/thread_checker.h" | 14 #include "base/threading/thread_checker.h" |
| 15 #include "chrome/common/resource_usage_reporter.mojom.h" | 15 #include "chrome/common/resource_usage_reporter.mojom.h" |
| 16 #include "third_party/WebKit/public/web/WebCache.h" | 16 #include "third_party/WebKit/public/web/WebCache.h" |
| 17 | 17 |
| 18 // Provides resource usage information about a child process. | 18 // Provides resource usage information about a child process. |
| 19 // | 19 // |
| 20 // This is a wrapper around the mojom::ResourceUsageReporter Mojo service that | 20 // This is a wrapper around the chrome::mojom::ResourceUsageReporter Mojo |
| 21 // exposes | 21 // service that exposes |
| 22 // information about resources used by a child process. Currently, this is only | 22 // information about resources used by a child process. Currently, this is only |
| 23 // V8 memory and Blink resource cache usage, but could be expanded to include | 23 // V8 memory and Blink resource cache usage, but could be expanded to include |
| 24 // other resources. This is intended for status viewers such as the task | 24 // other resources. This is intended for status viewers such as the task |
| 25 // manager. | 25 // manager. |
| 26 // | 26 // |
| 27 // To create: | 27 // To create: |
| 28 // 1. Create a mojom::ResourceUsageReporterPtr and obtain an InterfaceRequest<> | 28 // 1. Create a chrome::mojom::ResourceUsageReporterPtr and obtain an |
| 29 // InterfaceRequest<> |
| 29 // using | 30 // using |
| 30 // mojo::GetProxy. | 31 // mojo::GetProxy. |
| 31 // 2. Use the child process's service registry to connect to the service using | 32 // 2. Use the child process's service registry to connect to the service using |
| 32 // the InterfaceRequest<>. Note, ServiceRegistry is thread hostile and | 33 // the InterfaceRequest<>. Note, ServiceRegistry is thread hostile and |
| 33 // must always be accessed from the same thread. However, InterfaceRequest<> | 34 // must always be accessed from the same thread. However, InterfaceRequest<> |
| 34 // can be passed safely between threads, and therefore a task can be posted | 35 // can be passed safely between threads, and therefore a task can be posted |
| 35 // to the ServiceRegistry thread to connect to the remote service. | 36 // to the ServiceRegistry thread to connect to the remote service. |
| 36 // 3. Pass the mojom::ResourceUsageReporterPtr to the constructor. | 37 // 3. Pass the chrome::mojom::ResourceUsageReporterPtr to the constructor. |
| 37 // | 38 // |
| 38 // Example: | 39 // Example: |
| 39 // void Foo::ConnectToService( | 40 // void Foo::ConnectToService( |
| 40 // mojo::InterfaceRequest<mojom::ResourceUsageReporter> req) { | 41 // mojo::InterfaceRequest<chrome::mojom::ResourceUsageReporter> req) { |
| 41 // content::ServiceRegistry* registry = host_->GetServiceRegistry(); | 42 // content::ServiceRegistry* registry = host_->GetServiceRegistry(); |
| 42 // registry->ConnectToRemoteService(std::move(req)); | 43 // registry->ConnectToRemoteService(std::move(req)); |
| 43 // } | 44 // } |
| 44 // | 45 // |
| 45 // ... | 46 // ... |
| 46 // mojom::ResourceUsageReporterPtr service; | 47 // chrome::mojom::ResourceUsageReporterPtr service; |
| 47 // mojo::InterfaceRequest<mojom::ResourceUsageReporter> request = | 48 // mojo::InterfaceRequest<chrome::mojom::ResourceUsageReporter> request = |
| 48 // mojo::GetProxy(&service); | 49 // mojo::GetProxy(&service); |
| 49 // content::BrowserThread::PostTask( | 50 // content::BrowserThread::PostTask( |
| 50 // content::BrowserThread::IO, FROM_HERE, | 51 // content::BrowserThread::IO, FROM_HERE, |
| 51 // base::Bind(&Foo::ConnectToService, this, base::Passed(&request))); | 52 // base::Bind(&Foo::ConnectToService, this, base::Passed(&request))); |
| 52 // resource_usage_.reset(new ProcessResourceUsage(std::move(service))); | 53 // resource_usage_.reset(new ProcessResourceUsage(std::move(service))); |
| 53 // ... | 54 // ... |
| 54 // | 55 // |
| 55 // Note: ProcessResourceUsage is thread-hostile and must live on a single | 56 // Note: ProcessResourceUsage is thread-hostile and must live on a single |
| 56 // thread. | 57 // thread. |
| 57 class ProcessResourceUsage { | 58 class ProcessResourceUsage { |
| 58 public: | 59 public: |
| 59 // Must be called from the same thread that created |service|. | 60 // Must be called from the same thread that created |service|. |
| 60 explicit ProcessResourceUsage(mojom::ResourceUsageReporterPtr service); | 61 explicit ProcessResourceUsage( |
| 62 chrome::mojom::ResourceUsageReporterPtr service); |
| 61 ~ProcessResourceUsage(); | 63 ~ProcessResourceUsage(); |
| 62 | 64 |
| 63 // Refresh the resource usage information. |callback| is invoked when the | 65 // Refresh the resource usage information. |callback| is invoked when the |
| 64 // usage data is updated, or when the IPC connection is lost. | 66 // usage data is updated, or when the IPC connection is lost. |
| 65 void Refresh(const base::Closure& callback); | 67 void Refresh(const base::Closure& callback); |
| 66 | 68 |
| 67 // Get V8 memory usage information. | 69 // Get V8 memory usage information. |
| 68 bool ReportsV8MemoryStats() const; | 70 bool ReportsV8MemoryStats() const; |
| 69 size_t GetV8MemoryAllocated() const; | 71 size_t GetV8MemoryAllocated() const; |
| 70 size_t GetV8MemoryUsed() const; | 72 size_t GetV8MemoryUsed() const; |
| 71 | 73 |
| 72 // Get Blink resource cache information. | 74 // Get Blink resource cache information. |
| 73 blink::WebCache::ResourceTypeStats GetWebCoreCacheStats() const; | 75 blink::WebCache::ResourceTypeStats GetWebCoreCacheStats() const; |
| 74 | 76 |
| 75 private: | 77 private: |
| 76 // Mojo IPC callback. | 78 // Mojo IPC callback. |
| 77 void OnRefreshDone(mojom::ResourceUsageDataPtr data); | 79 void OnRefreshDone(chrome::mojom::ResourceUsageDataPtr data); |
| 78 | 80 |
| 79 void RunPendingRefreshCallbacks(); | 81 void RunPendingRefreshCallbacks(); |
| 80 | 82 |
| 81 mojom::ResourceUsageReporterPtr service_; | 83 chrome::mojom::ResourceUsageReporterPtr service_; |
| 82 bool update_in_progress_; | 84 bool update_in_progress_; |
| 83 std::deque<base::Closure> refresh_callbacks_; | 85 std::deque<base::Closure> refresh_callbacks_; |
| 84 | 86 |
| 85 mojom::ResourceUsageDataPtr stats_; | 87 chrome::mojom::ResourceUsageDataPtr stats_; |
| 86 | 88 |
| 87 base::ThreadChecker thread_checker_; | 89 base::ThreadChecker thread_checker_; |
| 88 | 90 |
| 89 DISALLOW_COPY_AND_ASSIGN(ProcessResourceUsage); | 91 DISALLOW_COPY_AND_ASSIGN(ProcessResourceUsage); |
| 90 }; | 92 }; |
| 91 | 93 |
| 92 #endif // CHROME_BROWSER_PROCESS_RESOURCE_USAGE_H_ | 94 #endif // CHROME_BROWSER_PROCESS_RESOURCE_USAGE_H_ |
| OLD | NEW |