tracing: optimization of branch tracer
authorWitold Baryluk <baryluk@smp.if.uj.edu.pl>
Tue, 17 Mar 2009 20:15:44 +0000 (21:15 +0100)
committerSteven Rostedt <srostedt@redhat.com>
Wed, 18 Mar 2009 03:10:43 +0000 (23:10 -0400)
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: Witold Baryluk <baryluk@smp.if.uj.edu.pl>
Signed-off-by: Steven Rostedt <srostedt@redhat.com>
include/linux/compiler.h

index d95da1020f1c95d7b392eecb7739a0393e79c4a3..6faa7e549de4c28c120a924bfb8015f26abb37ff 100644 (file)
@@ -68,6 +68,7 @@ struct ftrace_branch_data {
                        unsigned long miss;
                        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);
                                .line = __LINE__,                       \
                        };                                              \
                ______r = !!(cond);                                     \
-               if (______r)                                            \
-                       ______f.hit++;                                  \
-               else                                                    \
-                       ______f.miss++;                                 \
+               ______f.miss_hit[______r]++;                                    \
                ______r;                                                \
        }))
 #endif /* CONFIG_PROFILE_ALL_BRANCHES */