diff options
| author | Ingo Molnar <mingo@kernel.org> | 2020-05-28 07:58:12 +0200 | 
|---|---|---|
| committer | Ingo Molnar <mingo@kernel.org> | 2020-05-28 07:58:12 +0200 | 
| commit | 0bffedbce90818228f554651baf8d7c75f2876d8 (patch) | |
| tree | 96101208e0200c70c6688737ac6596bdd0ed2950 /kernel/trace/trace.c | |
| parent | c50c75e9b87946499a62bffc021e95c87a1d57cd (diff) | |
| parent | 9cb1fd0efd195590b828b9b865421ad345a4a145 (diff) | |
Merge tag 'v5.7-rc7' into perf/core, to pick up fixes
Signed-off-by: Ingo Molnar <mingo@kernel.org>
Diffstat (limited to 'kernel/trace/trace.c')
| -rw-r--r-- | kernel/trace/trace.c | 16 | 
1 files changed, 15 insertions, 1 deletions
| diff --git a/kernel/trace/trace.c b/kernel/trace/trace.c index 8d2b98812625..29615f15a820 100644 --- a/kernel/trace/trace.c +++ b/kernel/trace/trace.c @@ -947,7 +947,8 @@ int __trace_bputs(unsigned long ip, const char *str)  EXPORT_SYMBOL_GPL(__trace_bputs);  #ifdef CONFIG_TRACER_SNAPSHOT -void tracing_snapshot_instance_cond(struct trace_array *tr, void *cond_data) +static void tracing_snapshot_instance_cond(struct trace_array *tr, +					   void *cond_data)  {  	struct tracer *tracer = tr->current_trace;  	unsigned long flags; @@ -8525,6 +8526,19 @@ static int allocate_trace_buffers(struct trace_array *tr, int size)  	 */  	allocate_snapshot = false;  #endif + +	/* +	 * Because of some magic with the way alloc_percpu() works on +	 * x86_64, we need to synchronize the pgd of all the tables, +	 * otherwise the trace events that happen in x86_64 page fault +	 * handlers can't cope with accessing the chance that a +	 * alloc_percpu()'d memory might be touched in the page fault trace +	 * event. Oh, and we need to audit all other alloc_percpu() and vmalloc() +	 * calls in tracing, because something might get triggered within a +	 * page fault trace event! +	 */ +	vmalloc_sync_mappings(); +  	return 0;  } | 
