OLD | NEW |
---|---|
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 "ui/ozone/platform/dri/gbm_surfaceless.h" | 5 #include "ui/ozone/platform/dri/gbm_surfaceless.h" |
6 | 6 |
7 #include "base/bind.h" | |
8 #include "base/bind_helpers.h" | |
7 #include "ui/ozone/platform/dri/dri_vsync_provider.h" | 9 #include "ui/ozone/platform/dri/dri_vsync_provider.h" |
8 #include "ui/ozone/platform/dri/dri_window_delegate.h" | 10 #include "ui/ozone/platform/dri/dri_window_delegate.h" |
9 #include "ui/ozone/platform/dri/gbm_buffer.h" | 11 #include "ui/ozone/platform/dri/gbm_buffer.h" |
10 #include "ui/ozone/platform/dri/hardware_display_controller.h" | 12 #include "ui/ozone/platform/dri/hardware_display_controller.h" |
11 | 13 |
12 namespace ui { | 14 namespace ui { |
13 | 15 |
14 GbmSurfaceless::GbmSurfaceless(DriWindowDelegate* window_delegate) | 16 GbmSurfaceless::GbmSurfaceless(DriWindowDelegate* window_delegate) |
15 : window_delegate_(window_delegate) { | 17 : window_delegate_(window_delegate) { |
16 } | 18 } |
17 | 19 |
18 GbmSurfaceless::~GbmSurfaceless() {} | 20 GbmSurfaceless::~GbmSurfaceless() {} |
19 | 21 |
20 intptr_t GbmSurfaceless::GetNativeWindow() { | 22 intptr_t GbmSurfaceless::GetNativeWindow() { |
21 NOTREACHED(); | 23 NOTREACHED(); |
22 return 0; | 24 return 0; |
23 } | 25 } |
24 | 26 |
25 bool GbmSurfaceless::ResizeNativeWindow(const gfx::Size& viewport_size) { | 27 bool GbmSurfaceless::ResizeNativeWindow(const gfx::Size& viewport_size) { |
26 return true; | 28 return true; |
27 } | 29 } |
28 | 30 |
29 bool GbmSurfaceless::OnSwapBuffers() { | 31 bool GbmSurfaceless::OnSwapBuffers() { |
30 NOTREACHED(); | 32 HardwareDisplayController* controller = window_delegate_->GetController(); |
31 return false; | 33 if (!controller) |
34 return true; | |
35 | |
36 return controller->SchedulePageFlip(true, base::Bind(&base::DoNothing))); | |
dnicoara
2015/02/26 22:16:29
nit: Would you mind adding "true /* is_sync */," h
llandwerlin-old
2015/02/27 10:56:47
Done.
| |
32 } | 37 } |
33 | 38 |
34 bool GbmSurfaceless::OnSwapBuffersAsync( | 39 bool GbmSurfaceless::OnSwapBuffersAsync( |
35 const SwapCompletionCallback& callback) { | 40 const SwapCompletionCallback& callback) { |
36 HardwareDisplayController* controller = window_delegate_->GetController(); | 41 HardwareDisplayController* controller = window_delegate_->GetController(); |
37 if (!controller) { | 42 if (!controller) { |
38 callback.Run(); | 43 callback.Run(); |
39 return true; | 44 return true; |
40 } | 45 } |
41 | 46 |
42 return controller->SchedulePageFlip(callback); | 47 return controller->SchedulePageFlip(false, callback); |
43 } | 48 } |
44 | 49 |
45 scoped_ptr<gfx::VSyncProvider> GbmSurfaceless::CreateVSyncProvider() { | 50 scoped_ptr<gfx::VSyncProvider> GbmSurfaceless::CreateVSyncProvider() { |
46 return make_scoped_ptr(new DriVSyncProvider(window_delegate_)); | 51 return make_scoped_ptr(new DriVSyncProvider(window_delegate_)); |
47 } | 52 } |
48 | 53 |
49 } // namespace ui | 54 } // namespace ui |
OLD | NEW |