OLD | NEW |
---|---|
(Empty) | |
1 // Copyright (c) 2013 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. | |
4 | |
5 #ifndef UI_GFX_OZONE_IMPL_DRM_SKBITMAP_OZONE_H_ | |
6 #define UI_GFX_OZONE_IMPL_DRM_SKBITMAP_OZONE_H_ | |
7 | |
8 #include "base/basictypes.h" | |
9 #include "third_party/skia/include/core/SkBitmap.h" | |
10 | |
11 namespace gfx { | |
12 | |
13 // Extend the SkBitmap interface to keep track additional parameters used by the | |
rjkroege
2013/10/10 21:26:53
keep track of
| |
14 // DRM stack when allocating buffers. | |
15 class DrmSkBitmapOzone : public SkBitmap { | |
16 public: | |
17 DrmSkBitmapOzone(int fd); | |
18 virtual ~DrmSkBitmapOzone(); | |
19 | |
20 // Allocates the backing pixels using DRM. | |
21 // Return true on success, false otherwise. | |
22 virtual bool Initialize(); | |
23 | |
24 uint32_t get_handle() const { return handle_; }; | |
25 | |
26 uint32_t get_framebuffer() const { return framebuffer_; }; | |
27 | |
28 int get_fd() const { return fd_; }; | |
29 | |
30 // Return the color depth of a pixel in this buffer. | |
31 uint8_t GetColorDepth() const; | |
32 | |
33 private: | |
34 friend class DrmAllocator; | |
35 | |
36 void set_handle(uint32_t handle) { handle_ = handle; }; | |
37 void set_framebuffer(uint32_t framebuffer) { framebuffer_ = framebuffer; }; | |
38 | |
39 // File descriptor used by the DRM allocator to request buffers from the DRM | |
40 // stack. | |
41 int fd_; | |
42 | |
43 // Buffer handle used by the DRM allocator. | |
44 uint32_t handle_; | |
45 | |
46 // Buffer ID used by the DRM modesettings API. This is set when the buffer is | |
47 // registered with the CRTC. | |
48 uint32_t framebuffer_; | |
49 | |
50 DISALLOW_COPY_AND_ASSIGN(DrmSkBitmapOzone); | |
51 }; | |
52 | |
53 } // namespace gfx | |
54 | |
55 #endif // UI_GFX_OZONE_IMPL_DRM_SKBITMAP_OZONE_H_ | |
OLD | NEW |