[BACK]Return to pciio.h CVS log [TXT][DIR] Up to [local] / sys / sys

Annotation of sys/sys/pciio.h, Revision 1.1.1.1

1.1       nbrk        1: /*     $OpenBSD: pciio.h,v 1.2 2001/06/26 20:44:14 jason Exp $ */
                      2:
                      3: /*-
                      4:  * Copyright (c) 1997, Stefan Esser <se@FreeBSD.ORG>
                      5:  * Copyright (c) 1997, 1998, 1999, Kenneth D. Merry <ken@FreeBSD.ORG>
                      6:  * All rights reserved.
                      7:  *
                      8:  * Redistribution and use in source and binary forms, with or without
                      9:  * modification, are permitted provided that the following conditions
                     10:  * are met:
                     11:  * 1. Redistributions of source code must retain the above copyright
                     12:  *    notice unmodified, this list of conditions, and the following
                     13:  *    disclaimer.
                     14:  * 2. Redistributions in binary form must reproduce the above copyright
                     15:  *    notice, this list of conditions and the following disclaimer in the
                     16:  *    documentation and/or other materials provided with the distribution.
                     17:  *
                     18:  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
                     19:  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
                     20:  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
                     21:  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
                     22:  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
                     23:  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
                     24:  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
                     25:  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
                     26:  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
                     27:  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
                     28:  *
                     29:  *     $FreeBSD: src/sys/sys/pciio.h,v 1.5 1999/12/08 17:44:04 ken Exp $
                     30:  *
                     31:  */
                     32:
                     33: #ifndef _SYS_PCIIO_H_
                     34: #define        _SYS_PCIIO_H_
                     35:
                     36: #include <sys/ioccom.h>
                     37:
                     38: #define PCI_MAXNAMELEN 16
                     39:
                     40: typedef enum {
                     41:        PCI_GETCONF_LAST_DEVICE,
                     42:        PCI_GETCONF_LIST_CHANGED,
                     43:        PCI_GETCONF_MORE_DEVS,
                     44:        PCI_GETCONF_ERROR
                     45: } pci_getconf_status;
                     46:
                     47: typedef enum {
                     48:        PCI_GETCONF_NO_MATCH            = 0x00,
                     49:        PCI_GETCONF_MATCH_BUS           = 0x01,
                     50:        PCI_GETCONF_MATCH_DEV           = 0x02,
                     51:        PCI_GETCONF_MATCH_FUNC          = 0x04,
                     52:        PCI_GETCONF_MATCH_NAME          = 0x08,
                     53:        PCI_GETCONF_MATCH_UNIT          = 0x10,
                     54:        PCI_GETCONF_MATCH_VENDOR        = 0x20,
                     55:        PCI_GETCONF_MATCH_DEVICE        = 0x40,
                     56:        PCI_GETCONF_MATCH_CLASS         = 0x80
                     57: } pci_getconf_flags;
                     58:
                     59: struct pcisel {
                     60:        u_int8_t        pc_bus;         /* bus number */
                     61:        u_int8_t        pc_dev;         /* device on this bus */
                     62:        u_int8_t        pc_func;        /* function on this device */
                     63: };
                     64:
                     65: struct pci_conf {
                     66:        struct pcisel   pc_sel;         /* bus+slot+function */
                     67:        u_int8_t        pc_hdr;         /* PCI header type */
                     68:        u_int16_t       pc_subvendor;   /* card vendor ID */
                     69:        u_int16_t       pc_subdevice;   /* card device ID, assigned by
                     70:                                           card vendor */
                     71:        u_int16_t       pc_vendor;      /* chip vendor ID */
                     72:        u_int16_t       pc_device;      /* chip device ID, assigned by
                     73:                                           chip vendor */
                     74:        u_int8_t        pc_class;       /* chip PCI class */
                     75:        u_int8_t        pc_subclass;    /* chip PCI subclass */
                     76:        u_int8_t        pc_progif;      /* chip PCI programming interface */
                     77:        u_int8_t        pc_revid;       /* chip revision ID */
                     78:        char            pd_name[PCI_MAXNAMELEN + 1];  /* device name */
                     79:        u_long          pd_unit;        /* device unit number */
                     80: };
                     81:
                     82: struct pci_match_conf {
                     83:        struct pcisel           pc_sel;         /* bus+slot+function */
                     84:        char                    pd_name[PCI_MAXNAMELEN + 1];  /* device name */
                     85:        u_long                  pd_unit;        /* Unit number */
                     86:        u_int16_t               pc_vendor;      /* PCI Vendor ID */
                     87:        u_int16_t               pc_device;      /* PCI Device ID */
                     88:        u_int8_t                pc_class;       /* PCI class */
                     89:        pci_getconf_flags       flags;          /* Matching expression */
                     90: };
                     91:
                     92: struct pci_conf_io {
                     93:        u_int32_t               pat_buf_len;    /* pattern buffer length */
                     94:        u_int32_t               num_patterns;   /* number of patterns */
                     95:        struct pci_match_conf   *patterns;      /* pattern buffer */
                     96:        u_int32_t               match_buf_len;  /* match buffer length */
                     97:        u_int32_t               num_matches;    /* number of matches returned */
                     98:        struct pci_conf         *matches;       /* match buffer */
                     99:        u_int32_t               offset;         /* offset into device list */
                    100:        u_int32_t               generation;     /* device list generation */
                    101:        pci_getconf_status      status;         /* request status */
                    102: };
                    103:
                    104: struct pci_io {
                    105:        struct pcisel   pi_sel;         /* device to operate on */
                    106:        int             pi_reg;         /* configuration register to examine */
                    107:        int             pi_width;       /* width (in bytes) of read or write */
                    108:        u_int32_t       pi_data;        /* data to write or result of read */
                    109: };
                    110:
                    111:
                    112: #define        PCIOCGETCONF    _IOWR('p', 1, struct pci_conf_io)
                    113: #define        PCIOCREAD       _IOWR('p', 2, struct pci_io)
                    114: #define        PCIOCWRITE      _IOWR('p', 3, struct pci_io)
                    115: #define        PCIOCATTACHED   _IOWR('p', 4, struct pci_io)
                    116:
                    117: #endif /* !_SYS_PCIIO_H_ */

CVSweb