diff options
Diffstat (limited to 'kernel')
| -rw-r--r-- | kernel/bpf/hashtab.c | 2 | ||||
| -rw-r--r-- | kernel/trace/bpf_trace.c | 19 | 
2 files changed, 14 insertions, 7 deletions
| diff --git a/kernel/bpf/hashtab.c b/kernel/bpf/hashtab.c index e469e05c8e83..3905d4bc5b80 100644 --- a/kernel/bpf/hashtab.c +++ b/kernel/bpf/hashtab.c @@ -114,6 +114,7 @@ static void htab_free_elems(struct bpf_htab *htab)  		pptr = htab_elem_get_ptr(get_htab_elem(htab, i),  					 htab->map.key_size);  		free_percpu(pptr); +		cond_resched();  	}  free_elems:  	bpf_map_area_free(htab->elems); @@ -159,6 +160,7 @@ static int prealloc_init(struct bpf_htab *htab)  			goto free_elems;  		htab_elem_set_ptr(get_htab_elem(htab, i), htab->map.key_size,  				  pptr); +		cond_resched();  	}  skip_percpu_elems: diff --git a/kernel/trace/bpf_trace.c b/kernel/trace/bpf_trace.c index 0ce99c379c30..40207c2a4113 100644 --- a/kernel/trace/bpf_trace.c +++ b/kernel/trace/bpf_trace.c @@ -343,14 +343,13 @@ static const struct bpf_func_proto bpf_perf_event_read_value_proto = {  	.arg4_type	= ARG_CONST_SIZE,  }; -static DEFINE_PER_CPU(struct perf_sample_data, bpf_sd); +static DEFINE_PER_CPU(struct perf_sample_data, bpf_trace_sd);  static __always_inline u64  __bpf_perf_event_output(struct pt_regs *regs, struct bpf_map *map, -			u64 flags, struct perf_raw_record *raw) +			u64 flags, struct perf_sample_data *sd)  {  	struct bpf_array *array = container_of(map, struct bpf_array, map); -	struct perf_sample_data *sd = this_cpu_ptr(&bpf_sd);  	unsigned int cpu = smp_processor_id();  	u64 index = flags & BPF_F_INDEX_MASK;  	struct bpf_event_entry *ee; @@ -373,8 +372,6 @@ __bpf_perf_event_output(struct pt_regs *regs, struct bpf_map *map,  	if (unlikely(event->oncpu != cpu))  		return -EOPNOTSUPP; -	perf_sample_data_init(sd, 0, 0); -	sd->raw = raw;  	perf_event_output(event, sd, regs);  	return 0;  } @@ -382,6 +379,7 @@ __bpf_perf_event_output(struct pt_regs *regs, struct bpf_map *map,  BPF_CALL_5(bpf_perf_event_output, struct pt_regs *, regs, struct bpf_map *, map,  	   u64, flags, void *, data, u64, size)  { +	struct perf_sample_data *sd = this_cpu_ptr(&bpf_trace_sd);  	struct perf_raw_record raw = {  		.frag = {  			.size = size, @@ -392,7 +390,10 @@ BPF_CALL_5(bpf_perf_event_output, struct pt_regs *, regs, struct bpf_map *, map,  	if (unlikely(flags & ~(BPF_F_INDEX_MASK)))  		return -EINVAL; -	return __bpf_perf_event_output(regs, map, flags, &raw); +	perf_sample_data_init(sd, 0, 0); +	sd->raw = &raw; + +	return __bpf_perf_event_output(regs, map, flags, sd);  }  static const struct bpf_func_proto bpf_perf_event_output_proto = { @@ -407,10 +408,12 @@ static const struct bpf_func_proto bpf_perf_event_output_proto = {  };  static DEFINE_PER_CPU(struct pt_regs, bpf_pt_regs); +static DEFINE_PER_CPU(struct perf_sample_data, bpf_misc_sd);  u64 bpf_event_output(struct bpf_map *map, u64 flags, void *meta, u64 meta_size,  		     void *ctx, u64 ctx_size, bpf_ctx_copy_t ctx_copy)  { +	struct perf_sample_data *sd = this_cpu_ptr(&bpf_misc_sd);  	struct pt_regs *regs = this_cpu_ptr(&bpf_pt_regs);  	struct perf_raw_frag frag = {  		.copy		= ctx_copy, @@ -428,8 +431,10 @@ u64 bpf_event_output(struct bpf_map *map, u64 flags, void *meta, u64 meta_size,  	};  	perf_fetch_caller_regs(regs); +	perf_sample_data_init(sd, 0, 0); +	sd->raw = &raw; -	return __bpf_perf_event_output(regs, map, flags, &raw); +	return __bpf_perf_event_output(regs, map, flags, sd);  }  BPF_CALL_0(bpf_get_current_task) | 
