diff options
| author | Sage Weil <sage@inktank.com> | 2013-08-15 11:11:45 -0700 | 
|---|---|---|
| committer | Sage Weil <sage@inktank.com> | 2013-08-15 11:11:45 -0700 | 
| commit | ee3e542fec6e69bc9fb668698889a37d93950ddf (patch) | |
| tree | e74ee766a4764769ef1d3d45d266b4dea64101d3 /arch/powerpc/net | |
| parent | fe2a801b50c0bb8039d627e5ae1fec249d10ff39 (diff) | |
| parent | f1d6e17f540af37bb1891480143669ba7636c4cf (diff) | |
Merge remote-tracking branch 'linus/master' into testing
Diffstat (limited to 'arch/powerpc/net')
| -rw-r--r-- | arch/powerpc/net/bpf_jit_comp.c | 19 | 
1 files changed, 3 insertions, 16 deletions
| diff --git a/arch/powerpc/net/bpf_jit_comp.c b/arch/powerpc/net/bpf_jit_comp.c index c427ae36374..bf56e33f825 100644 --- a/arch/powerpc/net/bpf_jit_comp.c +++ b/arch/powerpc/net/bpf_jit_comp.c @@ -650,8 +650,7 @@ void bpf_jit_compile(struct sk_filter *fp)  	proglen = cgctx.idx * 4;  	alloclen = proglen + FUNCTION_DESCR_SIZE; -	image = module_alloc(max_t(unsigned int, alloclen, -				   sizeof(struct work_struct))); +	image = module_alloc(alloclen);  	if (!image)  		goto out; @@ -688,20 +687,8 @@ out:  	return;  } -static void jit_free_defer(struct work_struct *arg) -{ -	module_free(NULL, arg); -} - -/* run from softirq, we must use a work_struct to call - * module_free() from process context - */  void bpf_jit_free(struct sk_filter *fp)  { -	if (fp->bpf_func != sk_run_filter) { -		struct work_struct *work = (struct work_struct *)fp->bpf_func; - -		INIT_WORK(work, jit_free_defer); -		schedule_work(work); -	} +	if (fp->bpf_func != sk_run_filter) +		module_free(NULL, fp->bpf_func);  } | 
