summaryrefslogtreecommitdiffstats
path: root/content/browser
diff options
context:
space:
mode:
authorprimiano@chromium.org <primiano@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2012-03-27 14:01:12 +0000
committerprimiano@chromium.org <primiano@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2012-03-27 14:01:12 +0000
commit3652800bfca27dd1817b2175abecec91572895b4 (patch)
treeabdb3a263db26df357e3368fff2a2a968b0dd72f /content/browser
parent013f614070bab1555df4b789040b2f534630fd48 (diff)
downloadchromium_src-3652800bfca27dd1817b2175abecec91572895b4.zip
chromium_src-3652800bfca27dd1817b2175abecec91572895b4.tar.gz
chromium_src-3652800bfca27dd1817b2175abecec91572895b4.tar.bz2
Fixed a regression on speech input caused by issue 9858007 (r128895) that caused renderer hang on speech input complete / abort.
BUG=120173 TEST=Speech input must not freeze the page upon abort/completion. Review URL: http://codereview.chromium.org/9856021 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@129173 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'content/browser')
-rw-r--r--content/browser/speech/speech_recognizer_impl.cc22
-rw-r--r--content/browser/speech/speech_recognizer_impl.h5
2 files changed, 13 insertions, 14 deletions
diff --git a/content/browser/speech/speech_recognizer_impl.cc b/content/browser/speech/speech_recognizer_impl.cc
index 007f3ee..2e8cc48 100644
--- a/content/browser/speech/speech_recognizer_impl.cc
+++ b/content/browser/speech/speech_recognizer_impl.cc
@@ -57,6 +57,7 @@ bool DetectClipping(const speech::AudioChunk& chunk) {
return false;
}
+void OnAudioClosed(AudioInputController*) {}
} // namespace
SpeechRecognizer* SpeechRecognizer::Create(
@@ -157,7 +158,7 @@ void SpeechRecognizerImpl::AbortRecognition() {
// Stop recording if required.
if (audio_controller_.get()) {
- CloseAudioControllerSynchronously();
+ CloseAudioControllerAsynchronously();
}
VLOG(1) << "SpeechRecognizer canceling recognition.";
@@ -172,7 +173,7 @@ void SpeechRecognizerImpl::StopAudioCapture() {
if (!audio_controller_.get())
return;
- CloseAudioControllerSynchronously();
+ CloseAudioControllerAsynchronously();
listener_->OnSoundEnd(caller_id_);
listener_->OnAudioEnd(caller_id_);
@@ -323,17 +324,14 @@ void SpeechRecognizerImpl::InformErrorAndAbortRecognition(
listener_->OnRecognitionError(caller_id_, error);
}
-void SpeechRecognizerImpl::CloseAudioControllerSynchronously() {
+void SpeechRecognizerImpl::CloseAudioControllerAsynchronously() {
VLOG(1) << "SpeechRecognizer stopping record.";
-
- // TODO(satish): investigate the possibility to utilize the closure
- // and switch to async. version of this method. Compare with how
- // it's done in e.g. the AudioRendererHost.
- base::WaitableEvent closed_event(true, false);
- audio_controller_->Close(base::Bind(&base::WaitableEvent::Signal,
- base::Unretained(&closed_event)));
- closed_event.Wait();
- audio_controller_ = NULL; // Releases the ref ptr.
+ // Issues a Close on the audio controller, passing an empty callback. The only
+ // purpose of such callback is to keep the audio controller refcounted until
+ // Close has completed (in the audio thread) and automatically destroy it
+ // afterwards (upon return from OnAudioClosed).
+ audio_controller_->Close(base::Bind(&OnAudioClosed, audio_controller_));
+ audio_controller_ = NULL; // The controller is still refcounted by Bind.
}
bool SpeechRecognizerImpl::IsActive() const {
diff --git a/content/browser/speech/speech_recognizer_impl.h b/content/browser/speech/speech_recognizer_impl.h
index 48196c3..e4b8756 100644
--- a/content/browser/speech/speech_recognizer_impl.h
+++ b/content/browser/speech/speech_recognizer_impl.h
@@ -84,8 +84,9 @@ class CONTENT_EXPORT SpeechRecognizerImpl
// Handles OnData in the IO thread. Takes ownership of |raw_audio|.
void HandleOnData(AudioChunk* raw_audio);
- // Helper method which closes the audio controller and blocks until done.
- void CloseAudioControllerSynchronously();
+ // Helper method which closes the audio controller and frees it asynchronously
+ // without blocking the IO thread.
+ void CloseAudioControllerAsynchronously();
void SetAudioManagerForTesting(AudioManager* audio_manager);