| 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_DECRYPTING_AUDIO_DECODER_H_ | 5 #ifndef MEDIA_FILTERS_DECRYPTING_AUDIO_DECODER_H_ |
| 6 #define MEDIA_FILTERS_DECRYPTING_AUDIO_DECODER_H_ | 6 #define MEDIA_FILTERS_DECRYPTING_AUDIO_DECODER_H_ |
| 7 | 7 |
| 8 #include "base/callback.h" | 8 #include "base/callback.h" |
| 9 #include "base/memory/ref_counted.h" | 9 #include "base/memory/ref_counted.h" |
| 10 #include "base/memory/scoped_ptr.h" | 10 #include "base/memory/scoped_ptr.h" |
| (...skipping 25 matching lines...) Expand all Loading... |
| 36 // format designated by kSupportedBitsPerChannel. | 36 // format designated by kSupportedBitsPerChannel. |
| 37 // TODO(xhwang): Remove this restriction after http://crbug.com/169105 fixed. | 37 // TODO(xhwang): Remove this restriction after http://crbug.com/169105 fixed. |
| 38 static const int kSupportedBitsPerChannel; | 38 static const int kSupportedBitsPerChannel; |
| 39 | 39 |
| 40 DecryptingAudioDecoder( | 40 DecryptingAudioDecoder( |
| 41 const scoped_refptr<base::SingleThreadTaskRunner>& task_runner, | 41 const scoped_refptr<base::SingleThreadTaskRunner>& task_runner, |
| 42 const SetDecryptorReadyCB& set_decryptor_ready_cb); | 42 const SetDecryptorReadyCB& set_decryptor_ready_cb); |
| 43 virtual ~DecryptingAudioDecoder(); | 43 virtual ~DecryptingAudioDecoder(); |
| 44 | 44 |
| 45 // AudioDecoder implementation. | 45 // AudioDecoder implementation. |
| 46 virtual void Initialize(DemuxerStream* stream, | 46 virtual void Initialize(const AudioDecoderConfig& config, |
| 47 const PipelineStatusCB& status_cb, | 47 const PipelineStatusCB& status_cb) OVERRIDE; |
| 48 const StatisticsCB& statistics_cb) OVERRIDE; | 48 virtual void Decode(const scoped_refptr<DecoderBuffer>& buffer, |
| 49 virtual void Read(const ReadCB& read_cb) OVERRIDE; | 49 const DecodeCB& decode_cb) OVERRIDE; |
| 50 virtual void Reset(const base::Closure& closure) OVERRIDE; | 50 virtual void Reset(const base::Closure& closure) OVERRIDE; |
| 51 virtual void Stop(const base::Closure& closure) OVERRIDE; | 51 virtual void Stop(const base::Closure& closure) OVERRIDE; |
| 52 virtual int bits_per_channel() OVERRIDE; | 52 virtual int bits_per_channel() OVERRIDE; |
| 53 virtual ChannelLayout channel_layout() OVERRIDE; | 53 virtual ChannelLayout channel_layout() OVERRIDE; |
| 54 virtual int samples_per_second() OVERRIDE; | 54 virtual int samples_per_second() OVERRIDE; |
| 55 virtual bool HasQueuedData() const OVERRIDE; |
| 55 | 56 |
| 56 private: | 57 private: |
| 57 // For a detailed state diagram please see this link: http://goo.gl/8jAok | 58 // For a detailed state diagram please see this link: http://goo.gl/8jAok |
| 58 // TODO(xhwang): Add a ASCII state diagram in this file after this class | 59 // TODO(xhwang): Add a ASCII state diagram in this file after this class |
| 59 // stabilizes. | 60 // stabilizes. |
| 60 // TODO(xhwang): Update this diagram for DecryptingAudioDecoder. | 61 // TODO(xhwang): Update this diagram for DecryptingAudioDecoder. |
| 61 enum State { | 62 enum State { |
| 62 kUninitialized = 0, | 63 kUninitialized = 0, |
| 63 kDecryptorRequested, | 64 kDecryptorRequested, |
| 64 kPendingDecoderInit, | 65 kPendingDecoderInit, |
| 65 kIdle, | 66 kIdle, |
| 66 kPendingConfigChange, | 67 kPendingConfigChange, |
| 67 kPendingDemuxerRead, | 68 kPendingDemuxerRead, |
| 68 kPendingDecode, | 69 kPendingDecode, |
| 69 kWaitingForKey, | 70 kWaitingForKey, |
| 70 kDecodeFinished, | 71 kDecodeFinished, |
| 71 kStopped, | 72 kStopped, |
| 72 }; | 73 }; |
| 73 | 74 |
| 74 // Callback for DecryptorHost::RequestDecryptor(). | 75 // Callback for DecryptorHost::RequestDecryptor(). |
| 75 void SetDecryptor(Decryptor* decryptor); | 76 void SetDecryptor(Decryptor* decryptor); |
| 76 | 77 |
| 77 // Callback for Decryptor::InitializeAudioDecoder() during initialization. | 78 // Callback for Decryptor::InitializeAudioDecoder() during initialization. |
| 78 void FinishInitialization(bool success); | 79 void FinishInitialization(bool success); |
| 79 | 80 |
| 80 // Callback for Decryptor::InitializeAudioDecoder() during config change. | |
| 81 void FinishConfigChange(bool success); | |
| 82 | |
| 83 // Reads from the demuxer stream with corresponding callback method. | |
| 84 void ReadFromDemuxerStream(); | |
| 85 void DecryptAndDecodeBuffer(DemuxerStream::Status status, | |
| 86 const scoped_refptr<DecoderBuffer>& buffer); | |
| 87 | |
| 88 void DecodePendingBuffer(); | 81 void DecodePendingBuffer(); |
| 89 | 82 |
| 90 // Callback for Decryptor::DecryptAndDecodeAudio(). | 83 // Callback for Decryptor::DecryptAndDecodeAudio(). |
| 91 void DeliverFrame(int buffer_size, | 84 void DeliverFrame(int buffer_size, |
| 92 Decryptor::Status status, | 85 Decryptor::Status status, |
| 93 const Decryptor::AudioBuffers& frames); | 86 const Decryptor::AudioBuffers& frames); |
| 94 | 87 |
| 95 // Callback for the |decryptor_| to notify this object that a new key has been | 88 // Callback for the |decryptor_| to notify this object that a new key has been |
| 96 // added. | 89 // added. |
| 97 void OnKeyAdded(); | 90 void OnKeyAdded(); |
| (...skipping 10 matching lines...) Expand all Loading... |
| 108 void EnqueueFrames(const Decryptor::AudioBuffers& frames); | 101 void EnqueueFrames(const Decryptor::AudioBuffers& frames); |
| 109 | 102 |
| 110 scoped_refptr<base::SingleThreadTaskRunner> task_runner_; | 103 scoped_refptr<base::SingleThreadTaskRunner> task_runner_; |
| 111 base::WeakPtrFactory<DecryptingAudioDecoder> weak_factory_; | 104 base::WeakPtrFactory<DecryptingAudioDecoder> weak_factory_; |
| 112 base::WeakPtr<DecryptingAudioDecoder> weak_this_; | 105 base::WeakPtr<DecryptingAudioDecoder> weak_this_; |
| 113 | 106 |
| 114 State state_; | 107 State state_; |
| 115 | 108 |
| 116 PipelineStatusCB init_cb_; | 109 PipelineStatusCB init_cb_; |
| 117 StatisticsCB statistics_cb_; | 110 StatisticsCB statistics_cb_; |
| 118 ReadCB read_cb_; | 111 DecodeCB decode_cb_; |
| 119 base::Closure reset_cb_; | 112 base::Closure reset_cb_; |
| 120 base::Closure stop_cb_; | 113 base::Closure stop_cb_; |
| 121 | 114 |
| 122 // Pointer to the demuxer stream that will feed us compressed buffers. | 115 // Pointer to the demuxer stream that will feed us compressed buffers. |
| 123 DemuxerStream* demuxer_stream_; | 116 AudioDecoderConfig config_; |
| 124 | 117 |
| 125 // Callback to request/cancel decryptor creation notification. | 118 // Callback to request/cancel decryptor creation notification. |
| 126 SetDecryptorReadyCB set_decryptor_ready_cb_; | 119 SetDecryptorReadyCB set_decryptor_ready_cb_; |
| 127 | 120 |
| 128 Decryptor* decryptor_; | 121 Decryptor* decryptor_; |
| 129 | 122 |
| 130 // The buffer returned by the demuxer that needs decrypting/decoding. | 123 // The buffer returned by the demuxer that needs decrypting/decoding. |
| 131 scoped_refptr<media::DecoderBuffer> pending_buffer_to_decode_; | 124 scoped_refptr<media::DecoderBuffer> pending_buffer_to_decode_; |
| 132 | 125 |
| 133 // Indicates the situation where new key is added during pending decode | 126 // Indicates the situation where new key is added during pending decode |
| (...skipping 11 matching lines...) Expand all Loading... |
| 145 int samples_per_second_; | 138 int samples_per_second_; |
| 146 | 139 |
| 147 scoped_ptr<AudioTimestampHelper> timestamp_helper_; | 140 scoped_ptr<AudioTimestampHelper> timestamp_helper_; |
| 148 | 141 |
| 149 DISALLOW_COPY_AND_ASSIGN(DecryptingAudioDecoder); | 142 DISALLOW_COPY_AND_ASSIGN(DecryptingAudioDecoder); |
| 150 }; | 143 }; |
| 151 | 144 |
| 152 } // namespace media | 145 } // namespace media |
| 153 | 146 |
| 154 #endif // MEDIA_FILTERS_DECRYPTING_AUDIO_DECODER_H_ | 147 #endif // MEDIA_FILTERS_DECRYPTING_AUDIO_DECODER_H_ |
| OLD | NEW |