OLD | NEW |
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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 #include "content/browser/renderer_host/software_frame_manager.h" | 5 #include "content/browser/renderer_host/software_frame_manager.h" |
6 | 6 |
7 #include "base/bind.h" | 7 #include "base/bind.h" |
8 #include "base/callback_helpers.h" | 8 #include "base/callback_helpers.h" |
9 #include "base/sys_info.h" | |
10 #include "content/browser/renderer_host/dip_util.h" | 9 #include "content/browser/renderer_host/dip_util.h" |
11 #include "content/public/browser/user_metrics.h" | 10 #include "content/public/browser/user_metrics.h" |
12 | 11 |
13 namespace { | 12 namespace { |
14 | 13 |
15 void ReleaseMailbox(scoped_refptr<content::SoftwareFrame> frame, | 14 void ReleaseMailbox(scoped_refptr<content::SoftwareFrame> frame, |
16 unsigned sync_point, | 15 unsigned sync_point, |
17 bool lost_resource) {} | 16 bool lost_resource) {} |
18 | 17 |
19 } // namespace | 18 } // namespace |
(...skipping 113 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
133 } | 132 } |
134 | 133 |
135 bool SoftwareFrameManager::HasCurrentFrame() const { | 134 bool SoftwareFrameManager::HasCurrentFrame() const { |
136 return current_frame_.get() ? true : false; | 135 return current_frame_.get() ? true : false; |
137 } | 136 } |
138 | 137 |
139 void SoftwareFrameManager::DiscardCurrentFrame() { | 138 void SoftwareFrameManager::DiscardCurrentFrame() { |
140 if (!HasCurrentFrame()) | 139 if (!HasCurrentFrame()) |
141 return; | 140 return; |
142 current_frame_ = NULL; | 141 current_frame_ = NULL; |
143 SoftwareFrameMemoryManager::GetInstance()->RemoveFrame(this); | 142 RendererFrameManager::GetInstance()->RemoveFrame(this); |
144 } | 143 } |
145 | 144 |
146 void SoftwareFrameManager::SwapToNewFrameComplete(bool visible) { | 145 void SoftwareFrameManager::SwapToNewFrameComplete(bool visible) { |
147 DCHECK(HasCurrentFrame()); | 146 DCHECK(HasCurrentFrame()); |
148 SoftwareFrameMemoryManager::GetInstance()->AddFrame(this, visible); | 147 RendererFrameManager::GetInstance()->AddFrame(this, visible); |
149 } | 148 } |
150 | 149 |
151 void SoftwareFrameManager::SetVisibility(bool visible) { | 150 void SoftwareFrameManager::SetVisibility(bool visible) { |
152 if (HasCurrentFrame()) { | 151 if (HasCurrentFrame()) { |
153 SoftwareFrameMemoryManager::GetInstance()->SetFrameVisibility(this, | 152 RendererFrameManager::GetInstance()->SetFrameVisibility(this, visible); |
154 visible); | |
155 } | 153 } |
156 } | 154 } |
157 | 155 |
158 void SoftwareFrameManager::GetCurrentFrameMailbox( | 156 void SoftwareFrameManager::GetCurrentFrameMailbox( |
159 cc::TextureMailbox* mailbox, | 157 cc::TextureMailbox* mailbox, |
160 scoped_ptr<cc::SingleReleaseCallback>* callback) { | 158 scoped_ptr<cc::SingleReleaseCallback>* callback) { |
161 DCHECK(HasCurrentFrame()); | 159 DCHECK(HasCurrentFrame()); |
162 *mailbox = cc::TextureMailbox( | 160 *mailbox = cc::TextureMailbox( |
163 current_frame_->shared_memory_.get(), current_frame_->frame_size_pixels_); | 161 current_frame_->shared_memory_.get(), current_frame_->frame_size_pixels_); |
164 *callback = cc::SingleReleaseCallback::Create( | 162 *callback = cc::SingleReleaseCallback::Create( |
(...skipping 17 matching lines...) Expand all Loading... |
182 return current_frame_->frame_size_dip_; | 180 return current_frame_->frame_size_dip_; |
183 } | 181 } |
184 | 182 |
185 void SoftwareFrameManager::EvictCurrentFrame() { | 183 void SoftwareFrameManager::EvictCurrentFrame() { |
186 DCHECK(HasCurrentFrame()); | 184 DCHECK(HasCurrentFrame()); |
187 DiscardCurrentFrame(); | 185 DiscardCurrentFrame(); |
188 if (client_) | 186 if (client_) |
189 client_->ReleaseReferencesToSoftwareFrame(); | 187 client_->ReleaseReferencesToSoftwareFrame(); |
190 } | 188 } |
191 | 189 |
192 //////////////////////////////////////////////////////////////////////////////// | |
193 // SoftwareFrameMemoryManager | |
194 | |
195 SoftwareFrameMemoryManager* SoftwareFrameMemoryManager::GetInstance() { | |
196 return Singleton<SoftwareFrameMemoryManager>::get(); | |
197 } | |
198 | |
199 void SoftwareFrameMemoryManager::AddFrame(SoftwareFrameManager* frame, | |
200 bool visible) { | |
201 RemoveFrame(frame); | |
202 if (visible) | |
203 visible_frames_.insert(frame); | |
204 else | |
205 hidden_frames_.push_front(frame); | |
206 CullHiddenFrames(); | |
207 } | |
208 | |
209 void SoftwareFrameMemoryManager::RemoveFrame(SoftwareFrameManager* frame) { | |
210 visible_frames_.erase(frame); | |
211 hidden_frames_.remove(frame); | |
212 } | |
213 | |
214 void SoftwareFrameMemoryManager::SetFrameVisibility(SoftwareFrameManager* frame, | |
215 bool visible) { | |
216 if (visible) { | |
217 hidden_frames_.remove(frame); | |
218 visible_frames_.insert(frame); | |
219 } else { | |
220 visible_frames_.erase(frame); | |
221 hidden_frames_.push_front(frame); | |
222 CullHiddenFrames(); | |
223 } | |
224 } | |
225 | |
226 SoftwareFrameMemoryManager::SoftwareFrameMemoryManager() | |
227 : max_number_of_saved_frames_( | |
228 std::min(5, 2 + (base::SysInfo::AmountOfPhysicalMemoryMB() / 256))) {} | |
229 | |
230 SoftwareFrameMemoryManager::~SoftwareFrameMemoryManager() {} | |
231 | |
232 void SoftwareFrameMemoryManager::CullHiddenFrames() { | |
233 while (!hidden_frames_.empty() && | |
234 hidden_frames_.size() + visible_frames_.size() > | |
235 max_number_of_saved_frames()) { | |
236 size_t old_size = hidden_frames_.size(); | |
237 // Should remove self from list. | |
238 hidden_frames_.back()->EvictCurrentFrame(); | |
239 DCHECK_EQ(hidden_frames_.size() + 1, old_size); | |
240 } | |
241 } | |
242 | |
243 } // namespace content | 190 } // namespace content |
OLD | NEW |