summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorsergeyu@chromium.org <sergeyu@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2010-09-14 17:58:16 +0000
committersergeyu@chromium.org <sergeyu@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2010-09-14 17:58:16 +0000
commitc499d08ff59eae8bfae79ed3ea2d21178790a5c7 (patch)
tree26f83da51be78fcba29349c3b0edda38eba8afef
parent1d95a8f0e313c9afbfd56fa0c007a16ad3881ba9 (diff)
downloadchromium_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.cc42
-rw-r--r--media/audio/audio_output_controller.cc28
-rw-r--r--media/audio/audio_output_controller.h4
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.