1 | /*
|
---|
2 | =============================================================================
|
---|
3 | vhinit.c -- initialize VSDD hardware
|
---|
4 | Version 17 -- 1988-03-20 -- D.N. Lynx Crowe
|
---|
5 | (c) Copyright 1987, 1988 -- D.N. Lynx Crowe
|
---|
6 |
|
---|
7 | VHinit()
|
---|
8 |
|
---|
9 | Setup VSDD registers, clear access table, clear object table,
|
---|
10 | load character generator, set color lookup table defaults.
|
---|
11 | Defines major video system variables, since the linker isn't
|
---|
12 | smart enough to let me put them in a separate file.
|
---|
13 | =============================================================================
|
---|
14 | */
|
---|
15 |
|
---|
16 | #define FASTCHIP 1 /* non-zero if it's the fast VSDD chip */
|
---|
17 |
|
---|
18 | #include "hwdefs.h"
|
---|
19 | #include "vsdd.h"
|
---|
20 | #include "memory.h"
|
---|
21 |
|
---|
22 | #define VREG(h,v) ((h<<10)|v)
|
---|
23 |
|
---|
24 | extern int cgtable[];
|
---|
25 | extern int cg_rows;
|
---|
26 |
|
---|
27 | struct octent v_obtab[16]; /* object control table */
|
---|
28 |
|
---|
29 | struct octent *v_curob; /* current v_obtab pointer */
|
---|
30 |
|
---|
31 | int v_nobj; /* current object number */
|
---|
32 | int v_obpri; /* current object priority */
|
---|
33 |
|
---|
34 | /* |
---|
35 | */
|
---|
36 |
|
---|
37 | /* initialized variables */
|
---|
38 |
|
---|
39 | int vr_data[] = {
|
---|
40 |
|
---|
41 | 0x825B, /* R0 -- Mode word 0 */
|
---|
42 | 0xC474, /* R1 -- Mode word 1 */
|
---|
43 | 0x0006, /* R2 -- Register window base, Control flags */
|
---|
44 | 0x0100, /* R3 -- Data window base, X limit (0x200000) */
|
---|
45 | 0x0000, /* R4 -- Data length mask (128K) */
|
---|
46 | 0x0000, /* R5 -- Data segment base (0x000000) */
|
---|
47 | 0x0001, /* R6 -- Priority access count (1) */
|
---|
48 | 0x0040, /* R7 -- Object Descriptor Table base (0x200080) */
|
---|
49 | 0x0080, /* R8 -- Access Table base (0x200100) */
|
---|
50 | 0x0010, /* R9 -- Color Lookup Table base (0x200020) */
|
---|
51 | 0x00FF, /* R10 -- Character Generator bases (0x21E000) */
|
---|
52 | 0x0000, /* R11 -- Access Table address counter */
|
---|
53 |
|
---|
54 | #if FASTCHIP
|
---|
55 | VREG( 3, 8), /* R12 -- HC0 (HSYNC width) VC0 (VSYNC width) */
|
---|
56 | VREG( 5, 10), /* R13 -- HC1 (AHZ start) VC1 (AVZ start) */
|
---|
57 | VREG(37, 360), /* R14 -- HC2 (AHZ stop) VC2 (AVZ stop) */
|
---|
58 | VREG(40, 362) /* R15 -- HC3 (HOR sweep) VC3 (VRT sweep) */
|
---|
59 | #else
|
---|
60 | VREG( 3, 8), /* R12 -- HC0 (HSYNC width) VC0 (VSYNC width) */
|
---|
61 | VREG( 6, 10), /* R13 -- HC1 (AHZ start) VC1 (AVZ start) */
|
---|
62 | VREG(38, 360), /* R14 -- HC2 (AHZ stop) VC2 (AVZ stop) */
|
---|
63 | VREG(43, 361) /* R15 -- HC3 (HOR sweep) VC3 (VRT sweep) */
|
---|
64 | #endif
|
---|
65 | };
|
---|
66 |
|
---|
67 | /* |
---|
68 | */
|
---|
69 |
|
---|
70 | /*
|
---|
71 | =============================================================================
|
---|
72 | VHinit() -- initialize the VSDD
|
---|
73 | =============================================================================
|
---|
74 | */
|
---|
75 |
|
---|
76 | VHinit()
|
---|
77 | {
|
---|
78 |
|
---|
79 | /* select VSDD RAM bank 0 so we can access the control tables */
|
---|
80 |
|
---|
81 | vbank(0);
|
---|
82 |
|
---|
83 | /* set the video register values */
|
---|
84 |
|
---|
85 | memcpyw(v_regs, vr_data, 16);
|
---|
86 |
|
---|
87 | /* clear the access table to turn off all objects */
|
---|
88 |
|
---|
89 | memsetw(v_actab, 0xFFFF, 350);
|
---|
90 |
|
---|
91 | /* clear the object table */
|
---|
92 |
|
---|
93 | memsetw(v_odtab, 0, 64);
|
---|
94 |
|
---|
95 | /* move the character generator table to VSDD RAM */
|
---|
96 |
|
---|
97 | memsetw(v_cgtab, 0, 4096);
|
---|
98 | memcpyw(v_cgtab, cgtable, 256 * cg_rows);
|
---|
99 | }
|
---|