diff options
author | Jesse Natalie <jenatali@microsoft.com> | 2022-04-26 12:36:09 -0700 |
---|---|---|
committer | Marge Bot <emma+marge@anholt.net> | 2022-05-02 16:58:20 +0000 |
commit | 0bcb5f919ed5c6ecac7395fd06c6bc71601dbd86 (patch) | |
tree | 3650b645ec677acced1d0a21d798d3e13fa5366b | |
parent | 53a94fbdd57acbbe2bc745901cbfeca968e25273 (diff) | |
download | mesa-0bcb5f919ed5c6ecac7395fd06c6bc71601dbd86.tar.gz mesa-0bcb5f919ed5c6ecac7395fd06c6bc71601dbd86.tar.bz2 mesa-0bcb5f919ed5c6ecac7395fd06c6bc71601dbd86.zip |
bin: Add a script for filtering/sorting refcount logs
Reviewed-by: Sil Vilerino <sivileri@microsoft.com>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/16182>
-rw-r--r-- | bin/refcnt-log-helper.py | 78 |
1 files changed, 78 insertions, 0 deletions
diff --git a/bin/refcnt-log-helper.py b/bin/refcnt-log-helper.py new file mode 100644 index 00000000000..d703f023389 --- /dev/null +++ b/bin/refcnt-log-helper.py @@ -0,0 +1,78 @@ +#!/usr/bin/env python3 +# Copyright © Microsoft Corporation +# +# Permission is hereby granted, free of charge, to any person obtaining a +# copy of this software and associated documentation files (the "Software"), +# to deal in the Software without restriction, including without limitation +# the rights to use, copy, modify, merge, publish, distribute, sublicense, +# and/or sell copies of the Software, and to permit persons to whom the +# Software is furnished to do so, subject to the following conditions: +# +# The above copyright notice and this permission notice (including the next +# paragraph) shall be included in all copies or substantial portions of the +# Software. +# +# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL +# THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING +# FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS +# IN THE SOFTWARE. + +import argparse + +# Take a log file produced by GALLIUM_REFCNT_LOG, filter it to the objects that +# weren't destroyed by the end of the log, and write the results out sorted. +# Strips stacks by default to prevent OOM. Could probably be rewritten to walk +# the file twice to preserve stacks without OOM, but this was the easy way. +def main(): + parser = argparse.ArgumentParser() + parser.add_argument('--input', + action='store', + required=True, + help='path to file containing refcount log') + parser.add_argument('--output', + action='store', + required=True, + help='path to trimmed log') + parser.add_argument('--filter', + help='object type filter') + parser.add_argument('--keep-stacks', + help='keep stacks, otherwise only headers') + args = parser.parse_args() + + objects = {} + + with open(args.input) as in_file: + stack = [] + cur_object = '' + + for line in in_file: + if line[0] == '<': + + parts = line.split(' ') + prev_object = cur_object + cur_object = parts[1] + if parts[3].strip() == 'Destroy': + if cur_object in objects: + del objects[cur_object] + else: + if parts[3].strip() == 'Create': + if (not args.filter) or (args.filter in parts[0]): + objects[cur_object] = [] + if prev_object in objects: + objects[prev_object] += stack + + stack = [line] + elif args.keep_stacks: + stack += line + + with open(args.output, 'wt') as out_file: + for stack in objects.values(): + for stack_line in stack: + out_file.write(stack_line) + + +if __name__ == '__main__': + main() |