-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path212lin.asm
139 lines (105 loc) · 2.66 KB
/
212lin.asm
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
include macros.inc
; From tiles.as
extrn tiles
extrn colors
; From screen.as
extrn screen
NUM_TILES equ 20 ; 16 hex digits + 4 graphics
; VRAM tables for the V9938/V9958 GRAPHIC 3 mode
TAB_NAME equ 01800h ; Pattern name table
TAB_COLOR equ 02000h ; Color table
TAB_GENERATOR equ 00000h ; Pattern generator table
; ###################
; ## PROGRAM START ##
; ###################
start: di
; Save a pointer to the original interrupt handler
ld hl,(00038h+1)
ld (oldint),hl
; Install the new interrupt handler
ld hl,vblank
ld (00038h+1),hl
SET212LINES
SPRITESOFF
DISABLEHBLANK
ENABLEVBLANK
; Set the border color to something easy to see
ld a,7 ; Cyan
ld (RG0SAV+7),a
VDP 7
; Change to GRAPHIC 3 mode
call setgraphic3
; Set the start addresses of VRAM tables
ld a,000000110b ; Pattern name table in 01800h
VDP 2
ld a,010011111b ; Color table in 02000h
; 010000000b = Start at 02000h
; 000011111b = Use one tileset
VDP 3
xor a
VDP 10
xor a ; Pattern generator table in 00000h
VDP 4
; Copy the patterns (tiles) to VRAM
RAM2VRAM8 tiles,TAB_GENERATOR,NUM_TILES*8
RAM2VRAM8 colors,TAB_COLOR,NUM_TILES*8
; Copy the screen buffer to VRAM
RAM2VRAM16 screen,TAB_NAME,1024
ei
loop: jr loop
; ###############
; ## FUNCTIONS ##
; ###############
; Change to GRAPHIC 3 mode (SCREEN 4 in MSX-BASIC)
; Modifies: A
; Note: Interrupts must be disabled
setgraphic3: ld a,(RG0SAV+0)
and 011110001b
or 000000100b
ld (RG0SAV+0),a ; R#0 = ????010?b
VDP 0
ld a,(RG0SAV+1)
and 011100111b
ld (RG0SAV+1),a ; R#1 = ???00???b
VDP 1
ret
; Set VRAM address for read/write (only low 64KB)
; Input: DE = VRAM address (bits A0-A15)
; Modifies: A
; Note: Interrupts must be disabled
setvramaddr_w: ld a,d
rlca
rlca
and 000000011b
VDP 14 ; Send bits A16-A14 to VDP R#14
ld a,e
out (vdpport1),a ; Send bits A7-A0 to VDP (low 16KB)
ld a,d
and 000111111b
or 001000000b
out (vdpport1),a ; Send bits A13-A8 to VDP, for writing
ret
; ##########################
; ## INTERRUPT HANDLER(S) ##
; ##########################
vblank: ; Check whether the VDP generated the interrupt
RDVDP 0
and 010000000b
jr nz,vblank.2
; Not a VDP interrupt, ignore it
ei
ret
vblank.2:
; Increase the VDP's vertical scroll register
ld a,(RG8SAV+23)
inc a
ld (RG8SAV+23),a
VDP 23
; Re-enable interrupts and return to the main loop
ei
ret
; ###############
; ## VARIABLES ##
; ###############
oldint: defw 0 ; Pointer to the original interrupt handler