Roll src/third_party/WebKit d9c6159:8139f33 (svn 201974:201975)
[chromium-blink-merge.git] / media / base / android / media_codec_decoder.h
blobdcd29e3a5088aa25fd7cb9941640ed78d75e6cce
1 // Copyright 2015 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef MEDIA_BASE_ANDROID_MEDIA_CODEC_DECODER_H_
6 #define MEDIA_BASE_ANDROID_MEDIA_CODEC_DECODER_H_
8 #include "base/android/scoped_java_ref.h"
9 #include "base/callback.h"
10 #include "base/macros.h"
11 #include "base/memory/ref_counted.h"
12 #include "base/memory/scoped_ptr.h"
13 #include "base/single_thread_task_runner.h"
14 #include "base/synchronization/lock.h"
15 #include "base/threading/thread.h"
16 #include "base/time/time.h"
17 #include "media/base/android/access_unit_queue.h"
18 #include "media/base/android/demuxer_stream_player_params.h"
20 namespace media {
22 class MediaCodecBridge;
24 // The decoder for MediaCodecPlayer.
25 // This class accepts the incoming data into AccessUnitQueue and works with
26 // MediaCodecBridge for decoding and rendering the frames. The MediaCodecPlayer
27 // has two decoder objects: audio and video.
29 // The decoder works on two threads. The data from demuxer comes on Media
30 // thread. The commands from MediaCodecPlayer, such as Prefetch, Start,
31 // RequestToStop also come on the Media thread. The operations with MediaCodec
32 // buffers and rendering happen on a separate thread called Decoder thread.
33 // This class creates, starts and stops it as necessary.
35 // Decoder's internal state machine goes through the following states:
37 // [ Stopped ] <------------------- (any state except Error)
38 // | | |
39 // | Prefetch |--- internal ------|
40 // v | transition v
41 // [ Prefetching ] | [ Error ]
42 // | |
43 // | internal transition |
44 // v | Error recovery:
45 // [ Prefetched ] |
46 // | | (any state including Error)
47 // | Configure and Start | |
48 // v | | ReleaseDecoderResources
49 // [ Running ] | v
50 // | | [ InEmergencyStop ]
51 // | RequestToStop | |
52 // v | |(decoder thread stopped)
53 // [ Stopping ] ------------------- v
54 // [ Stopped ]
56 // [ Stopped ] --------------------
57 // ^ |
58 // | Flush |
59 // ---------------------------
61 // (any state except Error)
62 // |
63 // | SyncStop
64 // v
65 // [ InEmergencyStop ]
66 // |
67 // |(decoder thread stopped)
68 // v
69 // [ Stopped ]
71 // Here is the workflow that is expected to be maintained by a caller, which is
72 // MediaCodecPlayer currently.
74 // [ Stopped ]
75 // |
76 // | Prefetch
77 // v
78 // [ Prefetching ]
79 // |
80 // | (Enough data received)
81 // v
82 // [ Prefetched ]
83 // |
84 // | <---------- SetDemuxerConfigs (*)
85 // |
86 // | <---------- SetVideoSurface (**)
87 // |
88 // | Configure --------------------------------------------+
89 // | |
90 // v v
91 // ( Config Succeeded ) ( Key frame required )
92 // | |
93 // | Start |
94 // v |
95 // [ Running ] ------------------------------+ |
96 // | | |
97 // | | |
98 // | RequestToStop | SyncStop | SyncStop
99 // | | |
100 // [ Stopping ] | |
101 // | | |
102 // | ( Last frame rendered ) | |
103 // | | |
104 // | | |
105 // v | |
106 // [ Stopped ] <-----------------------------+-----------------+
109 // (*) Demuxer configs is a precondition to Configure(), but MediaCodecPlayer
110 // has stricter requirements and they are set before Prefetch().
112 // (**) VideoSurface is a precondition to video decoder Configure(), can be set
113 // any time before Configure().
115 class MediaCodecDecoder {
116 public:
117 // The result of MediaCodec configuration, used by MediaCodecPlayer.
118 enum ConfigStatus {
119 kConfigFailure = 0,
120 kConfigOk,
121 kConfigKeyFrameRequired,
124 // The decoder reports current playback time to the MediaCodecPlayer.
125 // For audio, the parameters designate the beginning and end of a time
126 // interval. The beginning is the estimated time that is playing right now.
127 // The end is the playback time of the last buffered data. During normal
128 // playback the subsequent intervals overlap.
129 // For video both values are PTS of the corresponding frame, i.e. the interval
130 // has zero width.
131 // The third parameter means "postpone", it is set to true if the actual
132 // rendering will start in a later point in time. This only happens with
133 // audio after preroll. The MediaCodecPlayer might decide to update the
134 // current time but not pass it to the upper layer.
135 typedef base::Callback<void(base::TimeDelta, base::TimeDelta, bool)>
136 SetTimeCallback;
138 // MediaCodecDecoder constructor.
139 // Parameters:
140 // media_task_runner:
141 // A task runner for the controlling thread. All public methods should be
142 // called on this thread, and callbacks are delivered on this thread.
143 // The MediaCodecPlayer uses a dedicated (Media) thread for this.
144 // external_request_data_cb:
145 // Called periodically as the amount of internally stored data decreases.
146 // The receiver should call OnDemuxerDataAvailable() with more data.
147 // starvation_cb:
148 // Called when starvation is detected. The decoder state does not change.
149 // The player is supposed to stop and then prefetch the decoder.
150 // stop_done_cb:
151 // Called when async stop request is completed.
152 // decoder_drained_cb:
153 // Called when decoder is drained for reconfiguration.
154 // error_cb:
155 // Called when a MediaCodec error occurred. If this happens, a player has
156 // to either call ReleaseDecoderResources() or destroy the decoder object.
157 // decoder_thread_name:
158 // The thread name to be passed to decoder thread constructor.
159 MediaCodecDecoder(
160 const scoped_refptr<base::SingleThreadTaskRunner>& media_task_runner,
161 const base::Closure& external_request_data_cb,
162 const base::Closure& starvation_cb,
163 const base::Closure& decoder_drained_cb,
164 const base::Closure& stop_done_cb,
165 const base::Closure& error_cb,
166 const char* decoder_thread_name);
167 virtual ~MediaCodecDecoder();
169 virtual const char* class_name() const;
171 // MediaCodecDecoder exists through the whole lifetime of the player
172 // to support dynamic addition and removal of the streams.
173 // This method returns true if the current stream (audio or video)
174 // is currently active.
175 virtual bool HasStream() const = 0;
177 // Stores configuration for the use of upcoming Configure()
178 virtual void SetDemuxerConfigs(const DemuxerConfigs& configs) = 0;
180 // Stops decoder thread, releases the MediaCodecBridge and other resources.
181 virtual void ReleaseDecoderResources() = 0;
183 // Flushes the MediaCodec, after that resets the AccessUnitQueue and blocks
184 // the input. Decoder thread should not be running.
185 virtual void Flush();
187 // Releases MediaCodecBridge and any related buffers or references.
188 virtual void ReleaseMediaCodec();
190 // Returns corresponding conditions.
191 bool IsPrefetchingOrPlaying() const;
192 bool IsStopped() const;
193 bool IsCompleted() const;
194 bool NotCompletedAndNeedsPreroll() const;
196 // Sets preroll timestamp and requests preroll.
197 void SetPrerollTimestamp(base::TimeDelta preroll_ts);
199 base::android::ScopedJavaLocalRef<jobject> GetMediaCrypto();
201 // Starts prefetching: accumulates enough data in AccessUnitQueue.
202 // Decoder thread is not running.
203 void Prefetch(const base::Closure& prefetch_done_cb);
205 // Configures MediaCodec.
206 ConfigStatus Configure();
208 // Starts the decoder for prerolling. This method starts the decoder thread.
209 bool Preroll(const base::Closure& preroll_done_cb);
211 // Starts the decoder after preroll is not needed, starting decoder thread
212 // if it has not started yet.
213 bool Start(base::TimeDelta start_timestamp);
215 // Stops the playback process synchronously. This method stops the decoder
216 // thread synchronously, and then releases all MediaCodec buffers.
217 void SyncStop();
219 // Requests to stop the playback and returns.
220 // Decoder will stop asynchronously after all the dequeued output buffers
221 // are rendered.
222 void RequestToStop();
224 // Notification posted when asynchronous stop is done or playback completed.
225 void OnLastFrameRendered(bool eos_encountered);
227 // Notification posted when last prerolled frame has been returned to codec.
228 void OnPrerollDone();
230 // Puts the incoming data into AccessUnitQueue.
231 void OnDemuxerDataAvailable(const DemuxerData& data);
233 // For testing only.
235 // Returns true if the decoder is in kPrerolling state.
236 bool IsPrerollingForTests() const;
238 // Drains decoder and reconfigures for each |kConfigChanged|.
239 void SetAlwaysReconfigureForTests();
241 // Sets the notification to be called when MediaCodec is created.
242 void SetCodecCreatedCallbackForTests(base::Closure cb);
244 // Turn on and off extra logging with elevated log level.
245 void SetVerboseForTests(bool value);
247 protected:
248 enum RenderMode {
249 kRenderSkip = 0,
250 kRenderAfterPreroll,
251 kRenderNow,
254 // Returns true if the new DemuxerConfigs requires MediaCodec
255 // reconfiguration.
256 virtual bool IsCodecReconfigureNeeded(const DemuxerConfigs& next) const = 0;
258 // Does the part of MediaCodecBridge configuration that is specific
259 // to audio or video.
260 virtual ConfigStatus ConfigureInternal() = 0;
262 // Associates PTS with device time so we can calculate delays.
263 // We use delays for video decoder only.
264 virtual void AssociateCurrentTimeWithPTS(base::TimeDelta current_time) {}
266 // Invalidate delay calculation. We use delays for video decoder only.
267 virtual void DissociatePTSFromTime() {}
269 // Processes the change of the output format, varies by stream.
270 virtual void OnOutputFormatChanged() = 0;
272 // Renders the decoded frame and releases output buffer, or posts
273 // a delayed task to do it at a later time,
274 virtual void Render(int buffer_index,
275 size_t offset,
276 size_t size,
277 RenderMode render_mode,
278 base::TimeDelta pts,
279 bool eos_encountered) = 0;
281 // Returns the number of delayed task (we might have them for video).
282 virtual int NumDelayedRenderTasks() const;
284 // Releases output buffers that are dequeued and not released yet (video).
285 virtual void ReleaseDelayedBuffers() {}
287 #ifndef NDEBUG
288 // For video, checks that access unit is the key frame or stand-alone EOS.
289 virtual void VerifyUnitIsKeyFrame(const AccessUnit* unit) const {}
290 #endif
292 // Helper methods.
294 // Synchroniously stop decoder thread.
295 void DoEmergencyStop();
297 // Returns true if we are in the process of sync stop.
298 bool InEmergencyStop() const { return GetState() == kInEmergencyStop; }
300 // Notifies the decoder if the frame is the last one.
301 void CheckLastFrame(bool eos_encountered, bool has_delayed_tasks);
303 const char* AsString(RenderMode render_mode);
305 // Protected data.
307 // Object for posting tasks on Media thread.
308 scoped_refptr<base::SingleThreadTaskRunner> media_task_runner_;
310 // Controls Android MediaCodec
311 scoped_ptr<MediaCodecBridge> media_codec_bridge_;
313 // We call MediaCodecBridge on this thread for both
314 // input and output buffers.
315 base::Thread decoder_thread_;
317 // The queue of access units.
318 AccessUnitQueue au_queue_;
320 // Flag forces reconfiguration even if |media_codec_bridge_| exists. Currently
321 // is set by video decoder when the video surface changes.
322 bool needs_reconfigure_;
324 // Flag forces to drain decoder in the process of dynamic reconfiguration.
325 bool drain_decoder_;
327 // For tests only. Forces to always reconfigure for |kConfigChanged| unit.
328 bool always_reconfigure_for_tests_;
330 // For tests only. Enables more logging output.
331 bool verbose_;
333 // For tests only. Callback to be callned when MediaCodec is created.
334 base::Closure codec_created_for_tests_cb_;
336 private:
337 enum DecoderState {
338 kStopped = 0,
339 kPrefetching,
340 kPrefetched,
341 kPrerolling,
342 kPrerolled,
343 kRunning,
344 kStopping,
345 kInEmergencyStop,
346 kError,
349 // Helper method that processes an error from MediaCodec.
350 void OnCodecError();
352 // Requests data. Ensures there is no more than one request at a time.
353 void RequestData();
355 // Prefetching callback that is posted to Media thread
356 // in the kPrefetching state.
357 void PrefetchNextChunk();
359 // The callback to do actual playback. Posted to Decoder thread
360 // in the kRunning state.
361 void ProcessNextFrame();
363 // Helper method for ProcessNextFrame.
364 // Pushes one input buffer to the MediaCodec if the codec can accept it.
365 // Returns false if there was MediaCodec error.
366 bool EnqueueInputBuffer();
368 // Helper method for EnqueueInputBuffer.
369 // Gets the next data frame from the queue, requesting more data and saving
370 // configuration changes on the way. Sets |drain_decoder| to true of any of
371 // the configuration changes requires draining the decoder. Returns the Info
372 // pointing to the current data unit ot empty Info if it got past the end of
373 // the queue.
374 AccessUnitQueue::Info AdvanceAccessUnitQueue(bool* drain_decoder);
376 // Helper method for ProcessNextFrame.
377 // Pulls all currently available output frames and renders them.
378 // Returns true if we need to continue decoding process, i.e post next
379 // ProcessNextFrame method, and false if we need to stop decoding.
380 bool DepleteOutputBufferQueue();
382 DecoderState GetState() const;
383 void SetState(DecoderState state);
384 const char* AsString(DecoderState state);
386 // Private Data.
388 // External data request callback that is passed to decoder.
389 base::Closure external_request_data_cb_;
391 // These notifications are called on corresponding conditions.
392 base::Closure prefetch_done_cb_;
393 base::Closure starvation_cb_;
394 base::Closure preroll_done_cb_;
395 base::Closure decoder_drained_cb_;
396 base::Closure stop_done_cb_;
397 base::Closure error_cb_;
399 // Data request callback that is posted by decoder internally.
400 base::Closure request_data_cb_;
402 // Callback used to post OnCodecError method.
403 base::Closure internal_error_cb_;
405 // Callback for posting OnPrerollDone method.
406 base::Closure internal_preroll_done_cb_;
408 // Internal state.
409 DecoderState state_;
410 mutable base::Lock state_lock_;
412 // Preroll timestamp is set if we need preroll and cleared after we done it.
413 base::TimeDelta preroll_timestamp_;
415 // Set to true when MediaCodec internal buffers are filled up.
416 bool is_prepared_;
418 // Flag is set when the EOS is enqueued into MediaCodec. Reset by Flush.
419 bool eos_enqueued_;
421 // Flag is set when the EOS is received in MediaCodec output. Reset by Flush.
422 bool completed_;
424 // Flag to ensure we post last frame notification once.
425 bool last_frame_posted_;
427 // Indicates whether the data request is in progress.
428 bool is_data_request_in_progress_;
430 // Indicates whether the incoming data should be ignored.
431 bool is_incoming_data_invalid_;
433 #ifndef NDEBUG
434 // When set, we check that the following video frame is the key frame.
435 bool verify_next_frame_is_key_;
436 #endif
438 // NOTE: Weak pointers must be invalidated before all other member variables.
439 base::WeakPtrFactory<MediaCodecDecoder> weak_factory_;
441 DISALLOW_COPY_AND_ASSIGN(MediaCodecDecoder);
444 } // namespace media
446 #endif // MEDIA_BASE_ANDROID_MEDIA_CODEC_DECODER_H_