2016-11-25 17:18:40 +01:00
|
|
|
/*
|
|
|
|
* This file is part of the UCB release of Plan 9. It is subject to the license
|
|
|
|
* terms in the LICENSE file found in the top-level directory of this
|
|
|
|
* distribution and at http://akaros.cs.berkeley.edu/files/Plan9License. No
|
|
|
|
* part of the UCB release of Plan 9, including this file, may be copied,
|
|
|
|
* modified, propagated, or distributed except according to the terms contained
|
|
|
|
* in the LICENSE file.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <u.h>
|
2017-04-19 23:33:14 +02:00
|
|
|
#include <lib9.h>
|
2016-11-25 17:18:40 +01:00
|
|
|
#include <bio.h>
|
|
|
|
|
|
|
|
#include "pci.h"
|
|
|
|
#include "vga.h"
|
|
|
|
|
|
|
|
/*
|
|
|
|
* S3 86C80[15] GUI Accelerator.
|
|
|
|
*/
|
|
|
|
static void
|
|
|
|
snarf(Vga* vga, Ctlr* ctlr)
|
|
|
|
{
|
|
|
|
s3generic.snarf(vga, ctlr);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
options(Vga* vga, Ctlr* ctlr)
|
|
|
|
{
|
|
|
|
ctlr->flag |= Henhanced|Foptions;
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
init(Vga* vga, Ctlr* ctlr)
|
|
|
|
{
|
|
|
|
uint32_t x;
|
|
|
|
|
|
|
|
s3generic.init(vga, ctlr);
|
|
|
|
vga->crt[0x3B] = vga->crt[0]-5;
|
|
|
|
|
|
|
|
if(vga->mode->z > 8)
|
|
|
|
error("depth %d not supported\n", vga->mode->z);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Display memory access control.
|
|
|
|
* Calculation of the M-parameter (Crt54) is
|
|
|
|
* memory-system and dot-clock dependent, the
|
|
|
|
* values below are guesses from dumping
|
|
|
|
* registers.
|
|
|
|
*/
|
|
|
|
vga->crt[0x60] = 0xFF;
|
|
|
|
x = (vga->mode->x)/4;
|
|
|
|
vga->crt[0x61] = 0x80|((x>>8) & 0x07);
|
|
|
|
vga->crt[0x62] = (x & 0xFF);
|
|
|
|
|
|
|
|
if(vga->mode->x <= 800)
|
|
|
|
vga->crt[0x54] = 0x88;
|
|
|
|
else if(vga->mode->x <= 1024)
|
|
|
|
vga->crt[0x54] = 0xF8;
|
|
|
|
else
|
|
|
|
vga->crt[0x54] = 0x40;
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
load(Vga* vga, Ctlr* ctlr)
|
|
|
|
{
|
|
|
|
uint16_t advfunc;
|
|
|
|
|
|
|
|
s3generic.load(vga, ctlr);
|
|
|
|
vgaxo(Crtx, 0x60, vga->crt[0x60]);
|
|
|
|
vgaxo(Crtx, 0x61, vga->crt[0x61]);
|
|
|
|
vgaxo(Crtx, 0x62, vga->crt[0x62]);
|
|
|
|
|
|
|
|
advfunc = 0x0000;
|
|
|
|
if(ctlr->flag & Uenhanced){
|
|
|
|
if(vga->mode->x == 1024 || vga->mode->x == 800)
|
|
|
|
advfunc = 0x0057;
|
|
|
|
else
|
|
|
|
advfunc = 0x0053;
|
|
|
|
}
|
|
|
|
outportw(0x4AE8, advfunc);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
dump(Vga* vga, Ctlr* ctlr)
|
|
|
|
{
|
|
|
|
s3generic.dump(vga, ctlr);
|
|
|
|
}
|
|
|
|
|
|
|
|
Ctlr s3801 = {
|
|
|
|
"s3801", /* name */
|
|
|
|
snarf, /* snarf */
|
|
|
|
options, /* options */
|
|
|
|
init, /* init */
|
|
|
|
load, /* load */
|
|
|
|
dump, /* dump */
|
|
|
|
};
|
|
|
|
|
|
|
|
Ctlr s3805 = {
|
|
|
|
"s3805", /* name */
|
|
|
|
snarf, /* snarf */
|
|
|
|
options, /* options */
|
|
|
|
init, /* init */
|
|
|
|
load, /* load */
|
|
|
|
dump, /* dump */
|
|
|
|
};
|