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

Unified Diff: cc/surfaces/surface.cc

Issue 2503203002: Revert "Getting rid of DelegatedFrameData" (Closed)
Patch Set: Created 4 years, 1 month 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 cc3de978b3068df4fee0773f585eec72d766a1ea..6ef97a22c9d5ff9b3407d86e833d9bac13420d3f 100644
--- a/cc/surfaces/surface.cc
+++ b/cc/surfaces/surface.cc
@@ -31,8 +31,8 @@ Surface::Surface(const SurfaceId& id, base::WeakPtr<SurfaceFactory> factory)
Surface::~Surface() {
ClearCopyRequests();
- if (current_frame_ && factory_) {
- UnrefFrameResources(*current_frame_);
+ if (current_frame_.delegated_frame_data && factory_) {
+ UnrefFrameResources(current_frame_.delegated_frame_data.get());
}
if (!draw_callback_.is_null())
draw_callback_.Run();
@@ -48,28 +48,32 @@ void Surface::QueueFrame(CompositorFrame frame, const DrawCallback& callback) {
DCHECK(factory_);
ClearCopyRequests();
- TakeLatencyInfo(&frame.metadata.latency_info);
+ if (frame.delegated_frame_data) {
+ TakeLatencyInfo(&frame.metadata.latency_info);
+ }
- base::Optional<CompositorFrame> previous_frame = std::move(current_frame_);
+ CompositorFrame previous_frame = std::move(current_frame_);
current_frame_ = std::move(frame);
- if (current_frame_) {
- factory_->ReceiveFromChild(current_frame_->resource_list);
+ if (current_frame_.delegated_frame_data) {
+ factory_->ReceiveFromChild(
+ 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_->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;
- new_referenced_surfaces = current_frame_->metadata.referenced_surfaces;
+ new_referenced_surfaces = current_frame_.metadata.referenced_surfaces;
- if (previous_frame)
- UnrefFrameResources(*previous_frame);
+ if (previous_frame.delegated_frame_data)
+ UnrefFrameResources(previous_frame.delegated_frame_data.get());
if (!draw_callback_.is_null())
draw_callback_.Run();
@@ -79,7 +83,7 @@ void Surface::QueueFrame(CompositorFrame frame, const DrawCallback& callback) {
(referenced_surfaces_ != new_referenced_surfaces);
referenced_surfaces_ = new_referenced_surfaces;
std::vector<uint32_t> satisfies_sequences =
- std::move(current_frame_->metadata.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
@@ -92,9 +96,11 @@ void Surface::QueueFrame(CompositorFrame frame, const DrawCallback& callback) {
void Surface::RequestCopyOfOutput(
std::unique_ptr<CopyOutputRequest> copy_request) {
- if (current_frame_ && !current_frame_->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_->render_pass_list.back()->copy_requests;
+ current_frame_.delegated_frame_data->render_pass_list.back()
+ ->copy_requests;
if (void* source = copy_request->source()) {
// Remove existing CopyOutputRequests made on the Surface by the same
@@ -116,8 +122,9 @@ void Surface::TakeCopyOutputRequests(
std::multimap<RenderPassId, std::unique_ptr<CopyOutputRequest>>*
copy_requests) {
DCHECK(copy_requests->empty());
- if (current_frame_) {
- for (const auto& render_pass : current_frame_->render_pass_list) {
+ if (current_frame_.delegated_frame_data) {
+ for (const auto& render_pass :
+ 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)));
@@ -128,21 +135,20 @@ void Surface::TakeCopyOutputRequests(
}
const CompositorFrame& Surface::GetEligibleFrame() {
- DCHECK(current_frame_);
- return current_frame_.value();
+ 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() {
@@ -170,9 +176,9 @@ void Surface::SatisfyDestructionDependencies(
destruction_dependencies_.end());
}
-void Surface::UnrefFrameResources(const CompositorFrame& frame) {
+void Surface::UnrefFrameResources(DelegatedFrameData* frame_data) {
ReturnedResourceArray resources;
- TransferableResource::ReturnResources(frame.resource_list, &resources);
+ TransferableResource::ReturnResources(frame_data->resource_list, &resources);
// No point in returning same sync token to sender.
for (auto& resource : resources)
resource.sync_token.Clear();
@@ -180,8 +186,9 @@ void Surface::UnrefFrameResources(const CompositorFrame& frame) {
}
void Surface::ClearCopyRequests() {
- if (current_frame_) {
- for (const auto& render_pass : current_frame_->render_pass_list) {
+ if (current_frame_.delegated_frame_data) {
+ for (const auto& render_pass :
+ 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