diff options
author | Dale Rahn <drahn@cvs.openbsd.org> | 2002-05-18 20:20:18 +0000 |
---|---|---|
committer | Dale Rahn <drahn@cvs.openbsd.org> | 2002-05-18 20:20:18 +0000 |
commit | 988f612ea14a8553226932e571f36ed947556a2d (patch) | |
tree | 958ed3becd227ffd4001ba35921a15df148ef123 | |
parent | 73e030b1076b096bf16a23b30e83e66e5d1b242e (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.c | 45 |
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 |