| Index: content/renderer/media/renderer_gpu_video_accelerator_factories.h
|
| diff --git a/content/renderer/media/renderer_gpu_video_decoder_factories.h b/content/renderer/media/renderer_gpu_video_accelerator_factories.h
|
| similarity index 64%
|
| rename from content/renderer/media/renderer_gpu_video_decoder_factories.h
|
| rename to content/renderer/media/renderer_gpu_video_accelerator_factories.h
|
| index 32f9bcdf227b8713cc0d603b69171d66752106b4..9db1c33546a75b7a54c6eda4a5e3e27f76ec9850 100644
|
| --- a/content/renderer/media/renderer_gpu_video_decoder_factories.h
|
| +++ b/content/renderer/media/renderer_gpu_video_accelerator_factories.h
|
| @@ -2,8 +2,8 @@
|
| // Use of this source code is governed by a BSD-style license that can be
|
| // found in the LICENSE file.
|
|
|
| -#ifndef CONTENT_RENDERER_MEDIA_RENDERER_GPU_VIDEO_DECODER_FACTORIES_H_
|
| -#define CONTENT_RENDERER_MEDIA_RENDERER_GPU_VIDEO_DECODER_FACTORIES_H_
|
| +#ifndef CONTENT_RENDERER_MEDIA_RENDERER_GPU_VIDEO_ACCELERATOR_FACTORIES_H_
|
| +#define CONTENT_RENDERER_MEDIA_RENDERER_GPU_VIDEO_ACCELERATOR_FACTORIES_H_
|
|
|
| #include <vector>
|
|
|
| @@ -12,7 +12,7 @@
|
| #include "base/memory/weak_ptr.h"
|
| #include "base/synchronization/waitable_event.h"
|
| #include "content/common/content_export.h"
|
| -#include "media/filters/gpu_video_decoder_factories.h"
|
| +#include "media/filters/gpu_video_accelerator_factories.h"
|
| #include "third_party/skia/include/core/SkBitmap.h"
|
| #include "ui/gfx/size.h"
|
|
|
| @@ -25,7 +25,7 @@ namespace content {
|
| class GpuChannelHost;
|
| class WebGraphicsContext3DCommandBufferImpl;
|
|
|
| -// Glue code to expose functionality needed by media::GpuVideoDecoder to
|
| +// Glue code to expose functionality needed by media::GpuVideoAccelerator to
|
| // RenderViewImpl. This class is entirely an implementation detail of
|
| // RenderViewImpl and only has its own header to allow extraction of its
|
| // implementation from render_view_impl.cc which is already far too large.
|
| @@ -34,27 +34,31 @@ class WebGraphicsContext3DCommandBufferImpl;
|
| // internally trampolined to the appropriate thread. GPU/GL-related calls go to
|
| // the constructor-argument loop (the media thread), and shmem-related calls go
|
| // to the render thread.
|
| -class CONTENT_EXPORT RendererGpuVideoDecoderFactories
|
| - : public media::GpuVideoDecoderFactories {
|
| +class CONTENT_EXPORT RendererGpuVideoAcceleratorFactories
|
| + : public media::GpuVideoAcceleratorFactories {
|
| public:
|
| // Takes a ref on |gpu_channel_host| and tests |context| for loss before each
|
| // use.
|
| - RendererGpuVideoDecoderFactories(
|
| + RendererGpuVideoAcceleratorFactories(
|
| GpuChannelHost* gpu_channel_host,
|
| const scoped_refptr<base::MessageLoopProxy>& message_loop,
|
| WebGraphicsContext3DCommandBufferImpl* wgc3dcbi);
|
|
|
| - // media::GpuVideoDecoderFactories implementation.
|
| - virtual media::VideoDecodeAccelerator* CreateVideoDecodeAccelerator(
|
| - media::VideoCodecProfile profile,
|
| - media::VideoDecodeAccelerator::Client* client) OVERRIDE;
|
| + // media::GpuVideoAcceleratorFactories implementation.
|
| + virtual scoped_ptr<media::VideoDecodeAccelerator>
|
| + CreateVideoDecodeAccelerator(
|
| + media::VideoCodecProfile profile,
|
| + media::VideoDecodeAccelerator::Client* client) OVERRIDE;
|
| + virtual scoped_ptr<media::VideoEncodeAccelerator>
|
| + CreateVideoEncodeAccelerator(
|
| + media::VideoEncodeAccelerator::Client* client) OVERRIDE;
|
| // Creates textures and produces them into mailboxes. Returns a sync point to
|
| // wait on before using the mailboxes, or 0 on failure.
|
| - virtual uint32 CreateTextures(
|
| - int32 count, const gfx::Size& size,
|
| - std::vector<uint32>* texture_ids,
|
| - std::vector<gpu::Mailbox>* texture_mailboxes,
|
| - uint32 texture_target) OVERRIDE;
|
| + virtual uint32 CreateTextures(int32 count,
|
| + const gfx::Size& size,
|
| + std::vector<uint32>* texture_ids,
|
| + std::vector<gpu::Mailbox>* texture_mailboxes,
|
| + uint32 texture_target) OVERRIDE;
|
| virtual void DeleteTexture(uint32 texture_id) OVERRIDE;
|
| virtual void WaitSyncPoint(uint32 sync_point) OVERRIDE;
|
| virtual void ReadPixels(uint32 texture_id,
|
| @@ -65,16 +69,14 @@ class CONTENT_EXPORT RendererGpuVideoDecoderFactories
|
| virtual scoped_refptr<base::MessageLoopProxy> GetMessageLoop() OVERRIDE;
|
| virtual void Abort() OVERRIDE;
|
| virtual bool IsAborted() OVERRIDE;
|
| -
|
| - // Makes a copy of |this|.
|
| - scoped_refptr<media::GpuVideoDecoderFactories> Clone();
|
| + scoped_refptr<RendererGpuVideoAcceleratorFactories> Clone();
|
|
|
| protected:
|
| - friend class base::RefCountedThreadSafe<RendererGpuVideoDecoderFactories>;
|
| - virtual ~RendererGpuVideoDecoderFactories();
|
| + friend class base::RefCountedThreadSafe<RendererGpuVideoAcceleratorFactories>;
|
| + virtual ~RendererGpuVideoAcceleratorFactories();
|
|
|
| private:
|
| - RendererGpuVideoDecoderFactories();
|
| + RendererGpuVideoAcceleratorFactories();
|
|
|
| // Helper for the constructor to acquire the ContentGLContext on
|
| // |message_loop_|.
|
| @@ -85,19 +87,25 @@ class CONTENT_EXPORT RendererGpuVideoDecoderFactories
|
| // (except for DeleteTexture, which is fire-and-forget).
|
| // AsyncCreateSharedMemory runs on the renderer thread and the rest run on
|
| // |message_loop_|.
|
| - // The AsyncCreateVideoDecodeAccelerator returns its output in the vda_
|
| - // member.
|
| + // AsyncCreateVideoDecodeAccelerator returns its output in the |vda_| member.
|
| + // AsyncCreateVideoEncodeAccelerator returns its output in the |vea_| member.
|
| void AsyncCreateVideoDecodeAccelerator(
|
| media::VideoCodecProfile profile,
|
| media::VideoDecodeAccelerator::Client* client);
|
| - void AsyncCreateTextures(int32 count, const gfx::Size& size,
|
| - uint32 texture_target, uint32* sync_point);
|
| + void AsyncCreateVideoEncodeAccelerator(
|
| + media::VideoEncodeAccelerator::Client* client);
|
| + void AsyncCreateTextures(int32 count,
|
| + const gfx::Size& size,
|
| + uint32 texture_target,
|
| + uint32* sync_point);
|
| void AsyncDeleteTexture(uint32 texture_id);
|
| void AsyncWaitSyncPoint(uint32 sync_point);
|
| - void AsyncReadPixels(uint32 texture_id, uint32 texture_target,
|
| + void AsyncReadPixels(uint32 texture_id,
|
| + uint32 texture_target,
|
| const gfx::Size& size);
|
| void AsyncCreateSharedMemory(size_t size);
|
| void AsyncDestroyVideoDecodeAccelerator();
|
| + void AsyncDestroyVideoEncodeAccelerator();
|
|
|
| scoped_refptr<base::MessageLoopProxy> message_loop_;
|
| scoped_refptr<base::MessageLoopProxy> main_message_loop_;
|
| @@ -116,9 +124,12 @@ class CONTENT_EXPORT RendererGpuVideoDecoderFactories
|
| // message loop to indicate their completion. e.g. AsyncCreateSharedMemory.
|
| base::WaitableEvent render_thread_async_waiter_;
|
|
|
| - // The vda returned by the CreateVideoAcclelerator function.
|
| + // The vda returned by the CreateVideoDecodeAccelerator function.
|
| scoped_ptr<media::VideoDecodeAccelerator> vda_;
|
|
|
| + // The vea returned by the CreateVideoEncodeAccelerator function.
|
| + scoped_ptr<media::VideoEncodeAccelerator> vea_;
|
| +
|
| // Shared memory segment which is returned by the CreateSharedMemory()
|
| // function.
|
| scoped_ptr<base::SharedMemory> shared_memory_segment_;
|
| @@ -130,9 +141,9 @@ class CONTENT_EXPORT RendererGpuVideoDecoderFactories
|
| std::vector<uint32> created_textures_;
|
| std::vector<gpu::Mailbox> created_texture_mailboxes_;
|
|
|
| - DISALLOW_COPY_AND_ASSIGN(RendererGpuVideoDecoderFactories);
|
| + DISALLOW_COPY_AND_ASSIGN(RendererGpuVideoAcceleratorFactories);
|
| };
|
|
|
| } // namespace content
|
|
|
| -#endif // CONTENT_RENDERER_MEDIA_RENDERER_GPU_VIDEO_DECODER_FACTORIES_H_
|
| +#endif // CONTENT_RENDERER_MEDIA_RENDERER_GPU_VIDEO_ACCELERATOR_FACTORIES_H_
|
|
|