Upstream version 9.37.197.0
[platform/framework/web/crosswalk.git] / src / ui / ozone / platform / dri / buffer_data.h
1 // Copyright 2014 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_OZONE_PLATFORM_DRI_BUFFER_DATA_H_
6 #define UI_OZONE_PLATFORM_DRI_BUFFER_DATA_H_
7
8 #include "base/memory/scoped_ptr.h"
9
10 struct gbm_bo;
11
12 namespace ui {
13
14 class DriWrapper;
15
16 // This class is used to tag a gbm buffer with custom information needed
17 // for presentation with the surface factory.
18 class BufferData {
19  public:
20   // When we create the BufferData we need to register the buffer. Once
21   // successfully registered, the |framebuffer_| field will hold the ID of the
22   // buffer. The controller will use this ID when scanning out the buffer. On
23   // creation we will also associate the BufferData with the buffer.
24   static BufferData* CreateData(DriWrapper* dri, gbm_bo* buffer);
25
26   // Callback used by GBM to destroy the BufferData associated with a buffer.
27   static void Destroy(gbm_bo* buffer, void* data);
28
29   // Returns the BufferData associated with |buffer|. NULL if no data is
30   // associated.
31   static BufferData* GetData(gbm_bo* buffer);
32
33   uint32_t framebuffer() const { return framebuffer_; }
34   uint32_t handle() const { return handle_; }
35
36  private:
37   BufferData(DriWrapper* dri, gbm_bo* buffer);
38   ~BufferData();
39
40   DriWrapper* dri_;
41
42   uint32_t handle_;
43
44   // ID provided by the controller when the buffer is registered. This ID is
45   // used when scanning out the buffer.
46   uint32_t framebuffer_;
47
48   DISALLOW_COPY_AND_ASSIGN(BufferData);
49 };
50
51 }  // namespace ui
52
53 #endif  // UI_OZONE_PLATFORM_DRI_BUFFER_DATA_H_