bi_mainbus.c revision 1.10
11.10Smatt/* $NetBSD: bi_mainbus.c,v 1.10 2008/03/11 05:34:02 matt 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.8Slukem 331.8Slukem#include <sys/cdefs.h> 341.10Smatt__KERNEL_RCSID(0, "$NetBSD: bi_mainbus.c,v 1.10 2008/03/11 05:34:02 matt Exp $"); 351.1Sragge 361.1Sragge#include <sys/param.h> 371.1Sragge#include <sys/device.h> 381.1Sragge 391.1Sragge#define _VAX_BUS_DMA_PRIVATE 401.1Sragge#include <machine/bus.h> 411.1Sragge#include <machine/nexus.h> 421.1Sragge#include <machine/sid.h> 431.2Sragge#include <machine/scb.h> 441.2Sragge#include <machine/cpu.h> 451.10Smatt#include <machine/mainbus.h> 461.1Sragge 471.1Sragge#include <dev/bi/bivar.h> 481.4Sragge#include <dev/bi/bireg.h> 491.1Sragge 501.10Smatt#include "ioconf.h" 511.1Sragge 521.10Smattstatic int bi_mainbus_match(device_t, cfdata_t, void *); 531.10Smattstatic void bi_mainbus_attach(device_t, device_t, void *); 541.10Smatt 551.10SmattCFATTACH_DECL_NEW(bi_mainbus, sizeof(struct bi_softc), 561.7Sthorpej bi_mainbus_match, bi_mainbus_attach, NULL, NULL); 571.1Sragge 581.3Smattstatic int 591.10Smattbi_mainbus_match(device_t parent, cfdata_t cf, void *aux) 601.1Sragge{ 611.10Smatt struct mainbus_attach_args * const ma = aux; 621.10Smatt 631.10Smatt return !strcmp(bi_cd.cd_name, ma->ma_type); 641.1Sragge} 651.1Sragge 661.3Smattstatic void 671.10Smattbi_mainbus_attach(device_t parent, device_t self, void *aux) 681.1Sragge{ 691.10Smatt struct bi_softc * const sc = device_private(self); 701.10Smatt struct mainbus_attach_args * const ma = aux; 711.1Sragge 721.10Smatt sc->sc_dev = self; 731.1Sragge /* 741.1Sragge * Fill in bus specific data. 751.1Sragge */ 761.4Sragge sc->sc_addr = (bus_addr_t)BI_BASE(0, 0); 771.10Smatt sc->sc_iot = ma->ma_iot; /* No special I/O handling */ 781.10Smatt sc->sc_dmat = ma->ma_dmat; /* No special DMA handling either */ 791.4Sragge sc->sc_intcpu = 1 << mfpr(PR_BINID); 801.4Sragge sc->sc_lastiv = 256; /* Lowest available vector address */ 811.1Sragge 821.1Sragge bi_attach(sc); 831.1Sragge} 84