/* | |
* linux/arch/arm26/mm/extable.c | |
*/ | |
#include <linux/module.h> | |
#include <asm/uaccess.h> | |
int fixup_exception(struct pt_regs *regs) | |
{ | |
const struct exception_table_entry *fixup; | |
fixup = search_exception_tables(instruction_pointer(regs)); | |
/* | |
* The kernel runs in SVC mode - make sure we keep running in SVC mode | |
* by frobbing the PSR appropriately (PSR and PC are in the same reg. | |
* on ARM26) | |
*/ | |
if (fixup) | |
regs->ARM_pc = fixup->fixup | PSR_I_BIT | MODE_SVC26; | |
return fixup != NULL; | |
} | |