| OLD | NEW |
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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 "content/common/gpu/client/gpu_memory_buffer_impl.h" | 5 #include "content/common/gpu/client/gpu_memory_buffer_impl.h" |
| 6 | 6 |
| 7 #include "base/logging.h" | 7 #include "base/logging.h" |
| 8 #include "base/numerics/safe_math.h" | 8 #include "base/numerics/safe_math.h" |
| 9 #include "content/common/gpu/client/gpu_memory_buffer_impl_shared_memory.h" | 9 #include "content/common/gpu/client/gpu_memory_buffer_impl_shared_memory.h" |
| 10 #include "ui/gl/gl_bindings.h" | 10 #include "ui/gl/gl_bindings.h" |
| 11 | 11 |
| 12 #if defined(OS_MACOSX) | 12 #if defined(OS_MACOSX) |
| 13 #include "content/common/gpu/client/gpu_memory_buffer_impl_io_surface.h" | 13 #include "content/common/gpu/client/gpu_memory_buffer_impl_io_surface.h" |
| 14 #endif | 14 #endif |
| 15 | 15 |
| 16 #if defined(OS_ANDROID) | 16 #if defined(OS_ANDROID) |
| 17 #include "content/common/gpu/client/gpu_memory_buffer_impl_surface_texture.h" | 17 #include "content/common/gpu/client/gpu_memory_buffer_impl_surface_texture.h" |
| 18 #endif | 18 #endif |
| 19 | 19 |
| 20 #if defined(USE_OZONE) | 20 #if defined(USE_OZONE) |
| 21 #include "content/common/gpu/client/gpu_memory_buffer_impl_ozone_native_pixmap.h
" | 21 #include "content/common/gpu/client/gpu_memory_buffer_impl_ozone_native_pixmap.h
" |
| 22 #endif | 22 #endif |
| 23 | 23 |
| 24 namespace content { | 24 namespace content { |
| 25 | 25 |
| 26 GpuMemoryBufferImpl::GpuMemoryBufferImpl(gfx::GpuMemoryBufferId id, | 26 GpuMemoryBufferImpl::GpuMemoryBufferImpl(gfx::GpuMemoryBufferId id, |
| 27 const gfx::Size& size, | 27 const gfx::Size& size, |
| 28 Format format, | 28 gfx::BufferFormat format, |
| 29 const DestructionCallback& callback) | 29 const DestructionCallback& callback) |
| 30 : id_(id), | 30 : id_(id), |
| 31 size_(size), | 31 size_(size), |
| 32 format_(format), | 32 format_(format), |
| 33 callback_(callback), | 33 callback_(callback), |
| 34 mapped_(false), | 34 mapped_(false), |
| 35 destruction_sync_point_(0) { | 35 destruction_sync_point_(0) {} |
| 36 } | |
| 37 | 36 |
| 38 GpuMemoryBufferImpl::~GpuMemoryBufferImpl() { | 37 GpuMemoryBufferImpl::~GpuMemoryBufferImpl() { |
| 39 DCHECK(!mapped_); | 38 DCHECK(!mapped_); |
| 40 callback_.Run(destruction_sync_point_); | 39 callback_.Run(destruction_sync_point_); |
| 41 } | 40 } |
| 42 | 41 |
| 43 // static | 42 // static |
| 44 scoped_ptr<GpuMemoryBufferImpl> GpuMemoryBufferImpl::CreateFromHandle( | 43 scoped_ptr<GpuMemoryBufferImpl> GpuMemoryBufferImpl::CreateFromHandle( |
| 45 const gfx::GpuMemoryBufferHandle& handle, | 44 const gfx::GpuMemoryBufferHandle& handle, |
| 46 const gfx::Size& size, | 45 const gfx::Size& size, |
| 47 Format format, | 46 gfx::BufferFormat format, |
| 48 Usage usage, | 47 gfx::BufferUsage usage, |
| 49 const DestructionCallback& callback) { | 48 const DestructionCallback& callback) { |
| 50 switch (handle.type) { | 49 switch (handle.type) { |
| 51 case gfx::SHARED_MEMORY_BUFFER: | 50 case gfx::SHARED_MEMORY_BUFFER: |
| 52 return GpuMemoryBufferImplSharedMemory::CreateFromHandle( | 51 return GpuMemoryBufferImplSharedMemory::CreateFromHandle( |
| 53 handle, size, format, callback); | 52 handle, size, format, callback); |
| 54 #if defined(OS_MACOSX) | 53 #if defined(OS_MACOSX) |
| 55 case gfx::IO_SURFACE_BUFFER: | 54 case gfx::IO_SURFACE_BUFFER: |
| 56 return GpuMemoryBufferImplIOSurface::CreateFromHandle( | 55 return GpuMemoryBufferImplIOSurface::CreateFromHandle( |
| 57 handle, size, format, usage, callback); | 56 handle, size, format, usage, callback); |
| 58 #endif | 57 #endif |
| (...skipping 14 matching lines...) Expand all Loading... |
| 73 } | 72 } |
| 74 | 73 |
| 75 // static | 74 // static |
| 76 GpuMemoryBufferImpl* GpuMemoryBufferImpl::FromClientBuffer( | 75 GpuMemoryBufferImpl* GpuMemoryBufferImpl::FromClientBuffer( |
| 77 ClientBuffer buffer) { | 76 ClientBuffer buffer) { |
| 78 return reinterpret_cast<GpuMemoryBufferImpl*>(buffer); | 77 return reinterpret_cast<GpuMemoryBufferImpl*>(buffer); |
| 79 } | 78 } |
| 80 | 79 |
| 81 // static | 80 // static |
| 82 size_t GpuMemoryBufferImpl::NumberOfPlanesForGpuMemoryBufferFormat( | 81 size_t GpuMemoryBufferImpl::NumberOfPlanesForGpuMemoryBufferFormat( |
| 83 Format format) { | 82 gfx::BufferFormat format) { |
| 84 switch (format) { | 83 switch (format) { |
| 85 case ATC: | 84 case gfx::BufferFormat::ATC: |
| 86 case ATCIA: | 85 case gfx::BufferFormat::ATCIA: |
| 87 case DXT1: | 86 case gfx::BufferFormat::DXT1: |
| 88 case DXT5: | 87 case gfx::BufferFormat::DXT5: |
| 89 case ETC1: | 88 case gfx::BufferFormat::ETC1: |
| 90 case R_8: | 89 case gfx::BufferFormat::R_8: |
| 91 case RGBA_4444: | 90 case gfx::BufferFormat::RGBA_4444: |
| 92 case RGBA_8888: | 91 case gfx::BufferFormat::RGBA_8888: |
| 93 case RGBX_8888: | 92 case gfx::BufferFormat::RGBX_8888: |
| 94 case BGRA_8888: | 93 case gfx::BufferFormat::BGRA_8888: |
| 95 return 1; | 94 return 1; |
| 96 case YUV_420: | 95 case gfx::BufferFormat::YUV_420: |
| 97 return 3; | 96 return 3; |
| 98 } | 97 } |
| 99 NOTREACHED(); | 98 NOTREACHED(); |
| 100 return 0; | 99 return 0; |
| 101 } | 100 } |
| 102 | 101 |
| 103 // static | 102 // static |
| 104 size_t GpuMemoryBufferImpl::SubsamplingFactor(Format format, int plane) { | 103 size_t GpuMemoryBufferImpl::SubsamplingFactor(gfx::BufferFormat format, |
| 104 int plane) { |
| 105 switch (format) { | 105 switch (format) { |
| 106 case ATC: | 106 case gfx::BufferFormat::ATC: |
| 107 case ATCIA: | 107 case gfx::BufferFormat::ATCIA: |
| 108 case DXT1: | 108 case gfx::BufferFormat::DXT1: |
| 109 case DXT5: | 109 case gfx::BufferFormat::DXT5: |
| 110 case ETC1: | 110 case gfx::BufferFormat::ETC1: |
| 111 case R_8: | 111 case gfx::BufferFormat::R_8: |
| 112 case RGBA_4444: | 112 case gfx::BufferFormat::RGBA_4444: |
| 113 case RGBA_8888: | 113 case gfx::BufferFormat::RGBA_8888: |
| 114 case RGBX_8888: | 114 case gfx::BufferFormat::RGBX_8888: |
| 115 case BGRA_8888: | 115 case gfx::BufferFormat::BGRA_8888: |
| 116 return 1; | 116 return 1; |
| 117 case YUV_420: { | 117 case gfx::BufferFormat::YUV_420: { |
| 118 static size_t factor[] = {1, 2, 2}; | 118 static size_t factor[] = {1, 2, 2}; |
| 119 DCHECK_LT(static_cast<size_t>(plane), arraysize(factor)); | 119 DCHECK_LT(static_cast<size_t>(plane), arraysize(factor)); |
| 120 return factor[plane]; | 120 return factor[plane]; |
| 121 } | 121 } |
| 122 } | 122 } |
| 123 NOTREACHED(); | 123 NOTREACHED(); |
| 124 return 0; | 124 return 0; |
| 125 } | 125 } |
| 126 | 126 |
| 127 // static | 127 // static |
| 128 bool GpuMemoryBufferImpl::RowSizeInBytes(size_t width, | 128 bool GpuMemoryBufferImpl::RowSizeInBytes(size_t width, |
| 129 Format format, | 129 gfx::BufferFormat format, |
| 130 int plane, | 130 int plane, |
| 131 size_t* size_in_bytes) { | 131 size_t* size_in_bytes) { |
| 132 base::CheckedNumeric<size_t> checked_size = width; | 132 base::CheckedNumeric<size_t> checked_size = width; |
| 133 switch (format) { | 133 switch (format) { |
| 134 case ATCIA: | 134 case gfx::BufferFormat::ATCIA: |
| 135 case DXT5: | 135 case gfx::BufferFormat::DXT5: |
| 136 DCHECK_EQ(plane, 0); | 136 DCHECK_EQ(plane, 0); |
| 137 *size_in_bytes = width; | 137 *size_in_bytes = width; |
| 138 return true; | 138 return true; |
| 139 case ATC: | 139 case gfx::BufferFormat::ATC: |
| 140 case DXT1: | 140 case gfx::BufferFormat::DXT1: |
| 141 case ETC1: | 141 case gfx::BufferFormat::ETC1: |
| 142 DCHECK_EQ(plane, 0); | 142 DCHECK_EQ(plane, 0); |
| 143 DCHECK_EQ(width % 2, 0u); | 143 DCHECK_EQ(width % 2, 0u); |
| 144 *size_in_bytes = width / 2; | 144 *size_in_bytes = width / 2; |
| 145 return true; | 145 return true; |
| 146 case R_8: | 146 case gfx::BufferFormat::R_8: |
| 147 checked_size += 3; | 147 checked_size += 3; |
| 148 if (!checked_size.IsValid()) | 148 if (!checked_size.IsValid()) |
| 149 return false; | 149 return false; |
| 150 *size_in_bytes = checked_size.ValueOrDie() & ~0x3; | 150 *size_in_bytes = checked_size.ValueOrDie() & ~0x3; |
| 151 return true; | 151 return true; |
| 152 case RGBA_4444: | 152 case gfx::BufferFormat::RGBA_4444: |
| 153 checked_size *= 2; | 153 checked_size *= 2; |
| 154 if (!checked_size.IsValid()) | 154 if (!checked_size.IsValid()) |
| 155 return false; | 155 return false; |
| 156 *size_in_bytes = checked_size.ValueOrDie(); | 156 *size_in_bytes = checked_size.ValueOrDie(); |
| 157 case RGBX_8888: | 157 case gfx::BufferFormat::RGBX_8888: |
| 158 case RGBA_8888: | 158 case gfx::BufferFormat::RGBA_8888: |
| 159 case BGRA_8888: | 159 case gfx::BufferFormat::BGRA_8888: |
| 160 checked_size *= 4; | 160 checked_size *= 4; |
| 161 if (!checked_size.IsValid()) | 161 if (!checked_size.IsValid()) |
| 162 return false; | 162 return false; |
| 163 *size_in_bytes = checked_size.ValueOrDie(); | 163 *size_in_bytes = checked_size.ValueOrDie(); |
| 164 return true; | 164 return true; |
| 165 case YUV_420: | 165 case gfx::BufferFormat::YUV_420: |
| 166 DCHECK_EQ(width % 2, 0u); | 166 DCHECK_EQ(width % 2, 0u); |
| 167 *size_in_bytes = width / SubsamplingFactor(format, plane); | 167 *size_in_bytes = width / SubsamplingFactor(format, plane); |
| 168 return true; | 168 return true; |
| 169 } | 169 } |
| 170 NOTREACHED(); | 170 NOTREACHED(); |
| 171 return false; | 171 return false; |
| 172 } | 172 } |
| 173 | 173 |
| 174 // static | 174 // static |
| 175 bool GpuMemoryBufferImpl::BufferSizeInBytes(const gfx::Size& size, | 175 bool GpuMemoryBufferImpl::BufferSizeInBytes(const gfx::Size& size, |
| 176 Format format, | 176 gfx::BufferFormat format, |
| 177 size_t* size_in_bytes) { | 177 size_t* size_in_bytes) { |
| 178 base::CheckedNumeric<size_t> checked_size = 0; | 178 base::CheckedNumeric<size_t> checked_size = 0; |
| 179 size_t num_planes = NumberOfPlanesForGpuMemoryBufferFormat(format); | 179 size_t num_planes = NumberOfPlanesForGpuMemoryBufferFormat(format); |
| 180 for (size_t i = 0; i < num_planes; ++i) { | 180 for (size_t i = 0; i < num_planes; ++i) { |
| 181 size_t row_size_in_bytes = 0; | 181 size_t row_size_in_bytes = 0; |
| 182 if (!RowSizeInBytes(size.width(), format, i, &row_size_in_bytes)) | 182 if (!RowSizeInBytes(size.width(), format, i, &row_size_in_bytes)) |
| 183 return false; | 183 return false; |
| 184 base::CheckedNumeric<size_t> checked_plane_size = row_size_in_bytes; | 184 base::CheckedNumeric<size_t> checked_plane_size = row_size_in_bytes; |
| 185 checked_plane_size *= size.height() / SubsamplingFactor(format, i); | 185 checked_plane_size *= size.height() / SubsamplingFactor(format, i); |
| 186 if (!checked_plane_size.IsValid()) | 186 if (!checked_plane_size.IsValid()) |
| 187 return false; | 187 return false; |
| 188 checked_size += checked_plane_size.ValueOrDie(); | 188 checked_size += checked_plane_size.ValueOrDie(); |
| 189 if (!checked_size.IsValid()) | 189 if (!checked_size.IsValid()) |
| 190 return false; | 190 return false; |
| 191 } | 191 } |
| 192 *size_in_bytes = checked_size.ValueOrDie(); | 192 *size_in_bytes = checked_size.ValueOrDie(); |
| 193 return true; | 193 return true; |
| 194 } | 194 } |
| 195 | 195 |
| 196 gfx::GpuMemoryBuffer::Format GpuMemoryBufferImpl::GetFormat() const { | 196 gfx::BufferFormat GpuMemoryBufferImpl::GetFormat() const { |
| 197 return format_; | 197 return format_; |
| 198 } | 198 } |
| 199 | 199 |
| 200 bool GpuMemoryBufferImpl::IsMapped() const { | 200 bool GpuMemoryBufferImpl::IsMapped() const { |
| 201 return mapped_; | 201 return mapped_; |
| 202 } | 202 } |
| 203 | 203 |
| 204 gfx::GpuMemoryBufferId GpuMemoryBufferImpl::GetId() const { | 204 gfx::GpuMemoryBufferId GpuMemoryBufferImpl::GetId() const { |
| 205 return id_; | 205 return id_; |
| 206 } | 206 } |
| 207 | 207 |
| 208 ClientBuffer GpuMemoryBufferImpl::AsClientBuffer() { | 208 ClientBuffer GpuMemoryBufferImpl::AsClientBuffer() { |
| 209 return reinterpret_cast<ClientBuffer>(this); | 209 return reinterpret_cast<ClientBuffer>(this); |
| 210 } | 210 } |
| 211 | 211 |
| 212 } // namespace content | 212 } // namespace content |
| OLD | NEW |