2005-04-17 05:20:36 +07:00
|
|
|
/*
|
|
|
|
* arch/sh/kernel/cpu/sh3/ex.S
|
|
|
|
*
|
2007-05-08 11:01:37 +07:00
|
|
|
* The SH-3 and SH-4 exception vector table.
|
2005-04-17 05:20:36 +07:00
|
|
|
|
|
|
|
* Copyright (C) 1999, 2000, 2002 Niibe Yutaka
|
2008-07-02 11:58:38 +07:00
|
|
|
* Copyright (C) 2003 - 2008 Paul Mundt
|
2005-04-17 05:20:36 +07:00
|
|
|
*
|
|
|
|
* This file is subject to the terms and conditions of the GNU General Public
|
|
|
|
* License. See the file "COPYING" in the main directory of this archive
|
|
|
|
* for more details.
|
|
|
|
*/
|
|
|
|
#include <linux/linkage.h>
|
|
|
|
|
2008-07-02 11:58:38 +07:00
|
|
|
#if !defined(CONFIG_MMU)
|
|
|
|
#define tlb_miss_load exception_error
|
|
|
|
#define tlb_miss_store exception_error
|
|
|
|
#define initial_page_write exception_error
|
|
|
|
#define tlb_protection_violation_load exception_error
|
|
|
|
#define tlb_protection_violation_store exception_error
|
|
|
|
#define address_error_load exception_error
|
|
|
|
#define address_error_store exception_error
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if !defined(CONFIG_SH_FPU)
|
|
|
|
#define fpu_error_trap_handler exception_error
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if !defined(CONFIG_KGDB_NMI)
|
|
|
|
#define kgdb_handle_exception exception_error
|
|
|
|
#endif
|
|
|
|
|
2005-04-17 05:20:36 +07:00
|
|
|
.align 2
|
|
|
|
.data
|
|
|
|
|
|
|
|
ENTRY(exception_handling_table)
|
|
|
|
.long exception_error /* 000 */
|
|
|
|
.long exception_error
|
|
|
|
.long tlb_miss_load /* 040 */
|
|
|
|
.long tlb_miss_store
|
|
|
|
.long initial_page_write
|
|
|
|
.long tlb_protection_violation_load
|
|
|
|
.long tlb_protection_violation_store
|
|
|
|
.long address_error_load
|
|
|
|
.long address_error_store /* 100 */
|
2007-11-26 18:38:36 +07:00
|
|
|
.long fpu_error_trap_handler /* 120 */
|
2007-05-08 11:01:37 +07:00
|
|
|
.long exception_error /* 140 */
|
2005-04-17 05:20:36 +07:00
|
|
|
.long system_call ! Unconditional Trap /* 160 */
|
|
|
|
.long exception_error ! reserved_instruction (filled by trap_init) /* 180 */
|
|
|
|
.long exception_error ! illegal_slot_instruction (filled by trap_init) /*1A0*/
|
|
|
|
ENTRY(nmi_slot)
|
2007-11-06 14:59:10 +07:00
|
|
|
.long kgdb_handle_exception /* 1C0 */ ! Allow trap to debugger
|
2005-04-17 05:20:36 +07:00
|
|
|
ENTRY(user_break_point_trap)
|
|
|
|
.long break_point_trap /* 1E0 */
|
2006-10-19 14:20:25 +07:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Pad the remainder of the table out, exceptions residing in far
|
|
|
|
* away offsets can be manually inserted in to their appropriate
|
|
|
|
* location via set_exception_table_{evt,vec}().
|
|
|
|
*/
|
2007-05-08 11:01:37 +07:00
|
|
|
.balign 4096,0,4096
|