zasm: add RST instruction

This commit is contained in:
Virgil Dupras 2019-11-12 14:07:45 -05:00
parent 518df7a05e
commit 4de2ce3ceb
6 changed files with 44 additions and 10 deletions

View File

@ -58,13 +58,14 @@
.equ I_RRA 0x33 .equ I_RRA 0x33
.equ I_RRC 0x34 .equ I_RRC 0x34
.equ I_RRCA 0x35 .equ I_RRCA 0x35
.equ I_SBC 0x36 .equ I_RST 0x36
.equ I_SCF 0x37 .equ I_SBC 0x37
.equ I_SET 0x38 .equ I_SCF 0x38
.equ I_SLA 0x39 .equ I_SET 0x39
.equ I_SRL 0x3a .equ I_SLA 0x3a
.equ I_SUB 0x3b .equ I_SRL 0x3b
.equ I_XOR 0x3c .equ I_SUB 0x3c
.equ I_XOR 0x3d
; *** Variables *** ; *** Variables ***
; Args are 3 bytes: argspec, then values of numerical constants (when that's ; Args are 3 bytes: argspec, then values of numerical constants (when that's
@ -555,6 +556,26 @@ handleLDrr:
ld c, 1 ld c, 1
ret ret
handleRST:
ld a, (INS_CURARG1+1)
; verify that A is either 0x08, 0x10, 0x18, 0x20, 0x28, 0x30 or 0x38.
; Good news: they're all multiples of 8.
; to verify that we're within range, we to 8-bit rotation. If any of
; the first 3 bytes are set (thus not a multiple of 8), the cp 8
; later will yield NC because those bits will now be upwards.
rrca \ rrca \ rrca
cp 8
jr nc, .error
; good, we have a proper arg. Now let's get those 3 bits in position
rlca \ rlca \ rlca
or 0b11000111
ld (INS_UPCODE), a
ld c, 1
ret
.error:
ld c, 0
ret
; Compute the upcode for argspec row at (DE) and arguments in curArg{1,2} and ; Compute the upcode for argspec row at (DE) and arguments in curArg{1,2} and
; writes the resulting upcode to IO. ; writes the resulting upcode to IO.
; A is zero, with Z set, on success. A is non-zero, with Z unset, on error. ; A is zero, with Z set, on success. A is non-zero, with Z unset, on error.
@ -1045,6 +1066,7 @@ instrNames:
.db "RRA", 0 .db "RRA", 0
.db "RRC", 0 .db "RRC", 0
.db "RRCA" .db "RRCA"
.db "RST", 0
.db "SBC", 0 .db "SBC", 0
.db "SCF", 0 .db "SCF", 0
.db "SET", 0 .db "SET", 0
@ -1214,6 +1236,7 @@ instrTBlRET:
.db I_RRA, 0, 0, 0, 0x1f , 0 ; RRA .db I_RRA, 0, 0, 0, 0x1f , 0 ; RRA
.db I_RRC, 0xb, 0,0x40, 0xcb, 0b00001000 ; RRC r .db I_RRC, 0xb, 0,0x40, 0xcb, 0b00001000 ; RRC r
.db I_RRCA,0, 0, 0, 0x0f , 0 ; RRCA .db I_RRCA,0, 0, 0, 0x0f , 0 ; RRCA
.db I_RST, 'n', 0, 0x20 \ .dw handleRST ; RST p
.db I_SBC, 'A', 'l', 0, 0x9e , 0 ; SBC A, (HL) .db I_SBC, 'A', 'l', 0, 0x9e , 0 ; SBC A, (HL)
.db I_SBC, 'A', 0xb, 0, 0b10011000 , 0 ; SBC A, r .db I_SBC, 'A', 0xb, 0, 0b10011000 , 0 ; SBC A, r
.db I_SBC,'h',0x3,0x44, 0xed, 0b01000010 ; SBC HL, ss .db I_SBC,'h',0x3,0x44, 0xed, 0b01000010 ; SBC HL, ss

Binary file not shown.

Binary file not shown.

View File

@ -1797,6 +1797,14 @@ RRC H
RRC L RRC L
RRC A RRC A
RRCA RRCA
RST 0
RST 8
RST 16
RST 24
RST 32
RST 40
RST 48
RST 56
SBC A, (HL) SBC A, (HL)
SBC A, B SBC A, B
SBC A, C SBC A, C

View File

@ -84,9 +84,10 @@ def getDbLines(fp, tblname):
line = fp.readline() line = fp.readline()
while line: while line:
line = cleanupLine(line) line = cleanupLine(line)
if line: if line == '.db 0xff':
if not line.startswith('.db'):
break break
# skip index labels lines
if line.startswith('.db'):
result.append([s.strip() for s in line[4:].split(',')]) result.append([s.strip() for s in line[4:].split(',')])
line = fp.readline() line = fp.readline()
return result return result
@ -151,6 +152,8 @@ def main():
args1 = eargs(args1) args1 = eargs(args1)
if n == 'IM': if n == 'IM':
args1 = [0, 1, 2] args1 = [0, 1, 2]
if n == 'RST':
args1 = [i*8 for i in range(8)]
if args1: if args1:
for arg1 in args1: for arg1 in args1:
args2 = genargs(a2) args2 = genargs(a2)