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

Side by Side Diff: gpu/command_buffer/tests/gl_manager.cc

Issue 1736093002: Add a workaround for copyTexImage2D as it is sometimes broken on OSX. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Comments from kbr. Created 4 years, 9 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 (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 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 "gpu/command_buffer/tests/gl_manager.h" 5 #include "gpu/command_buffer/tests/gl_manager.h"
6 6
7 #include <GLES2/gl2.h> 7 #include <GLES2/gl2.h>
8 #include <GLES2/gl2ext.h> 8 #include <GLES2/gl2ext.h>
9 #include <GLES2/gl2extchromium.h> 9 #include <GLES2/gl2extchromium.h>
10 #include <stddef.h> 10 #include <stddef.h>
11 #include <stdint.h> 11 #include <stdint.h>
12 12
13 #include <vector> 13 #include <vector>
14 14
15 #include "base/at_exit.h" 15 #include "base/at_exit.h"
16 #include "base/bind.h" 16 #include "base/bind.h"
17 #include "base/memory/ref_counted_memory.h" 17 #include "base/memory/ref_counted_memory.h"
18 #include "build/build_config.h"
18 #include "gpu/command_buffer/client/gles2_cmd_helper.h" 19 #include "gpu/command_buffer/client/gles2_cmd_helper.h"
19 #include "gpu/command_buffer/client/gles2_implementation.h" 20 #include "gpu/command_buffer/client/gles2_implementation.h"
20 #include "gpu/command_buffer/client/gles2_lib.h" 21 #include "gpu/command_buffer/client/gles2_lib.h"
21 #include "gpu/command_buffer/client/transfer_buffer.h" 22 #include "gpu/command_buffer/client/transfer_buffer.h"
22 #include "gpu/command_buffer/common/constants.h" 23 #include "gpu/command_buffer/common/constants.h"
23 #include "gpu/command_buffer/common/gles2_cmd_utils.h" 24 #include "gpu/command_buffer/common/gles2_cmd_utils.h"
24 #include "gpu/command_buffer/common/sync_token.h" 25 #include "gpu/command_buffer/common/sync_token.h"
25 #include "gpu/command_buffer/common/value_state.h" 26 #include "gpu/command_buffer/common/value_state.h"
26 #include "gpu/command_buffer/service/command_buffer_service.h" 27 #include "gpu/command_buffer/service/command_buffer_service.h"
27 #include "gpu/command_buffer/service/command_executor.h" 28 #include "gpu/command_buffer/service/command_executor.h"
28 #include "gpu/command_buffer/service/context_group.h" 29 #include "gpu/command_buffer/service/context_group.h"
29 #include "gpu/command_buffer/service/gl_context_virtual.h" 30 #include "gpu/command_buffer/service/gl_context_virtual.h"
30 #include "gpu/command_buffer/service/gles2_cmd_decoder.h" 31 #include "gpu/command_buffer/service/gles2_cmd_decoder.h"
31 #include "gpu/command_buffer/service/image_manager.h" 32 #include "gpu/command_buffer/service/image_manager.h"
32 #include "gpu/command_buffer/service/mailbox_manager_impl.h" 33 #include "gpu/command_buffer/service/mailbox_manager_impl.h"
33 #include "gpu/command_buffer/service/memory_tracking.h" 34 #include "gpu/command_buffer/service/memory_tracking.h"
34 #include "gpu/command_buffer/service/sync_point_manager.h" 35 #include "gpu/command_buffer/service/sync_point_manager.h"
35 #include "gpu/command_buffer/service/transfer_buffer_manager.h" 36 #include "gpu/command_buffer/service/transfer_buffer_manager.h"
36 #include "gpu/command_buffer/service/valuebuffer_manager.h" 37 #include "gpu/command_buffer/service/valuebuffer_manager.h"
37 #include "testing/gtest/include/gtest/gtest.h" 38 #include "testing/gtest/include/gtest/gtest.h"
38 #include "ui/gfx/buffer_format_util.h" 39 #include "ui/gfx/buffer_format_util.h"
39 #include "ui/gfx/gpu_memory_buffer.h" 40 #include "ui/gfx/gpu_memory_buffer.h"
40 #include "ui/gl/gl_context.h" 41 #include "ui/gl/gl_context.h"
41 #include "ui/gl/gl_image_ref_counted_memory.h" 42 #include "ui/gl/gl_image_ref_counted_memory.h"
42 #include "ui/gl/gl_share_group.h" 43 #include "ui/gl/gl_share_group.h"
43 #include "ui/gl/gl_surface.h" 44 #include "ui/gl/gl_surface.h"
44 45
46 #if defined(OS_MACOSX)
47 #include "ui/gfx/mac/io_surface.h"
48 #include "ui/gl/gl_image_io_surface.h"
49 #endif
50
45 namespace gpu { 51 namespace gpu {
46 namespace { 52 namespace {
47 53
48 uint64_t g_next_command_buffer_id = 0; 54 uint64_t g_next_command_buffer_id = 0;
49 55
50 class GpuMemoryBufferImpl : public gfx::GpuMemoryBuffer { 56 class GpuMemoryBufferImpl : public gfx::GpuMemoryBuffer {
51 public: 57 public:
52 GpuMemoryBufferImpl(base::RefCountedBytes* bytes, 58 GpuMemoryBufferImpl(base::RefCountedBytes* bytes,
53 const gfx::Size& size, 59 const gfx::Size& size,
54 gfx::BufferFormat format) 60 gfx::BufferFormat format)
(...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after
94 100
95 base::RefCountedBytes* bytes() { return bytes_.get(); } 101 base::RefCountedBytes* bytes() { return bytes_.get(); }
96 102
97 private: 103 private:
98 bool mapped_; 104 bool mapped_;
99 scoped_refptr<base::RefCountedBytes> bytes_; 105 scoped_refptr<base::RefCountedBytes> bytes_;
100 const gfx::Size size_; 106 const gfx::Size size_;
101 gfx::BufferFormat format_; 107 gfx::BufferFormat format_;
102 }; 108 };
103 109
110 #if defined(OS_MACOSX)
111 class IOSurfaceGpuMemoryBuffer : public gfx::GpuMemoryBuffer {
112 public:
113 IOSurfaceGpuMemoryBuffer(
114 const gfx::Size& size,
Zhenyao Mo 2016/03/15 17:40:47 nit: wrong indent
erikchen 2016/03/15 18:08:38 Done.
115 gfx::BufferFormat format)
116 : mapped_(false), size_(size), format_(format) {
117 iosurface_ = gfx::CreateIOSurface(size, gfx::BufferFormat::BGRA_8888);
118 }
119
120 ~IOSurfaceGpuMemoryBuffer() override {
121 CFRelease(iosurface_);
122 }
123
124 static IOSurfaceGpuMemoryBuffer* FromClientBuffer(ClientBuffer buffer) {
125 return reinterpret_cast<IOSurfaceGpuMemoryBuffer*>(buffer);
126 }
127
128 // Overridden from gfx::GpuMemoryBuffer:
129 bool Map() override {
130 DCHECK(!mapped_);
131 mapped_ = true;
132 return true;
133 }
134 void* memory(size_t plane) override {
135 DCHECK(mapped_);
136 DCHECK_LT(plane, gfx::NumberOfPlanesForBufferFormat(format_));
137 return IOSurfaceGetBaseAddressOfPlane(iosurface_, plane);
138 }
139 void Unmap() override {
140 DCHECK(mapped_);
141 mapped_ = false;
142 }
143 gfx::Size GetSize() const override { return size_; }
144 gfx::BufferFormat GetFormat() const override { return format_; }
145 int stride(size_t plane) const override {
146 DCHECK_LT(plane, gfx::NumberOfPlanesForBufferFormat(format_));
147 return IOSurfaceGetWidthOfPlane(iosurface_, plane);
148 }
149 gfx::GpuMemoryBufferId GetId() const override {
150 NOTREACHED();
151 return gfx::GpuMemoryBufferId(0);
152 }
153 gfx::GpuMemoryBufferHandle GetHandle() const override {
154 NOTREACHED();
155 return gfx::GpuMemoryBufferHandle();
156 }
157 ClientBuffer AsClientBuffer() override {
158 return reinterpret_cast<ClientBuffer>(this);
159 }
160
161 IOSurfaceRef iosurface() { return iosurface_; }
162
163 private:
164 bool mapped_;
165 IOSurfaceRef iosurface_;
166 const gfx::Size size_;
167 gfx::BufferFormat format_;
168 };
169 #endif // defined(OS_MACOSX)
170
104 } // namespace 171 } // namespace
105 172
106 int GLManager::use_count_; 173 int GLManager::use_count_;
107 scoped_refptr<gfx::GLShareGroup>* GLManager::base_share_group_; 174 scoped_refptr<gfx::GLShareGroup>* GLManager::base_share_group_;
108 scoped_refptr<gfx::GLSurface>* GLManager::base_surface_; 175 scoped_refptr<gfx::GLSurface>* GLManager::base_surface_;
109 scoped_refptr<gfx::GLContext>* GLManager::base_context_; 176 scoped_refptr<gfx::GLContext>* GLManager::base_context_;
110 177
111 GLManager::Options::Options() 178 GLManager::Options::Options()
112 : size(4, 4), 179 : size(4, 4),
113 sync_point_manager(NULL), 180 sync_point_manager(NULL),
(...skipping 28 matching lines...) Expand all
142 delete base_surface_; 209 delete base_surface_;
143 base_surface_ = NULL; 210 base_surface_ = NULL;
144 } 211 }
145 if (base_context_) { 212 if (base_context_) {
146 delete base_context_; 213 delete base_context_;
147 base_context_ = NULL; 214 base_context_ = NULL;
148 } 215 }
149 } 216 }
150 } 217 }
151 218
152 // static
153 scoped_ptr<gfx::GpuMemoryBuffer> GLManager::CreateGpuMemoryBuffer( 219 scoped_ptr<gfx::GpuMemoryBuffer> GLManager::CreateGpuMemoryBuffer(
154 const gfx::Size& size, 220 const gfx::Size& size,
155 gfx::BufferFormat format) { 221 gfx::BufferFormat format) {
222 #if defined(OS_MACOSX)
223 if (use_iosurface_memory_buffers_) {
224 return make_scoped_ptr<gfx::GpuMemoryBuffer>(
225 new IOSurfaceGpuMemoryBuffer(size, format));
226 }
227 #endif // defined(OS_MACOSX)
156 std::vector<uint8_t> data(gfx::BufferSizeForBufferFormat(size, format), 0); 228 std::vector<uint8_t> data(gfx::BufferSizeForBufferFormat(size, format), 0);
157 scoped_refptr<base::RefCountedBytes> bytes(new base::RefCountedBytes(data)); 229 scoped_refptr<base::RefCountedBytes> bytes(new base::RefCountedBytes(data));
158 return make_scoped_ptr<gfx::GpuMemoryBuffer>( 230 return make_scoped_ptr<gfx::GpuMemoryBuffer>(
159 new GpuMemoryBufferImpl(bytes.get(), size, format)); 231 new GpuMemoryBufferImpl(bytes.get(), size, format));
160 } 232 }
161 233
162 void GLManager::Initialize(const GLManager::Options& options) { 234 void GLManager::Initialize(const GLManager::Options& options) {
163 InitializeWithCommandLine(options, nullptr); 235 InitializeWithCommandLine(options, nullptr);
164 } 236 }
165 237
(...skipping 196 matching lines...) Expand 10 before | Expand all | Expand 10 after
362 } 434 }
363 435
364 void GLManager::MakeCurrent() { 436 void GLManager::MakeCurrent() {
365 ::gles2::SetGLContext(gles2_implementation_.get()); 437 ::gles2::SetGLContext(gles2_implementation_.get());
366 } 438 }
367 439
368 void GLManager::SetSurface(gfx::GLSurface* surface) { 440 void GLManager::SetSurface(gfx::GLSurface* surface) {
369 decoder_->SetSurface(surface); 441 decoder_->SetSurface(surface);
370 } 442 }
371 443
444 void GLManager::SetUseIOSurfaceMemoryBuffers(
445 bool use_iosurface_memory_buffers) {
446 use_iosurface_memory_buffers_ = use_iosurface_memory_buffers;
447 }
448
372 void GLManager::Destroy() { 449 void GLManager::Destroy() {
373 if (gles2_implementation_.get()) { 450 if (gles2_implementation_.get()) {
374 MakeCurrent(); 451 MakeCurrent();
375 EXPECT_TRUE(glGetError() == GL_NONE); 452 EXPECT_TRUE(glGetError() == GL_NONE);
376 gles2_implementation_->Flush(); 453 gles2_implementation_->Flush();
377 gles2_implementation_.reset(); 454 gles2_implementation_.reset();
378 } 455 }
379 transfer_buffer_.reset(); 456 transfer_buffer_.reset();
380 gles2_helper_.reset(); 457 gles2_helper_.reset();
381 command_buffer_.reset(); 458 command_buffer_.reset();
(...skipping 60 matching lines...) Expand 10 before | Expand all | Expand 10 after
442 } 519 }
443 520
444 Capabilities GLManager::GetCapabilities() { 521 Capabilities GLManager::GetCapabilities() {
445 return decoder_->GetCapabilities(); 522 return decoder_->GetCapabilities();
446 } 523 }
447 524
448 int32_t GLManager::CreateImage(ClientBuffer buffer, 525 int32_t GLManager::CreateImage(ClientBuffer buffer,
449 size_t width, 526 size_t width,
450 size_t height, 527 size_t height,
451 unsigned internalformat) { 528 unsigned internalformat) {
452 GpuMemoryBufferImpl* gpu_memory_buffer = 529 gfx::Size size(width, height);
453 GpuMemoryBufferImpl::FromClientBuffer(buffer); 530 scoped_refptr<gl::GLImage> gl_image;
454 531
455 scoped_refptr<gl::GLImageRefCountedMemory> image( 532 #if defined(OS_MACOSX)
456 new gl::GLImageRefCountedMemory(gfx::Size(width, height), 533 if (use_iosurface_memory_buffers_) {
457 internalformat)); 534 IOSurfaceGpuMemoryBuffer* gpu_memory_buffer =
458 if (!image->Initialize(gpu_memory_buffer->bytes(), 535 IOSurfaceGpuMemoryBuffer::FromClientBuffer(buffer);
459 gpu_memory_buffer->GetFormat())) { 536 scoped_refptr<gl::GLImageIOSurface> image(
460 return -1; 537 new gl::GLImageIOSurface(size, internalformat));
538 if (!image->Initialize(gpu_memory_buffer->iosurface(),
539 gfx::GenericSharedMemoryId(1),
540 gfx::BufferFormat::BGRA_8888)) {
541 return -1;
542 }
543 gl_image = image;
544 }
545 #endif // defined(OS_MACOSX)
546 if (!gl_image) {
547 GpuMemoryBufferImpl* gpu_memory_buffer =
548 GpuMemoryBufferImpl::FromClientBuffer(buffer);
549
550 scoped_refptr<gl::GLImageRefCountedMemory> image(
551 new gl::GLImageRefCountedMemory(size, internalformat));
552 if (!image->Initialize(gpu_memory_buffer->bytes(),
553 gpu_memory_buffer->GetFormat())) {
554 return -1;
555 }
556 gl_image = image;
461 } 557 }
462 558
463 static int32_t next_id = 1; 559 static int32_t next_id = 1;
464 int32_t new_id = next_id++; 560 int32_t new_id = next_id++;
465
466 gpu::gles2::ImageManager* image_manager = decoder_->GetImageManager(); 561 gpu::gles2::ImageManager* image_manager = decoder_->GetImageManager();
467 DCHECK(image_manager); 562 DCHECK(image_manager);
468 image_manager->AddImage(image.get(), new_id); 563 image_manager->AddImage(gl_image.get(), new_id);
469 return new_id; 564 return new_id;
470 } 565 }
471 566
472 int32_t GLManager::CreateGpuMemoryBufferImage(size_t width, 567 int32_t GLManager::CreateGpuMemoryBufferImage(size_t width,
473 size_t height, 568 size_t height,
474 unsigned internalformat, 569 unsigned internalformat,
475 unsigned usage) { 570 unsigned usage) {
476 DCHECK_EQ(usage, static_cast<unsigned>(GL_READ_WRITE_CHROMIUM)); 571 DCHECK_EQ(usage, static_cast<unsigned>(GL_READ_WRITE_CHROMIUM));
477 scoped_ptr<gfx::GpuMemoryBuffer> buffer = GLManager::CreateGpuMemoryBuffer( 572 scoped_ptr<gfx::GpuMemoryBuffer> buffer = CreateGpuMemoryBuffer(
478 gfx::Size(width, height), gfx::BufferFormat::RGBA_8888); 573 gfx::Size(width, height), gfx::BufferFormat::RGBA_8888);
479 return CreateImage(buffer->AsClientBuffer(), width, height, internalformat); 574 return CreateImage(buffer->AsClientBuffer(), width, height, internalformat);
480 } 575 }
481 576
482 void GLManager::DestroyImage(int32_t id) { 577 void GLManager::DestroyImage(int32_t id) {
483 gpu::gles2::ImageManager* image_manager = decoder_->GetImageManager(); 578 gpu::gles2::ImageManager* image_manager = decoder_->GetImageManager();
484 DCHECK(image_manager); 579 DCHECK(image_manager);
485 image_manager->RemoveImage(id); 580 image_manager->RemoveImage(id);
486 } 581 }
487 582
(...skipping 58 matching lines...) Expand 10 before | Expand all | Expand 10 after
546 641
547 // Something went wrong, just run the callback now. 642 // Something went wrong, just run the callback now.
548 callback.Run(); 643 callback.Run();
549 } 644 }
550 645
551 bool GLManager::CanWaitUnverifiedSyncToken(const gpu::SyncToken* sync_token) { 646 bool GLManager::CanWaitUnverifiedSyncToken(const gpu::SyncToken* sync_token) {
552 return false; 647 return false;
553 } 648 }
554 649
555 } // namespace gpu 650 } // namespace gpu
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698