mirror of
				https://github.com/torvalds/linux.git
				synced 2025-10-31 16:48:26 +02:00 
			
		
		
		
	tracing: Return -EBUSY when event_enable_func() fails to get module
Since try_module_get() returns false( = 0) when it fails to pindown a module, event_enable_func() returns 0 which means "succeed". This can cause a kernel panic when the entry is removed, because the event is already released. This fixes the bug by returning -EBUSY, because the reason why it fails is that the module is being removed at that time. Link: http://lkml.kernel.org/r/20130516114848.13508.97899.stgit@mhiramat-M0-7522 Cc: Srikar Dronamraju <srikar@linux.vnet.ibm.com> Cc: Oleg Nesterov <oleg@redhat.com> Cc: Tom Zanussi <tom.zanussi@intel.com> Cc: Frederic Weisbecker <fweisbec@gmail.com> Cc: Ingo Molnar <mingo@redhat.com> Signed-off-by: Masami Hiramatsu <masami.hiramatsu.pt@hitachi.com> Signed-off-by: Steven Rostedt <rostedt@goodmis.org>
This commit is contained in:
		
							parent
							
								
									b62fdd97fc
								
							
						
					
					
						commit
						6ed0106667
					
				
					 1 changed files with 3 additions and 1 deletions
				
			
		|  | @ -2072,8 +2072,10 @@ event_enable_func(struct ftrace_hash *hash, | ||||||
|  out_reg: |  out_reg: | ||||||
| 	/* Don't let event modules unload while probe registered */ | 	/* Don't let event modules unload while probe registered */ | ||||||
| 	ret = try_module_get(file->event_call->mod); | 	ret = try_module_get(file->event_call->mod); | ||||||
| 	if (!ret) | 	if (!ret) { | ||||||
|  | 		ret = -EBUSY; | ||||||
| 		goto out_free; | 		goto out_free; | ||||||
|  | 	} | ||||||
| 
 | 
 | ||||||
| 	ret = __ftrace_event_enable_disable(file, 1, 1); | 	ret = __ftrace_event_enable_disable(file, 1, 1); | ||||||
| 	if (ret < 0) | 	if (ret < 0) | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue
	
	 Masami Hiramatsu
						Masami Hiramatsu