| 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 #include "components/view_manager/gles2/mojo_gpu_memory_buffer.h" | 5 #include "components/view_manager/gles2/gpu_memory_buffer_impl.h" |
| 6 | 6 |
| 7 #include "base/logging.h" | 7 #include "ui/gfx/gpu_memory_buffer.h" |
| 8 #include "base/memory/shared_memory.h" | |
| 9 #include "base/numerics/safe_conversions.h" | |
| 10 | |
| 11 namespace gles2 { | |
| 12 | 8 |
| 13 namespace { | 9 namespace { |
| 14 | 10 |
| 15 int NumberOfPlanesForGpuMemoryBufferFormat(gfx::BufferFormat format) { | 11 size_t NumberOfPlanesForGpuMemoryBufferFormat( |
| 12 gfx::BufferFormat format) { |
| 16 switch (format) { | 13 switch (format) { |
| 17 case gfx::BufferFormat::ATC: | 14 case gfx::BufferFormat::ATC: |
| 18 case gfx::BufferFormat::ATCIA: | 15 case gfx::BufferFormat::ATCIA: |
| 19 case gfx::BufferFormat::DXT1: | 16 case gfx::BufferFormat::DXT1: |
| 20 case gfx::BufferFormat::DXT5: | 17 case gfx::BufferFormat::DXT5: |
| 21 case gfx::BufferFormat::ETC1: | 18 case gfx::BufferFormat::ETC1: |
| 22 case gfx::BufferFormat::R_8: | 19 case gfx::BufferFormat::R_8: |
| 23 case gfx::BufferFormat::RGBA_4444: | 20 case gfx::BufferFormat::RGBA_4444: |
| 24 case gfx::BufferFormat::RGBA_8888: | 21 case gfx::BufferFormat::RGBA_8888: |
| 25 case gfx::BufferFormat::RGBX_8888: | 22 case gfx::BufferFormat::RGBX_8888: |
| (...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 58 size_t StrideInBytes(size_t width, gfx::BufferFormat format, int plane) { | 55 size_t StrideInBytes(size_t width, gfx::BufferFormat format, int plane) { |
| 59 switch (format) { | 56 switch (format) { |
| 60 case gfx::BufferFormat::ATCIA: | 57 case gfx::BufferFormat::ATCIA: |
| 61 case gfx::BufferFormat::DXT5: | 58 case gfx::BufferFormat::DXT5: |
| 62 DCHECK_EQ(plane, 0); | 59 DCHECK_EQ(plane, 0); |
| 63 return width; | 60 return width; |
| 64 case gfx::BufferFormat::ATC: | 61 case gfx::BufferFormat::ATC: |
| 65 case gfx::BufferFormat::DXT1: | 62 case gfx::BufferFormat::DXT1: |
| 66 case gfx::BufferFormat::ETC1: | 63 case gfx::BufferFormat::ETC1: |
| 67 DCHECK_EQ(plane, 0); | 64 DCHECK_EQ(plane, 0); |
| 68 DCHECK_EQ(width % 2, 0u); | 65 DCHECK_EQ(width % 2, 0U); |
| 69 return width / 2; | 66 return width / 2; |
| 70 case gfx::BufferFormat::R_8: | 67 case gfx::BufferFormat::R_8: |
| 71 return (width + 3) & ~0x3; | 68 return (width + 3) & ~0x3; |
| 72 case gfx::BufferFormat::RGBA_4444: | 69 case gfx::BufferFormat::RGBA_4444: |
| 73 DCHECK_EQ(plane, 0); | 70 DCHECK_EQ(plane, 0); |
| 74 return width * 2; | 71 return width * 2; |
| 75 case gfx::BufferFormat::RGBA_8888: | 72 case gfx::BufferFormat::RGBA_8888: |
| 76 case gfx::BufferFormat::RGBX_8888: | |
| 77 case gfx::BufferFormat::BGRA_8888: | 73 case gfx::BufferFormat::BGRA_8888: |
| 78 DCHECK_EQ(plane, 0); | 74 DCHECK_EQ(plane, 0); |
| 79 return width * 4; | 75 return width * 4; |
| 76 case gfx::BufferFormat::RGBX_8888: |
| 77 NOTREACHED(); |
| 78 return 0; |
| 80 case gfx::BufferFormat::YUV_420: | 79 case gfx::BufferFormat::YUV_420: |
| 81 return width / SubsamplingFactor(format, plane); | 80 return width / SubsamplingFactor(format, plane); |
| 82 } | 81 } |
| 82 |
| 83 NOTREACHED(); | 83 NOTREACHED(); |
| 84 return 0; | 84 return 0; |
| 85 } | 85 } |
| 86 | 86 |
| 87 size_t BufferSizeInBytes(const gfx::Size& size, gfx::BufferFormat format) { | 87 size_t GetBufferSizeInBytes(const gfx::Size& size, gfx::BufferFormat format) { |
| 88 size_t size_in_bytes = 0; | 88 size_t size_in_bytes = 0; |
| 89 int num_planes = NumberOfPlanesForGpuMemoryBufferFormat(format); | 89 size_t num_planes = NumberOfPlanesForGpuMemoryBufferFormat(format); |
| 90 for (int i = 0; i < num_planes; ++i) { | 90 for (size_t i = 0; i < num_planes; ++i) { |
| 91 size_in_bytes += StrideInBytes(size.width(), format, i) * | 91 size_in_bytes += StrideInBytes(size.width(), format, i) * |
| 92 (size.height() / SubsamplingFactor(format, i)); | 92 (size.height() / SubsamplingFactor(format, i)); |
| 93 } | 93 } |
| 94 return size_in_bytes; | 94 return size_in_bytes; |
| 95 } | 95 } |
| 96 | 96 |
| 97 } // namespace | 97 } // namespace |
| 98 | 98 |
| 99 MojoGpuMemoryBufferImpl::MojoGpuMemoryBufferImpl( | 99 namespace gles2 { |
| 100 |
| 101 scoped_ptr<gfx::GpuMemoryBuffer> GpuMemoryBufferImpl::Create( |
| 100 const gfx::Size& size, | 102 const gfx::Size& size, |
| 101 gfx::BufferFormat format, | 103 gfx::BufferFormat format) { |
| 102 scoped_ptr<base::SharedMemory> shared_memory) | 104 std::vector<unsigned char> data(GetBufferSizeInBytes(size, format), 0); |
| 103 : size_(size), | 105 scoped_refptr<base::RefCountedBytes> bytes(new base::RefCountedBytes(data)); |
| 104 format_(format), | 106 return make_scoped_ptr<GpuMemoryBufferImpl>( |
| 105 shared_memory_(shared_memory.Pass()), | 107 new GpuMemoryBufferImpl(bytes.get(), size, format)); |
| 106 mapped_(false) {} | |
| 107 | |
| 108 MojoGpuMemoryBufferImpl::~MojoGpuMemoryBufferImpl() { | |
| 109 } | 108 } |
| 110 | 109 |
| 111 scoped_ptr<gfx::GpuMemoryBuffer> MojoGpuMemoryBufferImpl::Create( | 110 GpuMemoryBufferImpl::GpuMemoryBufferImpl(base::RefCountedBytes* bytes, |
| 112 const gfx::Size& size, | 111 const gfx::Size& size, |
| 113 gfx::BufferFormat format, | 112 gfx::BufferFormat format) |
| 114 gfx::BufferUsage usage) { | 113 : bytes_(bytes), |
| 115 size_t bytes = BufferSizeInBytes(size, format); | 114 size_(size), |
| 116 scoped_ptr<base::SharedMemory> shared_memory(new base::SharedMemory); | 115 format_(format), |
| 117 if (!shared_memory->CreateAnonymous(bytes)) | 116 mapped_(false) { |
| 118 return nullptr; | |
| 119 return make_scoped_ptr<gfx::GpuMemoryBuffer>( | |
| 120 new MojoGpuMemoryBufferImpl(size, format, shared_memory.Pass())); | |
| 121 } | 117 } |
| 122 | 118 |
| 123 MojoGpuMemoryBufferImpl* MojoGpuMemoryBufferImpl::FromClientBuffer( | 119 GpuMemoryBufferImpl::~GpuMemoryBufferImpl() { |
| 124 ClientBuffer buffer) { | |
| 125 return reinterpret_cast<MojoGpuMemoryBufferImpl*>(buffer); | |
| 126 } | 120 } |
| 127 | 121 |
| 128 bool MojoGpuMemoryBufferImpl::Map(void** data) { | 122 bool GpuMemoryBufferImpl::Map(void** data) { |
| 129 DCHECK(!mapped_); | |
| 130 if (!shared_memory_->Map(BufferSizeInBytes(size_, format_))) | |
| 131 return false; | |
| 132 mapped_ = true; | |
| 133 size_t offset = 0; | 123 size_t offset = 0; |
| 134 int num_planes = NumberOfPlanesForGpuMemoryBufferFormat(format_); | 124 size_t num_planes = NumberOfPlanesForGpuMemoryBufferFormat(format_); |
| 135 for (int i = 0; i < num_planes; ++i) { | 125 for (size_t i = 0; i < num_planes; ++i) { |
| 136 data[i] = reinterpret_cast<uint8*>(shared_memory_->memory()) + offset; | 126 data[i] = reinterpret_cast<uint8*>(&bytes_->data().front()) + offset; |
| 137 offset += StrideInBytes(size_.width(), format_, i) * | 127 offset += StrideInBytes(size_.width(), format_, i) * |
| 138 (size_.height() / SubsamplingFactor(format_, i)); | 128 (size_.height() / SubsamplingFactor(format_, i)); |
| 139 } | 129 } |
| 130 mapped_ = true; |
| 140 return true; | 131 return true; |
| 141 } | 132 } |
| 142 | 133 |
| 143 void MojoGpuMemoryBufferImpl::Unmap() { | 134 void GpuMemoryBufferImpl::Unmap() { |
| 144 DCHECK(mapped_); | |
| 145 shared_memory_->Unmap(); | |
| 146 mapped_ = false; | 135 mapped_ = false; |
| 147 } | 136 } |
| 148 | 137 |
| 149 bool MojoGpuMemoryBufferImpl::IsMapped() const { | 138 bool GpuMemoryBufferImpl::IsMapped() const { |
| 150 return mapped_; | 139 return mapped_; |
| 151 } | 140 } |
| 152 | 141 |
| 153 gfx::BufferFormat MojoGpuMemoryBufferImpl::GetFormat() const { | 142 gfx::BufferFormat GpuMemoryBufferImpl::GetFormat() const { |
| 154 return format_; | 143 return format_; |
| 155 } | 144 } |
| 156 | 145 |
| 157 void MojoGpuMemoryBufferImpl::GetStride(int* stride) const { | 146 gfx::GpuMemoryBufferId GpuMemoryBufferImpl::GetId() const { |
| 158 int num_planes = NumberOfPlanesForGpuMemoryBufferFormat(format_); | |
| 159 for (int i = 0; i < num_planes; ++i) | |
| 160 stride[i] = | |
| 161 base::checked_cast<int>(StrideInBytes(size_.width(), format_, i)); | |
| 162 } | |
| 163 | |
| 164 gfx::GpuMemoryBufferId MojoGpuMemoryBufferImpl::GetId() const { | |
| 165 return 0; | 147 return 0; |
| 166 } | 148 } |
| 167 | 149 |
| 168 gfx::GpuMemoryBufferHandle MojoGpuMemoryBufferImpl::GetHandle() const { | 150 void GpuMemoryBufferImpl::GetStride(int* stride) const { |
| 169 gfx::GpuMemoryBufferHandle handle; | 151 size_t num_planes = NumberOfPlanesForGpuMemoryBufferFormat(format_); |
| 170 handle.type = gfx::SHARED_MEMORY_BUFFER; | 152 for (size_t i = 0; i < num_planes; ++i) |
| 171 handle.handle = shared_memory_->handle(); | 153 stride[i] = StrideInBytes(size_.width(), format_, i); |
| 172 return handle; | |
| 173 } | 154 } |
| 174 | 155 |
| 175 ClientBuffer MojoGpuMemoryBufferImpl::AsClientBuffer() { | 156 gfx::GpuMemoryBufferHandle GpuMemoryBufferImpl::GetHandle() const { |
| 157 NOTREACHED(); |
| 158 return gfx::GpuMemoryBufferHandle(); |
| 159 } |
| 160 |
| 161 ClientBuffer GpuMemoryBufferImpl::AsClientBuffer() { |
| 176 return reinterpret_cast<ClientBuffer>(this); | 162 return reinterpret_cast<ClientBuffer>(this); |
| 177 } | 163 } |
| 178 | 164 |
| 179 } // namespace gles2 | 165 } // namespace gles2 |
| OLD | NEW |