6502 Assembler in Forth

6502 Assmbler in Forth (fig style)#



SCR # 81
0 (  FORTH-65 ASSEMBLER                                WFR-79JUN03 )
1 HEX
2 VOCABULARY  ASSEMBLER  IMMEDIATE       ASSEMBLER   DEFINITIONS
3
4 ( REGISTER ASSIGNMENT SPECIFIC TO IMPLEMENTATION  )
5 E0  CONSTANT  XSAVE       DC  CONSTANT  W      DE  CONSTANT  UP
6 D9  CONSTANT  IP          D1  CONSTANT  N
7
8 (  NUCLEUS LOCATIONS ARE IMPLEMENTATION SPECIFIC )
9 '  (DO)  0E  +    CONSTANT  POP
10 '  (DO)  OC  +    CONSTANT  POPTWO
11 '  LIT  13  +  CONSTANT  PUT
12 '  LIT  11  +  CONSTANT  PUSH
13 '  LIT  18  +  CONSTANT  NEXT
14 '  EXECUTE  NFA  11  -  CONSTANT  SETUP
15

SCR # 82
0 (     ASSEMBLER, CONT.                                WFR-78OCT03 )
1 0   VARIABLE  INDEX       -2   ALLOT
2 0909 , 1505 , 0115 , 8011 ,  8009 , 1DOD ,  8019 ,  8080  ,
3 0080 , 1404 , 8014 , 8080 ,  8080 , 1COC ,  801C ,  2C80  ,
4
5 2  VARIABLE  MODE
6 : .A   0 MODE ! ;    : #     1 MODE ! ;     : MEM   2 MODE  ! ;
7 : ,X   3 MODE ! ;    : ,Y    4 MODE ! ;     : X)    5 MODE  ! ;
8 : )Y   6 MODE ! ;    : )     F MODE ! ;
9
10 : BOT       ,X    0  ;     (  ADDRESS THE BOTTOM OF THE STACK  *)
11 : SEC       ,X    2  ;         ( ADDRESS SECOND ITEM ON STACK  *)
12 : RP)       ,X  101  ;      (  ADDRESS BOTTOM OF RETURN STACK  *)
13
14
15

SCR # 83
0 (  UPMODE,  CPU                                          WFR-78OCT23 )
1
2 :  UPMODE   IF   MODE  @ 8 AND  0=   IF  8  MODE +!   THEN THEN
3       1 MODE @   OF AND   -DUP   IF   0  DO   DUP +  LOOP  THEN
4       OVER 1+ @  AND  0=   ;
5
6 :  CPU   <BUILDS   C,  DOES>   C@    C,  MEM   ;
7       00 CPU BRK,    18 CPU  CLC,    D8 CPU  CLD,   58 CPU CLI,
8       B8 CPU CLV,    CA CPU  DEX,    88 CPU  DEY,   E8 CPU INX,
9       C8 CPU INY,    EA CPU  NOP,    48 CPU  PHA,   08 CPU PHP,
10       68 CPU PLA,    28 CPU  PLP,    40 CPU  RTI,   60 CPU RTS,
11       38 CPU SEC,    F8 CPU  SED,    78 CPU  SEI,   AA CPU TAX,
12       A8 CPU TAY,    BA CFU  TSX,    8A CPU  TXA,   9A CPU TXS,
13       98 CPU TYA,
14
15


SCR #  84
0 (   M/CPU,   MULTI-MODE  OP-CODES                        WFR-79MAR26  )
1 :   M/CPU  <BUILDS  C,   ,  DOES>
2         DUP 1+ @ 80 AND    IF  10  MODE +! THEN    OVER
3         FFOO AND UPMODE  UPMODE     IF MEM CR LATEST  ID.
4         3  ERROR  THEN   C@  MODE   C@
5         INDEX + C@ + C,     MODE C@  7 AND   IF MODE  C@
6         OF AND 7 <   IF C,  ELSE ,  THEN   THEN  MEM   ;
7
8    lC6E  60 M/CPU ADC,  1C6E  20  M/CPU AND,  lC6E C0  M/CPU  CMP,
9    lC6E  40 M/CPU EOR,  1C6E  A0  M/CPU LDA,  1C6E 00  M/CPU  ORA,
10    lC6E  E0 M/CPU SBC,  1C6C  80  M/CPU STA,  0D0D 01  M/CPU  ASL,
11    0C0C  Cl M/CPU DEC,  0C0C  El  M/CPU INC,  0D0D 41  M/CPU  LSR,
12    0D0D  21 M/CPU ROL,  0D0D  61  M/CPU ROR,  0414 81  M/CPU  STX,
13    0486  E0 M/CPU CPX,  0486  C0  M/CPU CPY,  1496 A2  M/CPU  LDX,
14    0C8E  A0 M/CPU LDY,  048C  80  M/CPU STY,  0480 14  M/CPU  JSR,
15    8480  40 M/CPU JMP,  0484  20  M/CPU BIT,



SCR # 85

0 (  ASSEMBLER CONDITIONALS                          WFR-79MAR26  )
1 : BEGIN,   HERE  1  ;                  IMMEDIATE
2 : UNTIL,   ?EXEC >R l ?PAIRS R> C, HERE  1+ - C, ; IMMEDIATE
3 : IF,      C,  HERE  0  C,  2  ;        IMMEDIATE
4 : THEN,    ?EXEC  2  ?PAIRS  HERE  OVER   C@
5         IF  SWAP ! ELSE  OVER 1+ - SWAP  C!  THEN  ; IMMEDIATE
6 : ELSE,    2 ?PAIRS HERE 1+   1 JMP
7            SWAP HERE OVER 1+ - SWAP  C!   2  ; IMMEDIATE
8 : NOT   20   +  ;                    ( REVERSE ASSEMBLY TEST )
9 90  CONSTANT  CS               ( ASSEMBLE TEST FOR CARRY SET )
10 DO  CONSTANT  O=             ( ASSEMBLER TEST FOR EQUAL ZERO )
11 10  CONSTANT  O<          ( ASSEMBLE TEST FOR LESS THAN ZERO )
12 90  CONSTANT  >=   ( ASSEMBLE TEST FOR GREATER OR EQUAL ZERO )
13                     ( >= IS ONLY CORRECT AFTER SUB, OR CMP,  )
14
15


SCR # 86
0 (  USE  OF  ASSEMBLER                                     WFR-79APR28  )
1 : END-CODE                              ( END  OF  CODE   DEFINITION  *)
2       CURRENT   @ CONTEXT  !      ?EXEC ?CSP SMUDGE  ;    IMMEDIATE
3
4 FORTH  DEFINITIONS      DECIMAL
5 : CODE                    ( CREATE  WORD  AT  ASSEMBLY  CODE   LEVEL  *)
6       ? EXEC CREATE    (COMPILE)   ASSEMBLER
7       ASSEMBLER  MEM    !CSP  ;       IMMEDIATE
8
9 ( LOCK ASSEMBLER INTO SYSTEM )
10 '  ASSEMBLER  CFA    '  ;CODE   8   +  !  ( OVER-WRITE SMUDGE )
11 LATEST  12  +ORIGIN  !  ( TOP  NFA  )
12 HERE    28  +ORIGIN  !  ( FENCE  )
13 HERE    30  +ORIGIN  !  ( DP )
14 '  ASSEMBLER  6  +    32  +ORIGIN    !   ( VOC-LINK )
15 HERE  FENCE  !