mirror of
https://github.com/varun-r-mallya/sysprof.git
synced 2025-12-31 20:36:25 +00:00
Move match to front (add_trace_to_tree): Break as soon as a recursive call
2006-11-22 Soren Sandmann <sandmann@daimi.au.dk> * profile.c (add_trace_to_tree): Move match to front (add_trace_to_tree): Break as soon as a recursive call is found. * stackstash.c (do_callback): Manual tail call optimization.
This commit is contained in:
committed by
Søren Sandmann Pedersen
parent
d1a082ffec
commit
d3c0e7be5c
25
stackstash.c
25
stackstash.c
@ -204,21 +204,26 @@ do_callback (StackNode *node,
|
||||
{
|
||||
GList link;
|
||||
|
||||
if (!node)
|
||||
return;
|
||||
|
||||
if (trace)
|
||||
trace->prev = &link;
|
||||
|
||||
|
||||
link.next = trace;
|
||||
link.data = node->address;
|
||||
link.prev = NULL;
|
||||
|
||||
if (node->size)
|
||||
func (&link, node->size, data);
|
||||
|
||||
do_callback (node->children, &link, func, data);
|
||||
do_callback (node->siblings, trace, func, data);
|
||||
while (node)
|
||||
{
|
||||
link.data = node->address;
|
||||
|
||||
if (node->size)
|
||||
func (&link, node->size, data);
|
||||
|
||||
do_callback (node->children, &link, func, data);
|
||||
|
||||
node = node->siblings;
|
||||
}
|
||||
|
||||
if (trace)
|
||||
trace->prev = NULL;
|
||||
}
|
||||
|
||||
void
|
||||
|
||||
Reference in New Issue
Block a user