diff options
| author | Takashi Iwai <tiwai@suse.de> | 2013-08-01 05:12:10 -0400 |
|---|---|---|
| committer | Takashi Iwai <tiwai@suse.de> | 2013-08-01 05:12:10 -0400 |
| commit | 209fb1b7e298c5f5a93a9450bc9e9e7923f745d9 (patch) | |
| tree | 27cbfa78e5eeaceb2aae1c165f7f0e24f6fee286 /kernel/trace/trace_event_perf.c | |
| parent | a8d30608eaed6cc759b8e2e8a8bbbb42591f797f (diff) | |
| parent | 3fef7f795fff7ccc58d55a28315ca73305515884 (diff) | |
Merge tag 'asoc-v3.11-rc3' of git://git.kernel.org/pub/scm/linux/kernel/git/broonie/sound into for-linus
ASoC: Fixes for v3.11
A fix to make sure userspace knows when control writes have caused a
change in value, fixing some UIs, plus a few few driver fixes mainly
cleaning up issues from recent refactorings on less mainstream platforms.
Diffstat (limited to 'kernel/trace/trace_event_perf.c')
| -rw-r--r-- | kernel/trace/trace_event_perf.c | 10 |
1 files changed, 8 insertions, 2 deletions
diff --git a/kernel/trace/trace_event_perf.c b/kernel/trace/trace_event_perf.c index 84b1e045faba..80c36bcf66e8 100644 --- a/kernel/trace/trace_event_perf.c +++ b/kernel/trace/trace_event_perf.c | |||
| @@ -236,6 +236,10 @@ __kprobes void *perf_trace_buf_prepare(int size, unsigned short type, | |||
| 236 | 236 | ||
| 237 | BUILD_BUG_ON(PERF_MAX_TRACE_SIZE % sizeof(unsigned long)); | 237 | BUILD_BUG_ON(PERF_MAX_TRACE_SIZE % sizeof(unsigned long)); |
| 238 | 238 | ||
| 239 | if (WARN_ONCE(size > PERF_MAX_TRACE_SIZE, | ||
| 240 | "perf buffer not large enough")) | ||
| 241 | return NULL; | ||
| 242 | |||
| 239 | pc = preempt_count(); | 243 | pc = preempt_count(); |
| 240 | 244 | ||
| 241 | *rctxp = perf_swevent_get_recursion_context(); | 245 | *rctxp = perf_swevent_get_recursion_context(); |
| @@ -266,6 +270,10 @@ perf_ftrace_function_call(unsigned long ip, unsigned long parent_ip, | |||
| 266 | struct pt_regs regs; | 270 | struct pt_regs regs; |
| 267 | int rctx; | 271 | int rctx; |
| 268 | 272 | ||
| 273 | head = this_cpu_ptr(event_function.perf_events); | ||
| 274 | if (hlist_empty(head)) | ||
| 275 | return; | ||
| 276 | |||
| 269 | #define ENTRY_SIZE (ALIGN(sizeof(struct ftrace_entry) + sizeof(u32), \ | 277 | #define ENTRY_SIZE (ALIGN(sizeof(struct ftrace_entry) + sizeof(u32), \ |
| 270 | sizeof(u64)) - sizeof(u32)) | 278 | sizeof(u64)) - sizeof(u32)) |
| 271 | 279 | ||
| @@ -279,8 +287,6 @@ perf_ftrace_function_call(unsigned long ip, unsigned long parent_ip, | |||
| 279 | 287 | ||
| 280 | entry->ip = ip; | 288 | entry->ip = ip; |
| 281 | entry->parent_ip = parent_ip; | 289 | entry->parent_ip = parent_ip; |
| 282 | |||
| 283 | head = this_cpu_ptr(event_function.perf_events); | ||
| 284 | perf_trace_buf_submit(entry, ENTRY_SIZE, rctx, 0, | 290 | perf_trace_buf_submit(entry, ENTRY_SIZE, rctx, 0, |
| 285 | 1, ®s, head, NULL); | 291 | 1, ®s, head, NULL); |
| 286 | 292 | ||
