void WebGLRenderbuffer::RenderbufferStorage(GLenum internalFormat, GLsizei width, GLsizei height) const { gl::GLContext* gl = mContext->gl; GLenum primaryFormat = internalFormat; GLenum secondaryFormat = 0; if (NeedsDepthStencilEmu(mContext->gl, primaryFormat)) { primaryFormat = DepthStencilDepthFormat(gl); secondaryFormat = LOCAL_GL_STENCIL_INDEX8; } gl->fRenderbufferStorage(LOCAL_GL_RENDERBUFFER, primaryFormat, width, height); if (!mSecondaryRB) { MOZ_ASSERT(!secondaryFormat); return; } // We can't leave the secondary RB unspecified either, since we should // handle the case where we attach a non-depth-stencil RB to a // depth-stencil attachment point, or attach this depth-stencil RB to a // non-depth-stencil attachment point. gl::ScopedBindRenderbuffer autoRB(gl, mSecondaryRB); if (secondaryFormat) { gl->fRenderbufferStorage(LOCAL_GL_RENDERBUFFER, secondaryFormat, width, height); } else { gl->fRenderbufferStorage(LOCAL_GL_RENDERBUFFER, LOCAL_GL_RGBA4, 1, 1); } }
GLuint CreateRenderbuffer(GLContext* aGL, GLenum aFormat, GLsizei aSamples, const gfx::IntSize& aSize) { GLuint rb = 0; aGL->fGenRenderbuffers(1, &rb); ScopedBindRenderbuffer autoRB(aGL, rb); RenderbufferStorageBySamples(aGL, aSamples, aFormat, aSize); return rb; }
void WebGLRenderbuffer::RenderbufferStorage(GLsizei samples, const webgl::FormatUsageInfo* format, GLsizei width, GLsizei height) { MOZ_ASSERT(mContext->mBoundRenderbuffer == this); gl::GLContext* gl = mContext->gl; MOZ_ASSERT(samples >= 0 && samples <= 256); // Sanity check. GLenum primaryFormat = format->format->sizedFormat; GLenum secondaryFormat = 0; if (NeedsDepthStencilEmu(mContext->gl, primaryFormat)) { primaryFormat = DepthStencilDepthFormat(gl); secondaryFormat = LOCAL_GL_STENCIL_INDEX8; } RenderbufferStorageMaybeMultisample(gl, samples, primaryFormat, width, height); if (mSecondaryRB) { // We can't leave the secondary RB unspecified either, since we should // handle the case where we attach a non-depth-stencil RB to a // depth-stencil attachment point, or attach this depth-stencil RB to a // non-depth-stencil attachment point. gl::ScopedBindRenderbuffer autoRB(gl, mSecondaryRB); if (secondaryFormat) { RenderbufferStorageMaybeMultisample(gl, samples, secondaryFormat, width, height); } else { RenderbufferStorageMaybeMultisample(gl, samples, LOCAL_GL_RGBA4, 1, 1); } } mSamples = samples; mFormat = format; mWidth = width; mHeight = height; mImageDataStatus = WebGLImageDataStatus::UninitializedImageData; mIsUsingSecondary = bool(secondaryFormat); InvalidateStatusOfAttachedFBs(); }
GLint WebGLRenderbuffer::GetRenderbufferParameter(RBTarget target, RBParam pname) const { gl::GLContext* gl = mContext->gl; switch (pname.get()) { case LOCAL_GL_RENDERBUFFER_STENCIL_SIZE: if (NeedsDepthStencilEmu(mContext->gl, InternalFormatForGL())) { if (gl->WorkAroundDriverBugs() && gl->Renderer() == gl::GLRenderer::Tegra) { return 8; } gl::ScopedBindRenderbuffer autoRB(gl, mSecondaryRB); GLint i = 0; gl->fGetRenderbufferParameteriv(target.get(), pname.get(), &i); return i; } // Fall through otherwise. case LOCAL_GL_RENDERBUFFER_WIDTH: case LOCAL_GL_RENDERBUFFER_HEIGHT: case LOCAL_GL_RENDERBUFFER_RED_SIZE: case LOCAL_GL_RENDERBUFFER_GREEN_SIZE: case LOCAL_GL_RENDERBUFFER_BLUE_SIZE: case LOCAL_GL_RENDERBUFFER_ALPHA_SIZE: case LOCAL_GL_RENDERBUFFER_DEPTH_SIZE: { GLint i = 0; gl->fGetRenderbufferParameteriv(target.get(), pname.get(), &i); return i; } } MOZ_ASSERT(false, "This function should only be called with valid `pname`."); return 0; }