Intel
82801BA ICH2 Datasheet
5-55
Functional Description
in that it is never retried. The reason for this is that Remote Read is a debug feature, and a "hung"
remote APIC that is unable to respond should not cause the debugger to hang.
5.8.4
PCI Message-Based Interrupts
5.8.4.1
Theory of Operation
The following scheme is only supported when the internal I/O(x) APIC is used (rather than just the
8259). The ICH2 supports the new method for PCI devices to deliver interrupts as write cycles,
rather than using the traditional PIRQ[A:D] signals. Essentially, the PCI devices are given a write
path directly to a register that will cause the desired interrupt. This mode is only supported when
the ICH2’s internal I/O APIC is enabled. Upon recognizing the write from the peripheral, the ICH2
sends the interrupt message to the processor using the I/O APIC’s serial bus.
The interrupts associated with the PCI Message-based interrupt method must be set up for edge-
triggered mode (rather than level-triggered) since the peripheral only does the write to indicate the
edge.
The following sequence is used:
1. During PCI PnP, the PCI peripheral is first programmed with an address
(MESSAGE_ADDRESS) and data value (MESSAGE_DATA) that will be used for the
interrupt message delivery. For the ICH2, the MESSAGE_ADDRESS is the IRQ Pin
Assertion Register, which is mapped to memory location: FEC0_0020h (same as APIC).
2. To cause the interrupt, the PCI peripheral requests the PCI bus and when granted, writes the
MESSAGE_DATA value to the location indicated by the MESSAGE_ADDRESS. The
MESSAGE_DATA value indicates which interrupt occurred. This MESSAGE_DATA value
is a binary encoded. For example, to indicate that interrupt 7 should go active, the peripheral
will write a binary value of 0000111. The MESSAGE_DATA will be a 32-bit value, although
only the lower 5 bits are used.
3. If the PRQ bit in the APIC Version Register is set, the ICH2 positively decodes the cycles (as
a slave) in medium time.
4. The ICH2 decodes the binary value written to MESSAGE_ADDRESS and sets the appropriate
IRR bit in the internal I/O APIC. The corresponding interrupt must be set up for edge-
triggered interrupts. The ICH2 supports interrupts 00h through 23h. Binary values outside this
range will not cause any action.
5. After sending the interrupt message to the processor, the ICH2 automatically clears the
interrupt.
Because they are edge-tiggered, the interrupts that are allocated to the PCI bus for this scheme may
not be shared with any other interrupt (e.g., the standard PCI PIRQ[A:D], those received via
SERIRQ#, or the internal level-triggered interrupts such as SCI or TCO).
The ICH2 ignores interrupt messages sent by PCI masters that attempt to use IRQ[0,2,8, or 13].
5.8.4.2
Registers and Bits Associated with PCI Interrupt Delivery
Capabilities Indication
The capability to support PCI interrupt delivery will be indicated via ACPI configuration
techniques. This involves the BIOS creating a data structure that gets reported to the ACPI
configuration software. The operating system reads the PRQ bit in the APIC Version Register to
see if the ICH2 is capable of support PCI-based interrupt messages. As a precaution, the PRQ bit is
not set if the XAPIC_EN bit is not set.
Powered by ICminer.com Electronic-Library Service CopyRight 2003