pcireg.h

来自「M5,一个功能强大的多处理器系统模拟器.很多针对处理器架构,性能的研究都使用它作」· C头文件 代码 · 共 150 行

H
150
字号
/* * Copyright (c) 2001, 2002, 2003, 2004, 2005 * The Regents of The University of Michigan * All Rights Reserved * * This code is part of the M5 simulator. * * Permission is granted to use, copy, create derivative works and * redistribute this software and such derivative works for any * purpose, so long as the copyright notice above, this grant of * permission, and the disclaimer below appear in all copies made; and * so long as the name of The University of Michigan is not used in * any advertising or publicity pertaining to the use or distribution * of this software without specific, written prior authorization. * * THIS SOFTWARE IS PROVIDED AS IS, WITHOUT REPRESENTATION FROM THE * UNIVERSITY OF MICHIGAN AS TO ITS FITNESS FOR ANY PURPOSE, AND * WITHOUT WARRANTY BY THE UNIVERSITY OF MICHIGAN OF ANY KIND, EITHER * EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION THE IMPLIED * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR * PURPOSE. THE REGENTS OF THE UNIVERSITY OF MICHIGAN SHALL NOT BE * LIABLE FOR ANY DAMAGES, INCLUDING DIRECT, SPECIAL, INDIRECT, * INCIDENTAL, OR CONSEQUENTIAL DAMAGES, WITH RESPECT TO ANY CLAIM * ARISING OUT OF OR IN CONNECTION WITH THE USE OF THE SOFTWARE, EVEN * IF IT HAS BEEN OR IS HEREAFTER ADVISED OF THE POSSIBILITY OF SUCH * DAMAGES. * * Authors: Nathan L. Binkert *          Miguel J. Serrano *//* @file * Device register definitions for a device's PCI config space */#ifndef __PCIREG_H__#define __PCIREG_H__#include <sys/types.h>union PCIConfig {    uint8_t data[64];    struct {        uint16_t vendor;        uint16_t device;        uint16_t command;        uint16_t status;        uint8_t revision;        uint8_t progIF;        uint8_t subClassCode;        uint8_t classCode;        uint8_t cacheLineSize;        uint8_t latencyTimer;        uint8_t headerType;        uint8_t bist;        uint32_t baseAddr[6];        uint32_t cardbusCIS;        uint16_t subsystemVendorID;        uint16_t subsystemID;        uint32_t expansionROM;        uint32_t reserved0;        uint32_t reserved1;        uint8_t interruptLine;        uint8_t interruptPin;        uint8_t minimumGrant;        uint8_t maximumLatency;    };};// Common PCI offsets#define PCI_VENDOR_ID		0x00	// Vendor ID			ro#define PCI_DEVICE_ID		0x02	// Device ID			ro#define PCI_COMMAND		0x04	// Command			rw#define PCI_STATUS		0x06	// Status			rw#define PCI_REVISION_ID 	0x08	// Revision ID			ro#define PCI_CLASS_CODE		0x09	// Class Code			ro#define PCI_SUB_CLASS_CODE	0x0A	// Sub Class Code		ro#define PCI_BASE_CLASS_CODE	0x0B	// Base Class Code		ro#define PCI_CACHE_LINE_SIZE	0x0C	// Cache Line Size		ro+#define PCI_LATENCY_TIMER	0x0D	// Latency Timer		ro+#define PCI_HEADER_TYPE		0x0E	// Header Type			ro#define PCI_BIST		0x0F	// Built in self test		rw// some pci command reg bitfields#define PCI_CMD_BME     0x04 // Bus master function enable#define PCI_CMD_MSE     0x02 // Memory Space Access enable#define PCI_CMD_IOSE    0x01 // I/O space enable// Type 0 PCI offsets#define PCI0_BASE_ADDR0		0x10	// Base Address 0		rw#define PCI0_BASE_ADDR1		0x14	// Base Address 1		rw#define PCI0_BASE_ADDR2		0x18	// Base Address 2		rw#define PCI0_BASE_ADDR3		0x1C	// Base Address 3		rw#define PCI0_BASE_ADDR4		0x20	// Base Address 4		rw#define PCI0_BASE_ADDR5		0x24	// Base Address 5		rw#define PCI0_CIS		0x28	// CardBus CIS Pointer		ro#define PCI0_SUB_VENDOR_ID	0x2C	// Sub-Vendor ID		ro#define PCI0_SUB_SYSTEM_ID	0x2E	// Sub-System ID		ro#define PCI0_ROM_BASE_ADDR	0x30	// Expansion ROM Base Address	rw#define PCI0_RESERVED0		0x34#define PCI0_RESERVED1		0x38#define PCI0_INTERRUPT_LINE	0x3C	// Interrupt Line		rw#define PCI0_INTERRUPT_PIN	0x3D	// Interrupt Pin		ro#define PCI0_MINIMUM_GRANT	0x3E	// Maximum Grant		ro#define PCI0_MAXIMUM_LATENCY	0x3F	// Maximum Latency		ro// Type 1 PCI offsets#define PCI1_BASE_ADDR0		0x10	// Base Address 0		rw#define PCI1_BASE_ADDR1		0x14	// Base Address 1		rw#define PCI1_PRI_BUS_NUM	0x18	// Primary Bus Number		rw#define PCI1_SEC_BUS_NUM	0x19	// Secondary Bus Number		rw#define PCI1_SUB_BUS_NUM	0x1A	// Subordinate Bus Number	rw#define PCI1_SEC_LAT_TIMER	0x1B	// Secondary Latency Timer	ro+#define PCI1_IO_BASE		0x1C	// I/O Base			rw#define PCI1_IO_LIMIT		0x1D	// I/O Limit			rw#define PCI1_SECONDARY_STATUS	0x1E	// Secondary Status		rw#define PCI1_MEM_BASE		0x20	// Memory Base			rw#define PCI1_MEM_LIMIT		0x22	// Memory Limit			rw#define PCI1_PRF_MEM_BASE	0x24	// Prefetchable Memory Base	rw#define PCI1_PRF_MEM_LIMIT	0x26	// Prefetchable Memory Limit	rw#define PCI1_PRF_BASE_UPPER	0x28	// Prefetchable Base Upper 32	rw#define PCI1_PRF_LIMIT_UPPER	0x2C	// Prefetchable Limit Upper 32	rw#define PCI1_IO_BASE_UPPER	0x30	// I/O Base Upper 16 bits	rw#define PCI1_IO_LIMIT_UPPER	0x32	// I/O Limit Upper 16 bits	rw#define PCI1_RESERVED		0x34	// Reserved			ro#define PCI1_ROM_BASE_ADDR	0x38	// Expansion ROM Base Address	rw#define PCI1_INTR_LINE		0x3C	// Interrupt Line		rw#define PCI1_INTR_PIN		0x3D	// Interrupt Pin		ro#define PCI1_BRIDGE_CTRL	0x3E	// Bridge Control		rw// Device specific offsets#define PCI_DEVICE_SPECIFIC     	0x40	// 192 bytes#define PCI_CONFIG_SIZE         0xFF// Some Vendor IDs#define PCI_VENDOR_DEC			0x1011#define PCI_VENDOR_NCR			0x101A#define PCI_VENDOR_QLOGIC		0x1077#define PCI_VENDOR_SIMOS		0x1291// Some Product IDs#define PCI_PRODUCT_DEC_PZA		0x0008#define PCI_PRODUCT_NCR_810		0x0001#define PCI_PRODUCT_QLOGIC_ISP1020	0x1020#define PCI_PRODUCT_SIMOS_SIMOS		0x1291#define PCI_PRODUCT_SIMOS_ETHER		0x1292#endif // __PCIREG_H__

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?