summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sys/arch/sparc64/include/autoconf.h182
-rw-r--r--sys/arch/sparc64/include/sparc64.h75
2 files changed, 257 insertions, 0 deletions
diff --git a/sys/arch/sparc64/include/autoconf.h b/sys/arch/sparc64/include/autoconf.h
new file mode 100644
index 00000000000..c0b8e800d20
--- /dev/null
+++ b/sys/arch/sparc64/include/autoconf.h
@@ -0,0 +1,182 @@
+/* $NetBSD: autoconf.h,v 1.10 2001/07/24 19:32:11 eeh Exp $ */
+
+/*-
+ * Copyright (c) 1997, 1998 The NetBSD Foundation, Inc.
+ * All rights reserved.
+ *
+ * This code is derived from software contributed to The NetBSD Foundation
+ * by Paul Kranenburg.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ * 3. All advertising materials mentioning features or use of this software
+ * must display the following acknowledgement:
+ * This product includes software developed by the NetBSD
+ * Foundation, Inc. and its contributors.
+ * 4. Neither the name of The NetBSD Foundation nor the names of its
+ * contributors may be used to endorse or promote products derived
+ * from this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
+ * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
+ * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
+ * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
+ * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+ * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
+ * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
+ * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
+ * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
+ * POSSIBILITY OF SUCH DAMAGE.
+ */
+
+/*
+ * Copyright (c) 1992, 1993
+ * The Regents of the University of California. All rights reserved.
+ *
+ * This software was developed by the Computer Systems Engineering group
+ * at Lawrence Berkeley Laboratory under DARPA contract BG 91-66 and
+ * contributed to Berkeley.
+ *
+ * All advertising materials mentioning features or use of this software
+ * must display the following acknowledgement:
+ * This product includes software developed by the University of
+ * California, Lawrence Berkeley Laboratory.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ * 3. All advertising materials mentioning features or use of this software
+ * must display the following acknowledgement:
+ * This product includes software developed by the University of
+ * California, Berkeley and its contributors.
+ * 4. Neither the name of the University nor the names of its contributors
+ * may be used to endorse or promote products derived from this software
+ * without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
+ * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
+ * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
+ * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
+ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
+ * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
+ *
+ * @(#)autoconf.h 8.2 (Berkeley) 9/30/93
+ */
+
+/*
+ * Autoconfiguration information.
+ */
+
+#include <machine/bus.h>
+#include <sparc64/dev/upavar.h>
+#include <dev/sbus/sbusvar.h>
+
+/* This is used to map device classes to IPLs */
+struct intrmap {
+ char *in_class;
+ int in_lev;
+};
+extern struct intrmap intrmap[];
+
+/* The "mainbus" on ultra desktops is actually the UPA bus. We need to
+ * separate this from peripheral buses like SBUS and PCI because each bus may
+ * have different ways of encoding properties, such as "reg" and "interrupts".
+ *
+ * Eventually I'll create a real UPA bus module to allow servers with multiple
+ * peripheral buses and things like FHC bus systems.
+ */
+
+/*
+ * Attach arguments presented by mainbus_attach()
+ *
+ * Large fields first followed by smaller ones to minimize stack space used.
+ */
+struct mainbus_attach_args {
+ bus_space_tag_t ma_bustag; /* parent bus tag */
+ bus_dma_tag_t ma_dmatag;
+ char *ma_name; /* PROM node name */
+ struct upa_reg *ma_reg; /* "reg" properties */
+ u_int *ma_address; /* "address" properties -- 32 bits */
+ u_int *ma_interrupts; /* "interrupts" properties */
+ int ma_upaid; /* UPA bus ID */
+ int ma_node; /* PROM handle */
+ int ma_nreg; /* Counts for those properties */
+ int ma_naddress;
+ int ma_ninterrupts;
+ int ma_pri; /* priority (IPL) */
+};
+
+/*
+ * length; the others convert or make some other guarantee.
+ */
+long getproplen __P((int node, char *name));
+int getprop __P((int, char *, size_t, int *, void **));
+char *getpropstring __P((int node, char *name));
+int getpropint __P((int node, char *name, int deflt));
+
+/* Frequently used options node */
+extern int optionsnode;
+
+ /* new interfaces: */
+char *getpropstringA __P((int, char *, char *));
+
+/*
+ * The matchbyname function is useful in drivers that are matched
+ * by romaux name, i.e., all `mainbus attached' devices. It expects
+ * its aux pointer to point to a pointer to the name (the address of
+ * a romaux structure suffices, for instance). (OBSOLETE)
+ */
+struct device;
+struct cfdata;
+int matchbyname __P((struct device *, struct cfdata *cf, void *aux));
+
+/*
+ * `clockfreq' produces a printable representation of a clock frequency
+ * (this is just a frill).
+ */
+char *clockfreq __P((long freq));
+
+/* Openprom V2 style boot path */
+struct bootpath {
+ char name[16]; /* name of this node */
+ int val[3]; /* up to three optional values */
+ struct device *dev; /* device that recognised this component */
+};
+struct bootpath *bootpath_store __P((int, struct bootpath *));
+int sd_crazymap __P((int));
+
+/* Parse a disk string into a dev_t, return device struct pointer */
+struct device *parsedisk __P((char *, int, int, dev_t *));
+
+/* Establish a mountroot_hook, for benefit of floppy drive, mostly. */
+void mountroot_hook_establish __P((void (*) __P((struct device *)),
+ struct device *));
+
+void bootstrap __P((int));
+int firstchild __P((int));
+int nextsibling __P((int));
+void callrom __P((void));
+struct device *getdevunit __P((char *, int));
+void *findzs __P((int));
+int romgetcursoraddr __P((int **, int **));
+int findroot __P((void));
+int findnode __P((int, const char *));
+int node_has_property __P((int, const char *));
+
diff --git a/sys/arch/sparc64/include/sparc64.h b/sys/arch/sparc64/include/sparc64.h
new file mode 100644
index 00000000000..d714b49ec8b
--- /dev/null
+++ b/sys/arch/sparc64/include/sparc64.h
@@ -0,0 +1,75 @@
+/* $NetBSD: sparc64.h,v 1.3 2000/10/20 05:47:03 mrg Exp $ */
+
+/*
+ * Copyright (C) 1996 Wolfgang Solfrank.
+ * Copyright (C) 1996 TooLs GmbH.
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ * 3. All advertising materials mentioning features or use of this software
+ * must display the following acknowledgement:
+ * This product includes software developed by TooLs GmbH.
+ * 4. The name of TooLs GmbH may not be used to endorse or promote products
+ * derived from this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY TOOLS GMBH ``AS IS'' AND ANY EXPRESS OR
+ * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
+ * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
+ * IN NO EVENT SHALL TOOLS GMBH BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+ * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
+ * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
+ * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
+ * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
+ * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
+ * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ */
+#ifndef _MACHINE_SPARC64_H_
+#define _MACHINE_SPARC64_H_
+
+struct mem_region {
+ u_int64_t start;
+ u_int64_t size;
+};
+
+int prom_set_trap_table __P((vaddr_t tba));
+u_int64_t prom_vtop __P((vaddr_t vaddr));
+vaddr_t prom_claim_virt __P((vaddr_t vaddr, int len));
+vaddr_t prom_alloc_virt __P((int len, int align));
+int prom_free_virt __P((vaddr_t vaddr, int len));
+int prom_unmap_virt __P((vaddr_t vaddr, int len));
+int prom_map_phys __P((u_int64_t paddr, off_t size, vaddr_t vaddr, int mode));
+u_int64_t prom_alloc_phys __P((int len, int align));
+u_int64_t prom_claim_phys __P((paddr_t phys, int len));
+int prom_free_phys __P((paddr_t paddr, int len));
+u_int64_t prom_get_msgbuf __P((int len, int align));
+
+/*
+ * Compatibility stuff.
+ */
+#define OF_findroot() OF_peer(0)
+#define OF_fd_phandle(x) OF_instance_to_package(x)
+
+/*
+ * These two functions get used solely in boot() in machdep.c.
+ *
+ * Not sure whether boot itself should be implementation dependent instead. XXX
+ */
+void ppc_exit __P((void)) __attribute__((__noreturn__));
+void ppc_boot __P((char *bootspec)) __attribute__((__noreturn__));
+
+int dk_match __P((char *name));
+
+void ofrootfound __P((void));
+
+/*
+ * Debug
+ */
+void prom_printf __P((const char *, ...));
+#endif /* _MACHINE_SPARC64_H_ */