blob: cca86635fb12c761324ec4dda4789a699932b0cb (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
|
// Copyright (c) 2009 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "app/gfx/gl/gl_context.h"
#include "gpu/command_buffer/service/gpu_processor.h"
using ::base::SharedMemory;
namespace gpu {
bool GPUProcessor::Initialize(gfx::PluginWindowHandle window,
const gfx::Size& size,
const char* allowed_extensions,
const std::vector<int32>& attribs,
GPUProcessor* parent,
uint32 parent_texture_id) {
// Get the parent decoder and the GLContext to share IDs with, if any.
gles2::GLES2Decoder* parent_decoder = NULL;
gfx::GLContext* parent_context = NULL;
void* parent_handle = NULL;
if (parent) {
parent_decoder = parent->decoder_.get();
DCHECK(parent_decoder);
parent_context = parent_decoder->GetGLContext();
DCHECK(parent_context);
}
// Create either a view or pbuffer based GLContext.
scoped_ptr<gfx::GLContext> context;
if (window) {
DCHECK(!parent_handle);
// TODO(apatrick): support multisampling.
context.reset(gfx::GLContext::CreateViewGLContext(window, false));
} else {
context.reset(gfx::GLContext::CreateOffscreenGLContext(parent_context));
}
if (!context.get()) {
LOG(ERROR) << "GPUProcessor::Initialize failed";
return false;
}
return InitializeCommon(context.release(),
size,
allowed_extensions,
attribs,
parent_decoder,
parent_texture_id);
}
void GPUProcessor::Destroy() {
DestroyCommon();
}
void GPUProcessor::WillSwapBuffers() {
if (wrapped_swap_buffers_callback_.get()) {
wrapped_swap_buffers_callback_->Run();
}
}
} // namespace gpu
|