| Index: content/common/gpu/image_transport_surface_fbo_mac.h
|
| diff --git a/content/common/gpu/texture_image_transport_surface.h b/content/common/gpu/image_transport_surface_fbo_mac.h
|
| similarity index 38%
|
| copy from content/common/gpu/texture_image_transport_surface.h
|
| copy to content/common/gpu/image_transport_surface_fbo_mac.h
|
| index dec6b35e9829657e7ba312e48b61bd0b3f2e6315..1302cfe51bc1d39cefc82bc7dc69038b246349f3 100644
|
| --- a/content/common/gpu/texture_image_transport_surface.h
|
| +++ b/content/common/gpu/image_transport_surface_fbo_mac.h
|
| @@ -1,110 +1,110 @@
|
| -// Copyright (c) 2012 The Chromium Authors. All rights reserved.
|
| +// Copyright 2014 The Chromium Authors. All rights reserved.
|
| // Use of this source code is governed by a BSD-style license that can be
|
| // found in the LICENSE file.
|
|
|
| -#ifndef CONTENT_COMMON_GPU_TEXTURE_IMAGE_TRANSPORT_SURFACE_H_
|
| -#define CONTENT_COMMON_GPU_TEXTURE_IMAGE_TRANSPORT_SURFACE_H_
|
| +#ifndef CONTENT_COMMON_GPU_IMAGE_TRANSPORT_SURFACE_FBO_MAC_H_
|
| +#define CONTENT_COMMON_GPU_IMAGE_TRANSPORT_SURFACE_FBO_MAC_H_
|
|
|
| -#include <string>
|
| -
|
| -#include "base/basictypes.h"
|
| +#include "base/mac/scoped_cftyperef.h"
|
| #include "base/memory/scoped_ptr.h"
|
| #include "content/common/gpu/gpu_command_buffer_stub.h"
|
| #include "content/common/gpu/image_transport_surface.h"
|
| -#include "gpu/command_buffer/common/mailbox.h"
|
| -#include "gpu/command_buffer/service/texture_manager.h"
|
| -#include "ui/gl/gl_context.h"
|
| -#include "ui/gl/gl_surface.h"
|
| +#include "ui/gl/gl_bindings.h"
|
|
|
| namespace content {
|
| -class GpuChannelManager;
|
|
|
| -class TextureImageTransportSurface
|
| - : public ImageTransportSurface,
|
| - public GpuCommandBufferStub::DestructionObserver,
|
| - public gfx::GLSurface {
|
| +// We are backed by an offscreen surface for the purposes of creating
|
| +// a context, but use FBOs to render to texture. The texture may be backed by
|
| +// an IOSurface, or it may be presented to the screen via a CALayer, depending
|
| +// on the StorageProvider class specified.
|
| +class ImageTransportSurfaceFBO
|
| + : public gfx::GLSurface,
|
| + public ImageTransportSurface,
|
| + public GpuCommandBufferStub::DestructionObserver {
|
| public:
|
| - TextureImageTransportSurface(GpuChannelManager* manager,
|
| - GpuCommandBufferStub* stub,
|
| - const gfx::GLSurfaceHandle& handle);
|
| -
|
| - // gfx::GLSurface implementation.
|
| + // The interface through which storage for the color buffer of the FBO is
|
| + // allocated.
|
| + class StorageProvider {
|
| + public:
|
| + virtual ~StorageProvider() {}
|
| + // IOSurfaces cause too much address space fragmentation if they are
|
| + // allocated on every resize. This gets a rounded size for allocation.
|
| + virtual gfx::Size GetRoundedSize(gfx::Size size) = 0;
|
| +
|
| + // Allocate the storage for the color buffer. The specified context is
|
| + // current, and there is a texture bound to GL_TEXTURE_RECTANGLE_ARB.
|
| + virtual bool AllocateColorBufferStorage(
|
| + CGLContextObj context, gfx::Size size) = 0;
|
| +
|
| + // Free the storage allocated in the AllocateColorBufferStorage call. The
|
| + // GL texture that was bound has already been deleted by the caller.
|
| + virtual void FreeColorBufferStorage() = 0;
|
| +
|
| + // Retrieve the handle for the surface to send to the browser process to
|
| + // display.
|
| + virtual uint64 GetSurfaceHandle() const = 0;
|
| + };
|
| +
|
| + ImageTransportSurfaceFBO(StorageProvider* storage_provider,
|
| + GpuChannelManager* manager,
|
| + GpuCommandBufferStub* stub,
|
| + gfx::PluginWindowHandle handle);
|
| +
|
| + // GLSurface implementation
|
| virtual bool Initialize() OVERRIDE;
|
| virtual void Destroy() OVERRIDE;
|
| virtual bool DeferDraws() OVERRIDE;
|
| virtual bool IsOffscreen() OVERRIDE;
|
| virtual bool SwapBuffers() OVERRIDE;
|
| + virtual bool PostSubBuffer(int x, int y, int width, int height) OVERRIDE;
|
| + virtual bool SupportsPostSubBuffer() OVERRIDE;
|
| virtual gfx::Size GetSize() OVERRIDE;
|
| virtual void* GetHandle() OVERRIDE;
|
| - virtual unsigned GetFormat() OVERRIDE;
|
| - virtual bool SupportsPostSubBuffer() OVERRIDE;
|
| + virtual void* GetDisplay() OVERRIDE;
|
| + virtual bool OnMakeCurrent(gfx::GLContext* context) OVERRIDE;
|
| virtual unsigned int GetBackingFrameBufferObject() OVERRIDE;
|
| - virtual bool PostSubBuffer(int x, int y, int width, int height) OVERRIDE;
|
| virtual bool SetBackbufferAllocation(bool allocated) OVERRIDE;
|
| virtual void SetFrontbufferAllocation(bool allocated) OVERRIDE;
|
| - virtual void* GetShareHandle() OVERRIDE;
|
| - virtual void* GetDisplay() OVERRIDE;
|
| - virtual void* GetConfig() OVERRIDE;
|
|
|
| protected:
|
| - // ImageTransportSurface implementation.
|
| + // ImageTransportSurface implementation
|
| virtual void OnBufferPresented(
|
| const AcceleratedSurfaceMsg_BufferPresented_Params& params) OVERRIDE;
|
| virtual void OnResize(gfx::Size size, float scale_factor) OVERRIDE;
|
| virtual void SetLatencyInfo(
|
| - const std::vector<ui::LatencyInfo>& latency_info) OVERRIDE;
|
| + const std::vector<ui::LatencyInfo>&) OVERRIDE;
|
| virtual void WakeUpGpu() OVERRIDE;
|
|
|
| // GpuCommandBufferStub::DestructionObserver implementation.
|
| virtual void OnWillDestroyStub() OVERRIDE;
|
|
|
| private:
|
| + virtual ~ImageTransportSurfaceFBO() OVERRIDE;
|
|
|
| - gfx::Size backbuffer_size() const {
|
| - DCHECK(backbuffer_.get());
|
| - GLsizei width = 0;
|
| - GLsizei height = 0;
|
| - backbuffer_->texture()->GetLevelSize(GL_TEXTURE_2D, 0, &width, &height);
|
| - return gfx::Size(width, height);
|
| - }
|
| -
|
| - virtual ~TextureImageTransportSurface();
|
| - void CreateBackTexture();
|
| - void AttachBackTextureToFBO();
|
| - void ReleaseBackTexture();
|
| - void ReleaseFrontTexture();
|
| - void BufferPresentedImpl(const gpu::Mailbox& mailbox_name);
|
| -
|
| - // The framebuffer that represents this surface (service id). Allocated lazily
|
| - // in OnMakeCurrent.
|
| - uint32 fbo_id_;
|
| -
|
| - // The current backbuffer.
|
| - scoped_refptr<gpu::gles2::TextureRef> backbuffer_;
|
| - scoped_refptr<gpu::gles2::TextureRef> frontbuffer_;
|
| -
|
| - // The mailbox name for the current backbuffer texture. Needs to be unique per
|
| - // GL texture and is invalid while service_id is zero.
|
| - gpu::Mailbox back_mailbox_;
|
| - gpu::Mailbox front_mailbox_;
|
| + void AdjustBufferAllocation();
|
| + void DestroyFramebuffer();
|
| + void CreateFramebuffer();
|
|
|
| - // The current size of the GLSurface. Used to disambiguate from the current
|
| - // texture size which might be outdated (since we use two buffers).
|
| - gfx::Size current_size_;
|
| - float scale_factor_;
|
| -
|
| - // Whether or not the command buffer stub has been destroyed.
|
| - bool stub_destroyed_;
|
| + scoped_ptr<StorageProvider> storage_provider_;
|
|
|
| + // Tracks the current buffer allocation state.
|
| bool backbuffer_suggested_allocation_;
|
| bool frontbuffer_suggested_allocation_;
|
|
|
| - scoped_ptr<ImageTransportHelper> helper_;
|
| - gfx::GLSurfaceHandle handle_;
|
| + uint32 fbo_id_;
|
| + GLuint texture_id_;
|
| + GLuint depth_stencil_renderbuffer_id_;
|
| + bool has_complete_framebuffer_;
|
| +
|
| + // Weak pointer to the context that this was last made current to.
|
| + gfx::GLContext* context_;
|
|
|
| - // The offscreen surface used to make the context current. However note that
|
| - // the actual rendering is always redirected to an FBO.
|
| - scoped_refptr<gfx::GLSurface> surface_;
|
| + gfx::Size size_;
|
| + gfx::Size rounded_size_;
|
| + float scale_factor_;
|
| +
|
| + // Whether or not we've successfully made the surface current once.
|
| + bool made_current_;
|
|
|
| // Whether a SwapBuffers is pending.
|
| bool is_swap_buffers_pending_;
|
| @@ -112,13 +112,13 @@ class TextureImageTransportSurface
|
| // Whether we unscheduled command buffer because of pending SwapBuffers.
|
| bool did_unschedule_;
|
|
|
| - // Holds a reference to the mailbox manager for cleanup.
|
| - scoped_refptr<gpu::gles2::MailboxManager> mailbox_manager_;
|
| -
|
| std::vector<ui::LatencyInfo> latency_info_;
|
| - DISALLOW_COPY_AND_ASSIGN(TextureImageTransportSurface);
|
| +
|
| + scoped_ptr<ImageTransportHelper> helper_;
|
| +
|
| + DISALLOW_COPY_AND_ASSIGN(ImageTransportSurfaceFBO);
|
| };
|
|
|
| } // namespace content
|
|
|
| -#endif // CONTENT_COMMON_GPU_TEXTURE_IMAGE_TRANSPORT_SURFACE_H_
|
| +#endif // CONTENT_COMMON_GPU_IMAGE_TRANSPORT_SURFACE_MAC_H_
|
|
|