1 /* $NetBSD: openfirm.h,v 1.1 1998/05/15 10:16:00 tsubai Exp $ */ 2 3 /*- 4 * SPDX-License-Identifier: (BSD-4-Clause AND BSD-2-Clause) 5 * 6 * Copyright (C) 1995, 1996 Wolfgang Solfrank. 7 * Copyright (C) 1995, 1996 TooLs GmbH. 8 * All rights reserved. 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 TooLs GmbH. 21 * 4. The name of TooLs GmbH may not be used to endorse or promote products 22 * derived from this software without specific prior written permission. 23 * 24 * THIS SOFTWARE IS PROVIDED BY TOOLS GMBH ``AS IS'' AND ANY EXPRESS OR 25 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 26 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 27 * IN NO EVENT SHALL TOOLS GMBH BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 28 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, 29 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; 30 * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, 31 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR 32 * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF 33 * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 34 */ 35 /* 36 * Copyright (C) 2000 Benno Rice. 37 * All rights reserved. 38 * 39 * Redistribution and use in source and binary forms, with or without 40 * modification, are permitted provided that the following conditions 41 * are met: 42 * 1. Redistributions of source code must retain the above copyright 43 * notice, this list of conditions and the following disclaimer. 44 * 2. Redistributions in binary form must reproduce the above copyright 45 * notice, this list of conditions and the following disclaimer in the 46 * documentation and/or other materials provided with the distribution. 47 * 48 * THIS SOFTWARE IS PROVIDED BY Benno Rice ``AS IS'' AND ANY EXPRESS OR 49 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 50 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 51 * IN NO EVENT SHALL TOOLS GMBH BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 52 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, 53 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; 54 * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, 55 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR 56 * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF 57 * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 58 */ 59 60 #ifndef _DEV_OPENFIRM_H_ 61 #define _DEV_OPENFIRM_H_ 62 63 #include <sys/types.h> 64 #include <machine/_bus.h> 65 66 /* 67 * Prototypes for Open Firmware Interface Routines 68 */ 69 70 typedef uint32_t ihandle_t; 71 typedef uint32_t phandle_t; 72 typedef uint32_t pcell_t; 73 74 #ifdef _KERNEL 75 #include <sys/malloc.h> 76 77 #include <machine/ofw_machdep.h> 78 79 MALLOC_DECLARE(M_OFWPROP); 80 81 /* 82 * Open Firmware interface initialization. OF_install installs the named 83 * interface as the Open Firmware access mechanism, OF_init initializes it. 84 */ 85 86 bool OF_install(char *name, int prio); 87 int OF_init(void *cookie); 88 89 /* 90 * Known Open Firmware interface names 91 */ 92 93 #define OFW_STD_DIRECT "ofw_std" /* Standard OF interface */ 94 #define OFW_STD_REAL "ofw_real" /* Real-mode OF interface */ 95 #define OFW_STD_32BIT "ofw_32bit" /* 32-bit OF interface */ 96 #define OFW_FDT "ofw_fdt" /* Flattened Device Tree */ 97 98 /* Generic functions */ 99 int OF_test(const char *name); 100 void OF_printf(const char *fmt, ...); 101 102 /* Device tree functions */ 103 phandle_t OF_peer(phandle_t node); 104 phandle_t OF_child(phandle_t node); 105 phandle_t OF_parent(phandle_t node); 106 ssize_t OF_getproplen(phandle_t node, const char *propname); 107 ssize_t OF_getprop(phandle_t node, const char *propname, void *buf, 108 size_t len); 109 ssize_t OF_getencprop(phandle_t node, const char *prop, pcell_t *buf, 110 size_t len); /* Same as getprop, but maintains endianness */ 111 int OF_hasprop(phandle_t node, const char *propname); 112 ssize_t OF_searchprop(phandle_t node, const char *propname, void *buf, 113 size_t len); 114 ssize_t OF_searchencprop(phandle_t node, const char *propname, 115 pcell_t *buf, size_t len); 116 ssize_t OF_getprop_alloc(phandle_t node, const char *propname, 117 void **buf); 118 ssize_t OF_getprop_alloc_multi(phandle_t node, const char *propname, 119 int elsz, void **buf); 120 ssize_t OF_getencprop_alloc(phandle_t node, const char *propname, 121 void **buf); 122 ssize_t OF_getencprop_alloc_multi(phandle_t node, const char *propname, 123 int elsz, void **buf); 124 void OF_prop_free(void *buf); 125 int OF_nextprop(phandle_t node, const char *propname, char *buf, 126 size_t len); 127 int OF_setprop(phandle_t node, const char *name, const void *buf, 128 size_t len); 129 ssize_t OF_canon(const char *path, char *buf, size_t len); 130 phandle_t OF_finddevice(const char *path); 131 ssize_t OF_package_to_path(phandle_t node, char *buf, size_t len); 132 133 /* 134 * Some OF implementations (IBM, FDT) have a concept of effective phandles 135 * used for device-tree cross-references. Given one of these, returns the 136 * real phandle. If one can't be found (or running on OF implementations 137 * without this property), returns its input. 138 */ 139 phandle_t OF_node_from_xref(phandle_t xref); 140 phandle_t OF_xref_from_node(phandle_t node); 141 142 /* 143 * When properties contain references to other nodes using xref handles it is 144 * often necessary to use interfaces provided by the driver for the referenced 145 * instance. These routines allow a driver that provides such an interface to 146 * register its association with an xref handle, and for other drivers to obtain 147 * the device_t associated with an xref handle. 148 */ 149 device_t OF_device_from_xref(phandle_t xref); 150 phandle_t OF_xref_from_device(device_t dev); 151 int OF_device_register_xref(phandle_t xref, device_t dev); 152 153 /* Device I/O functions */ 154 ihandle_t OF_open(const char *path); 155 void OF_close(ihandle_t instance); 156 ssize_t OF_read(ihandle_t instance, void *buf, size_t len); 157 ssize_t OF_write(ihandle_t instance, const void *buf, size_t len); 158 int OF_seek(ihandle_t instance, uint64_t where); 159 160 phandle_t OF_instance_to_package(ihandle_t instance); 161 ssize_t OF_instance_to_path(ihandle_t instance, char *buf, size_t len); 162 int OF_call_method(const char *method, ihandle_t instance, 163 int nargs, int nreturns, ...); 164 165 /* Memory functions */ 166 void *OF_claim(void *virtrequest, size_t size, u_int align); 167 void OF_release(void *virt, size_t size); 168 169 /* Control transfer functions */ 170 void OF_enter(void); 171 void OF_exit(void) __attribute__((noreturn)); 172 173 /* User interface functions */ 174 int OF_interpret(const char *cmd, int nreturns, ...); 175 176 /* 177 * Decode the Nth register property of the given device node and create a bus 178 * space tag and handle for accessing it. This is for use in setting up things 179 * like early console output before newbus is available. 180 */ 181 int OF_decode_addr(phandle_t dev, int regno, bus_space_tag_t *ptag, 182 bus_space_handle_t *phandle, bus_size_t *sz); 183 184 #endif /* _KERNEL */ 185 #endif /* _DEV_OPENFIRM_H_ */ 186