OLD | NEW |
(Empty) | |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. |
| 4 |
| 5 #ifndef ANDROID_WEBVIEW_BROWSER_GLOBAL_TILE_MANAGER_H_ |
| 6 #define ANDROID_WEBVIEW_BROWSER_GLOBAL_TILE_MANAGER_H_ |
| 7 |
| 8 #include <list> |
| 9 #include "base/basictypes.h" |
| 10 #include "base/lazy_instance.h" |
| 11 #include "base/sequence_checker.h" |
| 12 #include "base/synchronization/lock.h" |
| 13 |
| 14 namespace android_webview { |
| 15 |
| 16 class GlobalTileManagerClient; |
| 17 |
| 18 // A global tile manager that keeps track of the number of tile resources. Each |
| 19 // tile needs file descriptors (typically 2) and there is a soft limit of 1024 |
| 20 // file descriptors per Android process. The GlobalTileManager does not keep |
| 21 // track of how many tiles each individual view is actually using. The purpose |
| 22 // of GlobalTileManager is to behave gracefully (as in not crashing) when the |
| 23 // embedder of webview creates a lot of webviews and draw them at the same time. |
| 24 class GlobalTileManager { |
| 25 private: |
| 26 typedef std::list<GlobalTileManagerClient*> ListType; |
| 27 |
| 28 public: |
| 29 typedef ListType::iterator Key; |
| 30 static GlobalTileManager* GetInstance(); |
| 31 |
| 32 // Requests the |num_of_tiles| from the available global pool. Calls |
| 33 // GlobalTileManagerClient.SetNumTiles after the manager determines how many |
| 34 // tiles are available for the client. The tile policy on the clients are not |
| 35 // immediately enforced, unless |effective_immediately| is true. If the |
| 36 // number of tiles left are not enough to satisfy the request, the manager |
| 37 // will evict tiles allocated to other clients. |
| 38 void RequestTiles(size_t new_num_of_tiles, Key key); |
| 39 |
| 40 Key PushBack(GlobalTileManagerClient* client); |
| 41 |
| 42 // |key| must be already in manager. Move the tile manager client |
| 43 // corresponding to |key| to most recent. This function should be called after |
| 44 // RequestTiles. |
| 45 void DidUse(Key key); |
| 46 |
| 47 void Remove(Key key); |
| 48 |
| 49 private: |
| 50 friend struct base::DefaultLazyInstanceTraits<GlobalTileManager>; |
| 51 GlobalTileManager(); |
| 52 ~GlobalTileManager(); |
| 53 |
| 54 // Continues evicting the inactive views until freeing up at least amount of |
| 55 // tiles specified by |desired_num_tiles| to draw a view specified by |key|, |
| 56 // or until all inactive views have been evicted. Returns the amount of |
| 57 // memory that was actually evicted. This function is called when a |
| 58 // request cannot be satisfied. |
| 59 size_t Evict(size_t desired_num_tiles, Key key); |
| 60 |
| 61 // Check that the sum of all client's tiles is equal to |
| 62 // total_allocated_tiles_. |
| 63 bool IsConsistent() const; |
| 64 |
| 65 size_t total_allocated_tiles_; |
| 66 ListType mru_list_; |
| 67 base::SequenceChecker sequence_checker_; |
| 68 |
| 69 DISALLOW_COPY_AND_ASSIGN(GlobalTileManager); |
| 70 }; |
| 71 |
| 72 } // namespace android_webview |
| 73 |
| 74 #endif // ANDROID_WEBVIEW_BROWSER_GLOBAL_TILE_MANAGER_H_ |
OLD | NEW |