diff options
| author | Grant Likely <grant.likely@secretlab.ca> | 2010-12-29 22:20:30 -0700 | 
|---|---|---|
| committer | Grant Likely <grant.likely@secretlab.ca> | 2010-12-29 22:21:47 -0700 | 
| commit | d392da5207352f09030e95d9ea335a4225667ec0 (patch) | |
| tree | 7d6cd1932afcad0a5619a5c504a6d93ca318187c /lib/bug.c | |
| parent | e39d5ef678045d61812c1401f04fe8edb14d6359 (diff) | |
| parent | 387c31c7e5c9805b0aef8833d1731a5fe7bdea14 (diff) | |
Merge v2.6.37-rc8 into powerpc/next
Diffstat (limited to 'lib/bug.c')
| -rw-r--r-- | lib/bug.c | 18 | 
1 files changed, 10 insertions, 8 deletions
diff --git a/lib/bug.c b/lib/bug.c index f13daf435211..19552096d16b 100644 --- a/lib/bug.c +++ b/lib/bug.c @@ -72,8 +72,8 @@ static const struct bug_entry *module_find_bug(unsigned long bugaddr)  	return NULL;  } -int module_bug_finalize(const Elf_Ehdr *hdr, const Elf_Shdr *sechdrs, -			struct module *mod) +void module_bug_finalize(const Elf_Ehdr *hdr, const Elf_Shdr *sechdrs, +			 struct module *mod)  {  	char *secstrings;  	unsigned int i; @@ -97,8 +97,6 @@ int module_bug_finalize(const Elf_Ehdr *hdr, const Elf_Shdr *sechdrs,  	 * could potentially lead to deadlock and thus be counter-productive.  	 */  	list_add(&mod->bug_list, &module_bug_list); - -	return 0;  }  void module_bug_cleanup(struct module *mod) @@ -136,8 +134,6 @@ enum bug_trap_type report_bug(unsigned long bugaddr, struct pt_regs *regs)  	bug = find_bug(bugaddr); -	printk(KERN_EMERG "------------[ cut here ]------------\n"); -  	file = NULL;  	line = 0;  	warning = 0; @@ -156,19 +152,25 @@ enum bug_trap_type report_bug(unsigned long bugaddr, struct pt_regs *regs)  	if (warning) {  		/* this is a WARN_ON rather than BUG/BUG_ON */ +		printk(KERN_WARNING "------------[ cut here ]------------\n"); +  		if (file) -			printk(KERN_ERR "Badness at %s:%u\n", +			printk(KERN_WARNING "WARNING: at %s:%u\n",  			       file, line);  		else -			printk(KERN_ERR "Badness at %p " +			printk(KERN_WARNING "WARNING: at %p "  			       "[verbose debug info unavailable]\n",  			       (void *)bugaddr); +		print_modules();  		show_regs(regs); +		print_oops_end_marker();  		add_taint(BUG_GET_TAINT(bug));  		return BUG_TRAP_TYPE_WARN;  	} +	printk(KERN_EMERG "------------[ cut here ]------------\n"); +  	if (file)  		printk(KERN_CRIT "kernel BUG at %s:%u!\n",  		       file, line);  | 
