OLD | NEW |
1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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_DRM_DEVICE_MANAGER_H_ | 5 #ifndef UI_OZONE_PLATFORM_DRM_GPU_DRM_DEVICE_MANAGER_H_ |
6 #define UI_OZONE_PLATFORM_DRM_GPU_DRM_DEVICE_MANAGER_H_ | 6 #define UI_OZONE_PLATFORM_DRM_GPU_DRM_DEVICE_MANAGER_H_ |
7 | 7 |
8 #include <map> | 8 #include <map> |
| 9 #include <vector> |
9 | 10 |
10 #include "base/memory/ref_counted.h" | 11 #include "base/memory/ref_counted.h" |
| 12 #include "base/memory/scoped_ptr.h" |
11 #include "base/synchronization/lock.h" | 13 #include "base/synchronization/lock.h" |
12 #include "ui/gfx/native_widget_types.h" | 14 #include "ui/gfx/native_widget_types.h" |
13 #include "ui/ozone/ozone_export.h" | 15 #include "ui/ozone/ozone_export.h" |
14 | 16 |
| 17 namespace base { |
| 18 class FilePath; |
| 19 struct FileDescriptor; |
| 20 class SingleThreadTaskRunner; |
| 21 } |
| 22 |
15 namespace ui { | 23 namespace ui { |
16 | 24 |
17 class DrmDevice; | 25 class DrmDevice; |
| 26 class DrmDeviceGenerator; |
18 | 27 |
19 // Tracks the mapping between widgets and the DRM devices used to allocate | 28 // Tracks the mapping between widgets and the DRM devices used to allocate |
20 // buffers for the window represented by the widget. | 29 // buffers for the window represented by the widget. |
| 30 // Note: All calls are protected by a lock since |
| 31 // GetDrmDevice(gfx::AcceleratedWidget) may be called on the IO thread. |
21 class OZONE_EXPORT DrmDeviceManager { | 32 class OZONE_EXPORT DrmDeviceManager { |
22 public: | 33 public: |
23 DrmDeviceManager(const scoped_refptr<DrmDevice>& primary_device); | 34 DrmDeviceManager(scoped_ptr<DrmDeviceGenerator> drm_device_generator); |
24 ~DrmDeviceManager(); | 35 ~DrmDeviceManager(); |
25 | 36 |
| 37 // The first device registered is assumed to be the primary device. |
| 38 bool AddDrmDevice(const base::FilePath& path, const base::FileDescriptor& fd); |
| 39 void RemoveDrmDevice(const base::FilePath& path); |
| 40 |
| 41 void InitializeIOTaskRunner( |
| 42 const scoped_refptr<base::SingleThreadTaskRunner>& task_runner); |
| 43 |
26 // Updates the device associated with |widget|. | 44 // Updates the device associated with |widget|. |
27 void UpdateDrmDevice(gfx::AcceleratedWidget widget, | 45 void UpdateDrmDevice(gfx::AcceleratedWidget widget, |
28 const scoped_refptr<DrmDevice>& device); | 46 const scoped_refptr<DrmDevice>& device); |
29 | 47 |
30 // Removes the device associated with |widget|. | 48 // Removes the device associated with |widget|. |
31 void RemoveDrmDevice(gfx::AcceleratedWidget widget); | 49 void RemoveDrmDevice(gfx::AcceleratedWidget widget); |
32 | 50 |
33 // Returns the device associated with |widget|. If there is no association | 51 // Returns the device associated with |widget|. If there is no association |
34 // returns |primary_device_|. | 52 // returns |primary_device_|. |
35 scoped_refptr<DrmDevice> GetDrmDevice(gfx::AcceleratedWidget widget); | 53 scoped_refptr<DrmDevice> GetDrmDevice(gfx::AcceleratedWidget widget); |
36 | 54 |
| 55 std::vector<scoped_refptr<DrmDevice>> GetDrmDevices(); |
| 56 |
37 private: | 57 private: |
| 58 scoped_ptr<DrmDeviceGenerator> drm_device_generator_; |
| 59 |
| 60 scoped_refptr<base::SingleThreadTaskRunner> io_task_runner_; |
| 61 |
| 62 std::vector<scoped_refptr<DrmDevice>> devices_; |
| 63 |
38 std::map<gfx::AcceleratedWidget, scoped_refptr<DrmDevice>> drm_device_map_; | 64 std::map<gfx::AcceleratedWidget, scoped_refptr<DrmDevice>> drm_device_map_; |
39 | 65 |
40 // This device represents the primary graphics device and is used when: | 66 // This device represents the primary graphics device and is used when: |
41 // 1) 'widget == kNullAcceleratedWidget' when the API requesting a buffer has | 67 // 1) 'widget == kNullAcceleratedWidget' when the API requesting a buffer has |
42 // no knowledge of the surface/display it belongs to (currently this happens | 68 // no knowledge of the surface/display it belongs to (currently this happens |
43 // for video buffers), or | 69 // for video buffers), or |
44 // 2) in order to allocate buffers for unmatched surfaces (surfaces without a | 70 // 2) in order to allocate buffers for unmatched surfaces (surfaces without a |
45 // display; ie: when in headless mode). | 71 // display; ie: when in headless mode). |
46 scoped_refptr<DrmDevice> primary_device_; | 72 scoped_refptr<DrmDevice> primary_device_; |
47 | 73 |
48 // This class is accessed from the main thread and the IO thread. This lock | 74 // This class is accessed from the main thread and the IO thread. This lock |
49 // protects access to the device map. | 75 // protects access to the device map. |
50 base::Lock lock_; | 76 base::Lock lock_; |
51 | 77 |
52 DISALLOW_COPY_AND_ASSIGN(DrmDeviceManager); | 78 DISALLOW_COPY_AND_ASSIGN(DrmDeviceManager); |
53 }; | 79 }; |
54 | 80 |
55 } // namespace ui | 81 } // namespace ui |
56 | 82 |
57 #endif // UI_OZONE_PLATFORM_DRM_GPU_DRM_DEVICE_MANAGER_H_ | 83 #endif // UI_OZONE_PLATFORM_DRM_GPU_DRM_DEVICE_MANAGER_H_ |
OLD | NEW |