Add adev unit

This commit is contained in:
Virgil Dupras 2020-04-12 21:49:20 -04:00
parent d996dd8c9e
commit 76e4422796
4 changed files with 84 additions and 3 deletions

View File

@ -30,10 +30,10 @@ to been consistent in their use. Here's their definitions:
@ - Fetch @ - Fetch
$ - Initialize $ - Initialize
^ - Arguments in their opposite order ^ - Arguments in their opposite order
> - Pointer in a buffer < - Input
> - 1. Pointer in a buffer 2. Opposite of "<".
( - Lower boundary ( - Lower boundary
) - Upper boundary ) - Upper boundary
< - Input
* - Word indirection (pointer to word) * - Word indirection (pointer to word)
~ - Container for native code. Usually not an executable word. ~ - Container for native code. Usually not an executable word.
? - Is it ...? (example: IMMED?) ? - Is it ...? (example: IMMED?)
@ -122,6 +122,16 @@ HERE -- a Push HERE's address
H@ -- a HERE @ H@ -- a HERE @
MOVE a1 a2 u -- Copy u bytes from a1 to a2, starting with a1, going MOVE a1 a2 u -- Copy u bytes from a1 to a2, starting with a1, going
up. up.
*** Addressed devices ***
See usage.txt for details.
ADEV$ -- Initialize adev subsystem
A@ a -- c Indirect C@
A! c a -- Indirect C!
A@* -- a Address for A@ word
A!* -- a Address for A! word
AMOVE src dst u -- Same as MOVE, but with A@ and A!
*** Arithmetic / Bits *** *** Arithmetic / Bits ***

34
forth/adev.fs Normal file
View File

@ -0,0 +1,34 @@
( Addressed devices.
Abstractions to read and write to devices that allow addressed
access. At all times, we have one active "fetch" device and
one active "store" device, A@ and A!.
Those words have the same signature as C@ and C!, and in fact,
initially default to proxy of those words.
)
: ADEVMEM+ 0x55 RAM+ @ + ;
: A@* 0 ADEVMEM+ ;
: A!* 2 ADEVMEM+ ;
: ADEV$
H@ 0x55 RAM+ !
4 ALLOT
['] C@ A@* !
['] C! A!* !
;
: A@ A@* @ EXECUTE ;
: A! A!* @ EXECUTE ;
( Same as MOVE, but with A@ and A! )
( src dst u -- )
: AMOVE
( u ) 0 DO
SWAP DUP I + A@ ( dst src x )
ROT SWAP OVER I + ( src dst x dst )
A! ( src dst )
LOOP
2DROP
;

View File

@ -90,7 +90,8 @@ RAMSTART INITIAL_SP
+4e INTJUMP +4e INTJUMP
+51 CURRENTPTR +51 CURRENTPTR
+53 readln's variables +53 readln's variables
+55 FUTURE USES +55 adev's variables
+57 FUTURE USES
+59 z80a's variables +59 z80a's variables
+5b FUTURE USES +5b FUTURE USES
+70 DRIVERS +70 DRIVERS

View File

@ -86,3 +86,39 @@ flag to true. For example, "<>{ <>}" yields true.
To check whether A is in between B and C inclusively, you would write: To check whether A is in between B and C inclusively, you would write:
A <>{ B 1 - &> C 1 + &< <>} A <>{ B 1 - &> C 1 + &< <>}
*** Addressed devices
The adev unit provides a simple but powerful abstraction over C@ and C!: A@ and
A!. These work the same way as C@ and C! (but for performance reasons, aren't
used in core words), but are indirect calls.
Upon initialization, the default to C@ and C!, but can be set to any word
through A@* and A!*.
On top of that, it provides a few core-like words such as AMOVE.
Let's demonstrate its use through a toy example:
> : F! SWAP 1 + SWAP C! ;
> 8 H@ DUMP
:54 0000 0000 0000 0000 ........
> 9 H@ A!
> 8 H@ DUMP
:54 0900 0000 0000 0000 ........
> ' F! A!* !
> 9 H@ 1 + A!
> 8 H@ DUMP
:54 090a 0000 0000 0000 ........
> H@ H@ 2 + 2 AMOVE
> 8 H@ DUMP
:54 090a 0a0b 0000 0000 ........
>
Of course, you might want to end up using adev in this kind of ad-hoc way to
have some kind of mapping function, but what you'll mostly want to to is to
plug device drivers into those words.