pcivar.h revision 1.6 1 1.6 cgd /* $NetBSD: pcivar.h,v 1.6 1995/05/23 03:43:08 cgd Exp $ */
2 1.2 cgd
3 1.1 mycroft /*
4 1.1 mycroft * Copyright (c) 1994 Charles Hannum. All rights reserved.
5 1.1 mycroft *
6 1.1 mycroft * Redistribution and use in source and binary forms, with or without
7 1.1 mycroft * modification, are permitted provided that the following conditions
8 1.1 mycroft * are met:
9 1.1 mycroft * 1. Redistributions of source code must retain the above copyright
10 1.1 mycroft * notice, this list of conditions and the following disclaimer.
11 1.1 mycroft * 2. Redistributions in binary form must reproduce the above copyright
12 1.1 mycroft * notice, this list of conditions and the following disclaimer in the
13 1.1 mycroft * documentation and/or other materials provided with the distribution.
14 1.1 mycroft * 3. All advertising materials mentioning features or use of this software
15 1.1 mycroft * must display the following acknowledgement:
16 1.1 mycroft * This product includes software developed by Charles Hannum.
17 1.1 mycroft * 4. The name of the author may not be used to endorse or promote products
18 1.1 mycroft * derived from this software without specific prior written permission.
19 1.1 mycroft *
20 1.1 mycroft * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
21 1.1 mycroft * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
22 1.1 mycroft * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
23 1.1 mycroft * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
24 1.1 mycroft * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
25 1.1 mycroft * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
26 1.1 mycroft * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
27 1.1 mycroft * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
28 1.1 mycroft * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
29 1.1 mycroft * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
30 1.1 mycroft */
31 1.1 mycroft
32 1.1 mycroft /*
33 1.1 mycroft * Definitions for PCI autoconfiguration.
34 1.1 mycroft *
35 1.1 mycroft * This file describes types and functions which are used for PCI
36 1.1 mycroft * configuration. Some of this information is machine-specific, and is
37 1.1 mycroft * separated into pci_machdep.h.
38 1.1 mycroft */
39 1.1 mycroft
40 1.4 cgd #if (i386 != 1)
41 1.4 cgd ERROR: COMPILING FOR UNSUPPORTED MACHINE, OR MORE THAN ONE.
42 1.4 cgd #endif
43 1.4 cgd
44 1.4 cgd #if i386
45 1.1 mycroft #include <i386/pci/pci_machdep.h>
46 1.4 cgd #endif
47 1.4 cgd
48 1.5 cgd /* PCI interrupt levels; system interrupt levels for PCI bus use */
49 1.5 cgd typedef enum {
50 1.5 cgd PCI_IPL_NONE, /* block only the interrupt's IRQ*/
51 1.5 cgd PCI_IPL_BIO, /* block I/O interrupts */
52 1.5 cgd PCI_IPL_NET, /* network */
53 1.5 cgd PCI_IPL_TTY, /* terminal */
54 1.5 cgd PCI_IPL_CLOCK, /* clock */
55 1.5 cgd } pci_intrlevel;
56 1.1 mycroft
57 1.1 mycroft struct pci_attach_args {
58 1.1 mycroft int pa_bus;
59 1.1 mycroft int pa_device;
60 1.1 mycroft pcitag_t pa_tag;
61 1.1 mycroft pcireg_t pa_id, pa_class;
62 1.1 mycroft };
63 1.1 mycroft
64 1.1 mycroft pcitag_t pci_make_tag __P((int, int, int));
65 1.1 mycroft pcireg_t pci_conf_read __P((pcitag_t, int));
66 1.6 cgd void pci_conf_write __P((pcitag_t, int, pcireg_t));
67 1.6 cgd int pci_map_mem __P((pcitag_t, int, vm_offset_t *, vm_offset_t *));
68 1.6 cgd void *pci_map_int __P((pcitag_t, pci_intrlevel, int (*)(void *), void *));
69 1.6 cgd
70 1.6 cgd int pci_attach_subdev __P((struct device *, int, int));
71