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
3 // found in the LICENSE file.
5 #ifndef UI_OZONE_PLATFORM_DRM_GPU_CRTC_CONTROLLER_H_
6 #define UI_OZONE_PLATFORM_DRM_GPU_CRTC_CONTROLLER_H_
10 #include <xf86drmMode.h>
12 #include "base/memory/weak_ptr.h"
13 #include "base/observer_list.h"
14 #include "ui/ozone/ozone_export.h"
15 #include "ui/ozone/platform/drm/gpu/hardware_display_plane_manager.h"
16 #include "ui/ozone/platform/drm/gpu/overlay_plane.h"
17 #include "ui/ozone/platform/drm/gpu/scoped_drm_types.h"
22 class PageFlipObserver
;
24 // Wrapper around a CRTC.
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
28 // CRTC with multiple connectors results in hardware mirroring.
29 class OZONE_EXPORT CrtcController
30 : public base::SupportsWeakPtr
<CrtcController
> {
32 CrtcController(const scoped_refptr
<DrmDevice
>& drm
,
37 uint32_t crtc() const { return crtc_
; }
38 uint32_t connector() const { return connector_
; }
39 const scoped_refptr
<DrmDevice
>& drm() const { return drm_
; }
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_
; }
44 drmModeCrtc
* saved_crtc() const { return saved_crtc_
.get(); }
46 // Perform the initial modesetting operation using |plane| as the buffer for
47 // the primary plane. The CRTC configuration is specified by |mode|.
48 bool Modeset(const OverlayPlane
& plane
, drmModeModeInfo mode
);
50 // Disables the controller.
53 // Schedule a page flip event and present the overlays in |planes|.
54 bool SchedulePageFlip(HardwareDisplayPlaneList
* plane_list
,
55 const OverlayPlaneList
& planes
);
57 // Called if the page flip for this CRTC fails after being scheduled.
58 void PageFlipFailed();
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
62 // update internal state and propagate the update to the surface.
63 // The tuple (seconds, useconds) represents the event timestamp. |seconds|
64 // represents the number of seconds while |useconds| represents the
65 // microseconds (< 1 second) in the timestamp.
66 void OnPageFlipEvent(unsigned int frame
,
68 unsigned int useconds
);
70 bool SetCursor(const scoped_refptr
<ScanoutBuffer
>& buffer
);
72 bool MoveCursor(const gfx::Point
& location
);
74 void AddObserver(PageFlipObserver
* observer
);
75 void RemoveObserver(PageFlipObserver
* observer
);
78 scoped_refptr
<DrmDevice
> drm_
;
80 HardwareDisplayPlaneManager
* overlay_plane_manager_
; // Not owned.
82 // Buffers need to be declared first so that they are destroyed last. Needed
83 // since the controllers may reference the buffers.
84 OverlayPlaneList current_planes_
;
85 OverlayPlaneList pending_planes_
;
86 scoped_refptr
<ScanoutBuffer
> cursor_buffer_
;
90 // TODO(dnicoara) Add support for hardware mirroring (multiple connectors).
93 drmModeModeInfo mode_
;
95 // Store the state of the CRTC before we took over. Used to restore the CRTC
96 // once we no longer need it.
97 ScopedDrmCrtcPtr saved_crtc_
;
99 // Keeps track of the CRTC state. If a surface has been bound, then the value
100 // is set to false. Otherwise it is true.
103 // True if a successful SchedulePageFlip occurred. Reset to false by a modeset
104 // operation or when the OnPageFlipEvent callback is triggered.
105 bool page_flip_pending_
;
107 // The time of the last page flip event as reported by the kernel callback.
108 uint64_t time_of_last_flip_
;
110 ObserverList
<PageFlipObserver
> observers_
;
112 DISALLOW_COPY_AND_ASSIGN(CrtcController
);
117 #endif // UI_OZONE_PLATFORM_DRM_GPU_CRTC_CONTROLLER_H_