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