Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(203)

Side by Side Diff: components/view_manager/gles2/gpu_memory_buffer_impl.cc

Issue 1245683004: Mandoline: Merge Surfaces and Views apps (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Rebased Created 5 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
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
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
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698