| OLD | NEW |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 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 | 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 #include "ui/ozone/platform/dri/gbm_buffer.h" | 5 #include "ui/ozone/platform/dri/gbm_buffer.h" |
| 6 | 6 |
| 7 #include <drm.h> | 7 #include <drm.h> |
| 8 #include <fcntl.h> | 8 #include <fcntl.h> |
| 9 #include <gbm.h> | 9 #include <gbm.h> |
| 10 #include <xf86drm.h> | 10 #include <xf86drm.h> |
| 11 | 11 |
| 12 #include "base/logging.h" | 12 #include "base/logging.h" |
| 13 #include "ui/ozone/platform/dri/dri_wrapper.h" | 13 #include "ui/ozone/platform/dri/gbm_wrapper.h" |
| 14 | 14 |
| 15 namespace ui { | 15 namespace ui { |
| 16 | 16 |
| 17 namespace { | 17 namespace { |
| 18 | 18 |
| 19 int GetGbmFormatFromBufferFormat(SurfaceFactoryOzone::BufferFormat fmt) { | 19 int GetGbmFormatFromBufferFormat(SurfaceFactoryOzone::BufferFormat fmt) { |
| 20 switch (fmt) { | 20 switch (fmt) { |
| 21 case SurfaceFactoryOzone::RGBA_8888: | 21 case SurfaceFactoryOzone::RGBA_8888: |
| 22 return GBM_BO_FORMAT_ARGB8888; | 22 return GBM_BO_FORMAT_ARGB8888; |
| 23 case SurfaceFactoryOzone::RGBX_8888: | 23 case SurfaceFactoryOzone::RGBX_8888: |
| 24 return GBM_BO_FORMAT_XRGB8888; | 24 return GBM_BO_FORMAT_XRGB8888; |
| 25 default: | 25 default: |
| 26 NOTREACHED(); | 26 NOTREACHED(); |
| 27 return 0; | 27 return 0; |
| 28 } | 28 } |
| 29 } | 29 } |
| 30 | 30 |
| 31 } // namespace | 31 } // namespace |
| 32 | 32 |
| 33 GbmBuffer::GbmBuffer(DriWrapper* dri, gbm_bo* bo, bool scanout) | 33 GbmBuffer::GbmBuffer(GbmWrapper* gbm, gbm_bo* bo, bool scanout) |
| 34 : GbmBufferBase(dri, bo, scanout) { | 34 : GbmBufferBase(gbm, bo, scanout) { |
| 35 } | 35 } |
| 36 | 36 |
| 37 GbmBuffer::~GbmBuffer() { | 37 GbmBuffer::~GbmBuffer() { |
| 38 if (bo()) | 38 if (bo()) |
| 39 gbm_bo_destroy(bo()); | 39 gbm_bo_destroy(bo()); |
| 40 } | 40 } |
| 41 | 41 |
| 42 // static | 42 // static |
| 43 scoped_refptr<GbmBuffer> GbmBuffer::CreateBuffer( | 43 scoped_refptr<GbmBuffer> GbmBuffer::CreateBuffer( |
| 44 DriWrapper* dri, | 44 GbmWrapper* gbm, |
| 45 gbm_device* device, | |
| 46 SurfaceFactoryOzone::BufferFormat format, | 45 SurfaceFactoryOzone::BufferFormat format, |
| 47 const gfx::Size& size, | 46 const gfx::Size& size, |
| 48 bool scanout) { | 47 bool scanout) { |
| 49 unsigned flags = GBM_BO_USE_RENDERING; | 48 unsigned flags = GBM_BO_USE_RENDERING; |
| 50 if (scanout) | 49 if (scanout) |
| 51 flags |= GBM_BO_USE_SCANOUT; | 50 flags |= GBM_BO_USE_SCANOUT; |
| 52 gbm_bo* bo = gbm_bo_create(device, | 51 gbm_bo* bo = gbm_bo_create(gbm->device(), size.width(), size.height(), |
| 53 size.width(), | 52 GetGbmFormatFromBufferFormat(format), flags); |
| 54 size.height(), | |
| 55 GetGbmFormatFromBufferFormat(format), | |
| 56 flags); | |
| 57 if (!bo) | 53 if (!bo) |
| 58 return NULL; | 54 return NULL; |
| 59 | 55 |
| 60 scoped_refptr<GbmBuffer> buffer(new GbmBuffer(dri, bo, scanout)); | 56 scoped_refptr<GbmBuffer> buffer(new GbmBuffer(gbm, bo, scanout)); |
| 61 if (scanout && !buffer->GetFramebufferId()) | 57 if (scanout && !buffer->GetFramebufferId()) |
| 62 return NULL; | 58 return NULL; |
| 63 | 59 |
| 64 return buffer; | 60 return buffer; |
| 65 } | 61 } |
| 66 | 62 |
| 67 GbmPixmap::GbmPixmap(scoped_refptr<GbmBuffer> buffer) | 63 GbmPixmap::GbmPixmap(scoped_refptr<GbmBuffer> buffer) |
| 68 : buffer_(buffer), dma_buf_(-1) { | 64 : buffer_(buffer), dma_buf_(-1) { |
| 69 } | 65 } |
| 70 | 66 |
| 71 bool GbmPixmap::Initialize(DriWrapper* dri) { | 67 bool GbmPixmap::Initialize(GbmWrapper* gbm) { |
| 72 // We want to use the GBM API because it's going to call into libdrm | 68 // We want to use the GBM API because it's going to call into libdrm |
| 73 // which might do some optimizations on buffer allocation, | 69 // which might do some optimizations on buffer allocation, |
| 74 // especially when sharing buffers via DMABUF. | 70 // especially when sharing buffers via DMABUF. |
| 75 dma_buf_ = gbm_bo_get_fd(buffer_->bo()); | 71 dma_buf_ = gbm_bo_get_fd(buffer_->bo()); |
| 76 if (dma_buf_ < 0) { | 72 if (dma_buf_ < 0) { |
| 77 LOG(ERROR) << "Failed to export buffer to dma_buf"; | 73 LOG(ERROR) << "Failed to export buffer to dma_buf"; |
| 78 return false; | 74 return false; |
| 79 } | 75 } |
| 80 return true; | 76 return true; |
| 81 } | 77 } |
| 82 | 78 |
| 83 GbmPixmap::~GbmPixmap() { | 79 GbmPixmap::~GbmPixmap() { |
| 84 if (dma_buf_ > 0) | 80 if (dma_buf_ > 0) |
| 85 close(dma_buf_); | 81 close(dma_buf_); |
| 86 } | 82 } |
| 87 | 83 |
| 88 void* GbmPixmap::GetEGLClientBuffer() { | 84 void* GbmPixmap::GetEGLClientBuffer() { |
| 89 return nullptr; | 85 return nullptr; |
| 90 } | 86 } |
| 91 | 87 |
| 92 int GbmPixmap::GetDmaBufFd() { | 88 int GbmPixmap::GetDmaBufFd() { |
| 93 return dma_buf_; | 89 return dma_buf_; |
| 94 } | 90 } |
| 95 | 91 |
| 96 int GbmPixmap::GetDmaBufPitch() { | 92 int GbmPixmap::GetDmaBufPitch() { |
| 97 return gbm_bo_get_stride(buffer_->bo()); | 93 return gbm_bo_get_stride(buffer_->bo()); |
| 98 } | 94 } |
| 99 | 95 |
| 100 } // namespace ui | 96 } // namespace ui |
| OLD | NEW |