Home | History | Annotate | Line # | Download | only in boot
vreset.c revision 1.11
      1  1.11    andvar /* $NetBSD: vreset.c,v 1.11 2023/05/06 21:34:40 andvar Exp $ */
      2   1.5   garbled /*-
      3   1.5   garbled  * Copyright (c) 2006 The NetBSD Foundation, Inc.
      4   1.1    nonaka  * All rights reserved.
      5   1.1    nonaka  *
      6   1.5   garbled  * This code is derived from software contributed to The NetBSD Foundation
      7   1.5   garbled  * by Tim Rightnour
      8   1.1    nonaka  *
      9   1.1    nonaka  * Redistribution and use in source and binary forms, with or without
     10   1.1    nonaka  * modification, are permitted provided that the following conditions
     11   1.1    nonaka  * are met:
     12   1.1    nonaka  * 1. Redistributions of source code must retain the above copyright
     13   1.1    nonaka  *    notice, this list of conditions and the following disclaimer.
     14   1.1    nonaka  * 2. Redistributions in binary form must reproduce the above copyright
     15   1.1    nonaka  *    notice, this list of conditions and the following disclaimer in the
     16   1.1    nonaka  *    documentation and/or other materials provided with the distribution.
     17   1.1    nonaka  *
     18   1.5   garbled  * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
     19   1.5   garbled  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
     20   1.5   garbled  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
     21   1.5   garbled  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
     22   1.5   garbled  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
     23   1.5   garbled  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
     24   1.5   garbled  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
     25   1.5   garbled  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
     26   1.5   garbled  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
     27   1.5   garbled  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
     28   1.5   garbled  * POSSIBILITY OF SUCH DAMAGE.
     29   1.1    nonaka  */
     30   1.1    nonaka 
     31   1.5   garbled #ifdef VGA_RESET
     32   1.1    nonaka #include <lib/libsa/stand.h>
     33   1.1    nonaka #include "boot.h"
     34   1.1    nonaka #include "iso_font.h"
     35   1.1    nonaka 
     36   1.5   garbled #define VGA_SR_PORT	0x3c4
     37   1.5   garbled #define VGA_CR_PORT	0x3d4
     38   1.5   garbled #define VGA_CR_DATA	0x3d5
     39   1.5   garbled #define VGA_GR_PORT	0x3ce
     40   1.5   garbled #define VGA_GR_DATA	0x3cf
     41   1.5   garbled #define SRREGS	4
     42   1.5   garbled #define CRREGS	24
     43   1.5   garbled #define GRREGS	9
     44   1.5   garbled #define LINES 25
     45   1.5   garbled #define COLS 80
     46   1.5   garbled #define PCI_VENDOR_S3		0x5333
     47   1.5   garbled #define PCI_VENDOR_CIRRUS	0x1013
     48   1.5   garbled #define PCI_VENDOR_DIAMOND	0x100E
     49   1.5   garbled #define PCI_VENDOR_MATROX	0x102B
     50   1.5   garbled #define PCI_VENDOR_PARADISE	0x101C
     51   1.5   garbled 
     52   1.5   garbled static void write_attr(u_int8_t, u_int8_t, u_int8_t);
     53   1.5   garbled static void set_text_regs(void);
     54   1.5   garbled static void set_text_clut(int);
     55   1.5   garbled static void load_font(u_int8_t *);
     56   1.5   garbled static void unlock_S3(void);
     57   1.5   garbled static void clear_video_memory(void);
     58   1.5   garbled 
     59   1.5   garbled extern char *videomem;
     60   1.5   garbled 
     61   1.5   garbled typedef struct vga_reg {
     62   1.5   garbled 	u_int8_t idx;
     63   1.5   garbled 	u_int8_t val;
     64   1.5   garbled } vga_reg_t;
     65   1.5   garbled 
     66   1.5   garbled static vga_reg_t SR_regs[SRREGS] = {
     67   1.5   garbled 	/* idx  val */
     68   1.5   garbled 	{ 0x1,	0x0 },	/* 01: clocking mode */
     69   1.5   garbled 	{ 0x2,	0x3 },	/* 02: map mask */
     70   1.5   garbled 	{ 0x3,	0x0 },	/* 03: character map select */
     71   1.5   garbled 	{ 0x4,	0x2 }	/* 04: memory mode */
     72   1.1    nonaka };
     73   1.1    nonaka 
     74   1.5   garbled static vga_reg_t CR_regs[CRREGS] = {
     75   1.5   garbled 	/* idx  val */
     76   1.5   garbled 	{ 0x0,	0x61 }, /* 00: horizontal total */
     77   1.5   garbled 	{ 0x1,	0x4f }, /* 01: horizontal display-enable end */
     78   1.5   garbled 	{ 0x2,	0x50 }, /* 02: start horizontal blanking */
     79   1.8   tsutsui 	{ 0x3,	0x82 }, /* 03: display skew control / end horizontal blanking */
     80   1.8   tsutsui 	{ 0x4,	0x55 }, /* 04: start horizontal retrace pulse */
     81   1.5   garbled 	{ 0x5,	0x81 }, /* 05: horizontal retrace delay / end horiz. retrace */
     82   1.5   garbled 	{ 0x6,	0xf0 }, /* 06: vertical total */
     83   1.5   garbled 	{ 0x7,	0x1f }, /* 07: overflow register */
     84   1.5   garbled 	{ 0x8,	0x00 }, /* 08: preset row scan */
     85   1.5   garbled 	{ 0x9,	0x4f }, /* 09: overflow / maximum scan line */
     86   1.5   garbled 	{ 0xa,	0x0d }, /* 0A: cursor off / cursor start */
     87   1.5   garbled 	{ 0xb,	0x0e }, /* 0B: cursor skew / cursor end */
     88   1.5   garbled 	{ 0xc,	0x00 }, /* 0C: start regenerative buffer address high */
     89   1.5   garbled 	{ 0xd,	0x00 }, /* 0D: start regenerative buffer address low */
     90   1.5   garbled 	{ 0xe,	0x00 }, /* 0E: cursor location high */
     91   1.5   garbled 	{ 0xf,	0x00 }, /* 0F: cursor location low */
     92   1.5   garbled 	{ 0x10, 0x9a }, /* 10: vertical retrace start */
     93   1.5   garbled 	{ 0x11, 0x8c }, /* 11: vertical interrupt / vertical retrace end */
     94   1.5   garbled 	{ 0x12, 0x8f }, /* 12: vertical display enable end */
     95   1.5   garbled 	{ 0x13, 0x28 }, /* 13: logical line width */
     96   1.5   garbled 	{ 0x14, 0x1f }, /* 14: underline location */
     97   1.5   garbled 	{ 0x15, 0x97 }, /* 15: start vertical blanking */
     98   1.5   garbled 	{ 0x16, 0x00 }, /* 16: end vertical blanking */
     99   1.5   garbled 	{ 0x17, 0xa3 }, /* 17: CRT mode control */
    100   1.1    nonaka };
    101   1.1    nonaka 
    102   1.5   garbled static vga_reg_t GR_regs[GRREGS] = {
    103   1.5   garbled 	/* idx  val */
    104   1.5   garbled 	{ 0x0,	0x00 }, /* 00: set/reset map */
    105   1.5   garbled 	{ 0x1,	0x00 }, /* 01: enable set/reset */
    106   1.5   garbled 	{ 0x2,	0x00 }, /* 02: color compare */
    107   1.5   garbled 	{ 0x3,	0x00 }, /* 03: data rotate */
    108   1.5   garbled 	{ 0x4,	0x00 }, /* 04: read map select */
    109   1.5   garbled 	{ 0x5,	0x10 }, /* 05: graphics mode */
    110   1.5   garbled 	{ 0x6,	0x0e }, /* 06: miscellaneous */
    111   1.5   garbled 	{ 0x7,	0x00 }, /* 07: color don't care */
    112   1.5   garbled 	{ 0x8,	0xff }, /* 08: bit mask */
    113   1.1    nonaka };
    114   1.1    nonaka 
    115   1.5   garbled /* video DAC palette registers */
    116  1.11    andvar /* XXX only set up 16 colors used by internal palette in ATC registers */
    117   1.5   garbled static const u_int8_t vga_dacpal[] = {
    118   1.5   garbled 	/* R     G     B */
    119   1.5   garbled 	0x00, 0x00, 0x00,	/* BLACK        */
    120   1.5   garbled 	0x00, 0x00, 0x2a,	/* BLUE         */
    121   1.5   garbled 	0x00, 0x2a, 0x00,	/* GREEN        */
    122   1.5   garbled 	0x00, 0x2a, 0x2a,	/* CYAN         */
    123   1.5   garbled 	0x2a, 0x00, 0x00,	/* RED          */
    124   1.5   garbled 	0x2a, 0x00, 0x2a,	/* MAGENTA      */
    125   1.5   garbled 	0x2a, 0x15, 0x00,	/* BROWN        */
    126   1.5   garbled 	0x2a, 0x2a, 0x2a,	/* LIGHTGREY    */
    127   1.5   garbled 	0x15, 0x15, 0x15,	/* DARKGREY     */
    128   1.5   garbled 	0x15, 0x15, 0x3f,	/* LIGHTBLUE    */
    129   1.5   garbled 	0x15, 0x3f, 0x15,	/* LIGHTGREEN   */
    130   1.5   garbled 	0x15, 0x3f, 0x3f,	/* LIGHTCYAN    */
    131   1.5   garbled 	0x3f, 0x15, 0x15,	/* LIGHTRED     */
    132   1.5   garbled 	0x3f, 0x15, 0x3f,	/* LIGHTMAGENTA */
    133   1.5   garbled 	0x3f, 0x3f, 0x15,	/* YELLOW       */
    134   1.5   garbled 	0x3f, 0x3f, 0x3f	/* WHITE        */
    135   1.1    nonaka };
    136   1.1    nonaka 
    137   1.5   garbled static const u_int8_t vga_atc[] = {
    138   1.5   garbled 	0x00,	/* 00: internal palette  0 */
    139   1.5   garbled 	0x01,	/* 01: internal palette  1 */
    140   1.5   garbled 	0x02,	/* 02: internal palette  2 */
    141   1.5   garbled 	0x03,	/* 03: internal palette  3 */
    142   1.5   garbled 	0x04,	/* 04: internal palette  4 */
    143   1.5   garbled 	0x05,	/* 05: internal palette  5 */
    144   1.5   garbled 	0x14,	/* 06: internal palette  6 */
    145   1.5   garbled 	0x07,	/* 07: internal palette  7 */
    146   1.5   garbled 	0x38,	/* 08: internal palette  8 */
    147   1.5   garbled 	0x39,	/* 09: internal palette  9 */
    148   1.5   garbled 	0x3a,	/* 0A: internal palette 10 */
    149   1.5   garbled 	0x3b,	/* 0B: internal palette 11 */
    150   1.5   garbled 	0x3c,	/* 0C: internal palette 12 */
    151   1.5   garbled 	0x3d,	/* 0D: internal palette 13 */
    152   1.5   garbled 	0x3e,	/* 0E: internal palette 14 */
    153   1.5   garbled 	0x3f,	/* 0F: internal palette 15 */
    154   1.5   garbled 	0x0c,	/* 10: attribute mode control */
    155   1.5   garbled 	0x00,	/* 11: overscan color */
    156   1.5   garbled 	0x0f,	/* 12: color plane enable */
    157   1.5   garbled 	0x08,	/* 13: horizontal PEL panning */
    158   1.5   garbled 	0x00	/* 14: color select */
    159   1.1    nonaka };
    160   1.1    nonaka 
    161   1.1    nonaka void
    162   1.4   garbled vga_reset(u_char *ISA_mem)
    163   1.1    nonaka {
    164   1.6   garbled 	int slot, cardfound;
    165   1.1    nonaka 
    166   1.5   garbled 	/* check if we are in text mode, if so, punt */
    167   1.5   garbled 	outb(VGA_GR_PORT, 0x06);
    168   1.5   garbled 	if ((inb(VGA_GR_DATA) & 0x01) == 0)
    169   1.5   garbled 		return;
    170   1.5   garbled 
    171   1.5   garbled 	/* guess not, we lose. */
    172   1.5   garbled 	slot = -1;
    173   1.5   garbled 	while ((slot = scan_PCI(slot)) > -1) {
    174   1.6   garbled 		cardfound = 0;
    175   1.5   garbled 		switch (PCI_vendor(slot)) {
    176   1.5   garbled 		case PCI_VENDOR_CIRRUS:
    177   1.6   garbled 			unlockVideo(slot);
    178   1.5   garbled 			outw(VGA_SR_PORT, 0x0612); /* unlock ext regs */
    179   1.5   garbled 			outw(VGA_SR_PORT, 0x0700); /* reset ext sequence mode */
    180   1.6   garbled 			cardfound++;
    181   1.5   garbled 			break;
    182   1.5   garbled 		case PCI_VENDOR_PARADISE:
    183   1.6   garbled 			unlockVideo(slot);
    184   1.5   garbled 			outw(VGA_GR_PORT, 0x0f05); /* unlock registers */
    185   1.5   garbled 			outw(VGA_SR_PORT, 0x0648);
    186   1.5   garbled 			outw(VGA_CR_PORT, 0x2985);
    187   1.5   garbled 			outw(VGA_CR_PORT, 0x34a6);
    188   1.5   garbled 			outb(VGA_GR_PORT, 0x0b); /* disable linear addressing */
    189   1.5   garbled 			outb(VGA_GR_DATA, inb(VGA_GR_DATA) & ~0x30);
    190   1.5   garbled 			outw(VGA_SR_PORT, 0x1400);
    191   1.5   garbled 			outb(VGA_GR_PORT, 0x0e); /* disable 256 color mode */
    192   1.5   garbled 			outb(VGA_GR_DATA, inb(VGA_GR_DATA) & ~0x01);
    193   1.5   garbled 			outb(0xd00, 0xff); /* enable auto-centering */
    194   1.5   garbled 			if (!(inb(0xd01) & 0x03)) {
    195   1.5   garbled 				outb(VGA_CR_PORT, 0x33);
    196   1.5   garbled 				outb(VGA_CR_DATA, inb(VGA_CR_DATA) & ~0x90);
    197   1.5   garbled 				outb(VGA_CR_PORT, 0x32);
    198   1.5   garbled 				outb(VGA_CR_DATA, inb(VGA_CR_DATA) | 0x04);
    199   1.5   garbled 				outw(VGA_CR_PORT, 0x0250);
    200   1.5   garbled 				outw(VGA_CR_PORT, 0x07ba);
    201   1.5   garbled 				outw(VGA_CR_PORT, 0x0900);
    202   1.5   garbled 				outw(VGA_CR_PORT, 0x15e7);
    203   1.5   garbled 				outw(VGA_CR_PORT, 0x2a95);
    204   1.5   garbled 			}
    205   1.5   garbled 			outw(VGA_CR_PORT, 0x34a0);
    206   1.6   garbled 			cardfound++;
    207   1.5   garbled 			break;
    208   1.5   garbled 		case PCI_VENDOR_S3:
    209   1.6   garbled 			unlockVideo(slot);
    210   1.5   garbled 			unlock_S3();
    211   1.6   garbled 			cardfound++;
    212   1.5   garbled 			break;
    213   1.5   garbled 		default:
    214   1.5   garbled 			break;
    215   1.5   garbled 		}
    216   1.6   garbled 		if (cardfound) {
    217   1.6   garbled 			outw(VGA_SR_PORT, 0x0120); /* disable video */
    218   1.6   garbled 			set_text_regs();
    219   1.6   garbled 			set_text_clut(0);
    220   1.6   garbled 			load_font(ISA_mem);
    221   1.6   garbled 			set_text_regs();
    222   1.6   garbled 			outw(VGA_SR_PORT, 0x0100); /* re-enable video */
    223   1.6   garbled 			clear_video_memory();
    224   1.6   garbled 
    225   1.6   garbled 			if (PCI_vendor(slot) == PCI_VENDOR_S3)
    226   1.6   garbled 				outb(0x3c2, 0x63);	/* ??? */
    227   1.6   garbled 			delay(1000);
    228   1.6   garbled 		}
    229   1.5   garbled 	}
    230   1.5   garbled 	return;
    231   1.1    nonaka }
    232   1.1    nonaka 
    233   1.5   garbled /* write something to a VGA attribute register */
    234   1.5   garbled static void
    235   1.5   garbled write_attr(u_int8_t index, u_int8_t data, u_int8_t videoOn)
    236   1.1    nonaka {
    237   1.5   garbled 
    238   1.9       mrg 	(void)inb(0x3da);	/* reset attr addr toggle */
    239   1.1    nonaka 	if (videoOn)
    240   1.1    nonaka 		outb(0x3c0, (index & 0x1F) | 0x20);
    241   1.1    nonaka 	else
    242   1.1    nonaka 		outb(0x3c0, (index & 0x1F));
    243   1.1    nonaka 	outb(0x3c0, data);
    244   1.1    nonaka }
    245   1.1    nonaka 
    246   1.5   garbled static void
    247   1.5   garbled set_text_regs(void)
    248   1.1    nonaka {
    249   1.1    nonaka 	int i;
    250   1.1    nonaka 
    251   1.5   garbled 	for (i = 0; i < SRREGS; i++) {
    252   1.5   garbled 		outb(VGA_SR_PORT, SR_regs[i].idx);
    253   1.5   garbled 		outb(VGA_SR_PORT + 1, SR_regs[i].val);
    254   1.5   garbled 	}
    255   1.5   garbled 	for (i = 0; i < CRREGS; i++) {
    256   1.5   garbled 		outb(VGA_CR_PORT, CR_regs[i].idx);
    257   1.5   garbled 		outb(VGA_CR_PORT + 1, CR_regs[i].val);
    258   1.5   garbled 	}
    259   1.5   garbled 	for (i = 0; i < GRREGS; i++) {
    260   1.5   garbled 		outb(VGA_GR_PORT, GR_regs[i].idx);
    261   1.5   garbled 		outb(VGA_GR_PORT + 1, GR_regs[i].val);
    262   1.1    nonaka 	}
    263   1.1    nonaka 
    264   1.1    nonaka 	outb(0x3c2, 0x67);  /* MISC */
    265   1.1    nonaka 	outb(0x3c6, 0xff);  /* MASK */
    266   1.1    nonaka 
    267   1.5   garbled 	for (i = 0; i < 0x14; i++)
    268   1.5   garbled 		write_attr(i, vga_atc[i], 0);
    269   1.5   garbled 	write_attr(0x14, 0x00, 1); /* color select; video on  */
    270   1.1    nonaka }
    271   1.1    nonaka 
    272   1.5   garbled static void
    273   1.5   garbled set_text_clut(int shift)
    274   1.1    nonaka {
    275   1.1    nonaka 	int i;
    276   1.1    nonaka 
    277   1.5   garbled 	outb(0x3C6, 0xFF);
    278   1.5   garbled 	inb(0x3C7);
    279   1.5   garbled 	outb(0x3C8, 0);
    280   1.5   garbled 	inb(0x3C7);
    281   1.5   garbled 
    282   1.5   garbled 	for (i = 0; i < (16 * 3); ) {
    283   1.5   garbled 		outb(0x3c9, vga_dacpal[i++] << shift);
    284   1.5   garbled 		outb(0x3c9, vga_dacpal[i++] << shift);
    285   1.5   garbled 		outb(0x3c9, vga_dacpal[i++] << shift);
    286   1.1    nonaka 	}
    287   1.1    nonaka }
    288   1.1    nonaka 
    289   1.5   garbled static void
    290   1.5   garbled load_font(u_int8_t *ISA_mem)
    291   1.1    nonaka {
    292   1.1    nonaka 	int i, j;
    293   1.5   garbled 	u_int8_t *font_page = (u_int8_t *)&ISA_mem[0xA0000];
    294   1.5   garbled 
    295   1.1    nonaka 	outb(0x3C2, 0x67);
    296   1.5   garbled 	inb(0x3DA);  /* Reset Attr toggle */
    297   1.5   garbled 
    298   1.5   garbled 	outb(0x3C0, 0x30);
    299   1.5   garbled 	outb(0x3C0, 0x01);	/* graphics mode */
    300   1.5   garbled 	outw(0x3C4, 0x0001);	/* reset sequencer */
    301   1.5   garbled 	outw(0x3C4, 0x0204);	/* write to plane 2 */
    302   1.5   garbled 	outw(0x3C4, 0x0406);	/* enable plane graphics */
    303   1.5   garbled 	outw(0x3C4, 0x0003);	/* reset sequencer */
    304   1.5   garbled 	outw(0x3CE, 0x0402);	/* read plane 2 */
    305   1.5   garbled 	outw(0x3CE, 0x0500);	/* write mode 0, read mode 0 */
    306   1.5   garbled 	outw(0x3CE, 0x0605);	/* set graphics mode */
    307   1.1    nonaka 
    308   1.1    nonaka 	for (i = 0;  i < sizeof(font);  i += 16) {
    309   1.1    nonaka 		for (j = 0;  j < 16;  j++) {
    310  1.10  riastrad 			__asm__ volatile("eieio" ::: "memory");
    311   1.1    nonaka 			font_page[(2*i)+j] = font[i+j];
    312   1.1    nonaka 		}
    313   1.1    nonaka 	}
    314   1.1    nonaka }
    315   1.1    nonaka 
    316   1.5   garbled static void
    317   1.5   garbled unlock_S3(void)
    318   1.1    nonaka {
    319   1.5   garbled 	int s3_devid;
    320   1.1    nonaka 
    321   1.5   garbled 	outw(VGA_CR_PORT, 0x3848);
    322   1.5   garbled 	outw(VGA_CR_PORT, 0x39a5);
    323   1.5   garbled 	outb(VGA_CR_PORT, 0x2d);
    324   1.5   garbled 	s3_devid = inb(VGA_CR_DATA) << 8;
    325   1.5   garbled 	outb(VGA_CR_PORT, 0x2e);
    326   1.5   garbled 	s3_devid |= inb(VGA_CR_DATA);
    327   1.5   garbled 
    328   1.5   garbled 	if (s3_devid != 0x8812) {
    329   1.5   garbled 		/* from the S3 manual */
    330   1.5   garbled 		outb(0x46E8, 0x10);  /* Put into setup mode */
    331   1.5   garbled 		outb(0x3C3, 0x10);
    332   1.5   garbled 		outb(0x102, 0x01);   /* Enable registers */
    333   1.5   garbled 		outb(0x46E8, 0x08);  /* Enable video */
    334   1.5   garbled 		outb(0x3C3, 0x08);
    335   1.5   garbled 		outb(0x4AE8, 0x00);
    336   1.5   garbled                 outb(VGA_CR_PORT, 0x38);  /* Unlock all registers */
    337   1.5   garbled 		outb(VGA_CR_DATA, 0x48);
    338   1.5   garbled 		outb(VGA_CR_PORT, 0x39);
    339   1.5   garbled 		outb(VGA_CR_DATA, 0xA5);
    340   1.5   garbled 		outb(VGA_CR_PORT, 0x40);
    341   1.5   garbled 		outb(VGA_CR_DATA, inb(0x3D5)|0x01);
    342   1.5   garbled 		outb(VGA_CR_PORT, 0x33);
    343   1.5   garbled 		outb(VGA_CR_DATA, inb(0x3D5)&~0x52);
    344   1.5   garbled 		outb(VGA_CR_PORT, 0x35);
    345   1.5   garbled 		outb(VGA_CR_DATA, inb(0x3D5)&~0x30);
    346   1.5   garbled 		outb(VGA_CR_PORT, 0x3A);
    347   1.5   garbled 		outb(VGA_CR_DATA, 0x00);
    348   1.5   garbled 		outb(VGA_CR_PORT, 0x53);
    349   1.5   garbled 		outb(VGA_CR_DATA, 0x00);
    350   1.5   garbled 		outb(VGA_CR_PORT, 0x31);
    351   1.5   garbled 		outb(VGA_CR_DATA, inb(0x3D5)&~0x4B);
    352   1.5   garbled 		outb(VGA_CR_PORT, 0x58);
    353   1.5   garbled 
    354   1.5   garbled 		outb(VGA_CR_DATA, 0);
    355   1.5   garbled 
    356   1.5   garbled 		outb(VGA_CR_PORT, 0x54);
    357   1.5   garbled 		outb(VGA_CR_DATA, 0x38);
    358   1.5   garbled 		outb(VGA_CR_PORT, 0x60);
    359   1.5   garbled 		outb(VGA_CR_DATA, 0x07);
    360   1.5   garbled 		outb(VGA_CR_PORT, 0x61);
    361   1.5   garbled 		outb(VGA_CR_DATA, 0x80);
    362   1.5   garbled 		outb(VGA_CR_PORT, 0x62);
    363   1.5   garbled 		outb(VGA_CR_DATA, 0xA1);
    364   1.5   garbled 		outb(VGA_CR_PORT, 0x69);  /* High order bits for cursor address */
    365   1.5   garbled 		outb(VGA_CR_DATA, 0);
    366   1.5   garbled 
    367   1.5   garbled 		outb(VGA_CR_PORT, 0x32);
    368   1.5   garbled 		outb(VGA_CR_DATA, inb(0x3D5)&~0x10);
    369   1.5   garbled 	} else {
    370   1.5   garbled 		/* IBM Portable 860 */
    371   1.5   garbled 		outw(VGA_SR_PORT, 0x0806);
    372   1.5   garbled 		outw(VGA_SR_PORT, 0x1041);
    373   1.5   garbled 		outw(VGA_SR_PORT, 0x1128);
    374   1.5   garbled 		outw(VGA_CR_PORT, 0x4000);
    375   1.5   garbled 		outw(VGA_CR_PORT, 0x3100);
    376   1.5   garbled 		outw(VGA_CR_PORT, 0x3a05);
    377   1.5   garbled 		outw(VGA_CR_PORT, 0x6688);
    378   1.5   garbled 		outw(VGA_CR_PORT, 0x5800); /* disable linear addressing */
    379   1.5   garbled 		outw(VGA_CR_PORT, 0x4500); /* disable H/W cursor */
    380   1.5   garbled 		outw(VGA_SR_PORT, 0x5410); /* enable auto-centering */
    381   1.5   garbled 		outw(VGA_SR_PORT, 0x561f);
    382   1.5   garbled 		outw(VGA_SR_PORT, 0x1b80); /* lock DCLK selection */
    383   1.5   garbled 		outw(VGA_CR_PORT, 0x3900); /* lock S3 registers */
    384   1.5   garbled 		outw(VGA_CR_PORT, 0x3800);
    385   1.5   garbled 	}
    386   1.1    nonaka }
    387   1.1    nonaka 
    388   1.5   garbled static void
    389   1.5   garbled clear_video_memory(void)
    390   1.1    nonaka {
    391   1.5   garbled 	int i, j;
    392   1.1    nonaka 
    393   1.5   garbled 	for (i = 0;  i < LINES; i++) {
    394   1.5   garbled 		for (j = 0; j < COLS; j++) {
    395   1.5   garbled 			videomem[((i * COLS)+j) * 2] = 0x20; /* space */
    396   1.5   garbled 			videomem[((i * COLS)+j) * 2 + 1] = 0x07; /* fg/bg */
    397   1.1    nonaka 		}
    398   1.1    nonaka 	}
    399   1.1    nonaka }
    400   1.1    nonaka 
    401   1.5   garbled #endif /* VGA_RESET */
    402