summaryrefslogtreecommitdiff
path: root/java/src/IceInternal/Connection.java
diff options
context:
space:
mode:
authorMark Spruiell <mes@zeroc.com>2002-11-28 01:14:59 +0000
committerMark Spruiell <mes@zeroc.com>2002-11-28 01:14:59 +0000
commitb17f71d806a30507c279691f751b5372dc81041d (patch)
tree6b4c4728c11f503ac02050c43a5c35c09212b47d /java/src/IceInternal/Connection.java
parentdocu fixes (diff)
downloadice-b17f71d806a30507c279691f751b5372dc81041d.tar.bz2
ice-b17f71d806a30507c279691f751b5372dc81041d.tar.xz
ice-b17f71d806a30507c279691f751b5372dc81041d.zip
fixing potential deadlock with ObjectAdapter
Diffstat (limited to 'java/src/IceInternal/Connection.java')
-rw-r--r--java/src/IceInternal/Connection.java37
1 files changed, 29 insertions, 8 deletions
diff --git a/java/src/IceInternal/Connection.java b/java/src/IceInternal/Connection.java
index 9a9070265eb..fa44610a7aa 100644
--- a/java/src/IceInternal/Connection.java
+++ b/java/src/IceInternal/Connection.java
@@ -724,7 +724,8 @@ public final class Connection extends EventHandler
}
}
- public String toString()
+ public String
+ toString()
{
return _transceiver.toString();
}
@@ -752,6 +753,7 @@ public final class Connection extends EventHandler
{
assert(_usageCount == 0);
assert(_state == StateClosed);
+ assert(_incomingCache == null);
//
// Destroy the EventHandler's stream, so that its buffer
@@ -906,7 +908,14 @@ public final class Connection extends EventHandler
registerWithPool();
}
unregisterWithPool();
- destroyIncoming();
+ //
+ // The cache of Incoming objects must be destroyed
+ // outside the synchronization on _mutex to avoid
+ // a potential deadlock with ObjectAdapter.
+ //
+ Incoming cache = _incomingCache;
+ _incomingCache = null;
+ new DestroyIncomingThread(cache).start();
break;
}
}
@@ -1037,15 +1046,27 @@ public final class Connection extends EventHandler
_incomingCache = in;
}
- private void
- destroyIncoming()
+ //
+ // Must be called outside of synchronization on _mutex.
+ //
+ private static class DestroyIncomingThread extends Thread
{
- Incoming in = _incomingCache;
- while(in != null)
+ DestroyIncomingThread(Incoming cache)
{
- in.destroy();
- in = in.next;
+ _cache = cache;
}
+
+ public void
+ run()
+ {
+ while(_cache != null)
+ {
+ _cache.destroy();
+ _cache = _cache.next;
+ }
+ }
+
+ private Incoming _cache;
}
private final Transceiver _transceiver;