2003-09-03 23:59:56 +00:00
|
|
|
/*
|
2004-10-11 15:03:13 +00:00
|
|
|
* ReactOS AMD PCNet Driver
|
2003-09-03 23:59:56 +00:00
|
|
|
*
|
2004-10-11 15:03:13 +00:00
|
|
|
* Copyright (C) 2003 Vizzini <vizzini@plasmic.com>
|
2003-09-03 23:59:56 +00:00
|
|
|
*
|
2004-10-11 15:03:13 +00:00
|
|
|
* This program is free software; you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation; either version 2 of the License, or
|
|
|
|
* (at your option) any later version.
|
2003-09-03 23:59:56 +00:00
|
|
|
*
|
2004-10-11 15:03:13 +00:00
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
2003-09-03 23:59:56 +00:00
|
|
|
*
|
2009-10-27 10:34:16 +00:00
|
|
|
* You should have received a copy of the GNU General Public License along
|
|
|
|
* with this program; if not, write to the Free Software Foundation, Inc.,
|
|
|
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
2004-10-11 15:03:13 +00:00
|
|
|
*
|
|
|
|
* PURPOSE:
|
|
|
|
* PCI configuration constants
|
2003-09-03 23:59:56 +00:00
|
|
|
* REVISIONS:
|
2004-10-11 15:03:13 +00:00
|
|
|
* 01-Sept-2003 vizzini - Created
|
2003-09-03 23:59:56 +00:00
|
|
|
*/
|
|
|
|
|
2010-02-26 11:43:19 +00:00
|
|
|
#pragma once
|
2003-09-03 23:59:56 +00:00
|
|
|
|
|
|
|
/* PCI Config Space Offset Definitions */
|
|
|
|
#define PCI_PCIID 0x0 /* pci id - query 32 bits */
|
|
|
|
#define PCI_VENID 0x0 /* vendor ID */
|
|
|
|
#define PCI_DEVID 0x2 /* device ID */
|
|
|
|
#define PCI_COMMAND 0x4 /* command register */
|
|
|
|
#define PCI_STATUS 0x6 /* status register */
|
|
|
|
#define PCI_REVID 0x8 /* revision ID */
|
|
|
|
#define PCI_PIR 0x9 /* programming interface register */
|
|
|
|
#define PCI_SCR 0xa /* sub-class register */
|
|
|
|
#define PCI_BCR 0xb /* base-class register */
|
|
|
|
#define PCI_LTR 0xd /* latency timer register */
|
|
|
|
#define PCI_HTR 0xe /* header type register */
|
|
|
|
#define PCI_IOBAR 0x10 /* i/o base address register */
|
|
|
|
#define PCI_MMBAR 0x14 /* i/o memory-mapped base address register */
|
|
|
|
#define PCI_ERBAR 0x30 /* expansion rom base address register */
|
|
|
|
#define PCI_ILR 0x3c /* interrupt line register */
|
|
|
|
#define PCI_IPR 0x3d /* interrupt pin register */
|
|
|
|
#define PCI_MINGNT 0x3e /* min_gnt register */
|
|
|
|
#define PCI_MAXLAT 0x3f /* max_lat register */
|
|
|
|
|
|
|
|
/* PCI Command Register Bits */
|
|
|
|
#define PCI_IOEN 0x1 /* i/o space access enable */
|
|
|
|
#define PCI_MEMEN 0x2 /* memory space access enable */
|
|
|
|
#define PCI_BMEN 0x4 /* bus master enable */
|
|
|
|
#define PCI_SCYCEN 0x8 /* special cycle enable */
|
|
|
|
#define PCI_MWIEN 0X10 /* memory write and invalidate cycle enable */
|
|
|
|
#define PCI_VGASNOOP 0x20 /* vga palette snoop */
|
|
|
|
#define PCI_PERREN 0x40 /* parity error response enable */
|
|
|
|
#define PCI_ADSTEP 0x80 /* address/data stepping */
|
|
|
|
#define PCI_SERREN 0x100 /* signalled error enable */
|
|
|
|
#define PCI_FBTBEN 0X200 /* fast back-to-back enable */
|
|
|
|
|
|
|
|
/* PCI Status Register Bits */
|
|
|
|
#define PCI_FBTBC 0x80 /* fast back-to-back capable */
|
|
|
|
#define PCI_DATAPERR 0x100 /* data parity error detected */
|
|
|
|
#define PCI_DEVSEL1 0x200 /* device select timing lsb */
|
|
|
|
#define PCI_DEVSEL2 0x400 /* device select timing msb */
|
|
|
|
#define PCI_STABORT 0x800 /* send target abort */
|
|
|
|
#define PCI_RTABORT 0x1000 /* received target abort */
|
|
|
|
#define PCI_SERR 0x2000 /* signalled error */
|
|
|
|
#define PCI_PERR 0x4000 /* parity error */
|