提交 b1b1d4a6 编写于 作者: P Phil Carmody 提交者: Kyle McMartin

parisc: unwind - optimise linked-list searches for modules

Having many dozens of modules, the searches down the linked
list of sections would dominate the lookup time, dwarfing
any savings from the binary search within the section.

A simple move-to-front optimisation exploits the commonality
of the code paths taken, and in simple real-world tests
on other architectures reduced the number of steps in the
search to barely more than 1.
Signed-off-by: NPhil Carmody <ext-phil.2.carmody@nokia.com>
Signed-off-by: NKyle McMartin <kyle@redhat.com>
上级 f7208177
...@@ -80,9 +80,12 @@ find_unwind_entry(unsigned long addr) ...@@ -80,9 +80,12 @@ find_unwind_entry(unsigned long addr)
if (addr >= table->start && if (addr >= table->start &&
addr <= table->end) addr <= table->end)
e = find_unwind_entry_in_table(table, addr); e = find_unwind_entry_in_table(table, addr);
if (e) if (e) {
/* Move-to-front to exploit common traces */
list_move(&table->list, &unwind_tables);
break; break;
} }
}
return e; return e;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册