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 of additional parameters used by |
| 14 // the 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 |