Commit ebd7fc5099f8c643a2427bc18b8333d0cebef0d5
1 parent
fe76d976
Make sure ACPI structures are byte-aligned
Apparently, guests are very tolerant of corrupt ACPI tables because our tables have been badly corrupted for some time now. A version of Knoppix using a 2.6.11 kernel refused to boot and it turned out it was due to the interrupt override table introduced by the recent HPET commit. This patch updates the BIOS and introduces a patch to pack the ACPI tables. If you have a guest that used to work and is broken by the this commit, let me know. We have some weird hacks in the tables that I suspect are work arounds for this bug. Signed-off-by: Anthony Liguori <aliguori@us.ibm.com> git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@6108 c046a42c-6fe2-441c-8c8c-71466251a162
Showing
3 changed files
with
37 additions
and
0 deletions
pc-bios/bios-pq/0006_acpi-packing.patch
0 → 100644
1 | +Make ACPI tables byte-aligned | ||
2 | + | ||
3 | +The ACPI spec requires structures to be byte-aligned. I'm a bit surprised we've | ||
4 | +gotten away with this for so long. This patch allows Knoppix to boot. This bug | ||
5 | +was reported by Paul Brook. | ||
6 | + | ||
7 | +Signed-off-by: Anthony Liguori <aliguori@us.ibm.com> | ||
8 | + | ||
9 | +diff --git a/bios/rombios32.c b/bios/rombios32.c | ||
10 | +index 7953485..540912a 100644 | ||
11 | +--- a/bios/rombios32.c | ||
12 | ++++ b/bios/rombios32.c | ||
13 | +@@ -1099,6 +1099,12 @@ static void mptable_init(void) | ||
14 | + /* Table structure from Linux kernel (the ACPI tables are under the | ||
15 | + BSD license) */ | ||
16 | + | ||
17 | ++/* | ||
18 | ++ * All tables must be byte-packed to match the ACPI specification, since | ||
19 | ++ * the tables are provided by the system BIOS. | ||
20 | ++ */ | ||
21 | ++#pragma pack(1) | ||
22 | ++ | ||
23 | + #define ACPI_TABLE_HEADER_DEF /* ACPI common table header */ \ | ||
24 | + uint8_t signature [4]; /* ACPI signature (4 ASCII characters) */\ | ||
25 | + uint32_t length; /* Length of table, in bytes, including header */\ | ||
26 | +@@ -1326,6 +1332,10 @@ struct madt_int_override | ||
27 | + }; | ||
28 | + #endif | ||
29 | + | ||
30 | ++/* Reset to default packing */ | ||
31 | ++ | ||
32 | ++#pragma pack() | ||
33 | ++ | ||
34 | + #include "acpi-dsdt.hex" | ||
35 | + | ||
36 | + static inline uint16_t cpu_to_le16(uint16_t x) |
pc-bios/bios-pq/series
pc-bios/bios.bin
No preview for this file type