zig

fork of https://codeberg.org/ziglang/zig
Log | Files | Refs | README | LICENSE

openfirm.h (7627B) - Raw


      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 boolean_t	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_ */