Index: content/browser/media/android/browser_demuxer_android.cc |
diff --git a/content/browser/media/android/browser_demuxer_android.cc b/content/browser/media/android/browser_demuxer_android.cc |
index ed462032fdd7f6ad3d278996d36ae4009370ecca..5ba4fcb4a109fb2ff7976b82a28fa466c63bcfc0 100644 |
--- a/content/browser/media/android/browser_demuxer_android.cc |
+++ b/content/browser/media/android/browser_demuxer_android.cc |
@@ -4,7 +4,10 @@ |
#include "content/browser/media/android/browser_demuxer_android.h" |
+#include "base/command_line.h" |
#include "content/common/media/media_player_messages_android.h" |
+#include "media/base/android/mt/player.h" |
+#include "media/base/media_switches.h" |
namespace content { |
@@ -42,7 +45,7 @@ class BrowserDemuxerAndroid::Internal : public media::DemuxerAndroid { |
private: |
// Helper for DCHECKing that the ID is still registered. |
bool ClientIDExists() { |
- return demuxer_->demuxer_clients_.Lookup(demuxer_client_id_); |
+ return demuxer_->Lookup(demuxer_client_id_); |
} |
scoped_refptr<BrowserDemuxerAndroid> demuxer_; |
@@ -52,13 +55,21 @@ class BrowserDemuxerAndroid::Internal : public media::DemuxerAndroid { |
}; |
BrowserDemuxerAndroid::BrowserDemuxerAndroid() |
- : BrowserMessageFilter(MediaPlayerMsgStart) {} |
+ : BrowserMessageFilter(MediaPlayerMsgStart) { |
+ enable_media_player_v2_ = |
+ base::CommandLine::ForCurrentProcess()-> |
+ HasSwitch(switches::kEnableMediaPlayerV2); |
+ |
+} |
BrowserDemuxerAndroid::~BrowserDemuxerAndroid() {} |
void BrowserDemuxerAndroid::OverrideThreadForMessage( |
const IPC::Message& message, |
BrowserThread::ID* thread) { |
+ if (enable_media_player_v2_) |
+ return; // keep default BrowserThread::IO |
+ |
switch (message.type()) { |
case MediaPlayerHostMsg_DemuxerReady::ID: |
case MediaPlayerHostMsg_ReadFromDemuxerAck::ID: |
@@ -71,6 +82,31 @@ void BrowserDemuxerAndroid::OverrideThreadForMessage( |
bool BrowserDemuxerAndroid::OnMessageReceived(const IPC::Message& message) { |
bool handled = true; |
+ |
+ if (enable_media_player_v2_) { |
+ // Redirect demuxer messages to Media thread |
+ if (!media::mt::GetMediaTaskRunner()->BelongsToCurrentThread()) { |
+ media::mt::GetMediaTaskRunner()->PostTask( |
+ FROM_HERE, |
+ base::Bind( |
+ base::IgnoreResult(&BrowserDemuxerAndroid::OnMessageReceived), |
timav
2015/04/09 21:10:02
Posting the same method to another thread. Shall w
|
+ this, message)); |
+ |
+ switch(message.type()) { |
+ case MediaPlayerHostMsg_DemuxerReady::ID: |
+ case MediaPlayerHostMsg_ReadFromDemuxerAck::ID: |
+ case MediaPlayerHostMsg_DurationChanged::ID: |
+ case MediaPlayerHostMsg_DemuxerSeekDone::ID: |
+ handled = true; |
+ break; |
+ default: |
+ handled = false; |
+ break; |
+ } |
+ return handled; |
+ } |
+ } |
+ |
IPC_BEGIN_MESSAGE_MAP(BrowserDemuxerAndroid, message) |
IPC_MESSAGE_HANDLER(MediaPlayerHostMsg_DemuxerReady, OnDemuxerReady) |
IPC_MESSAGE_HANDLER(MediaPlayerHostMsg_ReadFromDemuxerAck, |
@@ -95,20 +131,29 @@ void BrowserDemuxerAndroid::AddDemuxerClient( |
media::DemuxerAndroidClient* client) { |
DVLOG(1) << __FUNCTION__ << " peer_pid=" << peer_pid() |
<< " demuxer_client_id=" << demuxer_client_id; |
+ |
+ base::AutoLock lock(lock_); |
demuxer_clients_.AddWithID(client, demuxer_client_id); |
} |
void BrowserDemuxerAndroid::RemoveDemuxerClient(int demuxer_client_id) { |
DVLOG(1) << __FUNCTION__ << " peer_pid=" << peer_pid() |
<< " demuxer_client_id=" << demuxer_client_id; |
+ |
+ base::AutoLock lock(lock_); |
demuxer_clients_.Remove(demuxer_client_id); |
} |
+media::DemuxerAndroidClient* |
+BrowserDemuxerAndroid::Lookup(int demuxer_client_id) { |
+ base::AutoLock lock(lock_); |
+ return demuxer_clients_.Lookup(demuxer_client_id); |
+} |
+ |
void BrowserDemuxerAndroid::OnDemuxerReady( |
int demuxer_client_id, |
const media::DemuxerConfigs& configs) { |
- media::DemuxerAndroidClient* client = |
- demuxer_clients_.Lookup(demuxer_client_id); |
+ media::DemuxerAndroidClient* client = Lookup(demuxer_client_id); |
if (client) |
client->OnDemuxerConfigsAvailable(configs); |
} |
@@ -116,8 +161,7 @@ void BrowserDemuxerAndroid::OnDemuxerReady( |
void BrowserDemuxerAndroid::OnReadFromDemuxerAck( |
int demuxer_client_id, |
const media::DemuxerData& data) { |
- media::DemuxerAndroidClient* client = |
- demuxer_clients_.Lookup(demuxer_client_id); |
+ media::DemuxerAndroidClient* client = Lookup(demuxer_client_id); |
if (client) |
client->OnDemuxerDataAvailable(data); |
} |
@@ -125,16 +169,14 @@ void BrowserDemuxerAndroid::OnReadFromDemuxerAck( |
void BrowserDemuxerAndroid::OnDemuxerSeekDone( |
int demuxer_client_id, |
const base::TimeDelta& actual_browser_seek_time) { |
- media::DemuxerAndroidClient* client = |
- demuxer_clients_.Lookup(demuxer_client_id); |
+ media::DemuxerAndroidClient* client = Lookup(demuxer_client_id); |
if (client) |
client->OnDemuxerSeekDone(actual_browser_seek_time); |
} |
void BrowserDemuxerAndroid::OnDurationChanged(int demuxer_client_id, |
const base::TimeDelta& duration) { |
- media::DemuxerAndroidClient* client = |
- demuxer_clients_.Lookup(demuxer_client_id); |
+ media::DemuxerAndroidClient* client = Lookup(demuxer_client_id); |
if (client) |
client->OnDemuxerDurationChanged(duration); |
} |