VGA bios support for PowerPC

git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@1494 c046a42c-6fe2-441c-8c8c-71466251a162
This commit is contained in:
bellard 2005-07-03 14:00:51 +00:00
parent fb3444b86c
commit d5295253b0
8 changed files with 65 additions and 21 deletions

View File

@ -59,7 +59,7 @@ install: all
mkdir -p "$(datadir)" mkdir -p "$(datadir)"
install -m 644 pc-bios/bios.bin pc-bios/vgabios.bin \ install -m 644 pc-bios/bios.bin pc-bios/vgabios.bin \
pc-bios/vgabios-cirrus.bin \ pc-bios/vgabios-cirrus.bin \
pc-bios/ppc_rom.bin \ pc-bios/ppc_rom.bin pc-bios/video.x \
pc-bios/proll.elf \ pc-bios/proll.elf \
pc-bios/linux_boot.bin "$(datadir)" pc-bios/linux_boot.bin "$(datadir)"
mkdir -p "$(docdir)" mkdir -p "$(docdir)"
@ -121,6 +121,7 @@ tarbin:
$(datadir)/vgabios.bin \ $(datadir)/vgabios.bin \
$(datadir)/vgabios-cirrus.bin \ $(datadir)/vgabios-cirrus.bin \
$(datadir)/ppc_rom.bin \ $(datadir)/ppc_rom.bin \
$(datadir)/video.x \
$(datadir)/proll.elf \ $(datadir)/proll.elf \
$(datadir)/linux_boot.bin \ $(datadir)/linux_boot.bin \
$(docdir)/qemu-doc.html \ $(docdir)/qemu-doc.html \

View File

@ -242,7 +242,7 @@ void mips_r4k_init (int ram_size, int vga_ram_size, int boot_device,
isa_pic = pic_init(pic_irq_request, cpu_single_env); isa_pic = pic_init(pic_irq_request, cpu_single_env);
serial_init(0x3f8, 4, serial_hds[0]); serial_init(0x3f8, 4, serial_hds[0]);
vga_initialize(NULL, ds, phys_ram_base + ram_size, ram_size, vga_initialize(NULL, ds, phys_ram_base + ram_size, ram_size,
vga_ram_size); vga_ram_size, 0, 0);
isa_ne2000_init(0x300, 9, &nd_table[0]); isa_ne2000_init(0x300, 9, &nd_table[0]);
} }

View File

@ -547,7 +547,7 @@ static void pc_init1(int ram_size, int vga_ram_size, int boot_device,
} }
} else { } else {
vga_initialize(pci_bus, ds, phys_ram_base + ram_size, ram_size, vga_initialize(pci_bus, ds, phys_ram_base + ram_size, ram_size,
vga_ram_size); vga_ram_size, 0, 0);
} }
rtc_state = rtc_init(0x70, 8); rtc_state = rtc_init(0x70, 8);

View File

@ -24,6 +24,7 @@
#include "vl.h" #include "vl.h"
#define BIOS_FILENAME "ppc_rom.bin" #define BIOS_FILENAME "ppc_rom.bin"
#define VGABIOS_FILENAME "video.x"
#define NVRAM_SIZE 0x2000 #define NVRAM_SIZE 0x2000
#define KERNEL_LOAD_ADDR 0x01000000 #define KERNEL_LOAD_ADDR 0x01000000
@ -232,12 +233,13 @@ static void ppc_chrp_init(int ram_size, int vga_ram_size, int boot_device,
void *pic; void *pic;
m48t59_t *nvram; m48t59_t *nvram;
int PPC_io_memory, unin_memory; int PPC_io_memory, unin_memory;
int ret, linux_boot, i; int linux_boot, i;
unsigned long bios_offset; unsigned long bios_offset, vga_bios_offset;
uint32_t kernel_base, kernel_size, initrd_base, initrd_size; uint32_t kernel_base, kernel_size, initrd_base, initrd_size;
ppc_def_t *def; ppc_def_t *def;
PCIBus *pci_bus; PCIBus *pci_bus;
const char *arch_name; const char *arch_name;
int vga_bios_size, bios_size;
linux_boot = (kernel_filename != NULL); linux_boot = (kernel_filename != NULL);
@ -247,14 +249,35 @@ static void ppc_chrp_init(int ram_size, int vga_ram_size, int boot_device,
/* allocate and load BIOS */ /* allocate and load BIOS */
bios_offset = ram_size + vga_ram_size; bios_offset = ram_size + vga_ram_size;
snprintf(buf, sizeof(buf), "%s/%s", bios_dir, BIOS_FILENAME); snprintf(buf, sizeof(buf), "%s/%s", bios_dir, BIOS_FILENAME);
ret = load_image(buf, phys_ram_base + bios_offset); bios_size = load_image(buf, phys_ram_base + bios_offset);
if (ret != BIOS_SIZE) { if (bios_size < 0 || bios_size > BIOS_SIZE) {
fprintf(stderr, "qemu: could not load PPC PREP bios '%s'\n", buf); fprintf(stderr, "qemu: could not load PowerPC bios '%s'\n", buf);
exit(1); exit(1);
} }
cpu_register_physical_memory((uint32_t)(-BIOS_SIZE), bios_size = (bios_size + 0xfff) & ~0xfff;
BIOS_SIZE, bios_offset | IO_MEM_ROM); cpu_register_physical_memory((uint32_t)(-bios_size),
cpu_single_env->nip = 0xfffffffc; bios_size, bios_offset | IO_MEM_ROM);
/* allocate and load VGA BIOS */
vga_bios_offset = bios_offset + bios_size;
snprintf(buf, sizeof(buf), "%s/%s", bios_dir, VGABIOS_FILENAME);
vga_bios_size = load_image(buf, phys_ram_base + vga_bios_offset + 8);
if (vga_bios_size < 0) {
/* if no bios is present, we can still work */
fprintf(stderr, "qemu: warning: could not load VGA bios '%s'\n", buf);
vga_bios_size = 0;
} else {
/* set a specific header (XXX: find real Apple format for NDRV
drivers) */
phys_ram_base[vga_bios_offset] = 'N';
phys_ram_base[vga_bios_offset + 1] = 'D';
phys_ram_base[vga_bios_offset + 2] = 'R';
phys_ram_base[vga_bios_offset + 3] = 'V';
cpu_to_be32w((uint32_t *)(phys_ram_base + vga_bios_offset + 4),
vga_bios_size);
vga_bios_size += 8;
}
vga_bios_size = (vga_bios_size + 0xfff) & ~0xfff;
if (linux_boot) { if (linux_boot) {
kernel_base = KERNEL_LOAD_ADDR; kernel_base = KERNEL_LOAD_ADDR;
@ -321,8 +344,9 @@ static void ppc_chrp_init(int ram_size, int vga_ram_size, int boot_device,
cpu_register_physical_memory(0xfe000000, 0x00200000, PPC_io_memory); cpu_register_physical_memory(0xfe000000, 0x00200000, PPC_io_memory);
/* init basic PC hardware */ /* init basic PC hardware */
vga_initialize(pci_bus, ds, phys_ram_base + ram_size, ram_size, vga_initialize(pci_bus, ds, phys_ram_base + ram_size,
vga_ram_size); ram_size, vga_ram_size,
vga_bios_offset, vga_bios_size);
pic = heathrow_pic_init(&heathrow_pic_mem_index); pic = heathrow_pic_init(&heathrow_pic_mem_index);
set_irq = heathrow_pic_set_irq; set_irq = heathrow_pic_set_irq;
pci_set_pic(pci_bus, set_irq, pic); 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,
cpu_register_physical_memory(0xf8000000, 0x00001000, unin_memory); cpu_register_physical_memory(0xf8000000, 0x00001000, unin_memory);
/* init basic PC hardware */ /* init basic PC hardware */
vga_initialize(pci_bus, ds, phys_ram_base + ram_size, ram_size, vga_initialize(pci_bus, ds, phys_ram_base + ram_size,
vga_ram_size); ram_size, vga_ram_size,
vga_bios_offset, vga_bios_size);
pic = openpic_init(NULL, &openpic_mem_index, 1); pic = openpic_init(NULL, &openpic_mem_index, 1);
set_irq = openpic_set_irq; set_irq = openpic_set_irq;
pci_set_pic(pci_bus, set_irq, pic); pci_set_pic(pci_bus, set_irq, pic);

View File

@ -1654,9 +1654,12 @@ static void vga_map(PCIDevice *pci_dev, int region_num,
uint32_t addr, uint32_t size, int type) uint32_t addr, uint32_t size, int type)
{ {
VGAState *s = vga_state; VGAState *s = vga_state;
if (region_num == PCI_ROM_SLOT) {
cpu_register_physical_memory(addr, s->bios_size, s->bios_offset);
} else {
cpu_register_physical_memory(addr, s->vram_size, s->vram_offset); cpu_register_physical_memory(addr, s->vram_size, s->vram_offset);
} }
}
void vga_common_init(VGAState *s, DisplayState *ds, uint8_t *vga_ram_base, void vga_common_init(VGAState *s, DisplayState *ds, uint8_t *vga_ram_base,
unsigned long vga_ram_offset, int vga_ram_size) unsigned long vga_ram_offset, int vga_ram_size)
@ -1701,7 +1704,8 @@ void vga_common_init(VGAState *s, DisplayState *ds, uint8_t *vga_ram_base,
int vga_initialize(PCIBus *bus, DisplayState *ds, uint8_t *vga_ram_base, int vga_initialize(PCIBus *bus, DisplayState *ds, uint8_t *vga_ram_base,
unsigned long vga_ram_offset, int vga_ram_size) unsigned long vga_ram_offset, int vga_ram_size,
unsigned long vga_bios_offset, int vga_bios_size)
{ {
VGAState *s; VGAState *s;
@ -1776,6 +1780,17 @@ int vga_initialize(PCIBus *bus, DisplayState *ds, uint8_t *vga_ram_base,
/* XXX: vga_ram_size must be a power of two */ /* XXX: vga_ram_size must be a power of two */
pci_register_io_region(d, 0, vga_ram_size, pci_register_io_region(d, 0, vga_ram_size,
PCI_ADDRESS_SPACE_MEM_PREFETCH, vga_map); PCI_ADDRESS_SPACE_MEM_PREFETCH, vga_map);
if (vga_bios_size != 0) {
unsigned int bios_total_size;
s->bios_offset = vga_bios_offset;
s->bios_size = vga_bios_size;
/* must be a power of two */
bios_total_size = 1;
while (bios_total_size < vga_bios_size)
bios_total_size <<= 1;
pci_register_io_region(d, PCI_ROM_SLOT, bios_total_size,
PCI_ADDRESS_SPACE_MEM_PREFETCH, vga_map);
}
} else { } else {
#ifdef CONFIG_BOCHS_VBE #ifdef CONFIG_BOCHS_VBE
/* XXX: use optimized standard vga accesses */ /* XXX: use optimized standard vga accesses */

View File

@ -78,6 +78,8 @@
uint8_t *vram_ptr; \ uint8_t *vram_ptr; \
unsigned long vram_offset; \ unsigned long vram_offset; \
unsigned int vram_size; \ unsigned int vram_size; \
unsigned long bios_offset; \
unsigned int bios_size; \
uint32_t latch; \ uint32_t latch; \
uint8_t sr_index; \ uint8_t sr_index; \
uint8_t sr[256]; \ uint8_t sr[256]; \

BIN
pc-bios/video.x Normal file

Binary file not shown.

5
vl.h
View File

@ -137,7 +137,7 @@ extern int win2k_install_hack;
/* XXX: make it dynamic */ /* XXX: make it dynamic */
#if defined (TARGET_PPC) #if defined (TARGET_PPC)
#define BIOS_SIZE (512 * 1024) #define BIOS_SIZE ((512 + 32) * 1024)
#elif defined(TARGET_MIPS) #elif defined(TARGET_MIPS)
#define BIOS_SIZE (128 * 1024) #define BIOS_SIZE (128 * 1024)
#else #else
@ -596,7 +596,8 @@ static inline void dpy_resize(DisplayState *s, int w, int h)
} }
int vga_initialize(PCIBus *bus, DisplayState *ds, uint8_t *vga_ram_base, int vga_initialize(PCIBus *bus, DisplayState *ds, uint8_t *vga_ram_base,
unsigned long vga_ram_offset, int vga_ram_size); unsigned long vga_ram_offset, int vga_ram_size,
unsigned long vga_bios_offset, int vga_bios_size);
void vga_update_display(void); void vga_update_display(void);
void vga_invalidate_display(void); void vga_invalidate_display(void);
void vga_screen_dump(const char *filename); void vga_screen_dump(const char *filename);