mirror of https://gerrit.osmocom.org/libosmocore
add contrib/talloc_count.sh
When a user reports a memory leak with a talloc report, this script is useful to quickly get a handle of what is being leaked. The alternative is eyeballing the talloc report for a very long time. Change-Id: I5b3242dd6e0649925ac6abfd1e96625c682b8934
This commit is contained in:
parent
96a8b559bb
commit
6939169de9
|
@ -0,0 +1,52 @@
|
||||||
|
#!/bin/sh
|
||||||
|
#
|
||||||
|
# Print a summary of how often each named object appears in a talloc report.
|
||||||
|
#
|
||||||
|
# usage:
|
||||||
|
# talloc_count.sh my_talloc_report.txt
|
||||||
|
# or:
|
||||||
|
# osmo_interact_vty.py -p 4242 -c 'show talloc-context application full' | talloc_count.sh
|
||||||
|
#
|
||||||
|
# produces output like:
|
||||||
|
# 1 struct foo
|
||||||
|
# 1 struct log_info
|
||||||
|
# 1 struct log_info_cat
|
||||||
|
# 21 msgb
|
||||||
|
# 1391 SCCP-SCOC(N)[N]
|
||||||
|
# 1402 struct osmo_fsm_inst
|
||||||
|
# [...]
|
||||||
|
|
||||||
|
f="$1"
|
||||||
|
|
||||||
|
tmpdir="$(mktemp -d)"
|
||||||
|
trap "rm -rf \"$tmpdir\"" EXIT
|
||||||
|
|
||||||
|
# without input file, read stdin
|
||||||
|
if [ "x$f" = "x" ]; then
|
||||||
|
f="$tmpdir/input"
|
||||||
|
cat > $f
|
||||||
|
fi
|
||||||
|
|
||||||
|
mangled="$tmpdir/mangled"
|
||||||
|
grep contains "$f" \
|
||||||
|
| sed 's/[ \t]*contains.*//' \
|
||||||
|
| sed 's/^[ \t]*//' \
|
||||||
|
| sed 's/[ \t][ \t]*/ /g' \
|
||||||
|
| grep -v '^$' \
|
||||||
|
| grep -v '^[0-9]\+$' \
|
||||||
|
| sed 's/0x[0-9a-fA-F]\+/N/g' \
|
||||||
|
| sed 's/[0-9]\+/N/g' \
|
||||||
|
| sort \
|
||||||
|
> "$mangled"
|
||||||
|
|
||||||
|
count() {
|
||||||
|
name="$1"
|
||||||
|
nr="$(grep -Fx "$name" "$mangled" | wc -l)"
|
||||||
|
printf "%6d $name\\n" $nr
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
cat "$mangled" | uniq | while read type; do
|
||||||
|
count "$type"
|
||||||
|
done
|
||||||
|
} | sort -h
|
Loading…
Reference in New Issue