/* $OpenBSD: autoconf.h,v 1.20 2009/10/16 00:15:48 miod Exp $ */ /* * Copyright (c) 2001-2003 Opsycon AB (www.opsycon.se / www.opsycon.com) * * 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. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 AUTHOR 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. * */ /* * Definitions used by autoconfiguration. */ #ifndef _MACHINE_AUTOCONF_H_ #define _MACHINE_AUTOCONF_H_ #include /* * Structure holding all misc config information. */ #define MAX_CPUS 4 struct sys_rec { int system_type; struct cpuinfo { u_int16_t type; u_int8_t vers_maj; u_int8_t vers_min; u_int16_t fptype; u_int8_t fpvers_maj; u_int8_t fpvers_min; u_int32_t clock; u_int32_t clock_bus; u_int32_t tlbsize; u_int32_t tlbwired; } cpu[MAX_CPUS]; /* Published cache operations. */ void (*_SyncCache)(void); void (*_InvalidateICache)(vaddr_t, int); void (*_SyncDCachePage)(vaddr_t); void (*_HitSyncDCache)(vaddr_t, int); void (*_IOSyncDCache)(vaddr_t, int, int); void (*_HitInvalidateDCache)(vaddr_t, int); /* Serial console configuration. */ struct mips_bus_space console_io; }; extern struct sys_rec sys_config; struct confargs { char *ca_name; int16_t ca_nasid; bus_space_tag_t ca_iot; bus_dma_tag_t ca_dmat; /* XXX the following are macebus-specific */ bus_space_tag_t ca_memt; int32_t ca_intr; bus_addr_t ca_baseaddr; }; void enaddr_aton(const char *, u_int8_t *); u_long bios_getenvint(const char *); struct device; void ip27_setup(void); void ip27_autoconf(struct device *); void ip30_setup(void); void ip32_setup(void); extern char osloadpartition[256]; extern int16_t masternasid; #endif /* _MACHINE_AUTOCONF_H_ */