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

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: Compile error, nits. 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
« no previous file with comments | « gpu/command_buffer/tests/gl_manager.h ('k') | gpu/command_buffer/tests/gl_test_utils.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
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 {
Ken Russell (switch to Gerrit) 2016/03/16 01:21:49 Is this new code path tested?
erikchen 2016/03/16 01:27:25 I'm not sure what you mean? If you're referring to
Ken Russell (switch to Gerrit) 2016/03/16 01:30:54 Sorry for the stupid question, but I didn't realiz
112 public:
113 IOSurfaceGpuMemoryBuffer(const gfx::Size& size, gfx::BufferFormat format)
114 : mapped_(false), size_(size), format_(format) {
115 iosurface_ = gfx::CreateIOSurface(size, gfx::BufferFormat::BGRA_8888);
116 }
117
118 ~IOSurfaceGpuMemoryBuffer() override {
119 CFRelease(iosurface_);
120 }
121
122 static IOSurfaceGpuMemoryBuffer* FromClientBuffer(ClientBuffer buffer) {
123 return reinterpret_cast<IOSurfaceGpuMemoryBuffer*>(buffer);
124 }
125
126 // Overridden from gfx::GpuMemoryBuffer:
127 bool Map() override {
128 DCHECK(!mapped_);
129 mapped_ = true;
130 return true;
131 }
132 void* memory(size_t plane) override {
133 DCHECK(mapped_);
134 DCHECK_LT(plane, gfx::NumberOfPlanesForBufferFormat(format_));
135 return IOSurfaceGetBaseAddressOfPlane(iosurface_, plane);
136 }
137 void Unmap() override {
138 DCHECK(mapped_);
139 mapped_ = false;
140 }
141 gfx::Size GetSize() const override { return size_; }
142 gfx::BufferFormat GetFormat() const override { return format_; }
143 int stride(size_t plane) const override {
144 DCHECK_LT(plane, gfx::NumberOfPlanesForBufferFormat(format_));
145 return IOSurfaceGetWidthOfPlane(iosurface_, plane);
146 }
147 gfx::GpuMemoryBufferId GetId() const override {
148 NOTREACHED();
149 return gfx::GpuMemoryBufferId(0);
150 }
151 gfx::GpuMemoryBufferHandle GetHandle() const override {
152 NOTREACHED();
153 return gfx::GpuMemoryBufferHandle();
154 }
155 ClientBuffer AsClientBuffer() override {
156 return reinterpret_cast<ClientBuffer>(this);
157 }
158
159 IOSurfaceRef iosurface() { return iosurface_; }
160
161 private:
162 bool mapped_;
163 IOSurfaceRef iosurface_;
164 const gfx::Size size_;
165 gfx::BufferFormat format_;
166 };
167 #endif // defined(OS_MACOSX)
168
104 } // namespace 169 } // namespace
105 170
106 int GLManager::use_count_; 171 int GLManager::use_count_;
107 scoped_refptr<gfx::GLShareGroup>* GLManager::base_share_group_; 172 scoped_refptr<gfx::GLShareGroup>* GLManager::base_share_group_;
108 scoped_refptr<gfx::GLSurface>* GLManager::base_surface_; 173 scoped_refptr<gfx::GLSurface>* GLManager::base_surface_;
109 scoped_refptr<gfx::GLContext>* GLManager::base_context_; 174 scoped_refptr<gfx::GLContext>* GLManager::base_context_;
110 175
111 GLManager::Options::Options() 176 GLManager::Options::Options()
112 : size(4, 4), 177 : size(4, 4),
113 sync_point_manager(NULL), 178 sync_point_manager(NULL),
(...skipping 28 matching lines...) Expand all
142 delete base_surface_; 207 delete base_surface_;
143 base_surface_ = NULL; 208 base_surface_ = NULL;
144 } 209 }
145 if (base_context_) { 210 if (base_context_) {
146 delete base_context_; 211 delete base_context_;
147 base_context_ = NULL; 212 base_context_ = NULL;
148 } 213 }
149 } 214 }
150 } 215 }
151 216
152 // static
153 scoped_ptr<gfx::GpuMemoryBuffer> GLManager::CreateGpuMemoryBuffer( 217 scoped_ptr<gfx::GpuMemoryBuffer> GLManager::CreateGpuMemoryBuffer(
154 const gfx::Size& size, 218 const gfx::Size& size,
155 gfx::BufferFormat format) { 219 gfx::BufferFormat format) {
220 #if defined(OS_MACOSX)
221 if (use_iosurface_memory_buffers_) {
222 return make_scoped_ptr<gfx::GpuMemoryBuffer>(
223 new IOSurfaceGpuMemoryBuffer(size, format));
224 }
225 #endif // defined(OS_MACOSX)
156 std::vector<uint8_t> data(gfx::BufferSizeForBufferFormat(size, format), 0); 226 std::vector<uint8_t> data(gfx::BufferSizeForBufferFormat(size, format), 0);
157 scoped_refptr<base::RefCountedBytes> bytes(new base::RefCountedBytes(data)); 227 scoped_refptr<base::RefCountedBytes> bytes(new base::RefCountedBytes(data));
158 return make_scoped_ptr<gfx::GpuMemoryBuffer>( 228 return make_scoped_ptr<gfx::GpuMemoryBuffer>(
159 new GpuMemoryBufferImpl(bytes.get(), size, format)); 229 new GpuMemoryBufferImpl(bytes.get(), size, format));
160 } 230 }
161 231
162 void GLManager::Initialize(const GLManager::Options& options) { 232 void GLManager::Initialize(const GLManager::Options& options) {
163 InitializeWithCommandLine(options, nullptr); 233 InitializeWithCommandLine(options, nullptr);
164 } 234 }
165 235
(...skipping 276 matching lines...) Expand 10 before | Expand all | Expand 10 after
442 } 512 }
443 513
444 Capabilities GLManager::GetCapabilities() { 514 Capabilities GLManager::GetCapabilities() {
445 return decoder_->GetCapabilities(); 515 return decoder_->GetCapabilities();
446 } 516 }
447 517
448 int32_t GLManager::CreateImage(ClientBuffer buffer, 518 int32_t GLManager::CreateImage(ClientBuffer buffer,
449 size_t width, 519 size_t width,
450 size_t height, 520 size_t height,
451 unsigned internalformat) { 521 unsigned internalformat) {
452 GpuMemoryBufferImpl* gpu_memory_buffer = 522 gfx::Size size(width, height);
453 GpuMemoryBufferImpl::FromClientBuffer(buffer); 523 scoped_refptr<gl::GLImage> gl_image;
454 524
455 scoped_refptr<gl::GLImageRefCountedMemory> image( 525 #if defined(OS_MACOSX)
456 new gl::GLImageRefCountedMemory(gfx::Size(width, height), 526 if (use_iosurface_memory_buffers_) {
457 internalformat)); 527 IOSurfaceGpuMemoryBuffer* gpu_memory_buffer =
458 if (!image->Initialize(gpu_memory_buffer->bytes(), 528 IOSurfaceGpuMemoryBuffer::FromClientBuffer(buffer);
459 gpu_memory_buffer->GetFormat())) { 529 scoped_refptr<gl::GLImageIOSurface> image(
460 return -1; 530 new gl::GLImageIOSurface(size, internalformat));
531 if (!image->Initialize(gpu_memory_buffer->iosurface(),
532 gfx::GenericSharedMemoryId(1),
533 gfx::BufferFormat::BGRA_8888)) {
534 return -1;
535 }
536 gl_image = image;
537 }
538 #endif // defined(OS_MACOSX)
539 if (!gl_image) {
540 GpuMemoryBufferImpl* gpu_memory_buffer =
541 GpuMemoryBufferImpl::FromClientBuffer(buffer);
542
543 scoped_refptr<gl::GLImageRefCountedMemory> image(
544 new gl::GLImageRefCountedMemory(size, internalformat));
545 if (!image->Initialize(gpu_memory_buffer->bytes(),
546 gpu_memory_buffer->GetFormat())) {
547 return -1;
548 }
549 gl_image = image;
461 } 550 }
462 551
463 static int32_t next_id = 1; 552 static int32_t next_id = 1;
464 int32_t new_id = next_id++; 553 int32_t new_id = next_id++;
465
466 gpu::gles2::ImageManager* image_manager = decoder_->GetImageManager(); 554 gpu::gles2::ImageManager* image_manager = decoder_->GetImageManager();
467 DCHECK(image_manager); 555 DCHECK(image_manager);
468 image_manager->AddImage(image.get(), new_id); 556 image_manager->AddImage(gl_image.get(), new_id);
469 return new_id; 557 return new_id;
470 } 558 }
471 559
472 int32_t GLManager::CreateGpuMemoryBufferImage(size_t width, 560 int32_t GLManager::CreateGpuMemoryBufferImage(size_t width,
473 size_t height, 561 size_t height,
474 unsigned internalformat, 562 unsigned internalformat,
475 unsigned usage) { 563 unsigned usage) {
476 DCHECK_EQ(usage, static_cast<unsigned>(GL_READ_WRITE_CHROMIUM)); 564 DCHECK_EQ(usage, static_cast<unsigned>(GL_READ_WRITE_CHROMIUM));
477 scoped_ptr<gfx::GpuMemoryBuffer> buffer = GLManager::CreateGpuMemoryBuffer( 565 scoped_ptr<gfx::GpuMemoryBuffer> buffer = CreateGpuMemoryBuffer(
478 gfx::Size(width, height), gfx::BufferFormat::RGBA_8888); 566 gfx::Size(width, height), gfx::BufferFormat::RGBA_8888);
479 return CreateImage(buffer->AsClientBuffer(), width, height, internalformat); 567 return CreateImage(buffer->AsClientBuffer(), width, height, internalformat);
480 } 568 }
481 569
482 void GLManager::DestroyImage(int32_t id) { 570 void GLManager::DestroyImage(int32_t id) {
483 gpu::gles2::ImageManager* image_manager = decoder_->GetImageManager(); 571 gpu::gles2::ImageManager* image_manager = decoder_->GetImageManager();
484 DCHECK(image_manager); 572 DCHECK(image_manager);
485 image_manager->RemoveImage(id); 573 image_manager->RemoveImage(id);
486 } 574 }
487 575
(...skipping 58 matching lines...) Expand 10 before | Expand all | Expand 10 after
546 634
547 // Something went wrong, just run the callback now. 635 // Something went wrong, just run the callback now.
548 callback.Run(); 636 callback.Run();
549 } 637 }
550 638
551 bool GLManager::CanWaitUnverifiedSyncToken(const gpu::SyncToken* sync_token) { 639 bool GLManager::CanWaitUnverifiedSyncToken(const gpu::SyncToken* sync_token) {
552 return false; 640 return false;
553 } 641 }
554 642
555 } // namespace gpu 643 } // namespace gpu
OLDNEW
« no previous file with comments | « gpu/command_buffer/tests/gl_manager.h ('k') | gpu/command_buffer/tests/gl_test_utils.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698