# HD6805S1 MCU (Microcomputer Unit) The HD6805S1 is the 8-bit Microcomputer Unit (MCU) which contains a CPU, on-chip clock, ROM, RAM, 1/O and timer. It is designed for the user who needs an economical microcomputer with the proven capabilities of the HD 6800-based instruction set. The following are some of the hardware and software highlights of the MCU. - HARDWARE FEATURES - 8-Bit Architecture - 64 Bytes of RAM - Memory Mapped I/O - 1100 Bytes of User ROM - Internal 8-Bit Timer with 7-Bit Prescaler - Vectored Interrupts External and Timer - 20 TTL/CMOS Compatible I/O Lines; 8 Lines LED Compatible - On-Chip Clock Circuit - Self-Check Mode - Master Reset - Low Voltage Inhibit - Easy for System Development and Debugging - 5 Vdc Single Supply - Compatible with MC6805P2 - SOFTWARE FEATURES - Similar to HD6800 - **Byte Efficient Instruction Set** - Easy to Program - True Bit Manipulation - Bit Test and Branch Instructions - Versatile Interrupt Function - Powerful Indexed Addressing for Tables - **Full Set of Conditional Branches** - Memory Usable as Registers/Flags - Single Instruction Memory Examine/Change - 10 Powerful Addressing Modes - All Addressing Modes Apply to ROM, RAM and I/O - Compatible with MC6805P2 ## **PIN ARRANGEMENT** ## - ABSOLUTE MAXIMUM RATINGS | Symbol | Value | Unit | |---------------------|--------------|-------------------------------------------------------| | <del></del> | -0.3 ~ +7.0 | | | , , , , | -0.3 ~ +7.0 | | | - V <sub>in</sub> " | -0.3 ~ +12.0 | | | Too | 0 ~+70 | °C | | T <sub>sto</sub> | - 55 ~ +150 | °C | | | T opr | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$ | With respect to V<sub>SS</sub> (SYSTEM GND) (NOTE) Permanent LSI damage may occur if maximum ratings are exceeded. Normal operation should be under recommended operating conditions. If these conditions are exceeded, it could affect reliability of LSI. ## **ELECTRICAL CHARACTERISTICS** # DC CHARACTERISTICS (V<sub>CC</sub>=5.25V ± 0.5V, V<sub>SS</sub>=GND, Ta=0~+70°C, unless otherwise noted.) | lten | n | Symbol | Test Condition | min | typ | max | Unit | |--------------------------------------|---------------------|-----------------|---------------------------------------|-------|----------|-----------------|-------------| | 1000 | RES | | | 4.0 | | V <sub>CC</sub> | ٧ | | Input "High" Voltage | INT | | | 3.0 | | Vcc | V | | mpat rugh voltage | All Other | V <sub>IH</sub> | | 2.0 | _ | V <sub>CC</sub> | V | | | Timer Mode | | | 2.0 | | Vcc | V | | Input "High" Voltage(Timer) | Self-Check Mode | | | 9.0 | | 11.0 | V | | | RES | | | -0.3 | | 0.8 | V | | | INT | V <sub>1L</sub> | | -0.3 | | 0.8 | + | | Input "Low" Voltage | EXTAL(Crystal Mode) | V <sub>1L</sub> | | -0.3 | | 0.6 | <del></del> | | | All Other | | | -0.3 | | 0.8 | ļ | | Power Dissipation | | PD | | | | 700 | mΨ | | Low Voltage Recover | | LVR | | | | 4.75 | | | | | LVI | | i - | 4.0 | _ | V | | LOW VOILAGE HUNDIT | TIMER | | | -20 | ] - | 20 | μΑ | | ow Voltage Inhibit put Leak Current | ĪNĪ | I <sub>IL</sub> | V <sub>in</sub> =0.4V~V <sub>CC</sub> | -50 | T- | 50 | μΑ | | | EXTAL(Crystal Mode) | 4 | | -1200 | <b>-</b> | 0 | μА | # ullet AC CHARACTERISTICS (V<sub>CC</sub>=5.25V $\pm$ 0.5V, V<sub>SS</sub>=GND, Ta=0 $\sim$ +70 $^{\circ}$ C, unless otherwise noted.) | | Item | Symbol | Test Condition | min | typ | max | Unit | |-----------------------------|-----------------------|-------------------|--------------------------------------------------|---------------------------|---------|----------|-------| | S) | T(CIII) | fcI | | 0.4 | Τ- | 4.0 | МН | | Clock Frequency | | | | 1.0 | 1 - | 10 | μs | | Cycle Time | | t <sub>cyc</sub> | D 45 01 (2) (40) | <del> </del> | 3.4 | <u> </u> | МН | | Oscillation Frequency (Ex | ternal Resistor Mode) | fEXT | R <sub>CP</sub> =15.0k\2±1% | | 3.4 | | 14111 | | INT Pulse Width | | t <sub>IWL</sub> | | t <sub>cyc</sub> +<br>250 | | _ | ns | | RES Pulse Width | | tRWL | | t <sub>cyc</sub> +<br>250 | | _ | ns | | TIMER Pulse Width | | t <sub>TWL</sub> | | t <sub>cyc</sub> +<br>250 | - | _ | ns | | Oscillation Start-up Time ( | Crystal Mode) | tosc | $C_L = 22pF \pm 20\%$ ,<br>$R_S = 60\Omega$ max. | | <u></u> | 100 | ms | | Delay Time Reset | | t <sub>RHL</sub> | External Cap. = 2.2 µF | 100 | ]= | | ms | | | XTAL | _ | | - | | 30 | pF | | Input Capacitance | | — C <sub>in</sub> | V <sub>in</sub> =0V | _ | _ | 10 | pF | | , | All Other | | <u> </u> | | | | | ● PORT ELECTRICAL CHARACTERISTICS (V<sub>CC</sub> = 5.25V ± 0.5V, V<sub>SS</sub> = GND, Ta = 0 ~ +70°C, unless otherwise noted.) | • . | | T | | ···· | | 1 | <del></del> | | |-----------------------|--------------|-----------------|------------------------------------------|------------------------|------|-----|-------------|----| | Item | | Symbol | Test Condition | min | typ | max | Unit | | | | Port A | | I <sub>OH</sub> = -10 μA | 3.5 | | | V | | | | TOTCA | ] | I <sub>OH</sub> = -100 μA | 2.4 | _ | - | V | | | Output "High" Voltage | Port B | V <sub>OH</sub> | $I_{OH} = -200 \mu A$ | 2.4 | _ | - | V | | | | FOICE | | I <sub>OH</sub> = -1 mA | 1.5 | | _ | V | | | | Port C | | I <sub>OH</sub> = -100 μA | 2.4 | _ | _ | V | | | Output "Low" Voltage | Port A and C | | I <sub>OL</sub> = 1.6 mA | | | 0.4 | V | | | | Port B | VoL | I <sub>OL</sub> = 3.2 mA | | - | 0.4 | V | | | | TOTEB | | I <sub>OL</sub> = 10 mA | | _ | 1.0 | V | | | Input "High" Voltage | B A B C | ViH | | 2.0 | _ | Vcc | V | | | Input "Low" Voltage | Port A, B, C | VIL | | -0.3 | _ | 0.8 | V | | | | Port A | 115 | - IL | V <sub>in</sub> = 0.8V | -500 | _ | _ | μА | | put Leak Current | Port A | | V <sub>in</sub> = 2V | -300 | - | - | μΑ | | | | Port B, C | | V <sub>in</sub> = 0.4V ~ V <sub>CC</sub> | - 20 | _ | 20 | μА | | (NOTE) 1. Load capacitance includes the floating capacitance of the probe and the jig etc. 2. All diodes are 1S2074 (P) or equivalent. Figure 1 Bus Timing Test Loads ## ■ SIGNAL DESCRIPTION The input and output signals for the MCU, shown in PIN ARRANGEMENT, are described in the following paragraphs. ## VCC and Vss Power is supplied to the MCU using these two pins. VCC is +5.25 V ±0.5 V. VSS is the ground connection. ## • <u>IN</u>7 This pin provides the capability for asynchronously applying an external interrupt to the MCU. Refer to INTERRUPTS for additional information. ## XTAL and EXTAL These pins provide connections for the on-chip clock circuit. A crystal (AT cut, 4 MHz maximum), a resistor or an external signal can be connected to these pins to provide a system clock with various stability/cost tradeoffs. Refer to INTERNAL OS-CILLATOR OPTIONS for recommendations about these inputs. ## TIMER This pin allows an external input to be used to decrement the internal timer circuitry. Refer to TIMER for additional information about the timer circuitry. ## • RES This pin allows resetting of the MCU at times other than the automatic resetting capability already in the MCU. Refer to RESETS for additional information. ## NUM This pin is not for user application and should be connected to $V_{\text{SS}}$ . ## Input/Output Lines (A<sub>0</sub> ~ A<sub>7</sub>, B<sub>0</sub> ~ B<sub>7</sub>, C<sub>0</sub> ~ C<sub>3</sub>) These 20 lines are arranged into two 8-bit ports (A and B) and one 4-bit port (C). All lines are programmable as either inputs or outputs under software control of the Data Direction Registers (DDR). Refer to INPUT/OUTPUT for additional information. ### MEMORY The MCU memory is configured as shown in Figure 2. During the processing of an interrupt, the contents of the CPU registers are pushed onto the stack in the order shown in Figure 3. Since the stack pointer decrements during pushes, the low order byte (PCL) of the program counter is stacked first; then the high order three bits (PCH) are stacked. This ensures that the program counter is loaded correctly as the stack pointer increments when it pulls data from the stack: A subroutine call will cause only the program counter (PCH, PCL) contents to be pushed onto the stack. Caution: - Self Test ROM Address Area Self test ROM locations can not be used for a user program. If the user's program is in this location, it will be removed when manufacturing mask for production. Figure 2 MCU Memory Configuration For subroutine calls, only PCH and PCL are stacked Figure 3 Interrupt Stacking Order Figure 4 Programming Model ### REGISTERS The CPU has five registers available to the programmer. They are shown in Figure 4 and are explained in the following paragraphs. ## Accumulator (A) The accumulator is a general purpose 8-bit register used to hold operands and results of arithmetic calculations or data manipulations. ### Index Register (X) The index register is an 8-bit register used for the indexed addressing mode. It contains an 8-bit address that may be added to an offset value to create an effective address. The index register can also be used for limited calculations and data manipulations when using read/modify/write instructions. When not required by a code sequence being executed, the index register can be used as a temporary storage area. ### Program Counter (PC) The program counter is an 11-bit register that contains the address of the next instruction to be executed. #### Stack Pointer (SP) The stack pointer is an 11-bit register that contains the address of the next free location on the stack. Initially, the stack pointer is set to location \$07F and is decremented as data is being pushed onto the stack and incremented as data is being pulled from the stack. The six most significant bits of the stack pointer are permanently set to 000011. During a MCU reset or the reset stack pointer (RSP) instruction, the stack pointer is set to location \$07F. Subroutines and interrupts may be nested down to location \$061 which allows the programmer to use up to 15 levels of subroutine calls. ### Condition Code Register (CC) The condition code register is a 5-bit register in which each bit is used to indicate or flag the results of the instruction just executed. These bits can be individually tested by a program and specific action taken as a result of their state. Each individual condition code register bit is explained in the following paragraphs. ## Half Carry (H) Used during arithmetic operations (ADD and ADC) to indicate that a carry occurred between bits 3 and 4. Interrupt (1) This bit is set to mask the timer and external interrupt (INT). If an interrupt occurs while this bit is set it is latched and will be processed as soon as the interrupt bit is reset. #### Negative (N) Used to indicate that the result of the last arithmetic, logical or data manipulation was negative (bit 7 in result equal to a logical one). #### Zero (Z) Used to indicate that the result of the last arithmetic, logical or data manipulation was zero. ## Carry/Borrow (C) Used to indicate that a carry or borrow out of the arithmetic logic unit (ALU) occurred during the last arithmetic operation. This bit is also affected during bit test and branch instructions, shifts, and rotates. #### TIMER The MCU timer circuitry is shown in Figure 5. The 8-bit counter, the Timer Data Register (TDR), is loaded under program control and counts down toward zero as soon as the clock input is applied. When the timer reaches zero, the timer interrupt request bit (bit 7) in the Timer Control Register (TCR) is set, the CPU responds to this interrupt by saving the present CPU state on the stack, fetching the timer interrupt vector from locations \$7F8 and \$7F9 and executing the interrupt routine. The timer interrupt can be masked by setting the timer interrupt mask bit (bit 6) in the TCR. The interrupt bit (I bit) in the Condition Code Register also prevents a time interrupt from being processed. The clock input to the timer can be from an external source applied to the TIMER input pin or it can be the internal $\phi_2$ signal. When the internal $\phi_2$ signal is selected as the input source, the node a is connected to b (see Fig. 5). In case of the external source, the node b connects with c. Figure 5 Timer Block Diagram When the $\phi_2$ signal is used as the source, the clock signal is input to the prescaler while the TIMER input is "High". The source of the clock input is one of the options that has to be specified before manufacture of the MCU. A prescaler option can be applied to the clock input that extends the timing interval up to a maximum of 128 counts before decrementing the counter (TDR). The timer continues to count past zero, falling through to \$FF from zero and then continuing the count. Thus, the counter (TDR) can be read at any time by monitoring the TDR. This allows a program to determine the length of time since a timer interrupt has occurred and not disturb the counting process. At power-up or reset, the prescaler and counter are initialized with all logical ones; the timer interrupt request bit (bit 7) is cleared, and the timer interrupt mask bit (bit 6) is set. (NOTE) If the MCU Timer is not used, the TIMER input pin must be grounded. ## ■ SELF CHECK The self-check capability of the MCU provides an internal check to determine if the part is functional. Connect the MCU as shown in Figure 6 and monitor the output of port C bit 3 for an oscillation of approximately 3Hz. ROM, RAM, TIMER, Interrupts, I/O of Port A, B and C are checked by this capability. • RESETS The MCU can be reset three ways; by initial power-up, by the external reset input (RES) and by an optional internal low voltage inhibit circuit, see Figure 7. All the I/O port are initialized to input mode (DDRs are cleared) during reset. During power-up, a minimum of 100 milliseconds is needed before allowing the RES input to go "High". This time allows the internal crystal oscillator to stabilize. Connecting a capacitor to the RES input, as shown in Figure 8, typically provides sufficient delay. \* Refer to Figure 9 about crystal option Figure 7 Power Up and RES Timing Figure 8 Power Up Reset Delay Circuit ## **■ INTERNAL OSCILLATOR OPTIONS** The internal oscillator circuit is designed to require a minimum of external components. A crystal, a resistor, a jumper wire, or an external signal may be used to generate a system clock with various stability/cost tradeoff. A manufacturing mask option is required to select either the crystal oscillator or the RC oscillator circuit. The different connection methods are shown in Figure 9. Crystal specifications are given in Figure 10. A resistor selection graph is given in Figure 11. Figure 9 Internal Oscillator Options Figure 11 Typical Resistor Selection Graph Figure 12 Interrupt Processing Flowchart ### INTERRUPTS The CPU can be interrupted three different ways: through the external interrupt (INT) input pin, the internal timer interrupt request, and a software interrupt instruction (SWI). When any interrupt occurs, processing is suspended, the present CPU state is pushed onto the stack, the interrupt bit (I) in the Condition Code Register is set, the address of the interrupt routine is obtained from the appropriate interrupt vector address, and the interrupt routine is executed. Stacking the CPU registers, setting the I bit, and vector fetching requires 11 cycles. The interrupt service routines normally end with a return from interrupt (RTI) instruction which allows the CPU to resume processing of the program prior to the interrupt. Table 1 provides a listing of the interrupts, their priority, and the vector address that contain-the starting address of the appropriate interrupt routine. A flowchart of the interrupt processing sequence is given in Figure 12. Table 1 Interrupt Priorities | Interrupt | Priority | Vector Address | |-----------|----------|-----------------| | RES | 1 | \$7FE and \$7FF | | SWI | 2 | \$7FC and \$7FD | | INT | 3 | \$7FA and \$7FB | | TIMER | 4 | \$7F8 and \$7F9 | Port A Programmed as output(s), driving CMOS and TTL Load directly. ### INPUT/OUTPUT There are 20 input/output pins, All pins are programmable as either inputs or outputs under software control of the corresponding Data Direction Register (DDR). When programmed as outputs, all I/O pins the latched output data is readable as input data, regardless of the logic levels at the output pin due to output loading (see Figure 13). When port B is programmed for outputs, it is capable of sinking 10mA on each pin (V<sub>OL</sub> = IV max). All input/output lines are TTL compatible as both inputs and outputs. Port A is CMOS compatible as outputs, and Port B and C are CMOS compatible as inputs. Figure 14 provides some examples of port connections. ### **BIT MANIPULATION** The MCU has the ability to set or clear any single random access memory or input/output bit (except the data direction registers) with a single instruction (BSET, BCLR). Any bit in the page zero read only memory can be tested, using the BRSET and BRCLR instructions, and the program branches as a result of its state. This capability to work with any bit in RAM, ROM or I/O allows the user to have individual flags in RAM or to handle single I/O bits as control lines. The example in Figure 15 illustrates the usefulness of the bit manipulation and test instructions. Assume that bit 0 of port A is connected to a zero crossing detector circuit and that bit 1 of port A is connected to the trigger of a TRIAC which powers the controlled hardware. This program, which uses only seven ROM locations, provides turn-on of the TRIAC within 14 microseconds of the zero crossing. The timer could also be incorporated to provide turn-on at some later time which would permit pulse-width modulation of the controlled power. Port B Programmed as output(s), driving Darlington-base directly. Port B Programmed as output(s), driving LED(s) directly. Port C Programmed as output(s), driving CMOS loads, using external pull-up resistors. (d) Figure 14 Typical Port Connections Figure 15 Bit Manipulation Example ## ADDRESSING MODES The CPU has ten addressing modes available for use by the programmer. They are explained and illustrated briefly in the following paragraphs. #### Immediate Refer to Figure 16. The immediate addressing mode accesses constants which do not change during program execution. Such instructions are two bytes long. The effective address (EA) is the PC and the operand is fetched from the byte following the opcode. ## Direct Refer to Figure 17. In direct addressing, the address of the operand is contained in the second byte of the instruction. Direct addressing allows the user to directly address the lowest 256 bytes in memory. All RAM space, I/O registers and 128 bytes of ROM are located in page zero to take advantage of this efficient memory addressing mode. ### Extended Refer to Figure 18. Extended addressing is used to reference any location in memory space. The EA is the contents of the two bytes following the opcode. Extended addressing instructions are three bytes long. ## Relative Refer to Figure 19. The relative addressing mode applies only to the branch instructions. In this mode the contents of the byte following the opcode is added to the program counter when the branch is taken. EA=(PC)+2+Rel. Rel is the contents of the location following the instruction opcode with bit 7 being the sign bit. If the branch is not taken Rel=0, when a branch takes place, the program goes to somewhere within the range of +129 bytes to -127 of the present instruction. These instructions are two bytes long. ## Indexed (No Offset) Refer to Figure 20. This mode of addressing accesses the lowest 256 bytes of memory. These instructions are one byte long and their EA is the contents of the index register. ## Indexed (8-bit Offset) Refer to Figure 21. The EA is calculated by adding the contents of the byte following the opcode to the contents of the index register. In this mode, 511 low memory locations are accessable. These instructions occupy two bytes. ## Indexed (16-bit Offset) Refer to Figure 22. This addressing mode calculates the EA by adding the contents of the two bytes following the opcode to the index register. Thus, the entire memory space may be accessed. Instructions which use this addressing mode are three bytes long. #### Bit Set/Clear Refer to Figure 23. This mode of addressing applies to instructions which can set or clear any bit on page zero. The lower three bits in the opcode specify the bit to be set or cleared while the byte following the opcode specifies the address in page zero. ## Bit Test and Branch Refer to Figure 24. This mode of addressing applies to instructions which can test any bit in the first 256 locations (\$00-\$FF) and branch to any location relative to the PC. The byte to be tested is addressed by the byte following the opcode. The individual bit within that byte to be tested is addressed by the lower three bits of the opcode. The third byte is the relative address to be added to the program counter if the branch condition is met. These instructions are three bytes long. The value of the bit tested is written to the carry bit in the condition code register. #### Implied Refer to Figure 25. The implied mode of addressing has no EA. All the information necessary to execute an instruction is contained in the opcode. Direct operations on the accumulator and the index register are included in this mode of addressing. In addition, control instructions such as SWI, RTI belong to this group. All implied addressing instructions are one byte long. ## ■ INSTRUCTION SET The MCU has a set of 59 basic instructions. They can be divided into five different types: register/memory, read/modify/write, branch, bit manipulation, and control. The following paragraphs briefly explain each type. All the instructions within a given type are presented in individual tables. #### Register/Memory Instructions Most of these instructions use two operands. One operand is either the accumulator or the index register. The other operand is obtained from memory using one of the addressing modes. The jump unconditional (JMP) and jump to subroutine (JSR) instructions have no register operand. Refer to Table 2. ## Read/Modity/Write Instructions These instructions read a memory location or a register, modify or test its contents, and write the modified value back to memory or to the register. The test for negative or zero (TST) instruction is an exception to the read/modify/write instructions since it does not perform the write. Refer to Table 3 ## Branch Instructions The branch instructions cause a branch from the program when a certain condition is met. Refer to Table 4. ## Bit Manipulation Instructions These instructions are used on any bit in the first 256 bytes of the memory. One group either sets or clears. The other group performs the bit test and branch operations. Refer to Table 5. ## Control Instructions The control instructions control the MCU operations during program execution, Refer to Table 6. ## Alphabetical Listing The complete instruction set is given in alphabetical order in Table 7 ## Opcode Map Table 8 is an opcode map for the instructions used on the MCU. Figure 16 Immediate Addressing Example Figure 17 Direct Addressing Example Figure 18 Extended Addressing Example Figure 19 Relative Addressing Example Figure 20 Indexed (No Offset) Addressing Example Figure 21 Indexed (8-Bit Offset) Addressing Example Figure 22 Indexed (16-Bit Offset) Addressing Example Figure 23 Bit Set/Clear Addressing Example Figure 24 Bit Test and Branch Addressing Example Figure 25 Implied Addressing Example Table 2 Register/Memory Instructions | | | | | | | | | | | Addressi | ing Mod | des | | | | | | | | |------------------------------------------|----------|--------------|------------|-------------|------------|------------|-------------|------------|------------|-------------|------------|--------------------|-------------|---------------------------|------------|-------------|----------------------------|----------|-------------| | Function | Mnemonic | le<br>le | nmedia | te | | Direct | | | Extende | d | | Indexed<br>No Offs | | Indexed<br>(8-Bit Offset) | | | Indexed<br>(16-Bit Offset) | | | | | | Op<br>Code | #<br>Bytes | #<br>Cycles | Op<br>Code | #<br>Bytes | #<br>Cycles | Op<br>Code | #<br>Bytes | #<br>Cycles | Op<br>Code | #<br>Bytes | #<br>Cycles | Op<br>Code | #<br>Bytes | #<br>Cycles | Op<br>Code | <u> </u> | #<br>Cycles | | Load A from Memory | LDA | A6 | 2 | 2 | B6 | 2 | 4 | C6 | 3 | 5 | F6 | 1 | 4 | E6 | 2 | 5 | D6 | 3 | 6 | | Load X from Memory | LDX | AE | 2 | 2 | BE | 2 | 4 | CE | 3 | 5_ | FE | 1 | 4 | EE | 2 | 5 | DE | 3 | 6 | | Store A in Memory | STA | - | - | - | B7 | 2 | 5 | C7 | 3 | 6 | F7 | 1 | 5 | E7 | 2 | 6 | D7 | 3 | 7 | | Store X in Memory | STX | - | | | BF | 2 | 5 | CF | 3 | 6 | FF | 1 | 5 | EF | 2 | 6 | DF | 3 | 7 | | Add Memory to A | ADD | AB | 2 | 2 | ВВ | 2 | 4 | СВ | 3 | 5 | FB | 1 | 4 | EB | 2 | 5 | DB | 3 | 6 | | Add Memory and<br>Carry to A | ADC | A9 | 2 | 2 | 89 | 2 | 4 | С9 | 3 | 5 | F9 | 1 | 4 | E9 | 2 | 5 | 09 | 3 | 6 | | Subtract Memory | SUB | A0 | 2 | 2 | 80 | 2 | 4 | CO | 3 | 5 | F0 | 1_ | 4 | EO | 2 | 5 | DD | 3 | 6 | | Subtract Memory from<br>A with Borrow | SBC | A2 | 2 | 2 | В2 | 2 | 4 | C2 | 3 | 5 | F2 | 1 | 4 | E2 | 2 | 5 | D2 | 3 | 6 | | AND Memory to A | AND | A4 | 2 | 2 | B4 | 2 | 4 | C4 | 3 | 5 | F4 | 1 | 4 | E4 | 2 | 5 | D4 | 3 | 6 | | OR Memory with A | DRA | AA | 2 | 2 | ВА | 2 | 4 | CA | 3 | 5 | FA | 1_ | 4 | EΑ | 2 | 5 | DA | 3 | 6 | | Exclusive OR Memory with A | EOR | A8 | 2 | 2 | 88 | 2 | 4 | С8 | 3 | 5 | FB | 1 | 4 | E8 | 2 | 5 | D8 | 3 | 6 | | Arithmetic Compare A with Memory | СМР | A1 | 2 | 2 | 81 | 2 | 4 | CI | 3 | 5 | F1 | 1 | 4 | E1 | 2 | 5 | D1 | 3 | 6 | | Arithmetic Compare X with Memory | CPX | А3 | 2 | 2 | В3 | 2 | 4 | СЗ | 3 | 5 | F3 | 1 | 4 | £3 | 2 | 5 | D3 | 3 | 6 | | Bit Test Memory with A (Logical Compare) | BiT | A5 | 2 | 2 | B5 | 2 | 4 | C5 | 3 | 5 | F5 | 1 | 4 | <b>E</b> 5 | 2 | 5 | D5 | 3 | 6 | | Jump Unconditional | JMP | 1 - | - | - | вс | 2 | 3 | cc | 3 | 4 | FC | 1 | 3 | EC | 2 | 4 | DC | 3 | 5 | | Jump to Subroutine | JSR | † <u>-</u> - | T - | T - | BD | 2 | 7 | CD | 3 | 8 | FD | 1 | 7 | ED | 2 | 8 | DD | 3 | 9 | Table 3 Read/Modify/Write Instructions | | | } | | | | | | Add | essing l | Modes | | | | | | | |----------------------------|----------|------------|------------|-------------|------------|------------|-------------|------------|------------|-------------|------------------------|------------|-------------|---------------------------|------------|-------------| | Function | Mnemonic | in | oplied (/ | A) | lm | plied () | <b>X</b> } | | Direct | | Indexed<br>(No Offset) | | | Indexed<br>(8-Bit Offset) | | | | | | Op<br>Code | #<br>Bytes | #<br>Cycles | Op<br>Code | #<br>Bytes | #<br>Cycles | Op<br>Code | #<br>Bytes | #<br>Cycles | Op<br>Code | #<br>Bytes | #<br>Cycles | Op<br>Code | #<br>Bytes | #<br>Cycles | | Increment | INC | 4C | 1 | 4 | 5C | 1 | 4 | 3C | 2 | 6 | 7C | 1 | 6 | 6C | 2 | 7 | | Decrement | DEC | 4A | 1 | 4 | 5A | 1 | 4 | 3A | 2 | 6 | 7A | 1 | 6 | 6A | 2 | 7 | | Clear | CLR | 4F | 1 | 4 | 5F | 1 | 4 | 3F | 2 | 6 | 7F | 1 | 6 | 6F | 2 | 7 | | Complement | COM | 43 | 1 | 4 | 53 | 1 | 4 | 33 | 2 | 6 | 73 | 1 | 6 | 63 | 2 | 7 | | Negate<br>(2's Complement) | NEG | 40 | 1 | 4 | 50 | 1 | 4 | 30 | 2 | 6 | 70 | 1 | 6 | 60 | 2 | 7 | | Rotate Left Thru Carry | ROL | 49 | 1 | 4 | 59 | 1 | 4 | 39 | 2 | 6 | 79 | 1 | 6 | 69 | 2 | 7 | | Rotate Right Thru Carry | ROR | 46 | 1 | 4 | 56 | 1 | 4 | 36 | 2 | 6 | 76 | 1 | 6 | 66 | 2 | 7 | | Logical Shift Left | LSL | 48 | 1 | 4 | 58 | 1 | 4 | 38 | 2 | 6 | 78 | 1 | 6 | 68 | 2 | 7_ | | Logical Shift Right | LSR | 44 | 1 | 4 | 54 | 1 | 4 | 34 | 2 | 6 | 74 | 1 | 6 | 64 | 2 | 7 | | Arithmetic Shift Right | ASR | 47 | 1 | 4 | 57 | 1 | 4 | 37 | 2 | 6 | 77 | 1 | 6 | 67 | 2 | 7_ | | Arithmetic Shift Left | ASL | 48 | 1 | 4 | 58 | 1 | 4 | 38 | 2 | 6 | 78 | 1 | 6 | 68 | 2 | 7 | | Test for Negative or Zero | тѕт | 4D | 1 | 4 | 5D | 1 | 4 | 3D | 2 | 6 | 70 | 1 | 6 | 6D | 2 | 7 | Table 4 Branch Instructions | | | Reia | tive Addressing l | Mode | |---------------------------------------|----------|------------|-------------------|-------------| | Function | Mnemonic | Op<br>Code | #<br>Bytes | #<br>Cycles | | Branch Always | BRA | 20 | 2 | 4 | | Branch Never | BRN | 21 | 2 | 4 | | Branch IF Higher | ВНІ | 22 | 2 | 4 | | Branch IF Lower or Same | BLS | 23 | 2 | 4 | | Branch IF Carry Clear | ВСС | 24 | 2 | 4 | | Branch IF Higher or Same) | (BHS) | 24 | 2 | 4 | | Branch IF Carry Set | BCS | 25 | 2 | 4 | | Branch IF Lower) | (BLO) | 25 | 2 | 4 | | Branch IF Not Equal | BNE | 26 | 2 | 4 | | Branch IF Equal | BEQ | 27 | 2 | 4 | | Branch IF Half Carry Clear | внсс | 28 | 2 | 4 | | Branch IF Half Carry Set | BHCS | 29 | 2 | 4 | | Branch IF Plus | BPL | 2A | 2 | 4 | | Branch IF Minus | ВМІ | 2B | 2 | 4 | | Branch IF Interrupt Mask Bit is Clear | вмс | 2C | 2 | 4 | | Branch IF Interrupt Mask Bit is Set | BMS | 2D | 2 | 4 | | Branch IF Interrupt Line is Low | BIL | 2E | 2 | 4 | | Branch IF Interrupt Line is High | ВІН | 2F | 2 | 4 | | Branch to Subroutine | BSR | AD | 2 | 8 | Table 5 Bit Manipulation Instructions | | | Addressing Modes | | | | | | | | | | | |--------------------------|-----------------|------------------|--------------|-------------|---------------------|------------|-------------|--|--|--|--|--| | Function | Mnemonic | 8 | it Set/Clear | | Bit Test and Branch | | | | | | | | | | | Op<br>Code | #<br>Bytes | #<br>Cycles | Op<br>Code | #<br>Bytes | #<br>Cycles | | | | | | | Branch IF Bit n is set | BRSET n (n=0 7) | _ | _ | _ | 2•n | 3 | 10 | | | | | | | Branch IF Bit n is clear | BRCLR n (n=07) | _ | _ | _ | 01+2·n | 3 | 10 | | | | | | | Set Bit n | BSET n (n=0 7) | 10+2•n | 2 | 7 | _ | _ | _ | | | | | | | Clear bit n | BCLR n (n=0 7) | 11+2•n | 2 | 7 | _ | _ | _ | | | | | | Table 6 Control Instructions | | | | Implied | | |--------------------------|----------|------------|------------|-------------| | Function | Mnemonic | Op<br>Code | #<br>Bytes | #<br>Cycles | | Transfer A to X | TAX | 97 | 1 | 2 | | Transfer X to A | TXA | 9F | 1 | 2 | | Set Carry Bit | SEC | 99 | 1 | 2 | | Clear Carry Bit | CLC | 98 | 1 | 2 | | Set Interrupt Mask Bit | SEI | 98 | 1 | 2 | | Clear Interrupt Mask Bit | CLI | 9A | 1 | 2 | | Software Interrupt | SWI | 83 | 1 | 11 | | Return from Subroutine | RTS | 81 | 1 | 6 | | Return from Interrupt | RTI | 80 | 1 | 9 | | Reset Stack Pointer | RSP | 9C | 1 | 2 | | No-Operation | NOP | 9D | 1 | 2 | Table 7 Instruction Set | | Addressing Modes | | | | | | | | Condition Cod | | | | | | | |-------------|--------------------------------------------------|------------------|--------------------------------------------------|--------------------------------------------------|--------------------------------------------------|--------------------------------------------------|--------------------------------------------------|----------------------|----------------------|--------------------------------------------------|---|-------|----------------------|----------------------|----------------------| | Mnemonic | Implied | Imme-<br>diate | Direct | Ex-<br>tended | Re-<br>lative | Indexed<br>(No<br>Offset) | Indexed<br>(8 Bits) | Indexed<br>(16 Bits) | Bit<br>Set/<br>Clear | Bit<br>Test &<br>Branch | Н | , | N | z | С | | ADC | | × | × | × | | × | × | × | | | Λ | • | ٨ | Λ | Λ | | ADD | 1 | × | × | × | | х | х | × | | | ٨ | • | ^ | Λ | ^ | | AND | 1 | × | × | × | | × | × | × | - | | • | • | ٨ | Λ | • | | ASL | х | i | × | | | х | × | | | | • | • | ٨ | Λ | Λ. | | ASR | × | | х | | | х | x | | | | • | • | Λ | Λ | Λ | | ВСС | | | | | × | | | | | | • | • | •_ | • | • | | BCLR | | | | | | | i<br>i | | × | <u>.</u> | • | • | • | • | • | | BCS | | | | | × | | | | | | • | • | • | • | • | | BEQ | 1 | | | | × | | 1 | | | | • | • | • | • | • | | внсс | | - | 1 | 1 | х | | | | | | • | • | • | • | • | | BHCS | 1 | <u> </u> | 1 | | × | · · · · · · · · · · · · · · · · · · · | | | | | • | • | • | • | • | | вні | | | | | × | | | | | | • | • | • | • | • | | BHS | <del> </del> | | | | × | | | | | | • | • | • | • | • | | BIH | | | T | | × | | : | | | | • | • | • | • | • | | BIL | 1 | | 1 | | × | 1 | | | | | • | • | • | • | • | | BIT | <u> </u> | × | × | × | | × | , x | × | | | • | • | ٨ | ^ | • | | BLO | | | 1 | 1 | х | | | | | | • | • | • | • | • | | BLS | <u> </u> | | <u> </u> | | × | | | 1 | | | • | • | • | • | • | | ВМС | + | | | † | × | | <del> </del> | | | <u> </u> | • | • | • | • | • | | BMI | - | † | 1 | | × | | | | | 1 | • | • | • | • | • | | BMS | <del> </del> | | <del> </del> | 1 | × | | | | 1 | | • | • | • | • | • | | BNE | 1 | | <del> </del> | <del> </del> | x | <del> </del> | + | <del> </del> | | <del> </del> | • | • | • | • | • | | BPL. | 1 | | + | <del> </del> | x | | <del> </del> | <del> </del> | <del> </del> | <del> </del> | • | • | • | • | • | | BRA | | <del> </del> | <del> </del> | <del> </del> | - x | ļ | <del> </del> | <del> </del> | | <del> </del> | • | • | • | • | • | | | | | <del></del> | <del> </del> | x | <del> </del> | | <del> </del> | † | <del> </del> | | • | • | | • | | BRN | _ | ļ <del></del> | <del> </del> | <del> </del> | | <del> </del> | <del> </del> | - | <b>†</b> | x | • | • | • | • | $\frac{1}{\lambda}$ | | BRCLR | <del> </del> | <del> </del> | <del> </del> | + | <del> </del> | | | <del> </del> | ļ | × | • | • | • | • | $\overline{}$ | | BRSET | - | | <u> </u> | <del> </del> | <del> </del> | <del> </del> | <del> </del> | | × | <del> </del> | • | • | • | • | • | | BSET<br>BSR | | <del> </del> | <del> </del> | | × | <del> </del> | + | | <del> </del> | <del> </del> | • | • | • | • | • | | | x | <del> </del> | <del> </del> | <del> </del> | 1 - | | + | <b>+</b> | - | <del> </del> | | • | • | • | 0 | | CLC | | | <del> </del> | <del> </del> | <del> </del> | <del> </del> | <del></del> | | - | 1 | • | 0 | • | • | • | | | × | <u> </u> | x | <del> </del> | <del> </del> | x | - x | <del> </del> | | <del> </del> | • | • | 0 | 1 | • | | CLR | <del> ^</del> - | × | | × | | x | x - | × | <u> </u> | <u> </u> | • | • | \<br>\<br>\ | 1 | $\overline{\Lambda}$ | | COM | х | <del> ^</del> | ^ | + ^- | | x | × × | | <b>†</b> | <u> </u> | • | • | $\overline{\Lambda}$ | <u></u> | 1 | | CPX | <b>^</b> | × | + ^ | <u> </u> | <del> </del> | × × | × × | × | <del> </del> | | • | • | | \ \ \ | $\overline{}$ | | | × | <del> ^</del> | | <del>† ^ -</del> | + | × | × | - | | <del> </del> | • | • | | 1 | • | | DEC | <del> ^</del> - | × | - ^ | × | <del> </del> | × | | × | <b></b> | <del> </del> | • | • | $\Lambda$ | $\overline{\Lambda}$ | • | | EOR | x | <del> ^</del> - | × | <del> </del> | + | × | × | | | † | • | • | ^ | | • | | INC | · | - | <del> </del> | × | <del> </del> | | <u> </u> | × | <del> </del> | <del> </del> | • | • | • | • | • | | JMP | <del> </del> - | + | × | * | <del> </del> | | × | × | <u> </u> | 1 | • | • | • | • | • | | JSR | <del> </del> | <del> </del> | X | <del></del> | ļ | × | <del></del> | | - | + | • | • | <u> </u> | <u> </u> | • | | LDA | | X | X | <u> </u> | <del> </del> | + | × | <del> </del> | <del> </del> | + | - | • | $\frac{1}{\lambda}$ | $\frac{1}{\Lambda}$ | • | | LDX | | × | × | × | <u> </u> | × | , x | × | <u> </u> | ــــــــــــــــــــــــــــــــــــــ | | lto b | | | | Condition Code Symbols. H Half Carry (From Bit 3) I Interrupt Mask N Negative (Sign Bit) Z Zero C Carry Borrow △ Test and Set if True, Cleared Otherwise Not Affected (to be continued) Table 7 Instruction Set | | | | А | ddressing | Modes | | | | | | C | ond | ition | Cod | e | |----------|---------|----------------|--------|---------------|---------------|---------------------------|---------------------|----------------------|----------------------|-------------------------|---|-----|-------|-----|---| | Mnemonic | Implied | lmme-<br>diate | Direct | Ex-<br>tended | Re-<br>lative | Indexed<br>(No<br>Offset) | Indexed<br>(8 Bits) | Indexed<br>(16 Bits) | Bit<br>Set/<br>Clear | Bit<br>Test &<br>Branch | н | ı | N | z | С | | LSL | × | | х | | | x | × | | | | • | • | Λ | Λ | Λ | | LSR | × | | × | | | × | х | | | | • | • | 0 | ٨ | Λ | | NEG | × | | × | | | × | x | | | | • | • | Λ | Λ | ٨ | | NOP | × | | | | | | | | | | • | • | • | • | • | | ORA | | × | × | × | | × | × | × | | | • | • | Λ | ^ | • | | ROL | × | | × | | | × | × | | | | • | • | Λ | Λ | Λ | | ROR | × | | × | | | × | × | | | | • | • | Λ | _ | Λ | | RSP | × | | | | | | | | | | • | • | • | • | • | | RTI | × | | | | | - | | | | | ? | ? | ? | ? | ? | | RTS | × | | | | · | | | | | | • | • | • | • | • | | SBC | | × | × | х | | × | × | × | | | • | • | Λ | ^ | Λ | | SEC | × | | _ | | | | | | | | • | • | • | • | 1 | | SEI | × | | | | | | | | | | • | 1 | • | • | • | | STA | | | × | × | | × | × | × | | | • | • | Λ | _ | • | | STX | | 1 | × | × | | × | × | × | | | • | • | Λ | ٨ | • | | SUB | | х | × | × | | × | × | x | · · · · | | • | • | ٨ | Λ | Λ | | SWI | × | | · | | | | | | | | • | 1 | • | • | • | | TAX | × | | | | | | | | | | • | • | • | • | • | | TST | х | • | × | | | x | x | | | | • | • | ٨ | ٨ | • | | TXA | x | | | | | | | | | | • | • | • | • | • | Condition Code Symbols: H Haif Carry (From Bit 3) I Interrupt Mask N Negative (Sign Bit) Z Zero Carry/Borrow Test and Set if True, Cleared Otherwise Not Affected Load CC Register From Stack Table 8 Opcode Map | | Bit Manip | oulation | Branch<br>Rei<br>2 | Read/Modify/Write | | | | | Control | | Register/Memory | | | | | | | | |---|------------------|--------------------|--------------------|-------------------|-----|-----|----------|-----|----------|----------|-----------------|----------|-----|----------|----------|-----|---|------| | | Test &<br>Branch | Set/<br>Clear<br>1 | | DIR<br>3 | A 4 | X 5 | ,X1<br>6 | ,X0 | IMP<br>8 | IMP<br>9 | IMM<br>A | DIR<br>B | EXT | ,X2<br>D | ,X1<br>E | ,xo | | | | | 0 | | | | | | | | | | | | | | | F | - | HIGH | | 0 | BRSET0 | BSETO | BRA | | | NEG | | | RTI* | | | SUB | | | | | | | | 1 | BRCLRO | BCLRO | BRN | - | | | | | RTS* | _ | 1 | СМР | | | | | | _ | | 2 | BRSET1 | BSET1 | ВНІ | - | | | | | - | _ | I | SBC | | | | | | _ | | 3 | BRCLR1 | BCLR1 | BLS | сом | | | | | swi* | _ | | CPX | | | | | 3 | L | | 4 | BRSET2 | BSET2 | всс | LSR | | | | | - | | | AND | | | | | 4 | 0 | | 5 | BRCLR2 | BCLR2 | BCS | | | | | | | L – | | BIT | | | | | 5 | W | | 6 | BRSET3 | BSET3 | BNE | | | ROR | | | | _ | | | | LDA | | | 6 | _ | | 7 | BRCLR3 | BCLR3 | BEQ | ASR | | | | | _ | TAX | I | STA(+1) | | | | 7 | _ | | | 8 | BRSET4 | BSET4 | внсс | LSL/ASL | | | | | _ | CLC | | EOR | | | | | 8 | _ | | 9 | BRCLR4 | BCLR4 | внсѕ | ROL | | | | | _ | SEC | | ADC | | | | | 9 | _ | | A | BRSET5 | BSET5 | BPL | DEC | | | | | - | CLI | I | ORA | | | | | | _ | | В | BRCLR5 | BCLR5 | ВМІ | _ | | | | | - | ŞEI | | ADD | | | | | 8 | _ | | С | BRSET6 | BSET6 | вмс_ | | | INC | | | _ | RSP | | JMP(-1) | | | | | C | _ | | D | BRCLR6 | BCLR6 | BMS | | | TST | | | | NOP | BSR* | JSR(+3) | | | | | D | - | | E | BRSET7 | BSET7 | BIL | | | | | | | | | LDX | | | | | E | _ | | F | BRCLR7 | BCLR7 | він | CLR | | | | | | TXA | - | STX(+1) | | | | | F | | | | 3/10 | 2/7 | 2/4 | 2/6 | 1/4 | 1/4 | 2/7 | 1/6 | 1/* | 1/2 | 2/2 | 2/4 | 3/5 | 3/6 | 2/5 | 1/4 | | | (NOTE) 1. Undefined opcodes are marked with "-". 2. The number at the bottom of each column denote the number of bytes and the number of cycles required (Bytes/Cycles). Mnemonics followed by a "+" require a different number of cycles as follows: RTI 9 RTS 6 SWI 11 11 ) indicate that the number in parenthesis must be added to the cycle count for that instruction.