Source code of Windows XP (NT5)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

206 lines
8.1 KiB

/*****************************************************************************
** **
** COPYRIGHT (C) 2000, 2001 MKNET CORPORATION **
** DEVELOPED FOR THE MK7100-BASED VFIR PCI CONTROLLER. **
** **
*****************************************************************************/
/**********************************************************************
Module Name:
WINPCI.H
Comments:
PCI & Windows PCI defs.
**********************************************************************/
#ifndef _WINPCI_H
#define _WINPCI_H
//-------------------------------------------------------------------------
// PCI configuration hardware ports
//-------------------------------------------------------------------------
#define CF1_CONFIG_ADDR_REGISTER 0x0CF8
#define CF1_CONFIG_DATA_REGISTER 0x0CFC
#define CF2_SPACE_ENABLE_REGISTER 0x0CF8
#define CF2_FORWARD_REGISTER 0x0CFA
#define CF2_BASE_ADDRESS 0xC000
//-------------------------------------------------------------------------
// Configuration Space Header
//-------------------------------------------------------------------------
typedef struct _PCI_CONFIG_STRUC {
USHORT PciVendorId; // PCI Vendor ID
USHORT PciDeviceId; // PCI Device ID
USHORT PciCommand;
USHORT PciStatus;
UCHAR PciRevisionId;
UCHAR PciClassCode[3];
UCHAR PciCacheLineSize;
UCHAR PciLatencyTimer;
UCHAR PciHeaderType;
UCHAR PciBIST;
ULONG PciBaseReg0;
ULONG PciBaseReg1;
ULONG PciBaseReg2;
ULONG PciBaseReg3;
ULONG PciBaseReg4;
ULONG PciBaseReg5;
ULONG PciReserved0;
ULONG PciReserved1;
ULONG PciExpROMAddress;
ULONG PciReserved2;
ULONG PciReserved3;
UCHAR PciInterruptLine;
UCHAR PciInterruptPin;
UCHAR PciMinGnt;
UCHAR PciMaxLat;
} PCI_CONFIG_STRUC, *PPCI_CONFIG_STRUC;
//----------------------------------------------------------------------
// PCI Config Space
//----------------------------------------------------------------------
#define PCI_VENDOR_ID_REGISTER 0x00 // PCI Vendor ID Register
#define PCI_DEVICE_ID_REGISTER 0x02 // PCI Device ID Register
#define PCI_CONFIG_ID_REGISTER 0x00 // PCI Configuration ID Register
#define PCI_COMMAND_REGISTER 0x04 // PCI Command Register
#define PCI_STATUS_REGISTER 0x06 // PCI Status Register
#define PCI_REV_ID_REGISTER 0x08 // PCI Revision ID Register
#define PCI_CLASS_CODE_REGISTER 0x09 // PCI Class Code Register
#define PCI_CACHE_LINE_REGISTER 0x0C // PCI Cache Line Register
#define PCI_LATENCY_TIMER 0x0D // PCI Latency Timer Register
#define PCI_HEADER_TYPE 0x0E // PCI Header Type Register
#define PCI_BIST_REGISTER 0x0F // PCI Built-In SelfTest Register
#define PCI_BAR_0_REGISTER 0x10 // PCI Base Address Register 0
#define PCI_BAR_1_REGISTER 0x14 // PCI Base Address Register 1
#define PCI_BAR_2_REGISTER 0x18 // PCI Base Address Register 2
#define PCI_BAR_3_REGISTER 0x1C // PCI Base Address Register 3
#define PCI_BAR_4_REGISTER 0x20 // PCI Base Address Register 4
#define PCI_BAR_5_REGISTER 0x24 // PCI Base Address Register 5
#define PCI_SUBVENDOR_ID_REGISTER 0x2C // PCI SubVendor ID Register
#define PCI_SUBDEVICE_ID_REGISTER 0x2E // PCI SubDevice ID Register
#define PCI_EXPANSION_ROM 0x30 // PCI Expansion ROM Base Register
#define PCI_INTERRUPT_LINE 0x3C // PCI Interrupt Line Register
#define PCI_INTERRUPT_PIN 0x3D // PCI Interrupt Pin Register
#define PCI_MIN_GNT_REGISTER 0x3E // PCI Min-Gnt Register
#define PCI_MAX_LAT_REGISTER 0x3F // PCI Max_Lat Register
#define PCI_NODE_ADDR_REGISTER 0x40 // PCI Node Address Register
//-------------------------------------------------------------------------
// PCI Class Code Definitions
// Configuration Space Header
//-------------------------------------------------------------------------
#define PCI_BASE_CLASS 0x02 // Base Class - Network Controller
#define PCI_SUB_CLASS 0x00 // Sub Class - Ethernet Controller
#define PCI_PROG_INTERFACE 0x00 // Prog I/F - Ethernet COntroller
//-------------------------------------------------------------------------
// The following is copied from EQUATES.H
// Bit Mask definitions
//-------------------------------------------------------------------------
#define BIT_0 0x0001
#define BIT_1 0x0002
#define BIT_2 0x0004
#define BIT_3 0x0008
#define BIT_4 0x0010
#define BIT_5 0x0020
#define BIT_6 0x0040
#define BIT_7 0x0080
#define BIT_8 0x0100
#define BIT_9 0x0200
#define BIT_10 0x0400
#define BIT_11 0x0800
#define BIT_12 0x1000
#define BIT_13 0x2000
#define BIT_14 0x4000
#define BIT_15 0x8000
#define BIT_24 0x01000000
#define BIT_28 0x10000000
//-------------------------------------------------------------------------
// PCI Command Register Bit Definitions
// Configuration Space Header
//-------------------------------------------------------------------------
#define CMD_IO_SPACE BIT_0
#define CMD_MEMORY_SPACE BIT_1
#define CMD_BUS_MASTER BIT_2
#define CMD_SPECIAL_CYCLES BIT_3
#define CMD_MEM_WRT_INVALIDATE BIT_4
#define CMD_VGA_PALLETTE_SNOOP BIT_5
#define CMD_PARITY_RESPONSE BIT_6
#define CMD_WAIT_CYCLE_CONTROL BIT_7
#define CMD_SERR_ENABLE BIT_8
#define CMD_BACK_TO_BACK BIT_9
//-------------------------------------------------------------------------
// PCI Status Register Bit Definitions
// Configuration Space Header
//-------------------------------------------------------------------------
#define STAT_BACK_TO_BACK BIT_7
#define STAT_DATA_PARITY BIT_8
#define STAT_DEVSEL_TIMING BIT_9 OR BIT_10
#define STAT_SIGNAL_TARGET_ABORT BIT_11
#define STAT_RCV_TARGET_ABORT BIT_12
#define STAT_RCV_MASTER_ABORT BIT_13
#define STAT_SIGNAL_MASTER_ABORT BIT_14
#define STAT_DETECT_PARITY_ERROR BIT_15
//-------------------------------------------------------------------------
// PCI Base Address Register For Memory (BARM) Bit Definitions
// Configuration Space Header
//-------------------------------------------------------------------------
#define BARM_LOCATE_BELOW_1_MEG BIT_1
#define BARM_LOCATE_IN_64_SPACE BIT_2
#define BARM_PREFETCHABLE BIT_3
//-------------------------------------------------------------------------
// PCI Base Address Register For I/O (BARIO) Bit Definitions
// Configuration Space Header
//-------------------------------------------------------------------------
#define BARIO_SPACE_INDICATOR BIT_0
//-------------------------------------------------------------------------
// PCI BIOS Definitions
// Refer To The PCI BIOS Specification
//-------------------------------------------------------------------------
//- Function Code List
#define PCI_FUNCTION_ID 0xB1 // AH Register
#define PCI_BIOS_PRESENT 0x01 // AL Register
#define FIND_PCI_DEVICE 0x02 // AL Register
#define FIND_PCI_CLASS_CODE 0x03 // AL Register
#define GENERATE_SPECIAL_CYCLE 0x06 // AL Register
#define READ_CONFIG_BYTE 0x08 // AL Register
#define READ_CONFIG_WORD 0x09 // AL Register
#define READ_CONFIG_DWORD 0x0A // AL Register
#define WRITE_CONFIG_BYTE 0x0B // AL Register
#define WRITE_CONFIG_WORD 0x0C // AL Register
#define WRITE_CONFIG_DWORD 0x0D // AL Register
//- Function Return Code List
#define SUCCESSFUL 0x00
#define FUNC_NOT_SUPPORTED 0x81
#define BAD_VENDOR_ID 0x83
#define DEVICE_NOT_FOUND 0x86
#define BAD_REGISTER_NUMBER 0x87
//- PCI BIOS Calls
#define PCI_BIOS_INTERRUPT 0x1A // PCI BIOS Int 1Ah Function Call
#define PCI_PRESENT_CODE 0x20494350 // Hex Equivalent Of 'PCI '
#define PCI_SERVICE_IDENTIFIER 0x49435024 // ASCII Codes for 'ICP$'
//- Device and Vendor IDs
#define MK7_PCI_DEVICE_ID 0x7100
#define MKNET_PCI_VENDOR_ID 0x1641
// For debugging
#define DBG_DEVICE_ID 0x7100
#define DBG_VENDOR_ID 0x2828
#endif // _WINPCI_H