undefined.h revision 1.9 1 1.9 rearnsha /* $NetBSD: undefined.h,v 1.9 2004/08/21 12:03:16 rearnsha 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.1 reinoud typedef int (*undef_handler_t) __P((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.9 rearnsha DEBUG_COPROC = 14,
64 1.9 rearnsha SYSTEM_COPROC = 15,
65 1.9 rearnsha /*
66 1.9 rearnsha *The following are not really co-processors, but are on the end
67 1.9 rearnsha * of the unknown instruction table for each coproc.
68 1.9 rearnsha */
69 1.9 rearnsha CORE_UNKNOWN_HANDLER = 16,
70 1.9 rearnsha #ifdef THUMB_CODE
71 1.9 rearnsha THUMB_UNKNOWN_HANDLER = 17,
72 1.9 rearnsha #endif
73 1.9 rearnsha NUM_UNKNOWN_HANDLERS /* Last entry */
74 1.9 rearnsha };
75 1.5 rearnsha
76 1.1 reinoud /* Prototypes for undefined.c */
77 1.1 reinoud
78 1.2 bjh21 void *install_coproc_handler __P((int, undef_handler_t));
79 1.2 bjh21 void remove_coproc_handler __P((void *));
80 1.1 reinoud void undefined_init __P((void));
81 1.1 reinoud
82 1.2 bjh21 /*
83 1.2 bjh21 * XXX Stuff below here is for use before malloc() is available. Most code
84 1.2 bjh21 * shouldn't use it.
85 1.2 bjh21 */
86 1.2 bjh21
87 1.2 bjh21 struct undefined_handler {
88 1.2 bjh21 LIST_ENTRY(undefined_handler) uh_link;
89 1.2 bjh21 undef_handler_t uh_handler;
90 1.2 bjh21 };
91 1.2 bjh21
92 1.2 bjh21 /*
93 1.2 bjh21 * Handlers installed using install_coproc_handler_static shouldn't be
94 1.2 bjh21 * removed.
95 1.2 bjh21 */
96 1.2 bjh21 void install_coproc_handler_static __P((int, struct undefined_handler *));
97 1.3 bjh21
98 1.3 bjh21 /* Calls up to undefined.c from trap handlers */
99 1.3 bjh21 void undefinedinstruction(struct trapframe *);
100 1.2 bjh21
101 1.1 reinoud #endif
102 1.1 reinoud
103 1.1 reinoud /* End of undefined.h */
104 1.2 bjh21
105 1.2 bjh21 #endif /* _ARM_UNDEFINED_H_ */
106