forked from luck/tmp_suning_uos_patched
5d86456d38
Tidying in preparation for the segfault register dumping patch which follows. void * pointers are changed to union uml_pt_regs *. This makes the types match reality, except in arch_fixup, which is changed to operate on a union uml_pt_regs. This fixes a bug in the call from segv_handler, which passes a union uml_pt_regs, to segv, which expects to pass a struct sigcontext to arch_fixup. Whitespace and other style fixes. There's also a errno printk fix. Signed-off-by: Jeff Dike <jdike@linux.intel.com> Cc: Paolo 'Blaisorblade' Giarrusso <blaisorblade@yahoo.it> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
29 lines
649 B
C
29 lines
649 B
C
/*
|
|
* Copyright (C) 2002 - 2004 Jeff Dike (jdike@addtoit.com)
|
|
* Licensed under the GPL
|
|
*/
|
|
|
|
#include "sysdep/ptrace.h"
|
|
|
|
/* These two are from asm-um/uaccess.h and linux/module.h, check them. */
|
|
struct exception_table_entry
|
|
{
|
|
unsigned long insn;
|
|
unsigned long fixup;
|
|
};
|
|
|
|
const struct exception_table_entry *search_exception_tables(unsigned long add);
|
|
|
|
/* Compare this to arch/i386/mm/extable.c:fixup_exception() */
|
|
int arch_fixup(unsigned long address, union uml_pt_regs *regs)
|
|
{
|
|
const struct exception_table_entry *fixup;
|
|
|
|
fixup = search_exception_tables(address);
|
|
if(fixup != 0){
|
|
UPT_IP(regs) = fixup->fixup;
|
|
return(1);
|
|
}
|
|
return(0);
|
|
}
|