diff options
author | sergeyu@chromium.org <sergeyu@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-09-14 17:58:16 +0000 |
---|---|---|
committer | sergeyu@chromium.org <sergeyu@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-09-14 17:58:16 +0000 |
commit | c499d08ff59eae8bfae79ed3ea2d21178790a5c7 (patch) | |
tree | 26f83da51be78fcba29349c3b0edda38eba8afef | |
parent | 1d95a8f0e313c9afbfd56fa0c007a16ad3881ba9 (diff) | |
download | chromium_src-c499d08ff59eae8bfae79ed3ea2d21178790a5c7.zip chromium_src-c499d08ff59eae8bfae79ed3ea2d21178790a5c7.tar.gz chromium_src-c499d08ff59eae8bfae79ed3ea2d21178790a5c7.tar.bz2 |
Fixed crash in AudioOutputController.
AudioOutputController must not call EventHandler after it has been
closed. Changing it so that lock_ is always locked whenever we call
handler_ to ensure that state_ != kClosed.
BUG=54939
TEST=unittests
Review URL: http://codereview.chromium.org/3308025
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@59398 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r-- | chrome/browser/media_uitest.cc | 42 | ||||
-rw-r--r-- | media/audio/audio_output_controller.cc | 28 | ||||
-rw-r--r-- | media/audio/audio_output_controller.h | 4 |
3 files changed, 50 insertions, 24 deletions
diff --git a/chrome/browser/media_uitest.cc b/chrome/browser/media_uitest.cc index 1713e5f..8f62a2a 100644 --- a/chrome/browser/media_uitest.cc +++ b/chrome/browser/media_uitest.cc @@ -48,38 +48,56 @@ class MediaTest : public UITest { } }; -// Crashes, see http://crbug.com/54939 -TEST_F(MediaTest, DISABLED_VideoBearTheora) { +#if defined(OS_WIN) + +// Tests may fail on windows: http://crbug.com/55477 +#define MAYBE_VideoBearTheora FLAKY_VideoBearTheora +#define MAYBE_VideoBearSilentTheora FLAKY_VideoBearSilentTheora +#define MAYBE_VideoBearWebm FLAKY_VideoBearWebm +#define MAYBE_VideoBearSilentWebm FLAKY_VideoBearSilentWebm +#define MAYBE_VideoBearMp4 FLAKY_VideoBearMp4 +#define MAYBE_VideoBearSilentMp4 FLAKY_VideoBearSilentMp4 +#define MAYBE_MediaUILayoutTest FLAKY_MediaUILayoutTest + +#else + +#define MAYBE_VideoBearTheora VideoBearTheora +#define MAYBE_VideoBearSilentTheora VideoBearSilentTheora +#define MAYBE_VideoBearWebm VideoBearWebm +#define MAYBE_VideoBearSilentWebm VideoBearSilentWebm +#define MAYBE_VideoBearMp4 VideoBearMp4 +#define MAYBE_VideoBearSilentMp4 VideoBearSilentMp4 +#define MAYBE_MediaUILayoutTest MediaUILayoutTest + +#endif + +TEST_F(MediaTest, MAYBE_VideoBearTheora) { PlayVideo("bear.ogv"); } -// Crashes, see http://crbug.com/54939 -TEST_F(MediaTest, DISABLED_VideoBearSilentTheora) { +TEST_F(MediaTest, MAYBE_VideoBearSilentTheora) { PlayVideo("bear_silent.ogv"); } -// Crashes, see http://crbug.com/54939 -TEST_F(MediaTest, DISABLED_VideoBearWebm) { +TEST_F(MediaTest, MAYBE_VideoBearWebm) { PlayVideo("bear.webm"); } -// Crashes, see http://crbug.com/54939 -TEST_F(MediaTest, DISABLED_VideoBearSilentWebm) { +TEST_F(MediaTest, MAYBE_VideoBearSilentWebm) { PlayVideo("bear_silent.webm"); } #if defined(GOOGLE_CHROME_BUILD) || defined(USE_PROPRIETARY_CODECS) -TEST_F(MediaTest, VideoBearMp4) { +TEST_F(MediaTest, MAYBE_VideoBearMp4) { PlayVideo("bear.mp4"); } -TEST_F(MediaTest, VideoBearSilentMp4) { +TEST_F(MediaTest, MAYBE_VideoBearSilentMp4) { PlayVideo("bear_silent.mp4"); } #endif -// Crashes, see http://crbug.com/54939 -TEST_F(UILayoutTest, DISABLED_MediaUILayoutTest) { +TEST_F(UILayoutTest, MAYBE_MediaUILayoutTest) { static const char* kResources[] = { "content", "media-file.js", diff --git a/media/audio/audio_output_controller.cc b/media/audio/audio_output_controller.cc index 66c91a3..6ff02aa 100644 --- a/media/audio/audio_output_controller.cc +++ b/media/audio/audio_output_controller.cc @@ -187,28 +187,28 @@ void AudioOutputController::DoCreate(AudioParameters params, void AudioOutputController::DoPlay() { DCHECK_EQ(message_loop_, MessageLoop::current()); - State old_state; - // Update the |state_| to kPlaying. { AutoLock auto_lock(lock_); // We can start from created or paused state. if (state_ != kCreated && state_ != kPaused) return; - old_state = state_; state_ = kPlaying; } // We start the AudioOutputStream lazily. stream_->Start(this); - // Tell the event handler that we are now playing. - handler_->OnPlaying(this); + { + AutoLock auto_lock(lock_); + // Tell the event handler that we are now playing. + if (state_ != kClosed) + handler_->OnPlaying(this); + } } void AudioOutputController::DoPause() { DCHECK_EQ(message_loop_, MessageLoop::current()); - // Sets the |state_| to kPaused so we don't draw more audio data. { AutoLock auto_lock(lock_); // We can pause from started state. @@ -227,7 +227,11 @@ void AudioOutputController::DoPause() { sync_reader_->UpdatePendingBytes(kPauseMark); } - handler_->OnPaused(this); + { + AutoLock auto_lock(lock_); + if (state_ != kClosed) + handler_->OnPaused(this); + } } void AudioOutputController::DoFlush() { @@ -274,7 +278,11 @@ void AudioOutputController::DoSetVolume(double volume) { void AudioOutputController::DoReportError(int code) { DCHECK_EQ(message_loop_, MessageLoop::current()); - handler_->OnError(this, code); + { + AutoLock auto_lock(lock_); + if (state_ != kClosed) + handler_->OnError(this, code); + } } uint32 AudioOutputController::OnMoreData(AudioOutputStream* stream, @@ -335,10 +343,6 @@ void AudioOutputController::SubmitOnMoreData_Locked() { uint32 pending_bytes = hardware_pending_bytes_ + push_source_.UnProcessedBytes(); - // If we need more data then call the event handler to ask for more data. - // It is okay that we don't lock in this block because the parameters are - // correct and in the worst case we are just asking more data than needed. - AutoUnlock auto_unlock(lock_); handler_->OnMoreData(this, timestamp, pending_bytes); } diff --git a/media/audio/audio_output_controller.h b/media/audio/audio_output_controller.h index c260e58..e9ed321 100644 --- a/media/audio/audio_output_controller.h +++ b/media/audio/audio_output_controller.h @@ -175,6 +175,7 @@ class AudioOutputController // Helper method to submit a OnMoreData() call to the event handler. void SubmitOnMoreData_Locked(); + // |handler_| may be called only if |state_| is not kClosed. EventHandler* handler_; AudioOutputStream* stream_; @@ -188,6 +189,9 @@ class AudioOutputController uint32 hardware_pending_bytes_; base::Time last_callback_time_; + + // The |lock_| must be acquired whenever we access |state_| or call + // |handler_|. Lock lock_; // PushSource role is to buffer and it's only used in regular latency mode. |