xref: /freebsd/sys/dev/syscons/fade/fade_saver.c (revision 2ad872c5794e4c26fdf6ed219ad3f09ca0d5304a)
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