Index: media/base/android/webaudio_media_codec_bridge.cc |
diff --git a/media/base/android/webaudio_media_codec_bridge.cc b/media/base/android/webaudio_media_codec_bridge.cc |
index 963d3b2cecc365e8d47aabc8829827e42aa0f905..7a21261b13fe7809612a5dcaa2cc5e48901e3618 100644 |
--- a/media/base/android/webaudio_media_codec_bridge.cc |
+++ b/media/base/android/webaudio_media_codec_bridge.cc |
@@ -15,6 +15,7 @@ |
#include "base/logging.h" |
#include "base/posix/eintr_wrapper.h" |
#include "jni/WebAudioMediaCodecBridge_jni.h" |
+#include "media/base/android/webaudio_media_codec_info.h" |
using base::android::AttachCurrentThread; |
@@ -23,17 +24,20 @@ namespace media { |
void WebAudioMediaCodecBridge::RunWebAudioMediaCodec( |
base::SharedMemoryHandle encoded_audio_handle, |
- base::FileDescriptor pcm_output) { |
- WebAudioMediaCodecBridge bridge(encoded_audio_handle, pcm_output); |
+ base::FileDescriptor pcm_output, |
+ size_t data_size) { |
+ WebAudioMediaCodecBridge bridge(encoded_audio_handle, pcm_output, data_size); |
bridge.DecodeInMemoryAudioFile(); |
} |
WebAudioMediaCodecBridge::WebAudioMediaCodecBridge( |
base::SharedMemoryHandle encoded_audio_handle, |
- base::FileDescriptor pcm_output) |
+ base::FileDescriptor pcm_output, |
+ size_t data_size) |
: encoded_audio_handle_(encoded_audio_handle.fd), |
- pcm_output_(pcm_output.fd) { |
+ pcm_output_(pcm_output.fd), |
+ data_size_(data_size) { |
DVLOG(1) << "WebAudioMediaCodecBridge start **********************" |
<< "input fd = " << encoded_audio_handle_ |
<< " output fd = " << pcm_output.fd; |
@@ -60,7 +64,8 @@ bool WebAudioMediaCodecBridge::DecodeInMemoryAudioFile() { |
env, |
base::android::GetApplicationContext(), |
reinterpret_cast<intptr_t>(this), |
- encoded_audio_handle_); |
+ encoded_audio_handle_, |
+ data_size_); |
DVLOG(1) << "decoded = " << decoded; |
return decoded; |
@@ -71,29 +76,25 @@ void WebAudioMediaCodecBridge::InitializeDestination( |
jobject /*java object*/, |
jint channel_count, |
jint sample_rate, |
- jlong duration_microsec, |
- jboolean is_vorbis) { |
+ jlong duration_microsec) { |
// Send information about this audio file: number of channels, |
- // sample rate (Hz), number of frames, a flag indicating whether |
- // this file is an audio/vorbis file. Information is sent as a set of |
- // 4 longs. This must be coordinated with DecodeAudioFileData! |
- |
- unsigned long info[4] = {static_cast<unsigned long>(channel_count), |
- static_cast<unsigned long>(sample_rate), |
- // The number of frames is the duration of the file |
- // (in microseconds) times the sample rate. |
- static_cast<unsigned long>( |
- 0.5 + (duration_microsec * 0.000001 * |
- sample_rate)), |
- is_vorbis ? 1ul : 0ul}; |
+ // sample rate (Hz), and the number of frames. |
+ struct WebAudioMediaCodecInfo info = { |
+ static_cast<unsigned long>(channel_count), |
+ static_cast<unsigned long>(sample_rate), |
+ // The number of frames is the duration of the file |
+ // (in microseconds) times the sample rate. |
+ static_cast<unsigned long>( |
+ 0.5 + (duration_microsec * 0.000001 * |
+ sample_rate)) |
+ }; |
DVLOG(1) << "InitializeDestination:" |
<< " channel count = " << channel_count |
<< " rate = " << sample_rate |
- << " duration = " << duration_microsec << " microsec" |
- << " vorbis = " << (is_vorbis ? "yes" : "no"); |
+ << " duration = " << duration_microsec << " microsec"; |
- HANDLE_EINTR(write(pcm_output_, info, sizeof(info))); |
+ HANDLE_EINTR(write(pcm_output_, &info, sizeof(info))); |
} |
void WebAudioMediaCodecBridge::OnChunkDecoded( |