#### GENERAL DESCRIPTION Hua Ko has designed and manufactured a CMOS 8 bit microprocessor family with a total number of 18 microprocessors. The family consists of two series of devices: One series, designated HKE65SCXX is pin-to-pin compatible with the NMOS 6500 microprocessor series. The other series, designated HKE65SC1XX has several hardware enhancement not available in the NMOS 6500 series. Both series of the CMOS 8 bit microprocessors offered by Hua Ko are manufactured using the state-of-the-art silicon gate CMOS technology. Both series are TTL and CMOS compatible. All 18 microprocessors are software compatible within the family and all are bus compatible with MC6800 series. The family provides the designer with a wide selection range of addressable memory (4K or 64K), input interrupt options, and on-chip or external clock options. The HKE65SCXX series consists of 10 microprocessors (i.e. HKE65SC02 - 07 and HKE65SC12 - 15). They can be used as drop-in replaceable of the NMOS 6500 microprocessors currently on the market. However, the CMOS family is specifically designed for use in the fully CMOS systems, such as industrial controllers, battery operated or portable computers, controllers and other instruments. The CMOS microprocessor is most valuable in industry because CMOS overcomes all the problems suffered by NMOS and TTL such as excessive power consumption, poor electrical noise immunity, and narrow operatingtemperature range. Almost all industrial environments have problems with electrical noise and large temperature fluctuations. A CMOS system works best for all kinds of industrial applications because of its higher noise immunity and wider temperature range. The low-power consumption of a CMOS system is certainly essential to systems located remotely and powered by battery; it is also becoming an essential factor even for office equipment. For example, in an NMOS or TTL system, the regulated power supply easily occupies up to 50% of the total system volume and often requires a cooling fan. By using a CMOS system, the power supply can be reduced to less than 10% of the total system volume. In addition, the cooling fan can be eliminated. This would give a much smaller, lighter and more reliable system. Most importantly, the total system cost using all CMOS components is most likely to be below that of an NMOS or TTL system, due to the simplification of its power supply and other related components. The ten microprocessors in the HKE65SCXX series offer designer more than just drop-in compatible with NMOS 6500 microprocessors and advantages of leading edge CMOS technology. Several hardware, software and operational enhancements are designed into the HKE65SCXX series that are not available to users of the NMOS 6500. The specifications and details of the improvement of CMOS 65SCXX over the NMOS 6500 are described in a later section. The eight microprocessors in the HKE65SC1XX series offer designer an extra feature of an on-chip divide-by-four oscillator such that an economical television crystal (3.579545 MHz) can be used. The access time (tACC) is increased by approximately 25 percent due to this advantageous on-chip oscillator design. All watelons of the HKE656GXX and HKE689C1XX micropress comore are available in 1, 2, 3 and 4 MH Inskirkum operatings frequencies. The standard package of the microprocessors is plastic. However, ceramic, cerdip or leadless chip carrier packaging are available as customer's options. #### **FEATURES** - \* Silicon-Gate COMS process - \* Pin-to-pin compatible with NMOS 6500 series microprocessors - \* TTL and CMOS I/O compatible - \* Uses single +5 volt (±20%) power supply - \* Low power consumption (4mA @ 1 MHz) - \* 1, 2, 3 or 4 MHz versions - \* Choice of 4K, 8K or 64K byte addressable memory - \* Enhanced instruction set: 64 instructions - 178 operational codes - 15 addressing modes - \* Choice of external or on-chip clock generator operation - \* On-chip clock generator/oscillator can be driven by an external singlephase clock input, an RC network, or a crystal circuit - \* Advanced memory access timing ( $\phi$ 4) on selected versions - \* Early address valid allows use with any type of speed memory - \* Early write data for dynamic memories - \* 8-bit parallel processing - \* Decimal and binary arithmetic - \* Pipeline architecture - \* Programmable stack pointer - \* Variable length stack - \* Interrupt capability - \* Non-maskable interrupt - \* 8-bit bidirectional data bus - \* "Ready" input (for single cycle execution) - \* Direct memory access capability - \* Bus compatible with M6800 - \* Available on selected versions, a memory lock output and bus enable input signals simplify multiprocessor design - \* Available in either 28 or 40 pin dual-in-line packaging - \* Commercial and industrial temperature versions ## IMPROVEMENT OF CMOS HKE65SCXX OVER NMOS 6500 The HKE65SCXX microprocessors are pin-to-pin compatible with the NMOS 6500 microprocessors currently offered by many other manufacturers. However, several hardware, software and operational enhancements have been designed and implemented to provide the designer with more options that are not available to users of the NMOS 6500. The enhancements include: Addressing modes, microprocessor instructions, and operational codes. The enhancements are discussed in details and compared with the NMOS 6500 series as follows: **Expanded Addressing Modes:** NMOS 6500 has 13 addressing modes. The CMOS HKE65SCXX has 15 addressing modes, thus provide the designer with the highest degree of flexibility in addressing in all the 8-bit microprocessors (Intel 8080/8085 has 5 addressing modes; M6800 has 7 addressing modes; Z-80 has 10; and Texas 9900 has 8). The expanded addressing modes are very useful in reducing the memory space for storing a program and increasing the operational effeciency. **Exapnded Instruction Set:** The microprocessor instructions of HKE65SCXX has been expanded from 56 to 64 instructions. The 8 expanded instructions have improved the performance of the microprocessor and made it more powerful in controlling system. **Expanded Operational Codes:** The NMOS 6500 has 151 codes. The CMOS HKE65SCXX has expanded to 178 operational codes. This has substantially improved the effective use of the microprocessor instructions. The hardware enhancements of the CMOS HKE65SCXX are summerized in Table I. The operational enhancements of the CMOS HKE65SC1XX are summerized in Table II. #### TABLE I MICROPROCESSOR HARDWARE ENHANCEMENTS | Function | NMOS 6500 | HKE65SCXX Family | |--------------------------------------------------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------------| | Oscillator | Requires external active components | Crystal or RC network will oscillate when connected as Figure 4(a) and 4(b). | | Assertion of Ready (RDY) during write Operations. | Ignored | Stops processor during $\phi 2$ . | | 1X series clock inputs | Two non-overlapping clock input (\$\phi\$1 and \$\phi\$2) are required. | $\phi$ 2 (IN) is the only required clock input. | | Unused input-only pins<br>(IRQ, NMI, RDY, RES,<br>SO, DBE*, BE**). | Must be connected to low impedance signal to avoid noise problems. | Connected internally by a high-resistance to VDD (approximately 1 Megohm). | <sup>\*</sup> DBE is used in the HKE65SC12 only. # TABLE II MICROPROCESSOR OPERATIONAL ENHANCEMENTS | Function | NMOS 6500<br>Microprocessor | | CXX Family processor | | |------------------------------------------------------|----------------------------------------------------|---------------------------------------------------------------------|-------------------------------------|----------------------------| | Indexed addressing across page boundary. | Extra read of invalid address. | Extra read of last in | nstruction byte. | | | Execution of invalid op codes | Some terminate only by reset. | All are NOPs (reserv | ved for future u | se). | | | Results are undefined. | Op Code<br>X2<br>X3, X7, XB, XF<br>44<br>54, D4, F4<br>5C<br>DC, FC | Bytes<br>2<br>1<br>2<br>2<br>3<br>3 | Cycles 2 1 3 4 8 4 | | Jump indirect, operand =XXFF | Page address does not increment. | Page address increm | nents. One addit | ional cycle. | | Read/modify/write instructions at effective address. | One read and two write cycles. | Two read and one v | write cycle. | | | Decimal flag. | Indeterminate after reset. | Initialized to binary | y mode (D=0) at | fter reset and interrupts. | | Flags after decimal operation. | Invalid N, V and Z flags. | Valid flags. One add | ditional cycle. | | | Interrupt after fetch of BRK instruction. | Interrupt vector is loaded, BRK vector is ignored. | BRK is executed, the | hen interrupt is | executed. | <sup>\*\*</sup>BE is used in the HKE65SC102 and 112. \* Refer to Signal Description Figure 1. Internal Architecture Block Diagram ## **FUNCTIONAL DESCRIPTION** A block diagram of the internal architecture of HKE65SCXX and HKE65SC1XX are shown in Figure 1. The basic on-chip units implemented in the microprocessor include: Clock generator, timing control, logic control, arithmetic and logic unit, accumulator, program counter, registers, I/O, and data address bus drivers, etc. The functional description of each on-chip unit is given as follows:— # **Clock Generator and Timing Control** The clock generator generates the clock signal for the timing control and provides other clock signals for external use. The timing control unit keeps track of the instruction cycle. The unit is set to zero each time an instruction fetch is executed and is advanced at the beginning of each phase one clock pulse ( $\phi$ 1) for as many cycles as is required to complete the instruction. Each data transfer which takes place between the registers depends upon decoding the contents of both the instruction register and the timing control unit. ## **Program Counter** The 16-bit program counter is divided into a program-counter lower-byte (PCL) and higher-byte (PCH), when a instruction or data is fetched, this unit always places an address of the instruction code or data to be fetched on the 16-bit address bus. When the BRK, Jump instruction or a special operation, for example: Reset, Interrupt request, or Nomaskable interrupts is executed, a 16-bit (in two 8-bits) now address or a 16-bit (in two 8-bits) new vector address is entered into this Counter Via and 8-bit data Bus. This counter can be automatically incremented each time after an instruction or data is fetched. ## Instruction Register and Decoder Instructions fetched from memory are gated onto the internal data bus. These instructions are latched into the instruction register then decoded, along with timing and interrupt signals, to generate control signals for the registers. # Arithmetic and Logic Unit (ALU) All arithmetic and logic operations take place in the ALU including incrementing and decrementing internal registers (except the program counter). The ALU has no internal memory and is used only to perform logical and transient numerical operations. #### **Accumulator** The accumulator is a general purpose 8-bit register that stores the results of most arithmetic and logic operations. In addition, the accumulator usually contains one of the two data words used in these operations. #### **Index Registers** Two 8-bit index registers, labelled as X and Y registers, are used to count program steps or to provide an index value for generating effective address. In executing instructions with specific indexed addresses, the CPU fetches the op code and the base address from the memory, and modifies the address by adding the index register to the base address prior to performing the desired operation. Pre- or post-indexing of indirect addresses is possible. #### Stack Pointer The stack pointer is an 8-bit register used to control the addressing of the variable-length stack. The stack pointer is automatically incremented and decremented under control of the microprocessor to perform stack manipulations under direction of either the program or interrupts ( $\overline{\text{NMI}}$ and $\overline{\text{IRQ}}$ ). The stack allows simple implementation of nested subroutines and multiple level interrupts. #### **Processor Status Register** The 8-bit processor status register contains seven status flags and one empty bit. Some of the flags are controlled by the program, others may be controlled both by the program and the CPU. The 6500 instruction set contains a number of conditional branch instructions which are designed to allow testing of these flags. A simplified architectural diagrams of the internal registers is given in Figure 2a and 2b. Fig. 2a Architecture of internal registers Fig 2b Architecture of internal register "P" ## SIGNAL DESCRIPTION The signals of the HKE65SCXX and HKE65SC1XX microprocessors can be divided into four basic groups: - (1) Address bus (A0 to A15), - (2) Data bus (D0 to D7), - (3) Clock and timing ( $\phi$ 0 to $\phi$ 4), and - (4) Control signals (BE, DBE, ML, RES, RDY, R/W, SO, SYNC, IRQ, NMI). Each microprocessor of the 18 members of the family consists a specific set of signals. Detail identification of each microprocessor is given in a later section under the title of FAMILY MEMBER DESCRIPTION. A brief description of all the signals is given as follows: Address Bus (A0 to A11 for 4K, A0 to A12 for 8K and A0 to A15 for 64K addressable memory) Packaging options of 28-pin and 40-pin are available. In the 40-pin package, A0 to A15 forms a 16-bit address bus and is capable of addressing 64K byte memories. In the 28-pin package, two versions of address bus are available. One (A0 to A11) is capable of addressing 4K byte and the other (A0 to A12) is capable of addressing 8K byte memories. The address lines are set (See BE below) to the high impedance state by the bus enable (BE) signal\*. The output of each address line is TTL compatible, capable of driving one standard TTL load and 130pF. # Data Bus (D0 to D7) The data lines (D0 - D7) consists of an 8-bit bidirectional data bus used for data exchanges to and from the device and peripherals. The outputs are three-state buffers capable of driving one TTL load and 130pF. The data lines are set to the high impedance state by BE or DBE. ### Bus Enable (BE) This signal allows external control of the data and the address output buffers and $R\overline{/M}$ . For normal operation, BE is high causing the address buffers and $R\overline{/M}$ to be active and the data buffers to be active during a write cycle. For external control, BE is held low to disable the buffers. This signal is designed into HKE65C102 and 112 only (see Tabel III) <sup>\*</sup>BE is used in HKE65SC102 and 112 only. #### Data Bus Enable (DBE)\* This TTL-compatible input allows external control of the three-state data output buffers. In normal operation, DBE would be driven by the phase two $(\phi 2)$ clock, thus allowing data input from microprocessor only during $\phi 2$ . During the read cycle, the data bus buffers are internally disabled, becoming essentially an open circuit. To disable the data bus externally, DBE should be held low. The signal is designed into HKE65SC112 only. ## Memory Lock (ML)\*\* In a multiprocessor system, $\overline{ML}$ indicates the need to defer the rearbitration of the next bus cycle to ensure the integrity of read-modify-write instructions. $\overline{ML}$ goes low during ASL, DEC, INC, LSR, ROL, ROR, TRB, TSB memory referencing instructions. This signal is low for the modify and write cycles. ## Reset (RES) The $\overline{RES}$ must be set high for normal operation. The microprocessor will not operate if $\overline{RES}$ is low. A positive transition on this line causes an initialization sequence to begin. Reset must be held low for at least two clock cycles after ${}^V DD$ reaches operating voltage from a power down condition. After this time, $R/\overline{W}$ is high and SYNC is low. When a positive edge is detected, there is an initialization sequence lasting six clock cycles. Then the interrupt mask flag is set, the decimal mode is cleared, and the program counter is loaded with the restart vector from locations FFFC (low byte) and FFFC (high byte). This is the start location for program control. #### Ready (RDY) This input signal allows the user to operate on the microprocessor by single-cycle on all cycles including write cycles. A negative transition to the low state during or coincident with phase one ( $\phi$ 1) will halt the microprocessor with the output address lines reflecting the current address being fetched. This condition will remain through a subsequent phase two ( $\phi$ 2) in which the ready signal is low. This feature allows microprocessor with low-speed memory as well as direct memory access (DMA). # Set Overflow (SO) A negative transition on this line sets the overflow flag-bit in the status code register. The signal is sampled on the trailing edge of $\phi 1$ ## Synchronize (SYNC) This output line is provided to identify those cycles during which the microprocessor is doing an OP CODE fetch. The SYNC line goes high during $\phi 1$ of an OP CODE fetch and stays high for the remainder of that cycle. If the RDY line is pulled low during the $\phi 1$ clock pulse in which SYNC went high, the processor will stop in its current state and will remain in the state until the RDY line goes high. In this manner, the SYNC signal can be used to control RDY to cause single instruction execution. #### Read/Write (R/W) This signal is normally in the high state indicating that the microprocessor is reading data from memory or I/O bus. In the low state the data bus has valid data from the microprocessor to be stored at the addressed memory location. $R/\overline{W}$ is set to the high impedance state by BE. (HKE65SC102 and 112 only). ## Interrupt Request (IRQ) This signal requests the microprocessor to execute an interrupt sequence. If $\overline{1RQ}$ is sampled during $\phi 2$ and the interrupt flag in the processor status register is zero, the current instruction is completed and the interrupt sequence begins during $\phi 1$ of next cycle. Then the program counter and processor status register are stored in the stack and the microprocessor will set the interrupt mask flag high so that no further interrupts may occur. At the end of this interrupt process, the program counter low will be loaded from address FFFE, and program counter high from location FFFF, i.e. the starting address of the interrupt service-routine is transferred into the program counter. The RDY signal must be in the high state for any interrupt to be recognized. A 3K ohm external resistor should be used for proper wire-OR operation. # Non-maskable Interrupt (NMI) This signal causes the microprocessor to execute a non-maskable interrupt sequence, when it is at low state and sampled during $\phi 2.$ After the current instruction is completed ,the interrupt sequence begins during $\phi 1.$ The program counter is loaded with the interrupt vector from locations FFFA (low byte) and FFFB (high byte), thereby transferring program control to the non-maskable interrupt routine. However, it should be noted this is an edge-sensitive input. As a result another interrupt will occur if there is another negative-going transition on this line and the program has not returned from a previous interrupt. Also, no new interrupt will occur if $\overline{NMl}$ is low and negative-going edge has not occurred since the last non-maskable interrupt. The following descriptions of timing signals are refered to Figure 3a and Figure 3b. ## Phase 0 IN ( $\phi$ 0 (IN) ) This is the buffered clock input to the internal clock generator on the HKE65SCOX series. Clock output $\phi$ 1(OUT) and $\phi$ 2(OUT) are derived from this signal. All three signals are on-chip signals in HKE65SCO2. ### Phase 1 Out (φ1 (OUT) ) This signal is derived from $\phi 0$ and is the inversion signal of $\dot{\phi} 2$ (out). $\dot{\phi} 1$ (out) provides timing for external R/W operations. ## Phase 2 Out ( $\phi$ 2 (OUT) ) This signal is derived from $\phi 0$ and provides timing for external bus $R/\overline{W}$ operation. Addresses are valid after the address setup time (tADS) from the falling edge of $\phi 2$ (OUT). # Clock In (CLK (IN) ) The 65SC10X series is supplied with an internal clock generator operating at four times the $\phi 2$ frequency. The frequency of these clocks are externally controlled by the crystal or oscillator circuit shown in Figure 3b. <sup>\*</sup> DBE is used in the HKE65SC12 only <sup>\*\*</sup>ML is designed into the HKE65SC102, 112 and 115 only. <sup>\*</sup>Voltage levels shown are $V_L \le 0.4 \, \text{V}$ , $V_H \ge 2.4 \, \text{V}$ unless otherwise specified. <sup>\*</sup>Measurement points shown are 0.8V & 2.0V unless otherwise specified. ## Phase 2 in ( $\phi$ 2(IN)) This is the unbuffered clock input to the internal clock generator on the HKE65SC1X and HKE65SC11X series. The clock output, $\phi$ 2 (OUT) is derived from this signal. # Oscillator Out (OSC(OUT) ) On the HKE65SC102 microprocessor, an internal inverter is connected between pins 35 and 37. The inverter has sufficient loop gain to provide oscillation using an external crystal. ## Phase 4 Out ( $\phi$ 4(OUT) ) This signal is delayed by tAVS from $\phi 2(\text{OUT})$ . The address output is valid prior to the rising edge of $\phi 4(\text{OUT})$ , this signal is used in HKE65SC104 only. Examples of crystal and RC circuits for internal oscillation timing signals are given in Figure 4 (a) and (b), respectively. The crystal circuit for external oscillation timing signal is given in Figure 4 (c). C1, C2 = 51pF R1 = 200K X1 = 1MHz Fig. 4(a) Crystal Circuit for internal Oscillator Suggested RC network configuration for internal oscillator. Fig. 4(b) RC Circuit for Internal Oscillator CRYSTAL: CTS KNIGHTS MP SERIES OR EQUIVALENT Fig. 4(c) Crystal Circuit for External Oscillator ## **ADDRESSING MODES** Fifteen addressing modes are available to the user of the HKE65SCXX and HKE65SC1XX series of microprocessors. The addressing modes are described in the following paragraphs: ## 1. Implied Addressing [implied] or [imp.] In the implied addressing mode, the address containing the operand is implicitly stated in the operation code of the instruction. Only one byte of memory is required for an instruction in this addressing mode. #### 2. Accumulator Addressing [Accu.] This addressing is similar to the implies addressing. It is represented with an one-byte instruction and implies that an operand is in the accumulator. #### Immediate Addressing [Imm.] With immediate addressing, the operand is contained in the second byte of the instruction; no further memory addressing is required. Two bytes of memory space is required in this addressing mode. #### 4. Absolute Addressing [Abs.] For absolute addressing the second byte of the instruction specifies the eight low order bits of the effective address while the third byte specifies the eight high order bits. Therefore, this addressing mode allows access to the total 64K bytes of addressable memory. Three bytes of memory space is required. # 5, 6. Absoulte Indexed Addressing [Abs, X] or [Abs, Y] Absolute indexed addressing is used in conjunction with X or Y index register and is referred to as "Absolute, X," and "Absolute, Y". Three bytes of memory space is required. The effective address is formed by adding the contents of X or Y to the address contained in the second byte of the instruction; the carry, if occured, is added to third byte of the instruction. This mode allows the index register to contain the index or count value and the instruction to contain the base address. This type of indexing allows any location referencing and the index to modify multiple fields resulting in reduced coding and execution time. ## 7. Zero Page Addressing [Z. Page] Zero page addressing allows shorter code and execution times by only fetching the second byte of the instruction and assuming a zero high address byte. The careful use of zero page addressing can result in significant increase in code efficiency. ## 8, 9. Zero Page Indexed Addressing [Z. Page, X] or [Z. Page, Y] Zero page addressing mode is used in conjunction with the index register and is referred to as "Zero Page, X" or "Zero Page, Y". The effective address is calculated by adding the second byte to the contents of the index register. Since this is a form of "Zero Page" addressing, the content of the second byte references a location in page Zero. Additionally, due to the "Zero Page" addressing nature of this mode, no carry is added to the high order eight bits of memory and crossing of page boundaries does not occur. Two bytes of the memory space are required for this instruction using this addressing mode. #### 10. Relative Addressing [Rela.] Relative addressing mode is used only with branch instruction; it establishes a distination for the conditional branch. Two bytes of memory space is required. ### 11. <sup>†</sup>Zero Page Indirect Addressing [(Z. PG)] In this form of addressing the second byte of the instruction contains the low order eight bits of a memory location. The high order eight bits is always zero. The contents of the fully specified memory location is the low order byte of the effective address. The next memory location contains the high order byte of the effective address. Two bytes of memory space is required. ## 12. Absolute Indirect Addressing [(Abs.)] The second byte of the instruction contains the low order eight bits of a memory location, which is referred to as the indirect address. The high order eight bits of that memory location is contained in the third byte of the instruction. The contents of the fully specified memory location is the low order byte of the effective address. The next memory location contains the high order byte of the effective address, and the effective address composed of two bytes is loaded into the 16 bits of the program counter. #### 13. Indirect Indexed Addressing [(Z. PG), Y] This form of addressing is usually referred to as Indirect, Y. The second byte of the instruction points to a memory location in page Zero. The contents of this memory location is added to the contents of the Y index register, the result being order eight bits of the effective address. The carry from this addition is added to the contents of the next location in page zero, the result being the high order eight bits of the effective address. The indirect indexed addressing may contain various combinational addresses of which, however, only the zero-page-indirect combinating with Y-index is available to the HKE65SCXXX. # 14. Zero Page Indexed Indirect Addressing [(Z. PG, X)] With zero page indexed indirect addressing (usually referred to as indirect X) the second byte of the instruction is added to the contents of the X index register; the carry is discarded. The result of this addition points to a memory location on page zero whose contents is the low order eight bits of the effective address. The next memory location in page zero contains the high order eight bits of the effective address. Both memory locations specifying the high and low order bytes of the effective address must be in page zero. This addressing mode is not available to the index register X. Each instruction, using this mode occupies two bytes of memory space. # 15. \*Absolute Index Indirect Addressing [(Abs, X)] The second byte of the instruction is added to the contents of the X index register. The high order eight bits of that memory location is contained in the third byte of the instruction. The result of this addition points to a memory location whose contents is the low order eight bits of the effective address. The next memory location contains the high order eight bits of the effective address. Both memory locations specifying the high and low order bytes of the effective address, i.e. An absolute X-index addressing followed by an absolute indirect addressing mode. <sup>\*</sup> New addressing mode available to the CMOS HKE65SCXXX microprocessors only. It is not designed in the NMOS6500. <sup>( )</sup> represents indirect addressing. # **INSTRUCTIONS AND MACHINE CODES** # The 64 instructions and 178 machine Codes of HKE65SCXXX (Typical example: HKE65SC02) Microprocessors | | | | | | | | | | | , | | | | | | | | | | | | |----------|-------------------|------------------------------------------------------------------------------------------------|--------------------------------------------------|---------------|----------------|--------------------------------------------------|--------------------------------------------------|--------------------------------------------------|--------------------------------------------------|--------------------------------------------------|--------------------------------------------------|--------------------------------------------------|--------------------------------------------------|--------------|--------------------------------------------------|--------------------------------------------------|--------------------------------------------------|--------------------------------------------------|--------------------------------------------------|--------------------------------------------------|-----------------| | No. | Mnemonic | OPERATION | | mp. | | | ccu. | | | nm. | | | . PG | | | PG, | | | G, Y | | | | | | | ор | # | n | op | # | n | op | # | n | op | # | | op | | n | ор | # | n | op | | 1 | ADC <sup>†</sup> | A+M+C→A 2 | | | | | | | 69 | 2 | 2 | 65 | 2 | 3 | 75 | 2 | 4 | <u> </u> | | - | 6D<br>2[ | | 2 | AND <sup>†</sup> | $A \wedge M \rightarrow A$ | <u> </u> | | | | | | 29 | 2 | 2 | 25 | 2 | | 35<br>16 | 2 | | | - | ├ | OE OE | | 3 | ASL | C ← 76543210 ← 0 | | | | 0A | 1_ | | | <u> </u> | - | 06 | 2 | 5 | 16 | 2 | 10 | | ├ | ⊢ | UE | | 4 | BCC | Branch occurs, if C=0 1 | | | | | | | | <u> </u> | | | | <u> </u> | | ┼ | + | | ├ | ├ | ł | | 5 | BCS | Branch occurs, if C=1 1 | | | | | | | | - | H | | | $\vdash$ | | ┼ | + | | | $\vdash$ | 1 | | 6 | BEQ | Branch occurs, if Z=1 1 | | - | | | | | oot. | - | 2 | 24 | 2 | 3 | 34+ | 2 | 4 | <del> </del> | - | - | 2C | | 7 | BIT <sup>+</sup> | $A \land M \rightarrow Z$ , $M7 \rightarrow N$ , $M6 \rightarrow V$<br>Branch occurs, if $N=1$ | | ├ | | - | | | 89 <sup>†</sup> | 2 | 1 | 24 | | 3 | 34 | 1- | +- | <del> </del> | <del> </del> | <del> </del> | <u> </u> | | 8 9 | BMI<br>BNE | Branch occurs, if N=1 1 Branch occurs, if Z=0 1 | | | | | | $\vdash$ | | | - | <del> </del> | | | - | 1 | <del> </del> | <del> </del> | _ | ╁ | $\vdash$ | | 10 | BPL. | Branch occurs, if V=0 | | - | - | | | | | ├─ | | | | - | | 1 | 1 | | | $\vdash$ | | | 11 | BRA++ | Unconditional Branch | | - | | | | - | | <b></b> | <del> </del> | <b>-</b> | | | | $\vdash$ | +- | <b></b> | - | 1 | | | 12 | BRK | PC+2↓, P↓FFFE, FFFF→PCL, PCH | 00 | 1 | 7 | | | | | <del> </del> | | <b> </b> | | | | <del> </del> | † | | <del> </del> | <del> </del> | t | | 13 | BVC | Branch occurs V=0 | - 00 | <del> '</del> | $\vdash$ | | | | | - | <del> </del> | 1 | | | | + | 1 | | | <del> </del> | 1 | | 14 | BVS | Branch occurs V=1 1 | <b>-</b> | | | | | | | <del> </del> | $\vdash$ | | | | $\vdash$ | 1 | <del> </del> | | <u> </u> | | | | 15 | CLC | 0 → C | 18 | 1 | 2 | | | | | <del> </del> | | | | | <del> </del> | 1 | <del> </del> | | | | | | 16 | CLD | 0 → D | D8 | 1 | 2 | | | | | h | | | | | | t | 1 | | $\vdash$ | 1 | | | 17 | CLI | 0 → 1 | 58 | 1 | 2 | | | | | <del> </del> | | | | | | 1 | 1 | <del> </del> | | | t | | 18 | CLV | 0 → V | B8 | 1 | 2 | | | | | | T | <b>†</b> | | | | $\vdash$ | † | Ī | 1 | | 1 | | 19 | CMP <sup>+</sup> | A_M→N.Z.C. | <u> </u> | †÷ | $\vdash$ | | | | C9 | 2 | 2 | C5 | 2 | 3 | D5 | 2 | 4 | <b>T</b> | İ | t | CD | | 20 | CPX | X_M→N.Z.C. | | t | | l | <b>-</b> | | EO | 2 | 2 | E4 | 2 | 3 | | T_ | T . | | | | EC | | 21 | CPY | Y–M→N.Z.C. | t | <b>†</b> | | | $\vdash$ | | CO | 2 | 2 | C4 | 2 | 3 | | | 1 | t | | <b>1</b> | cc | | 22 | DEC <sup>†</sup> | $A=1\rightarrow A$ or $M=1\rightarrow M$ | t | 1 | $\Box$ | 3A <sup>+</sup> | 1 | 2 | T | Ē | Ť | C6 | 2 | 5 | D6 | 2 | 6 | T | T | † | CE | | 23 | DEX | X-1→X | CA | 1 | 2 | | Ė | _ | $\vdash$ | | | | Ť | Ť | T | Ť | Ť | T | | | 1 | | 24 | DEY | Y_1-→Y | 88 | 1 | 2 | | | | † | | 1 | | | | T | | I | | | | | | 25 | EOR <sup>†</sup> | $AVM \rightarrow A$ | <del> </del> | T | | | 1 | | 49 | 2 | 2, | 45 | 2 | 3 | 55 | 2 | 4 | | | | 4D | | 26 | INC | A+1→A or M+1→M | | | | 1A <sup>+</sup> | 1 | 2 | | | <del> </del> | E6 | 2 | 5 | F6 | 2 | _ | | <u> </u> | | EE | | 27 | INX | X+1→X | E8 | 1 | 2 | | | T | | | | | | | | | | | | | | | 28 | INY | Y+1→Y | C8 | 1 | 2 | | | | | | | | | | | | | | Ĺ | | | | . 29 | JMP <sup>+</sup> | (PC+1)→PCL, (PC+2)→PCH | | | | | | | | | | | | | | <u>L</u> | | | | | 4C | | 30 | JSR | (PC+2)↓, (PC+1)→PCL(PC+2)→PCH | | | | | | | | | | | | | | | | | | | 20 | | 31 | LDA <sup>+</sup> | $M \rightarrow A$ | | | | | | | Α9 | 2 | 2 | A5 | 2 | 3 | B5 | 2 | 4 | | | L | ΑD | | 32 | LDX | $M \rightarrow X$ | | | | | | | A2 | 2 | 2 | A6 | 2 | 3 | | | | В6 | 2 | 4 | ΑE | | 33 | LDY | $M \rightarrow Y$ | | | | | | | Α0 | 2 | 2 | Α4 | 2 | 3 | B4 | 2 | 4 | | | | ΑC | | 34 | LSR | 0→76543210→C | | | | 4A | 1 | 2 | | | | 46 | 2 | 5 | 56 | 2 | 6 | | | | 4E | | 35 | NOP | No operation | ĒΑ | 1 | 2 | | | | | | | | | | L | | 1 | | <u> </u> | | <u> </u> | | 36 | ORA <sup>+</sup> | $AM \rightarrow A$ | | | | <u> </u> | | | 09 | 2 | 2 | 05 | 2 | 3 | 15 | 2 | 4 | ↓ | <u> </u> | <u> </u> | OD | | 37 | PHA | A↓(A → Ms), S-1→S | 48 | 1 | 3 | | L | | <u> </u> | L . | <u> </u> | | ļ | ļ | <u> </u> | 1 | <b> </b> | | <u> </u> | <u> </u> | ₽ | | 38 | PHP | $P\downarrow (P \rightarrow M_S), S-1 \rightarrow S$ | 08 | 1 | 3 | | | | | L. | ļ | | <u> </u> | ļ | | 1_ | ـــــ | | <u> </u> | <u> </u> | <u> </u> | | 39 | PHX <sup>++</sup> | ×↓(× →Ms), S–1→S | DA | | 3 | | 1 | <u> </u> | | <u> </u> | <u> </u> | | <u> </u> | <u> </u> | <b></b> | ļ | ↓ | | <u> </u> | <u> </u> | ┞— | | 40 | PHY++ | $Y\downarrow (Y \rightarrow M_S), S-1\rightarrow S$ | 5A <sup>†</sup> | 1 | - | <u> </u> | <u> </u> | ļ | ļ | | L | <b>.</b> | <u> </u> | | ļ | ļ | <b>├</b> | | 1 | <u> </u> | ₽ | | 41 | PLA | $A\uparrow (M_S \rightarrow A), S+1 \rightarrow S$ | 68 | 1 | 4 | <b>!</b> | L | ļ | | <u> </u> | <u> </u> | ļ | _ | ļ | <u> </u> | 1 | <del> </del> | <b> </b> | <b>↓</b> | <b>↓</b> — | ₩ | | 42 | PLP | $P\uparrow(M_S \rightarrow P), S+1\rightarrow S$ | 28 | 1 | 4 | <u> </u> | L | <b> </b> | <b> </b> | <u> </u> | <u> </u> | | ļ | <del> </del> | <u> </u> | <b> </b> | <b> </b> | | ऻ— | <del> </del> | <b>!</b> | | 43 | PLX <sup>++</sup> | X↑(Ms→X), S+1→S | FA <sup>+</sup> | 1 | | <b></b> | - | ļ | <b> </b> | | <u> </u> | | <u> </u> | | <b></b> | <del> </del> — | <b>├</b> | <u> </u> | <b>↓</b> | <b>├</b> | <b>!</b> | | 44 | PLY <sup>++</sup> | Y↑(Ms → Y), S+1→S | 7A <sup>+</sup> | 1 | 4 | <u> </u> | <u> </u> | _ | L | ļ | <b>L</b> | | <u> </u> | - | | +- | +- | <u> </u> | <del> </del> | <del> </del> | | | 45 | | 7 6-0- | <u> </u> | <del> </del> | <b>—</b> | 2A | 1 | 2 | ļ | ├- | <b>├</b> | 26 | 2 | 5 | 36 | 2 | | ├ | 1 | <del> </del> | 2E<br>6E | | 46 | ROR_ | -C-9 6- | 40 | 1 | 6 | 6A | 1 | 2 | <b>-</b> | <del> </del> | - | 66 | 2 | 5 | 76 | 2 | 6 | 1 | - | - | OE. | | 47 | | P↑, PС↑ S+1→S | 40 | 1 | 6 | $\vdash$ | $\vdash$ | - | - | <del> </del> | - | - | <del> </del> | - | <del> </del> | $\vdash$ | + | ├ | $\vdash$ | <del> </del> | $\vdash$ | | 48 | | PC↑, PC+1→PC S+1→S<br>$A-M-\overline{C}\rightarrow A$ , $\overline{C}$ :Borrow 2 | 60 | 1 | 6 | <del> </del> | - | | E9 | 2 | 2 | E5 | 3 | 4 | F5 | 2 | 4 | <del> </del> | + | <del> </del> | ED | | 49 | | | 30 | 1 | 1 | <del> </del> | - | <del> </del> | E9 | <del> _</del> | 12 | _ C O | 3 | ++- | 1.2 | 12 | +-4- | t | $\vdash$ | <del> </del> | 100 | | 50 | SEC | 1 → C<br>1 → D | 38<br>F8 | 1 | 2 | <b>.</b> | <del> </del> | - | <del> </del> | | - | <del> </del> | <del> </del> | | 1- | + | ╁ | 1 | <del> </del> | <del> </del> | 1 | | 51 | SED | 1 → 1 | 78 | | | $\vdash$ | - | <del> </del> | <del> </del> | <del> </del> | $\vdash$ | <del> </del> | <del> </del> | <del> </del> | +- | + | + | <del> </del> | <del> </del> | <del> </del> | 1 | | 52 | | | <del> ′°</del> | 1 | <del> </del> | <b>}</b> | <del> </del> | + | <del> </del> | <del> </del> | + | 85 | 2 | 3 | 95 | 2 | 4 | <del> </del> | 1 | - | 8D | | 53<br>54 | | $\begin{array}{c} A \to M \\ X \to M \end{array}$ | <del> </del> | +- | <del> </del> | <del> </del> | <del> </del> | <u> </u> | <del> </del> | + | <del> </del> | 86 | 2 | 3 | 90 | <del> _</del> | +- | 96 | 2 | 4 | 8E | | | | | 1 | + | <del> </del> | <b> </b> - | <del> </del> | <del> </del> | | +- | <del> </del> | 84 | 2 | 3 | 94 | 2 | 4 | 1-30 | 1- | + | 8C | | 55 | | Y → M<br>00 – M | <del> </del> | +- | <del> </del> - | <b>}</b> | ├— | <del> </del> | <del> </del> | | <del> </del> | 64 <sup>+</sup> | 2 | | 74 | | 4 | <del> </del> | 1 | <del> </del> | 9C | | 56<br>57 | | A – M | AA | 1 | 2 | 1 | <del> </del> | | <del> </del> | <del> </del> | <del> </del> | 04 | | 1 2 | 1-/4 | +- | += | <del> </del> | <del> </del> | <del> </del> | <u>90</u> | | 57<br>58 | | A – M<br>A – Y | AB | + | 2 | <del> </del> | <u> </u> | - | <del> </del> | $\vdash$ | <del> </del> | t | <del> </del> | | | + | <del> </del> | t | <del> </del> | <del> </del> | t | | | | | H AB | +- | +- | <b></b> | + | | $\vdash$ | + | <del> </del> | 14+ | 2 | 5 | <del> </del> | <del> </del> | + | 1 | 1 | <del> </del> | 1C <sup>†</sup> | | 59 | 4 | $A \wedge M - M$ | <del> </del> | + | + | $\vdash$ | <del> </del> | <del> </del> | <del> </del> | + | + | 04+ | 2 | 5 | <del> </del> | + | <del> </del> | <del> </del> | <del> </del> | <del> </del> | OC <sup>†</sup> | | 60 | | $\begin{array}{c} A \lor M - M \\ S \to X \end{array}$ | ВА | 1 | 2 | <del> </del> | <del> </del> | <del> </del> | <del> </del> - | | <del> </del> | - 04 | | ۲ | <del> </del> | <del> </del> | <del> </del> | $\vdash$ | + | <b>!</b> | -00 | | 61 | | $S \rightarrow X$<br>$X \rightarrow A$ | SA | 1 | 2 | $\vdash$ | 1 | <del> </del> | <del> </del> | <del> </del> | <del> </del> | <del> </del> | | <del> </del> | <del> </del> | ╁ | +- | <del> </del> | <del> </del> | <del> </del> | 1 | | 62 | | | 9A | 1. | | <del> </del> | ├ | + | <del></del> | <del> </del> | <del> - </del> | 1 | | | <del> </del> | 1 | $\vdash$ | <del> </del> | + | <del> </del> | 1 | | 63 | + | X → S | 98 | + | 2 | <b>!</b> | <del> </del> | $\vdash$ | <del> </del> | <del> </del> | <del> </del> | <del> </del> | - | 1 | <del> </del> | $\vdash$ | + | $\vdash$ | 1- | <del> </del> | <del> </del> | | 64 | TYA | Y→A | | 1 <u>1</u> | L | <u> </u> | 1 | Ь | <del> </del> | <u></u> | <u> </u> | - | Z DC | <u> </u> | -7 | PC | <del>^</del> | <del> </del> | PC. | <del>^</del> | <del> </del> | | | L | Function | 1 | imp. | | | accu. | | <u> </u> | mm. | | | Z.PG | | ∠. | .PG. | ٨ | | .PG, | ř | <b>I</b> . | Notes: A Accu X inde: Y inde: <sup>\*</sup> Add 1 to n if page boundary is crossed. Add 1 to n if branch occurs to same pate. Add 2 to n if branch occurs to different page. <sup>2.</sup> Add 1 to n if decimal mode. New instruction <sup>+ (</sup>with) additional addressing mode(s) M Mem | | _ | | | | | | | | | | - | | | | | | | - | | | | | 1 | | | c | tute | flan | , | | 7 | | |--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--------------------------------------------------|--------------------------------------------------|--------------|--------------------------------------------------|------------------|--------------------------------------------------|--------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------|--------------------------------------------------|--------------------------------------------------|--------------------------------------------------|--------------------------------------------------|-----------------|--------------|-----------------|------------------------|--------------------------------------------------|--------------------------------------------------|--------------------------------------------------|--------------|--------------|--------------------------------------------------|----------|-----------------|----------|--------------|----------------|--------------|--------------------| | | | Mod | | | - 1 | | | | , | | _ | 17 | DO 1 | | , , , | 261 | V | 17 | D C 1 <sup>+</sup> | | /21 | os, X | , | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | abs | | _ | | bs. Y | | | ela.<br># | اير | op (a | abs.) | n | (Z. | PG, 2 | X) | - {∠. l<br>op | °G),<br># | Y<br>n | (Z.<br>op | PG) <sup>†</sup> | n | Ор | os, A | n | Z / | $\frac{\circ}{\vee}$ | - | B | D | | z | č | | | | | n<br>4* | ор<br>79 | # | n<br>4* | op | # | n | οp | # | | 61 | 2 | 6 | 71 | 2 | 5* | 72 <sup>+</sup> | 2 | 5 | <u> </u> | " | | Z | Ť | $\dashv$ | | | | Z | Č | ADC <sup>+</sup> | | | | 4* | 39 | 3 | 4* | | | | | | | 21 | 2 | 6 | 31 | 2 | 5* | 32+ | 2 | 5 | | Н | | N | _ | | | | | z | | AND | | | 3 | 7 | 39 | 3 | - | | | | | - | | ۷, | - | Ť | <del></del> | | <del>-</del> | J2 | - | Ť | | | | N | | | | | | z | С | ASL | | +-` | + | - | | - | _ | 90 | 2 | 2 | | | | | | | | | - † | | $\dashv$ | | | $\Box$ | | | | | | 一 | | | | BCC | | ╫ | + | | | $\vdash$ | _ | B0 | 2 | 2 | | $\vdash$ | | | | - | | $\vdash$ | | | $\dashv$ | | | | | _ | | $\neg$ | | | | | | BCS | | ┿ | + | - | | - | | F0 | 2 | 2 | | - | | | | | | Н | | | | | | | | | | | | | _ | | | BEO | | +; | <del>,</del> + | 4* | | $\vdash$ | | го | - | - | | | - | <u> </u> | - | | | $\vdash \dashv$ | | - | | | | | | М7 | М6 | | | | | z | | BIT | | + | 3 | 4 | | - | | 30 | 2 | <u> </u> | | $\vdash$ | Н | | | | | $\vdash$ | | | | | | | - | ,,,,, | | | $\neg \uparrow$ | 1 | | | | BMI | | + | - | | | ├─┤ | | | | 2 | | ├ | | | | | | Н | | | | - | <u> </u> | | | | | $\neg$ | $\neg$ | T | | | | BNE | | + | $\dashv$ | - | | Н | | D0<br>10 | 2 | 2 | | - | - | | Н | | | | | | | | <del></del> | $\vdash$ | $\dashv$ | | | | | $\dashv$ | _ | | | BPL | | + | -+ | | | - | | | 2 | 3 | | | $\vdash$ | | | | | - | $\dashv$ | | | | <del> </del> | | | | $\vdash$ | | _ | | $\neg$ | $\neg \neg$ | | BRA | | + | + | - | | <u> </u> | | 80 <b>*</b> | <del> _</del> | 3 | | - | | | | | | | -+ | | | | <del> </del> | | - | | | | 1 | 0 | 1 | | | BRK | | + | - | | | $\vdash$ | | | <u> </u> | | | - | | | | | | Н | -+ | | - | | <del> </del> | <del> </del> | | | | | | <u> </u> | | | | BVC | | + | $\dashv$ | | | | | 50 | 2 | 2 | | | | | | | | $\vdash$ | -1 | | | - | <del> </del> | $\vdash$ | | | $\vdash$ | | $\neg$ | 1 | | | | BYŞ | | + | - | | | | | 70 | 2 | 2 | | 1 | | - | | | | $\vdash$ | - | - | | - | <b>-</b> | <del> </del> | | | $\vdash$ | | | $\neg$ | | | 0 | CLC | | 4 | 4 | | | | | | <del> </del> | | | ļ., | | | <u> </u> | | | $\vdash$ | | | | | ├ | <del> </del> | | | | | | 7 | | | Ť | CLD | | + | 4 | | | <b> </b> | | | - | | | ₩ | | | | $\vdash$ | | $\vdash$ | | | | | ├ | - | | | ├┤ | $\dashv$ | | $\dashv$ | 0 | | - | CLI | | + | $\dashv$ | | | | | | - | <b>├</b> | ļ | ├ | $\vdash$ | | - | | | | $\dashv$ | | - | | <del> </del> - | | | | 0 | $\dashv$ | | | - | $\vdash$ | | CLV | | + | _ | 1 | | | | | _ | ļ | <b>—</b> | <del> </del> | ļ | | | 6 | D.1 | | | D3 | <del> </del> | F* | <b></b> | - | | N | <del> </del> | $\dashv$ | | $\dashv$ | | Z | С | CMP | | 1 | 3 | 4* | D9 | 3 | 4* | | _ | | <b>—</b> | <del> </del> | <b> </b> | C1 | 2 | 6 | D1 | 2 | 5* | D2 | 2 | 5* | <del> </del> | 1 | | N | $\vdash$ | | - | - | | Z | С | CPX | | + | _ | | <u></u> | $\perp$ | | | | $\vdash$ | <u> </u> | ₩ | | | | $\vdash$ | | $\vdash \vdash$ | | | <b></b> | | <b>-</b> | - | | | | $\vdash$ | | | | Z | C | CPY | | $\perp$ | $\perp$ | | | Ш | | | | Ь. | | <del> </del> | | | $\vdash$ | | | $\vdash$ | | | $\vdash \vdash \vdash$ | | | $\vdash$ | | N | $\vdash$ | | | | | Z | | DEC <sup>*</sup> | | 1 | 3 | 7 | | | | | <u> </u> | <u> </u> | | ↓ | <u> </u> | ļ | | $\vdash \vdash$ | | | | | $\vdash$ | | <del> </del> | | $\vdash$ | N | | | | | | . Z | | DEX | | 1 | $\perp$ | | | $ldsymbol{\sqcup}$ | | | <b>L</b> | | | <u> </u> | <b> </b> - | <b>-</b> | ļ | | | | | | $\vdash \vdash$ | | ├ | <del> </del> | | N | $\vdash$ | | | - | | . Z | | DEY | | 1 | | | | L_ | | Ļ | ₩ | <u></u> | | ₩ | <b></b> | <del> </del> | <u> </u> | <u> </u> | F. | <u> </u> | | + | اجا | _ | <del> </del> | $\vdash$ | | | $\vdash$ | | | | | | $\vdash$ | EOR | | | 3 | 4* | 59 | 3 | 4* | | <u> </u> | ļ | | <b>↓</b> | <b> </b> | 41 | 2 | 6 | 51 | 2 | 5* | 52 <sup>†</sup> | 2 | 5 | - | <b>├</b> | | N | $\vdash \vdash \vdash$ | $\vdash$ | | | | Z | | | | 1 | 3 | 7 | | <u> </u> | | L | <u> </u> | igwdow | | ļ | <u> </u> | | | L | | ļ | | | | | <u> </u> | <b>├</b> — | | N | $\vdash \vdash$ | | | | | Z | | INC <sup>†</sup> | | $\perp$ | [ | | | | | | <u> </u> | | | <del> _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ </del> | | | <u> </u> | <b> </b> | <u> </u> | | | | $\sqcup$ | | <u> </u> | - | ļ | <u>N</u> | $\vdash$ | | | | | Z | $\dashv$ | | | $\prod$ | $\bot$ | | | | | | L. | | L | | | L | L | igsquare | | L | | | | | | <del> </del> | | Ν | $\longmapsto$ | | | | | Z | - | INY | | $\prod$ | $oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{oldsymbol{ol{ol{ol}}}}}}}}}}}}}}}}}}$ | | | | | | | | 6C | 3 | 5 | <u> </u> | | Ш | <u> </u> | | | | | | 7C <sup>+</sup> | 3 | 6 | | $\sqcup$ | | | | | | $\sqcup$ | JMP <sup>+</sup> | | I | | | | | | | | | | | | | | | | <b>.</b> | | | Щ | | | lacksquare | L | | $\sqcup$ | | | | | _ | | JSR | | I | 3 | 4* | В9 | 3 | 4* | | | | | | | Α1 | 2 | 6 | B1 | 2 | 5* | В2 <b>*</b> _ | 2 | 5 | | ļ | | Ν | 1 | | | | | Z | | LDA | | 1 | $\Box$ | | BE | 3 | 4* | | | | | | | | | $\Box$ | | | | | | | | ļ | Ш | Ζ | $\sqcup$ | | | | | Z | <b>}</b> | LDX | | | 3 | 4* | | | | | | | | | | | | | | | | | $\square$ | | <u> </u> | <u> </u> | $\sqcup$ | 2 | <b>├</b> | | | | | Z | Ļ | LDY | | Ī | 3 | 7 | [ | | | | | | | | | | | | | | i | | | | L | <u> </u> | | 0 | <b>↓</b> | | | | | Z | С | LSR_ | | | | | | | | | | | | | | | | | | | I | | | | L | <u> </u> | $oxed{oxed}$ | | igsqcut | | | | | <u> </u> | Ш | NOP | | $\top$ | 3 | 4* | 19 | 3 | 4* | | L | | | | | 01 | 2 | 6 | 11 | 2 | 5* | 12 <sup>†</sup> | 2 | 5 | | | | Ζ | $\sqcup$ | | | | | Z | Ш | ORA | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | PHA | | $\top$ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | PHP | | + | | | | t | | | | T | 1 | | 1 | | | | | | | | | | | | | | | | | | | | | PHX <sup>++</sup> | | 十 | † | | | † | | | | | | † | | 1 | | | | | | | | | | | | | | | | | | | | PHY <sup>++</sup> | | + | | | | $\vdash$ | | | 1 | | | t | T | | | | | | | | | | 1 | | | Ν | | | | | | Z | | PLA | | + | | | <b></b> | $\vdash$ | | | <u> </u> | † · · · · | | T | † | | Τ" | | | | | | | | <b>†</b> | | | Ζ | V | | 1 | D | 1 | Z | С | PLP | | + | $\dashv$ | - | <b></b> | <del> </del> | | | † | t | <b>T</b> | | | 1 | T | | | 1 | | | | | Ī | | | 2 | | | | | | Z | | PLX** | | + | $\dashv$ | $\vdash$ | <b>—</b> | t | $\vdash$ | | † | <del> </del> | t | t | | 1 | t | | | 1 | | | | | | | | N | П | | | | | Z | | PLY++ | | + | 3 | 6* | <b></b> | $\vdash$ | | | | | <b>—</b> | <del> </del> | t | | t | † · · · | t — | T | | | | | t | | | N | | | | | | Z | С | ROL | | | 3 | 6* | $\vdash$ | <del> </del> | <u> </u> | <del> </del> | + | 1 | | † | + | 1 | t | t | | <u> </u> | | | | | <b>1</b> | 1 | 1 | Z | П | | | | · · | Z | C | ROR | | + | <del>- </del> | ┝┷┤ | $\vdash$ | $\vdash$ | | <b></b> | $\vdash$ | $\vdash$ | <b>-</b> | <del> </del> | t | $\vdash$ | t | <del> </del> | <b>†</b> | †=== | - | | | <u> </u> | | <u> </u> | | Z | V | | 1 | D | 1 | Z | C | RTI | | + | - | $\vdash$ | <del> </del> | <del> </del> | <del> </del> | <del> </del> | + | $\vdash$ | <del> </del> | † | 1 | <b>†</b> | t | | <b>-</b> | <del> </del> | * | | $\vdash$ | | | † | $\vdash$ | Ė | $\vdash$ | _ | | | | Ē | Ť | RTS | | $^{\dagger}$ | 3 | 4* | F9 | 3 | 4* | <del> </del> | + | <u> </u> | <del> </del> | † | <del> </del> | E1 | 2 | 6 | F1 | 2 | 5* | F2 <sup>+</sup> | 2 | 5 | $t^{-}$ | † | $\Box$ | N | V | - | | | | Z | С | SBC <sup>+</sup> | | + | <del>-</del> | | | ۲ | <del> </del> | <del> </del> | + | <del> </del> | <b></b> | † | $\dagger$ | <del> </del> | +- | ✝Ť | <b>-</b> | ╁╌ | <del></del> | 1.4 | += | | t | 1 | $\vdash$ | <u> </u> | <u> </u> | | | | | Ť | 1 | SEC | | + | $\dashv$ | $\vdash\vdash$ | $\vdash$ | <del> </del> | - | <del> </del> | + | + | <del> </del> | + | <del> </del> | <del> </del> | <del> </del> | <b> </b> | <b>†</b> | | $\vdash$ | | ţ | | t | 1 | | ┢┈ | <del> </del> | <b>-</b> | | 1 | | $\vdash$ | † <u> </u> | SED | | + | | <b></b> | <del> </del> | + | | <b></b> | +- | - | $\vdash$ | + | + | + | +- | <del> </del> | <b>-</b> | <del> </del> | | | 1 | - | <b>†</b> | +- | | <del> </del> | | <u> </u> | - | ÷ | 1 | - | <del> </del> | SEI | | + | _ | - | -00 | 1 - | _ | <b> </b> | + | ┼ | <del> </del> | +- | +- | 81 | 2 | 6 | 91 | 2 | 6 | 92 <sup>+</sup> | 2 | 6 | <del> </del> | + | | ⊢ | - | | | | + | - | <del> </del> | STA <sup>+</sup> | | Ŧ | 3 | 5 | 99 | 3 | 5 | ├ | + | ┼── | - | + | ╂ | 01 | _ | <del> °</del> | 91 | +- | <u>-</u> | 92 | ┝╧ | 0 | + | + | | <del> </del> | $\vdash$ | | $\vdash$ | | - | <del> </del> | <u> </u> | STX | | + | | | <b></b> | - | | | + | - | 1 | + | + | 1 | ┼ | <del> </del> | <del> </del> | <del> </del> | | ļ | + | | <del> </del> | + | | | $\vdash$ | $\vdash$ | $\vdash$ | - | <del> </del> | $\vdash$ | + | STY | | + | | لــِــا | | - | ļ | <u> </u> | - | ₩ | <b>├</b> ─ | <del> </del> | 1- | <b> </b> | | | <b> </b> | ├ | $\vdash$ | | <del> </del> | <del> </del> | - | + | | _ | $\vdash$ | <u> </u> | <del> </del> | | $\vdash$ | $\vdash$ | <del> </del> | | | 1 | 3 | 5 | ļ | - | ļ | | $\vdash$ | - | <b>├</b> | + | +- | <b>├</b> | <b>├</b> | +- | ├ | 1 | $\vdash$ | | <del> </del> | 1 | <b>├</b> ── | 1 | H | - N 1 | <del> </del> | $\vdash$ | $\vdash$ | | $\vdash$ | - | ├ | STZ <sup>++</sup> | | + | _ | | ļ | <del> </del> | <b>—</b> — | <b>—</b> | 1 | - | | + | ₩- | <b>!</b> | + | - | <del> </del> | <del> </del> | ļ | ļ | <b>!</b> | 1 | 1 | ┼ | <del> </del> | Z | $\vdash$ | <b>!</b> | 1 | <u> </u> | - | Z | - | TAX | | 1 | | <b></b> | ļ | - | <u> </u> | <b>!</b> | <del> -</del> | <del> </del> | ļ | ₩ | ↓ | <u> </u> | ـــ | <del> </del> | <b></b> | <b>-</b> | Ш | | - | | ₩ | ↓ | <b>├</b> ─ | N | | $\vdash$ | <u> </u> | | - | Z | - | TAY | | $\bot$ | _ | | | 1 | | | 4— | <u> </u> | <b> </b> | 1_ | <b>_</b> | L | 1 | 1 | | <u> </u> | $oxed{oxed}$ | | 1 | <b> </b> | 1 | ـ | <b> </b> | Μ7 | M6 | <u> </u> | _ | | _ | <del> _</del> | <del> </del> | TRB <sup>†</sup> | | 丄 | | | L | 1 | | <u> </u> | | ļ | <u> </u> | ↓ | <u> </u> | <u> </u> | 1 | ļ | L | <b> </b> | Ш | | <u> </u> | L | <u> </u> | <del> </del> | Щ. | | М6 | ļ | ļ | ļ | | Z | <u> </u> | TSB <sup>+ 1</sup> | | $\perp$ | | | | 1 | L | ļ | | | <u> </u> | 4_ | lacksquare | L | <u> </u> | <u> </u> | | ↓ | ļ | | L | <u> </u> | <b> </b> | ↓ | <u> </u> | Ν | igspace | _ | _ | | | Z | L- | TSX | | $\perp$ | | L | L | | | | | | | | | 1 | 1 | | | <u> </u> | | | | <u> </u> | 1 | <u> </u> | <u> </u> | Ν | | | | | <u></u> | Z | <u> </u> | TXA | | ┑. | | | L | | L | | $oxed{\Box}$ | | | $\bot$ | | | | | | | | | <u> </u> | | | | | Ν | | | | | | Z | <u> </u> | TXS | | | | | | | | | $\mathbb{L}^{-}$ | | | | L | L | | | | | | | | 1 | | | <u> </u> | Ν | | _ | | | | Z | _ | TYA | | | | | | abs, Y | | | rela. | | | (abs.) | , | 1 | .PG, | | | PG), | _ | | .PG | _ | | abs, > | | Z | V | | В | Ð | | Z | С | | effective address Ms Memory byte per stack pointer Bytes per instruction n Cycles per instructionM6 bit 6 of memory byte M7 bit 7 of memory byte N~C Flag bit of state register +/- ADD/Substrate Λ/V AND/OR Exclusive OR Trans. from . . . to . . . Push . . . on stack Pull . . . from stack # INSTRUCTION SET ALPHABETIC SEQUENCE (Typical Version: HKE65SC02 | Mnemonic | Function | Mnemonic | Function | |-----------------------------------|-----------------------------------------------------------------|------------------------|----------------------------------------------| | (1) ADC <sup>†</sup> | Add Memory to Accumulator with Carry | (33) LDY | Load Index Y with Memory | | (2) AND+ | "AND" Memory with Accumulator | (34) LSR | Shift One Bit Right (Memory or Accumulator) | | (3) ASL | Shift Left One Bit (Memory or Accumulator) | (35) NOP | No Operation | | (4) BCC | Branch on Carry Clear | (36) ORA* | "OR" Memory with Accumulator | | (5) BSC | Branch on Carry Set | (37) PHA | Push Accumulator on Stack | | (6) BEQ | Branch on Result Zero | (38) PHP | Push Processor Status on Stack | | (7) BIT | Test Bits in Memory with Accumulator | (39) PHX** | Push X Register on Stack | | (8) BMI | Branch on Result Minus | (40) PHY** | Push Y Register on Stack | | (9) BNE | Branch on Result not Zero | (41) PLA | Pull Accumulator from Stack | | (10) BPL | Branch on Result Plus | (42) PLP | Pull Processor Status from Stack | | (11) BRA++ | Branch Always | (43) PLX** | Pull X Register from Stack | | (12) BRK | Force Break | (44) PLY** | Pull Y Register from Stack | | (13) BVC | Branch on Overflow Clear | (45) ROL | Rotate One Bit Left (Memory or Accumulator) | | (14) BVS | Branch on Overflow Set | (46) BOB | Rotate One Bit Right (Memory or Accumulator) | | (15) CLC | Clear Carry Flag | (47) BTI | Return from Interrupt | | (16) CLD | Clear Decimal Mode | (48) RTS | Return from Subroutine | | (17) CLI | Clear Interrupt Disable Bit | (49) SBC | Subtract Memory from Accumulator with Borrow | | (18) CLV | Clear Overflow Flag | (50) SEC | Set Carry Flag | | (19) CMP <sup>+</sup> | Compare Memory and Accumulator | (51) SED | Set Deciami Mode | | (20) CPX | Compare Memory and Index X | (52) SEI | Set Interrupt Disable Status | | | Compare Memory and Index Y | (53) STA <sup>+</sup> | Store Accumulator in Memory | | (21) CPY | Decrement Memory by One | (54) STX | Store Index X in Memory | | (22) DEC <sup>+</sup> | Decrement Index X by One | (55) STY | Store Index Y in Memory | | (23) DEX | Decrement Index Y by One | (56) STZ++ | Store Zero | | (24) DEY | "Exclusive-OR" Memory with Accumulator | (57) TAX | Transfer Accumulator to Index X | | (25) EOR <sup>+</sup> | Increment Memory by One | (58) TAY | Transfer Accumulator to Index Y | | (26) INC <sup>†</sup> | Increment Index X by One | (59) TRB++ | Test and Reset Bits | | (27) INX | Increment Index X by One | (60) TSB <sup>++</sup> | Test and Set Bits | | (28) INY | | (61) TSX | Transfer Stack Pointer to Index X | | (29) JMP <sup>+</sup> | Jump to New Location Jump to New Location Saving Return Address | (62) TXA | Transfer Index X to Accumulator | | (30) JSR | | (62) TXS | Transfer Index X to Stack Register | | (31) LDA <sup>†</sup><br>(32) LDX | Load Accumulator with Memory Load Index X with Memory | (64) TYA | Transfer Index Y to Accumulator | # INSTRUCTION SET OP CODE MATRIX (TYPICAL VERSION: HKE65SC02) | | | | | | | ETOT | | | | | | | | | | | |-------|----------------------|------------------------|--------------------|---|--------------------|----------------------|--------------------|--------------------|-----------------------|---------------------|---|-----------------------|------------------------|-----------------------|----|---| | MSESB | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 8 | 9 | А | В | С | D | E | F | | | 0 | BRK<br>Impl<br>17 | ORA<br>(ZP,X)<br>26 | | | TSB<br>ZP<br>25 | ORA<br>ZP<br>23 | ASL<br>ZP<br>25 | PHP<br>Impl<br>1 3 | ORA<br>IMM<br>22 | ASL<br>Accum<br>1 2 | | TSB<br>ABS<br>36 | ORA<br>ABS<br>3 4 | ASL<br>ABS<br>36 | | 0 | | 1 | BPL<br>Rela<br>2 2** | ORA<br>(ZP),Y<br>25* | ORA<br>(ZP)<br>25 | | TRB<br>ZP<br>25 | ORA<br>ZP, X<br>24 | ASL<br>ZP,X<br>26 | CLC<br>Impl<br>1 2 | ORA<br>ABS,Y<br>3 4* | INC<br>Accum<br>1 2 | | TRB<br>ABS<br>36 | ORA<br>ABS, X<br>3 4* | ASL<br>ABS, X<br>37 | | 1 | | 2 | JSR<br>Abs<br>36 | AND<br>(ZP,X)<br>26 | | | BIT<br>ZP<br>23 | AND<br>ZP<br>23 | ROL<br>ZP<br>25 | PLP<br>Impl<br>1 4 | AND<br>IMM<br>22 | ROL<br>Accum<br>1 2 | | BIT<br>ABS<br>3 4 | AND<br>ABS<br>34 | ROL<br>ABS<br>36 | | 2 | | 3 | BMI<br>Rela<br>2 2** | AND<br>(ZP), Y<br>25* | AND<br>(ZP)<br>25 | | BIT<br>ZP, X<br>24 | AND<br>ZP, X<br>24 | ROL<br>ZP, X<br>26 | SEC<br>Impl<br>1 2 | AND<br>ABS,Y<br>3 4* | DEC<br>Accum<br>1 2 | | BIT<br>ABS, X<br>3 4* | AND<br>ABS, X<br>3 4* | ROL<br>ABS, X<br>37 | | 3 | | 4 | RTI<br>Impl<br>16 | EOR<br>(ZP,X)<br>26 | | | | EOR<br>ZP<br>23 | LSR<br>ZP<br>25 | RHA<br>Impl<br>13 | EOR<br>IMM<br>22 | LSR<br>Accum<br>1 2 | | JMP<br>ABS<br>33 | EOR<br>ABS<br>34 | LSR<br>ABS<br>36 | | 4 | | 5 | BVC<br>Rela<br>2 2** | EOR<br>(ZP), Y<br>25* | EOR<br>(ZP)<br>25 | | | EOR<br>ZP, X<br>24 | LSR<br>ZP, X<br>26 | CLI<br>Impl<br>12 | EOR<br>ABS,Y<br>3 4* | PHY<br>Impl<br>13 | | | EOR<br>ABS, X<br>3 4* | LSR<br>ABS, X<br>37 | | 5 | | 6 | RTS<br>Impl<br>16 | ADC<br>(ZP,X)<br>26+ | | | STZ<br>ZP<br>23 | ADC<br>ZP<br>23+ | ROR<br>ZP<br>25 | PLA<br>Impl<br>1 4 | ADC<br>IMM<br>2 2+ | ROR<br>Accum<br>1 2 | | JMP<br>(ABS)<br>35 | ADC<br>ABS<br>3 4+ | ROR<br>ABS<br>36 | | 6 | | 7 | BVS<br>Rela<br>2 2** | ADC<br>(ZP), Y<br>25*+ | ADC<br>ZP,X<br>25+ | | STZ<br>ZP,X<br>24 | ADC<br>ZP, X<br>2 4+ | ROR<br>ZP, X<br>26 | SEI<br>Impi<br>12 | ADC<br>ABS,Y<br>3 4*+ | PLY<br>Impl<br>14 | | JMP<br>(ABS,X)<br>36 | ADC<br>ABS, X<br>3 4*+ | ROR<br>ABS, X<br>37 | | 7 | | 8 | BRA<br>Rela<br>23 | STA<br>(ZP,X)<br>26 | | | STY<br>ZP<br>23 | STA<br>ZP<br>23 | STX<br>ZP<br>23 | DEY<br>Impl<br>12 | BIT<br>IMM<br>22 | TXA<br>Impl<br>1 2 | | STY<br>ABS<br>3 4 | STA<br>ABS<br>3 4 | STX<br>ABS<br>3 4 | | 8 | | 9 | BCC<br>Rela<br>2 2** | STA<br>(ZP), Y<br>. 26 | STA<br>(ZP)<br>26 | | STY<br>ZP,X<br>24 | STA<br>ZP, X<br>24 | STX<br>ZP, Y<br>24 | TYA<br>Impl<br>12 | STA<br>ABS,Y<br>35 | TXS<br>Impl<br>1 2 | | STZ<br>ABS<br>3 4 | STA<br>ABS,X<br>35 | STZ<br>ABS, X<br>35 | | 9 | | А | LDY<br>IMM<br>22 | LDA<br>(ZP,X)<br>26 | LDX<br>IMM<br>22 | | LDY<br>ZP<br>23 | LDA<br>ZP<br>23 | LDX<br>ZP<br>23 | TAY<br>Impl<br>12 | LDA<br>IMM<br>22 | TAX<br>Impl<br>12 | | LDY<br>ABS<br>34 | LDA<br>ABS<br>3 4 | LDX<br>ABS<br>3 4 | | А | | В | BCS<br>Rela<br>2 2** | LDA<br>(ZP), Y<br>25* | LDA<br>(ZP)<br>25 | | LDY<br>ZP, X<br>24 | LDA<br>ZP,X<br>24 | LDX<br>ZP, Y<br>24 | CLV<br>Impl<br>1 2 | LDA<br>ABS,Y<br>3 4* | TSX<br>Impl<br>1 2 | | LDY<br>ABS, X<br>3 4* | LDA<br>ABS, X<br>3 4* | LDX<br>ABS, Y<br>3 4* | | В | | С | CPY<br>IMM<br>22 | CMP<br>(ZP, X)<br>26 | | | CPY<br>ZP<br>23 | CMP<br>ZP<br>23 | DEC<br>ZP<br>25 | INY<br>Impl<br>12 | CMP<br>IMM<br>22 | DEX<br>Impl<br>12 | | CPY<br>ABS<br>3 4 | CMP<br>ABS<br>3 4 | DEC<br>ABS<br>36 | | С | | D | BNE<br>Rela<br>2.2** | CMP<br>(ZP), Y<br>25* | CMP<br>(ZP)<br>25 | | | CMP<br>ZP, X<br>24 | DEC<br>ZP, X<br>26 | CLD<br>Impl<br>1 2 | CMP<br>ABS,Y<br>34* | PHX<br>Impl<br>13 | | | CMP<br>ABS, X<br>3 4* | DEC<br>ABS, X<br>3 7 | | D | | E | CPX<br>IMM<br>22 | SBC<br>(ZP, X)<br>26+ | | | CPX<br>ZP<br>23 | SBC<br>ZP<br>23+ | INC<br>ZP<br>25 | INX<br>Impl<br>12 | SBC<br>IMM<br>2 2+ | NOP<br>Impl<br>1 2 | | CPX<br>ABS<br>3 4 | SBC<br>ABS<br>3 4+ | INC<br>ABS<br>36 | | E | | F | BEQ<br>Rela<br>2 2** | SBC<br>(ZP), Y<br>25*+ | SBC<br>(ZP)<br>25 | | | SBC<br>ZP, X<br>2 4+ | INC<br>ZP, X<br>26 | SED<br>Impl<br>1 2 | SBC<br>ABS,Y<br>3 4*+ | PLX<br>Impl<br>1 4 | | | SBC<br>ABS,X<br>3 4*+ | INC<br>ABS, X<br>37 | | F | | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 8 | 9 | A | В | С | D | E | F_ | | BRK Impl 17 - OP Code Addressing Mode Instruction Bytes, Machine Cycles New Opcode LSB - Least significant Byte MSB - Most significant Byte - Add 1 to N if in decimal mode. - \* Add 1 to N if page boundary is crossed. - Add 1 to N if branch occurs to same page; Add 2 to N if branch occurs to different page. Notes: ++ New Instruction, + Previous Instruction with additional addressing mode(s) # **DC CHARACTERISTICS** # DC Characteristics: $V_{DD}$ = 5.0V $\pm$ 5%, $V_{SS}$ = OV, $T_A$ = -40°C to +85°C | Parameter | Symbol | Min | Тур | Max | Unit | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|-------------------------------------------------------------------------|-------------|-------------------------------------------------------------------------|----------------| | Input High Voltage \$\dphi_0 \text{(IN)}\$ \$\dphi_2 \text{(IN)}\$ \$\dphi_2 \text{(IN)}\$ \$\text{RES, NMI, RDY, \overline{IRQ}, Data, \overline{SQ}, DBE, BE}\$ | Viн | V <sub>SS</sub> + 2.4<br>V <sub>DD</sub> - 0.2<br>V <sub>SS</sub> + 2.0 | - | V <sub>DD</sub> + 0.3<br>V <sub>DD</sub> + 0.3<br>V <sub>DD</sub> + 0.3 | >>> | | Input Low Voltage<br>\$\phi_0\$ (IN), CLK (IN)<br>\$\phi_2\$ (IN)<br>RES, NMI, RDY, TRQ, Data, SQ, DBE, BE | VIL | V <sub>SS</sub> - 0.3<br>V <sub>SS</sub> - 0.3<br>V <sub>SS</sub> - 0.3 | -<br>-<br>- | VSS+ 0.4<br>VSS+ 0.2<br>VSS+ 0.8 | >>> | | Input Leakage Current ( $V_{ N}$ = 0 to 5.25V, $V_{DD}$ = 5.25V)<br>RES, NMI, RDY, IRQ, SO, DBE, BE (internal Pull-up)<br>$\phi$ 2(IN), $\phi$ 0(IN), CLK (IN)<br>Address, Data, R/ $\overline{W}$ (Off State) | IIN | -20<br>-1<br>-10 | _<br>_<br>_ | 1.0<br>1.0<br>10.0 | uA<br>uA<br>uA | | Output High Voltage (I <sub>OH</sub> = -100μA, V <sub>DD</sub> = 4.75V)<br>SYNC, Data, A0-A15, R/W | Voн | V <sub>SS</sub> + 2.4 | _ | _ | ٧ | | Output Low Voltage (I <sub>OL</sub> = <u>1.</u> 6mA, V <sub>DD</sub> = 4.75V)<br>SYNC, Data, A0-A15, R/W | V <sub>OL</sub> | _ | _ | V <sub>SS</sub> + 0.4 | ٧ | | Supply Current f = 1 MHz<br>f = 2 MHz<br>f = 3 MHz<br>f = 4 MHz | <sup>1</sup> cc | _ | _ | 4<br>8<br>12<br>16 | mA | | Capacitance (V <sub>IN</sub> = 0, T <sub>A</sub> = 25°C, f = 1 MHz<br>Logic, φ0 (IN), CLK (IN)<br>A0-A15, R/W, Data (Off State)<br>φ2 (IN) | Cin<br>C <sub>TS</sub><br>C2 (IN) | <u>-</u><br>- | | 10<br>15<br>40 | pF | ## **ABSOLUTE MAXIMUM RATINGS** # Absolute Maximum Ratings: (Note 1) | Rating | Symbol | Value | Unit | |-----------------------|-----------------|---------------|------| | Supply Voltage | V <sub>DD</sub> | -0.3 to + 7.0 | V | | Input Voltage | VIN | -0.3 to + 7.0 | V | | Operating Temperature | TA | -40 to +85 | ОС | | Storage Temperature | TS | -55 to + 150 | Ос | This device contains input protection against damage due to high static voltages or electric fields; however, precautions should be taken to avoid application of voltages higher than the maximum rating. # Notes: <sup>1.</sup> Exceeding these ratings may result in permanent damage. Functional operation under these conditions is not implied. # AC CHARACTERISTICS AC Characteristics HKE65SC02 - 07 HKE65SC12 - 15 HKE65SC112 - 115 VDD = 5.0V ±5%, TA = -40°C to + 85°C | | | 1 N | ИHz | 21 | ИНz | 3 M | ИНz | 4 N | ИHz | | |--------------------------------------------|---------------|-----|----------|------|-----|------|-----|------|-----|------| | Parameter | Symbol | MIN | Max | Min | Max | Min | Max | Min | Max | Unit | | Delay Time, φ0(IN) to φ2 (OUT) | tD <b>φ</b> 0 | - | 100 | - | 100 | - | 100 | _ | 100 | nS | | Delay Time, $\phi$ 2(IN) to $\phi$ 2 (OUT) | tD <b>φ</b> 2 | _ | 75 | - | 75 | 1 | 75 | _ | 75 | nS | | Delay Time, φ1(OUT) to φ2 (OUT) | tD <b>φ</b> 1 | _ | 50 | _ | 50 | - | 50 | _ | 50 | nS | | Cycle Time | tCYC | 1.0 | DC | 0.50 | DC | 0.33 | DC | 0.25 | DC | nS | | Clock Pulse Width Low | tPW(φ2L) | 470 | _ | 240 | | 160 | | 115 | | nS | | Clock Pulse Width High | tPW(φ2H) | 470 | <u> </u> | 240 | | 160 | | 115 | | nS | | Fall Time, Rise Time | tF, tR | _ | 25 | _ | 25 | _ | 15 | _ | 15 | nS | | Address Hold Time | tAH | 30 | _ | 30 | _ | 15 | _ | 10- | | nS | | Address Setup Time | tADS | 225 | _ | 140 | _ | 110 | _ | 90 | _ | nS | | Access Time | tACC | 650 | _ | 310 | _ | 170 | _ | 110 | | nS | | Read Data Hold Time | tDHR | 10 | - | 10 | _ | 10 | - | 10 | | nS | | Read Data Setup Time | tDSR | 100 | _ | 50 | _ | 50 | _ | 50 | | nS | | Write Data Delay Time | tMDS | _ | 175 | _ | 100 | _ | 75 | _ | 70 | nS | | Write Data Hold Time | tDHW | 30 | - | 30 | _ | 30 | _ | 30 | _ | nS | | SO Setup Time | tSO | 100 | _ | 50 | _ | 35 | _ | 25 | _ | nS | | Processor Control Setup Time | tPCS | 200 | - | 200 | - | 150 | | 120 | | nS | AC Characteristic HKE65SC102 - 107 $V_{DD}$ = 5.0V $\pm$ 5%, $T_{A}$ = $-40^{\circ}$ C to + 85°C. | | | 1 M | 1Hz | 2 1 | ИHz | 3 N | ИHz | 4 N | ЛНz | | |----------------------------------------|-------------------|-----|-----|------|-----|------|-----|------|-----|------| | Parameter | Symbol | Min | Max | Min | Max | Min | Max | Min | Max | Unit | | Delay Time, CLK (IN) to $\phi$ 2 (OUT) | tDCLK | - | 100 | - | 100 | _ | 100 | _ | 100 | nS | | Delay Time, OSC(OUT) to $\phi$ 2 (OUT) | tDOSC | - | 75 | _ | 75 | - | 75 | | 75 | nS | | Cycle Time | tCYC | 1.0 | DC | 0.50 | DC | 0.33 | DC | 0.25 | DC | nS | | Clock Pulse Width Low | tPW( <b>φ</b> 2L) | 470 | _ | 240 | _ | 160 | _ | 115 | | nS | | Clock Pulse Width High | tPW( <b>φ</b> 2H) | 470 | _ | 240 | _ | 160 | _ | 115 | | nS | | Fall Time, Rise Time | tF, tR | _ | 25 | - | 25 | - | 15 | | 15 | nS | | Delay Time, φ2(OUT) to φ4(OUT) | tAVS | _ | 250 | _ | 125 | _ | 83 | - | 63 | nS | | Address Valid to <b>¢4</b> (OUT) | tΑ <b>φ</b> 4 | 50 | _ | 25 | _ | 16 | | 12 | _ ` | nS | | Address Hold Time | tAH | 30 | _ | 20 | _ | 20 | _ | 20_ | _ | nS | | Access Time | tACC | 695 | _ | 340 | _ | 220 | _ | 170 | | nS | | Read Data Hold Time | tDHR | 10 | _ | 10 | _ | 10 | _ | 10 | | nS | | Read Data Setup Time | tDSR | 80 | - | 40 | _ | 30 | - | 20 | | nS | | Write Data Hold Time | tDHW | 30 | 200 | 30 | - | 30 | | 30 | _ | nS | | Write Data Delay Time | tDD <b>4</b> | _ | _ | _ | 110 | _ | 70 | _ | 30 | nS | | SO Setup Time | tSO | 100 | _ | 50 | _ | 35 | | 25 | | nS | | Processor Control Setup Time | tPCS | 100 | | 50 | | 35 | | 25 | _ | nS | # **FAMILY MEMBER DESCRIPTION** #### (A) Functional The capabilities of each microprocessor in the HKE65SCXXX family is summarized in Table III. # Table III HKE65SCXXX FAMILY MICROPROCESSOR CAPABILITIES | ITEM<br>NO. | HKE<br>PART<br>NUMBER | DIP<br>PINS | ADDRESSABLE<br>MEMORY<br>(BYTES) | ON-CHIP<br>CLOCK<br>OSCILLATOR<br>(SEE NOTE) | EXTERNAL<br>CLOCK<br>GENERATOR<br>REQUIRED | ADVANCED<br>MEMORY<br>ACCESS (\$4) | ĪŔΩ | NMI | so | DBE | BE | SYNC | RDY | ML | RES | |-------------|-----------------------|-------------|----------------------------------|----------------------------------------------|--------------------------------------------|------------------------------------|-----|-----|----|-----|----|------|-----|----|-----| | 1 | 65SC02 | 40 | 040130 <mark>65K</mark> | • | | | • | • | • | | | • | • | | • | | 2 | 65SC03 | 28 | 4K | | • | | • | • | | | | | | | • | | 3 | √ 65SC04 | 28 | 8K | | • | | • | | | | | | | | • | | 4 | 65SC05 | 28 | 4K | | • | | • | | | | | | • | | • | | 5 | √ 65SC06 | 28 | 4K | | • | | • | | | | | | | | • | | 6 | ✓65SC07 | 28 | 8K | | • | | | | | | | | • | | • | | 7 | 65SC12 | 40 | 65K | | • | | • | • | | • | | • | | | • | | 8 | √65SC13 | 28 | 4K | | • | | • | • | | | | | | | • | | 9 | √65SC14 | 28 | 8K | | • | | • | | | | | | | | • | | 10 | √65SC15 | 28 | 4K | | • | | • | | | | | | • | | • | | 11 | √ 65SC102 | 40 | 65K | • | | • | • | • | • | | • | • | • | • | • | | 12 | √ 65SC103 | 28 | 4K | | • | • | • | • | | | | | | | • | | 13 | 7 <sub>65SC104</sub> | 28 | 8K | | • | • | • | | | | | | | | • | | 14 | 65SC105 | 28 | 4K | | • | • | • • | | | | | | • | | • | | 15 | 765SC106 | 28 | 4K | | • | • | • | | | | | | | | • | | 16 | √ 65SC107 | 28 | 8K | | • | • | | | | | | | • | | • | | 17 | √65SC112 | 40 | 65K | • | | | • | • | • | | • | • | • | • | • | | 18 | √ 65SC115 | 28 | 4K | | • | | • | | | | | | • | • | • | NOTE: These devices can operate in any of the following clock generation modes: 1. External crystal - 1. External crystal 2. External RC network - 3. $\phi O(1N)$ from external clock source As shown in Table III, the family includes 18 microprocessors of which three have on-chip oscillators while the others require an external clock generator. The HKE65SC02, HKE65SC102 or HKE65SC112 on-chip oscillators may be driven by an external crystal (Figure 4(a)), an RC network (Figure 4(b)) or by an external clock source. The rest (15 microprocessors) of the microprocessors in the family require an external oscillator. An example of the crystal circuit of an external oscillator is given in Figure 4(c) The versions of the microprocessor which require an external clock source are generally intended for multiprocessor applications where maximum timing control is necessary. The three family members with on-chip oscillators are intended for high performance, low cost operations where single phase inputs, crystals, or RC inpouts provide the time base. ## (B) Pin Configuration ## **PIN FUNCTION TABLE** | Pin | Description | |-----------------|------------------------| | A0-A×× | Address Bus | | BE | Bus Enable | | CLK(IN) | Clock Input | | <b>φ</b> 0 (IN) | Phase 0 In | | φ2 (IN) | Phase 2 In | | DBE | Data Bus Enable | | D0-D7 | Date Bus | | 1RQ | Interrupt Request | | ML | Memory Lock | | NC | No Connection | | NMI | Non-Maskable Interrupt | | Pin | Description | |-----------------|------------------------------------| | OSC (OUT) | Oscillator Output | | φ1(OUT) | Phase 1 Out | | <b>φ</b> 2(ΟUT) | Phase 2 Out | | <b>ø</b> 4(OUT) | Phase 4 Out | | RDY | Ready | | RES | Reset | | R/₩ | Read/Write | | SO | Set Overflow | | SYNC | Synchronize | | $V_{DD}$ | Positive Power Supply (+5.0 Volts) | | Vss | Internal Logic Ground | # Pin Configuration Α8 Α9 **1**4 Δ7 Α8 ☐ 14 16 🗖 A10 15 🗖 A9 # Pin Configuration | RES | 2(IN)<br>/W<br>0<br>1<br>2<br>3<br>4<br>5<br>6<br>7<br>11 | |-----|-----------------------------------------------------------| |-----|-----------------------------------------------------------| # PACKAGING INFORMATION # Typical Outline Drawing (Ceramic) | 40 PIN CERAMIC PACKAGE | | | | | |------------------------|-------------|--------|--------|-------| | DIM | MILLIMETERS | | INCHES | | | DIN | MIN | MAX | MIN | MAX | | Α | 50.419 | 51.181 | 1.985 | 2.015 | | В | 14.605 | 15.367 | 0.575 | 0.605 | | С | | 3.810 | | 0.150 | | D | 0.381 | 0.533 | 0.015 | 0.021 | | E | 0.889 | 1.524 | 0.035 | 0.060 | | F | 2.286 | 2.794 | 0.090 | 0.110 | | G | 1.016 | 1.524 | 0.040 | 0.060 | | Н | 0.203 | 0.305 | 0.008 | 0.012 | | J | 15.113 | 15.875 | 0.590 | 0.620 | | Κ | 15.24 | REF | 0.600 | REF | | L | 0.889 | 1.651 | 0.035 | 0.065 | | М | 2.540 | 3.556 | 0.100 | 0.140 | | | | | | | | 40 PIN PLASTIC PACKAGE | | | | | |------------------------|-------------|-------|--------|-------| | DIM | MILLIMETERS | | INCHES | | | DIN | MIN | MAX | MIN | MAX | | Α | 51.69 | 52.45 | 2.035 | 2.065 | | В | 13.72 | 14.22 | 0.540 | 0.560 | | C | 3.94 | 5.08 | 0.155 | 0.200 | | ٥ | 0.36 | 0.56 | 0.014 | 0.022 | | E | 1.02 | 1.52 | 0.040 | 0.060 | | F | 2.54 | TYP | 0.100 | TYP | | G | 1.65 | 2.16 | 0.065 | 0.085 | | Н | 0.20 | 0.38 | 0.008 | 0.015 | | J | 15.24 | TYP | 0.600 | TYP | | Κ | | | | | | L | 0.51 | 1.02 | 0.020 | 0.040 | | М | 2.92 | 3,43 | 0.115 | 0.135 | | | 40 PIN CERDIP PACKAGE | | | | | |------|-----------------------|--------|--------|-------|--| | 5114 | MILLIMETERS | | INCHES | | | | DIM | MIN | MAX | MIN | MAX | | | Α | | 53.57 | | 2.109 | | | В | 12.19 | 14.98 | 0.480 | 0.590 | | | С | | | | | | | D | 0.381 | 0.508 | 0.015 | 0.020 | | | E | 1.016 | 1.651 | 0.040 | 0.065 | | | F | 2.540 | TYP | 0.100 | TYP | | | G | | | | | | | Н | 0.203 | 0.305 | 0.008 | 0.012 | | | J | 14.99 | 15.490 | 0.590 | 0.610 | | | К | | | | | | | L | 0.381 | | 0.015 | | | | М | 2.290 | | 0.090 | | | | 28 PIN CERAMIC PACKAGE | | | | | |------------------------|-------------|-------|--------|--------| | | MILLIMETERS | | INCHES | | | DIM | MIN | MAX | MIN | MAX | | Α | 35.20 | 35.92 | 1.386 | 1.414 | | В | 14.43 | 14.94 | 0.568 | 0.588 | | C | 3.05 | 4.19 | 0.120 | 0.165 | | ٥ | 0.41 | 0.51 | 0.016 | 0.020 | | Е | 1.12 | 1.42 | 0.044 | 0.056 | | F | 2.54 BSC | | 0.1 | 00 BSC | | G | 1.12 | 1.42 | 0.044 | 0.056 | | Н | 0.23 | 0.26 | 0.008 | 0.011 | | J | 14.83 | 15.14 | 0.584 | 0.596 | | К | | | | | | L | 0.51 | 0.52 | 0.020 | 0.060 | | М | 2.54 | 4.19 | 0.100 | 0.165 | | | | | | | | 28 PIN PLASTIC PACKAGE | | | | | | |------------------------|-------------|-------|--------|-------|--| | DIM | MILLIMETERS | | INCHES | | | | DIM | MIN | MAX | MIN | MAX | | | Α | 36.32 | 37.34 | 1.430 | 1.470 | | | В | 13.72 | 14.22 | 0.540 | 0.560 | | | С | 4.57 | 5.08 | 0.180 | 0.200 | | | D | 0.38 | 0.51 | 0.015 | 0.020 | | | E | 1.02 | 1.52 | 0.040 | 0.060 | | | F | 2.41 | 2.67 | 0.095 | 0.105 | | | G | 1.65 | 2.16 | 0.065 | 0.085 | | | Н | 0.20 | 0.30 | 0.008 | 0.012 | | | J | 14.99 | 15.49 | 0.590 | 0.610 | | | К | | | | | | | L | 0.51 | 1.02 | 0.020 | 0.040 | | | M | 3.05 | 3.56 | 0.120 | 0.140 | | | | | | | | | | 28 PIN CERDIP PACKAGE | | | | | | |-----------------------|-------------|-------|--------|-------|--| | 5114 | MILLIMETERS | | INCHES | | | | DIM | MIN | MAX | MIN | MAX | | | Α | 36.45 | 37.21 | 1.435 | 1.465 | | | В | 13.72 | 14.22 | 0.540 | 0.560 | | | С | 3.94 | 5.08 | 0.155 | 0.200 | | | D | 0.36 | 0.56 | 0.014 | 0.022 | | | E | 1.02 | 1.52 | 0.040 | 0.060 | | | F | 2.54 | TYP | 0.100 | TYP | | | G | 1.65 | 2.16 | 0.065 | 0.085 | | | Н | 0.20 | 0.38 | 0.008 | 0.015 | | | J | 15.24 | TYP | 0.600 | TYP | | | К | | | | | | | L | 0.51 | 1.02 | 0.020 | 0.040 | | | М | 2.92 | 3.43 | 0.115 | 0.135 | | | | | | | | | # ORDERING INFORMATION Designators selected for speed and power specifications 1MHz 2MHz 3MH2