Home | History | Annotate | Line # | Download | only in include
      1 /* $NetBSD: eisa_machdep.h,v 1.13 2021/09/25 20:16:17 thorpej Exp $ */
      2 
      3 /*
      4  * Copyright (c) 1996 Carnegie-Mellon University.
      5  * All rights reserved.
      6  *
      7  * Author: Chris G. Demetriou
      8  *
      9  * Permission to use, copy, modify and distribute this software and
     10  * its documentation is hereby granted, provided that both the copyright
     11  * notice and this permission notice appear in all copies of the
     12  * software, derivative works or modified versions, and any portions
     13  * thereof, and that both notices appear in supporting documentation.
     14  *
     15  * CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS"
     16  * CONDITION.  CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND
     17  * FOR ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE.
     18  *
     19  * Carnegie Mellon requests users of this software to return to
     20  *
     21  *  Software Distribution Coordinator  or  Software.Distribution (at) CS.CMU.EDU
     22  *  School of Computer Science
     23  *  Carnegie Mellon University
     24  *  Pittsburgh PA 15213-3890
     25  *
     26  * any improvements or extensions that they make and grant Carnegie the
     27  * rights to redistribute these changes.
     28  */
     29 
     30 /*
     31  * Types provided to machine-independent EISA code.
     32  */
     33 typedef struct alpha_eisa_chipset *eisa_chipset_tag_t;
     34 typedef int eisa_intr_handle_t;
     35 
     36 struct alpha_eisa_chipset {
     37 	void	*ec_v;
     38 
     39 	void	(*ec_attach_hook)(device_t, device_t,
     40 		    struct eisabus_attach_args *);
     41 	int	(*ec_maxslots)(void *);
     42 	int	(*ec_intr_map)(void *, u_int, eisa_intr_handle_t *);
     43 	const char *(*ec_intr_string)(void *, eisa_intr_handle_t, char *,
     44 		    size_t);
     45 	const struct evcnt *(*ec_intr_evcnt)(void *, eisa_intr_handle_t);
     46 	void	*(*ec_intr_establish)(void *, eisa_intr_handle_t,
     47 		    int, int, int (*)(void *), void *);
     48 	void	(*ec_intr_disestablish)(void *, void *);
     49 };
     50 
     51 /*
     52  * Functions provided to machine-independent EISA code.
     53  */
     54 void		eisa_attach_hook(device_t, device_t,
     55 		    struct eisabus_attach_args *);
     56 int		eisa_maxslots(eisa_chipset_tag_t);
     57 int		eisa_intr_map(eisa_chipset_tag_t, u_int, eisa_intr_handle_t *);
     58 const char *	eisa_intr_string(eisa_chipset_tag_t, eisa_intr_handle_t,
     59 		    char *, size_t);
     60 const struct evcnt *eisa_intr_evcnt(eisa_chipset_tag_t, eisa_intr_handle_t);
     61 void *		eisa_intr_establish(eisa_chipset_tag_t, eisa_intr_handle_t,
     62 		    int, int, int (*)(void *), void *);
     63 void		eisa_intr_disestablish(eisa_chipset_tag_t, void *);
     64 
     65 int		eisa_conf_read_mem(eisa_chipset_tag_t, int, int, int,
     66 		    struct eisa_cfg_mem *);
     67 int		eisa_conf_read_irq(eisa_chipset_tag_t, int, int, int,
     68 		    struct eisa_cfg_irq *);
     69 int		eisa_conf_read_dma(eisa_chipset_tag_t, int, int, int,
     70 		    struct eisa_cfg_dma *);
     71 int		eisa_conf_read_io(eisa_chipset_tag_t, int, int, int,
     72 		    struct eisa_cfg_io *);
     73 
     74 /*
     75  * Internal functions, NOT TO BE USED BY MACHINE-INDEPENDENT CODE!
     76  */
     77 
     78 void	eisa_init(eisa_chipset_tag_t);
     79 
     80 extern bus_size_t eisa_config_stride;
     81 extern paddr_t eisa_config_addr;
     82