OLD | NEW |
| (Empty) |
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 | |
3 // found in the LICENSE file. | |
4 | |
5 #ifndef WEBKIT_RENDERER_MEDIA_CRYPTO_PPAPI_FFMPEG_CDM_AUDIO_DECODER_H_ | |
6 #define WEBKIT_RENDERER_MEDIA_CRYPTO_PPAPI_FFMPEG_CDM_AUDIO_DECODER_H_ | |
7 | |
8 #include <vector> | |
9 | |
10 #include "base/basictypes.h" | |
11 #include "base/compiler_specific.h" | |
12 #include "base/memory/scoped_ptr.h" | |
13 #include "base/time/time.h" | |
14 #include "webkit/renderer/media/crypto/ppapi/cdm/content_decryption_module.h" | |
15 | |
16 struct AVCodecContext; | |
17 struct AVFrame; | |
18 | |
19 namespace media { | |
20 class AudioBus; | |
21 class AudioTimestampHelper; | |
22 } | |
23 | |
24 namespace webkit_media { | |
25 | |
26 // TODO(xhwang): This class is partially cloned from media::FFmpegAudioDecoder. | |
27 // When media::FFmpegAudioDecoder is updated, it's a pain to keep this class | |
28 // in sync with media::FFmpegAudioDecoder. We need a long term sustainable | |
29 // solution for this. See http://crbug.com/169203 | |
30 class FFmpegCdmAudioDecoder { | |
31 public: | |
32 explicit FFmpegCdmAudioDecoder(cdm::Host* host); | |
33 ~FFmpegCdmAudioDecoder(); | |
34 bool Initialize(const cdm::AudioDecoderConfig& config); | |
35 void Deinitialize(); | |
36 void Reset(); | |
37 | |
38 // Returns true when |config| is a valid audio decoder configuration. | |
39 static bool IsValidConfig(const cdm::AudioDecoderConfig& config); | |
40 | |
41 // Decodes |compressed_buffer|. Returns |cdm::kSuccess| after storing | |
42 // output in |decoded_frames| when output is available. Returns | |
43 // |cdm::kNeedMoreData| when |compressed_frame| does not produce output. | |
44 // Returns |cdm::kDecodeError| when decoding fails. | |
45 // | |
46 // A null |compressed_buffer| will attempt to flush the decoder of any | |
47 // remaining frames. |compressed_buffer_size| and |timestamp| are ignored. | |
48 cdm::Status DecodeBuffer(const uint8_t* compressed_buffer, | |
49 int32_t compressed_buffer_size, | |
50 int64_t timestamp, | |
51 cdm::AudioFrames* decoded_frames); | |
52 | |
53 private: | |
54 void ResetTimestampState(); | |
55 void ReleaseFFmpegResources(); | |
56 | |
57 base::TimeDelta GetNextOutputTimestamp() const; | |
58 | |
59 void SerializeInt64(int64_t value); | |
60 | |
61 bool is_initialized_; | |
62 | |
63 cdm::Host* const host_; | |
64 | |
65 // FFmpeg structures owned by this object. | |
66 AVCodecContext* codec_context_; | |
67 AVFrame* av_frame_; | |
68 | |
69 // Audio format. | |
70 int bits_per_channel_; | |
71 int samples_per_second_; | |
72 int channels_; | |
73 | |
74 // AVSampleFormat initially requested; not Chrome's SampleFormat. | |
75 int av_sample_format_; | |
76 | |
77 // Used for computing output timestamps. | |
78 scoped_ptr<media::AudioTimestampHelper> output_timestamp_helper_; | |
79 int bytes_per_frame_; | |
80 base::TimeDelta last_input_timestamp_; | |
81 | |
82 // We may need to convert the audio data coming out of FFmpeg from planar | |
83 // float to integer. | |
84 scoped_ptr<media::AudioBus> converter_bus_; | |
85 | |
86 // Number of output sample bytes to drop before generating output buffers. | |
87 // This is required for handling negative timestamps when decoding Vorbis | |
88 // audio, for example. | |
89 int output_bytes_to_drop_; | |
90 | |
91 typedef std::vector<uint8_t> SerializedAudioFrames; | |
92 SerializedAudioFrames serialized_audio_frames_; | |
93 | |
94 DISALLOW_COPY_AND_ASSIGN(FFmpegCdmAudioDecoder); | |
95 }; | |
96 | |
97 } // namespace webkit_media | |
98 | |
99 #endif // WEBKIT_RENDERER_MEDIA_CRYPTO_PPAPI_FFMPEG_CDM_AUDIO_DECODER_H_ | |
OLD | NEW |