OLD | NEW |
1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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 "cc/surfaces/display_scheduler.h" | 5 #include "cc/surfaces/display_scheduler.h" |
6 | 6 |
7 #include <vector> | 7 #include <vector> |
8 | 8 |
9 #include "base/auto_reset.h" | 9 #include "base/auto_reset.h" |
10 #include "base/stl_util.h" | 10 #include "base/stl_util.h" |
(...skipping 346 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
357 | 357 |
358 void DisplayScheduler::OnBeginFrameDeadline() { | 358 void DisplayScheduler::OnBeginFrameDeadline() { |
359 TRACE_EVENT0("cc", "DisplayScheduler::OnBeginFrameDeadline"); | 359 TRACE_EVENT0("cc", "DisplayScheduler::OnBeginFrameDeadline"); |
360 DCHECK(inside_begin_frame_deadline_interval_); | 360 DCHECK(inside_begin_frame_deadline_interval_); |
361 | 361 |
362 bool did_draw = AttemptDrawAndSwap(); | 362 bool did_draw = AttemptDrawAndSwap(); |
363 DidFinishFrame(did_draw); | 363 DidFinishFrame(did_draw); |
364 } | 364 } |
365 | 365 |
366 void DisplayScheduler::DidFinishFrame(bool did_draw) { | 366 void DisplayScheduler::DidFinishFrame(bool did_draw) { |
367 // TODO(eseckler): Determine and set correct |ack.latest_confirmed_frame|. | 367 DCHECK(begin_frame_source_); |
368 BeginFrameAck ack(current_begin_frame_args_.source_id, | 368 // TODO(eseckler): Let client know that frame was completed. |
369 current_begin_frame_args_.sequence_number, | 369 begin_frame_source_->DidFinishFrame(this); |
370 current_begin_frame_args_.sequence_number, did_draw); | |
371 begin_frame_source_->DidFinishFrame(this, ack); | |
372 } | 370 } |
373 | 371 |
374 void DisplayScheduler::DidSwapBuffers() { | 372 void DisplayScheduler::DidSwapBuffers() { |
375 pending_swaps_++; | 373 pending_swaps_++; |
376 uint32_t swap_id = next_swap_id_++; | 374 uint32_t swap_id = next_swap_id_++; |
377 TRACE_EVENT_ASYNC_BEGIN0("cc", "DisplayScheduler:pending_swaps", swap_id); | 375 TRACE_EVENT_ASYNC_BEGIN0("cc", "DisplayScheduler:pending_swaps", swap_id); |
378 } | 376 } |
379 | 377 |
380 void DisplayScheduler::DidReceiveSwapBuffersAck() { | 378 void DisplayScheduler::DidReceiveSwapBuffersAck() { |
381 uint32_t swap_id = next_swap_id_ - pending_swaps_; | 379 uint32_t swap_id = next_swap_id_ - pending_swaps_; |
382 pending_swaps_--; | 380 pending_swaps_--; |
383 TRACE_EVENT_ASYNC_END0("cc", "DisplayScheduler:pending_swaps", swap_id); | 381 TRACE_EVENT_ASYNC_END0("cc", "DisplayScheduler:pending_swaps", swap_id); |
384 ScheduleBeginFrameDeadline(); | 382 ScheduleBeginFrameDeadline(); |
385 } | 383 } |
386 | 384 |
387 } // namespace cc | 385 } // namespace cc |
OLD | NEW |