Revision c6d25871

b/pc-bios/bios-pq/0013_fix-non-acpi-timer-interrupt-routing.patch
1
Fix non-ACPI Timer Interrupt Routing (Beth Kon)
2

  
3
Replicate ACPI irq0->inti2 override in mp table for non-acpi case.
4

  
5
v1 -> v2 adds comment suggested by Ryan.
6

  
7
Signed-off-by: Beth Kon <eak@us.ibm.com>
8
Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
9

  
10
diff --git a/bios/rombios32.c b/bios/rombios32.c
11
index 7be4216..dc7b5f3 100644
12
--- a/bios/rombios32.c
13
+++ b/bios/rombios32.c
14
@@ -1168,6 +1168,12 @@ static void mptable_init(void)
15
 
16
     /* irqs */
17
     for(i = 0; i < 16; i++) {
18
+#ifdef BX_QEMU
19
+        /* One entry per ioapic input. Input 2 is covered by 
20
+           irq0->inti2 override (i == 0). irq 2 is unused */
21
+        if (i == 2)
22
+            continue;
23
+#endif        
24
         putb(&q, 3); /* entry type = I/O interrupt */
25
         putb(&q, 0); /* interrupt type = vectored interrupt */
26
         putb(&q, 0); /* flags: po=0, el=0 */
27
@@ -1175,7 +1181,11 @@ static void mptable_init(void)
28
         putb(&q, 0); /* source bus ID = ISA */
29
         putb(&q, i); /* source bus IRQ */
30
         putb(&q, ioapic_id); /* dest I/O APIC ID */
31
+#ifdef BX_QEMU
32
+        putb(&q, i == 0 ? 2 : i); /* dest I/O APIC interrupt in */
33
+#else
34
         putb(&q, i); /* dest I/O APIC interrupt in */
35
+#endif        
36
     }
37
     /* patch length */
38
     len = q - mp_config_table;
b/pc-bios/bios-pq/series
10 10
0010_bios-mark-the-acpi-sci-interrupt-as-connected-to-irq-9.patch
11 11
0011_read-additional-acpi-tables-from-a-vm.patch
12 12
0012-load-smbios-entries-and-files-from-qemu.patch
13
0013_fix-non-acpi-timer-interrupt-routing.patch

Also available in: Unified diff