Merge "Avoid deadlock in OMX::freeNode by making sure OMXCodecObserver does not hold the last reference of OMXCodec object" into honeycomb
This commit is contained in:
@@ -70,8 +70,6 @@ struct OMXCodec : public MediaSource,
|
|||||||
|
|
||||||
virtual status_t pause();
|
virtual status_t pause();
|
||||||
|
|
||||||
void on_message(const omx_message &msg);
|
|
||||||
|
|
||||||
// from MediaBufferObserver
|
// from MediaBufferObserver
|
||||||
virtual void signalBufferReturned(MediaBuffer *buffer);
|
virtual void signalBufferReturned(MediaBuffer *buffer);
|
||||||
|
|
||||||
@@ -79,6 +77,13 @@ protected:
|
|||||||
virtual ~OMXCodec();
|
virtual ~OMXCodec();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
|
// Make sure mLock is accessible to OMXCodecObserver
|
||||||
|
friend class OMXCodecObserver;
|
||||||
|
|
||||||
|
// Call this with mLock hold
|
||||||
|
void on_message(const omx_message &msg);
|
||||||
|
|
||||||
enum State {
|
enum State {
|
||||||
DEAD,
|
DEAD,
|
||||||
LOADED,
|
LOADED,
|
||||||
|
|||||||
@@ -235,7 +235,9 @@ struct OMXCodecObserver : public BnOMXObserver {
|
|||||||
sp<OMXCodec> codec = mTarget.promote();
|
sp<OMXCodec> codec = mTarget.promote();
|
||||||
|
|
||||||
if (codec.get() != NULL) {
|
if (codec.get() != NULL) {
|
||||||
|
Mutex::Autolock autoLock(codec->mLock);
|
||||||
codec->on_message(msg);
|
codec->on_message(msg);
|
||||||
|
codec.clear();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1845,8 +1847,6 @@ OMXCodec::BufferInfo* OMXCodec::dequeueBufferFromNativeWindow() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void OMXCodec::on_message(const omx_message &msg) {
|
void OMXCodec::on_message(const omx_message &msg) {
|
||||||
Mutex::Autolock autoLock(mLock);
|
|
||||||
|
|
||||||
switch (msg.type) {
|
switch (msg.type) {
|
||||||
case omx_message::EVENT:
|
case omx_message::EVENT:
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -86,6 +86,9 @@ OMX::CallbackDispatcher::~CallbackDispatcher() {
|
|||||||
mQueueChanged.signal();
|
mQueueChanged.signal();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Don't call join on myself
|
||||||
|
CHECK(mThread != pthread_self());
|
||||||
|
|
||||||
void *dummy;
|
void *dummy;
|
||||||
pthread_join(mThread, &dummy);
|
pthread_join(mThread, &dummy);
|
||||||
}
|
}
|
||||||
@@ -246,9 +249,12 @@ status_t OMX::freeNode(node_id node) {
|
|||||||
|
|
||||||
status_t err = instance->freeNode(mMaster);
|
status_t err = instance->freeNode(mMaster);
|
||||||
|
|
||||||
index = mDispatchers.indexOfKey(node);
|
{
|
||||||
CHECK(index >= 0);
|
Mutex::Autolock autoLock(mLock);
|
||||||
mDispatchers.removeItemsAt(index);
|
index = mDispatchers.indexOfKey(node);
|
||||||
|
CHECK(index >= 0);
|
||||||
|
mDispatchers.removeItemsAt(index);
|
||||||
|
}
|
||||||
|
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user