aboutsummaryrefslogtreecommitdiffstats
path: root/include
diff options
context:
space:
mode:
Diffstat (limited to 'include')
-rw-r--r--include/asm-generic/vmlinux.lds.h2
-rw-r--r--include/linux/compiler.h19
2 files changed, 11 insertions, 10 deletions
diff --git a/include/asm-generic/vmlinux.lds.h b/include/asm-generic/vmlinux.lds.h
index e10beb5335c9..a5e4ed9baec8 100644
--- a/include/asm-generic/vmlinux.lds.h
+++ b/include/asm-generic/vmlinux.lds.h
@@ -45,7 +45,7 @@
45#define MCOUNT_REC() 45#define MCOUNT_REC()
46#endif 46#endif
47 47
48#ifdef CONFIG_TRACE_UNLIKELY_PROFILE 48#ifdef CONFIG_TRACE_BRANCH_PROFILING
49#define LIKELY_PROFILE() VMLINUX_SYMBOL(__start_likely_profile) = .; \ 49#define LIKELY_PROFILE() VMLINUX_SYMBOL(__start_likely_profile) = .; \
50 *(_ftrace_likely) \ 50 *(_ftrace_likely) \
51 VMLINUX_SYMBOL(__stop_likely_profile) = .; \ 51 VMLINUX_SYMBOL(__stop_likely_profile) = .; \
diff --git a/include/linux/compiler.h b/include/linux/compiler.h
index 63b7d9089d6e..c7d804a7a4d6 100644
--- a/include/linux/compiler.h
+++ b/include/linux/compiler.h
@@ -59,26 +59,27 @@ extern void __chk_io_ptr(const volatile void __iomem *);
59 * specific implementations come from the above header files 59 * specific implementations come from the above header files
60 */ 60 */
61 61
62/* 62struct ftrace_branch_data {
63 * Note: DISABLE_UNLIKELY_PROFILE can be used by special lowlevel code
64 * to disable branch tracing on a per file basis.
65 */
66#if defined(CONFIG_TRACE_UNLIKELY_PROFILE) && !defined(DISABLE_UNLIKELY_PROFILE)
67struct ftrace_likely_data {
68 const char *func; 63 const char *func;
69 const char *file; 64 const char *file;
70 unsigned line; 65 unsigned line;
71 unsigned long correct; 66 unsigned long correct;
72 unsigned long incorrect; 67 unsigned long incorrect;
73}; 68};
74void ftrace_likely_update(struct ftrace_likely_data *f, int val, int expect); 69
70/*
71 * Note: DISABLE_BRANCH_PROFILING can be used by special lowlevel code
72 * to disable branch tracing on a per file basis.
73 */
74#if defined(CONFIG_TRACE_BRANCH_PROFILING) && !defined(DISABLE_BRANCH_PROFILING)
75void ftrace_likely_update(struct ftrace_branch_data *f, int val, int expect);
75 76
76#define likely_notrace(x) __builtin_expect(!!(x), 1) 77#define likely_notrace(x) __builtin_expect(!!(x), 1)
77#define unlikely_notrace(x) __builtin_expect(!!(x), 0) 78#define unlikely_notrace(x) __builtin_expect(!!(x), 0)
78 79
79#define likely_check(x) ({ \ 80#define likely_check(x) ({ \
80 int ______r; \ 81 int ______r; \
81 static struct ftrace_likely_data \ 82 static struct ftrace_branch_data \
82 __attribute__((__aligned__(4))) \ 83 __attribute__((__aligned__(4))) \
83 __attribute__((section("_ftrace_likely"))) \ 84 __attribute__((section("_ftrace_likely"))) \
84 ______f = { \ 85 ______f = { \
@@ -93,7 +94,7 @@ void ftrace_likely_update(struct ftrace_likely_data *f, int val, int expect);
93 }) 94 })
94#define unlikely_check(x) ({ \ 95#define unlikely_check(x) ({ \
95 int ______r; \ 96 int ______r; \
96 static struct ftrace_likely_data \ 97 static struct ftrace_branch_data \
97 __attribute__((__aligned__(4))) \ 98 __attribute__((__aligned__(4))) \
98 __attribute__((section("_ftrace_unlikely"))) \ 99 __attribute__((section("_ftrace_unlikely"))) \
99 ______f = { \ 100 ______f = { \