1| $NetBSD: vectors.s,v 1.8 2002/09/11 01:46:36 mycroft 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#if 1 71 VECTOR(spurintr) /* 24: spurious interrupt */ 72#else 73 VECTOR(intrhand_autovec) 74#endif 75 VECTOR(intrhand_autovec) /* 25: level 1 interrupt autovector */ 76 VECTOR(intrhand_autovec) /* 26: level 2 interrupt autovector */ 77 VECTOR(intrhand_autovec) /* 27: level 3 interrupt autovector */ 78 VECTOR(intrhand_autovec) /* 28: level 4 interrupt autovector */ 79 VECTOR(intrhand_autovec) /* 29: level 5 interrupt autovector */ 80 VECTOR(intrhand_autovec) /* 30: level 6 interrupt autovector */ 81#if 1 82 VECTOR(lev7intr) /* 31: level 7 interrupt autovector */ 83#else 84 VECTOR(intrhand_autovec) 85#endif 86 VECTOR(trap0) /* 32: syscalls */ 87#ifdef COMPAT_13 88 VECTOR(trap1) /* 33: compat_13_sigreturn */ 89#else 90 VECTOR(illinst) 91#endif 92 VECTOR(trap2) /* 34: trace */ 93 VECTOR(trap3) /* 35: sigreturn special syscall */ 94 VECTOR(illinst) /* 36: TRAP instruction vector */ 95 VECTOR(illinst) /* 37: TRAP instruction vector */ 96 VECTOR(illinst) /* 38: TRAP instruction vector */ 97 VECTOR(illinst) /* 39: TRAP instruction vector */ 98 VECTOR(illinst) /* 40: TRAP instruction vector */ 99 VECTOR(illinst) /* 41: TRAP instruction vector */ 100 VECTOR(illinst) /* 42: TRAP instruction vector */ 101 VECTOR(illinst) /* 43: TRAP instruction vector */ 102 VECTOR(trap12) /* 44: TRAP instruction vector */ 103 VECTOR(illinst) /* 45: TRAP instruction vector */ 104 VECTOR(illinst) /* 46: TRAP instruction vector */ 105 VECTOR(trap15) /* 47: TRAP instruction vector */ 106#ifdef FPSP 107 ASVECTOR(bsun) /* 48: FPCP branch/set on unordered cond */ 108 ASVECTOR(inex) /* 49: FPCP inexact result */ 109 ASVECTOR(dz) /* 50: FPCP divide by zero */ 110 ASVECTOR(unfl) /* 51: FPCP underflow */ 111 ASVECTOR(operr) /* 52: FPCP operand error */ 112 ASVECTOR(ovfl) /* 53: FPCP overflow */ 113 ASVECTOR(snan) /* 54: FPCP signalling NAN */ 114#else 115 VECTOR(fpfault) /* 48: FPCP branch/set on unordered cond */ 116 VECTOR(fpfault) /* 49: FPCP inexact result */ 117 VECTOR(fpfault) /* 50: FPCP divide by zero */ 118 VECTOR(fpfault) /* 51: FPCP underflow */ 119 VECTOR(fpfault) /* 52: FPCP operand error */ 120 VECTOR(fpfault) /* 53: FPCP overflow */ 121 VECTOR(fpfault) /* 54: FPCP signalling NAN */ 122#endif 123 VECTOR(fpunsupp) /* 55: FPCP unimplemented data type */ 124 VECTOR(badtrap) /* 56: unassigned, reserved */ 125 VECTOR(badtrap) /* 57: unassigned, reserved */ 126 VECTOR(badtrap) /* 58: unassigned, reserved */ 127 VECTOR(badtrap) /* 59: unassigned, reserved */ 128 VECTOR(badtrap) /* 60: unassigned, reserved */ 129 VECTOR(badtrap) /* 61: unassigned, reserved */ 130 VECTOR(badtrap) /* 62: unassigned, reserved */ 131 VECTOR(badtrap) /* 63: unassigned, reserved */ 132 133#define BADTRAP16 \ 134 VECTOR(badtrap) ; VECTOR(badtrap) ; \ 135 VECTOR(badtrap) ; VECTOR(badtrap) ; \ 136 VECTOR(badtrap) ; VECTOR(badtrap) ; \ 137 VECTOR(badtrap) ; VECTOR(badtrap) ; \ 138 VECTOR(badtrap) ; VECTOR(badtrap) ; \ 139 VECTOR(badtrap) ; VECTOR(badtrap) ; \ 140 VECTOR(badtrap) ; VECTOR(badtrap) ; \ 141 VECTOR(badtrap) ; VECTOR(badtrap) 142 143 /* 144 * PCC, PCCTWO, MC, and VME vectors are installed from 64-255 145 * by the *intr_extablish() functions. 146 */ 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 BADTRAP16 /* 64-255: user interrupt vectors */ 152 BADTRAP16 /* 64-255: user interrupt vectors */ 153 BADTRAP16 /* 64-255: user interrupt vectors */ 154 BADTRAP16 /* 64-255: user interrupt vectors */ 155 BADTRAP16 /* 64-255: user interrupt vectors */ 156 BADTRAP16 /* 64-255: user interrupt vectors */ 157 BADTRAP16 /* 64-255: user interrupt vectors */ 158 BADTRAP16 /* 64-255: user interrupt vectors */ 159