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 #ifndef UI_OZONE_PLATFORM_DRM_GPU_CRTC_CONTROLLER_H_ | 5 #ifndef UI_OZONE_PLATFORM_DRM_GPU_CRTC_CONTROLLER_H_ |
6 #define UI_OZONE_PLATFORM_DRM_GPU_CRTC_CONTROLLER_H_ | 6 #define UI_OZONE_PLATFORM_DRM_GPU_CRTC_CONTROLLER_H_ |
7 | 7 |
8 #include <stddef.h> | 8 #include <stddef.h> |
9 #include <stdint.h> | 9 #include <stdint.h> |
10 #include <xf86drmMode.h> | 10 #include <xf86drmMode.h> |
11 | 11 |
12 #include "base/memory/weak_ptr.h" | 12 #include "base/memory/weak_ptr.h" |
13 #include "base/observer_list.h" | 13 #include "base/observer_list.h" |
14 #include "ui/ozone/ozone_export.h" | 14 #include "ui/ozone/ozone_export.h" |
15 #include "ui/ozone/platform/drm/gpu/hardware_display_plane_manager.h" | 15 #include "ui/ozone/platform/drm/gpu/hardware_display_plane_manager.h" |
16 #include "ui/ozone/platform/drm/gpu/overlay_plane.h" | 16 #include "ui/ozone/platform/drm/gpu/overlay_plane.h" |
17 #include "ui/ozone/platform/drm/gpu/scoped_drm_types.h" | 17 #include "ui/ozone/platform/drm/gpu/scoped_drm_types.h" |
18 | 18 |
19 namespace ui { | 19 namespace ui { |
20 | 20 |
21 class DrmDevice; | 21 class DrmDevice; |
22 class PageFlipObserver; | 22 class PageFlipRequest; |
23 | 23 |
24 // Wrapper around a CRTC. | 24 // Wrapper around a CRTC. |
25 // | 25 // |
26 // One CRTC can be paired up with one or more connectors. The simplest | 26 // One CRTC can be paired up with one or more connectors. The simplest |
27 // configuration represents one CRTC driving one monitor, while pairing up a | 27 // configuration represents one CRTC driving one monitor, while pairing up a |
28 // CRTC with multiple connectors results in hardware mirroring. | 28 // CRTC with multiple connectors results in hardware mirroring. |
29 class OZONE_EXPORT CrtcController | 29 class OZONE_EXPORT CrtcController |
30 : public base::SupportsWeakPtr<CrtcController> { | 30 : public base::SupportsWeakPtr<CrtcController> { |
31 public: | 31 public: |
32 CrtcController(const scoped_refptr<DrmDevice>& drm, | 32 CrtcController(const scoped_refptr<DrmDevice>& drm, |
33 uint32_t crtc, | 33 uint32_t crtc, |
34 uint32_t connector); | 34 uint32_t connector); |
35 ~CrtcController(); | 35 ~CrtcController(); |
36 | 36 |
37 uint32_t crtc() const { return crtc_; } | 37 uint32_t crtc() const { return crtc_; } |
38 uint32_t connector() const { return connector_; } | 38 uint32_t connector() const { return connector_; } |
39 const scoped_refptr<DrmDevice>& drm() const { return drm_; } | 39 const scoped_refptr<DrmDevice>& drm() const { return drm_; } |
40 bool is_disabled() const { return is_disabled_; } | 40 bool is_disabled() const { return is_disabled_; } |
41 bool page_flip_pending() const { return page_flip_pending_; } | |
42 uint64_t time_of_last_flip() const { return time_of_last_flip_; } | 41 uint64_t time_of_last_flip() const { return time_of_last_flip_; } |
43 | 42 |
44 drmModeCrtc* saved_crtc() const { return saved_crtc_.get(); } | 43 drmModeCrtc* saved_crtc() const { return saved_crtc_.get(); } |
45 | 44 |
46 // Perform the initial modesetting operation using |plane| as the buffer for | 45 // Perform the initial modesetting operation using |plane| as the buffer for |
47 // the primary plane. The CRTC configuration is specified by |mode|. | 46 // the primary plane. The CRTC configuration is specified by |mode|. |
48 bool Modeset(const OverlayPlane& plane, drmModeModeInfo mode); | 47 bool Modeset(const OverlayPlane& plane, drmModeModeInfo mode); |
49 | 48 |
50 // Disables the controller. | 49 // Disables the controller. |
51 bool Disable(); | 50 bool Disable(); |
52 | 51 |
53 // Schedule a page flip event and present the overlays in |planes|. | 52 // Schedule a page flip event and present the overlays in |planes|. |
54 bool SchedulePageFlip(HardwareDisplayPlaneList* plane_list, | 53 bool SchedulePageFlip(HardwareDisplayPlaneList* plane_list, |
55 const OverlayPlaneList& planes); | 54 const OverlayPlaneList& planes, |
| 55 scoped_refptr<PageFlipRequest> page_flip_request); |
56 | 56 |
57 // Called if the page flip for this CRTC fails after being scheduled. | 57 // Called if the page flip for this CRTC fails after being scheduled. |
58 void PageFlipFailed(); | 58 void PageFlipFailed(); |
59 | 59 |
60 // Called when the page flip event occurred. The event is provided by the | 60 // Called when the page flip event occurred. The event is provided by the |
61 // kernel when a VBlank event finished. This allows the controller to | 61 // kernel when a VBlank event finished. This allows the controller to |
62 // update internal state and propagate the update to the surface. | 62 // update internal state and propagate the update to the surface. |
63 // The tuple (seconds, useconds) represents the event timestamp. |seconds| | 63 // The tuple (seconds, useconds) represents the event timestamp. |seconds| |
64 // represents the number of seconds while |useconds| represents the | 64 // represents the number of seconds while |useconds| represents the |
65 // microseconds (< 1 second) in the timestamp. | 65 // microseconds (< 1 second) in the timestamp. |
66 void OnPageFlipEvent(unsigned int frame, | 66 void OnPageFlipEvent(unsigned int frame, |
67 unsigned int seconds, | 67 unsigned int seconds, |
68 unsigned int useconds); | 68 unsigned int useconds); |
69 | 69 |
70 bool SetCursor(const scoped_refptr<ScanoutBuffer>& buffer); | 70 bool SetCursor(const scoped_refptr<ScanoutBuffer>& buffer); |
71 bool MoveCursor(const gfx::Point& location); | 71 bool MoveCursor(const gfx::Point& location); |
72 | 72 |
73 void AddObserver(PageFlipObserver* observer); | |
74 void RemoveObserver(PageFlipObserver* observer); | |
75 | |
76 private: | 73 private: |
77 bool ResetCursor(); | 74 bool ResetCursor(); |
78 | 75 |
| 76 void SignalPageFlipRequest(); |
| 77 |
79 scoped_refptr<DrmDevice> drm_; | 78 scoped_refptr<DrmDevice> drm_; |
80 | 79 |
81 HardwareDisplayPlaneManager* overlay_plane_manager_; // Not owned. | 80 HardwareDisplayPlaneManager* overlay_plane_manager_; // Not owned. |
82 | 81 |
83 // Buffers need to be declared first so that they are destroyed last. Needed | 82 // Buffers need to be declared first so that they are destroyed last. Needed |
84 // since the controllers may reference the buffers. | 83 // since the controllers may reference the buffers. |
85 OverlayPlaneList current_planes_; | 84 OverlayPlaneList current_planes_; |
86 OverlayPlaneList pending_planes_; | 85 OverlayPlaneList pending_planes_; |
87 scoped_refptr<ScanoutBuffer> cursor_buffer_; | 86 scoped_refptr<ScanoutBuffer> cursor_buffer_; |
| 87 scoped_refptr<PageFlipRequest> page_flip_request_; |
88 | 88 |
89 uint32_t crtc_; | 89 uint32_t crtc_; |
90 | 90 |
91 // TODO(dnicoara) Add support for hardware mirroring (multiple connectors). | 91 // TODO(dnicoara) Add support for hardware mirroring (multiple connectors). |
92 uint32_t connector_; | 92 uint32_t connector_; |
93 | 93 |
94 drmModeModeInfo mode_; | 94 drmModeModeInfo mode_; |
95 | 95 |
96 // Store the state of the CRTC before we took over. Used to restore the CRTC | 96 // Store the state of the CRTC before we took over. Used to restore the CRTC |
97 // once we no longer need it. | 97 // once we no longer need it. |
98 ScopedDrmCrtcPtr saved_crtc_; | 98 ScopedDrmCrtcPtr saved_crtc_; |
99 | 99 |
100 // Keeps track of the CRTC state. If a surface has been bound, then the value | 100 // Keeps track of the CRTC state. If a surface has been bound, then the value |
101 // is set to false. Otherwise it is true. | 101 // is set to false. Otherwise it is true. |
102 bool is_disabled_; | 102 bool is_disabled_; |
103 | 103 |
104 // True if a successful SchedulePageFlip occurred. Reset to false by a modeset | |
105 // operation or when the OnPageFlipEvent callback is triggered. | |
106 bool page_flip_pending_; | |
107 | |
108 // The time of the last page flip event as reported by the kernel callback. | 104 // The time of the last page flip event as reported by the kernel callback. |
109 uint64_t time_of_last_flip_; | 105 uint64_t time_of_last_flip_; |
110 | 106 |
111 ObserverList<PageFlipObserver> observers_; | |
112 | |
113 DISALLOW_COPY_AND_ASSIGN(CrtcController); | 107 DISALLOW_COPY_AND_ASSIGN(CrtcController); |
114 }; | 108 }; |
115 | 109 |
116 } // namespace ui | 110 } // namespace ui |
117 | 111 |
118 #endif // UI_OZONE_PLATFORM_DRM_GPU_CRTC_CONTROLLER_H_ | 112 #endif // UI_OZONE_PLATFORM_DRM_GPU_CRTC_CONTROLLER_H_ |
OLD | NEW |