| /* |
| * Copyright (C) 2009, 2014-2019 Apple Inc. All rights reserved. |
| * |
| * Redistribution and use in source and binary forms, with or without |
| * modification, are permitted provided that the following conditions |
| * are met: |
| * 1. Redistributions of source code must retain the above copyright |
| * notice, this list of conditions and the following disclaimer. |
| * 2. Redistributions in binary form must reproduce the above copyright |
| * notice, this list of conditions and the following disclaimer in the |
| * documentation and/or other materials provided with the distribution. |
| * |
| * THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY |
| * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE |
| * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR |
| * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR |
| * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, |
| * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, |
| * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR |
| * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY |
| * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
| * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
| * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
| */ |
| |
| #pragma once |
| |
| #if ENABLE(WEBGL) && !USE(ANGLE) |
| |
| #include "ANGLEWebKitBridge.h" |
| #include "ExtensionsGLOpenGLCommon.h" |
| #include "GraphicsContextGL.h" |
| #include "GraphicsContextGLState.h" |
| #include <memory> |
| #include <wtf/HashMap.h> |
| #include <wtf/ListHashSet.h> |
| #include <wtf/UniqueRef.h> |
| |
| #if USE(NICOSIA) |
| namespace Nicosia { |
| class GCGLLayer; |
| } |
| #endif |
| |
| namespace WebCore { |
| #if USE(OPENGL_ES) |
| class ExtensionsGLOpenGLES; |
| #else |
| class ExtensionsGLOpenGL; |
| #endif |
| class HostWindow; |
| class ImageBuffer; |
| class MediaPlayer; |
| class PixelBuffer; |
| #if USE(TEXTURE_MAPPER) |
| class TextureMapperGCGLPlatformLayer; |
| #endif |
| |
| typedef HashMap<CString, uint64_t> ShaderNameHash; |
| |
| // Base class for GraphicsContextGL contexts that use OpenGL or OpenGL ES. |
| class WEBCORE_EXPORT GraphicsContextGLOpenGL : public GraphicsContextGL |
| { |
| public: |
| virtual ~GraphicsContextGLOpenGL(); |
| |
| // With multisampling on, blit from multisampleFBO to regular FBO. |
| void prepareTexture(); |
| |
| // Get an attribute location without checking the name -> mangledname mapping. |
| int getAttribLocationDirect(PlatformGLObject program, const String& name); |
| |
| // Compile a shader without going through ANGLE. |
| void compileShaderDirect(PlatformGLObject); |
| |
| // Equivalent to ::glTexImage2D(). Allows pixels==0 with no allocation. |
| void texImage2DDirect(GCGLenum target, GCGLint level, GCGLenum internalformat, GCGLsizei width, GCGLsizei height, GCGLint border, GCGLenum format, GCGLenum type, const void* pixels); |
| |
| bool texImage2DResourceSafe(GCGLenum target, GCGLint level, GCGLenum internalformat, GCGLsizei width, GCGLsizei height, GCGLint border, GCGLenum format, GCGLenum type, GCGLint alignment = 4); |
| |
| // GraphicsContextGL overrides. |
| bool isGLES2Compliant() const final; |
| //---------------------------------------------------------------------- |
| // Entry points for WebGL. |
| // |
| |
| void activeTexture(GCGLenum texture) final; |
| void attachShader(PlatformGLObject program, PlatformGLObject shader) final; |
| void bindAttribLocation(PlatformGLObject, GCGLuint index, const String& name) final; |
| void bindBuffer(GCGLenum target, PlatformGLObject) final; |
| void bindFramebuffer(GCGLenum target, PlatformGLObject) final; |
| void bindRenderbuffer(GCGLenum target, PlatformGLObject) final; |
| void bindTexture(GCGLenum target, PlatformGLObject) final; |
| void blendColor(GCGLclampf red, GCGLclampf green, GCGLclampf blue, GCGLclampf alpha) final; |
| void blendEquation(GCGLenum mode) final; |
| void blendEquationSeparate(GCGLenum modeRGB, GCGLenum modeAlpha) final; |
| void blendFunc(GCGLenum sfactor, GCGLenum dfactor) final; |
| void blendFuncSeparate(GCGLenum srcRGB, GCGLenum dstRGB, GCGLenum srcAlpha, GCGLenum dstAlpha) final; |
| |
| void bufferData(GCGLenum target, GCGLsizeiptr size, GCGLenum usage) final; |
| void bufferData(GCGLenum target, GCGLSpan<const GCGLvoid> data, GCGLenum usage) final; |
| void bufferSubData(GCGLenum target, GCGLintptr offset, GCGLSpan<const GCGLvoid> data) final; |
| |
| GCGLenum checkFramebufferStatus(GCGLenum target) final; |
| void clear(GCGLbitfield mask) final; |
| void clearColor(GCGLclampf red, GCGLclampf green, GCGLclampf blue, GCGLclampf alpha) final; |
| void clearDepth(GCGLclampf depth) final; |
| void clearStencil(GCGLint s) final; |
| void colorMask(GCGLboolean red, GCGLboolean green, GCGLboolean blue, GCGLboolean alpha) final; |
| void compileShader(PlatformGLObject) final; |
| |
| void copyTexImage2D(GCGLenum target, GCGLint level, GCGLenum internalformat, GCGLint x, GCGLint y, GCGLsizei width, GCGLsizei height, GCGLint border) final; |
| void copyTexSubImage2D(GCGLenum target, GCGLint level, GCGLint xoffset, GCGLint yoffset, GCGLint x, GCGLint y, GCGLsizei width, GCGLsizei height) final; |
| void cullFace(GCGLenum mode) final; |
| void depthFunc(GCGLenum func) final; |
| void depthMask(GCGLboolean flag) final; |
| void depthRange(GCGLclampf zNear, GCGLclampf zFar) final; |
| void detachShader(PlatformGLObject, PlatformGLObject) final; |
| void disable(GCGLenum cap) final; |
| void disableVertexAttribArray(GCGLuint index) final; |
| void drawArrays(GCGLenum mode, GCGLint first, GCGLsizei count) final; |
| void drawElements(GCGLenum mode, GCGLsizei count, GCGLenum type, GCGLintptr offset) final; |
| |
| void enable(GCGLenum cap) final; |
| void enableVertexAttribArray(GCGLuint index) final; |
| void finish() final; |
| void flush() final; |
| void framebufferRenderbuffer(GCGLenum target, GCGLenum attachment, GCGLenum renderbuffertarget, PlatformGLObject) final; |
| void framebufferTexture2D(GCGLenum target, GCGLenum attachment, GCGLenum textarget, PlatformGLObject, GCGLint level) final; |
| void frontFace(GCGLenum mode) final; |
| void generateMipmap(GCGLenum target) final; |
| |
| bool getActiveAttrib(PlatformGLObject program, GCGLuint index, ActiveInfo&) final; |
| bool getActiveAttribImpl(PlatformGLObject program, GCGLuint index, ActiveInfo&); |
| bool getActiveUniform(PlatformGLObject program, GCGLuint index, ActiveInfo&) final; |
| bool getActiveUniformImpl(PlatformGLObject program, GCGLuint index, ActiveInfo&); |
| void getAttachedShaders(PlatformGLObject program, GCGLsizei maxCount, GCGLsizei* count, PlatformGLObject* shaders); |
| GCGLint getAttribLocation(PlatformGLObject, const String& name) final; |
| void getBooleanv(GCGLenum pname, GCGLSpan<GCGLboolean> value) final; |
| GCGLint getBufferParameteri(GCGLenum target, GCGLenum pname) final; |
| GCGLenum getError() final; |
| void getFloatv(GCGLenum pname, GCGLSpan<GCGLfloat> value) final; |
| GCGLint getFramebufferAttachmentParameteri(GCGLenum target, GCGLenum attachment, GCGLenum pname) final; |
| void getIntegerv(GCGLenum pname, GCGLSpan<GCGLint> value) final; |
| void getIntegeri_v(GCGLenum pname, GCGLuint index, GCGLSpan<GCGLint, 4> value) final; // NOLINT |
| GCGLint64 getInteger64(GCGLenum pname) final; |
| GCGLint64 getInteger64i(GCGLenum pname, GCGLuint index) final; |
| GCGLint getProgrami(PlatformGLObject program, GCGLenum pname) final; |
| void getNonBuiltInActiveSymbolCount(PlatformGLObject program, GCGLenum pname, GCGLint* value); |
| String getProgramInfoLog(PlatformGLObject) final; |
| String getUnmangledInfoLog(PlatformGLObject[2], GCGLsizei, const String&); |
| GCGLint getRenderbufferParameteri(GCGLenum target, GCGLenum pname) final; |
| GCGLint getShaderi(PlatformGLObject, GCGLenum pname) final; |
| String getShaderInfoLog(PlatformGLObject) final; |
| void getShaderPrecisionFormat(GCGLenum shaderType, GCGLenum precisionType, GCGLSpan<GCGLint, 2> range, GCGLint* precision) final; |
| String getShaderSource(PlatformGLObject) final; |
| String getString(GCGLenum name) final; |
| GCGLfloat getTexParameterf(GCGLenum target, GCGLenum pname) final; |
| GCGLint getTexParameteri(GCGLenum target, GCGLenum pname) final; |
| void getUniformfv(PlatformGLObject program, GCGLint location, GCGLSpan<GCGLfloat> value) final; |
| void getUniformiv(PlatformGLObject program, GCGLint location, GCGLSpan<GCGLint> value) final; |
| void getUniformuiv(PlatformGLObject program, GCGLint location, GCGLSpan<GCGLuint> value) final; |
| GCGLint getUniformLocation(PlatformGLObject, const String& name) final; |
| GCGLsizeiptr getVertexAttribOffset(GCGLuint index, GCGLenum pname) final; |
| |
| void hint(GCGLenum target, GCGLenum mode) final; |
| GCGLboolean isBuffer(PlatformGLObject) final; |
| GCGLboolean isEnabled(GCGLenum cap) final; |
| GCGLboolean isFramebuffer(PlatformGLObject) final; |
| GCGLboolean isProgram(PlatformGLObject) final; |
| GCGLboolean isRenderbuffer(PlatformGLObject) final; |
| GCGLboolean isShader(PlatformGLObject) final; |
| GCGLboolean isTexture(PlatformGLObject) final; |
| void lineWidth(GCGLfloat) final; |
| void linkProgram(PlatformGLObject) final; |
| void pixelStorei(GCGLenum pname, GCGLint param) final; |
| void polygonOffset(GCGLfloat factor, GCGLfloat units) final; |
| |
| void readnPixels(GCGLint x, GCGLint y, GCGLsizei width, GCGLsizei height, GCGLenum format, GCGLenum type, GCGLSpan<GCGLvoid> data) final; |
| void readnPixels(GCGLint x, GCGLint y, GCGLsizei width, GCGLsizei height, GCGLenum format, GCGLenum type, GCGLintptr offset) final; |
| |
| void renderbufferStorage(GCGLenum target, GCGLenum internalformat, GCGLsizei width, GCGLsizei height) final; |
| void sampleCoverage(GCGLclampf value, GCGLboolean invert) final; |
| void scissor(GCGLint x, GCGLint y, GCGLsizei width, GCGLsizei height) final; |
| void shaderSource(PlatformGLObject, const String& string) final; |
| void stencilFunc(GCGLenum func, GCGLint ref, GCGLuint mask) final; |
| void stencilFuncSeparate(GCGLenum face, GCGLenum func, GCGLint ref, GCGLuint mask) final; |
| void stencilMask(GCGLuint mask) final; |
| void stencilMaskSeparate(GCGLenum face, GCGLuint mask) final; |
| void stencilOp(GCGLenum fail, GCGLenum zfail, GCGLenum zpass) final; |
| void stencilOpSeparate(GCGLenum face, GCGLenum fail, GCGLenum zfail, GCGLenum zpass) final; |
| |
| void texImage2D(GCGLenum target, GCGLint level, GCGLenum internalformat, GCGLsizei width, GCGLsizei height, GCGLint border, GCGLenum format, GCGLenum type, GCGLSpan<const GCGLvoid> pixels) final; |
| void texImage2D(GCGLenum target, GCGLint level, GCGLenum internalformat, GCGLsizei width, GCGLsizei height, GCGLint border, GCGLenum format, GCGLenum type, GCGLintptr offset) final; |
| void texSubImage2D(GCGLenum target, GCGLint level, GCGLint xoffset, GCGLint yoffset, GCGLsizei width, GCGLsizei height, GCGLenum format, GCGLenum type, GCGLSpan<const GCGLvoid> pixels) final; |
| void texSubImage2D(GCGLenum target, GCGLint level, GCGLint xoffset, GCGLint yoffset, GCGLsizei width, GCGLsizei height, GCGLenum format, GCGLenum type, GCGLintptr offset) final; |
| void compressedTexImage2D(GCGLenum target, GCGLint level, GCGLenum internalformat, GCGLsizei width, GCGLsizei height, GCGLint border, GCGLsizei imageSize, GCGLSpan<const GCGLvoid> data) final; |
| void compressedTexImage2D(GCGLenum target, GCGLint level, GCGLenum internalformat, GCGLsizei width, GCGLsizei height, GCGLint border, GCGLsizei imageSize, GCGLintptr offset) final; |
| void compressedTexSubImage2D(GCGLenum target, GCGLint level, GCGLint xoffset, GCGLint yoffset, GCGLsizei width, GCGLsizei height, GCGLenum format, GCGLsizei imageSize, GCGLSpan<const GCGLvoid> data) final; |
| void compressedTexSubImage2D(GCGLenum target, GCGLint level, GCGLint xoffset, GCGLint yoffset, GCGLsizei width, GCGLsizei height, GCGLenum format, GCGLsizei imageSize, GCGLintptr offset) final; |
| |
| void texParameterf(GCGLenum target, GCGLenum pname, GCGLfloat param) final; |
| void texParameteri(GCGLenum target, GCGLenum pname, GCGLint param) final; |
| |
| void uniform1f(GCGLint location, GCGLfloat x) final; |
| void uniform1fv(GCGLint location, GCGLSpan<const GCGLfloat> v) final; |
| void uniform1i(GCGLint location, GCGLint x) final; |
| void uniform1iv(GCGLint location, GCGLSpan<const GCGLint> v) final; |
| void uniform2f(GCGLint location, GCGLfloat x, GCGLfloat y) final; |
| void uniform2fv(GCGLint location, GCGLSpan<const GCGLfloat> v) final; |
| void uniform2i(GCGLint location, GCGLint x, GCGLint y) final; |
| void uniform2iv(GCGLint location, GCGLSpan<const GCGLint> v) final; |
| void uniform3f(GCGLint location, GCGLfloat x, GCGLfloat y, GCGLfloat z) final; |
| void uniform3fv(GCGLint location, GCGLSpan<const GCGLfloat> v) final; |
| void uniform3i(GCGLint location, GCGLint x, GCGLint y, GCGLint z) final; |
| void uniform3iv(GCGLint location, GCGLSpan<const GCGLint> v) final; |
| void uniform4f(GCGLint location, GCGLfloat x, GCGLfloat y, GCGLfloat z, GCGLfloat w) final; |
| void uniform4fv(GCGLint location, GCGLSpan<const GCGLfloat> v) final; |
| void uniform4i(GCGLint location, GCGLint x, GCGLint y, GCGLint z, GCGLint w) final; |
| void uniform4iv(GCGLint location, GCGLSpan<const GCGLint> v) final; |
| void uniformMatrix2fv(GCGLint location, GCGLboolean transpose, GCGLSpan<const GCGLfloat> value) final; |
| void uniformMatrix3fv(GCGLint location, GCGLboolean transpose, GCGLSpan<const GCGLfloat> value) final; |
| void uniformMatrix4fv(GCGLint location, GCGLboolean transpose, GCGLSpan<const GCGLfloat> value) final; |
| |
| void useProgram(PlatformGLObject) final; |
| void validateProgram(PlatformGLObject) final; |
| bool checkVaryingsPacking(PlatformGLObject vertexShader, PlatformGLObject fragmentShader) const; |
| bool precisionsMatch(PlatformGLObject vertexShader, PlatformGLObject fragmentShader) const; |
| |
| void vertexAttrib1f(GCGLuint index, GCGLfloat x) final; |
| void vertexAttrib1fv(GCGLuint index, GCGLSpan<const GCGLfloat, 1> values) final; |
| void vertexAttrib2f(GCGLuint index, GCGLfloat x, GCGLfloat y) final; |
| void vertexAttrib2fv(GCGLuint index, GCGLSpan<const GCGLfloat, 2> values) final; |
| void vertexAttrib3f(GCGLuint index, GCGLfloat x, GCGLfloat y, GCGLfloat z) final; |
| void vertexAttrib3fv(GCGLuint index, GCGLSpan<const GCGLfloat, 3> values) final; |
| void vertexAttrib4f(GCGLuint index, GCGLfloat x, GCGLfloat y, GCGLfloat z, GCGLfloat w) final; |
| void vertexAttrib4fv(GCGLuint index, GCGLSpan<const GCGLfloat, 4> values) final; |
| void vertexAttribPointer(GCGLuint index, GCGLint size, GCGLenum type, GCGLboolean normalized, GCGLsizei stride, GCGLintptr offset) final; |
| |
| void viewport(GCGLint x, GCGLint y, GCGLsizei width, GCGLsizei height) final; |
| |
| void reshape(int width, int height) final; |
| |
| void drawArraysInstanced(GCGLenum mode, GCGLint first, GCGLsizei count, GCGLsizei primcount) final; |
| void drawElementsInstanced(GCGLenum mode, GCGLsizei count, GCGLenum type, GCGLintptr offset, GCGLsizei primcount) final; |
| void vertexAttribDivisor(GCGLuint index, GCGLuint divisor) final; |
| |
| // VertexArrayOject calls |
| PlatformGLObject createVertexArray() final; |
| void deleteVertexArray(PlatformGLObject) final; |
| GCGLboolean isVertexArray(PlatformGLObject) final; |
| void bindVertexArray(PlatformGLObject) final; |
| |
| // ========== WebGL2 entry points. |
| |
| void bufferData(GCGLenum target, const void* data, GCGLenum usage, GCGLuint srcOffset, GCGLuint length); |
| void bufferSubData(GCGLenum target, GCGLintptr dstByteOffset, const void* srcData, GCGLuint srcOffset, GCGLuint length); |
| void copyBufferSubData(GCGLenum readTarget, GCGLenum writeTarget, GCGLintptr readOffset, GCGLintptr writeOffset, GCGLsizeiptr size) final; |
| |
| void getBufferSubData(GCGLenum target, GCGLintptr offset, GCGLSpan<GCGLvoid> data) final; |
| |
| void blitFramebuffer(GCGLint srcX0, GCGLint srcY0, GCGLint srcX1, GCGLint srcY1, GCGLint dstX0, GCGLint dstY0, GCGLint dstX1, GCGLint dstY1, GCGLbitfield mask, GCGLenum filter) final; |
| void framebufferTextureLayer(GCGLenum target, GCGLenum attachment, PlatformGLObject texture, GCGLint level, GCGLint layer) final; |
| void invalidateFramebuffer(GCGLenum target, GCGLSpan<const GCGLenum> attachments) final; |
| void invalidateSubFramebuffer(GCGLenum target, GCGLSpan<const GCGLenum> attachments, GCGLint x, GCGLint y, GCGLsizei width, GCGLsizei height) final; |
| void readBuffer(GCGLenum src) final; |
| |
| // getInternalFormatParameter |
| void getInternalformativ(GCGLenum target, GCGLenum internalformat, GCGLenum pname, GCGLSpan<GCGLint> data) final; |
| void renderbufferStorageMultisample(GCGLenum target, GCGLsizei samples, GCGLenum internalformat, GCGLsizei width, GCGLsizei height) final; |
| |
| void texStorage2D(GCGLenum target, GCGLsizei levels, GCGLenum internalformat, GCGLsizei width, GCGLsizei height) final; |
| void texStorage3D(GCGLenum target, GCGLsizei levels, GCGLenum internalformat, GCGLsizei width, GCGLsizei height, GCGLsizei depth) final; |
| |
| void texImage3D(GCGLenum target, GCGLint level, GCGLint internalformat, GCGLsizei width, GCGLsizei height, GCGLsizei depth, GCGLint border, GCGLenum format, GCGLenum type, GCGLSpan<const GCGLvoid> pixels) final; |
| void texImage3D(GCGLenum target, GCGLint level, GCGLint internalformat, GCGLsizei width, GCGLsizei height, GCGLsizei depth, GCGLint border, GCGLenum format, GCGLenum type, GCGLintptr offset) final; |
| void texSubImage3D(GCGLenum target, GCGLint level, GCGLint xoffset, GCGLint yoffset, GCGLint zoffset, GCGLsizei width, GCGLsizei height, GCGLsizei depth, GCGLenum format, GCGLenum type, GCGLSpan<const GCGLvoid> pixels) final; |
| void texSubImage3D(GCGLenum target, GCGLint level, GCGLint xoffset, GCGLint yoffset, GCGLint zoffset, GCGLsizei width, GCGLsizei height, GCGLsizei depth, GCGLenum format, GCGLenum type, GCGLintptr offset) final; |
| void copyTexSubImage3D(GCGLenum target, GCGLint level, GCGLint xoffset, GCGLint yoffset, GCGLint zoffset, GCGLint x, GCGLint y, GCGLsizei width, GCGLsizei height) final; |
| void compressedTexImage3D(GCGLenum target, GCGLint level, GCGLenum internalformat, GCGLsizei width, GCGLsizei height, GCGLsizei depth, GCGLint border, GCGLsizei imageSize, GCGLSpan<const GCGLvoid> data) final; |
| void compressedTexImage3D(GCGLenum target, GCGLint level, GCGLenum internalformat, GCGLsizei width, GCGLsizei height, GCGLsizei depth, GCGLint border, GCGLsizei imageSize, GCGLintptr offset) final; |
| void compressedTexSubImage3D(GCGLenum target, GCGLint level, GCGLint xoffset, GCGLint yoffset, GCGLint zoffset, GCGLsizei width, GCGLsizei height, GCGLsizei depth, GCGLenum format, GCGLsizei imageSize, GCGLSpan<const GCGLvoid> data) final; |
| void compressedTexSubImage3D(GCGLenum target, GCGLint level, GCGLint xoffset, GCGLint yoffset, GCGLint zoffset, GCGLsizei width, GCGLsizei height, GCGLsizei depth, GCGLenum format, GCGLsizei imageSize, GCGLintptr offset) final; |
| |
| GCGLint getFragDataLocation(PlatformGLObject program, const String& name) final; |
| |
| void uniform1ui(GCGLint location, GCGLuint v0) final; |
| void uniform2ui(GCGLint location, GCGLuint v0, GCGLuint v1) final; |
| void uniform3ui(GCGLint location, GCGLuint v0, GCGLuint v1, GCGLuint v2) final; |
| void uniform4ui(GCGLint location, GCGLuint v0, GCGLuint v1, GCGLuint v2, GCGLuint v3) final; |
| void uniform1uiv(GCGLint location, GCGLSpan<const GCGLuint>) final; |
| void uniform2uiv(GCGLint location, GCGLSpan<const GCGLuint>) final; |
| void uniform3uiv(GCGLint location, GCGLSpan<const GCGLuint>) final; |
| void uniform4uiv(GCGLint location, GCGLSpan<const GCGLuint>) final; |
| void uniformMatrix2x3fv(GCGLint location, GCGLboolean transpose, GCGLSpan<const GCGLfloat> data) final; |
| void uniformMatrix3x2fv(GCGLint location, GCGLboolean transpose, GCGLSpan<const GCGLfloat> data) final; |
| void uniformMatrix2x4fv(GCGLint location, GCGLboolean transpose, GCGLSpan<const GCGLfloat> data) final; |
| void uniformMatrix4x2fv(GCGLint location, GCGLboolean transpose, GCGLSpan<const GCGLfloat> data) final; |
| void uniformMatrix3x4fv(GCGLint location, GCGLboolean transpose, GCGLSpan<const GCGLfloat> data) final; |
| void uniformMatrix4x3fv(GCGLint location, GCGLboolean transpose, GCGLSpan<const GCGLfloat> data) final; |
| void vertexAttribI4i(GCGLuint index, GCGLint x, GCGLint y, GCGLint z, GCGLint w) final; |
| void vertexAttribI4iv(GCGLuint index, GCGLSpan<const GCGLint, 4> values) final; |
| void vertexAttribI4ui(GCGLuint index, GCGLuint x, GCGLuint y, GCGLuint z, GCGLuint w) final; |
| void vertexAttribI4uiv(GCGLuint index, GCGLSpan<const GCGLuint, 4> values) final; |
| void vertexAttribIPointer(GCGLuint index, GCGLint size, GCGLenum type, GCGLsizei stride, GCGLintptr offset) final; |
| |
| void drawRangeElements(GCGLenum mode, GCGLuint start, GCGLuint end, GCGLsizei count, GCGLenum type, GCGLintptr offset) final; |
| |
| void drawBuffers(GCGLSpan<const GCGLenum> bufs) final; |
| void clearBufferiv(GCGLenum buffer, GCGLint drawbuffer, GCGLSpan<const GCGLint> values) final; |
| void clearBufferuiv(GCGLenum buffer, GCGLint drawbuffer, GCGLSpan<const GCGLuint> values) final; |
| void clearBufferfv(GCGLenum buffer, GCGLint drawbuffer, GCGLSpan<const GCGLfloat> values) final; |
| void clearBufferfi(GCGLenum buffer, GCGLint drawbuffer, GCGLfloat depth, GCGLint stencil) final; |
| |
| PlatformGLObject createQuery() final; |
| void deleteQuery(PlatformGLObject query) final; |
| GCGLboolean isQuery(PlatformGLObject query) final; |
| void beginQuery(GCGLenum target, PlatformGLObject query) final; |
| void endQuery(GCGLenum target) final; |
| PlatformGLObject getQuery(GCGLenum target, GCGLenum pname) final; |
| // getQueryParameter |
| GCGLuint getQueryObjectui(PlatformGLObject query, GCGLenum pname) final; |
| |
| PlatformGLObject createSampler() final; |
| void deleteSampler(PlatformGLObject sampler) final; |
| GCGLboolean isSampler(PlatformGLObject sampler) final; |
| void bindSampler(GCGLuint unit, PlatformGLObject sampler) final; |
| void samplerParameteri(PlatformGLObject sampler, GCGLenum pname, GCGLint param) final; |
| void samplerParameterf(PlatformGLObject sampler, GCGLenum pname, GCGLfloat param) final; |
| // getSamplerParameter |
| GCGLfloat getSamplerParameterf(PlatformGLObject sampler, GCGLenum pname) final; |
| GCGLint getSamplerParameteri(PlatformGLObject sampler, GCGLenum pname) final; |
| |
| GCGLsync fenceSync(GCGLenum condition, GCGLbitfield flags) final; |
| GCGLboolean isSync(GCGLsync) final; |
| void deleteSync(GCGLsync) final; |
| GCGLenum clientWaitSync(GCGLsync, GCGLbitfield flags, GCGLuint64 timeout) final; |
| void waitSync(GCGLsync, GCGLbitfield flags, GCGLint64 timeout) final; |
| // getSyncParameter |
| // FIXME - this can be implemented at the WebGL level if we signal the WebGLSync object. |
| GCGLint getSynci(GCGLsync, GCGLenum pname) final; |
| |
| PlatformGLObject createTransformFeedback() final; |
| void deleteTransformFeedback(PlatformGLObject id) final; |
| GCGLboolean isTransformFeedback(PlatformGLObject id) final; |
| void bindTransformFeedback(GCGLenum target, PlatformGLObject id) final; |
| void beginTransformFeedback(GCGLenum primitiveMode) final; |
| void endTransformFeedback() final; |
| void transformFeedbackVaryings(PlatformGLObject program, const Vector<String>& varyings, GCGLenum bufferMode) final; |
| void getTransformFeedbackVarying(PlatformGLObject program, GCGLuint index, ActiveInfo&) final; |
| void pauseTransformFeedback() final; |
| void resumeTransformFeedback() final; |
| |
| void bindBufferBase(GCGLenum target, GCGLuint index, PlatformGLObject buffer) final; |
| void bindBufferRange(GCGLenum target, GCGLuint index, PlatformGLObject buffer, GCGLintptr offset, GCGLsizeiptr size) final; |
| // getIndexedParameter -> use getParameter calls above. |
| Vector<GCGLuint> getUniformIndices(PlatformGLObject program, const Vector<String>& uniformNames) final; |
| Vector<GCGLint> getActiveUniforms(PlatformGLObject program, const Vector<GCGLuint>& uniformIndices, GCGLenum pname) final; |
| |
| GCGLuint getUniformBlockIndex(PlatformGLObject program, const String& uniformBlockName) final; |
| // getActiveUniformBlockParameter |
| String getActiveUniformBlockName(PlatformGLObject program, GCGLuint uniformBlockIndex) final; |
| void uniformBlockBinding(PlatformGLObject program, GCGLuint uniformBlockIndex, GCGLuint uniformBlockBinding) final; |
| |
| void getActiveUniformBlockiv(GCGLuint program, GCGLuint uniformBlockIndex, GCGLenum pname, GCGLSpan<GCGLint> params) final; |
| |
| // GL_ANGLE_multi_draw |
| void multiDrawArraysANGLE(GCGLenum mode, GCGLSpanTuple<const GCGLint, const GCGLsizei> firstsAndCounts) override; |
| void multiDrawArraysInstancedANGLE(GCGLenum mode, GCGLSpanTuple<const GCGLint, const GCGLsizei, const GCGLsizei> firstsCountsAndInstanceCounts) override; |
| void multiDrawElementsANGLE(GCGLenum mode, GCGLSpanTuple<const GCGLsizei, const GCGLint> countsAndOffsets, GCGLenum type) override; |
| void multiDrawElementsInstancedANGLE(GCGLenum mode, GCGLSpanTuple<const GCGLsizei, const GCGLint, const GCGLsizei> countsOffsetsAndInstanceCounts, GCGLenum type) override; |
| |
| // GL_OES_draw_buffers_indexed |
| void enableiOES(GCGLenum target, GCGLuint index) final; |
| void disableiOES(GCGLenum target, GCGLuint index) final; |
| void blendEquationiOES(GCGLuint buf, GCGLenum mode) final; |
| void blendEquationSeparateiOES(GCGLuint buf, GCGLenum modeRGB, GCGLenum modeAlpha) final; |
| void blendFunciOES(GCGLuint buf, GCGLenum src, GCGLenum dst) final; |
| void blendFuncSeparateiOES(GCGLuint buf, GCGLenum srcRGB, GCGLenum dstRGB, GCGLenum srcAlpha, GCGLenum dstAlpha) final; |
| void colorMaskiOES(GCGLuint buf, GCGLboolean red, GCGLboolean green, GCGLboolean blue, GCGLboolean alpha) final; |
| |
| bool supportsExtension(const String&) final; |
| void ensureExtensionEnabled(const String&) final; |
| bool isExtensionEnabled(const String&) final; |
| void drawBuffersEXT(GCGLSpan<const GCGLenum>) override; |
| String getTranslatedShaderSourceANGLE(PlatformGLObject) final; |
| |
| // Helper methods. |
| void paintRenderingResultsToCanvas(ImageBuffer&) final; |
| RefPtr<PixelBuffer> paintRenderingResultsToPixelBuffer() final; |
| void paintCompositedResultsToCanvas(ImageBuffer&) final; |
| |
| RefPtr<PixelBuffer> readRenderingResultsForPainting(); |
| RefPtr<PixelBuffer> readCompositedResultsForPainting(); |
| |
| void setContextVisibility(bool) final; |
| |
| // Support for buffer creation and deletion |
| PlatformGLObject createBuffer() final; |
| PlatformGLObject createFramebuffer() final; |
| PlatformGLObject createProgram() final; |
| PlatformGLObject createRenderbuffer() final; |
| PlatformGLObject createShader(GCGLenum) final; |
| PlatformGLObject createTexture() final; |
| |
| void deleteBuffer(PlatformGLObject) final; |
| void deleteFramebuffer(PlatformGLObject) final; |
| void deleteProgram(PlatformGLObject) final; |
| void deleteRenderbuffer(PlatformGLObject) final; |
| void deleteShader(PlatformGLObject) final; |
| void deleteTexture(PlatformGLObject) final; |
| |
| void synthesizeGLError(GCGLenum error) final; |
| bool moveErrorsToSyntheticErrorList() final; |
| |
| // Support for extensions. Returns a non-null object, though not |
| // all methods it contains may necessarily be supported on the |
| // current hardware. Must call ExtensionsGLOpenGL{ES}::supports() to |
| // determine this. |
| #if USE(OPENGL_ES) |
| ExtensionsGLOpenGLES& getExtensions(); |
| #else |
| ExtensionsGLOpenGL& getExtensions(); |
| #endif |
| void simulateEventForTesting(SimulatedEventForTesting) override; |
| |
| void prepareForDisplay() override; |
| |
| protected: |
| GraphicsContextGLOpenGL(GraphicsContextGLAttributes); |
| |
| GCGLuint m_texture { 0 }; |
| |
| // Called once by all the public entry points that eventually call OpenGL. |
| // Called once by all the public entry points of ExtensionsGLOpenGL/ExtensionGLOpenGLES that eventually call OpenGL. |
| bool makeContextCurrent() WARN_UNUSED_RETURN; |
| |
| // Initializes the instance. Returns false if the instance should not be used. |
| bool initialize(); |
| virtual bool platformInitialize() = 0; |
| |
| // 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 validateDepthStencil(ASCIILiteral packedDepthStencilExtension); |
| void validateAttributes(); |
| |
| void readnPixelsImpl(GCGLint x, GCGLint y, GCGLsizei width, GCGLsizei height, GCGLenum format, GCGLenum type, GCGLsizei bufSize, GCGLsizei* length, GCGLsizei* columns, GCGLsizei* rows, GCGLvoid* data, bool readingToPixelBufferObject); |
| |
| // Did the most recent drawing operation leave the GPU in an acceptable state? |
| void checkGPUStatus(); |
| |
| RefPtr<PixelBuffer> readRenderingResults(); |
| RefPtr<PixelBuffer> readCompositedResults(); |
| RefPtr<PixelBuffer> readPixelsForPaintResults(); |
| |
| bool reshapeFBOs(const IntSize&); |
| void resolveMultisamplingIfNecessary(const IntRect& = IntRect()); |
| void attachDepthAndStencilBufferIfNeeded(GCGLuint internalDepthStencilFormat, int width, int height); |
| |
| |
| typedef HashMap<String, UniqueRef<sh::ShaderVariable>> ShaderSymbolMap; |
| |
| struct ShaderSourceEntry { |
| GCGLenum type; |
| String source; |
| String translatedSource; |
| String log; |
| bool isValid; |
| ShaderSymbolMap attributeMap; |
| ShaderSymbolMap uniformMap; |
| ShaderSymbolMap varyingMap; |
| ShaderSourceEntry() |
| : type(VERTEX_SHADER) |
| , isValid(false) |
| { |
| } |
| |
| ShaderSymbolMap& symbolMap(enum ANGLEShaderSymbolType symbolType) |
| { |
| ASSERT(symbolType == SHADER_SYMBOL_TYPE_ATTRIBUTE || symbolType == SHADER_SYMBOL_TYPE_UNIFORM || symbolType == SHADER_SYMBOL_TYPE_VARYING); |
| if (symbolType == SHADER_SYMBOL_TYPE_ATTRIBUTE) |
| return attributeMap; |
| if (symbolType == SHADER_SYMBOL_TYPE_VARYING) |
| return varyingMap; |
| return uniformMap; |
| } |
| }; |
| |
| // FIXME: Shaders are never removed from this map, even if they and their program are deleted. |
| // This is bad, and it also relies on the fact we never reuse PlatformGLObject numbers. |
| typedef HashMap<PlatformGLObject, ShaderSourceEntry> ShaderSourceMap; |
| ShaderSourceMap m_shaderSourceMap; |
| |
| typedef HashMap<PlatformGLObject, std::pair<PlatformGLObject, PlatformGLObject>> LinkedShaderMap; |
| LinkedShaderMap m_linkedShaderMap; |
| |
| struct ActiveShaderSymbolCounts { |
| Vector<GCGLint> filteredToActualAttributeIndexMap; |
| Vector<GCGLint> filteredToActualUniformIndexMap; |
| |
| ActiveShaderSymbolCounts() |
| { |
| } |
| |
| GCGLint countForType(GCGLenum activeType) |
| { |
| ASSERT(activeType == ACTIVE_ATTRIBUTES || activeType == ACTIVE_UNIFORMS); |
| if (activeType == ACTIVE_ATTRIBUTES) |
| return filteredToActualAttributeIndexMap.size(); |
| |
| return filteredToActualUniformIndexMap.size(); |
| } |
| }; |
| typedef HashMap<PlatformGLObject, ActiveShaderSymbolCounts> ShaderProgramSymbolCountMap; |
| ShaderProgramSymbolCountMap m_shaderProgramSymbolCountMap; |
| |
| typedef HashMap<String, String> HashedSymbolMap; |
| HashedSymbolMap m_possiblyUnusedAttributeMap; |
| |
| String mappedSymbolName(PlatformGLObject program, ANGLEShaderSymbolType, const String& name); |
| String mappedSymbolName(PlatformGLObject shaders[2], size_t count, const String& name); |
| String originalSymbolName(PlatformGLObject program, ANGLEShaderSymbolType, const String& name); |
| std::optional<String> mappedSymbolInShaderSourceMap(PlatformGLObject shader, ANGLEShaderSymbolType, const String& name); |
| std::optional<String> originalSymbolInShaderSourceMap(PlatformGLObject shader, ANGLEShaderSymbolType, const String& name); |
| |
| std::unique_ptr<ShaderNameHash> nameHashMapForShaders; |
| |
| friend class ExtensionsGLOpenGLCommon; |
| #if USE(OPENGL_ES) |
| friend class ExtensionsGLOpenGLES; |
| std::unique_ptr<ExtensionsGLOpenGLES> m_extensions; |
| #else |
| friend class ExtensionsGLOpenGL; |
| std::unique_ptr<ExtensionsGLOpenGL> m_extensions; |
| #endif |
| |
| Vector<Vector<float>> m_vertexArray; |
| |
| ANGLEWebKitBridge m_compiler; |
| |
| GCGLuint m_fbo { 0 }; |
| #if USE(COORDINATED_GRAPHICS) |
| GCGLuint m_compositorTexture { 0 }; |
| GCGLuint m_intermediateTexture { 0 }; |
| #endif |
| |
| #if USE(OPENGL_ES) |
| GCGLuint m_depthBuffer { 0 }; |
| GCGLuint m_stencilBuffer { 0 }; |
| #endif |
| GCGLuint m_depthStencilBuffer { 0 }; |
| |
| GCGLuint m_internalColorFormat { 0 }; |
| |
| |
| GraphicsContextGLState m_state; |
| |
| // For multisampling |
| GCGLuint m_multisampleFBO { 0 }; |
| GCGLuint m_multisampleDepthStencilBuffer { 0 }; |
| GCGLuint m_multisampleColorBuffer { 0 }; |
| |
| // Errors raised by synthesizeGLError(). |
| ListHashSet<GCGLenum> m_syntheticErrors; |
| |
| #if USE(NICOSIA) |
| friend class Nicosia::GCGLLayer; |
| std::unique_ptr<Nicosia::GCGLLayer> m_nicosiaLayer; |
| #elif USE(TEXTURE_MAPPER) |
| friend class TextureMapperGCGLPlatformLayer; |
| std::unique_ptr<TextureMapperGCGLPlatformLayer> m_texmapLayer; |
| #endif |
| |
| bool m_isForWebGL2 { false }; |
| bool m_usingCoreProfile { false }; |
| |
| unsigned m_statusCheckCount { 0 }; |
| bool m_failNextStatusCheck { false }; |
| |
| #if USE(CAIRO) |
| PlatformGLObject m_vao { 0 }; |
| #endif |
| }; |
| |
| } // namespace WebCore |
| |
| #endif // ENABLE(WEBGL) && !USE(ANGLE) |