Changes

MOS 6502

202 bytes added, 11 May
/* Oddities */
! ''No arg'' !! A !! #$nn !! $nnnn !! $nnnn,X !! $nnnn,Y !! ($nnnn) !! $nn !! $nn,X !! $nn,Y !! ($nn,X) !! ($nn),Y !! rel !! N !! V !! D !! I !! Z !! C
|-
| ADC BIT || || || 69 (2) || 6D 2C (4) || 7D (4+p) || 79 (4+p) || || 65 24 (3) || 75 (4) || || 61 (6) || 71 (5+p) || || N || V || - || - || Z || C - || A + M + CF , M<sub>7</sub> ANF, CF || ADd with Carry|-| SBC || || || E9 (2) || ED (4) || FD (4+p) || F9 (4+p) || || E5 (3) || F5 (4) || || E1 (M<sub>6) || F1 (5+p) || || N || V || - || - || Z || C || A - M - (1 - CF) </sub> A || SuBtract with Carry|-| CMP || || || C9 (2) || CD (4) || DD (4+p) || D9 (4+p) || || C5 (3) || D5 (4) || || C1 (6) || D1 (5+p) || || N || - || - || - || Z || C || A - M VF || CoMPare accumulatortest BITs
|-
| AND || || || 29 (2) || 2D (4) || 3D (4+p) || 39 (4+p) || || 25 (3) || 35 (4) || || 21 (6) || 31 (5+p) || || N || - || - || - || Z || - || A ∧ M → A || bitwise AND with accumulator
| ORA || || || 09 (2) || 0D (4) || 1D (4+p) || 19 (4+p) || || 05 (3) || 15 (4) || || 01 (6) || 11 (5+p) || || N || - || - || - || Z || - || A ∨ M → A || bitwise OR with Accumulator
|-
| BIT ADC || || || 69 (2) || 2C 6D (4) || 7D (4+p) || 79 (4+p) || || 24 65 (3) || 75 (4) || || 61 (6) || 71 (5+p) || || N || V || - || - || Z || - C || A + M, M<sub>7</sub> + CF NFA, M<sub>CF || ADd with Carry|-| SBC || || || E9 (2) || ED (4) || FD (4+p) || F9 (4+p) || || E5 (3) || F5 (4) || || E1 (6</sub> ) || F1 (5+p) || || N || V || - || - || Z || C || A - M - (1 - CF) VF A || SuBtract with Carry|-| CMP || || || C9 (2) || CD (4) || DD (4+p) || D9 (4+p) || || C5 (3) || D5 (4) || || C1 (6) || D1 (5+p) || || N || - || - || - || Z || C || A - M || test BITsCoMPare accumulator
|-
| CPX || || || E0 (2) || EC (4) || || || || E4 (3) || || || || || || N || - || - || - || Z || C || X - M || ComPare X register
| STY || || || 8C (4) || || || || 84 (3) || 94 (4) || || || || || - || - || - || - || - || - || Y → M || STore Y register
|-
| PHA TAX || 48 AA (32) || || || || || || || || || || || || - N || - || - || - || - Z || - || A↓ A → X || PusH AccumulatorTransfer A to X
|-
| PHP TXA || 08 8A (32) || || || || || || || || || || || || - N || - || - || - || - Z || - || P↓ X → A || PusH Processor statusTransfer X to A
|-
| PLA TAY || 68 A8 (42) || || || || || || || || || || || || N || - || - || - || Z || - || (S)↑ A A Y || PuLl AccumulatorTransfer A to Y
|-
| PLP TYA || 28 98 (42) || || || || || || || || || || || || N || V - || D - || I - || Z || C - || (S)↑ Y P A || PuLl Processor statusTransfer Y to A
|-
| TAX TSX || AA BA (2) || || || || || || || || || || || || N || - || - || - || Z || - || A S → X || Transfer A Stack pointer to X
|-
| TAY TXS || A8 9A (2) || || || || || || || || || || || || N - || - || - || - || Z - || - || A X Y S || Transfer A X to YStack pointer
|-
| TSX PLP || BA 28 (24) || || || || || || || || || || || || N || - V || - D || - I || Z || - C || (S )↑ X P || Transfer Stack pointer to XPuLl Processor status
|-
| TXA PLA || 8A 68 (24) || || || || || || || || || || || || N || - || - || - || Z || - || X (S)↑ → A || Transfer X to APuLl Accumulator
|-
| TXS PHP || 9A 08 (23) || || || || || || || || || || || || - || - || - || - || - || - || X → S P↓ || Transfer X to Stack pointerPusH Processor status
|-
| TYA PHA || 98 48 (23) || || || || || || || || || || || || N - || - || - || - || Z - || - || Y → A A↓ || Transfer Y to APusH Accumulator
|}
|-
! ''No arg'' !! #$nn !! $nnnn !! $nnnn,X !! $nnnn,Y !! ($nnnn) !! $nn !! $nn,X !! $nn,Y !! ($nn,X) !! ($nn),Y !! rel !! N !! V !! D !! I !! Z !! C
 
|-
| BCC JMP || || || 4C (3) || || || 6C (5) || || || || || || 90 (2+t+p) || - || - || - || - || - || - || Branch on CF = 0 [PC + 1] → PCL, [PC + 2] → PCH || Branch on Carry ClearJuMP
|-
| BCS JSR || || || 20 (6) || || || || || || || || || B0 (2+t+p) || - || - || - || - || - || - || Branch on CF = PC + 2↓, [PC + 1 ] → PCL, [PC + 2] → PCH || Branch on Carry SetJump to SubRoutine
|-
| BEQ RTS || 60 (6) || || || || || || || || || || || F0 (2+t+p) || - || - || - || - || - || - || Branch on ZF = (S)↑ → PCL, (S)↑ → PCH, PC + 1 → PC || Branch on EQualReTurn from Subroutine
|-
| BMI RTI || 40 (6) || || || || || || || || || || || 30 (2+t+p) || - N || - V || - D || - I || - Z || - C || Branch on NF = 1 (S)↑ → P, (S)↑ → PCL, (S)↑ → PCH || Branch on MInusReTurn from Interrupt
|-
| BNE BRK || 00 (7) || || || || || || || || || || || D0 (2+t+p) || - || - || - || - 1 || - || - || Branch on ZF = 0 PC + 2↓, [FFFE] → PCL, [FFFF] → PCH || Branch on Not EqualBReaK
|-
| BPL SEI || 78 (2) || || || || || || || || || || || 10 (2+t+p) || - || - || - || - 1 || - || - || Branch on NF = 0 1 → IF || Branch on PLusSEt Interrupt flag
|-
| BVC CLI || 58 (2) || || || || || || || || || || || 50 (2+t+p) || - || - || - || - 0 || - || - || Branch on VF = 0 → IF || Branch on oVerflow ClearCLear Interrupt flag
|-
| BVS SEC || 38 (2) || || || || || || || || || || || 70 (2+t+p) || - || - || - || - || - || - 1 || Branch on VF = 1 → CF || Branch on oVerflow SetSEt Carry flag
|-
| JMP CLC || 18 (2) || || 4C (3) || || || 6C (5) || || || || || || || - || - || - || - || - || - 0 || [PC + 1] → PCL, [PC + 2] 0 PCH CF || JuMPCLear Carry flag
|-
| JSR SED || F8 (2) || || 20 (6) || || || || || || || || || || - || - || - 1 || - || - || - || PC + 2↓, [PC + 1] → PCL, [PC + 2] PCH DF || Jump to SubRoutineSEt Decimal flag
|-
| BRK CLD || 00 D8 (72) || || || || || || || || || || || || - || - || - 0 || 1 - || - || - || PC + 2↓, [FFFE] → PCL, [FFFF] 0 PCH DF || BReaKCLear Decimal flag
|-
| RTI CLV || 40 B8 (62) || || || || || || || || || || || || N - || V 0 || D - || I - || Z - || C - || (S)↑ → P, (S)↑ → PCL, (S)↑ 0 PCH VF || ReTurn from InterruptCLear oVerflow flag
|-
| RTS NOP || 60 EA (62) || || || || || || || || || || || || - || - || - || - || - || - || (S)↑ → PCL, (S)↑ → PCH, PC + 1 → PC No operation || ReTurn from SubroutineNo OPeration
|-
| CLV BPL || B8 (2) || || || || || || || || || || || 10 (2+t+p) || - || 0 - || - || - || - || - || Branch on NF = 0 → VF || CLear oVerflow flagBranch on PLus
|-
| CLD BMI || D8 (2) || || || || || || || || || || || 30 (2+t+p) || - || - || 0 - || - || - || - || 0 → DF Branch on NF = 1 || CLear Decimal flagBranch on MInus
|-
| CLI BVC || 58 (2) || || || || || || || || || || || 50 (2+t+p) || - || - || - || 0 - || - || - || Branch on VF = 0 → IF || CLear Interrupt flagBranch on oVerflow Clear
|-
| CLC BVS || 18 (2) || || || || || || || || || || || 70 (2+t+p) || - || - || - || - || - || 0 - || 0 → CF Branch on VF = 1 || CLear Carry flagBranch on oVerflow Set
|-
| SED BCC || F8 (2) || || || || || || || || || || || 90 (2+t+p) || - || - || 1 - || - || - || - || 1 → DF Branch on CF = 0 || SEt Decimal flagBranch on Carry Clear
|-
| SEI BCS || 78 (2) || || || || || || || || || || || B0 (2+t+p) || - || - || - || 1 - || - || - || Branch on CF = 1 → IF || SEt Interrupt flagBranch on Carry Set
|-
| SEC BNE || 38 (2) || || || || || || || || || || || D0 (2+t+p) || - || - || - || - || - || 1 - || 1 → CF Branch on ZF = 0 || SEt Carry flagBranch on Not Equal
|-
| NOP BEQ || EA (2) || || || || || || || || || || || F0 (2+t+p) || - || - || - || - || - || - || No operation Branch on ZF = 1 || No OPerationBranch on EQual
|}
! ''No arg'' !! #$nn !! $nnnn !! $nnnn,X !! $nnnn,Y !! $nn !! $nn,X !! $nn,Y !! ($nn,X) !! ($nn),Y !! N !! V !! D !! I !! Z !! C
|-
| ALR DCP (ASRDCM) || || 4B || CF (26) || DF (7) || DB (7) || C7 (5) || D7 (6) || || C3 (8) || D3 (8) || || 0 N || - || - || - || Z || C || A AND oper, 0 M -> [76543210] 1 -> CF M, A - M || AND DEC oper + LSRCMP oper
|-
| ANC ISC (ISB, INS) || || || 0B EF (26) || FF (7) || FB (7) || E7 (5) || F7 (6) || || E3 (8) || || F3 (8) || N || - V || - || - || Z || C || A AND oper, bit(7) M + 1 -> M, A - M - CF -> A || AND INC oper + set CF as ASLSBC oper
|-
| ANC2 RLA || || 2B || 2F (26) || 3F (7) || 3B (7) || 27 (5) || 37 (6) || || 23 (8) || || 33 (8) || N || - || - || - || Z || C || M = CF <- [76543210] <- CF, A AND M -> A || ROL oper+ AND oper|-| RRA || || || 6F (6) || 7F (7) || 7B (7) || 67 (5) || 77 (6) || || 63 (8) || 73 (8) || N || V || - || - || Z || C || M = CF -> [76543210] -> CF, bitA + M + CF -> A, CF || ROR oper + ADC oper|-| SLO (ASO) || || || 0F (6) || 1F (7) || 1B (7) || 07 (5) || 17 (6) || || 03 (8) || 13 (8) || N || - || - || - || Z || C || M = CF <- [76543210] <- 0, A OR M -> A || ASL oper + ORA oper|-| SRE (LSE) || || || 4F (6) || 5F (7) || 5B (7) || 47 (5) || 57 (6) || || 43 (8) || 53 (8) || N || - || - || - || Z || C || M = 0 -> [76543210] -> CF , A EOR M -> A || LSR oper + EOR oper|-| LAX || || || AF (4) || || BF (4+p) || A7 (3) || || B7 (4) || A3 (6) || B3 (5+p) || N || - || - || - || Z || - || M -> A -> X || LDA oper + LDX oper|-| SAX (AXS, AAX) || || || 8F (4) || || || 87 (3) || || 97 (4) || 83 (6) || || - || - || - || - || - || - || A AND X -> M || Stores the bitwise AND of A and X|-| LAS (LAR) || || || || || BB (4+p) || || || || || || N || - || - || - || Z || - || M AND SP -> A, X, SP || LDA/TSX oper |-| TAS (XAS, SHS) || || || || || style="color: #CC0000;"|'''9B''' (5) || || || || || || - || - || - || - || - || - || A AND X -> SP, A AND X AND (H+ set CF as ROL1) -> M || Puts A AND X in SP and stores A AND X AND (high-byte of addr + 1) at addrunstable: sometimes 'AND (H+1)' is dropped, page boundary crossings may not work|-| SHA (AHX, AXA) || || || || || style="color: #CC0000;"|'''9F''' (5) || || || || || style="color: #CC0000;"|'''93''' (6) || - || - || - || - || - || - || A AND X AND (H+1) -> M || Stores A AND X AND (high-byte of addr + 1) at addrunstable: sometimes 'AND (H+1)' is dropped, page boundary crossings may not work|-| SHX (A11, SXA, XAS) || || || || || style="color: #CC0000;"|'''9E''' (5) || || || || || || - || - || - || - || - || - || X AND (H+1) -> M || Stores X AND (high-byte of addr + 1) at addrunstable: sometimes 'AND (H+1)' is dropped, page boundary crossings may not work|-| SHY (SYA, SAY) || || || || style="color: #CC0000;"|'''9C''' (5) || || || || || || || - || - || - || - || - || - || Y AND (H+1) -> M || Stores Y AND (high-byte of addr + 1) at addrunstable: sometimes 'AND (H+1)' is dropped, page boundary crossings may not work
|-
| ANE (XAA) || || style="color: #CC0000;"|'''8B''' (2) || || || || || || || || || N || - || - || - || Z || - || (A OR magic) AND X AND oper -> A || * AND X + AND oper
Turrican 3 on C64 requires a different magic constant than $EE for ANE. $EF is recommended by Groepaz (VICE team)
|-
| LXA (LAX) || || style="color: #CC0000;"|'''AB''' (2) || || || || || || || || || N || - || - || - || Z || - || (A OR magic) AND oper -> A -> X || Store * AND oper in A and X
highly unstable: involves a 'magic' constant that depends on temperature, the chip series, and maybe other factors.
 
Wizball on C64 requires a $EE magic constant for LXA
|-
| ALR (ASR) || || 4B (2) || || || || || || || || || 0 || - || - || - || Z || C || A AND oper, 0 -> [76543210] -> CF || AND oper + LSR
|-
| ARR || || 6B (2) || || || || || || || || || N || V || - || - || Z || C || A AND oper, CF -> [76543210] -> CF || AND oper + ROR
|-
| DCP (DCM) ANC || || || CF 0B (62) || DF (7) || DB (7) || C7 (5) || D7 (6) || || C3 (8) || D3 (8) || || N || - || - || - || Z || C || M - 1 A AND oper, bit(7) -> M, A - M CF || DEC AND oper + CMP operset CF as ASL
|-
| ISC ANC2 || || 2B (ISB, INS2) || || || EF (6) || FF || || || || || N || - || - || - || Z || C || A AND oper, bit(7) -> CF || FB AND oper + set CF as ROL|-| SBX (7AXS, SAX) || E7 || CB (52) || F7 || || || || || || || || N || - || - || - || Z || C || (6A AND X) - oper -> X || CMP and DEX at once, sets flags like CMP|-| E3 USBC (8SBC) || F3 || EB (82) || || || || || || || || || N || V || - || - || Z || C || M + 1 -> M, A - M - ~CF -> A || INC SBC oper + SBC operNOP
|-
| JAM (KIL, HLT) || 02, 12, 22,
B2, D2, F2 (X)
|| || || || || || || || || || - || - || - || - || - || - || Stop execution || Halt the CPU. The processor will be trapped infinitely in T1 phase with $FF on the data bus. Reset required.
|-
| LAS (LAR) || || || || || BB (4+p) || || || || || || N || - || - || - || Z || - || M AND SP -> A, X, SP || LDA/TSX oper
|-
| LAX || || || AF (4) || || BF (4+p) || A7 (3) || || B7 (4) || A3 (6) || B3 (5+p) || N || - || - || - || Z || - || M -> A -> X || LDA oper + LDX oper
|-
| LXA (LAX) || || style="color: #CC0000;"|'''AB''' (2) || || || || || || || || || N || - || - || - || Z || - || (A OR magic) AND oper -> A -> X || Store * AND oper in A and X
highly unstable: involves a 'magic' constant that depends on temperature, the chip series, and maybe other factors.
 
Wizball on C64 requires a $EE magic constant for LXA
|-
| NOP (DOP, TOP) || 1A, 3A, 5A,
74, D4, F4 (4)
|| || || || - || - || - || - || - || - || No operation || No Operation
|-
| RLA || || || 2F (6) || 3F (7) || 3B (7) || 27 (5) || 37 (6) || || 23 (8) || 33 (8) || N || - || - || - || Z || C || M = CF <- [76543210] <- CF, A AND M -> A || ROL oper + AND oper
|-
| RRA || || || 6F (6) || 7F (7) || 7B (7) || 67 (5) || 77 (6) || || 63 (8) || 73 (8) || N || V || - || - || Z || C || M = CF -> [76543210] -> CF, A + M + CF -> A, CF || ROR oper + ADC oper
|-
| SAX (AXS, AAX) || || || 8F (4) || || || 87 (3) || || 97 (4) || 83 (6) || || - || - || - || - || - || - || A AND X -> M || Stores the bitwise AND of A and X
|-
| SBX (AXS, SAX) || || CB (2) || || || || || || || || || N || - || - || - || Z || C || (A AND X) - oper -> X || CMP and DEX at once, sets flags like CMP
|-
| SHA (AHX, AXA) || || || || || style="color: #CC0000;"|'''9F''' (5) || || || || || style="color: #CC0000;"|'''93''' (6) || - || - || - || - || - || - || A AND X AND (H+1) -> M || Stores A AND X AND (high-byte of addr + 1) at addr
unstable: sometimes 'AND (H+1)' is dropped, page boundary crossings may not work
|-
| SHX (A11, SXA, XAS) || || || || || style="color: #CC0000;"|'''9E''' (5) || || || || || || - || - || - || - || - || - || X AND (H+1) -> M || Stores X AND (high-byte of addr + 1) at addr
unstable: sometimes 'AND (H+1)' is dropped, page boundary crossings may not work
|-
| SHY (SYA, SAY) || || || || style="color: #CC0000;"|'''9C''' (5) || || || || || || || - || - || - || - || - || - || Y AND (H+1) -> M || Stores Y AND (high-byte of addr + 1) at addr
unstable: sometimes 'AND (H+1)' is dropped, page boundary crossings may not work
|-
| SLO (ASO) || || || 0F (6) || 1F (7) || 1B (7) || 07 (5) || 17 (6) || || 03 (8) || 13 (8) || N || - || - || - || Z || C || M = CF <- [76543210] <- 0, A OR M -> A || ASL oper + ORA oper
|-
| SRE (LSE) || || || 4F (6) || 5F (7) || 5B (7) || 47 (5) || 57 (6) || || 43 (8) || 53 (8) || N || - || - || - || Z || C || M = 0 -> [76543210] -> CF, A EOR M -> A || LSR oper + EOR oper
|-
| TAS (XAS, SHS) || || || || || style="color: #CC0000;"|'''9B''' (5) || || || || || || - || - || - || - || - || - || A AND X -> SP, A AND X AND (H+1) -> M || Puts A AND X in SP and stores A AND X AND (high-byte of addr + 1) at addr
unstable: sometimes 'AND (H+1)' is dropped, page boundary crossings may not work
|-
| USBC (SBC) || || EB (2) || || || || || || || || || N || V || - || - || Z || C || A - M - ~CF -> A || SBC oper + NOP
|}
* Conditional jumps are only 8-bit relative. And unconditional jumps are only 16-bit absolute.
* ADC is the only command for addition. To perform an addition without carry, the carry flag must be cleared manually first. Same with SBC for subtract.
* The TXS instruction does not affect any flag, while all other transfer instructions do.* The BIT instruction copies bit 6 of the memory location to VF, regardless of any arithmetic overflow concept.* The CLV (Clear Overflow Flag) instruction exist , but not the SEV (Set Overflow Flag) instruction.
* On NMOS, INC A and DEC A instructions do not exist. They do exist on CMOS.
* The NOP instruction takes 2 full-cycles. This is the minimum amount of cycles an instruction can take. It is necessary because, while the instruction itself does nothing, it still has to increment the 16-bit PC register.
13,173
edits