mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	kprobes/x86: Just return error for sanity check failure instead of using BUG_ON
Return an error from __copy_instruction() and use printk() to give us a more productive message, since this is just an error case which we can handle and also the BUG_ON() never tells us why and what happened. This is related to the following bug-report: https://bugzilla.redhat.com/show_bug.cgi?id=910649 Signed-off-by: Masami Hiramatsu <masami.hiramatsu.pt@hitachi.com> Cc: Frank Ch. Eigler <fche@redhat.com> Cc: Steven Rostedt <rostedt@goodmis.org> Cc: yrl.pp-manager.tt@hitachi.com Link: http://lkml.kernel.org/r/20130404104230.22862.85242.stgit@mhiramat-M0-7522 Signed-off-by: Ingo Molnar <mingo@kernel.org>
This commit is contained in:
		
							parent
							
								
									324670b620
								
							
						
					
					
						commit
						8101376dc5
					
				| @ -353,7 +353,11 @@ int __kprobes __copy_instruction(u8 *dest, u8 *src) | |||||||
| 		 * have given. | 		 * have given. | ||||||
| 		 */ | 		 */ | ||||||
| 		newdisp = (u8 *) src + (s64) insn.displacement.value - (u8 *) dest; | 		newdisp = (u8 *) src + (s64) insn.displacement.value - (u8 *) dest; | ||||||
| 		BUG_ON((s64) (s32) newdisp != newdisp); /* Sanity check.  */ | 		if ((s64) (s32) newdisp != newdisp) { | ||||||
|  | 			pr_err("Kprobes error: new displacement does not fit into s32 (%llx)\n", newdisp); | ||||||
|  | 			pr_err("\tSrc: %p, Dest: %p, old disp: %x\n", src, dest, insn.displacement.value); | ||||||
|  | 			return 0; | ||||||
|  | 		} | ||||||
| 		disp = (u8 *) dest + insn_offset_displacement(&insn); | 		disp = (u8 *) dest + insn_offset_displacement(&insn); | ||||||
| 		*(s32 *) disp = (s32) newdisp; | 		*(s32 *) disp = (s32) newdisp; | ||||||
| 	} | 	} | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Masami Hiramatsu
						Masami Hiramatsu