mirror of
https://github.com/MoleskiCoder/EightBit.git
synced 2025-01-20 00:29:54 +00:00
480 lines
32 KiB
Plaintext
480 lines
32 KiB
Plaintext
|
MC6809 Cycle-By-Cycle Performance
|
||
|
=================================
|
||
|
|
||
|
This document is based on Arto Salmi's work.
|
||
|
(salmiarto@gmail.com, http://koti.mbnet.fi/~atjs/mc6809/Information/6809cyc.txt). Additional information by ALeX Kazik.
|
||
|
|
||
|
This information is taken from Motorola Semiconductor Technical Data: MC6809E 8-bit microprocessing unit
|
||
|
http://www.funet.fi/pub/cbm/documents/chipdata/6809/index.html (6809-21.gif - 6809-25.gif).
|
||
|
Interrupt information is taken from HD6809E, HD68A09E, HD68B09E datasheet.
|
||
|
|
||
|
Please mail me if you find errors, something is missing etc... (salmiarto@gmail.com)
|
||
|
|
||
|
V1.0 2000-10-19 atjs first version (there must be errors)
|
||
|
V1.1 2000-11-03 atjs tabs -> spaces, clean up, now normal text file (no MS-DOS), added LEA, stack writes
|
||
|
and interrupts.
|
||
|
V1.2 2000-11-30 atjs fixed LBRA, LBSR cycles
|
||
|
|
||
|
V1.3 2015-10-21 ALeX restructured the document
|
||
|
added [,R]
|
||
|
added reset (soft- & hardware) characteristics
|
||
|
|
||
|
|
||
|
Format
|
||
|
------
|
||
|
- Cycle (1, 2, ...)
|
||
|
- Read/Write (R/W)
|
||
|
- Data Bus
|
||
|
- Address Bus
|
||
|
|
||
|
|
||
|
Address Bus
|
||
|
-----------
|
||
|
$xxxx: fixed Address
|
||
|
PC: Program Counter
|
||
|
SP: Hardware Stack Pointer (aka S)
|
||
|
US: User Stack Pointer (aka U)
|
||
|
EA: Effective Address
|
||
|
IX: Indexed Indirect Address
|
||
|
Z: Tri-Stated bus
|
||
|
|
||
|
|
||
|
########################################################
|
||
|
Immediate, Direct, Extended and Indexed Addressing Modes
|
||
|
########################################################
|
||
|
|
||
|
ASL, ASR, CLR, COM, DEC, INC, LSL, LSR, NEG, ROL, ROR
|
||
|
----------------------------|-----------------------------|-----------------------------|----------------------------
|
||
|
| Direct Addressing Mode | Extended Addressing Mode | Indexed Addressing Mode
|
||
|
----------------------------|-----------------------------|-----------------------------|----------------------------
|
||
|
| 1 R Opcode Fetch PC | 1 R Opcode Fetch PC | 1 R Opcode Fetch PC
|
||
|
| 2 R Address Low PC+1 | 2 R Address High PC+1 | 2 R Post Byte PC+1
|
||
|
| 3 R Don't Care $ffff | 3 R Address Low PC+2 | Based on Index Mode
|
||
|
| 4 R Data EA | 4 R Don't Care $ffff | ? R Data EA
|
||
|
| 5 R Don't Care $ffff | 5 R Data EA | ? R Don't Care $ffff
|
||
|
| 6 W Data EA | 6 R Don't Care $ffff | ? W Data EA
|
||
|
| | 7 W Data EA |
|
||
|
|
||
|
TST
|
||
|
----------------------------|-----------------------------|-----------------------------|----------------------------
|
||
|
| Direct Addressing Mode | Extended Addressing Mode | Indexed Addressing Mode
|
||
|
----------------------------|-----------------------------|-----------------------------|----------------------------
|
||
|
| 1 R Opcode Fetch PC | 1 R Opcode Fetch PC | 1 R Opcode Fetch PC
|
||
|
| 2 R Address Low PC+1 | 2 R Address High PC+1 | 2 R Post Byte PC+1
|
||
|
| 3 R Don't Care $ffff | 3 R Address Low PC+2 | Based on Index Mode
|
||
|
| 4 R Data EA | 4 R Don't Care $ffff | ? R Data EA
|
||
|
| 5 R Don't Care $ffff | 5 R Data EA | ? R Don't Care $ffff
|
||
|
| 6 R Don't Care $ffff | 6 R Don't Care $ffff | ? R Don't Care $ffff
|
||
|
| | 7 R Don't Care $ffff |
|
||
|
|
||
|
ADCA, ADCB, ADDA, ADDB, ANDA, ANDB, BITA, BITB, CMPA, CMPB, EORA, EORB, LDA, LDB, ORA, ORB, SBCA, SBCB, SUBA, SUBB
|
||
|
----------------------------|-----------------------------|-----------------------------|----------------------------
|
||
|
Immediate Addressing Mode | Direct Addressing Mode | Extended Addressing Mode | Indexed Addressing Mode
|
||
|
----------------------------|-----------------------------|-----------------------------|----------------------------
|
||
|
1 R Opcode Fetch PC | 1 R Opcode Fetch PC | 1 R Opcode Fetch PC | 1 R Opcode Fetch PC
|
||
|
2 R Data PC+1 | 2 R Address Low PC+1 | 2 R Address High PC+1 | 2 R Post Byte PC+1
|
||
|
| 3 R Don't Care $ffff | 3 R Address Low PC+2 | Based on Index Mode
|
||
|
| 4 R Data EA | 4 R Don't Care $ffff | ? R Data EA
|
||
|
| | 5 R Data EA |
|
||
|
|
||
|
ANDCC, ORCC
|
||
|
----------------------------|-----------------------------|-----------------------------|----------------------------
|
||
|
Immediate Addressing Mode | | |
|
||
|
----------------------------|-----------------------------|-----------------------------|----------------------------
|
||
|
1 R Opcode Fetch PC | | |
|
||
|
2 R Data PC+1 | | |
|
||
|
3 R Don't Care $ffff | | |
|
||
|
|
||
|
STA, STB
|
||
|
----------------------------|-----------------------------|-----------------------------|----------------------------
|
||
|
| Direct Addressing Mode | Extended Addressing Mode | Indexed Addressing Mode
|
||
|
----------------------------|-----------------------------|-----------------------------|----------------------------
|
||
|
| 1 R Opcode Fetch PC | 1 R Opcode Fetch PC | 1 R Opcode Fetch PC
|
||
|
| 2 R Address Low PC+1 | 2 R Address High PC+1 | 2 R Post Byte PC+1
|
||
|
| 3 R Don't Care $ffff | 3 R Address Low PC+2 | Based on Index Mode
|
||
|
| 4 W Register EA | 4 R Don't Care $ffff | ? W Register EA
|
||
|
| | 5 W Register EA |
|
||
|
|
||
|
ADDD, CMPX, SUBD
|
||
|
----------------------------|-----------------------------|-----------------------------|----------------------------
|
||
|
Immediate Addressing Mode | Direct Addressing Mode | Extended Addressing Mode | Indexed Addressing Mode
|
||
|
----------------------------|-----------------------------|-----------------------------|----------------------------
|
||
|
1 R Opcode Fetch PC | 1 R Opcode Fetch PC | 1 R Opcode Fetch PC | 1 R Opcode Fetch PC
|
||
|
2 R Data High PC+1 | 2 R Address Low PC+1 | 2 R Address High PC+1 | 2 R Post Byte PC+1
|
||
|
3 R Data Low PC+2 | 3 R Don't Care $ffff | 3 R Address Low PC+2 | Based on Index Mode
|
||
|
4 R Don't Care $ffff | 4 R Data High EA | 4 R Don't Care $ffff | ? R Data High EA
|
||
|
| 5 R Data Low EA+1 | 5 R Data High EA | ? R Data Low EA+1
|
||
|
| 6 R Don't Care $ffff | 6 R Data Low EA+1 | ? R Don't Care $ffff
|
||
|
| | 7 R Don't Care $ffff |
|
||
|
|
||
|
CMPY, CMPD, CMPS, CMPU
|
||
|
----------------------------|-----------------------------|-----------------------------|----------------------------
|
||
|
Immediate Addressing Mode | Direct Addressing Mode | Extended Addressing Mode | Indexed Addressing Mode
|
||
|
----------------------------|-----------------------------|-----------------------------|----------------------------
|
||
|
1 R Opcode Fetch PC | 1 R Opcode Fetch PC | 1 R Opcode Fetch PC | 1 R Opcode Fetch PC
|
||
|
2 R Opcode 2nd Byte PC+1 | 2 R Opcode 2nd Byte PC+1 | 2 R Opcode 2nd Byte PC+1 | 2 R Opcode 2nd Byte PC+1
|
||
|
3 R Data High PC+2 | 3 R Address Low PC+2 | 3 R Address High PC+2 | 3 R Post Byte PC+2
|
||
|
4 R Data Low PC+3 | 4 R Don't Care $ffff | 4 R Address Low PC+3 | Based on Index Mode; see Note
|
||
|
5 R Don't Care $ffff | 5 R Data High EA | 5 R Don't Care $ffff | ? R Data High EA
|
||
|
| 6 R Data Low EA+1 | 6 R Data High EA | ? R Data Low EA+1
|
||
|
| 7 R Don't Care $ffff | 7 R Data Low EA+1 | ? R Don't Care $ffff
|
||
|
| | 8 R Don't Care $ffff |
|
||
|
|
||
|
LDD, LDU, LDX
|
||
|
----------------------------|-----------------------------|-----------------------------|----------------------------
|
||
|
Immediate Addressing Mode | Direct Addressing Mode | Extended Addressing Mode | Indexed Addressing Mode
|
||
|
----------------------------|-----------------------------|-----------------------------|----------------------------
|
||
|
1 R Opcode Fetch PC | 1 R Opcode Fetch PC | 1 R Opcode Fetch PC | 1 R Opcode Fetch PC
|
||
|
2 R Register High PC+1 | 2 R Address Low PC+1 | 2 R Address High PC+1 | 2 R Post Byte PC+1
|
||
|
3 R Register Low PC+2 | 3 R Don't Care $ffff | 3 R Address Low PC+2 | Based on Index Mode
|
||
|
| 4 R Register High EA | 4 R Don't Care $ffff | ? R Register High EA
|
||
|
| 5 R Register Low EA+1 | 5 R Register High EA | ? R Register Low EA+1
|
||
|
| | 6 R Register Low EA+1 |
|
||
|
|
||
|
LDS, LDY
|
||
|
----------------------------|-----------------------------|-----------------------------|----------------------------
|
||
|
Immediate Addressing Mode | Direct Addressing Mode | Extended Addressing Mode | Indexed Addressing Mode
|
||
|
----------------------------|-----------------------------|-----------------------------|----------------------------
|
||
|
1 R Opcode Fetch PC | 1 R Opcode Fetch PC | 1 R Opcode Fetch PC | 1 R Opcode Fetch PC
|
||
|
2 R Opcode 2nd Byte PC+1 | 2 R Opcode 2nd Byte PC+1 | 2 R Opcode 2nd Byte PC+1 | 2 R Opcode 2nd Byte PC+1
|
||
|
3 R Register High PC+2 | 3 R Address Low PC+2 | 3 R Address High PC+2 | 3 R Post Byte PC+2
|
||
|
4 R Register Low PC+3 | 4 R Don't Care $ffff | 4 R Address Low PC+3 | Based on Index Mode; see Note
|
||
|
| 5 R Register High EA | 5 R Don't Care $ffff | ? R Register High EA
|
||
|
| 6 R Register Low EA+1 | 6 R Register High EA | ? R Register Low EA+1
|
||
|
| | 7 R Register Low EA+1 |
|
||
|
|
||
|
STD, STU, STX
|
||
|
----------------------------|-----------------------------|-----------------------------|----------------------------
|
||
|
| Direct Addressing Mode | Extended Addressing Mode | Indexed Addressing Mode
|
||
|
----------------------------|-----------------------------|-----------------------------|----------------------------
|
||
|
| 1 R Opcode Fetch PC | 1 R Opcode Fetch PC | 1 R Opcode Fetch PC
|
||
|
| 2 R Address Low PC+1 | 2 R Address High PC+1 | 2 R Post Byte PC+1
|
||
|
| 3 R Don't Care $ffff | 3 R Address Low PC+2 | Based on Index Mode
|
||
|
| 4 W Register High EA | 4 R Don't Care $ffff | ? W Register High EA
|
||
|
| 5 W Register Low EA+1 | 5 W Register High EA | ? W Register Low EA+1
|
||
|
| | 6 W Register Low EA+1 |
|
||
|
|
||
|
STS, STY
|
||
|
----------------------------|-----------------------------|-----------------------------|----------------------------
|
||
|
| Direct Addressing Mode | Extended Addressing Mode | Indexed Addressing Mode
|
||
|
----------------------------|-----------------------------|-----------------------------|----------------------------
|
||
|
| 1 R Opcode Fetch PC | 1 R Opcode Fetch PC | 1 R Opcode Fetch PC
|
||
|
| 2 R Opcode 2nd Byte PC+1 | 2 R Opcode 2nd Byte PC+1 | 2 R Opcode 2nd Byte PC+1
|
||
|
| 3 R Address Low PC+2 | 3 R Address High PC+2 | 3 R Post Byte PC+2
|
||
|
| 4 R Don't Care $ffff | 4 R Address Low PC+3 | Based on Index Mode; see Note
|
||
|
| 5 W Register High EA | 5 R Don't Care $ffff | ? W Register High EA
|
||
|
| 6 W Register Low EA+1 | 6 W Register High EA | ? W Register Low EA+1
|
||
|
| | 7 W Register Low EA+1 |
|
||
|
|
||
|
LEAS, LEAU, LEAX, LEAY
|
||
|
----------------------------|-----------------------------|-----------------------------|----------------------------
|
||
|
| | | Indexed Addressing Mode
|
||
|
----------------------------|-----------------------------|-----------------------------|----------------------------
|
||
|
| | | 1 R Opcode Fetch PC
|
||
|
| | | 2 R Post Byte PC+1
|
||
|
| | | Based on Index Mode
|
||
|
| | | ? R Don't Care $ffff
|
||
|
|
||
|
JMP
|
||
|
----------------------------|-----------------------------|-----------------------------|----------------------------
|
||
|
| Direct Addressing Mode | Extended Addressing Mode | Indexed Addressing Mode
|
||
|
----------------------------|-----------------------------|-----------------------------|----------------------------
|
||
|
| 1 R Opcode Fetch PC | 1 R Opcode Fetch PC | 1 R Opcode Fetch PC
|
||
|
| 2 R Address Low PC+1 | 2 R Address High PC+1 | 2 R Post Byte PC+1
|
||
|
| 3 R Don't Care $ffff | 3 R Address Low PC+2 | Based on Index Mode
|
||
|
| | 4 R Don't Care $ffff |
|
||
|
|
||
|
JSR
|
||
|
----------------------------|-----------------------------|-----------------------------|----------------------------
|
||
|
| Direct Addressing Mode | Extended Addressing Mode | Indexed Addressing Mode
|
||
|
----------------------------|-----------------------------|-----------------------------|----------------------------
|
||
|
| 1 R Opcode Fetch PC | 1 R Opcode Fetch PC | 1 R Opcode Fetch PC
|
||
|
| 2 R Address Low PC+1 | 2 R Address High PC+1 | 2 R Post Byte PC+1
|
||
|
| 3 R Don't Care $ffff | 3 R Address Low PC+2 | Based on Index Mode
|
||
|
| 4 R Don't Care EA | 4 R Don't Care $ffff | ? R Don't Care EA
|
||
|
| 5 R Don't Care $ffff | 5 R Don't Care EA | ? R Don't Care $ffff
|
||
|
| 6 W PC Low SP-1 | 6 R Don't Care $ffff | ? W PC Low SP-1
|
||
|
| 7 W PC High SP-2 | 7 W PC Low SP-1 | ? W PC High SP-2
|
||
|
| | 8 W PC High SP-2 |
|
||
|
|
||
|
|
||
|
#########################
|
||
|
Relative Addressing Modes
|
||
|
#########################
|
||
|
|
||
|
BCC, BCS, BEQ, BGE, BGT, BHI, BHS, BLE, BLO, BLS, BLT, BMI, BNE, BPL, BRA, BRN, BVC, BVS
|
||
|
---------------------------
|
||
|
1 R Opcode Fetch PC
|
||
|
2 R Offset PC+1
|
||
|
3 R Don't Care $ffff
|
||
|
|
||
|
LBCC, LBCS, LBEQ, LBGE, LBGT, LBHI, LBHS, LBLE, LBLO, LBLS, LBLT, LBMI, LBNE, LBPL, LBRN, LBVC, LBVS
|
||
|
---------------------------------------------------------------------------------------
|
||
|
1 R Opcode Fetch PC | |
|
||
|
2 R Opcode 2nd Byte PC+1 | |
|
||
|
3 R Offset High PC+2 | |
|
||
|
4 R Offset Low PC+3 | |
|
||
|
5 R Don't Care $ffff | |
|
||
|
Depends on branching | IF Branch is not taken | IF Branch is taken
|
||
|
| | 6 R Don't Care $ffff
|
||
|
|
||
|
BSR | LBSR | LBRA
|
||
|
----------------------------|-----------------------------|----------------------------
|
||
|
1 R Opcode Fetch PC | 1 R Opcode Fetch PC | 1 R Opcode Fetch PC
|
||
|
2 R Offset PC+1 | 2 R Offset High PC+1 | 2 R Offset High PC+1
|
||
|
3 R Don't Care $ffff | 3 R Offset Low PC+2 | 3 R Offset Low PC+2
|
||
|
4 R Don't Care EA | 4 R Don't Care $ffff | 4 R Don't Care $ffff
|
||
|
5 R Don't Care $ffff | 5 R Don't Care $ffff | 5 R Don't Care $ffff
|
||
|
6 W Return Addr Low SP-1 | 6 R Don't Care EA |
|
||
|
7 W Return Addr High SP-2 | 7 R Don't Care $ffff |
|
||
|
| 8 W Return Addr Low SP-1 |
|
||
|
| 9 W Return Addr High SP-2 |
|
||
|
|
||
|
#########################
|
||
|
Inherent Addressing Modes
|
||
|
#########################
|
||
|
|
||
|
ASLA, ASRA, CLRA, COMA, DECA, INCA, LSLA, LSRA, NEGA, ROLA, RORA, TSTA
|
||
|
ASLB, ASRB, CLRB, COMB, DECB, INCB, LSLB, LSRB, NEGB, ROLB, RORB, TSTB
|
||
|
DAA, NOP, SEX
|
||
|
---------------------------
|
||
|
1 R Opcode Fetch PC
|
||
|
2 R Don't Care PC+1
|
||
|
|
||
|
ABX | MUL
|
||
|
----------------------------|----------------------------
|
||
|
1 R Opcode Fetch PC | 1 R Opcode Fetch PC
|
||
|
2 R Don't Care PC+1 | 2 R Don't Care PC+1
|
||
|
3 R Don't Care $ffff | 3 R Don't Care $ffff
|
||
|
| 4 R Don't Care $ffff
|
||
|
| 5 R Don't Care $ffff
|
||
|
| 6 R Don't Care $ffff
|
||
|
| 7 R Don't Care $ffff
|
||
|
| 8 R Don't Care $ffff
|
||
|
| 9 R Don't Care $ffff
|
||
|
| 10 R Don't Care $ffff
|
||
|
| 11 R Don't Care $ffff
|
||
|
|
||
|
EXG | TFR
|
||
|
----------------------------|----------------------------
|
||
|
1 R Opcode Fetch PC | 1 R Opcode Fetch PC
|
||
|
2 R Post Byte PC+1 | 2 R Post Byte PC+1
|
||
|
3 R Don't Care $ffff | 3 R Don't Care $ffff
|
||
|
4 R Don't Care $ffff | 4 R Don't Care $ffff
|
||
|
5 R Don't Care $ffff | 5 R Don't Care $ffff
|
||
|
6 R Don't Care $ffff | 6 R Don't Care $ffff
|
||
|
7 R Don't Care $ffff |
|
||
|
8 R Don't Care $ffff |
|
||
|
|
||
|
RTS | RTI
|
||
|
----------------------------|----------------------------------------------------------------------------------------
|
||
|
1 R Opcode Fetch PC | 1 R Opcode Fetch PC | |
|
||
|
2 R Don't Care PC+1 | 2 R Don't Care PC+1 | |
|
||
|
3 R PC High SP | 3 R CCR SP | |
|
||
|
4 R PC Low SP+1 | Depends on E, see right | IF E=0 | IF E=1
|
||
|
5 R Don't Care $ffff | | 4 R PC High SP+1 | 4 R A Register SP+1
|
||
|
| | 5 R PC Low SP+2 | 5 R B Register SP+2
|
||
|
| | 6 R Don't Care $ffff | 6 R DP Register SP+3
|
||
|
| | | 7 R X Register High SP+4
|
||
|
| | | 8 R X Register Low SP+5
|
||
|
| | | 9 R Y Register High SP+6
|
||
|
| | | 10 R Y Register Low SP+7
|
||
|
| | | 11 R User Stack High SP+8
|
||
|
| | | 12 R User Stack Low SP+9
|
||
|
| | | 13 R PC High SP+10
|
||
|
| | | 14 R PC Low SP+11
|
||
|
| | | 15 R Don't Care $ffff
|
||
|
|
||
|
PSHS | PSHU | PULS | PULU
|
||
|
----------------------------|-----------------------------|-----------------------------|----------------------------
|
||
|
1 R Opcode Fetch PC | 1 R Opcode Fetch PC | 1 R Opcode Fetch PC | 1 R Opcode Fetch PC
|
||
|
2 R Post Byte PC+1 | 2 R Post Byte PC+1 | 2 R Post Byte PC+1 | 2 R Post Byte PC+1
|
||
|
3 R Don't Care $ffff | 3 R Don't Care $ffff | 3 R Don't Care $ffff | 3 R Don't Care $ffff
|
||
|
4 R Don't Care $ffff | 4 R Don't Care $ffff | 4 R Don't Care $ffff | 4 R Don't Care $ffff
|
||
|
5 R Don't Care SP | 5 R Don't Care US | PULL 0-12 Bytes (0-8 Regs) | PULL 0-12 Bytes (0-8 Regs)
|
||
|
PUSH 0-12 Bytes (0-8 Regs) | PUSH 0-12 Bytes (0-8 Regs) | ? R Register ? SP | ? R Register ? US
|
||
|
? W Register ? SP-1 | ? W Register ? US-1 | ? R Register ? SP+1 | ? R Register ? US+1
|
||
|
? W Register ? SP-2 | ? W Register ? US-2 | ? R Register ? SP+2 | ? R Register ? US+2
|
||
|
? W Register ? SP-3 | ? W Register ? US-3 | ? R ... | ? R ...
|
||
|
? W ... | ? W ... | END LOOP | END LOOP
|
||
|
END LOOP | END LOOP | ? R Don't Care SP+X | ? R Don't Care US+X
|
||
|
|
||
|
SWI | SWI2 | SWI3 | RESET (undocumented Op $3e)
|
||
|
----------------------------|-----------------------------|-----------------------------|----------------------------
|
||
|
1 R Opcode Fetch PC | 1 R Opcode Fetch PC | 1 R Opcode Fetch PC | 1 R Opcode Fetch PC
|
||
|
2 R Don't Care PC+1 | 2 R Opcode 2nd Byte PC+1 | 2 R Opcode 2nd Byte PC+1 | 2 R Don't Care PC+1
|
||
|
3 R Don't Care $ffff | 3 R Don't Care PC+2 | 3 R Don't Care PC+2 | 3 R Don't Care $ffff
|
||
|
4 W PC Low SP-1 | 4 R Don't Care $ffff | 4 R Don't Care $ffff | 4 W PC Low SP-1
|
||
|
5 W PC High SP-2 | 5 W PC Low SP-1 | 5 W PC Low SP-1 | 5 W PC High SP-2
|
||
|
6 W User Stack Low SP-3 | 6 W PC High SP-2 | 6 W PC High SP-2 | 6 W User Stack Low SP-3
|
||
|
7 W User Stack High SP-4 | 7 W User Stack Low SP-3 | 7 W User Stack Low SP-3 | 7 W User Stack High SP-4
|
||
|
8 W Y Register Low SP-5 | 8 W User Stack High SP-4 | 8 W User Stack High SP-4 | 8 W Y Register Low SP-5
|
||
|
9 W Y Register High SP-6 | 9 W Y Register Low SP-5 | 9 W Y Register Low SP-5 | 9 W Y Register High SP-6
|
||
|
10 W X Register Low SP-7 | 10 W Y Register High SP-6 | 10 W Y Register High SP-6 | 10 W X Register Low SP-7
|
||
|
11 W X Register High SP-8 | 11 W X Register Low SP-7 | 11 W X Register Low SP-7 | 11 W X Register High SP-8
|
||
|
12 W DP Register SP-9 | 12 W X Register High SP-8 | 12 W X Register High SP-8 | 12 W DP Register SP-9
|
||
|
13 W B Register SP-10 | 13 W DP Register SP-9 | 13 W DP Register SP-9 | 13 W B Register SP-10
|
||
|
14 W A Register SP-11 | 14 W B Register SP-10 | 14 W B Register SP-10 | 14 W A Register SP-11
|
||
|
15 W CC Register SP-12 | 15 W A Register SP-11 | 15 W A Register SP-11 | 15 W CC Register SP-12
|
||
|
16 R Don't Care $ffff | 16 W CC Register SP-12 | 16 W CC Register SP-12 | 16 R Don't Care $ffff
|
||
|
17 R Int. Vector High $fffa | 17 R Don't Care $ffff | 17 R Don't Care $ffff | 17 R Int. Vector High $fffe
|
||
|
18 R Int. Vector Low $fffb | 18 R Int. Vector High $fff4 | 18 R Int. Vector High $fff2 | 18 R Int. Vector Low $ffff
|
||
|
19 R Don't Care $ffff | 19 R Int. Vector Low $fff5 | 19 R Int. Vector Low $fff3 | 19 R Don't Care $ffff
|
||
|
| 20 R Don't Care $ffff | 20 R Don't Care $ffff |
|
||
|
|
||
|
CWAI | SYNC
|
||
|
----------------------------|----------------------------
|
||
|
1 R Opcode Fetch PC | 1 R Opcode Fetch PC
|
||
|
2 R CC Mask PC+1 | 2 R Don't Care PC+1
|
||
|
3 R Don't Care PC+2 | DO
|
||
|
4 R Don't Care $ffff | ? R Don't Care Z
|
||
|
5 W PC Low SP-1 | WHILE Interrupt Not Present
|
||
|
6 W PC High SP-2 | ? R Don't Care Z
|
||
|
7 W User Stack Low SP-3 |
|
||
|
8 W User Stack High SP-4 |
|
||
|
9 W Y Register Low SP-5 |
|
||
|
10 W Y Register High SP-6 |
|
||
|
11 W X Register Low SP-7 |
|
||
|
12 W X Register High SP-8 |
|
||
|
13 W DP Register SP-9 |
|
||
|
14 W B Register SP-10 |
|
||
|
15 W A Register SP-11 |
|
||
|
16 W CC Register SP-12 |
|
||
|
DO |
|
||
|
? R Don't Care $ffff |
|
||
|
WHILE Interrupt Not Present |
|
||
|
? R Int. Vector High $fffx |
|
||
|
? R Int. Vector Low $fffy |
|
||
|
? R Don't Care $ffff |
|
||
|
|
||
|
|
||
|
###################
|
||
|
Hardware Interrupts
|
||
|
###################
|
||
|
|
||
|
FIRQ | IRQ | NMI | RESET
|
||
|
----------------------------|-----------------------------|-----------------------------|----------------------------
|
||
|
1 R ? PC | 1 R ? PC | 1 R ? PC | DO
|
||
|
2 R ? PC | 2 R ? PC | 2 R ? PC | ? R Don't Care $fffe
|
||
|
3 R Don't Care $ffff | 3 R Don't Care $ffff | 3 R Don't Care $ffff | WHILE Reset Line is Low
|
||
|
4 W PC Low SP-1 | 4 W PC Low SP-1 | 4 W PC Low SP-1 | ? R Don't Care $fffe
|
||
|
5 W PC High SP-2 | 5 W PC High SP-2 | 5 W PC High SP-2 | ? R Don't Care $fffe
|
||
|
6 W CC Register SP-3 | 6 W User Stack Low SP-3 | 6 W User Stack Low SP-3 | ? R Don't Care $fffe
|
||
|
7 R Don't Care $ffff | 7 W User Stack High SP-4 | 7 W User Stack High SP-4 | ? R Int. Vector High $fffe
|
||
|
8 R Int. Vector High $fff6 | 8 W Y Register Low SP-5 | 8 W Y Register Low SP-5 | ? R Int. Vector Low $ffff
|
||
|
9 R Int. Vector Low $fff7 | 9 W Y Register High SP-6 | 9 W Y Register High SP-6 | ? R Don't Care $ffff
|
||
|
10 R Don't Care $ffff | 10 W X Register Low SP-7 | 10 W X Register Low SP-7 |
|
||
|
| 11 W X Register High SP-8 | 11 W X Register High SP-8 |
|
||
|
| 12 W DP Register SP-9 | 12 W DP Register SP-9 |
|
||
|
| 13 W B Register SP-10 | 13 W B Register SP-10 |
|
||
|
| 14 W A Register SP-11 | 14 W A Register SP-11 |
|
||
|
| 15 W CC Register SP-12 | 15 W CC Register SP-12 |
|
||
|
| 16 R Don't Care $ffff | 16 R Don't Care $ffff |
|
||
|
| 17 R Int. Vector Low $fff8 | 17 R Int. Vector Low $fffc |
|
||
|
| 18 R Int. Vector High $fff9 | 18 R Int. Vector High $fffd |
|
||
|
| 19 R Don't Care $ffff | 19 R Don't Care $ffff |
|
||
|
|
||
|
|
||
|
################################
|
||
|
Index Addressing Mode variations
|
||
|
################################
|
||
|
|
||
|
NOTE: For opcodes $10xx and $11xx cycle and PC
|
||
|
has to be increased by 1 to get correct values.
|
||
|
|
||
|
,R | [,R]
|
||
|
----------------------------|----------------------------
|
||
|
3 R Don't Care PC+2 | 3 R Don't Care PC+2
|
||
|
| 4 R Indirect High IX
|
||
|
| 5 R Indirect Low IX+1
|
||
|
| 6 R Don't Care $ffff
|
||
|
|
||
|
5n,R |
|
||
|
----------------------------|----------------------------
|
||
|
3 R Don't Care PC+2 |
|
||
|
4 R Don't Care $ffff |
|
||
|
|
||
|
8n,R | [8n,R]
|
||
|
----------------------------|----------------------------
|
||
|
3 R Offset PC+2 | 3 R Offset PC+2
|
||
|
4 R Don't Care $ffff | 4 R Don't Care $ffff
|
||
|
| 5 R Indirect High IX
|
||
|
| 6 R Indirect Low IX+1
|
||
|
| 7 R Don't Care $ffff
|
||
|
|
||
|
16n,R | [16n,R]
|
||
|
----------------------------|----------------------------
|
||
|
3 R Offset High PC+2 | 3 R Offset High PC+2
|
||
|
4 R Offset Low PC+3 | 4 R Offset Low PC+3
|
||
|
5 R Don't Care PC+4 | 5 R Don't Care PC+4
|
||
|
6 R Don't Care $ffff | 6 R Don't Care $ffff
|
||
|
7 R Don't Care $ffff | 7 R Don't Care $ffff
|
||
|
| 8 R Indirect High IX
|
||
|
| 9 R Indirect Low IX+1
|
||
|
| 10 R Don't Care $ffff
|
||
|
|
||
|
A,R / B,R | [A,R] / [B,R]
|
||
|
----------------------------|----------------------------
|
||
|
3 R Don't Care PC+2 | 3 R Don't Care PC+2
|
||
|
4 R Don't Care $ffff | 4 R Don't Care $ffff
|
||
|
| 5 R Indirect High IX
|
||
|
| 6 R Indirect Low IX+1
|
||
|
| 7 R Don't Care $ffff
|
||
|
|
||
|
D,R | [D,R]
|
||
|
----------------------------|----------------------------
|
||
|
3 R Don't Care PC+2 | 3 R Don't Care PC+2
|
||
|
4 R Don't Care PC+3 | 4 R Don't Care PC+3
|
||
|
5 R Don't Care PC+4 | 5 R Don't Care PC+4
|
||
|
6 R Don't Care $ffff | 6 R Don't Care $ffff
|
||
|
7 R Don't Care $ffff | 7 R Don't Care $ffff
|
||
|
| 8 R Indirect High IX
|
||
|
| 9 R Indirect Low IX+1
|
||
|
| 10 R Don't Care $ffff
|
||
|
|
||
|
,R+ / ,-R |
|
||
|
----------------------------|----------------------------
|
||
|
3 R Don't Care PC+2 |
|
||
|
4 R Don't Care $ffff |
|
||
|
5 R Don't Care $ffff |
|
||
|
|
||
|
,R++ / ,--R | [,R++] / [,--R]
|
||
|
----------------------------|----------------------------
|
||
|
3 R Don't Care PC+2 | 3 R Don't Care PC+2
|
||
|
4 R Don't Care $ffff | 4 R Don't Care $ffff
|
||
|
5 R Don't Care $ffff | 5 R Don't Care $ffff
|
||
|
6 R Don't Care $ffff | 6 R Don't Care $ffff
|
||
|
| 7 R Indirect High IX
|
||
|
| 8 R Indirect Low IX+1
|
||
|
| 9 R Don't Care $ffff
|
||
|
|
||
|
8n,PC | [8n,PC]
|
||
|
----------------------------|----------------------------
|
||
|
3 R Offset PC+2 | 3 R Offset PC+2
|
||
|
4 R Don't Care $ffff | 4 R Don't Care $ffff
|
||
|
| 5 R Indirect High IX
|
||
|
| 6 R Indirect Low IX+1
|
||
|
| 7 R Don't Care $ffff
|
||
|
|
||
|
16n,PC | [16n,PC]
|
||
|
----------------------------|----------------------------
|
||
|
3 R Offset High PC+2 | 3 R Offset High PC+2
|
||
|
4 R Offset Low PC+3 | 4 R Offset Low PC+3
|
||
|
5 R Don't Care PC+4 | 5 R Don't Care PC+4
|
||
|
6 R Don't Care $ffff | 6 R Don't Care $ffff
|
||
|
7 R Don't Care $ffff | 7 R Don't Care $ffff
|
||
|
8 R Don't Care $ffff | 8 R Don't Care $ffff
|
||
|
| 9 R Indirect High IX
|
||
|
| 10 R Indirect Low IX+1
|
||
|
| 11 R Don't Care $ffff
|
||
|
|
||
|
| [Addr]
|
||
|
----------------------------|----------------------------
|
||
|
| 3 R Address High PC+2
|
||
|
| 4 R Address Low PC+3
|
||
|
| 5 R Don't Care PC+4
|
||
|
| 6 R Indirect High IX
|
||
|
| 7 R Indirect Low IX+1
|
||
|
| 8 R Don't Care $ffff
|
||
|
|