NetBSD/sys/dev/xmi/xmivar.h
matt dfba816635 Rototill the vax code. Switch to devicet/PRIV_ALLOC. Cleanup vax autoconf
code.  Move to prototype definitions.  staticfy, constify, avoid casting.
Use device_* accessors.
2008-03-11 05:34:01 +00:00

72 lines
2.7 KiB
C

/* $NetBSD: xmivar.h,v 1.2 2008/03/11 05:34:02 matt Exp $ */
/*
* Copyright (c) 2000 Ludd, University of Lule}, Sweden. All rights reserved.
*
* 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.
* 3. All advertising materials mentioning features or use of this software
* must display the following acknowledgement:
* This product includes software developed at Ludd, University of
* Lule}, Sweden and its contributors.
* 4. The name of the author may not be used to endorse or promote products
* derived from this software without specific prior written permission
*
* 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.
*/
/*
* per-XMI-adapter state.
*/
struct xmi_softc {
struct device *sc_dev;
bus_space_tag_t sc_iot; /* Space tag for the XMI bus */
bus_dma_tag_t sc_dmat;
bus_addr_t sc_addr; /* Address base address for this bus */
int sc_busnr; /* (Physical) number of this bus */
int sc_lastiv; /* last available interrupt vector */
int sc_intcpu;
};
/*
* Struct used for autoconfiguration; attaching of XMI nodes.
*/
struct xmi_attach_args {
bus_space_tag_t xa_iot;
bus_space_handle_t xa_ioh; /* Base address for this node */
bus_dma_tag_t xa_dmat;
int xa_busnr;
int xa_nodenr;
int xa_intcpu; /* Mask of which cpus to interrupt */
int xa_ivec; /* Interrupt vector to use */
void *xa_icookie;
};
/*
* XMI node list.
*/
struct xmi_list {
uint16_t xl_nr; /* Unit ID# */
uint16_t xl_havedriver; /* Have device driver (informal) */
const char *xl_name; /* DEC name */
};
/* Prototype */
void xmi_attach(struct xmi_softc *);
void xmi_intr_establish(void *, int, void (*)(void *), void *, struct evcnt *);