summaryrefslogtreecommitdiff
path: root/tools/perf/scripts/python/task-analyzer.py
diff options
context:
space:
mode:
authorPeter Zijlstra <peterz@infradead.org>2022-11-03 00:31:19 +0300
committerPeter Zijlstra <peterz@infradead.org>2022-11-05 13:28:02 +0300
commit19526717f768bf2f89ca01bd2a595728ebe57540 (patch)
tree60198c6408870ad2725459b6a8fbe4b05e622721 /tools/perf/scripts/python/task-analyzer.py
parent0c3e806ec0f9771fa1f34c60499097d9260a8bb7 (diff)
downloadlinux-19526717f768bf2f89ca01bd2a595728ebe57540.tar.xz
objtool: Optimize elf_dirty_reloc_sym()
When moving a symbol in the symtab its index changes and any reloc referring that symtol-table-index will need to be rewritten too. In order to facilitate this, objtool simply marks the whole reloc section 'changed' which will cause the whole section to be re-generated. However, finding the relocs that use any given symbol is implemented rather crudely -- a fully iteration of all sections and their relocs. Given that some builds have over 20k sections (kallsyms etc..) iterating all that for *each* symbol moved takes a bit of time. Instead have each symbol keep a list of relocs that reference it. This *vastly* improves build times for certain configs. Reported-by: Borislav Petkov <bp@alien8.de> Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org> Link: https://lkml.kernel.org/r/Y2LlRA7x+8UsE1xf@hirez.programming.kicks-ass.net
Diffstat (limited to 'tools/perf/scripts/python/task-analyzer.py')
0 files changed, 0 insertions, 0 deletions