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"
|
|
|
|
|
|
|
|
static void
|
|
|
|
init(Vga* vga, Ctlr* ctlr)
|
|
|
|
{
|
|
|
|
ctlr->flag |= Finit;
|
|
|
|
|
|
|
|
if(cflag)
|
|
|
|
return;
|
|
|
|
/*
|
|
|
|
* Use of the on-chip hwgc requires using enhanced mode.
|
|
|
|
*/
|
|
|
|
if(vga->ctlr == 0 || (vga->ctlr->flag & Henhanced) == 0 || vga->mode->z < 8){
|
|
|
|
cflag = 1;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
resyncinit(vga, ctlr, Uenhanced, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
load(Vga* vga, Ctlr* ctlr)
|
|
|
|
{
|
|
|
|
ctlr->flag |= Fload;
|
|
|
|
|
|
|
|
if(cflag)
|
|
|
|
return;
|
|
|
|
/*
|
|
|
|
* Use of the on-chip hwgc requires using enhanced mode.
|
|
|
|
*/
|
|
|
|
if(vga->ctlr == 0 || (vga->ctlr->flag & Uenhanced) == 0 || vga->mode->z < 8)
|
|
|
|
cflag = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
Ctlr bt485hwgc = {
|
|
|
|
"bt485hwgc", /* name */
|
|
|
|
0, /* snarf */
|
|
|
|
0, /* options */
|
|
|
|
0, /* init */
|
|
|
|
0, /* load */
|
|
|
|
0, /* dump */
|
|
|
|
};
|
|
|
|
|
|
|
|
Ctlr rgb524hwgc = {
|
|
|
|
"rgb524hwgc", /* name */
|
|
|
|
0, /* snarf */
|
|
|
|
0, /* options */
|
|
|
|
0, /* init */
|
|
|
|
0, /* load */
|
|
|
|
0, /* dump */
|
|
|
|
};
|
|
|
|
|
|
|
|
Ctlr s3hwgc = {
|
|
|
|
"s3hwgc", /* name */
|
|
|
|
0, /* snarf */
|
|
|
|
0, /* options */
|
|
|
|
init, /* init */
|
|
|
|
load, /* load */
|
|
|
|
0, /* dump */
|
|
|
|
};
|
|
|
|
|
|
|
|
Ctlr tvp3020hwgc = {
|
|
|
|
"tvp3020hwgc", /* name */
|
|
|
|
0, /* snarf */
|
|
|
|
0, /* options */
|
|
|
|
0, /* init */
|
|
|
|
0, /* load */
|
|
|
|
0, /* dump */
|
|
|
|
};
|
|
|
|
|
|
|
|
Ctlr tvp3026hwgc = {
|
|
|
|
"tvp3026hwgc", /* name */
|
|
|
|
0, /* snarf */
|
|
|
|
0, /* options */
|
|
|
|
0, /* init */
|
|
|
|
0, /* load */
|
|
|
|
0, /* dump */
|
|
|
|
};
|