1 1.16 msaitoh /* $NetBSD: undefined.h,v 1.16 2021/12/05 04:42:55 msaitoh Exp $ */ 2 1.1 reinoud 3 1.1 reinoud /* 4 1.1 reinoud * Copyright (c) 1995-1996 Mark Brinicombe. 5 1.1 reinoud * Copyright (c) 1995 Brini. 6 1.1 reinoud * All rights reserved. 7 1.1 reinoud * 8 1.1 reinoud * This code is derived from software written for Brini by Mark Brinicombe 9 1.1 reinoud * 10 1.1 reinoud * Redistribution and use in source and binary forms, with or without 11 1.1 reinoud * modification, are permitted provided that the following conditions 12 1.1 reinoud * are met: 13 1.1 reinoud * 1. Redistributions of source code must retain the above copyright 14 1.1 reinoud * notice, this list of conditions and the following disclaimer. 15 1.1 reinoud * 2. Redistributions in binary form must reproduce the above copyright 16 1.1 reinoud * notice, this list of conditions and the following disclaimer in the 17 1.1 reinoud * documentation and/or other materials provided with the distribution. 18 1.1 reinoud * 3. All advertising materials mentioning features or use of this software 19 1.1 reinoud * must display the following acknowledgement: 20 1.1 reinoud * This product includes software developed by Brini. 21 1.1 reinoud * 4. The name of the company nor the name of the author may be used to 22 1.1 reinoud * endorse or promote products derived from this software without specific 23 1.1 reinoud * prior written permission. 24 1.1 reinoud * 25 1.1 reinoud * THIS SOFTWARE IS PROVIDED BY BRINI ``AS IS'' AND ANY EXPRESS OR IMPLIED 26 1.1 reinoud * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF 27 1.1 reinoud * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 28 1.1 reinoud * IN NO EVENT SHALL BRINI OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, 29 1.1 reinoud * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES 30 1.1 reinoud * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR 31 1.1 reinoud * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 32 1.1 reinoud * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 33 1.1 reinoud * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 34 1.1 reinoud * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 35 1.1 reinoud * SUCH DAMAGE. 36 1.1 reinoud * 37 1.1 reinoud * RiscBSD kernel project 38 1.1 reinoud * 39 1.1 reinoud * undefined.h 40 1.1 reinoud * 41 1.1 reinoud * Undefined instruction types, symbols and prototypes 42 1.1 reinoud * 43 1.1 reinoud * Created : 08/02/95 44 1.1 reinoud */ 45 1.1 reinoud 46 1.2 bjh21 47 1.2 bjh21 #ifndef _ARM_UNDEFINED_H_ 48 1.2 bjh21 #define _ARM_UNDEFINED_H_ 49 1.1 reinoud #ifdef _KERNEL 50 1.1 reinoud 51 1.2 bjh21 #include <sys/queue.h> 52 1.2 bjh21 53 1.12 dsl typedef int (*undef_handler_t)(unsigned int, unsigned int, trapframe_t *, int); 54 1.1 reinoud 55 1.9 rearnsha /* 56 1.9 rearnsha * Enumeration of coprocessor numbers. Values may be duplicated 57 1.9 rearnsha * (the iWMMX coprocessor clashes with the FPA, for example), but 58 1.9 rearnsha * keep this table in numeric order. 59 1.5 rearnsha */ 60 1.9 rearnsha enum arm_coprocs { 61 1.9 rearnsha FPA_COPROC = 1, 62 1.9 rearnsha FPA_COPROC2 = 2, 63 1.11 rearnsha VFP_COPROC = 10, 64 1.11 rearnsha VFP_COPROC2 = 11, 65 1.9 rearnsha DEBUG_COPROC = 14, 66 1.9 rearnsha SYSTEM_COPROC = 15, 67 1.13 skrll /* 68 1.14 skrll * The following are not really co-processors, but are on the end 69 1.9 rearnsha * of the unknown instruction table for each coproc. 70 1.9 rearnsha */ 71 1.9 rearnsha CORE_UNKNOWN_HANDLER = 16, 72 1.9 rearnsha #ifdef THUMB_CODE 73 1.9 rearnsha THUMB_UNKNOWN_HANDLER = 17, 74 1.9 rearnsha #endif 75 1.9 rearnsha NUM_UNKNOWN_HANDLERS /* Last entry */ 76 1.9 rearnsha }; 77 1.5 rearnsha 78 1.1 reinoud /* Prototypes for undefined.c */ 79 1.1 reinoud 80 1.12 dsl void *install_coproc_handler(int, undef_handler_t); 81 1.15 skrll void replace_coproc_handler(int, undef_handler_t); 82 1.12 dsl void remove_coproc_handler(void *); 83 1.12 dsl void undefined_init(void); 84 1.1 reinoud 85 1.2 bjh21 /* 86 1.15 skrll * Stuff below here is for use before kmem(9) is available. Most code 87 1.2 bjh21 * shouldn't use it. 88 1.2 bjh21 */ 89 1.2 bjh21 90 1.2 bjh21 struct undefined_handler { 91 1.2 bjh21 LIST_ENTRY(undefined_handler) uh_link; 92 1.2 bjh21 undef_handler_t uh_handler; 93 1.2 bjh21 }; 94 1.2 bjh21 95 1.2 bjh21 /* 96 1.2 bjh21 * Handlers installed using install_coproc_handler_static shouldn't be 97 1.16 msaitoh * removed. We special case the 'test vfp existence' handler. 98 1.2 bjh21 */ 99 1.12 dsl void install_coproc_handler_static(int, struct undefined_handler *); 100 1.3 bjh21 101 1.3 bjh21 /* Calls up to undefined.c from trap handlers */ 102 1.3 bjh21 void undefinedinstruction(struct trapframe *); 103 1.2 bjh21 104 1.1 reinoud #endif 105 1.1 reinoud 106 1.1 reinoud /* End of undefined.h */ 107 1.2 bjh21 108 1.2 bjh21 #endif /* _ARM_UNDEFINED_H_ */ 109