[Author Prev][Author Next][Thread Prev][Thread Next][Author Index][Thread Index]

[or-cvs] r18757: {torctl} Fix refcount-related WARNs and bugs and also WARN on traceba (torctl/trunk/python/TorCtl)



Author: mikeperry
Date: 2009-03-03 03:39:24 -0500 (Tue, 03 Mar 2009)
New Revision: 18757

Modified:
   torctl/trunk/python/TorCtl/PathSupport.py
   torctl/trunk/python/TorCtl/StatsSupport.py
   torctl/trunk/python/TorCtl/TorCtl.py
Log:

Fix refcount-related WARNs and bugs and also WARN on traceback 
seen by Roger instead of crashing.



Modified: torctl/trunk/python/TorCtl/PathSupport.py
===================================================================
--- torctl/trunk/python/TorCtl/PathSupport.py	2009-03-03 06:52:19 UTC (rev 18756)
+++ torctl/trunk/python/TorCtl/PathSupport.py	2009-03-03 08:39:24 UTC (rev 18757)
@@ -826,6 +826,7 @@
         ext = self.entry_gen.generate()
     for r in path:
       r.refcount += 1
+      plog("DEBUG", "Circ refcount "+str(r.refcount)+" for "+r.idhex)
     return path
 
 # TODO: Implement example manager.
@@ -1069,6 +1070,10 @@
       e = self.consensus.routers[self.exit_id[1:]]
       plog("NOTICE", "Requested downed exit "+str(self.exit_id)+" (bw: "+str(e.bw)+", flags: "+str(e.flags)+")")
       self.bad_restrictions = True
+    elif self.consensus.routers[self.exit_id[1:]].deleted:
+      e = self.consensus.routers[self.exit_id[1:]]
+      plog("NOTICE", "Requested deleted exit "+str(self.exit_id)+" (bw: "+str(e.bw)+", flags: "+str(e.flags)+", Down: "+str(e.down)+", ref: "+str(e.refcount)+")")
+      self.bad_restrictions = True
     else:
       self.exit_rstr.add_restriction(IdHexRestriction(self.exit_id))
       try:
@@ -1323,15 +1328,20 @@
         self.last_exit = None
         # Kill this stream
         plog("NOTICE", "Closing impossible stream "+str(stream.strm_id)+" ("+str(e)+")")
-        self.c.close_stream(stream.strm_id, "4") # END_STREAM_REASON_EXITPOLICY
+        try:
+          self.c.close_stream(stream.strm_id, "4") # END_STREAM_REASON_EXITPOLICY
+        except TorCtl.ErrorReply, e:
+          plog("WARN", "Error closing stream: "+str(e))
         return
       except TorCtl.ErrorReply, e:
         plog("WARN", "Error building circ: "+str(e.args))
         self.last_exit = None
         # Kill this stream
         plog("NOTICE", "Closing stream "+str(stream.strm_id))
-        # END_STREAM_REASON_DESTROY
-        self.c.close_stream(stream.strm_id, "5") 
+        try:
+          self.c.close_stream(stream.strm_id, "5") # END_STREAM_REASON_DESTROY
+        except TorCtl.ErrorReply, e:
+          plog("WARN", "Error closing stream: "+str(e))
         return
       for u in unattached_streams:
         plog("DEBUG",
@@ -1358,6 +1368,7 @@
       circ = self.circuits[c.circ_id]
       for r in circ.path:
         r.refcount -= 1
+        plog("DEBUG", "Close refcount "+str(r.refcount)+" for "+r.idhex)
         if r.deleted and r.refcount == 0:
           # XXX: This shouldn't happen with StatsRouters.. 
           if r.__class__.__name__ == "StatsRouter":

Modified: torctl/trunk/python/TorCtl/StatsSupport.py
===================================================================
--- torctl/trunk/python/TorCtl/StatsSupport.py	2009-03-03 06:52:19 UTC (rev 18756)
+++ torctl/trunk/python/TorCtl/StatsSupport.py	2009-03-03 08:39:24 UTC (rev 18757)
@@ -196,6 +196,7 @@
     # StatsRouters should not be destroyed when Tor forgets about them
     # Give them an extra refcount:
     self.refcount += 1
+    plog("DEBUG", "Stats refcount "+str(self.refcount)+" for "+self.idhex)
   
   def reset(self):
     "Reset all stats on this Router"

Modified: torctl/trunk/python/TorCtl/TorCtl.py
===================================================================
--- torctl/trunk/python/TorCtl/TorCtl.py	2009-03-03 06:52:19 UTC (rev 18756)
+++ torctl/trunk/python/TorCtl/TorCtl.py	2009-03-03 08:39:24 UTC (rev 18757)
@@ -351,9 +351,11 @@
     'new' """
     if self.idhex != new.idhex:
       plog("ERROR", "Update of router "+self.nickname+"changes idhex!")
+    plog("DEBUG", "Updating refcount "+str(self.refcount)+" for "+self.idhex)
     for i in new.__dict__.iterkeys():
-      if i == "refcount": pass
+      if i == "refcount": continue
       self.__dict__[i] = new.__dict__[i]
+    plog("DEBUG", "Updated refcount "+str(self.refcount)+" for "+self.idhex)
 
   def will_exit_to(self, ip, port):
     """ Check the entire exitpolicy to see if the router will allow
@@ -1157,6 +1159,10 @@
     deleted =  filter(lambda r: r.deleted, list)
     for d in deleted:
       plog("WARN", "Router "+d.idhex+" still present but is deleted. Down: "+str(d.down)+", flags: "+str(d.flags)+", bw: "+str(d.bw))
+
+    zero =  filter(lambda r: r.refcount == 0 and r.__class__.__name__ == "StatsRouter", list)
+    for d in zero:
+      plog("WARN", "Router "+d.idhex+" has refcount 0. Del:"+str(d.deleted)+", Down: "+str(d.down)+", flags: "+str(d.flags)+", bw: "+str(d.bw))
  
   def _update_consensus(self, nslist):
     self.ns_map = {}
@@ -1202,6 +1208,8 @@
       for i in xrange(len(self.sorted_r)): self.sorted_r[i].list_rank = i
     plog("DEBUG", "Read " + str(len(d.idlist))+" ND => " 
        + str(len(self.sorted_r)) + " routers. Update: "+str(update))
+    # XXX: Verification only. Can be removed.
+    self._sanity_check(self.sorted_r)
     return update
 
   def current_consensus(self):