bi_mainbus.c revision 1.8
11.8Slukem/*	$NetBSD: bi_mainbus.c,v 1.8 2003/07/15 02:15:00 lukem 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.8Slukem__KERNEL_RCSID(0, "$NetBSD: bi_mainbus.c,v 1.8 2003/07/15 02:15:00 lukem 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.1Sragge
461.1Sragge#include <dev/bi/bivar.h>
471.4Sragge#include <dev/bi/bireg.h>
481.1Sragge
491.1Sraggestatic	int bi_mainbus_match __P((struct device *, struct cfdata *, void *));
501.1Sraggestatic	void bi_mainbus_attach __P((struct device *, struct device *, void *));
511.1Sragge
521.6SthorpejCFATTACH_DECL(bi_mainbus, sizeof(struct bi_softc),
531.7Sthorpej    bi_mainbus_match, bi_mainbus_attach, NULL, NULL);
541.1Sragge
551.1Sraggeextern	struct vax_bus_space vax_mem_bus_space;
561.1Sraggeextern	struct vax_bus_dma_tag vax_bus_dma_tag;
571.1Sragge
581.3Smattstatic int
591.3Smattbi_mainbus_match(struct device *parent, struct cfdata *vcf, void *aux)
601.1Sragge{
611.1Sragge	if (vax_bustype == VAX_BIBUS)
621.1Sragge		return 1;
631.1Sragge	return 0;
641.1Sragge}
651.1Sragge
661.3Smattstatic void
671.3Smattbi_mainbus_attach(struct device *parent, struct device *self, void *aux)
681.1Sragge{
691.1Sragge	struct bi_softc *sc = (void *)self;
701.1Sragge
711.1Sragge	/*
721.1Sragge	 * Fill in bus specific data.
731.1Sragge	 */
741.4Sragge	sc->sc_addr = (bus_addr_t)BI_BASE(0, 0);
751.1Sragge	sc->sc_iot = &vax_mem_bus_space; /* No special I/O handling */
761.1Sragge	sc->sc_dmat = &vax_bus_dma_tag;	/* No special DMA handling either */
771.4Sragge	sc->sc_intcpu = 1 << mfpr(PR_BINID);
781.4Sragge	sc->sc_lastiv = 256; /* Lowest available vector address */
791.1Sragge
801.1Sragge	bi_attach(sc);
811.1Sragge}
82