Commit aeb3c85f59bc35371c76f285f0761f01245dc3cd
1 parent
1f04275e
Cirrus fixes
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@898 c046a42c-6fe2-441c-8c8c-71466251a162
Showing
1 changed file
with
45 additions
and
32 deletions
hw/cirrus_vga.c
1 | 1 | /* |
2 | - * QEMU Cirrus VGA Emulator. | |
2 | + * QEMU Cirrus CLGD 54xx VGA Emulator. | |
3 | 3 | * |
4 | 4 | * Copyright (c) 2004 Fabrice Bellard |
5 | - * Copyright (c) 2004 Suzu | |
5 | + * Copyright (c) 2004 Makoto Suzuki (suzu) | |
6 | 6 | * |
7 | 7 | * Permission is hereby granted, free of charge, to any person obtaining a copy |
8 | 8 | * of this software and associated documentation files (the "Software"), to deal |
... | ... | @@ -22,6 +22,10 @@ |
22 | 22 | * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN |
23 | 23 | * THE SOFTWARE. |
24 | 24 | */ |
25 | +/* | |
26 | + * Reference: Finn Thogersons' VGADOC4b | |
27 | + * available at http://home.worldonline.dk/~finth/ | |
28 | + */ | |
25 | 29 | #include "vl.h" |
26 | 30 | #include "vga_int.h" |
27 | 31 | |
... | ... | @@ -478,8 +482,8 @@ cirrus_colorexpand_8(CirrusVGAState * s, uint8_t * dst, |
478 | 482 | unsigned bitmask; |
479 | 483 | int srcskipleft = 0; |
480 | 484 | |
481 | - colors[0] = s->gr[0x00]; | |
482 | - colors[1] = s->gr[0x01]; | |
485 | + colors[0] = s->cirrus_shadow_gr0; | |
486 | + colors[1] = s->cirrus_shadow_gr1; | |
483 | 487 | |
484 | 488 | bitmask = 0x80 >> srcskipleft; |
485 | 489 | bits = *src++; |
... | ... | @@ -504,9 +508,9 @@ cirrus_colorexpand_16(CirrusVGAState * s, uint8_t * dst, |
504 | 508 | unsigned index; |
505 | 509 | int srcskipleft = 0; |
506 | 510 | |
507 | - colors[0][0] = s->gr[0x00]; | |
511 | + colors[0][0] = s->cirrus_shadow_gr0; | |
508 | 512 | colors[0][1] = s->gr[0x10]; |
509 | - colors[1][0] = s->gr[0x01]; | |
513 | + colors[1][0] = s->cirrus_shadow_gr1; | |
510 | 514 | colors[1][1] = s->gr[0x11]; |
511 | 515 | |
512 | 516 | bitmask = 0x80 >> srcskipleft; |
... | ... | @@ -534,10 +538,10 @@ cirrus_colorexpand_24(CirrusVGAState * s, uint8_t * dst, |
534 | 538 | unsigned index; |
535 | 539 | int srcskipleft = 0; |
536 | 540 | |
537 | - colors[0][0] = s->gr[0x00]; | |
541 | + colors[0][0] = s->cirrus_shadow_gr0; | |
538 | 542 | colors[0][1] = s->gr[0x10]; |
539 | 543 | colors[0][2] = s->gr[0x12]; |
540 | - colors[1][0] = s->gr[0x01]; | |
544 | + colors[1][0] = s->cirrus_shadow_gr1; | |
541 | 545 | colors[1][1] = s->gr[0x11]; |
542 | 546 | colors[1][2] = s->gr[0x13]; |
543 | 547 | |
... | ... | @@ -567,11 +571,11 @@ cirrus_colorexpand_32(CirrusVGAState * s, uint8_t * dst, |
567 | 571 | unsigned index; |
568 | 572 | int srcskipleft = 0; |
569 | 573 | |
570 | - colors[0][0] = s->gr[0x00]; | |
574 | + colors[0][0] = s->cirrus_shadow_gr0; | |
571 | 575 | colors[0][1] = s->gr[0x10]; |
572 | 576 | colors[0][2] = s->gr[0x12]; |
573 | 577 | colors[0][3] = s->gr[0x14]; |
574 | - colors[1][0] = s->gr[0x01]; | |
578 | + colors[1][0] = s->cirrus_shadow_gr1; | |
575 | 579 | colors[1][1] = s->gr[0x11]; |
576 | 580 | colors[1][2] = s->gr[0x13]; |
577 | 581 | colors[1][3] = s->gr[0x15]; |
... | ... | @@ -1103,7 +1107,7 @@ static int cirrus_get_bpp(VGAState *s1) |
1103 | 1107 | } |
1104 | 1108 | } else { |
1105 | 1109 | /* VGA */ |
1106 | - ret = 8; | |
1110 | + ret = 0; | |
1107 | 1111 | } |
1108 | 1112 | |
1109 | 1113 | return ret; |
... | ... | @@ -1172,16 +1176,6 @@ cirrus_hook_read_sr(CirrusVGAState * s, unsigned reg_index, int *reg_value) |
1172 | 1176 | case 0x06: // Unlock Cirrus extensions |
1173 | 1177 | *reg_value = s->sr[reg_index]; |
1174 | 1178 | break; |
1175 | - case 0x05: // ??? | |
1176 | - case 0x07: // Extended Sequencer Mode | |
1177 | - case 0x08: // EEPROM Control | |
1178 | - case 0x09: // Scratch Register 0 | |
1179 | - case 0x0a: // Scratch Register 1 | |
1180 | - case 0x0b: // VCLK 0 | |
1181 | - case 0x0c: // VCLK 1 | |
1182 | - case 0x0d: // VCLK 2 | |
1183 | - case 0x0e: // VCLK 3 | |
1184 | - case 0x0f: // DRAM Control | |
1185 | 1179 | case 0x10: |
1186 | 1180 | case 0x30: |
1187 | 1181 | case 0x50: |
... | ... | @@ -1190,6 +1184,8 @@ cirrus_hook_read_sr(CirrusVGAState * s, unsigned reg_index, int *reg_value) |
1190 | 1184 | case 0xb0: |
1191 | 1185 | case 0xd0: |
1192 | 1186 | case 0xf0: // Graphics Cursor X |
1187 | + *reg_value = s->sr[0x10]; | |
1188 | + break; | |
1193 | 1189 | case 0x11: |
1194 | 1190 | case 0x31: |
1195 | 1191 | case 0x51: |
... | ... | @@ -1197,6 +1193,18 @@ cirrus_hook_read_sr(CirrusVGAState * s, unsigned reg_index, int *reg_value) |
1197 | 1193 | case 0x91: |
1198 | 1194 | case 0xb1: |
1199 | 1195 | case 0xd1: |
1196 | + *reg_value = s->sr[0x11]; | |
1197 | + break; | |
1198 | + case 0x05: // ??? | |
1199 | + case 0x07: // Extended Sequencer Mode | |
1200 | + case 0x08: // EEPROM Control | |
1201 | + case 0x09: // Scratch Register 0 | |
1202 | + case 0x0a: // Scratch Register 1 | |
1203 | + case 0x0b: // VCLK 0 | |
1204 | + case 0x0c: // VCLK 1 | |
1205 | + case 0x0d: // VCLK 2 | |
1206 | + case 0x0e: // VCLK 3 | |
1207 | + case 0x0f: // DRAM Control | |
1200 | 1208 | case 0xf1: // Graphics Cursor Y |
1201 | 1209 | case 0x12: // Graphics Cursor Attribute |
1202 | 1210 | case 0x13: // Graphics Cursor Pattern Address |
... | ... | @@ -1387,6 +1395,12 @@ static int |
1387 | 1395 | cirrus_hook_read_gr(CirrusVGAState * s, unsigned reg_index, int *reg_value) |
1388 | 1396 | { |
1389 | 1397 | switch (reg_index) { |
1398 | + case 0x00: // Standard VGA, BGCOLOR 0x000000ff | |
1399 | + *reg_value = s->cirrus_shadow_gr0; | |
1400 | + return CIRRUS_HOOK_HANDLED; | |
1401 | + case 0x01: // Standard VGA, FGCOLOR 0x000000ff | |
1402 | + *reg_value = s->cirrus_shadow_gr1; | |
1403 | + return CIRRUS_HOOK_HANDLED; | |
1390 | 1404 | case 0x02: // Standard VGA |
1391 | 1405 | case 0x03: // Standard VGA |
1392 | 1406 | case 0x04: // Standard VGA |
... | ... | @@ -1416,10 +1430,10 @@ cirrus_hook_write_gr(CirrusVGAState * s, unsigned reg_index, int reg_value) |
1416 | 1430 | { |
1417 | 1431 | switch (reg_index) { |
1418 | 1432 | case 0x00: // Standard VGA, BGCOLOR 0x000000ff |
1419 | - s->gr[0x00] = reg_value; | |
1433 | + s->cirrus_shadow_gr0 = reg_value; | |
1420 | 1434 | return CIRRUS_HOOK_NOT_HANDLED; |
1421 | 1435 | case 0x01: // Standard VGA, FGCOLOR 0x000000ff |
1422 | - s->gr[0x01] = reg_value; | |
1436 | + s->cirrus_shadow_gr1 = reg_value; | |
1423 | 1437 | return CIRRUS_HOOK_NOT_HANDLED; |
1424 | 1438 | case 0x02: // Standard VGA |
1425 | 1439 | case 0x03: // Standard VGA |
... | ... | @@ -1840,9 +1854,9 @@ static void cirrus_mem_writeb_mode4and5_8bpp(CirrusVGAState * s, |
1840 | 1854 | dst = s->vram_ptr + offset; |
1841 | 1855 | for (x = 0; x < 8; x++) { |
1842 | 1856 | if (val & 0x80) { |
1843 | - *dst++ = s->gr[0x01]; | |
1857 | + *dst++ = s->cirrus_shadow_gr1; | |
1844 | 1858 | } else if (mode == 5) { |
1845 | - *dst++ = s->gr[0x00]; | |
1859 | + *dst++ = s->cirrus_shadow_gr0; | |
1846 | 1860 | } |
1847 | 1861 | val <<= 1; |
1848 | 1862 | } |
... | ... | @@ -1862,10 +1876,10 @@ static void cirrus_mem_writeb_mode4and5_16bpp(CirrusVGAState * s, |
1862 | 1876 | dst = s->vram_ptr + offset; |
1863 | 1877 | for (x = 0; x < 8; x++) { |
1864 | 1878 | if (val & 0x80) { |
1865 | - *dst++ = s->gr[0x01]; | |
1879 | + *dst++ = s->cirrus_shadow_gr1; | |
1866 | 1880 | *dst++ = s->gr[0x11]; |
1867 | 1881 | } else if (mode == 5) { |
1868 | - *dst++ = s->gr[0x00]; | |
1882 | + *dst++ = s->cirrus_shadow_gr0; | |
1869 | 1883 | *dst++ = s->gr[0x10]; |
1870 | 1884 | } |
1871 | 1885 | val <<= 1; |
... | ... | @@ -1891,6 +1905,8 @@ static uint32_t cirrus_vga_mem_readb(void *opaque, target_phys_addr_t addr) |
1891 | 1905 | return vga_mem_readb(s, addr); |
1892 | 1906 | } |
1893 | 1907 | |
1908 | + addr &= 0x1ffff; | |
1909 | + | |
1894 | 1910 | if (addr < 0x10000) { |
1895 | 1911 | /* XXX handle bitblt */ |
1896 | 1912 | /* video memory */ |
... | ... | @@ -1965,6 +1981,8 @@ static void cirrus_vga_mem_writeb(void *opaque, target_phys_addr_t addr, |
1965 | 1981 | return; |
1966 | 1982 | } |
1967 | 1983 | |
1984 | + addr &= 0x1ffff; | |
1985 | + | |
1968 | 1986 | if (addr < 0x10000) { |
1969 | 1987 | if (s->cirrus_srcptr != s->cirrus_srcptr_end) { |
1970 | 1988 | /* bitblt */ |
... | ... | @@ -2283,11 +2301,6 @@ static uint32_t vga_ioport_read(void *opaque, uint32_t addr) |
2283 | 2301 | #ifdef DEBUG_VGA_REG |
2284 | 2302 | printf("vga: read CR%x = 0x%02x\n", s->cr_index, val); |
2285 | 2303 | #endif |
2286 | -#ifdef DEBUG_S3 | |
2287 | - if (s->cr_index >= 0x20) | |
2288 | - printf("S3: CR read index=0x%x val=0x%x\n", | |
2289 | - s->cr_index, val); | |
2290 | -#endif | |
2291 | 2304 | break; |
2292 | 2305 | case 0x3ba: |
2293 | 2306 | case 0x3da: | ... | ... |