📄 tcx.c.svn-base
字号:
/* flush to display */ dpy_update(ts->ds, 0, y_start, ts->width, y - y_start); y_start = -1; } d += dd * 4; s += ds * 4; cptr += ds * 4; s24 += ds * 4; } } if (y_start >= 0) { /* flush to display */ dpy_update(ts->ds, 0, y_start, ts->width, y - y_start); } /* reset modified pages */ if (page_min <= page_max) { reset_dirty(ts, page_min, page_max, page24, cpage); }}static void tcx_invalidate_display(void *opaque){ TCXState *s = opaque; int i; for (i = 0; i < MAXX*MAXY; i += TARGET_PAGE_SIZE) { cpu_physical_memory_set_dirty(s->vram_offset + i); }}static void tcx24_invalidate_display(void *opaque){ TCXState *s = opaque; int i; tcx_invalidate_display(s); for (i = 0; i < MAXX*MAXY * 4; i += TARGET_PAGE_SIZE) { cpu_physical_memory_set_dirty(s->vram24_offset + i); cpu_physical_memory_set_dirty(s->cplane_offset + i); }}static void tcx_save(QEMUFile *f, void *opaque){ TCXState *s = opaque; qemu_put_be16s(f, (uint16_t *)&s->height); qemu_put_be16s(f, (uint16_t *)&s->width); qemu_put_be16s(f, (uint16_t *)&s->depth); qemu_put_buffer(f, s->r, 256); qemu_put_buffer(f, s->g, 256); qemu_put_buffer(f, s->b, 256); qemu_put_8s(f, &s->dac_index); qemu_put_8s(f, &s->dac_state);}static int tcx_load(QEMUFile *f, void *opaque, int version_id){ TCXState *s = opaque; uint32_t dummy; if (version_id != 3 && version_id != 4) return -EINVAL; if (version_id == 3) { qemu_get_be32s(f, (uint32_t *)&dummy); qemu_get_be32s(f, (uint32_t *)&dummy); qemu_get_be32s(f, (uint32_t *)&dummy); } qemu_get_be16s(f, (uint16_t *)&s->height); qemu_get_be16s(f, (uint16_t *)&s->width); qemu_get_be16s(f, (uint16_t *)&s->depth); qemu_get_buffer(f, s->r, 256); qemu_get_buffer(f, s->g, 256); qemu_get_buffer(f, s->b, 256); qemu_get_8s(f, &s->dac_index); qemu_get_8s(f, &s->dac_state); update_palette_entries(s, 0, 256); if (s->depth == 24) tcx24_invalidate_display(s); else tcx_invalidate_display(s); return 0;}static void tcx_reset(void *opaque){ TCXState *s = opaque; /* Initialize palette */ memset(s->r, 0, 256); memset(s->g, 0, 256); memset(s->b, 0, 256); s->r[255] = s->g[255] = s->b[255] = 255; update_palette_entries(s, 0, 256); memset(s->vram, 0, MAXX*MAXY); cpu_physical_memory_reset_dirty(s->vram_offset, s->vram_offset + MAXX * MAXY * (1 + 4 + 4), VGA_DIRTY_FLAG); s->dac_index = 0; s->dac_state = 0;}static uint32_t tcx_dac_readl(void *opaque, target_phys_addr_t addr){ return 0;}static void tcx_dac_writel(void *opaque, target_phys_addr_t addr, uint32_t val){ TCXState *s = opaque; uint32_t saddr; saddr = (addr & (TCX_DAC_NREGS - 1)) >> 2; switch (saddr) { case 0: s->dac_index = val >> 24; s->dac_state = 0; break; case 1: switch (s->dac_state) { case 0: s->r[s->dac_index] = val >> 24; update_palette_entries(s, s->dac_index, s->dac_index + 1); s->dac_state++; break; case 1: s->g[s->dac_index] = val >> 24; update_palette_entries(s, s->dac_index, s->dac_index + 1); s->dac_state++; break; case 2: s->b[s->dac_index] = val >> 24; update_palette_entries(s, s->dac_index, s->dac_index + 1); s->dac_index = (s->dac_index + 1) & 255; // Index autoincrement default: s->dac_state = 0; break; } break; default: break; } return;}static CPUReadMemoryFunc *tcx_dac_read[3] = { NULL, NULL, tcx_dac_readl,};static CPUWriteMemoryFunc *tcx_dac_write[3] = { NULL, NULL, tcx_dac_writel,};static uint32_t tcx_dummy_readl(void *opaque, target_phys_addr_t addr){ return 0;}static void tcx_dummy_writel(void *opaque, target_phys_addr_t addr, uint32_t val){}static CPUReadMemoryFunc *tcx_dummy_read[3] = { NULL, NULL, tcx_dummy_readl,};static CPUWriteMemoryFunc *tcx_dummy_write[3] = { NULL, NULL, tcx_dummy_writel,};void tcx_init(DisplayState *ds, target_phys_addr_t addr, uint8_t *vram_base, unsigned long vram_offset, int vram_size, int width, int height, int depth){ TCXState *s; int io_memory, dummy_memory; int size; s = qemu_mallocz(sizeof(TCXState)); if (!s) return; s->ds = ds; s->addr = addr; s->vram_offset = vram_offset; s->width = width; s->height = height; s->depth = depth; // 8-bit plane s->vram = vram_base; size = vram_size; cpu_register_physical_memory(addr + 0x00800000ULL, size, vram_offset); vram_offset += size; vram_base += size; io_memory = cpu_register_io_memory(0, tcx_dac_read, tcx_dac_write, s); cpu_register_physical_memory(addr + 0x00200000ULL, TCX_DAC_NREGS, io_memory); dummy_memory = cpu_register_io_memory(0, tcx_dummy_read, tcx_dummy_write, s); cpu_register_physical_memory(addr + 0x00700000ULL, TCX_TEC_NREGS, dummy_memory); if (depth == 24) { // 24-bit plane size = vram_size * 4; s->vram24 = (uint32_t *)vram_base; s->vram24_offset = vram_offset; cpu_register_physical_memory(addr + 0x02000000ULL, size, vram_offset); vram_offset += size; vram_base += size; // Control plane size = vram_size * 4; s->cplane = (uint32_t *)vram_base; s->cplane_offset = vram_offset; cpu_register_physical_memory(addr + 0x0a000000ULL, size, vram_offset); graphic_console_init(s->ds, tcx24_update_display, tcx24_invalidate_display, tcx24_screen_dump, s); } else { cpu_register_physical_memory(addr + 0x00300000ULL, TCX_THC_NREGS_8, dummy_memory); graphic_console_init(s->ds, tcx_update_display, tcx_invalidate_display, tcx_screen_dump, s); } // NetBSD writes here even with 8-bit display cpu_register_physical_memory(addr + 0x00301000ULL, TCX_THC_NREGS_24, dummy_memory); register_savevm("tcx", addr, 4, tcx_save, tcx_load, s); qemu_register_reset(tcx_reset, s); tcx_reset(s); dpy_resize(s->ds, width, height);}static void tcx_screen_dump(void *opaque, const char *filename){ TCXState *s = opaque; FILE *f; uint8_t *d, *d1, v; int y, x; f = fopen(filename, "wb"); if (!f) return; fprintf(f, "P6\n%d %d\n%d\n", s->width, s->height, 255); d1 = s->vram; for(y = 0; y < s->height; y++) { d = d1; for(x = 0; x < s->width; x++) { v = *d; fputc(s->r[v], f); fputc(s->g[v], f); fputc(s->b[v], f); d++; } d1 += MAXX; } fclose(f); return;}static void tcx24_screen_dump(void *opaque, const char *filename){ TCXState *s = opaque; FILE *f; uint8_t *d, *d1, v; uint32_t *s24, *cptr, dval; int y, x; f = fopen(filename, "wb"); if (!f) return; fprintf(f, "P6\n%d %d\n%d\n", s->width, s->height, 255); d1 = s->vram; s24 = s->vram24; cptr = s->cplane; for(y = 0; y < s->height; y++) { d = d1; for(x = 0; x < s->width; x++, d++, s24++) { if ((*cptr++ & 0xff000000) == 0x03000000) { // 24-bit direct dval = *s24 & 0x00ffffff; fputc((dval >> 16) & 0xff, f); fputc((dval >> 8) & 0xff, f); fputc(dval & 0xff, f); } else { v = *d; fputc(s->r[v], f); fputc(s->g[v], f); fputc(s->b[v], f); } } d1 += MAXX; } fclose(f); return;}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -