summaryrefslogtreecommitdiffstats
path: root/chrome
diff options
context:
space:
mode:
authorjabdelmalek@google.com <jabdelmalek@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2008-08-13 01:33:39 +0000
committerjabdelmalek@google.com <jabdelmalek@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2008-08-13 01:33:39 +0000
commit536be10ea126937cc05f6e946e1cd8ec169689ac (patch)
treed0f0b2b7b73cac6831de8f79de6f69ef56a5b134 /chrome
parentf4ed29583452e1e1d62c05aa886586956f8d2cb9 (diff)
downloadchromium_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.cc59
-rw-r--r--chrome/common/ipc_sync_channel.h5
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);