21 #define PCI_MAX_BUS 255 22 #define PCI_MAX_DEVICE 31 23 #define PCI_MAX_FUNC 7 144 #define PCI_CLASS_OLD 0x00 145 #define PCI_CLASS_OLD_OTHER 0x00 146 #define PCI_CLASS_OLD_VGA 0x01 148 #define PCI_CLASS_MASS_STORAGE 0x01 149 #define PCI_CLASS_MASS_STORAGE_SCSI 0x00 150 #define PCI_CLASS_MASS_STORAGE_IDE 0x01 151 #define PCI_CLASS_MASS_STORAGE_FLOPPY 0x02 152 #define PCI_CLASS_MASS_STORAGE_IPI 0x03 153 #define PCI_CLASS_MASS_STORAGE_RAID 0x04 154 #define PCI_CLASS_MASS_STORAGE_OTHER 0x80 156 #define PCI_CLASS_NETWORK 0x02 157 #define PCI_CLASS_NETWORK_ETHERNET 0x00 158 #define PCI_CLASS_NETWORK_TOKENRING 0x01 159 #define PCI_CLASS_NETWORK_FDDI 0x02 160 #define PCI_CLASS_NETWORK_ATM 0x03 161 #define PCI_CLASS_NETWORK_ISDN 0x04 162 #define PCI_CLASS_NETWORK_OTHER 0x80 164 #define PCI_CLASS_DISPLAY 0x03 165 #define PCI_CLASS_DISPLAY_VGA 0x00 166 #define PCI_IF_VGA_VGA 0x00 167 #define PCI_IF_VGA_8514 0x01 168 #define PCI_CLASS_DISPLAY_XGA 0x01 169 #define PCI_CLASS_DISPLAY_3D 0x02 170 #define PCI_CLASS_DISPLAY_OTHER 0x80 172 #define PCI_CLASS_MEDIA 0x04 173 #define PCI_CLASS_MEDIA_VIDEO 0x00 174 #define PCI_CLASS_MEDIA_AUDIO 0x01 175 #define PCI_CLASS_MEDIA_TELEPHONE 0x02 176 #define PCI_CLASS_MEDIA_OTHER 0x80 178 #define PCI_CLASS_MEMORY_CONTROLLER 0x05 179 #define PCI_CLASS_MEMORY_RAM 0x00 180 #define PCI_CLASS_MEMORY_FLASH 0x01 181 #define PCI_CLASS_MEMORY_OTHER 0x80 183 #define PCI_CLASS_BRIDGE 0x06 184 #define PCI_CLASS_BRIDGE_HOST 0x00 185 #define PCI_CLASS_BRIDGE_ISA 0x01 186 #define PCI_CLASS_BRIDGE_EISA 0x02 187 #define PCI_CLASS_BRIDGE_MCA 0x03 188 #define PCI_CLASS_BRIDGE_P2P 0x04 189 #define PCI_IF_BRIDGE_P2P 0x00 190 #define PCI_IF_BRIDGE_P2P_SUBTRACTIVE 0x01 191 #define PCI_CLASS_BRIDGE_PCMCIA 0x05 192 #define PCI_CLASS_BRIDGE_NUBUS 0x06 193 #define PCI_CLASS_BRIDGE_CARDBUS 0x07 194 #define PCI_CLASS_BRIDGE_RACEWAY 0x08 195 #define PCI_CLASS_BRIDGE_OTHER 0x80 196 #define PCI_CLASS_BRIDGE_ISA_PDECODE 0x80 198 #define PCI_CLASS_SCC 0x07 199 #define PCI_SUBCLASS_SERIAL 0x00
200 #define PCI_IF_GENERIC_XT 0x00 201 #define PCI_IF_16450 0x01 202 #define PCI_IF_16550 0x02 203 #define PCI_IF_16650 0x03 204 #define PCI_IF_16750 0x04 205 #define PCI_IF_16850 0x05 206 #define PCI_IF_16950 0x06 207 #define PCI_SUBCLASS_PARALLEL 0x01 208 #define PCI_IF_PARALLEL_PORT 0x00 209 #define PCI_IF_BI_DIR_PARALLEL_PORT 0x01 210 #define PCI_IF_ECP_PARALLEL_PORT 0x02 211 #define PCI_IF_1284_CONTROLLER 0x03 212 #define PCI_IF_1284_DEVICE 0xFE 213 #define PCI_SUBCLASS_MULTIPORT_SERIAL 0x02 214 #define PCI_SUBCLASS_MODEM 0x03 215 #define PCI_IF_GENERIC_MODEM 0x00 216 #define PCI_IF_16450_MODEM 0x01 217 #define PCI_IF_16550_MODEM 0x02 218 #define PCI_IF_16650_MODEM 0x03 219 #define PCI_IF_16750_MODEM 0x04 220 #define PCI_SUBCLASS_SCC_OTHER 0x80 222 #define PCI_CLASS_SYSTEM_PERIPHERAL 0x08 223 #define PCI_SUBCLASS_PIC 0x00 224 #define PCI_IF_8259_PIC 0x00 225 #define PCI_IF_ISA_PIC 0x01 226 #define PCI_IF_EISA_PIC 0x02 227 #define PCI_IF_APIC_CONTROLLER 0x10 228 #define PCI_IF_APIC_CONTROLLER2 0x20
229 #define PCI_SUBCLASS_DMA 0x01 230 #define PCI_IF_8237_DMA 0x00 231 #define PCI_IF_ISA_DMA 0x01 232 #define PCI_IF_EISA_DMA 0x02 233 #define PCI_SUBCLASS_TIMER 0x02 234 #define PCI_IF_8254_TIMER 0x00 235 #define PCI_IF_ISA_TIMER 0x01 236 #define PCI_IF_EISA_TIMER 0x02 237 #define PCI_SUBCLASS_RTC 0x03 238 #define PCI_IF_GENERIC_RTC 0x00 239 #define PCI_IF_ISA_RTC 0x01 240 #define PCI_SUBCLASS_PNP_CONTROLLER 0x04 241 #define PCI_SUBCLASS_PERIPHERAL_OTHER 0x80
243 #define PCI_CLASS_INPUT_DEVICE 0x09 244 #define PCI_SUBCLASS_KEYBOARD 0x00 245 #define PCI_SUBCLASS_PEN 0x01 246 #define PCI_SUBCLASS_MOUSE_CONTROLLER 0x02 247 #define PCI_SUBCLASS_SCAN_CONTROLLER 0x03 248 #define PCI_SUBCLASS_GAMEPORT 0x04 249 #define PCI_IF_GAMEPORT 0x00 250 #define PCI_IF_GAMEPORT1 0x10 251 #define PCI_SUBCLASS_INPUT_OTHER 0x80 253 #define PCI_CLASS_DOCKING_STATION 0x0A 254 #define PCI_SUBCLASS_DOCKING_GENERIC 0x00 255 #define PCI_SUBCLASS_DOCKING_OTHER 0x80 257 #define PCI_CLASS_PROCESSOR 0x0B 258 #define PCI_SUBCLASS_PROC_386 0x00 259 #define PCI_SUBCLASS_PROC_486 0x01 260 #define PCI_SUBCLASS_PROC_PENTIUM 0x02 261 #define PCI_SUBCLASS_PROC_ALPHA 0x10 262 #define PCI_SUBCLASS_PROC_POWERPC 0x20 263 #define PCI_SUBCLASS_PROC_MIPS 0x30 264 #define PCI_SUBCLASS_PROC_CO_PORC 0x40 266 #define PCI_CLASS_SERIAL 0x0C 267 #define PCI_CLASS_SERIAL_FIREWIRE 0x00 268 #define PCI_IF_1394 0x00 269 #define PCI_IF_1394_OPEN_HCI 0x10 270 #define PCI_CLASS_SERIAL_ACCESS_BUS 0x01 271 #define PCI_CLASS_SERIAL_SSA 0x02 272 #define PCI_CLASS_SERIAL_USB 0x03 273 #define PCI_IF_UHCI 0x00 274 #define PCI_IF_OHCI 0x10 275 #define PCI_IF_USB_OTHER 0x80 276 #define PCI_IF_USB_DEVICE 0xFE 277 #define PCI_CLASS_SERIAL_FIBRECHANNEL 0x04 278 #define PCI_CLASS_SERIAL_SMB 0x05 280 #define PCI_CLASS_WIRELESS 0x0D 281 #define PCI_SUBCLASS_IRDA 0x00 282 #define PCI_SUBCLASS_IR 0x01 283 #define PCI_SUBCLASS_RF 0x10 284 #define PCI_SUBCLASS_WIRELESS_OTHER 0x80 286 #define PCI_CLASS_INTELLIGENT_IO 0x0E 288 #define PCI_CLASS_SATELLITE 0x0F 289 #define PCI_SUBCLASS_TV 0x01 290 #define PCI_SUBCLASS_AUDIO 0x02 291 #define PCI_SUBCLASS_VOICE 0x03 292 #define PCI_SUBCLASS_DATA 0x04 294 #define PCI_SECURITY_CONTROLLER 0x10 295 #define PCI_SUBCLASS_NET_COMPUT 0x00
296 #define PCI_SUBCLASS_ENTERTAINMENT 0x10 297 #define PCI_SUBCLASS_SECURITY_OTHER 0x80 299 #define PCI_CLASS_DPIO 0x11 300 #define PCI_SUBCLASS_DPIO 0x00 301 #define PCI_SUBCLASS_DPIO_OTHER 0x80 313 #define IS_CLASS1(_p, c) ((_p)->Hdr.ClassCode[2] == (c)) 326 #define IS_CLASS2(_p, c, s) (IS_CLASS1 (_p, c) && ((_p)->Hdr.ClassCode[1] == (s))) 340 #define IS_CLASS3(_p, c, s, p) (IS_CLASS2 (_p, c, s) && ((_p)->Hdr.ClassCode[0] == (p))) 351 #define IS_PCI_DISPLAY(_p) IS_CLASS1 (_p, PCI_CLASS_DISPLAY) 362 #define IS_PCI_VGA(_p) IS_CLASS3 (_p, PCI_CLASS_DISPLAY, PCI_CLASS_DISPLAY_VGA, PCI_IF_VGA_VGA) 373 #define IS_PCI_8514(_p) IS_CLASS3 (_p, PCI_CLASS_DISPLAY, PCI_CLASS_DISPLAY_VGA, PCI_IF_VGA_8514) 384 #define IS_PCI_OLD(_p) IS_CLASS1 (_p, PCI_CLASS_OLD) 395 #define IS_PCI_OLD_VGA(_p) IS_CLASS2 (_p, PCI_CLASS_OLD, PCI_CLASS_OLD_VGA) 406 #define IS_PCI_IDE(_p) IS_CLASS2 (_p, PCI_CLASS_MASS_STORAGE, PCI_CLASS_MASS_STORAGE_IDE) 417 #define IS_PCI_SCSI(_p) IS_CLASS2 (_p, PCI_CLASS_MASS_STORAGE, PCI_CLASS_MASS_STORAGE_SCSI) 428 #define IS_PCI_RAID(_p) IS_CLASS2 (_p, PCI_CLASS_MASS_STORAGE, PCI_CLASS_MASS_STORAGE_RAID) 439 #define IS_PCI_LPC(_p) IS_CLASS2 (_p, PCI_CLASS_BRIDGE, PCI_CLASS_BRIDGE_ISA) 450 #define IS_PCI_P2P(_p) IS_CLASS3 (_p, PCI_CLASS_BRIDGE, PCI_CLASS_BRIDGE_P2P, PCI_IF_BRIDGE_P2P) 461 #define IS_PCI_P2P_SUB(_p) IS_CLASS3 (_p, PCI_CLASS_BRIDGE, PCI_CLASS_BRIDGE_P2P, PCI_IF_BRIDGE_P2P_SUBTRACTIVE) 472 #define IS_PCI_16550_SERIAL(_p) IS_CLASS3 (_p, PCI_CLASS_SCC, PCI_SUBCLASS_SERIAL, PCI_IF_16550) 483 #define IS_PCI_USB(_p) IS_CLASS2 (_p, PCI_CLASS_SERIAL, PCI_CLASS_SERIAL_USB) 488 #define HEADER_TYPE_DEVICE 0x00 489 #define HEADER_TYPE_PCI_TO_PCI_BRIDGE 0x01 490 #define HEADER_TYPE_CARDBUS_BRIDGE 0x02 491 #define HEADER_TYPE_MULTI_FUNCTION 0x80 495 #define HEADER_LAYOUT_CODE 0x7f 506 #define IS_PCI_BRIDGE(_p) (((_p)->Hdr.HeaderType & HEADER_LAYOUT_CODE) == (HEADER_TYPE_PCI_TO_PCI_BRIDGE)) 517 #define IS_CARDBUS_BRIDGE(_p) (((_p)->Hdr.HeaderType & HEADER_LAYOUT_CODE) == (HEADER_TYPE_CARDBUS_BRIDGE)) 528 #define IS_PCI_MULTI_FUNC(_p) ((_p)->Hdr.HeaderType & HEADER_TYPE_MULTI_FUNCTION) 533 #define PCI_BRIDGE_ROMBAR 0x38 535 #define PCI_MAX_BAR 0x0006 536 #define PCI_MAX_CONFIG_OFFSET 0x0100 538 #define PCI_VENDOR_ID_OFFSET 0x00 539 #define PCI_DEVICE_ID_OFFSET 0x02 540 #define PCI_COMMAND_OFFSET 0x04 541 #define PCI_PRIMARY_STATUS_OFFSET 0x06 542 #define PCI_REVISION_ID_OFFSET 0x08 543 #define PCI_CLASSCODE_OFFSET 0x09 544 #define PCI_CACHELINE_SIZE_OFFSET 0x0C 545 #define PCI_LATENCY_TIMER_OFFSET 0x0D 546 #define PCI_HEADER_TYPE_OFFSET 0x0E 547 #define PCI_BIST_OFFSET 0x0F 548 #define PCI_BASE_ADDRESSREG_OFFSET 0x10 549 #define PCI_CARDBUS_CIS_OFFSET 0x28 550 #define PCI_SVID_OFFSET 0x2C 551 #define PCI_SUBSYSTEM_VENDOR_ID_OFFSET 0x2C
552 #define PCI_SID_OFFSET 0x2E 553 #define PCI_SUBSYSTEM_ID_OFFSET 0x2E
554 #define PCI_EXPANSION_ROM_BASE 0x30 555 #define PCI_CAPBILITY_POINTER_OFFSET 0x34 556 #define PCI_INT_LINE_OFFSET 0x3C 557 #define PCI_INT_PIN_OFFSET 0x3D
558 #define PCI_MAXGNT_OFFSET 0x3E
559 #define PCI_MAXLAT_OFFSET 0x3F
564 #define PCI_BRIDGE_PRIMARY_BUS_REGISTER_OFFSET 0x18 565 #define PCI_BRIDGE_SECONDARY_BUS_REGISTER_OFFSET 0x19 566 #define PCI_BRIDGE_SUBORDINATE_BUS_REGISTER_OFFSET 0x1a 567 #define PCI_BRIDGE_SECONDARY_LATENCY_TIMER_OFFSET 0x1b 568 #define PCI_BRIDGE_STATUS_REGISTER_OFFSET 0x1E 569 #define PCI_BRIDGE_CONTROL_REGISTER_OFFSET 0x3E 574 #define PCI_INT_LINE_UNKNOWN 0xFF 593 #define EFI_PCI_COMMAND_IO_SPACE BIT0 594 #define EFI_PCI_COMMAND_MEMORY_SPACE BIT1
595 #define EFI_PCI_COMMAND_BUS_MASTER BIT2
596 #define EFI_PCI_COMMAND_SPECIAL_CYCLE BIT3
597 #define EFI_PCI_COMMAND_MEMORY_WRITE_AND_INVALIDATE BIT4
598 #define EFI_PCI_COMMAND_VGA_PALETTE_SNOOP BIT5
599 #define EFI_PCI_COMMAND_PARITY_ERROR_RESPOND BIT6
600 #define EFI_PCI_COMMAND_STEPPING_CONTROL BIT7
601 #define EFI_PCI_COMMAND_SERR BIT8
602 #define EFI_PCI_COMMAND_FAST_BACK_TO_BACK BIT9
607 #define EFI_PCI_BRIDGE_CONTROL_PARITY_ERROR_RESPONSE BIT0 608 #define EFI_PCI_BRIDGE_CONTROL_SERR BIT1
609 #define EFI_PCI_BRIDGE_CONTROL_ISA BIT2
610 #define EFI_PCI_BRIDGE_CONTROL_VGA BIT3
611 #define EFI_PCI_BRIDGE_CONTROL_VGA_16 BIT4
612 #define EFI_PCI_BRIDGE_CONTROL_MASTER_ABORT BIT5
613 #define EFI_PCI_BRIDGE_CONTROL_RESET_SECONDARY_BUS BIT6
614 #define EFI_PCI_BRIDGE_CONTROL_FAST_BACK_TO_BACK BIT7
615 #define EFI_PCI_BRIDGE_CONTROL_PRIMARY_DISCARD_TIMER BIT8
616 #define EFI_PCI_BRIDGE_CONTROL_SECONDARY_DISCARD_TIMER BIT9
617 #define EFI_PCI_BRIDGE_CONTROL_TIMER_STATUS BIT10
618 #define EFI_PCI_BRIDGE_CONTROL_DISCARD_TIMER_SERR BIT11
623 #define EFI_PCI_BRIDGE_CONTROL_IREQINT_ENABLE BIT7 624 #define EFI_PCI_BRIDGE_CONTROL_RANGE0_MEMORY_TYPE BIT8
625 #define EFI_PCI_BRIDGE_CONTROL_RANGE1_MEMORY_TYPE BIT9
626 #define EFI_PCI_BRIDGE_CONTROL_WRITE_POSTING_ENABLE BIT10
631 #define EFI_PCI_STATUS_CAPABILITY BIT4 632 #define EFI_PCI_STATUS_66MZ_CAPABLE BIT5
633 #define EFI_PCI_FAST_BACK_TO_BACK_CAPABLE BIT7
634 #define EFI_PCI_MASTER_DATA_PARITY_ERROR BIT8
639 #define EFI_PCI_CARDBUS_BRIDGE_CAPABILITY_PTR 0x14 645 #define EFI_PCI_CAPABILITY_ID_PMI 0x01 646 #define EFI_PCI_CAPABILITY_ID_AGP 0x02 647 #define EFI_PCI_CAPABILITY_ID_VPD 0x03 648 #define EFI_PCI_CAPABILITY_ID_SLOTID 0x04 649 #define EFI_PCI_CAPABILITY_ID_MSI 0x05 650 #define EFI_PCI_CAPABILITY_ID_HOTPLUG 0x06 651 #define EFI_PCI_CAPABILITY_ID_SHPC 0x0C 680 #define EFI_PCI_PMC_D3_COLD_MASK (BIT15) 700 #define PCI_POWER_STATE_D0 0 701 #define PCI_POWER_STATE_D1 1 702 #define PCI_POWER_STATE_D2 2 703 #define PCI_POWER_STATE_D3_HOT 3 796 #define PCI_BAR_IDX0 0x00 797 #define PCI_BAR_IDX1 0x01 798 #define PCI_BAR_IDX2 0x02 799 #define PCI_BAR_IDX3 0x03 800 #define PCI_BAR_IDX4 0x04 801 #define PCI_BAR_IDX5 0x05 806 #define EFI_ROOT_BRIDGE_LIST 'eprb' 807 #define EFI_PCI_EXPANSION_ROM_HEADER_EFISIGNATURE 0x0EF1 809 #define PCI_EXPANSION_ROM_HEADER_SIGNATURE 0xaa55 810 #define PCI_DATA_STRUCTURE_SIGNATURE SIGNATURE_32 ('P', 'C', 'I', 'R') 811 #define PCI_CODE_TYPE_PCAT_IMAGE 0x00 812 #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
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.
PACKED struct @531::@545 Bits
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