Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #ifndef CONTENT_COMMON_GPU_MEDIA_GPU_VIDEO_ENCODE_ACCELERATOR_H_ | 5 #ifndef CONTENT_COMMON_GPU_MEDIA_GPU_VIDEO_ENCODE_ACCELERATOR_H_ |
| 6 #define CONTENT_COMMON_GPU_MEDIA_GPU_VIDEO_ENCODE_ACCELERATOR_H_ | 6 #define CONTENT_COMMON_GPU_MEDIA_GPU_VIDEO_ENCODE_ACCELERATOR_H_ |
| 7 | 7 |
| 8 #include <vector> | 8 #include <vector> |
| 9 | 9 |
| 10 #include "base/memory/scoped_ptr.h" | 10 #include "base/memory/scoped_ptr.h" |
| 11 #include "base/memory/scoped_vector.h" | |
| 11 #include "base/memory/weak_ptr.h" | 12 #include "base/memory/weak_ptr.h" |
| 12 #include "content/common/gpu/gpu_command_buffer_stub.h" | 13 #include "content/common/gpu/gpu_command_buffer_stub.h" |
| 13 #include "gpu/config/gpu_info.h" | 14 #include "gpu/config/gpu_info.h" |
| 14 #include "ipc/ipc_listener.h" | 15 #include "ipc/ipc_listener.h" |
| 15 #include "media/video/video_encode_accelerator.h" | 16 #include "media/video/video_encode_accelerator.h" |
| 16 #include "ui/gfx/size.h" | 17 #include "ui/gfx/size.h" |
| 17 | 18 |
| 18 namespace base { | 19 namespace base { |
| 19 | 20 |
| 20 class SharedMemory; | 21 class SharedMemory; |
| (...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 53 size_t payload_size, | 54 size_t payload_size, |
| 54 bool key_frame) override; | 55 bool key_frame) override; |
| 55 void NotifyError(media::VideoEncodeAccelerator::Error error) override; | 56 void NotifyError(media::VideoEncodeAccelerator::Error error) override; |
| 56 | 57 |
| 57 // GpuCommandBufferStub::DestructionObserver implementation. | 58 // GpuCommandBufferStub::DestructionObserver implementation. |
| 58 void OnWillDestroyStub() override; | 59 void OnWillDestroyStub() override; |
| 59 | 60 |
| 60 // Static query for supported profiles. This query calls the appropriate | 61 // Static query for supported profiles. This query calls the appropriate |
| 61 // platform-specific version. | 62 // platform-specific version. |
| 62 static std::vector<gpu::VideoEncodeAcceleratorSupportedProfile> | 63 static std::vector<gpu::VideoEncodeAcceleratorSupportedProfile> |
| 63 GetSupportedProfiles(); | 64 GetSupportedProfiles(); |
| 64 static std::vector<gpu::VideoEncodeAcceleratorSupportedProfile> | 65 static std::vector<gpu::VideoEncodeAcceleratorSupportedProfile> |
| 65 ConvertMediaToGpuProfiles(const std::vector< | 66 ConvertMediaToGpuProfiles(const std::vector< |
| 66 media::VideoEncodeAccelerator::SupportedProfile>& media_profiles); | 67 media::VideoEncodeAccelerator::SupportedProfile>& media_profiles); |
| 67 | 68 |
| 68 private: | 69 private: |
| 69 // Create the appropriate platform-specific VEA. | 70 // Create the appropriate platform-specific VEA. |
|
Pawel Osciak
2014/12/26 01:11:36
Please update comments.
henryhsu
2014/12/26 08:40:40
Done.
| |
| 70 static scoped_ptr<media::VideoEncodeAccelerator> CreateEncoder(); | 71 static ScopedVector<media::VideoEncodeAccelerator> CreateEncoder(); |
|
Pawel Osciak
2014/12/26 01:11:36
CreateEncoders
henryhsu
2014/12/26 08:40:40
Done.
| |
| 71 | 72 |
| 72 // IPC handlers, proxying media::VideoEncodeAccelerator for the renderer | 73 // IPC handlers, proxying media::VideoEncodeAccelerator for the renderer |
| 73 // process. | 74 // process. |
| 74 void OnEncode(int32 frame_id, | 75 void OnEncode(int32 frame_id, |
| 75 base::SharedMemoryHandle buffer_handle, | 76 base::SharedMemoryHandle buffer_handle, |
| 76 uint32 buffer_size, | 77 uint32 buffer_size, |
| 77 bool force_keyframe); | 78 bool force_keyframe); |
| 78 void OnUseOutputBitstreamBuffer(int32 buffer_id, | 79 void OnUseOutputBitstreamBuffer(int32 buffer_id, |
| 79 base::SharedMemoryHandle buffer_handle, | 80 base::SharedMemoryHandle buffer_handle, |
| 80 uint32 buffer_size); | 81 uint32 buffer_size); |
| 81 void OnRequestEncodingParametersChange(uint32 bitrate, uint32 framerate); | 82 void OnRequestEncodingParametersChange(uint32 bitrate, uint32 framerate); |
| 82 | 83 |
| 83 void OnDestroy(); | 84 void OnDestroy(); |
| 84 | 85 |
| 85 void EncodeFrameFinished(int32 frame_id, scoped_ptr<base::SharedMemory> shm); | 86 void EncodeFrameFinished(int32 frame_id, scoped_ptr<base::SharedMemory> shm); |
| 86 | 87 |
| 87 void Send(IPC::Message* message); | 88 void Send(IPC::Message* message); |
| 88 // Helper for replying to the creation request. | 89 // Helper for replying to the creation request. |
| 89 void SendCreateEncoderReply(IPC::Message* message, bool succeeded); | 90 void SendCreateEncoderReply(IPC::Message* message, bool succeeded); |
| 90 | 91 |
| 91 // Route ID to communicate with the host. | 92 // Route ID to communicate with the host. |
| 92 int32 host_route_id_; | 93 int32 host_route_id_; |
| 93 | 94 |
| 94 // Unowned pointer to the underlying GpuCommandBufferStub. |this| is | 95 // Unowned pointer to the underlying GpuCommandBufferStub. |this| is |
| 95 // registered as a DestuctionObserver of |stub_| and will self-delete when | 96 // registered as a DestuctionObserver of |stub_| and will self-delete when |
| 96 // |stub_| is destroyed. | 97 // |stub_| is destroyed. |
| 97 GpuCommandBufferStub* stub_; | 98 GpuCommandBufferStub* stub_; |
| 98 | 99 |
| 99 // Owned pointer to the underlying VideoEncodeAccelerator. | 100 // Owned pointer to all VideoEncodeAccelerator. |
|
Pawel Osciak
2014/12/26 01:11:36
s/pointer/pointers/
s/VideoEncodeAccelerator/Video
henryhsu
2014/12/26 08:40:40
encoder_list is not used.
| |
| 100 scoped_ptr<media::VideoEncodeAccelerator> encoder_; | 101 ScopedVector<media::VideoEncodeAccelerator> encoder_list_; |
|
Pawel Osciak
2014/12/26 01:11:36
s/encoder_list_/encoders_/, since it's not a list.
henryhsu
2014/12/26 08:40:40
Done.
| |
| 102 // Pointer to valid VideoEncodeAccelerator. | |
|
Pawel Osciak
2014/12/26 01:11:36
What does "valid" mean here?
henryhsu
2014/12/26 08:40:40
Done.
| |
| 103 media::VideoEncodeAccelerator* encoder_; | |
| 101 base::Callback<bool(void)> make_context_current_; | 104 base::Callback<bool(void)> make_context_current_; |
| 102 | 105 |
| 103 // Video encoding parameters. | 106 // Video encoding parameters. |
| 104 media::VideoFrame::Format input_format_; | 107 media::VideoFrame::Format input_format_; |
| 105 gfx::Size input_visible_size_; | 108 gfx::Size input_visible_size_; |
| 106 gfx::Size input_coded_size_; | 109 gfx::Size input_coded_size_; |
| 107 size_t output_buffer_size_; | 110 size_t output_buffer_size_; |
| 108 | 111 |
| 109 // Weak pointer for media::VideoFrames that refer back to |this|. | 112 // Weak pointer for media::VideoFrames that refer back to |this|. |
| 110 base::WeakPtrFactory<GpuVideoEncodeAccelerator> weak_this_factory_; | 113 base::WeakPtrFactory<GpuVideoEncodeAccelerator> weak_this_factory_; |
| 111 | 114 |
| 112 DISALLOW_COPY_AND_ASSIGN(GpuVideoEncodeAccelerator); | 115 DISALLOW_COPY_AND_ASSIGN(GpuVideoEncodeAccelerator); |
| 113 }; | 116 }; |
| 114 | 117 |
| 115 } // namespace content | 118 } // namespace content |
| 116 | 119 |
| 117 #endif // CONTENT_COMMON_GPU_MEDIA_GPU_VIDEO_ENCODE_ACCELERATOR_H_ | 120 #endif // CONTENT_COMMON_GPU_MEDIA_GPU_VIDEO_ENCODE_ACCELERATOR_H_ |
| OLD | NEW |