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