| Index: content/common/gpu/media/gpu_video_encode_accelerator.h
|
| diff --git a/content/common/gpu/media/gpu_video_encode_accelerator.h b/content/common/gpu/media/gpu_video_encode_accelerator.h
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..7beb2145347d7aa5ee139a014ab8f7c7710fa5f6
|
| --- /dev/null
|
| +++ b/content/common/gpu/media/gpu_video_encode_accelerator.h
|
| @@ -0,0 +1,86 @@
|
| +// Copyright (c) 2013 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_MEDIA_GPU_VIDEO_ENCODE_ACCELERATOR_H_
|
| +#define CONTENT_COMMON_GPU_MEDIA_GPU_VIDEO_ENCODE_ACCELERATOR_H_
|
| +
|
| +#include <vector>
|
| +
|
| +#include "base/memory/scoped_ptr.h"
|
| +#include "ipc/ipc_listener.h"
|
| +#include "media/video/video_encode_accelerator.h"
|
| +
|
| +namespace gfx {
|
| +
|
| +class Size;
|
| +
|
| +} // namespace gfx
|
| +
|
| +namespace content {
|
| +
|
| +class GpuChannel;
|
| +
|
| +// This class encapsulates the GPU process view of a VideoEncodeAccelerator,
|
| +// wrapping the platform-specific VideoEncodeAccelerator instance. It handles
|
| +// IPC coming in from the renderer and passes it to the underlying VEA.
|
| +class GpuVideoEncodeAccelerator : public IPC::Listener,
|
| + public media::VideoEncodeAccelerator::Client {
|
| + public:
|
| + GpuVideoEncodeAccelerator(GpuChannel* gpu_channel, int32 route_id);
|
| + virtual ~GpuVideoEncodeAccelerator();
|
| +
|
| + // IPC::Listener implementation
|
| + virtual bool OnMessageReceived(const IPC::Message& message) OVERRIDE;
|
| + virtual void OnChannelError() OVERRIDE;
|
| +
|
| + // media::VideoEncodeAccelerator::Client implementation.
|
| + virtual void NotifyInitializeDone() OVERRIDE;
|
| + virtual void RequireBitstreamBuffers(int input_count,
|
| + const gfx::Size& input_dimensions,
|
| + size_t output_size) OVERRIDE;
|
| + virtual void NotifyInputDone(int32 bitstream_buffer_id) OVERRIDE;
|
| + virtual void BitstreamBufferReady(int32 bitstream_buffer_id,
|
| + size_t payload_size,
|
| + bool key_frame) OVERRIDE;
|
| + virtual void NotifyError(media::VideoEncodeAccelerator::Error error) OVERRIDE;
|
| +
|
| + // Static query for supported profiles. This query calls the appropriate
|
| + // platform-specific version.
|
| + static std::vector<media::VideoEncodeAccelerator::SupportedProfile>
|
| + GetSupportedProfiles();
|
| +
|
| + private:
|
| + // Create the appropriate platform-specific VEA.
|
| + void CreateEncoder();
|
| +
|
| + void Send(IPC::Message* message);
|
| +
|
| + // IPC handlers, proxying media::VideoEncodeAccelerator for the renderer
|
| + // process.
|
| + void OnInitialize(media::VideoFrame::Format input_format,
|
| + const gfx::Size& input_resolution,
|
| + media::VideoCodecProfile output_profile,
|
| + int32 initial_bitrate);
|
| + void OnEncode(int32 buffer_id,
|
| + base::SharedMemoryHandle buffer_handle,
|
| + uint32 buffer_size,
|
| + bool force_keyframe);
|
| + void OnUseOutputBitstreamBuffer(int32 buffer_id,
|
| + base::SharedMemoryHandle buffer_handle,
|
| + uint32 buffer_size);
|
| + void OnRequestEncodingParameterChange(int32 bitrate);
|
| +
|
| + // The GpuChannel owns this GpuVideoEncodeAccelerator and will outlive |this|.
|
| + GpuChannel* channel_;
|
| + const int32 route_id_;
|
| +
|
| + // Owned pointer to the underlying VideoEncodeAccelerator.
|
| + scoped_ptr<media::VideoEncodeAccelerator> encoder_;
|
| +
|
| + DISALLOW_COPY_AND_ASSIGN(GpuVideoEncodeAccelerator);
|
| +};
|
| +
|
| +} // namespace content
|
| +
|
| +#endif // CONTENT_COMMON_GPU_MEDIA_GPU_VIDEO_ENCODE_ACCELERATOR_H_
|
|
|