summaryrefslogtreecommitdiff
path: root/contrib/scripts
diff options
context:
space:
mode:
authorCorey Farrell <git@cfware.com>2014-07-13 21:57:00 +0000
committerCorey Farrell <git@cfware.com>2014-07-13 21:57:00 +0000
commitfcdc4ad0bf5ef3661e6cb1fa7abd487efb23e46c (patch)
tree1fee74bc3fb6a286f2b46033287f6271f0d7c4ea /contrib/scripts
parent3e245920d8063a6416ad542e9bb01b2c3f3b38df (diff)
astobj2: work around REF_DEBUG race which causes out of order log entries
* Update refcounter.py to use delta's to track the current reference count. * Use result from internal_ao2_ref to write old_refcount to refs_log. Review: https://reviewboard.asterisk.org/r/3756/ ........ Merged revisions 418504 from http://svn.asterisk.org/svn/asterisk/branches/1.8 ........ Merged revisions 418505 from http://svn.asterisk.org/svn/asterisk/branches/11 ........ Merged revisions 418506 from http://svn.asterisk.org/svn/asterisk/branches/12 git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@418507 65c4cc65-6c06-0410-ace0-fbb531ad65f3
Diffstat (limited to 'contrib/scripts')
-rwxr-xr-xcontrib/scripts/refcounter.py17
1 files changed, 11 insertions, 6 deletions
diff --git a/contrib/scripts/refcounter.py b/contrib/scripts/refcounter.py
index 3aad3530a..9bad4007c 100755
--- a/contrib/scripts/refcounter.py
+++ b/contrib/scripts/refcounter.py
@@ -79,10 +79,15 @@ def process_file(options):
obj = parsed_line['addr']
if obj not in current_objects:
- current_objects[obj] = []
- if options.skewed and 'constructor' not in parsed_line['state']:
- skewed_objects.append((obj, current_objects[obj]))
- current_objects[obj].append("[%s] %s:%s %s: %s %s - [%s]" % (
+ current_objects[obj] = {'log': [], 'curcount': 1,}
+ if 'constructor' not in parsed_line['state']:
+ current_objects[obj]['curcount'] = parsed_line['state']
+ if options.skewed:
+ skewed_objects.append((obj, current_objects[obj]))
+ else:
+ current_objects[obj]['curcount'] += int(parsed_line['delta'])
+
+ current_objects[obj]['log'].append("[%s] %s:%s %s: %s %s - [%s]" % (
parsed_line['thread_id'],
parsed_line['file'],
parsed_line['line'],
@@ -91,7 +96,7 @@ def process_file(options):
parsed_line['tag'],
parsed_line['state']))
- if 'destructor' in parsed_line['state']:
+ if current_objects[obj]['curcount'] == 0:
if options.normal:
finished_objects.append((obj, current_objects[obj]))
del current_objects[obj]
@@ -115,7 +120,7 @@ def print_objects(objects, prefix=""):
print "\n"
for obj in objects:
print "==== %s Object %s history ====" % (prefix, obj[0])
- for line in obj[1]:
+ for line in obj[1]['log']:
print line
print "\n"