xref: /freebsd/sys/dev/syscons/fade/fade_saver.c (revision 0de89efe5c443f213c7ea28773ef2dc6cf3af2ed)
117ee9d00SSøren Schmidt /*-
2b6b9dfa1SSøren Schmidt  * Copyright (c) 1995-1997 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
917ee9d00SSøren Schmidt  *    notice, this list of conditions and the following disclaimer
1017ee9d00SSøren Schmidt  *    in this position and unchanged.
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
1517ee9d00SSøren Schmidt  *    derived from this software withough 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  *
280de89efeSKazutaka YOKOTA  *	$Id: fade_saver.c,v 1.11 1997/07/15 14:49:25 yokota Exp $
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:
87b6b9dfa1SSøren Schmidt 			load_palette(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