Commit 97e7e4f3 authored by Witold Baryluk's avatar Witold Baryluk Committed by Steven Rostedt

tracing: optimization of branch tracer

Impact: better performance for if branch tracer

Use an array to count the hit and misses of a conditional instead
of using another conditional. This cuts down on saturation of branch
predictions and increases performance of modern pipelined architectures.
Signed-off-by: default avatarWitold Baryluk <baryluk@smp.if.uj.edu.pl>
Signed-off-by: default avatarSteven Rostedt <srostedt@redhat.com>
parent af4617bd
...@@ -68,6 +68,7 @@ struct ftrace_branch_data { ...@@ -68,6 +68,7 @@ struct ftrace_branch_data {
unsigned long miss; unsigned long miss;
unsigned long hit; unsigned long hit;
}; };
unsigned long miss_hit[2];
}; };
}; };
...@@ -125,10 +126,7 @@ void ftrace_likely_update(struct ftrace_branch_data *f, int val, int expect); ...@@ -125,10 +126,7 @@ void ftrace_likely_update(struct ftrace_branch_data *f, int val, int expect);
.line = __LINE__, \ .line = __LINE__, \
}; \ }; \
______r = !!(cond); \ ______r = !!(cond); \
if (______r) \ ______f.miss_hit[______r]++; \
______f.hit++; \
else \
______f.miss++; \
______r; \ ______r; \
})) }))
#endif /* CONFIG_PROFILE_ALL_BRANCHES */ #endif /* CONFIG_PROFILE_ALL_BRANCHES */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment