summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDale Rahn <drahn@cvs.openbsd.org>2002-05-18 20:20:18 +0000
committerDale Rahn <drahn@cvs.openbsd.org>2002-05-18 20:20:18 +0000
commit988f612ea14a8553226932e571f36ed947556a2d (patch)
tree958ed3becd227ffd4001ba35921a15df148ef123
parent73e030b1076b096bf16a23b30e83e66e5d1b242e (diff)
Workaround for color restoration on return from X. vgafb will not
reset the color palette to it's default colors when going back to text mode. Would be better to fix this in the X server. ok matthieu@
-rw-r--r--sys/arch/macppc/pci/vgafb.c45
1 files changed, 33 insertions, 12 deletions
diff --git a/sys/arch/macppc/pci/vgafb.c b/sys/arch/macppc/pci/vgafb.c
index e5b059c2803..1a83b75f3b5 100644
--- a/sys/arch/macppc/pci/vgafb.c
+++ b/sys/arch/macppc/pci/vgafb.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: vgafb.c,v 1.11 2002/04/29 22:07:56 drahn Exp $ */
+/* $OpenBSD: vgafb.c,v 1.12 2002/05/18 20:20:17 drahn Exp $ */
/* $NetBSD: vga.c,v 1.3 1996/12/02 22:24:54 cgd Exp $ */
/*
@@ -66,6 +66,7 @@ struct cfdriver vgafb_cd = {
void vgafb_setcolor(struct vgafb_config *vc, unsigned int index,
u_int8_t r, u_int8_t g, u_int8_t b);
+void vgafb_restore_default_colors(struct vgafb_config *vc);
struct vgafb_devconfig {
struct rasops_info dc_rinfo; /* raster display data */
@@ -290,13 +291,17 @@ vgafb_common_setup(iot, memt, vc, iobase, iosize, membase, memsize, mmiobase, mm
vc->vc_at = 0x00 | 0xf; /* black bg|white fg */
vc->vc_so_at = 0x00 | 0xf | 0x80; /* black bg|white fg|blink */
#endif
- {
- int i;
- for (i = 0; i < 256; i++) {
- const u_char *color;
- color = &rasops_cmap[i*3];
- vgafb_setcolor(vc, i, color[0], color[1], color[2]);
- }
+ vgafb_restore_default_colors(vc);
+}
+
+void
+vgafb_restore_default_colors(struct vgafb_config *vc)
+{
+ int i;
+ for (i = 0; i < 256; i++) {
+ const u_char *color;
+ color = &rasops_cmap[i*3];
+ vgafb_setcolor(vc, i, color[0], color[1], color[2]);
}
}
@@ -349,6 +354,20 @@ vgafb_ioctl(v, cmd, data, flag, p)
case WSDISPLAYIO_PUTCMAP:
return vgafb_putcmap(vc, (struct wsdisplay_cmap *)data);
+ case WSDISPLAYIO_SMODE:
+ /* track the state of the display,
+ * if returning to WSDISPLAYIO_MODE_EMUL
+ * restore the last palette, workaround for
+ * bad accellerated X servers that does not restore
+ * the correct palette.
+ */
+
+ vgafb_restore_default_colors(vc);
+
+ /* now that we have done our work, let the wscons
+ * layer handle this ioctl
+ */
+ return -1;
case WSDISPLAYIO_SVIDEO:
case WSDISPLAYIO_GVIDEO:
case WSDISPLAYIO_GCURPOS:
@@ -356,6 +375,7 @@ vgafb_ioctl(v, cmd, data, flag, p)
case WSDISPLAYIO_GCURMAX:
case WSDISPLAYIO_GCURSOR:
case WSDISPLAYIO_SCURSOR:
+ default:
return -1; /* not supported yet */
}
@@ -486,6 +506,7 @@ struct {
u_int8_t g;
u_int8_t b;
} vgafb_color[256];
+
void
vgafb_setcolor(vc, index, r, g, b)
struct vgafb_config *vc;
@@ -496,11 +517,11 @@ vgafb_setcolor(vc, index, r, g, b)
vc->vc_cmap_green[index] = g;
vc->vc_cmap_blue[index] = b;
- vgafb_color[0].r = r;
- vgafb_color[0].g = g;
- vgafb_color[0].b = b;
+ vgafb_color[index].r = r;
+ vgafb_color[index].g = g;
+ vgafb_color[index].b = b;
OF_call_method_1("set-colors", cons_display_ofh, 3,
- &vgafb_color, index, 1);
+ &vgafb_color[index], index, 1);
}
int