| 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 |