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 * 28a8445737SSøren Schmidt * $Id$ 2917ee9d00SSøren Schmidt */ 3017ee9d00SSøren Schmidt 3117ee9d00SSøren Schmidt #include <sys/param.h> 3217ee9d00SSøren Schmidt #include <sys/systm.h> 3317ee9d00SSøren Schmidt #include <sys/exec.h> 3417ee9d00SSøren Schmidt #include <sys/sysent.h> 3517ee9d00SSøren Schmidt #include <sys/lkm.h> 36ce834215SKazutaka YOKOTA 37ce834215SKazutaka YOKOTA #include <i386/isa/isa.h> 38ce834215SKazutaka YOKOTA 3917ee9d00SSøren Schmidt #include <saver.h> 4017ee9d00SSøren Schmidt 41b3e24f9cSBruce Evans MOD_MISC(fade_saver); 4217ee9d00SSøren Schmidt 4317ee9d00SSøren Schmidt static void 4417ee9d00SSøren Schmidt fade_saver(int blank) 4517ee9d00SSøren Schmidt { 4617ee9d00SSøren Schmidt static int count = 0; 4717ee9d00SSøren Schmidt int i; 4817ee9d00SSøren Schmidt 4917ee9d00SSøren Schmidt if (blank) { 5017ee9d00SSøren Schmidt scrn_blanked = 1; 510de89efeSKazutaka YOKOTA switch (crtc_type) { 520de89efeSKazutaka YOKOTA case KD_VGA: 5317ee9d00SSøren Schmidt if (count < 64) { 5417ee9d00SSøren Schmidt outb(PIXMASK, 0xFF); /* no pixelmask */ 5517ee9d00SSøren Schmidt outb(PALWADR, 0x00); 5617ee9d00SSøren Schmidt outb(PALDATA, 0); 5717ee9d00SSøren Schmidt outb(PALDATA, 0); 5817ee9d00SSøren Schmidt outb(PALDATA, 0); 5917ee9d00SSøren Schmidt for (i = 3; i < 768; i++) { 6017ee9d00SSøren Schmidt if (palette[i] - count > 15) 6117ee9d00SSøren Schmidt outb(PALDATA, palette[i]-count); 6217ee9d00SSøren Schmidt else 6317ee9d00SSøren Schmidt outb(PALDATA, 15); 6417ee9d00SSøren Schmidt } 6517ee9d00SSøren Schmidt inb(crtc_addr+6); /* reset flip/flop */ 6617ee9d00SSøren Schmidt outb(ATC, 0x20); /* enable palette */ 6717ee9d00SSøren Schmidt count++; 6817ee9d00SSøren Schmidt } 690de89efeSKazutaka YOKOTA break; 700de89efeSKazutaka YOKOTA case KD_EGA: 710de89efeSKazutaka YOKOTA /* not yet done XXX */ 720de89efeSKazutaka YOKOTA break; 730de89efeSKazutaka YOKOTA case KD_CGA: 740de89efeSKazutaka YOKOTA outb(crtc_addr + 4, 0x25); 750de89efeSKazutaka YOKOTA break; 760de89efeSKazutaka YOKOTA case KD_MONO: 770de89efeSKazutaka YOKOTA case KD_HERCULES: 780de89efeSKazutaka YOKOTA outb(crtc_addr + 4, 0x21); 790de89efeSKazutaka YOKOTA break; 800de89efeSKazutaka YOKOTA default: 810de89efeSKazutaka YOKOTA break; 820de89efeSKazutaka YOKOTA } 8317ee9d00SSøren Schmidt } 8417ee9d00SSøren Schmidt else { 850de89efeSKazutaka YOKOTA switch (crtc_type) { 860de89efeSKazutaka YOKOTA case KD_VGA: 87a8445737SSøren Schmidt load_palette(cur_console, palette); 880de89efeSKazutaka YOKOTA count = 0; 890de89efeSKazutaka YOKOTA break; 900de89efeSKazutaka YOKOTA case KD_EGA: 910de89efeSKazutaka YOKOTA /* not yet done XXX */ 920de89efeSKazutaka YOKOTA break; 930de89efeSKazutaka YOKOTA case KD_CGA: 940de89efeSKazutaka YOKOTA outb(crtc_addr + 4, 0x2d); 950de89efeSKazutaka YOKOTA break; 960de89efeSKazutaka YOKOTA case KD_MONO: 970de89efeSKazutaka YOKOTA case KD_HERCULES: 980de89efeSKazutaka YOKOTA outb(crtc_addr + 4, 0x29); 990de89efeSKazutaka YOKOTA break; 1000de89efeSKazutaka YOKOTA default: 1010de89efeSKazutaka YOKOTA break; 1020de89efeSKazutaka YOKOTA } 1030de89efeSKazutaka YOKOTA scrn_blanked = 0; 10417ee9d00SSøren Schmidt } 10517ee9d00SSøren Schmidt } 10617ee9d00SSøren Schmidt 107b3e24f9cSBruce Evans static int 1088e6b0117SPeter Wemm fade_saver_load(struct lkm_table *lkmtp, int cmd) 10917ee9d00SSøren Schmidt { 1100de89efeSKazutaka YOKOTA switch (crtc_type) { 1110de89efeSKazutaka YOKOTA case KD_MONO: 1120de89efeSKazutaka YOKOTA case KD_HERCULES: 1130de89efeSKazutaka YOKOTA case KD_CGA: 1140de89efeSKazutaka YOKOTA /* 1150de89efeSKazutaka YOKOTA * `fade' saver is not fully implemented for MDA and CGA. 1160de89efeSKazutaka YOKOTA * It simply blanks the display instead. 1170de89efeSKazutaka YOKOTA */ 1180de89efeSKazutaka YOKOTA case KD_VGA: 1190de89efeSKazutaka YOKOTA break; 1200de89efeSKazutaka YOKOTA case KD_EGA: 1210de89efeSKazutaka YOKOTA /* EGA is yet to be supported */ 1220de89efeSKazutaka YOKOTA default: 1230de89efeSKazutaka YOKOTA return ENODEV; 1240de89efeSKazutaka YOKOTA } 125ce834215SKazutaka YOKOTA return add_scrn_saver(fade_saver); 12617ee9d00SSøren Schmidt } 12717ee9d00SSøren Schmidt 128b3e24f9cSBruce Evans static int 1298e6b0117SPeter Wemm fade_saver_unload(struct lkm_table *lkmtp, int cmd) 13017ee9d00SSøren Schmidt { 131ce834215SKazutaka YOKOTA return remove_scrn_saver(fade_saver); 13217ee9d00SSøren Schmidt } 13317ee9d00SSøren Schmidt 134b3e24f9cSBruce Evans int 1358e6b0117SPeter Wemm fade_saver_mod(struct lkm_table *lkmtp, int cmd, int ver) 13617ee9d00SSøren Schmidt { 137952d1128SPeter Dufault MOD_DISPATCH(fade_saver, lkmtp, cmd, ver, 138952d1128SPeter Dufault fade_saver_load, fade_saver_unload, lkm_nullcmd); 13917ee9d00SSøren Schmidt } 140