Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(113)

Side by Side Diff: media/filters/decoder_stream.h

Issue 1666653002: media: Remove SetCdmReadyCB and CdmReadyCB (part 1). (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: rebase and fix compile errors Created 4 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « media/filters/decoder_selector.cc ('k') | media/filters/decoder_stream.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 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_DECODER_STREAM_H_ 5 #ifndef MEDIA_FILTERS_DECODER_STREAM_H_
6 #define MEDIA_FILTERS_DECODER_STREAM_H_ 6 #define MEDIA_FILTERS_DECODER_STREAM_H_
7 7
8 #include <list> 8 #include <list>
9 9
10 #include "base/callback.h" 10 #include "base/callback.h"
11 #include "base/compiler_specific.h" 11 #include "base/compiler_specific.h"
12 #include "base/memory/ref_counted.h" 12 #include "base/memory/ref_counted.h"
13 #include "base/memory/scoped_vector.h" 13 #include "base/memory/scoped_vector.h"
14 #include "base/memory/weak_ptr.h" 14 #include "base/memory/weak_ptr.h"
15 #include "media/base/audio_decoder.h" 15 #include "media/base/audio_decoder.h"
16 #include "media/base/cdm_context.h"
17 #include "media/base/demuxer_stream.h" 16 #include "media/base/demuxer_stream.h"
18 #include "media/base/media_export.h" 17 #include "media/base/media_export.h"
19 #include "media/base/media_log.h" 18 #include "media/base/media_log.h"
20 #include "media/base/moving_average.h" 19 #include "media/base/moving_average.h"
21 #include "media/base/pipeline_status.h" 20 #include "media/base/pipeline_status.h"
22 #include "media/base/timestamp_constants.h" 21 #include "media/base/timestamp_constants.h"
23 #include "media/filters/decoder_selector.h" 22 #include "media/filters/decoder_selector.h"
24 #include "media/filters/decoder_stream_traits.h" 23 #include "media/filters/decoder_stream_traits.h"
25 24
26 namespace base { 25 namespace base {
27 class SingleThreadTaskRunner; 26 class SingleThreadTaskRunner;
28 } 27 }
29 28
30 namespace media { 29 namespace media {
31 30
31 class CdmContext;
32 class DecryptingDemuxerStream; 32 class DecryptingDemuxerStream;
33 33
34 // Wraps a DemuxerStream and a list of Decoders and provides decoded 34 // Wraps a DemuxerStream and a list of Decoders and provides decoded
35 // output to its client (e.g. Audio/VideoRendererImpl). 35 // output to its client (e.g. Audio/VideoRendererImpl).
36 template<DemuxerStream::Type StreamType> 36 template<DemuxerStream::Type StreamType>
37 class MEDIA_EXPORT DecoderStream { 37 class MEDIA_EXPORT DecoderStream {
38 public: 38 public:
39 typedef DecoderStreamTraits<StreamType> StreamTraits; 39 typedef DecoderStreamTraits<StreamType> StreamTraits;
40 typedef typename StreamTraits::DecoderType Decoder; 40 typedef typename StreamTraits::DecoderType Decoder;
41 typedef typename StreamTraits::OutputType Output; 41 typedef typename StreamTraits::OutputType Output;
(...skipping 16 matching lines...) Expand all
58 const scoped_refptr<base::SingleThreadTaskRunner>& task_runner, 58 const scoped_refptr<base::SingleThreadTaskRunner>& task_runner,
59 ScopedVector<Decoder> decoders, 59 ScopedVector<Decoder> decoders,
60 const scoped_refptr<MediaLog>& media_log); 60 const scoped_refptr<MediaLog>& media_log);
61 virtual ~DecoderStream(); 61 virtual ~DecoderStream();
62 62
63 // Returns the string representation of the StreamType for logging purpose. 63 // Returns the string representation of the StreamType for logging purpose.
64 std::string GetStreamTypeString(); 64 std::string GetStreamTypeString();
65 65
66 // Initializes the DecoderStream and returns the initialization result 66 // Initializes the DecoderStream and returns the initialization result
67 // through |init_cb|. Note that |init_cb| is always called asynchronously. 67 // through |init_cb|. Note that |init_cb| is always called asynchronously.
68 // |cdm_context| can be used to handle encrypted stream. Can be null if the
69 // stream is not encrypted.
68 void Initialize(DemuxerStream* stream, 70 void Initialize(DemuxerStream* stream,
69 const InitCB& init_cb, 71 const InitCB& init_cb,
70 const SetCdmReadyCB& set_cdm_ready_cb, 72 CdmContext* cdm_context,
71 const StatisticsCB& statistics_cb, 73 const StatisticsCB& statistics_cb,
72 const base::Closure& waiting_for_decryption_key_cb); 74 const base::Closure& waiting_for_decryption_key_cb);
73 75
74 // Reads a decoded Output and returns it via the |read_cb|. Note that 76 // Reads a decoded Output and returns it via the |read_cb|. Note that
75 // |read_cb| is always called asynchronously. This method should only be 77 // |read_cb| is always called asynchronously. This method should only be
76 // called after initialization has succeeded and must not be called during 78 // called after initialization has succeeded and must not be called during
77 // pending Reset(). 79 // pending Reset().
78 void Read(const ReadCB& read_cb); 80 void Read(const ReadCB& read_cb);
79 81
80 // Resets the decoder, flushes all decoded outputs and/or internal buffers, 82 // Resets the decoder, flushes all decoded outputs and/or internal buffers,
(...skipping 45 matching lines...) Expand 10 before | Expand all | Expand 10 after
126 STATE_UNINITIALIZED, 128 STATE_UNINITIALIZED,
127 STATE_INITIALIZING, 129 STATE_INITIALIZING,
128 STATE_NORMAL, // Includes idle, pending decoder decode/reset. 130 STATE_NORMAL, // Includes idle, pending decoder decode/reset.
129 STATE_FLUSHING_DECODER, 131 STATE_FLUSHING_DECODER,
130 STATE_PENDING_DEMUXER_READ, 132 STATE_PENDING_DEMUXER_READ,
131 STATE_REINITIALIZING_DECODER, 133 STATE_REINITIALIZING_DECODER,
132 STATE_END_OF_STREAM, // End of stream reached; returns EOS on all reads. 134 STATE_END_OF_STREAM, // End of stream reached; returns EOS on all reads.
133 STATE_ERROR 135 STATE_ERROR
134 }; 136 };
135 137
136 void SelectDecoder(const SetCdmReadyCB& set_cdm_ready_cb); 138 void SelectDecoder(CdmContext* cdm_context);
137 139
138 // Called when |decoder_selector| selected the |selected_decoder|. 140 // Called when |decoder_selector| selected the |selected_decoder|.
139 // |decrypting_demuxer_stream| was also populated if a DecryptingDemuxerStream 141 // |decrypting_demuxer_stream| was also populated if a DecryptingDemuxerStream
140 // is created to help decrypt the encrypted stream. 142 // is created to help decrypt the encrypted stream.
141 void OnDecoderSelected( 143 void OnDecoderSelected(
142 scoped_ptr<Decoder> selected_decoder, 144 scoped_ptr<Decoder> selected_decoder,
143 scoped_ptr<DecryptingDemuxerStream> decrypting_demuxer_stream); 145 scoped_ptr<DecryptingDemuxerStream> decrypting_demuxer_stream);
144 146
145 // Satisfy pending |read_cb_| with |status| and |output|. 147 // Satisfy pending |read_cb_| with |status| and |output|.
146 void SatisfyRead(Status status, 148 void SatisfyRead(Status status,
(...skipping 86 matching lines...) Expand 10 before | Expand all | Expand 10 after
233 235
234 template <> 236 template <>
235 int DecoderStream<DemuxerStream::AUDIO>::GetMaxDecodeRequests() const; 237 int DecoderStream<DemuxerStream::AUDIO>::GetMaxDecodeRequests() const;
236 238
237 typedef DecoderStream<DemuxerStream::VIDEO> VideoFrameStream; 239 typedef DecoderStream<DemuxerStream::VIDEO> VideoFrameStream;
238 typedef DecoderStream<DemuxerStream::AUDIO> AudioBufferStream; 240 typedef DecoderStream<DemuxerStream::AUDIO> AudioBufferStream;
239 241
240 } // namespace media 242 } // namespace media
241 243
242 #endif // MEDIA_FILTERS_DECODER_STREAM_H_ 244 #endif // MEDIA_FILTERS_DECODER_STREAM_H_
OLDNEW
« no previous file with comments | « media/filters/decoder_selector.cc ('k') | media/filters/decoder_stream.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698