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