# TO THE 6500 CHIP FAMILY SUPPLEMENT CROSS ASSEMBLER MANUAL CAS-2006-00 #### TABLE OF CONTENTS | INTRODUCTION S-1 | |------------------------------------------| | 6500 PERMANENT SYMBOL TABLE S-1 | | CALLING THE 6500 CROSS ASSEMBLER S-9 | | TERMINATING THE 6500 CROSS ASSEMBLER S-9 | | SAMPLE 6500 ASSEMBLY LISTINGS S-9 | | | | | | LIST OF TABLES | | | S-1. 6500 INSTRUCTION SET SUMMARY..... S-2 This guide is a supplement to the Emulogic Relocatable Macro Cross Assembler Manual, providing specific assembler information for writing software programs to run on the 6500 microprocessor series. This supplement applies to the following chips: | * | 6502 | * | 6505 | * | 6512 | |---|------|---|------|---|------| | * | 6503 | * | 6506 | * | 6513 | | * | 6504 | * | 6507 | * | 6515 | #### This supplement includes: - \* a summary of the 6500 instruction set, - \* procedures for running the 6500 cross assembler, and The following is a summary of the mnemonics for the \* sample 6500 cross assembler output listings ### 6500 PERMANENT SYMBOL TABLE operation (op) codes included in the 6500 series instruction set. They are stored in the Permanent Symbol Table and are automatically recognized by the Emulogic relocatable macro cross assembler. References to, and operations with the registers within the microprocessor are legal. For a detailed description of the 6500 op codes, refer to the Synertek SY6500/MCS6500 Microcomputer Family Programming Manual. Instruction operands are represented herein as follows: | Opera | nd I | Meaning | |-------|----------|------------------------------| | | | | | ii | Immed | iate operand (byte) | | ^^ | 8-bit | relative branch address | | aa | 8-bit | address variable (zero page) | | aa | aa 16-bi | t absolute address | | x | X inde | ex register | | у | Y ind | ex register | | A | Accum | ulator | #### Programming Notes: - (1) Address references in zero page must be predefined. - (2) The use of complex forward references should be avoided as they may result in phase errors. ### TABLE S-1. 6500 INSTRUCTION SET SUMMARY | MNEMONIC | OPERANDS | DESCRIPTION | EXAMPLE | | | |----------|----------|-------------------------------------------------------|---------|----------------|--| | ADC | #ii | Add immediate to accumulator with carry | ADC | #20 | | | ADC | aa | Add memory to accumulator with carry | ADC | 3F | | | ADC | aaaa | Add memory to accumulator with carry | ADC | OFFF | | | ADC | aa,x | Add memory indexed to accumu-<br>lator with carry | ADC | 3,X | | | ADC | aaaa,x | Add memory indexed to accumu-lator with carry | ADC | TAG,X | | | ADC | aaaa,y | Add memory indexed to accumu-<br>lator with carry | ADC | 245 <b>,</b> Y | | | ADC | (aa,x) | Add memory indexed indirect to accumulator with carry | ADC | (4,X) | | | ADC | (aa),y | Add memory indirect indexed to accumulator with carry | ADC | (7),Y | | | AND | #ii | AND immediate with accumulator | AND | #125. | | | AND | aa | AND memory with accumulator | AND | 10 | | | AND | aaaa | AND memory with accumulator | AND | 258. | | | AND | aa,x | AND memory indexed with accumulator | AND | 5A,X | | | AND | aaaa,x | AND memory indexed with accumulator | AND | 300.,x | | | AND | aaaa,y | AND memory indexed with accumulator | AND | TAG,Y | | | AND | (aa,x) | AND memory indexed indirect with accumulator | AND | (OFE,X) | | | AND | (aa),y | AND memory indirect indexed with accumulator | AND | (25.),Y | | | ASL | A | Shift left accumulator one bit | ASL | A | | | ASL | aa | Shift left memory one bit | ASL | 254. | | | ASL | aaaa | Shift left memory one bit | ASL | TAG | | Table S-1. 6500 Instruction Set Summary (contd) | MNEMONIC | OPERANDS | DESCRIPTION | EXA | AMPLE | |----------|----------|---------------------------------------|-----|---------| | ASL | aa,x | Shift left memory indexed one bit | ASL | 0A4,X | | ASL | aaaa,x | Shift left memory indexed one bit | ASL | 1452,X | | всс | ^^ | Branch on carry clear | всс | 12 | | BCS | ^^ | Branch on carry set | BCS | TAG | | BEQ | ^^ | Branch on result zero | BEQ | 34. | | ВІТ | aa | Test bits in memory with accumulator | BIT | OFF | | BIT | aaaa | Test bits in memory with accumulator | BIT | 257. | | BMI | ^^ | Branch on result minus | BMI | OA | | BNE | ^^ | Branch on result not zero | BNE | 123. | | BPL | ^^ | Branch on result plus | BPL | TAG1 | | BRK | | Force break | BRK | | | BVC | ^^ | Branch on overflow clear | BVC | 24 | | BVS | ^^ | Branch on overflow set | BVS | OAB | | CLC | | Clear carry flag | CLC | | | CLD | | Clear decimal load | CLD | | | CLI | | Clear interrupt disable bit | CLI | | | CLV | | Clear overflow flag | CLV | | | СМР | #ii | Compare immediate to accumu-<br>lator | CMP | #250. | | CMP | aa | Compare memory to accumulator | СМР | 86 | | CMP | aaaa | Compare memory to accumulator | СМР | 257. | | СМР | aa,x | Compare memory indexed to accumulator | CMP | 4,X | | CMP | aaaa,x | Compare memory indexed to accumulator | CMP | OFFFF,X | | | | | | | Table S-1. 6500 Instruction Set Summary (contd) | MNEMONIC | OPERANDS | DESCRIPTION | EX. | AMPLE | |----------|----------|------------------------------------------------|-----|-------------| | СМР | aaaa,y | Compare memory indexed to accumulator | СМР | TAG,Y | | СМР | (aa,x) | Compare memory indexed indirect to accumulator | CMP | (255.,X) | | СМР | (aa),y | Compare memory indirect indexed to accumulator | CMP | (6F),Y | | CPX | #ii | Compare immediate and index X | CPX | <i>‡</i> 77 | | CPX | aa | Compare memory and index X | CPX | 45 | | CPX | aaaa | Compare memory and index X | CPX | 284 | | CPY | #ii | Compare immediate and index Y | CPY | #2 | | CPY | aa | Compare memory and index Y | CPY | 7 F | | CPY | aaaa | Compare memory and index Y | CPY | OFFA | | DEC | aa | Decrement memory by one | DEC | 80 | | DEC | aaaa | Decrement memory by one | DEC | TAG | | DEC | aa,x | Decrement memory indexed by one | DEC | 7F,X | | DEC | aaaa,x | Decrement memory indexed by one | DEC | 3FA,X | | DEX | | Decrement index X by one | DEX | | | DEY | | Decrement index Y by one | DEY | | | EOR | #ii | Exclusive OR immediate with accumulator | EOR | #9 | | EOR | aa | Exclusive OR memory with accumulator | EOR | OF7 | | EOR | aaaa | Exclusive OR memory with accumulator | EOR | 100 | | EOR | aa,x | Exclusive OR memory indexed with accumulator | EOR | 25,X | | EOR | aaaa,x | Exclusive OR memory indexed with accumulator | EOR | TAG,X | | EOR | aaaa,y | Exclusive OR memory indexed with accumulator | EOR | 200, Y | Table S-1. 6500 Instruction Set Summary (contd) | | | | | ,<br> | |----------|----------|-------------------------------------------------------|-----|---------| | MNEMONIC | OPERANDS | DESCRIPTION | EX. | AMPLE | | EOR | (aa,x) | Exclusive OR memory indexed indirect with accumulator | EOR | (5,X) | | EOR | (aa),y | Exclusive OR memory indirect indexed with accumulator | EOR | (OFF),Y | | INC | aa | Increment memory by one | INC | 88 | | INC | aaaa | Increment memory by one | INC | 986 | | INC | aa,x | Increment memory indexed by one | INC | 35,X | | INC | aaaa,x | Increment memory indexed by one | INC | 458,X | | INX | | Increment index X by one | INX | | | INY | | Increment index Y by one | INY | | | JMP | aaaa | Jump to new location | JMP | 6 | | JMP | (aaaa) | Jump to new location indirect | JMP | (TAG) | | JSR | aaaa | Jump to new location saving return address | JSR | 101 | | LDA | #ii | Load accumulator with immediate | LDA | #55 | | LDA | aa | Load accumulator with memory | LDA | 99 | | LDA | aaaa | Load accumulator with memory | LDA | 105 | | LDA | aa,x | Load accumulator with memory indexed | LDA | OFF,X | | LDA | aaaa,x | Load accumulator with memory indexed | LDA | TAG,X | | LDA | aaaa,y | Load accumulator with memory indexed | LDA | 3FF,Y | | LDA | (aa,x) | Load accumulator with memory indexed indirect | LDA | (ODD,X) | | LDA | (aa),y | Load accumulator with memory indirect indexed | LDA | (55),Y | | LDX | #ii | Load index X with immediate data | LDX | #123. | | LDX | aa | Load index X with memory | LDX | 255. | | LDX | aaaa | Load index X with memory | LDX | 100 | | | | | | | Table S-1. 6500 Instruction Set Summary (contd) | MNEMONIC | OPERANDS | DESCRIPTION | EXA | MPLE | |----------|----------|---------------------------------------------|-----|--------| | LDX | aa,y | Load index X with memory indexed | LDX | OAB,Y | | LDX | aaaa,y | Load index X with memory indexed | LDX | 105,Y | | LDY | #ii | Load index Y with immediate data | LDY | #34 | | LDY | aa | Load index Y with memory | LDY | OFA | | LDY | aaaa | Load index Y with memory | LDY | 555 | | LDY | aa,x | Load index Y with memory indexed | LDY | 2,X | | LDY | aaaa,x | Load index Y with memory indexed | LDY | 4F5,X | | LSR | A | Shift right accumulator one bit | LSR | A | | LSR | aa | Shift right memory one bit | LSR | 55 | | LSR | aaaa | Shift right memory one bit | LSR | 375 | | LSR | aa,x | Shift right memory indexed one bit | LSR | 41,X | | LSR | aaaa,x | Shift right memory indexed one bit | LSR | TAG,X | | NOP | | No operation | NOP | | | ORA | #ii | OR immediate with accumulator | ORA | #154. | | ORA | aa | OR memory with accumulator | ORA | OF1 | | ORA | aaaa | OR memory with accumulator | ORA | TAG1 | | ORA | aa,x | OR memory indexed with accumulator | ORA | 56,X | | ORA | aaaa,x | OR memory indexed with accumulator | ORA | 678,X | | ORA | aaaa,y | OR memory indexed with accumulator | ORA | 34,Y | | ORA | (aa,x) | OR memory indexed indirect with accumulator | ORA | (45,X) | | ORA | (aa),y | OR memory indirect indexed with accumulator | ORA | (77),Y | | PHA | | Push accumulator on stack | PHA | | | | | | | | | | | 0 ( | | | Table S-1. 6500 Instruction Set Summary (contd) | MNEMONIC | OPERANDS | DESCRIPTION | EXA | MPLE | |----------|----------|---------------------------------------------------------------|-----|---------------------------------------| | PHP | | Push processor status on stack | PHP | · · · · · · · · · · · · · · · · · · · | | PLA | | Pull accumulator from stack | PLA | | | PLP | | Pull processor status from stack | PLP | | | ROL | A | Rotate left accumulator one bit | ROL | A | | ROL | aa | Rotate left memory one bit | ROL | 23 | | ROL | aaaa | Rotate left memory one bit | ROL | OFFF | | ROL | aa,x | Rotate left memory indexed one bit | ROL | 34,X | | ROL | aaaa,x | Rotate left memory indexed one bit | ROL | TAG,X | | ROR | A | Rotate right accumulator one bit | ROR | A | | ROR | aa | Rotate right memory one bit | ROR | 63 | | ROR | aaaa | Rotate right memory one bit | ROR | 1627 | | ROR | aa,x | Rotate right memory indexed one bit | ROR | 3,X | | ROR | aaaa,x | Rotate right memory indexed one bit | ROR | OCA4,X | | RTI | | Return from interrupt | RTI | | | RTS | | Return from subroutine | RTS | | | SBC | #ii | Subtract immediate from accumulator with borrow | SBC | #OFF | | SBC | aa | Subtract memory from accumulator with borrow | SBC | 65. | | SBC | aaaa | Subtract memory from accumulator with borrow | SBC | 250 | | SBC | aa,x | Subtract memory indexed from accumulator with borrow | SBC | OED,X | | SBC | aaaa,x | Subtract memory indexed from accumulator with borrow | SBC | 1000,X | | SBC | aaaa,y | Subtract memory indexed from accumulator with borrow | SBC | 8219,Y | | SBC | (aa,x) | Subtract memory indexed indirect from accumulator with borrow | SBC | (88,X) | Table S-1. 6500 Instruction Set Summary (contd) | MNEMONIC | OPERANDS | DESCRIPTION | EXA | MPLE | |----------|----------|---------------------------------------------------------------|-----|---------------| | SBC | (aa),y | Subtract memory indirect indexed from accumulator with borrow | SBC | (ODC),Y | | SEC | | Set carry flag | SEC | | | SED | | Set decimal mode | SED | | | SEI | | Set interrupt disable status | SEI | | | STA | aa | Store accumulator in memory | STA | 2 | | STA | aaaa | Store accumulator in memory | STA | 258. | | STA | aa,x | Store accumulator in memory indexed | STA | OBA,X | | STA | aaaa,x | Store accumulator in memory indexed | STA | TAG,X | | STA | aaaa,y | Store accumulator in memory indexed | STA | 56 <b>,</b> Y | | STA | (aa,x) | Store accumulator in memory indexed indirect | STA | (65,X) | | STA | (aa),y | Store accumulator in memory indirect indexed | STA | (52),Y | | STX | aa | Store index X in memory | STX | OFF | | STX | aaaa | Store index X in memory | STX | TAG1 | | STX | aa,y | Store index X in memory indexed | STX | 79 <b>,</b> Y | | STY | aa | Store index Y in memory | STY | 45 | | STY | aaaa | Store index Y in memory | STY | 376 | | STY | aa,x | Store index Y in memory indexed | STY | 123.,X | | TAX | | Transfer accumulator to index X | TAX | | | TAY | | Transfer accumulator to index Y | TAY | | | TSX | | Transfer stack pointer to index X | TSX | | | TXA | | Transfer index X to accumulator | TXA | | | TXS | | Transfer index X to stack pointer | TXS | | | TYA | | Transfer index Y to accumulator | TYA | | # CALLING THE 6500 CROSS ASSEMBLER To call the 6500 cross assembler from the system device, enter the following command in response to the RT-11 keyboard monitor prompt: #### .RUN X6500 CR When the cross assembler responds with an asterisk (\*), it is ready to accept command string input and to perform an assembly. # TERMINATING THE 6500 CROSS ASSEMBLER If you have typed .RUN X6500 CR and received the asterisk prompt but have not yet entered the command string, you can terminate 6500 cross assembler control and return to the keyboard monitor by typing ^C If you have completed command string input and started an assembly, you can halt the assembly process at any time by typing ^C^C This returns control to the RT-11 keyboard monitor, and a system monitor prompt (.) will appear on the terminal screen. # SAMPLE 6500 ASSEMBLY LISTINGS The remainder of this supplement consists of sample output listings from the 6500 cross assembler. | 1 | | 0010 | | | , | RADIX 1 | 6 | | |----------|--------------|--------------|----------|----|----------------|------------------------|-----------------------|---------------------------------| | 2 | 0000 | | | | | ASECT | | | | 3 | | | | , | | | | | | 4 | | | | j | | DIRECT AS | SIGNMENT | OF LABELS | | 5 | | 0032 | | ţ | | PC=32 | | | | 6<br>7 | | 003E | | | | SEMI=3B | | | | 8 | | EC18 | | | | 0E1=0EC18 | } | | | 9 | | EA84 | | | | PACK=0EA8 | | | | 10 | | EB9E | | | | PHXY=0EB9 | PE | | | 11 | | EBAC | | | | PLXY=0EBA | AC . | | | 12 | | F2E1 | | | | COLO=OF2 | | | | 13 | | F321 | | | | COL1=0F3 | | | | 14 | | F361 | | | | COL2=0F3 | | | | 15<br>16 | | F3A1<br>F3E1 | | | | COL3=0F3/<br>COL4=0F3/ | | | | 17 | | A808 | | | | T2L=0A80 | | | | 18 | | 3000<br>3000 | | | | HOTON=OC | | | | 19 | | 000E | | | | MOTOFF=0 | | | | 20 | | A000 | | | | DRB=0A00 | 0 | | | 21 | | A001 | | | | DRA=0A00 | 1 | | | 22 | | A002 | | | | DDRB=0A0 | | | | 23 | | A003 | | | | DDRA=0A0 | | | | 24 | | A004 | | | | T1L=0A00 | | | | 25<br>26 | | A005<br>A007 | | | | T1CH=0A0<br>T1H=0A00 | | | | 27 | | AOOB | | | | ACR=0A00 | | | | 28 | | AOOC | | | | PCR=0A00 | | | | 29 | | AOOD | | | | IFR=0A00 | | 2 | | 30 | | 0190 | | | | .=190 | | | | 31 | 0190 | 00 | | | | SAVA: | BYTE | | | 32 | 0191 | 00 | | | | EQFL: | .BYTE | | | 33 | 0192 | 00 | | | | CRFL: | .BYTE | | | 34<br>35 | 0193<br>0194 | 00<br>00 | | | | PBPTR:<br>PBUF: | .BYTE<br>.BYTE | | | 36 | V174 | 0200 | | | | .=200 | 10116 | | | 37 | | 4200 | | | ; | , 200 | | | | 38 | | | | | ; | ENTRY & | INITIAL | IZATION | | 39 | | | | | ; | | | | | 40 | 0200 | 08 | | | PRINT: | PHP | | ISAVE PROCESSOR STATUS | | 41 | 0201 | 78 | | | | SEI | | FDISABLE INTERRUPT DURING PRINT | | 42 | | A9 | DO | ۸۸ | | LDA | ‡0D0 | | | 43<br>44 | | 8D<br>A9 | 04<br>0C | A0 | | STA<br>LDA | T1L<br>#MOTON | | | 45 | | 8D | 00 | AO | | STA | PCR | START HOTOR | | 46 | | 2C | 00 | | PR1: | BIT | DRB | FTEST LIMIT SWITCHES | | 47 | | 50 | 53 | | | BVC | RHAR | | | 49 | | 30 | F9 | | | BMI | PR1 | | | 49 | | | | | į | | | | | 50 | | | | | ; | LEFT TO | RIGHT P | RINT | | 51 | | 24 | פר | ۸٦ | ;<br> WAD+ | ico | חבסמבו | * DEDOUNCE DELAY | | 52<br>53 | | 20<br>A0 | CF<br>00 | 02 | LMAR: | JSR<br>LDY | DEBD <b>e</b> l<br>#0 | DEBOUNCE DELAY | | 54 | | но<br>20 | 00 | A0 | LM1: | BIT | DRB | | | 55 | | 10 | FB | nv | ₩11 <b>4 9</b> | BPL | LM1 | WAIT TO CLEAR MARGIN | | 56 | | A9 | 01 | | | LDA | <b>‡</b> 1 | | | 57 | | 8D | 05 | AO | | STA | TICH | START DOT RIMER(200) | | ·HAIN· | X6500 | V1.01 16-MA | Y-82 PAGE | 1-1 | | | | | |------------|--------------|-------------|------------|----------|------------|------------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 58 | 0222 | <b>P9</b> | 94 | Λ1 | LM2: | LDA | PRHE.Y | \$LOAD ₩ITH CHARACTER | | 59 | 0225 | 29 | 3F | 4. | | AND | #3F | TEORD WITH CHRENCIER | | 60 | 0227 | AA | | | | TAX | • • • | | | 61 | 0228 | A9 | 20 | | | LDA | <b>‡</b> 20 | | | 62 | 022A | 99 | 94 | 01 | | STA | PBUF,Y | FREPLACE WITH BLANK | | 63 | 022D | BD | E1 | F2 | | LDA | COLO,X | | | 64 | 0230 | 20 | A6 | 02 | | JSR | | FOUTPUT COLUMN O | | 65 | 0233 | | 21 | F3 | | LDA | COL1,X | ACTION OF THE PARTY PART | | 66<br>67 | 0236<br>0239 | 20<br>BD | A6<br>61 | 02 | | JSR | OUTDOT | FOUTPUT COLUMN 1 | | 68 | 023C | | A6 | F3<br>02 | | LDA<br>JSR | COL2,X<br>OUTDOT | FOUTPUT COLUMN 2 | | 69 | 023F | | A1 | F3 | | LDA | COL3.X | 70011 OT COLONIA 2 | | 70 | 0242 | | A6 | 02 | | JSR | OUTDOT | FOUTPUT COLUMN 3 | | 71 | 0245 | | E1 | F3 | | LDA | COL4,X | | | 72 | 0248 | | A6 | 02 | | JSR | | FOUTPUT COLUMN 4 | | 73 | 024B | A9 | 00 | | | LDA | <b>‡</b> 0 | FINSERT 1 SPACE BETWEEN CHARACTERS | | 74 | 024D | | A6 | 02 | | JSR | TOGTUG | | | 75 | 0250 | | | | | INY | | | | 76 | 0251 | | 48 | | | CPY | | ;END OF LINE? | | 77 | 0253 | 90 | CD | | | BCC | LM2 | ; IF NOT, GET MORE CHARACTERS | | 78<br>79 | | | | | ; | CV17 1 | MUTTHE | | | 80 | | | | | ;<br>; | EXIII | ROUTINE | | | 81 | | 5 A9 | FF | | PRXIT: | LDA | #0FF | | | 82 | | | 08 | 88 | INALIF | STA | T2L | | | 83 | | | 18 | EC | | JSR | DE1 | | | 84 | | | 0E | | | LDA | #HOTOFF | | | 85 | 025F | ed 80 | OC. | A0 | | STA | PCR | FMOTOR OFF | | 86 | 0262 | 28 | | | | PLP | | FRESTORE PROCESSOR STATUS | | 87 | | 3 60 | | | | RTS | | | | 88 | | | | | Ĵ | | | | | 89 | | | | | • | RIGHT | TO LEFT P | RINT | | 90 | | | 05 | | j<br>DVADA | 100 | BERREI | | | 91 | | | CF | 02 | RMAR: | JSR | DEBDEL | *DIOUT BUCKED LIVIT | | 92<br>93 | | | 47<br>00 | A0 | RM1: | LDY<br>Bit | #71.<br>DRB | RIGHT BUFFER LIMIT | | 73<br>94 | | | FB | nv | KHT. | BVC | RM1 | | | 95 | | | 01 | | | LDA | <b>#1</b> | | | 96 | | | 05 | A0 | | STA | T1CH | | | 97 | 027 | 3 B9 | 94 | 01 | | LDA | PBUF, Y | | | 98 | | | 3F | | | AND | #3F | | | 99 | | | ** | | | TAX | | | | 100 | | | 20 | | | LDA | #20 | | | 101<br>102 | | | 94<br>51 | 01 | | STA | PBUF,Y | | | 103 | | | E1<br>A6 | F3<br>02 | | lda<br>Jsr | COL4,X<br>OUTDOT | | | 104 | | | A1 | F3 | | LDA | COL3.X | | | 105 | | | A6 | 02 | | JSR | OUTDOT | | | 106 | | | 61 | F3 | | LDA | COL2,X | | | 107 | | | A6 | 02 | | JSR | OUTDOT | | | 108 | | | 21 | F3 | | LDA | COL1,X | | | 109 | | | A6 | 02 | | JSR | OUTDOT | | | 110 | | | E1 | F2 | | LDA | COLO,X | | | 11 | | | A6 | 02 | ? | JSR | OUTDOT | | | 11:<br>11: | | | 0 <b>0</b> | ^- | ) | LDA | #0<br>0UTDGT | | | 11: | | | A6 | 02 | : | JSR | OUTDOT | | | 11 | 7 UZF | 11 99 | | | | DEY | | | | 115 | 02A2 | 10 | CF | | | BPL | RM2 | • | |--------|--------------|-----|------------|----|--------------|--------|--------------|-----------------------------| | 116 | 02A4 | 30 | AF | | | BMI | | | | 117 | | • | 131 | | | DUIT | PRXIT | | | 118 | | | | | ; | | | | | 119 | | | | | j | HERE | TO OUTPUT | 1 COLUMN OF DOTS | | | 0047 | | | | <b>;</b> | | | | | 120 | 02A6 | 49 | FF | | OUTDOT: | EOR | #OFF | FINVERT FOR OUTPUT | | 121 | 02A8 | 2C | OD | A0 | OD1: | BIT | IFR | | | 122 | 02AB | 50 | FB | | | BVC | OD1 | WAIT FOR INTER-DOT TIMEOUT | | 123 | 02AD | 8D | 01 | AO | | STA | DRA | FOUTPUT DOTS | | 124 | 02B0 | A9 | 05 | | | LDA | | 1001101 0012 | | 125 | 02B2 | 8D | 07 | 44 | | | <b>#</b> 5 | | | 126 | 0285 | A9 | | A0 | | STA | T1H | LOAD INTER-DOT TIME | | 127 | | | 86 | | | LDA | <b>‡</b> 86 | | | | 0287 | 8D | 04 | AO | | STA | T1L | | | 128 | 02BA | A9 | FF | | | LDA | #OFF | | | 129 | 02BC | 2C | OD | A0 | OD2: | BIT | IFR | | | 130 | 02BF | 50 | FB | | | BVC | 0D2 | WAIT FOR DOT TIMEOUT | | 131 | 02C1 | 8D | 01 | A0 | | STA | DRA | OFF | | 132 | 0204 | A9 | 01 | | | LDA | <b>#1</b> | | | 133 | 0206 | 8D | 07 | A0 | | STA | T1H | | | 134 | 0209 | A9 | DO | | | LDA | #0D0 | | | 135 | 02CB | 8D | 04 | AO | | | | | | 136 | 02CE | 60 | V7 | HU | | STA | TIL | | | 137 | VZGL | OV. | | | | RTS | | | | | | | | | į | | | | | 138 | | | | | <del>,</del> | DELAY | ROUTINE | | | 139 | | | | | ; | | | | | 140 | 92CF | A9 | 10 | | DEBDEL: | LDA | <b>‡</b> 10 | DEBOUNCE DELAY | | 141 | 02D1 | 8D | 08 | A8 | | STA | T2L | | | 142 | 02D4 | A9 | 27 | | | LDA | <b>\$</b> 27 | | | 143 | 0296 | 4C | 18 | EC | | JMP | DE1 | | | 144 | | | | | ; | 3111 | nc 1 | | | 145 | | | | | ; | THETT | V TZATTON | SOUTTUE | | 146 | | | | | | TMT:TE | ALIZATION | KUUTINE | | 147 | 0209 | A9 | 47 | | ;<br>DDT: | | | | | 148 | | | 47 | | DRI: | LDA | <b>#71.</b> | | | | 02DB | A9 | 20 | | _ | LDA | <b>\$</b> 20 | | | 149 | 02DD | 9D | 94 | 01 | DRI1: | STA | PBUF,X | CLEAR BUFFER | | 150 | 02E0 | CA | | | | DEX | | | | 151 | 02E1 | 10 | FA | | | BPL | DRI1 | | | 152 | 02 <b>E3</b> | A9 | 00 | | | LDA | <b>‡</b> 0 | | | 153 | 02E5 | 8D | 93 | 01 | | STA | PBPTR | | | 154 | 02E8 | 8D | 92 | 01 | | STA | CRFL | | | 155 | 02EB | 8D | 91 | 01 | | | | | | 156 | 02EE | 8E | 01 | | | STA | EQFL | | | 157 | 02F1 | | | A0 | | STX | DRA | | | | | 8E | 03 | A0 | | STX | DDRA | | | 158 | 02F4 | A9 | 40 | | | LDA | <b>‡</b> 40 | | | 159 | 02F6 | 8D | OB | A0 | | STA | ACR | FT1 FREE RUN | | 160 | 02F <b>9</b> | 60 | | | | RTS | | | | 161 | | | | | <b>;</b> | | | | | 162 | | | | | ; | DRIVER | ROUTINE | | | 163 | | | | | ; | | | | | 164 | 02FA | 90 | DD | | DRIVER: | BCC | DRI | CHECK COD INTITAL TRATTON | | 165 | 02FC | 68 | | | | PLA | DUT | CHECK FOR INITIALIZATION | | 166 | 02FD | 20 | 9E | EB | | | DUVV | GET CHARACTER TO BE PRINTED | | 167 | 0300 | 8D | 90 | | | JSR | PHXY | | | 168 | 0303 | 29 | | 01 | | STA | SAVA | | | | | | 7 <b>F</b> | | | AND | #7F | | | 169 | 0305 | C9 | OD | | | CMP | #0D | CARRIAGE RETURN? | | 170 | 0307 | DO | 0E | | | BNE | DR1 | | | 4 74 4 | | | | | | | | | | 171 | 0309 | 0E | 92 | 01 | | ASL | CRFL | †YES | .MAIN. X6500 V1.01 16-MAY-82 PAGE 1-3 172 030C `90 03 BCC CR1 FLAG SET? 173 030E 20 7**A** 03 JSR PLINE FYES, PRINT LINE 174 0311 38 CR1: SEC FSET CARRY FLAG 175 0312 бE 92 01 ROR CRFL **FSET CARRIAGE RETURN FLAG** 176 0315 DO 36 BNE DRXIT 177 0317 C9 3D DR1: CMP #3D JIS THERE AN " = "? 178 0319 DO 14 BNE DR3 179 031B 0E 92 01 **ASL** CRFL FYES 180 031E 90 0E BCC BR2 181 0320 20 00 02 **JSR** PRINT FPRINT LINE 182 0323 A9 00 LDA #0 183 0325 8D 93 01 STA **PBPTR ;**ZERO BUFFER POINTER 184 0328 38 SEC 185 0329 6E 91 01 ROR EQFL FSET EQUAL FLAG 186 032C DO 1F BNE DRXIT 187 032E 0E 91 01 DR2: **ASL** EQFL CRFL NOT SET, TEST EQFL 188 0331 90 35 BCC STUFF PUT " = " IN BUFFER IF FIRST 189 0333 BO 18 BCS DRXIT FIGNORE IF SECOND 190 0335 €5 3B DR3: CMP SEMI SEMICOLON? 191 0337 DO 1B BNE DR5 192 0339 0E 92 01 ASL CRFL FYES 193 0330 ΑE 93 01 LDX PBFTR 194 033F E0 00 CPX **#12.** FSTART OF LINE? 195 0341 F0 25 REQ STUFF 196 0343 A2 1E DR4: LDX **#**30. ; NO 197 0345 EC 93 01 CPX **PBPTR** FTAB TO COLUMN 30 198 0348 90 03 BCC DRXIT 199 034A 8E 93 01 STX **PBPTR** 200 034D 20 AC EB DRXIT: JSR PLXY 201 0350 ΑD 90 01 LDA SAVA 202 0353 60 RTS 203 0354 0E 92 01 DR5: ASL CRFL ;NOT CARRIAGE RETURN, EQUAL OR SEMICOLON 204 0357 90 0F BCC STUFF ;LOAD 205 0359 **A2** 00 LDX **#12.** 206 035B EC 93 01 CPX **PBPTR** FCHECK FOR BEYOND COLUMN 12 207 035E 90 05 BCC DR6 208 0360 8E 93 01 STX **PBPTR** TAB TO COLUMN 12 209 0363 BO 03 BCS STUFF **\$LOAD** 210 0365 20 7A 03 DR6: JSR PLINE FRINT LINE 211 0368 ΑD 90 01 STUFF: LDA SAVA GET CHARACTER 212 036B AΕ 93 01 LDX **PBPTR** GET BUFFER POINTER 213 036E E0 48 CPX **‡72.** CHECK FOR FULL 214 0370 BO DB BCS DRXIT 215 0372 9D 94 01 STA PBUF,X ;NO, PUT CHARACTER IN BUFFER 216 0375 EE 93 01 INC **PBPTR** FINCREMENT FOR ANOTHER 217 0378 DO D3 BNE DRXIT 218 037A 20 00 PLINE: JSR PRINT 219 037D **A2** 00 LDX #0 220 037F **A5** 33 LDA PC+1 #PC UPPER 221 0381 20 8F 03 JSR CONVT 222 0384 A5 32 LDA PC FPC LOWER 223 0386 20 8F 03 **JSR** CONVT 224 0389 A9 OC. LDA **#12.** 225 038B 8E 93 01 STX PBPTR **FSET COLUMN POINTER** 226 038E 60 RTS ÷ ŧ HEX TO ASCII CONVERSION AND LOAD 227 228 .MAIN. X6500 V1.01 16-MAY-82 PAGE 1-4 229 038F 48 CONVT: PHA 230 0390 4A LSR A 231 0391 4A LSR A 232 0392 4A LSR A 233 0393 4A LSR A 234 0394 20 9A 03 **JSR** CONV 235 0397 88 PLA 236 0398 29 0F AND #0F 237 039A 18 CONV: CLC CLEAR CARRY FLAG 238 039B 69 30 ADC **‡**30 239 039D C9 3A CMP #3A 240 039F 90 02 BCC CONV1 241 03A1 69 06 ADC **‡**6 242 03A3 9D 94 01 CONV1: STA PBUF, X 243 03A6 E8 INX 244 03A7 60 RTS 245 0001 .END ``` SYMBOL TABLE ACR A00B DDRB = A002 DR4 0343 OUTDOT 0246 PR1 020C F2E1 DEBDEL DR5 0354 PACK = EA84 RMAR 0264 COLO 02CF COL1 F321 DE1 EC18 DR6 0365 PBPTR 0193 RM1 0269 = = COL2 F361 EQFL 0191 PBUF 0194 RM2 0273 DRA A001 COL3 F3A1 DRB IFR A00D PC 0032 SAVA 0190 A000 Ξ = = Ξ COL4 F3E1 DRI 02D9 LMAR 0213 PCR A00C SEMI 003B = = CONV 039A PHXY DRIVER 02FA LH1 0218 EB9E STUFF 0368 ``` | CONV1 | 03A3 | DRXIT | 034D | | |--------|------|-------|------|--| | CRFL | 0192 | DR1 | 0317 | | | CR1 | 0311 | DR2 | 032E | | | DDRA = | E00A | DR3 | 0335 | | | ADC | A7A0 | ۸۸ | | | V1.01 16-MAY-82 PAGE 1-5 DRI1 02DD 74 PAGES .MAIN. CONVT X6500 038F MOTOFF= 000E **HOTON** = 000C OD1 02A8 0222 PLINE 037A PLXY EBAC PRINT 0200 PRXIT 0255 T1H TIL = T2L = T1CH = **808**A A005 A007 A004 0D2 02BC 03A8 00 \* 9R2\* 0000 01 LH2 0 ERRORS DETECTED: VIRTUAL MEMORY USED: 288 WORDS ( 2 PAGES) DYNAMIC MEMORY AVAILABLE FOR \*DY1:TST65=DY1:TST65 ADDENDUM TO: The ability to reference the low and/or high byte of a word has been added to the instruction set of the EMULOGIC 6500 cross assembler. This added capability has been provided for all 8-bit immediate data instructions. A coding example is provided in the following table. | ADC<br>ADC<br>AND | #nn(L)<br>#nn(H) | Add with carry the low order byte of the immedaite data to the accumulator | ADC | #TAG(L) | |-------------------|------------------|-----------------------------------------------------------------------------|-----|---------| | | #nn(H) | | | "IAG(L) | | AND | | Add with carry the high order byte of the immediate data to the accumulator | ADC | #TAG(H) | | | #nn(L) | Logical AND the low order byte of the immediate data and the accumulator | AND | #TAG(L) | | AND | #nn(H) | Logical AND the high order byte of the immediate data and the accumulator | AND | #TAG(H) | | CMP | #nn(L) | Compare the low order byte of the immediate data with the accumulator | CMP | #TAG(L) | | CMP | #nn(H) | Compare the high order byte of the immediate data with the accumulator | | #TAG(H) | | CPX | #nn(L) | Compare the low order byte of the immediate data with Index X | | #TAG(L) | | CPX | #nn(H) | Compare the high order byte of the immediate data with Index X | | #TAG(H) | | CPY | #nn(L) | Compare the low order byte of the immediate data with Index Y | | #TAG(L) | | CPY | #nn(H) | Compare the high order byte of the immediate data with Index Y | | #TAG(H) | | EOR | #nn(L) | Exclusive OR the low order byte of the immedaite data and the accumulator | EOR | #TAG(L) | | EOR | #nn(H) | Exclusive OR the high order byte of the immediate data and the accumulator | EOR | #TAG(H) | | LDA | #nn(L) | Load the accumulator with the low order byte of the immediate data | LDA | #TAG(L) | | LDA | #nn(H) | Load the accumulator with the high order byte of the immediate data | LDA | #TAG(H) | | LDX | #nn(L) | Load Index X with the low order byte of the immediate data | | #TAG(L) | | LDX | #nn(H) | Load Index X with the high order byte of the immediate data | | #TAG(H) | | LDY | #nn(L) | Load Index Y with the low order byte of the immediate data | | #TAG(L) | | LDY | #nn(H) | Load Index Y with the high order byte of the immediate data | LDY | #TAG(H) | | ORA | #nn(L) | Logical OR the low order byte of the immediate data with the accumulator | ORA | #TAG(L) | | мугмомт | C / ODED AND | DECORIDATION | TWANE - | |---------|--------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|--------------| | | C/OPERAND | DESCRIPTION | EXAMPLE | | ORA | #nn(H) | Logical OR the high order byte of the immediate data with the accumulator | ORA #TAG(H) | | SBC | #nn(L) | Subtract the low order byte of the immediate data from the accumulator with borrow | SBC #TAG(L) | | SBC | #nn(H) | Subtract the high order byte of the immediate data from the accumulator with borrow. | SBC #TAG(H) | | TAG | = absolute refe | rence, relocatable reference, or global | reference | | to the | ing modes (for t<br>EMULOGIC 6500 cr | the ability to force absolute and absolute those intructions which it is legal) has coss assembler. The instructions for whithe table below. | been added | | MNEMONI | C/OPERAND | DESCRIPTION | EXAMPLE | | ADC | OPER | Add with carry memory to accumulator | ADC TAG(A) | | ADC | OPER,X | Add with carry memory to accumulator indexed by X | ADC TAG(A),X | | ADC | OPER,Y | Add with carry memory to accumulator indexed by Y | ADC TAG(A),Y | | AND | OPER | Logical AND memory with accumulator | AND TAG(A) | | AND | OPER,X | Logical AND memory with accumulator indexed by X | AND TAG(A),X | | AND | OPER,Y | Logical AND memory with accumulator indexed by Y | AND TAG(A),Y | | ASL | OPER | Shift left one bit (memory or accumu-lator) | ASL TAG(A) | | ASL | OPER,X | Shift left one bit (memory or accumu-lator) indexed by X | ASL TAG(A),X | | BIT | OPER | Test bits in memory with accumulator | BIT TAG(A) | | CMP | OPER | Compare memory with accumulator | CMP TAG(A) | | CMP | OPER,X | Compare memory with accumulator indexed by X | CMP TAG(A),X | | CMP | OPER,Y | Compare memory with accumulator indexed by Y | CMP TAG(A),Y | | CPX | OPER | Compare memory and index X | CPX TAG(A) | | CPY | OPER | Compare memory and index Y | CPY TAG(A) | | DEC | OPER | Decrement memory by one | DEC TAG(A) | | DEC | OPER,X | Decrement memory by one indexed by X | DEC TAG(A),X | | | | A-2 | | | MNEMONIC/OPERAND | | DESCRIPTION | EXAMPLE | | |------------------|--------|-----------------------------------------------------------|--------------|--| | EOR | OPER | Exclusive OR memory with accumulator | EOR TAG(A) | | | EOR | OPER,X | Exclusive OR memory with accumulator indexed by X | EOR TAG(A),X | | | EOR | OPER,Y | Exclusive OR memory with accumulator indexed by Y | EOR TAG(A),Y | | | INC | OPER | Increment memory by one | INC TAG(A) | | | INC | OPER,X | Increment memory by one indexed by X | INC TAG(A),X | | | JMP | OPER | Jump to new location | JMP TAG(A) | | | JSR | OPER | Jump to new location saving return address | JSR TAG(A) | | | LDA | OPER | Load the accumulator with memory | LDA TAG(A) | | | LDA | OPER,X | Load the accumulator with memory indexed by X | LDA TAG(A),X | | | LDA | OPER,Y | Load the accumulator with memory indexed by Y | LDA TAG(A),Y | | | LDX | OPER | Load Index X with memory | LDX TAG(A) | | | LDX | OPER,Y | Load Index X with memory indexed by Y | LDX TAG(A),Y | | | LDY | OPER | Load Index Y with memory | LDY TAG(A) | | | LDY | OPER,X | Load Index Y with memory indexed by X | LDY TAG(A),X | | | LSR | OPER | Shift right one bit | LSR TAG(A) | | | LSR | OPER,X | Shift right one bit indexed by X | LSR TAG(A),X | | | ORA | OPER | Logical OR memory with accumulator | ORA TAG(A) | | | ORA | OPER,X | Logical OR memory with accumulator indexed by X | ORA TAG(A),X | | | ORA | OPER,Y | Logical OR memory with accumulator indexed by Y | ORA TAG(A),Y | | | ROL | OPER | Rotate one bit left | ROL TAG(A) | | | ROL | OPER,X | Rotate one bit left indexed by X | ROL TAG(A),X | | | ROR | OPER | Rotate one bit right | ROR TAG(A) | | | ROR | OPER,X | Rotate one bit right indexed by X | ROR TAG(A),X | | | SBC | OPER | Subtract memory from accumulator with borrow | SBC TAG(A) | | | SBC | OPER,X | Subtract memory from accumulator with borrow indexed by X | SBC TAG(A),X | | | SBC | OPER,Y | Subtract memory from accumulator with borrow indexed by Y | SBC TAG(A),Y | | | STA | OPER | Store accumulator in memory | STA TAG(A) | | | | | | | | | MNEMO | NIC/OPERAND | DESCRIPTION | EXAMPLE | |-------|-------------|------------------------------------------|---------------------| | STA | OPER,X | Store accumulator in memory | STA TAG(A),X | | STA | OPER,Y | indexed by X Store accumulator in memory | STA TAG(A),Y | | STX | OPER | indexed by Y Store index X in memory | STX TAG(A) | | STY | OPER | Store index Y in memory | STY TAG(A) | | TAG | = absolute | reference, relocatable reference, | or global reference | In the preceding tables, TAG references may be one of three types. ### ABSOLUTE REFERENCE: When defining/accessing defined data, all references are resolved at assembly time and are displayed in the assembly listing. #### GLOBAL REFERENCE: When defining/accessing global data, the list file outputs a zero byte, followed by a "G". The linker will select from its symbol table the global variable and resolve the low or high byte. #### RELOCATABLE REFERENCE: When defining/accesing relocatable data, the assembler list always shows the low byte of the reference, followed by a "' mark. However, the entire relocation constant is transferred to the linker. The linker (ELINK2.SAV) will locate the actual value and select the appropriate low or high byte. The ability to force zero page and zero page indexed addressing modes has been implemented (for those instructions which it is legal). The instructions are described in the table below | tions | are described | in the table below. | | |--------|---------------|--------------------------------------------------------------|--------------| | MNEMON | IC/OPERAND | DESCRIPTION | EXAMPLE | | ADC | ZPAGE | Add with carry memory to accumulator | ADC TAG(Z) | | ADC | ZPAGE,X | Add with carry memory to accumulator indexed by X | ADC TAG(Z),X | | AND | ZPAGE | Logical AND memory with accumulator | AND TAG(Z) | | AND | ZPAGE,X | Logical AND memory with accumulator indexed by X | AND TAG(Z),X | | ASL | ZPAGE | Shift left one bit (memory or accumu-lator) | ASL TAG(Z) | | ASL | ZPAGE,X | Shift left one bit (memory or accumu-<br>lator) indexed by X | ASL TAG(Z),X | | BIT | ZPAGE | Test bits in memory with accumulator | BIT TAG(Z) | | CMP | ZPAGE | Compare memory with accumulator | CMP TAG(Z) | | CMP | ZPAGE,X | Compare memory with accumulator indexed by X | CMP TAG(Z),X | | CPX | ZPAGE | Compare memory and index X | CPX TAG(Z) | | CPY | ZPAGE | Compare memory and index Y | CPY TAG(Z) | | DEC | ZPAGE | Decrement memory by one | DEC TAG(Z) | | DEC | ZPAGE,X | Decrement memory by one indexed by X | DEC TAG(Z),X | | EOR | ZPAGE | Exclusive OR memory with accumulator | EOR TAG(Z) | | | | | | EOR INC INC LDA LDA LDX LDX LDY LDY LSR LSR ZPAGE, X ZPAGE, X ZPAGE, X ZPAGE, Y ZPAGE, X ZPAGE, X **ZPAGE** **ZPAGE** **ZPAGE** **ZPAGE** **ZPAGE** Exclusive OR memory with accumulator Increment memory by one indexed by X Load the accumulator with memory Load the accumulator with memory indexed by X indexed by X indexed by Y indexed by X indexed by X Shift right one bit A-5 Increment memory by one Load Index X with memory Load Index X with memory Load Index Y with memory Load Index Y with memory Shift right one bit with EOR TAG(Z), X INC TAG(Z), X LDA TAG(Z), X LDX TAG(Z), Y LDY TAG(Z), X LSR TAG(Z), X INC TAG(Z) LDA TAG(Z) LDX TAG(Z) LDY TAG(Z) LSR TAG(Z) | MNEMONIC/OPERAND | | DESCRIPTION | EXAMPLE | |------------------|--------------|------------------------------------------------------|--------------| | ORA | ZPAGE | Logical OR memory with accumulator | ORA TAG(Z) | | ORA | ZPAGE, X | Logical OR memory with accumulator | ORA TAG(Z),X | | ROL | ZPAGE | indexed by X<br>Rotate one bit left | ROL TAG(Z) | | ROL | ZPAGE,X | Rotate one bit left indexed by X | ROL TAG(Z),X | | ROR | ZPAGE | Rotate one bit right | ROR TAG(Z) | | ROR | ZPAGE,X | Rotate one bit right indexed by X | ROR TAG(Z),X | | SBC | ZPAGE | Subtract memory from accumulator with borrow | SBC TAG(Z) | | SBC | ZPAGE, X | Subtract memory from accumulator | SBC TAG(Z),X | | STA | ZPAGE | with borrow indexed by X Store accumulator in memory | STA TAG(Z) | | STA | ZPAGE, X | Store accumulator in memory | STA TAG(Z),X | | STX | ZPAGE | indexed by X<br>Store index X in memory | STX TAG(Z) | | STX | ZPAGE,Y | Store index X in memory indexed by Y | STX TAG(Z),Y | | STY | ZPAGE | Store index Y in memory | STY TAG(Z) | | STY | ZPAGE,X | Store index Y in memory indexed by X | STY TAG(Z),X | | TAG | = absolute r | eference, relocatable reference, or global | | TAG = absolute reference, relocatable reference, or global reference If TAG is absolute and greater than FF, an error will be indicated at assembly time. If TAG is relocatable or global and greater than FF, an error will be indicated at link time. The following lists additional information for programming with the cross assembler. - 1.) If address zero is referenced, the instruction will be assembled with the extended addressing mode instead of the direct addressing mode. To have the instruction assemble address zero as only a byte, you must use the force zero page syntax. - 2.) Addressing references in zero page must be predefined. - 3.) The use of complex forward references should be avoided as they may result in phase errors. However, when a complex forward reference is made, it can be forced absolute, thereby avoiding phasing errors. ex.) LDX TAG+3(A) where TAG is a forward reference. EMULOGIC, INC. 3 Technology Way Norwood, MA 02062-3978 Tel: (617) 329-1031 Telex: 710-336-5908 # **EMULOGIC** # 6502 User's Guide Supplement #### 6502 USER'S GUIDE SUPPLEMENT This document supplements the ECL-3211 System User's Guide by providing operational information specific to the emulation of 6502 and compatible microprocessors. This document describes special set-up procedures, conditions, and limitations to be noted when emulating the 6502. It is assumed here that the reader has read the User's Manual and is already familiar with the details of the 6502. Ready access to the technical literature is a plus. This supplement covers five general areas. - 1) Installation - 2) Initialization 3) Abbreviations (p.3) 4) Unique Features (p.7) 5) Electrical (DC) Characteristics (p.11) \*\*\* INSTALLATION \*\* System installation instructions will be found in the User's Manual. \*\*\* INITIALIZATION \* Type on the keyboard "RUN L01500" to load the Emulation Software into the ECL-3211. (The "RUN" command is discussed in the User's Guide.) Note that a user can use the Operating System's RENAME function to give the file a name the user would prefer. Additionally, a Command File can be created which can invoke L01500. There are no special initialization instructions for the 6502. \*\*\* ABBREVIATIONS \*\* #### SYSTEM DISPLAY These are seen on the top half of the display when using the Emulation Software. All of these registers and flags can be loaded with user prefered values with the SET Command or ALTER mode as described in the User Manual or HELP file. | *** | *** DESCRIPTION *** | | | | | |-----|------------------------|----|--------|------|--------| | PC | Program Counter | 16 | bits/4 | hex | digits | | X | Index Register X | 8 | bits/2 | hex | digits | | S | Status Register | 8 | bits/2 | hex | digits | | A | Accumulator | 8 | bits/2 | hex | digits | | Y | Index Register Y | 8 | bits/2 | hex | digits | | P | Stack Pointer | 8 | bits/2 | hex | digits | | N | Negative Result (Sign) | | Stat | us b | it 7 | | V | Overflow | | Stat | us b | it 6 | | - | | | | | | | В | Break | | Stat | us b | it 4 | | D | Decimal Mode (BCD) | | Stat | us b | it 3 | | I | Interrupt enable/disab | le | Stat | us b | it 2 | | Z | Zero | | Stat | us b | it l | | С | Carry | | Stat | us b | it O | TRACE DISPLAY Note: Low=0 High=1 Don't Care=X "1" and "0" refer to ELECTRICAL, NOT logical levels; though for ECL-3211 functions logical and electrical coincide. These are seen when examining the Trace. \*\*\* \*\*\* DESCRIPTION \*\*\* IQ Interrupt Request-L NM Non-Maskable Interrupt-L RS Reset-L RY Ready RD Read/Write-L SO Set Overflow BA Bus Available; generated by the ECL-3211, a "O" indicates that the Data Bus is Tristate. SY Sync | BREAKPOINT | DISPLAY | Note: Low=0 | High=1 | Don't care=X | |------------|---------|-------------|--------|--------------| | | | | | -on c care n | These are seen when examining or setting Breakpoints. | E0-E7 | Pod External Input 0-7 | |------------|--------------------------------------------------------------------------------------------| | SW1 | Logical Switch 1 | | SW2 | External Trigger l<br>Logical Switch 2<br>External Trigger 2 | | SW3<br>SW4 | Logical Switch 3 Logical Switch 4 | | ROM | ROM access; "l" means trigger on a read from an address designated as ROM. | | SYNC | SYNC; A "l" indicates the fetch of the first byte of an Op Code as a Breakpoint Condition. | | CO1<br>CO2 | "1" selects Counter 1 expired "1" selects Counter 2 expired | | ADDR | Program Counter: 16 bits | | HDDK | riogram counter, to bits | |------|--------------------------| | DATA | Data; 8 bits | | IRQ | Interrupt Request-L | | NMI | Non-Maskable Interrupt-L | | DEC | Pagat-T | | Reset-1 | |---------| | Ready | | | | READ | Read/Write-L | |------|--------------| | SO | Set Overflow | | BA | Bus | Available; | а ' | "0" | sel | lects | as | а | Breakpoint | condition | |----|-----|------------|-----|------|-----|-------|------|----|------------|-----------| | | | | th | e Da | ata | Bus | beir | 12 | Tristate. | | | PH=JMP | The | 6502 | Pod | per | forms | Phantom | Jumps | |--------|------|--------|--------|-----|--------|---------|-------| | | as a | a Brea | ak no: | int | Action | ١. | | PAGE 7 # L01500 The file name for the Emulation Software is L01500. It is accessed through the Operating System hosted by the ECL-3211's CPU. RESET The ECL-3211's RESET command resets the 6502 Pod only, and does not reset the Target. A Reset generated by the Target has effect during emulation only. ## NO TARGET Not having the 6502 Pod deployed in a target will not affect the operation of the Emulator in any way, assuming the user does not try to access resources in the Target. # MAX FREQ The maximum frequency of operation is 2 Megahertz for both Target and ECL-3211 memory. ## DEC INTERNAL The 6502 Pod cannot operate using the bank of memory termed in the User's Guide as DEC Internal. #### PHANTOMS The 6502 Pod performs Phantom Jumps. Naturally, provision must be made to return to the original code path if that is desired by the user. There are two important qualifications to their use: - 1) The instruction immediately preceding the Phantom Jump must perform a Prefetch. This means that a Phantom Jump cannot be inserted after a 2 or 3 byte intruction. - 2) The address desired as a Breakpoint condition must be defined as an address value (ADDR) rather than a Program Counter value (PC). To illustrate, consider the following examples of defining Breakpoint 4 as a Phantom Jump to address 5050: | Given | this | code | segment | ADDR<br>*** | INSTR | DATA<br>**** | |-------|------|------|---------|-------------|---------|--------------| | | | | | • | • | • | | | | | | • | • | • | | | | | | A500 | DEX | CA | | | | | | A501 | LDX OFF | A2 | | | | | | A502 | | FF | | | | | | A503 | INX | E8 | | | | | | • | • | • | | | | | | • | • | • | - a) Typing "BR 4 PH=5050/ADDR=A501" will be successful. The Phantom Jump is being inserted by the Prefetch of a single byte instruction at a location defined as ADDR rather than PC (Program Counter). - b) Typing "BR 4 PH=5050/PC=A501" will fail. The address where the Phantom Jump is intended to be inserted is defined as PC, a Program Counter value. - c) Typing "BR 4 PH=5050/ADDR=A503" will fail. The preceding instruction, LDX, is a 2 byte instruction and does not Prefetch. #### TRACE DATA CAPTURE If the Trace has been turned on, it takes a "snapshot" of conditions during each Machine Cycle when the conditions are valid. For example, the Data bus is sampled when it contains valid Data. Address information is sampled when there is a valid Address on the bus. Control signals are sampled at the same time as the Data unless they must be sampled at a different point in the Machine Cycle. (The Trace is turned on by defining a Breakpoint with conditions that will be met and an Action statement including Set Trace, as described in the User's Guide and HELP file.) Instructions are disassembled in the Trace as they appeared on the Data bus when they were fetched. Note that the External Inputs are not sampled simultaneously in a Machine Cycle. External Inputs 0-3 are sampled during the valid address time of a Machine Cycle and External Inputs 4-7 are sampled during valid data time. #### BREAKPOINT ACTION Defined Breakpoint conditions are tested and resolved prior to the end of the Machine Cycle. Any Breakpoint Actions for a Breakpoint with conditions that have been met in a Machine Cycle commence at the completion of that Machine Cycle. #### CLOCK The Emulator provides two sources of Clock signals for the 6502 Pod, the ECL-3211 and the Target circuit. Internal Clock has a guarantee of 100 Kilohertz resolution. #### --- External --- External Clock is the mode in which the Target Circuit provides the clock. Since it is buffered in the Pod with TTL logic, the clock signal must be TTL driven or equivalent. Do not clock the Pod with a Crystal/RC Network circuit. Type "FREQ EXT" to select this mode. #### --- Internal --- Internal Clock is the mode in which the 6502 Pod is clocked by the Emulator. The clocking signal taken from the Target is not used. $\emptyset$ 1 (pin 3) and $\emptyset$ 2 (pin 39) are still active. Type "FREQ xxxx" to select the Internal Clock mode. "xxxx" is the value of the frequency in units of Kilohertz. There is no need to specify "Internal" at any point. #### NOT EMULATING When the ECL-3211 is not in Emulation mode, the signals from the 6502 Pod to the Target have the following status: | A0-A15 | Active | |------------|--------------------------------------------| | DO-D7 | Tri-state | | SYNC | Active | | SO | Active | | <b>Ø</b> 2 | Active | | <b>Ø</b> 1 | Active | | <b>Ø</b> 0 | Active; ignored if Clock Internal selected | | IRQ-L | High; ignored by Pod | | NMI-L | High; ignored by Pod | | RES-L | High; ignored by Pod | | RDY | High; ignored by Pod | | R/W-L | High: ignored by Pod | Buffer 74xxx LS245 LS245 LS04 F04 LS04 LS04 LS04 LS00 LS32 LS32 LS32 LS32 LS32 Type Signal A0-A15 D0-D7 SYNC **Ø**2 $\emptyset 1$ SO **Ø**0 IRQ-L NMI-L RES-L HALT-L RDY R/W-L pull-up R ohms PAGE 11 Outr Driv High mA -15.0 -15.0 -0.4 -1.0 -0.4 -0.4 | put | |-----| | | | ve | Low mA 24.0 24.0 2.0 8.0 8.0 8.0 High mΑ 0.02 0.02 0.02 0.02 0.02 0.02 0.02 0.02 \*\*\* ELECTRICAL (DC) CHARACTERISTIC Input Load Low mΑ 0.2 -0.4 -0.4 -0.4 -0.4 -0.4 -0.4 -0.4 Delay, Termination, additional nSec typical 12 8 13 13 20 20 20 14 14 24 14 14