117ee9d00SSøren Schmidt /*- 2a8445737SSøren Schmidt * Copyright (c) 1995-1998 S�ren Schmidt 317ee9d00SSøren Schmidt * All rights reserved. 417ee9d00SSøren Schmidt * 517ee9d00SSøren Schmidt * Redistribution and use in source and binary forms, with or without 617ee9d00SSøren Schmidt * modification, are permitted provided that the following conditions 717ee9d00SSøren Schmidt * are met: 817ee9d00SSøren Schmidt * 1. Redistributions of source code must retain the above copyright 9a8445737SSøren Schmidt * notice, this list of conditions and the following disclaimer, 10a8445737SSøren Schmidt * without modification, immediately at the beginning of the file. 1117ee9d00SSøren Schmidt * 2. Redistributions in binary form must reproduce the above copyright 1217ee9d00SSøren Schmidt * notice, this list of conditions and the following disclaimer in the 1317ee9d00SSøren Schmidt * documentation and/or other materials provided with the distribution. 1417ee9d00SSøren Schmidt * 3. The name of the author may not be used to endorse or promote products 15a8445737SSøren Schmidt * derived from this software without specific prior written permission. 1617ee9d00SSøren Schmidt * 1717ee9d00SSøren Schmidt * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR 1817ee9d00SSøren Schmidt * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 1917ee9d00SSøren Schmidt * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 2017ee9d00SSøren Schmidt * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, 2117ee9d00SSøren Schmidt * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 2217ee9d00SSøren Schmidt * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 2317ee9d00SSøren Schmidt * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 2417ee9d00SSøren Schmidt * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 2517ee9d00SSøren Schmidt * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF 2617ee9d00SSøren Schmidt * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 2717ee9d00SSøren Schmidt * 282ad872c5SKazutaka YOKOTA * $Id: fade_saver.c,v 1.15 1998/11/04 03:49:38 peter Exp $ 2917ee9d00SSøren Schmidt */ 3017ee9d00SSøren Schmidt 3117ee9d00SSøren Schmidt #include <sys/param.h> 3217ee9d00SSøren Schmidt #include <sys/systm.h> 330640d357SPeter Wemm #include <sys/kernel.h> 340640d357SPeter Wemm #include <sys/module.h> 35ce834215SKazutaka YOKOTA 36ce834215SKazutaka YOKOTA #include <i386/isa/isa.h> 37ce834215SKazutaka YOKOTA 3817ee9d00SSøren Schmidt #include <saver.h> 3917ee9d00SSøren Schmidt 402ad872c5SKazutaka YOKOTA static u_char palette[256*3]; 412ad872c5SKazutaka YOKOTA static int blanked; 422ad872c5SKazutaka YOKOTA 432ad872c5SKazutaka YOKOTA static int 442ad872c5SKazutaka YOKOTA fade_saver(video_adapter_t *adp, int blank) 4517ee9d00SSøren Schmidt { 4617ee9d00SSøren Schmidt static int count = 0; 47d74e86d9SSøren Schmidt u_char pal[256*3]; 4817ee9d00SSøren Schmidt int i; 4917ee9d00SSøren Schmidt 5017ee9d00SSøren Schmidt if (blank) { 512ad872c5SKazutaka YOKOTA blanked = TRUE; 522ad872c5SKazutaka YOKOTA switch (adp->va_type) { 530de89efeSKazutaka YOKOTA case KD_VGA: 542ad872c5SKazutaka YOKOTA if (count <= 0) 552ad872c5SKazutaka YOKOTA save_palette(adp, palette); 5617ee9d00SSøren Schmidt if (count < 64) { 57d74e86d9SSøren Schmidt pal[0] = pal[1] = pal[2] = 0; 58d74e86d9SSøren Schmidt for (i = 3; i < 256*3; i++) { 59d74e86d9SSøren Schmidt if (palette[i] - count > 60) 60d74e86d9SSøren Schmidt pal[i] = palette[i] - count; 6117ee9d00SSøren Schmidt else 62d74e86d9SSøren Schmidt pal[i] = 60; 6317ee9d00SSøren Schmidt } 642ad872c5SKazutaka YOKOTA load_palette(adp, pal); 6517ee9d00SSøren Schmidt count++; 6617ee9d00SSøren Schmidt } 670de89efeSKazutaka YOKOTA break; 680de89efeSKazutaka YOKOTA case KD_EGA: 690de89efeSKazutaka YOKOTA /* not yet done XXX */ 700de89efeSKazutaka YOKOTA break; 710de89efeSKazutaka YOKOTA case KD_CGA: 722ad872c5SKazutaka YOKOTA outb(adp->va_crtc_addr + 4, 0x25); 730de89efeSKazutaka YOKOTA break; 740de89efeSKazutaka YOKOTA case KD_MONO: 750de89efeSKazutaka YOKOTA case KD_HERCULES: 762ad872c5SKazutaka YOKOTA outb(adp->va_crtc_addr + 4, 0x21); 770de89efeSKazutaka YOKOTA break; 780de89efeSKazutaka YOKOTA default: 790de89efeSKazutaka YOKOTA break; 800de89efeSKazutaka YOKOTA } 8117ee9d00SSøren Schmidt } 8217ee9d00SSøren Schmidt else { 832ad872c5SKazutaka YOKOTA switch (adp->va_type) { 840de89efeSKazutaka YOKOTA case KD_VGA: 852ad872c5SKazutaka YOKOTA load_palette(adp, palette); 860de89efeSKazutaka YOKOTA count = 0; 870de89efeSKazutaka YOKOTA break; 880de89efeSKazutaka YOKOTA case KD_EGA: 890de89efeSKazutaka YOKOTA /* not yet done XXX */ 900de89efeSKazutaka YOKOTA break; 910de89efeSKazutaka YOKOTA case KD_CGA: 922ad872c5SKazutaka YOKOTA outb(adp->va_crtc_addr + 4, 0x2d); 930de89efeSKazutaka YOKOTA break; 940de89efeSKazutaka YOKOTA case KD_MONO: 950de89efeSKazutaka YOKOTA case KD_HERCULES: 962ad872c5SKazutaka YOKOTA outb(adp->va_crtc_addr + 4, 0x29); 970de89efeSKazutaka YOKOTA break; 980de89efeSKazutaka YOKOTA default: 990de89efeSKazutaka YOKOTA break; 1000de89efeSKazutaka YOKOTA } 1012ad872c5SKazutaka YOKOTA blanked = FALSE; 10217ee9d00SSøren Schmidt } 1032ad872c5SKazutaka YOKOTA return 0; 10417ee9d00SSøren Schmidt } 10517ee9d00SSøren Schmidt 106b3e24f9cSBruce Evans static int 1072ad872c5SKazutaka YOKOTA fade_init(video_adapter_t *adp) 10817ee9d00SSøren Schmidt { 1092ad872c5SKazutaka YOKOTA switch (adp->va_type) { 1100de89efeSKazutaka YOKOTA case KD_MONO: 1110de89efeSKazutaka YOKOTA case KD_HERCULES: 1120de89efeSKazutaka YOKOTA case KD_CGA: 1130de89efeSKazutaka YOKOTA /* 1140de89efeSKazutaka YOKOTA * `fade' saver is not fully implemented for MDA and CGA. 1150de89efeSKazutaka YOKOTA * It simply blanks the display instead. 1160de89efeSKazutaka YOKOTA */ 1170de89efeSKazutaka YOKOTA case KD_VGA: 1180de89efeSKazutaka YOKOTA break; 1190de89efeSKazutaka YOKOTA case KD_EGA: 1200de89efeSKazutaka YOKOTA /* EGA is yet to be supported */ 1210de89efeSKazutaka YOKOTA default: 1220de89efeSKazutaka YOKOTA return ENODEV; 1230de89efeSKazutaka YOKOTA } 1242ad872c5SKazutaka YOKOTA blanked = FALSE; 1252ad872c5SKazutaka YOKOTA return 0; 12617ee9d00SSøren Schmidt } 12717ee9d00SSøren Schmidt 128b3e24f9cSBruce Evans static int 1292ad872c5SKazutaka YOKOTA fade_term(video_adapter_t *adp) 13017ee9d00SSøren Schmidt { 1312ad872c5SKazutaka YOKOTA return 0; 13217ee9d00SSøren Schmidt } 13317ee9d00SSøren Schmidt 1342ad872c5SKazutaka YOKOTA static scrn_saver_t fade_module = { 1352ad872c5SKazutaka YOKOTA "fade_saver", fade_init, fade_term, fade_saver, NULL, 1362ad872c5SKazutaka YOKOTA }; 1372ad872c5SKazutaka YOKOTA 1382ad872c5SKazutaka YOKOTA SAVER_MODULE(fade_saver, fade_module); 139