1
0
mirror of https://github.com/pfusik/xasm.git synced 2025-01-18 08:31:07 +00:00
xasm/xasm.asm

1313 lines
19 KiB
NASM
Raw Normal View History

1998-05-10 21:14:44 +02:00
; X-Assembler
IDEAL
P386
MODEL TINY
CODESEG
ORG 100h
start:
1998-05-22 18:27:22 +02:00
db 4096 dup(0) ;for packing
1998-05-10 21:14:44 +02:00
1998-05-22 18:27:22 +02:00
l_icl = 1000
1998-05-10 21:14:44 +02:00
l_org = 1000*2
1998-05-22 18:27:22 +02:00
l_lab = 50000
STRUC com
nam db ?,?,?
cod db ?
vec dw ?
ENDS
STRUC icl
prev dw ?
handle dw ?
line dd ?
nam db ?
ENDS
STRUC lab
prev dw ?
val dw ?
nam db ?
ENDS
1998-05-10 21:14:44 +02:00
;<3B><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
eol equ 13,10
eot equ 13,10,'$'
MACRO lda _rg
xchg ax, _rg ; in meaning 'mov ax, _rg', but xchg is shorter
ENDM
MACRO sta _rg
xchg _rg, ax ; in meaning 'mov _rg, ax', but xchg is shorter
ENDM
MACRO dos _func
IFNB <_func>
IF _func and 0ff00h
mov ax, _func
ELSE
mov ah, _func
ENDIF
ENDIF
int 21h
ENDM
MACRO file _func, _errtx
mov bp, offset _errtx
IF _func and 0ff00h
mov ax, _func
ELSE
mov ah, _func
ENDIF
call xdisk
ENDM
MACRO print _text
IFNB <_text>
mov dx, offset _text
ENDIF
dos 9
ENDM
MACRO dtext _text
db '&_text'
ENDM
MACRO cmd _oper
_tp SUBSTR <_oper>, 1, 3
dtext %_tp
_tp SUBSTR <_oper>, 4, 2
_tp CATSTR <0>, &_tp, <h>
db &_tp
_tp SUBSTR <_oper>, 6
dw _tp
ENDM
;<3B><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
print hello
mov di, 81h
movzx cx, [di-1]
jcxz usg
mov al, ' '
repe scasb
je usg
dec di
inc cx
mov [fnad], di
mov al, '?'
repne scasb
1998-05-22 18:27:22 +02:00
jne begin
1998-05-10 21:14:44 +02:00
usg: print usgtxt
dos 4c01h
1998-05-22 18:27:22 +02:00
begin: mov [origin], 0
call ldname
opfile: mov bx, offset (icl).nam
add bx, [iclen]
mov si, di
srex2: dec si
1998-05-10 21:14:44 +02:00
cmp [byte si], '\'
1998-05-22 18:27:22 +02:00
je adex2
1998-05-10 21:14:44 +02:00
cmp [byte si], '.'
1998-05-22 18:27:22 +02:00
je lvex2
cmp si, bx
ja srex2
adex2: mov [byte di-1], '.'
mov ax, 'sa'
1998-05-10 21:14:44 +02:00
stosw
1998-05-22 18:27:22 +02:00
mov ax, 'x'
1998-05-10 21:14:44 +02:00
stosw
1998-05-22 18:27:22 +02:00
lvex2: call fopen
1998-05-10 21:14:44 +02:00
main: test [eoflag], 0ffh
jnz filend
1998-05-22 18:27:22 +02:00
mov bx, [iclen]
mov bx, [(icl bx).prev]
inc [(icl bx).line]
1998-05-10 21:14:44 +02:00
inc [lines]
mov di, offset line-1
gline1: cmp di, offset line+255
jnb linlon
mov cx, 1
lea dx, [di+1]
push dx
1998-05-22 18:27:22 +02:00
call fread
1998-05-10 21:14:44 +02:00
pop di
jz eof
cmp [byte di], 0ah
jne gline1
jmp syntax
eof: inc [eoflag]
1998-05-21 15:50:52 +02:00
mov [word di], 0a0dh
1998-05-10 21:14:44 +02:00
syntax: mov si, offset line
mov al, [si]
cmp al, 0dh
je main
cmp al, '*'
je main
cmp al, ';'
je main
cmp al, '|'
je main
mov [labvec], 0
cmp al, ' '
je s_cmd
cmp al, 9
je s_cmd
call rlabel
jc asilab
cmp bx, [p1laben]
jnb ltwice
mov [pslaben], bx
1998-05-22 18:27:22 +02:00
inc [labvec] ;1
1998-05-10 21:14:44 +02:00
jmp s_cmd
ltwice: mov ax, offset e_twice
jmp panica
asilab: push si
mov si, offset tlabel
mov di, [laben]
scasw
mov [labvec], di
mov ax, [origin]
stosw
mov ax, di
add ax, dx
cmp ax, offset t_lab+l_lab
jnb tmlab
mov cx, dx
rep movsb
mov ax, di
xchg ax, [laben]
stosw
pop si
1998-05-21 15:50:52 +02:00
s_cmd: lodsb
cmp al, ' '
je s_cmd
cmp al, 9
je s_cmd
cmp al, 0dh
jne s_cmd1
cmp [byte high labvec], 0
je main
jmp uneol
s_cmd1: dec si
1998-05-10 21:14:44 +02:00
lodsw
1998-05-22 18:27:22 +02:00
and ax, 0dfdfh
1998-05-21 15:50:52 +02:00
sta dx
1998-05-10 21:14:44 +02:00
lodsb
and al, 0dfh
mov di, offset comtab
1998-05-22 18:27:22 +02:00
mov bx, 64*size com
1998-05-10 21:14:44 +02:00
sfcmd1: mov ah, al
mov cx, dx
1998-05-22 18:27:22 +02:00
sub ah, [(com di+bx+2).nam]
sbb ch, [(com di+bx+1).nam]
sbb cl, [(com di+bx).nam]
1998-05-10 21:14:44 +02:00
jb sfcmd3
or ah, ch
or ah, cl
jnz sfcmd2
1998-05-22 18:27:22 +02:00
mov al, [(com di+bx).cod]
1998-05-10 21:14:44 +02:00
mov [cod], al
1998-05-22 18:27:22 +02:00
call [(com di+bx).vec]
1998-05-21 15:50:52 +02:00
call linend
jmp main
1998-05-10 21:14:44 +02:00
sfcmd2: add di, bx
cmp di, offset comend
jb sfcmd3
sub di, bx
sfcmd3: shr bx, 1
cmp bl, 3
ja sfcmd1
mov bl, 0
je sfcmd1
mov ax, offset e_inst
jmp panica
filend: mov [eoflag], 0
cmp [pass], 1
jnb noforg
call putorg
1998-05-22 18:27:22 +02:00
noforg: call fclose
cmp bx, offset t_icl
ja main
cmp [pass], 1
jnb fin
1998-05-10 21:14:44 +02:00
inc [pass]
1998-05-22 18:27:22 +02:00
call ldname
mov si, di
srex1: dec si
cmp [byte si], '\'
je adex1
cmp [byte si], '.'
je chex1
cmp si, offset (icl t_icl).nam
ja srex1
jmp adex1
chex1: mov di, si
adex1: mov [byte di-1], '.'
mov [dword di], 'moc'
mov dx, offset (icl t_icl).nam
xor cx, cx
file 3ch, e_creat
mov [ohand], ax
mov ax, 0ffffh
call putwor
mov [orgvec], offset t_org
xor ax, ax
call pheadr
mov ax, [laben]
mov [p1laben], ax
inc [pslaben] ;0
jmp begin
1998-05-10 21:14:44 +02:00
1998-05-22 18:27:22 +02:00
fin: mov bx, [ohand]
1998-05-10 21:14:44 +02:00
file 3eh, e_writ
mov eax, [lines]
shr eax, 1
call pridec
print lintxt
mov eax, [bytes]
call pridec
print byttxt
dos 4c00h
tmlab: mov ax, offset e_tlab
jmp panica
linlon: mov ax, offset e_long
1998-05-22 18:27:22 +02:00
; Obsluga bledow
1998-05-10 21:14:44 +02:00
panica: mov [errad], ax
panic: cmp [errad], offset lislin
jb panifn
mov si, offset line-1
prilin: inc si
mov dl, [si]
dos 2
cmp [byte si], 0ah
jne prilin
1998-05-22 18:27:22 +02:00
panifn: mov bx, [iclen]
cmp bx, offset t_icl
jna eronly
mov di, [(icl bx).prev]
push di
lea dx, [(icl di).nam]
mov [byte bx-1], ' '
mov [word bx], '$('
1998-05-10 21:14:44 +02:00
print
1998-05-22 18:27:22 +02:00
pop bx
mov eax, [(icl bx).line]
1998-05-10 21:14:44 +02:00
call pridec
1998-05-22 18:27:22 +02:00
mov dl, ')'
dos 2
eronly: print errtxt
1998-05-10 21:14:44 +02:00
mov dx, [errad]
print
dos 4c01h
1998-05-22 18:27:22 +02:00
; I/O
1998-05-10 21:14:44 +02:00
xdisk: mov [errad], bp
dos
jc panic
ret
1998-05-22 18:27:22 +02:00
fopen: mov ax, offset e_icl
cmp di, offset t_icl+l_icl-2
jnb panica
mov bx, [iclen]
mov [(icl bx).line], 0
lea dx, [(icl bx).nam]
mov [(icl di).prev], bx
mov [iclen], di
file 3d00h, e_open
mov bx, [iclen]
mov bx, [(icl bx).prev]
mov [(icl bx).handle], ax
ret
fread: mov ah, 3fh
freacl: mov bx, [iclen]
mov bx, [(icl bx).prev]
mov bx, [(icl bx).handle]
mov bp, offset e_read
call xdisk
test ax, ax
ret
fclose: mov ah, 3eh
call freacl
mov bx, [iclen]
mov bx, [(icl bx).prev]
mov [iclen], bx
ret
1998-05-10 21:14:44 +02:00
putwor: push ax
call putbyt
pop ax
mov al, ah
putbyt: mov cx, 1
cmp [pass], cx
jb putx
mov [obyte], al
mov dx, offset obyte
mov bx, [ohand]
file 40h, e_writ
inc [bytes]
putx: ret
savwor: inc [origin]
inc [origin]
jmp putwor
savbyt: inc [origin]
jmp putbyt
1998-05-22 18:27:22 +02:00
; Przepisuje nazwe z linii komend
ldname: mov si, [fnad]
mov di, offset (icl t_icl).nam
ldnam1: lodsb
stosb
cmp al, 0dh
jne ldnam1
mov [byte di-1], 0
ret
1998-05-10 21:14:44 +02:00
; Wyswietla dziesietnie EAX
pridec: mov di, offset dectxt+10
mov ebx, 10
pride1: cdq
div ebx
add dl, '0'
dec di
mov [di], dl
test eax, eax
jnz pride1
mov dx, di
print
ret
1998-05-21 15:50:52 +02:00
; Pobiera znak (eol=error)
get: lodsb
cmp al, 0dh
je uneol
ret
uneol: mov ax, offset e_uneol
jmp panica
ilchar: mov ax, offset e_char
jmp panica
1998-05-10 21:14:44 +02:00
; Omija spacje i tabulatory
1998-05-21 15:50:52 +02:00
spaces: call get
1998-05-10 21:14:44 +02:00
cmp al, ' '
1998-05-21 15:50:52 +02:00
je space1
1998-05-10 21:14:44 +02:00
cmp al, 9
1998-05-21 15:50:52 +02:00
je space1
mov ax, offset e_spac
jmp panica
space1: call get
cmp al, ' '
je space1
cmp al, 9
je space1
1998-05-10 21:14:44 +02:00
dec si
rstret: ret
1998-05-22 18:27:22 +02:00
; Stwierdza blad, jesli nie spacja, tab lub eol
1998-05-21 15:50:52 +02:00
linend: lodsb
cmp al, 0dh
je rstret
cmp al, ' '
je rstret
cmp al, 9
je rstret
mov ax, offset e_xtra
jmp panica
1998-05-22 18:27:22 +02:00
; Czyta nazwe pliku
rfname: call spaces
mov di, offset (icl).nam
add di, [iclen]
1998-05-10 21:14:44 +02:00
; Czyta lancuch i zapisuje do [di]
1998-05-21 15:50:52 +02:00
rstr: call get
1998-05-10 21:14:44 +02:00
cmp al, "'"
jne strer
1998-05-22 18:27:22 +02:00
mov dx, di
1998-05-21 15:50:52 +02:00
rstr1: call get
1998-05-10 21:14:44 +02:00
stosb
cmp al, "'"
jne rstr1
lodsb
cmp al, "'"
je rstr1
dec si
1998-05-22 18:27:22 +02:00
mov [byte di-1], 0
lea cx, [di-1]
sub cx, dx
1998-05-10 21:14:44 +02:00
jnz rstret
strer: mov ax, offset e_str
jmp panica
; Przepisuje etykiete do tlabel, szuka w t_lab
; na wyjsciu: dx-dlugosc etykiety
; C=0: znaleziona, bx=adres wpisu
; C=1: nie ma jej
rlabel: mov di, offset tlabel
mov [byte di], 0
ldlab1: lodsb
cmp al, '0'
jb sflab0
cmp al, '9'
jbe ldlab2
cmp al, 'A'
jb sflab0
cmp al, 'Z'
jbe ldlab2
cmp al, '_'
je ldlab2
cmp al, 'a'
jb sflab0
cmp al, 'z'
ja sflab0
add al, 'A'-'a'
ldlab2: stosb
jmp ldlab1
sflab0: mov dx, di
mov di, offset tlabel
cmp [byte di], 'A'
jb ilchar
sub dx, di
dec si
push si
mov bx, [laben]
1998-05-22 18:27:22 +02:00
sflab1: cmp bx, offset (lab t_lab).nam
1998-05-10 21:14:44 +02:00
jb sflabn
lea cx, [bx-4]
1998-05-22 18:27:22 +02:00
mov bx, [(lab bx).prev]
1998-05-10 21:14:44 +02:00
sub cx, bx
cmp cx, dx
jne sflab1
1998-05-22 18:27:22 +02:00
lea si, [(lab bx).nam]
1998-05-10 21:14:44 +02:00
mov di, offset tlabel
repe cmpsb
jne sflab1
clc
sflabn: pop si
ret
getval: call spaces
; Czyta wyrazenie i zwraca jego wartosc w [val] (C=1 wartosc nieokreslona)
value: mov [val], 0
mov [undef], 0
lodsb
cmp al, '-'
je valuem
dec si
mov al, '+'
valuem: mov [oper], al
xor dx, dx
mov ch, -1
1998-05-21 15:50:52 +02:00
call get
1998-05-10 21:14:44 +02:00
cmp al, '*'
je valorg
cmp al, "'"
je valchr
1998-05-21 15:50:52 +02:00
cmp al, '^'
je valreg
1998-05-10 21:14:44 +02:00
mov bx, 16
cmp al, '$'
je rdnum3
mov bl, 2
cmp al, '%'
je rdnum3
mov bl, 10
cmp al, '0'
jb ilchar
cmp al, '9'
ja vlabel
rdnum1: cmp al, 'A'
jb rdnum2
and al, 0dfh
cmp al, 'A'
jb value0
add al, '0'+10-'A'
rdnum2: sub al, '0'
cmp al, bl
jnb value0
movzx cx, al
mov ax, dx
mul bx
add ax, cx
adc dx, dx
jnz toobig
sta dx
rdnum3: lodsb
jmp rdnum1
vlabel: dec si
call rlabel
jnc vlabkn
cmp [pass], 1
jb vlabun
jmp unknow
1998-05-22 18:27:22 +02:00
vlabkn: mov dx, [(lab bx).val]
1998-05-10 21:14:44 +02:00
cmp bx, [pslaben]
jbe value1
vlabun: mov [undef], 0ffh
jmp value1
1998-05-21 15:50:52 +02:00
valchr: call get
1998-05-10 21:14:44 +02:00
cmp al, "'"
jne valch1
lodsb
cmp al, "'"
jne strer
valch1: movzx dx, al
lodsb
cmp al, "'"
jne strer
cmp [byte si], '*'
jne value1
inc si
xor dl, 80h
jmp value1
1998-05-21 15:50:52 +02:00
valreg: call get
cmp al, '4'
ja ilchar
sub al, '0'
jb ilchar
add al, 0d0h
mov ah, al
call get
cmp al, 'A'
jb valre1
and al, 0dfh
cmp al, 'A'
jb valre1
add al, '0'+10-'A'
valre1: sub al, '0'
cmp al, 0fh
ja ilchar
cmp ah, 0d1h
jne valre2
sub ax, 0f0h
valre2: sta dx
jmp value1
1998-05-10 21:14:44 +02:00
valorg: mov dx, [origin]
jmp value1
value0: dec si
test ch, ch
jnz ilchar
value1: cmp [oper], '-'
jne value2
neg dx
value2: add [val], dx
lodsb
cmp al, '+'
je valuem
cmp al, '-'
je valuem
dec si
add [undef], 1
ret
toobig: mov ax, offset e_nbig
jmp panica
; Pobiera operand rozkazu i rozpoznaje tryb adresowania
getadr: call spaces
lodsb
xor dl, dl
cmp al, '@'
je getadx
1998-05-22 18:27:22 +02:00
push 0ffh
1998-05-10 21:14:44 +02:00
inc dx
cmp al, '#'
je getad1
mov dl, 10
cmp al, '<'
je getad1
inc dx
cmp al, '>'
je getad1
mov dl, 8
cmp al, '('
je getad1
dec si
1998-05-22 18:27:22 +02:00
lodsw
and al, 0dfh
xor dx, dx
cmp ax, ':Z'
je getad0
dec dx
cmp ax, ':A'
je getad0
dec si
dec si
jmp getad9
getad0: pop ax
push dx
getad9: mov dl, 2
1998-05-10 21:14:44 +02:00
getad1: mov [amod], dl
call value
mov al, [byte high val]
jnc getad2
sbb al, al
1998-05-22 18:27:22 +02:00
getad2: pop dx
and al, dl
or al, dh
mov dl, [amod]
1998-05-10 21:14:44 +02:00
cmp dl, 1
je getart
cmp dl, 10
jnb getalh
cmp dl, 8
je getaid
cmp al, 1
adc dl, 0
lodsw
and ah, 0dfh
cmp ax, 'X,'
je getaxi
cmp ax, 'Y,'
je getayi
dec si
dec si
jmp getadx
getalh: mov bx, offset val
je getal1
inc bx
getal1: movzx ax, [bx]
mov [val], ax
mov dl, 1
jmp getadx
getaid: lodsb
cmp al, ','
je getaix
cmp al, ')'
jne mbrack
lodsw
and ah, 0dfh
cmp ax, 'Y,'
je getaiy
mov dl, 10
dec si
dec si
jmp getadx
getaix: lodsw
and al, 0dfh
cmp ax, ')X'
je getart
jmp ilchar
getayi: inc dx
inc dx
getaxi: inc dx
getaiy: inc dx
getadx: mov [amod], dl
getart: mov al, [amod]
putret: ret
p_imp = savbyt
1998-05-21 15:50:52 +02:00
p_ads: call getadr
mov al, [cod]
call savbyt
mov al, 60h
cmp [cod], 18h
je p_as1
mov al, 0e0h
p_as1: mov [cod], al
mov al, [amod]
jmp p_ac1
1998-05-10 21:14:44 +02:00
p_acc: call getadr
1998-05-21 15:50:52 +02:00
p_ac1: cmp al, 7
1998-05-10 21:14:44 +02:00
jne acc1
dec ax
mov [amod], al
acc1: mov bx, offset acctab
xlat
test al, al
jz ilamod
or al, [cod]
cmp al, 89h
jne putcmd
ilamod: mov ax, offset e_amod
jmp panica
p_srt: call getadr
cmp al, 6
jnb ilamod
cmp al, 1
je ilamod
mov bx, offset srttab
xlat
or al, [cod]
cmp al, 0c0h
je ilamod
cmp al, 0e0h
je ilamod
jmp putcmd
1998-05-22 18:27:22 +02:00
p_inw: call getadr
cmp al, 6
jnb ilamod
sub al, 2
jb ilamod
mov bx, offset inwtab
xlat
push ax
call putcmd
inc [val]
mov ax, 03d0h
test [amod], 1
jz p_iw1
dec ah
p_iw1: call savwor
pop ax
jmp putcmd
1998-05-10 21:14:44 +02:00
p_ldi: call getadr
cmp al, 1
jb ilamod
cmp al, 4
jb ldi1
and al, 0feh
xor al, [cod]
cmp al, 0a4h
jne ilamod
mov al, [amod]
ldi1: mov bx, offset lditab
xlat
putcod: or al, [cod]
putcmd: call savbyt
mov al, [amod]
mov bx, offset lentab
xlat
cmp al, 2
jb putret
mov ax, [val]
jne savwor
cmp [pass], 1
jb putcm1
test ah, ah
jnz toobig
putcm1: jmp savbyt
p_sti: call getadr
cmp al, 2
jb ilamod
cmp al, 3
jb cod8
je cod0
and al, 0feh
xor al, [cod]
cmp al, 80h
jne ilamod
or [amod], 1
mov al, 10h
jmp putcod
cod8: mov al, 8
jmp putcod
cod0: xor al, al
jmp putcod
p_cpi: call getadr
cmp al, 1
jb ilamod
cmp al, 4
jnb ilamod
cmp al, 2
jb cod0
je cod8
mov al, 4
jmp putcod
p_bra: call getadr
cmp [pass], 1
jb bra1
mov ax, [val]
sub ax, [origin]
add ax, 7eh
test ah, ah
jnz toofar
add al, 80h
mov [byte val], al
mov al, [cod]
bra1: call savbyt
mov al, [byte val]
jmp savbyt
toofar: mov ax, offset e_bra
jmp panica
p_jsr: call getadr
mov al, 20h
1998-05-21 15:50:52 +02:00
jmp p_abs
1998-05-10 21:14:44 +02:00
p_bit: call getadr
cmp al, 2
mov al, 2ch
je putcmd
cmp [amod], 3
jne ilamod
mov al, 24h
jmp putcmd
1998-05-21 15:50:52 +02:00
p_juc: call getadr
mov al, [cod]
mov ah, 3
call savwor
jmp p_jp1
1998-05-10 21:14:44 +02:00
p_jmp: call getadr
cmp al, 10
mov al, 6ch
je putcmd
1998-05-21 15:50:52 +02:00
p_jp1: mov al, 4ch
p_abs: and [amod], 0feh
1998-05-10 21:14:44 +02:00
cmp [amod], 2
jne ilamod
jmp putcmd
p_opt: call getval
jc unknow
mov ax, [val]
test ah, ah
jnz toobig
ret
p_equ: mov di, [labvec]
cmp di, 1
jb nolabl
je equret
mov [word di], 0
call getval
mov di, [labvec]
jc lbund
mov ax, [val]
stosw
equret: ret
lbund: cmp [pass], 1
jnb unknow
lea ax, [di-2]
mov [laben], ax
ret
nolabl: mov ax, offset e_label
jmp panica
p_org: call getval
jc unknow
1998-05-22 18:27:22 +02:00
p_org1: cmp [pass], 1
1998-05-10 21:14:44 +02:00
jnb org1
call putorg
stc
org1: mov ax, [val]
mov [origin], ax
jc pheart
pheadr: mov bx, [orgvec]
cmp ax, [bx]
je pheart
call putwor
mov bx, [orgvec]
mov ax, [bx]
dec ax
call putwor
pheart: add [orgvec], 2
ret
putorg: mov bx, [orgvec]
cmp bx, offset t_org+l_org-2
jnb tmorgs
mov ax, [origin]
mov [bx], ax
ret
tmorgs: mov ax, offset e_orgs
jmp panica
1998-05-22 18:27:22 +02:00
p_rui: mov ah, 2
mov [val], ax
call p_org1
call getval
mov ax, [val]
jmp savwor
1998-05-21 15:50:52 +02:00
valuco: call value
jc unknow
call get
cmp al, ','
jne badsin
mov ax, [val]
ret
badsin: mov ax, offset e_sin
jmp panica
1998-05-10 21:14:44 +02:00
p_dta: call spaces
1998-05-21 15:50:52 +02:00
dta1: call get
1998-05-10 21:14:44 +02:00
and al, 0dfh
mov [cod], al
cmp al, 'A'
je dtan1
cmp al, 'B'
je dtan1
cmp al, 'L'
je dtan1
cmp al, 'H'
je dtan1
cmp al, 'C'
je dtat1
cmp al, 'D'
je dtat1
jmp ilchar
dtan1: lodsb
cmp al, '('
jne mbrack
1998-05-21 15:50:52 +02:00
dtan2: lodsd
and eax, 0ffdfdfdfh
cmp eax, '(NIS'
jne dtansi
call valuco
mov [sinadd], ax
call valuco
mov [sinamp], ax
call value
jc unknow
mov ax, [val]
test ax, ax
js badsin
jz badsin
mov [sinsiz], ax
mov [sinmin], 0
dec ax
mov [sinmax], ax
call get
cmp al, ')'
je presin
cmp al, ','
jne badsin
call valuco
test ax, ax
js badsin
mov [sinmin], ax
call value
jc unknow
mov ax, [val]
test ax, ax
js badsin
cmp ax, [sinmin]
jb badsin
mov [sinmax], ax
lodsb
cmp al, ')'
jne mbrack
presin: finit
fldpi
fld st
faddp st(1), st
fild [sinsiz]
fdivp st(1), st
gensin: fild [sinmin]
inc [sinmin]
fmul st, st(1)
fsin
fild [sinamp]
fmulp st(1), st
fistp [val]
mov ax, [sinadd]
add [val], ax
jmp dtasto
dtansi: sub si, 4
call value
1998-05-10 21:14:44 +02:00
jc dtan3
1998-05-21 15:50:52 +02:00
dtasto: cmp [pass], 1
1998-05-10 21:14:44 +02:00
jb dtan4
mov al, [cod]
cmp al, 'B'
je dtanb
cmp al, 'L'
je dtanl
cmp al, 'H'
je dtanh
mov ax, [val]
call savwor
jmp dtanx
dtanb: mov ax, [val]
test ah, ah
jz dtans
jmp toobig
dtanl: mov al, [byte low val]
jmp dtans
dtanh: mov al, [byte high val]
dtans: call savbyt
jmp dtanx
dtan3: cmp [pass], 1
jnb unknow
dtan4: cmp [cod], 'A'+1
adc [origin], 1
1998-05-21 15:50:52 +02:00
dtanx: mov ax, [sinmin]
cmp ax, [sinmax]
jbe gensin
lodsb
1998-05-10 21:14:44 +02:00
cmp al, ','
je dtan2
cmp al, ')'
je dtanxt
mbrack: mov ax, offset e_brack
jmp panica
unknow: mov ax, offset e_uknow
jmp panica
dtat1: mov di, offset tlabel
call rstr
lodsb
mov ah, 80h
cmp al, '*'
je dtat2
dec si
xor ah, ah
dtat2: push si
1998-05-22 18:27:22 +02:00
mov si, dx
1998-05-10 21:14:44 +02:00
dtatm: lodsb
xor al, ah
cmp [cod], 'D'
jne ascinx
mov dl, 60h
and dl, al
jz ascin1
cmp dl, 60h
je ascinx
sub al, 60h
ascin1: add al, 40h
ascinx: push ax cx si
call savbyt
pop si cx ax
loop dtatm
pop si
dtanxt: lodsb
cmp al, ','
je dta1
dec si
ret
1998-05-22 18:27:22 +02:00
p_icl: call rfname
1998-05-21 15:50:52 +02:00
pop ax
call linend
1998-05-10 21:14:44 +02:00
jmp opfile
1998-05-22 18:27:22 +02:00
p_ins: call rfname
call fopen
push si
p_in1: mov cx, 256
mov dx, offset tlabel
call fread
jz p_in2
add [origin], ax
cwde
mov bx, [iclen]
mov bx, [(icl bx).prev]
add [(icl bx).line], eax
cmp [pass], 1
jb p_in1
add [bytes], eax
sta cx
mov bx, [ohand]
mov dx, offset tlabel
file 40h, e_writ
jmp p_in1
p_in2: call fclose
pop si
ret
1998-05-10 21:14:44 +02:00
p_end: pop ax
1998-05-21 15:50:52 +02:00
call linend
1998-05-10 21:14:44 +02:00
jmp filend
1998-05-22 18:27:22 +02:00
; addressing modes:
; 0-@ 1-# 2-A 3-Z 4-A,X 5-Z,X 6-A,Y 7-Z,Y 8-(Z,X) 9-(Z),Y 10-(A)
1998-05-10 21:14:44 +02:00
lentab db 1,2,3,2,3,2,3,2,2,2,3
acctab db 0,9,0dh,5,1dh,15h,19h,19h,1,11h,0
srttab db 0ah,0,0eh,6,1eh,16h
lditab db 0,0,0ch,4,1ch,14h,1ch,14h
1998-05-22 18:27:22 +02:00
inwtab db 0eeh,0e6h,0feh,0f6h
1998-05-10 21:14:44 +02:00
comtab: cmd ADC60p_acc
1998-05-21 15:50:52 +02:00
cmd ADD18p_ads
1998-05-10 21:14:44 +02:00
cmd AND20p_acc
cmd ASL00p_srt
cmd BCC90p_bra
cmd BCSb0p_bra
cmd BEQf0p_bra
cmd BIT2cp_bit
cmd BMI30p_bra
cmd BNEd0p_bra
cmd BPL10p_bra
cmd BRK00p_imp
cmd BVC50p_bra
cmd BVS70p_bra
cmd CLC18p_imp
cmd CLDd8p_imp
cmd CLI58p_imp
cmd CLVb8p_imp
cmd CMPc0p_acc
cmd CPXe0p_cpi
cmd CPYc0p_cpi
cmd DECc0p_srt
cmd DEXcap_imp
cmd DEY88p_imp
cmd DTA00p_dta
cmd END00p_end
cmd EOR40p_acc
cmd EQU00p_equ
cmd ICL00p_icl
cmd INCe0p_srt
1998-05-22 18:27:22 +02:00
cmd INIe2p_rui
cmd INS00p_ins
cmd INW00p_inw
1998-05-10 21:14:44 +02:00
cmd INXe8p_imp
cmd INYc8p_imp
1998-05-21 15:50:52 +02:00
cmd JCCb0p_juc
cmd JCS90p_juc
cmd JEQd0p_juc
cmd JMI10p_juc
1998-05-10 21:14:44 +02:00
cmd JMP4cp_jmp
1998-05-21 15:50:52 +02:00
cmd JNEf0p_juc
cmd JPL30p_juc
1998-05-10 21:14:44 +02:00
cmd JSR20p_jsr
1998-05-21 15:50:52 +02:00
cmd JVC70p_juc
cmd JVS50p_juc
1998-05-10 21:14:44 +02:00
cmd LDAa0p_acc
cmd LDXa2p_ldi
cmd LDYa0p_ldi
cmd LSR40p_srt
cmd NOPeap_imp
cmd OPT00p_opt
cmd ORA00p_acc
cmd ORG00p_org
cmd PHA48p_imp
cmd PHP08p_imp
cmd PLA68p_imp
cmd PLP28p_imp
cmd ROL20p_srt
cmd ROR60p_srt
cmd RTI40p_imp
cmd RTS60p_imp
1998-05-22 18:27:22 +02:00
cmd RUNe0p_rui
1998-05-10 21:14:44 +02:00
cmd SBCe0p_acc
cmd SEC38p_imp
cmd SEDf8p_imp
cmd SEI78p_imp
cmd STA80p_acc
cmd STX86p_sti
cmd STY84p_sti
1998-05-21 15:50:52 +02:00
cmd SUB38p_ads
1998-05-10 21:14:44 +02:00
cmd TAXaap_imp
cmd TAYa8p_imp
cmd TSXbap_imp
cmd TXA8ap_imp
cmd TXS9ap_imp
cmd TYA98p_imp
comend:
1998-05-22 18:27:22 +02:00
hello db 'X-Assembler 1.2 by Fox/Taquart',eot
1998-05-10 21:14:44 +02:00
usgtxt db 'Give a source filename. Default extension is .ASX.',eol
db 'Destination will have the same name and .COM extension.',eot
lintxt db ' lines assembled',eot
byttxt db ' bytes written',eot
dectxt db 10 dup(' '),'$'
1998-05-22 18:27:22 +02:00
errtxt db ' ERROR: $'
1998-05-10 21:14:44 +02:00
e_open db 'Can''t open file',eot
e_read db 'Disk read error',eot
e_creat db 'Can''t write destination',eot
e_writ db 'Disk write error',eot
e_icl db 'Too many files nested',eot
e_long db 'Line too long',eot
lislin:
e_uneol db 'Unexpected eol',eot
e_char db 'Illegal character',eot
e_twice db 'Label declared twice',eot
e_inst db 'Illegal instruction',eot
e_nbig db 'Number too big',eot
e_uknow db 'Unknown value',eot
e_xtra db 'Extra characters on line',eot
e_label db 'Label name required',eot
e_str db 'String error',eot
e_orgs db 'Too many ORGs',eot
e_brack db 'Missing bracket',eot
e_tlab db 'Too many labels',eot
e_amod db 'Illegal adressing mode',eot
e_bra db 'Branch too far',eot
1998-05-21 15:50:52 +02:00
e_sin db 'Bad or missing sinus parameter',eot
e_spac db 'Space expected',eot
1998-05-10 21:14:44 +02:00
pass dw 0
lines dd 0
bytes dd 0
1998-05-22 18:27:22 +02:00
iclen dw t_icl
1998-05-10 21:14:44 +02:00
laben dw t_lab
p1laben dw 0
pslaben dw -1
orgvec dw t_org
eoflag db 0
1998-05-21 15:50:52 +02:00
sinmin dw 1
sinmax dw 0
sinadd dw ?
sinamp dw ?
sinsiz dw ?
1998-05-10 21:14:44 +02:00
ohand dw ?
errad dw ?
val dw ?
oper db ?
cod db ?
amod db ?
origin dw ?
obyte db ?
undef db ?
labvec dw ?
fnad dw ?
fname db 80 dup(?)
line db 258 dup(?)
tlabel db 256 dup(?)
t_icl db l_icl dup(?)
t_org db l_org dup(?)
t_lab db l_lab+4 dup(?)
ENDS
END start