freebsd-dev/sys/i386/pci/pci_device.h
Garrett Wollman f86233fe54 Added a bit of missing functionality to make this work correctly on a
wider variety of systems.  Include the deivers from pci_intel.c in
pci_config.c (I hope this is what was intended; my system works ok).
Use pmap_mapdev().  Automatically map any large linear frame buffers
or whatnot in VGA-style devices which ordinarily would not have their
own drivers, and don't call not_supported() for them.  (This shuts up
complaints about my Matrox card.)  Include the beginnings of what could
eventually become dynamically-loadable PCI devices.  Allow for the
possibility of PCI devices simply providing a PCI veneer over an existing
ISA device, and shut up about them, too.
Make autoconfiguration text conform more to the style of other supported
buses.
1994-09-14 01:34:51 +00:00

123 lines
4.3 KiB
C
Raw Blame History

This file contains invisible Unicode characters

This file contains invisible Unicode characters that are indistinguishable to humans but may be processed differently by a computer. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

/**************************************************************************
**
** $Id: pci_device.h,v 1.2 1994/09/01 02:01:41 se Exp $
**
** #define for pci based device drivers
**
** 386bsd / FreeBSD
**
**-------------------------------------------------------------------------
**
** Copyright (c) 1994 Wolfgang Stanglmeier. 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.
**
**-------------------------------------------------------------------------
**
** $Log: pci_device.h,v $
* Revision 1.2 1994/09/01 02:01:41 se
* Submitted by: Wolfgang Stanglmeier <wolf@dentaro.GUN.de>
* Merged in changes required for NetBSD support (by mycroft@gnu.ai.mit.edu)
* and support for multiple NCR chips.
*
** Revision 2.0.0.1 94/08/18 23:06:43 wolf
** Copyright message.
**
** Revision 2.0 94/07/10 15:53:31 wolf
** FreeBSD release.
**
** Revision 1.0 94/06/07 20:02:22 wolf
** Beta release.
**
***************************************************************************
*/
#ifndef __PCI_DEVICE_H__
#define __PCI_DEVICE_H__
/*------------------------------------------------------------
**
** Per driver structure.
**
**------------------------------------------------------------
*/
struct pci_driver {
int (*probe )(pcici_t pci_ident); /* test whether device is present */
int (*attach)(pcici_t pci_ident); /* setup driver for a device */
pcidi_t device_id; /* device pci id */
char *name; /* device name */
char *vendor; /* device long name */
int (*intr)(int); /* interupt handler */
};
/*-----------------------------------------------------------
**
** Per device structure.
**
** It is initialized by the config utility and should live in
** "ioconf.c". At the moment there is only one field.
**
** This is a first attempt to include the pci bus to 386bsd.
** So this structure may grow ..
**
**-----------------------------------------------------------
*/
struct pci_device {
struct pci_driver * pd_driver;
pcidi_t pd_device_id; /* device pci id */
const char *pd_name; /* for future loadable drivers */
int pd_flags;
};
#define PDF_LOADABLE 0x01
#define PDF_COVERED 0x02
/*-----------------------------------------------------------
**
** This table should be generated in file "ioconf.c"
** by the config program.
** It is used at boot time by the configuration function
** pci_configure()
**
**-----------------------------------------------------------
*/
extern struct pci_device pci_devtab[];
/*-----------------------------------------------------------
**
** This functions may be used by drivers to map devices
** to virtual and physical addresses. The va and pa
** addresses are "in/out" parameters. If they are 0
** on entry, the mapping function assigns an address.
**
**-----------------------------------------------------------
*/
int pci_map_mem (pcici_t tag, u_long entry, u_long * va, u_long * pa);
int pci_map_port(pcici_t tag, u_long entry, u_short * pa);
#endif /*__PCI_DEVICE_H__*/