promlib.h revision 1.10
1/* $NetBSD: promlib.h,v 1.10 2003/06/25 14:38:53 martin 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 */ 60struct 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 122extern struct promops promops; 123 124/* 125 * Memory description array. 126 * Same as version 2 rom meminfo property. 127 */ 128struct memarr { 129 int zero; 130 u_int addr; 131 u_int len; 132}; 133int prom_makememarr(struct memarr *, int max, int which); 134#define MEMARR_AVAILPHYS 0 135#define MEMARR_TOTALPHYS 1 136 137struct idprom *prom_getidprom(void); 138void prom_getether(u_char *); 139 140void prom_init __P((void)); /* To setup promops */ 141 142/* Utility routines */ 143int prom_prop __P((int, char *, int, int *, void **)); 144int PROM_getprop __P((int, char *, int, int *, void **)); 145int PROM_getpropint __P((int node, char *name, int deflt)); 146char *PROM_getpropstring __P((int node, char *name)); 147char *PROM_getpropstringA __P((int node, char *name, char *, size_t)); 148void prom_printf __P((const char *, ...)); 149 150int prom_findroot __P((void)); 151int prom_findnode __P((int, const char *)); 152int prom_search __P((int, const char *)); 153int prom_opennode __P((char *)); 154int 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 162void prom_halt __P((void)) __attribute__((__noreturn__)); 163void 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 225extern void *romp; /* PROM-supplied argument (see locore) */ 226 227#endif /* _SPARC_PROMLIB_H_ */ 228