diff options
author | Peter Zijlstra <peterz@infradead.org> | 2022-11-03 00:31:19 +0300 |
---|---|---|
committer | Peter Zijlstra <peterz@infradead.org> | 2022-11-05 13:28:02 +0300 |
commit | 19526717f768bf2f89ca01bd2a595728ebe57540 (patch) | |
tree | 60198c6408870ad2725459b6a8fbe4b05e622721 /tools/perf/scripts/python/task-analyzer.py | |
parent | 0c3e806ec0f9771fa1f34c60499097d9260a8bb7 (diff) | |
download | linux-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