Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1071)

Unified Diff: content/renderer/pepper/pepper_media_stream_audio_track_host.cc

Issue 430943004: Return from |Configure()| asynchronously, and allow |InitBuffers()| to return errors. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@pepper-mediastream-duration
Patch Set: Rebase. Created 6 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: content/renderer/pepper/pepper_media_stream_audio_track_host.cc
diff --git a/content/renderer/pepper/pepper_media_stream_audio_track_host.cc b/content/renderer/pepper/pepper_media_stream_audio_track_host.cc
index 3069988773563454c958d8eb78e19e2d6786a1c6..e8340414827578e1f52be12d4e55c9f88242ddaa 100644
--- a/content/renderer/pepper/pepper_media_stream_audio_track_host.cc
+++ b/content/renderer/pepper/pepper_media_stream_audio_track_host.cc
@@ -16,6 +16,7 @@
#include "ppapi/c/ppb_audio_buffer.h"
#include "ppapi/host/dispatch_host_message.h"
#include "ppapi/host/host_message_context.h"
+#include "ppapi/host/ppapi_host.h"
#include "ppapi/proxy/ppapi_messages.h"
#include "ppapi/shared_impl/media_stream_audio_track_shared.h"
#include "ppapi/shared_impl/media_stream_buffer.h"
@@ -88,9 +89,16 @@ void PepperMediaStreamAudioTrackHost::AudioSink::EnqueueBuffer(int32_t index) {
buffers_.push_back(index);
}
-void PepperMediaStreamAudioTrackHost::AudioSink::Configure(
- int32_t number_of_buffers, int32_t duration) {
+int32_t PepperMediaStreamAudioTrackHost::AudioSink::Configure(
+ int32_t number_of_buffers, int32_t duration,
+ const ppapi::host::ReplyMessageContext& context) {
DCHECK_EQ(main_message_loop_proxy_, base::MessageLoopProxy::current());
+
+ if (pending_configure_reply_.is_valid()) {
+ return PP_ERROR_INPROGRESS;
+ }
+ pending_configure_reply_ = context;
+
bool changed = false;
if (number_of_buffers != number_of_buffers_)
changed = true;
@@ -100,9 +108,25 @@ void PepperMediaStreamAudioTrackHost::AudioSink::Configure(
}
number_of_buffers_ = number_of_buffers;
- // Initialize later in OnSetFormat if bytes_per_second_ is not know yet.
- if (changed && bytes_per_second_ > 0 && bytes_per_frame_ > 0)
- InitBuffers();
+ if (changed) {
+ // Initialize later in OnSetFormat if bytes_per_second_ is not known yet.
+ if (bytes_per_second_ > 0 && bytes_per_frame_ > 0)
+ InitBuffers();
+ } else {
+ SendConfigureReply(PP_OK);
+ }
+ return PP_OK_COMPLETIONPENDING;
+}
+
+void PepperMediaStreamAudioTrackHost::AudioSink::SendConfigureReply(
+ int32_t result) {
+ if (pending_configure_reply_.is_valid()) {
+ pending_configure_reply_.params.set_result(result);
+ host_->host()->SendReply(
+ pending_configure_reply_,
+ PpapiPluginMsg_MediaStreamAudioTrack_ConfigureReply());
+ pending_configure_reply_ = ppapi::host::ReplyMessageContext();
+ }
}
void PepperMediaStreamAudioTrackHost::AudioSink::SetFormatOnMainThread(
@@ -140,8 +164,10 @@ void PepperMediaStreamAudioTrackHost::AudioSink::InitBuffers() {
bool result = host_->InitBuffers(number_of_buffers_,
buffer_size.ValueOrDie(),
kRead);
- // TODO(penghuang): Send PP_ERROR_NOMEMORY to plugin.
- CHECK(result);
+ if (!result) {
+ SendConfigureReply(PP_ERROR_NOMEMORY);
+ return;
+ }
// Fill the |buffers_|, so the audio thread can continue receiving audio data.
base::AutoLock lock(lock_);
@@ -151,6 +177,8 @@ void PepperMediaStreamAudioTrackHost::AudioSink::InitBuffers() {
DCHECK_GE(index, 0);
buffers_.push_back(index);
}
+
+ SendConfigureReply(PP_OK);
}
void PepperMediaStreamAudioTrackHost::AudioSink::
@@ -320,10 +348,8 @@ int32_t PepperMediaStreamAudioTrackHost::OnHostMsgConfigure(
int32_t buffers = attributes.buffers
? std::min(kMaxNumberOfBuffers, attributes.buffers)
: kDefaultNumberOfBuffers;
- audio_sink_.Configure(buffers, attributes.duration);
-
- context->reply_msg = PpapiPluginMsg_MediaStreamAudioTrack_ConfigureReply();
- return PP_OK;
+ return audio_sink_.Configure(buffers, attributes.duration,
+ context->MakeReplyMessageContext());
}
void PepperMediaStreamAudioTrackHost::OnClose() {
@@ -331,6 +357,7 @@ void PepperMediaStreamAudioTrackHost::OnClose() {
MediaStreamAudioSink::RemoveFromAudioTrack(&audio_sink_, track_);
connected_ = false;
}
+ audio_sink_.SendConfigureReply(PP_ERROR_ABORTED);
}
void PepperMediaStreamAudioTrackHost::OnNewBufferEnqueued() {
« no previous file with comments | « content/renderer/pepper/pepper_media_stream_audio_track_host.h ('k') | ppapi/tests/test_media_stream_audio_track.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698