Changes
MOS 6502
,/* 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
|-
| PLP TAY || 28 A8 (42) || || || || || || || || || || || || N || V - || D - || I - || Z || C - || (S)↑ A → P Y || PuLl Processor statusTransfer A to Y
|-
| PLA TYA || 68 98 (42) || || || || || || || || || || || || N || - || - || - || Z || - || (S)↑ Y → A || PuLl AccumulatorTransfer 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
|-
| TYA PHP || 98 08 (23) || || || || || || || || || || || || N - || - || - || - || Z - || - || Y → A P↓ || Transfer Y to APusH Processor status
|-
| TXS PHA || 9A 48 (23) || || || || || || || || || || || || - || - || - || - || - || - || X → S A↓ || Transfer X to Stack pointerPusH Accumulator
|}
| JSR || || || 20 (6) || || || || || || || || || || - || - || - || - || - || - || PC + 2↓, [PC + 1] → PCL, [PC + 2] → PCH || Jump to SubRoutine
|-
| BRK RTS || 00 60 (76) || || || || || || || || || || || || - || - || - || 1 - || - || - || PC + 2↓, [FFFE] (S)↑ → PCL, [FFFF] (S)↑ → PCH , PC + 1 → PC || BReaKReTurn from Subroutine
|-
| RTI || 40 (6) || || || || || || || || || || || || N || V || D || I || Z || C || (S)↑ → P, (S)↑ → PCL, (S)↑ → PCH || ReTurn from Interrupt
|-
| RTS BRK || 60 00 (67) || || || || || || || || || || || || - || - || - || - 1 || - || - || (S)↑ PC + 2↓, [FFFE] → PCL, (S)↑ [FFFF] → PCH, PC + 1 → PC || ReTurn from SubroutineBReaK
|-
| CLV SEI || B8 78 (2) || || || || || || || || || || || || - || 0 || - || - || - || - || 0 → VF || CLear oVerflow flag|-| CLD || D8 (2) || || || || || || || || || || || || - || - || 0 || - 1 || - || - || 0 1 → DF IF || CLear Decimal SEt Interrupt flag
|-
| CLI || 58 (2) || || || || || || || || || || || || - || - || - || 0 || - || - || 0 → IF || CLear Interrupt flag
|-
| SEC || 38 (2) || || || || || || || || || || || || - || - || - || - || - || 1 || 1 → CF || SEt Carry flag
|-
| CLC || 18 (2) || || || || || || || || || || || || - || - || - || - || - || 0 || 0 → CF || CLear Carry flag
| SED || F8 (2) || || || || || || || || || || || || - || - || 1 || - || - || - || 1 → DF || SEt Decimal flag
|-
| SEI CLD || 78 D8 (2) || || || || || || || || || || || || - || - || - 0 || 1 - || - || - || 1 0 → IF DF || SEt Interrupt CLear Decimal flag
|-
| SEC CLV || 38 B8 (2) || || || || || || || || || || || || - || - 0 || - || - || - || 1 - || 1 0 → CF VF || SEt Carry CLear oVerflow flag
|-
| NOP || EA (2) || || || || || || || || || || || || - || - || - || - || - || - || No operation || No OPeration
|-
| BCC BPL || || || || || || || || || || || || 90 10 (2+t+p) || - || - || - || - || - || - || Branch on CF NF = 0 || Branch on Carry ClearPLus
|-
| BCS BMI || || || || || || || || || || || || B0 30 (2+t+p) || - || - || - || - || - || - || Branch on CF NF = 1 || Branch on Carry SetMInus
|-
| BEQ BVC || || || || || || || || || || || || F0 50 (2+t+p) || - || - || - || - || - || - || Branch on ZF VF = 1 0 || Branch on EQualoVerflow Clear
|-
| BMI BVS || || || || || || || || || || || || 30 70 (2+t+p) || - || - || - || - || - || - || Branch on NF VF = 1 || Branch on MInusoVerflow Set
|-
| BNE BCC || || || || || || || || || || || || D0 90 (2+t+p) || - || - || - || - || - || - || Branch on ZF CF = 0 || Branch on Not EqualCarry Clear
|-
| BPL BCS || || || || || || || || || || || || 10 B0 (2+t+p) || - || - || - || - || - || - || Branch on NF CF = 0 1 || Branch on PLusCarry Set
|-
| BVC BNE || || || || || || || || || || || || 50 D0 (2+t+p) || - || - || - || - || - || - || Branch on VF ZF = 0 || Branch on oVerflow ClearNot Equal
|-
| BVS BEQ || || || || || || || || || || || || 70 F0 (2+t+p) || - || - || - || - || - || - || Branch on VF ZF = 1 || Branch on oVerflow SetEQual
|}
|-
| ARR || || 6B (2) || || || || || || || || || N || V || - || - || Z || C || A AND oper, CF -> [76543210] -> CF || AND oper + ROR
|-
| ANC || || 0B (2) || || || || || || || || || N || - || - || - || Z || C || A AND oper, bit(7) -> CF || AND oper + set CF as ASL
|-
| ANC2 || || 2B (2) || || || || || || || || || N || - || - || - || Z || C || A AND oper, bit(7) -> CF || AND oper + set CF as ROL
|-
| SBX (AXS, SAX) || || CB (2) || || || || || || || || || N || - || - || - || Z || C || (A AND X) - oper -> X || CMP and DEX at once, sets flags like CMP
|-
| 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.