mirror of
https://github.com/forth-ev/VolksForth.git
synced 2025-01-10 05:29:55 +00:00
commit
c03d6d0c82
@ -24,7 +24,7 @@ update: $(vf_blk_fth_files) $(vf_fth_files_petscii)
|
|||||||
|
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
rm -f cbmfiles/*.fr cbmfiles/*.fth cbmfiles/*.log
|
rm -f cbmfiles/*.fr cbmfiles/*.fth cbmfiles/*.log tmp/*
|
||||||
rm -f *.log *.result *.golden
|
rm -f *.log *.result *.golden
|
||||||
rm -f cbmfiles/c??-testbase
|
rm -f cbmfiles/c??-testbase
|
||||||
rm -f disks/scratch.d64 emulator/sdcard.img
|
rm -f disks/scratch.d64 emulator/sdcard.img
|
||||||
@ -58,7 +58,7 @@ run-testbase16: emulator/testbase16.T64
|
|||||||
|
|
||||||
# Targetcompiler targets
|
# Targetcompiler targets
|
||||||
|
|
||||||
cbmfiles/tcbase: emulator/c64-vf-390.T64 emulator/build-tcbase.sh \
|
cbmfiles/tcbase: emulator/v4th-c64-4tc.T64 emulator/build-tcbase.sh \
|
||||||
disks/tc38q.d64 disks/file-words.d64 cbmfiles/tc-base.fth
|
disks/tc38q.d64 disks/file-words.d64 cbmfiles/tc-base.fth
|
||||||
emulator/build-tcbase.sh
|
emulator/build-tcbase.sh
|
||||||
|
|
||||||
@ -132,7 +132,7 @@ test-v4th-c16-.log: emulator/v4th-c16-.T64
|
|||||||
test-v4th-x16.log: cbmfiles/v4th-x16 emulator/sdcard.img
|
test-v4th-x16.log: cbmfiles/v4th-x16 emulator/sdcard.img
|
||||||
rm -f cbmfiles/test.log
|
rm -f cbmfiles/test.log
|
||||||
emulator/run-in-x16emu.sh v4th-x16 \
|
emulator/run-in-x16emu.sh v4th-x16 \
|
||||||
"INCLUDE RUN-STD-TESTS.FTH\\X0D1234567890\\X0D"
|
"include run-std-tests.fth\n1234567890\n"
|
||||||
mcopy -i emulator/sdcard.img ::TEST.LOG cbmfiles/test.log
|
mcopy -i emulator/sdcard.img ::TEST.LOG cbmfiles/test.log
|
||||||
petscii2ascii cbmfiles/test.log $@
|
petscii2ascii cbmfiles/test.log $@
|
||||||
|
|
||||||
|
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
BIN
6502/C64/cbmfiles/v4th-c64-4tc
Normal file
BIN
6502/C64/cbmfiles/v4th-c64-4tc
Normal file
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
@ -14,4 +14,4 @@ keybuf="3 drive 20 load\n3 drive 10 load\nsave\n\
|
|||||||
savesystem tcbase\ndos s0:notdone\n"
|
savesystem tcbase\ndos s0:notdone\n"
|
||||||
|
|
||||||
DISK10=tc38q DISK11=file-words "${emulatordir}/run-in-vice.sh" \
|
DISK10=tc38q DISK11=file-words "${emulatordir}/run-in-vice.sh" \
|
||||||
"c64-vf-390" "${keybuf}"
|
"v4th-c64-4tc" "${keybuf}"
|
||||||
|
@ -5,9 +5,10 @@ emulatordir="$(realpath --relative-to="$PWD" "$(dirname "${BASH_SOURCE[0]}")")"
|
|||||||
basedir="$(realpath --relative-to="$PWD" "${emulatordir}/..")"
|
basedir="$(realpath --relative-to="$PWD" "${emulatordir}/..")"
|
||||||
cbmfilesdir="${basedir}/cbmfiles"
|
cbmfilesdir="${basedir}/cbmfiles"
|
||||||
sdcard="${emulatordir}/sdcard.img"
|
sdcard="${emulatordir}/sdcard.img"
|
||||||
|
x16script="${basedir}/tmp/x16script"
|
||||||
|
|
||||||
mformat -i "${sdcard}" -F
|
mformat -i "${sdcard}" -F
|
||||||
for asciifile in $(cd "${cbmfilesdir}" && ls *.fth *fr)
|
for asciifile in $(cd "${cbmfilesdir}" && ls)
|
||||||
do
|
do
|
||||||
# Convert filename to PETSCII, remove trailing CR.
|
# Convert filename to PETSCII, remove trailing CR.
|
||||||
petsciifile="$(echo ${asciifile} | ascii2petscii - |tr -d '\r')"
|
petsciifile="$(echo ${asciifile} | ascii2petscii - |tr -d '\r')"
|
||||||
@ -20,13 +21,18 @@ then
|
|||||||
autostart="-prg ${cbmfilesdir}/${1} -run"
|
autostart="-prg ${cbmfilesdir}/${1} -run"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
keybuf=""
|
script=""
|
||||||
warp=""
|
warp=""
|
||||||
scale=""
|
scale=""
|
||||||
debug=""
|
debug=""
|
||||||
if [ -n "$2" ]
|
if [ -n "$2" ]
|
||||||
then
|
then
|
||||||
keybuf="${2}"
|
test -d tmp || mkdir tmp
|
||||||
|
rm -f "${x16script}".*
|
||||||
|
echo "load\"${1}\"\nrun\n${2}" | sed 's/\\n/\n/g' > "${x16script}".ascii
|
||||||
|
ascii2petscii "${x16script}.ascii" "${x16script}.petscii"
|
||||||
|
script="-bas ${x16script}.petscii"
|
||||||
|
autostart=""
|
||||||
mcopy -i "${sdcard}" "${emulatordir}/notdone" "::NOTDONE"
|
mcopy -i "${sdcard}" "${emulatordir}/notdone" "::NOTDONE"
|
||||||
warp="-warp"
|
warp="-warp"
|
||||||
else
|
else
|
||||||
@ -39,13 +45,13 @@ x16emu \
|
|||||||
-keymap de \
|
-keymap de \
|
||||||
-sdcard "${sdcard}" \
|
-sdcard "${sdcard}" \
|
||||||
$autostart \
|
$autostart \
|
||||||
-keybuf "$keybuf" \
|
$script \
|
||||||
$warp \
|
$warp \
|
||||||
$scale \
|
$scale \
|
||||||
$debug \
|
$debug \
|
||||||
&
|
&
|
||||||
|
|
||||||
if [ -n "$keybuf" ]
|
if [ -n "$script" ]
|
||||||
then
|
then
|
||||||
while mtype -i "${sdcard}" "::NOTDONE" > /dev/null
|
while mtype -i "${sdcard}" "::NOTDONE" > /dev/null
|
||||||
do sleep 1
|
do sleep 1
|
||||||
|
15
6502/C64/emulator/update-v4th-4tc.sh
Executable file
15
6502/C64/emulator/update-v4th-4tc.sh
Executable file
@ -0,0 +1,15 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
set -e
|
||||||
|
|
||||||
|
# Script to update the base binary on which the target compiler
|
||||||
|
# is run.
|
||||||
|
|
||||||
|
# The updating of v4th-c64-4tc from the newly built binaries
|
||||||
|
# is intentionally not automatically via Makefile, to ensure a
|
||||||
|
# certain stability for the target compiler.
|
||||||
|
|
||||||
|
emulatordir="$(realpath --relative-to="$PWD" "$(dirname "${BASH_SOURCE[0]}")")"
|
||||||
|
basedir="$(realpath --relative-to="$PWD" "${emulatordir}/..")"
|
||||||
|
cbmfilesdir="${basedir}/cbmfiles"
|
||||||
|
|
||||||
|
cp "${cbmfilesdir}/v4thblk-c64" "${cbmfilesdir}/v4th-c64-4tc"
|
11
6502/C64/src/notmpheap.fth
Normal file
11
6502/C64/src/notmpheap.fth
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
|
||||||
|
\ When no tmpheap mechanism is needed, i.e. all temporary names
|
||||||
|
\ of a project fit onto the regular heap at once, then this zero-cost
|
||||||
|
\ implementation can be used which directs all tmpheap definitions
|
||||||
|
\ to the regular heap.
|
||||||
|
|
||||||
|
' | alias ||
|
||||||
|
' |on alias ||on
|
||||||
|
' |off alias ||off
|
||||||
|
|
||||||
|
' noop alias tmpclear
|
59
6502/C64/src/tmpheap.fth
Normal file
59
6502/C64/src/tmpheap.fth
Normal file
@ -0,0 +1,59 @@
|
|||||||
|
|
||||||
|
\ This is the reference implementation of tmpheap which allocates
|
||||||
|
\ the tmpheap on the regular heap and moves definitons prefixed
|
||||||
|
\ with || or within a ||on to ||off range onto the tmpheap.
|
||||||
|
\ tmpclear will remove all words on the tmpheap, wheras regular clear
|
||||||
|
\ will remove all words on tmpheap and heap together.
|
||||||
|
|
||||||
|
\ Before the first use of ||, the tmpheap size in bytes must be
|
||||||
|
\ set with mk-tmp-heap ( size -- )
|
||||||
|
|
||||||
|
User tmpheap[
|
||||||
|
User tmpheap>
|
||||||
|
User ]tmpheap
|
||||||
|
|
||||||
|
: reset-tmp-heap ( -- )
|
||||||
|
up@ dup ]tmpheap ! dup tmpheap> ! tmpheap[ ! ;
|
||||||
|
|
||||||
|
reset-tmp-heap
|
||||||
|
' reset-tmp-heap is custom-remove
|
||||||
|
|
||||||
|
: mk-tmp-heap ( size -- )
|
||||||
|
heap dup ]tmpheap ! tmpheap> ! hallot heap tmpheap[ ! ;
|
||||||
|
|
||||||
|
: tmp-hallot ( size -- addr )
|
||||||
|
tmpheap> @ swap -
|
||||||
|
dup tmpheap[ @ u< abort" tmp heap overflow"
|
||||||
|
dup tmpheap> ! ;
|
||||||
|
|
||||||
|
| : tmp-heapmove ( from from size -- from offset )
|
||||||
|
dup tmp-hallot swap cmove
|
||||||
|
tmpheap> @ over - ;
|
||||||
|
|
||||||
|
| : tmp-heapmove1x ( from size -- from offset )
|
||||||
|
tmp-heapmove ?heapmovetx off ;
|
||||||
|
|
||||||
|
: || ['] tmp-heapmove1x ?heapmovetx ! ;
|
||||||
|
: ||on ['] tmp-heapmove ?heapmovetx ! ;
|
||||||
|
: ||off ?heapmovetx off ;
|
||||||
|
|
||||||
|
|
||||||
|
| : remove-tmp-words-in-voc ( voc -- )
|
||||||
|
BEGIN dup @ ?dup WHILE ( thread next-in-thread )
|
||||||
|
dup tmpheap[ @ ]tmpheap @ uwithin IF ( thread next-in-thread )
|
||||||
|
@ ?dup IF ( thread next-next-in-thread ) over !
|
||||||
|
ELSE ( thread ) off exit THEN
|
||||||
|
ELSE ( thread next-in-thread ) nip
|
||||||
|
THEN
|
||||||
|
REPEAT drop ;
|
||||||
|
|
||||||
|
| : remove-tmp-words ( -- )
|
||||||
|
voc-link BEGIN @ ?dup
|
||||||
|
WHILE dup 4 - remove-tmp-words-in-voc REPEAT ;
|
||||||
|
|
||||||
|
: tmpclear ( -- )
|
||||||
|
remove-tmp-words
|
||||||
|
\ Uncomment the following line to help determine the ideal tmpheap
|
||||||
|
\ size for your project.
|
||||||
|
\ tmpheap> @ tmpheap[ @ - cr u. ." spare tmpheap bytes"
|
||||||
|
]tmpheap @ tmpheap> ! last off ;
|
@ -7,7 +7,7 @@
|
|||||||
|
|
||||||
(C64 02 )
|
(C64 02 )
|
||||||
(C16 02 )
|
(C16 02 )
|
||||||
(X16 $30 )
|
(X16 $50 )
|
||||||
dup >label RP 2+
|
dup >label RP 2+
|
||||||
dup >label UP 2+
|
dup >label UP 2+
|
||||||
|
|
||||||
@ -1602,13 +1602,6 @@ Code clearstack
|
|||||||
: heap? ( addr -- flag)
|
: heap? ( addr -- flag)
|
||||||
heap up@ uwithin ;
|
heap up@ uwithin ;
|
||||||
|
|
||||||
| : heapmove ( from -- from)
|
|
||||||
dup here over -
|
|
||||||
dup hallot heap swap cmove
|
|
||||||
heap over - last +! reveal ;
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
\ *** Block No. 74, Hexblock 4a
|
\ *** Block No. 74, Hexblock 4a
|
||||||
4a fthpage
|
4a fthpage
|
||||||
@ -1642,7 +1635,7 @@ Label docreate
|
|||||||
\ *** Block No. 75, Hexblock 4b
|
\ *** Block No. 75, Hexblock 4b
|
||||||
4b fthpage
|
4b fthpage
|
||||||
|
|
||||||
( 6502-align ?head | 08sep84bp)
|
( 6502-align 08sep84bp)
|
||||||
|
|
||||||
| : 6502-align/1 ( adr -- adr' )
|
| : 6502-align/1 ( adr -- adr' )
|
||||||
dup $FF and $FF = - ;
|
dup $FF and $FF = - ;
|
||||||
@ -1654,49 +1647,48 @@ Label docreate
|
|||||||
1 last +! 1 allot THEN ;
|
1 last +! 1 allot THEN ;
|
||||||
|
|
||||||
|
|
||||||
Variable ?head 0 ?head !
|
|
||||||
|
|
||||||
: | ?head @ ?exit -1 ?head ! ;
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
\ *** Block No. 76, Hexblock 4c
|
\ *** Block No. 76, Hexblock 4c
|
||||||
4c fthpage
|
4c fthpage
|
||||||
|
|
||||||
( warning Create 30dec84bp)
|
\ warning ?heapmovetx | |on |off Create
|
||||||
|
|
||||||
Variable warning 0 warning !
|
Variable warning 0 warning !
|
||||||
|
|
||||||
| : exists?
|
| : exists? ( -- )
|
||||||
warning @ ?exit
|
warning @ ?exit
|
||||||
last @ current @ (find nip
|
last @ current @ (find nip
|
||||||
IF space last @ .name ." exists " ?cr
|
IF space last @ .name ." exists " ?cr
|
||||||
THEN ;
|
THEN ;
|
||||||
|
|
||||||
|
Variable ?heapmovetx 0 ?heapmovetx !
|
||||||
|
|
||||||
|
| : heapmove ( from size -- offset )
|
||||||
|
over >r dup hallot ( from size ) heap swap cmove ( )
|
||||||
|
heap r> - ;
|
||||||
|
|
||||||
|
| : heapmove1x ( from size -- offset )
|
||||||
|
heapmove ?heapmovetx off ;
|
||||||
|
|
||||||
|
: | ['] heapmove1x ?heapmovetx ! ;
|
||||||
|
: |on ['] heapmove ?heapmovetx ! ;
|
||||||
|
: |off ?heapmovetx off ;
|
||||||
|
|
||||||
: Create
|
: Create
|
||||||
here blk @ , current @ @ ,
|
here
|
||||||
name c@ dup 1 $20
|
blk @ , current @ @ ,
|
||||||
uwithin not Abort" invalid name"
|
name c@
|
||||||
here last ! 1+ allot
|
dup 1 $20 uwithin not Abort" invalid name"
|
||||||
exists? ?head @
|
here last ! 1+ allot exists?
|
||||||
IF 1 ?head +! dup 6502-align/1 ,
|
?heapmovetx @
|
||||||
\ Pointer to code
|
IF dup 6502-align/1 , \ Pointer to code
|
||||||
heapmove $20 flag! 6502-align/1 dp !
|
dup here over -
|
||||||
|
?heapmovetx perform last +!
|
||||||
|
$20 flag! 6502-align/1 dp !
|
||||||
ELSE 6502-align/2 drop
|
ELSE 6502-align/2 drop
|
||||||
THEN reveal 0 ,
|
THEN reveal 0 ,
|
||||||
;Code docreate jmp end-code
|
;Code docreate jmp end-code
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
\ *** Block No. 77, Hexblock 4d
|
\ *** Block No. 77, Hexblock 4d
|
||||||
4d fthpage
|
4d fthpage
|
||||||
|
|
||||||
@ -1797,8 +1789,8 @@ Variable warning 0 warning !
|
|||||||
: User Create 2 uallot c,
|
: User Create 2 uallot c,
|
||||||
;Code SP 2dec 2 # ldy
|
;Code SP 2dec 2 # ldy
|
||||||
W )Y lda clc UP adc SP X) sta
|
W )Y lda clc UP adc SP X) sta
|
||||||
txa iny UP 1+ adc 1 # ldy
|
dey txa UP 1+ adc SP )Y sta
|
||||||
SP )Y sta Next jmp end-code
|
Next jmp end-code
|
||||||
|
|
||||||
: Alias ( cfa --)
|
: Alias ( cfa --)
|
||||||
Create last @ dup c@ $20 and
|
Create last @ dup c@ $20 and
|
||||||
@ -1818,6 +1810,13 @@ Variable warning 0 warning !
|
|||||||
|
|
||||||
( voc-link vp current context also bp)
|
( voc-link vp current context also bp)
|
||||||
|
|
||||||
|
\ vp contains the vocabulary search oder respectively stack.
|
||||||
|
\ vp/vp+1: order/stack size. 0 = one vocabulary on the stack
|
||||||
|
\ vp+2/vp+3: bottom vocabulary on the stack
|
||||||
|
\ ...
|
||||||
|
\ vp+N+2/vp+N+3: the current context vocabulary, the top of stack,
|
||||||
|
\ if N is the content of vp/vp+1.
|
||||||
|
\ The top two vocabularies are the same after also is called.
|
||||||
Create vp $10 allot
|
Create vp $10 allot
|
||||||
Variable current
|
Variable current
|
||||||
|
|
||||||
@ -1961,6 +1960,8 @@ Label findloop 0 # ldy
|
|||||||
( find ' ['] 13jan85bp)
|
( find ' ['] 13jan85bp)
|
||||||
|
|
||||||
: find ( string -- cfa n / string false)
|
: find ( string -- cfa n / string false)
|
||||||
|
\ Skip the top vocabulary in the search order if it's equal to the
|
||||||
|
\ second in the search order, as is the case after also is called.
|
||||||
context dup @ over 2- @ = IF 2- THEN
|
context dup @ over 2- @ = IF 2- THEN
|
||||||
BEGIN under @ (find
|
BEGIN under @ (find
|
||||||
IF nip found exit THEN
|
IF nip found exit THEN
|
||||||
@ -2404,21 +2405,30 @@ Defer init-buffers ' noop IS init-buffers
|
|||||||
name> under 1+ u< swap heap? or ;
|
name> under 1+ u< swap heap? or ;
|
||||||
|
|
||||||
| : endpoints ( addr -- addr symb)
|
| : endpoints ( addr -- addr symb)
|
||||||
heap voc-link >r
|
\ heap is the starting value for symb
|
||||||
BEGIN r> @ ?dup \ through all Vocabs
|
\ at the end symb is heap or 2 + the highest of all cfas that are
|
||||||
WHILE dup >r 4 - >r \ link on returnst.
|
\ either in the heap or u> addr
|
||||||
BEGIN r> @ >r over 1- dup r@ u<
|
heap voc-link >r ( addr symb / R: voc-link )
|
||||||
\ until link or
|
BEGIN \ outer loop through all vocabs
|
||||||
swap r@ 2+ name> u< and
|
r> @ ?dup ( addr symb / R: ) \ this is the word's exit point
|
||||||
\ code under adr
|
WHILE dup >r 4 - >r ( addr symb / R: next-voc prev-lfa )
|
||||||
WHILE r@ heap? [ 2dup ] UNTIL
|
BEGIN \ inner loop through all words of a vocab
|
||||||
|
r> @ >r ( R: prev-voc next-lfa )
|
||||||
|
over 1- dup r@ u<
|
||||||
|
( addr heap addr-1 flag:addr-1_u<_next-lfa_? )
|
||||||
|
swap r@ 2+ name> u<
|
||||||
|
( addr heap flag:addr-1_u<_next-lfa_? flag:addr-1_u<_next-cfa_? )
|
||||||
|
and ( addr heap flag )
|
||||||
|
\ flag means both lfa and cfa of next word are still u> addr-1
|
||||||
|
\ i.e. WHILE flag means exit loop if either lfa or cfa u<= addr
|
||||||
|
WHILE r@ heap? [ 2dup ] UNTIL \ Continue loop if lfa not on heap
|
||||||
\ search for a name in heap
|
\ search for a name in heap
|
||||||
r@ 2+ |? IF over r@ 2+ forget?
|
r@ 2+ |? IF over r@ 2+ forget?
|
||||||
IF r@ 2+ (name> 2+ umax
|
IF r@ 2+ (name> 2+ umax
|
||||||
THEN \ then update symb
|
THEN \ then update symb
|
||||||
THEN
|
THEN
|
||||||
REPEAT rdrop
|
REPEAT rdrop ( R: next-voc )
|
||||||
REPEAT ;
|
REPEAT ;
|
||||||
|
|
||||||
|
|
||||||
\ *** Block No. 114, Hexblock 72
|
\ *** Block No. 114, Hexblock 72
|
||||||
@ -2426,23 +2436,41 @@ Defer init-buffers ' noop IS init-buffers
|
|||||||
|
|
||||||
\ remove 23jul85we
|
\ remove 23jul85we
|
||||||
|
|
||||||
| Code remove ( dic symb thr - dic symb)
|
| Code remove ( dict symb thread - dict symb)
|
||||||
|
\ thread: vocabulary linked list
|
||||||
|
\
|
||||||
5 # ldy [[ SP )Y lda N ,Y sta dey 0< ?]
|
5 # ldy [[ SP )Y lda N ,Y sta dey 0< ?]
|
||||||
|
\ N+4/5: dict N+2/3: symb N+0/1: thread
|
||||||
user' s0 # ldy
|
user' s0 # ldy
|
||||||
clc UP )Y lda 6 # adc N 6 + sta
|
clc UP )Y lda 6 # adc N 6 + sta
|
||||||
iny UP )Y lda 0 # adc N 7 + sta
|
iny UP )Y lda 0 # adc N 7 + sta
|
||||||
1 # ldy
|
1 # ldy
|
||||||
|
\ N+6/7: s0
|
||||||
[[ N X) lda N 8 + sta
|
[[ N X) lda N 8 + sta
|
||||||
N )Y lda N 9 + sta N 8 + ora 0<>
|
N )Y lda N 9 + sta N 8 + ora 0<>
|
||||||
|
\ N+8/9: next ptr in thread
|
||||||
|
\ compare N+8/9 next ptr to s0 in N+6/7:
|
||||||
?[[ N 8 + lda N 6 + cmp
|
?[[ N 8 + lda N 6 + cmp
|
||||||
N 9 + lda N 7 + sbc CS
|
N 9 + lda N 7 + sbc CS
|
||||||
|
\ CS aka u>= :
|
||||||
|
\ compare N+8/9 next ptr to symb N+2/3
|
||||||
?[ N 8 + lda N 2 + cmp
|
?[ N 8 + lda N 2 + cmp
|
||||||
N 9 + lda N 3 + sbc
|
N 9 + lda N 3 + sbc
|
||||||
|
\ CC aka u< :
|
||||||
|
\ compare N+4/5 dict to next ptr N+8/9
|
||||||
][ N 4 + lda N 8 + cmp
|
][ N 4 + lda N 8 + cmp
|
||||||
N 5 + lda N 9 + sbc
|
N 5 + lda N 9 + sbc
|
||||||
]? CC
|
]? CC
|
||||||
|
\ CC aka u< i.e.
|
||||||
|
\ either (inner CS above) s0 u<= next ptr u< symb
|
||||||
|
\ or (inner CC above) dict u< next ptr u< s0
|
||||||
|
\ let current ptr's adr point to next ptr's adr,
|
||||||
|
\ i.e. remover next ptr from vocabulary thread.
|
||||||
?[ N 8 + X) lda N X) sta
|
?[ N 8 + X) lda N X) sta
|
||||||
N 8 + )Y lda N )Y sta
|
N 8 + )Y lda N )Y sta
|
||||||
|
\ CS aka u>= :
|
||||||
|
\ let next ptr N+8/9 be current ptr N+0/1
|
||||||
|
\ i.e. leave next ptr in vocabulary thread.
|
||||||
][ N 8 + lda N sta
|
][ N 8 + lda N sta
|
||||||
N 9 + lda N 1+ sta ]?
|
N 9 + lda N 1+ sta ]?
|
||||||
]]? (drop jmp end-code
|
]]? (drop jmp end-code
|
||||||
@ -2455,17 +2483,17 @@ Defer init-buffers ' noop IS init-buffers
|
|||||||
|
|
||||||
( remove- forget-words 29apr85bp)
|
( remove- forget-words 29apr85bp)
|
||||||
|
|
||||||
| : remove-words ( dic symb -- dic symb)
|
| : remove-words ( dict symb -- dict symb)
|
||||||
voc-link BEGIN @ ?dup
|
voc-link BEGIN @ ?dup
|
||||||
WHILE dup >r 4 - remove r> REPEAT ;
|
WHILE dup >r 4 - remove r> REPEAT ;
|
||||||
|
|
||||||
| : remove-tasks ( dic --)
|
| : remove-tasks ( dict --)
|
||||||
up@ BEGIN 1+ dup @ up@ -
|
up@ BEGIN 1+ dup @ up@ -
|
||||||
WHILE 2dup @ swap here uwithin
|
WHILE 2dup @ swap here uwithin
|
||||||
IF dup @ 1+ @ over ! 1- ELSE @ THEN
|
IF dup @ 1+ @ over ! 1- ELSE @ THEN
|
||||||
REPEAT 2drop ;
|
REPEAT 2drop ;
|
||||||
|
|
||||||
| : remove-vocs ( dic symb -- dic symb)
|
| : remove-vocs ( dict symb -- dict symb)
|
||||||
voc-link remove thru.vocstack
|
voc-link remove thru.vocstack
|
||||||
DO 2dup I @ -rot uwithin
|
DO 2dup I @ -rot uwithin
|
||||||
IF [ ' Forth 2+ ] Literal I ! THEN
|
IF [ ' Forth 2+ ] Literal I ! THEN
|
||||||
@ -2484,7 +2512,13 @@ Defer custom-remove
|
|||||||
|
|
||||||
( deleting words from dict. 13jan83ks)
|
( deleting words from dict. 13jan83ks)
|
||||||
|
|
||||||
| : forget-words ( dic symb --)
|
\ forget-words use cases:
|
||||||
|
\ clear: dict=here, symb=up@
|
||||||
|
\ forget: dict=cfa-to-forget,
|
||||||
|
\ symb=umax(heap, 2 + (highest cfa either in heap or u> dict)
|
||||||
|
\ empty: dict=here@cold, symb=up@
|
||||||
|
\ save: dict=here, symb=up@
|
||||||
|
| : forget-words ( dict symb --)
|
||||||
over remove-tasks remove-vocs
|
over remove-tasks remove-vocs
|
||||||
remove-words custom-remove
|
remove-words custom-remove
|
||||||
heap swap - hallot dp ! 0 last ! ;
|
heap swap - hallot dp ! 0 last ! ;
|
||||||
|
@ -11,17 +11,21 @@ Target
|
|||||||
|
|
||||||
Forth also definitions
|
Forth also definitions
|
||||||
|
|
||||||
|
(C16 : (16 ) (C64 : (64 ) (X16 : (CX ) ; immediate
|
||||||
|
|
||||||
(C16 : (64 ) \ jumps belhind C)
|
(C16 : (64 ) \ jumps belhind C)
|
||||||
(C64 : (16 )
|
(C64 : (16 )
|
||||||
(X16 : (CX )
|
(X16 : (64 )
|
||||||
BEGIN name count dup 0=
|
BEGIN name count dup 0=
|
||||||
abort" C) missing" 2 = >r
|
abort" C) missing" 2 = >r
|
||||||
@ [ Ascii C Ascii ) $100 * + ] Literal
|
@ [ Ascii C Ascii ) $100 * + ] Literal
|
||||||
= r> and UNTIL ; immediate
|
= r> and UNTIL ; immediate
|
||||||
|
|
||||||
: C) ; immediate
|
(C16 ' (64 alias (CX immediate )
|
||||||
|
(C64 ' (16 alias (CX immediate )
|
||||||
|
(X16 ' (64 alias (16 immediate )
|
||||||
|
|
||||||
(C16 : (16 ) (C64 : (64 ) (X16 : (CX ) ; immediate
|
: C) ; immediate
|
||||||
|
|
||||||
: forth-83 ; \ last word in Dictionary
|
: forth-83 ; \ last word in Dictionary
|
||||||
|
|
||||||
|
@ -28,5 +28,5 @@ here dup origin!
|
|||||||
$100 allot
|
$100 allot
|
||||||
|
|
||||||
Create logo
|
Create logo
|
||||||
(C16+ ," volksFORTH-83 3.91-C16+ " )
|
(C16+ ," volksFORTH-83 3.9.2-C16+ " )
|
||||||
(C16- ," volksFORTH-83 3.91-C16- " )
|
(C16- ," volksFORTH-83 3.9.2-C16- " )
|
||||||
|
@ -28,4 +28,4 @@ here dup origin!
|
|||||||
$100 allot
|
$100 allot
|
||||||
|
|
||||||
Create logo
|
Create logo
|
||||||
," volksFORTH-83 3.91-C64 "
|
," volksFORTH-83 3.9.2-C64 "
|
||||||
|
@ -27,4 +27,4 @@ here dup origin!
|
|||||||
$100 allot
|
$100 allot
|
||||||
|
|
||||||
Create logo
|
Create logo
|
||||||
," volksFORTH-83 3.91-X16 "
|
," volksFORTH-83 3.9.2-X16 "
|
||||||
|
@ -8,6 +8,7 @@ $FFA5 >label ACPTR
|
|||||||
$FFC6 >label CHKIN
|
$FFC6 >label CHKIN
|
||||||
$FFC9 >label CHKOUT
|
$FFC9 >label CHKOUT
|
||||||
$FFD2 >label CHROUT
|
$FFD2 >label CHROUT
|
||||||
|
$FFCF >label CHRIN
|
||||||
$FF81 >label CINT
|
$FF81 >label CINT
|
||||||
$FFA8 >label CIOUT
|
$FFA8 >label CIOUT
|
||||||
$FFC3 >label CLOSE
|
$FFC3 >label CLOSE
|
||||||
@ -25,5 +26,6 @@ $FF96 >label TKSA
|
|||||||
$FFEA >label UDTIM
|
$FFEA >label UDTIM
|
||||||
$FFAE >label UNLSN
|
$FFAE >label UNLSN
|
||||||
$FFAB >label UNTLK
|
$FFAB >label UNTLK
|
||||||
$FFCF >label CHRIN
|
|
||||||
$FF99 >label MEMTOP
|
$FF99 >label MEMTOP
|
||||||
|
$FFBD >label SETNAM
|
||||||
|
$FFBA >label SETLFS
|
||||||
|
@ -7,6 +7,7 @@ include vf-lbls-cbm.fth
|
|||||||
\ C16-Labels clv13.4.87)
|
\ C16-Labels clv13.4.87)
|
||||||
|
|
||||||
0ff4c >label ConOut
|
0ff4c >label ConOut
|
||||||
|
090 >label IOStatus
|
||||||
09a >label MsgFlg
|
09a >label MsgFlg
|
||||||
099 >label OutDev
|
099 >label OutDev
|
||||||
098 >label InDev
|
098 >label InDev
|
||||||
@ -55,8 +56,6 @@ end-code
|
|||||||
|
|
||||||
include vf-sys-cbm.fth
|
include vf-sys-cbm.fth
|
||||||
|
|
||||||
: i/o-status? $90 c@ ;
|
|
||||||
|
|
||||||
|
|
||||||
\ *** Block No. 143, Hexblock 8f
|
\ *** Block No. 143, Hexblock 8f
|
||||||
\ ... continued
|
\ ... continued
|
||||||
|
@ -7,6 +7,7 @@ include vf-lbls-cbm.fth
|
|||||||
\ C64-Labels clv13.4.87)
|
\ C64-Labels clv13.4.87)
|
||||||
|
|
||||||
0E716 >label ConOut
|
0E716 >label ConOut
|
||||||
|
090 >label IOStatus
|
||||||
09d >label MsgFlg
|
09d >label MsgFlg
|
||||||
09a >label OutDev
|
09a >label OutDev
|
||||||
099 >label InDev
|
099 >label InDev
|
||||||
@ -58,8 +59,6 @@ Code curoff ( --)
|
|||||||
|
|
||||||
include vf-sys-cbm.fth
|
include vf-sys-cbm.fth
|
||||||
|
|
||||||
: i/o-status? $90 c@ ;
|
|
||||||
|
|
||||||
|
|
||||||
\ *** Block No. 143, Hexblock 8f
|
\ *** Block No. 143, Hexblock 8f
|
||||||
\ ... continued
|
\ ... continued
|
||||||
|
@ -99,6 +99,9 @@ Output: display [ here output ! ]
|
|||||||
\ *** Block No. 135, Hexblock 87
|
\ *** Block No. 135, Hexblock 87
|
||||||
87 fthpage
|
87 fthpage
|
||||||
|
|
||||||
|
Code i/o-status? ( -- n )
|
||||||
|
IOStatus lda Push0A jmp end-code
|
||||||
|
|
||||||
\ b/blk drive >drive drvinit clv14:2x87
|
\ b/blk drive >drive drvinit clv14:2x87
|
||||||
|
|
||||||
400 Constant b/blk
|
400 Constant b/blk
|
||||||
@ -143,10 +146,10 @@ Label nodevice 0 # ldx 1 # ldy
|
|||||||
\ ?device clv12jul87
|
\ ?device clv12jul87
|
||||||
|
|
||||||
Label (?dev
|
Label (?dev
|
||||||
90 stx (C16 $ae sta ( ) LISTEN jsr
|
IOStatus stx (C16 $ae sta ( ) LISTEN jsr
|
||||||
\ because of error in OS
|
\ because of error in OS
|
||||||
60 # lda SECOND jsr UNLSN jsr
|
60 # lda SECOND jsr UNLSN jsr
|
||||||
90 lda 0<> ?[ pla pla nodevice jmp ]?
|
IOStatus lda 0<> ?[ pla pla nodevice jmp ]?
|
||||||
rts end-code
|
rts end-code
|
||||||
|
|
||||||
Code (?device ( dev --)
|
Code (?device ( dev --)
|
||||||
@ -212,7 +215,8 @@ Code bus@ ( -- 8b)
|
|||||||
bounds ?DO bus@ I c! LOOP pause ;
|
bounds ?DO bus@ I c! LOOP pause ;
|
||||||
|
|
||||||
: derror? ( -- flag )
|
: derror? ( -- flag )
|
||||||
disk $F busin bus@ dup Ascii 0 -
|
disk $F busin bus@ dup Ascii 0 =
|
||||||
IF BEGIN emit bus@ dup #cr = UNTIL
|
IF drop BEGIN bus@ drop i/o-status? UNTIL false
|
||||||
0= cr ELSE BEGIN bus@ #cr = UNTIL
|
ELSE BEGIN emit bus@ i/o-status? UNTIL emit true THEN
|
||||||
THEN 0= busoff ;
|
busoff ;
|
||||||
|
|
||||||
|
@ -6,6 +6,7 @@ include vf-lbls-cbm.fth
|
|||||||
\ X16 labels
|
\ X16 labels
|
||||||
|
|
||||||
0c28c >label ConOut
|
0c28c >label ConOut
|
||||||
|
0286 >label IOStatus
|
||||||
028c >label MsgFlg
|
028c >label MsgFlg
|
||||||
028b >label OutDev
|
028b >label OutDev
|
||||||
028a >label InDev
|
028a >label InDev
|
||||||
@ -29,18 +30,23 @@ include vf-lbls-cbm.fth
|
|||||||
\ X16 c64key? getkey
|
\ X16 c64key? getkey
|
||||||
|
|
||||||
Code c64key? ( -- flag)
|
Code c64key? ( -- flag)
|
||||||
|
9f61 ldx
|
||||||
0 # lda 9f61 sta
|
0 # lda 9f61 sta
|
||||||
0a00a lda
|
0a00a lda
|
||||||
0<> ?[ 0FF # lda ]? pha
|
0<> ?[ 0FF # lda ]? pha
|
||||||
|
9f61 stx
|
||||||
Push jmp end-code
|
Push jmp end-code
|
||||||
|
|
||||||
Code getkey ( -- 8b)
|
Code getkey ( -- 8b)
|
||||||
|
9f61 lda N sta
|
||||||
0 # lda 9f61 sta
|
0 # lda 9f61 sta
|
||||||
0a00a lda 0<>
|
0a00a lda 0<>
|
||||||
?[ sei 0a000 ldy
|
?[ sei 0a000 ldy
|
||||||
[[ 0a000 1+ ,X lda 0a000 ,X sta inx
|
[[ 0a000 1+ ,X lda 0a000 ,X sta inx
|
||||||
0a00a cpx 0= ?]
|
0a00a cpx 0= ?]
|
||||||
0a00a dec tya cli 0A0 # cmp
|
0a00a dec
|
||||||
|
N lda 9f61 sta
|
||||||
|
tya cli 0A0 # cmp
|
||||||
0= ?[ bl # lda ]?
|
0= ?[ bl # lda ]?
|
||||||
]?
|
]?
|
||||||
Push0A jmp end-code
|
Push0A jmp end-code
|
||||||
@ -70,8 +76,6 @@ Code curoff ( --)
|
|||||||
|
|
||||||
include vf-sys-cbm.fth
|
include vf-sys-cbm.fth
|
||||||
|
|
||||||
: i/o-status? $0286 c@ ;
|
|
||||||
|
|
||||||
|
|
||||||
\ *** Block No. 143, Hexblock 8f
|
\ *** Block No. 143, Hexblock 8f
|
||||||
\ ... continued
|
\ ... continued
|
||||||
|
62
6502/C64/src/x16tmpheap.fth
Normal file
62
6502/C64/src/x16tmpheap.fth
Normal file
@ -0,0 +1,62 @@
|
|||||||
|
|
||||||
|
\ This is a custom implementation of tmpheap for the X16 which
|
||||||
|
\ allocates the tmpheap in a RAM bank and moves definitons prefixed
|
||||||
|
\ with || or within a ||on to ||off range there.
|
||||||
|
\ tmpclear will remove all words on the tmpheap, wheras regular clear
|
||||||
|
\ will remove all words on tmpheap and heap together.
|
||||||
|
|
||||||
|
\ Other than the reference tmpheap living on the regular heap, this
|
||||||
|
\ custom tmpheap needs no initialization as its position and
|
||||||
|
\ size (8k) is fixed.
|
||||||
|
|
||||||
|
User tmpheap[
|
||||||
|
User tmpheap>
|
||||||
|
User ]tmpheap
|
||||||
|
|
||||||
|
\ $9f61 is the X16 RAM bank select register. This will change to $0001
|
||||||
|
\ in the next X16 board version.
|
||||||
|
\ 1 is the RAM bank selected for the tmpheap. RAM bank 0 is used by the
|
||||||
|
\ X16 KERNAL. The banked RAM lives from $a000 to $bfff.
|
||||||
|
1 $9f61 c! $a000 tmpheap[ ! $c000 dup ]tmpheap ! tmpheap> !
|
||||||
|
|
||||||
|
: mk-tmp-heap ( size -- )
|
||||||
|
heap dup ]tmpheap ! tmpheap> ! hallot heap tmpheap[ ! ;
|
||||||
|
|
||||||
|
: tmp-hallot ( size -- addr )
|
||||||
|
tmpheap> @ swap -
|
||||||
|
dup tmpheap[ @ u< abort" tmp heap overflow"
|
||||||
|
dup tmpheap> ! ;
|
||||||
|
|
||||||
|
| : tmp-heapmove ( from from size -- from offset )
|
||||||
|
dup tmp-hallot swap cmove
|
||||||
|
tmpheap> @ over - ;
|
||||||
|
|
||||||
|
| : tmp-heapmove1x ( from size -- from offset )
|
||||||
|
tmp-heapmove ?heapmovetx off ;
|
||||||
|
|
||||||
|
: || ['] tmp-heapmove1x ?heapmovetx ! ;
|
||||||
|
: ||on ['] tmp-heapmove ?heapmovetx ! ;
|
||||||
|
: ||off ?heapmovetx off ;
|
||||||
|
|
||||||
|
|
||||||
|
| : remove-tmp-words-in-voc ( voc -- )
|
||||||
|
BEGIN dup @ ?dup WHILE ( thread next-in-thread )
|
||||||
|
dup tmpheap[ @ ]tmpheap @ uwithin IF ( thread next-in-thread )
|
||||||
|
@ ?dup IF ( thread next-next-in-thread ) over !
|
||||||
|
ELSE ( thread ) off exit THEN
|
||||||
|
ELSE ( thread next-in-thread ) nip
|
||||||
|
THEN
|
||||||
|
REPEAT drop ;
|
||||||
|
|
||||||
|
| : remove-tmp-words ( -- )
|
||||||
|
voc-link BEGIN @ ?dup
|
||||||
|
WHILE dup 4 - remove-tmp-words-in-voc REPEAT ;
|
||||||
|
|
||||||
|
: tmpclear ( -- )
|
||||||
|
remove-tmp-words
|
||||||
|
\ Uncomment the following line to help determine the ideal tmpheap
|
||||||
|
\ size for your project.
|
||||||
|
\ tmpheap> @ tmpheap[ @ - cr u. ." tmpheap spare"
|
||||||
|
]tmpheap @ tmpheap> ! last off ;
|
||||||
|
|
||||||
|
' tmpclear is custom-remove
|
Loading…
x
Reference in New Issue
Block a user