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:
parent
fb3444b86c
commit
d5295253b0
3
Makefile
3
Makefile
@ -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 \
|
||||||
|
@ -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]);
|
||||||
}
|
}
|
||||||
|
2
hw/pc.c
2
hw/pc.c
@ -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);
|
||||||
|
@ -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);
|
||||||
|
19
hw/vga.c
19
hw/vga.c
@ -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 */
|
||||||
|
@ -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
BIN
pc-bios/video.x
Normal file
Binary file not shown.
5
vl.h
5
vl.h
@ -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);
|
||||||
|
Loading…
Reference in New Issue
Block a user