xref: /netbsd/sys/arch/next68k/next68k/vectors.s (revision bf9ec67e)
1| $NetBSD: vectors.s,v 1.7 2001/05/12 22:35:30 chs Exp $
2
3| This file was taken from from mvme68k/mvme68k/vectors.s
4| should probably be re-synced when needed.
5| Darrin B. Jewell <jewell@mit.edu>  Tue Nov 10 05:07:16 1998
6| original cvs id: NetBSD: vectors.s,v 1.7 1998/10/18 04:42:37 itohy Exp
7
8| Copyright (c) 1988 University of Utah
9| Copyright (c) 1990, 1993
10|	The Regents of the University of California.  All rights reserved.
11|
12| Redistribution and use in source and binary forms, with or without
13| modification, are permitted provided that the following conditions
14| are met:
15| 1. Redistributions of source code must retain the above copyright
16|    notice, this list of conditions and the following disclaimer.
17| 2. Redistributions in binary form must reproduce the above copyright
18|    notice, this list of conditions and the following disclaimer in the
19|    documentation and/or other materials provided with the distribution.
20| 3. All advertising materials mentioning features or use of this software
21|    must display the following acknowledgement:
22|	This product includes software developed by the University of
23|	California, Berkeley and its contributors.
24| 4. Neither the name of the University nor the names of its contributors
25|    may be used to endorse or promote products derived from this software
26|    without specific prior written permission.
27|
28| THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
29| ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
30| IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
31| ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
32| FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
33| DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
34| OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
35| HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
36| LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
37| OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
38| SUCH DAMAGE.
39|
40|	@(#)vectors.s	8.2 (Berkeley) 1/21/94
41|
42
43	.data
44
45GLOBAL(vectab)
46	VECTOR(badtrap)		/* 0: (unused reset SSP) */
47	VECTOR(badtrap)		/* 1: NOT USED (reset PC) */
48	VECTOR(badtrap)		/* 2: bus error (set at boot in locore.s) */
49	VECTOR(badtrap)		/* 3: address error (set at boot in locore.s) */
50	VECTOR(illinst)		/* 4: illegal instruction */
51	VECTOR(zerodiv)		/* 5: zero divide */
52	VECTOR(chkinst)		/* 6: CHK instruction */
53	VECTOR(trapvinst)	/* 7: TRAPV instruction */
54	VECTOR(privinst)	/* 8: privilege violation */
55	VECTOR(trace)		/* 9: trace */
56	VECTOR(illinst)		/* 10: line 1010 emulator */
57	VECTOR(fpfline)		/* 11: line 1111 emulator */
58	VECTOR(badtrap)		/* 12: unassigned, reserved */
59	VECTOR(coperr)		/* 13: coprocessor protocol violation */
60	VECTOR(fmterr)		/* 14: format error */
61	VECTOR(badtrap)		/* 15: uninitialized interrupt vector */
62	VECTOR(badtrap)		/* 16: unassigned, reserved */
63	VECTOR(badtrap)		/* 17: unassigned, reserved */
64	VECTOR(badtrap)		/* 18: unassigned, reserved */
65	VECTOR(badtrap)		/* 19: unassigned, reserved */
66	VECTOR(badtrap)		/* 20: unassigned, reserved */
67	VECTOR(badtrap)		/* 21: unassigned, reserved */
68	VECTOR(badtrap)		/* 22: unassigned, reserved */
69	VECTOR(badtrap)		/* 23: unassigned, reserved */
70	VECTOR(spurintr)	/* 24: spurious interrupt */
71	VECTOR(intrhand_autovec) /* 25: level 1 interrupt autovector */
72	VECTOR(intrhand_autovec) /* 26: level 2 interrupt autovector */
73	VECTOR(intrhand_autovec) /* 27: level 3 interrupt autovector */
74	VECTOR(intrhand_autovec) /* 28: level 4 interrupt autovector */
75	VECTOR(intrhand_autovec) /* 29: level 5 interrupt autovector */
76	VECTOR(intrhand_autovec) /* 30: level 6 interrupt autovector */
77	VECTOR(lev7intr)	/* 31: level 7 interrupt autovector */
78	VECTOR(trap0)		/* 32: syscalls */
79#ifdef COMPAT_13
80	VECTOR(trap1)		/* 33: compat_13_sigreturn */
81#else
82	VECTOR(illinst)
83#endif
84	VECTOR(trap2)		/* 34: trace */
85	VECTOR(trap3)		/* 35: sigreturn special syscall */
86	VECTOR(illinst)		/* 36: TRAP instruction vector */
87	VECTOR(illinst)		/* 37: TRAP instruction vector */
88	VECTOR(illinst)		/* 38: TRAP instruction vector */
89	VECTOR(illinst)		/* 39: TRAP instruction vector */
90	VECTOR(illinst)		/* 40: TRAP instruction vector */
91	VECTOR(illinst)		/* 41: TRAP instruction vector */
92	VECTOR(illinst)		/* 42: TRAP instruction vector */
93	VECTOR(illinst)		/* 43: TRAP instruction vector */
94	VECTOR(trap12)		/* 44: TRAP instruction vector */
95	VECTOR(illinst)		/* 45: TRAP instruction vector */
96	VECTOR(illinst)		/* 46: TRAP instruction vector */
97	VECTOR(trap15)		/* 47: TRAP instruction vector */
98#ifdef FPSP
99	ASVECTOR(bsun)		/* 48: FPCP branch/set on unordered cond */
100	ASVECTOR(inex)		/* 49: FPCP inexact result */
101	ASVECTOR(dz)		/* 50: FPCP divide by zero */
102	ASVECTOR(unfl)		/* 51: FPCP underflow */
103	ASVECTOR(operr)		/* 52: FPCP operand error */
104	ASVECTOR(ovfl)		/* 53: FPCP overflow */
105	ASVECTOR(snan)		/* 54: FPCP signalling NAN */
106#else
107	VECTOR(fpfault)		/* 48: FPCP branch/set on unordered cond */
108	VECTOR(fpfault)		/* 49: FPCP inexact result */
109	VECTOR(fpfault)		/* 50: FPCP divide by zero */
110	VECTOR(fpfault)		/* 51: FPCP underflow */
111	VECTOR(fpfault)		/* 52: FPCP operand error */
112	VECTOR(fpfault)		/* 53: FPCP overflow */
113	VECTOR(fpfault)		/* 54: FPCP signalling NAN */
114#endif
115	VECTOR(fpunsupp)	/* 55: FPCP unimplemented data type */
116	VECTOR(badtrap)		/* 56: unassigned, reserved */
117	VECTOR(badtrap)		/* 57: unassigned, reserved */
118	VECTOR(badtrap)		/* 58: unassigned, reserved */
119	VECTOR(badtrap)		/* 59: unassigned, reserved */
120	VECTOR(badtrap)		/* 60: unassigned, reserved */
121	VECTOR(badtrap)		/* 61: unassigned, reserved */
122	VECTOR(badtrap)		/* 62: unassigned, reserved */
123	VECTOR(badtrap)		/* 63: unassigned, reserved */
124
125#define	BADTRAP16	\
126	VECTOR(badtrap) ; VECTOR(badtrap) ; \
127	VECTOR(badtrap) ; VECTOR(badtrap) ; \
128	VECTOR(badtrap) ; VECTOR(badtrap) ; \
129	VECTOR(badtrap) ; VECTOR(badtrap) ; \
130	VECTOR(badtrap) ; VECTOR(badtrap) ; \
131	VECTOR(badtrap) ; VECTOR(badtrap) ; \
132	VECTOR(badtrap) ; VECTOR(badtrap) ; \
133	VECTOR(badtrap) ; VECTOR(badtrap)
134
135	/*
136	 * PCC, PCCTWO, MC, and VME vectors are installed from 64-255
137	 * by the *intr_extablish() functions.
138	 */
139	BADTRAP16		/* 64-255: user interrupt vectors */
140	BADTRAP16		/* 64-255: user interrupt vectors */
141	BADTRAP16		/* 64-255: user interrupt vectors */
142	BADTRAP16		/* 64-255: user interrupt vectors */
143	BADTRAP16		/* 64-255: user interrupt vectors */
144	BADTRAP16		/* 64-255: user interrupt vectors */
145	BADTRAP16		/* 64-255: user interrupt vectors */
146	BADTRAP16		/* 64-255: user interrupt vectors */
147	BADTRAP16		/* 64-255: user interrupt vectors */
148	BADTRAP16		/* 64-255: user interrupt vectors */
149	BADTRAP16		/* 64-255: user interrupt vectors */
150	BADTRAP16		/* 64-255: user interrupt vectors */
151