-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathboot.asm
388 lines (346 loc) · 7.37 KB
/
boot.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
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
;--------------------------------------------------------------------------
; Simple test program for Sys9080 project https://github.com/zpekic/sys9080
; (c) [email protected] - 2017, 2018
;--------------------------------------------------------------------------
;include ./sys9080.asm
ORG 0x0000 ;-----RST0 == RESET
DI
JMP Boot
ORG 0x0008 ;-----RST1 (TRACE)
OUT PORT_VGATRACE
RET
ORG 0x0010 ;-----RST2 (ACIA1)
DI
JMP Acia1ToPort
ORG 0x0018 ;-----RST3 (no device, execution trap)
DI
CALL DumpState
JMP WaitForSS
ORG 0x0020 ;-----RST4 (no device, execution trap)
DI
CALL DumpState
JMP WaitForSS
ORG 0x0028 ;-----RST5 (no device, execution trap)
DI
CALL DumpState
JMP WaitForSS
ORG 0x0030 ;-----RST6 (BTN1, execution trap)
DI
JMP DumpState
JMP WaitForSS
ORG 0x0038 ;-----RST7 (BTN0, execution trap)
DI
CALL DumpState
WaitForSS: PUSH PSW
CheckSW7: IN PORT0
RAL ;faster than ANI MASK_SW7
JNC CheckSW7
POP PSW
EI
RET
DumpState: XTHL ;PC from stack is now in HL
SHLD Temp_PC ;store away (making this code non re-entrant)
XTHL ;restore PC to stack
PUSH H
PUSH D
PUSH B
PUSH PSW
PUSH H
PUSH D
PUSH B
PUSH PSW
LXI H, TextAF
CALL TxStringAtHL
XTHL
CALL TxValueOfHL
POP H
LXI H, TextBC
CALL TxStringAtHL
XTHL
CALL TxValueOfHL
CALL BytesAtHL
POP H
LXI H, TextDE
CALL TxStringAtHL
XTHL
CALL TxValueOfHL
CALL BytesAtHL
POP H
LXI H, TextHL
CALL TxStringAtHL
XTHL
CALL TxValueOfHL
CALL BytesAtHL
POP H
LXI H, TextPC
CALL TxStringAtHL
LHLD Temp_PC
CALL TxValueOfHL
CALL BytesAtHL
LXI H, TextSP
CALL TxStringAtHL
LXI D, 0xFFFF ;start searching for stack position from top of memory down
LHLD Temp_PC
XCHG ;HL = 0xFFFF, DE = PC to search for
SearchForPC:MOV A, D
CMP M
JNZ NotFound
DCX H
MOV A, E
CMP M
JNZ SearchForPC
CALL TxValueOfHL
CALL BytesAtHL
MVI A, CR
CALL SendChar
MVI A, LF
CALL SendChar
JMP RestoreRegs
NotFound: DCX H
JMP SearchForPC
RestoreRegs: POP PSW
POP B
POP D
POP H
EI
RET
;-------------------------------------------
Acia0toPort: PUSH PSW
IN ACIA0_STATUS
OUT PORT0
IN ACIA0_DATA
OUT PORT1
POP PSW
EI
RET
Acia1toPort: PUSH PSW
IN ACIA1_STATUS
OUT PORT0
IN ACIA1_DATA
OUT PORT1
POP PSW
EI
RET
OnByteReceived: PUSH PSW
IN PORT1 ;hooked up to 4 push buttons
ANI MASK_BUTTON1
JZ ProcessByte
PUSH H
PUSH D
PUSH B
IN ACIA1_STATUS
MOV H, A
IN ACIA1_DATA
MOV L, A
PUSH H
IN ACIA0_STATUS
MOV H, A
IN ACIA0_DATA
MOV L, A
PUSH H
LXI H, TextACIA0
CALL TxStringAtHL
POP H
CALL TxValueOfHL
LXI H, TextACIA1
CALL TxStringAtHL
POP H
CALL TxValueOfHL
POP B
POP D
POP H
ProcessByte: POP PSW
EI
RET
;-------------------------------------------
Boot: LXI H, 0000H
;DCX H
SPHL
CALL InitAcias
CALL TxInlineString
TextGreet1: DB CR, LF, "*** Sys9080 is ready. RAM @ ", 0x00
IN PORT0
ANI 00000100B
JNZ TestRam ;if using "fast" clock then check RAM, otherwise skip
CALL TxInlineString
DB "(skipped)", 0x00
JMP TextPort
TestRam: CALL GetLowestRam
MOV A, L
OUT PORT0
MOV A, H
OUT PORT1 ;display on LEDs
CALL TxValueOfHL ;display on console
TextPort: CALL TxInlineString
DB " Switches= ", 0x00
IN PORT0 ;big slider switches
MOV L, A
IN PORT2 ;dip switches B4...B1 A4..A1
MOV H, A
CALL TxValueOfHL
CALL TxInlineString
TextVdp: DB " Vdp rows/cols= ", 0x00
LHLD VdpCols
CALL TxValueOfHL
CALL TxInlineString
TextGreet2: DB " ***", CR, LF, " (BTN0/1 to dump CPU/ACIAs state)", CR, LF, 0x00
MVI A, CS
OUT PORT_VGATRACE
EI
; HLT ;interrupt is needed to go further
;-------------------------------------------------------------------------
JMP AltMon ;enter monitor program
;-------------------------------------------------------------------------
InitAcias: MVI a,3 ;reset 6850 uart
OUT ACIA0_STATUS
OUT ACIA1_STATUS ;2nd 2SIO port as well
IN PORT2 ;slide switches contain ACIA mode
OUT PORT2 ;reflect on LEDs
MVI a,10h ;8N2, baudrate clock / 1 (== 38400)
;NOP
;NOP
OUT ACIA0_STATUS
OUT ACIA1_STATUS ;2nd 2SIO port as well
RET
;PrintAsciiSet: LXI B, 0D20H ;set C to ASCII space
;SendNextChar: MOV A, C
; CALL SendChar ;send char
; CPI "~" ;end of printable chars reached?
; JZ NextLine
; INR C
; JMP SendNextChar
;NextLine: MOV A, B
; CALL SendChar ;send char
; XRI 00000110B ;cheap trick to convert newline to linefeed
; CALL SendChar ;send char
; RET
DumpTrace: PUSH H
PUSH D
PUSH B
PUSH PSW
CALL TxInlineString
DB "AF=", 0x00
XTHL
CALL TxValueOfHL
XTHL
INX SP
INX SP
CALL TxInlineString
DB " BC=", 0x00
XTHL
CALL TxValueOfHL
XTHL
INX SP
INX SP
CALL TxInlineString
DB " DE=", 0x00
XTHL
CALL TxValueOfHL
XTHL
INX SP
INX SP
CALL TxInlineString
DB " HL=", 0x00
XTHL
CALL TxValueOfHL
XTHL
INX SP
INX SP
CALL TxInlineString
DB " PC=", 0x00
XTHL
CALL TxValueOfHL
XTHL
CALL TxInlineString
DB CR, LF, 0x00
DCX SP
DCX SP
DCX SP
DCX SP
DCX SP
DCX SP
DCX SP
DCX SP
POP PSW
POP B
POP D
POP H
;OUT CPUTRACEON
EI
RET
TxStringAtHL: MOV A, M
ANA A
RZ
CALL SendChar
INX H
JMP TxStringAtHL
TxInlineString: POP H ;Return address was pointing at string start
TxInlineChar: MOV A, M
ANA A
JZ Return
CALL SendChar
INX H
JMP TxInlineChar
Return: INX H ;go beyond terminating null byte
PCHL
BytesAtHL: MVI C, 0x10 ;dump 16 bytes at (HL)
NextByteAtHL: MVI A, " "
CALL SendChar
MOV A, M
CALL TxValueOfA
DCR C
RZ ;return if reached 0
INX H
JMP NextByteAtHL
TxValueOfHL: MOV A, H
CALL TxValueOfA
MOV A, L
TxValueOfA: PUSH PSW
RRC
RRC
RRC
RRC
CALL TxHexDig
POP PSW
TxHexDig: ANI 0x0F
ADI '0'
CPI '9' + 1
JM TxHexDigOut
ADI 0x07
TxHexDigOut: CALL SendChar
RET
SendChar: PUSH PSW
OUT PORT_VGATRACE
CheckIfReady: IN ACIA0_STATUS
ANI MASK_READY
JZ CheckIfReady
POP PSW
OUT ACIA0_DATA
RET
GetLowestRam: LXI H, 0xFFFF ;assume RAM is located near top of address space
NextAddress: MOV A, M
CMA ;flip all bits
MOV M, A
CMP M
JNZ LowestFound
CMA
MOV M, A
MOV A, L
OUT PORT0 ;display address being examined
MOV A, H
OUT PORT1
ORA L
RZ ;Bail if HL = 0
DCX H
JMP NextAddress
LowestFound: INX H
RET
TextAF: DB CR, LF, " AF=", 0x00
TextBC: DB CR, LF, " BC=", 0x00
TextDE: DB CR, LF, " DE=", 0x00
TextHL: DB CR, LF, " HL=", 0x00
TextPC: DB CR, LF, " PC=", 0x00
TextSP: DB CR, LF, " SP=", 0x00
TextACIA0: DB CR, LF, " ACIA0=", 0x00
TextACIA1: DB CR, LF, " ACIA1=", 0x00
End: DB 0x00 ;Cheap trick to see last used address