openbsd-ports/emulators/frodo/patches/patch-Src_Display_x_i

119 lines
3.6 KiB
Plaintext
Raw Normal View History

$OpenBSD: patch-Src_Display_x_i,v 1.4 2010/06/30 22:25:57 jakemsr Exp $
--- Src/Display_x.i.orig Wed Jan 2 13:17:29 2002
+++ Src/Display_x.i Thu Jan 14 08:50:09 2010
@@ -4,6 +4,7 @@
*
* Frodo (C) 1994-1997,2002 Christian Bauer
* X11 stuff by Bernd Schmidt/Lutz Vieweg
+ * Support for visuals >8 bits by Michael Krause and Marc Espie
*/
#include "SAM.h"
@@ -34,7 +35,9 @@ static XImage *img;
static Visual *vis;
static XVisualInfo visualInfo;
static int bitdepth;
-static char *bufmem;
+static char *bufmem, *bufmem8;
+static uint32 trans[1<<12];
+static uint32 eight2thirtytwo[16];
static int hsize;
// For LED error blinking
@@ -392,7 +395,7 @@ int init_graphics(void)
vis = visualInfo.visual;
bitdepth = visualInfo.depth;
pixbytes = (bitdepth == 24 || bitdepth == 32 ? 4 : bitdepth == 12 || bitdepth == 16 ? 2 : 1);
- fprintf(stderr, "Using %d bit visual\n", bitdepth);
+ fprintf(stderr, "Using %d bit visual%s", bitdepth, bitdepth>8 ? " - please use 8 bits for highest performance!\n" : "\n");
hsize = (DISPLAY_X + 3) & ~3;
@@ -413,6 +416,10 @@ int init_graphics(void)
img = XCreateImage(display, vis, bitdepth, ZPixmap, 0, bufmem, hsize, DISPLAY_Y, 32, 0);
#endif
+ if(bitdepth > 8) {
+ bufmem8 = (char*)malloc(hsize * DISPLAY_Y);
+ }
+
cmap = XCreateColormap(display, rootwin, vis, AllocNone);
XParseColor(display, cmap, "#000000", &black);
@@ -478,6 +485,33 @@ void C64Display::Update(void)
{
// Update C64 display
XSync(display, 0);
+
+ if(bitdepth == 16) {
+ // Best thing would be to change
+ // VIC.cpp so it could render directly into 16-bit or 32-bit
+ // memory instead of into an 8-bit chunky buffer.
+ uint16 *p = (uint16*)bufmem8, *x = p + hsize*DISPLAY_Y/2;
+ uint32 *d = (uint32*)bufmem;
+ while(p < x) {
+ *d++ = trans[*p++ & 0x0fff];
+ }
+#if 0
+ // Just a plain version. Might be necessary on non-i386
+ // machines?
+ uint8 *p = (uint8*)bufmem8, *x = p + hsize*DISPLAY_Y;
+ uint16 *d = (uint16*)bufmem;
+ while(p < x) {
+ *d++ = eight2sixteen[*p++];
+ }
+#endif
+ } else if (bitdepth == 32 || bitdepth == 24) {
+ uint8 *p = (uint8*)bufmem8, *x = p + hsize*DISPLAY_Y;
+ uint32 *d = (uint32*)bufmem;
+ while(p < x) {
+ *d++ = eight2thirtytwo[*p++];
+ }
+ }
+
#if defined(X_USE_SHM)
XShmPutImage(display, mywin, black_gc, img, 0, 0, 0, 0, DISPLAY_X, DISPLAY_Y, 0);
#else
@@ -560,7 +594,7 @@ void C64Display::Speedometer(int speed)
uint8 *C64Display::BitmapBase(void)
{
- return (uint8 *)bufmem;
+ return (uint8*)(bitdepth>8 ? bufmem8 : bufmem);
}
@@ -770,14 +804,32 @@ void C64Display::InitColors(uint8 *colors)
int i;
XColor col;
char str[20];
+ uint16 eight2sixteen[16];
for (i=0; i< 256; i++) {
+ if(bitdepth == 16) {
+ colors[i] = i & 0x0f;
+ if(i < 16) {
+ eight2sixteen[i] = ((uint16(palette_red[i]) << 8) & 0xf800) | ((uint16(palette_green[i]) << 3) & 0x07e0) | (palette_blue[i] >> 3);
+ }
+ } else if(bitdepth == 32 || bitdepth == 24) {
+ colors[i] = i & 0x0f;
+ if(i <16) {
+ eight2thirtytwo[i] = (uint32(palette_red[i]) << 16) | (uint32(palette_green[i]) << 8) | palette_blue[i];
+ }
+ } else {
sprintf(str, "rgb:%x/%x/%x", palette_red[i & 0x0f], palette_green[i & 0x0f], palette_blue[i & 0x0f]);
XParseColor(display, cmap, str, &col);
if (XAllocColor(display, cmap, &col))
colors[i] = col.pixel;
else
fprintf(stderr, "Couldn't get all colors\n");
+ }
+ }
+
+ // Table to translate two 8-bit src -> two 16-bit dest
+ for(i=0; i<1<<12;i++) {
+ trans[i] = eight2sixteen[i & 0x0f] | (eight2sixteen[i >> 8] << 16);
}
}