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

Side by Side Diff: gpu/command_buffer/service/context_group.cc

Issue 10795037: Revert 147328 - Current status of patch: (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src/
Patch Set: Created 8 years, 5 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 | Annotate | Revision Log
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/service/context_group.h" 5 #include "gpu/command_buffer/service/context_group.h"
6 6
7 #include <algorithm>
8 #include <string> 7 #include <string>
9 8
10 #include "base/command_line.h" 9 #include "base/command_line.h"
11 #include "base/string_util.h" 10 #include "base/string_util.h"
12 #include "gpu/command_buffer/common/id_allocator.h" 11 #include "gpu/command_buffer/common/id_allocator.h"
13 #include "gpu/command_buffer/service/buffer_manager.h" 12 #include "gpu/command_buffer/service/buffer_manager.h"
14 #include "gpu/command_buffer/service/framebuffer_manager.h" 13 #include "gpu/command_buffer/service/framebuffer_manager.h"
15 #include "gpu/command_buffer/service/gles2_cmd_decoder.h" 14 #include "gpu/command_buffer/service/gles2_cmd_decoder.h"
16 #include "gpu/command_buffer/service/gpu_switches.h" 15 #include "gpu/command_buffer/service/gpu_switches.h"
17 #include "gpu/command_buffer/service/mailbox_manager.h" 16 #include "gpu/command_buffer/service/mailbox_manager.h"
18 #include "gpu/command_buffer/service/program_manager.h" 17 #include "gpu/command_buffer/service/program_manager.h"
19 #include "gpu/command_buffer/service/renderbuffer_manager.h" 18 #include "gpu/command_buffer/service/renderbuffer_manager.h"
20 #include "gpu/command_buffer/service/shader_manager.h" 19 #include "gpu/command_buffer/service/shader_manager.h"
21 #include "gpu/command_buffer/service/texture_manager.h" 20 #include "gpu/command_buffer/service/texture_manager.h"
22 #include "gpu/command_buffer/service/transfer_buffer_manager.h" 21 #include "gpu/command_buffer/service/transfer_buffer_manager.h"
23 #include "ui/gl/gl_implementation.h" 22 #include "ui/gl/gl_implementation.h"
24 23
25 namespace gpu { 24 namespace gpu {
26 namespace gles2 { 25 namespace gles2 {
27 26
28 ContextGroup::ContextGroup( 27 ContextGroup::ContextGroup(
29 MailboxManager* mailbox_manager, 28 MailboxManager* mailbox_manager,
30 bool bind_generates_resource, 29 bool bind_generates_resource)
31 ProgramCache* program_cache)
32 : mailbox_manager_(mailbox_manager ? mailbox_manager : new MailboxManager), 30 : mailbox_manager_(mailbox_manager ? mailbox_manager : new MailboxManager),
33 num_contexts_(0), 31 num_contexts_(0),
34 enforce_gl_minimums_(CommandLine::ForCurrentProcess()->HasSwitch( 32 enforce_gl_minimums_(CommandLine::ForCurrentProcess()->HasSwitch(
35 switches::kEnforceGLMinimums)), 33 switches::kEnforceGLMinimums)),
36 bind_generates_resource_(bind_generates_resource), 34 bind_generates_resource_(bind_generates_resource),
37 max_vertex_attribs_(0u), 35 max_vertex_attribs_(0u),
38 max_texture_units_(0u), 36 max_texture_units_(0u),
39 max_texture_image_units_(0u), 37 max_texture_image_units_(0u),
40 max_vertex_texture_image_units_(0u), 38 max_vertex_texture_image_units_(0u),
41 max_fragment_uniform_vectors_(0u), 39 max_fragment_uniform_vectors_(0u),
42 max_varying_vectors_(0u), 40 max_varying_vectors_(0u),
43 max_vertex_uniform_vectors_(0u), 41 max_vertex_uniform_vectors_(0u),
44 program_cache_(program_cache),
45 feature_info_(new FeatureInfo()) { 42 feature_info_(new FeatureInfo()) {
46 { 43 {
47 TransferBufferManager* manager = new TransferBufferManager(); 44 TransferBufferManager* manager = new TransferBufferManager();
48 transfer_buffer_manager_.reset(manager); 45 transfer_buffer_manager_.reset(manager);
49 manager->Initialize(); 46 manager->Initialize();
50 } 47 }
51 48
52 id_namespaces_[id_namespaces::kBuffers].reset(new IdAllocator); 49 id_namespaces_[id_namespaces::kBuffers].reset(new IdAllocator);
53 id_namespaces_[id_namespaces::kFramebuffers].reset(new IdAllocator); 50 id_namespaces_[id_namespaces::kFramebuffers].reset(new IdAllocator);
54 id_namespaces_[id_namespaces::kProgramsAndShaders].reset( 51 id_namespaces_[id_namespaces::kProgramsAndShaders].reset(
(...skipping 34 matching lines...) Expand 10 before | Expand all | Expand 10 after
89 GLint max_samples = 0; 86 GLint max_samples = 0;
90 if (feature_info_->feature_flags().chromium_framebuffer_multisample) { 87 if (feature_info_->feature_flags().chromium_framebuffer_multisample) {
91 glGetIntegerv(GL_MAX_SAMPLES, &max_samples); 88 glGetIntegerv(GL_MAX_SAMPLES, &max_samples);
92 } 89 }
93 90
94 buffer_manager_.reset(new BufferManager()); 91 buffer_manager_.reset(new BufferManager());
95 framebuffer_manager_.reset(new FramebufferManager()); 92 framebuffer_manager_.reset(new FramebufferManager());
96 renderbuffer_manager_.reset(new RenderbufferManager( 93 renderbuffer_manager_.reset(new RenderbufferManager(
97 max_renderbuffer_size, max_samples)); 94 max_renderbuffer_size, max_samples));
98 shader_manager_.reset(new ShaderManager()); 95 shader_manager_.reset(new ShaderManager());
99 program_manager_.reset(new ProgramManager(program_cache_)); 96 program_manager_.reset(new ProgramManager());
100 97
101 // Lookup GL things we need to know. 98 // Lookup GL things we need to know.
102 const GLint kGLES2RequiredMinimumVertexAttribs = 8u; 99 const GLint kGLES2RequiredMinimumVertexAttribs = 8u;
103 if (!QueryGLFeatureU( 100 if (!QueryGLFeatureU(
104 GL_MAX_VERTEX_ATTRIBS, kGLES2RequiredMinimumVertexAttribs, 101 GL_MAX_VERTEX_ATTRIBS, kGLES2RequiredMinimumVertexAttribs,
105 &max_vertex_attribs_)) { 102 &max_vertex_attribs_)) {
106 LOG(ERROR) << "ContextGroup::Initialize failed because too few " 103 LOG(ERROR) << "ContextGroup::Initialize failed because too few "
107 << "vertex attributes supported."; 104 << "vertex attributes supported.";
108 return false; 105 return false;
109 } 106 }
(...skipping 188 matching lines...) Expand 10 before | Expand all | Expand 10 after
298 GetIntegerv(pname, &value); 295 GetIntegerv(pname, &value);
299 bool result = CheckGLFeatureU(min_required, &value); 296 bool result = CheckGLFeatureU(min_required, &value);
300 *v = value; 297 *v = value;
301 return result; 298 return result;
302 } 299 }
303 300
304 } // namespace gles2 301 } // namespace gles2
305 } // namespace gpu 302 } // namespace gpu
306 303
307 304
OLDNEW
« no previous file with comments | « gpu/command_buffer/service/context_group.h ('k') | gpu/command_buffer/service/context_group_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698