diff options
author | jabdelmalek@google.com <jabdelmalek@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2008-08-13 01:33:39 +0000 |
---|---|---|
committer | jabdelmalek@google.com <jabdelmalek@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2008-08-13 01:33:39 +0000 |
commit | 536be10ea126937cc05f6e946e1cd8ec169689ac (patch) | |
tree | d0f0b2b7b73cac6831de8f79de6f69ef56a5b134 /chrome | |
parent | f4ed29583452e1e1d62c05aa886586956f8d2cb9 (diff) | |
download | chromium_src-536be10ea126937cc05f6e946e1cd8ec169689ac.zip chromium_src-536be10ea126937cc05f6e946e1cd8ec169689ac.tar.gz chromium_src-536be10ea126937cc05f6e946e1cd8ec169689ac.tar.bz2 |
IPCSyncChannel cleanup:
-remove reply_lock_ since received_replies_ was only being used on the IPC thread
-stop using nested locks
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@773 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome')
-rw-r--r-- | chrome/common/ipc_sync_channel.cc | 59 | ||||
-rw-r--r-- | chrome/common/ipc_sync_channel.h | 5 |
2 files changed, 26 insertions, 38 deletions
diff --git a/chrome/common/ipc_sync_channel.cc b/chrome/common/ipc_sync_channel.cc index e29d330..25a22c8 100644 --- a/chrome/common/ipc_sync_channel.cc +++ b/chrome/common/ipc_sync_channel.cc @@ -99,8 +99,6 @@ class SyncChannel::ReceivedSyncMsgQueue : } void QueueReply(const Message &msg, SyncChannel::SyncContext* context) { - AutoLock auto_lock(reply_lock_); - received_replies_.push_back(Reply(new Message(msg), context)); } @@ -151,13 +149,7 @@ class SyncChannel::ReceivedSyncMsgQueue : // Called on the IPC thread when the current sync Send() call is unblocked. void OnUnblock() { - bool queued_replies = false; - { - AutoLock auto_lock(reply_lock_); - queued_replies = !received_replies_.empty(); - } - - if (queued_replies) { + if (!received_replies_.empty()) { MessageLoop::current()->PostTask(FROM_HERE, NewRunnableMethod( this, &ReceivedSyncMsgQueue::DispatchReplies)); } @@ -191,8 +183,6 @@ class SyncChannel::ReceivedSyncMsgQueue : // Called on the ipc thread to check if we can unblock any current Send() // calls based on a queued reply. void DispatchReplies() { - AutoLock auto_lock(reply_lock_); - for (size_t i = 0; i < received_replies_.size(); ++i) { Message* message = received_replies_[i].message; if (received_replies_[i].context->UnblockListener(message)) { @@ -235,7 +225,6 @@ class SyncChannel::ReceivedSyncMsgQueue : }; std::vector<Reply> received_replies_; - Lock reply_lock_; }; @@ -300,33 +289,39 @@ bool SyncChannel::SyncContext::UnblockListener(const Message* msg) { bool rv = false; HANDLE reply_event = NULL; { - AutoLock auto_lock(deserializers_lock_); if (channel_closed_) { // The channel is closed, or we couldn't connect, so cancel all Send() // calls. reply_deserialize_result_ = false; - if (!deserializers_.empty()) { - reply_event = deserializers_.top().reply_event; - PopDeserializer(false); + { + AutoLock auto_lock(deserializers_lock_); + if (!deserializers_.empty()) + reply_event = deserializers_.top().reply_event; } - } else { - if (deserializers_.empty()) - return false; - if (!IPC::SyncMessage::IsMessageReplyTo(*msg, deserializers_.top().id)) - return false; + if (reply_event) + PopDeserializer(false); + } else { + { + AutoLock auto_lock(deserializers_lock_); + if (deserializers_.empty()) + return false; + + if (!IPC::SyncMessage::IsMessageReplyTo(*msg, deserializers_.top().id)) + return false; + + rv = true; + if (msg->is_reply_error()) { + reply_deserialize_result_ = false; + } else { + reply_deserialize_result_ = deserializers_.top().deserializer-> + SerializeOutputParameters(*msg); + } - rv = true; - if (msg->is_reply_error()) { - reply_deserialize_result_ = false; - } else { - reply_deserialize_result_ = - deserializers_.top().deserializer->SerializeOutputParameters(*msg); + // Can't CloseHandle the event just yet, since doing so might cause the + // Wait call above to never return. + reply_event = deserializers_.top().reply_event; } - - // Can't CloseHandle the event just yet, since doing so might cause the - // Wait call above to never return. - reply_event = deserializers_.top().reply_event; PopDeserializer(false); } } @@ -456,7 +451,6 @@ bool SyncChannel::SendWithTimeout(IPC::Message* message, int timeout_ms) { if (result == WAIT_OBJECT_0 || result == WAIT_TIMEOUT) { // Process shut down before we can get a reply to a synchronous message, // or timed-out. Unblock the thread. - AutoLock auto_lock(*(sync_context()->deserializers_lock())); sync_context()->PopDeserializer(true); return false; } @@ -494,7 +488,6 @@ bool SyncChannel::SendWithTimeout(IPC::Message* message, int timeout_ms) { timeout_ms -= static_cast<int>(time_delta.InMilliseconds()); if (timeout_ms <= 0) { // We timed-out while processing messages. - AutoLock auto_lock(*(sync_context()->deserializers_lock())); sync_context()->PopDeserializer(true); return false; } diff --git a/chrome/common/ipc_sync_channel.h b/chrome/common/ipc_sync_channel.h index fa3566e..280b097 100644 --- a/chrome/common/ipc_sync_channel.h +++ b/chrome/common/ipc_sync_channel.h @@ -102,13 +102,8 @@ class SyncChannel : public ChannelProxy { // Otherwise the function returns false. bool UnblockListener(const Message* msg); - // Cleanly remove the top deserializer (and throw it away). - // You need to acquire the deserializers_lock before calling this. void PopDeserializer(bool close_reply_event); - - // Returns the lock that should be acquired before calling PopDeserializer. - Lock* deserializers_lock() { return &deserializers_lock_; } private: void OnMessageReceived(const Message& msg); |