bi_mainbus.c revision 1.7
11.7Sthorpej/* $NetBSD: bi_mainbus.c,v 1.7 2002/10/02 16:02:31 thorpej Exp $ */ 21.1Sragge/* 31.1Sragge * Copyright (c) 1999 Ludd, University of Lule}, Sweden. 41.1Sragge * All rights reserved. 51.1Sragge * 61.1Sragge * Redistribution and use in source and binary forms, with or without 71.1Sragge * modification, are permitted provided that the following conditions 81.1Sragge * are met: 91.1Sragge * 1. Redistributions of source code must retain the above copyright 101.1Sragge * notice, this list of conditions and the following disclaimer. 111.1Sragge * 2. Redistributions in binary form must reproduce the above copyright 121.1Sragge * notice, this list of conditions and the following disclaimer in the 131.1Sragge * documentation and/or other materials provided with the distribution. 141.1Sragge * 3. All advertising materials mentioning features or use of this software 151.1Sragge * must display the following acknowledgement: 161.1Sragge * This product includes software developed at Ludd, University of 171.1Sragge * Lule}, Sweden and its contributors. 181.1Sragge * 4. The name of the author may not be used to endorse or promote products 191.1Sragge * derived from this software without specific prior written permission 201.1Sragge * 211.1Sragge * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR 221.1Sragge * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 231.1Sragge * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 241.1Sragge * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, 251.1Sragge * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 261.1Sragge * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 271.1Sragge * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 281.1Sragge * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 291.1Sragge * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF 301.1Sragge * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 311.1Sragge */ 321.1Sragge 331.1Sragge#include <sys/param.h> 341.1Sragge#include <sys/device.h> 351.1Sragge 361.1Sragge#define _VAX_BUS_DMA_PRIVATE 371.1Sragge#include <machine/bus.h> 381.1Sragge#include <machine/nexus.h> 391.1Sragge#include <machine/sid.h> 401.2Sragge#include <machine/scb.h> 411.2Sragge#include <machine/cpu.h> 421.1Sragge 431.1Sragge#include <dev/bi/bivar.h> 441.4Sragge#include <dev/bi/bireg.h> 451.1Sragge 461.1Sraggestatic int bi_mainbus_match __P((struct device *, struct cfdata *, void *)); 471.1Sraggestatic void bi_mainbus_attach __P((struct device *, struct device *, void *)); 481.1Sragge 491.6SthorpejCFATTACH_DECL(bi_mainbus, sizeof(struct bi_softc), 501.7Sthorpej bi_mainbus_match, bi_mainbus_attach, NULL, NULL); 511.1Sragge 521.1Sraggeextern struct vax_bus_space vax_mem_bus_space; 531.1Sraggeextern struct vax_bus_dma_tag vax_bus_dma_tag; 541.1Sragge 551.3Smattstatic int 561.3Smattbi_mainbus_match(struct device *parent, struct cfdata *vcf, void *aux) 571.1Sragge{ 581.1Sragge if (vax_bustype == VAX_BIBUS) 591.1Sragge return 1; 601.1Sragge return 0; 611.1Sragge} 621.1Sragge 631.3Smattstatic void 641.3Smattbi_mainbus_attach(struct device *parent, struct device *self, void *aux) 651.1Sragge{ 661.1Sragge struct bi_softc *sc = (void *)self; 671.1Sragge 681.1Sragge /* 691.1Sragge * Fill in bus specific data. 701.1Sragge */ 711.4Sragge sc->sc_addr = (bus_addr_t)BI_BASE(0, 0); 721.1Sragge sc->sc_iot = &vax_mem_bus_space; /* No special I/O handling */ 731.1Sragge sc->sc_dmat = &vax_bus_dma_tag; /* No special DMA handling either */ 741.4Sragge sc->sc_intcpu = 1 << mfpr(PR_BINID); 751.4Sragge sc->sc_lastiv = 256; /* Lowest available vector address */ 761.1Sragge 771.1Sragge bi_attach(sc); 781.1Sragge} 79