xref: /rk3399_rockchip-uboot/arch/m68k/lib/traps.c (revision 93e1459641e758d2b096d3f1b39414a39bb314f8)
1ea0364f1SPeter Tyser /*
2ea0364f1SPeter Tyser  * (C) Copyright 2003
3ea0364f1SPeter Tyser  * Josef Baumgartner <josef.baumgartner@telex.de>
4ea0364f1SPeter Tyser  *
5ea0364f1SPeter Tyser  * (C) Copyright 2000
6ea0364f1SPeter Tyser  * Wolfgang Denk, DENX Software Engineering, wd@denx.de.
7ea0364f1SPeter Tyser  *
8*1a459660SWolfgang Denk  * SPDX-License-Identifier:	GPL-2.0+
9ea0364f1SPeter Tyser  */
10ea0364f1SPeter Tyser 
11ea0364f1SPeter Tyser #include <common.h>
12ea0364f1SPeter Tyser #include <watchdog.h>
13ea0364f1SPeter Tyser #include <command.h>
14ea0364f1SPeter Tyser #include <asm/processor.h>
15ea0364f1SPeter Tyser 
16ea0364f1SPeter Tyser 
17ea0364f1SPeter Tyser extern void _exc_handler(void);
18ea0364f1SPeter Tyser extern void _int_handler(void);
19ea0364f1SPeter Tyser 
show_frame(struct pt_regs * fp)20ea0364f1SPeter Tyser static void show_frame(struct pt_regs *fp)
21ea0364f1SPeter Tyser {
22ea0364f1SPeter Tyser 	printf ("Vector Number: %d  Format: %02x  Fault Status: %01x\n\n", (fp->vector & 0x3fc) >> 2,
23ea0364f1SPeter Tyser 		fp->format, (fp->vector & 0x3) | ((fp->vector & 0xc00) >> 8));
24ea0364f1SPeter Tyser 	printf ("PC: %08lx    SR: %08lx    SP: %08lx\n", fp->pc, (long) fp->sr, (long) fp);
25ea0364f1SPeter Tyser 	printf ("D0: %08lx    D1: %08lx    D2: %08lx    D3: %08lx\n",
26ea0364f1SPeter Tyser 		fp->d0, fp->d1, fp->d2, fp->d3);
27ea0364f1SPeter Tyser 	printf ("D4: %08lx    D5: %08lx    D6: %08lx    D7: %08lx\n",
28ea0364f1SPeter Tyser 		fp->d4, fp->d5, fp->d6, fp->d7);
29ea0364f1SPeter Tyser 	printf ("A0: %08lx    A1: %08lx    A2: %08lx    A3: %08lx\n",
30ea0364f1SPeter Tyser 		fp->a0, fp->a1, fp->a2, fp->a3);
31ea0364f1SPeter Tyser 	printf ("A4: %08lx    A5: %08lx    A6: %08lx\n",
32ea0364f1SPeter Tyser 		fp->a4, fp->a5, fp->a6);
33ea0364f1SPeter Tyser }
34ea0364f1SPeter Tyser 
exc_handler(struct pt_regs * fp)35ea0364f1SPeter Tyser void exc_handler(struct pt_regs *fp) {
36ea0364f1SPeter Tyser 	printf("\n\n*** Unexpected exception ***\n");
37ea0364f1SPeter Tyser 	show_frame (fp);
38ea0364f1SPeter Tyser 	printf("\n*** Please Reset Board! ***\n");
39ea0364f1SPeter Tyser 	for(;;);
40ea0364f1SPeter Tyser }
41ea0364f1SPeter Tyser 
trap_init(ulong value)42ea0364f1SPeter Tyser void trap_init(ulong value) {
43ea0364f1SPeter Tyser 	unsigned long *vec = (ulong *)value;
44ea0364f1SPeter Tyser 	int i;
45ea0364f1SPeter Tyser 
46ea0364f1SPeter Tyser 	for(i = 2; i < 25; i++) {
47ea0364f1SPeter Tyser 		vec[i] = (unsigned long)_exc_handler;
48ea0364f1SPeter Tyser 	}
49ea0364f1SPeter Tyser 	for(i = 25; i < 32; i++) {
50ea0364f1SPeter Tyser 		vec[i] = (unsigned long)_int_handler;
51ea0364f1SPeter Tyser 	}
52ea0364f1SPeter Tyser 	for(i = 32; i < 64; i++) {
53ea0364f1SPeter Tyser 		vec[i] = (unsigned long)_exc_handler;
54ea0364f1SPeter Tyser 	}
55ea0364f1SPeter Tyser 	for(i = 64; i < 256; i++) {
56ea0364f1SPeter Tyser 		vec[i] = (unsigned long)_int_handler;
57ea0364f1SPeter Tyser 	}
58ea0364f1SPeter Tyser 
59ea0364f1SPeter Tyser 	setvbr(value);		/* set vector base register to new table */
60ea0364f1SPeter Tyser }
61