Home | History | Annotate | Line # | Download | only in tc
tcvar.h revision 1.4
      1  1.4  jonathan /*	$NetBSD: tcvar.h,v 1.4 1996/03/17 21:37:47 jonathan Exp $	*/
      2  1.1       cgd 
      3  1.1       cgd /*
      4  1.1       cgd  * Copyright (c) 1995 Carnegie-Mellon University.
      5  1.1       cgd  * All rights reserved.
      6  1.1       cgd  *
      7  1.1       cgd  * Author: Chris G. Demetriou
      8  1.1       cgd  *
      9  1.1       cgd  * Permission to use, copy, modify and distribute this software and
     10  1.1       cgd  * its documentation is hereby granted, provided that both the copyright
     11  1.1       cgd  * notice and this permission notice appear in all copies of the
     12  1.1       cgd  * software, derivative works or modified versions, and any portions
     13  1.1       cgd  * thereof, and that both notices appear in supporting documentation.
     14  1.1       cgd  *
     15  1.1       cgd  * CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS"
     16  1.1       cgd  * CONDITION.  CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND
     17  1.1       cgd  * FOR ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE.
     18  1.1       cgd  *
     19  1.1       cgd  * Carnegie Mellon requests users of this software to return to
     20  1.1       cgd  *
     21  1.1       cgd  *  Software Distribution Coordinator  or  Software.Distribution (at) CS.CMU.EDU
     22  1.1       cgd  *  School of Computer Science
     23  1.1       cgd  *  Carnegie Mellon University
     24  1.1       cgd  *  Pittsburgh PA 15213-3890
     25  1.1       cgd  *
     26  1.1       cgd  * any improvements or extensions that they make and grant Carnegie the
     27  1.1       cgd  * rights to redistribute these changes.
     28  1.1       cgd  */
     29  1.1       cgd 
     30  1.1       cgd #ifndef __DEV_TC_TCVAR_H__
     31  1.1       cgd #define __DEV_TC_TCVAR_H__
     32  1.1       cgd 
     33  1.1       cgd /*
     34  1.1       cgd  * TurboChannel autoconfiguration definitions.
     35  1.1       cgd  */
     36  1.1       cgd 
     37  1.1       cgd #include <dev/tc/tcreg.h>
     38  1.1       cgd #include <machine/tc_machdep.h>
     39  1.1       cgd 
     40  1.1       cgd /*
     41  1.1       cgd  * Interrupt levels.  XXX should be common, elsewhere.
     42  1.1       cgd  */
     43  1.1       cgd typedef enum {
     44  1.1       cgd 	TC_IPL_NONE,			/* block only this interrupt */
     45  1.1       cgd 	TC_IPL_BIO,			/* block disk interrupts */
     46  1.1       cgd 	TC_IPL_NET,			/* block network interrupts */
     47  1.1       cgd 	TC_IPL_TTY,			/* block terminal interrupts */
     48  1.1       cgd 	TC_IPL_CLOCK,			/* block clock interrupts */
     49  1.1       cgd } tc_intrlevel_t;
     50  1.1       cgd 
     51  1.1       cgd /*
     52  1.1       cgd  * Arguments used to attach TurboChannel busses.
     53  1.1       cgd  */
     54  1.2       cgd struct tcbus_attach_args {
     55  1.2       cgd 	char		*tba_busname;		/* XXX should be common */
     56  1.1       cgd 
     57  1.2       cgd 	/* Bus information */
     58  1.3       cgd 	u_int		tba_speed;		/* see TC_SPEED_* below */
     59  1.2       cgd 	u_int		tba_nslots;
     60  1.2       cgd 	struct tc_slotdesc *tba_slots;
     61  1.2       cgd 	u_int		tba_nbuiltins;
     62  1.2       cgd 	const struct tc_builtin *tba_builtins;
     63  1.2       cgd 
     64  1.1       cgd 
     65  1.2       cgd 	/* TC bus resource management; XXX will move elsewhere eventually. */
     66  1.2       cgd 	void	(*tba_intr_establish) __P((struct device *, void *,
     67  1.1       cgd 		    tc_intrlevel_t, int (*)(void *), void *));
     68  1.2       cgd 	void	(*tba_intr_disestablish) __P((struct device *, void *));
     69  1.1       cgd };
     70  1.1       cgd 
     71  1.1       cgd /*
     72  1.1       cgd  * Arguments used to attach TurboChannel devices.
     73  1.1       cgd  */
     74  1.2       cgd struct tc_attach_args {
     75  1.2       cgd 	char		ta_modname[TC_ROM_LLEN+1];
     76  1.2       cgd 	u_int		ta_slot;
     77  1.2       cgd 	tc_offset_t	ta_offset;
     78  1.2       cgd 	tc_addr_t	ta_addr;
     79  1.2       cgd 	void		*ta_cookie;
     80  1.3       cgd 	u_int		ta_busspeed;		/* see TC_SPEED_* below */
     81  1.1       cgd };
     82  1.1       cgd 
     83  1.1       cgd /*
     84  1.1       cgd  * Description of TurboChannel slots, provided by machine-dependent
     85  1.1       cgd  * code to the TurboChannel bus driver.
     86  1.1       cgd  */
     87  1.1       cgd struct tc_slotdesc {
     88  1.2       cgd 	tc_addr_t	tcs_addr;
     89  1.2       cgd 	void		*tcs_cookie;
     90  1.2       cgd 	int		tcs_used;
     91  1.1       cgd };
     92  1.1       cgd 
     93  1.1       cgd /*
     94  1.1       cgd  * Description of built-in TurboChannel devices, provided by
     95  1.1       cgd  * machine-dependent code to the TurboChannel bus driver.
     96  1.1       cgd  */
     97  1.1       cgd struct tc_builtin {
     98  1.2       cgd 	char		*tcb_modname;
     99  1.2       cgd 	u_int		tcb_slot;
    100  1.2       cgd 	tc_offset_t	tcb_offset;
    101  1.2       cgd 	void		*tcb_cookie;
    102  1.1       cgd };
    103  1.1       cgd 
    104  1.1       cgd /*
    105  1.1       cgd  * Interrupt establishment functions.
    106  1.1       cgd  */
    107  1.1       cgd void	tc_intr_establish __P((struct device *, void *, tc_intrlevel_t,
    108  1.1       cgd 	    int (*)(void *), void *));
    109  1.1       cgd void	tc_intr_disestablish __P((struct device *, void *));
    110  1.1       cgd 
    111  1.1       cgd /*
    112  1.1       cgd  * Easy to remember names for TurboChannel device locators.
    113  1.1       cgd  */
    114  1.1       cgd #define	tccf_slot	cf_loc[0]		/* slot */
    115  1.1       cgd #define	tccf_offset	cf_loc[1]		/* offset */
    116  1.1       cgd 
    117  1.1       cgd #define	TCCF_SLOT_UNKNOWN	-1
    118  1.1       cgd #define	TCCF_OFFSET_UNKNOWN	-1
    119  1.3       cgd 
    120  1.3       cgd /*
    121  1.3       cgd  * Miscellaneous definitions.
    122  1.3       cgd  */
    123  1.3       cgd #define	TC_SPEED_12_5_MHZ	0		/* 12.5MHz TC bus */
    124  1.3       cgd #define	TC_SPEED_25_MHZ		1		/* 25MHz TC bus */
    125  1.1       cgd 
    126  1.1       cgd /*
    127  1.1       cgd  * The TurboChannel bus cfdriver, so that subdevices can more
    128  1.1       cgd  * easily tell what bus they're on.
    129  1.1       cgd  */
    130  1.4  jonathan extern struct cfdriver tc_cd;
    131  1.1       cgd 
    132  1.1       cgd #endif /* __DEV_TC_TCVAR_H__ */
    133