xref: /freebsd/sys/dev/syscons/green/green_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: green_saver.c,v 1.14 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 
362ad872c5SKazutaka YOKOTA #include <dev/fb/vgareg.h>
372ad872c5SKazutaka YOKOTA 
38ce834215SKazutaka YOKOTA #include <i386/isa/isa.h>
39ce834215SKazutaka YOKOTA 
4017ee9d00SSøren Schmidt #include <saver.h>
4117ee9d00SSøren Schmidt 
422ad872c5SKazutaka YOKOTA static int
432ad872c5SKazutaka YOKOTA green_saver(video_adapter_t *adp, int blank)
4417ee9d00SSøren Schmidt {
452ad872c5SKazutaka YOKOTA 	int crtc_addr;
4617ee9d00SSøren Schmidt 	u_char val;
472ad872c5SKazutaka YOKOTA 
482ad872c5SKazutaka YOKOTA 	crtc_addr = adp->va_crtc_addr;
4917ee9d00SSøren Schmidt 	if (blank) {
502ad872c5SKazutaka YOKOTA 		switch (adp->va_type) {
510de89efeSKazutaka YOKOTA 		case KD_VGA:
5217ee9d00SSøren Schmidt 			outb(TSIDX, 0x01); val = inb(TSREG);
5317ee9d00SSøren Schmidt 			outb(TSIDX, 0x01); outb(TSREG, val | 0x20);
5417ee9d00SSøren Schmidt 			outb(crtc_addr, 0x17); val = inb(crtc_addr + 1);
5517ee9d00SSøren Schmidt 			outb(crtc_addr + 1, val & ~0x80);
560de89efeSKazutaka YOKOTA 			break;
570de89efeSKazutaka YOKOTA 		case KD_EGA:
580de89efeSKazutaka YOKOTA 			/* not yet done XXX */
590de89efeSKazutaka YOKOTA 			break;
600de89efeSKazutaka YOKOTA 		case KD_CGA:
610de89efeSKazutaka YOKOTA 			outb(crtc_addr + 4, 0x25);
620de89efeSKazutaka YOKOTA 			break;
630de89efeSKazutaka YOKOTA 		case KD_MONO:
640de89efeSKazutaka YOKOTA 		case KD_HERCULES:
650de89efeSKazutaka YOKOTA 			outb(crtc_addr + 4, 0x21);
660de89efeSKazutaka YOKOTA 			break;
670de89efeSKazutaka YOKOTA 		default:
680de89efeSKazutaka YOKOTA 			break;
690de89efeSKazutaka YOKOTA 		}
7017ee9d00SSøren Schmidt 	}
7117ee9d00SSøren Schmidt 	else {
722ad872c5SKazutaka YOKOTA 		switch (adp->va_type) {
730de89efeSKazutaka YOKOTA 		case KD_VGA:
7417ee9d00SSøren Schmidt 			outb(TSIDX, 0x01); val = inb(TSREG);
7517ee9d00SSøren Schmidt 			outb(TSIDX, 0x01); outb(TSREG, val & 0xDF);
7617ee9d00SSøren Schmidt 			outb(crtc_addr, 0x17); val = inb(crtc_addr + 1);
7717ee9d00SSøren Schmidt 			outb(crtc_addr + 1, val | 0x80);
780de89efeSKazutaka YOKOTA 			break;
790de89efeSKazutaka YOKOTA 		case KD_EGA:
800de89efeSKazutaka YOKOTA 			/* not yet done XXX */
810de89efeSKazutaka YOKOTA 			break;
820de89efeSKazutaka YOKOTA 		case KD_CGA:
830de89efeSKazutaka YOKOTA 			outb(crtc_addr + 4, 0x2d);
840de89efeSKazutaka YOKOTA 			break;
850de89efeSKazutaka YOKOTA 		case KD_MONO:
860de89efeSKazutaka YOKOTA 		case KD_HERCULES:
870de89efeSKazutaka YOKOTA 			outb(crtc_addr + 4, 0x29);
880de89efeSKazutaka YOKOTA 			break;
890de89efeSKazutaka YOKOTA 		default:
900de89efeSKazutaka YOKOTA 			break;
910de89efeSKazutaka YOKOTA 		}
9217ee9d00SSøren Schmidt 	}
932ad872c5SKazutaka YOKOTA 	return 0;
9417ee9d00SSøren Schmidt }
9517ee9d00SSøren Schmidt 
96b3e24f9cSBruce Evans static int
972ad872c5SKazutaka YOKOTA green_init(video_adapter_t *adp)
9817ee9d00SSøren Schmidt {
992ad872c5SKazutaka YOKOTA 	switch (adp->va_type) {
1000de89efeSKazutaka YOKOTA 	case KD_MONO:
1010de89efeSKazutaka YOKOTA 	case KD_HERCULES:
1020de89efeSKazutaka YOKOTA 	case KD_CGA:
1030de89efeSKazutaka YOKOTA 		/*
1040de89efeSKazutaka YOKOTA 		 * `green' saver is not fully implemented for MDA and CGA.
1050de89efeSKazutaka YOKOTA 		 * It simply blanks the display instead.
1060de89efeSKazutaka YOKOTA 		 */
1070de89efeSKazutaka YOKOTA 	case KD_VGA:
1080de89efeSKazutaka YOKOTA 		break;
1090de89efeSKazutaka YOKOTA 	case KD_EGA:
1100de89efeSKazutaka YOKOTA 		/* EGA is yet to be supported */
1110de89efeSKazutaka YOKOTA 	default:
1120de89efeSKazutaka YOKOTA 		return ENODEV;
1130de89efeSKazutaka YOKOTA 	}
1142ad872c5SKazutaka YOKOTA 	return 0;
11517ee9d00SSøren Schmidt }
11617ee9d00SSøren Schmidt 
117b3e24f9cSBruce Evans static int
1182ad872c5SKazutaka YOKOTA green_term(video_adapter_t *adp)
11917ee9d00SSøren Schmidt {
1202ad872c5SKazutaka YOKOTA 	return 0;
12117ee9d00SSøren Schmidt }
12217ee9d00SSøren Schmidt 
1232ad872c5SKazutaka YOKOTA static scrn_saver_t green_module = {
1242ad872c5SKazutaka YOKOTA 	"green_saver", green_init, green_term, green_saver, NULL,
1252ad872c5SKazutaka YOKOTA };
1262ad872c5SKazutaka YOKOTA 
1272ad872c5SKazutaka YOKOTA SAVER_MODULE(green_saver, green_module);
128