Chromium Code Reviews| 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..492851d595e5432b0004fe735e8717ce3fda8d6e 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<media::GpuVideoAcceleratorFactories> Clone() OVERRIDE; |
| 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 ouptu tin the vea_ member. |
|
hshi1
2013/08/02 17:29:36
"outpu tin" -> "output in"
sheu
2013/08/03 01:31:03
Done.
|
| 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_ |