PCI Bridge acpi apic routing

Question about which tools to use, bugs, the best way to implement a function, etc should go here. Don't forget to see if your question is answered in the wiki first! When in doubt post here.
Post Reply
digo_rp
Member
Member
Posts: 233
Joined: Sun Jun 05, 2005 11:00 pm

PCI Bridge acpi apic routing

Post by digo_rp »

Hi all,

Let me try to explain.

for now I can read acpi apic routing table " method _PRT ". but my biggest question is.

for all devices in BUS 00 I lookup at the table... its fine! ok!

when I have devices under the bridge? like my ethernet card: BUS 2, DEVICE 0, FUNCTION 0.

I cannot understand what can I do. that information is not in the acpi apic routing table.

can anyone help me please?
digo_rp
Member
Member
Posts: 233
Joined: Sun Jun 05, 2005 11:00 pm

Re: PCI Bridge acpi apic routing

Post by digo_rp »

problem solved, Just scan PCI BUS looking for PCIBridge for that BUS example " 2 ", then look at the acpi apic routing and find what irq is assign for Device and int pin for that bridge device and funcion.

But I have some problem. how can I execute a _PRT method in acpi ? and how can I inform acpi that I want to use apic, insted of PIC 8259?

I read so many pdf from acpica, etc. I cannot understand. I have a virtualbox and I'm testing my os changing chipset from ICH9 to PIIX3.
using ICH9 and enable IOAPIC, everything works, but when I change to PIIX3 with IOAPIC, all irqs from PCI is in mode PIC 8259. I cannot find how to get what irq table is using...


tnx all.
User avatar
Brendan
Member
Member
Posts: 8561
Joined: Sat Jan 15, 2005 12:00 am
Location: At his keyboard!
Contact:

Re: PCI Bridge acpi apic routing

Post by Brendan »

Hi,
digo_rp wrote:and how can I inform acpi that I want to use apic, insted of PIC 8259?
The firmware's AML has a global "_PIC" method that you're supposed to execute to tell it you want to use IO APICs.
digo_rp wrote:But I have some problem. how can I execute a _PRT method in acpi ?
To execute AML (ACPI Machine Language) you need an interpreter (e.g. something that fetches the next machine code instruction, figures out what it is, then emulates the instruction; and keeps doing that in a loop).

Of course this interpreter will need to allow the AML to access various things (IO ports, PCI configuration space, ...) and there's no sane/easy way to tell if the AML was maliciously tampered with before the OS was booted, so now you've got "potentially malicious AML" accessing various things (IO ports, PCI configuration space, ...). ;)


Cheers,

Brendan
For all things; perfection is, and will always remain, impossible to achieve in practice. However; by striving for perfection we create things that are as perfect as practically possible. Let the pursuit of perfection be our guide.
digo_rp
Member
Member
Posts: 233
Joined: Sun Jun 05, 2005 11:00 pm

Re: PCI Bridge acpi apic routing

Post by digo_rp »

tnx a lot Brendan.

but do you know the best way to discover if acpi is using apic or picm without an interpreter?

Because using virtualbox with PIIX3 chipset with IOAPIC, just work PIC 8259 ISA Interrupt routed to PCI. and when I change to ICH9, then I can use APIC Interrupts.

example: my network card is at legacy IRQ 9 PIN 1 <- INTA, with PIIX3 with IOAPIC, with apic enable, all pci are routed to PIC 8259 ISA IRQ.
User avatar
Brendan
Member
Member
Posts: 8561
Joined: Sat Jan 15, 2005 12:00 am
Location: At his keyboard!
Contact:

Re: PCI Bridge acpi apic routing

Post by Brendan »

Hi,
digo_rp wrote:but do you know the best way to discover if acpi is using apic or picm without an interpreter?
This is a bit backwards - typically you don't discover what ACPI is using; the OS decides what it wants to use (e.g. using FADT to determine if PIC chips exist, using MADT to determine of IO APICs exist) and then tells ACPI what it wants to use. If the OS doesn't tell ACPI that it wants to use IO APICs; then (if PIC chips exist) ACPI assumes the OS will be using PIC chips and won't be using IO APICs at all.

It's also not going to help much - you will need "something" to determine (and possibly reconfigure) IRQ routing, and to switch to different sleep states, and to control fan speeds, and to handle various events (to wake the OS up, to inform it a device was inserted, ...) and for many other things. Trying to figure out "PIC or IO APIC" without an AML interpreter today just postpones the problem until tomorrow when you want to do everything else without an AML interpreter.

There's are only 4 actual solutions that I know of:
  • Use an AML interpreter (e.g. port ACPICA)
  • Spend ages researching and implementing an "AML to native" compiler so that you can convert the AML to native and execute it without an interpreter. Note: This doesn't make much sense because AML isn't performance critical, the native compiler won't be portable, and AML is only part of the problem anyway.
  • Write a motherboard driver for every motherboard (most likely based on any motherboard/chipset datasheet you can get your hands on combined with a disassembly of the motherboard's AML)
  • Don't use ACPI at all (and rely on backward compatibility), which means no power management, no IO APIC, no hot-plug PCI, ...
digo_rp wrote:Because using virtualbox with PIIX3 chipset with IOAPIC, just work PIC 8259 ISA Interrupt routed to PCI. and when I change to ICH9, then I can use APIC Interrupts.

example: my network card is at legacy IRQ 9 PIN 1 <- INTA, with PIIX3 with IOAPIC, with apic enable, all pci are routed to PIC 8259 ISA IRQ.
The worse type of bug a programmer can have is "works by accident" because there's no symptoms to tell the programmer that their code is completely wrong.

If VirtualBox uses "IO APIC input number = legacy PIC input number" then that's just a trap to lead unsuspecting victims towards "works by accident" bugs.


Cheers,

Brendan
For all things; perfection is, and will always remain, impossible to achieve in practice. However; by striving for perfection we create things that are as perfect as practically possible. Let the pursuit of perfection be our guide.
digo_rp
Member
Member
Posts: 233
Joined: Sun Jun 05, 2005 11:00 pm

Re: PCI Bridge acpi apic routing

Post by digo_rp »

thx so much.
Post Reply