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.
5 #ifndef ANDROID_WEBVIEW_BROWSER_GLOBAL_TILE_MANAGER_H_
6 #define ANDROID_WEBVIEW_BROWSER_GLOBAL_TILE_MANAGER_H_
9 #include "base/basictypes.h"
10 #include "base/lazy_instance.h"
11 #include "base/sequence_checker.h"
12 #include "base/synchronization/lock.h"
14 namespace android_webview
{
16 class GlobalTileManagerClient
;
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
{
26 typedef std::list
<GlobalTileManagerClient
*> ListType
;
29 typedef ListType::iterator Key
;
30 static GlobalTileManager
* GetInstance();
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. If the number of tiles left is not
35 // enough to satisfy the request, the manager will evict tiles allocated to
37 void RequestTiles(size_t new_num_of_tiles
, Key key
);
39 Key
PushBack(GlobalTileManagerClient
* client
);
41 // |key| must be already in manager. Move the tile manager client
42 // corresponding to |key| to most recent. This function should be called after
49 friend struct base::DefaultLazyInstanceTraits
<GlobalTileManager
>;
53 // Continues evicting the inactive views until freeing up at least amount of
54 // tiles specified by |desired_num_tiles| to draw a view specified by |key|,
55 // or until all inactive views have been evicted. Returns the amount of
56 // memory that was actually evicted. This function is called when a
57 // request cannot be satisfied.
58 size_t Evict(size_t desired_num_tiles
, Key key
);
60 // Check that the sum of all client's tiles is equal to
61 // total_allocated_tiles_.
62 bool IsConsistent() const;
64 size_t total_allocated_tiles_
;
66 base::SequenceChecker sequence_checker_
;
68 DISALLOW_COPY_AND_ASSIGN(GlobalTileManager
);
71 } // namespace android_webview
73 #endif // ANDROID_WEBVIEW_BROWSER_GLOBAL_TILE_MANAGER_H_