Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 MEDIA_FILTERS_GPU_VIDEO_DECODER_H_ | 5 #ifndef MEDIA_FILTERS_GPU_VIDEO_DECODER_H_ |
| 6 #define MEDIA_FILTERS_GPU_VIDEO_DECODER_H_ | 6 #define MEDIA_FILTERS_GPU_VIDEO_DECODER_H_ |
| 7 | 7 |
| 8 #include <list> | 8 #include <list> |
| 9 #include <map> | 9 #include <map> |
| 10 #include <set> | 10 #include <set> |
| (...skipping 10 matching lines...) Expand all Loading... | |
| 21 namespace base { | 21 namespace base { |
| 22 class MessageLoopProxy; | 22 class MessageLoopProxy; |
| 23 class SharedMemory; | 23 class SharedMemory; |
| 24 } | 24 } |
| 25 | 25 |
| 26 class SkBitmap; | 26 class SkBitmap; |
| 27 | 27 |
| 28 namespace media { | 28 namespace media { |
| 29 | 29 |
| 30 class DecoderBuffer; | 30 class DecoderBuffer; |
| 31 class VDAClientProxy; | |
| 32 | 31 |
| 33 // GPU-accelerated video decoder implementation. Relies on | 32 // GPU-accelerated video decoder implementation. Relies on |
| 34 // AcceleratedVideoDecoderMsg_Decode and friends. | 33 // AcceleratedVideoDecoderMsg_Decode and friends. |
| 35 // All methods internally trampoline to the |message_loop| passed to the ctor. | |
| 36 class MEDIA_EXPORT GpuVideoDecoder | 34 class MEDIA_EXPORT GpuVideoDecoder |
| 37 : public VideoDecoder, | 35 : public VideoDecoder, |
| 38 public VideoDecodeAccelerator::Client { | 36 public VideoDecodeAccelerator::Client { |
| 39 public: | 37 public: |
| 40 // Helper interface for specifying factories needed to instantiate a | 38 // Helper interface for specifying factories needed to instantiate a |
| 41 // GpuVideoDecoder. | 39 // GpuVideoDecoder. |
| 40 // TODO(wuchengli): move this out of GpuVideoDecoder because RTCVideoDecoder | |
|
Ami GONE FROM CHROMIUM
2013/07/22 19:46:21
Rebase makes this unnecessary?
wuchengli
2013/07/23 16:29:28
I couldn't submit that CL today because of submit
| |
| 41 // also uses this. | |
| 42 class MEDIA_EXPORT Factories : public base::RefCountedThreadSafe<Factories> { | 42 class MEDIA_EXPORT Factories : public base::RefCountedThreadSafe<Factories> { |
| 43 public: | 43 public: |
| 44 // Caller owns returned pointer. | 44 // Caller owns returned pointer. |
| 45 virtual VideoDecodeAccelerator* CreateVideoDecodeAccelerator( | 45 virtual VideoDecodeAccelerator* CreateVideoDecodeAccelerator( |
| 46 VideoCodecProfile, VideoDecodeAccelerator::Client*) = 0; | 46 VideoCodecProfile, VideoDecodeAccelerator::Client*) = 0; |
| 47 | 47 |
| 48 // Allocate & delete native textures. | 48 // Allocate & delete native textures. |
| 49 virtual uint32 CreateTextures(int32 count, const gfx::Size& size, | 49 virtual uint32 CreateTextures(int32 count, const gfx::Size& size, |
| 50 std::vector<uint32>* texture_ids, | 50 std::vector<uint32>* texture_ids, |
| 51 std::vector<gpu::Mailbox>* texture_mailboxes, | 51 std::vector<gpu::Mailbox>* texture_mailboxes, |
| (...skipping 13 matching lines...) Expand all Loading... | |
| 65 // Returns the message loop the VideoDecodeAccelerator runs on. | 65 // Returns the message loop the VideoDecodeAccelerator runs on. |
| 66 virtual scoped_refptr<base::MessageLoopProxy> GetMessageLoop() = 0; | 66 virtual scoped_refptr<base::MessageLoopProxy> GetMessageLoop() = 0; |
| 67 | 67 |
| 68 // Abort any outstanding factory operations and error any future | 68 // Abort any outstanding factory operations and error any future |
| 69 // attempts at factory operations | 69 // attempts at factory operations |
| 70 virtual void Abort() = 0; | 70 virtual void Abort() = 0; |
| 71 | 71 |
| 72 // Returns true if Abort() has been called. | 72 // Returns true if Abort() has been called. |
| 73 virtual bool IsAborted() = 0; | 73 virtual bool IsAborted() = 0; |
| 74 | 74 |
| 75 // Makes a copy of |this|. | |
| 76 virtual scoped_refptr<Factories> Clone() = 0; | |
| 77 | |
| 75 protected: | 78 protected: |
| 76 friend class base::RefCountedThreadSafe<Factories>; | 79 friend class base::RefCountedThreadSafe<Factories>; |
| 77 virtual ~Factories(); | 80 virtual ~Factories(); |
| 78 }; | 81 }; |
| 79 | 82 |
| 83 // |message_loop| should be the same as the one running |factories|. | |
|
Ami GONE FROM CHROMIUM
2013/07/22 19:46:21
Why not drop this param and just use factories->Ge
wuchengli
2013/07/23 16:29:28
That was recommended by Andrew. https://codereview
| |
| 80 GpuVideoDecoder(const scoped_refptr<base::MessageLoopProxy>& message_loop, | 84 GpuVideoDecoder(const scoped_refptr<base::MessageLoopProxy>& message_loop, |
| 81 const scoped_refptr<Factories>& factories); | 85 const scoped_refptr<Factories>& factories); |
| 82 | 86 |
| 83 // VideoDecoder implementation. | 87 // VideoDecoder implementation. |
| 84 virtual void Initialize(const VideoDecoderConfig& config, | 88 virtual void Initialize(const VideoDecoderConfig& config, |
| 85 const PipelineStatusCB& status_cb) OVERRIDE; | 89 const PipelineStatusCB& status_cb) OVERRIDE; |
| 86 virtual void Decode(const scoped_refptr<DecoderBuffer>& buffer, | 90 virtual void Decode(const scoped_refptr<DecoderBuffer>& buffer, |
| 87 const ReadCB& read_cb) OVERRIDE; | 91 const ReadCB& read_cb) OVERRIDE; |
| 88 virtual void Reset(const base::Closure& closure) OVERRIDE; | 92 virtual void Reset(const base::Closure& closure) OVERRIDE; |
| 89 virtual void Stop(const base::Closure& closure) OVERRIDE; | 93 virtual void Stop(const base::Closure& closure) OVERRIDE; |
| (...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 126 const scoped_refptr<VideoFrame>& frame); | 130 const scoped_refptr<VideoFrame>& frame); |
| 127 | 131 |
| 128 // Indicate the picture buffer can be reused by the decoder. | 132 // Indicate the picture buffer can be reused by the decoder. |
| 129 void ReusePictureBuffer(int64 picture_buffer_id, uint32 sync_point); | 133 void ReusePictureBuffer(int64 picture_buffer_id, uint32 sync_point); |
| 130 | 134 |
| 131 void RecordBufferData( | 135 void RecordBufferData( |
| 132 const BitstreamBuffer& bitstream_buffer, const DecoderBuffer& buffer); | 136 const BitstreamBuffer& bitstream_buffer, const DecoderBuffer& buffer); |
| 133 void GetBufferData(int32 id, base::TimeDelta* timetamp, | 137 void GetBufferData(int32 id, base::TimeDelta* timetamp, |
| 134 gfx::Rect* visible_rect, gfx::Size* natural_size); | 138 gfx::Rect* visible_rect, gfx::Size* natural_size); |
| 135 | 139 |
| 136 // Sets |vda_| and |weak_vda_| on the GVD thread and runs |status_cb|. | |
| 137 void SetVDA(const PipelineStatusCB& status_cb, | |
| 138 VideoDecodeAccelerator* vda, | |
| 139 base::WeakPtr<VideoDecodeAccelerator> weak_vda); | |
| 140 | |
| 141 // Call VDA::Destroy() on |vda_loop_proxy_| ensuring that |this| outlives the | |
| 142 // Destroy() call. | |
| 143 void DestroyVDA(); | 140 void DestroyVDA(); |
| 144 | 141 |
| 145 // A shared memory segment and its allocated size. | 142 // A shared memory segment and its allocated size. |
| 146 struct SHMBuffer { | 143 struct SHMBuffer { |
| 147 SHMBuffer(base::SharedMemory* m, size_t s); | 144 SHMBuffer(base::SharedMemory* m, size_t s); |
| 148 ~SHMBuffer(); | 145 ~SHMBuffer(); |
| 149 base::SharedMemory* shm; | 146 base::SharedMemory* shm; |
| 150 size_t size; | 147 size_t size; |
| 151 }; | 148 }; |
| 152 | 149 |
| 153 // Request a shared-memory segment of at least |min_size| bytes. Will | 150 // Request a shared-memory segment of at least |min_size| bytes. Will |
| 154 // allocate as necessary. Caller does not own returned pointer. | 151 // allocate as necessary. Caller does not own returned pointer. |
| 155 SHMBuffer* GetSHM(size_t min_size); | 152 SHMBuffer* GetSHM(size_t min_size); |
| 156 | 153 |
| 157 // Return a shared-memory segment to the available pool. | 154 // Return a shared-memory segment to the available pool. |
| 158 void PutSHM(SHMBuffer* shm_buffer); | 155 void PutSHM(SHMBuffer* shm_buffer); |
| 159 | 156 |
| 160 void DestroyTextures(); | 157 void DestroyTextures(); |
| 161 | 158 |
| 162 bool needs_bitstream_conversion_; | 159 bool needs_bitstream_conversion_; |
| 163 | 160 |
| 164 // Message loop on which to fire callbacks and trampoline calls to this class | 161 // Message loop which this class and |factories_| run on. |
| 165 // if they arrive on other loops. | |
| 166 scoped_refptr<base::MessageLoopProxy> gvd_loop_proxy_; | 162 scoped_refptr<base::MessageLoopProxy> gvd_loop_proxy_; |
| 167 base::WeakPtrFactory<GpuVideoDecoder> weak_factory_; | 163 base::WeakPtrFactory<GpuVideoDecoder> weak_factory_; |
| 168 base::WeakPtr<GpuVideoDecoder> weak_this_; | 164 base::WeakPtr<GpuVideoDecoder> weak_this_; |
| 169 | 165 |
| 170 // Message loop on which to makes all calls to vda_. (beware this loop may be | |
| 171 // paused during the Pause/Flush/Stop dance PipelineImpl::Stop() goes | |
| 172 // through). | |
| 173 scoped_refptr<base::MessageLoopProxy> vda_loop_proxy_; | |
| 174 | |
| 175 scoped_refptr<Factories> factories_; | 166 scoped_refptr<Factories> factories_; |
| 176 | 167 |
| 177 // Proxies calls from |vda_| to |gvd_loop_proxy_| and used to safely detach | 168 // Populated during Initialize() (on success) and unchanged until an error |
| 178 // during shutdown. | 169 // occurs. |
| 179 scoped_refptr<VDAClientProxy> client_proxy_; | |
| 180 | |
| 181 // Populated during Initialize() via SetVDA() (on success) and unchanged | |
| 182 // until an error occurs. | |
| 183 scoped_ptr<VideoDecodeAccelerator> vda_; | 170 scoped_ptr<VideoDecodeAccelerator> vda_; |
| 184 // Used to post tasks from the GVD thread to the VDA thread safely. | |
| 185 base::WeakPtr<VideoDecodeAccelerator> weak_vda_; | |
| 186 | 171 |
| 187 // Callbacks that are !is_null() only during their respective operation being | 172 // Callbacks that are !is_null() only during their respective operation being |
| 188 // asynchronously executed. | 173 // asynchronously executed. |
| 189 ReadCB pending_read_cb_; | 174 ReadCB pending_read_cb_; |
| 190 base::Closure pending_reset_cb_; | 175 base::Closure pending_reset_cb_; |
| 191 | 176 |
| 192 State state_; | 177 State state_; |
| 193 | 178 |
| 194 VideoDecoderConfig config_; | 179 VideoDecoderConfig config_; |
| 195 | 180 |
| (...skipping 43 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 239 // Set during ProvidePictureBuffers(), used for checking and implementing | 224 // Set during ProvidePictureBuffers(), used for checking and implementing |
| 240 // HasAvailableOutputFrames(). | 225 // HasAvailableOutputFrames(). |
| 241 int available_pictures_; | 226 int available_pictures_; |
| 242 | 227 |
| 243 DISALLOW_COPY_AND_ASSIGN(GpuVideoDecoder); | 228 DISALLOW_COPY_AND_ASSIGN(GpuVideoDecoder); |
| 244 }; | 229 }; |
| 245 | 230 |
| 246 } // namespace media | 231 } // namespace media |
| 247 | 232 |
| 248 #endif // MEDIA_FILTERS_GPU_VIDEO_DECODER_H_ | 233 #endif // MEDIA_FILTERS_GPU_VIDEO_DECODER_H_ |
| OLD | NEW |