summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--chrome/renderer/webgraphicscontext3d_command_buffer_impl.cc1017
-rw-r--r--chrome/renderer/webgraphicscontext3d_command_buffer_impl.h379
-rw-r--r--webkit/gpu/webgraphicscontext3d_in_process_impl.cc1640
-rw-r--r--webkit/gpu/webgraphicscontext3d_in_process_impl.h453
4 files changed, 0 insertions, 3489 deletions
diff --git a/chrome/renderer/webgraphicscontext3d_command_buffer_impl.cc b/chrome/renderer/webgraphicscontext3d_command_buffer_impl.cc
index 08443ea..c5ad191 100644
--- a/chrome/renderer/webgraphicscontext3d_command_buffer_impl.cc
+++ b/chrome/renderer/webgraphicscontext3d_command_buffer_impl.cc
@@ -24,8 +24,6 @@
#include "chrome/renderer/render_view.h"
#include "third_party/WebKit/Source/WebKit/chromium/public/WebView.h"
-#if defined(USE_WGC3D_TYPES)
-
WebGraphicsContext3DCommandBufferImpl::WebGraphicsContext3DCommandBufferImpl()
: context_(NULL),
web_view_(NULL),
@@ -1000,1019 +998,4 @@ void WebGraphicsContext3DCommandBufferImpl::OnSwapBuffers() {
renderview->DidFlushPaint();
}
-#else // USE_WGC3D_TYPES
-
-WebGraphicsContext3DCommandBufferImpl::WebGraphicsContext3DCommandBufferImpl()
- : context_(NULL),
- web_view_(NULL),
- cached_width_(0),
- cached_height_(0),
- bound_fbo_(0) {
-}
-
-WebGraphicsContext3DCommandBufferImpl::
- ~WebGraphicsContext3DCommandBufferImpl() {
- if (context_) {
- ggl::DestroyContext(context_);
- }
-}
-
-static const char* kWebGraphicsContext3DPerferredGLExtensions =
- "GL_OES_packed_depth_stencil "
- "GL_OES_depth24 "
- "GL_CHROMIUM_webglsl";
-
-bool WebGraphicsContext3DCommandBufferImpl::initialize(
- WebGraphicsContext3D::Attributes attributes,
- WebKit::WebView* web_view,
- bool render_directly_to_web_view) {
- RenderThread* render_thread = RenderThread::current();
- if (!render_thread)
- return false;
- GpuChannelHost* host = render_thread->EstablishGpuChannelSync();
- if (!host)
- return false;
- DCHECK(host->state() == GpuChannelHost::kConnected);
-
- // Convert WebGL context creation attributes into GGL/EGL size requests.
- const int alpha_size = attributes.alpha ? 8 : 0;
- const int depth_size = attributes.depth ? 24 : 0;
- const int stencil_size = attributes.stencil ? 8 : 0;
- const int samples = attributes.antialias ? 4 : 0;
- const int sample_buffers = attributes.antialias ? 1 : 0;
- const int32 attribs[] = {
- ggl::GGL_ALPHA_SIZE, alpha_size,
- ggl::GGL_DEPTH_SIZE, depth_size,
- ggl::GGL_STENCIL_SIZE, stencil_size,
- ggl::GGL_SAMPLES, samples,
- ggl::GGL_SAMPLE_BUFFERS, sample_buffers,
- ggl::GGL_NONE,
- };
-
- GPUInfo gpu_info = host->gpu_info();
- UMA_HISTOGRAM_ENUMERATION(
- "GPU.WebGraphicsContext3D_Init_CanLoseContext",
- attributes.canRecoverFromContextLoss * 2 + gpu_info.can_lose_context(),
- 4);
- if (attributes.canRecoverFromContextLoss == false) {
- if (gpu_info.can_lose_context())
- return false;
- }
-
- if (render_directly_to_web_view) {
- RenderView* renderview = RenderView::FromWebView(web_view);
- if (!renderview)
- return false;
-
- web_view_ = web_view;
- context_ = ggl::CreateViewContext(
- host,
- renderview->routing_id(),
- kWebGraphicsContext3DPerferredGLExtensions,
- attribs);
- if (context_) {
- ggl::SetSwapBuffersCallback(
- context_,
- NewCallback(this,
- &WebGraphicsContext3DCommandBufferImpl::OnSwapBuffers));
- }
- } else {
- bool compositing_enabled = !CommandLine::ForCurrentProcess()->HasSwitch(
- switches::kDisableAcceleratedCompositing);
- ggl::Context* parent_context = NULL;
- // If GPU compositing is enabled we need to create a GL context that shares
- // resources with the compositor's context.
- if (compositing_enabled) {
- // Asking for the WebGraphicsContext3D on the WebView will force one to
- // be created if it doesn't already exist. When the compositor is created
- // for the view it will use the same context.
- WebKit::WebGraphicsContext3D* view_context =
- web_view->graphicsContext3D();
- if (view_context) {
- WebGraphicsContext3DCommandBufferImpl* context_impl =
- static_cast<WebGraphicsContext3DCommandBufferImpl*>(view_context);
- parent_context = context_impl->context_;
- }
- }
- context_ = ggl::CreateOffscreenContext(
- host,
- parent_context,
- gfx::Size(1, 1),
- kWebGraphicsContext3DPerferredGLExtensions,
- attribs);
- web_view_ = NULL;
- }
- if (!context_)
- return false;
- // TODO(gman): Remove this.
- const CommandLine& command_line = *CommandLine::ForCurrentProcess();
- if (command_line.HasSwitch(switches::kDisableGLSLTranslator)) {
- DisableShaderTranslation(context_);
- }
-
- // Set attributes_ from created offscreen context.
- {
- attributes_ = attributes;
- GLint alpha_bits = 0;
- getIntegerv(GL_ALPHA_BITS, &alpha_bits);
- attributes_.alpha = alpha_bits > 0;
- GLint depth_bits = 0;
- getIntegerv(GL_DEPTH_BITS, &depth_bits);
- attributes_.depth = depth_bits > 0;
- GLint stencil_bits = 0;
- getIntegerv(GL_STENCIL_BITS, &stencil_bits);
- attributes_.stencil = stencil_bits > 0;
- GLint samples = 0;
- getIntegerv(GL_SAMPLES, &samples);
- attributes_.antialias = samples > 0;
- }
-
- return true;
-}
-
-bool WebGraphicsContext3DCommandBufferImpl::makeContextCurrent() {
- return ggl::MakeCurrent(context_);
-}
-
-int WebGraphicsContext3DCommandBufferImpl::width() {
- return cached_width_;
-}
-
-int WebGraphicsContext3DCommandBufferImpl::height() {
- return cached_height_;
-}
-
-int WebGraphicsContext3DCommandBufferImpl::sizeInBytes(int type) {
- switch (type) {
- case GL_BYTE:
- return sizeof(GLbyte);
- case GL_UNSIGNED_BYTE:
- return sizeof(GLubyte);
- case GL_SHORT:
- return sizeof(GLshort);
- case GL_UNSIGNED_SHORT:
- return sizeof(GLushort);
- case GL_INT:
- return sizeof(GLint);
- case GL_UNSIGNED_INT:
- return sizeof(GLuint);
- case GL_FLOAT:
- return sizeof(GLfloat);
- }
- return 0;
-}
-
-bool WebGraphicsContext3DCommandBufferImpl::isGLES2Compliant() {
- return true;
-}
-
-bool WebGraphicsContext3DCommandBufferImpl::isGLES2NPOTStrict() {
- return true;
-}
-
-bool WebGraphicsContext3DCommandBufferImpl::
- isErrorGeneratedOnOutOfBoundsAccesses() {
- return true;
-}
-
-unsigned int WebGraphicsContext3DCommandBufferImpl::getPlatformTextureId() {
- DCHECK(context_);
- return ggl::GetParentTextureId(context_);
-}
-
-void WebGraphicsContext3DCommandBufferImpl::prepareTexture() {
- // Copies the contents of the off-screen render target into the texture
- // used by the compositor.
- ggl::SwapBuffers(context_);
-}
-
-void WebGraphicsContext3DCommandBufferImpl::reshape(int width, int height) {
- cached_width_ = width;
- cached_height_ = height;
- makeContextCurrent();
-
- if (web_view_) {
-#if defined(OS_MACOSX)
- ggl::ResizeOnscreenContext(context_, gfx::Size(width, height));
-#else
- glResizeCHROMIUM(width, height);
-#endif
- } else {
- ggl::ResizeOffscreenContext(context_, gfx::Size(width, height));
- // Force a SwapBuffers to get the framebuffer to resize.
- ggl::SwapBuffers(context_);
- }
-
-#ifdef FLIP_FRAMEBUFFER_VERTICALLY
- scanline_.reset(new uint8[width * 4]);
-#endif // FLIP_FRAMEBUFFER_VERTICALLY
-}
-
-unsigned WebGraphicsContext3DCommandBufferImpl::createCompositorTexture(
- unsigned width, unsigned height) {
- makeContextCurrent();
- return ggl::CreateParentTexture(context_, gfx::Size(width, height));
-}
-
-void WebGraphicsContext3DCommandBufferImpl::deleteCompositorTexture(
- unsigned parent_texture) {
- makeContextCurrent();
- ggl::DeleteParentTexture(context_, parent_texture);
-}
-
-#ifdef FLIP_FRAMEBUFFER_VERTICALLY
-void WebGraphicsContext3DCommandBufferImpl::FlipVertically(
- uint8* framebuffer,
- unsigned int width,
- unsigned int height) {
- uint8* scanline = scanline_.get();
- if (!scanline)
- return;
- unsigned int row_bytes = width * 4;
- unsigned int count = height / 2;
- for (unsigned int i = 0; i < count; i++) {
- uint8* row_a = framebuffer + i * row_bytes;
- uint8* row_b = framebuffer + (height - i - 1) * row_bytes;
- // TODO(kbr): this is where the multiplication of the alpha
- // channel into the color buffer will need to occur if the
- // user specifies the "premultiplyAlpha" flag in the context
- // creation attributes.
- memcpy(scanline, row_b, row_bytes);
- memcpy(row_b, row_a, row_bytes);
- memcpy(row_a, scanline, row_bytes);
- }
-}
-#endif
-
-bool WebGraphicsContext3DCommandBufferImpl::readBackFramebuffer(
- unsigned char* pixels,
- size_t buffer_size) {
- if (buffer_size != static_cast<size_t>(4 * width() * height())) {
- return false;
- }
-
- makeContextCurrent();
-
- // Earlier versions of this code used the GPU to flip the
- // framebuffer vertically before reading it back for compositing
- // via software. This code was quite complicated, used a lot of
- // GPU memory, and didn't provide an obvious speedup. Since this
- // vertical flip is only a temporary solution anyway until Chrome
- // is fully GPU composited, it wasn't worth the complexity.
-
- bool mustRestoreFBO = (bound_fbo_ != 0);
- if (mustRestoreFBO) {
- glBindFramebuffer(GL_FRAMEBUFFER, 0);
- }
- glReadPixels(0, 0, cached_width_, cached_height_,
- GL_RGBA, GL_UNSIGNED_BYTE, pixels);
-
- // Swizzle red and blue channels
- // TODO(kbr): expose GL_BGRA as extension
- for (size_t i = 0; i < buffer_size; i += 4) {
- std::swap(pixels[i], pixels[i + 2]);
- }
-
- if (mustRestoreFBO) {
- glBindFramebuffer(GL_FRAMEBUFFER, bound_fbo_);
- }
-
-#ifdef FLIP_FRAMEBUFFER_VERTICALLY
- if (pixels) {
- FlipVertically(pixels, cached_width_, cached_height_);
- }
-#endif
-
- return true;
-}
-
-void WebGraphicsContext3DCommandBufferImpl::synthesizeGLError(
- unsigned long error) {
- if (find(synthetic_errors_.begin(), synthetic_errors_.end(), error) ==
- synthetic_errors_.end()) {
- synthetic_errors_.push_back(error);
- }
-}
-
-void* WebGraphicsContext3DCommandBufferImpl::mapBufferSubDataCHROMIUM(
- unsigned target,
- int offset,
- int size,
- unsigned access) {
- return glMapBufferSubDataCHROMIUM(target, offset, size, access);
-}
-
-void WebGraphicsContext3DCommandBufferImpl::unmapBufferSubDataCHROMIUM(
- const void* mem) {
- return glUnmapBufferSubDataCHROMIUM(mem);
-}
-
-void* WebGraphicsContext3DCommandBufferImpl::mapTexSubImage2DCHROMIUM(
- unsigned target,
- int level,
- int xoffset,
- int yoffset,
- int width,
- int height,
- unsigned format,
- unsigned type,
- unsigned access) {
- return glMapTexSubImage2DCHROMIUM(
- target, level, xoffset, yoffset, width, height, format, type, access);
-}
-
-void WebGraphicsContext3DCommandBufferImpl::unmapTexSubImage2DCHROMIUM(
- const void* mem) {
- glUnmapTexSubImage2DCHROMIUM(mem);
-}
-
-void WebGraphicsContext3DCommandBufferImpl::copyTextureToParentTextureCHROMIUM(
- unsigned texture, unsigned parentTexture) {
- copyTextureToCompositor(texture, parentTexture);
-}
-
-WebKit::WebString WebGraphicsContext3DCommandBufferImpl::
- getRequestableExtensionsCHROMIUM() {
- return WebKit::WebString::fromUTF8(glGetRequestableExtensionsCHROMIUM());
-}
-
-void WebGraphicsContext3DCommandBufferImpl::requestExtensionCHROMIUM(
- const char* extension) {
- glRequestExtensionCHROMIUM(extension);
-}
-
-void WebGraphicsContext3DCommandBufferImpl::blitFramebufferCHROMIUM(
- int srcX0, int srcY0, int srcX1, int srcY1,
- int dstX0, int dstY0, int dstX1, int dstY1,
- unsigned mask, unsigned filter) {
- glBlitFramebufferEXT(srcX0, srcY0, srcX1, srcY1,
- dstX0, dstY0, dstX1, dstY1,
- mask, filter);
-}
-
-void WebGraphicsContext3DCommandBufferImpl::
- renderbufferStorageMultisampleCHROMIUM(
- unsigned long target, int samples, unsigned internalformat,
- unsigned width, unsigned height) {
- glRenderbufferStorageMultisampleEXT(target, samples, internalformat,
- width, height);
-}
-
-// Helper macros to reduce the amount of code.
-
-#define DELEGATE_TO_GL(name, glname) \
-void WebGraphicsContext3DCommandBufferImpl::name() { \
- makeContextCurrent(); \
- gl##glname(); \
-}
-
-#define DELEGATE_TO_GL_1(name, glname, t1) \
-void WebGraphicsContext3DCommandBufferImpl::name(t1 a1) { \
- makeContextCurrent(); \
- gl##glname(a1); \
-}
-
-#define DELEGATE_TO_GL_1_C(name, glname, t1) \
-void WebGraphicsContext3DCommandBufferImpl::name(t1 a1) { \
- makeContextCurrent(); \
- gl##glname(static_cast<GLclampf>(a1)); \
-}
-
-#define DELEGATE_TO_GL_1R(name, glname, t1, rt) \
-rt WebGraphicsContext3DCommandBufferImpl::name(t1 a1) { \
- makeContextCurrent(); \
- return gl##glname(a1); \
-}
-
-#define DELEGATE_TO_GL_1RB(name, glname, t1, rt) \
-rt WebGraphicsContext3DCommandBufferImpl::name(t1 a1) { \
- makeContextCurrent(); \
- return gl##glname(a1) ? true : false; \
-}
-
-#define DELEGATE_TO_GL_2(name, glname, t1, t2) \
-void WebGraphicsContext3DCommandBufferImpl::name(t1 a1, t2 a2) { \
- makeContextCurrent(); \
- gl##glname(a1, a2); \
-}
-
-#define DELEGATE_TO_GL_2_C1(name, glname, t1, t2) \
-void WebGraphicsContext3DCommandBufferImpl::name(t1 a1, t2 a2) { \
- makeContextCurrent(); \
- gl##glname(static_cast<GLclampf>(a1), a2); \
-}
-
-#define DELEGATE_TO_GL_2_C12(name, glname, t1, t2) \
-void WebGraphicsContext3DCommandBufferImpl::name(t1 a1, t2 a2) { \
- makeContextCurrent(); \
- gl##glname(static_cast<GLclampf>(a1), static_cast<GLclampf>(a2)); \
-}
-
-#define DELEGATE_TO_GL_2R(name, glname, t1, t2, rt) \
-rt WebGraphicsContext3DCommandBufferImpl::name(t1 a1, t2 a2) { \
- makeContextCurrent(); \
- return gl##glname(a1, a2); \
-}
-
-#define DELEGATE_TO_GL_3(name, glname, t1, t2, t3) \
-void WebGraphicsContext3DCommandBufferImpl::name(t1 a1, t2 a2, t3 a3) { \
- makeContextCurrent(); \
- gl##glname(a1, a2, a3); \
-}
-
-#define DELEGATE_TO_GL_4(name, glname, t1, t2, t3, t4) \
-void WebGraphicsContext3DCommandBufferImpl::name(t1 a1, t2 a2, t3 a3, t4 a4) { \
- makeContextCurrent(); \
- gl##glname(a1, a2, a3, a4); \
-}
-
-#define DELEGATE_TO_GL_4_C1234(name, glname, t1, t2, t3, t4) \
-void WebGraphicsContext3DCommandBufferImpl::name(t1 a1, t2 a2, t3 a3, t4 a4) { \
- makeContextCurrent(); \
- gl##glname(static_cast<GLclampf>(a1), static_cast<GLclampf>(a2), \
- static_cast<GLclampf>(a3), static_cast<GLclampf>(a4)); \
-}
-
-#define DELEGATE_TO_GL_5(name, glname, t1, t2, t3, t4, t5) \
-void WebGraphicsContext3DCommandBufferImpl::name(t1 a1, t2 a2, t3 a3, \
- t4 a4, t5 a5) { \
- makeContextCurrent(); \
- gl##glname(a1, a2, a3, a4, a5); \
-}
-
-#define DELEGATE_TO_GL_6(name, glname, t1, t2, t3, t4, t5, t6) \
-void WebGraphicsContext3DCommandBufferImpl::name(t1 a1, t2 a2, t3 a3, \
- t4 a4, t5 a5, t6 a6) { \
- makeContextCurrent(); \
- gl##glname(a1, a2, a3, a4, a5, a6); \
-}
-
-#define DELEGATE_TO_GL_7(name, glname, t1, t2, t3, t4, t5, t6, t7) \
-void WebGraphicsContext3DCommandBufferImpl::name(t1 a1, t2 a2, t3 a3, \
- t4 a4, t5 a5, t6 a6, t7 a7) { \
- makeContextCurrent(); \
- gl##glname(a1, a2, a3, a4, a5, a6, a7); \
-}
-
-#define DELEGATE_TO_GL_8(name, glname, t1, t2, t3, t4, t5, t6, t7, t8) \
-void WebGraphicsContext3DCommandBufferImpl::name(t1 a1, t2 a2, t3 a3, \
- t4 a4, t5 a5, t6 a6, \
- t7 a7, t8 a8) { \
- makeContextCurrent(); \
- gl##glname(a1, a2, a3, a4, a5, a6, a7, a8); \
-}
-
-#define DELEGATE_TO_GL_9(name, glname, t1, t2, t3, t4, t5, t6, t7, t8, t9) \
-void WebGraphicsContext3DCommandBufferImpl::name(t1 a1, t2 a2, t3 a3, \
- t4 a4, t5 a5, t6 a6, \
- t7 a7, t8 a8, t9 a9) { \
- makeContextCurrent(); \
- gl##glname(a1, a2, a3, a4, a5, a6, a7, a8, a9); \
-}
-
-DELEGATE_TO_GL_1(activeTexture, ActiveTexture, unsigned long)
-
-DELEGATE_TO_GL_2(attachShader, AttachShader, WebGLId, WebGLId)
-
-DELEGATE_TO_GL_3(bindAttribLocation, BindAttribLocation, WebGLId,
- unsigned long, const char*)
-
-DELEGATE_TO_GL_2(bindBuffer, BindBuffer, unsigned long, WebGLId)
-
-void WebGraphicsContext3DCommandBufferImpl::bindFramebuffer(
- unsigned long target,
- WebGLId framebuffer) {
- makeContextCurrent();
- glBindFramebuffer(target, framebuffer);
- bound_fbo_ = framebuffer;
-}
-
-DELEGATE_TO_GL_2(bindRenderbuffer, BindRenderbuffer, unsigned long, WebGLId)
-
-DELEGATE_TO_GL_2(bindTexture, BindTexture, unsigned long, WebGLId)
-
-DELEGATE_TO_GL_4_C1234(blendColor, BlendColor, double, double, double, double)
-
-DELEGATE_TO_GL_1(blendEquation, BlendEquation, unsigned long)
-
-DELEGATE_TO_GL_2(blendEquationSeparate, BlendEquationSeparate,
- unsigned long, unsigned long)
-
-DELEGATE_TO_GL_2(blendFunc, BlendFunc, unsigned long, unsigned long)
-
-DELEGATE_TO_GL_4(blendFuncSeparate, BlendFuncSeparate,
- unsigned long, unsigned long, unsigned long, unsigned long)
-
-DELEGATE_TO_GL_4(bufferData, BufferData,
- unsigned long, int, const void*, unsigned long)
-
-DELEGATE_TO_GL_4(bufferSubData, BufferSubData,
- unsigned long, long, int, const void*)
-
-DELEGATE_TO_GL_1R(checkFramebufferStatus, CheckFramebufferStatus,
- unsigned long, unsigned long)
-
-DELEGATE_TO_GL_1(clear, Clear, unsigned long)
-
-DELEGATE_TO_GL_4_C1234(clearColor, ClearColor, double, double, double, double)
-
-DELEGATE_TO_GL_1_C(clearDepth, ClearDepthf, double)
-
-DELEGATE_TO_GL_1(clearStencil, ClearStencil, long)
-
-DELEGATE_TO_GL_4(colorMask, ColorMask, bool, bool, bool, bool)
-
-DELEGATE_TO_GL_1(compileShader, CompileShader, WebGLId)
-
-DELEGATE_TO_GL_8(copyTexImage2D, CopyTexImage2D,
- unsigned long, long, unsigned long, long, long,
- unsigned long, unsigned long, long)
-
-DELEGATE_TO_GL_8(copyTexSubImage2D, CopyTexSubImage2D,
- unsigned long, long, long, long, long, long,
- unsigned long, unsigned long)
-
-DELEGATE_TO_GL_1(cullFace, CullFace, unsigned long)
-
-DELEGATE_TO_GL_1(depthFunc, DepthFunc, unsigned long)
-
-DELEGATE_TO_GL_1(depthMask, DepthMask, bool)
-
-DELEGATE_TO_GL_2_C12(depthRange, DepthRangef, double, double)
-
-DELEGATE_TO_GL_2(detachShader, DetachShader, WebGLId, WebGLId)
-
-DELEGATE_TO_GL_1(disable, Disable, unsigned long)
-
-DELEGATE_TO_GL_1(disableVertexAttribArray, DisableVertexAttribArray,
- unsigned long)
-
-DELEGATE_TO_GL_3(drawArrays, DrawArrays, unsigned long, long, long)
-
-void WebGraphicsContext3DCommandBufferImpl::drawElements(unsigned long mode,
- unsigned long count,
- unsigned long type,
- long offset) {
- makeContextCurrent();
- glDrawElements(mode, count, type,
- reinterpret_cast<void*>(static_cast<intptr_t>(offset)));
-}
-
-DELEGATE_TO_GL_1(enable, Enable, unsigned long)
-
-DELEGATE_TO_GL_1(enableVertexAttribArray, EnableVertexAttribArray,
- unsigned long)
-
-DELEGATE_TO_GL(finish, Finish)
-
-DELEGATE_TO_GL(flush, Flush)
-
-DELEGATE_TO_GL_4(framebufferRenderbuffer, FramebufferRenderbuffer,
- unsigned long, unsigned long, unsigned long, WebGLId)
-
-DELEGATE_TO_GL_5(framebufferTexture2D, FramebufferTexture2D,
- unsigned long, unsigned long, unsigned long, WebGLId, long)
-
-DELEGATE_TO_GL_1(frontFace, FrontFace, unsigned long)
-
-DELEGATE_TO_GL_1(generateMipmap, GenerateMipmap, unsigned long)
-
-bool WebGraphicsContext3DCommandBufferImpl::getActiveAttrib(
- WebGLId program, unsigned long index, ActiveInfo& info) {
- makeContextCurrent();
- if (!program) {
- synthesizeGLError(GL_INVALID_VALUE);
- return false;
- }
- GLint max_name_length = -1;
- glGetProgramiv(program, GL_ACTIVE_ATTRIBUTE_MAX_LENGTH, &max_name_length);
- if (max_name_length < 0)
- return false;
- scoped_array<GLchar> name(new GLchar[max_name_length]);
- if (!name.get()) {
- synthesizeGLError(GL_OUT_OF_MEMORY);
- return false;
- }
- GLsizei length = 0;
- GLint size = -1;
- GLenum type = 0;
- glGetActiveAttrib(program, index, max_name_length,
- &length, &size, &type, name.get());
- if (size < 0) {
- return false;
- }
- info.name = WebKit::WebString::fromUTF8(name.get(), length);
- info.type = type;
- info.size = size;
- return true;
-}
-
-bool WebGraphicsContext3DCommandBufferImpl::getActiveUniform(
- WebGLId program, unsigned long index, ActiveInfo& info) {
- makeContextCurrent();
- GLint max_name_length = -1;
- glGetProgramiv(program, GL_ACTIVE_UNIFORM_MAX_LENGTH, &max_name_length);
- if (max_name_length < 0)
- return false;
- scoped_array<GLchar> name(new GLchar[max_name_length]);
- if (!name.get()) {
- synthesizeGLError(GL_OUT_OF_MEMORY);
- return false;
- }
- GLsizei length = 0;
- GLint size = -1;
- GLenum type = 0;
- glGetActiveUniform(program, index, max_name_length,
- &length, &size, &type, name.get());
- if (size < 0) {
- return false;
- }
- info.name = WebKit::WebString::fromUTF8(name.get(), length);
- info.type = type;
- info.size = size;
- return true;
-}
-
-DELEGATE_TO_GL_4(getAttachedShaders, GetAttachedShaders,
- WebGLId, int, int*, unsigned int*)
-
-DELEGATE_TO_GL_2R(getAttribLocation, GetAttribLocation,
- WebGLId, const char*, int)
-
-DELEGATE_TO_GL_2(getBooleanv, GetBooleanv, unsigned long, unsigned char*)
-
-DELEGATE_TO_GL_3(getBufferParameteriv, GetBufferParameteriv,
- unsigned long, unsigned long, int*)
-
-WebKit::WebGraphicsContext3D::Attributes
-WebGraphicsContext3DCommandBufferImpl::getContextAttributes() {
- return attributes_;
-}
-
-unsigned long WebGraphicsContext3DCommandBufferImpl::getError() {
- if (synthetic_errors_.size() > 0) {
- std::vector<unsigned long>::iterator iter = synthetic_errors_.begin();
- unsigned long err = *iter;
- synthetic_errors_.erase(iter);
- return err;
- }
-
- makeContextCurrent();
- return glGetError();
-}
-
-bool WebGraphicsContext3DCommandBufferImpl::isContextLost() {
- return ggl::IsCommandBufferContextLost(context_);
-}
-
-DELEGATE_TO_GL_2(getFloatv, GetFloatv, unsigned long, float*)
-
-DELEGATE_TO_GL_4(getFramebufferAttachmentParameteriv,
- GetFramebufferAttachmentParameteriv,
- unsigned long, unsigned long, unsigned long, int*)
-
-DELEGATE_TO_GL_2(getIntegerv, GetIntegerv, unsigned long, int*)
-
-DELEGATE_TO_GL_3(getProgramiv, GetProgramiv, WebGLId, unsigned long, int*)
-
-WebKit::WebString WebGraphicsContext3DCommandBufferImpl::getProgramInfoLog(
- WebGLId program) {
- makeContextCurrent();
- GLint logLength = 0;
- glGetProgramiv(program, GL_INFO_LOG_LENGTH, &logLength);
- if (!logLength)
- return WebKit::WebString();
- scoped_array<GLchar> log(new GLchar[logLength]);
- if (!log.get())
- return WebKit::WebString();
- GLsizei returnedLogLength = 0;
- glGetProgramInfoLog(program, logLength, &returnedLogLength, log.get());
- DCHECK_EQ(logLength, returnedLogLength + 1);
- WebKit::WebString res =
- WebKit::WebString::fromUTF8(log.get(), returnedLogLength);
- return res;
-}
-
-DELEGATE_TO_GL_3(getRenderbufferParameteriv, GetRenderbufferParameteriv,
- unsigned long, unsigned long, int*)
-
-DELEGATE_TO_GL_3(getShaderiv, GetShaderiv, WebGLId, unsigned long, int*)
-
-WebKit::WebString WebGraphicsContext3DCommandBufferImpl::getShaderInfoLog(
- WebGLId shader) {
- makeContextCurrent();
- GLint logLength = 0;
- glGetShaderiv(shader, GL_INFO_LOG_LENGTH, &logLength);
- if (!logLength)
- return WebKit::WebString();
- scoped_array<GLchar> log(new GLchar[logLength]);
- if (!log.get())
- return WebKit::WebString();
- GLsizei returnedLogLength = 0;
- glGetShaderInfoLog(shader, logLength, &returnedLogLength, log.get());
- DCHECK_EQ(logLength, returnedLogLength + 1);
- WebKit::WebString res =
- WebKit::WebString::fromUTF8(log.get(), returnedLogLength);
- return res;
-}
-
-WebKit::WebString WebGraphicsContext3DCommandBufferImpl::getShaderSource(
- WebGLId shader) {
- makeContextCurrent();
- GLint logLength = 0;
- glGetShaderiv(shader, GL_SHADER_SOURCE_LENGTH, &logLength);
- if (!logLength)
- return WebKit::WebString();
- scoped_array<GLchar> log(new GLchar[logLength]);
- if (!log.get())
- return WebKit::WebString();
- GLsizei returnedLogLength = 0;
- glGetShaderSource(shader, logLength, &returnedLogLength, log.get());
- DCHECK_EQ(logLength, returnedLogLength + 1);
- WebKit::WebString res =
- WebKit::WebString::fromUTF8(log.get(), returnedLogLength);
- return res;
-}
-
-WebKit::WebString WebGraphicsContext3DCommandBufferImpl::getString(
- unsigned long name) {
- makeContextCurrent();
- return WebKit::WebString::fromUTF8(
- reinterpret_cast<const char*>(glGetString(name)));
-}
-
-DELEGATE_TO_GL_3(getTexParameterfv, GetTexParameterfv,
- unsigned long, unsigned long, float*)
-
-DELEGATE_TO_GL_3(getTexParameteriv, GetTexParameteriv,
- unsigned long, unsigned long, int*)
-
-DELEGATE_TO_GL_3(getUniformfv, GetUniformfv, WebGLId, long, float*)
-
-DELEGATE_TO_GL_3(getUniformiv, GetUniformiv, WebGLId, long, int*)
-
-DELEGATE_TO_GL_2R(getUniformLocation, GetUniformLocation,
- WebGLId, const char*, long)
-
-DELEGATE_TO_GL_3(getVertexAttribfv, GetVertexAttribfv,
- unsigned long, unsigned long, float*)
-
-DELEGATE_TO_GL_3(getVertexAttribiv, GetVertexAttribiv,
- unsigned long, unsigned long, int*)
-
-long WebGraphicsContext3DCommandBufferImpl::getVertexAttribOffset(
- unsigned long index, unsigned long pname) {
- makeContextCurrent();
- GLvoid* value = NULL;
- // NOTE: If pname is ever a value that returns more then 1 element
- // this will corrupt memory.
- glGetVertexAttribPointerv(index, pname, &value);
- return reinterpret_cast<intptr_t>(value);
-}
-
-DELEGATE_TO_GL_2(hint, Hint, unsigned long, unsigned long)
-
-DELEGATE_TO_GL_1RB(isBuffer, IsBuffer, WebGLId, bool)
-
-DELEGATE_TO_GL_1RB(isEnabled, IsEnabled, unsigned long, bool)
-
-DELEGATE_TO_GL_1RB(isFramebuffer, IsFramebuffer, WebGLId, bool)
-
-DELEGATE_TO_GL_1RB(isProgram, IsProgram, WebGLId, bool)
-
-DELEGATE_TO_GL_1RB(isRenderbuffer, IsRenderbuffer, WebGLId, bool)
-
-DELEGATE_TO_GL_1RB(isShader, IsShader, WebGLId, bool)
-
-DELEGATE_TO_GL_1RB(isTexture, IsTexture, WebGLId, bool)
-
-DELEGATE_TO_GL_1_C(lineWidth, LineWidth, double)
-
-DELEGATE_TO_GL_1(linkProgram, LinkProgram, WebGLId)
-
-DELEGATE_TO_GL_2(pixelStorei, PixelStorei, unsigned long, long)
-
-DELEGATE_TO_GL_2_C12(polygonOffset, PolygonOffset, double, double)
-
-DELEGATE_TO_GL_7(readPixels, ReadPixels,
- long, long, unsigned long, unsigned long, unsigned long,
- unsigned long, void*)
-
-void WebGraphicsContext3DCommandBufferImpl::releaseShaderCompiler() {
-}
-
-DELEGATE_TO_GL_4(renderbufferStorage, RenderbufferStorage,
- unsigned long, unsigned long, unsigned long, unsigned long)
-
-DELEGATE_TO_GL_2_C1(sampleCoverage, SampleCoverage, double, bool)
-
-DELEGATE_TO_GL_4(scissor, Scissor, long, long, unsigned long, unsigned long)
-
-void WebGraphicsContext3DCommandBufferImpl::shaderSource(
- WebGLId shader, const char* string) {
- makeContextCurrent();
- GLint length = strlen(string);
- glShaderSource(shader, 1, &string, &length);
-}
-
-DELEGATE_TO_GL_3(stencilFunc, StencilFunc, unsigned long, long, unsigned long)
-
-DELEGATE_TO_GL_4(stencilFuncSeparate, StencilFuncSeparate,
- unsigned long, unsigned long, long, unsigned long)
-
-DELEGATE_TO_GL_1(stencilMask, StencilMask, unsigned long)
-
-DELEGATE_TO_GL_2(stencilMaskSeparate, StencilMaskSeparate,
- unsigned long, unsigned long)
-
-DELEGATE_TO_GL_3(stencilOp, StencilOp,
- unsigned long, unsigned long, unsigned long)
-
-DELEGATE_TO_GL_4(stencilOpSeparate, StencilOpSeparate,
- unsigned long, unsigned long, unsigned long, unsigned long)
-
-DELEGATE_TO_GL_9(texImage2D, TexImage2D,
- unsigned, unsigned, unsigned, unsigned, unsigned, unsigned,
- unsigned, unsigned, const void*)
-
-DELEGATE_TO_GL_3(texParameterf, TexParameterf, unsigned, unsigned, float);
-
-static const unsigned int kTextureWrapR = 0x8072;
-
-void WebGraphicsContext3DCommandBufferImpl::texParameteri(
- unsigned target, unsigned pname, int param) {
- // TODO(kbr): figure out whether the setting of TEXTURE_WRAP_R in
- // GraphicsContext3D.cpp is strictly necessary to avoid seams at the
- // edge of cube maps, and, if it is, push it into the GLES2 service
- // side code.
- if (pname == kTextureWrapR) {
- return;
- }
- makeContextCurrent();
- glTexParameteri(target, pname, param);
-}
-
-DELEGATE_TO_GL_9(texSubImage2D, TexSubImage2D,
- unsigned, unsigned, unsigned, unsigned, unsigned, unsigned,
- unsigned, unsigned, const void*)
-
-DELEGATE_TO_GL_2(uniform1f, Uniform1f, long, float)
-
-DELEGATE_TO_GL_3(uniform1fv, Uniform1fv, long, int, float*)
-
-DELEGATE_TO_GL_2(uniform1i, Uniform1i, long, int)
-
-DELEGATE_TO_GL_3(uniform1iv, Uniform1iv, long, int, int*)
-
-DELEGATE_TO_GL_3(uniform2f, Uniform2f, long, float, float)
-
-DELEGATE_TO_GL_3(uniform2fv, Uniform2fv, long, int, float*)
-
-DELEGATE_TO_GL_3(uniform2i, Uniform2i, long, int, int)
-
-DELEGATE_TO_GL_3(uniform2iv, Uniform2iv, long, int, int*)
-
-DELEGATE_TO_GL_4(uniform3f, Uniform3f, long, float, float, float)
-
-DELEGATE_TO_GL_3(uniform3fv, Uniform3fv, long, int, float*)
-
-DELEGATE_TO_GL_4(uniform3i, Uniform3i, long, int, int, int)
-
-DELEGATE_TO_GL_3(uniform3iv, Uniform3iv, long, int, int*)
-
-DELEGATE_TO_GL_5(uniform4f, Uniform4f, long, float, float, float, float)
-
-DELEGATE_TO_GL_3(uniform4fv, Uniform4fv, long, int, float*)
-
-DELEGATE_TO_GL_5(uniform4i, Uniform4i, long, int, int, int, int)
-
-DELEGATE_TO_GL_3(uniform4iv, Uniform4iv, long, int, int*)
-
-DELEGATE_TO_GL_4(uniformMatrix2fv, UniformMatrix2fv,
- long, int, bool, const float*)
-
-DELEGATE_TO_GL_4(uniformMatrix3fv, UniformMatrix3fv,
- long, int, bool, const float*)
-
-DELEGATE_TO_GL_4(uniformMatrix4fv, UniformMatrix4fv,
- long, int, bool, const float*)
-
-DELEGATE_TO_GL_1(useProgram, UseProgram, WebGLId)
-
-DELEGATE_TO_GL_1(validateProgram, ValidateProgram, WebGLId)
-
-DELEGATE_TO_GL_2(vertexAttrib1f, VertexAttrib1f, unsigned long, float)
-
-DELEGATE_TO_GL_2(vertexAttrib1fv, VertexAttrib1fv, unsigned long, const float*)
-
-DELEGATE_TO_GL_3(vertexAttrib2f, VertexAttrib2f, unsigned long, float, float)
-
-DELEGATE_TO_GL_2(vertexAttrib2fv, VertexAttrib2fv, unsigned long, const float*)
-
-DELEGATE_TO_GL_4(vertexAttrib3f, VertexAttrib3f,
- unsigned long, float, float, float)
-
-DELEGATE_TO_GL_2(vertexAttrib3fv, VertexAttrib3fv, unsigned long, const float*)
-
-DELEGATE_TO_GL_5(vertexAttrib4f, VertexAttrib4f,
- unsigned long, float, float, float, float)
-
-DELEGATE_TO_GL_2(vertexAttrib4fv, VertexAttrib4fv, unsigned long, const float*)
-
-void WebGraphicsContext3DCommandBufferImpl::vertexAttribPointer(
- unsigned long indx, int size, int type, bool normalized,
- unsigned long stride, unsigned long offset) {
- makeContextCurrent();
-
- glVertexAttribPointer(indx, size, type, normalized, stride,
- reinterpret_cast<void*>(
- static_cast<intptr_t>(offset)));
-}
-
-DELEGATE_TO_GL_4(viewport, Viewport, long, long, unsigned long, unsigned long)
-
-unsigned WebGraphicsContext3DCommandBufferImpl::createBuffer() {
- makeContextCurrent();
- GLuint o;
- glGenBuffers(1, &o);
- return o;
-}
-
-unsigned WebGraphicsContext3DCommandBufferImpl::createFramebuffer() {
- makeContextCurrent();
- GLuint o = 0;
- glGenFramebuffers(1, &o);
- return o;
-}
-
-unsigned WebGraphicsContext3DCommandBufferImpl::createProgram() {
- makeContextCurrent();
- return glCreateProgram();
-}
-
-unsigned WebGraphicsContext3DCommandBufferImpl::createRenderbuffer() {
- makeContextCurrent();
- GLuint o;
- glGenRenderbuffers(1, &o);
- return o;
-}
-
-DELEGATE_TO_GL_1R(createShader, CreateShader, unsigned long, unsigned);
-
-unsigned WebGraphicsContext3DCommandBufferImpl::createTexture() {
- makeContextCurrent();
- GLuint o;
- glGenTextures(1, &o);
- return o;
-}
-
-void WebGraphicsContext3DCommandBufferImpl::deleteBuffer(unsigned buffer) {
- makeContextCurrent();
- glDeleteBuffers(1, &buffer);
-}
-
-void WebGraphicsContext3DCommandBufferImpl::deleteFramebuffer(
- unsigned framebuffer) {
- makeContextCurrent();
- glDeleteFramebuffers(1, &framebuffer);
-}
-
-void WebGraphicsContext3DCommandBufferImpl::deleteProgram(unsigned program) {
- makeContextCurrent();
- glDeleteProgram(program);
-}
-
-void WebGraphicsContext3DCommandBufferImpl::deleteRenderbuffer(
- unsigned renderbuffer) {
- makeContextCurrent();
- glDeleteRenderbuffers(1, &renderbuffer);
-}
-
-void WebGraphicsContext3DCommandBufferImpl::deleteShader(unsigned shader) {
- makeContextCurrent();
- glDeleteShader(shader);
-}
-
-void WebGraphicsContext3DCommandBufferImpl::deleteTexture(unsigned texture) {
- makeContextCurrent();
- glDeleteTextures(1, &texture);
-}
-
-void WebGraphicsContext3DCommandBufferImpl::copyTextureToCompositor(
- unsigned texture, unsigned parentTexture) {
- makeContextCurrent();
- glCopyTextureToParentTextureCHROMIUM(texture, parentTexture);
- glFlush();
-}
-
-void WebGraphicsContext3DCommandBufferImpl::OnSwapBuffers() {
- // This may be called after tear-down of the RenderView.
- RenderView* renderview =
- web_view_ ? RenderView::FromWebView(web_view_) : NULL;
- if (renderview)
- renderview->DidFlushPaint();
-}
-
-#endif // USE_WGC3D_TYPES
-
#endif // defined(ENABLE_GPU)
diff --git a/chrome/renderer/webgraphicscontext3d_command_buffer_impl.h b/chrome/renderer/webgraphicscontext3d_command_buffer_impl.h
index 86ecfd4..85edd03 100644
--- a/chrome/renderer/webgraphicscontext3d_command_buffer_impl.h
+++ b/chrome/renderer/webgraphicscontext3d_command_buffer_impl.h
@@ -32,8 +32,6 @@ class GLES2Implementation;
using WebKit::WebGLId;
-#if defined(USE_WGC3D_TYPES)
-
using WebKit::WGC3Dchar;
using WebKit::WGC3Denum;
using WebKit::WGC3Dboolean;
@@ -449,383 +447,6 @@ class WebGraphicsContext3DCommandBufferImpl
#endif
};
-#else // USE_WGC3D_TYPES
-
-class WebGraphicsContext3DCommandBufferImpl
- : public WebKit::WebGraphicsContext3D {
- public:
-
- WebGraphicsContext3DCommandBufferImpl();
- virtual ~WebGraphicsContext3DCommandBufferImpl();
-
- //----------------------------------------------------------------------
- // WebGraphicsContext3D methods
- virtual bool initialize(WebGraphicsContext3D::Attributes attributes,
- WebKit::WebView*,
- bool renderDirectlyToWebView);
-
- virtual bool makeContextCurrent();
-
- virtual int width();
- virtual int height();
-
- virtual int sizeInBytes(int type);
-
- virtual bool isGLES2Compliant();
- virtual bool isGLES2NPOTStrict();
- virtual bool isErrorGeneratedOnOutOfBoundsAccesses();
-
- virtual void reshape(int width, int height);
-
- virtual bool readBackFramebuffer(unsigned char* pixels, size_t buffer_size);
-
- virtual unsigned int getPlatformTextureId();
- virtual void prepareTexture();
-
- virtual void activeTexture(unsigned long texture);
- virtual void attachShader(WebGLId program, WebGLId shader);
- virtual void bindAttribLocation(WebGLId program, unsigned long index,
- const char* name);
- virtual void bindBuffer(unsigned long target, WebGLId buffer);
- virtual void bindFramebuffer(unsigned long target, WebGLId framebuffer);
- virtual void bindRenderbuffer(unsigned long target, WebGLId renderbuffer);
- virtual void bindTexture(unsigned long target, WebGLId texture);
- virtual void blendColor(double red, double green,
- double blue, double alpha);
- virtual void blendEquation(unsigned long mode);
- virtual void blendEquationSeparate(unsigned long modeRGB,
- unsigned long modeAlpha);
- virtual void blendFunc(unsigned long sfactor, unsigned long dfactor);
- virtual void blendFuncSeparate(unsigned long srcRGB,
- unsigned long dstRGB,
- unsigned long srcAlpha,
- unsigned long dstAlpha);
-
- virtual void bufferData(unsigned long target, int size,
- const void* data, unsigned long usage);
- virtual void bufferSubData(unsigned long target, long offset,
- int size, const void* data);
-
- virtual unsigned long checkFramebufferStatus(unsigned long target);
- virtual void clear(unsigned long mask);
- virtual void clearColor(double red, double green,
- double blue, double alpha);
- virtual void clearDepth(double depth);
- virtual void clearStencil(long s);
- virtual void colorMask(bool red, bool green, bool blue, bool alpha);
- virtual void compileShader(WebGLId shader);
-
- virtual void copyTexImage2D(unsigned long target,
- long level,
- unsigned long internalformat,
- long x,
- long y,
- unsigned long width,
- unsigned long height,
- long border);
- virtual void copyTexSubImage2D(unsigned long target,
- long level,
- long xoffset,
- long yoffset,
- long x,
- long y,
- unsigned long width,
- unsigned long height);
- virtual void cullFace(unsigned long mode);
- virtual void depthFunc(unsigned long func);
- virtual void depthMask(bool flag);
- virtual void depthRange(double zNear, double zFar);
- virtual void detachShader(WebGLId program, WebGLId shader);
- virtual void disable(unsigned long cap);
- virtual void disableVertexAttribArray(unsigned long index);
- virtual void drawArrays(unsigned long mode, long first, long count);
- virtual void drawElements(unsigned long mode,
- unsigned long count,
- unsigned long type,
- long offset);
-
- virtual void enable(unsigned long cap);
- virtual void enableVertexAttribArray(unsigned long index);
- virtual void finish();
- virtual void flush();
- virtual void framebufferRenderbuffer(unsigned long target,
- unsigned long attachment,
- unsigned long renderbuffertarget,
- WebGLId renderbuffer);
- virtual void framebufferTexture2D(unsigned long target,
- unsigned long attachment,
- unsigned long textarget,
- WebGLId texture,
- long level);
- virtual void frontFace(unsigned long mode);
- virtual void generateMipmap(unsigned long target);
-
- virtual bool getActiveAttrib(WebGLId program,
- unsigned long index,
- ActiveInfo&);
- virtual bool getActiveUniform(WebGLId program,
- unsigned long index,
- ActiveInfo&);
-
- virtual void getAttachedShaders(WebGLId program,
- int maxCount,
- int* count,
- unsigned int* shaders);
-
- virtual int getAttribLocation(WebGLId program, const char* name);
-
- virtual void getBooleanv(unsigned long pname, unsigned char* value);
-
- virtual void getBufferParameteriv(unsigned long target,
- unsigned long pname,
- int* value);
-
- virtual Attributes getContextAttributes();
-
- virtual unsigned long getError();
-
- virtual bool isContextLost();
-
- virtual void getFloatv(unsigned long pname, float* value);
-
- virtual void getFramebufferAttachmentParameteriv(unsigned long target,
- unsigned long attachment,
- unsigned long pname,
- int* value);
-
- virtual void getIntegerv(unsigned long pname, int* value);
-
- virtual void getProgramiv(WebGLId program, unsigned long pname, int* value);
-
- virtual WebKit::WebString getProgramInfoLog(WebGLId program);
-
- virtual void getRenderbufferParameteriv(unsigned long target,
- unsigned long pname,
- int* value);
-
- virtual void getShaderiv(WebGLId shader, unsigned long pname, int* value);
-
- virtual WebKit::WebString getShaderInfoLog(WebGLId shader);
-
- // TBD
- // void glGetShaderPrecisionFormat (GLenum shadertype,
- // GLenum precisiontype,
- // GLint* range,
- // GLint* precision);
-
- virtual WebKit::WebString getShaderSource(WebGLId shader);
- virtual WebKit::WebString getString(unsigned long name);
-
- virtual void getTexParameterfv(unsigned long target,
- unsigned long pname,
- float* value);
- virtual void getTexParameteriv(unsigned long target,
- unsigned long pname,
- int* value);
-
- virtual void getUniformfv(WebGLId program, long location, float* value);
- virtual void getUniformiv(WebGLId program, long location, int* value);
-
- virtual long getUniformLocation(WebGLId program, const char* name);
-
- virtual void getVertexAttribfv(unsigned long index, unsigned long pname,
- float* value);
- virtual void getVertexAttribiv(unsigned long index, unsigned long pname,
- int* value);
-
- virtual long getVertexAttribOffset(unsigned long index, unsigned long pname);
-
- virtual void hint(unsigned long target, unsigned long mode);
- virtual bool isBuffer(WebGLId buffer);
- virtual bool isEnabled(unsigned long cap);
- virtual bool isFramebuffer(WebGLId framebuffer);
- virtual bool isProgram(WebGLId program);
- virtual bool isRenderbuffer(WebGLId renderbuffer);
- virtual bool isShader(WebGLId shader);
- virtual bool isTexture(WebGLId texture);
- virtual void lineWidth(double);
- virtual void linkProgram(WebGLId program);
- virtual void pixelStorei(unsigned long pname, long param);
- virtual void polygonOffset(double factor, double units);
-
- virtual void readPixels(long x,
- long y,
- unsigned long width,
- unsigned long height,
- unsigned long format,
- unsigned long type,
- void* pixels);
-
- virtual void releaseShaderCompiler();
- virtual void renderbufferStorage(unsigned long target,
- unsigned long internalformat,
- unsigned long width,
- unsigned long height);
- virtual void sampleCoverage(double value, bool invert);
- virtual void scissor(long x, long y,
- unsigned long width, unsigned long height);
- virtual void shaderSource(WebGLId shader, const char* string);
- virtual void stencilFunc(unsigned long func, long ref, unsigned long mask);
- virtual void stencilFuncSeparate(unsigned long face,
- unsigned long func,
- long ref,
- unsigned long mask);
- virtual void stencilMask(unsigned long mask);
- virtual void stencilMaskSeparate(unsigned long face, unsigned long mask);
- virtual void stencilOp(unsigned long fail,
- unsigned long zfail,
- unsigned long zpass);
- virtual void stencilOpSeparate(unsigned long face,
- unsigned long fail,
- unsigned long zfail,
- unsigned long zpass);
-
- virtual void texImage2D(unsigned target,
- unsigned level,
- unsigned internalformat,
- unsigned width,
- unsigned height,
- unsigned border,
- unsigned format,
- unsigned type,
- const void* pixels);
-
- virtual void texParameterf(unsigned target, unsigned pname, float param);
- virtual void texParameteri(unsigned target, unsigned pname, int param);
-
- virtual void texSubImage2D(unsigned target,
- unsigned level,
- unsigned xoffset,
- unsigned yoffset,
- unsigned width,
- unsigned height,
- unsigned format,
- unsigned type,
- const void* pixels);
-
- virtual void uniform1f(long location, float x);
- virtual void uniform1fv(long location, int count, float* v);
- virtual void uniform1i(long location, int x);
- virtual void uniform1iv(long location, int count, int* v);
- virtual void uniform2f(long location, float x, float y);
- virtual void uniform2fv(long location, int count, float* v);
- virtual void uniform2i(long location, int x, int y);
- virtual void uniform2iv(long location, int count, int* v);
- virtual void uniform3f(long location, float x, float y, float z);
- virtual void uniform3fv(long location, int count, float* v);
- virtual void uniform3i(long location, int x, int y, int z);
- virtual void uniform3iv(long location, int count, int* v);
- virtual void uniform4f(long location, float x, float y, float z, float w);
- virtual void uniform4fv(long location, int count, float* v);
- virtual void uniform4i(long location, int x, int y, int z, int w);
- virtual void uniform4iv(long location, int count, int* v);
- virtual void uniformMatrix2fv(long location, int count, bool transpose,
- const float* value);
- virtual void uniformMatrix3fv(long location, int count, bool transpose,
- const float* value);
- virtual void uniformMatrix4fv(long location, int count, bool transpose,
- const float* value);
-
- virtual void useProgram(WebGLId program);
- virtual void validateProgram(WebGLId program);
-
- virtual void vertexAttrib1f(unsigned long indx, float x);
- virtual void vertexAttrib1fv(unsigned long indx, const float* values);
- virtual void vertexAttrib2f(unsigned long indx, float x, float y);
- virtual void vertexAttrib2fv(unsigned long indx, const float* values);
- virtual void vertexAttrib3f(unsigned long indx, float x, float y, float z);
- virtual void vertexAttrib3fv(unsigned long indx, const float* values);
- virtual void vertexAttrib4f(unsigned long indx,
- float x, float y, float z, float w);
- virtual void vertexAttrib4fv(unsigned long indx, const float* values);
- virtual void vertexAttribPointer(unsigned long indx, int size, int type,
- bool normalized, unsigned long stride,
- unsigned long offset);
-
- virtual void viewport(long x, long y,
- unsigned long width, unsigned long height);
-
- // Support for buffer creation and deletion
- virtual unsigned createBuffer();
- virtual unsigned createFramebuffer();
- virtual unsigned createProgram();
- virtual unsigned createRenderbuffer();
- virtual unsigned createShader(unsigned long);
- virtual unsigned createTexture();
-
- virtual void deleteBuffer(unsigned);
- virtual void deleteFramebuffer(unsigned);
- virtual void deleteProgram(unsigned);
- virtual void deleteRenderbuffer(unsigned);
- virtual void deleteShader(unsigned);
- virtual void deleteTexture(unsigned);
-
- virtual void synthesizeGLError(unsigned long error);
-
- virtual void* mapBufferSubDataCHROMIUM(
- unsigned target, int offset, int size, unsigned access);
- virtual void unmapBufferSubDataCHROMIUM(const void*);
- virtual void* mapTexSubImage2DCHROMIUM(
- unsigned target,
- int level,
- int xoffset,
- int yoffset,
- int width,
- int height,
- unsigned format,
- unsigned type,
- unsigned access);
- virtual void unmapTexSubImage2DCHROMIUM(const void*);
-
- virtual void copyTextureToParentTextureCHROMIUM(
- unsigned texture, unsigned parentTexture);
-
- virtual WebKit::WebString getRequestableExtensionsCHROMIUM();
- virtual void requestExtensionCHROMIUM(const char*);
-
- virtual void blitFramebufferCHROMIUM(
- int srcX0, int srcY0, int srcX1, int srcY1,
- int dstX0, int dstY0, int dstX1, int dstY1,
- unsigned mask, unsigned filter);
- virtual void renderbufferStorageMultisampleCHROMIUM(
- unsigned long target, int samples, unsigned internalformat,
- unsigned width, unsigned height);
-
- virtual unsigned createCompositorTexture(unsigned width, unsigned height);
- virtual void deleteCompositorTexture(unsigned parent_texture);
- virtual void copyTextureToCompositor(unsigned texture,
- unsigned parent_texture);
-
- ggl::Context* context() { return context_; }
-
- private:
- // SwapBuffers callback;
- void OnSwapBuffers();
-
- // The GGL context we use for OpenGL rendering.
- ggl::Context* context_;
- // If rendering directly to WebView, weak pointer to it.
- WebKit::WebView* web_view_;
-
- WebKit::WebGraphicsContext3D::Attributes attributes_;
- int cached_width_, cached_height_;
-
- // For tracking which FBO is bound.
- unsigned int bound_fbo_;
-
- // Errors raised by synthesizeGLError().
- std::vector<unsigned long> synthetic_errors_;
-
-#ifdef FLIP_FRAMEBUFFER_VERTICALLY
- scoped_ptr<uint8> scanline_;
- void FlipVertically(uint8* framebuffer,
- unsigned int width,
- unsigned int height);
-#endif
-};
-
-#endif // USE_WGC3D_TYPES
-
#endif // defined(ENABLE_GPU)
#endif // CHROME_RENDERER_WEBGRAPHICSCONTEXT3D_COMMAND_BUFFER_IMPL_H_
diff --git a/webkit/gpu/webgraphicscontext3d_in_process_impl.cc b/webkit/gpu/webgraphicscontext3d_in_process_impl.cc
index ff7020f..3721bbf 100644
--- a/webkit/gpu/webgraphicscontext3d_in_process_impl.cc
+++ b/webkit/gpu/webgraphicscontext3d_in_process_impl.cc
@@ -25,8 +25,6 @@ enum {
MAX_FRAGMENT_UNIFORM_VECTORS = 0x8DFD
};
-#if defined(USE_WGC3D_TYPES)
-
WebGraphicsContext3DInProcessImpl::WebGraphicsContext3DInProcessImpl()
: initialized_(false),
render_directly_to_web_view_(false),
@@ -1580,1644 +1578,6 @@ bool WebGraphicsContext3DInProcessImpl::AngleValidateShaderSource(
return true;
}
-#else // USE_WGC3D_TYPES
-
-WebGraphicsContext3DInProcessImpl::
- VertexAttribPointerState::VertexAttribPointerState()
- : enabled(false),
- buffer(0),
- indx(0),
- size(0),
- type(0),
- normalized(false),
- stride(0),
- offset(0) {
-}
-
-WebGraphicsContext3DInProcessImpl::WebGraphicsContext3DInProcessImpl()
- : initialized_(false),
- render_directly_to_web_view_(false),
- is_gles2_(false),
- have_ext_framebuffer_object_(false),
- have_ext_framebuffer_multisample_(false),
- have_angle_framebuffer_multisample_(false),
- texture_(0),
- fbo_(0),
- depth_stencil_buffer_(0),
- cached_width_(0),
- cached_height_(0),
- multisample_fbo_(0),
- multisample_depth_stencil_buffer_(0),
- multisample_color_buffer_(0),
- bound_fbo_(0),
- bound_texture_(0),
- copy_texture_to_parent_texture_fbo_(0),
- bound_array_buffer_(0),
-#ifdef FLIP_FRAMEBUFFER_VERTICALLY
- scanline_(0),
-#endif
- fragment_compiler_(0),
- vertex_compiler_(0) {
-}
-
-WebGraphicsContext3DInProcessImpl::~WebGraphicsContext3DInProcessImpl() {
- if (!initialized_)
- return;
-
- makeContextCurrent();
-
- if (attributes_.antialias) {
- glDeleteRenderbuffersEXT(1, &multisample_color_buffer_);
- if (attributes_.depth || attributes_.stencil)
- glDeleteRenderbuffersEXT(1, &multisample_depth_stencil_buffer_);
- glDeleteFramebuffersEXT(1, &multisample_fbo_);
- } else {
- if (attributes_.depth || attributes_.stencil)
- glDeleteRenderbuffersEXT(1, &depth_stencil_buffer_);
- }
- glDeleteTextures(1, &texture_);
- glDeleteFramebuffersEXT(1, &copy_texture_to_parent_texture_fbo_);
-#ifdef FLIP_FRAMEBUFFER_VERTICALLY
- if (scanline_)
- delete[] scanline_;
-#endif
- glDeleteFramebuffersEXT(1, &fbo_);
-
- gl_context_->Destroy();
-
- for (ShaderSourceMap::iterator ii = shader_source_map_.begin();
- ii != shader_source_map_.end(); ++ii) {
- if (ii->second)
- delete ii->second;
- }
- AngleDestroyCompilers();
-}
-
-bool WebGraphicsContext3DInProcessImpl::initialize(
- WebGraphicsContext3D::Attributes attributes,
- WebView* webView,
- bool render_directly_to_web_view) {
- if (!gfx::GLContext::InitializeOneOff())
- return false;
-
- render_directly_to_web_view_ = render_directly_to_web_view;
- gfx::GLContext* share_context = 0;
-
- if (!render_directly_to_web_view) {
- // Pick up the compositor's context to share resources with.
- WebGraphicsContext3D* view_context = webView->graphicsContext3D();
- if (view_context) {
- WebGraphicsContext3DInProcessImpl* contextImpl =
- static_cast<WebGraphicsContext3DInProcessImpl*>(view_context);
- share_context = contextImpl->gl_context_.get();
- } else {
- // The compositor's context didn't get created
- // successfully, so conceptually there is no way we can
- // render successfully to the WebView.
- render_directly_to_web_view_ = false;
- }
- }
-
- // This implementation always renders offscreen regardless of
- // whether render_directly_to_web_view is true. Both DumpRenderTree
- // and test_shell paint first to an intermediate offscreen buffer
- // and from there to the window, and WebViewImpl::paint already
- // correctly handles the case where the compositor is active but
- // the output needs to go to a WebCanvas.
- gl_context_.reset(gfx::GLContext::CreateOffscreenGLContext(share_context));
- if (!gl_context_.get())
- return false;
-
- attributes_ = attributes;
-
- // FIXME: for the moment we disable multisampling for the compositor.
- // It actually works in this implementation, but there are a few
- // considerations. First, we likely want to reduce the fuzziness in
- // these tests as much as possible because we want to run pixel tests.
- // Second, Mesa's multisampling doesn't seem to antialias straight
- // edges in some CSS 3D samples. Third, we don't have multisampling
- // support for the compositor in the normal case at the time of this
- // writing.
- if (render_directly_to_web_view)
- attributes_.antialias = false;
-
- is_gles2_ = gfx::GetGLImplementation() == gfx::kGLImplementationEGLGLES2;
- const char* extensions =
- reinterpret_cast<const char*>(glGetString(GL_EXTENSIONS));
- have_ext_framebuffer_object_ =
- strstr(extensions, "GL_EXT_framebuffer_object") != NULL;
- have_ext_framebuffer_multisample_ =
- strstr(extensions, "GL_EXT_framebuffer_multisample") != NULL;
- have_angle_framebuffer_multisample_ =
- strstr(extensions, "GL_ANGLE_framebuffer_multisample") != NULL;
-
- ValidateAttributes();
-
- if (!is_gles2_) {
- glEnable(GL_VERTEX_PROGRAM_POINT_SIZE);
- glEnable(GL_POINT_SPRITE);
- }
-
- if (!AngleCreateCompilers()) {
- AngleDestroyCompilers();
- return false;
- }
-
- glGenFramebuffersEXT(1, &copy_texture_to_parent_texture_fbo_);
-
- initialized_ = true;
- return true;
-}
-
-void WebGraphicsContext3DInProcessImpl::ValidateAttributes() {
- const char* extensions =
- reinterpret_cast<const char*>(glGetString(GL_EXTENSIONS));
-
- if (attributes_.stencil) {
- if (strstr(extensions, "GL_OES_packed_depth_stencil") ||
- strstr(extensions, "GL_EXT_packed_depth_stencil")) {
- if (!attributes_.depth) {
- attributes_.depth = true;
- }
- } else {
- attributes_.stencil = false;
- }
- }
- if (attributes_.antialias) {
- bool isValidVendor = true;
-#if defined(OS_MACOSX)
- // Currently in Mac we only turn on antialias if vendor is NVIDIA.
- const char* vendor = reinterpret_cast<const char*>(glGetString(GL_VENDOR));
- if (!strstr(vendor, "NVIDIA"))
- isValidVendor = false;
-#endif
- if (!(isValidVendor &&
- (have_ext_framebuffer_multisample_ ||
- (have_angle_framebuffer_multisample_ &&
- strstr(extensions, "GL_OES_rgb8_rgba8")))))
- attributes_.antialias = false;
-
- // Don't antialias when using Mesa to ensure more reliable testing and
- // because it doesn't appear to multisample straight lines correctly.
- const char* renderer =
- reinterpret_cast<const char*>(glGetString(GL_RENDERER));
- if (!strncmp(renderer, "Mesa", 4)) {
- attributes_.antialias = false;
- }
- }
- // FIXME: instead of enforcing premultipliedAlpha = true, implement the
- // correct behavior when premultipliedAlpha = false is requested.
- attributes_.premultipliedAlpha = true;
-}
-
-void WebGraphicsContext3DInProcessImpl::ResolveMultisampledFramebuffer(
- unsigned x, unsigned y, unsigned width, unsigned height) {
- if (attributes_.antialias) {
- glBindFramebufferEXT(GL_READ_FRAMEBUFFER_EXT, multisample_fbo_);
- glBindFramebufferEXT(GL_DRAW_FRAMEBUFFER_EXT, fbo_);
- if (have_ext_framebuffer_multisample_) {
- glBlitFramebufferEXT(x, y,
- x + width, y + height,
- x, y,
- x + width, y + height,
- GL_COLOR_BUFFER_BIT, GL_NEAREST);
- } else {
- DCHECK(have_angle_framebuffer_multisample_);
- glBlitFramebufferANGLE(x, y,
- x + width, y + height,
- x, y,
- x + width, y + height,
- GL_COLOR_BUFFER_BIT, GL_NEAREST);
- }
- glBindFramebufferEXT(GL_FRAMEBUFFER_EXT, bound_fbo_);
- }
-}
-
-bool WebGraphicsContext3DInProcessImpl::makeContextCurrent() {
- return gl_context_->MakeCurrent();
-}
-
-int WebGraphicsContext3DInProcessImpl::width() {
- return cached_width_;
-}
-
-int WebGraphicsContext3DInProcessImpl::height() {
- return cached_height_;
-}
-
-int WebGraphicsContext3DInProcessImpl::sizeInBytes(int type) {
- switch (type) {
- case GL_BYTE:
- return sizeof(GLbyte);
- case GL_UNSIGNED_BYTE:
- return sizeof(GLubyte);
- case GL_SHORT:
- return sizeof(GLshort);
- case GL_UNSIGNED_SHORT:
- return sizeof(GLushort);
- case GL_INT:
- return sizeof(GLint);
- case GL_UNSIGNED_INT:
- return sizeof(GLuint);
- case GL_FLOAT:
- return sizeof(GLfloat);
- }
- return 0;
-}
-
-bool WebGraphicsContext3DInProcessImpl::isGLES2Compliant() {
- return is_gles2_;
-}
-
-unsigned int WebGraphicsContext3DInProcessImpl::getPlatformTextureId() {
- return texture_;
-}
-
-void WebGraphicsContext3DInProcessImpl::prepareTexture() {
- if (!render_directly_to_web_view_) {
- // We need to prepare our rendering results for the compositor.
- makeContextCurrent();
- ResolveMultisampledFramebuffer(0, 0, cached_width_, cached_height_);
- }
-}
-
-namespace {
-
-int CreateTextureObject(GLenum target) {
- GLuint texture = 0;
- glGenTextures(1, &texture);
- glBindTexture(target, texture);
- glTexParameterf(target, GL_TEXTURE_MIN_FILTER, GL_NEAREST);
- glTexParameterf(target, GL_TEXTURE_MAG_FILTER, GL_NEAREST);
- return texture;
-}
-
-} // anonymous namespace
-
-void WebGraphicsContext3DInProcessImpl::reshape(int width, int height) {
- cached_width_ = width;
- cached_height_ = height;
- makeContextCurrent();
-
- GLenum target = GL_TEXTURE_2D;
-
- if (!texture_) {
- // Generate the texture object
- texture_ = CreateTextureObject(target);
- // Generate the framebuffer object
- glGenFramebuffersEXT(1, &fbo_);
- glBindFramebufferEXT(GL_FRAMEBUFFER_EXT, fbo_);
- bound_fbo_ = fbo_;
- if (attributes_.depth || attributes_.stencil)
- glGenRenderbuffersEXT(1, &depth_stencil_buffer_);
- // Generate the multisample framebuffer object
- if (attributes_.antialias) {
- glGenFramebuffersEXT(1, &multisample_fbo_);
- glBindFramebufferEXT(GL_FRAMEBUFFER_EXT, multisample_fbo_);
- bound_fbo_ = multisample_fbo_;
- glGenRenderbuffersEXT(1, &multisample_color_buffer_);
- if (attributes_.depth || attributes_.stencil)
- glGenRenderbuffersEXT(1, &multisample_depth_stencil_buffer_);
- }
- }
-
- GLint internal_multisampled_color_format = 0;
- GLint internal_color_format = 0;
- GLint color_format = 0;
- GLint internal_depth_stencil_format = 0;
- if (attributes_.alpha) {
- // GL_RGBA8_OES == GL_RGBA8
- internal_multisampled_color_format = GL_RGBA8;
- internal_color_format = is_gles2_ ? GL_RGBA : GL_RGBA8;
- color_format = GL_RGBA;
- } else {
- // GL_RGB8_OES == GL_RGB8
- internal_multisampled_color_format = GL_RGB8;
- internal_color_format = is_gles2_ ? GL_RGB : GL_RGB8;
- color_format = GL_RGB;
- }
- if (attributes_.stencil || attributes_.depth) {
- // We don't allow the logic where stencil is required and depth is not.
- // See GraphicsContext3DInternal constructor.
- if (attributes_.stencil && attributes_.depth) {
- internal_depth_stencil_format = GL_DEPTH24_STENCIL8_EXT;
- } else {
- if (is_gles2_)
- internal_depth_stencil_format = GL_DEPTH_COMPONENT16;
- else
- internal_depth_stencil_format = GL_DEPTH_COMPONENT;
- }
- }
-
- bool must_restore_fbo = false;
-
- // Resize multisampling FBO
- if (attributes_.antialias) {
- GLint max_sample_count;
- glGetIntegerv(GL_MAX_SAMPLES_EXT, &max_sample_count);
- GLint sample_count = std::min(8, max_sample_count);
- if (bound_fbo_ != multisample_fbo_) {
- must_restore_fbo = true;
- glBindFramebufferEXT(GL_FRAMEBUFFER_EXT, multisample_fbo_);
- }
- glBindRenderbufferEXT(GL_RENDERBUFFER_EXT, multisample_color_buffer_);
- if (have_ext_framebuffer_multisample_) {
- glRenderbufferStorageMultisampleEXT(GL_RENDERBUFFER_EXT,
- sample_count,
- internal_multisampled_color_format,
- width,
- height);
- } else {
- DCHECK(have_angle_framebuffer_multisample_);
- glRenderbufferStorageMultisampleANGLE(GL_RENDERBUFFER_EXT,
- sample_count,
- internal_multisampled_color_format,
- width,
- height);
- }
- glFramebufferRenderbufferEXT(GL_FRAMEBUFFER_EXT,
- GL_COLOR_ATTACHMENT0_EXT,
- GL_RENDERBUFFER_EXT,
- multisample_color_buffer_);
- if (attributes_.stencil || attributes_.depth) {
- glBindRenderbufferEXT(GL_RENDERBUFFER_EXT,
- multisample_depth_stencil_buffer_);
- if (have_ext_framebuffer_multisample_) {
- glRenderbufferStorageMultisampleEXT(GL_RENDERBUFFER_EXT,
- sample_count,
- internal_depth_stencil_format,
- width,
- height);
- } else {
- DCHECK(have_angle_framebuffer_multisample_);
- glRenderbufferStorageMultisampleANGLE(GL_RENDERBUFFER_EXT,
- sample_count,
- internal_depth_stencil_format,
- width,
- height);
- }
- if (attributes_.stencil)
- glFramebufferRenderbufferEXT(GL_FRAMEBUFFER_EXT,
- GL_STENCIL_ATTACHMENT_EXT,
- GL_RENDERBUFFER_EXT,
- multisample_depth_stencil_buffer_);
- if (attributes_.depth)
- glFramebufferRenderbufferEXT(GL_FRAMEBUFFER_EXT,
- GL_DEPTH_ATTACHMENT_EXT,
- GL_RENDERBUFFER_EXT,
- multisample_depth_stencil_buffer_);
- }
- glBindRenderbufferEXT(GL_RENDERBUFFER_EXT, 0);
- GLenum status = glCheckFramebufferStatusEXT(GL_FRAMEBUFFER_EXT);
- if (status != GL_FRAMEBUFFER_COMPLETE_EXT) {
- LOG(ERROR) << "Multisampling framebuffer was incomplete";
-
- // FIXME: cleanup.
- NOTIMPLEMENTED();
- }
- }
-
- // Resize regular FBO
- if (bound_fbo_ != fbo_) {
- glBindFramebufferEXT(GL_FRAMEBUFFER_EXT, fbo_);
- must_restore_fbo = true;
- }
- glBindTexture(target, texture_);
- glTexImage2D(target, 0, internal_color_format,
- width, height,
- 0, color_format, GL_UNSIGNED_BYTE, 0);
- glFramebufferTexture2DEXT(GL_FRAMEBUFFER_EXT,
- GL_COLOR_ATTACHMENT0_EXT,
- target,
- texture_,
- 0);
- glBindTexture(target, 0);
- if (!attributes_.antialias && (attributes_.stencil || attributes_.depth)) {
- glBindRenderbufferEXT(GL_RENDERBUFFER_EXT, depth_stencil_buffer_);
- glRenderbufferStorageEXT(GL_RENDERBUFFER_EXT,
- internal_depth_stencil_format,
- width, height);
- if (attributes_.stencil)
- glFramebufferRenderbufferEXT(GL_FRAMEBUFFER_EXT,
- GL_STENCIL_ATTACHMENT_EXT,
- GL_RENDERBUFFER_EXT,
- depth_stencil_buffer_);
- if (attributes_.depth)
- glFramebufferRenderbufferEXT(GL_FRAMEBUFFER_EXT,
- GL_DEPTH_ATTACHMENT_EXT,
- GL_RENDERBUFFER_EXT,
- depth_stencil_buffer_);
- glBindRenderbufferEXT(GL_RENDERBUFFER_EXT, 0);
- }
- GLenum status = glCheckFramebufferStatusEXT(GL_FRAMEBUFFER_EXT);
- if (status != GL_FRAMEBUFFER_COMPLETE_EXT) {
- LOG(ERROR) << "Framebuffer was incomplete";
-
- // FIXME: cleanup.
- NOTIMPLEMENTED();
- }
-
- if (attributes_.antialias) {
- glBindFramebufferEXT(GL_FRAMEBUFFER_EXT, multisample_fbo_);
- if (bound_fbo_ == multisample_fbo_)
- must_restore_fbo = false;
- }
-
- // Initialize renderbuffers to 0.
- GLfloat clearColor[] = {0, 0, 0, 0}, clearDepth = 0;
- GLint clearStencil = 0;
- GLboolean colorMask[] = {GL_TRUE, GL_TRUE, GL_TRUE, GL_TRUE};
- GLboolean depthMask = GL_TRUE;
- GLuint stencilMask = 0xffffffff;
- GLboolean isScissorEnabled = GL_FALSE;
- GLboolean isDitherEnabled = GL_FALSE;
- GLbitfield clearMask = GL_COLOR_BUFFER_BIT;
- glGetFloatv(GL_COLOR_CLEAR_VALUE, clearColor);
- glClearColor(0, 0, 0, 0);
- glGetBooleanv(GL_COLOR_WRITEMASK, colorMask);
- glColorMask(GL_TRUE, GL_TRUE, GL_TRUE, GL_TRUE);
- if (attributes_.depth) {
- glGetFloatv(GL_DEPTH_CLEAR_VALUE, &clearDepth);
- glClearDepth(1);
- glGetBooleanv(GL_DEPTH_WRITEMASK, &depthMask);
- glDepthMask(GL_TRUE);
- clearMask |= GL_DEPTH_BUFFER_BIT;
- }
- if (attributes_.stencil) {
- glGetIntegerv(GL_STENCIL_CLEAR_VALUE, &clearStencil);
- glClearStencil(0);
- glGetIntegerv(GL_STENCIL_WRITEMASK,
- reinterpret_cast<GLint*>(&stencilMask));
- glStencilMaskSeparate(GL_FRONT, 0xffffffff);
- clearMask |= GL_STENCIL_BUFFER_BIT;
- }
- isScissorEnabled = glIsEnabled(GL_SCISSOR_TEST);
- glDisable(GL_SCISSOR_TEST);
- isDitherEnabled = glIsEnabled(GL_DITHER);
- glDisable(GL_DITHER);
-
- glClear(clearMask);
-
- glClearColor(clearColor[0], clearColor[1], clearColor[2], clearColor[3]);
- glColorMask(colorMask[0], colorMask[1], colorMask[2], colorMask[3]);
- if (attributes_.depth) {
- glClearDepth(clearDepth);
- glDepthMask(depthMask);
- }
- if (attributes_.stencil) {
- glClearStencil(clearStencil);
- glStencilMaskSeparate(GL_FRONT, stencilMask);
- }
- if (isScissorEnabled)
- glEnable(GL_SCISSOR_TEST);
- else
- glDisable(GL_SCISSOR_TEST);
- if (isDitherEnabled)
- glEnable(GL_DITHER);
- else
- glDisable(GL_DITHER);
-
- if (must_restore_fbo)
- glBindFramebufferEXT(GL_FRAMEBUFFER_EXT, bound_fbo_);
-
-#ifdef FLIP_FRAMEBUFFER_VERTICALLY
- if (scanline_) {
- delete[] scanline_;
- scanline_ = 0;
- }
- scanline_ = new unsigned char[width * 4];
-#endif // FLIP_FRAMEBUFFER_VERTICALLY
-}
-
-#ifdef FLIP_FRAMEBUFFER_VERTICALLY
-void WebGraphicsContext3DInProcessImpl::FlipVertically(
- unsigned char* framebuffer, unsigned int width, unsigned int height) {
- unsigned char* scanline = scanline_;
- if (!scanline)
- return;
- unsigned int row_bytes = width * 4;
- unsigned int count = height / 2;
- for (unsigned int i = 0; i < count; i++) {
- unsigned char* row_a = framebuffer + i * row_bytes;
- unsigned char* row_b = framebuffer + (height - i - 1) * row_bytes;
- // FIXME: this is where the multiplication of the alpha
- // channel into the color buffer will need to occur if the
- // user specifies the "premultiplyAlpha" flag in the context
- // creation attributes.
- memcpy(scanline, row_b, row_bytes);
- memcpy(row_b, row_a, row_bytes);
- memcpy(row_a, scanline, row_bytes);
- }
-}
-#endif
-
-bool WebGraphicsContext3DInProcessImpl::readBackFramebuffer(
- unsigned char* pixels, size_t bufferSize) {
- if (bufferSize != static_cast<size_t>(4 * width() * height()))
- return false;
-
- makeContextCurrent();
-
- // Earlier versions of this code used the GPU to flip the
- // framebuffer vertically before reading it back for compositing
- // via software. This code was quite complicated, used a lot of
- // GPU memory, and didn't provide an obvious speedup. Since this
- // vertical flip is only a temporary solution anyway until Chrome
- // is fully GPU composited, it wasn't worth the complexity.
-
- ResolveMultisampledFramebuffer(0, 0, cached_width_, cached_height_);
- glBindFramebufferEXT(GL_FRAMEBUFFER_EXT, fbo_);
-
- GLint pack_alignment = 4;
- bool must_restore_pack_alignment = false;
- glGetIntegerv(GL_PACK_ALIGNMENT, &pack_alignment);
- if (pack_alignment > 4) {
- glPixelStorei(GL_PACK_ALIGNMENT, 4);
- must_restore_pack_alignment = true;
- }
-
- if (is_gles2_) {
- // FIXME: consider testing for presence of GL_OES_read_format
- // and GL_EXT_read_format_bgra, and using GL_BGRA_EXT here
- // directly.
- glReadPixels(0, 0, cached_width_, cached_height_,
- GL_RGBA, GL_UNSIGNED_BYTE, pixels);
- for (size_t i = 0; i < bufferSize; i += 4) {
- std::swap(pixels[i], pixels[i + 2]);
- }
- } else {
- glReadPixels(0, 0, cached_width_, cached_height_,
- GL_BGRA, GL_UNSIGNED_BYTE, pixels);
- }
-
- if (must_restore_pack_alignment)
- glPixelStorei(GL_PACK_ALIGNMENT, pack_alignment);
-
- glBindFramebufferEXT(GL_FRAMEBUFFER_EXT, bound_fbo_);
-
-#ifdef FLIP_FRAMEBUFFER_VERTICALLY
- if (pixels)
- FlipVertically(pixels, cached_width_, cached_height_);
-#endif
-
- return true;
-}
-
-void WebGraphicsContext3DInProcessImpl::synthesizeGLError(unsigned long error) {
- if (synthetic_errors_set_.find(error) == synthetic_errors_set_.end()) {
- synthetic_errors_set_.insert(error);
- synthetic_errors_list_.push_back(error);
- }
-}
-
-void* WebGraphicsContext3DInProcessImpl::mapBufferSubDataCHROMIUM(
- unsigned target, int offset, int size, unsigned access) {
- return 0;
-}
-
-void WebGraphicsContext3DInProcessImpl::unmapBufferSubDataCHROMIUM(
- const void* mem) {
-}
-
-void* WebGraphicsContext3DInProcessImpl::mapTexSubImage2DCHROMIUM(
- unsigned target, int level, int xoffset, int yoffset,
- int width, int height, unsigned format, unsigned type, unsigned access) {
- return 0;
-}
-
-void WebGraphicsContext3DInProcessImpl::unmapTexSubImage2DCHROMIUM(
- const void* mem) {
-}
-
-void WebGraphicsContext3DInProcessImpl::copyTextureToParentTextureCHROMIUM(
- unsigned id, unsigned id2) {
- if (!glGetTexLevelParameteriv)
- return;
-
- makeContextCurrent();
- glBindFramebufferEXT(GL_FRAMEBUFFER_EXT, copy_texture_to_parent_texture_fbo_);
- glFramebufferTexture2DEXT(GL_FRAMEBUFFER,
- GL_COLOR_ATTACHMENT0,
- GL_TEXTURE_2D,
- id,
- 0); // level
- glBindTexture(GL_TEXTURE_2D, id2);
- GLsizei width, height;
- glGetTexLevelParameteriv(GL_TEXTURE_2D, 0, GL_TEXTURE_WIDTH, &width);
- glGetTexLevelParameteriv(GL_TEXTURE_2D, 0, GL_TEXTURE_HEIGHT, &height);
- glCopyTexImage2D(GL_TEXTURE_2D,
- 0, // level
- GL_RGBA,
- 0, 0, // x, y
- width,
- height,
- 0); // border
- glBindTexture(GL_TEXTURE_2D, bound_texture_);
- glBindFramebufferEXT(GL_FRAMEBUFFER_EXT, bound_fbo_);
-}
-
-WebString WebGraphicsContext3DInProcessImpl::
- getRequestableExtensionsCHROMIUM() {
- return WebString();
-}
-
-void WebGraphicsContext3DInProcessImpl::requestExtensionCHROMIUM(const char*) {
-}
-
-void WebGraphicsContext3DInProcessImpl::blitFramebufferCHROMIUM(
- int srcX0, int srcY0, int srcX1, int srcY1,
- int dstX0, int dstY0, int dstX1, int dstY1,
- unsigned mask, unsigned filter) {
-}
-
-void WebGraphicsContext3DInProcessImpl::renderbufferStorageMultisampleCHROMIUM(
- unsigned long target, int samples, unsigned internalformat,
- unsigned width, unsigned height) {
-}
-
-// Helper macros to reduce the amount of code.
-
-#define DELEGATE_TO_GL(name, glname) \
-void WebGraphicsContext3DInProcessImpl::name() { \
- makeContextCurrent(); \
- gl##glname(); \
-}
-
-#define DELEGATE_TO_GL_1(name, glname, t1) \
-void WebGraphicsContext3DInProcessImpl::name(t1 a1) { \
- makeContextCurrent(); \
- gl##glname(a1); \
-}
-
-#define DELEGATE_TO_GL_1_C(name, glname, t1) \
-void WebGraphicsContext3DInProcessImpl::name(t1 a1) { \
- makeContextCurrent(); \
- gl##glname(static_cast<GLclampf>(a1)); \
-}
-
-#define DELEGATE_TO_GL_1R(name, glname, t1, rt) \
-rt WebGraphicsContext3DInProcessImpl::name(t1 a1) { \
- makeContextCurrent(); \
- return gl##glname(a1); \
-}
-
-#define DELEGATE_TO_GL_1RB(name, glname, t1, rt) \
-rt WebGraphicsContext3DInProcessImpl::name(t1 a1) { \
- makeContextCurrent(); \
- return gl##glname(a1) ? true : false; \
-}
-
-#define DELEGATE_TO_GL_2(name, glname, t1, t2) \
-void WebGraphicsContext3DInProcessImpl::name(t1 a1, t2 a2) { \
- makeContextCurrent(); \
- gl##glname(a1, a2); \
-}
-
-#define DELEGATE_TO_GL_2_C1(name, glname, t1, t2) \
-void WebGraphicsContext3DInProcessImpl::name(t1 a1, t2 a2) { \
- makeContextCurrent(); \
- gl##glname(static_cast<GLclampf>(a1), a2); \
-}
-
-#define DELEGATE_TO_GL_2_C12(name, glname, t1, t2) \
-void WebGraphicsContext3DInProcessImpl::name(t1 a1, t2 a2) { \
- makeContextCurrent(); \
- gl##glname(static_cast<GLclampf>(a1), static_cast<GLclampf>(a2)); \
-}
-
-#define DELEGATE_TO_GL_2R(name, glname, t1, t2, rt) \
-rt WebGraphicsContext3DInProcessImpl::name(t1 a1, t2 a2) { \
- makeContextCurrent(); \
- return gl##glname(a1, a2); \
-}
-
-#define DELEGATE_TO_GL_3(name, glname, t1, t2, t3) \
-void WebGraphicsContext3DInProcessImpl::name(t1 a1, t2 a2, t3 a3) { \
- makeContextCurrent(); \
- gl##glname(a1, a2, a3); \
-}
-
-#define DELEGATE_TO_GL_4(name, glname, t1, t2, t3, t4) \
-void WebGraphicsContext3DInProcessImpl::name(t1 a1, t2 a2, t3 a3, t4 a4) { \
- makeContextCurrent(); \
- gl##glname(a1, a2, a3, a4); \
-}
-
-#define DELEGATE_TO_GL_4_C1234(name, glname, t1, t2, t3, t4) \
-void WebGraphicsContext3DInProcessImpl::name(t1 a1, t2 a2, t3 a3, t4 a4) { \
- makeContextCurrent(); \
- gl##glname(static_cast<GLclampf>(a1), static_cast<GLclampf>(a2), \
- static_cast<GLclampf>(a3), static_cast<GLclampf>(a4)); \
-}
-
-#define DELEGATE_TO_GL_5(name, glname, t1, t2, t3, t4, t5) \
-void WebGraphicsContext3DInProcessImpl::name(t1 a1, t2 a2, t3 a3, t4 a4, \
- t5 a5) { \
- makeContextCurrent(); \
- gl##glname(a1, a2, a3, a4, a5); \
-}
-
-#define DELEGATE_TO_GL_6(name, glname, t1, t2, t3, t4, t5, t6) \
-void WebGraphicsContext3DInProcessImpl::name(t1 a1, t2 a2, t3 a3, t4 a4, \
- t5 a5, t6 a6) { \
- makeContextCurrent(); \
- gl##glname(a1, a2, a3, a4, a5, a6); \
-}
-
-#define DELEGATE_TO_GL_7(name, glname, t1, t2, t3, t4, t5, t6, t7) \
-void WebGraphicsContext3DInProcessImpl::name(t1 a1, t2 a2, t3 a3, t4 a4, \
- t5 a5, t6 a6, t7 a7) { \
- makeContextCurrent(); \
- gl##glname(a1, a2, a3, a4, a5, a6, a7); \
-}
-
-#define DELEGATE_TO_GL_8(name, glname, t1, t2, t3, t4, t5, t6, t7, t8) \
-void WebGraphicsContext3DInProcessImpl::name(t1 a1, t2 a2, t3 a3, t4 a4, \
- t5 a5, t6 a6, t7 a7, t8 a8) { \
- makeContextCurrent(); \
- gl##glname(a1, a2, a3, a4, a5, a6, a7, a8); \
-}
-
-#define DELEGATE_TO_GL_9(name, glname, t1, t2, t3, t4, t5, t6, t7, t8, t9) \
-void WebGraphicsContext3DInProcessImpl::name(t1 a1, t2 a2, t3 a3, t4 a4, \
- t5 a5, t6 a6, t7 a7, t8 a8, \
- t9 a9) { \
- makeContextCurrent(); \
- gl##glname(a1, a2, a3, a4, a5, a6, a7, a8, a9); \
-}
-
-void WebGraphicsContext3DInProcessImpl::activeTexture(unsigned long texture) {
- // FIXME: query number of textures available.
- if (texture < GL_TEXTURE0 || texture > GL_TEXTURE0+32)
- // FIXME: raise exception.
- return;
-
- makeContextCurrent();
- glActiveTexture(texture);
-}
-
-DELEGATE_TO_GL_2(attachShader, AttachShader, WebGLId, WebGLId)
-
-DELEGATE_TO_GL_3(bindAttribLocation, BindAttribLocation,
- WebGLId, unsigned long, const char*)
-
-void WebGraphicsContext3DInProcessImpl::bindBuffer(
- unsigned long target, WebGLId buffer) {
- makeContextCurrent();
- if (target == GL_ARRAY_BUFFER)
- bound_array_buffer_ = buffer;
- glBindBuffer(target, buffer);
-}
-
-void WebGraphicsContext3DInProcessImpl::bindFramebuffer(
- unsigned long target, WebGLId framebuffer) {
- makeContextCurrent();
- if (!framebuffer)
- framebuffer = (attributes_.antialias ? multisample_fbo_ : fbo_);
- if (framebuffer != bound_fbo_) {
- glBindFramebufferEXT(target, framebuffer);
- bound_fbo_ = framebuffer;
- }
-}
-
-DELEGATE_TO_GL_2(bindRenderbuffer, BindRenderbufferEXT, unsigned long, WebGLId)
-
-void WebGraphicsContext3DInProcessImpl::bindTexture(
- unsigned long target, WebGLId texture) {
- makeContextCurrent();
- glBindTexture(target, texture);
- bound_texture_ = texture;
-}
-
-DELEGATE_TO_GL_4_C1234(blendColor, BlendColor, double, double, double, double)
-
-DELEGATE_TO_GL_1(blendEquation, BlendEquation, unsigned long)
-
-DELEGATE_TO_GL_2(blendEquationSeparate, BlendEquationSeparate,
- unsigned long, unsigned long)
-
-DELEGATE_TO_GL_2(blendFunc, BlendFunc, unsigned long, unsigned long)
-
-DELEGATE_TO_GL_4(blendFuncSeparate, BlendFuncSeparate,
- unsigned long, unsigned long, unsigned long, unsigned long)
-
-DELEGATE_TO_GL_4(bufferData, BufferData,
- unsigned long, int, const void*, unsigned long)
-
-DELEGATE_TO_GL_4(bufferSubData, BufferSubData,
- unsigned long, long, int, const void*)
-
-DELEGATE_TO_GL_1R(checkFramebufferStatus, CheckFramebufferStatusEXT,
- unsigned long, unsigned long)
-
-DELEGATE_TO_GL_1(clear, Clear, unsigned long)
-
-DELEGATE_TO_GL_4_C1234(clearColor, ClearColor, double, double, double, double)
-
-DELEGATE_TO_GL_1(clearDepth, ClearDepth, double)
-
-DELEGATE_TO_GL_1(clearStencil, ClearStencil, long)
-
-DELEGATE_TO_GL_4(colorMask, ColorMask, bool, bool, bool, bool)
-
-void WebGraphicsContext3DInProcessImpl::compileShader(WebGLId shader) {
- makeContextCurrent();
-
- ShaderSourceMap::iterator result = shader_source_map_.find(shader);
- if (result == shader_source_map_.end()) {
- // Passing down to gl driver to generate the correct error; or the case
- // where the shader deletion is delayed when it's attached to a program.
- glCompileShader(shader);
- return;
- }
- ShaderSourceEntry* entry = result->second;
- DCHECK(entry);
-
- if (!AngleValidateShaderSource(entry)) {
- // Shader didn't validate; don't move forward with compiling
- // translated source.
- return;
- }
-
- const char* translated_source = entry->translated_source.get();
- int shader_length = translated_source ? strlen(translated_source) : 0;
- glShaderSource(
- shader, 1, const_cast<const char**>(&translated_source), &shader_length);
- glCompileShader(shader);
-
-#ifndef NDEBUG
- int compileStatus;
- glGetShaderiv(shader, GL_COMPILE_STATUS, &compileStatus);
- // DCHECK that ANGLE generated GLSL will be accepted by OpenGL
- DCHECK(compileStatus == GL_TRUE);
-#endif
-}
-
-void WebGraphicsContext3DInProcessImpl::copyTexImage2D(
- unsigned long target, long level, unsigned long internalformat,
- long x, long y, unsigned long width, unsigned long height, long border) {
- makeContextCurrent();
-
- bool needsResolve = (attributes_.antialias && bound_fbo_ == multisample_fbo_);
- if (needsResolve) {
- ResolveMultisampledFramebuffer(x, y, width, height);
- glBindFramebufferEXT(GL_FRAMEBUFFER_EXT, fbo_);
- }
-
- glCopyTexImage2D(target, level, internalformat, x, y, width, height, border);
-
- if (needsResolve)
- glBindFramebufferEXT(GL_FRAMEBUFFER_EXT, bound_fbo_);
-}
-
-void WebGraphicsContext3DInProcessImpl::copyTexSubImage2D(
- unsigned long target, long level, long xoffset, long yoffset,
- long x, long y, unsigned long width, unsigned long height) {
- makeContextCurrent();
-
- bool needsResolve = (attributes_.antialias && bound_fbo_ == multisample_fbo_);
- if (needsResolve) {
- ResolveMultisampledFramebuffer(x, y, width, height);
- glBindFramebufferEXT(GL_FRAMEBUFFER_EXT, fbo_);
- }
-
- glCopyTexSubImage2D(target, level, xoffset, yoffset, x, y, width, height);
-
- if (needsResolve)
- glBindFramebufferEXT(GL_FRAMEBUFFER_EXT, bound_fbo_);
-}
-
-DELEGATE_TO_GL_1(cullFace, CullFace, unsigned long)
-
-DELEGATE_TO_GL_1(depthFunc, DepthFunc, unsigned long)
-
-DELEGATE_TO_GL_1(depthMask, DepthMask, bool)
-
-DELEGATE_TO_GL_2(depthRange, DepthRange, double, double)
-
-DELEGATE_TO_GL_2(detachShader, DetachShader, WebGLId, WebGLId)
-
-DELEGATE_TO_GL_1(disable, Disable, unsigned long)
-
-void WebGraphicsContext3DInProcessImpl::disableVertexAttribArray(
- unsigned long index) {
- makeContextCurrent();
- if (index < kNumTrackedPointerStates)
- vertex_attrib_pointer_state_[index].enabled = false;
- glDisableVertexAttribArray(index);
-}
-
-DELEGATE_TO_GL_3(drawArrays, DrawArrays, unsigned long, long, long)
-
-void WebGraphicsContext3DInProcessImpl::drawElements(
- unsigned long mode, unsigned long count, unsigned long type, long offset) {
- makeContextCurrent();
- glDrawElements(mode, count, type,
- reinterpret_cast<void*>(static_cast<intptr_t>(offset)));
-}
-
-DELEGATE_TO_GL_1(enable, Enable, unsigned long)
-
-void WebGraphicsContext3DInProcessImpl::enableVertexAttribArray(
- unsigned long index) {
- makeContextCurrent();
- if (index < kNumTrackedPointerStates)
- vertex_attrib_pointer_state_[index].enabled = true;
- glEnableVertexAttribArray(index);
-}
-
-DELEGATE_TO_GL(finish, Finish)
-
-DELEGATE_TO_GL(flush, Flush)
-
-DELEGATE_TO_GL_4(framebufferRenderbuffer, FramebufferRenderbufferEXT,
- unsigned long, unsigned long, unsigned long, WebGLId)
-
-DELEGATE_TO_GL_5(framebufferTexture2D, FramebufferTexture2DEXT,
- unsigned long, unsigned long, unsigned long, WebGLId, long)
-
-DELEGATE_TO_GL_1(frontFace, FrontFace, unsigned long)
-
-void WebGraphicsContext3DInProcessImpl::generateMipmap(unsigned long target) {
- makeContextCurrent();
- if (is_gles2_ || have_ext_framebuffer_object_)
- glGenerateMipmapEXT(target);
- // FIXME: provide alternative code path? This will be unpleasant
- // to implement if glGenerateMipmapEXT is not available -- it will
- // require a texture readback and re-upload.
-}
-
-bool WebGraphicsContext3DInProcessImpl::getActiveAttrib(
- WebGLId program, unsigned long index, ActiveInfo& info) {
- makeContextCurrent();
- if (!program) {
- synthesizeGLError(GL_INVALID_VALUE);
- return false;
- }
- GLint max_name_length = -1;
- glGetProgramiv(program, GL_ACTIVE_ATTRIBUTE_MAX_LENGTH, &max_name_length);
- if (max_name_length < 0)
- return false;
- scoped_array<GLchar> name(new GLchar[max_name_length]);
- GLsizei length = 0;
- GLint size = -1;
- GLenum type = 0;
- glGetActiveAttrib(program, index, max_name_length,
- &length, &size, &type, name.get());
- if (size < 0) {
- return false;
- }
- info.name = WebString::fromUTF8(name.get(), length);
- info.type = type;
- info.size = size;
- return true;
-}
-
-bool WebGraphicsContext3DInProcessImpl::getActiveUniform(
- WebGLId program, unsigned long index, ActiveInfo& info) {
- makeContextCurrent();
- GLint max_name_length = -1;
- glGetProgramiv(program, GL_ACTIVE_UNIFORM_MAX_LENGTH, &max_name_length);
- if (max_name_length < 0)
- return false;
- scoped_array<GLchar> name(new GLchar[max_name_length]);
- GLsizei length = 0;
- GLint size = -1;
- GLenum type = 0;
- glGetActiveUniform(program, index, max_name_length,
- &length, &size, &type, name.get());
- if (size < 0) {
- return false;
- }
- info.name = WebString::fromUTF8(name.get(), length);
- info.type = type;
- info.size = size;
- return true;
-}
-
-DELEGATE_TO_GL_4(getAttachedShaders, GetAttachedShaders,
- WebGLId, int, int*, unsigned int*)
-
-DELEGATE_TO_GL_2R(getAttribLocation, GetAttribLocation,
- WebGLId, const char*, int)
-
-DELEGATE_TO_GL_2(getBooleanv, GetBooleanv,
- unsigned long, unsigned char*)
-
-DELEGATE_TO_GL_3(getBufferParameteriv, GetBufferParameteriv,
- unsigned long, unsigned long, int*)
-
-WebGraphicsContext3D::Attributes WebGraphicsContext3DInProcessImpl::
- getContextAttributes() {
- return attributes_;
-}
-
-unsigned long WebGraphicsContext3DInProcessImpl::getError() {
- DCHECK(synthetic_errors_list_.size() == synthetic_errors_set_.size());
- if (synthetic_errors_set_.size() > 0) {
- unsigned long error = synthetic_errors_list_.front();
- synthetic_errors_list_.pop_front();
- synthetic_errors_set_.erase(error);
- return error;
- }
-
- makeContextCurrent();
- return glGetError();
-}
-
-bool WebGraphicsContext3DInProcessImpl::isContextLost() {
- return false;
-}
-
-DELEGATE_TO_GL_2(getFloatv, GetFloatv, unsigned long, float*)
-
-void WebGraphicsContext3DInProcessImpl::getFramebufferAttachmentParameteriv(
- unsigned long target, unsigned long attachment,
- unsigned long pname, int* value) {
- makeContextCurrent();
- if (attachment == GL_DEPTH_STENCIL_ATTACHMENT)
- attachment = GL_DEPTH_ATTACHMENT; // Or GL_STENCIL_ATTACHMENT;
- // either works.
- glGetFramebufferAttachmentParameterivEXT(target, attachment, pname, value);
-}
-
-void WebGraphicsContext3DInProcessImpl::getIntegerv(
- unsigned long pname, int* value) {
- makeContextCurrent();
- if (is_gles2_) {
- glGetIntegerv(pname, value);
- return;
- }
- // Need to emulate MAX_FRAGMENT/VERTEX_UNIFORM_VECTORS and
- // MAX_VARYING_VECTORS because desktop GL's corresponding queries
- // return the number of components whereas GLES2 return the number
- // of vectors (each vector has 4 components). Therefore, the value
- // returned by desktop GL needs to be divided by 4.
- switch (pname) {
- case MAX_FRAGMENT_UNIFORM_VECTORS:
- glGetIntegerv(GL_MAX_FRAGMENT_UNIFORM_COMPONENTS, value);
- *value /= 4;
- break;
- case MAX_VERTEX_UNIFORM_VECTORS:
- glGetIntegerv(GL_MAX_VERTEX_UNIFORM_COMPONENTS, value);
- *value /= 4;
- break;
- case MAX_VARYING_VECTORS:
- glGetIntegerv(GL_MAX_VARYING_FLOATS, value);
- *value /= 4;
- break;
- default:
- glGetIntegerv(pname, value);
- }
-}
-
-DELEGATE_TO_GL_3(getProgramiv, GetProgramiv, WebGLId, unsigned long, int*)
-
-WebString WebGraphicsContext3DInProcessImpl::getProgramInfoLog(
- WebGLId program) {
- makeContextCurrent();
- GLint log_length;
- glGetProgramiv(program, GL_INFO_LOG_LENGTH, &log_length);
- if (!log_length)
- return WebString();
- scoped_array<GLchar> log(new GLchar[log_length]);
- GLsizei returned_log_length;
- glGetProgramInfoLog(program, log_length, &returned_log_length, log.get());
- DCHECK(log_length == returned_log_length + 1);
- WebString res = WebString::fromUTF8(log.get(), returned_log_length);
- return res;
-}
-
-DELEGATE_TO_GL_3(getRenderbufferParameteriv, GetRenderbufferParameterivEXT,
- unsigned long, unsigned long, int*)
-
-void WebGraphicsContext3DInProcessImpl::getShaderiv(
- WebGLId shader, unsigned long pname, int* value) {
- makeContextCurrent();
-
- ShaderSourceMap::iterator result = shader_source_map_.find(shader);
- if (result != shader_source_map_.end()) {
- ShaderSourceEntry* entry = result->second;
- DCHECK(entry);
- switch (pname) {
- case GL_COMPILE_STATUS:
- if (!entry->is_valid) {
- *value = 0;
- return;
- }
- break;
- case GL_INFO_LOG_LENGTH:
- if (!entry->is_valid) {
- *value = entry->log.get() ? strlen(entry->log.get()) : 0;
- if (*value)
- (*value)++;
- return;
- }
- break;
- case GL_SHADER_SOURCE_LENGTH:
- *value = entry->source.get() ? strlen(entry->source.get()) : 0;
- if (*value)
- (*value)++;
- return;
- }
- }
-
- glGetShaderiv(shader, pname, value);
-}
-
-WebString WebGraphicsContext3DInProcessImpl::getShaderInfoLog(WebGLId shader) {
- makeContextCurrent();
-
- ShaderSourceMap::iterator result = shader_source_map_.find(shader);
- if (result != shader_source_map_.end()) {
- ShaderSourceEntry* entry = result->second;
- DCHECK(entry);
- if (!entry->is_valid) {
- if (!entry->log.get())
- return WebString();
- WebString res = WebString::fromUTF8(
- entry->log.get(), strlen(entry->log.get()));
- return res;
- }
- }
-
- GLint log_length = 0;
- glGetShaderiv(shader, GL_INFO_LOG_LENGTH, &log_length);
- if (log_length <= 1)
- return WebString();
- scoped_array<GLchar> log(new GLchar[log_length]);
- GLsizei returned_log_length;
- glGetShaderInfoLog(shader, log_length, &returned_log_length, log.get());
- DCHECK(log_length == returned_log_length + 1);
- WebString res = WebString::fromUTF8(log.get(), returned_log_length);
- return res;
-}
-
-WebString WebGraphicsContext3DInProcessImpl::getShaderSource(WebGLId shader) {
- makeContextCurrent();
-
- ShaderSourceMap::iterator result = shader_source_map_.find(shader);
- if (result != shader_source_map_.end()) {
- ShaderSourceEntry* entry = result->second;
- DCHECK(entry);
- if (!entry->source.get())
- return WebString();
- WebString res = WebString::fromUTF8(
- entry->source.get(), strlen(entry->source.get()));
- return res;
- }
-
- GLint log_length = 0;
- glGetShaderiv(shader, GL_SHADER_SOURCE_LENGTH, &log_length);
- if (log_length <= 1)
- return WebString();
- scoped_array<GLchar> log(new GLchar[log_length]);
- GLsizei returned_log_length;
- glGetShaderSource(shader, log_length, &returned_log_length, log.get());
- DCHECK(log_length == returned_log_length + 1);
- WebString res = WebString::fromUTF8(log.get(), returned_log_length);
- return res;
-}
-
-WebString WebGraphicsContext3DInProcessImpl::getString(unsigned long name) {
- makeContextCurrent();
- std::string result(reinterpret_cast<const char*>(glGetString(name)));
- if (name == GL_EXTENSIONS) {
- // GL_CHROMIUM_copy_texture_to_parent_texture requires the
- // desktopGL-only function glGetTexLevelParameteriv (GLES2
- // doesn't support it).
- if (!is_gles2_)
- result += " GL_CHROMIUM_copy_texture_to_parent_texture";
- }
- return WebString::fromUTF8(result.c_str());
-}
-
-DELEGATE_TO_GL_3(getTexParameterfv, GetTexParameterfv,
- unsigned long, unsigned long, float*)
-
-DELEGATE_TO_GL_3(getTexParameteriv, GetTexParameteriv,
- unsigned long, unsigned long, int*)
-
-DELEGATE_TO_GL_3(getUniformfv, GetUniformfv, WebGLId, long, float*)
-
-DELEGATE_TO_GL_3(getUniformiv, GetUniformiv, WebGLId, long, int*)
-
-DELEGATE_TO_GL_2R(getUniformLocation, GetUniformLocation,
- WebGLId, const char*, long)
-
-DELEGATE_TO_GL_3(getVertexAttribfv, GetVertexAttribfv,
- unsigned long, unsigned long, float*)
-
-DELEGATE_TO_GL_3(getVertexAttribiv, GetVertexAttribiv,
- unsigned long, unsigned long, int*)
-
-long WebGraphicsContext3DInProcessImpl::getVertexAttribOffset(
- unsigned long index, unsigned long pname) {
- makeContextCurrent();
- void* pointer;
- glGetVertexAttribPointerv(index, pname, &pointer);
- return reinterpret_cast<long>(pointer);
-}
-
-DELEGATE_TO_GL_2(hint, Hint, unsigned long, unsigned long)
-
-DELEGATE_TO_GL_1RB(isBuffer, IsBuffer, WebGLId, bool)
-
-DELEGATE_TO_GL_1RB(isEnabled, IsEnabled, unsigned long, bool)
-
-DELEGATE_TO_GL_1RB(isFramebuffer, IsFramebufferEXT, WebGLId, bool)
-
-DELEGATE_TO_GL_1RB(isProgram, IsProgram, WebGLId, bool)
-
-DELEGATE_TO_GL_1RB(isRenderbuffer, IsRenderbufferEXT, WebGLId, bool)
-
-DELEGATE_TO_GL_1RB(isShader, IsShader, WebGLId, bool)
-
-DELEGATE_TO_GL_1RB(isTexture, IsTexture, WebGLId, bool)
-
-DELEGATE_TO_GL_1_C(lineWidth, LineWidth, double)
-
-DELEGATE_TO_GL_1(linkProgram, LinkProgram, WebGLId)
-
-DELEGATE_TO_GL_2(pixelStorei, PixelStorei, unsigned long, long)
-
-DELEGATE_TO_GL_2_C12(polygonOffset, PolygonOffset, double, double)
-
-void WebGraphicsContext3DInProcessImpl::readPixels(
- long x, long y, unsigned long width, unsigned long height,
- unsigned long format, unsigned long type, void* pixels) {
- makeContextCurrent();
- // FIXME: remove the two glFlush calls when the driver bug is fixed, i.e.,
- // all previous rendering calls should be done before reading pixels.
- glFlush();
- bool needs_resolve =
- (attributes_.antialias && bound_fbo_ == multisample_fbo_);
- if (needs_resolve) {
- ResolveMultisampledFramebuffer(x, y, width, height);
- glBindFramebufferEXT(GL_FRAMEBUFFER_EXT, fbo_);
- glFlush();
- }
-
- glReadPixels(x, y, width, height, format, type, pixels);
-
- if (needs_resolve)
- glBindFramebufferEXT(GL_FRAMEBUFFER_EXT, bound_fbo_);
-}
-
-void WebGraphicsContext3DInProcessImpl::releaseShaderCompiler() {
-}
-
-void WebGraphicsContext3DInProcessImpl::renderbufferStorage(
- unsigned long target,
- unsigned long internalformat,
- unsigned long width,
- unsigned long height) {
- makeContextCurrent();
- if (!is_gles2_) {
- switch (internalformat) {
- case GL_DEPTH_STENCIL:
- internalformat = GL_DEPTH24_STENCIL8_EXT;
- break;
- case GL_DEPTH_COMPONENT16:
- internalformat = GL_DEPTH_COMPONENT;
- break;
- case GL_RGBA4:
- case GL_RGB5_A1:
- internalformat = GL_RGBA;
- break;
- case 0x8D62: // GL_RGB565
- internalformat = GL_RGB;
- break;
- }
- }
- glRenderbufferStorageEXT(target, internalformat, width, height);
-}
-
-DELEGATE_TO_GL_2_C1(sampleCoverage, SampleCoverage, double, bool)
-
-DELEGATE_TO_GL_4(scissor, Scissor, long, long, unsigned long, unsigned long)
-
-void WebGraphicsContext3DInProcessImpl::texImage2D(
- unsigned target, unsigned level, unsigned internalFormat,
- unsigned width, unsigned height, unsigned border,
- unsigned format, unsigned type, const void* pixels) {
- if (width && height && !pixels) {
- synthesizeGLError(GL_INVALID_VALUE);
- return;
- }
- makeContextCurrent();
- glTexImage2D(target, level, internalFormat,
- width, height, border, format, type, pixels);
-}
-
-void WebGraphicsContext3DInProcessImpl::shaderSource(
- WebGLId shader, const char* source) {
- makeContextCurrent();
- GLint length = source ? strlen(source) : 0;
- ShaderSourceMap::iterator result = shader_source_map_.find(shader);
- if (result != shader_source_map_.end()) {
- ShaderSourceEntry* entry = result->second;
- DCHECK(entry);
- entry->source.reset(new char[length + 1]);
- memcpy(entry->source.get(), source, (length + 1) * sizeof(char));
- } else {
- glShaderSource(shader, 1, &source, &length);
- }
-}
-
-DELEGATE_TO_GL_3(stencilFunc, StencilFunc, unsigned long, long, unsigned long)
-
-DELEGATE_TO_GL_4(stencilFuncSeparate, StencilFuncSeparate,
- unsigned long, unsigned long, long, unsigned long)
-
-DELEGATE_TO_GL_1(stencilMask, StencilMask, unsigned long)
-
-DELEGATE_TO_GL_2(stencilMaskSeparate, StencilMaskSeparate,
- unsigned long, unsigned long)
-
-DELEGATE_TO_GL_3(stencilOp, StencilOp,
- unsigned long, unsigned long, unsigned long)
-
-DELEGATE_TO_GL_4(stencilOpSeparate, StencilOpSeparate,
- unsigned long, unsigned long, unsigned long, unsigned long)
-
-DELEGATE_TO_GL_3(texParameterf, TexParameterf, unsigned, unsigned, float);
-
-DELEGATE_TO_GL_3(texParameteri, TexParameteri, unsigned, unsigned, int);
-
-DELEGATE_TO_GL_9(texSubImage2D, TexSubImage2D,
- unsigned, unsigned, unsigned, unsigned, unsigned,
- unsigned, unsigned, unsigned, const void*)
-
-DELEGATE_TO_GL_2(uniform1f, Uniform1f, long, float)
-
-DELEGATE_TO_GL_3(uniform1fv, Uniform1fv, long, int, float*)
-
-DELEGATE_TO_GL_2(uniform1i, Uniform1i, long, int)
-
-DELEGATE_TO_GL_3(uniform1iv, Uniform1iv, long, int, int*)
-
-DELEGATE_TO_GL_3(uniform2f, Uniform2f, long, float, float)
-
-DELEGATE_TO_GL_3(uniform2fv, Uniform2fv, long, int, float*)
-
-DELEGATE_TO_GL_3(uniform2i, Uniform2i, long, int, int)
-
-DELEGATE_TO_GL_3(uniform2iv, Uniform2iv, long, int, int*)
-
-DELEGATE_TO_GL_4(uniform3f, Uniform3f, long, float, float, float)
-
-DELEGATE_TO_GL_3(uniform3fv, Uniform3fv, long, int, float*)
-
-DELEGATE_TO_GL_4(uniform3i, Uniform3i, long, int, int, int)
-
-DELEGATE_TO_GL_3(uniform3iv, Uniform3iv, long, int, int*)
-
-DELEGATE_TO_GL_5(uniform4f, Uniform4f, long, float, float, float, float)
-
-DELEGATE_TO_GL_3(uniform4fv, Uniform4fv, long, int, float*)
-
-DELEGATE_TO_GL_5(uniform4i, Uniform4i, long, int, int, int, int)
-
-DELEGATE_TO_GL_3(uniform4iv, Uniform4iv, long, int, int*)
-
-DELEGATE_TO_GL_4(uniformMatrix2fv, UniformMatrix2fv,
- long, int, bool, const float*)
-
-DELEGATE_TO_GL_4(uniformMatrix3fv, UniformMatrix3fv,
- long, int, bool, const float*)
-
-DELEGATE_TO_GL_4(uniformMatrix4fv, UniformMatrix4fv,
- long, int, bool, const float*)
-
-DELEGATE_TO_GL_1(useProgram, UseProgram, WebGLId)
-
-DELEGATE_TO_GL_1(validateProgram, ValidateProgram, WebGLId)
-
-DELEGATE_TO_GL_2(vertexAttrib1f, VertexAttrib1f, unsigned long, float)
-
-DELEGATE_TO_GL_2(vertexAttrib1fv, VertexAttrib1fv, unsigned long, const float*)
-
-DELEGATE_TO_GL_3(vertexAttrib2f, VertexAttrib2f, unsigned long, float, float)
-
-DELEGATE_TO_GL_2(vertexAttrib2fv, VertexAttrib2fv, unsigned long, const float*)
-
-DELEGATE_TO_GL_4(vertexAttrib3f, VertexAttrib3f,
- unsigned long, float, float, float)
-
-DELEGATE_TO_GL_2(vertexAttrib3fv, VertexAttrib3fv, unsigned long, const float*)
-
-DELEGATE_TO_GL_5(vertexAttrib4f, VertexAttrib4f,
- unsigned long, float, float, float, float)
-
-DELEGATE_TO_GL_2(vertexAttrib4fv, VertexAttrib4fv, unsigned long, const float*)
-
-void WebGraphicsContext3DInProcessImpl::vertexAttribPointer(
- unsigned long indx, int size, int type, bool normalized,
- unsigned long stride, unsigned long offset) {
- makeContextCurrent();
-
- if (bound_array_buffer_ <= 0) {
- // FIXME: raise exception.
- // LogMessagef(("bufferData: no buffer bound"));
- return;
- }
-
- if (indx < kNumTrackedPointerStates) {
- VertexAttribPointerState& state = vertex_attrib_pointer_state_[indx];
- state.buffer = bound_array_buffer_;
- state.indx = indx;
- state.size = size;
- state.type = type;
- state.normalized = normalized;
- state.stride = stride;
- state.offset = offset;
- }
-
- glVertexAttribPointer(indx, size, type, normalized, stride,
- reinterpret_cast<void*>(static_cast<intptr_t>(offset)));
-}
-
-DELEGATE_TO_GL_4(viewport, Viewport, long, long, unsigned long, unsigned long)
-
-unsigned WebGraphicsContext3DInProcessImpl::createBuffer() {
- makeContextCurrent();
- GLuint o;
- glGenBuffersARB(1, &o);
- return o;
-}
-
-unsigned WebGraphicsContext3DInProcessImpl::createFramebuffer() {
- makeContextCurrent();
- GLuint o = 0;
- glGenFramebuffersEXT(1, &o);
- return o;
-}
-
-unsigned WebGraphicsContext3DInProcessImpl::createProgram() {
- makeContextCurrent();
- return glCreateProgram();
-}
-
-unsigned WebGraphicsContext3DInProcessImpl::createRenderbuffer() {
- makeContextCurrent();
- GLuint o;
- glGenRenderbuffersEXT(1, &o);
- return o;
-}
-
-unsigned WebGraphicsContext3DInProcessImpl::createShader(
- unsigned long shaderType) {
- makeContextCurrent();
- DCHECK(shaderType == GL_VERTEX_SHADER || shaderType == GL_FRAGMENT_SHADER);
- unsigned shader = glCreateShader(shaderType);
- if (shader) {
- ShaderSourceMap::iterator result = shader_source_map_.find(shader);
- if (result != shader_source_map_.end()) {
- delete result->second;
- shader_source_map_.erase(result);
- }
- shader_source_map_.insert(
- ShaderSourceMap::value_type(shader, new ShaderSourceEntry(shaderType)));
- }
-
- return shader;
-}
-
-unsigned WebGraphicsContext3DInProcessImpl::createTexture() {
- makeContextCurrent();
- GLuint o;
- glGenTextures(1, &o);
- return o;
-}
-
-void WebGraphicsContext3DInProcessImpl::deleteBuffer(unsigned buffer) {
- makeContextCurrent();
- glDeleteBuffersARB(1, &buffer);
-}
-
-void WebGraphicsContext3DInProcessImpl::deleteFramebuffer(
- unsigned framebuffer) {
- makeContextCurrent();
- glDeleteFramebuffersEXT(1, &framebuffer);
-}
-
-void WebGraphicsContext3DInProcessImpl::deleteProgram(unsigned program) {
- makeContextCurrent();
- glDeleteProgram(program);
-}
-
-void WebGraphicsContext3DInProcessImpl::deleteRenderbuffer(
- unsigned renderbuffer) {
- makeContextCurrent();
- glDeleteRenderbuffersEXT(1, &renderbuffer);
-}
-
-void WebGraphicsContext3DInProcessImpl::deleteShader(unsigned shader) {
- makeContextCurrent();
-
- ShaderSourceMap::iterator result = shader_source_map_.find(shader);
- if (result != shader_source_map_.end()) {
- delete result->second;
- shader_source_map_.erase(result);
- }
- glDeleteShader(shader);
-}
-
-void WebGraphicsContext3DInProcessImpl::deleteTexture(unsigned texture) {
- makeContextCurrent();
- glDeleteTextures(1, &texture);
-}
-
-bool WebGraphicsContext3DInProcessImpl::AngleCreateCompilers() {
- if (!ShInitialize())
- return false;
-
- ShBuiltInResources resources;
- ShInitBuiltInResources(&resources);
- getIntegerv(GL_MAX_VERTEX_ATTRIBS, &resources.MaxVertexAttribs);
- getIntegerv(MAX_VERTEX_UNIFORM_VECTORS, &resources.MaxVertexUniformVectors);
- getIntegerv(MAX_VARYING_VECTORS, &resources.MaxVaryingVectors);
- getIntegerv(GL_MAX_VERTEX_TEXTURE_IMAGE_UNITS,
- &resources.MaxVertexTextureImageUnits);
- getIntegerv(GL_MAX_COMBINED_TEXTURE_IMAGE_UNITS,
- &resources.MaxCombinedTextureImageUnits);
- getIntegerv(GL_MAX_TEXTURE_IMAGE_UNITS, &resources.MaxTextureImageUnits);
- getIntegerv(MAX_FRAGMENT_UNIFORM_VECTORS,
- &resources.MaxFragmentUniformVectors);
- // Always set to 1 for OpenGL ES.
- resources.MaxDrawBuffers = 1;
-
- fragment_compiler_ = ShConstructCompiler(
- SH_FRAGMENT_SHADER, SH_WEBGL_SPEC, &resources);
- vertex_compiler_ = ShConstructCompiler(
- SH_VERTEX_SHADER, SH_WEBGL_SPEC, &resources);
- return (fragment_compiler_ && vertex_compiler_);
-}
-
-void WebGraphicsContext3DInProcessImpl::AngleDestroyCompilers() {
- if (fragment_compiler_) {
- ShDestruct(fragment_compiler_);
- fragment_compiler_ = 0;
- }
- if (vertex_compiler_) {
- ShDestruct(vertex_compiler_);
- vertex_compiler_ = 0;
- }
-}
-
-bool WebGraphicsContext3DInProcessImpl::AngleValidateShaderSource(
- ShaderSourceEntry* entry) {
- entry->is_valid = false;
- entry->translated_source.reset();
- entry->log.reset();
-
- ShHandle compiler = 0;
- switch (entry->type) {
- case GL_FRAGMENT_SHADER:
- compiler = fragment_compiler_;
- break;
- case GL_VERTEX_SHADER:
- compiler = vertex_compiler_;
- break;
- }
- if (!compiler)
- return false;
-
- char* source = entry->source.get();
- if (!ShCompile(compiler, &source, 1, SH_OBJECT_CODE)) {
- int logSize = 0;
- ShGetInfo(compiler, SH_INFO_LOG_LENGTH, &logSize);
- if (logSize > 1) {
- entry->log.reset(new char[logSize]);
- ShGetInfoLog(compiler, entry->log.get());
- }
- return false;
- }
-
- int length = 0;
- if (is_gles2_) {
- // ANGLE does not yet have a GLSL ES backend. Therefore if the
- // compile succeeds we send the original source down.
- length = strlen(entry->source.get());
- if (length > 0)
- ++length; // Add null terminator
- } else {
- ShGetInfo(compiler, SH_OBJECT_CODE_LENGTH, &length);
- }
- if (length > 1) {
- entry->translated_source.reset(new char[length]);
- if (is_gles2_)
- strncpy(entry->translated_source.get(), entry->source.get(), length);
- else
- ShGetObjectCode(compiler, entry->translated_source.get());
- }
- entry->is_valid = true;
- return true;
-}
-
-#endif // USE_WGC3D_TYPES
-
} // namespace gpu
} // namespace webkit
diff --git a/webkit/gpu/webgraphicscontext3d_in_process_impl.h b/webkit/gpu/webgraphicscontext3d_in_process_impl.h
index 8c24863..bdf2494 100644
--- a/webkit/gpu/webgraphicscontext3d_in_process_impl.h
+++ b/webkit/gpu/webgraphicscontext3d_in_process_impl.h
@@ -21,7 +21,6 @@ namespace gfx {
class GLContext;
}
-#if defined(USE_WGC3D_TYPES)
using WebKit::WGC3Dchar;
using WebKit::WGC3Denum;
using WebKit::WGC3Dboolean;
@@ -33,7 +32,6 @@ using WebKit::WGC3Dfloat;
using WebKit::WGC3Dclampf;
using WebKit::WGC3Dintptr;
using WebKit::WGC3Dsizeiptr;
-#endif
using WebKit::WebGLId;
@@ -50,8 +48,6 @@ namespace gpu {
// It is provided for support of test_shell and any Chromium ports
// where an in-renderer WebGL implementation would be helpful.
-#if defined(USE_WGC3D_TYPES)
-
class WebGraphicsContext3DInProcessImpl : public WebGraphicsContext3D {
public:
WebGraphicsContext3DInProcessImpl();
@@ -480,455 +476,6 @@ class WebGraphicsContext3DInProcessImpl : public WebGraphicsContext3D {
ShHandle vertex_compiler_;
};
-#else // USE_WGC3D_TYPES
-
-class WebGraphicsContext3DInProcessImpl : public WebKit::WebGraphicsContext3D {
- public:
- WebGraphicsContext3DInProcessImpl();
- virtual ~WebGraphicsContext3DInProcessImpl();
-
- //----------------------------------------------------------------------
- // WebGraphicsContext3D methods
- virtual bool initialize(
- WebGraphicsContext3D::Attributes attributes, WebKit::WebView*, bool);
- virtual bool makeContextCurrent();
-
- virtual int width();
- virtual int height();
-
- virtual int sizeInBytes(int type);
-
- virtual bool isGLES2Compliant();
-
- virtual void reshape(int width, int height);
-
- virtual bool readBackFramebuffer(unsigned char* pixels, size_t bufferSize);
-
- virtual unsigned int getPlatformTextureId();
- virtual void prepareTexture();
-
- virtual void synthesizeGLError(unsigned long error);
- virtual void* mapBufferSubDataCHROMIUM(
- unsigned target, int offset, int size, unsigned access);
- virtual void unmapBufferSubDataCHROMIUM(const void*);
- virtual void* mapTexSubImage2DCHROMIUM(
- unsigned target,
- int level,
- int xoffset,
- int yoffset,
- int width,
- int height,
- unsigned format,
- unsigned type,
- unsigned access);
- virtual void unmapTexSubImage2DCHROMIUM(const void*);
- virtual void copyTextureToParentTextureCHROMIUM(
- unsigned texture, unsigned parentTexture);
-
- virtual WebKit::WebString getRequestableExtensionsCHROMIUM();
- virtual void requestExtensionCHROMIUM(const char*);
-
- virtual void blitFramebufferCHROMIUM(
- int srcX0, int srcY0, int srcX1, int srcY1,
- int dstX0, int dstY0, int dstX1, int dstY1,
- unsigned mask, unsigned filter);
- virtual void renderbufferStorageMultisampleCHROMIUM(
- unsigned long target, int samples, unsigned internalformat,
- unsigned width, unsigned height);
-
- virtual void activeTexture(unsigned long texture);
- virtual void attachShader(WebKit::WebGLId program, WebKit::WebGLId shader);
- virtual void bindAttribLocation(
- WebKit::WebGLId program, unsigned long index, const char* name);
- virtual void bindBuffer(unsigned long target, WebKit::WebGLId buffer);
- virtual void bindFramebuffer(
- unsigned long target, WebKit::WebGLId framebuffer);
- virtual void bindRenderbuffer(
- unsigned long target, WebKit::WebGLId renderbuffer);
- virtual void bindTexture(unsigned long target, WebKit::WebGLId texture);
- virtual void blendColor(
- double red, double green, double blue, double alpha);
- virtual void blendEquation(unsigned long mode);
- virtual void blendEquationSeparate(
- unsigned long modeRGB, unsigned long modeAlpha);
- virtual void blendFunc(unsigned long sfactor, unsigned long dfactor);
- virtual void blendFuncSeparate(
- unsigned long srcRGB,
- unsigned long dstRGB,
- unsigned long srcAlpha,
- unsigned long dstAlpha);
-
- virtual void bufferData(
- unsigned long target, int size, const void* data, unsigned long usage);
- virtual void bufferSubData(
- unsigned long target, long offset, int size, const void* data);
-
- virtual unsigned long checkFramebufferStatus(unsigned long target);
- virtual void clear(unsigned long mask);
- virtual void clearColor(
- double red, double green, double blue, double alpha);
- virtual void clearDepth(double depth);
- virtual void clearStencil(long s);
- virtual void colorMask(bool red, bool green, bool blue, bool alpha);
- virtual void compileShader(WebKit::WebGLId shader);
-
- virtual void copyTexImage2D(
- unsigned long target,
- long level,
- unsigned long internalformat,
- long x,
- long y,
- unsigned long width,
- unsigned long height,
- long border);
- virtual void copyTexSubImage2D(
- unsigned long target,
- long level,
- long xoffset,
- long yoffset,
- long x,
- long y,
- unsigned long width,
- unsigned long height);
- virtual void cullFace(unsigned long mode);
- virtual void depthFunc(unsigned long func);
- virtual void depthMask(bool flag);
- virtual void depthRange(double zNear, double zFar);
- virtual void detachShader(WebKit::WebGLId program, WebKit::WebGLId shader);
- virtual void disable(unsigned long cap);
- virtual void disableVertexAttribArray(unsigned long index);
- virtual void drawArrays(unsigned long mode, long first, long count);
- virtual void drawElements(
- unsigned long mode,
- unsigned long count,
- unsigned long type,
- long offset);
-
- virtual void enable(unsigned long cap);
- virtual void enableVertexAttribArray(unsigned long index);
- virtual void finish();
- virtual void flush();
- virtual void framebufferRenderbuffer(
- unsigned long target,
- unsigned long attachment,
- unsigned long renderbuffertarget,
- WebKit::WebGLId renderbuffer);
- virtual void framebufferTexture2D(
- unsigned long target,
- unsigned long attachment,
- unsigned long textarget,
- WebKit::WebGLId texture,
- long level);
- virtual void frontFace(unsigned long mode);
- virtual void generateMipmap(unsigned long target);
-
- virtual bool getActiveAttrib(
- WebKit::WebGLId program, unsigned long index, ActiveInfo&);
- virtual bool getActiveUniform(
- WebKit::WebGLId program, unsigned long index, ActiveInfo&);
-
- virtual void getAttachedShaders(
- WebKit::WebGLId program, int maxCount, int* count, unsigned int* shaders);
-
- virtual int getAttribLocation(WebKit::WebGLId program, const char* name);
-
- virtual void getBooleanv(unsigned long pname, unsigned char* value);
-
- virtual void getBufferParameteriv(
- unsigned long target, unsigned long pname, int* value);
-
- virtual Attributes getContextAttributes();
-
- virtual unsigned long getError();
-
- virtual bool isContextLost();
-
- virtual void getFloatv(unsigned long pname, float* value);
-
- virtual void getFramebufferAttachmentParameteriv(
- unsigned long target,
- unsigned long attachment,
- unsigned long pname,
- int* value);
-
- virtual void getIntegerv(unsigned long pname, int* value);
-
- virtual void getProgramiv(
- WebKit::WebGLId program, unsigned long pname, int* value);
-
- virtual WebKit::WebString getProgramInfoLog(WebKit::WebGLId program);
-
- virtual void getRenderbufferParameteriv(
- unsigned long target, unsigned long pname, int* value);
-
- virtual void getShaderiv(
- WebKit::WebGLId shader, unsigned long pname, int* value);
-
- virtual WebKit::WebString getShaderInfoLog(WebKit::WebGLId shader);
-
- // TBD
- // void glGetShaderPrecisionFormat(
- // GLenum shadertype, GLenum precisiontype,
- // GLint* range, GLint* precision);
-
- virtual WebKit::WebString getShaderSource(WebKit::WebGLId shader);
- virtual WebKit::WebString getString(unsigned long name);
-
- virtual void getTexParameterfv(
- unsigned long target, unsigned long pname, float* value);
- virtual void getTexParameteriv(
- unsigned long target, unsigned long pname, int* value);
-
- virtual void getUniformfv(
- WebKit::WebGLId program, long location, float* value);
- virtual void getUniformiv(
- WebKit::WebGLId program, long location, int* value);
-
- virtual long getUniformLocation(WebKit::WebGLId program, const char* name);
-
- virtual void getVertexAttribfv(
- unsigned long index, unsigned long pname, float* value);
- virtual void getVertexAttribiv(
- unsigned long index, unsigned long pname, int* value);
-
- virtual long getVertexAttribOffset(
- unsigned long index, unsigned long pname);
-
- virtual void hint(unsigned long target, unsigned long mode);
- virtual bool isBuffer(WebKit::WebGLId buffer);
- virtual bool isEnabled(unsigned long cap);
- virtual bool isFramebuffer(WebKit::WebGLId framebuffer);
- virtual bool isProgram(WebKit::WebGLId program);
- virtual bool isRenderbuffer(WebKit::WebGLId renderbuffer);
- virtual bool isShader(WebKit::WebGLId shader);
- virtual bool isTexture(WebKit::WebGLId texture);
- virtual void lineWidth(double width);
- virtual void linkProgram(WebKit::WebGLId program);
- virtual void pixelStorei(unsigned long pname, long param);
- virtual void polygonOffset(double factor, double units);
-
- virtual void readPixels(
- long x, long y,
- unsigned long width, unsigned long height,
- unsigned long format,
- unsigned long type,
- void* pixels);
-
- virtual void releaseShaderCompiler();
- virtual void renderbufferStorage(
- unsigned long target,
- unsigned long internalformat,
- unsigned long width,
- unsigned long height);
- virtual void sampleCoverage(double value, bool invert);
- virtual void scissor(
- long x, long y, unsigned long width, unsigned long height);
- virtual void shaderSource(WebKit::WebGLId shader, const char* source);
- virtual void stencilFunc(unsigned long func, long ref, unsigned long mask);
- virtual void stencilFuncSeparate(
- unsigned long face, unsigned long func, long ref, unsigned long mask);
- virtual void stencilMask(unsigned long mask);
- virtual void stencilMaskSeparate(unsigned long face, unsigned long mask);
- virtual void stencilOp(
- unsigned long fail, unsigned long zfail, unsigned long zpass);
- virtual void stencilOpSeparate(
- unsigned long face,
- unsigned long fail,
- unsigned long zfail,
- unsigned long zpass);
-
- virtual void texImage2D(
- unsigned target,
- unsigned level,
- unsigned internalformat,
- unsigned width,
- unsigned height,
- unsigned border,
- unsigned format,
- unsigned type,
- const void* pixels);
-
- virtual void texParameterf(unsigned target, unsigned pname, float param);
- virtual void texParameteri(unsigned target, unsigned pname, int param);
-
- virtual void texSubImage2D(
- unsigned target,
- unsigned level,
- unsigned xoffset,
- unsigned yoffset,
- unsigned width,
- unsigned height,
- unsigned format,
- unsigned type,
- const void* pixels);
-
- virtual void uniform1f(long location, float x);
- virtual void uniform1fv(long location, int count, float* v);
- virtual void uniform1i(long location, int x);
- virtual void uniform1iv(long location, int count, int* v);
- virtual void uniform2f(long location, float x, float y);
- virtual void uniform2fv(long location, int count, float* v);
- virtual void uniform2i(long location, int x, int y);
- virtual void uniform2iv(long location, int count, int* v);
- virtual void uniform3f(long location, float x, float y, float z);
- virtual void uniform3fv(long location, int count, float* v);
- virtual void uniform3i(long location, int x, int y, int z);
- virtual void uniform3iv(long location, int count, int* v);
- virtual void uniform4f(long location, float x, float y, float z, float w);
- virtual void uniform4fv(long location, int count, float* v);
- virtual void uniform4i(long location, int x, int y, int z, int w);
- virtual void uniform4iv(long location, int count, int* v);
- virtual void uniformMatrix2fv(
- long location, int count, bool transpose, const float* value);
- virtual void uniformMatrix3fv(
- long location, int count, bool transpose, const float* value);
- virtual void uniformMatrix4fv(
- long location, int count, bool transpose, const float* value);
-
- virtual void useProgram(WebKit::WebGLId program);
- virtual void validateProgram(WebKit::WebGLId program);
-
- virtual void vertexAttrib1f(unsigned long indx, float x);
- virtual void vertexAttrib1fv(unsigned long indx, const float* values);
- virtual void vertexAttrib2f(unsigned long indx, float x, float y);
- virtual void vertexAttrib2fv(unsigned long indx, const float* values);
- virtual void vertexAttrib3f(unsigned long indx, float x, float y, float z);
- virtual void vertexAttrib3fv(unsigned long indx, const float* values);
- virtual void vertexAttrib4f(
- unsigned long indx, float x, float y, float z, float w);
- virtual void vertexAttrib4fv(unsigned long indx, const float* values);
- virtual void vertexAttribPointer(
- unsigned long indx,
- int size,
- int type,
- bool normalized,
- unsigned long stride,
- unsigned long offset);
-
- virtual void viewport(
- long x, long y, unsigned long width, unsigned long height);
-
- // Support for buffer creation and deletion
- virtual unsigned createBuffer();
- virtual unsigned createFramebuffer();
- virtual unsigned createProgram();
- virtual unsigned createRenderbuffer();
- virtual unsigned createShader(unsigned long);
- virtual unsigned createTexture();
-
- virtual void deleteBuffer(unsigned);
- virtual void deleteFramebuffer(unsigned);
- virtual void deleteProgram(unsigned);
- virtual void deleteRenderbuffer(unsigned);
- virtual void deleteShader(unsigned);
- virtual void deleteTexture(unsigned);
-
- private:
- enum {
- kNumTrackedPointerStates = 2
- };
-
- // Note: we aren't currently using this information, but we will
- // need to in order to verify that all enabled vertex arrays have
- // a valid buffer bound -- to avoid crashes on certain cards.
- struct VertexAttribPointerState {
- VertexAttribPointerState();
-
- bool enabled;
- unsigned long buffer;
- unsigned long indx;
- int size;
- int type;
- bool normalized;
- unsigned long stride;
- unsigned long offset;
- };
-
- // ANGLE related.
- struct ShaderSourceEntry {
- explicit ShaderSourceEntry(unsigned long shader_type)
- : type(shader_type),
- is_valid(false) {
- }
-
- unsigned long type;
- scoped_array<char> source;
- scoped_array<char> log;
- scoped_array<char> translated_source;
- bool is_valid;
- };
-
- typedef base::hash_map<WebKit::WebGLId, ShaderSourceEntry*> ShaderSourceMap;
-
-#ifdef FLIP_FRAMEBUFFER_VERTICALLY
- void FlipVertically(unsigned char* framebuffer,
- unsigned int width,
- unsigned int height);
-#endif
-
- // Take into account the user's requested context creation attributes, in
- // particular stencil and antialias, and determine which could or could
- // not be honored based on the capabilities of the OpenGL implementation.
- void ValidateAttributes();
-
- // Resolve the given rectangle of the multisampled framebuffer if necessary.
- void ResolveMultisampledFramebuffer(
- unsigned x, unsigned y, unsigned width, unsigned height);
-
- bool AngleCreateCompilers();
- void AngleDestroyCompilers();
- bool AngleValidateShaderSource(ShaderSourceEntry* entry);
-
- WebGraphicsContext3D::Attributes attributes_;
- bool initialized_;
- bool render_directly_to_web_view_;
- bool is_gles2_;
- bool have_ext_framebuffer_object_;
- bool have_ext_framebuffer_multisample_;
- bool have_angle_framebuffer_multisample_;
-
- unsigned int texture_;
- unsigned int fbo_;
- unsigned int depth_stencil_buffer_;
- unsigned int cached_width_, cached_height_;
-
- // For multisampling
- unsigned int multisample_fbo_;
- unsigned int multisample_depth_stencil_buffer_;
- unsigned int multisample_color_buffer_;
-
- // For tracking which FBO is bound
- unsigned int bound_fbo_;
-
- // For tracking which texture is bound
- unsigned int bound_texture_;
-
- // FBO used for copying child texture to parent texture.
- unsigned copy_texture_to_parent_texture_fbo_;
-
- unsigned int bound_array_buffer_;
-
-#ifdef FLIP_FRAMEBUFFER_VERTICALLY
- unsigned char* scanline_;
-#endif
-
- VertexAttribPointerState vertex_attrib_pointer_state_[
- kNumTrackedPointerStates];
-
- // Errors raised by synthesizeGLError().
- std::list<unsigned long> synthetic_errors_list_;
- std::set<unsigned long> synthetic_errors_set_;
-
- scoped_ptr<gfx::GLContext> gl_context_;
-
- ShaderSourceMap shader_source_map_;
-
- ShHandle fragment_compiler_;
- ShHandle vertex_compiler_;
-};
-
-#endif // USE_WGC3D_TYPES
-
} // namespace gpu
} // namespace webkit