aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--kernel/trace/ring_buffer.c23
1 files changed, 15 insertions, 8 deletions
diff --git a/kernel/trace/ring_buffer.c b/kernel/trace/ring_buffer.c
index d9f3e7a82137..f5007d0d932d 100644
--- a/kernel/trace/ring_buffer.c
+++ b/kernel/trace/ring_buffer.c
@@ -2078,7 +2078,7 @@ static void rb_start_commit(struct ring_buffer_per_cpu *cpu_buffer)
2078 local_inc(&cpu_buffer->commits); 2078 local_inc(&cpu_buffer->commits);
2079} 2079}
2080 2080
2081static void rb_end_commit(struct ring_buffer_per_cpu *cpu_buffer) 2081static inline void rb_end_commit(struct ring_buffer_per_cpu *cpu_buffer)
2082{ 2082{
2083 unsigned long commits; 2083 unsigned long commits;
2084 2084
@@ -2193,13 +2193,9 @@ rb_reserve_next_event(struct ring_buffer *buffer,
2193 2193
2194#define TRACE_RECURSIVE_DEPTH 16 2194#define TRACE_RECURSIVE_DEPTH 16
2195 2195
2196static int trace_recursive_lock(void) 2196/* Keep this code out of the fast path cache */
2197static noinline void trace_recursive_fail(void)
2197{ 2198{
2198 current->trace_recursion++;
2199
2200 if (likely(current->trace_recursion < TRACE_RECURSIVE_DEPTH))
2201 return 0;
2202
2203 /* Disable all tracing before we do anything else */ 2199 /* Disable all tracing before we do anything else */
2204 tracing_off_permanent(); 2200 tracing_off_permanent();
2205 2201
@@ -2211,10 +2207,21 @@ static int trace_recursive_lock(void)
2211 in_nmi()); 2207 in_nmi());
2212 2208
2213 WARN_ON_ONCE(1); 2209 WARN_ON_ONCE(1);
2210}
2211
2212static inline int trace_recursive_lock(void)
2213{
2214 current->trace_recursion++;
2215
2216 if (likely(current->trace_recursion < TRACE_RECURSIVE_DEPTH))
2217 return 0;
2218
2219 trace_recursive_fail();
2220
2214 return -1; 2221 return -1;
2215} 2222}
2216 2223
2217static void trace_recursive_unlock(void) 2224static inline void trace_recursive_unlock(void)
2218{ 2225{
2219 WARN_ON_ONCE(!current->trace_recursion); 2226 WARN_ON_ONCE(!current->trace_recursion);
2220 2227