Home | History | Annotate | Line # | Download | only in ic
bhavar.h revision 1.7
      1  1.7   thorpej /*	$NetBSD: bhavar.h,v 1.7 1997/06/06 23:31:04 thorpej Exp $	*/
      2  1.2   mycroft 
      3  1.2   mycroft /*
      4  1.6   mycroft  * Copyright (c) 1994, 1996, 1997 Charles M. Hannum.  All rights reserved.
      5  1.2   mycroft  *
      6  1.2   mycroft  * Redistribution and use in source and binary forms, with or without
      7  1.2   mycroft  * modification, are permitted provided that the following conditions
      8  1.2   mycroft  * are met:
      9  1.2   mycroft  * 1. Redistributions of source code must retain the above copyright
     10  1.2   mycroft  *    notice, this list of conditions and the following disclaimer.
     11  1.2   mycroft  * 2. Redistributions in binary form must reproduce the above copyright
     12  1.2   mycroft  *    notice, this list of conditions and the following disclaimer in the
     13  1.2   mycroft  *    documentation and/or other materials provided with the distribution.
     14  1.2   mycroft  * 3. All advertising materials mentioning features or use of this software
     15  1.2   mycroft  *    must display the following acknowledgement:
     16  1.2   mycroft  *	This product includes software developed by Charles M. Hannum.
     17  1.2   mycroft  * 4. The name of the author may not be used to endorse or promote products
     18  1.2   mycroft  *    derived from this software without specific prior written permission.
     19  1.2   mycroft  *
     20  1.2   mycroft  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
     21  1.2   mycroft  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
     22  1.2   mycroft  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
     23  1.2   mycroft  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
     24  1.2   mycroft  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
     25  1.2   mycroft  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
     26  1.2   mycroft  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
     27  1.2   mycroft  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
     28  1.2   mycroft  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
     29  1.2   mycroft  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
     30  1.2   mycroft  */
     31  1.2   mycroft 
     32  1.1   mycroft /*
     33  1.1   mycroft  * Mail box defs  etc.
     34  1.1   mycroft  * these could be bigger but we need the bha_softc to fit on a single page..
     35  1.1   mycroft  */
     36  1.1   mycroft #define BHA_MBX_SIZE	32	/* mail box size  (MAX 255 MBxs) */
     37  1.1   mycroft 				/* don't need that many really */
     38  1.1   mycroft #define BHA_CCB_MAX	32	/* store up to 32 CCBs at one time */
     39  1.1   mycroft #define	CCB_HASH_SIZE	32	/* hash table size for phystokv */
     40  1.1   mycroft #define	CCB_HASH_SHIFT	9
     41  1.1   mycroft #define CCB_HASH(x)	((((long)(x))>>CCB_HASH_SHIFT) & (CCB_HASH_SIZE - 1))
     42  1.1   mycroft 
     43  1.1   mycroft #define bha_nextmbx(wmb, mbx, mbio) \
     44  1.1   mycroft 	if ((wmb) == &(mbx)->mbio[BHA_MBX_SIZE - 1])	\
     45  1.1   mycroft 		(wmb) = &(mbx)->mbio[0];		\
     46  1.1   mycroft 	else						\
     47  1.1   mycroft 		(wmb)++;
     48  1.1   mycroft 
     49  1.1   mycroft struct bha_mbx {
     50  1.1   mycroft 	struct bha_mbx_out mbo[BHA_MBX_SIZE];
     51  1.1   mycroft 	struct bha_mbx_in mbi[BHA_MBX_SIZE];
     52  1.1   mycroft 	struct bha_mbx_out *cmbo;	/* Collection Mail Box out */
     53  1.1   mycroft 	struct bha_mbx_out *tmbo;	/* Target Mail Box out */
     54  1.1   mycroft 	struct bha_mbx_in *tmbi;	/* Target Mail Box in */
     55  1.1   mycroft };
     56  1.1   mycroft 
     57  1.1   mycroft struct bha_softc {
     58  1.1   mycroft 	struct device sc_dev;
     59  1.6   mycroft 
     60  1.3   thorpej 	bus_space_tag_t sc_iot;
     61  1.3   thorpej 	bus_space_handle_t sc_ioh;
     62  1.7   thorpej 	bus_dma_tag_t sc_dmat;
     63  1.7   thorpej 	bus_dmamap_t sc_dmamap_mbox;	/* maps the mailbox */
     64  1.7   thorpej 	int sc_dmaflags;		/* bus-specific dma map flags */
     65  1.1   mycroft 	void *sc_ih;
     66  1.1   mycroft 
     67  1.7   thorpej 	struct bha_mbx *sc_mbx;		/* all our mailboxes */
     68  1.7   thorpej #define	wmbx	(sc->sc_mbx)
     69  1.1   mycroft 	struct bha_ccb *sc_ccbhash[CCB_HASH_SIZE];
     70  1.1   mycroft 	TAILQ_HEAD(, bha_ccb) sc_free_ccb, sc_waiting_ccb;
     71  1.1   mycroft 	int sc_numccbs, sc_mbofull;
     72  1.6   mycroft 	struct scsi_link sc_link;	/* prototype for devs */
     73  1.6   mycroft 
     74  1.6   mycroft 	char sc_model[7],
     75  1.6   mycroft 	     sc_firmware[6];
     76  1.6   mycroft };
     77  1.6   mycroft 
     78  1.6   mycroft struct bha_probe_data {
     79  1.6   mycroft 	int sc_irq, sc_drq;
     80  1.1   mycroft 	int sc_scsi_dev;		/* adapters scsi id */
     81  1.5   thorpej 	int sc_iswide;			/* adapter is wide */
     82  1.1   mycroft };
     83  1.1   mycroft 
     84  1.6   mycroft #define	ISWIDE(sc)	(sc->sc_link.max_target >= 8)
     85  1.6   mycroft 
     86  1.3   thorpej int	bha_find __P((bus_space_tag_t, bus_space_handle_t,
     87  1.6   mycroft 	    struct bha_probe_data *));
     88  1.6   mycroft void	bha_attach __P((struct bha_softc *, struct bha_probe_data *));
     89  1.1   mycroft int	bha_intr __P((void *));
     90  1.4  jonathan 
     91  1.4  jonathan int	bha_disable_isacompat __P((struct bha_softc *));
     92  1.7   thorpej void	bha_inquire_setup_information __P((struct bha_softc *));
     93