1bd389b36SDavid du Colombier #include <u.h>
2bd389b36SDavid du Colombier #include <libc.h>
37dd7cddfSDavid du Colombier #include <bio.h>
4bd389b36SDavid du Colombier
5*9a747e4fSDavid du Colombier #include "pci.h"
6219b2ee8SDavid du Colombier #include "vga.h"
7bd389b36SDavid du Colombier
8219b2ee8SDavid du Colombier enum {
9219b2ee8SDavid du Colombier NSeqx = 0x05,
10219b2ee8SDavid du Colombier NCrtx = 0x19,
11219b2ee8SDavid du Colombier NGrx = 0x09,
12219b2ee8SDavid du Colombier NAttrx = 0x15,
13219b2ee8SDavid du Colombier };
14bd389b36SDavid du Colombier
15219b2ee8SDavid du Colombier uchar
vgai(long port)16219b2ee8SDavid du Colombier vgai(long port)
17219b2ee8SDavid du Colombier {
18219b2ee8SDavid du Colombier uchar data;
19bd389b36SDavid du Colombier
20219b2ee8SDavid du Colombier switch(port){
21bd389b36SDavid du Colombier
22219b2ee8SDavid du Colombier case MiscR:
23219b2ee8SDavid du Colombier case Status0:
24219b2ee8SDavid du Colombier case Status1:
25219b2ee8SDavid du Colombier case FeatureR:
26219b2ee8SDavid du Colombier case PaddrW:
27219b2ee8SDavid du Colombier case Pdata:
28219b2ee8SDavid du Colombier case Pixmask:
29219b2ee8SDavid du Colombier case Pstatus:
30219b2ee8SDavid du Colombier data = inportb(port);
31219b2ee8SDavid du Colombier break;
32219b2ee8SDavid du Colombier
33219b2ee8SDavid du Colombier default:
347dd7cddfSDavid du Colombier error("vgai(0x%4.4lX): unknown port\n", port);
35219b2ee8SDavid du Colombier /*NOTREACHED*/
36219b2ee8SDavid du Colombier data = 0xFF;
37219b2ee8SDavid du Colombier break;
38bd389b36SDavid du Colombier }
39219b2ee8SDavid du Colombier return data;
40bd389b36SDavid du Colombier }
41bd389b36SDavid du Colombier
42bd389b36SDavid du Colombier uchar
vgaxi(long port,uchar index)43219b2ee8SDavid du Colombier vgaxi(long port, uchar index)
44bd389b36SDavid du Colombier {
45219b2ee8SDavid du Colombier uchar data;
46bd389b36SDavid du Colombier
47219b2ee8SDavid du Colombier switch(port){
48bd389b36SDavid du Colombier
49219b2ee8SDavid du Colombier case Seqx:
50219b2ee8SDavid du Colombier case Crtx:
51219b2ee8SDavid du Colombier case Grx:
52219b2ee8SDavid du Colombier outportb(port, index);
53219b2ee8SDavid du Colombier data = inportb(port+1);
54219b2ee8SDavid du Colombier break;
55bd389b36SDavid du Colombier
56219b2ee8SDavid du Colombier case Attrx:
57bd389b36SDavid du Colombier /*
58219b2ee8SDavid du Colombier * Allow processor access to the colour
59219b2ee8SDavid du Colombier * palette registers. Writes to Attrx must
60219b2ee8SDavid du Colombier * be preceded by a read from Status1 to
61219b2ee8SDavid du Colombier * initialise the register to point to the
62219b2ee8SDavid du Colombier * index register and not the data register.
63219b2ee8SDavid du Colombier * Processor access is allowed by turning
64219b2ee8SDavid du Colombier * off bit 0x20.
65bd389b36SDavid du Colombier */
66219b2ee8SDavid du Colombier inportb(Status1);
67219b2ee8SDavid du Colombier if(index < 0x10){
68219b2ee8SDavid du Colombier outportb(Attrx, index);
69219b2ee8SDavid du Colombier data = inportb(Attrx+1);
70219b2ee8SDavid du Colombier inportb(Status1);
71219b2ee8SDavid du Colombier outportb(Attrx, 0x20|index);
72bd389b36SDavid du Colombier }
73bd389b36SDavid du Colombier else{
74219b2ee8SDavid du Colombier outportb(Attrx, 0x20|index);
75219b2ee8SDavid du Colombier data = inportb(Attrx+1);
76bd389b36SDavid du Colombier }
77bd389b36SDavid du Colombier break;
78219b2ee8SDavid du Colombier
79bd389b36SDavid du Colombier default:
807dd7cddfSDavid du Colombier error("vgaxi(0x%4.4lx, 0x%2.2uX): unknown port\n", port, index);
81219b2ee8SDavid du Colombier /*NOTREACHED*/
82219b2ee8SDavid du Colombier data = 0xFF;
83219b2ee8SDavid du Colombier break;
84bd389b36SDavid du Colombier }
85219b2ee8SDavid du Colombier return data;
86bd389b36SDavid du Colombier }
87219b2ee8SDavid du Colombier
88219b2ee8SDavid du Colombier void
vgao(long port,uchar data)89219b2ee8SDavid du Colombier vgao(long port, uchar data)
90219b2ee8SDavid du Colombier {
91219b2ee8SDavid du Colombier switch(port){
92219b2ee8SDavid du Colombier
93219b2ee8SDavid du Colombier case MiscW:
94219b2ee8SDavid du Colombier case FeatureW:
95219b2ee8SDavid du Colombier case PaddrW:
96219b2ee8SDavid du Colombier case Pdata:
97219b2ee8SDavid du Colombier case Pixmask:
98219b2ee8SDavid du Colombier case PaddrR:
99219b2ee8SDavid du Colombier outportb(port, data);
100219b2ee8SDavid du Colombier break;
101219b2ee8SDavid du Colombier
102219b2ee8SDavid du Colombier default:
1037dd7cddfSDavid du Colombier error("vgao(0x%4.4lX, 0x%2.2uX): unknown port\n", port, data);
104219b2ee8SDavid du Colombier /*NOTREACHED*/
105219b2ee8SDavid du Colombier break;
106219b2ee8SDavid du Colombier }
107219b2ee8SDavid du Colombier }
108219b2ee8SDavid du Colombier
109219b2ee8SDavid du Colombier void
vgaxo(long port,uchar index,uchar data)110219b2ee8SDavid du Colombier vgaxo(long port, uchar index, uchar data)
111219b2ee8SDavid du Colombier {
112219b2ee8SDavid du Colombier switch(port){
113219b2ee8SDavid du Colombier
114219b2ee8SDavid du Colombier case Seqx:
115219b2ee8SDavid du Colombier case Crtx:
116219b2ee8SDavid du Colombier case Grx:
117219b2ee8SDavid du Colombier /*
118219b2ee8SDavid du Colombier * We could use an outport here, but some chips
119219b2ee8SDavid du Colombier * (e.g. 86C928) have trouble with that for some
120219b2ee8SDavid du Colombier * registers.
121219b2ee8SDavid du Colombier */
122219b2ee8SDavid du Colombier outportb(port, index);
123219b2ee8SDavid du Colombier outportb(port+1, data);
124219b2ee8SDavid du Colombier break;
125219b2ee8SDavid du Colombier
126219b2ee8SDavid du Colombier case Attrx:
127219b2ee8SDavid du Colombier inportb(Status1);
128219b2ee8SDavid du Colombier if(index < 0x10){
129219b2ee8SDavid du Colombier outportb(Attrx, index);
130219b2ee8SDavid du Colombier outportb(Attrx, data);
131219b2ee8SDavid du Colombier inportb(Status1);
132219b2ee8SDavid du Colombier outportb(Attrx, 0x20|index);
133219b2ee8SDavid du Colombier }
134219b2ee8SDavid du Colombier else{
135219b2ee8SDavid du Colombier outportb(Attrx, 0x20|index);
136219b2ee8SDavid du Colombier outportb(Attrx, data);
137219b2ee8SDavid du Colombier }
138219b2ee8SDavid du Colombier break;
139219b2ee8SDavid du Colombier
140219b2ee8SDavid du Colombier default:
1417dd7cddfSDavid du Colombier error("vgaxo(0x%4.4lX, 0x%2.2uX, 0x%2.2uX): unknown port\n",
1427dd7cddfSDavid du Colombier port, index, data);
143219b2ee8SDavid du Colombier break;
144219b2ee8SDavid du Colombier }
145219b2ee8SDavid du Colombier }
146219b2ee8SDavid du Colombier
147219b2ee8SDavid du Colombier static void
snarf(Vga * vga,Ctlr * ctlr)148219b2ee8SDavid du Colombier snarf(Vga* vga, Ctlr* ctlr)
149219b2ee8SDavid du Colombier {
150219b2ee8SDavid du Colombier int i;
151219b2ee8SDavid du Colombier
152219b2ee8SDavid du Colombier /*
153219b2ee8SDavid du Colombier * Generic VGA registers:
154219b2ee8SDavid du Colombier * misc, feature;
155219b2ee8SDavid du Colombier * sequencer;
156219b2ee8SDavid du Colombier * crt;
157219b2ee8SDavid du Colombier * graphics;
158219b2ee8SDavid du Colombier * attribute;
159219b2ee8SDavid du Colombier * palette.
160219b2ee8SDavid du Colombier */
161219b2ee8SDavid du Colombier vga->misc = vgai(MiscR);
162219b2ee8SDavid du Colombier vga->feature = vgai(FeatureR);
163219b2ee8SDavid du Colombier
164219b2ee8SDavid du Colombier for(i = 0; i < NSeqx; i++)
165219b2ee8SDavid du Colombier vga->sequencer[i] = vgaxi(Seqx, i);
166219b2ee8SDavid du Colombier
167219b2ee8SDavid du Colombier for(i = 0; i < NCrtx; i++)
168219b2ee8SDavid du Colombier vga->crt[i] = vgaxi(Crtx, i);
169219b2ee8SDavid du Colombier
170219b2ee8SDavid du Colombier for(i = 0; i < NGrx; i++)
171219b2ee8SDavid du Colombier vga->graphics[i] = vgaxi(Grx, i);
172219b2ee8SDavid du Colombier
173219b2ee8SDavid du Colombier for(i = 0; i < NAttrx; i++)
174219b2ee8SDavid du Colombier vga->attribute[i] = vgaxi(Attrx, i);
175219b2ee8SDavid du Colombier
176219b2ee8SDavid du Colombier if(dflag)
1777dd7cddfSDavid du Colombier palette.snarf(vga, ctlr);
178219b2ee8SDavid du Colombier
179219b2ee8SDavid du Colombier ctlr->flag |= Fsnarf;
180219b2ee8SDavid du Colombier }
181219b2ee8SDavid du Colombier
182219b2ee8SDavid du Colombier static void
init(Vga * vga,Ctlr * ctlr)183219b2ee8SDavid du Colombier init(Vga* vga, Ctlr* ctlr)
184219b2ee8SDavid du Colombier {
185219b2ee8SDavid du Colombier Mode *mode;
186219b2ee8SDavid du Colombier int vt, vde, vrs, vre;
1877dd7cddfSDavid du Colombier ulong tmp;
188219b2ee8SDavid du Colombier
189219b2ee8SDavid du Colombier mode = vga->mode;
190219b2ee8SDavid du Colombier
191219b2ee8SDavid du Colombier memset(vga->sequencer, 0, NSeqx*sizeof(vga->sequencer[0]));
192219b2ee8SDavid du Colombier memset(vga->crt, 0, NCrtx*sizeof(vga->crt[0]));
193219b2ee8SDavid du Colombier memset(vga->graphics, 0, NGrx*sizeof(vga->graphics[0]));
194219b2ee8SDavid du Colombier memset(vga->attribute, 0, NAttrx*sizeof(vga->attribute[0]));
195219b2ee8SDavid du Colombier if(dflag)
196219b2ee8SDavid du Colombier memset(vga->palette, 0, sizeof(vga->palette));
197219b2ee8SDavid du Colombier
198219b2ee8SDavid du Colombier /*
199219b2ee8SDavid du Colombier * Misc. If both the horizontal and vertical sync polarity
200219b2ee8SDavid du Colombier * options are set, use them. Otherwise use the defaults for
201219b2ee8SDavid du Colombier * the given vertical size.
202219b2ee8SDavid du Colombier */
203219b2ee8SDavid du Colombier vga->misc = 0x23;
204219b2ee8SDavid du Colombier if(mode->frequency == VgaFreq1)
205219b2ee8SDavid du Colombier vga->misc |= 0x04;
206219b2ee8SDavid du Colombier if(mode->hsync && mode->vsync){
207219b2ee8SDavid du Colombier if(mode->hsync == '-')
208219b2ee8SDavid du Colombier vga->misc |= 0x40;
209219b2ee8SDavid du Colombier if(mode->vsync == '-')
210219b2ee8SDavid du Colombier vga->misc |= 0x80;
211219b2ee8SDavid du Colombier }
212219b2ee8SDavid du Colombier else{
213219b2ee8SDavid du Colombier if(mode->y < 480)
214219b2ee8SDavid du Colombier vga->misc |= 0x40;
215219b2ee8SDavid du Colombier else if(mode->y < 400)
216219b2ee8SDavid du Colombier vga->misc |= 0x80;
217219b2ee8SDavid du Colombier else if(mode->y < 768)
218219b2ee8SDavid du Colombier vga->misc |= 0xC0;
219219b2ee8SDavid du Colombier }
220219b2ee8SDavid du Colombier
221219b2ee8SDavid du Colombier /*
222219b2ee8SDavid du Colombier * Sequencer
223219b2ee8SDavid du Colombier */
224219b2ee8SDavid du Colombier vga->sequencer[0x00] = 0x03;
225219b2ee8SDavid du Colombier vga->sequencer[0x01] = 0x01;
226219b2ee8SDavid du Colombier vga->sequencer[0x02] = 0x0F;
227219b2ee8SDavid du Colombier vga->sequencer[0x03] = 0x00;
2287dd7cddfSDavid du Colombier if(mode->z >= 8)
229219b2ee8SDavid du Colombier vga->sequencer[0x04] = 0x0A;
230219b2ee8SDavid du Colombier else
231219b2ee8SDavid du Colombier vga->sequencer[0x04] = 0x06;
232219b2ee8SDavid du Colombier
233219b2ee8SDavid du Colombier /*
234219b2ee8SDavid du Colombier * Crt. Most of the work here is in dealing
235219b2ee8SDavid du Colombier * with field overflow.
236219b2ee8SDavid du Colombier */
237219b2ee8SDavid du Colombier memset(vga->crt, 0, NCrtx);
238219b2ee8SDavid du Colombier
239219b2ee8SDavid du Colombier vga->crt[0x00] = (mode->ht>>3)-5;
240219b2ee8SDavid du Colombier vga->crt[0x01] = (mode->x>>3)-1;
241219b2ee8SDavid du Colombier vga->crt[0x02] = (mode->shb>>3)-1;
242219b2ee8SDavid du Colombier
243219b2ee8SDavid du Colombier /*
244219b2ee8SDavid du Colombier * End Horizontal Blank is a 6-bit field, 5-bits
245219b2ee8SDavid du Colombier * in Crt3, high bit in Crt5.
246219b2ee8SDavid du Colombier */
2477dd7cddfSDavid du Colombier tmp = mode->ehb>>3;
2487dd7cddfSDavid du Colombier vga->crt[0x03] = 0x80|(tmp & 0x1F);
2497dd7cddfSDavid du Colombier if(tmp & 0x20)
250219b2ee8SDavid du Colombier vga->crt[0x05] |= 0x80;
2517dd7cddfSDavid du Colombier
2527dd7cddfSDavid du Colombier if(mode->shs == 0)
2537dd7cddfSDavid du Colombier mode->shs = mode->shb;
2547dd7cddfSDavid du Colombier vga->crt[0x04] = mode->shs>>3;
2557dd7cddfSDavid du Colombier if(mode->ehs == 0)
2567dd7cddfSDavid du Colombier mode->ehs = mode->ehb;
2577dd7cddfSDavid du Colombier vga->crt[0x05] |= ((mode->ehs>>3) & 0x1F);
258219b2ee8SDavid du Colombier
259219b2ee8SDavid du Colombier /*
260219b2ee8SDavid du Colombier * Vertical Total is 10-bits, 8 in Crt6, the high
261219b2ee8SDavid du Colombier * two bits in Crt7. What if vt is >= 1024? We hope
262219b2ee8SDavid du Colombier * the specific controller has some more overflow
263219b2ee8SDavid du Colombier * bits.
264219b2ee8SDavid du Colombier *
265219b2ee8SDavid du Colombier * Interlace: if 'v', divide the vertical timing
266219b2ee8SDavid du Colombier * values by 2.
267219b2ee8SDavid du Colombier */
268219b2ee8SDavid du Colombier vt = mode->vt;
269219b2ee8SDavid du Colombier vde = mode->y;
270219b2ee8SDavid du Colombier vrs = mode->vrs;
271219b2ee8SDavid du Colombier vre = mode->vre;
272219b2ee8SDavid du Colombier
273219b2ee8SDavid du Colombier if(mode->interlace == 'v'){
274219b2ee8SDavid du Colombier vt /= 2;
275219b2ee8SDavid du Colombier vde /= 2;
276219b2ee8SDavid du Colombier vrs /= 2;
277219b2ee8SDavid du Colombier vre /= 2;
278219b2ee8SDavid du Colombier }
279219b2ee8SDavid du Colombier
2807dd7cddfSDavid du Colombier tmp = vt-2;
2817dd7cddfSDavid du Colombier vga->crt[0x06] = tmp;
2827dd7cddfSDavid du Colombier if(tmp & 0x100)
283219b2ee8SDavid du Colombier vga->crt[0x07] |= 0x01;
2847dd7cddfSDavid du Colombier if(tmp & 0x200)
285219b2ee8SDavid du Colombier vga->crt[0x07] |= 0x20;
286219b2ee8SDavid du Colombier
2877dd7cddfSDavid du Colombier tmp = vrs;
2887dd7cddfSDavid du Colombier vga->crt[0x10] = tmp;
2897dd7cddfSDavid du Colombier if(tmp & 0x100)
290219b2ee8SDavid du Colombier vga->crt[0x07] |= 0x04;
2917dd7cddfSDavid du Colombier if(tmp & 0x200)
292219b2ee8SDavid du Colombier vga->crt[0x07] |= 0x80;
293219b2ee8SDavid du Colombier
294219b2ee8SDavid du Colombier vga->crt[0x11] = 0x20|(vre & 0x0F);
295219b2ee8SDavid du Colombier
2967dd7cddfSDavid du Colombier tmp = vde-1;
2977dd7cddfSDavid du Colombier vga->crt[0x12] = tmp;
2987dd7cddfSDavid du Colombier if(tmp & 0x100)
299219b2ee8SDavid du Colombier vga->crt[0x07] |= 0x02;
3007dd7cddfSDavid du Colombier if(tmp & 0x200)
301219b2ee8SDavid du Colombier vga->crt[0x07] |= 0x40;
302219b2ee8SDavid du Colombier
303219b2ee8SDavid du Colombier vga->crt[0x15] = vrs;
304219b2ee8SDavid du Colombier if(vrs & 0x100)
305219b2ee8SDavid du Colombier vga->crt[0x07] |= 0x08;
306219b2ee8SDavid du Colombier if(vrs & 0x200)
307219b2ee8SDavid du Colombier vga->crt[0x09] |= 0x20;
308219b2ee8SDavid du Colombier
309219b2ee8SDavid du Colombier vga->crt[0x16] = (vrs+1);
310219b2ee8SDavid du Colombier
311219b2ee8SDavid du Colombier vga->crt[0x17] = 0x83;
312*9a747e4fSDavid du Colombier tmp = ((vga->virtx*mode->z)/8);
3137dd7cddfSDavid du Colombier if(tmp >= 512){
314219b2ee8SDavid du Colombier vga->crt[0x14] |= 0x60;
3157dd7cddfSDavid du Colombier tmp /= 8;
316219b2ee8SDavid du Colombier }
3177dd7cddfSDavid du Colombier else if(tmp >= 256){
318219b2ee8SDavid du Colombier vga->crt[0x17] |= 0x08;
3197dd7cddfSDavid du Colombier tmp /= 4;
320219b2ee8SDavid du Colombier }
321219b2ee8SDavid du Colombier else{
322219b2ee8SDavid du Colombier vga->crt[0x17] |= 0x40;
3237dd7cddfSDavid du Colombier tmp /= 2;
324219b2ee8SDavid du Colombier }
3257dd7cddfSDavid du Colombier vga->crt[0x13] = tmp;
326219b2ee8SDavid du Colombier
327219b2ee8SDavid du Colombier if(mode->x*mode->y*mode->z/8 > 64*1024)
328219b2ee8SDavid du Colombier vga->crt[0x17] |= 0x20;
329219b2ee8SDavid du Colombier
330219b2ee8SDavid du Colombier vga->crt[0x18] = 0x7FF;
331219b2ee8SDavid du Colombier if(vga->crt[0x18] & 0x100)
332219b2ee8SDavid du Colombier vga->crt[0x07] |= 0x10;
333219b2ee8SDavid du Colombier if(vga->crt[0x18] & 0x200)
334219b2ee8SDavid du Colombier vga->crt[0x09] |= 0x40;
335219b2ee8SDavid du Colombier
336219b2ee8SDavid du Colombier /*
337219b2ee8SDavid du Colombier * Graphics
338219b2ee8SDavid du Colombier */
339219b2ee8SDavid du Colombier memset(vga->graphics, 0, NGrx);
340219b2ee8SDavid du Colombier if((vga->sequencer[0x04] & 0x04) == 0)
341219b2ee8SDavid du Colombier vga->graphics[0x05] |= 0x10;
3427dd7cddfSDavid du Colombier if(mode->z >= 8)
343219b2ee8SDavid du Colombier vga->graphics[0x05] |= 0x40;
344219b2ee8SDavid du Colombier vga->graphics[0x06] = 0x05;
345219b2ee8SDavid du Colombier vga->graphics[0x07] = 0x0F;
346219b2ee8SDavid du Colombier vga->graphics[0x08] = 0xFF;
347219b2ee8SDavid du Colombier
348219b2ee8SDavid du Colombier /*
349219b2ee8SDavid du Colombier * Attribute
350219b2ee8SDavid du Colombier */
351219b2ee8SDavid du Colombier memset(vga->attribute, 0, NAttrx);
3527dd7cddfSDavid du Colombier for(tmp = 0; tmp < 0x10; tmp++)
3537dd7cddfSDavid du Colombier vga->attribute[tmp] = tmp;
354219b2ee8SDavid du Colombier vga->attribute[0x10] = 0x01;
3557dd7cddfSDavid du Colombier if(mode->z >= 8)
356219b2ee8SDavid du Colombier vga->attribute[0x10] |= 0x40;
357219b2ee8SDavid du Colombier vga->attribute[0x11] = 0xFF;
358219b2ee8SDavid du Colombier vga->attribute[0x12] = 0x0F;
359219b2ee8SDavid du Colombier
360219b2ee8SDavid du Colombier /*
361219b2ee8SDavid du Colombier * Palette
362219b2ee8SDavid du Colombier */
363219b2ee8SDavid du Colombier if(dflag)
3647dd7cddfSDavid du Colombier palette.init(vga, ctlr);
365219b2ee8SDavid du Colombier
366219b2ee8SDavid du Colombier ctlr->flag |= Finit;
367219b2ee8SDavid du Colombier }
368219b2ee8SDavid du Colombier
369219b2ee8SDavid du Colombier static void
load(Vga * vga,Ctlr * ctlr)370219b2ee8SDavid du Colombier load(Vga* vga, Ctlr* ctlr)
371219b2ee8SDavid du Colombier {
372219b2ee8SDavid du Colombier int i;
373219b2ee8SDavid du Colombier
374219b2ee8SDavid du Colombier /*
375219b2ee8SDavid du Colombier * Reset the sequencer and leave it off.
376219b2ee8SDavid du Colombier * Load the generic VGA registers:
377219b2ee8SDavid du Colombier * misc;
378219b2ee8SDavid du Colombier * sequencer (but not seq01, display enable);
379219b2ee8SDavid du Colombier * take the sequencer out of reset;
380219b2ee8SDavid du Colombier * take off write-protect on crt[0x00-0x07];
381219b2ee8SDavid du Colombier * crt;
382219b2ee8SDavid du Colombier * graphics;
383219b2ee8SDavid du Colombier * attribute;
384219b2ee8SDavid du Colombier * palette.
385219b2ee8SDavid du Colombier vgaxo(Seqx, 0x00, 0x00);
386219b2ee8SDavid du Colombier */
387219b2ee8SDavid du Colombier
388219b2ee8SDavid du Colombier vgao(MiscW, vga->misc);
389219b2ee8SDavid du Colombier
390219b2ee8SDavid du Colombier for(i = 2; i < NSeqx; i++)
391219b2ee8SDavid du Colombier vgaxo(Seqx, i, vga->sequencer[i]);
392219b2ee8SDavid du Colombier /*vgaxo(Seqx, 0x00, 0x03);*/
393219b2ee8SDavid du Colombier
394219b2ee8SDavid du Colombier vgaxo(Crtx, 0x11, vga->crt[0x11] & ~0x80);
395219b2ee8SDavid du Colombier for(i = 0; i < NCrtx; i++)
396219b2ee8SDavid du Colombier vgaxo(Crtx, i, vga->crt[i]);
397219b2ee8SDavid du Colombier
398219b2ee8SDavid du Colombier for(i = 0; i < NGrx; i++)
399219b2ee8SDavid du Colombier vgaxo(Grx, i, vga->graphics[i]);
400219b2ee8SDavid du Colombier
401219b2ee8SDavid du Colombier for(i = 0; i < NAttrx; i++)
402219b2ee8SDavid du Colombier vgaxo(Attrx, i, vga->attribute[i]);
403219b2ee8SDavid du Colombier
404219b2ee8SDavid du Colombier if(dflag)
4057dd7cddfSDavid du Colombier palette.load(vga, ctlr);
406219b2ee8SDavid du Colombier
407219b2ee8SDavid du Colombier ctlr->flag |= Fload;
408219b2ee8SDavid du Colombier }
409219b2ee8SDavid du Colombier
410219b2ee8SDavid du Colombier static void
dump(Vga * vga,Ctlr * ctlr)411219b2ee8SDavid du Colombier dump(Vga* vga, Ctlr* ctlr)
412219b2ee8SDavid du Colombier {
413219b2ee8SDavid du Colombier int i;
414219b2ee8SDavid du Colombier
415219b2ee8SDavid du Colombier printitem(ctlr->name, "misc");
416219b2ee8SDavid du Colombier printreg(vga->misc);
417219b2ee8SDavid du Colombier printitem(ctlr->name, "feature");
418219b2ee8SDavid du Colombier printreg(vga->feature);
419219b2ee8SDavid du Colombier
420219b2ee8SDavid du Colombier printitem(ctlr->name, "sequencer");
421219b2ee8SDavid du Colombier for(i = 0; i < NSeqx; i++)
422219b2ee8SDavid du Colombier printreg(vga->sequencer[i]);
423219b2ee8SDavid du Colombier
424219b2ee8SDavid du Colombier printitem(ctlr->name, "crt");
425219b2ee8SDavid du Colombier for(i = 0; i < NCrtx; i++)
426219b2ee8SDavid du Colombier printreg(vga->crt[i]);
427219b2ee8SDavid du Colombier
428219b2ee8SDavid du Colombier printitem(ctlr->name, "graphics");
429219b2ee8SDavid du Colombier for(i = 0; i < NGrx; i++)
430219b2ee8SDavid du Colombier printreg(vga->graphics[i]);
431219b2ee8SDavid du Colombier
432219b2ee8SDavid du Colombier printitem(ctlr->name, "attribute");
433219b2ee8SDavid du Colombier for(i = 0; i < NAttrx; i++)
434219b2ee8SDavid du Colombier printreg(vga->attribute[i]);
435219b2ee8SDavid du Colombier
436219b2ee8SDavid du Colombier if(dflag)
4377dd7cddfSDavid du Colombier palette.dump(vga, ctlr);
438219b2ee8SDavid du Colombier
439*9a747e4fSDavid du Colombier printitem(ctlr->name, "virtual");
440*9a747e4fSDavid du Colombier Bprint(&stdout, "%ld %ld\n", vga->virtx, vga->virty);
441*9a747e4fSDavid du Colombier printitem(ctlr->name, "panning");
442*9a747e4fSDavid du Colombier Bprint(&stdout, "%s\n", vga->panning ? "on" : "off");
4437dd7cddfSDavid du Colombier if(vga->f[0]){
4447dd7cddfSDavid du Colombier printitem(ctlr->name, "clock[0] f");
4457dd7cddfSDavid du Colombier Bprint(&stdout, "%9ld\n", vga->f[0]);
4467dd7cddfSDavid du Colombier printitem(ctlr->name, "clock[0] d i m");
4477dd7cddfSDavid du Colombier Bprint(&stdout, "%9ld %8ld - %8ld\n",
4487dd7cddfSDavid du Colombier vga->d[0], vga->i[0], vga->m[0]);
4497dd7cddfSDavid du Colombier printitem(ctlr->name, "clock[0] n p q r");
4507dd7cddfSDavid du Colombier Bprint(&stdout, "%9ld %8ld - %8ld %8ld\n",
4517dd7cddfSDavid du Colombier vga->n[0], vga->p[0], vga->q[0], vga->r[0]);
4527dd7cddfSDavid du Colombier }
4537dd7cddfSDavid du Colombier if(vga->f[1]){
4547dd7cddfSDavid du Colombier printitem(ctlr->name, "clock[1] f");
4557dd7cddfSDavid du Colombier Bprint(&stdout, "%9ld\n", vga->f[1]);
4567dd7cddfSDavid du Colombier printitem(ctlr->name, "clock[1] d i m");
4577dd7cddfSDavid du Colombier Bprint(&stdout, "%9ld %8ld - %8ld\n",
4587dd7cddfSDavid du Colombier vga->d[1], vga->i[1], vga->m[1]);
4597dd7cddfSDavid du Colombier printitem(ctlr->name, "clock[1] n p q r");
4607dd7cddfSDavid du Colombier Bprint(&stdout, "%9ld %8ld - %8ld %8ld\n",
4617dd7cddfSDavid du Colombier vga->n[1], vga->p[1], vga->q[1], vga->r[1]);
462219b2ee8SDavid du Colombier }
463219b2ee8SDavid du Colombier
4647dd7cddfSDavid du Colombier if(vga->vma || vga->vmb){
4657dd7cddfSDavid du Colombier printitem(ctlr->name, "vm a b");
4667dd7cddfSDavid du Colombier Bprint(&stdout, "%9lud %8lud\n", vga->vma, vga->vmb);
467219b2ee8SDavid du Colombier }
4687dd7cddfSDavid du Colombier if(vga->vmz){
4697dd7cddfSDavid du Colombier printitem(ctlr->name, "vmz");
4707dd7cddfSDavid du Colombier Bprint(&stdout, "%9lud\n", vga->vmz);
4717dd7cddfSDavid du Colombier }
4727dd7cddfSDavid du Colombier printitem(ctlr->name, "apz");
4737dd7cddfSDavid du Colombier Bprint(&stdout, "%9lud\n", vga->apz);
4747dd7cddfSDavid du Colombier
4757dd7cddfSDavid du Colombier printitem(ctlr->name, "linear");
4767dd7cddfSDavid du Colombier Bprint(&stdout, "%9d\n", vga->linear);
477219b2ee8SDavid du Colombier }
478219b2ee8SDavid du Colombier
479219b2ee8SDavid du Colombier Ctlr generic = {
480219b2ee8SDavid du Colombier "vga", /* name */
481219b2ee8SDavid du Colombier snarf, /* snarf */
482219b2ee8SDavid du Colombier 0, /* options */
483219b2ee8SDavid du Colombier init, /* init */
484219b2ee8SDavid du Colombier load, /* load */
485219b2ee8SDavid du Colombier dump, /* dump */
486219b2ee8SDavid du Colombier };
487