| Index: cc/resources/picture_layer_tiling.h
 | 
| diff --git a/cc/resources/picture_layer_tiling.h b/cc/resources/picture_layer_tiling.h
 | 
| index daa04851d9c22f8759e283d5fd0d9d048b3f22bb..4b80aa047516dabfdd82f02af782b9201782f28f 100644
 | 
| --- a/cc/resources/picture_layer_tiling.h
 | 
| +++ b/cc/resources/picture_layer_tiling.h
 | 
| @@ -48,9 +48,6 @@ class CC_EXPORT PictureLayerTilingClient {
 | 
|    virtual PictureLayerTiling* GetRecycledTwinTiling(
 | 
|        const PictureLayerTiling* tiling) = 0;
 | 
|    virtual TilePriority::PriorityBin GetMaxTilePriorityBin() const = 0;
 | 
| -  virtual size_t GetMaxTilesForInterestArea() const = 0;
 | 
| -  virtual float GetSkewportTargetTimeInSeconds() const = 0;
 | 
| -  virtual int GetSkewportExtrapolationLimitInContentPixels() const = 0;
 | 
|    virtual WhichTree GetTree() const = 0;
 | 
|    virtual bool RequiresHighResToDraw() const = 0;
 | 
|  
 | 
| @@ -62,15 +59,6 @@ class CC_EXPORT PictureLayerTiling {
 | 
|   public:
 | 
|    static const int kBorderTexels = 1;
 | 
|  
 | 
| -  enum EvictionCategory {
 | 
| -    EVENTUALLY,
 | 
| -    EVENTUALLY_AND_REQUIRED_FOR_ACTIVATION,
 | 
| -    SOON,
 | 
| -    SOON_AND_REQUIRED_FOR_ACTIVATION,
 | 
| -    NOW,
 | 
| -    NOW_AND_REQUIRED_FOR_ACTIVATION
 | 
| -  };
 | 
| -
 | 
|    class CC_EXPORT TilingRasterTileIterator {
 | 
|     public:
 | 
|      TilingRasterTileIterator();
 | 
| @@ -121,18 +109,24 @@ class CC_EXPORT PictureLayerTiling {
 | 
|    ~PictureLayerTiling();
 | 
|  
 | 
|    // Create a tiling with no tiles.  CreateTiles must be called to add some.
 | 
| +  // TODO(danakj): Pass the raster_source here instead of the size, store the
 | 
| +  // raster source instead of layer bounds?
 | 
|    static scoped_ptr<PictureLayerTiling> Create(
 | 
|        float contents_scale,
 | 
|        const gfx::Size& layer_bounds,
 | 
| -      PictureLayerTilingClient* client);
 | 
| +      PictureLayerTilingClient* client,
 | 
| +      size_t max_tiles_for_interest_area,
 | 
| +      float skewport_target_time_in_seconds,
 | 
| +      int skewport_extrapolation_limit_in_content_pixels);
 | 
| +
 | 
|    gfx::Size layer_bounds() const { return layer_bounds_; }
 | 
| -  void UpdateTilesToCurrentRasterSource(RasterSource* raster_source,
 | 
| -                                        const Region& layer_invalidation,
 | 
| -                                        const gfx::Size& new_layer_bounds);
 | 
| +  void Resize(const gfx::Size& new_layer_bounds);
 | 
| +  void Invalidate(const Region& layer_invalidation);
 | 
| +  void SetRasterSource(scoped_refptr<RasterSource> raster_source);
 | 
|    void CreateMissingTilesInLiveTilesRect();
 | 
| -  void RemoveTilesInRegion(const Region& layer_region);
 | 
|  
 | 
| -  void SetClient(PictureLayerTilingClient* client);
 | 
| +  void CloneTilesAndPropertiesFrom(const PictureLayerTiling& twin_tiling);
 | 
| +
 | 
|    void set_resolution(TileResolution resolution) { resolution_ = resolution; }
 | 
|    TileResolution resolution() const { return resolution_; }
 | 
|    void set_can_require_tiles_for_activation(bool can_require_tiles) {
 | 
| @@ -288,10 +282,16 @@ class CC_EXPORT PictureLayerTiling {
 | 
|  
 | 
|    PictureLayerTiling(float contents_scale,
 | 
|                       const gfx::Size& layer_bounds,
 | 
| -                     PictureLayerTilingClient* client);
 | 
| +                     PictureLayerTilingClient* client,
 | 
| +                     size_t max_tiles_for_interest_area,
 | 
| +                     float skewport_target_time_in_seconds,
 | 
| +                     int skewport_extrapolation_limit_in_content_pixels);
 | 
|    void SetLiveTilesRect(const gfx::Rect& live_tiles_rect);
 | 
| -  void VerifyLiveTilesRect();
 | 
| -  Tile* CreateTile(int i, int j, const PictureLayerTiling* twin_tiling);
 | 
| +  void VerifyLiveTilesRect(bool is_on_recycle_tree) const;
 | 
| +  Tile* CreateTile(int i,
 | 
| +                   int j,
 | 
| +                   const PictureLayerTiling* twin_tiling,
 | 
| +                   PictureLayerTiling* recycled_twin);
 | 
|    // Returns true if the Tile existed and was removed from the tiling.
 | 
|    bool RemoveTileAt(int i, int j, PictureLayerTiling* recycled_twin);
 | 
|  
 | 
| @@ -303,18 +303,21 @@ class CC_EXPORT PictureLayerTiling {
 | 
|                              const gfx::Rect& visible_rect_in_content_space)
 | 
|        const;
 | 
|  
 | 
| -  void UpdateEvictionCacheIfNeeded(TreePriority tree_priority);
 | 
| -  const std::vector<Tile*>* GetEvictionTiles(TreePriority tree_priority,
 | 
| -                                             EvictionCategory category);
 | 
| -
 | 
| -  void Invalidate(const Region& layer_region);
 | 
| -
 | 
| -  void DoInvalidate(const Region& layer_region,
 | 
| -                    bool recreate_invalidated_tiles);
 | 
| +  // Save the required data for computing tile priorities later.
 | 
| +  void UpdateTilePriorityRects(float content_to_screen_scale_,
 | 
| +                               const gfx::Rect& visible_rect_in_content_space,
 | 
| +                               const gfx::Rect& skewport,
 | 
| +                               const gfx::Rect& soon_border_rect,
 | 
| +                               const gfx::Rect& eventually_rect,
 | 
| +                               const Occlusion& occlusion_in_layer_space);
 | 
|  
 | 
|    void UpdateTileAndTwinPriority(Tile* tile) const;
 | 
|    void UpdateTilePriority(Tile* tile) const;
 | 
|  
 | 
| +  const size_t max_tiles_for_interest_area_;
 | 
| +  const float skewport_target_time_in_seconds_;
 | 
| +  const int skewport_extrapolation_limit_in_content_pixels_;
 | 
| +
 | 
|    // Given properties.
 | 
|    float contents_scale_;
 | 
|    gfx::Size layer_bounds_;
 | 
| @@ -330,36 +333,23 @@ class CC_EXPORT PictureLayerTiling {
 | 
|    double last_impl_frame_time_in_seconds_;
 | 
|    gfx::Rect last_viewport_in_layer_space_;
 | 
|    gfx::Rect last_visible_rect_in_content_space_;
 | 
| -  float content_to_screen_scale_;
 | 
|  
 | 
|    bool can_require_tiles_for_activation_;
 | 
|  
 | 
| -  // Iteration rects in content space
 | 
| +  // Iteration rects in content space.
 | 
|    gfx::Rect current_visible_rect_;
 | 
|    gfx::Rect current_skewport_rect_;
 | 
|    gfx::Rect current_soon_border_rect_;
 | 
|    gfx::Rect current_eventually_rect_;
 | 
| +  // Other properties used for tile iteration and prioritization.
 | 
| +  float current_content_to_screen_scale_;
 | 
| +  Occlusion current_occlusion_in_layer_space_;
 | 
|  
 | 
|    bool has_visible_rect_tiles_;
 | 
|    bool has_skewport_rect_tiles_;
 | 
|    bool has_soon_border_rect_tiles_;
 | 
|    bool has_eventually_rect_tiles_;
 | 
|  
 | 
| -  Occlusion current_occlusion_in_layer_space_;
 | 
| -
 | 
| -  // TODO(reveman): Remove this in favour of an array of eviction_tiles_ when we
 | 
| -  // change all enums to have a consistent way of getting the count/last
 | 
| -  // element.
 | 
| -  std::vector<Tile*> eviction_tiles_now_;
 | 
| -  std::vector<Tile*> eviction_tiles_now_and_required_for_activation_;
 | 
| -  std::vector<Tile*> eviction_tiles_soon_;
 | 
| -  std::vector<Tile*> eviction_tiles_soon_and_required_for_activation_;
 | 
| -  std::vector<Tile*> eviction_tiles_eventually_;
 | 
| -  std::vector<Tile*> eviction_tiles_eventually_and_required_for_activation_;
 | 
| -
 | 
| -  bool eviction_tiles_cache_valid_;
 | 
| -  TreePriority eviction_cache_tree_priority_;
 | 
| -
 | 
|   private:
 | 
|    DISALLOW_ASSIGN(PictureLayerTiling);
 | 
|  
 | 
| 
 |