Commit 271dd5e09ee1d8ad4438471211ffbf6b5a377084
1 parent
95efd11c
Use the firmware configuration device
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@6130 c046a42c-6fe2-441c-8c8c-71466251a162
Showing
1 changed file
with
14 additions
and
0 deletions
hw/ppc_oldworld.c
| ... | ... | @@ -32,9 +32,17 @@ |
| 32 | 32 | #include "isa.h" |
| 33 | 33 | #include "pci.h" |
| 34 | 34 | #include "boards.h" |
| 35 | +#include "fw_cfg.h" | |
| 35 | 36 | |
| 36 | 37 | #define MAX_IDE_BUS 2 |
| 37 | 38 | #define VGA_BIOS_SIZE 65536 |
| 39 | +#define CFG_ADDR 0xf0000510 | |
| 40 | + | |
| 41 | +enum { | |
| 42 | + ARCH_PREP = 0, | |
| 43 | + ARCH_MAC99, | |
| 44 | + ARCH_HEATHROW, | |
| 45 | +}; | |
| 38 | 46 | |
| 39 | 47 | /* temporary frame buffer OSI calls for the video.x driver. The right |
| 40 | 48 | solution is to modify the driver to use VGA PCI I/Os */ |
| ... | ... | @@ -128,6 +136,7 @@ static void ppc_heathrow_init (ram_addr_t ram_size, int vga_ram_size, |
| 128 | 136 | int ppc_boot_device; |
| 129 | 137 | BlockDriverState *hd[MAX_IDE_BUS * MAX_IDE_DEVS]; |
| 130 | 138 | int index; |
| 139 | + void *fw_cfg; | |
| 131 | 140 | |
| 132 | 141 | linux_boot = (kernel_filename != NULL); |
| 133 | 142 | |
| ... | ... | @@ -363,6 +372,11 @@ static void ppc_heathrow_init (ram_addr_t ram_size, int vga_ram_size, |
| 363 | 372 | |
| 364 | 373 | /* Special port to get debug messages from Open-Firmware */ |
| 365 | 374 | register_ioport_write(0x0F00, 4, 1, &PPC_debug_write, NULL); |
| 375 | + | |
| 376 | + fw_cfg = fw_cfg_init(0, 0, CFG_ADDR, CFG_ADDR + 2); | |
| 377 | + fw_cfg_add_i32(fw_cfg, FW_CFG_ID, 1); | |
| 378 | + fw_cfg_add_i64(fw_cfg, FW_CFG_RAM_SIZE, (uint64_t)ram_size); | |
| 379 | + fw_cfg_add_i16(fw_cfg, FW_CFG_MACHINE_ID, ARCH_HEATHROW); | |
| 366 | 380 | } |
| 367 | 381 | |
| 368 | 382 | QEMUMachine heathrow_machine = { | ... | ... |