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

Unified Diff: ipc/ipc_channel_posix.cc

Issue 30133002: Fix posix IPC channel hanging problem. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: make new test pass Created 7 years, 1 month 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
« no previous file with comments | « no previous file | ipc/ipc_channel_posix_unittest.cc » ('j') | ipc/ipc_channel_posix_unittest.cc » ('J')
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: ipc/ipc_channel_posix.cc
diff --git a/ipc/ipc_channel_posix.cc b/ipc/ipc_channel_posix.cc
index a74178a694b99dbaf4e759e30e195461a29d30ef..bd3d4fef8a63b4317f0dd6dbd60930cec6b0fa16 100644
--- a/ipc/ipc_channel_posix.cc
+++ b/ipc/ipc_channel_posix.cc
@@ -31,6 +31,7 @@
#include "base/posix/global_descriptors.h"
#include "base/process/process_handle.h"
#include "base/rand_util.h"
+#include "base/run_loop.h"
#include "base/stl_util.h"
#include "base/strings/string_util.h"
#include "base/synchronization/lock.h"
@@ -522,7 +523,10 @@ bool Channel::ChannelImpl::Send(Message* message) {
message->TraceMessageBegin();
output_queue_.push(message);
if (!is_blocked_on_write_ && !waiting_connect_) {
- return ProcessOutgoingMessages();
+ if (!ProcessOutgoingMessages()) {
+ ClosePipeOnError();
+ return false;
+ }
}
return true;
@@ -707,7 +711,11 @@ bool Channel::ChannelImpl::AcceptConnection() {
// In server mode we will send a hello message when we receive one from a
// client.
waiting_connect_ = false;
- return ProcessOutgoingMessages();
+ if (!ProcessOutgoingMessages()) {
+ ClosePipeOnError();
+ return false;
+ }
+ return true;
} else if (mode_ & MODE_SERVER_FLAG) {
waiting_connect_ = true;
return true;
« no previous file with comments | « no previous file | ipc/ipc_channel_posix_unittest.cc » ('j') | ipc/ipc_channel_posix_unittest.cc » ('J')

Powered by Google App Engine
This is Rietveld 408576698