Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 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 CONTENT_PUBLIC_BROWSER_MEMORY_COORDINATOR_H_ | 5 #ifndef CONTENT_PUBLIC_BROWSER_MEMORY_COORDINATOR_H_ |
| 6 #define CONTENT_PUBLIC_BROWSER_MEMORY_COORDINATOR_H_ | 6 #define CONTENT_PUBLIC_BROWSER_MEMORY_COORDINATOR_H_ |
| 7 | 7 |
| 8 #include "base/memory/memory_coordinator_client.h" | 8 #include "base/memory/memory_coordinator_client.h" |
| 9 #include "base/process/process_handle.h" | 9 #include "base/process/process_handle.h" |
| 10 #include "content/common/content_export.h" | 10 #include "content/common/content_export.h" |
| 11 | 11 |
| 12 namespace content { | 12 namespace content { |
| 13 | 13 |
| 14 // The interface that represents the browser side of MemoryCoordinator. | 14 // The interface that represents the browser side of MemoryCoordinator. |
| 15 // MemoryCoordinator determines memory state of each process (both browser | 15 // MemoryCoordinator determines memory state of each process (both browser |
| 16 // and renderers) and dispatches state change notifications to its clients. | 16 // and renderers) and dispatches state change notifications to its clients. |
| 17 // See comments on MemoryCoordinatorClient for details. | 17 // See comments on MemoryCoordinatorClient for how to use it. |
| 18 // | |
| 19 // Currently we have three ways to control memory components: | |
|
Ryan Sleevi
2017/02/08 15:02:04
Similar to my earlier remarks, the "we" here is am
haraken
2017/02/09 02:37:31
Yeah, the fact that we don't have MemoryCoordinato
| |
| 20 // MemoryCoordinator, MemoryPressureListener and isLowEndDevice. | |
| 21 // | |
| 22 // - MemoryPressureListener provides a way for memory components to listen | |
| 23 // memory-pressure notifications and purge memory when the system is under | |
| 24 // high memory pressure. This is a 'reactive' way to reduce memory | |
| 25 // footprint. | |
| 26 // | |
| 27 // - isLowEndDevice provides a way for memory components to enter a low-memory | |
| 28 // mode on low-memory devices. In the low-memory mode, the memory components | |
| 29 // are exepcted to trade off performance for memory. This is a 'proactive' | |
| 30 // way to reduce memory footprint. | |
| 31 // | |
| 32 // - It is a responsibility of each memory component to decide on which one(s) | |
| 33 // the memory component should use. | |
| 34 // | |
| 35 // - MemoryCoordinator provides both ways. In the future, | |
| 36 // MemoryPressureListener and isLowEndDevice will be unified into | |
| 37 // MemoryCoordinator. | |
| 18 class CONTENT_EXPORT MemoryCoordinator { | 38 class CONTENT_EXPORT MemoryCoordinator { |
| 19 public: | 39 public: |
| 20 virtual ~MemoryCoordinator() {} | 40 virtual ~MemoryCoordinator() {} |
| 21 | 41 |
| 22 static MemoryCoordinator* GetInstance(); | 42 static MemoryCoordinator* GetInstance(); |
| 23 | 43 |
| 24 // Returns the memory state of the given process handle. | 44 // Returns the memory state of the given process handle. |
| 25 virtual base::MemoryState GetStateForProcess(base::ProcessHandle handle) = 0; | 45 virtual base::MemoryState GetStateForProcess(base::ProcessHandle handle) = 0; |
| 26 }; | 46 }; |
| 27 | 47 |
| 28 } // namespace content | 48 } // namespace content |
| 29 | 49 |
| 30 #endif // CONTENT_PUBLIC_BROWSER_MEMORY_COORDINATOR_H_ | 50 #endif // CONTENT_PUBLIC_BROWSER_MEMORY_COORDINATOR_H_ |
| OLD | NEW |