## **COMMON INSTRUCTIONS**

## OF THE 6800 AND 6502

BY B. T. C. TAN
Dept. of Physics
University of Singapore
Singapore 10

The 6800 and 6502 microprocessors share many common features in their architectures, instruction sets, busses, and general system philosophy. I have compiled for teaching purposes a list of their common instructions and their addressing modes. This list is used in conjunction with a programming model which shows only the two MPUs' common features (Fig. 1). The programming model has an 8-bit accumulator, index register, stack pointer and status register and a 16-bit program counter. Only 5 bits of the status register are used: carry/borrow, overflow, zero, negative and interrupt mask.



There are 43 instructions in the list (Fig. 2) common to the 6800 and 6502, which form a viable instruction set. This set is useful in the teaching of the two MPUs as well as in defining a common assembly language for them (In my microcomputer classes, I have given the name "5800" to this common microprocessor model).

| 7                         |        |         |           | -     | -   |     |
|---------------------------|--------|---------|-----------|-------|-----|-----|
|                           |        |         |           |       |     |     |
| ll .                      |        |         |           |       |     |     |
| ll .                      | IMM    | DIR     | EXT       | IMP   | REL | IND |
| ADC                       | x      | x       | x         |       |     | x   |
| AND                       | x      | x       | x         |       |     | x   |
| ASL/ASIA                  | ^      | ^       | x         | x     |     | x   |
| BCC                       |        |         |           | -     | x   |     |
| BCS                       |        |         |           |       | x   |     |
| BEQ                       |        |         |           |       | x   |     |
| BIT                       |        | x       | x         |       |     |     |
| BMI                       |        |         |           |       | x   |     |
| BNE                       |        |         |           |       | x   |     |
| BVC                       |        |         |           |       | x   |     |
| BVS<br>BPL                |        |         |           |       | x   |     |
| CIC/CLB                   |        |         |           | x     | x   |     |
| CLI                       |        |         |           | x     |     |     |
| CLV                       |        |         |           | x     |     |     |
| CMP                       | x      | x       | x         | -     |     | x   |
| CPX                       | x      | x       | х         |       |     |     |
| DEC                       |        |         | x         |       |     | х   |
| DEX                       |        |         |           | x     |     | 222 |
| EOR                       | x      | x       | x         |       |     | x   |
| INC                       |        |         | x         |       |     | х   |
| INX                       |        |         |           | x     |     |     |
| JMP                       |        |         | x         |       |     |     |
| JSR                       | - 2    | -22     | x         |       |     |     |
| LDX                       | x      | х       | x         |       |     | х   |
| ISR/ISRA                  | x      | x       | x         | ×     |     | x   |
| NOP                       |        |         | X         | x     |     | X   |
| ORA                       | x      | x       | x         | ^     |     | x   |
| PSH                       | ^      |         | ^         | x     |     | ^   |
| PUL                       |        |         |           | x     |     |     |
| ROL/ROLA                  |        |         | x         | х     |     | x   |
| ROR/RORA                  |        |         | x         | x     |     | х   |
| RTI                       |        |         |           | x     |     |     |
| RTS                       |        |         |           | x     |     |     |
| SBC                       | x      | x       | x         |       |     | x   |
| SEC/SEB                   |        |         |           | x     |     |     |
| SEI                       |        |         | -         | х     |     |     |
| STA                       |        | x       | x         |       |     | x   |
| STX                       |        | x       | х         | x     |     |     |
| TSX                       |        |         |           | x     |     |     |
| TXS                       |        |         |           | x     |     |     |
|                           |        |         |           |       |     |     |
|                           |        |         |           |       |     |     |
| Figure 2. Instruction Set |        |         |           |       |     |     |
|                           | rigure | 2. 1115 | ti uctioi | 1 261 |     |     |
|                           |        |         |           |       |     |     |

Certain points should be noted about this instruction set:

- The mnemonics used are generally those of the 6800, with the A or B accumulator specification omitted. For the 6502, PSH, PUL and SWI correspond to PHA, PLA and BRK respectively.
- There are six addressing modes: immediate, direct, extended, implied, relative and indexed, as for the 6800.
   For the 6502 direct, extended and indexed correspond to zero page, absolute and zero page indexed respectively.

- 3. The indexed mode is restricted to a zero page addressing range, with a one-byte operand and an 8-bit index register. For the 6800, "00" should be loaded into the high byte of the 16-bit index register to simulate an 8-bit index register.
- 4. The 8-bit stack pointer operates like that of the 6502; its contents are always preceded by hex 01, so that the stack is always in the range hex 0100 to 01FF. For the 6800, hex 01 should be loaded into the high byte of the 16-bit stack pointer.
- 5. The borrow bit and the SBC instruction operate differently for the 6800 and 6502. For the 6800, the borrow bit is equal to the carry bit while for the 6502 it is the inverse of the carry bit. Two "pseudo- instructions" have been added to the instruction set: clear borrow bit (CLB) and

set borrow bit (SEB). These are to be used in conjunction with the SBC instruction. For the 6800, CLB and SEB are replaced by CLC and SEC respectively, while for the 6502 the reverse is peformed, *i.e.* SEC replaces CLB and CLC replaces SEB. This enables us to add SBC to the list of common instructions.

The list and programming model have been useful to me both in teaching and writing source programs that will run on both MPUs. I have prepared for my students a more comprehensive data sheet that also gives the respective op codes for the 6800 and 6502, which I will be happy to send to interested readers (the new Motorola 6805 microcomputer, strangely enough, resembles the above model in some respects).

