xref: /netbsd-src/sys/arch/alpha/include/eisa_machdep.h (revision 0ff686a3a684360c3140adda0e24043c8ae24569)
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@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