Commit d5295253b0d2baf190180b08c2a531021af91c99
1 parent
fb3444b8
VGA bios support for PowerPC
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@1494 c046a42c-6fe2-441c-8c8c-71466251a162
Showing
8 changed files
with
65 additions
and
21 deletions
Makefile
... | ... | @@ -59,7 +59,7 @@ install: all |
59 | 59 | mkdir -p "$(datadir)" |
60 | 60 | install -m 644 pc-bios/bios.bin pc-bios/vgabios.bin \ |
61 | 61 | pc-bios/vgabios-cirrus.bin \ |
62 | - pc-bios/ppc_rom.bin \ | |
62 | + pc-bios/ppc_rom.bin pc-bios/video.x \ | |
63 | 63 | pc-bios/proll.elf \ |
64 | 64 | pc-bios/linux_boot.bin "$(datadir)" |
65 | 65 | mkdir -p "$(docdir)" |
... | ... | @@ -121,6 +121,7 @@ tarbin: |
121 | 121 | $(datadir)/vgabios.bin \ |
122 | 122 | $(datadir)/vgabios-cirrus.bin \ |
123 | 123 | $(datadir)/ppc_rom.bin \ |
124 | + $(datadir)/video.x \ | |
124 | 125 | $(datadir)/proll.elf \ |
125 | 126 | $(datadir)/linux_boot.bin \ |
126 | 127 | $(docdir)/qemu-doc.html \ | ... | ... |
hw/mips_r4k.c
... | ... | @@ -242,7 +242,7 @@ void mips_r4k_init (int ram_size, int vga_ram_size, int boot_device, |
242 | 242 | isa_pic = pic_init(pic_irq_request, cpu_single_env); |
243 | 243 | serial_init(0x3f8, 4, serial_hds[0]); |
244 | 244 | vga_initialize(NULL, ds, phys_ram_base + ram_size, ram_size, |
245 | - vga_ram_size); | |
245 | + vga_ram_size, 0, 0); | |
246 | 246 | |
247 | 247 | isa_ne2000_init(0x300, 9, &nd_table[0]); |
248 | 248 | } | ... | ... |
hw/pc.c
... | ... | @@ -547,7 +547,7 @@ static void pc_init1(int ram_size, int vga_ram_size, int boot_device, |
547 | 547 | } |
548 | 548 | } else { |
549 | 549 | vga_initialize(pci_bus, ds, phys_ram_base + ram_size, ram_size, |
550 | - vga_ram_size); | |
550 | + vga_ram_size, 0, 0); | |
551 | 551 | } |
552 | 552 | |
553 | 553 | rtc_state = rtc_init(0x70, 8); | ... | ... |
hw/ppc_chrp.c
... | ... | @@ -24,6 +24,7 @@ |
24 | 24 | #include "vl.h" |
25 | 25 | |
26 | 26 | #define BIOS_FILENAME "ppc_rom.bin" |
27 | +#define VGABIOS_FILENAME "video.x" | |
27 | 28 | #define NVRAM_SIZE 0x2000 |
28 | 29 | |
29 | 30 | #define KERNEL_LOAD_ADDR 0x01000000 |
... | ... | @@ -232,12 +233,13 @@ static void ppc_chrp_init(int ram_size, int vga_ram_size, int boot_device, |
232 | 233 | void *pic; |
233 | 234 | m48t59_t *nvram; |
234 | 235 | int PPC_io_memory, unin_memory; |
235 | - int ret, linux_boot, i; | |
236 | - unsigned long bios_offset; | |
236 | + int linux_boot, i; | |
237 | + unsigned long bios_offset, vga_bios_offset; | |
237 | 238 | uint32_t kernel_base, kernel_size, initrd_base, initrd_size; |
238 | 239 | ppc_def_t *def; |
239 | 240 | PCIBus *pci_bus; |
240 | 241 | const char *arch_name; |
242 | + int vga_bios_size, bios_size; | |
241 | 243 | |
242 | 244 | linux_boot = (kernel_filename != NULL); |
243 | 245 | |
... | ... | @@ -247,15 +249,36 @@ static void ppc_chrp_init(int ram_size, int vga_ram_size, int boot_device, |
247 | 249 | /* allocate and load BIOS */ |
248 | 250 | bios_offset = ram_size + vga_ram_size; |
249 | 251 | snprintf(buf, sizeof(buf), "%s/%s", bios_dir, BIOS_FILENAME); |
250 | - ret = load_image(buf, phys_ram_base + bios_offset); | |
251 | - if (ret != BIOS_SIZE) { | |
252 | - fprintf(stderr, "qemu: could not load PPC PREP bios '%s'\n", buf); | |
252 | + bios_size = load_image(buf, phys_ram_base + bios_offset); | |
253 | + if (bios_size < 0 || bios_size > BIOS_SIZE) { | |
254 | + fprintf(stderr, "qemu: could not load PowerPC bios '%s'\n", buf); | |
253 | 255 | exit(1); |
254 | 256 | } |
255 | - cpu_register_physical_memory((uint32_t)(-BIOS_SIZE), | |
256 | - BIOS_SIZE, bios_offset | IO_MEM_ROM); | |
257 | - cpu_single_env->nip = 0xfffffffc; | |
258 | - | |
257 | + bios_size = (bios_size + 0xfff) & ~0xfff; | |
258 | + cpu_register_physical_memory((uint32_t)(-bios_size), | |
259 | + bios_size, bios_offset | IO_MEM_ROM); | |
260 | + | |
261 | + /* allocate and load VGA BIOS */ | |
262 | + vga_bios_offset = bios_offset + bios_size; | |
263 | + snprintf(buf, sizeof(buf), "%s/%s", bios_dir, VGABIOS_FILENAME); | |
264 | + vga_bios_size = load_image(buf, phys_ram_base + vga_bios_offset + 8); | |
265 | + if (vga_bios_size < 0) { | |
266 | + /* if no bios is present, we can still work */ | |
267 | + fprintf(stderr, "qemu: warning: could not load VGA bios '%s'\n", buf); | |
268 | + vga_bios_size = 0; | |
269 | + } else { | |
270 | + /* set a specific header (XXX: find real Apple format for NDRV | |
271 | + drivers) */ | |
272 | + phys_ram_base[vga_bios_offset] = 'N'; | |
273 | + phys_ram_base[vga_bios_offset + 1] = 'D'; | |
274 | + phys_ram_base[vga_bios_offset + 2] = 'R'; | |
275 | + phys_ram_base[vga_bios_offset + 3] = 'V'; | |
276 | + cpu_to_be32w((uint32_t *)(phys_ram_base + vga_bios_offset + 4), | |
277 | + vga_bios_size); | |
278 | + vga_bios_size += 8; | |
279 | + } | |
280 | + vga_bios_size = (vga_bios_size + 0xfff) & ~0xfff; | |
281 | + | |
259 | 282 | if (linux_boot) { |
260 | 283 | kernel_base = KERNEL_LOAD_ADDR; |
261 | 284 | /* now we can load the kernel */ |
... | ... | @@ -321,8 +344,9 @@ static void ppc_chrp_init(int ram_size, int vga_ram_size, int boot_device, |
321 | 344 | cpu_register_physical_memory(0xfe000000, 0x00200000, PPC_io_memory); |
322 | 345 | |
323 | 346 | /* init basic PC hardware */ |
324 | - vga_initialize(pci_bus, ds, phys_ram_base + ram_size, ram_size, | |
325 | - vga_ram_size); | |
347 | + vga_initialize(pci_bus, ds, phys_ram_base + ram_size, | |
348 | + ram_size, vga_ram_size, | |
349 | + vga_bios_offset, vga_bios_size); | |
326 | 350 | pic = heathrow_pic_init(&heathrow_pic_mem_index); |
327 | 351 | set_irq = heathrow_pic_set_irq; |
328 | 352 | pci_set_pic(pci_bus, set_irq, pic); |
... | ... | @@ -363,8 +387,9 @@ static void ppc_chrp_init(int ram_size, int vga_ram_size, int boot_device, |
363 | 387 | cpu_register_physical_memory(0xf8000000, 0x00001000, unin_memory); |
364 | 388 | |
365 | 389 | /* init basic PC hardware */ |
366 | - vga_initialize(pci_bus, ds, phys_ram_base + ram_size, ram_size, | |
367 | - vga_ram_size); | |
390 | + vga_initialize(pci_bus, ds, phys_ram_base + ram_size, | |
391 | + ram_size, vga_ram_size, | |
392 | + vga_bios_offset, vga_bios_size); | |
368 | 393 | pic = openpic_init(NULL, &openpic_mem_index, 1); |
369 | 394 | set_irq = openpic_set_irq; |
370 | 395 | pci_set_pic(pci_bus, set_irq, pic); | ... | ... |
hw/vga.c
... | ... | @@ -1654,8 +1654,11 @@ static void vga_map(PCIDevice *pci_dev, int region_num, |
1654 | 1654 | uint32_t addr, uint32_t size, int type) |
1655 | 1655 | { |
1656 | 1656 | VGAState *s = vga_state; |
1657 | - | |
1658 | - cpu_register_physical_memory(addr, s->vram_size, s->vram_offset); | |
1657 | + if (region_num == PCI_ROM_SLOT) { | |
1658 | + cpu_register_physical_memory(addr, s->bios_size, s->bios_offset); | |
1659 | + } else { | |
1660 | + cpu_register_physical_memory(addr, s->vram_size, s->vram_offset); | |
1661 | + } | |
1659 | 1662 | } |
1660 | 1663 | |
1661 | 1664 | void vga_common_init(VGAState *s, DisplayState *ds, uint8_t *vga_ram_base, |
... | ... | @@ -1701,7 +1704,8 @@ void vga_common_init(VGAState *s, DisplayState *ds, uint8_t *vga_ram_base, |
1701 | 1704 | |
1702 | 1705 | |
1703 | 1706 | int vga_initialize(PCIBus *bus, DisplayState *ds, uint8_t *vga_ram_base, |
1704 | - unsigned long vga_ram_offset, int vga_ram_size) | |
1707 | + unsigned long vga_ram_offset, int vga_ram_size, | |
1708 | + unsigned long vga_bios_offset, int vga_bios_size) | |
1705 | 1709 | { |
1706 | 1710 | VGAState *s; |
1707 | 1711 | |
... | ... | @@ -1776,6 +1780,17 @@ int vga_initialize(PCIBus *bus, DisplayState *ds, uint8_t *vga_ram_base, |
1776 | 1780 | /* XXX: vga_ram_size must be a power of two */ |
1777 | 1781 | pci_register_io_region(d, 0, vga_ram_size, |
1778 | 1782 | PCI_ADDRESS_SPACE_MEM_PREFETCH, vga_map); |
1783 | + if (vga_bios_size != 0) { | |
1784 | + unsigned int bios_total_size; | |
1785 | + s->bios_offset = vga_bios_offset; | |
1786 | + s->bios_size = vga_bios_size; | |
1787 | + /* must be a power of two */ | |
1788 | + bios_total_size = 1; | |
1789 | + while (bios_total_size < vga_bios_size) | |
1790 | + bios_total_size <<= 1; | |
1791 | + pci_register_io_region(d, PCI_ROM_SLOT, bios_total_size, | |
1792 | + PCI_ADDRESS_SPACE_MEM_PREFETCH, vga_map); | |
1793 | + } | |
1779 | 1794 | } else { |
1780 | 1795 | #ifdef CONFIG_BOCHS_VBE |
1781 | 1796 | /* XXX: use optimized standard vga accesses */ | ... | ... |
hw/vga_int.h
pc-bios/video.x
0 → 100644
No preview for this file type
vl.h
... | ... | @@ -137,7 +137,7 @@ extern int win2k_install_hack; |
137 | 137 | |
138 | 138 | /* XXX: make it dynamic */ |
139 | 139 | #if defined (TARGET_PPC) |
140 | -#define BIOS_SIZE (512 * 1024) | |
140 | +#define BIOS_SIZE ((512 + 32) * 1024) | |
141 | 141 | #elif defined(TARGET_MIPS) |
142 | 142 | #define BIOS_SIZE (128 * 1024) |
143 | 143 | #else |
... | ... | @@ -596,7 +596,8 @@ static inline void dpy_resize(DisplayState *s, int w, int h) |
596 | 596 | } |
597 | 597 | |
598 | 598 | int vga_initialize(PCIBus *bus, DisplayState *ds, uint8_t *vga_ram_base, |
599 | - unsigned long vga_ram_offset, int vga_ram_size); | |
599 | + unsigned long vga_ram_offset, int vga_ram_size, | |
600 | + unsigned long vga_bios_offset, int vga_bios_size); | |
600 | 601 | void vga_update_display(void); |
601 | 602 | void vga_invalidate_display(void); |
602 | 603 | void vga_screen_dump(const char *filename); | ... | ... |