22 #define PCI_MAX_BUS 255 23 #define PCI_MAX_DEVICE 31 24 #define PCI_MAX_FUNC 7 145 #define PCI_CLASS_OLD 0x00 146 #define PCI_CLASS_OLD_OTHER 0x00 147 #define PCI_CLASS_OLD_VGA 0x01 149 #define PCI_CLASS_MASS_STORAGE 0x01 150 #define PCI_CLASS_MASS_STORAGE_SCSI 0x00 151 #define PCI_CLASS_MASS_STORAGE_IDE 0x01 152 #define PCI_CLASS_MASS_STORAGE_FLOPPY 0x02 153 #define PCI_CLASS_MASS_STORAGE_IPI 0x03 154 #define PCI_CLASS_MASS_STORAGE_RAID 0x04 155 #define PCI_CLASS_MASS_STORAGE_OTHER 0x80 157 #define PCI_CLASS_NETWORK 0x02 158 #define PCI_CLASS_NETWORK_ETHERNET 0x00 159 #define PCI_CLASS_NETWORK_TOKENRING 0x01 160 #define PCI_CLASS_NETWORK_FDDI 0x02 161 #define PCI_CLASS_NETWORK_ATM 0x03 162 #define PCI_CLASS_NETWORK_ISDN 0x04 163 #define PCI_CLASS_NETWORK_OTHER 0x80 165 #define PCI_CLASS_DISPLAY 0x03 166 #define PCI_CLASS_DISPLAY_VGA 0x00 167 #define PCI_IF_VGA_VGA 0x00 168 #define PCI_IF_VGA_8514 0x01 169 #define PCI_CLASS_DISPLAY_XGA 0x01 170 #define PCI_CLASS_DISPLAY_3D 0x02 171 #define PCI_CLASS_DISPLAY_OTHER 0x80 173 #define PCI_CLASS_MEDIA 0x04 174 #define PCI_CLASS_MEDIA_VIDEO 0x00 175 #define PCI_CLASS_MEDIA_AUDIO 0x01 176 #define PCI_CLASS_MEDIA_TELEPHONE 0x02 177 #define PCI_CLASS_MEDIA_OTHER 0x80 179 #define PCI_CLASS_MEMORY_CONTROLLER 0x05 180 #define PCI_CLASS_MEMORY_RAM 0x00 181 #define PCI_CLASS_MEMORY_FLASH 0x01 182 #define PCI_CLASS_MEMORY_OTHER 0x80 184 #define PCI_CLASS_BRIDGE 0x06 185 #define PCI_CLASS_BRIDGE_HOST 0x00 186 #define PCI_CLASS_BRIDGE_ISA 0x01 187 #define PCI_CLASS_BRIDGE_EISA 0x02 188 #define PCI_CLASS_BRIDGE_MCA 0x03 189 #define PCI_CLASS_BRIDGE_P2P 0x04 190 #define PCI_IF_BRIDGE_P2P 0x00 191 #define PCI_IF_BRIDGE_P2P_SUBTRACTIVE 0x01 192 #define PCI_CLASS_BRIDGE_PCMCIA 0x05 193 #define PCI_CLASS_BRIDGE_NUBUS 0x06 194 #define PCI_CLASS_BRIDGE_CARDBUS 0x07 195 #define PCI_CLASS_BRIDGE_RACEWAY 0x08 196 #define PCI_CLASS_BRIDGE_OTHER 0x80 197 #define PCI_CLASS_BRIDGE_ISA_PDECODE 0x80 199 #define PCI_CLASS_SCC 0x07 200 #define PCI_SUBCLASS_SERIAL 0x00
201 #define PCI_IF_GENERIC_XT 0x00 202 #define PCI_IF_16450 0x01 203 #define PCI_IF_16550 0x02 204 #define PCI_IF_16650 0x03 205 #define PCI_IF_16750 0x04 206 #define PCI_IF_16850 0x05 207 #define PCI_IF_16950 0x06 208 #define PCI_SUBCLASS_PARALLEL 0x01 209 #define PCI_IF_PARALLEL_PORT 0x00 210 #define PCI_IF_BI_DIR_PARALLEL_PORT 0x01 211 #define PCI_IF_ECP_PARALLEL_PORT 0x02 212 #define PCI_IF_1284_CONTROLLER 0x03 213 #define PCI_IF_1284_DEVICE 0xFE 214 #define PCI_SUBCLASS_MULTIPORT_SERIAL 0x02 215 #define PCI_SUBCLASS_MODEM 0x03 216 #define PCI_IF_GENERIC_MODEM 0x00 217 #define PCI_IF_16450_MODEM 0x01 218 #define PCI_IF_16550_MODEM 0x02 219 #define PCI_IF_16650_MODEM 0x03 220 #define PCI_IF_16750_MODEM 0x04 221 #define PCI_SUBCLASS_SCC_OTHER 0x80 223 #define PCI_CLASS_SYSTEM_PERIPHERAL 0x08 224 #define PCI_SUBCLASS_PIC 0x00 225 #define PCI_IF_8259_PIC 0x00 226 #define PCI_IF_ISA_PIC 0x01 227 #define PCI_IF_EISA_PIC 0x02 228 #define PCI_IF_APIC_CONTROLLER 0x10 229 #define PCI_IF_APIC_CONTROLLER2 0x20
230 #define PCI_SUBCLASS_DMA 0x01 231 #define PCI_IF_8237_DMA 0x00 232 #define PCI_IF_ISA_DMA 0x01 233 #define PCI_IF_EISA_DMA 0x02 234 #define PCI_SUBCLASS_TIMER 0x02 235 #define PCI_IF_8254_TIMER 0x00 236 #define PCI_IF_ISA_TIMER 0x01 237 #define PCI_IF_EISA_TIMER 0x02 238 #define PCI_SUBCLASS_RTC 0x03 239 #define PCI_IF_GENERIC_RTC 0x00 240 #define PCI_IF_ISA_RTC 0x01 241 #define PCI_SUBCLASS_PNP_CONTROLLER 0x04 242 #define PCI_SUBCLASS_PERIPHERAL_OTHER 0x80
244 #define PCI_CLASS_INPUT_DEVICE 0x09 245 #define PCI_SUBCLASS_KEYBOARD 0x00 246 #define PCI_SUBCLASS_PEN 0x01 247 #define PCI_SUBCLASS_MOUSE_CONTROLLER 0x02 248 #define PCI_SUBCLASS_SCAN_CONTROLLER 0x03 249 #define PCI_SUBCLASS_GAMEPORT 0x04 250 #define PCI_IF_GAMEPORT 0x00 251 #define PCI_IF_GAMEPORT1 0x10 252 #define PCI_SUBCLASS_INPUT_OTHER 0x80 254 #define PCI_CLASS_DOCKING_STATION 0x0A 255 #define PCI_SUBCLASS_DOCKING_GENERIC 0x00 256 #define PCI_SUBCLASS_DOCKING_OTHER 0x80 258 #define PCI_CLASS_PROCESSOR 0x0B 259 #define PCI_SUBCLASS_PROC_386 0x00 260 #define PCI_SUBCLASS_PROC_486 0x01 261 #define PCI_SUBCLASS_PROC_PENTIUM 0x02 262 #define PCI_SUBCLASS_PROC_ALPHA 0x10 263 #define PCI_SUBCLASS_PROC_POWERPC 0x20 264 #define PCI_SUBCLASS_PROC_MIPS 0x30 265 #define PCI_SUBCLASS_PROC_CO_PORC 0x40 267 #define PCI_CLASS_SERIAL 0x0C 268 #define PCI_CLASS_SERIAL_FIREWIRE 0x00 269 #define PCI_IF_1394 0x00 270 #define PCI_IF_1394_OPEN_HCI 0x10 271 #define PCI_CLASS_SERIAL_ACCESS_BUS 0x01 272 #define PCI_CLASS_SERIAL_SSA 0x02 273 #define PCI_CLASS_SERIAL_USB 0x03 274 #define PCI_IF_UHCI 0x00 275 #define PCI_IF_OHCI 0x10 276 #define PCI_IF_USB_OTHER 0x80 277 #define PCI_IF_USB_DEVICE 0xFE 278 #define PCI_CLASS_SERIAL_FIBRECHANNEL 0x04 279 #define PCI_CLASS_SERIAL_SMB 0x05 281 #define PCI_CLASS_WIRELESS 0x0D 282 #define PCI_SUBCLASS_IRDA 0x00 283 #define PCI_SUBCLASS_IR 0x01 284 #define PCI_SUBCLASS_RF 0x10 285 #define PCI_SUBCLASS_WIRELESS_OTHER 0x80 287 #define PCI_CLASS_INTELLIGENT_IO 0x0E 289 #define PCI_CLASS_SATELLITE 0x0F 290 #define PCI_SUBCLASS_TV 0x01 291 #define PCI_SUBCLASS_AUDIO 0x02 292 #define PCI_SUBCLASS_VOICE 0x03 293 #define PCI_SUBCLASS_DATA 0x04 295 #define PCI_SECURITY_CONTROLLER 0x10 296 #define PCI_SUBCLASS_NET_COMPUT 0x00
297 #define PCI_SUBCLASS_ENTERTAINMENT 0x10 298 #define PCI_SUBCLASS_SECURITY_OTHER 0x80 300 #define PCI_CLASS_DPIO 0x11 301 #define PCI_SUBCLASS_DPIO 0x00 302 #define PCI_SUBCLASS_DPIO_OTHER 0x80 314 #define IS_CLASS1(_p, c) ((_p)->Hdr.ClassCode[2] == (c)) 327 #define IS_CLASS2(_p, c, s) (IS_CLASS1 (_p, c) && ((_p)->Hdr.ClassCode[1] == (s))) 341 #define IS_CLASS3(_p, c, s, p) (IS_CLASS2 (_p, c, s) && ((_p)->Hdr.ClassCode[0] == (p))) 352 #define IS_PCI_DISPLAY(_p) IS_CLASS1 (_p, PCI_CLASS_DISPLAY) 363 #define IS_PCI_VGA(_p) IS_CLASS3 (_p, PCI_CLASS_DISPLAY, PCI_CLASS_DISPLAY_VGA, PCI_IF_VGA_VGA) 374 #define IS_PCI_8514(_p) IS_CLASS3 (_p, PCI_CLASS_DISPLAY, PCI_CLASS_DISPLAY_VGA, PCI_IF_VGA_8514) 385 #define IS_PCI_OLD(_p) IS_CLASS1 (_p, PCI_CLASS_OLD) 396 #define IS_PCI_OLD_VGA(_p) IS_CLASS2 (_p, PCI_CLASS_OLD, PCI_CLASS_OLD_VGA) 407 #define IS_PCI_IDE(_p) IS_CLASS2 (_p, PCI_CLASS_MASS_STORAGE, PCI_CLASS_MASS_STORAGE_IDE) 418 #define IS_PCI_SCSI(_p) IS_CLASS2 (_p, PCI_CLASS_MASS_STORAGE, PCI_CLASS_MASS_STORAGE_SCSI) 429 #define IS_PCI_RAID(_p) IS_CLASS2 (_p, PCI_CLASS_MASS_STORAGE, PCI_CLASS_MASS_STORAGE_RAID) 440 #define IS_PCI_LPC(_p) IS_CLASS2 (_p, PCI_CLASS_BRIDGE, PCI_CLASS_BRIDGE_ISA) 451 #define IS_PCI_P2P(_p) IS_CLASS3 (_p, PCI_CLASS_BRIDGE, PCI_CLASS_BRIDGE_P2P, PCI_IF_BRIDGE_P2P) 462 #define IS_PCI_P2P_SUB(_p) IS_CLASS3 (_p, PCI_CLASS_BRIDGE, PCI_CLASS_BRIDGE_P2P, PCI_IF_BRIDGE_P2P_SUBTRACTIVE) 473 #define IS_PCI_16550_SERIAL(_p) IS_CLASS3 (_p, PCI_CLASS_SCC, PCI_SUBCLASS_SERIAL, PCI_IF_16550) 484 #define IS_PCI_USB(_p) IS_CLASS2 (_p, PCI_CLASS_SERIAL, PCI_CLASS_SERIAL_USB) 489 #define HEADER_TYPE_DEVICE 0x00 490 #define HEADER_TYPE_PCI_TO_PCI_BRIDGE 0x01 491 #define HEADER_TYPE_CARDBUS_BRIDGE 0x02 492 #define HEADER_TYPE_MULTI_FUNCTION 0x80 496 #define HEADER_LAYOUT_CODE 0x7f 507 #define IS_PCI_BRIDGE(_p) (((_p)->Hdr.HeaderType & HEADER_LAYOUT_CODE) == (HEADER_TYPE_PCI_TO_PCI_BRIDGE)) 518 #define IS_CARDBUS_BRIDGE(_p) (((_p)->Hdr.HeaderType & HEADER_LAYOUT_CODE) == (HEADER_TYPE_CARDBUS_BRIDGE)) 529 #define IS_PCI_MULTI_FUNC(_p) ((_p)->Hdr.HeaderType & HEADER_TYPE_MULTI_FUNCTION) 534 #define PCI_BRIDGE_ROMBAR 0x38 536 #define PCI_MAX_BAR 0x0006 537 #define PCI_MAX_CONFIG_OFFSET 0x0100 539 #define PCI_VENDOR_ID_OFFSET 0x00 540 #define PCI_DEVICE_ID_OFFSET 0x02 541 #define PCI_COMMAND_OFFSET 0x04 542 #define PCI_PRIMARY_STATUS_OFFSET 0x06 543 #define PCI_REVISION_ID_OFFSET 0x08 544 #define PCI_CLASSCODE_OFFSET 0x09 545 #define PCI_CACHELINE_SIZE_OFFSET 0x0C 546 #define PCI_LATENCY_TIMER_OFFSET 0x0D 547 #define PCI_HEADER_TYPE_OFFSET 0x0E 548 #define PCI_BIST_OFFSET 0x0F 549 #define PCI_BASE_ADDRESSREG_OFFSET 0x10 550 #define PCI_CARDBUS_CIS_OFFSET 0x28 551 #define PCI_SVID_OFFSET 0x2C 552 #define PCI_SUBSYSTEM_VENDOR_ID_OFFSET 0x2C
553 #define PCI_SID_OFFSET 0x2E 554 #define PCI_SUBSYSTEM_ID_OFFSET 0x2E
555 #define PCI_EXPANSION_ROM_BASE 0x30 556 #define PCI_CAPBILITY_POINTER_OFFSET 0x34 557 #define PCI_INT_LINE_OFFSET 0x3C 558 #define PCI_INT_PIN_OFFSET 0x3D
559 #define PCI_MAXGNT_OFFSET 0x3E
560 #define PCI_MAXLAT_OFFSET 0x3F
565 #define PCI_BRIDGE_PRIMARY_BUS_REGISTER_OFFSET 0x18 566 #define PCI_BRIDGE_SECONDARY_BUS_REGISTER_OFFSET 0x19 567 #define PCI_BRIDGE_SUBORDINATE_BUS_REGISTER_OFFSET 0x1a 568 #define PCI_BRIDGE_SECONDARY_LATENCY_TIMER_OFFSET 0x1b 569 #define PCI_BRIDGE_STATUS_REGISTER_OFFSET 0x1E 570 #define PCI_BRIDGE_CONTROL_REGISTER_OFFSET 0x3E 575 #define PCI_INT_LINE_UNKNOWN 0xFF 594 #define EFI_PCI_COMMAND_IO_SPACE BIT0 595 #define EFI_PCI_COMMAND_MEMORY_SPACE BIT1
596 #define EFI_PCI_COMMAND_BUS_MASTER BIT2
597 #define EFI_PCI_COMMAND_SPECIAL_CYCLE BIT3
598 #define EFI_PCI_COMMAND_MEMORY_WRITE_AND_INVALIDATE BIT4
599 #define EFI_PCI_COMMAND_VGA_PALETTE_SNOOP BIT5
600 #define EFI_PCI_COMMAND_PARITY_ERROR_RESPOND BIT6
601 #define EFI_PCI_COMMAND_STEPPING_CONTROL BIT7
602 #define EFI_PCI_COMMAND_SERR BIT8
603 #define EFI_PCI_COMMAND_FAST_BACK_TO_BACK BIT9
608 #define EFI_PCI_BRIDGE_CONTROL_PARITY_ERROR_RESPONSE BIT0 609 #define EFI_PCI_BRIDGE_CONTROL_SERR BIT1
610 #define EFI_PCI_BRIDGE_CONTROL_ISA BIT2
611 #define EFI_PCI_BRIDGE_CONTROL_VGA BIT3
612 #define EFI_PCI_BRIDGE_CONTROL_VGA_16 BIT4
613 #define EFI_PCI_BRIDGE_CONTROL_MASTER_ABORT BIT5
614 #define EFI_PCI_BRIDGE_CONTROL_RESET_SECONDARY_BUS BIT6
615 #define EFI_PCI_BRIDGE_CONTROL_FAST_BACK_TO_BACK BIT7
616 #define EFI_PCI_BRIDGE_CONTROL_PRIMARY_DISCARD_TIMER BIT8
617 #define EFI_PCI_BRIDGE_CONTROL_SECONDARY_DISCARD_TIMER BIT9
618 #define EFI_PCI_BRIDGE_CONTROL_TIMER_STATUS BIT10
619 #define EFI_PCI_BRIDGE_CONTROL_DISCARD_TIMER_SERR BIT11
624 #define EFI_PCI_BRIDGE_CONTROL_IREQINT_ENABLE BIT7 625 #define EFI_PCI_BRIDGE_CONTROL_RANGE0_MEMORY_TYPE BIT8
626 #define EFI_PCI_BRIDGE_CONTROL_RANGE1_MEMORY_TYPE BIT9
627 #define EFI_PCI_BRIDGE_CONTROL_WRITE_POSTING_ENABLE BIT10
632 #define EFI_PCI_STATUS_CAPABILITY BIT4 633 #define EFI_PCI_STATUS_66MZ_CAPABLE BIT5
634 #define EFI_PCI_FAST_BACK_TO_BACK_CAPABLE BIT7
635 #define EFI_PCI_MASTER_DATA_PARITY_ERROR BIT8
640 #define EFI_PCI_CARDBUS_BRIDGE_CAPABILITY_PTR 0x14 646 #define EFI_PCI_CAPABILITY_ID_PMI 0x01 647 #define EFI_PCI_CAPABILITY_ID_AGP 0x02 648 #define EFI_PCI_CAPABILITY_ID_VPD 0x03 649 #define EFI_PCI_CAPABILITY_ID_SLOTID 0x04 650 #define EFI_PCI_CAPABILITY_ID_MSI 0x05 651 #define EFI_PCI_CAPABILITY_ID_HOTPLUG 0x06 652 #define EFI_PCI_CAPABILITY_ID_SHPC 0x0C 681 #define EFI_PCI_PMC_D3_COLD_MASK (BIT15) 701 #define PCI_POWER_STATE_D0 0 702 #define PCI_POWER_STATE_D1 1 703 #define PCI_POWER_STATE_D2 2 704 #define PCI_POWER_STATE_D3_HOT 3 797 #define PCI_BAR_IDX0 0x00 798 #define PCI_BAR_IDX1 0x01 799 #define PCI_BAR_IDX2 0x02 800 #define PCI_BAR_IDX3 0x03 801 #define PCI_BAR_IDX4 0x04 802 #define PCI_BAR_IDX5 0x05 807 #define EFI_ROOT_BRIDGE_LIST 'eprb' 808 #define EFI_PCI_EXPANSION_ROM_HEADER_EFISIGNATURE 0x0EF1 810 #define PCI_EXPANSION_ROM_HEADER_SIGNATURE 0xaa55 811 #define PCI_DATA_STRUCTURE_SIGNATURE SIGNATURE_32 ('P', 'C', 'I', 'R') 812 #define PCI_CODE_TYPE_PCAT_IMAGE 0x00 813 #define EFI_PCI_EXPANSION_ROM_HEADER_COMPRESSED 0x0001
UINT8 PciBusNumber
PCI Bus Number.
PCI-to-PCI Bridge Configuration Space Section 3.2, PCI-PCI Bridge Architecture, Version 1....
UINT8 CardBusBusNumber
CardBus Bus Number.
UINT32 IoLimit0
I/O Base Register 0.
Message Capability Structure for 64-bit Message Address Section 6.8.1, PCI Local Bus Specification,...
EFI_PCI_CAPABILITY_HDR Hdr
EFI_PCI_CAPABILITY_HDR Hdr
UINT32_t Reserved[2]
Must be zero.
PMCSR - Power Management Control/Status Section 3.2.4, PCI Power Management Interface Specification,...
A.G.P Capability Section 6.1.4, Accelerated Graphics Port Interface Specification,...
UINT32 IoBase1
I/O Limit Register 0.
VPD Capability Structure Appendix I, PCI Local Bus Specification, 2.2.
UINT16 SecondaryStatus
Secondary Status.
UINT8 SubordinateBusNumber
Subordinate Bus Number.
UINT32 CardBusSocketReg
Cardbus Socket/ExCA Base.
PMCSR_BSE - PMCSR PCI-to-PCI Bridge Support Extensions Section 3.2.5, PCI Power Management Interface ...
FILE_LICENCE(BSD2_PATENT)
UINT8 BusPowerClockControl
UINT16 PrefetchableMemoryBase
EFI_PCI_CAPABILITY_HDR Hdr
Capability EFI_PCI_CAPABILITY_ID_HOTPLUG, CompactPCI Hot Swap Specification PICMG 2....
PCI_BRIDGE_CONTROL_REGISTER Bridge
PCI Device Configuration Space Section 6.1, PCI Local Bus Specification, 2.2.
PCI_DEVICE_INDEPENDENT_REGION Hdr
PCI_DEVICE_INDEPENDENT_REGION Hdr
UINT16 ReservedForPciExpress
PCI-PCI Bridge header region in PCI Configuration Space Section 3.2, PCI-PCI Bridge Architecture,...
Power Management Register Block Definition Section 3.2, PCI Power Management Interface Specification,...
CardBus Controller Configuration Space, Section 4.5.1, PC Card Standard.
EFI_PCI_PMCSR_BSE BridgeExtention
UINT32 MemoryBase0
Memory Base Register 0.
UINT16 PrefetchableMemoryLimit
EFI_PCI_CAPABILITY_HDR Hdr
PACKED struct @540::@554 Bits
EFI_PCI_CAPABILITY_HDR Hdr
Message Capability Structure for 32-bit Message Address Section 6.8.1, PCI Local Bus Specification,...
Slot Numbering Capabilities Register Section 3.2.6, PCI-to-PCI Bridge Architecture Specification,...
UINT32 MemoryLimit0
Memory Limit Register 0.
UINT8 InterruptLine
Interrupt Line.
UINT8 SecondaryLatencyTimer
UINT16 BridgeControl
Bridge Control.
EFI_PCI_CAPABILITY_HDR Hdr
UINT8 CardBusLatencyTimer
CardBus Latency Timer.
PCI Data Structure Format Section 6.3.1.2, PCI Local Bus Specification, 2.2.
PCI_DEVICE_HEADER_TYPE_REGION Device
Common header region in PCI Configuration Space Section 6.1, PCI Local Bus Specification,...
PMC - Power Management Capabilities Section 3.2.3, PCI Power Management Interface Specification,...
UINT32 PrefetchableLimitUpper32
UINT32 PrefetchableBaseUpper32
EFI_PCI_CAPABILITY_HDR Hdr
UINT8 InterruptPin
Interrupt Pin.
Capabilities List Header Section 6.7, PCI Local Bus Specification, 2.2.
UINT16 DeviceSpecificInitialization