2002-03-21 19:23:24 -05:00
|
|
|
$OpenBSD: patch-Src_Display_x_i,v 1.3 2002/03/22 00:23:24 espie Exp $
|
|
|
|
--- Src/Display_x.i.orig Wed Jan 2 22:17:29 2002
|
|
|
|
+++ Src/Display_x.i Thu Mar 14 01:48:46 2002
|
2001-01-13 15:55:59 -05:00
|
|
|
@@ -4,6 +4,7 @@
|
|
|
|
*
|
2002-03-21 19:23:24 -05:00
|
|
|
* Frodo (C) 1994-1997,2002 Christian Bauer
|
2001-01-13 15:55:59 -05:00
|
|
|
* X11 stuff by Bernd Schmidt/Lutz Vieweg
|
|
|
|
+ * Support for visuals >8 bits by Michael Krause and Marc Espie
|
|
|
|
*/
|
|
|
|
|
2002-03-21 19:23:24 -05:00
|
|
|
#include "SAM.h"
|
|
|
|
@@ -34,7 +35,9 @@ static XImage *img;
|
2001-01-13 15:55:59 -05:00
|
|
|
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
|
2002-03-21 19:23:24 -05:00
|
|
|
@@ -392,7 +395,7 @@ int init_graphics(void)
|
2001-01-13 15:55:59 -05:00
|
|
|
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;
|
|
|
|
|
2002-03-21 19:23:24 -05:00
|
|
|
@@ -413,6 +416,10 @@ int init_graphics(void)
|
2001-01-13 15:55:59 -05:00
|
|
|
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);
|
2002-03-21 19:23:24 -05:00
|
|
|
@@ -478,6 +485,33 @@ void C64Display::Update(void)
|
2001-01-13 15:55:59 -05:00
|
|
|
{
|
|
|
|
// 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
|
2002-03-21 19:23:24 -05:00
|
|
|
@@ -560,7 +594,7 @@ void C64Display::Speedometer(int speed)
|
2001-01-13 15:55:59 -05:00
|
|
|
|
|
|
|
uint8 *C64Display::BitmapBase(void)
|
|
|
|
{
|
|
|
|
- return (uint8 *)bufmem;
|
|
|
|
+ return (uint8*)(bitdepth>8 ? bufmem8 : bufmem);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2002-03-21 19:23:24 -05:00
|
|
|
@@ -770,14 +804,32 @@ void C64Display::InitColors(uint8 *color
|
2001-01-13 15:55:59 -05:00
|
|
|
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);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|