aboutsummaryrefslogtreecommitdiff
path: root/hw
diff options
context:
space:
mode:
authorAlex Williamson <alex.williamson@redhat.com>2010-11-07 20:57:00 -0700
committerAnthony Liguori <aliguori@us.ibm.com>2010-11-16 14:35:00 -0600
commit8ca209ad90bdb678932a6b18caf32b461dbe5eee (patch)
treeac1f897ee9155a1ca23b44e1e604fb0062b37f69 /hw
parent67d4b0c1907455f42ad8cea445ff10b81b49eebc (diff)
downloadqemu-8ca209ad90bdb678932a6b18caf32b461dbe5eee.zip
qemu-8ca209ad90bdb678932a6b18caf32b461dbe5eee.tar.gz
qemu-8ca209ad90bdb678932a6b18caf32b461dbe5eee.tar.bz2
pc: Fix e820 fw_cfg for big endian
Signed-off-by: Alex Williamson <alex.williamson@redhat.com> Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
Diffstat (limited to 'hw')
-rw-r--r--hw/pc.c14
1 files changed, 7 insertions, 7 deletions
diff --git a/hw/pc.c b/hw/pc.c
index e7f7ac6..c34d194 100644
--- a/hw/pc.c
+++ b/hw/pc.c
@@ -467,19 +467,19 @@ static void bochs_bios_write(void *opaque, uint32_t addr, uint32_t val)
int e820_add_entry(uint64_t address, uint64_t length, uint32_t type)
{
- int index = e820_table.count;
+ int index = le32_to_cpu(e820_table.count);
struct e820_entry *entry;
if (index >= E820_NR_ENTRIES)
return -EBUSY;
- entry = &e820_table.entry[index];
+ entry = &e820_table.entry[index++];
- entry->address = address;
- entry->length = length;
- entry->type = type;
+ entry->address = cpu_to_le64(address);
+ entry->length = cpu_to_le64(length);
+ entry->type = cpu_to_le32(type);
- e820_table.count++;
- return e820_table.count;
+ e820_table.count = cpu_to_le32(index);
+ return index;
}
static void *bochs_bios_init(void)