Changes
MOS 6502
,/* Standard instructions */
{| class="wikitable"
|-
! Mnemonic !! Operation !! Implied !! A !! #$nn !! $nnnn !! $nnnn,X !! $nnnn,Y !! ($nnnn) !! $nn !! $nn,X !! $nn,Y !! ($nn,X) !! ($nn),Y !! $nnnn !! N !! V !! - !! B !! D !! I !! Z !! C!! Description
|-
| ADC || A + M + C → A, C || || || 69 || 6D || 7D || 79 || || 65 || 75 || || 61 || 71 || || N || V || - || - || - || - || Z || C|| Add Memory to Accumulator with Carry
|-
| AND || A ∧ M → A || || || 29 || 2D || 3D || 39 || || 25 || 35 || || 21 || 31 || || N || - || - || - || - || - || Z || -|| "AND" Memory with Accumulator
|-
| ASL || C ← /M<sub>7</sub>...M<sub>0</sub>/ ← 0 || || 0A || || 0E || 1E || || || 06 || 16 || || || || || N || - || - || - || - || - || Z || C|| Arithmetic Shift Left
|-
| BCC || Branch on C = 0 || || || || || || || || || || || || || 90 || - || - || - || - || - || - || - || -|| Branch on Carry Clear
|-
| BCS || Branch on C = 1 || || || || || || || || || || || || || B0 || - || - || - || - || - || - || - || -|| Branch on Carry Set
|-
| BEQ || Branch on Z = 1 || || || || || || || || || || || || || F0 || - || - || - || - || - || - || - || -|| Branch on Result Zero
|-
| BIT || A ∧ M, M<sub>7</sub> → N, M<sub>6</sub> → V || || || || 2C || || || || 24 || || || || || || N || V || - || - || - || - || Z || -|| Test Bits in Memory with Accumulator
|-
| BMI || Branch on N = 1 || || || || || || || || || || || || || 30 || - || - || - || - || - || - || - || -|| Branch on Result Minus
|-
| BNE || Branch on Z = 0 || || || || || || || || || || || || || D0 || - || - || - || - || - || - || - || -|| Branch on Result Not Zero
|-
| BPL || Branch on N = 0 || || || || || || || || || || || || || 10 || - || - || - || - || - || - || - || -|| Branch on Result Plus
|-
| BRK || PC + 2↓, [FFFE] → PCL, [FFFF] → PCH || 00 || || || || || || || || || || || || || - || - || - || - || - || 1 || - || -|| Break Command
|-
| BVC || Branch on V = 0 || || || || || || || || || || || || || 50 || - || - || - || - || - || - || - || -|| Branch on Overflow Clear
|-
| BVS || Branch on V = 1 || || || || || || || || || || || || || 70 || - || - || - || - || - || - || - || -|| Branch on Overflow Set
|-
| CLC || 0 → C || 18 || || || || || || || || || || || || || - || - || - || - || - || - || - || 0|| Clear Carry Flag
|-
| CLD || 0 → D || D8 || || || || || || || || || || || || || - || - || - || - || 0 || - || - || -|| Clear Decimal Mode
|-
| CLI || 0 → I || 58 || || || || || || || || || || || || || - || - || - || - || - || 0 || - || -|| Clear Interrupt Disable
|-
| CLV || 0 → V || B8 || || || || || || || || || || || || || - || 0 || - || - || - || - || - || -|| Clear Overflow Flag
|-
| CMP || A - M || || || C9 || CD || DD || D9 || || C5 || D5 || || C1 || D1 || || N || - || - || - || - || - || Z || C|| Compare Memory and Accumulator
|-
| CPX || X - M || || || E0 || EC || || || || E4 || || || || || || N || - || - || - || - || - || Z || C|| Compare Index Register X To Memory
|-
| CPY || Y - M || || || C0 || CC || || || || C4 || || || || || || N || - || - || - || - || - || Z || C|| Compare Index Register Y To Memory
|-
| DEC || M - 1 → M || || || || CE || DE || || || C6 || D6 || || || || || N || - || - || - || - || - || Z || -|| Decrement Memory By One
|-
| DEX || X - 1 → X || CA || || || || || || || || || || || || || N || - || - || - || - || - || Z || -|| Decrement Index Register X By One
|-
| DEY || Y - 1 → Y || 88 || || || || || || || || || || || || || N || - || - || - || - || - || Z || -|| Decrement Index Register Y By One
|-
| EOR || A ⊻ M → A || || || 49 || 4D || 5D || 59 || || 45 || 55 || || 41 || 51 || || N || - || - || - || - || - || Z || -|| "Exclusive OR" Memory with Accumulator
|-
| INC || M + 1 → M || || || || EE || FE || || || E6 || F6 || || || || || N || - || - || - || - || - || Z || -|| Increment Memory By One
|-
| INX || X + 1 → X || E8 || || || || || || || || || || || || || N || - || - || - || - || - || Z || -|| Increment Index Register X By One
|-
| INY || Y + 1 → Y || C8 || || || || || || || || || || || || || N || - || - || - || - || - || Z || -|| Increment Index Register Y By One
|-
| JMP || [PC + 1] → PCL, [PC + 2] → PCH || || || || 4C || || || 6C || || || || || || || - || - || - || - || - || - || - || -|| JMP Indirect
|-
| JSR || PC + 2↓, [PC + 1] → PCL, [PC + 2] → PCH || || || || 20 || || || || || || || || || || - || - || - || - || - || - || - || -|| Jump To Subroutine
|-
| LDA || M → A || || || A9 || AD || BD || B9 || || A5 || B5 || || A1 || B1 || || N || - || - || - || - || - || Z || -|| Load Accumulator with Memory
|-
| LDX || M → X || || || A2 || AE || || BE || || A6 || || B6 || || || || N || - || - || - || - || - || Z || -|| Load Index Register X From Memory
|-
| LDY || M → Y || || || A0 || AC || BC || || || A4 || B4 || || || || || N || - || - || - || - || - || Z || -|| Load Index Register Y From Memory
|-
| LSR || 0 → /M<sub>7</sub>...M<sub>0</sub>/ → C || || 4A || || 4E || 5E || || || 46 || 56 || || || || || 0 || - || - || - || - || - || Z || C|| Logical Shift Right
|-
| NOP || No operation || EA || || || || || || || || || || || || || - || - || - || - || - || - || - || -|| No Operation
|-
| ORA || A ∨ M → A || || || 09 || 0D || 1D || 19 || || 05 || 15 || || 01 || 11 || || N || - || - || - || - || - || Z || -|| "OR" Memory with Accumulator
|-
| PHA || A↓ || 48 || || || || || || || || || || || || || - || - || - || - || - || - || - || -|| Push Accumulator On Stack
|-
| PHP || P↓ || 08 || || || || || || || || || || || || || - || - || - || - || - || - || - || -|| Push Processor Status On Stack
|-
| PLA || A↑ || 68 || || || || || || || || || || || || || N || - || - || - || - || - || Z || -|| Pull Accumulator From Stack
|-
| PLP || P↑ || 28 || || || || || || || || || || || || || N || V || - || - || D || I || Z || C|| Pull Processor Status From Stack
|-
| ROL || C ← /M<sub>7</sub>...M<sub>0</sub>/ ← C || || 2A || || 2E || 3E || || || 26 || 36 || || || || || N || - || - || - || - || - || Z || C|| Rotate Left
|-
| ROR || C → /M<sub>7</sub>...M<sub>0</sub>/ → C || || 6A || || 6E || 7E || || || 66 || 76 || || || || || N || - || - || - || - || - || Z || C|| Rotate Right
|-
| RTI || P↑ PC↑ || 40 || || || || || || || || || || || || || N || V || - || - || D || I || Z || C|| Return From Interrupt
|-
| RTS || PC↑, PC + 1 → PC || 60 || || || || || || || || || || || || || - || - || - || - || - || - || - || -|| Return From Subroutine
|-
| SBC || A - M - ~C → A || || || E9 || ED || FD || F9 || || E5 || F5 || || E1 || F1 || || N || V || - || - || - || - || Z || C|| Subtract Memory from Accumulator with Borrow
|-
| SEC || 1 → C || 38 || || || || || || || || || || || || || - || - || - || - || - || - || - || 1|| Set Carry Flag
|-
| SED || 1 → D || F8 || || || || || || || || || || || || || - || - || - || - || 1 || - || - || -|| Set Decimal Mode
|-
| SEI || 1 → I || 78 || || || || || || || || || || || || || - || - || - || - || - || 1 || - || -|| Set Interrupt Disable
|-
| STA || A → M || || || || 8D || 9D || 99 || || 85 || 95 || || 81 || 91 || || - || - || - || - || - || - || - || -|| Store Accumulator in Memory
|-
| STX || X → M || || || || 8E || || || || 86 || || 96 || || || || - || - || - || - || - || - || - || -|| Store Index Register X In Memory
|-
| STY || Y → M || || || || 8C || || || || 84 || 94 || || || || || - || - || - || - || - || - || - || -|| Store Index Register Y In Memory
|-
| TAX || A → X || AA || || || || || || || || || || || || || N || - || - || - || - || - || Z || -|| Transfer Accumulator To Index X
|-
| TAY || A → Y || A8 || || || || || || || || || || || || || N || - || - || - || - || - || Z || -|| Transfer Accumulator To Index Y
|-
| TSX || S → X || BA || || || || || || || || || || || || || N || - || - || - || - || - || Z || -|| Transfer Stack Pointer To Index X
|-
| TXA || X → A || 8A || || || || || || || || || || || || || N || - || - || - || - || - || Z || -|| Transfer Index X To Accumulator
|-
| TXS || X → S || 9A || || || || || || || || || || || || || - || - || - || - || - || - || - || -|| Transfer Index X To Stack Pointer
|-
| TYA || Y → A || 98 || || || || || || || || || || || || || N || - || - || - || - || - || Z || -|| Transfer Index Y To Accumulator
|}