scripts: Strip compiler suffixes in result scripts

This can be explicitly disabled with -x/--no-strip in the relevant
scripts, but stripping by default seems to be more useful for composing
results in higher-level scripts. It's better for the result names to be
consistent, even if they don't match the .o symbols exactly.

Note some scripts are unaffected:

- cov.py - gcov doesn't seem to have an option for getting the
  unstripped symbols, so we only output the stripped names.

- structs.py - structs.py deals with struct names, which are notably not
  symbols.
This commit is contained in:
Christopher Haster
2025-03-06 15:07:12 -06:00
parent 9e22167a31
commit 1cc38acc91
6 changed files with 64 additions and 3 deletions

View File

@@ -458,6 +458,7 @@ def collect_dwarf_info(obj_path, tags=None, *,
def collect_ctx(obj_paths, *,
everything=False,
no_strip=False,
depth=1,
**args):
results = []
@@ -693,9 +694,14 @@ def collect_ctx(obj_paths, *,
children=children_,
notes=notes_))
# strip compiler suffixes
name = sym.name
if not no_strip:
name = name.split('.', 1)[0]
# context = sum of params
name = entry.name
size = sum((param.size for param in params), start=RInt(0))
results.append(CtxResult(
0, 0, file, name, 0, size,
children=params))
@@ -1507,6 +1513,10 @@ if __name__ == "__main__":
'--everything',
action='store_true',
help="Include builtin and libc specific symbols.")
parser.add_argument(
'-x', '--no-strip',
action='store_true',
help="Don't strip compiler optimization suffixes from symbols.")
parser.add_argument(
'--objdump-path',
type=lambda x: x.split(),