Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(356)

Unified Diff: ui/ozone/platform/drm/gpu/screen_manager.h

Issue 1285183008: Ozone integration. (Closed) Base URL: https://github.com/domokit/mojo.git@master
Patch Set: add missing license header Created 5 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « ui/ozone/platform/drm/gpu/scanout_buffer.h ('k') | ui/ozone/platform/drm/gpu/screen_manager.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: ui/ozone/platform/drm/gpu/screen_manager.h
diff --git a/ui/ozone/platform/drm/gpu/screen_manager.h b/ui/ozone/platform/drm/gpu/screen_manager.h
new file mode 100644
index 0000000000000000000000000000000000000000..f9c5bc0cfdecc0761c4a70376e745cc1c4dfa266
--- /dev/null
+++ b/ui/ozone/platform/drm/gpu/screen_manager.h
@@ -0,0 +1,132 @@
+// Copyright 2014 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#ifndef UI_OZONE_PLATFORM_DRM_GPU_SCREEN_MANAGER_H_
+#define UI_OZONE_PLATFORM_DRM_GPU_SCREEN_MANAGER_H_
+
+#include "base/containers/scoped_ptr_hash_map.h"
+#include "base/macros.h"
+#include "base/memory/scoped_vector.h"
+#include "base/observer_list.h"
+#include "ui/gfx/native_widget_types.h"
+#include "ui/ozone/ozone_export.h"
+#include "ui/ozone/platform/drm/gpu/hardware_display_controller.h"
+
+typedef struct _drmModeModeInfo drmModeModeInfo;
+
+namespace gfx {
+class Point;
+class Rect;
+class Size;
+} // namespace gfx
+
+namespace ui {
+
+class DrmDevice;
+class DrmWindow;
+class ScanoutBufferGenerator;
+
+// Responsible for keeping track of active displays and configuring them.
+class OZONE_EXPORT ScreenManager {
+ public:
+ ScreenManager(ScanoutBufferGenerator* surface_generator);
+ virtual ~ScreenManager();
+
+ // Register a display controller. This must be called before trying to
+ // configure it.
+ void AddDisplayController(const scoped_refptr<DrmDevice>& drm,
+ uint32_t crtc,
+ uint32_t connector);
+
+ // Remove a display controller from the list of active controllers. The
+ // controller is removed since it was disconnected.
+ void RemoveDisplayController(const scoped_refptr<DrmDevice>& drm,
+ uint32_t crtc);
+
+ // Configure a display controller. The display controller is identified by
+ // (|crtc|, |connector|) and the controller is modeset using |mode|.
+ bool ConfigureDisplayController(const scoped_refptr<DrmDevice>& drm,
+ uint32_t crtc,
+ uint32_t connector,
+ const gfx::Point& origin,
+ const drmModeModeInfo& mode);
+
+ // Disable the display controller identified by |crtc|. Note, the controller
+ // may still be connected, so this does not remove the controller.
+ bool DisableDisplayController(const scoped_refptr<DrmDevice>& drm,
+ uint32_t crtc);
+
+ // Returns a reference to the display controller configured to display within
+ // |bounds|. If the caller caches the controller it must also register as an
+ // observer to be notified when the controller goes out of scope.
+ HardwareDisplayController* GetDisplayController(const gfx::Rect& bounds);
+
+ // Adds a window for |widget|. Note: |widget| should not be associated with a
+ // window when calling this function.
+ void AddWindow(gfx::AcceleratedWidget widget, scoped_ptr<DrmWindow> window);
+
+ // Removes the window for |widget|. Note: |widget| must have a window
+ // associated with it when calling this function.
+ scoped_ptr<DrmWindow> RemoveWindow(gfx::AcceleratedWidget widget);
+
+ // Returns the window associated with |widget|. Note: This function should be
+ // called only if a valid window has been associated with |widget|.
+ DrmWindow* GetWindow(gfx::AcceleratedWidget widget);
+
+ // Updates the mapping between display controllers and windows such that a
+ // controller will be associated with at most one window.
+ void UpdateControllerToWindowMapping();
+
+ private:
+ typedef ScopedVector<HardwareDisplayController> HardwareDisplayControllers;
+
+ typedef base::ScopedPtrHashMap<gfx::AcceleratedWidget, scoped_ptr<DrmWindow>>
+ WidgetToWindowMap;
+
+ // Returns an iterator into |controllers_| for the controller identified by
+ // (|crtc|, |connector|).
+ HardwareDisplayControllers::iterator FindDisplayController(
+ const scoped_refptr<DrmDevice>& drm,
+ uint32_t crtc);
+
+ bool ActualConfigureDisplayController(const scoped_refptr<DrmDevice>& drm,
+ uint32_t crtc,
+ uint32_t connector,
+ const gfx::Point& origin,
+ const drmModeModeInfo& mode);
+
+ // Returns an iterator into |controllers_| for the controller located at
+ // |origin|.
+ HardwareDisplayControllers::iterator FindActiveDisplayControllerByLocation(
+ const gfx::Rect& bounds);
+
+ // Tries to set the controller identified by (|crtc|, |connector|) to mirror
+ // those in |mirror|. |original| is an iterator to the HDC where the
+ // controller is currently present.
+ bool HandleMirrorMode(HardwareDisplayControllers::iterator original,
+ HardwareDisplayControllers::iterator mirror,
+ const scoped_refptr<DrmDevice>& drm,
+ uint32_t crtc,
+ uint32_t connector);
+
+ // Modeset the |controller| using |origin| and |mode|. If there is a window at
+ // the controller location, then we'll re-use the current buffer.
+ bool EnableController(HardwareDisplayController* controller,
+ const gfx::Point& origin,
+ const drmModeModeInfo& mode);
+
+ DrmWindow* FindWindowAt(const gfx::Rect& bounds) const;
+
+ ScanoutBufferGenerator* buffer_generator_; // Not owned.
+ // List of display controllers (active and disabled).
+ HardwareDisplayControllers controllers_;
+
+ WidgetToWindowMap window_map_;
+
+ DISALLOW_COPY_AND_ASSIGN(ScreenManager);
+};
+
+} // namespace ui
+
+#endif // UI_OZONE_PLATFORM_DRM_GPU_SCREEN_MANAGER_H_
« no previous file with comments | « ui/ozone/platform/drm/gpu/scanout_buffer.h ('k') | ui/ozone/platform/drm/gpu/screen_manager.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698