cacheops_machdep.h revision 1.1 1 1.1 chs /* $NetBSD: cacheops_machdep.h,v 1.1 2002/11/02 20:03:06 chs Exp $ */
2 1.1 chs
3 1.1 chs /*
4 1.1 chs * Copyright (c) 1988 University of Utah.
5 1.1 chs * Copyright (c) 1980, 1990, 1993
6 1.1 chs * The Regents of the University of California. All rights reserved.
7 1.1 chs *
8 1.1 chs * This code is derived from software contributed to Berkeley by
9 1.1 chs * the Systems Programming Group of the University of Utah Computer
10 1.1 chs * Science Department.
11 1.1 chs *
12 1.1 chs * Redistribution and use in source and binary forms, with or without
13 1.1 chs * modification, are permitted provided that the following conditions
14 1.1 chs * are met:
15 1.1 chs * 1. Redistributions of source code must retain the above copyright
16 1.1 chs * notice, this list of conditions and the following disclaimer.
17 1.1 chs * 2. Redistributions in binary form must reproduce the above copyright
18 1.1 chs * notice, this list of conditions and the following disclaimer in the
19 1.1 chs * documentation and/or other materials provided with the distribution.
20 1.1 chs * 3. All advertising materials mentioning features or use of this software
21 1.1 chs * must display the following acknowledgement:
22 1.1 chs * This product includes software developed by the University of
23 1.1 chs * California, Berkeley and its contributors.
24 1.1 chs * 4. Neither the name of the University nor the names of its contributors
25 1.1 chs * may be used to endorse or promote products derived from this software
26 1.1 chs * without specific prior written permission.
27 1.1 chs *
28 1.1 chs * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
29 1.1 chs * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
30 1.1 chs * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
31 1.1 chs * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
32 1.1 chs * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
33 1.1 chs * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
34 1.1 chs * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
35 1.1 chs * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
36 1.1 chs * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
37 1.1 chs * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
38 1.1 chs * SUCH DAMAGE.
39 1.1 chs */
40 1.1 chs
41 1.1 chs #ifndef _NEWS68K_CACHEOPS_MACHDEP_H_
42 1.1 chs #define _NEWS68K_CACHEOPS_MACHDEP_H_
43 1.1 chs
44 1.1 chs extern void *cache_clr;
45 1.1 chs
46 1.1 chs int DCIx_md(void);
47 1.1 chs extern __inline int
48 1.1 chs DCIx_md(void)
49 1.1 chs {
50 1.1 chs volatile uint8_t *p = cache_clr;
51 1.1 chs
52 1.1 chs if (ectype != EC_VIRT) {
53 1.1 chs return 0;
54 1.1 chs }
55 1.1 chs
56 1.1 chs *p = 0xff;
57 1.1 chs return 1;
58 1.1 chs }
59 1.1 chs
60 1.1 chs int DCIA_md(void);
61 1.1 chs extern __inline int
62 1.1 chs DCIA_md(void)
63 1.1 chs {
64 1.1 chs return DCIx_md();
65 1.1 chs }
66 1.1 chs
67 1.1 chs int DCIS_md(void);
68 1.1 chs extern __inline int
69 1.1 chs DCIS_md(void)
70 1.1 chs {
71 1.1 chs return DCIx_md();
72 1.1 chs }
73 1.1 chs
74 1.1 chs int DCIU_md(void);
75 1.1 chs extern __inline int
76 1.1 chs DCIU_md(void)
77 1.1 chs {
78 1.1 chs return DCIx_md();
79 1.1 chs }
80 1.1 chs
81 1.1 chs int PCIA_md(void);
82 1.1 chs extern __inline int
83 1.1 chs PCIA_md(void)
84 1.1 chs {
85 1.1 chs volatile uint8_t *p = cache_clr;
86 1.1 chs
87 1.1 chs if (ectype != EC_PHYS) {
88 1.1 chs return 0;
89 1.1 chs }
90 1.1 chs
91 1.1 chs *p = 0xff;
92 1.1 chs return 1;
93 1.1 chs }
94 1.1 chs #endif /* _NEWS68K_CACHEOPS_MACHDEP_H_ */
95