# HD6809E, HD68A09E, HD68B09E MPU(Micro Processing Unit) The HD6809E is a revolutionary high performance 8-bit microprocessor which supports modern programming techniques such as position independence, reentrancy, and modular programming. This third-generation addition to the HMCS6800 family has major architectural improvements which include additional registers, instructions and addressing modes. The basic instructions of any computer are greatly enhanced by the presence of powerful addressing modes. The HD6809E has the most complete set of addressing modes available on any 8-bit microprocessor today. The HD6809E has hardware and software features which make it an ideal processor for higher level language execution or standard controller applications. External clock inputs are provided to allow synchronization with peripherals, systems or other MPUs. # **HD6800 COMPATIBLE** - Hardware Interfaces with All HMCS6800 Peripherals - Software Upward Source Code Compatible Instruction Set and Addressing Modes # ■ ARCHITECTURAL FEATURES - Two 16-bit Index Registers - Two 16-bit Indexable Stack Pointers - Two 8-bit Accumulators can be Concatenated to Form One 16-Bit Accumulator - Direct Page Register Allows Direct Addressing Throughout Memory # **■ HARDWARE FEATURES** - External Clock Inputs, E and Q, Allow Synchronization - TSC Input Controls Internal Bus Buffers - LIC Indicates Opcode Fetch - AVMA Allows Efficient Use of Common Resources in A Multiprocessor System - BUSY is a Status Line for Multiprocessing - Fast Interrupt Request Input Stacks Only Condition Code Register and Program Counter - Interrupt Acknowledge Output Allows Vectoring By Devices - SYNC Acknowledge Output Allows for Synchronization to External Event - Single Bus-Cycle RESET - Single 5-Volt Supply Operation - NMI Blocked After RESET Until After First Load of Stack Pointer - Early Address Valid Allows Use With Slower Memories - Early Write-Data for Dynamic Memories - SOFTWARE FEATURES - 10 Addressing Modes - HMCS6800 Upward Compatible Addressing Modes - Direct Addressing Anywhere in Memory Map - · Long Relative Branches - · Program Counter Relative - · True Indirect Addressing - Expanded Indexed Addressing: 0, 5, 8, or 16-bit Constant Offsets 8, or 16-bit Accumulator Offsets Auto-Increment/Decrement by 1 or 2 - Improved Stack Manipulation - 1464 Instruction with Unique Addressing Modes - 8 x 8 Unsigned Multiply - 16-bit Arithmetic - Transfer/Exchange All Registers - Push/Pull Any Registers or Any Set of Registers - Load Effective Address # PIN ARRANGEMENT # ■ ABSOLUTE MAXIMUM RATINGS | Item | Symbol | Value | Unit | | |-----------------------------|--------|--------------------|------|--| | Supply Voltage | Vcc* | <b>−0.3</b> ~ +7.0 | | | | Input Voltage | Vin* | -0.3 ~ +7.0 | V | | | Operating Temperature Range | Topr | <b>−20</b> ~ +75 | °C | | | Storage Temperature Range | Tstg | −55 ~ +150 | °C | | <sup>\*</sup> With respect to Vss (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. # ■ RECOMMENDED OPERATING CONDITIONS | | Item | Symbol | min | typ | max | unit | | |----------------------------------------------|---------------|--------------------|------------|-----|-----------|------|--| | Supply Voltage | | Vcc* | 4.75 | 5.0 | 5.25 | V | | | опред по | Logic, Q, RES | VIL* | -0.2 | _ | 0.8 | V | | | | E | VILC* | -0.3 | _ | 0.4 | ٧ | | | Input Voltage | Logic | | 2.2 | - | Vcc* | V | | | mput voltage | RES | V <sub>1</sub> H * | 4.0 | - | Vcc* | V | | | | E | Vinc* | Vcc* -0.75 | _ | Vcc* +0.3 | V | | | Operating Temper | | Topr | -20 | 25 | 75 | °C | | <sup>\*</sup> With respect to Vss (SYSTEM GND) # ■ ELECTRICAL CHARACTERISTICS # • DC CHARACTERISTICS (V<sub>CC</sub> = 5.0V $\pm 5\%$ , V<sub>SS</sub> = 0V, Ta = -20 $\sim$ +75 $^{\circ}$ C, unless otherwise noted.) | | | | | HD6809E | | | HD68A09E | | | HD68B09E | | | Unit | | |------------------------|-----------------------------------------------------------------------|--------|------------------------------------------|--------------|----------|-------------|--------------|-------------|-------------|--------------|-----------|-------------|----------|--| | Item | | Symbol | Test Condition | min | typ* | max | min | typ* | max | min | typ* | max | | | | | Logic, Q | Vін | | 2.2 | ı | Vec | 2.2 | _ | Vcc | 2.2 | - | Vcc | ٧ | | | Input "High" Voltage | RES | VIHR | | 4.0 | - | Vcc | 4.0 | _ | Vcc | 4.0 | - | Vcc | ٧ | | | | E | Vinc | | Vcc<br>-0.75 | _ | Vcc<br>+0.3 | Vcc<br>-0.75 | - | Vcc<br>+0.3 | Vcc<br>-0.75 | _ | Vcc<br>+0.3 | ٧ | | | | Logic, Q, RES | VIL | | -0.2 | _ | 8.0 | -0.2 | | 0.8 | -0.2 | - | 0.8 | ٧ | | | Input "Low" Voltage | E | VILC | | -0.3 | - | 0.4 | -0.3 | - | 0.4 | -0.3 | _ | 0.4 | <u> </u> | | | | Logic, Q, RES | | Vin = 0 ~ 5,25V, | -2.5 | _ | 2.5 | -2.5 | | 2.5 | -2.5 | - | 2.5 | μА | | | Input Leakage Current | E | ⊣ lin | Vcc = max | -100 | - | 100 | 100 | - | 100 | -100 | - | 100 | μА | | | | D <sub>0</sub> ~ D <sub>7</sub> | | Load = -205µA,<br>Vcc = min | 2.4 | - | - | 2.4 | _ | - | 2.4 | - | - | ٧ | | | Output "High" Voltage | A <sub>0</sub> ~ A <sub>15</sub> , R/W | Vон | I <sub>Load</sub> = -145μA,<br>Vcc = min | 2.4 | _ | - | 2.4 | _ | - | 2.4 | _ | - | v | | | | BA, BS, LIC,<br>AVMA, BUSY | | lLoad = −100μA,<br>Vcc = min | 2.4 | - | - | 2.4 | - | _ | 2.4 | - | _ | v | | | Output "Low" Voltage | 1 | Vol | Load = 2mA,<br>Vcc = min | - | - | 0.5 | _ | - | 0.5 | _ | - | 0.5 | v | | | Power Dissipation | | Po | | - | - | 1,0 | | <u> -</u> _ | 1.0 | | - | 1,0 | W | | | Input Capacitance | D <sub>0</sub> ~ D <sub>7</sub> , Logic | Cin | Vin = 0V,<br>Ta = 25°C, | _ | 10 | 15 | - | 10 | 15 | - | 10 | 15 | pF | | | input oupuorterios | E | 1 | f = 1MHz | _ | 30 | 50 | Ī <u>-</u> | 30 | 50 | | 30 | 50 | ρF | | | Output Capacitance | A <sub>0</sub> ~ A <sub>15</sub> , R/W,<br>BA, BS, LIC,<br>AVMA, BUSY | Cout | Vin = 0V,<br>Ta = 25°C,<br>f = 1MHz | _ | 10 | 15 | | 10 | 15 | - | 10 | 15 | pF | | | Frequency of Operation | E, Q | 1 | | 0.1 | _ | 1.0 | 0.1 | - | 1,5 | 0.1 | - | 2.0 | MH | | | | D <sub>0</sub> ~ D <sub>7</sub> | | Vin = 0.4 ~ 2.4V, | -10 | <u> </u> | 10 | -10 | _ | 10 | -10 | <u> -</u> | 10 | μΑ | | | Input Current | A0 ~ A15, R/W | ITSI | Vcc = max | -100 | - | 100 | -100 | - J | 100 | -100 | - | 100 | μΑ | | <sup>•</sup> Ta = 25°C, V<sub>CC</sub> = 5V # $\bullet$ AC CHARACTERISTICS (V<sub>CC</sub> = 5.0V ±5%, V<sub>SS</sub> = 0V, Ta = -20 $\sim$ +75°C, unless otherwise noted.) READ/WRITE TIMING | Ite | ∍m | Symbol | Test | | HD6809E | | | D68A | 09E | Н | D68B | 09E | | |-------------------------------------------|----------------|-----------------------------------|----------------------|----------------|---------|------------|-----|------|-------|-----|------|--------------|--------------| | Cycle Time | | tour | Condition | min | typ | max | min | typ | max | min | typ | max | Un | | Peripheral Read Access Tir | | tcyc | 4 | 1000 | | 10000 | 667 | | 10000 | 500 | | 10000 | n | | tcyc - tEf - tAD - tDSR | = tACC | tACC | | 695 | - | - | 440 | _ | - | 330 | _ | _ | ns | | Data Setup Time (Read) | | †DSR | | 80 | | † <u> </u> | 60 | | | 40 | | _ | <del> </del> | | Input Data Hold Time | | †DHR | 1 | 10 | | †_ | 10 | | _ | 10 | | | ns | | Output Data Hold Time | Ta = 0 ~ +75°C | | 1 | 30 | | _ | 30 | | | 30 | | | ns | | Output Data Hold Time | Ta = -20 ~ 0°C | whd | į | 20 | _ | | 20 | | _ | 20 | | <del>-</del> | ns | | Address Hold Time | Ta = 0 ~ +75°C | | | 20 | _ | _ | 20 | | _ | 20 | | _ | ns | | (Address, R/W) | Ta = -20 ~ 0°C | <sup>→</sup> t <sub>AH</sub> | | 10 | _ | - | 10 | _ | _ | 10 | _ | | ns | | Address Delay | | <sup>t</sup> AD | | | _ | 200 | _ | | 140 | | | 120 | ns | | Data Delay Time (Write) | | tDDW | Fig. 1, 2, | - 1 | _ | 200 | _ | | 140 | _ | | 110 | ns | | E Clock "Low" | | tPWEL. | 7 ~ 10,<br>14 and 17 | 450 | _ | 9500 | 295 | | 9500 | 210 | | 9500 | ns | | E Clock "High" (Measured at VIH) | | tPWEH | <b>!</b><br> | 450 | | 9500 | 280 | _ | 9500 | 220 | | 9500 | ns | | E Rise and Fall Time | | t <sub>Er</sub> , t <sub>Ef</sub> | | _ | _ | 25 | _ | _ | 25 | _ | | 20 | ns | | Q Clock "High" | | tPWQH | | 450 | | 9500 | 280 | | 9500 | 220 | _ | 9500 | ns | | Q Rise and Fall Time | | tQr, tQf | | _ | | 25 | | | 25 | _ | | 20 | ns | | E "Low" to Q Rising | | tEQ1 | | 200 | | _ | 130 | | | 100 | | _ | ns | | Q "High" to E Rising | | tEQ2 | | 200 | _ | | 130 | _ | | 100 | _ | | ns | | E "High" to Q Falling | | tEQ3 | | 200 | _ | | 130 | | | 100 | | | | | Q "Low" to E Falling | • | tEQ4 | | 200 | | | 130 | | | 100 | | | ns | | Interrupts HALT, RES and | TSC Setup Time | tPCS | | 200 | | | 140 | _ | | 110 | | _ | ns | | TSC Drive to Valid Logic L | evels | tTSA | | | | 210 | _ | | 150 | _ | | 120 | nş | | TSC Release MOS Buffers to High Impedance | | tTSR | | <del>-</del> ; | _ | 200 | _ | _ | 140 | _+ | - | 110 | ns | | TSC Three-State Delay | | <sup>†</sup> TSD | - | _ | _ | 120 | _ | _ | 85 | _+ | | 80 | ns | | Control Delay (BUSY, LIC) | | tCD | } | _ | | 300 | | | 250 | | | | ns | | Control Delay (AVMA*) | | tCD | } | | _ | 300 | | _ | 270 | _ | _ | 200 | ns | | Processor Control Rise/Fall | | tPCr, tPCf | - | | _ | 100 | _+ | | 100 | _ | _ | 100 | ns | | TSC Input Delay | | †PCT | ļ | 10 | | - | 10 | | | 10 | | | ns | AVMA drives a not-valid data before providing correct output, so spec t<sub>CD</sub> max = 270 nsec (HD68A09E) and 240 nsec (HD68B09E) are applied to this signal. When this delay time causes a problem in user's application, please use D-type latch to get stable output. (NOTE) Waveform measurements for all inputs and outputs are specified at logic "High" = V<sub>1Hmin</sub> and logic "Low" = V<sub>1Lmex</sub> unless otherwise specified. Figure 1 Read Data from Memory or Peripherals (NOTE) Waveform measurements for all inputs and outputs are specified at logic "High" = V<sub>IHmin</sub> and logic "Low" = V<sub>ILmax</sub> unless otherwise specified. Figure 2 Write Data to Memory or Peripherals Figure 3 HD6809E Expanded Block Diagram C = 30 pF for BA, BS, LIC, AVMA, BUSY 130 pF for $D_0 \sim D_7$ 90 pF for $A_0 \sim A_{15}$ , R/W R = 11.7 k $\Omega$ for D<sub>0</sub> ~ D<sub>7</sub> 16.5 k $\Omega$ for A<sub>0</sub> ~ A<sub>15</sub>, R/ $\overline{W}$ 24 k $\Omega$ for BA, BS , LIC, AVMA, BUSY All diodes are 1S2074(H) or equivalent. C includes stray capacitance, Figure 4 Bus Timing Test Load ### ■ PROGRAMMING MODEL As shown in Figure 5, the HD6809E adds three registers to the set available in the HD6800. The added registers include a Direct Page Register, the User Stack pointer and a second Index Register. # Accumulators (A, B, D) The A and B registers are general purpose accumulators which are used for arithmetic calculations and manipulation of data. Certain instructions concatenate the A and B registers to form a single 16-bit accumulator. This is referred to as the D Register, and is formed with the A Register as the most significant byte. # Direct Page Register (DP) The Direct Page Register of the HD6809E serves to enhance the Direct Addressing Mode. The content of this register appears at the higher address outputs ( $A_8 \sim A_{15}$ ) during direct addressing instruction execution. This allows the direct mode to be used at any place in memory, under program control. To ensure HD6800 compatibility, all bits of this register are cleared during Processor Reset. Figure 5 Programming Model of The Microprocessing Unit ### • Index Registers (X, Y) The Index Registers are used in indexed mode of addressing. The 16-bit address in this register takes part in the calculation of effective addresses. This address may be used to point to data directly or may be modified by an optional constant or register offset. During some indexed modes, the contents of the index register are incremented or decremented to point to the next item of tabular type data. All four pointer registers (X, Y, U, S) may be used as index registers. # Stack Pointer (U, S) The Hardware Stack Pointer (S) is used automatically by the processor during subroutine calls and interrupts. The User Stack Pointer (U) is controlled exclusively by the programmer thus allowing arguments to be passed to and from subroutines with ease. The U-register is frequently used as a stack marker. Both Stack Pointers have the same indexed mode addressing capabilities as the X and Y registers, but also support Push and Pull instructions. This allows the HD6809E to be used efficiently as a stack processor, greatly enhancing its ability to support higher level languages and modular programming. (NOTE) The stack pointers of the HD6809E point to the top of the stack, in contrast to the HD6800 stack pointer, which pointed to the next free location on stack. # Program Counter (PC) The Program Counter is used by the processor to point to the address of the next instruction to be executed by the processor. Relative Addressing is provided allowing the Program Counter to be used like an index register in some situations. # Condition Code Register (CC) The Condition Code Register defines the state of the processor at any given time. See Figure 6. Figure 6 Condition Code Register Format # CONDITION CODE REGISTER DESCRIPTION ### Bit 0 (C Bit 0 is the carry flag, and is usually the carry from the binary ALU. C is also used to represent a 'borrow' from subtract like instructions (CMP, NEG, SUB, SBC) and is the complement of the carry from the binary ALU. ### Bit 1 (V) Bit 1 is the overflow flag, and is set to a one by an operation which causes a signed two's complement arithmetic overflow. This overflow is detected in an operation in which the carry from the MSB in the ALU does not match the carry from the MSB-1. # Bit 2 (Z) Bit 2 is the zero flag, and is set to a one if the result of the previous operation was identically zero. # • Bit 3 (N) Bit 3 is the negative flag, which contains exactly the value of the MSB of the result of the preceding operation. Thus, a negative two's-complement result will leave N set to a one. ### • Bit 4 (i) Bit 4 is the IRQ mask bit. The processor will not recognize interrupts from the IRQ line if this bit is set to a one. NMI, FIRQ, IRQ, RES and SWI all set I to a one; SWI2 and SWI3 do not affect I. ### Bit 5 (H) Bit 5 is the half-carry bit, and is used to indicate a carry from bit 3 in the ALU as a result of an 8-bit addition only (ADC or ADD). This bit is used by the DAA instruction to perform a BCD decimal add adjust operation. The state of this flag is undefined in all subtract-like instructions. ### Bit 6 (F) Bit 6 is the $\overline{FIRQ}$ mask bit. The processor will not recognize interrupts from the $\overline{FIRQ}$ line if this bit is a one. $\overline{NMI}$ , $\overline{FIRQ}$ , SWI, and $\overline{RES}$ all set F to a one. $\overline{IRQ}$ , SWI2 and SWI3 do not affect F. ### • Bit 7 (E) Bit 7 is the entire flag, and when set to a one indicates that the complete machine state (all the registers) was stacked, as opposed to the subset state (PC and CC). The E bit of the stacked CC is used on a return from interrupt (RTI) to determine the extent of the unstacking. Therefore, the current E left in the Condition Code Register represents past action. ### ■ HD6809E MPU SIGNAL DESCRIPTION # • Power (Vss, Vcc) Two pins are used to supply power to the part: Vss is ground or 0 volts, while Vcc is +5.0 V ±5%. # Address Bus (A<sub>0</sub> ~ A<sub>15</sub>) Sixteen pins are used to output address information from the MPU onto the Address Bus. When the processor does not require the bus for a data transfer, it will output address FFFF<sub>16</sub>, R/W = "High", and BS = "Low"; this is a "dummy access" or $\overline{VMA}$ cycle. All address bus drivers are made high-impedance when output Bus Available (BA) is "High" or when TSC is asserted. Each pin will drive one Schottky TTL load or four LS TTL loads, and 90 pF. Refer to Figures 1 and 2. # • Data Bus ( $D_0 \sim D_7$ ) These eight pins provide communication with the system bi-directional data bus. Each pin will drive one Schottky TTL load or four LS TTL loads, and 130 pF. # ● Read/Write (R/W) This signal indicates the direction of data transfer on the data bus. A "Low" indicates that the MPU is writing data-onto the data bus. $R/\overline{W}$ is made high impedance when BA is "High" or when TSC is asserted. Refer to Figures 1 and 2. ### • RES A "Low" level on this Schmitt-trigger input for greater than one bus cycle will reset the MPU, as shown in Figure 7. The Reset vectors are fetched from locations $FFFE_{16}$ and $FFFF_{16}$ (Table 1) when Interrupt Acknowledge is true, $(\overline{BA} \cdot BS = 1)$ . During initial power-on, the Reset line should be held "Low" until the clock input signals are fully operational. Because the HD6809E Reset pin has a Schmitt-trigger input with a threshold voltage higher than that of standard peripherals, a simple R/C network may be used to reset the entire system. This higher threshold voltage ensures that all peripherals are out of the reset state before the Processor. Table 1 Memory Map for Interrupt Vectors | Memory Ma<br>Locat | p for Vector<br>ions | Interrupt Vector Description | |--------------------|----------------------|------------------------------| | MS | LS | Description | | FFFE | FFFF | RES | | FFFC | FFFD | NMI | | FFFA | FFFB | SWI | | FFF8 | FFF9 | ĪRQ | | FFF6 | FFF7 | FIRO | | FFF4 | FFF5 | SW12 | | FFF2 | FFF3 | SWI3 | | FFF0 | FFF1 | Reserved | # • HALT A "Low" level on this input pin will cause the MPU to stop running at the end of the present instruction and remain halted indefinitely without loss of data. When halted, the BA output is driven "High" indicating the buses are high impedance. BS is also "High" which indicates the processor is in the Halt state. While halted, the MPU will not respond to external real-time requests (FIRQ, $\overline{IRQ}$ ) although $\overline{NMI}$ or $\overline{RES}$ will be latched for later response. During the Halt state Q and E should continue to run normally. A halted state (BA · BS = 1) can be achieved by pulling $\overline{HALT}$ "Low" while $\overline{RES}$ is still "Low". See Figure 8. # Bus Available, Bus Status (BA, BS) The Bus Available output is an indication of an internal control signal which makes the MOS buses of the MPU high impedance. When BA goes "Low", a dead cycle will elapse before the MPU acquires the bus. BA will not be asserted when TSC is active, thus allowing dead cycle consistency. The Bus Status output signal, when decoded with BA, represents the MPU state (valid with leading edge of Q). | MPL | J State | 140110 | |-----|---------|--------------------------------| | ВА | BS | MPU State Definition | | 0 | 0 | Normal (Running) | | 0 | 1 | Interrupt or RESET Acknowledge | | 1 | 0 | SYNC Acknowledge | | 1 | 1 | HALT Acknowledge | Interrupt Acknowledge is indicated during both cycles of a hardware-vector-fetch (RES, NMI, FIRQ, IRQ, SWI, SWI2, SWI3). This signal, plus decoding of the lower four address lines, can provide the user with an indication of which interrupt level is being serviced and allow vectoring by device. See Table 1. **Sync Acknowledge** is indicated while the MPU is waiting for external synchronization on an interrupt line. Halt Acknowledge is indicated when the HD6809E is in a Halt condition. (NOTE) Waveform measurements for all inputs and outputs are specified at logic "High" = VIHmin and logic "Low" = VILmax unless otherwise specified. Figure 7 RES Timing Figure 8 HALT and Single Instruction Execution for System Debug # Non Maskable Interrupt (NMI)\* A negative transition on this input requests that a non-maskable interrupt sequence be generated. A non-maskable interrupt cannot be inhibited by the program, and also has a higher priority than FIRQ, IRQ or software interrupts. During recognition of an NMI, the entire machine state is saved on the hardware stack. After reset, an NMI will not be recognized until the first program load of the Hardware Stack Pointer (S). The pulse width of NMI low must be at least one E cycle. If the NMI input does not meet the minimum set up with respect to Q, the interrupt will not be recognized until the next cycle. See Figure 9. # ● Fast-Interrupt Request (FIRQ)\* A "Low" level on this input pin will initiate a fast interrupt sequence, provided its mask bit (F) in the CC is clear. This sequence has priority over the standard Interrupt Request $(\overline{IRQ})$ , and is fast in the sense that it stacks only the contents of the condition code register and the program counter. The interrupt service routine should clear the source of the interrupt before doing an RTI. See Figure 10. # ● Interrupt Request (IRQ)\* A "Low" level input on this pin will initiate an Interrupt Request sequence provided the mask bit (I) in the CC is clear. Since $\overline{IRQ}$ stacks the entire machine state it provides a slower response to interrupts than $\overline{FIRQ}$ . $\overline{IRQ}$ also has a lower priority than $\overline{FIRQ}$ . Again, the interrupt service routine should clear the source of the interrupt before doing an RTI. See Figure 9. \* NMI, FIRQ, and IRQ requests are sampled on the falling edge of Q. One cycle is required for synchronization before these interrupts are recognized. The pending interrupt(s) will not be serviced until completion of the current instruction unless a SYNC or CWAI condition is present. If IRQ and FIRQ do not remain "Low" until completion of the current instruction they may not be recognized. However, NMI is latched and need only remain "Low" for one cycle. ### • Clock Inputs E, Q E and Q are the clock signals required by the HD6809E. Q must lead E; that is, a transition on Q must be followed by a similar transition on E after a minimum delay. Addresses will be valid from the MPU, t<sub>AD</sub> after the falling edge of E, and data will be latched from the bus by the falling edge of E. While the Q input is fully TTL compatible, the E input directly drives internal MOS circuitry and, thus, requires levels above normal TTL levels. This approach minimizes clock skew inherent with an internal buffer. Timing and waveforms for E and Q are shown in Figures 1 and 2 while Figure 11 shows a simple clock generator for the HD6809E. ### RUSY Busy will be "High" for the read and modify cycles of a readmodify-write instruction and during the access of the first byte of a double-byte operation (e.g., LDX, STD, ADDD). Busy is also "High" during the first byte of any indirect or other vector fetch (e.g., jump extended, SWI indirect etc.). In a multi-processor system, busy indicates the need to defer the rearbitration of the next bus cycle to insure the integrity of the above operations. This difference provides the indivisible memory access required for a "test-and-set" primitive, using any one of several read-modify-write instructions. Busy does not become active during PSH or PUL operations. A typical read-modify-write instruction (ASL) is shown in Figure 12. Timing information is given in Figure 13. Busy is valid $t_{\rm CD}$ after the rising edge of Q. ### AVMA AVMA is the Advanced VMA signal and indicates that the MPU will use the bus in the following bus cycle. The predictive nature of the AVMA signal allows efficient shared-bus multiprocessor systems. AVMA is "Low" when the MPU is in either a HALT or SYNC state. AVMA is valid t<sub>CD</sub> after the rising edge of Q. # • LIC LIC (Last Instruction Cycle) is "High" during the last cycle of every instruction, and its transition from "High" to "Low" will indicate that the first byte of an opcode will be latched at the end of the present bus cycle. LIC will be "High" when the MPU is Halted at the end of an instruction, (i.e., not in CWAI or RESET) in SYNC state or while stacking during interrupts. LIC is valid t<sub>CD</sub> after the rising edge of Q. ### • TSC TSC (Three-State Control) will cause MOS address, data, and R/W buffers to assume a high-impedance state. The control signals (BA, BS, BUSY, AVMA and LIC) will not go to the high-impedance state. TSC is intended to allow a single bus to be shared with other bus masters (processors or DMA controllers) While E is "Low", TSC controls the address buffers and $R/\overline{W}$ directly. The data bus buffers during a write operation are in a high-impedance state until Q rises at which time, if TSC is true, they will remain in a high-impedance state. If TSC is held beyond the rising edge of E, then it will be internally latched, keeping the bus drivers in a high-impedance state for the remainder of the bus cycle. See Figure 14. # MPU Operation During normal operation, the MPU fetches an instruction from memory and then executes the requested function. This sequence begins after RES and is repeated indefinitely unless altered by a special instruction or hardware occurrence. Software instructions that alter normal MPU operation are: SWI, SWI2, SWI3, CWAI, RTI and SYNC. An interrupt or HALT input can also alter the normal execution of instructions. Figure 15 illustrates the flow chart for the HD6809E. (NOTE) Waveform measurements for all inputs and outputs are specified at logic "High" = V<sub>IHmin</sub> and logic "Low" = V<sub>ILmax</sub> unless otherwise specified. E clock shown for reference only. Figure 9 IRQ and NMI Interrupt Timing (NOTE) Waveform measurements for all inputs and outputs are specified at logic "High" = VIHmin and logic "Low" = VILmax unless otherwise specified. E clock shown for reference only. Figure 10 FIRO Interrupt Timing ( HITACHI Figure 11 HD6809E Clock Generator Figure 12 Read Modify Write Instruction Example (ASL Extended Indirect) (NOTE) Waveform measurements for all inputs and outputs are specified at logic "High" = V<sub>IHmin</sub> and logic "Low" = V<sub>ILmax</sub> unless otherwise specified. (NOTES) Data will be asserted by the MPU only during the interval while R/W is "Low" and E or Q is "High". Waveform measurements for all inputs and outputs are specified at logic "High" = V<sub>IHmin</sub> and logic "Low" = V<sub>IL</sub>max unless otherwise specified. Figure 14 TSC Timing **OHITACHI** ### ■ ADDRESSING MODES The basic instructions of any computer are greatly enhanced by the presence of powerful addressing modes. The HD6809E has the most complete set of addressing modes available on any microcomputer today. For example, the HD6809E has 59 basic instructions; however, it recognizes 1464 different variations of instructions and addressing modes. The addressing modes support modern programming techniques. The following addressing modes are available on the HD6809E: - (1) Implied (Includes Accumulator) - (2) Immediate - (3) Extended - (4) Extended Indirect - (5) Direct - (6) Register - (7) Indexed Zero-Offset Constant Offset Accumulator Offset Auto Increment/Decrement - (8) Indexed Indirect - (9) Relative - (10) Program Counter Relative ### Implied (Includes Accumulator) In this addressing mode, the opcode of the instruction contains all the address information necessary. Examples of Implied Addressing are: ABX, DAA, SWI, ASRA, and CLRB. # • Immediate Addressing In Immediate Addressing, the effective address of the data is the location immediately following the opcode (i.e., the data to be used in the instruction immediately follows the opcode of the instruction). The HD6809E uses both 8 and 16-bit immediate values depending on the size of argument specified by the opcode. Examples of instructions with immediate Addressing are: LDA #\$20 LDX #\$F000 LDY #CAT (NOTE) # signifies immediate addressing, \$ signifies hexadecimal value. ### Extended Addressing In Extended Addressing, the contents of the two bytes immediately following the opcode fully specify the 16-bit effective address used by the instruction. Note that the address generated by an extended instruction defines an absolute address and is not position independent. Examples of Extended Addressing include: LDA CAT STX MOUSE LDD \$2000 # • Extended Indirect As a special case of indexed addressing (discussed below), one level of indirection may be added to Extended Addressing. In Extended Indirect, the two bytes following the postbyte of an Indexed instruction contain the address of the data. LDA [CAT] LDX [\$FFFE] STU [DOG] ### Direct Addressing Direct addressing is similar to extended addressing except that only one byte of address follows the opcode. This byte specifies the lower 8 bits of the address to be used. The upper 8 bits of the address are supplied by the direct page register. Since only one byte of address is required in direct addressing, this mode requires less memory and executes faster than extended addressing. Of course, only 256 locations (one page) can be accessed without redefining the contents of the DP register. Since the DP register is set to \$00 on Reset, direct addressing on the HD6809E is compatible with direct addressing on the HD6800. Indirection is not allowed in direct addressing. Some examples of direct addressing are: LDA \$30 SETDP \$10 (Assembler directive) LDB \$1030 LDD <CAT (NOTE) < is an assembler directive which forces direct addressing. ### Register Addressing Some opcodes are followed by a byte that defines a register or set of registers to be used by the instruction. This is called a postbyte. Some examples of register addressing are: TFR X, Y Transfer X into Y A, B Exchanges A with B EXG **PSHS** A, B, X, Y Push Y, X, B and A onto S Pull D, X, and Y from U **PULU** X, Y, D ### Indexed Addressing In all indexed addressing, one of the pointer registers (X, Y, U, S, and sometimes PC) is used in a calculation of the effective address of the operand to be used by the instruction. Five basic types of indexing are available and are discussed below. The postbyte of an indexed instruction specifies the basic type and variation of the addressing mode as well as the pointer register to be used. Figure 16 lists the legal formats for the postbyte. Table 2 gives the assembler form and the number of cycles and bytes added to the basic values for indexed addressing for each variation. | | | 2000 5 | 3vte F | 2 | Indexed | | | | |-------|----------------------------------------------------------------------------------------|--------------|----------|---|----------------------------|---|----|--------------------------| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Addressing | | | <del> </del> | | <u>├</u> | | + - + - + | | - | Mode | | 0 | R | R | d | d | d | d | d | EA = ,R + 5 Bit Offset | | _1_ | R | R | 0 | 0 | 0 0 0 | | | ,R + | | . 1 | R | R | i | 0 | 0_ | 0 | 1 | ,R++ | | _1 | R | R | 0 | 0 | 0 | 1 | 0_ | , -R | | 1 | R | R | i | 0 | 0 | 1 | 1 | ,R | | 1 | R | R | i | 0 | 1_ | 0 | 0 | EA = ,R + 0 Offset | | 1 | R | R | i | 0 | 1 | 0 | 1 | EA = ,R + ACCB Offset | | 1 | R | R | i | 0 | 1 | 1 | 0 | EA = ,R + ACCA Offset | | 1 | R | R | 1 | 1 | 0 | 0 | 0 | EA = , R + 8 Bit Offset | | 1 | R | R | i | 1 | 0 0 1 | | | EA = ,R + 16 Bit Offset | | 1 | R | R | i | 1 | 0 1 1 | | | EA = ,R + D Offset | | 1 | × | × | i | 1 | | | | EA = ,PC + 8 Bit Offset | | 1 | × | × | i | 1 | 1 | 0 | 1 | EA = ,PC + 16 Bit Offset | | 1 | R | R | i | 1 | 1 | 1 | 1 | EA = [,Address] | | | Addressing Mode Field Indirect Field (Sigh bit when b7 = 0) Register Field : RR 00 = X | | | | | | | | | i = { | fset ( | Bit<br>on In | ndirec | τ | 01 = Y<br>10 = U<br>11 = S | | | | Figure 16 Index Addressing Postbyte Register Bit Assignments Table 2 Indexed Addressing Mode | | | | - 1.00 mg | | - | | | | | |----------------------------------------------------|-------------------|-------------------|---------------------|-----|---------------|-------------------|---------------------|-----|---| | | | N | lon Indirect | | | | Indirect | | | | Туре | Forms | Assembler<br>Form | Postbyte<br>OP Code | + ~ | <b>+</b><br># | Assembler<br>Form | Postbyte<br>OP Code | + ~ | 1 | | Constant Offset From R | No Offset | ,R | 1RR00100 | 0 | 0 | [,R] | 1RR10100 | 3 | 0 | | (2's Complement Offsets) | 5 Bit Offset | n, R | 0RRnnnnn | 1 | 0 | default | ts to 8-bit | †- | Т | | | 8 Bit Offset | n, R | 1RR01000 | 1 | 1 | [n, R] | 1RR11000 | 4 | 1 | | | 16 Bit Offset | n, R | 1RR01001 | 4 | 2 | [n, R] | 1RR11001 | 7 | 2 | | Accumulator Offset From R (2's Complement Offsets) | A Register Offset | A, R | 1RR00110 | 1 | 0 | [A, R] | 1RR10110 | 4 | 0 | | | B Register Offset | B, R | 1RR00101 | 1 | 0 | [B, R] | 1RR10101 | 4 | 0 | | | D Register Offset | D, R | 1RR01011 | 4 | 0 | [D, R] | 1RR11011 | 7 | 0 | | Auto Increment/Decrement R | Increment By 1 | ,R + | 1RR00000 | 2 | 0 | not | allowed | | | | | Increment By 2 | ,R + + | 1RR00001 | 3 | 0 | [,R ++] | 1RR10001 | 6 | 0 | | | Decrement By 1 | , - R | 1RR00010 | 2 | 0 | not | allowed | T | | | | Decrement By 2 | , R | 1RR00011 | 3 | 0 | [, R] | 1RR10011 | 6 | 0 | | Constant Offset From PC | 8 Bit Offset | n, PCR | 1xx01100 | 1 | 1 | [n, PCR] | 1xx11100 | 4 | 1 | | 2's Complement Offsets) | 16 Bit Offset | n, PCR | 1xx01101 | 5 | 2 | [n, PCR] | 1xx11101 | 8 | 2 | | Extended Indirect | 16 Bit Address | _ | _ | T- | - | [n] | 10011111 | 5 | 2 | # Zero-Offset Indexed In this mode, the selected pointer register contains the effective address of the data to be used by the instruction. This is the fastest indexing mode. Examples are: LDD 0, X LDA S ### **Constant Offset Indexed** In this mode, a two's-complement offset and the contents of one of the pointer registers are added to form the effective address of the operand. The pointer register's initial content is unchanged by the addition. Three sizes of offsets are available: 5-bit (-16 to +15) 8-bit (-128 to +127) 16-bit (-32768 to +32767) The two's complement 5-bit offset is included in the postbyte and, therefore, is most efficient in use of bytes and cycles. The two's complement 8-bit offset is contained in a single byte following the postbyte. The two's complement 16-bit offset is in the two bytes following the postbyte. In most cases the programmer need not be concerned with the size of this offset since the assembler will select the optimal size automatically. Examples of constant-offset indexing are: LDA 23, X LDX -2, S LDY 300, X LDU CAT, Y # **Accumulator-Offset Indexed** This mode is similar to constant offset indexed except that the two's-complement value in one of the accumulators (A, B or D) and the contents of one of the pointer registers are added to form the effective address of the operand. The contents of both the accumulator and the pointer register are unchanged by the addition. The postbyte specifies which accumulator to use as an offset and no additional bytes are required. The advantage of an accumulator offset is that the value of the offset can be calculated by a program at run-time. Some examples are: LDA B, Y LDX D, Y LEAX B, X # Auto Increment/Decrement Indexed In the auto increment addressing mode, the pointer register contains the address of the operand. Then, after the pointer register is used it is incremented by one or two. This addressing mode is useful in stepping through tables, moving data, or for the creation of software stacks. In auto decrement, the pointer register is decremented prior to use as the address of the data. The use of auto decrement is similar to that of auto increment; but the tables, etc., are scanned from the high to low addresses. The size of the increment/decrement can be either one or two to allow for tables of either 8- or 16-bit data to be accessed and is selectable by the programmer. The pre- $<sup>\</sup>stackrel{+}{\sim}$ and $\stackrel{+}{\#}$ indicate the number of additional cycles and bytes for the particular variation. decrement, post-increment nature of these modes allow them to be used to create additional software stacks that behave identically to the U and S stacks. Some examples of the auto increment/decrement addressing modes are: LDA ,X + STD ,Y++ LDB ,-Y LDX ,--S Care should be taken in performing operations on 16-bit pointer registers (X, Y, U, S) where the same register is used to calculate the effective address. Consider the following instruction: STX 0, X + + (X initialized to 0) The desired result is to store a 0 in locations \$0000 and \$0001 then increment X to point to \$0002. In reality, the following occurs: $0 \rightarrow \text{temp}$ calculate the EA; temp is a holding register $X + 2 \rightarrow X$ perform autoincrement $X \rightarrow \text{(temp)}$ do store operation # Indexed Indirect All of the indexing modes with the exception of auto increment/decrement by one, or a ±4-bit offset may have an additional level of indirection specified. In indirect addressing, the effective address is contained at the location specified by the contents of the Index Register plus any offset. In the example below, the A accumulator is loaded indirectly using an effective address calculated from the Index Register and an offset. Before Execution A = XX (don't care) X = \$F000 \$0100 LDA [\$10, X] EA is now \$F010 \$F010 \$F1 \$F150 is now the \$F011 \$50 new EA \$F150 \$AA After Execution A = \$AA (Actual Data Loaded) X = \$F000 All modes of indexed indirect are included except those which are meaningless (e.g., auto increment/decrement by 1 indirect). Some examples of indexed indirect are: LDA [, X] LDD [10, S] LDA [B, Y] LDD [, X++] # Relative Addressing The byte(s) following the branch opcode is (are) treated as a signed offset which may be added to the program counter. If the branch condition is true then the calculated address (PC + signed offset) is loaded into the program counter. Program execution continues at the new location as indicated by the PC; short (1 byte offset) and long (2 bytes offset) relative addressing modes are available. All of memory can be reached in long relative addressing as an effective address is interpreted modulo 2<sup>16</sup>. Some examples of relative addressing are: | BEQ | CAT | (short) | |-----|-----|---------| | BGT | DOG | (short) | | CAT<br>DOG | LBEQ<br>LBGT | RAT<br>RABBIT | (long) | |------------|--------------|---------------|--------| | | | | | | | • | | | | RAT | NOP | | | | RABBIT | NOP | | | ### Program Counter Relative The PC can be used as the pointer register with 8 or 16-bit signed offsets. As in relative addressing, the offset is added to the current PC to create the effective address. The effective address is then used as the address of the operand or data. Program Counter Relative Addressing is used for writing position independent programs. Tables related to a particular routine will maintain the same relationship after the routine is moved, if referenced relative to the Program Counter. Examples are: LDA CAT, PCR LEAX TABLE, PCR Since program counter relative is a type of indexing, an additional level of indirection is available. LDA [CAT, PCR] LDU [DOG, PCR] # ■ HD6809E INSTRUCTION SET The instruction set of the HD6809E is similar to that of the HD6800 and is upward compatible at the source code level. The number of opcodes has been reduced from 72 to 59, but because of the expanded architecture and additional addressing modes, the number of available opcodes (with different addressing modes) has risen from 197 to 1464. Some of the new instructions are described in detail below: ### PSHU/PSHS The push instructions have the capability of pushing onto either the hardware stack (S) or user stack (U) any single register, or set of registers with a single instruction. # • PULU/PULS The pull instructions have the same capability of the push instruction, in reverse order. The byte immediately following the push or pull opcode determines which register or registers are to be pushed or pulled. The actual PUSH/PULL sequence is fixed; each bit defines a unique register to push or pull, as shown in below. # PUSH/PULL POST BYTE | | ← P | ull Or | der | P | ush O | rder → | | |------|------|---------|-------|--------|--------|--------|------| | PC | U | Y | X | DP | В | Α | CC | | FFFF | ← ir | icreasi | ng me | mory a | addres | ss | 0000 | | PC | | | | | | | CC | # TFR/EXG Within the HD6809E, any register may be transferred to or exchanged with another of like-size; i.e., 8-bit to 8-bit or 16-bit to 16-bit. Bits $4\sim7$ of postbyte define the source register, while bits $0\sim3$ represent the destination register. These are denoted as follows: | 0000 - D | 0101 - PC | |----------|-----------| | 0001 - X | 1000 - A | | 0010 - Y | 1001 - B | | 0011 – U | 1010 - CC | | 0100 - S | 1011 - DP | (NOTE) All other combinations are undefined and INVALID. ### TRANSFER/EXCHANGE POST BYTE | 1 1 1 | 1 1 1 | |--------|-------------| | SOURCE | DESTINATION | | | i | ### • LEAX/LEAY/LEAU/LEAS The LEA (Load Effective Address) works by calculating the effective address used in an indexed instruction and stores that address value, rather than the data at that address, in a pointer register. This makes all the features of the internal addressing hardware available to the programmer. Some of the implications of this instruction are illustrated in Table 3. The LEA instruction also allows the user to access data in a position independent manner. For example: | | LEAX<br>LBSR | MSG1, PCR PDATA (Print message routine) | |------|--------------|-----------------------------------------| | | • | | | | • | | | MSG1 | FCC | 'MESSAGE' | This sample program prints: 'MESSAGE'. By writing MSG1, PCR, the assembler computes the distance between the present address and MSG1. This result is placed as a constant into the LEAX instruction which will be indexed from the PC value at the time of execution. No matter where the code is located, when it is executed, the computed offset from the PC will put the absolute address of MSG1 into the X pointer register. This code is totally position independent. The LEA instructions are very powerful and use an internal holding register (temp). Care must be exercised when using the LEA instructions with the autoincrement and autodecrement addressing modes due to the sequence of internal operations. The LEA internal sequence is outlined as follows: Autoincrement-by-two and autodecrement-by-two instructions work similarly. Note that LEAX, X+ does not change X, however LEAX, -X does decrement X. LEAX 1, X should be used to increment X by one. (load a) 3. temp $\rightarrow$ a Table 3 LEA Examples | Instruction | Operation | Comment | |-------------|-----------------------|--------------------------------| | LEAX 10, X | X + 10 → X | Adds 5-bit constant 10 to X | | LEAX 500, X | X + 500 → X | Adds 16-bit constant 500 to X | | LEAY A, Y | $Y + A \rightarrow Y$ | Adds 8-bit A accumulator to Y | | LEAY D, Y | $Y + D \rightarrow Y$ | Adds 16-bit D accumulator to Y | | LEAU –10, U | U – 10 → U | Subtracts 10 from U | | LEAS -10, S | S - 10 → S | Used to reserve area on stack | | LEAS 10, S | S + 10 → S | Used to 'clean up' stack | | LEAX 5, S | $S+5 \rightarrow X$ | Transfers as well as adds | ### • MUL Multiplies the unsigned binary numbers in the A and B accumulator and places the unsigned result into the 16-bit D accumulator. This unsigned multiply also allows multiple-precision multiplications. ### Long and Short Relative Branches The HD6809E has the capability of program counter relative branching throughout the entire memory map. In this mode, if the branch is to be taken, the 8 or 16-bit signed offset is added to the value of the program counter to be used as the effective address. This allows the program to branch anywhere in the 64k memory map. Position independent code can be easily generated through the use of relative branching. Both short (8-bit) and long (16-bit) branches are available. ### SYNC After encountering a Sync instruction, the MPU enters a Sync state, stops processing instructions and waits for an interrupt. If the pending interrupt is non-maskable $(\overline{NMI})$ or maskable $(\overline{FIRQ}, \overline{IRQ})$ with its mask bit (F or I) clear, the processor will clear the Sync state and perform the normal interrupt stacking and service routine. Since $\overline{FIRQ}$ and $\overline{IRQ}$ are not edge-triggered, a low level with a minimum duration of three bus cycles is required to assure that the interrupt will be taken. If the pending interrupt is maskable $(\overline{FIRQ}, \overline{IRQ})$ with its mask bit (F or I) set, the processor will clear the Sync state and continue processing by executing the next inline instruction. Figure 17 depicts Sync timing. ### Software Interrupts A Software Interrupt is an instruction which will cause an interrupt, and its associated vector fetch. These Software Interrupts are useful in operating system calls, software debugging, trace operations, memory mapping, and software development systems. Three levels of SWI are available on this HD6809E, and are prioritized in the following order: SWI, SWI2, SWI3. ### 16-Bit Operation The HD6809E has the capability of processing 16-bit data. These instructions include loads, stores, compares, adds, subtracts, transfers, exchanges, pushes and pulls. # **■ CYCLE-BY-CYCLE OPERATION** The address bus cycle-by-cycle performance chart illustrates the memory-access sequence corresponding to each possible instruction and addressing mode in the HD6809E. Each instruction begins with an opcode fetch. While that opcode is being internally decoded, the next program byte is always fetched. (Most instructions will use the next byte, so this technique considerably speeds throughput.) Next, the operation of each opcode will follow the flow chart. VMA is an indication of FFFF<sub>16</sub> on the address bus, $R/\overline{W}$ = "High" and BS = "Low". The following examples illustrate the use of the chart; see Figure 18. Example 1: LBSR (Branch Taken) | Dofore | · Eva | aution | CD - | F000 | |--------|--------|---------|-------|---------| | Delui | 7 1.XC | CULIVII | .71 - | - 1 000 | | | | • | | |--------|-----|----------|--------------| | | | • | | | | | • | | | \$8000 | | LBSR | CAT | | | | • | | | | | • | | | | | • | | | \$A000 | CAT | • | | | | | CYCLE-BY | Y-CYCLE FLOW | | Cycle # | Address | Data | $R/\overline{W}$ | Description | |---------|---------|------------|------------------|------------------| | 1 | 8000 | 17 | 1 | Opcode Fetch | | 2 | 8001 | 1 <b>F</b> | 1 | Offset High Byte | | 3 | 8002 | FD | 1 | Offset Low Byte | | 4 | FFFF | * | 1 | VMA Cycle | | 5 | FFFF | * | 1 | VMA Cycle | | 6 | FFFF | * | 1 | VMA Cycle | | 7 | FFFF | * | 1 | VMA Cycle | | 8 | EFFF | 03 | 0 | Stack Low Order | | | | | | Byte of Return | | | | | | Address | | 9 | EFFE | 80 | 0 | Stack High Order | | | | | | Byte of Return | | | | | | Address | # Example 2: DEC (Extended) \$8000 | \$A000 | FCE | 3 | \$80 | 1 | |---------|---------|------------|------------------|------------------| | | | CYCLI | E-BY-CY | CLE FLOW | | Cycle # | Address | Data | $R/\overline{W}$ | Description | | 1 | 8000 | 7A | 1 | Opcode Fetch | | 2 | 8001 | <b>A</b> 0 | 1 | Operand Address, | | | | | | High Byte | | 3 | 8002 | 00 | 1 | Operand Address, | | | | | | Low Byte | | 4 | FFFF | * | 1 | VMA Cycle | | 5 | A000 | 80 | 1 | Read the Data | | 6 | FFFF | * | 1 | VMA Cycle | | 7 | A000 | 7 <b>F</b> | 0 | Store the Decre- | | | | | | | \$A000 mented Data # ■ HD6809E INSTRUCTION SET TABLES DEC The instructions of the HD6809E have been broken down into five different categories. They are as follows: 8-Bit operation (Table 4) 16-Bit operation (Table 5) Index register/stack pointer instructions (Table 6) Relative branches (long or short) (Table 7) Miscellaneous instructions (Table 8) HD6809E instruction set tables and Hexadecimal Values of instructions are shown in Table 9 and Table 10. <sup>\*</sup> The data bus has the data at that particular address. (NOTES) 1. If the associated mask bit is set when the interrupt is requested, LIC will go "Low" and this cycle will be an instruction fetch from address location PC + 1. However, if the interrupt is accepted (NMI) or an unmasked FIRQ or IRQ) LIC will remain "High" and interrupt processing will start with this cycle as (m) on Figure 9 and 10 (Interrupt Timing). 2. If mask bits are clear, IRQ and FIRQ must be held "Low" for three cycles to guarantee that interrupt will be taken, although only one cycle is necessary to bring the processor out of SYNC. 3. Waveform measurements for all inputs and outputs are specified at logic "High" = V<sub>IHmin</sub> and logic "Low" = V<sub>ILmax</sub> unless otherwise specified. Figure 17 SYNC Timing Figure 18 Address Bus Cycle-by-Cycle Performance Figure 18 Address Bus Cycle-by-Cycle Performance (Continued) (1) HITACHI 1. Stack (W) refers to the following sequence: SP ← SP − 1, then ADDR ← SP with R/W = "Low" Stack (R) refers to the following sequence: ADDR ← SP with R/W = "High", then SP ← SP + 1. PSHU, PULU instructions use the user stack pointer (i.e., SP = U) and PSHS, PULS use the hardware stack pointer (i.e., SP = S). 2. Vector refers to the address of an interrupt or reset vector (see Table 1). 3. The number of stack accesses will vary according to the number of bytes saved. 4. VMĀ cycles will occur until an interrupt occurs. (NOTES) Figure 18 Address Bus Cycle-by-Cycle Performance (Continued) Table 4 8-Bit Accumulator and Memory Instructions | Mnemonic(s) | Operation | |-----------------|----------------------------------------------------| | ADCA, ADCB | Add memory to accumulator with carry | | ADDA, ADDB | Add memory to accumulator | | ANDA, ANDB | And memory with accumulator | | ASL, ASLA, ASLB | Arithmetic shift of accumulator or memory left | | ASR, ASRA, ASRB | Arithmetic shift of accumulator or memory right | | BITA, BITB | Bit test memory with accumulator | | CLR, CLRA, CLRB | Clear accumulator or memory location | | CMPA, CMPB | Compare memory from accumulator | | COM, COMA, COMB | Complement accumultor or memory location | | DAA | Decimal adjust A accumulator | | DEC, DECA, DECB | Decrement accumulator or memory location | | EORA, EORB | Exclusive or memory with accumulator | | EXG R1, R2 | Exchange R1 with R2 (R1, R2 = A, B, CC, DP) | | INC, INCA, INCB | Increment accumulator or memory location | | LDA, LDB | Load accumulator from memory | | LSL, LSLA, LSLB | Logical shift left accumulator or memory location | | LSR, LSRA, LSRB | Logical shift right accumulator or memory location | | MUL | Unsigned multiply $(A \times B \rightarrow D)$ | | NEG, NEGA, NEGB | Negate accumulator or memory | | ORA, ORB | Or memory with accumulator | | ROL, ROLA, ROLB | Rotate accumulator or memory left | | ROR, RORA, RORB | Rotate accumulator or memory right | | SBCA, SBCB | Subtract memory from accumulator with borrow | | STA, STB | Store accumulator to memory | | SUBA, SUBB | Subtract memory from accumulator | | TST, TSTA, TSTB | Test accumulator or memory location | | TFR R1, R2 | Transfer R1 to R2 (R1, R2 = A, B, CC, DP) | (NOTE) A, B, CC or DP may be pushed to (pulled from) either stack with PSHS, PSHU (PULS, PULU) instructions. Table 5 16-Bit Accumulator and Memory Instructions | Mnemonic(s) | Operation | | |-------------|----------------------------------------------|--| | ADDD | Add memory to D accumulator | | | CMPD | Compare memory from D accumulator | | | EXG D, R | Exchange D with X, Y, S, U or PC | | | LDD | Load D accumulator from memory | | | SEX | Sign Extend B accumulator into A accumulator | | | STD | Store D accumulator to memory | | | SUBD | Subtract memory from D accumulator | | | TFR D, R | Transfer D to X, Y, S, U or PC | | | TFR R, D | Transfer X, Y, S, U or PC to D | | (NOTE) D may be pushed (pulled) to either stack with PSHS, PSHU (PULS, PULU) instructions. Table 6 Index Register Stack Pointer Instructions | Mnemonic(s) | Operation | |-------------|----------------------------------------------------------| | CMPS, CMPU | Compare memory from stack pointer | | CMPX, CMPY | Compare memory from index register | | EXG R1, R2 | Exchange D, X, Y, S, U or PC with D, X, Y, S, U or PC | | LEAS, LEAU | Load effective address into stack pointer | | LEAX, LEAY | Load effective address into index register | | LDS, LDU | Load stack pointer from memory | | LDX, LDY | Load index register from memory | | PSHS | Push A, B, CC, DP, D, X, Y, U, or PC onto hardware stack | | PSHU | Push A, B, CC, DP, D, X, Y, S, or PC onto user stack | | PULS | Pull A, B, CC, DP, D, X, Y, U or PC from hardware stack | | PULU | Pull A, B, CC, DP, D, X, Y, S or PC from user stack | | STS, STU | Store stack pointer to memory | | STX, STY | Store index register to memory | | TFR R1, R2 | Transfer D, X, Y, S, U or PC to D, X, Y, S, U or PC | | ABX | Add B accumulator to X (unsigned) | Table 7 Branch Instructions | Operation | |------------------------------------------| | SIMPLE BRANCHES | | Branch if equal | | Branch if not equal | | Branch if minus | | Branch if plus | | Branch if carry set | | Branch if carry clear | | Branch if overflow set | | Branch if overflow clear | | SIGNED BRANCHES | | Branch if greater (signed) | | Branch if greater than or equal (signed) | | Branch if equal | | Branch if less than or equal (signed) | | Branch if less than (signed) | | UNSIGNED BRANCHES | | Branch if higher (unsigned) | | Branch if higher or same (unsigned) | | Branch if equal | | Branch if lower or same (unsigned) | | Branch if lower (unsigned) | | OTHER BRANCHES | | Branch to subroutine | | Branch always | | Branch never | | | Table 8 Miscellaneous Instructions | Mnemonic(s) | Operation | |-----------------|------------------------------------------------------| | ANDCC | AND condition code register | | CWAI | AND condition code register, then wait for interrupt | | NOP | No operation | | ORCC | OR condition code register | | JMP | Jump | | JSR | Jump to subroutine | | RTI | Return from interrupt | | RTS | Return from subroutine | | SWI, SWI2, SWI3 | Software interrupt (absolute indirect) | | SYNC | Synchronize with interrupt line | Table 9 HD6809E Instruction Set Table | INSTR | UCTION/ | | | | | | Н | D680 | 9E A | DDF | RESS | NG N | MODI | , | | | | | | | | | _ | _ | _ | |-------|-----------------------|----------|------|-----|----------------|-------|-------|----------------|-------------|-----|----------------|-------|-------|----------------|----------------|----------------|----------------|-----------|-----|-----------------------------------------------------------|-------------|-----|--------|-------------|-------------| | | DRMS | | MPLI | T | + | REC | | <del></del> | TEND | | | EDI | | + | DEX | | + | LATI | | | 5 | 3 | 2 | 1 | 0 | | ABX | | OP<br>3A | 3 | 1 | OP | ~_ | # | OP | ~_ | # | OP | ~ | # | OP | ~ | # | OP | ~5 | # | 6 | H | 2 | Z | V | C | | ADC | ADCA<br>ADCB | 34 | 3 | • | 99<br>D9 | 4 | 2 2 | B9<br>F9 | 5<br>5 | 3 | 89<br>C9 | 2 | 2 2 | A9<br>E9 | 4+<br>4+ | 2+<br>2+ | | | | B + X → X<br>(UNSIGNED)<br>A + M + C → A<br>B + M + C → B | : | ‡ | ‡<br>‡ | : | : | | ADD | ADDA<br>ADDB<br>ADDD | | | | 9B<br>DB<br>D3 | 4 4 6 | 2 2 2 | BB<br>FB<br>F3 | 5<br>5<br>7 | 3 3 | 8B<br>CB<br>C3 | 2 2 4 | 2 2 3 | AB<br>EB<br>E3 | 4+<br>4+<br>6+ | 2+<br>2+<br>2+ | | | | A + M → A<br>B + M → B<br>D + M:M + 1 → D | : | 1 | 1 | ;<br>;<br>; | ‡<br>‡<br>‡ | | AND | ANDA<br>ANDB<br>ANDCC | | | | 94<br>D4 | 4 4 | 2 2 | B4<br>F4 | 5<br>5 | 3 | 84<br>C4<br>1C | 2 2 3 | 2 2 2 | A4<br>E4 | 4+<br>4+ | 2+<br>2+ | | | | A ∧M → A<br>B ∧M → B<br>CC∧ IMM → CC | • • - | : | 1 1 | 0 | • | | ASL | ASLA<br>ASLB<br>ASL | 48<br>58 | 2 2 | 1 1 | 08 | 6 | 2 | 78 | 7 | 3 | , , | | | 68 | 6+ | 2+ | | | | A B W | , (8 8) (8) | 1 1 | 1 | : | 1 1 1 | | ASR | ASRA<br>ASRB<br>ASR | 47<br>57 | 2 2 | 1 | 07 | 6 | 2 | 77 | 7 | 3 | | | | 67 | 6+ | 2+ | | | | A) - [ ] - [ ] - [ ] | 8 8 | 1 1 | : | • | 1 1 | | всс | BCC<br>LBCC | | | | | | - | | Í | | | | | | | | 24<br>10<br>24 | 3<br>5(6) | 2 | Branch C = 0<br>Long Branch<br>C = 0 | : | • | • | • | • | | BCS | BCS<br>LBCS | | | | | | | | | | | | | | | | 25<br>10<br>25 | 3<br>5(6) | 2 | Branch C = 1<br>Long Branch<br>C = 1 | : | : | : | : | • | | BEQ | BEQ<br>LBEQ | | | | | | | | | | | | | | | | 27<br>10<br>27 | 3<br>5(6) | 2 | Branch Z = 1<br>Long Branch<br>Z = 1 | • | : | • | • | • | | BGE | BGE<br>LBGE | | | | | | | | | | | | | | | | 2C<br>10<br>2C | 3<br>5(6) | 2 4 | Branch N⊕V=0<br>Long Branch<br>N⊕V=0 | : | • | : | • | • | | BGT | BGT<br>LBGT | | | | | | | | | | | | | | | | 2E<br>10<br>2E | 3<br>5(6) | 2 4 | Branch Z√(N⊕V)=0<br>Long Branch<br>Z√(N⊕V)=0 | : | : | : | • | : | | BHI | BHI<br>LBHI | | | | | | | | | | | | | | | | 22<br>10<br>22 | 3<br>5(6) | 2 4 | Branch C∨Z=0<br>Long Branch<br>C∨Z=0 | : | : | : | : | • | | BHS | BHS | | | | | | | | | | | | | | | | 24 | 3 | 2 | Branch | • | • | • | • | • | | | LBHS | | | | | | | | | | | | | | | | 10<br>24 | 5(6) | 4 | C=0<br>Long Branch<br>C=0 | • | • | • | • | • | | ВІТ | BITA<br>BITB | | | | 95<br>D5 | 4 | 2 2 | B5<br>F5 | 5<br>5 | 3 | 85<br>C5 | 2 2 | 2 2 | A5<br>E5 | 4+<br>4+ | 2+<br>2+ | | | | Bit Test A (M ∧ A)<br>Bit Test B (M ∧B) | • | 1 | 1 | 0 | • | | BLE | BLE<br>LBLE | | | | | | | | | | | | | | | | 2F<br>10<br>2F | 3<br>5(6) | 2 4 | Branch Z√(N⊕V)=1<br>Long Branch<br>Z√(N⊕V)=1 | : | : | : | : | • | | BLO | BLO<br>LBLO | | | | | | | | | | | | | | | | 25<br>10<br>25 | 3<br>5(6) | 2 4 | Branch C=1<br>Long Branch<br>C=1 | • | • | • | • | • | | BLS | BLS | | | | | | | | | | | | | | | | 23 | 3 | 2 | Branch | • | • | • | • | • | | | LBLS | | | | | | | | | | | | | | | | 10<br>23 | 5(6) | 4 | C∀Z=1<br>Long Branch<br>C∀Z=1 | • | • | • | • | • | | BLT | BLT<br>LBLT | | | | | | | | | | | | | | | | 2D<br>10<br>2D | 3<br>5(6) | 2 4 | Branch N⊕V=1<br>Long Branch<br>N⊕V=1 | : | • | • | • | • | | ВМІ | BMI<br>LBMI | | | | | | | | | | | | | | | | 2B<br>10<br>2B | 3<br>5(6) | 2 4 | Branch N=1<br>Long Branch<br>N=1 | • | • | • | • | : | | BNE | BNE<br>LBNE | | | | | | | | | | | | | | | | 26<br>10<br>26 | 3<br>5(6) | 2 4 | Branch Z = 0<br>Long Branch<br>Z = 0 | : | : | : | • | • | | BPL | BPL<br>LBPL | | | | | | | | | | | | | | | | 2A<br>10<br>2A | 3<br>5(6) | 2 4 | Branch N = 0<br>Long Branch<br>N = 0 | • | : | • | • | • | | BRA | BRA<br>LBRA | | | | | | | | | | | | | | | | 20<br>16 | 3<br>5 | 2 | Branch Always<br>Long Branch/<br>Always | • | : | : | • | • | | BRN | BRN<br>LBRN | | | | | | | | | | | | | | | | 21<br>10<br>21 | 3<br>5 | 2 4 | Branch Never<br>Long Branch Never | • | : | • | : | : | (to be continued) | | UCTION/ | IN | IPLI | D | DIRECT EXTENDED | | | | | ED | IMM | EDIA | TE | IND | EXE | DŒ | RE | LATI | VΕ | DESCRIPTION | 5 | 3 | 2 | 1 | 0 | |------|-----------------------------|----------|------|-----|----------------------|------------------|-------------|----------------------|------------------|-------------|----------------------|-------------|------------------|----------------------|----------------------|----------------------|----------------|-----------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|---------------|-------------|-----------------------------------------|-----| | FU | | | ~ | # | OP | ~ | # | OP | ~ | # | OP | ~ | # | OP | ~ | # | OP | ~3 | # | DESCRIPTION | Н | N | z | V | C | | SR | BSR | | | | 1 | | | | | | | | | | | | 8D | 7 | 2 | Branch to | • | • | • | • | • | | | LBSR | | | | | | | | | | | | | | | | 17 | 9 | 3 | Subroutine<br>Long Branch to<br>Subroutine | • | • | • | • | • | | в∨с | BVC<br>LBVC | | | | | | | | | | | | | | | | 28<br>10<br>28 | 3<br>5(6) | 2<br>4 | Branch V = 0<br>Long Branch<br>V = 0 | • | • | • | : | • | | BVS | BVS<br>LBVS | | | | | : | | | | | | | | | | | 29<br>10<br>29 | 3<br>5(6) | 2<br>4 | Branch V = 1<br>Long Branch<br>V = 1 | • | : | • | : | : | | CLR | CLRA<br>CLRB<br>CLR | 4F<br>5F | 2 | 1 | 0F | 6 | 2 | 7F | 7 | 3 | | | | 6F | 6+ | 2+ | | | | 0 → A<br>0 → B<br>0 → M | • | 000 | 1 | 000 | 000 | | CMP | CMPA<br>CMPB<br>CMPD | | | | 91<br>D1<br>10 | 4<br>4<br>7 | 2<br>2<br>3 | B1<br>F1<br>10 | 5<br>5<br>8 | 3<br>3<br>4 | 81<br>C1<br>10 | 2<br>2<br>5 | 2<br>2<br>4 | A1<br>E1<br>10 | 4+<br>4+<br>7+ | 2+<br>2+<br>3+ | | | | Compare M from A<br>Compare M from B<br>Compare M: M + 1<br>from D | 8 | : | ‡<br>‡<br>‡ | : | 1 | | | CMPS | | | | 93 | 7 | 3 | B3<br>11 | 8 | 4 | 83<br>11 | 5 | 4 | A3 | 7+ | 3+ | | | | Compare M: M + 1 | • | 1 | 1 | 1 | 1 | | | СМРИ | | | | 9C | 7 | 3 | BC<br>11 | 8 | 4 | 8C | 5 | 4 | AC<br>11 | 7+ | 3+ | | | | from S<br>Compare M: M + 1 | • | 1 | 1 | 1 | 1 | | | CMPX | | l | | 93<br>9C | 6 | 2 | B3<br>BC | 7 | 3 | 8C<br>83 | 4 | 3 | A3<br>AC | 6+ | 2+ | | | | from U<br>Compare M: M + 1<br>from X | • | 1 | 1 | 1 | | | | CMPY | | | | 10<br>9C | 7 | 3 | 10<br>BC | 8 | 4 | 10<br>8C | 5 | 4 | 10<br>AC | 7+ | 3+ | | | | Compare M: M + 1<br>from Y | • | 1 | 1 | 1 | | | COM | COMA<br>COMB<br>COM | 43<br>53 | 2 | 1 1 | 03 | 6 | 2 | 73 | 7 | 3 | | | | 63 | 6+ | 2+ | | | | Ā → A<br>B → B<br>M → M | • | 1 | 1 1 1 | 0 0 0 | | | CWAI | | 3C | 20 | 2 | | | | | | | | | | | | | ı | | | CC ∧ IMM → CC<br>(except 1→E)<br>Wait for Interrupt | (- | | 7 | | İ | | DAA | | 19 | 2 | 1 | | | | | | | | | | | | | | | | Decimal Adjust A A – 1 → A | • | I<br>I | 1 | 8. | ١, | | DEC | DECA<br>DECB<br>DEC | 4A<br>5A | 2 | 1 1 | 0A | 6 | 2 | 7A | 7 | 3 | | | | 6A | 6+ | 2+ | | | | $\begin{array}{c c} B-1 \rightarrow B \\ M-1 \rightarrow M \end{array}$ | • | 1 | i | 1 | | | EOR | EORA<br>EORB | | | | 98<br>D8 | 4 | 2 2 | B8<br>F8 | 5 | 3 | 88<br>C8 | 2 2 | 2 2 | A8<br>E8 | 4+ | 2+ | | | | $A \oplus M \rightarrow A$<br>$B \oplus M \rightarrow B$ | • | 1 | l<br>1 | 0 | | | EXG | R1, R2 | 1E | 7 | 2 | | , | - | " | - | - | 1 | | | | | | | | | R1 → R2 <sup>2</sup> | \ (- | $\vdash$ | 10) | $\vdash$ | + | | INC | INCA<br>INCB<br>INC | 4C<br>5C | 2 2 | 1 1 | ос | 6 | 2 | 7C | 7 | 3 | | | | 6C | 6+ | 2+ | | | | A + 1 → A<br>B + 1 → B<br>M + 1 → M | • | 1 | 1 1 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | | JMP | | | | | 0E | 3 | 2 | 7E | 4 | 3 | | | | 6E | 3+ | 2+ | | | | EA <sup>3</sup> → PC | • | • | • | • | 1 | | JSR | | | | | 9D | 7 | 2 | BD | 8 | 3 | | | | AD | 7+ | 2+ | | | | Jump to Subroutin | e • | • | • | • | | | LD | LDA<br>LDB<br>LDD<br>LDS | | | | 96<br>D6<br>DC | 4<br>4<br>5<br>6 | 2 2 2 3 | 86<br>F6<br>FC<br>10 | 5<br>5<br>6<br>7 | 3<br>3<br>4 | 86<br>C6<br>CC<br>10 | 2 2 3 4 | 2<br>2<br>3<br>4 | A6<br>E6<br>EC | 4+<br>4+<br>5+<br>6+ | 2+<br>2+<br>2+<br>3+ | | | | M → A<br>M → B<br>M: M + 1 → D<br>M: M + 1 → S | • | 1 1 1 1 1 1 1 | 1 1 1 1 | 0 0 0 | | | | LDU<br>LDX<br>LDY | | | | DE<br>DE<br>9E<br>10 | 5<br>5<br>6 | 2 2 3 | FE<br>FE<br>BE<br>10 | 6<br>6<br>7 | 3<br>3<br>4 | CE<br>CE<br>8E<br>10 | 3<br>3<br>4 | 3<br>3<br>4 | EE<br>AE<br>10 | 5+<br>5+<br>6+ | 2+<br>2+<br>3+ | | | | M: M + 1 → U<br>M: M + 1 → X<br>M: M + 1 → Y | • | t<br>t | 1 | 000 | | | LEA | LEAS<br>LEAU<br>LEAX | | | | 9E | | | BE | | | 8E | | | 32<br>33<br>30<br>31 | 4+<br>4+<br>4+<br>4+ | 2+<br>2+<br>2+<br>2+ | | | | EA <sup>3</sup> → S<br>EA <sup>3</sup> → U<br>EA <sup>3</sup> → X<br>EA <sup>3</sup> → Y | • | • | | • | ļ | | LSL | LEAY<br>LSLA<br>LSLB<br>LSL | 48<br>58 | 2 2 | 1 1 | 08 | 6 | 2 | 78 | 7 | 3 | | | | 68 | 6+ | 2+ | | | | Â}[-,] | • | 1 1 | ‡<br>‡ | 1 | | | LSR | LSRA<br>LSRB | 44<br>54 | 2 2 | 1 1 | | | | 74 | | | | | | 64 | 6+ | 2+ | | | | A<br>B<br>M | ] | 000 | t | • | | | MUL | LSR | 3D | 11 | 1 | 04 | 6 | 2 | /4 | 7 | 3 | | | | 04 | 0,4 | 2+ | | | | A×B→D<br>(Unsigned) | • | • | ı | • | 1 | | NEG | NEGA<br>NEGB<br>NEG | 40<br>50 | 2 2 | 1 1 | 00 | 6 | 2 | 70 | 7 | 3 | | | | 60 | 6+ | 2+ | | | | A + 1 → A<br>B + 1 → B<br>M + 1 → M | (8)<br>(8) | 1 | 1 | 1 | ļ | | NOP | | 12 | 2 | 1 | | | - | | | | | | | | L | | | | | No Operation | • | • | • | • | | | | | | | | | | | | | | | | | | | | | | | and the second of o | (to | be | cor | ntir | 11 | | INSTRI | UCTION/ | | | | , | | | D6809 | E A | UR | SSIN | IG M | ODES | | | | | | | | | | | | _ | |--------|--------------------------|----------------|-----------------|-----|----------------------------|------------------|------------------|----------------------------|------------------|------------------|----------------|-------------|-------------|----------------------------|----------------------|----------------------|--------------|------|---|--------------------------------------------------------------------------------------|---------|----------|----------|------|---| | | RMS | - | MPLIE | · | + 1 | IREC | | EXTE | | | - | EDI | | | | ED <sup>®</sup> | <del> </del> | LATI | | DESCRIPTION | | 3 | | 1 | 1 | | | | OP | ~_ | # | OP | ~ | # | OP | ~ | # | OP | ~ | # | OP | ~_ | # | OP | ~5 | # | | Н | N | Z | ٧ | 1 | | OR | ORA<br>ORB<br>ORCC | | | | 9A<br>DA | 4 | 2 2 | BA<br>FA | 5<br>5 | 3 | 8A<br>CA<br>1A | 2 2 3 | 2<br>2<br>2 | AA<br>EA | 4+<br>4+ | 2+<br>2+ | | | | $A \lor M \rightarrow A$<br>$B \lor M \rightarrow B$<br>$CC \lor IMM \rightarrow CC$ | •<br>(- | i | ‡<br>(7) | 0 | - | | PSH | PSHS | 34 | 5+ <sup>®</sup> | 2 | | | | | | | | | | | | | | | | Push Registers on<br>S Stack | • | • | • | • | - | | | PSHU | 36 | 5+ <sup>®</sup> | 2 | | | | | | | | | | | | | | | | Push Registers on<br>U Stack | • | • | • | • | | | PUL | PULS | 35 | 5+3 | 2 | | | | | | | | | | | | | | | | Pull Registers from<br>S Stack | (- | | (10) | | | | | PULU | 37 | 5+® | 2 | | | | | | | | | | | | | | | | Pull Registers from<br>U Stack | (- | | (10) | _ | • | | ROL | ROLA<br>ROLB<br>ROL | 49<br>59 | 2 | 1 | 09 | 6 | 2 | 79 | 7 | 3 | | | | 69 | 6+ | 2+ | | | | â} | • | 1 | 1 1 | 1 1 | | | ROR | RORA<br>RORB<br>ROR | 46<br>56 | 2 2 | 1 | 06 | 6 | 2 | 76 | 7 | 3 | | | | 66 | 6+ | 2+ | | | | Å} | • | ‡<br>‡ | 1 1 | • | | | RTI | | 3B | 6/15 | 1 | | | | | ; | | | | | | | ! | | | | Return From<br>Interrupt | (- | $\vdash$ | .7 | | | | RTS | | 39 | 5 | 1 | | | | | | | | | | | | | | | | Return From<br>Subroutine | • | • | • | • | | | SBC | SBCA<br>SBCB | | | | 92<br>D2 | 4 | 2 2 | B2<br>F2 | 5<br>5 | 3 | 82<br>C2 | 2 | 2 | A2<br>E2 | 4+<br>4+ | 2+<br>2+ | | | | $\begin{array}{c} A-M-C\rightarrow A \\ B-M-C\rightarrow B \end{array}$ | 8. | ‡ | 1 | : | | | SEX | | 1D | 2 | 1 | | | | | | | | | | | | | | | | Sign Extend B<br>into A | • | t | İ | • | | | ST | STA<br>STB<br>STD<br>STS | | | | 97<br>D7<br>DD<br>10 | 4<br>4<br>5<br>6 | 2<br>2<br>2<br>3 | 87<br>F7<br>FD<br>10 | 5<br>5<br>6<br>7 | 3<br>3<br>3<br>4 | | | | A7<br>E7<br>ED<br>10 | 4+<br>4+<br>5+<br>6+ | 2+<br>2+<br>2+<br>3+ | | | | A → M<br>B → M<br>D → M: M+ 1<br>S → M: M + 1 | • | 1 1 1 | 1 1 | 0000 | | | | STU<br>STX<br>STY | | | | DF<br>DF<br>9F<br>10<br>9F | 5<br>5<br>6 | 2 2 3 | FF<br>FF<br>BF<br>10<br>BF | 6<br>6<br>7 | 3<br>3<br>4 | | | | EF<br>EF<br>AF<br>10<br>AF | 5+<br>5+<br>6+ | 2+<br>2+<br>3+ | | | | U → M: M + 1<br>X → M: M + 1<br>Y → M: M + 1 | • | 1 1 1 | 1 | 000 | | | SUB | SUBA<br>SUBB<br>SUBD | | | | 90<br>D0<br>93 | 4<br>4<br>6 | 2<br>2<br>2 | B0<br>F0<br>B3 | 5<br>5<br>7 | 3<br>3<br>3 | 80<br>C0<br>83 | 2<br>2<br>4 | 2<br>2<br>3 | A0<br>E0<br>A3 | 4+<br>4+<br>6+ | 2+<br>2+<br>2+ | | | | A M -> A<br>B M -> B<br>D M: M + 1 -> D | 8 | 1 1 1 | 1 | 1 | | | SWI | SWI®<br>SWI2® | 3F<br>10 | 19<br>20 | 1 2 | | | | | | | | | | | | | | | | Software Interrupt1<br>Software Interrupt2 | : | : | • | • | | | | SWI3 '6 | 3F<br>11<br>3F | 20 | 2 | | | | | | | | | | | | | | | | Software Interrupt3 | • | • | • | • | | | SYNC | | 13 | ≥2 | 1 | | | | | | | | | | | | | | | | Synchronize to<br>Interrupt | • | • | • | • | | | TFR | R1, R2 | 1F | 6 | 2 | | | | | | | | | | | | | | | | R1 → R2 <sup>2</sup> | (- | $\vdash$ | (10) | _ | | | TST | TSTA<br>TSTB<br>TST | 4D<br>5D | 2 | 1 | 0D | 6 | 2 | <br> סד | 7 | 3 | | | | 6D | 6+ | 2+ | | | | Test A Test B Test M | | †<br>† | 1 | 000 | | # (NOTES) - This column gives a base cycle and byte count. To obtain total count, and the values obtained from the INDEXED ADDRESSING MODES table. R1 and R2 may be any pair of 8 bit or any pair of 16 bit registers. The 8 bit registers are: A, B, CC, DP The 16 bit registers are: X, Y, U, S, D, PC EA is the effective address. The PSH and PUL instructions require 5 cycle plus 1 cycle for each byte pushed or pulled. 5(6) means: 5 cycles if branch not taken, 6 cycles if taken. SWI sets 1 and F bits, SWI2 and SWI3 do not affect I and F. Conditions Codes set as a direct result of the instruction. Value of half-carry flag is undefined. Special Case Carry set if b7 is SET. Condition Codes set as a direct result of the instruction if CC is specified, and not affected otherwise. - Condition Codes set as a direct result of the instruction if CC is specified, and not affected otherwise. - LEGEND: OP Oper Num # Num + Ariti Operation Code (Hexadecimal) Number of MPU Cycles Number of Program Bytes Arithmetic Plus - × - Arithmetic Plus Arithmetic Minus Multiply Complement of M Transfer Into Half-carry (from bit 3) Negative (sign bit) Ĥ - Zero (byte) Overflow, 2's complement Carry from bit 7 Test and set if true, cleared otherwise - ¢ - cc .. > ^ Not Affected Condition Code Register - Concatenation Logical or - Logical and - $\oplus$ Logical Exclusive or Table 10 Hexadecimal Values of Machine Codes | OP | Mnem | Mode | ~ | # | OP | Mnem | Mode | ~ | # | OP | Mnem | Mode | ~ | # | |----------|------------|---------------------|---|-----|-----|------------|---------------------|------|----|----|---------|-----------------------------------------|----|----| | 00 | NEG | Direct | 6 | 2 | 30 | LEAX | Indexed | 4+ | 2+ | 60 | NEG | Indexed | 6+ | 2+ | | 01 | • | <b>A</b> | | | 31 | LEAY | <b>+</b> | 4+ | 2+ | 61 | * | <b>+</b> | | | | 02 | • | | | | 32 | LEAS | . ↓ | 4+ | 2+ | 62 | • | | | | | 03 | COM | | 6 | 2 | 33 | LEAU | Indexed | 4+ | 2+ | 63 | COM | | 6+ | 2+ | | 04 | LSR | | 6 | 2 | 34 | PSHS | Implied | 5+ | 2 | 64 | LSR | | 6+ | 2+ | | 05 | • | 1 | | | 35 | PULS | <b></b> | 5+ | 2 | 65 | * | | | | | 06 | ROR | 1 | 6 | 2 | 36 | PSHU | | 5+ | 2 | 66 | ROR | | 6+ | 2+ | | 07 | ASR | | 6 | 2 | 37 | PULU | | 5+ | 2 | 67 | ASR | | 6+ | 2+ | | 08 | ASL, LSL | | 6 | 2 | 38 | • | | | | 68 | ASL, LS | L | 6+ | 2+ | | 09 | ROL | | 6 | 2 | 39 | RTS | | 5 | 1 | 69 | ROL | | 6+ | 2+ | | 0A | DEC | | 6 | 2 | 3A | ABX | | 3 | 1 | 6A | DEC | | 6+ | 2+ | | OB | * | İ | • | _ | 38 | RTI | İ | 6,15 | 1 | 6B | * | İ | | | | OC. | INC | | 6 | 2 | 3C | CWAI | | 20 | 2 | 6C | INC | | 6+ | 2+ | | 0D | TST | 1 | 6 | 2 | 3D | MUL | | 11 | 1 | 6D | TST | | 6+ | 2+ | | 0E | JMP | 1 | 3 | 2 | 3E | * | 1 | • • | • | 6E | JMP | 1 | 3+ | 2+ | | 0F | CLR | ▼<br>Direct | 6 | 2 | 3F | SWI | Implied | 19 | 1 | 6F | CLR | Indexed | 6+ | 2+ | | ŲF | CEN | Direct | U | 2 | ٥, | 3111 | mpneo | ,,, | • | | 02.1 | *************************************** | | _ | | 10 | ) See | _ | _ | _ | 40 | NEGA | Implied | 2 | 1 | 70 | NEG | Extended | 7 | 3 | | 11 | Next Page | _ | _ | _ | 41 | * | <b>A</b> | | | 71 | • | <b>A</b> | | | | 12 | NOP | Implied | 2 | 1 | 42 | • | T | | | 72 | | | | | | 13 | SYNC | Implied | 2 | 1 | 43 | COMA | | 2 | 1 | 73 | COM | | 7 | 3 | | 14 | * | mprica | - | • | 44 | LSRA | 1 | 2 | 1 | 74 | LSR | | 7 | 3 | | 15 | | | | | 45 | * | | | | 75 | • | | | | | 16 | LBRA | Relative | 5 | 3 | 46 | RORA | | 2 | 1 | 76 | ROR | | 7 | 3 | | 17 | LBSR | Relative | 9 | 3 | 47 | ASRA | l | 2 | 1 | 77 | ASR | | 7 | 3 | | 18 | * | riciative | • | Ū | 48 | ASLA, LSLA | Į | 2 | 1 | 78 | ASL, LS | SL | 7 | 3 | | 19 | DAA | Implied | 2 | 1 | 49 | ROLA | ļ | 2 | 1 | 79 | ROL | | 7 | 3 | | 1A | ORCC | Immed | 3 | 2 | 4A | DECA | | 2 | 1 | 7A | DEC | | 7 | 3 | | 1B | • | - | • | - | 48 | * | 1 | _ | - | 7B | | | | | | 1C | ANDCC | Immed | 3 | 2 | 4C | INCA | | 2 | 1 | 7C | INC | İ | 7 | 3 | | 10 | SEX | Implied | 2 | 1 | 4D | TSTA | | 2 | 1 | 7D | TST | | 7 | 3 | | 1E | EXG | ‡ | 8 | 2 | 4E | * | 1 | - | • | 7E | JMP | | 4 | 3 | | 1F | TFR | <b>↓</b><br>Implied | 6 | 2 | 4F | CLRA | Implied | 2 | 1 | 7F | CLR | Extended | 7 | 3 | | 15 | irn | mpned | o | - 2 | | CLITA | mpnea | - | • | • | 02 | -Atomas 4 | | • | | 20 | BRA | Relative | 3 | 2 | 50 | NEGB | Implied | 2 | 1 | 80 | SUBA | Immed | 2 | 2 | | 21 | BRN | A | 3 | -2 | 51 | | • | | | 81 | CMPA | <b>A</b> | 2 | 2 | | 22 | ВНІ | Ţ | 3 | 2 | 52 | * | | | | 82 | SBCA | | 2 | 2 | | 23 | BLS | ļ | 3 | 2 | 53 | СОМВ | | 2 | 1 | 83 | SUBD | | 4 | 3 | | 24 | BHS, BCC | 1 | 3 | 2 | 54 | LSRB | | 2 | 1 | 84 | ANDA | | 2 | 2 | | 25 | BLO, BCS | | 3 | 2 | 55 | * | - | _ | | 85 | BITA | 1 | 2 | 2 | | 26 | BNE | | 3 | 2 | 56 | RORB | | 2 | 1 | 86 | LDA | | 2 | 2 | | 27 | BEQ | 1 | 3 | 2 | 57 | ASRB | | 2 | 1 | 87 | * | | | | | 28 | BVC | | 3 | 2 | 58 | ASLB, LSLB | | 2 | 1 | 88 | EORA | | 2 | 2 | | 29 | BVS | | 3 | 2 | 59 | ROLB | | 2 | 1 | 89 | ADCA | | 2 | 2 | | | BVS<br>BPL | l | 3 | 2 | 5A | DECB | | 2 | 1 | 8A | ORA | | 2 | 2 | | 2A | BM! | ĺ | 3 | 2 | 5B | * | | • | • | 8B | ADDA | 1 | 2 | 2 | | 2B<br>2C | BGE | | 3 | 2 | 5C | INCB | | 2 | 1 | 8C | CMPX | ▼<br>Immed | 4 | 3 | | 2D | BLT | İ | 3 | 2 | 5D | TSTB | | 2 | 1 | 8D | BSR | Relative | 7 | 2 | | 2D<br>2E | BGT | 1 | 3 | 2 | 5E | * | Ţ | - | • | 8E | LDX | Immed | 3 | 3 | | 2E | BLE | ▼<br>Relative | 3 | 2 | 5F | CLRB | <b>V</b><br>Implied | 2 | 1 | 8F | * | | - | - | | 21 | DLC | neiative | 3 | 2 | OF, | CLIND | mpned | - | • | 01 | | | | | LEGEND: Number of MPU cycles (less possible push pull or indexed-mode cycles) Wumber of program bytes Denotes unused opcode (to be continued) (NOTE): All unused opcodes are both undefined and illegal 2 2 4 2 2 2 3 2 Immed Immed 3 3 3 3 5 5 5 5 Extended indexed Indexed Extended Extended 7+ 3+ 11AC CMPS 11B3 CMPU 11BC CMPS LDB STB **EORB** ADCB ADDB ORB F7 F8 F9 FΑ CO C1 C2 C3 C4 C5 SUBB СМРВ SBCB ADDD ANDB BITB # • NOTE FOR USE # **Execution Sequence of CLR Instruction** Cycle-by-cycle flow of CLR instruction (Direct, Extended, Indexed Addressing Mode) is shown below. In this sequence the content of the memory location specified by the operand is read before writing "00" into it. Note that status Flags, such as IRQ Flag, will be cleared by this extra data read operation when accessing the control/status register (sharing the same address between read and write) of peripheral devices. | Example | | | |---------|--|--| | | | | | | | | | \$8000<br>\$A000 | CLR<br>FCB | \$A000<br>\$80 | e e | | |------------------|------------|----------------|------------------|------------------| | Cycle # | Address | Data | $R/\overline{W}$ | Description | | 1 | 8000 | 7 <b>F</b> | 1 | Opcode Fetch | | 2 | 8001 | <b>A</b> 0 | 1 | Operand Address, | | | | | | High Byte | | 3 | 8002 | 00 | 1 | Operand Address, | | | | | | Low Byte | | 4 | FFFF | * | 1 | VMA Cycle | | 5 | A000 | 80 | 1 | Read the Data | | 6 | FFFF | * | 1 | VMA Cycle | | 7 | A000 | 00 | 0 | Store Fixed "00" | | | | | | into Specified | | | | | | Location | <sup>\*</sup> The data bus has the data at that particular address.