X-Git-Url: https://vcs.maemo.org/git/?a=blobdiff_plain;f=hw%2Fvmware_vga.c;h=e850952da1abb79f4b3c0d2bd398251abfef6738;hb=cd346349b45ef056f138a184f660b8c34c3213cc;hp=1a4f4cd9d34ff2477de8e21176889a3c5994b9e2;hpb=d34cab9f49bc3ad83a2a968fc2d2719179db2c15;p=qemu diff --git a/hw/vmware_vga.c b/hw/vmware_vga.c index 1a4f4cd..e850952 100644 --- a/hw/vmware_vga.c +++ b/hw/vmware_vga.c @@ -114,14 +114,14 @@ struct pci_vmsvga_state_s { # define SVGA_IO_BASE SVGA_LEGACY_BASE_PORT # define SVGA_IO_MUL 1 # define SVGA_FIFO_SIZE 0x10000 -# define SVGA_MEM_BASE 0xec000000 +# define SVGA_MEM_BASE 0xe0000000 # define SVGA_PCI_DEVICE_ID PCI_DEVICE_ID_VMWARE_SVGA2 #else # define SVGA_ID SVGA_ID_1 # define SVGA_IO_BASE SVGA_LEGACY_BASE_PORT # define SVGA_IO_MUL 4 # define SVGA_FIFO_SIZE 0x10000 -# define SVGA_MEM_BASE 0xec000000 +# define SVGA_MEM_BASE 0xe0000000 # define SVGA_PCI_DEVICE_ID PCI_DEVICE_ID_VMWARE_SVGA #endif @@ -226,18 +226,19 @@ enum { #ifdef VERBOSE # define GUEST_OS_BASE 0x5001 static const char *vmsvga_guest_id[] = { - [0x0] = "Dos", - [0x1] = "Windows 3.1", - [0x2] = "Windows 95", - [0x3] = "Windows 98", - [0x4] = "Windows ME", - [0x5] = "Windows NT", - [0x6] = "Windows 2000", - [0x7] = "Linux", - [0x8] = "OS/2", - [0x9] = "Unknown", - [0xa] = "BSD", - [0xb] = "Whistler", + [0x00 ... 0x15] = "an unknown OS", + [0x00] = "Dos", + [0x01] = "Windows 3.1", + [0x02] = "Windows 95", + [0x03] = "Windows 98", + [0x04] = "Windows ME", + [0x05] = "Windows NT", + [0x06] = "Windows 2000", + [0x07] = "Linux", + [0x08] = "OS/2", + [0x0a] = "BSD", + [0x0b] = "Whistler", + [0x15] = "Windows 2003", }; #endif @@ -459,7 +460,7 @@ static inline void vmsvga_cursor_define(struct vmsvga_state_s *s, static inline int vmsvga_fifo_empty(struct vmsvga_state_s *s) { if (!s->config || !s->enable) - return 0; + return 1; return (s->cmd->next_cmd == s->cmd->stop); } @@ -619,7 +620,7 @@ static uint32_t vmsvga_value_read(void *opaque, uint32_t address) return SVGA_MAX_WIDTH; case SVGA_REG_MAX_HEIGHT: - return SVGA_MAX_WIDTH; + return SVGA_MAX_HEIGHT; case SVGA_REG_DEPTH: return s->depth; @@ -727,7 +728,8 @@ static void vmsvga_value_write(void *opaque, uint32_t address, uint32_t value) break; case SVGA_REG_ENABLE: - s->enable = s->config = value & s->config; + s->enable = value; + s->config &= !!value; s->width = -1; s->height = -1; s->invalidated = 1; @@ -770,7 +772,7 @@ static void vmsvga_value_write(void *opaque, uint32_t address, uint32_t value) if (s->cmd->max < s->cmd->min + 10 * 1024) break; } - s->config = value; + s->config = !!value; break; case SVGA_REG_SYNC: @@ -902,14 +904,14 @@ static void vmsvga_reset(struct vmsvga_state_s *s) s->wblue = 0x0000f800; break; case 24: - s->wred = 0x000000ff; + s->wred = 0x00ff0000; s->wgreen = 0x0000ff00; - s->wblue = 0x00ff0000; + s->wblue = 0x000000ff; break; case 32: - s->wred = 0x000000ff; + s->wred = 0x00ff0000; s->wgreen = 0x0000ff00; - s->wblue = 0x00ff0000; + s->wblue = 0x000000ff; break; } s->syncing = 0; @@ -928,6 +930,8 @@ static void vmsvga_invalidate_display(void *opaque) s->invalidated = 1; } +/* save the vga display in a PPM image even if no display is + available */ static void vmsvga_screen_dump(void *opaque, const char *filename) { struct vmsvga_state_s *s = (struct vmsvga_state_s *) opaque; @@ -938,7 +942,9 @@ static void vmsvga_screen_dump(void *opaque, const char *filename) return; } - /* TODO */ + if (s->depth == 32) { + ppm_save(filename, s->vram, s->width, s->height, s->ds->linesize); + } } #ifdef DIRECT_VRAM