851de295eb
pci_attach_args *" instead of from four separate parameters which in all cases were extracted from the same "struct pci_attach_args". This both simplifies the driver api, and allows for alternate PCI interrupt mapping schemes, such as one using the tables described in the Intel Multiprocessor Spec which describe interrupt wirings for devices behind pci-pci bridges based on the device's location rather the bridge's location. Tested on alpha and i386; welcome to 1.5Q
69 lines
2.7 KiB
C
69 lines
2.7 KiB
C
/* $NetBSD: pci_machdep.h,v 1.5 2000/12/28 22:59:10 sommerfeld Exp $ */
|
|
|
|
/*
|
|
* Copyright (c) 1999 Matthew R. Green
|
|
* All rights reserved.
|
|
*
|
|
* Redistribution and use in source and binary forms, with or without
|
|
* modification, are permitted provided that the following conditions
|
|
* are met:
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
* notice, this list of conditions and the following disclaimer.
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
* documentation and/or other materials provided with the distribution.
|
|
* 3. The name of the author may not be used to endorse or promote products
|
|
* derived from this software without specific prior written permission.
|
|
*
|
|
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
|
|
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
|
|
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
|
|
* IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
|
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
|
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
|
|
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
|
|
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
* SUCH DAMAGE.
|
|
*/
|
|
|
|
#ifndef _MACHINE_PCI_MACHDEP_H_
|
|
#define _MACHINE_PCI_MACHDEP_H_
|
|
|
|
/*
|
|
* Forward declarations.
|
|
*/
|
|
struct pci_attach_args;
|
|
|
|
/*
|
|
* define some bits used to glue into the common PCI code.
|
|
*/
|
|
|
|
typedef struct sparc_pci_chipset *pci_chipset_tag_t;
|
|
typedef u_int pcitag_t;
|
|
typedef u_int pci_intr_handle_t;
|
|
|
|
struct sparc_pci_chipset {
|
|
void *cookie; /* psycho_pbm, but sssh! */
|
|
int node; /* OFW node */
|
|
int busno; /* PCI bus number */
|
|
/* do we need any more here? */
|
|
};
|
|
|
|
void pci_attach_hook(struct device *, struct device *,
|
|
struct pcibus_attach_args *);
|
|
int pci_bus_maxdevs(pci_chipset_tag_t, int);
|
|
pcitag_t pci_make_tag(pci_chipset_tag_t, int, int, int);
|
|
pcireg_t pci_conf_read(pci_chipset_tag_t, pcitag_t, int);
|
|
void pci_conf_write(pci_chipset_tag_t, pcitag_t, int,
|
|
pcireg_t);
|
|
int pci_intr_map(struct pci_attach_args *, pci_intr_handle_t *);
|
|
const char *pci_intr_string(pci_chipset_tag_t, pci_intr_handle_t);
|
|
const struct evcnt *pci_intr_evcnt(pci_chipset_tag_t, pci_intr_handle_t);
|
|
void *pci_intr_establish(pci_chipset_tag_t, pci_intr_handle_t,
|
|
int, int (*)(void *), void *);
|
|
void pci_intr_disestablish(pci_chipset_tag_t, void *);
|
|
|
|
#endif /* _MACHINE_PCI_MACHDEP_H_ */
|