Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(4821)

Unified Diff: cc/surfaces/surface.cc

Issue 2098953003: Make cc::CompositorFrames movable [Part 2 of 2] (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Fixed exo unittests Created 4 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « cc/surfaces/surface.h ('k') | cc/surfaces/surface_aggregator.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: cc/surfaces/surface.cc
diff --git a/cc/surfaces/surface.cc b/cc/surfaces/surface.cc
index ed99a1b018b0d061746f520227ad76db349a534e..706b6738fe8b7caa04b06d035f3ea8c5470590c3 100644
--- a/cc/surfaces/surface.cc
+++ b/cc/surfaces/surface.cc
@@ -31,8 +31,8 @@ Surface::Surface(SurfaceId id, SurfaceFactory* factory)
Surface::~Surface() {
ClearCopyRequests();
- if (current_frame_ && factory_) {
- UnrefFrameResources(current_frame_->delegated_frame_data.get());
+ if (current_frame_.delegated_frame_data && factory_) {
+ UnrefFrameResources(current_frame_.delegated_frame_data.get());
}
if (!draw_callback_.is_null())
draw_callback_.Run(SurfaceDrawStatus::DRAW_SKIPPED);
@@ -51,39 +51,37 @@ void Surface::SetGpuMemoryBufferClientId(int gpu_memory_buffer_client_id) {
gpu_memory_buffer_client_id_ = gpu_memory_buffer_client_id;
}
-void Surface::QueueFrame(std::unique_ptr<CompositorFrame> frame,
- const DrawCallback& callback) {
+void Surface::QueueFrame(CompositorFrame frame, const DrawCallback& callback) {
DCHECK(factory_);
ClearCopyRequests();
- if (frame) {
- TakeLatencyInfo(&frame->metadata.latency_info);
+ if (frame.delegated_frame_data) {
+ TakeLatencyInfo(&frame.metadata.latency_info);
}
- std::unique_ptr<CompositorFrame> previous_frame = std::move(current_frame_);
+ CompositorFrame previous_frame = std::move(current_frame_);
current_frame_ = std::move(frame);
- if (current_frame_) {
+ if (current_frame_.delegated_frame_data) {
factory_->ReceiveFromChild(
- current_frame_->delegated_frame_data->resource_list);
+ current_frame_.delegated_frame_data->resource_list);
}
// Empty frames shouldn't be drawn and shouldn't contribute damage, so don't
// increment frame index for them.
- if (current_frame_ &&
- !current_frame_->delegated_frame_data->render_pass_list.empty())
+ if (current_frame_.delegated_frame_data &&
+ !current_frame_.delegated_frame_data->render_pass_list.empty()) {
++frame_index_;
+ }
previous_frame_surface_id_ = surface_id();
std::vector<SurfaceId> new_referenced_surfaces;
- if (current_frame_) {
- new_referenced_surfaces = current_frame_->metadata.referenced_surfaces;
- }
+ new_referenced_surfaces = current_frame_.metadata.referenced_surfaces;
+
+ if (previous_frame.delegated_frame_data)
+ UnrefFrameResources(previous_frame.delegated_frame_data.get());
- if (previous_frame) {
- UnrefFrameResources(previous_frame->delegated_frame_data.get());
- }
if (!draw_callback_.is_null())
draw_callback_.Run(SurfaceDrawStatus::DRAW_SKIPPED);
draw_callback_ = callback;
@@ -91,9 +89,9 @@ void Surface::QueueFrame(std::unique_ptr<CompositorFrame> frame,
bool referenced_surfaces_changed =
(referenced_surfaces_ != new_referenced_surfaces);
referenced_surfaces_ = new_referenced_surfaces;
- std::vector<uint32_t> satisfies_sequences;
- if (current_frame_)
- current_frame_->metadata.satisfies_sequences.swap(satisfies_sequences);
+ std::vector<uint32_t> satisfies_sequences =
+ std::move(current_frame_.metadata.satisfies_sequences);
+
if (referenced_surfaces_changed || !satisfies_sequences.empty()) {
// Notify the manager that sequences were satisfied either if some new
// sequences were satisfied, or if the set of referenced surfaces changed
@@ -105,10 +103,10 @@ void Surface::QueueFrame(std::unique_ptr<CompositorFrame> frame,
void Surface::RequestCopyOfOutput(
std::unique_ptr<CopyOutputRequest> copy_request) {
- if (current_frame_ &&
- !current_frame_->delegated_frame_data->render_pass_list.empty()) {
+ if (current_frame_.delegated_frame_data &&
+ !current_frame_.delegated_frame_data->render_pass_list.empty()) {
std::vector<std::unique_ptr<CopyOutputRequest>>& copy_requests =
- current_frame_->delegated_frame_data->render_pass_list.back()
+ current_frame_.delegated_frame_data->render_pass_list.back()
->copy_requests;
if (void* source = copy_request->source()) {
@@ -131,9 +129,9 @@ void Surface::TakeCopyOutputRequests(
std::multimap<RenderPassId, std::unique_ptr<CopyOutputRequest>>*
copy_requests) {
DCHECK(copy_requests->empty());
- if (current_frame_) {
+ if (current_frame_.delegated_frame_data) {
for (const auto& render_pass :
- current_frame_->delegated_frame_data->render_pass_list) {
+ current_frame_.delegated_frame_data->render_pass_list) {
for (auto& request : render_pass->copy_requests) {
copy_requests->insert(
std::make_pair(render_pass->id, std::move(request)));
@@ -143,21 +141,21 @@ void Surface::TakeCopyOutputRequests(
}
}
-const CompositorFrame* Surface::GetEligibleFrame() {
- return current_frame_.get();
+const CompositorFrame& Surface::GetEligibleFrame() {
+ return current_frame_;
}
void Surface::TakeLatencyInfo(std::vector<ui::LatencyInfo>* latency_info) {
- if (!current_frame_)
+ if (!current_frame_.delegated_frame_data)
return;
if (latency_info->empty()) {
- current_frame_->metadata.latency_info.swap(*latency_info);
+ current_frame_.metadata.latency_info.swap(*latency_info);
return;
}
- std::copy(current_frame_->metadata.latency_info.begin(),
- current_frame_->metadata.latency_info.end(),
+ std::copy(current_frame_.metadata.latency_info.begin(),
+ current_frame_.metadata.latency_info.end(),
std::back_inserter(*latency_info));
- current_frame_->metadata.latency_info.clear();
+ current_frame_.metadata.latency_info.clear();
}
void Surface::RunDrawCallbacks(SurfaceDrawStatus drawn) {
@@ -195,9 +193,9 @@ void Surface::UnrefFrameResources(DelegatedFrameData* frame_data) {
}
void Surface::ClearCopyRequests() {
- if (current_frame_) {
+ if (current_frame_.delegated_frame_data) {
for (const auto& render_pass :
- current_frame_->delegated_frame_data->render_pass_list) {
+ current_frame_.delegated_frame_data->render_pass_list) {
for (const auto& copy_request : render_pass->copy_requests)
copy_request->SendEmptyResult();
}
« no previous file with comments | « cc/surfaces/surface.h ('k') | cc/surfaces/surface_aggregator.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698