xref: /netbsd-src/sys/arch/sparc/include/promlib.h (revision d20841bb642898112fe68f0ad3f7b26dddf56f07)
1 /*	$NetBSD: promlib.h,v 1.11 2003/08/27 15:59:50 mrg Exp $ */
2 
3 /*-
4  * Copyright (c) 1999 The NetBSD Foundation, Inc.
5  * All rights reserved.
6  *
7  * This code is derived from software contributed to The NetBSD Foundation
8  * by Paul Kranenburg.
9  *
10  * Redistribution and use in source and binary forms, with or without
11  * modification, are permitted provided that the following conditions
12  * are met:
13  * 1. Redistributions of source code must retain the above copyright
14  *    notice, this list of conditions and the following disclaimer.
15  * 2. Redistributions in binary form must reproduce the above copyright
16  *    notice, this list of conditions and the following disclaimer in the
17  *    documentation and/or other materials provided with the distribution.
18  * 3. All advertising materials mentioning features or use of this software
19  *    must display the following acknowledgement:
20  *        This product includes software developed by the NetBSD
21  *        Foundation, Inc. and its contributors.
22  * 4. Neither the name of The NetBSD Foundation nor the names of its
23  *    contributors may be used to endorse or promote products derived
24  *    from this software without specific prior written permission.
25  *
26  * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
27  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
28  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
29  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
30  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
31  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
32  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
33  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
34  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
35  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
36  * POSSIBILITY OF SUCH DAMAGE.
37  */
38 
39 /*
40  * OPENPROM functions.  These are here mainly to hide the OPENPROM interface
41  * from the rest of the kernel.
42  */
43 
44 #ifndef _SPARC_PROMLIB_H_
45 #define _SPARC_PROMLIB_H_
46 
47 #ifdef _KERNEL_OPT
48 #include "opt_multiprocessor.h"
49 #endif
50 
51 #include <machine/idprom.h>
52 #include <machine/bsd_openprom.h>
53 #include <machine/openfirm.h>
54 
55 /*
56  * A set of methods to access the firmware.
57  * We use this to support various versions of Open Boot Prom
58  * or Open Firmware implementations.
59  */
60 struct promops {
61 	int	po_version;		/* PROM version number */
62 #define PROM_OLDMON	0
63 #define PROM_OBP_V0	1
64 #define PROM_OBP_V2	2
65 #define PROM_OBP_V3	3
66 #define PROM_OPENFIRM	4
67 	int	po_revision;		/* revision level */
68 	int	po_stdin;		/* stdio handles */
69 	int	po_stdout;		/* */
70 	void	*po_bootcookie;
71 
72 	/* Access to boot arguments */
73 	char	*(*po_bootpath) __P((void));
74 	char	*(*po_bootfile) __P((void));
75 	char	*(*po_bootargs) __P((void));
76 
77 	/* I/O functions */
78 	int	(*po_getchar) __P((void));
79 	int	(*po_peekchar) __P((void));
80 	void	(*po_putchar) __P((int));
81 	void	(*po_putstr) __P((char *, int));
82 	int	(*po_open) __P((char *));
83 	void	(*po_close) __P((int));
84 	int	(*po_read) __P((int, void *, int));
85 	int	(*po_write) __P((int, void *, int));
86 	int	(*po_seek) __P((int, u_quad_t));
87 
88 	int	(*po_instance_to_package) __P((int));
89 
90 	/* Misc functions (common in OBP 0,2,3) */
91 	void	(*po_halt) __P((void))		__attribute__((__noreturn__));
92 	void	(*po_reboot) __P((char *))	__attribute__((__noreturn__));
93 	void	(*po_abort) __P((void));
94 	void	(*po_interpret) __P((char *));
95 	void	(*po_setcallback) __P((void (*)__P((void))));
96 	int	(*po_ticks) __P((void));
97 	void	*po_tickdata;
98 
99 	/* sun4/sun4c only */
100 	void	(*po_setcontext) __P((int ctxt, caddr_t va, int pmeg));
101 
102 	/* MP functions (OBP v3 only) */
103 	int	(*po_cpustart) __P((int, struct openprom_addr *, int, caddr_t));
104 	int	(*po_cpustop) __P((int));
105 	int	(*po_cpuidle) __P((int));
106 	int	(*po_cpuresume) __P((int));
107 
108 	/* Device node traversal (OBP v0, v2, v3; but not sun4) */
109 	int	(*po_firstchild) __P((int));
110 	int	(*po_nextsibling) __P((int));
111 
112 	/* Device node properties */
113 	int	(*po_getproplen) __P((int node, char *name));
114 	int	(*po_getprop) __P((int node, char *name, void *, int));
115 	int	(*po_setprop) __P((int node, char *name, const void *, int));
116 	char	*(*po_nextprop) __P((int node, char *name));
117 
118 	int	(*po_finddevice) __P((char *name));
119 
120 };
121 
122 extern struct promops	promops;
123 
124 /*
125  * Memory description array.
126  * Same as version 2 rom meminfo property.
127  */
128 struct memarr {
129 	int	zero;
130 	u_int	addr;
131 	u_int	len;
132 };
133 int	prom_makememarr(struct memarr *, int max, int which);
134 #define	MEMARR_AVAILPHYS	0
135 #define	MEMARR_TOTALPHYS	1
136 
137 struct idprom	*prom_getidprom(void);
138 void		prom_getether(u_char *);
139 
140 void	prom_init	__P((void));	/* To setup promops */
141 
142 /* Utility routines */
143 int	prom_prop	__P((int, char *, int, int *, void **));
144 int	PROM_getprop		__P((int, char *, int, int *, void *));
145 int	PROM_getpropint	__P((int node, char *name, int deflt));
146 char	*PROM_getpropstring	__P((int node, char *name));
147 char	*PROM_getpropstringA	__P((int node, char *name, char *, size_t));
148 void	prom_printf	__P((const char *, ...));
149 
150 int	prom_findroot	__P((void));
151 int	prom_findnode	__P((int, const char *));
152 int	prom_search	__P((int, const char *));
153 int	prom_opennode	__P((char *));
154 int	prom_node_has_property __P((int, const char *));
155 
156 #define	findroot()		prom_findroot()
157 #define	findnode(node,name)	prom_findnode(node,name)
158 #define	search_prom(node,name)	prom_search(node,name)
159 #define	opennode(name)		prom_opennode(name)
160 #define	node_has_property(node,prop)	prom_node_has_property(node,prop)
161 
162 void	prom_halt __P((void))	__attribute__((__noreturn__));
163 void	prom_boot __P((char *))	__attribute__((__noreturn__));
164 
165 #if defined(MULTIPROCESSOR)
166 #define callrom() do {		\
167 	mp_pause_cpus();	\
168 	prom_abort();		\
169 	mp_resume_cpus();	\
170 } while (0)
171 #else
172 #define callrom()		prom_abort()
173 #endif
174 
175 #define prom_version()		(promops.po_version)
176 #define prom_revision()		(promops.po_revision)
177 #define prom_stdin()		(promops.po_stdin)
178 #define prom_stdout()		(promops.po_stdout)
179 #define _prom_halt()		((*promops.po_halt)(/*void*/))
180 #define _prom_boot(a)		((*promops.po_reboot)(a))
181 #define prom_abort()		((*promops.po_abort)(/*void*/))
182 #define prom_interpret(a)	((*promops.po_interpret)(a))
183 #define prom_setcallback(f)	((*promops.po_setcallback)(f))
184 #define prom_setcontext(c,a,p)	((*promops.po_setcontext)(c,a,p))
185 #define prom_getbootpath()	((*promops.po_bootpath)(/*void*/))
186 #define prom_getbootfile()	((*promops.po_bootfile)(/*void*/))
187 #define prom_getbootargs()	((*promops.po_bootargs)(/*void*/))
188 #define prom_ticks()		((*promops.po_ticks)(/*void*/))
189 
190 
191 #define prom_open(name)		((*promops.po_open)(name))
192 #define prom_close(fd)		((*promops.po_close)(fd))
193 #define prom_instance_to_package(fd) \
194 				((*promops.po_instance_to_package)(fd))
195 #define prom_read(fd,b,n)	((*promops.po_read)(fd,b,n))
196 #define prom_write(fd,b,n)	((*promops.po_write)(fd,b,n))
197 #define prom_seek(fd,o)		((*promops.po_seek)(fd,o))
198 #define prom_getchar()		((*promops.po_getchar)(/*void*/))
199 #define prom_peekchar()		((*promops.po_peekchar)(/*void*/))
200 #define prom_putchar(c)		((*promops.po_putchar)(c))
201 #define prom_putstr(b,n)	((*promops.po_putstr)(b,n))
202 
203 /* Node traversal */
204 #define prom_firstchild(node)	((*promops.po_firstchild)(node))
205 #define prom_nextsibling(node)	((*promops.po_nextsibling)(node))
206 #define prom_proplen(node,name)	((*promops.po_getproplen)(node, name))
207 #define _prom_getprop(node, name, buf, len) \
208 				((*promops.po_getprop)(node, name, buf, len))
209 #define prom_setprop(node, name, value, len) \
210 				((*promops.po_setprop)(node, name, value, len))
211 #define prom_nextprop(node,name)	((*promops.po_nextprop)(node, name))
212 #define prom_finddevice(name)	((*promops.po_finddevice)(name))
213 
214 #define firstchild(node)	prom_firstchild(node)
215 #define nextsibling(node)	prom_nextsibling(node)
216 #define PROM_getproplen(node,name)	prom_proplen(node, name)
217 
218 
219 /* MP stuff - not currently used */
220 #define prom_cpustart(m,a,c,pc)	((*promops.po_cpustart)(m,a,c,pc))
221 #define prom_cpustop(m)		((*promops.po_cpustop)(m))
222 #define prom_cpuidle(m)		((*promops.po_cpuidle)(m))
223 #define prom_cpuresume(m)	((*promops.po_cpuresume)(m))
224 
225 extern void	*romp;		/* PROM-supplied argument (see locore) */
226 
227 #endif /* _SPARC_PROMLIB_H_ */
228