# MPU (Micro Processing Unit) #### - HD68000 - The HD68000 is the first in a family of advanced microprocessors from Hitachi. Utilizing VLSI technology, the HD68000 is a fully-implemented 16-bit microprocessor with 32-bit registers, a rich basic instruction set, and versatile addressing modes. The HD68000 possesses an asynchronous bus structure with a 24-bit address bus and a 16-bit data bus. #### FFATURES - 32-Bit Data and Address Registers - 16 Megabyte Direct Addressing Range - 56 Powerful Instruction Types - Operations of Five Main Data Types - Memory Mapped, I/O - 14 Addressing Modes #### - HD68HC000 -- The HD68HC000 is a 16-bit microprocessor of HD68000 family, which is exactly compatible with the conventional HD68000. The HD68HC000 is a complete CMOS device and the power dissipation is extremely low. #### **FEATURES** - Instruction Compatible with NMOS HD68000 - Pin Compatible with NMOS HD68000 - AC Timing Compatible with NMOS HD68000 - Low Power Dissipation (I<sub>CC</sub> typ = 20 mA, I<sub>CC</sub> max =35 mA at f = 12.5 MHz) # ■ TYPE OF PRODUCTS | Туре No. | Process | Clock Frequency<br>(MHz) | Package | |---------------|---------|--------------------------|---------| | HD68000-8 | | 8.0 | DC-64 | | HD68000-10 | | 10.0 | DC-64 | | HD68000-12 | 1 | 12.5 | | | HD68000Y8 | 1 | 8.0 | 204.00 | | HD68000Y-10 | NMOS | 10.0 | PGA-68 | | HD68000Y-12 | NMOS | 12.5 | | | HD68000P8 | 1 | 8.0 | DP-64 | | HD68000P98 | ! | 8.0 | DP-64S | | HD68000CR8 | 1 | 8.0 | CP-68 | | HD68HC000-8 | | 8.0 | | | HD68HC000-10 | İ | 10.0 | DC-64 | | HD68HC000-12 | | 12.5 | DC-64 | | HD68HC000Y8 | | 8.0 | | | HD68HC000Y-10 | | 10.0 | PGA-68 | | HD68HC000Y-12 | | 12.5 | | | HD68HC000R8 | | 8.0 | | | HD68HC000P-10 | CMOS | 10.0 | DP-64 | | HD68HC000R12 | | 12.5 | | | HD68HC000P38 | | 8.0 | | | HD68HC000PS10 | | 10.0 | DP-64S | | HD68HC000PS12 | | 12.5 | | | HD68HC000CP8 | | 8.0 | | | HD68HC000CP10 | | 10.0 | CP-68 | | HD68HC000CP12 | | 12.5 | | (Note) HD68000 refers to the NMOS version 68000, and HD68HC000 refers to the CMOS version 68000. 68000 stands for NMOS and CMOS version. - . PIN ARRANGEMENT - DC-64, DP-64, DP-64S # PGA-68 • CP-68 # **@HITACHI** # **ABSOLUTE MAXIMUM RATINGS** | item | Symbol | HD68000 | HD68HC000 | Unit | |-----------------------------|-------------------|-------------------|--------------------|------| | | Syllibol | Value | Value | | | Supply Voltage | Vcc* | -0.3 ~ +7.0 | <b>-0.3 ∼ +6.5</b> | V | | Input Voltage | V <sub>in</sub> * | -0.3 ~ +7.0 | <b>−0.3 ~ +6.5</b> | V | | Operating Temperature Range | Topr | 0~+70 | 0~+70 | °c | | Storage Temperature | T <sub>stg</sub> | <b>−55</b> ~ +150 | <b>−55</b> ~ +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. Since the HD68HC000 is a C-MOS device, users are expected to be cautious on "latch-up" problem caused by voltage fracturations. # ■ RECOMMENDED OPERATING CONDITIONS | Ite | ım. | Symbol | HD68000 | | | H | 00 | Unit | | |------------------|--------------|--------|---------|-------------|-----------------|------|-----|------|-------| | | | Symbol | min | typ | max | min | typ | max | Offic | | Supply Voltage | | Vcc* | 4.75 | 5.0 | 5.25 | 4.75 | 5.0 | 5.25 | V | | | CLK | | 2.0 | <del></del> | \/ | 2.8 | | Vcc | V | | Input Voltage | Other Inputs | VIH* | 2.0 | _ | V <sub>CC</sub> | 2.0 | _ | Vcc | v | | | All Inputs | VIL* | -0.3 | _ | 0.8 | -0.3 | _ | 0.8 | V | | Operating Temper | ature | Topr | 0 | 25 | 70 | 0 | 25 | 70 | °c | <sup>\*</sup> With respect to VSS (SYSTEM GND) # ELECTRICAL CHARACTERISTICS # • DC CHARACTERISTICS ( $V_{CC}$ = 5V ± 5%, $V_{SS}$ = 0V, Te = 0 $\sim$ +70°C, Fig. 1, unless otherwise noted.) | | | | T O distan | HD68 | 3000 | HD68H | Unit | | |---------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|--------------------------------------------------|-----------------------|------|----------------------|-----------------|----------| | | Item | Symbol | Test Condition | min | max | min | max | Onit | | Input "High" Voltage | CLK<br>Other inputs | ViH | | 2.0 | Vcc | 2.8<br>2.0 | V <sub>CC</sub> | ٧ | | Input "Low" Voltage | Other inputs | VIL | | V <sub>SS</sub> -0.3 | 0.8 | V <sub>SS</sub> -0.3 | 0.8 | > | | | BERR, BGACK, BR, DTACK, $\overline{IPL_0} \sim \overline{IPL_2}$ , $\overline{VPA}$ , CLK | | | - | 2.5 | - | 2.5 | | | Input Leakage Current | HALT, RES | 1 in | <b>Ø</b> 5.25∨ | | 20 | | 20 | μΑ | | Three-State (Off State) Input Current | $\overline{AS}$ , $A_1 \sim A_{23}$ , $D_0 \sim D_{15}$ ,<br>$FC_0 \sim FC_2$ , $\overline{LDS}$ , $R/\overline{W}$ , $\overline{UDS}$ ,<br>$\overline{VMA}$ | 1 <sub>TSI</sub> | @ 2.4V/0.4V | - | 20 | - | 20 | μΑ | | Output "High" Voltage | $\overrightarrow{AS}$ , $A_1 \sim A_{23}$ , $\overrightarrow{BG}$ , $D_0 \sim D_{15}$ , $FC_0 \sim FC_2$ , LDS, R/W, UDS, VMA, E | Voн | I <sub>OH</sub> = -400μΑ | 2.4 | _ | V <sub>CC</sub> -075 | - | v | | | E* | 7 _ | | V <sub>CC</sub> -0.75 | | | | | | | HALT | | I <sub>OL</sub> =1.6 mA | | 0.5 | | 0.5 | 4 | | O | A <sub>1</sub> ~A <sub>23</sub> , BG, FC <sub>0</sub> ~ FC <sub>2</sub> | VOL | t <sub>OL</sub> =3.2 mA | | 0.5 | | 0.5 | | | Output "Low" Voltage | RES | ] *0L | I <sub>OL</sub> =5.0 mA | | 0.5 | | 0.5 | \ \ | | | $\overline{AS}$ , $D_0 \sim D_{15}$ , $\overline{LDS}$ , $R/\overline{W}$ , E, $\overline{UDS}$ , $\overline{VMA}$ | | I <sub>OL</sub> =5.3 mA | | 0.5 | | 0.5 | | | | CERAMIC PACKAGE | | f = 6 MHz<br>f = 8 MHz<br>f = 10 MHz | <u> </u> | 1.5 | | | | | Power Dissipation | | PD | f = 12.5 MHz | I | 1.75 | ] - | - | w | | | PLASTIC PACKAGE | | f = 8 MHz,<br>V <sub>CC</sub> = 5V,<br>Ta = 25°C | | 0.9 | | | | | | 1 | | f = 8 MHz | | | | 25 | 4 | | Current Dissipation | | lo** | f = 10 MHz | | | | 30 | _ m.A | | • | | | f = 12.5 MHz | I - | L | | 35 | <u> </u> | | Capacitance (Package T | ype Dependent) | C <sub>in</sub> | V <sub>in</sub> = 0V,<br>Ta = 25°C,<br>f = 1 MHz | - | 20.0 | - | 20.0 | pF | <sup>\*</sup>With external pull up resistor of 1.1 kΩ. <sup>\*\*</sup>Without load. Figure 1 Test Loads # **OHITACHI** # • AC CHARACTERISTICS (V<sub>CC</sub> = 5V $\pm$ 5%, V<sub>SS</sub> = 0V, Ta = 0 $\sim$ +70 $^{\circ}$ C, unless otherwise noted.) # **CLOCK TIMING** | ltem | Symbol Test Condition | | 8 MHz | | 10 MHz | | 12.5 MHz | | Unit | |------------------------|-----------------------|----------------|-------|-----|--------|------|----------|------|------| | 1000 | - Symbol | rest condition | min | max | min | max | min | max | Unit | | Frequency of Operation | f | | 4.0 | 8.0 | 4.0 | 10.0 | 4.0 | 12.5 | MHz | | Cycle Time | t <sub>cyc</sub> | | 125 | 250 | 100 | 250 | 80 | 250 | ns | | 01 1 0 1 100 11 | t <sub>CL</sub> | Fig. 2 | 55 | 125 | 45 | 125 | 35 | 125 | ns | | Clock Pulse Width | tсн | 9. 2 | 55 | 125 | 45 | 125 | 35 | 125 | กร | | Rise and Fall Times | tcr | | _ | 10 | - | 10 | _ | 5 | ns | | nise and rair Times | t <sub>Cf</sub> | | - 1 | 10 | - | 10 | _ | 5 | ns | # (NOTE) Timing measurements are referenced to and from a low voltage of 0.8 volt and high a voltage of 2.0 volts, unless otherwise noted. The voltage swing through this range should start outside and pass through the range such that the rise or fall will be linear between 0.8 volt and 2.0 volts. Figure 2 Clock Input Timing # READ AND WRITE CYCLES | | | | Test | 8 M | IHz | 10 1 | VIHz | 12.5 | MHz | | |------------------|-------------------------------------------------------------|---------------------|-----------|----------|--------------------------------------------------|--------------|------------------|----------|------------------|--------------| | Num. | Item | Symbol | Condition | min | max | min | max | min | max | Unit | | 1 | Clock Period | t <sub>cyc</sub> | | 125 | 250 | 100 | 250 | 80 | 250 | ns | | 2 | Clock Width Low | tcL | | 55 | 125 | 45 | 125 | 35 | 125 | ns | | 3 | Clock Width High | <sup>t</sup> CH | | 55 | 125 | 45 | 125 | 35 | 125 | ns _ | | 4 | Clock Fall Time | tCf | | - | 10 | | 10 | | 5 | ns | | 5 | Clock Rise Time | tcr | | _ | 10 | _ | 10 | | 5 | ns | | 6 | Clock Low to Address Valid | tCLAV | | - | 70 | | 60 | _ | 55* | ns | | 6A | Clock High to FC Valid | tCHFCV | | _ | 70 | _ | 60 | | 55 | ns | | 7 | Clock High to Address, Data Bus<br>High Impedance (Maximum) | tCHADZ | | _ | 80 | - | 70 | | 60 | ns | | 8 | Clock High to Address, FC Invalid (Minimum) | tchafi | | 0 | _ | 0 | | 0 | - | ns | | 91 | Clock High to AS, DS Low | tchsL | | 0 | 60 | _0_ | 55 | 0 | 55 | ns | | 112 | Address Valid to AS, DS Low (Read)/<br>AS Low (Write) | tAVSL | | 30 | | 20 | - | 0 | | ns | | 11A <sup>2</sup> | FC Valid to AS, DS Low (Read)/<br>AS Low (Write) | tFCVSL | | 60 | _ | 50 | | 40 | _ | ns_ | | 12 <sup>1</sup> | Clock Low to AS, DS High | tCLSH | Fig. 3, | | 70 | | 55 | | 50 | ns | | 13 <sup>2</sup> | AS, DS High to Address/FC Invalid | tSHAF1 | Fig. 4 | 30 | - 1 | 20 | _ | 10 | - | ns | | 14 <sup>2</sup> | AS, DS Width Low (Read)/AS Low (Write) | t <sub>6</sub> ∟ | | 240 | _ | 195 | | 160 | | ns | | 14A <sup>2</sup> | DS Width Low (Write) | tDSL | | 115 | <u> </u> | 95 | <u> </u> | 80 | | ns | | 15 <sup>2</sup> | AS, DS Width High | <sup>t</sup> sH | | 150 | | 105 | | 65 | | ns | | 16 | Clock High to Control Bus High Impedance | tcHCZ | _ | <u> </u> | 80 | | 70 | - | 60 | ns | | 17 <sup>2</sup> | AS, DS High to R/W High (Read) | tshRH | j | 40 | | 20 | | 10 | | ns | | 18 <sup>1</sup> | Clock High to R/W High | *CHRH | 1 | 0 | 70 | 0 | 60 | 0 | 60 | ns | | 20 <sup>1</sup> | Clock High to R/W Low (Write) | CHRL | | | 70 | | 60 | <u> </u> | 60 | ns | | 20A <sup>6</sup> | AS Low to R/W Valid (Write) | †ASRV | 1 | | 20 | | 20 | | 20 | ns | | 21 <sup>2</sup> | Address Valid to R/W Low (Write) | TAVEL | 1 | 20 | | 0 | | 0 | | ns | | 21A <sup>2</sup> | FC Valid to R/W Low (Write) | TECVAL | ] | 60 | | 50 | <u> </u> | 30 | | ns | | 22 <sup>2</sup> | R/W Low to DS Low (Write) | 'tRLSL | 1 | 80 | <u> </u> | 50 | <u> </u> | 30 | - | ns | | 23 | Clock Low to Data Out Valid (Write) | tCLDO | _ | <u> </u> | 70 | _ | 55 | | 55 | ns | | 25 <sup>2</sup> | AS, DS High to Data Out Invalid (Write) | SHDOL | 4 | 30 | <b>├</b> =- | 20 | | 15 | <del></del> - | nş | | 26 <sup>2</sup> | Data Out Valid to DS Low (Write) | TOOSL | 4 | 30 | + | 20 | <u>├</u> - | 15 | <b>├</b> | ns | | 27 <sup>5</sup> | Data In to Clock Low (Setup Time on Read) | †DICL_ | 4 | 15 | <del> </del> | 10 | + | 10 | | ns | | 28 <sup>2</sup> | AS, DS High to DTACK High | tSHDAH | 4 | 0 | 245 | 0 | 190 | 0 | 150 | ns | | 29 | AS, DS High to Data In Invalid<br>(Hold Time on Read) | tshoii | | 0 | _ | 0 | _ | 0 | | ns | | 30 | AS, DS High to BERR High | <sup>t</sup> SH8EH | 4 | 0 | <u> </u> | 0 | <del> -</del> - | 0 | <u> </u> | ns | | 312,5 | DTACK Low to Data In (Setup Time) | †DALD! | | | 90 | _ | 65 | | 50 | ns | | 32 | HALT and RESET Input Transition Time | t <sub>RHr, f</sub> | . ↓ | 0 | 200 | 0 | 200 | + | 200 | ns | | 33 | Clock High to BG Low | tCHGL | _ | <u>_</u> | 70 | <u> -</u> . | 60 | + | 50 | ns | | 34 | Clock High to BG High | †CHGH | _ | _ | 70 | <u> </u> | 60 | <u> </u> | 50 | ns | | 35 | BR Low to BG Low | t <sub>BRLGL</sub> | - | 1.5 | 90<br>ns<br>+3.5 | 1.5 | 80<br>ns<br>+3.5 | 1.5 | 70<br>ns<br>+3.5 | Clk.<br>Per. | <sup>\* 57</sup> for HD68HC000 # **(1)** HITACHI # READ AND WRITE CYCLES (CONTINUED) | | | | Test | 8 | MHz | 10 | MHz | 12. | 5 MHz | | |------------------|------------------------------------------------------------------|---------------------|-----------|-----|---------------|-----|---------------|-----|---------------|----------| | Num. | Item | Symbol | Condition | min | max | min | max | min | max | Unit | | 36 <sup>7</sup> | BR High to BG High | <sup>t</sup> BRHGH | | 1.5 | 90 ns<br>+3.5 | 1.5 | 80 ns<br>+3.5 | 1.5 | 70 ns<br>+3.5 | Clk.Per. | | 37 | BGACK Low to BG High | <sup>‡</sup> GALGH | | 1.5 | 90 ns<br>+3.5 | 1.5 | 80 ns<br>+3.5 | 1.5 | 70 ns<br>+3.5 | Clk.Per. | | 37A <sup>8</sup> | BGACK Low to BR High | <sup>t</sup> GALBRH | 1 | 20 | 1.5<br>Clocks | 20 | 1.5<br>Clocks | 20 | 1.5<br>Clocks | ns | | 38 | BG Low to Control, Address, Data Bus<br>High Impedance (AS High) | t <sub>GLZ</sub> | | _ | 80 | - | 70 | _ | 60 | ns | | 39 | BG Width High | tgн | | 1.5 | - | 1.5 | _ | 1.5 | _ | Clk.Per. | | 40 | Clock Low to VMA Low | †CLVML | | _ | 70 | _ | 70 | _ | 70 | ns | | 41 | Clock Low to E Transition | tCLET | 1 | _ | 70 | _ | 55 | - | 45 | ns | | 42 | E Output Rise and Fall Time | ter, f | | _ | 25 | - | 25 | 1 | 25 | ns | | 43 | VMA Low to E High | tVMLEH | | 200 | - | 150 | - | 90 | _ | ns | | 44 | AS, DS High to VPA High | tsh∨ph | Fig. 3, | 0 | 120 | 0 | 90 | 0 | 70 | ns | | 45 | E Low to Control, Address Bus Invalid (Address Hold Time) | <b>t</b> ELCAI | Fig. 4 | 30 | _ | 10 | _ | 10 | _ | ns | | 46 | BGACK Width Low | <sup>t</sup> GAL | | 1.5 | | 1.5 | _ | 1.5 | _ | Clk.Per. | | 47 <sup>5</sup> | Asynchronous Input Setup Time | tASI | ĺ | 20 | _ | 20 | _ | 20 | - | ns | | 48 <sup>3</sup> | BERR Low to DTACK Low | BELDAL | | 20 | _ | 20 | _ | 20 | | ns | | 49 <sup>9</sup> | AS, DS High to E Low | tshel. | Ī | -70 | 70 | -55 | 55 | -45 | 45 | ns | | 50 | E Width High | t <sub>EH</sub> | | 450 | - | 350 | - | 280 | _ | ns | | 51 | E Width Low | teL | | 700 | | 550 | - | 440 | _ | ns | | 53 | Clock High to Data Out Invalid | ‡CHDOI | Ī | 0 | - | 0 | - 1 | 0 | _ | ns | | 54 | E Low to Data Out Invalid | t <sub>ELDOI</sub> | Ī | 30 | - | 20 | _ | 15 | - | ns | | 55 | R/W to Data Bus Driven | tal DBD | Ţ | 30 | _ | 20 | - | 10 | _ | ns | | 56 <sup>4</sup> | HALT/RESET Pulse Width | tHRPW | Ī | 10 | | 10 | _ | 10 | _ | Clk.Per. | | 57 | BGACK High to Control Bus Driven | <sup>‡</sup> GABD | | 1.5 | | 1.5 | | 1.5 | _ | Clk.Per. | | 58 <sup>7</sup> | BG High to Control Bus Driven | <sup>t</sup> GHBD | Ī | 1.5 | _ | 1.5 | - | 1.5 | _ | Clk.Per. | # NOTES: - 1. For a loading capacitance of less than or equal to 50 picofarads, substract 5 nanoseconds from the value given in the maximum columns. - 2. Actual value depends on clock period. - 3. If #47 is satisfied for both DTACK and BERR, #48 may be 0 nanoseconds. - For power up, the MPU must be held in RES state for 100 ms to allow stabilization of on-chip circuitry. After the system is powered up, #56 refers to the minimum pulse width required to reset the system. - If the asynchronous setup time (#47) requirements are satisfied, the DTACK low-to-data setup time (#31) requirement can be ignored. The data must only satisfy the date-in clock-low setup time (#27) for the following cycle. - 6. When AS and R/W are equally loaded (±20%), subtract 10 nanoseconds from the values given in these columns. - 7. The processor will negate BG and begin driving the bus again if external arbitration logic negates BR before asserting BGACK. - 8. The minimum value must be met to guarantee proper operation. If the maximum value is exceeded, BG may be reasserted. - The falling edge of S6 triggers both the negation of the strobes (AS and xDS) and the falling edge of E. Either of these events can occur first, depending upon the loading on each signal. Specification #49 indicates the absolute maximum skew that will occur between the rising edge of the strobes and the falling edge of the E clock. # **(1)** HITACHI These waveforms should only be referenced in regard to the edge-to-edge measurement of the timing specifications. They are not intended as a functional description of the input and output signals. Refer to other functional descriptions and their related diagrams for device operation. # NOTES: - 1. Setup time for the synchronous inputs BGACK, IPL<sub>0-2</sub> and VPA guarantees their recognition at the next falling edge of the clock. - 2. BR need fall at this time only in order to insure being recognized at the end of this bus cycle. - 3. Timing measurements are referenced to and from a low voltage of 0.8 volt and a high voltage 2.0 volts, unless otherwise noted. The voltage swing through this range should start outside and pass through the range such that the rise or fall will be linear between 0.8 volt and 2.0 volts. Figure 3. Read Cycle Timing These waveforms should only be referenced in regard to the edge-to-edge measurement of the timing specifications. They are not intended as a functional description of the input and output signals. Refer to other functional descriptions and their related diagrams for device operation. # NOTES: - Timing measurements are referenced to and from a low voltage of 0.8 volt and a high voltage of 2.0 volts, unless otherwise noted. The voltage swing through this range should start outside and pass through the range such that the rise or fall will be linear between 0.8 volt and 2.0 volts. - 2. Because of loading variations, R/W may be valid after AS even though both are initiated by the rising edge of S2 (Specification 20A). Figure 4. Write Cycle Timing #### • HMCS6800 TIMING | | | | Test | 6 N | ЛНz | 8 N | 1Hz | 10 | MHz | 12.5 | MHz | | |------|-----------------------------------------------------------|--------------------|-----------|-----|-----|-----|-----|-----|-----|------|----------|------| | Num. | Item | Symbol | Condition | min | max | min | max | min | max | min | max | Unit | | 12 | Clock Low to AS, DS High | <sup>t</sup> CLSH | | _ | 80 | - | 70 | - | 55 | _ | 50 | ns | | 18 | Clock High to R/W High | tCHRH | | 0 | 80 | 0 | 70 | 0 | 60 | 0 | 60 | ns | | 20 | Clock High to R/W Low (Write) | tCHRL | ] | - | 80 | - | 70 | _ | 60 | _ | 60 | ns | | 23 | Clock Low to Data Out Valid (Write) | *CLD0 | | _ | 80 | _ | 70 | | 55 | 1 | 55 | ns | | 27 | Data In to Clock Low (Setup Time on Read) | †DICL. | | 25 | | 15 | - | 10 | - | 10 | - | ns | | 29 | AS, DS High to Data In Invalid<br>(Hold Time on Read) | *SHDII | Fig. 5, | 0 | _ | 0 | - | 0 | 1 | 0 | _ | ns | | 40 | Clock Low to VMA Low | †CLVML | Fig. 6 | _ | 80 | - | 70 | - | 70 | _ | 70 | ns | | 41 | Clock Low to E Transition | †CLET | ] | _ | 35 | - | 70 | - | 55 | - | 45 | ns | | 42 | E Output Rise and Fall Time | ter, f | | | 25 | 1 | 25 | | 25 | _ | 25 | ns | | 43 | VMA Low to E High | <sup>‡</sup> ∨MLEH | | 240 | _ | 200 | _ | 150 | _ | 90 | | ns | | 44 | AS, DS High to VPA High | tsH∨PH | | 0 | 160 | 0 | 120 | 0 | 90 | 0 | 70 | ns | | 45 | E Low to Control, Address Bus Invalid (Address Hold Time) | telcai | | 35 | | 30 | - | 10 | - | 10 | | ns | | 47 | Asynchronous Input Setup Time | tASI | | 25 | | 20 | _ | 20 | _ | 20 | _ | ns | | 491 | AS, DS High to E Low | †SHEL | | -80 | _ | -70 | 70 | -55 | 55 | -45 | 45 | ns | | 50 | E Width High | t∈H | ] | 600 | - | 450 | _ | 350 | _ | 280 | | ns | | 51 | E Width Low | t <sub>E</sub> L | ] | 900 | | 700 | _ | 550 | | 440 | | ns | | 54 | E Low to Data Out Invalid | t <sub>ELDOI</sub> | | 40 | - | 30 | _ | 20 | | 15 | <u> </u> | ns | #### NOTE: The falling edge of S6 triggers both the negation of the strobes (AS and xDS) and the falling edge of E. Either of these events can occur first, depending upon the loading on each signal. Specification #49 indicates the absolute maximum skew that will occur between the rising edge of the strobes and the falling edge of the E clock. NOTE: This timing diagram is included for those who wish to design their own circuit to generate VMA. It shows the best case possibly attainable. Figure 5. HD6800 Timing—Best Case # **OHITACHI** Hitachi America, Ltd. • Hitachi Plaza • 2000 Sierra Point Pkwy. • Brisbane, CA 94005-1819 • (415) 589-8300 917 NOTE: This timing diagram is included for those who wish to design their own circuit to generate VMA. It shows the worst case possibly attainable. Figure 6. HD6800 Timing-Worst Case # **BUS ARBITRATION** | | | | Test | 81 | ИHz | 10 | MHz | 12.5 | MHz | | |------------------|---------------------------------------------------------------|---------------------|--------------------|-----|---------------|-----|---------------|------|---------------|----------| | Num. | Item | Symbol | Condition | min | max | min | max | min | max | Unit | | 7 | Clock High to Address, Data Bus<br>High Impedance | tchadz | | _ | 80 | _ | 70 | _ | 60 | ns | | 16 | Clock High to Control Bus High Impedance | *CHCZ | ] | _ | 80 | _ | 70 | _ | 60 | ns | | 33 | Clock High to BG Low | tCHGL | ] | _ | 70 | _ | 60 | | 50 | ns | | 34 | Clock High to BG High | tchgh | | _ | 70 | | 60 | - | 50 | ns | | 35 | BR Low to BG Low | <sup>t</sup> BRLGL | | 1.5 | 90ns<br>+3.5 | 1.5 | 80ns<br>+3.5 | 1.5 | 70ns<br>+3.5 | Clk.Per. | | 361 | BR High to BG High | <sup>t</sup> BRHGH | | 1.5 | 90ns<br>+3.5 | 1.5 | 80ns<br>+3.5 | 1.5 | 70ns<br>+3.5 | Clk.Per. | | 37 | BGACK Low to BG High | <sup>‡</sup> GALGH | Fig. 7 ~<br>Fig. 9 | 1.5 | 90ns<br>+3.5 | 1.5 | 80ns<br>+3.5 | 1.5 | 70ns<br>+3.5 | Clk.Per. | | 37A <sup>2</sup> | BGACK Low to BR High | <sup>t</sup> GALBRH | _ | 20 | 1.5<br>Clocks | 20 | 1.5<br>Clocks | 20 | 1.5<br>Clocks | ns | | 38 | BG Low to Control, Address, Data Bus High Impedance (AS High) | t <sub>GLZ</sub> | | _ | 80 | - | 70 | - | 60 | ns | | 39 | BG Width High | t <sub>GH</sub> | | 1.5 | _ | 1.5 | _ | 1.5 | | Clk.Per. | | 46 | BGACK Width Low | <sup>‡</sup> GAL | | 1.5 | - | 1.5 | _ | 1.5 | _ | Clk.Per. | | 47 | Asynchronous Input Setup Time | tasi | | 20 | - | 20 | _ | 20 | _ | ns | | 57 | BGACK High to Control Bus Driven | †GABD | | 1.5 | - | 1.5 | _ | 1.5 | _ | Clk.Per. | | 58 <sup>1</sup> | BG High to Control Bus Driven | t <sub>GHBD</sub> | | 1.5 | _ | 1.5 | _ | 1.5 | _ | Clk.Per. | # NOTES: 918 - 1. The processor will negate BG and begin driving the bus again if external arbitration logic negates BR before asserting BGACK. - 2. The minimum value must be met to guarantee proper operation. If the maximum value is exceeded, $\overline{BG}$ may be reasserted. Figures 7, 8, and 9 depict the three bus arbitration cases that can arise. Figure 7 shows the timing where $\overline{AS}$ is negated when the processor asserts $\overline{BG}$ (Idle Bus Case). Figure 8 shows the timing where $\overline{AS}$ is asserted when the processor asserts $\overline{BG}$ (Active Bus Case). Figure 9 shows the timing where more than one bus master are requesting the bus. Refer to Bus Arbitration for a complete discussion of bus arbitration. The waveforms shown in Figures 7, 8, and 9 should only be referenced in regard to the edge-to-edge measurement of the timing specifications. They are not intended as a functional description of the input and output signals. Refer to other functional descriptions and their related diagrams for device operation. Figure 7. Bus Arbitration Timing Diagram - Idle Bus Case Figure 8. Bus Arbitration Timing Diagram — Active Bus Case Figure 9. Bus Arbitration Timing Diagram — Multiple Bus Requests As shown in the programming model, the 68000 offers seventeen 32-bit registers in addition to the 32-bit program counter and a 16-bit status register. The first eight registers (D0 $\sim$ D7) are used as data registers for byte (8-bit), word (16-bit), and long word (32-bit) data operations. The second set of seven registers (A0 $\sim$ A6) and the system stack pointer may be used as software stack pointers and base address registers. In addition, these registers may be used for word and long word address operations. All 17 registers may be used as index registers. The status register contains the interrupt mask (eight levels available) as well as the condition codes; extend (X), negative (N), zero (Z), overflow (V), and carry (C). Additional status bits indicate that the processor is in a trace (T) mode and/or in a supervisor (S) state. # Status Register Unused, read as zero. # • DATA TYPES AND ADDRESSING MODES Five basic data types are supported. These data types are: - (1) Bits - (2) BCD Digits (4 bits) - (3) Bytes (8 bits) - (4) Word (16 bits) - (5) Long Words (32 bits) In addition, operations on other data types such as memory address, status word data, etc., are provided for in the instruction set. The 14 addressing modes, shown in Table 1, includes six basic types: - (1) Register Direct - (2) Register Indirect - (3) Absolute - (4) Immediate - (5) Program Counter Relative - (6) Implied Included in the register indirect addressing modes is the capability to do postincrementing, predecrementing, offsetting and indexing. Program counter relative mode can also be modified via indexing and offsetting. Table 1 Addressing Modes | Mode | Generation | |---------------------------------------|-----------------------------------------------------| | Register Direct Addressing | | | Data Register Direct | EA = Dn | | Address Register Direct | EA = An | | Absolute Data Addressing | | | Absolute Short | EA = (Next Word) | | Absolute Long | EA = (Next Two Words) | | Program Counter Relative Addressing | | | Relative with Offset | EA = (PC) + d <sub>16</sub> | | Relative with Index and Offset | EA = (PC) + (Xn) + d <sub>6</sub> | | Register Indirect Addressing | | | Register Indirect | EA = (An) | | Postincrement Register Indirect | EA = (AN), An ← An + N | | Predecrement Register Indirect | An ← An N, EA = (An) | | Register Indirect with Offset | EA = (An) + d <sub>16</sub> | | Indexed Register Indirect with Offset | EA = (An) + (Xn) + da | | Immediate Data Addressing | | | Immediate | DATA = Next Word(s) | | Quick Immediate | Inherent Data | | Implied Addressing | | | Implied Register | EA = SR, USP, SP, PC | | NOTES) | | | EA = Effective Address | d <sub>16</sub> = Sixteen-bit Offset | | An = Address Register | (displacement) | | Dn = Data Register | N = 1 for Byte, 2 for | | Xn = Address or Data Register used | Words and 4 for Long | | as Index Register | Words. If An is the stack | | SR = Status Register | pointer and the operand | | PC = Program Counter | size is byte, N=2 to keep<br>the stack pointer on a | | ( ) = Contents of | word boundary. | | ds = Eight-bit Offset | ← = Replaces | | (displacement) | - neplaces | (1) HITACHI (displacement) Hitachi America, Ltd. • Hitachi Plaza • 2000 Sierra Point Pkwy. • Brisbane, CA 94005-1819 • (415) 589-8300 921 # • INSTRUCTION SET OVERVIEW The 68000 instruction set is shown in Table 2. Some additional instructions are variations, or subsets, of these and they appear in Table 3. Special emphasis has been given to the instruction set's support of structured high-level languages to facilitate ease of programming. Each instruction, with few exceptions, operates on bytes, words, and long words and most instructions can use any of the 14 addressing modes. Combining instruction types, data types, and addressing modes, over 1000 useful instructions are provided. These instructions include signed and unsigned multiply and divide, "quick" arithmetic operations, BCD arithmetic and expanded operations (through traps). Table 2 Instruction Set | Mnemonic | Description | Mnemonic | Description | Mnemonic | Description | |----------------------------------------|---------------------------------------------------------------------------|---------------------------|--------------------------------------------------------------------------|-----------------------------------|-------------------------------------------------------------------------------------------------------------------| | ABCD | Add Decimal with Extend | EOR | Exclusive Or | PEA | Push Effective Address | | ADD<br>AND | Add<br>Logical And | EXG<br>EXT | Exchange Registers Sign Extend | RESET | Reset External Devices Rotate Left without Extend | | ASL<br>ASR | Arithmetic Shift Left Arithmetic Shift Right | JMP<br>JSR | Jump Jump to Subroutine | ROR<br>ROXL | Rotate Right without Extend | | B <sub>CC</sub><br>BCHG<br>BCLR<br>BRA | Branch Conditionally Bit Test and Change Bit Test and Clear Branch Always | LEA<br>LINK<br>LSL<br>LSR | Load Effective Address Link Stack Logical Shift Left Logical Shift Right | ROXE<br>ROXE<br>RTE<br>RTR<br>RTS | Rotate Right with Extend Rotate Right with Extend Return from Exception Return and Restore Return from Subroutine | | BSET<br>BSR<br>BTST | Bit Test and Set Branch to Subroutine Bit Test | MOVE<br>MOVEM<br>MOVEP | Move Move Multiple Registers Move Peripheral Data | SBCD<br>SCC<br>STOP | Subtract Decimal with Extend<br>Set Conditional<br>Stop | | CHK<br>CLR<br>CMP | Check Register Against Bounds<br>Clear Operand | MULS<br>MULU | Signed Multiply Unsigned Multiply | SUB<br>SWAP | Subtract<br>Swap Data Register Halves | | DB <sub>CC</sub> | Test Condition, Decrement and<br>Branch | NBCD<br>NEG<br>NOP | Negate Decimal with Extend Negate No Operation | TAS<br>Trap<br>Trapv | Test and Set Operand Trap Trap on Overflow | | DIVS<br>DIVU | Signed Divide Unsigned Divide | NOT | One's Complement Logical Or | UNLK | Test Unlink | Table 3 Variations of Instruction Types | Instruction<br>Type | Variation | Description | Instruction<br>Type | Variation | Description | |---------------------|-------------|-------------------------------------------|---------------------|--------------|---------------------------| | ADD | ADD | Add | MOVE | MOVE | Move | | | ADDA | Add Address | | MOVEA | Move Address | | | ADDQ | Add Quick | | MOVEQ | Move Quick | | | ADDI | Add Immediate | | MOVE from SR | Move from Status Register | | | ADDX | Add with Extend | | MOVE to SR | Move to Status Register | | AND | AND | Logical And | | MOVE to CCR | Move to Condition Codes | | | ANDI | And Immediate | | MOVE USP | Move User Stack Pointer | | | ANDI to CCR | And Immediate to | NEG | NEG | Negate | | | | Condition Codes | | NEGX | Negate with Extend | | | ANDI to SR | And Immediate to | OR | OR | Logical Or | | | 1 | Status Register | | ORI | Or Immediate | | CMP | CMP | Compare | | ORI to CCR | Or Immediate to | | | CMPA | Compare Address | | | Condition Codes | | | CMPM | Compare Memory | | ORI to \$R | Or Immediate to | | | CMPI | Compare Immediate | | | Status Register | | EOR | EOR | Exclusive Or | SUB | SUB | Subtract | | | EORI | Exclusive Or Immediate | | SUBA | Subtract Address | | | EORI to CCR | Exclusive Or Immediate | | SUBI | Subtract Immediate | | | | to Condition Codes | | SUBQ | Subtract Quick | | | EORI to SR | Exclusive Or Immediate to Status Register | | SUBX | Subtract with Extend | # ■ REGISTER DESCRIPTION AND DATA ORGANIZATION The following paragraphs describe the registers and data organization of the 68000. #### • OPERAND SIZE Operand sizes are defined as follows: a byte equals 8 bits, a word equals 16 bits, and a long word equals 32 bits. The operand size for each instruction is either explicitly encoded in the instruction or implicitly defined by the instruction operation. Implict instructions support some subset of all three sizes. #### • DATA ORGANIZATION IN REGISTERS The eight data registers support data operands of 1, 8, 16, or 32 bits. The seven address registers together with the active stack pointer support address operands of 32 bits. # DATA REGISTERS Each data register is 32 bits wide. Byte operands occupy the low order 8 bits, word operands the low order 16 bits, and long word operands the entire 32 bits. The least significant bit is addressed as bit zero; the most significant bit is addressed as bit 31. When a data register is used as either a source or destination operand, only the appropriate low-order portion is changed: the remaining high-order portion is neither used nor changed. #### ADDRESS REGISTERS Each address register and the stack pointer is 32 bits wide and holds a full 32 bit address. Address registers do not support byte sized operands. Therefore, when an address register is used as a source operand, either the low order word or the entire long word operand is used depending upon the operation size. When an address register is used as the destination operand, the entire register is affected regardless of the operation size. If the operation size is word, any other operands are sign extended to 32 bits before the operation is performed. #### DATA ORGANIZATION IN MEMORY Bytes are individually addressable with the high order byte having an even address the same as the word, as shown in Figure 10. The low order byte has an odd address that is one count higher than the word address. Instructions and multibyte data are accessed only on word (even byte) boundaries. If a long word datum is located at address n + 2. The data types supported by the 68000 are: bit data, integer data of 8, 16, or 32 bits, 32-bit addresses and binary coded decimal data. Each of these data types is put in memory, as shown in Figure 11. The numbers indicate the order in which the data would be accessed from the processor. Figure 10 Word Organization in Memory Figure 11 Data Organization in Memory #### ADDRESSING Instructions for the 68000 contain two kinds of information: the type of function to be performed, and the location of the operand(s) on which to perform that function. The methods used to locate (address) the operand(s) are explained in the following paragraphs. Instructions specify an operand location in one of three ways: Register Specification — the number of the register is given in the register field of the instruction. Effective Address – use of the different effective address Implicit Reference – the definition of certain instructions implies the use of specific registers. # • INSTRUCTION FORMAT Instructions are from one to five words in length, as shown in Figure 12. The length of the instruction and the operation to be performed is specified by the first word of the instruction which is called the operation word. The remaining words further specify the operands. These words are either immediate operands or extensions to the effective address mode specified in the operation word. # • PROGRAM/DATA REFERENCES The 68000 separates memory references into two classes: program references, and data references. Program references, as the name implies, are references to that section of memory that contains the program being executed. Data references refer to that section of memory that contains data. Operand reads are from the data space except in the case of the program counter relative addressing mode. All operand writes are to the data space. #### • REGISTER SPECIFICATION The register field within an instruction specifies the register to be used. Other fields within the instruction specify whether the register selected is an address or data register and how the register is to be used. #### • EFFECTIVE ADDRESS Most instructions specify the location of an operand by using the effective address field in the operation word. For example, Figure 13 shows the general format of the single effective address instruction operation word. The effective address is composed of two 3-bit fields: the mode field, and the register field. The value in the mode field selects the different address modes. The register field contains the number of a register. The effective address field may require additional information to fully specify the operand. This additional information, called the effective address extension, is contained in the following word or words and is considered part of the instruction, as shown in Figure 12. The effective address modes are grouped into three categories: register direct, memory addressing, and special. Figure 12 Instruction Format Figure 13 Single-Effective-Address Instruction Operation Word General Format # REGISTER DIRECT MODES These effective addressing modes specify that the operand is in one of the 16 multifunction registers. # **Data Register Direct** The operand is in the data register specified by the effective address register field. # **Address Register Direct** The operand is in the address register specified by the effective address register field. 927 # MEMORY ADDRESS MODES These effective addressing modes specify that the operand is in memory and provide the specific address of the operand. # Address Register Indirect The address of the operand is in the address register specified by the register field. The reference is classified as a data reference with the exception of the jump and jump to subroutine instructions. # ( HITACHI # **Address Register Indirect With Postincrement** The address of the operand is in the address register specified by the register field. After the operand address is used, it is incremented by one, two, or four depending upon whether the size of the operand is byte, word, or long word. If the address register is the stack pointer and the operand size is byte, the address is incremented by two rather than one to keep the stack pointer on a word boundary. The reference is classified as a data reference. #### Address Register Indirect With Predecrement The address of the operand is in the address register specified by the register field. Before the operand address is used, it is decremented by one, two, or four depending upon whether the operand size is byte, word, or long word. If the address register is the stack pointer and the operand size is byte, the address is decremented by two rather than one to keep the stack pointer on a word boundary. The reference is classified as a data reference. # **Address Register Indirect With Displacement** This address mode requires one word of extension. The address of the operand is the sum of the address in the address register and the sign-extended 16-bit displacement integer in the extension word. The reference is classified as a data reference with the exception of the jump to subroutine instructions. # **Address Register Indirect With Index** This address mode requires one word of extension. The address of the operand is the sum of the address in the address register, the sign-extended displacement integer in the low order eight bits of the extension word, and the contents of the index register. The reference is classified as a data reference with the exception of the jump and jump to subroutine instructions. ( HITACHI # **SPECIAL ADDRESS MODE** The special address modes use the effective address register field to specify the special addressing mode instead of a register number. # **Absolute Short Address** This address mode requires one word of extension. The address of the operand is the extension word. The 16-bit address is sign extended before it is used. The reference is classified as a data reference with the exception of the jump and jump to subroutine instructions. #### Absolute Long Address This address mode requires two words of extension. The address of the operand is developed by the concatenation of the extension words. The high-order part of the address is the first extension word; the low-order part of the address is the second extension word. The reference is classified as a data reference with the exception of the jump and jump to subroutine instructions. # **Program Counter With Displacement** This address mode requires one word of extension. The address of the operand is the sum of the address in the program counter and the sign-extended 16-bit displacement integer in the extension word. The value in the program counter is the address of the extension word. The reference is classified as a program reference. # **Program Counter With Index** This address mode requires one word of extension. This address is the sum of the address in the program counter, the sign-extended displacement integer in the lower eight bits of the extension word, and the contents of the index register. The value in the program counter is the address of the extension word. This reference is classified as a program reference. Low Order #### **Immediate Data** This address mode requires either one or two words of extension depending on the size of the operation. Byte operation - operand is low order byte of extension Word operation - operand is extension word Long word operation - operand is in the two extension words, high-order 16 bits are in the first extension word, low-order 16 bits are in the second extension word. # Byte 0 0 0 0 0 0 0 0 OF 15 Word or High Order **Extension Word** #### COMMENTS Data = Next Word(s) Data is Sign Extended for Address Register but not Data Register ---- Long Word - - - - - - Machine Level Coding MOVE #\$1000, A0 # COMMENTS - Inherent Data - Data is Sign Extended to Long Word - Destination must be a Data Register - Machine Level Coding MOVEQ #\$5A, D3 # **@HITACHI** #### **Condition Codes or Status Register** A selected set of instructions may reference the status register by means of the effective address field. These are: # COMMENTS - EA ≈ (Next Word) Note: This Example is a Privileged Instruction - Machine Level Coding MOVE \$1020, SR #### EFFECTIVE ADDRESS ENCODING SUMMARY Table 4 is a summary of the effective addressing modes discussed in the previous paragraphs. Table 4 Effective Address Encoding Summary | Addressing Mode | Mode | Register | | |------------------------------------------------|------|-----------------|--| | Data Register Direct | 000 | register number | | | Address Register Direct | 001 | register number | | | Address Register Indirect | 010 | register number | | | Address Register Indirect with Postincrement | 011 | register number | | | Address Register Indirect with<br>Predecrement | 100 | register number | | | Address Register Indirect with<br>Displacement | 101 | register number | | | Address Register Indirect with Index | 110 | register number | | | Absolute Short | 111 | 000 | | | Absolute Long | 111 | 001 | | | Program Counter with<br>Displacement | 111 | 010 | | | Program Counter with Index | 111 | 011 | | | Immediate | 111 | 100 | | # • IMPLICIT REFERENCE 934 Some instructions make implicit reference to the program counter (PC), the system stack pointer (SP), the supervisor stack pointer (SSP), the user stack pointer (USP), or the status register (SR). # SYSTEM STACK The system stack is used implicitly by many instructions; user stacks and queues may be created and maintained through the addressing modes. Address register seven (A7) is the system stack pointer (SP). The system stack pointer is either the supervisor stack pointer (SSP) or the user stack pointer (USP), depending on the state of the S-bit in the status register. If the S-bit indicates supervisor state, SSP is the active system stack pointer, and the USP cannot be referenced as an address register. If the S-bit indicates user state, the USP is the active system stack pointer, and the SSP cannot be referenced. Each system stack fills from high memory to low memory. # SYSTEM STACK POINTERS User Stack Supervisor Stack USP-SSP Accessed when S = 0 Accessed when S = 1 PC is Stacked on PC is Stacked on Subroutine Calls in Subroutine Calls in User State Supervisor State Used for Exception \* Increasing Addresses **Processing** The address mode SP@- creates a new item on the active system stack, and the address mode SP@+ deletes an item from the active system stack. The program counter is saved on the active system stack on subroutine calls, and restored from the active system stack on returns. On the other hand, both the program counter and the status register are saved on the supervisor stack during the processing of traps and interrupts. Thus, the correct execution of the supervisor state code is not dependent on the behavior of user code and user programs may use the user stack pointer arbitrarily. In order to keep data on the system stack aligned properly, data entry on the stack is restricted so that data is always put in the stack on a word boundary. Thus byte data is pushed on or pulled from the system stack in the high order half of the word; the lower half is unchanged. #### **USER STACKS** User stacks can be implemented and manipulated by employing the address register indirect with postincrement and predecrement addressing modes. Using an address register (on of A0 through A6), the user may implement stacks which are filled either from high memory to low memory, or vice versa. The important things to remember are: using predecrement, the register is decremented before its contents are used as the pointer into the stack, using postincrement, the register is incremented after its contents are used as the pointer into the stack, byte data must be put on the stack in pairs when mixed with word or long data so that the stack will not get misaligned when the data is retrieved. Word and long accesses must be on word boundary (even) addresses. Stack growth from high to low memory is implemented with An@- to push data on the stack. An@+ to pull data from the stack. After eigher a push or a pull operation, register An points to the last (top) item on the stack. This is illustrated as: Stack growth from low to high memory is implemented with An@+ to push data on the stack, An@- to pull data from the stack. After either a push or a pull operation, register An points to the next available space on the stack. This is illustrated as: #### QUEUES User queues can be implemented and manipulated with the address register indirect with postincrement or predecrement addressing modes. Using a pair of address registers (two of A0 through A6), the user may implement queues which are filled either from high memory to low memory, or vice versa. Because queues are pushed from one end and pulled from the other, two registers are used: the put and get pointers. Queue growth from low to high memory is implemented with Aput@+ to put data into the queue. Aget@+ to get data from the queue. After a put operation, the put address register points to the next available space in the queue and the unchanged get address register points to the next item to remove from the queue. After a get operation, the get address register points to the next item to remove from the queue and the unchanged put address register points to the next available space in the queue. This is illustrated as: If the queue is to be implemented as a circular buffer, the address register should be checked and, if necessary, adjusted before the put or get operation is performed. The address register is adjusted by subtracting the buffer length (in bytes). Queue growth from high to low memory is implemented with Aput@- to put data into the queue. Aget@ - to get data from the queue. After a put operation, the put address register points to the last item put in the queue, and the unchanged get address register points to the last item removed from the queue. After a get operation, the get address register points to the last item removed from the queue and the unchanged put address register points to the last item put in the queue. This is illustrated as: If the queue is to be implemented as a circular buffer, the get or put operation should be performed first, and then the address register should be checked and, if necessary, adjusted. The address register is adjusted by adding the buffer length (in bytes). #### **INSTRUCTION SET SUMMARY** The following paragraphs contain an overview of the form and structure of the 68000 instruction set. The instructions form a set of tools that include all the machine functions to perform the following operations: Data Movement Integer Arithmetic Logical Shift and Rotate Bit Manipulation Binary Coded Decimal Program Control System Control The complete range of instruction capabilities combined with the flexible addressing modes described previously provide a very flexible base for program development. #### DATA MOVEMENT OPERATIONS The basic method of data acquisition (transfer and storage) is provided by the move (MOVE) instruction. The move instruction and the effective addressing modes allow both address and data manipulation. Data move instructions allow byte, word, and long word operands to be transferred from memory to memory, memory to register, register to memory, and register to memory, and register to memory, and register to operand transfers and ensure that only legal address manipulations are executed. In addition to the general move instruction there are several special data movement instructions: move multiple registers (MOVEM), move peripheral data (MOVEP), exchange registers (EXG), load effective address (PEA), push effective address (PEA), link stack (LINK), unlink stack (UNLK), and move quick (MOVEQ). Table 5 is a summary of the data movement operations. Table 5 Data Movement Operations | Instruction | Operand Size | Operation | |-------------|--------------|--------------------------------------------------------------------------------------------------------| | EXG | 32 | Rx ↔ Ry | | LEA | 32 | EA → An | | LINK | _ | $ \begin{pmatrix} An \rightarrow - (SP) \\ SP \rightarrow An; \\ SP + d \rightarrow SP \end{pmatrix} $ | | MOVE | 8, 16, 32 | (EA)s → EAd | | MOVEM | 16, 32 | (EA) → An, Dn<br>An, Dn → EA | | MOVEP | 16, 32 | (EA) → Dn<br>Dn → EA | | MOVEQ | 8 | #xxx → Dn | | PEA | 32 | EA → -(SP) | | SWAP | 32 | On[31:16] + Dn[15:0] | | UNLK | - | (An → Sp;<br>(SP) + → An | #### (NOTES) - s = source —( ) = indirect with predecrement d = destination ( ) + = indirect with postincrement [ ] = bit numbers # = immediate data - INTEGER ARITHMETIC OPERATIONS The arithmetic operations include the four basic operations of add (ADD), subtract (SUB), multiply (MUL), and divide (DIV) as well as arithmetic compare (CMP), clear (CLR), and negate (NEG). The add and subtract instructions are available for both address and data operations, with data operations accepting all operand sizes. Address operations are limited to legal address size operands (16 or 32 bits). Data, address, and memory compare operations are also available. The clear and negate instructions may be used on all sizes of data operands. The multiply and divide operations are available for signed and unsigned operands using word multiply to produce a long word product, and a long word dividend with word divisor to produce a word quotien with a word remainder. Multiprecision and mixed size arithmetic can be accomplished using a set of extended instructions. These instructions are: add extended (ADDX), subtract extended (SUBX), sign extend (EXT), and negate binary with extend (NEGX). A test operand (TST) instruction that will set the condition codes as a result of a compare of the operand with zero is also available. Test and set (TAS) is a synchronization instruction useful in multiprocessor systems. Table 6 is a summary of the integer arithmetic operations. Table 6 Integer Arithmetic Operations | Instruction | Operand Size | Operation | | |-------------|---------------------|-------------------------------------------------------------------------------|--| | ADD | 8, 16, 32<br>16, 32 | Dn + (EA) → Dn<br>(EA)+ Dn → EA<br>(EA) + #xxx → EA<br>AN + (EA) → An | | | ADDX | 8, 16, 32<br>16, 32 | $Dx + Dy + X \rightarrow Dx$ $-(Ax) + - (Ay) + X \rightarrow (Ax)$ | | | CLR | 8, 16, 32 | (EA) → MPU<br>0 → EA | | | СМР | 8, 16, 32<br>16, 32 | Dn - (EA)<br>(EA) - #xxx<br>(Ax) + - (Ay) +<br>An - (EA) | | | DIVS | 32 ÷ 16 | Dn÷(EA) → Dn | | | DIVU | 32 ÷ 16 | Dn÷(EA) → Dn | | | EXT | 8 → 16<br>16 → 32 | (Dn) <sub>8</sub> → Dn <sub>16</sub><br>(Dn) <sub>16</sub> → Dn <sub>32</sub> | | | MULS | 16×16 → 32 | Dn×(EA) → Dn | | | MULU | 16×16 → 32 | Dn×(EA) → Dn | | | NEG | 8, 16, 32 | 0 - (EA) → EA | | | NEGX | 8, 16, 32 | 0 - (EA) - X - EA | | | SUB | 8, 16, 32<br>16, 32 | Dn - (EA) → Dn<br>(EA) - Dn → EA<br>(EA) - #xxx → EA<br>An - (EA) → An | | | SUBX | 8, 16, 32 | $Dx - Dy - X \rightarrow Dx$ $-(Ax) (Ay) - X \rightarrow (Ax)$ | | | TAS | 8 | (EA) - 0, 1 → EA[7] | | | TST | 8, 16, 32 | (EA) - 0 | | (NOTE) [ ] = bit number - ( ) = indirect with predecrement ( ) + = indirect with postincrement # = immediate data #### LOGICAL OPERATIONS Logical operation instructions AND, OR, EOR, and NOT are available for all sizes of integer data operands. A similar set of immediate instructions (ANDI, ORI, and EORI) provide these logical operations with all sizes of immediate data. Table 7 is a summary of the logical operations. Table 7 Logical Operations | Instruction | Operand Size | Operation | | |---------------|--------------|------------------------------------------------------|--| | AND 8, 16, 32 | | Dn ∧ (EA) → Dn<br>(EA) ∧ Dn → EA<br>(EA) ∧ =xxx → EA | | | OR | 8, 16, 32 | Dn v (EA) → Dn<br>(EA) v Dn → EA<br>(EA) v =xxx → EA | | | EOR | 8, 16, 32 | (EA)⊕Dy → EA<br>(EA)⊕ #xxx → EA | | | NOT | 8, 16, 32 | ~ (EA) - EA | | [NOTE] ~ = invert v = logical OR # = immediate data ↑ = logical AND ⊕ = exclusive OR # . SHIFT AND ROTATE OPERATIONS Shift operations in both directions are provided by the arithmetic instructions ASR and ASL and logical shift instructions LSR and LSL. The rotate instructions (with and without extend) available are ROXR, ROXL, ROR, and ROL. All shift and rotate operations can be performed in either registers or memory. Register shifts and rotates support all operand sizes and allow a shift count specified in the instruction of one to eight bits, or 0 to 63 specified in a data register. Memory shifts and rotates are for word operands only and allow only single-bit shifts or rotates. Table 8 is a summary of the shift and rotate operations. Table 8 Shift and Rotate Operations | Instruction | Operand Size | Operation | |-------------|--------------|------------| | ASL | 8, 16, 32 | x/c - 0 | | ASR | 8, 16, 32 | <b>X/C</b> | | LSL | 8, 16, 32 | X/C - 0 | | LSR | 8, 16, 32 | 0 X/C | | ROL | 8, 16, 32 | C | | ROR | 8, 16, 32 | | | ROXL | 8, 16, 32 | C - X | | ROXR | 8, 16, 32 | x + c | #### BIT MANIPULATION OPERATIONS Bit manipulation operations are accomplished using the following instructions: bit test (BTST), bit test and set (BSET), bit test and clear (BCLR), and bit test and change (BCHG). Table 9 is a summary of the bit manipulation operations. (Bit 2 of the status register is Z.) Table 9 Bit Manipulation Operations | Instruction | Operand Size | Operation | | |-------------|--------------|--------------------------------------------------|--| | BTST | 8, 32 | ~ bit of (EA) → Z | | | BSET | 8, 32 | (~ bit of (EA) → Z;<br>1 → bit of EA | | | BCLR 8.32 | | (~ bit of (EA) → Z;<br>0 → bit of EA | | | BCHG 8, 32 | | (~ bit of (EA) → Z;<br>~ bit of (EA) → bit of EA | | (Note) ~ = invert # . BINARY CODED DECIMAL OPERATIONS Multiprecision arithmetic operations on binary coded decimal numbers are accomplished using the following instructions: add decimal with extend (ABCD), subtract decimal with extend (SBCD), and negate decimal with extend (NBCD). Table 10 is a summary of the binary coded decimal operations. Table 10 Binary Coded Decimal Operations | Instruction | Operand Size | Operation | |-------------|--------------|-------------------------------------------------------------------------------------------------| | ABCD | 8 | $Dx_{10} + Dy_{10} + X \rightarrow Dx$<br>- $(Ax)_{10} + - (Ay)_{10} + X \rightarrow (Ax)_{10}$ | | SBCD | 8 | $Dx_{10} - Dy_{10} - X \rightarrow Dx$<br>- $(Ax)_{10} (Ay)_{10} - X \rightarrow (Ax)$ | | NBCD | 8 | 0 - (EA) <sub>10</sub> - X → EA | - ( ) = indirect with predecrement ( HITACHI # PROGRAM CONTROL OPERATIONS Program control operations are accomplished using a series of conditional and unconditional branch instructions and return instructions. These instructions are summarized in Table 11. The conditional instructions provide setting and branching for the following conditions: | CC | _ | carry clear | LS - | low or same | |----|---|------------------|------|-------------| | | | carry set | LT - | less than | | EQ | _ | equal | MI – | minus | | F | _ | never true | NE - | not equal | | | | greater or equal | PL – | plus | | GT | _ | greater than | Т – | always true | | | | high | VC - | no overflow | | LE | _ | less or equal | VS - | overflow | Table 11 Program Control Operations | Instruction | Operation | | |---------------|----------------------------------------|--| | Conditional | | | | BCC | Branch conditionally (14 conditions) | | | | 8- and 16-bit displacement | | | DBCC | Test condition, decrement, and branch | | | | 16-bit displacement | | | Scc | Set byte conditionally (16 conditions) | | | Unconditional | | | | BRA | Branch always | | | | 8-and 16-bit displacement | | | BSR | Branch to subroutine | | | | 8- and 16-bit displacement | | | JMP | Jump | | | JSR | Jump to subroutine | | | Returns | | | | RTR | Return and restore condition codes | | | RTS | Return from subroutine | | # • SYSTEM CONTROL OPERATIONS System control operations are accomplished by using privileged instructions, trap generating instructions, and instructions that use or modify the status register. These instructions are summarized in Table 12. Table 12 System Control Operations | Instruction | Operation | | |-----------------|--------------------------------|--| | Privileged | | | | RESET | Reset external devices | | | RTE | Return from exception | | | STOP | Stop program execution | | | ORI to SR | Logical OR to status register | | | MOVE USP | Move user stack pointer | | | ANDI to SR | Logical AND to status register | | | EORI to SR | Logical EOR to status register | | | MOVE EA to SR | Load new status register | | | Trap Generating | | | | TRAP | Trap | | | TRAPV | Trap on overflow | | | CHK | Check register against bounds | | | Status Register | | | | ANDI to CCR | Logical AND to condition codes | | | EORI to CCR | Logical EOR to condition codes | | | MOVE EA to CCR | Load new condition codes | | | ORI to CCR | Logical OR to condition codes | | | MOVE SR to EA | Store status register | | # • BRANCH INSTRUCTION ADDRESSING #### BRANCH INSTRUCTION FORMAT | | 15 8 | 1_7 | 0 | |----------------|---------------------|---------------------------|--------| | Operation Word | Operation Code | 8 bit Displacement | $\neg$ | | Extension Word | 16 bit Displacement | if 8 bit Displacement = 0 | | # RELATIVE, FORWARD REFERENCE, 8-BIT OFFSET 938 # 4 939 # RELATIVE, BACKWARD REFERENCE 8-BIT OFFSET # RELATIVE, FORWARD REFERENCE, 16-BIT OFFSET # SIGNAL AND BUS OPERATION DESCRIPTION The following paragraphs contain a brief description of the input and output signals. A discussion of bus operation during the various machine cycles and operations is also given. (NOTE) The terms assertion and negation will be used extensively. This is done to avoid confusion when dealing with a mixture of "active-low" and "active-high" signals. The term assert or assertion is used to indicate that a signal is active or true independent of whether that voltage is low or high. The term negate or negation is used to indicate that a signal is inactive or false. #### SIGNAL DESCRIPTION The input and output signals can be functionally organized into the groups shown in Figure 14. The following paragraphs provide a brief description of the signals and also a reference (if applicable) to other paragraphs that contain more detail about the function being performed. Figure 14 Input and Output Signals #### ADDRESS BUS (A1 through A23) This 23-bit, unidirectional, three-state bus is capable of addressing 8 megawords of data. It provides the address for bus operation during all cycles except interrupt cycles. During interrupt cycles, address lines A<sub>1</sub>, A<sub>2</sub>, and A<sub>3</sub>. Provide information about what level interrupt is being serviced while address lines A<sub>4</sub> through A<sub>23</sub> are all set to a logic high. # DATA BUS (Do through D15) This 16-bit, bidirectional, three-state bus is the general purpose data path. It can transfer and accept data in either word or byte length. During an interrupt acknowledge cycle, an external device supplies the vector number on data lines Do through D<sub>7</sub>. # **ASYNCHRONOUS BUS CONTROL** Asynchronous data transfer are handled using the following control signals: address strobe, read/write, upper and lower data strobes, and data transfer acknowledge. These signals are explained in the following paragraphs. # Address Strobe (AS) 940 This signal indicates that there is a valid address on the address bus. #### Read/Write (R/W) This signal defines the data bus transfer as a read or write cycle. The R/W signal also works in conjunction with the upper and lower data strobes as explained in the following paragraph. #### Upper and Lower Data Strobes (UDS, LDS) These signals control the data on the data bus, as shown in Table 13. When the $R/\overline{W}$ line is high, the processor will read from the data bus as indicated. When the $R/\overline{W}$ line is low, the processor will write to the data bus as shown. Table 13 Data Strobe Control of Data Bus | UDS | LDS | R/W | D <sub>8</sub> ~ D <sub>15</sub> | $D_0 \sim D_7$ | |------|------|------|----------------------------------|----------------------------| | High | High | _ | No valid data | No valid data | | Low | Low | High | Valid data bits<br>8 ∼ 15 | Valid data bits<br>0 ~ 7 | | High | Low | High | No valid data | Valid data bits<br>0 ∼ 7 | | Low | High | High | Valid data bits<br>8 ∼ 15 | No valid data | | Low | Low | Low | Valid data bits<br>8 ~ 15 | Valid data bits<br>0 ∼ 7 | | High | Low | Low | Valid data bits<br>0 ~ 7* | Valid data bits<br>0 ∼ 7 | | Low | High | Low | Valid data bits<br>8 ∼ 15 | Valid data bits<br>8 ~ 15* | These conditions are a result of current implementation and may not appear on future devices. # Data Transfer Acknowledge (DTACK) This input indicates that the data transfer is completed. When the processor recognizes DTACK during a read cycle, data is latched and the bus cycle terminated. When DTACK is recognized during a write cycle, the bus cycle is terminated. (Refer to ASYNCHRONOUS VERSUS SYNCHRONOUS OPERATION) #### **BUS ARBITRATION CONTROL** These three signals form a bus arbitration circuit to determine which device will be the bus master device. #### Bus Request (BR) This input is wire ORed with all other devices that could be bus masters. This input indicates to the processor that some other device desires to become the bus master. #### Bus Grant (BG) This output indicates to all other potential bus master devices that the processor will release bus control at the end of the current bus cycle. #### Bus Grand Acknowledge (BGACK) This input indicates that some other device has become the bus master. This signal cannot be asserted until the following four conditions are met: - (1) A Bus Grant has been received - (2) Address Strobe is inactive which indicates that the microprocessor is not using the bus - (3) Data Transfer Acknowledge is inactive which indicates that neither memory nor peripherals are using the bus Bus Grant Acknowledge is inactive which indicates that no other device is still claiming bus mastership. # INTERRUPT CONTROL (IPL, IPL, IPL,) These input pins indicate the encoded priority lèvel of the device requesting an interrupt. Level seven is the highest priority while level zero indicates that no interrupts are requested. Level seven can not be masked. The least significant bit is given in IPLo and the most significant bit is contained in IPL2. These lines must remain stable until the processor signals interrupt acknowledge (FCo $\sim$ FC2 are all high) to insure that the interrupt is recognized. #### SYSTEM CONTROL The system control inputs are used to either reset or halt the processor and to indicate to the processor that bus errors have occurred. The three system control inputs are explained in the following paragraphs. # Bus Error (BERR) This input informs the processor that there is a problem with the cycle currently being executed. Problems may be a result of: - (1) Nonresponding devices - (2) Interrupt vector number acquisition failure - (3) Illegal access request as determined by a memory management unit - (4) Other application dependent errors. The bus error signal interacts with the halt signal to determine if exception processing should be performed or if the current bus cycle should be retried. Refer to BUS ERROR AND HALT OPERATION paragraph for additional information about the interaction of the bus error and halt signals. #### Reset (RES) This bidirectional signal line acts to reset (initiate a system initialization sequence) the processor in response to an external reset signal. An internally generated reset (result of a RESET instruction) causes all external devices to be reset and the internal state of the processor is not affected. A total system reset (processor and external devices) is the result of external HALT and RESET signals applied at the same time. Refer to RESET OPERATION paragraph for additional information about reset operation. # Halt (HALT) When this bidirectional line is driven by an external device, it will cause the processor to stop at the completion of the current bus cycle. When the processor has been halted using this input, all control signals are inactive and all three-state lines are put in their high-impedance state. Refer to BUS ERROR AND HALT OPERATION paragraph for additional information about the interaction between the halt and bus error signals. When the processor has stopped executing instructions, such as in a double bus fault condition, the halt line is driven by the processor to indicate to external devices that the processor has stopped. # HMCS6800 PERIPHERAL CONTROL These control signals are used to allow the interfacing of synchronous HD6800 peripheral devices with the asynchronous 68000. These signals are explained in the following paragraphs. #### Enable (E) This signal is the standard enable signal common to all HD6800 type peripheral devices. The period for this output is ten 68000 clock periods (six clocks low; four clocks high). Enable is generated by an internal ring counter which may come up in any state (i.e., at power on, it is impossible to guarantee phase relationship of E to CLK), E is a free-running clock and runs regardless of the state of the bus on the MPU. # Valid Peripheral Address (VPA) This input indicates that the device or region addressed is a HD6800 family device and that data transfer should be synchronized with the enable (E) signal. This input also indicates that the processor should use automatic vectoring for an interrupt. Refer to INTERFACE WITH HD6800 PERIPHERALS. ALS. #### Valid Memory Address (VMA) This output is used to indicate to HD6800 peripheral devices that there is a valid address on the address bus and the processor is synchronized to enable. This signal only responds to a valid peripheral address (VPA) input which indicates that the peripheral is a HD6800 family device. # PROCESSOR STATUS (FC0, FC1, FC2) These function code outputs indicate the state (user or supervisor) and the cycle type currently being executed, as shown in Table 14. The information indicated by the function code outputs is valid whenever address strobe $(\overline{AS})$ is active. Table 14 Function Code Outputs | FC <sub>2</sub> | FC <sub>1</sub> | FC <sub>0</sub> | Cycle Type | | | |-----------------|-----------------|-----------------|-----------------------|--|--| | Low | Low | Low | (Undefined, Reserved) | | | | Low | Low | High | User Data | | | | Low | High | Low | User Program | | | | Low | High | High | (Undefined, Reserved) | | | | High | Low | Low | (Undefined, Reserved) | | | | High | Low | High | Superviser Data | | | | High | High | Low | Supervisor Program | | | | High | High | High | Interrupt Acknowledge | | | #### CLOCK (CLK) The clock input is a TTL-compatible signal that is internally buffered for development of the internal clocks needed by the processor. The clock input should not be gated off at any time, and the clock signal must conform to minimum and maximum pulse width time. # SIGNAL SUMMARY Table 15 is a summary of all the signals discussed in the previous paragraphs. # • BUS OPERATION The following paragraphs explain control signal and bus operation during data transfer operations, bus arbitration, bus error and halt conditions, and reset operation. **(1)** HITACHI Table 15 Signal Summary | Signat Name | Mnemonic | Input/Output | Active State | Three State | | |------------------------------|-----------------------------------------------------|--------------|------------------------|-------------|--------| | Signal Ivalite | | | | On BGACK | On HAL | | Address Bus | A <sub>1</sub> ~ A <sub>23</sub> | output | high | yes | yes | | Data Bus | D <sub>0</sub> ~ D <sub>15</sub> | input/output | high | yes | yes | | Address Strobe | ĀŠ | output | low | yes | no | | Read/Write | R/W | output | read-high<br>write-low | yes | no | | Upper and Lower Data Strobes | UDS, LDS | output | low | yes | no | | Data Transfer Acknowledge | DTACK | input | low | no | no | | Bus Request | BR | input | low | no | no | | Bus Grant | BĞ | output | low | no | no | | Bus Grant Acknowledge | BGACK | input | low | no | no | | Interrupt Priority Level | IPLo, IPL1, IPL2 | input | low | no | по | | Bus Error | BERR | input | low | no | no | | Reset | RES | input/output | low | no* | no* | | Halt | HALT | input/output | low | no* | no* | | Enable | E | output | high | no | no | | Valid Memory Address | VMA | output | low | yes | no | | Valid Peripheral Address | <b>VPA</b> | input | low | no | no | | Function Code Output | FC <sub>0</sub> , FC <sub>1</sub> , FC <sub>2</sub> | output | high | yes | no | | Clock | CLK | input | high | no | no | | Power Input | V <sub>cc</sub> | input | _ | | _ | | Ground | V <sub>SS</sub> | input | _ | 1 - | | <sup>\*</sup> Open drain #### DATA TRANSFER OPERATIONS Transfer of data between devices involve the following leads: - (1) Address Bus A1 through A23 - (2) Data Bus Do through D15 - (3) Control Signals The address and data buses are separate parallel buses used to transfer data using an asynchronous bus structure. In all cycles, the bus master assumes responsibility for deskewing all signals it issues at both the start and end of a cycle. In addition, the bus master is responsible for deskewing the acknowledge and data signals from the slave device. The following paragraphs explain the read, write, and read-modify-write cycles. The indivisible read-modify-write cycle is the method used by the 68000 for interlocked multiprocessor communications. #### Read Cycle During a read cycle, the processor receives data from memory or a peripheral device. The processor reads bytes of data in all cases. If the instruction specifies a word (or double word) operation, the processor reads both upper and lower bytes simultaneously by asserting both upper and lower data strobes. When the instruction specifies byte operation, the processor uses an internal Ao bit to determine which byte to read and then issues the data strobe required for that byte. For bytes operations, when the Ao bit equals zero, the upper data strobe is issued. When the Ao bit equals one, the lower data strobe is issued. When the data is received, the processor correctly positions it internally. A word read cycle flow chart is given in Figure 15. A byte read cycle flow chart is given in Figure 16. Read cycle timing is given in Figure 17. Figure 18 details word and byte read cycle operations. Refer to these illustrations during the following detailed. At state zero (S0) in the read cycle, the address bus ( $A_1$ through $A_{23}$ ) is in the high impedance state. A function code is asserted on the function code output line (FC<sub>0</sub> through FC<sub>2</sub>). The read/write (R/W) signal is switched high to indicate a read cycle. One half clock cycle later, at state 1, the address bus is released from the high impedance state. The function code outputs indicate which address space that this cycle will operate on. In state 2, the address strobe $(\overline{AS})$ is asserted to indicate that there is a valid address on the address bus and the upper and lower data strobe $(\overline{UDS}, \overline{LDS})$ is asserted as required. The memory or peripheral device uses the address bus and the address strobe to determine if it has been selected. The selected device uses the read/write signal and the data strobe to place its information on the data bus. Concurrent with placing data on the data bus, the selected device asserts data transfer acknowledge $(\overline{DTACK})$ . Data transfer acknowledge must be present at the processor at the start of state 5 or the processor will substitute wait states for states 5 and 6. State 5 starts the synchronization of the returning data transfer acknowledge. At the end of state 6 (beginning of state 7) incoming data is latched into an internal data bus holding register. During state 7, address strobe and the upper and/or lower data strobes are negated. The address bus is held valid through state 7 to allow for static memory operation and signal skew. Figure 15 Word Read Cycle Flow Chart Figure 16 Byte Read Cycle Flow Chart Figure 17 Read and Write Cycle Timing Diagram **@HITACHI** Figure 18 Word and Byte Read Cycle Timing Diagram The read/write signal and the function code outputs also remain valid through state 7 to ensure a correct transfer operation. The slave device keeps its data asserted until it detects the negation of either the address strobe or the upper and/or lower data strobe. The slave device must remove its data and data transfer acknowledge within one clock period of recognizing the negation of the address or data strobes. Note that the data bus might not become free and data transfer acknowledge might not be removed until state 0 or 1. When address strobe is negated, the slave device is released. Note that a slave device must remain selected as long as address strobe is asserted to ensure the correct functioning of the read-modify-write cycle. #### Write Cycle During a write cycle, the processor sends data to memory or a peripheral device. The processor writes bytes of data in all cases. If the instruction specifies a word operation, the processor writes both bytes. When the instruction specifies a byte operation, the processor uses an internal $A_0$ bit to determine which byte to write and then issues the data strobe required for that byte. For byte operations, when the $A_0$ bit equals zero, the upper data strobe is issued. When the $A_0$ bit equals one, the lower data strobe is issued. A word write cycle flow chart is given in Figure 19. A byte write cycle flow chart is given in Figure 20. Write cycle timing is given in Figure 17. Figure 21 details word and byte write cycle operation. Refer to these illustrations during the following detailed discussion. At state zero (S0) in the write cycle, the address bus ( $A_1$ through $A_{23}$ ) is in the high impedance state. A function code is asserted on the function code output line (FC<sub>0</sub> through FC<sub>2</sub>). (NOTE) The read/write (R/W) signal remains high until state 2 to prevent bus conflicts with preceding read cycles. The data bus is not driven until state 3. One half clock later, at state 1, the address bus is released from the high impedance state. The function code outputs indicate which address space that this cycle will operate on. In state 2, the address strobe $(\overline{AS})$ is asserted to indicate that there is a valid address on the address bus. The memory or peripheral device uses the address bus and the address strobe to determine if it has been selected. During state 2, the read/write signal is switched low to indicate a write cycle. When external processor data bus buffers are required, the read/write line provides sufficient directional control. Data is not asserted during this state to allow sufficient turn around time for external data buffers (if used). Data is asserted onto the data bus during state 3. In state 4, the data strobes are asserted as required to indicate that the data bus is stable. The selected device uses the read/write signal and the data strobes to take its information from the data bus. The selected device asserts data transfer acknowledge (DTACK) when it has successfully stored the data. Data transfer acknowledge must be present at the processor at the start of state 5 or the processor will substitute wait states for states 5 and 6. State 5 starts the synchronization of the returning data transfer acknowledge. During state 7, address strobe and the upper and/or lower data strobes are negated. The address and data buses are held valid through state 7 to allow for static memory operation and signal skew. The read/write signal and the function code outputs also remain valid through state 7 to ensure a correct transfer operation. The slave device keeps its data transfer acknowledge asserted until it detects the negation of either the address strobe or the upper and/or lower data strobe. The slave device must remove its data transfer acknowledge within one clock period after recognizing the negation of the address or data strobes. Note that the processor releases the data bus at the end of state 7 but that data transfer acknowledge might not be removed until state 0 or 1. When address strobe is negated, the slave device is released. ## **@HITACHI** Figure 19 Word Write Cycle Flow Chart Figure 20 Byte Write Cycle Flow Chart Figure 21 Word and Byte Write Cycle Timing Diagram **@HITACHI** ### Read-Modify-Write Cycle The read-modify-write cycle performs a read, modifies the data in the arithmetic-logic unit, and writes the data back to the same address. In the 68000 this cycle is indivisible in that the address strobe is asserted throughout the entire cycle. The test and set (TAS) instruction uses this cycle to provide meaningful communication between processors in a multiple processor environment. This instruction is the only instruction that uses the read-modify-write cycle and since the test and set instruction only operates on bytes, all read-modify-write cycles are byte operations. A read-modify-write cycle flow chart is given in Figure 22 and a timing diagram is given in Figure 23. Refer to these illustrations during the following detailed discussions. At state zero (S0) in the read-modify-write cycle, the address bus ( $A_1$ through $A_{23}$ ) is in the high impedance state. A function code is asserted on the function code output line (FC<sub>0</sub> through FC<sub>2</sub>). The read/write ( $R/\overline{W}$ ) signal is switched high to indicate a read cycle. One half clock cycle later, at state 1, the address bus is released from the high impedance state. The function code outputs indicate which address space that this cycle will operate on. In state 2, the address strobe (AS) is asserted to indicate that there is a valid address on the address bus and the upper or lower data strobe (UDS, LDS) is asserted as required. The memory or peripheral device uses the address bus and the address strobe to determine if it has been selected. The selected device uses the read/write signal and the data strobe to place its information on the data bus. Concurrent with placing data on the data bus, the selected device asserts data transfer acknowledge (DTACK). Data transfer acknowledge must be present at the processor at the start of state 5 or the processor will substitute wait states for states 5 and 6. State 5 starts the synchronization of the returning data transfer acknowledge. At the end of state 6 (beginning of state 7) incoming data is latched into an internal data bus holding register. During state 7, the upper or lower data strobe is negated. The address bus, address strobe, read/write signal, and function code outputs remain as they were in preparation for the write portion of the cycle. The slave device keeps its data asserted until it detects the negation of the upper or lower data strobe. The slave device must remove its data and data transfer acknowledge within one clock period of recognizing the negation of the data strobes. Internal modification of data may occur from state 8 to state 11. (NOTE) The read/write signal remains high until state 14 to prevent bus conflicts with the preceding read portion of the cycle and the data bus is not asserted by the processor until state 15. In state 14, the read/write signal is switched low to indicate a write cycle. When external processor data bus buffers are required, the read/write line provides sufficient directional control. Data is not asserted during this state to allow sufficient turn around time for external data buffers (if used). Data is asserted onto the data bus during state 15. In state 16, the data strobe is asserted as required to indicate that the data bus is stable. The selected device uses the read/write signal and the data strobe to take its information from the data bus. The selected device asserts data transfer acknowledge (DTACK) when it has successfully stored its data. Data transfer acknowledge must be present at the processor at the start of state 17 or the processor will substitute wait states for states 17 and 18. State 17 starts the synchronization of the returning data transfer acknowledge for the write portion of the cycle. The bus interface circuitry issues requests for subsequent internal cycles during state 18. During state 19, address strobe and the upper or lower data strobe is negated. The address and data buses are held valid through state 19 to allow for static memory operation and signal skew. The read/write signal and the function code outputs also remain valid through state 19 to ensure a correct transfer operation. The slave device keeps its data transfer acknowledge asserted until it detects the negation of either the address strobe or the upper or lower data strobe. The slave device must remove its data transfer acknowledge within once clock period after recognizing the negation of the address or data strobes. Note that the processor releases the data bus at the end of state 19 but that data transfer acknowledge might not be removed until state 0 or 1. When address strobe is negated the slave device is released. #### **BUS ARBITRATION** Bus arbitration is a technique used by master-type devices to request, be granted, and acknowledge bus mastership. In its simplest form, it consists of: - (1) Asserting a bus mastership request. - (2) Receiving a grant that the bus is available at the end of the current cycle. - (3) Acknowledging that mastership has been assumed. Figure 24 is a flow chart showing the detail involved in a request from a single device. Figure 25 is a timing diagram for the same operations. This technique allows processing of bus requests during data transfer cycles. The timing diagram shows that the bus request is negated at the time that an acknowledge is asserted. This type of operation would be true for a system consisting of the processor and one device capable of bus mastership. In systems having a number of devices capable of bus mastership, the bus request line from each device is wire ORed to the processor. In this system, it is easy to see that there could be more than one bus request being made. The timing diagram shows that the bus grant signal is negated a few clock cycles after the transition of the acknowledge (BGACK) signal. However, if the bus requests are still pending, the processor will assert another bus grant within a few clock cycles after it was negated. This additional assertion of bus grant allows external arbitration circuitry to select the next bus master before the current bus master has completed its requirements. The following paragraphs provide additional information about the three steps in the arbitration process. Figure 22 Read-Modify-Write Cycle Flow Chart Figure 23 Read-Modify-Write Cycle Timing Diagram **OHITACHI** Hitachi America, Ltd. • Hitachi Plaza • 2000 Sierra Point Pkwy. • Brisbane, CA 94005-1819 • (415) 589-8300 947 Figure 24 Bus Arbitration Cycle Flow Chart #### Requesting the Bus External devices capable of becoming bus masters request the bus by asserting the bus request (BR) signal. This is a wire ORed signal (although it need not be constructed from open collector devices) that indicates to the processor that some external device requires control of the external bus. The processor is effectively at a lower bus priority level that the external device and will relinquish the bus after it has completed the last bus cycle it has started. When no acknowledge is received before the bus request signal goes inactive, the processor will continue processing when it detects that the bus request is inactive. This allows ordinary processing to continue if the arbitration circuitry responded to noise inadvertently. ### Receiving the Bus Grant The processor asserts bus grant (BG) as soon as possible. Normally this is immediately after internal synchronization. The only exception to this occurs when the processor has made an internal decision to execute the next bus cycle but has not progressed far enough into the cycle to have asserted the address strobe (AS) signal. In this case, bus grant will not be asserted until one clock after address strobe is asserted to indicate to external devices that a bus cycle is being executed. The bus grant signal may be routed through a daisy-chained network or through a specific priority-encoded network. The processor is not affected by the external method of arbitration as long as the protocol is obeyed. #### Acknowledgement of Mastership Upon receiving a bus grant, the requesting device waits until address strobe, data transfer acknowledge, and bus grant acknowledge are negated before issuing its own BGACK. The negation of the address strobe indicates that the previous master has completed its cycle, the negation of bus grant acknowledge indicates that the previous master has released the bus. (While address strobe is asserted no device is allowed to "break into" a cycle.) The negation of data transfer acknowledge indicates the previous slave has terminated its connection to the previous master. Note that in some applications data Figure 25 Bus Arbitration Cycle Timing Diagram ## **OHITACHI** transfer acknowledge might not enter into this function. General purpose devices would then be connected such that they were only dependent on address strobe. When bus grant acknowledge is issued the device is bus master until it negates bus grant acknowledge. Bus grant acknowledge should not be negated until after the bus cycle(s) is (are) completed. Bus mastership is terminated at the negation of bus grant acknowledge. The bus request from the granted device should be dropped after bus grant acknowledge is asserted. If a bus request is still pending, another bus grant will be asserted within a few clocks of the negation of bus grant. Refer to Bus Arbitration Control section. Note that the processor does not perform any external bus cycles before it re-asserts bus grant. #### BUS ARBITRATION CONTROL The bus arbitration control unit in the 68000 is implemented with a finite state machine. A state diagram of this machine is shown in Figure 26. All asynchronous signals to the 68000 are synchronized before being used internally. This synchronization is accomplished in a maximum of one cycle of the system clock, assuming that the asynchronous input setup time (#47) has been met (see Figure 27). The input signal is sampled on the falling edge of the clock and is valid internally after the next falling edge. As shown in Figure 26, input signals labeled R and A are internally synchronized on the bus request and bus grant acknowledge pins respectively. The bus grant output is lebeled G and the internal three-state control signal T. If T is true, the address, data, function code line, and control buses are placed in a high-impedance state when $\overline{AS}$ is negated. All signals are shown in positive logic (active high) regardless of their true active voltage level. State changes (valid outputs) occur on the next rising edge after the internal signal is valid. A timing diagram of the bus arbitration sequence during a processor bus cycle is shown in Figure 28. The bus arbitration sequence while the bus is inactive (i.e., executing internal operations such as a multiply instruction) is shown in Figure 29. If a bus request is made at a time when the MPU has already begun a bus cycle but $\overline{AS}$ has not been asserted (bus state S0), $\overline{BG}$ will not be asserted on the next rising edge. Instead, $\overline{BG}$ will be delayed until the second rising edge following it's internal assertion. This sequence is shown in Figure 30. - R = Bus Request Internal - A = Bus Grant Acknowledge Internal - G = Bus Grant - T = Three-State Control to Bus Control Logic\*\* - X = Don't Care - State machine will not change state if bus is in S0. Refer to BUS ARBITRATION CONTROL for additional information. - \*\* The address bus will be placed in the high impedance state if T is asserted and AS is negated. Figure 26 State Diagram of 68000 Bus Arbitration Unit Figure 27 Timing Relationship of External Asynchronous Inputs to Internal Signals Figure 28 Bus Arbitration During Processor Bus Cycle Figure 29 Bus Arbitration with Bus Inactive Hitachi America, Ltd. • Hitachi Plaza • 2000 Sierra Point Pkwy. • Brisbane, CA 94005-1819 • (415) 589-8300 950 Figure 30 Bus Arbitration During Processor Bus Cycle Special Case #### BUS ERROR AND HALT OPERATION In a bus architecture that requires a handshake from an external device, the possibility exists that the handshake might not occur. Since different systems will require a different maximum response time, a bus error input is provided. External circuitry must be used to determine the duration between address strobe and data transfer acknowledge before issuing a bus error signal. When a bus error signal is received, the processor has two options initiate a bus error exception sequence or try running the bus cycle again. ### **Exception Sequence** When the bus error signal is asserted, the current bus cycle is terminated. If BERR is asserted before the falling edge of S2, AS will be negated in S7 in either a read or write cycle. As long as BERR remains asserted, the data and address buses will be in the high-impedance state. When BERR is negated, the processor will begin stacking for exception processing. Figure 31 is a timing diagram for the exception sequence. The sequence is composed of the following elements. - (1) Stacking the program counter and status register - (2) Stacking the error information - (3) Reading the bus error vector table entry - (4) Executing the bus error handler routine The stacking of the program counter and the status register is the same as if an interrupt had occurred. Several additional items are stacked when a bus error occurs. These items are used to determine the nature of the error and correct it, if possible. The bus error vector is vector number two located at address \$000008. The processor loads the new program counter from this location. A software bus error handler routine is then executed by the processor. Refer to EXCEPTION PROCESS-ING for additional information. #### Re-Running the Bus Cycle When, during a bus cycle, the processor receives a bus error signal and the halt pin is being driven by an external device, the processor enters the re-run sequence. Figure 32 is a timing diagram for re-running the bus cycle. The processor terminates the bus cycle, then puts the address and data output lines in the high-impedance state. The processor remains "halted," and will not run another bus cycle until the halt signal is removed by external logic. Then the processor will re-run the previous bus cycle using the same address, the same function codes, the same data (for a write operation), and the same controls. The bus error signal should be removed at least one clock cycle before the halt signal is removed. (NOTE) The processor will not re-run a read-modify-write cycle. This restriction is made to guarantee that the entire cycle runs correctly and that the write operation of a Test-and-Set operation is performed without ever releasing AS. If BERR and HALT are asserted during a read-modify-write bus cycle, a bus error operation results. Figure 31 Bus Error Timing Diagram Figure 32 Re-Run Bus Cycle Timing Information ### Halt Operation with No Bus Error The halt input signal to the 68000 perform a Halt/Run/ Single-Step function in a similar fashion to the HD6800 halt function. The halt and run modes are somewhat self explanatory in that when the halt signal is constantly active the processor "halts" (does nothing) and when the halt signal is constantly inactive the processor "runs" (does something). The single-step mode is derived from correctly timed transitions on the halt signal input. It forces the processor to execute a single bus cycle by entering the "run" mode until the processor starts a bus cycle then changing to the "halt" mode. Thus, the single-step mode allows the user to proceed through (and therefore debug) processor operations one bus cycle at a time. Figure 33 details the timing required for correct single-step operations and Figure 34 shows a simple circuit for providing the single-step function. Some care must be exercised to avoid harmful interactions between the bus error signal and the halt pin when using the single cycle mode as a debugging tool. This is also true of interactions between the halt and reset lines since these can reset the machine. When the processor completes a bus cycle after recognizing that the halt signal is active, most three-state signals are put in the high-impedance state. These include: - (1) Address lines - (2) Data lines This is required for correct performance of the re-run bus cycle operation. While the processor is honoring the halt request, bus arbitration performs as usual. That is, halting has no effect on bus arbitration. It is the bus arbitration function that removes the control signals from the bus. The halt function and the hardware trace capability allow the hardware debugger to trace single bus cycles or single instructions at a time. These processor capabilities, along with a software debugging package, give total debugging flexibility. 953 RUN MODE SINGLE RUN/SINGLE STEP STEP MODE (To Processor) OPEN COLLECTOR DEVICE SINGLE STEP Q STEP WAIT STEP σ $\eta$ AS (From Processor) RESET Figure 34 Simplified Single-Step Circuit #### **Double Bus Faults** When a bus error exception occurs, the processor will attempt to stack several words containing information about the state of the machine. If a bus error exception occurs during the stacking operation, there have been two bus errors in a row. This is commonly referred to as a double bus fault. When a double bus fault occurs, the processor will halt. Once a bus error exception has occurred, any bus error exception occurring before the execution of the next instruction constitutes a double bus fault. Note that a bus cycle which is re-run does not constitute a bus error exception, and does not contribute to a double bus fault. Note also that this means that as long as the external hardware requests it, the processor will continue to re-run the same bus cycle. The bus error pin also has an effect on processor operation after the processor receives an external reset input. The processor reads the vector table after a reset to determine the address to start program execution. If a bus error occurs while reading the vector table (or at any time before the first instruction is executed), the processor reacts as if a double bus fault has occurred and it halts. Only an external reset will start a halted processor. **@HITACHI** #### RESET OPERATION The reset signal is a bidirectional signal that allows either the processor or an external signal to reset the system. Figure 35 is a timing diagram for the reset operations. Both the halt and reset lines must be asserted to ensure total reset of the processor. When the reset and halt lines are driven by an external device, it is recognized as an entire system reset, including the processor. The processor responds by reading the reset vector table entry (vector unumber zero, address \$000000) and loads it into the supervisor stack pointer (SSP). Vector table entry number one at address \$000004 is read next and loaded into the program counter. The processor initializes the status register to an interrupt level of seven. No other registers are affected by the reset sequence. When a RESET instruction is executed, the processor drives the reset pin for 124 clock periods. In this case, the processor is trying to reset the rest of the system. Therefore, there is no effect on the internal state of the processor. All of the processor's internal registers and the status register are unaffected by the execution of a RESET instruction. All external devices connected to the reset line should be reset at the completion of the RESET instruction. Asserting the Reset and Halt pins for 10 clock cycles will cause a processor reset, except when $V_{\rm CC}$ is initially applied to the processor. In this case, an external reset must be applied for 100 milliseconds. Figure 35 Reset Operation Timing Diagram ## THE RELATIONSHIP OF DTACK, BERR, AND HALT In order to properly control termination of a bus cycle for a re-run or a bus error condition, DTACK, BERR, and HALT should be asserted and negated on the rising edge of the 68000 clock. This will assure that when two signals are asserted simultaneously, the required setup time (#47) for both of them will be met during the same bus state. This, or some equivalent precaution, should be designed external to the 68000. Parameter #48 is intended to ensure this operation in a totally asynchronous system, and may be ignored if the above conditions are met. The preferred bus cycle terminations may be summarized as follows (case numbers refer to Table 16): Normal Termination: DTACK occurs first (case 1). Halt Termination: HALT is asserted at the same time or before DTACK and BERR remains negated (cases 2 and 3). Bus Error Termination: BERR is asserted in lieu of, at the same time, or before DTACK (case 4); BERR is negated at the same time or after DTACK. Re-Run Termination: HALT and BERR are asserted in lieu of, at the same time, or before DTACK (cases 6 and 7); HALT must be held at least one cycle after BERR. Case 5 indicates BERR may precede HALT which allows fully asynchronous assertion. Table 16 details the resulting bus cycle termination under various combinations of control signal sequences. The negation of these same control signals under several conditions is shown in Table 17 (DTACK is assumed to be negated normally in all cases; for best results, both DTACK and BERR should be negated when address strobe is negated.) Exemple A: A system uses a watch-dog timer to terminate accesses to un-populated address space. The timer asserts DTACK and BERR simultaneously after time-out. (case 4) Example B: A system uses error detection on RAM contents. Designer may (a) delay DTACK until data verified, and return BERR and HALT simultaneously to re-run error cycle (case 6), or if valid, return DTACK; (b) delay DTACK until data verified and return BERR at same time as DTACK if data in error (case 4); (c) return DTACK prior to data verification, as described in previous section. If data invalid, BERR is asserted (case 1) in next cycle. Error-handling software must know how to recover error cycle. 955 Table 16 DTACK, BERR, HALT Assertion Results | Case No. | Control Signal | Asserted on Rising<br>Edge of State | | Result | | |----------|-----------------------|-------------------------------------|--------------|----------------------------------------------------------|--| | | | N | N + 2 | | | | 1 | DTACK<br>BERR<br>HALT | A<br>NA<br>NA | S<br>X<br>X | Normal cycle terminate and continue. | | | 2 | DTACK<br>BERR<br>HALT | A<br>NA<br>A | S<br>X<br>S | Normal cycle terminate and halt. Continue when HALT remo | | | 3 | DTACK<br>BERR<br>HALT | NA<br>NA<br>A | A<br>NA<br>S | | | | 4 | DTACK<br>BERR<br>HALT | X<br>A<br>NA | X<br>S<br>NA | Terminate and take bus error trap. | | | 5 | DTACK<br>BERR<br>HALT | NA<br>A<br>NA | X<br>S<br>A | Terminate and re-run. | | | 6 | DTACK<br>BERR<br>HALT | X<br>A<br>A | X<br>S<br>S | Terminate and re-run when HALT removed. | | | 7 | DTACK<br>BERR<br>HALT | NA<br>NA<br>A | X<br>A<br>S | Terminate and re-run when HALT removed. | | gend: N - The number of the current even bus state (e.g., S4, S6, etc.) A — Signal is asserted in this bus state NA — Signal is not asserted in this state X - Don't care S — Signal was asserted in previous state and remains asserted in this state Table 17 BERR and HALT Negation Results | Conditions of<br>Termination in | Control Signal | Negated on Rising<br>Edge of State | | | Results — Next Cycle | | |---------------------------------|----------------|------------------------------------|----------|------|---------------------------------------------------------------|--| | Table A | | N | N + 2 | | ] | | | Bus Error | BERR<br>HALT | • | or<br>or | • | Takes bus error trap. | | | Re-run | BERR<br>HALT | • | or | • | filegal sequence; usually traps to vector number 0. | | | Re-run | BERR<br>HALT | • | | • | Re-runs the bus cycle. | | | Normal | BERR<br>HALT | • | or | • | May lengthen next cycle. | | | Normal | BERR<br>HALT | • | or | none | If next cycle is started it will be terminated as a bus error | | ## ASYNCHRONOUS VERSUS SYNCHRONOUS OPERATION Asynchronous Operation To achieve clock frequency independence at a system level, the 68000 can be used in an asynchronous manner. This entails using only the bus handshake lines (AS, UDS, LDS, DTACK, BERR, HALT, and VPA) to control the data transfer. Using this method, AS signals the start of a bus cycle and the data strobes are used as a condition for valid data on a write cycle. The slave device (memory or peripheral) then responds by placing the requested data on the data bus for a read cycle or latching data on a write cycle and asserting the data transfer acknowledge signal (DTACK) to terminate the bus cycle. If no slave responds or the access is invalid, external control logic asserts the $\overline{BERR}$ , or $\overline{BERR}$ and $\overline{HALT}$ , signal to abort or re-run the bus cycle. The DTACK signal is allowed to be asserted before the data from a slave device is valid on a read cycle. The length of time that DTACK may precede data is given as parameter #31 and it must be met in any asynchronous system to insure that valid data is latched into the processor. Notice that there is no maximum time specified from the assertion of AS to the assertion of DTACK. This is because the MPU will insert wait cycles of one clock period each until DTACK is recognized. The BERR signal is allowed to be asserted after the DTACK signal is asserted. BERR must be asserted within the time given as parameter #48 after DTACK is asserted in any asynchronous **@HITACHI** system to insure proper operation. If this maximum delay time is violated, the processor may exhibit erratic behavior. #### **Synchronous Operation** To allow for those systems which use the system clock as a signal to generate DTACK and other asynchronous inputs, the asynchronous input setup time is given as parameter #47. If this setup is met on an input, such as DTACK, the processor is guaranteed to recognize that signal on the next falling edge of the system clock. However, the converse is not true—if the input signal does not meet the setup time it is not guaranteed not to be recognized. In addition, if DTACK is recognized on a falling edge, valid data will be latched into the processor (on a read cycle) on the next falling edge provided that the data meets the setup time given as parameter #27. Given this, parameter #31 may be ignored. Note that if DTACK is asserted, with the required setup time, before the falling edge of S4, no wait status will be incurred and the bus cycle will run at its maximum speed of four clock periods. In order to assure proper operation in a synchronous system when BERR is asserted after DTACK. BERR must meet the setup time parameter #27A prior to the falling edge of the clock one clock cycle after DTACK was recognized. This setup time is critical to proper operation, and the HD68000 may exhibit erratic behavior if it is violated. #### (NOTE) During an active bus cycle, VPA and BERR are sampled on every falling edge of the clock starting with SO. DTACK is sampled on every falling edge of the clock starting with S4 and data is latched on the falling edge of S6 during a read. The bus cycle will then be terminated in S7 except when BERR is asserted in the absence of DTACK, in which case it will terminate one clock cycle later in S9. #### ■ PROCESSING STATES 956 This section describes the actions the 68000 which are outside the normal processing associated with the execution of instructions. The functions of the bits in the supervisor portion of the status register are covered: the supervisor/user bit, the trace enable bit, and the processor interrupt priority mask. Finally, the sequence of memory references and actions taken by the processor on exception conditions is detailed. The 68000 is always in one of three processing states: normal, exception, or halted. The normal processing state is that associated with instruction execution: the memory references are to fetch instructions and operands, and to store results. A special case of the normal state is the stopped state which the processor enters when a STOP instruction is executed. In this state, no further memory references are made. The exception processing state is associated with interrupts, trap instructions, tracing and other exceptional conditions. The exception may be internally generated by an instruction or by an unusual condition arising during the execution of an instruction. Externally, exception processing can be forced by an interrupt, by a bus error, or by a reset. Exception processing is designed to provide an efficient context switch so that the processor may handle unusual conditions. The halted processing state is an indication of catastrophic hardware failure. For example, if during the exception processing of a bus error another bus error occurs, the processor assumes that the system is unusable and halts. Only an external reset can restart a halted processor. Note that a processor in the stopped state is not in the halted state, nor vice versa. ### PROCESSING STATES | NORMAL | INSTRUCTION EXECUTION (INCLUDING STOP) | |-----------|----------------------------------------| | EXCEPTION | INTERRUPTS<br>TRAPS<br>TRACING ETC. | | HALTED | HARDWARE HALT<br>DOUBLE BUS FAULT | #### PRIVILEGE STATES The processor operates in one of two states of privilege: the "user" state or the "supervisor" state. The privilege state determines which operations are legal, are used to choose between the supervisor stack pointer and the user stack pointer in instruction references, and may be used by an external memory management device to control and translate accesses. The privileges state is a mechanism for providing security in a computer system. Programs should access only their own code and data areas, and ought to be restricted from accessing information which they do not need and must not modify. The privilege mechanism provides security by allowing most programs to execute in user state. In this state, the accesses are controlled, and the effects on other parts of the system are limited. The operating system executes in the supervisor state, has access to all resources, and performs the overhead tasks for the user state programs. #### SUPERVISOR STATE The supervisor state is the higher state of privilege. For instruction execution, the supervisor state is determined by the S-bit of the status register; if the S-bit is asserted (high), the processor is in the supervisor state. All instructions can be executed in the supervisor state. The bus cycles generated by instructions executed in the supervisor state are classified as supervisor references. While the processor is in the supervisor privilege state, those instructions which use either the system stack pointer implicitly or address register seven explicitly access the supervisor stack pointer. All exception processing is done in the supervisor state, regardless of the setting of the S-bit. The bus cycles generated during exception processing are classified as supervisor references. All stacking operations during exception processing use the supervisor stack pointer. #### USER STATE The user state is the lower state of privilege. For instruction execution, the user state is determined by the S-bit of the status register; if the S-bit is negated (low), the processor is executing instructions in the user state. Most instructions execute the same in user state as in the supervisor state. However, some instructions which have important system effects are made privileged. User programs are not permitted to execute the STOP instruction, or the **@HITACHI** RESET instruction. To ensure that a user program cannot enter the supervisor state except in a controlled manner, the instructions which modify the whole status register are privileged. To aid in debugging programs which are to be used as operating systems, the move to user stack pointer (MOVE to USP) and move from user stack pointer (MOVE from USP) instructions are also privileged. The bus cycles generated by an instruction executed in user state are classified as user state references. This allows an external memory management device to translate the address and to control access to protected portions of the address space. While the processor is in the user privilege state, those instructions which use either the system stack pointer implicitly, or address register seven explicitly, access the use stack pointer. #### PRIVILEGE STATE CHANGES Once the processor is in the user state and executing instructions, only exception processing can change the privilege state. During exception processing, the current setting of the S-bit of the status register is saved and the S-bit is asserted, putting the processing in the supervisor state. Therefore, when instruction execution resumes at the address specified to process the exception, the processor is in the supervisor privilege state. #### USER/SUPERVISOR MODES # TRANSITION ONLY MAY OCCUR DURING EXCEPTION PROCESSING TRANSITION MAY BE MADE BY: RTE; MOVE, ANDI, EORI TO STATUS WORD ### REFERENCE CLASSIFICATION When the processor makes a reference, it classifies the kind of reference being made, using the encoding on the three function code output lines. This allows external translation of addresses, control of access, and differentiation of special processor states, such as interrupt acknowledge. Table 18 lists the classification of references. Table 18 Reference Classification | Funct | ion Code ( | Output | Reference Class | | |-----------------|-----------------|--------|-----------------------|--| | FC <sub>2</sub> | FC <sub>1</sub> | FC₀ | Treference Grass | | | 0 | 0 | 0 | (Unassigned) | | | 0 | 0 | 1 | User Data | | | 0 | 1 | 0 | User Program | | | 0 | 1 | 1 | (Unassigned) | | | 1 | 0 | 0 | (Unassigned) | | | 1 | 0 | 1 | Supervisor Data | | | 1 | 1 | 0 | Supervisor Program | | | 1 | 1 | 1 | Interrupt Acknowledge | | ### • EXCEPTION PROCESSING Before discussing the details of interrupts, traps, and tracing, a general description of exception processing is in order. The processing of an exception occurs in four steps, with variations for different exception causes. During the first step, a temporary copy of the status register is made, and the status register is set for exception processing. In the second step the exception vector is determined, and the third step is the saving of the current processor context. In the fourth step a new context is obtained, and the processor switches to instruction processing. #### **EXCEPTION VECTORS** Exception vectors are memory locations from which the processor fetches the address of a routine which will handle that exception. All exception vectors are two words in length (Figure 36), except for the reset vector, which is four words. All exception vectors lie in the supervisor data space, except for the reset vector which is in the supervisor program space. A vector number is an eight-bit number which, when multiplied by four, gives the address of an exception vector. Vector numbers are generated internally or externally depending on the cause of the exception. In the case of interrupts, during the interrupt acknowledge bus cycle, a peripheral provides an 8-bit vector number (Figure 37) to the processor on data bus lines Do through D<sub>7</sub>. The processor translates the vector number into a full 24-bit address, as shown in Figure 38. The memory layout for exception vectors is given in Table 19. As shown in Table 19, the memory layout is 512 words long (1024 bytes). It starts at address 0 and proceeds through address 1023. This provides 255 unique vectors; some of these are reserved for TRAPS and other system functions. Of the 255, there are 192 reserved for user interrupt vectors. However, there is no protection on the first 64 entries, so user interrupt vectors may overlap at the discretion of the systems designer. #### KINDS OF EXCEPTIONS Exceptions can be generated by either internal or external causes. The externally generated exceptions are the interrupts and the bus error and reset requests. The interrupts are requests from peripheral devices for processor action while the bus error and reset inputs are used for access control and processor restart. The internally generated exceptions come from instructions, or from address error or tracing. The trap (TRAP), trap on overflow (TRAPV), check register against bounds (CHK) and divide (DIV) instructions all can generate exceptions as part of their instruction execution. In addition, illegal instructions, word fetches from odd addresses and privilege violations cause exceptions. Tracing behaves like a very high priority, internally generated interrupt after each instruction execution. #### **EXCEPTION PROCESSING SEQUENCE** Exception processing occurs in four identifiable steps. In the first step, an internal copy is made of the status register. After the copy is made, the S-bit is asserted, putting the processor into the supervisor privilege state. Also, the T-bit is negated which will allow the exception handler to execute unhindered by tracing. For the reset and interrupt exceptions, the interrupt priority mask is also updated. In the second step, the vector number of the exception is determined. For interrupts, the vector number is obtained by a processor fetch, classified as an interrupt acknowledge. For all other exceptions, internal logic provides the vector number. This vector number is then used to generate the address of the exception vector. **(1)** HITACHI Figure 36 Exception Vector Format Where v7 is the MSB of the Vector Number v0 is the LSB of the Vector Number Figure 37 Peripheral Vector Number Format Figure 38 Address Translated From 8-Bit Vector Number Table 19 Exception Vector Assignment | Vector | 1 | Address | | A | | |-----------|------|---------|-------|--------------------------------|--| | Number(s) | Dec | Hex | Space | Assignment | | | 0 | 0 | 000 | SP | Reset: Initial SSP | | | _ | 4 | 004 | SP | Reset: Initial PC | | | 2 | 8 | 008 | SD | Bus Error | | | 3 | 12 | 00C | SD | Address Error | | | 4 | 16 | 010 | SD | Illegal Instruction | | | 5 | 20 | 014 | SD | Zero Divide | | | 6 | 24 | 018 | SD | CHK Instruction | | | 7 | 28 | 01C | SD | TRAPV Instruction | | | 8 | 32 | 020 | SD | Privilege Violation | | | 9 | 36 | 024 | SD | Trace | | | 10 | 40 | 028 | SD | Line 1010 Emulator | | | 11 | 44 | 02C | SD | Line 1111 Emulator | | | 12* | 48 | 030 | SD | (Unassigned, reserved) | | | 13* | 52 | 034 | SD | (Unassigned, reserved) | | | 14* | 56 | 038 | SD | (Unassigned, reserved) | | | 15 | 60 | 03C | SD | Uninitialized Interrupt Vector | | | 16 ~ 23* | 64 | 040 | SD | (Ulmanianad assessed) | | | 16 - 23 | 95 | 05F | 30 | (Unassigned, reserved) | | | 24 | 96 | 060 | SD | Spurious Interrupt | | | 25 | 100 | 064 | SD | Level 1 Interrupt Autovector | | | 26 | 104 | 068 | SD | Level 2 Interrupt Autovector | | | 27 | 108 | 06C | SD | Level 3 Interrupt Autovector | | | 28 | 112 | 070 | SD | Level 4 Interrupt Autovector | | | 29 | 116 | 074 | SD | Level 5 Interrupt Autovector | | | 30 | 120 | 078 | SD | Level 6 Interrupt Autovector | | | 31 | 124 | 07C | SD | Level 7 Interrupt Autovector | | | 32 ~ 47 | 128 | 080 | SD | TRAP Instruction Vectors | | | J2 - 47 | 191 | OBF | 30 | THAP Instruction vectors | | | 48 ~ 63* | 192 | 0C0 | SD | (Upperiamed sessional) | | | 40 ° 03 | 255 | OFF | 30 | (Unassigned, reserved) | | | 64 - 255 | 256 | 100 | | | | | 64 ~ 255 | 1023 | 3FF | SD | User Interrupt Vectors | | SP: Supervisor program, SD: Supervisor data Vector numbers 12, 13, 14, 16 through 23 and 48 through 63 are reserved for future enhancements by Hitachi. No user peripheral devices should be assigned these numbers. 959 The third step is to save the current processor status, except for the reset exception. The current program counter value and the saved copy of the status register are stacked using the supervisor stack pointer as shown in Figure 39. The program counter value stacked usually points to the next unexecuted instruction, however for bus error and address error, the value stacked for the program counter is unpredictable, and may be incremented from the address of the instruction which caused the error. Additional information defining the current context is stacked for the bus error and address error exceptions. The last step is the same for all exceptions. The new program counter value is fetched from the exception vector. The processor then resumes instruction execution. Then instruction at the address given in the exception vector is fetched, and normal instruction decoding and execution is started. Figure 39 Exception Stack Order (Group 1, 2) Figure 40 Exception Processing Sequence (Not Reset) **@ HITACHI** #### MULTIPLE EXCEPTIONS These paragraphs describe the processing which occurs when multiple exceptions arise simultaneously. Exceptions can be grouped according to their occurrence and priority. The Group 0 exceptions are reset, bus error, and address error. These exceptions cause the instruction currently being executed to be aborted, and the exeception processing to commence within two clock cycles. The Group 1 exceptions are trace and interrupt, as well as the privilege violations and illegal instructions. These exceptions allow the current instruction to execute to completion, but preempt the execution of the next instruction by forcing exception processing to occur (privilege violations and illegal instructions are detected when they are the next instruction to be executed). The Group 2 exceptions occur as part of the normal processing of instructions. The TRAP, TRAPV, CHK, and zero divide exceptions are in this group. For these exceptions, the normal execution of an instruction may lead to exception processing. Group 0 exceptions have highest priority, while Group 2 exceptions have lowest priority. Within Group 0, reset has highest priority, followed by address error and then bus error. Within Group 1, trace has priority over external interrupts, which in turn takes priority over illegal instruction and privilege violation. Since only one instruction can be executed at a time, there is no priority relation within Group 2. The priority relation between two exceptions determines which is taken, or taken first, if the conditions for both arise simultaneously. Therefore, if a bus error occurs during a TRAP instruction, the bus error takes precedence, and the TRAP instruction processing is aborted. In another example, if an interrupt request occurs during the execution of an instruction while the T-bit is asserted, the trace exception has priority, and is processed first. Before instruction processing resumes, however, the interrupt exception is also processed, and instruction processing commences finally in the interrupt handler routine. A summary of exception grouping and priority is given in Table 20. Table 20 Exception Grouping and Priority | Group | Exception | Processing | |-------|--------------------------------------------|-----------------------------------------------------------------| | 0 | Reset<br>Address Error<br>Bus Error | Exception processing begins within two clock cycles. | | 1 | Trace<br>Interrupt<br>Illegal<br>Privilege | Exception processing begins before the next instruction | | 2 | TRAP, TRAPV<br>CHK,<br>Zero Divide | Exception processing is started by normal instruction execution | # RECOGNITION TIMES OF EXCEPTIONS, HALT, AND BUS ARBITRATION END OF A CLOCK CYCLE RESET END OF A BUS CYCLE ADDRESS ERROR BUS ERROR HALT BUS ARBITRATION END OF AN INSTRUCTION CYCLE TRACE EXCEPTION INTERRUPT EXCEPTIONS ILLEGAL INSTRUCTION UNIMPLEMENTED INSTRUCTION PRIVILEGE VIOLATION WITHIN AN INSTRUCTION CYCLE TRAP, TRAPY CHK ZERO DIVIDE #### • EXCEPTION PROCESSING DETAILED DISCUSSION Exceptions have a number of sources, and each exception has processing which is peculiar to it. The following paragraphs detail the sources of exceptions, how each arises, and how each is processed. #### RESET The reset input provides the highest exception level. The processing of the reset signal is designed for system initiation, and recovery from catastrophic failure. Any processing in progress at the time of the reset is aborted and cannot be recovered. The processor is forced into the supervisor state, and the trace state is forced off. The processor interrupt priority mask is set at level seven. The vector number is internally generated to reference the reset exception vector at location 0 in the supervisor program space. Because no assumptions can be made about the validity of register contents, in particular the supervisor stack pointer, neither the program counter nor the status register is saved. The address contained in the first two words of the reset exception vector is fetched as the initial supervisor stack pointer, and the address in the last two words of the reset exception vector is fetched as the initial program counter. Finally, instruction execution is started at the address in the program counter. The power-up/restart code should be pointed to by the initial program counter. The RESET instruction does not cause loading of the reset vector, but does assert the reset line to reset external devices. This allows the software to reset the system to a known state and then continue processing with the next instruction. Figure 41 Reset Exception Processing ## INTERRUPTS Seven levels of interrupt priorities are provided. Devices may be chained externally within interrupt priority levels, allowing an unlimited number of peripheral devices to interrupt the processor. Interrupt priority levels are numbered from one to seven, with level seven being the highest priority. The status register contains a three-bit mask which indicates the current processor priority, and interrupts are inhibited for all priority levels less than or equal to the current processor priority. An interrupt request is made to the processor by encoding the interrupt request level on the interrupt request lines; a zero indicates no interrupt request. Interrupt requests arriving at the processor do not force immediate exception processing, but are made pending. Pending interrupts are detected between instruction executions. If the priority of the pending interrupt is lower than or equal to the current processor priority, execution continues with the next instruction and the interrupt exception processing is postponed. (The recognition of level seven is slightly different, as explained in a following paragraph.) If the priority of the pending interrupt is greater than the current processor priority, the exception processing sequence is started. First a copy of the status register is saved, and the privilege state is set to supervisor, tracing is suppressed, and the processor priority level is set to the level of the interrupt being acknowledged. The processor fetches the vector number from the interrupting device, classifying the reference as an interrupt acknowledge and displaying the level number of (C) HITACHI ## HD68000/HD68HC000 the interrupt being acknowledged on the address bus. If external logic requests an automatic vectoring, the processor internally generates a vector number which is determined by the interrupt level number. If external logic indicates a bus error, the interrupt is taken to be spurious, and the generated vector number references the spurious interrupt vector. The processor then proceeds with the usual exception processing, saving the program counter and status register on the supervisor stack. The saved value of the program counter is the address of the instruction which would have been executed had the interrupt not been present. The content of the interrupt vector whose vector number was previously obtained is fetched and loaded into the program counter, and normal instruction execution commences in the interrupt handling routine. A flow chart for the interrupt acknowledge sequence is given in Figure 42, a timing diagram is given in Figure 43, and the interrupt exception timing sequence is shown in Figure 44. Table 21 Internal Interrupt Level | Level | 12 | 11 | 10 | Interrupt | |-------|----|----|----|------------------------| | 7 | 1 | 1 | 1 | Non-Maskable Interrupt | | 6 | 1 | 1 | 0 | | | 5 | 1 | 0 | 1 | | | 4 | 1 | 0 | 0 | Maskable Interrupt | | 3 | 0 | 1 | 1 | | | 2 | 0 | 1 | 0 | | | 1 | 0 | 0 | 1 | <b></b> | | 0 | 0 | 0 | 0 | No Interrupt | (NOTE) The internal interrupt mask level (I2, I1, I0) are inverted to the logic level applied to the pins ( $\overline{IPL_2}$ , $\overline{IPL_1}$ , $\overline{IPL_0}$ ). 962 Although a vector number is one byte, both data strobes are asserted due to the microcode used for exception processing. The processor does not recognize anything on data lines 0, through D<sub>1</sub>, at this time. \* Although a vector number is one byte, both data strobes are asserted due to the microcode used for exception processing. The processor does not recognize anything on data lines D<sub>4</sub> through D<sub>15</sub> at this time. Figure 43 Interrupt Acknowledge Sequence Timing Diagram ## ( HITACHI Note: SSP refers to the value of the supervisor stack pointer before the interrupt occurs. Figure 44 Interrupt Exception Timing Sequence Priority level seven is a special case. Level seven interrupts cannot be inhibited by the interrupt priority mask, thus providing a "non-maskable interrupt" capability. An interrupt is generated each time the interrupt request level changes from some lower level to level seven. Note that a level seven interrupt may still be caused by the level comparison if the request level is a seven and the processor priority is set to a lower level by an instruction. #### UNINITIALIZED INTERRUPT An interrupting device asserts $\overline{VPA}$ or provides an interrupt vector during an interrupt acknowledge cycle to the 68000. If the vector register has not been initialized, the responding HD68000 Family peripheral will provide vector 15, the unitialized interrupt vector. This provides a uniform way to recover from a programming error. ## SPURIOUS INTERRUPT If during the interrupt acknowledge cycle no device responds by asserting DTACK or VPA, the bus error line should be asserted to terminate the vector acquisition. The processor separates the processing of this error from bus error by fetching the spurious interrupt vector instead of the bus error vector. The processor then proceeds with the usual exception processing. ## INSTRUCTION TRAPS Traps are exceptions caused by instructions. They arise either from processor recognition of abnormal conditions during instruction execution, or from use of instructions whose normal behavior is trapping. Some instructions are used specifically to generate traps. The TRAP instruction always forces an exception, and is useful for implementing system calls for user programs. The TRAPV and CHK instructions force an exception if the user program detects a runtime error, which may be an arithmetic overflow or a subscript out of bounds. The signed divide (DIVS) and unsigned divide (DIVU) instructions will force an exception if a division operation is attempted with a divisor of zero. #### ILLEGAL AND UNIMPLEMENTED INSTRUCTIONS Illegal instruction is the term used to refer to any of the word bit patterns which are not the bit pattern of the first word of a legal instruction. During instruction execution, if such an instruction is fetched, an illegal instruction exception occurs. Word patterns with bits 15 through 12 equaling 1010 or 1111 are distinguished as unimplemented instructions and separate exception vectors are given to these patterns to permit efficient emulation. This facility allows the operating system to detect program errors, or to emulate unimplemented instructions in software. #### ILLEGAL INSTRUCTION EXAMPLE #### PRIVILEGE VIOLATIONS In order to provide system security, various instructions are privileged. An attempt to execute one of the privileged instructions while in the user state will cause an exception. The privileged instruction are: STOP AND (word) Immediate to SR RESET EOR (word) Immediate to SR RTE OR (word) Immediate to SR MOVE to SR MOVE USP #### TRACING To aid in program development, the 68000 includes a facility to allow instruction by instruction tracing. In the trace state, after each instruction is executed an exceptions is forced, allowing a debugging program to monitor the execution of the program under test. The trace facility uses the T-bit in the supervisor portion of the status register. If the T-bit is negated (off), tracing is disabled, and instruction execution proceeds from instruction to instruction as normal. If the T-bit is asserted (on) at the beginning of the execution of an instruction, a trace exception will be generated after the execution of that instruction is completed. If the instruction is not executed either because an interrupt is taken, or the instruction is illegal or privileged, the trace exception does not occur. The trace exception also does not occur if the instruction is aborted by a reset, bus ## ( HITACHI 963 ### HD68000/HD68HC000 error, or address error exception. If the instruction is indeed executed and an interrupt is pending on completion, the trace exception is processed before the interrupt exception. If, during the execution of the instruction, an exception is forced by that instruction, the forced exception is processed before the trace exception. As an extreme illustration of the above rules, consider the arrival of an interrupt during the execution of a TRAP instruction while tracing is enabled. First the trap exception is processed, then the trace exception, and finally the interrupt exception. Instruction execution resumes in the interrupt handler routine. #### TRACE MODE - 1. If, upon completion of an instruction, T = 1, go to trace exception processing - Execute trace exception sequence - Execute trace service routine - At the end of the service routine, execute return from exception (RTE). #### BUS ERROR Bus error exceptions occur when the external logic requests that a bus error be processed by an exception. The current bus cycle which the processor is making is then aborted. Whether the processor was doing instruction or exception processing, that processing is terminated, and the processor immediately begins exception processing. Exception processing for bus error follows the usual sequence of steps. The status register is copied, the supervisor state is entered, and the trace state is turned off. The vector number is generated to refer to the bus error vector. Since the processor was not between instructions when the bus error exception request was made, the context of the processor is more detailed. To save more of this context, additional information is saved on the supervisor stack. The program counter and the copy of the status register are of course saved. The value saved for the program counter is advanced by some amount, one to five words beyond the address of the first word of the instruction which made the reference causing the bus error. If the bus error occurred during the fetch of the next instruction, the saved program counter has a value in the vicinity of the current instruction, even if the current instruction is a branch, a jump, or a return instruction. Besides the usual information, the processor saves its internal copy of the first word of the instruction being processed, and the address which was being accessed by the aborted bus cycle. Specific information about the access is also saved: whether it was a read or a write, whether the processor was processing an instruction or not, and the classification displayed on the function code outputs when the bus error occurred. The processor is processing an instruction if it is in the normal state or processing a Group 2 exception; the processor is not processing an instruction if it is processing a Group 0 or a Group 1 exception. Figure 45 illustrates how this information is organized on the supervisor stack. Although this information is not sufficient in general to effect full recovery from the bus error, it does allow software diagnosis. Finally, the processor commences instruction processing at the address contained in the vector. It is the responsibility of the error handler routine to clean up the stack and determine where to continue execution. If a bus error occurs during the exception processing for a bus error, address error, or reset, the processor is halted, and all processing cases. This simplifies the detection of catastrophic system failure, since the processor removes itself from the system rather than destroy all memory contents. Only the RES pin can restart a halted processor. #### ADDRESS ERROR Address error exceptions occur when the processor attempts to access a word or a long word operand or an instruction at an odd address. The effect is much like an internally generated bus error, so that the bus cycle is aborted, and the processor ceases whatever processing it is currently doing and begins exception processing. After exception processing commences, the sequence is the same as that for bus error including the information that is stacked, except that the vector number refers to the address error vector instead. Likewise, if an address error occurs during the exception processing for a bus error, address error, or reset, the processor is halted. As shown in Figure 46, an address error will execute a short bus cycle followed by exception processing. R/W (read/write): write = 0, read = 1. I/N (instruction/not): instruction = 0, not = 1 Figure 45 Exception Stack Order (Group 0) Figure 46 Address Error Timing #### ■ INTERFACE WITH HD6800 PERIPHERALS Hitachi's extensive line of HD6800 peripherals are directly compatible with the 68000. Some of these devices that are particularly useful are: HD6821 Peripheral Interface Adapter HD6840 Programmable Timer Module HD6843 Floppy Disk Controller HD6845S CRT Controller HD46508 Analog Data Acquisition Unit HD6850 Asynchronous Communication Interface Adapter HD6852 Synchronous Serial Data Adapter To interface the synchronous HD6800 peripherals with the asynchronous 68000, the processor modifies its bus cycle to meet the HD6800 cycle requirements whenever an HD6800 device address is detected. This is possible since both processors use memory mapped I/O. Figure 48 is a flow chart of the interference operation between the processor and HD6800 devices. #### • DATA TRANSFER OPERATION Three signals on the processor provide the HD6800 interface. They are enable (E), valid memory address (VMA), and valid peripheral address (VPA). Enable corresponds to the E or $\phi_2$ signal in existing HD6800 systems. The bus frequency is one tenth of the incoming 68000 clock frequency. The timing of E allows 1 MHz peripherals to be used with an 8 MHz 68000. Enable has a 60/40 duty cycle; that is, it is low for six input clocks and high for four input clocks. This duty cycle allows the processor to do successive VPA accesses on successive E pulses. HD6800 cycle timing is given in Figures 49 and 50. At state zero (S0) in the cycle, the address bus is in the high-impedance state. A function code is asserted on the function code output lines. One-half clock later, in state 1 the address bus is released from the high-impedance state. During state 2, the address strobe $(\overline{AS})$ is asserted to indicate that there is a valid address on the address bus. If the bus cycle is a read cycle, the upper and/or lower data strobes are also asserted in state 2. If the bus cycle is a write cycle, **OHITACHI** Figure 47 Connection of HD6800 Peripherals the read/write $(R/\overline{W})$ signal is switched to low (write) during state 2. One half clock later, in state 3, the write data is placed on the data bus, and in state 4 the data strobes are issued to indicate valid data on the data bus. The processor now inserts wait states until it recognizes the assertion of $\overline{VPA}$ . The $\overline{\text{VPA}}$ input signals the processor that the address on the bus is the address of an HD6800 device (or an area reserved for HD6800 devices) and that the bus should conform to the $\phi_2$ transfer characteristics of the HD6800 bus. Valid peripheral address is derived by decoding the address bus, conditioned by address strobe. Chip select for the HD6800 peripherals should be derived by decoding the address bus conditioned by $\overline{\text{VMA}}$ . After the recognition of VPA, the processor assures that the Enable (E) is low, by waiting if necessary, and subsequently asserts VMA. Valid memory address is then used as part of the chip select equation of the peripheral. This ensures that the HD6800 peripherals are selected and deselected at the correct time. The peripheral now runs in cycle during the high portion of the E signal. Figures 49 and 50 depict the best and worst case HD6800 cycle timing. This cycle length is dependent strictly upon when VPA is asserted in relationship to the E clock. dependent strictly upon when $\overline{VPA}$ is asserted in relationship to the E clock. If we assume that external circuitry asserts VPA as soon as possible after the assertion of AS, then VPA will be recognized as being asserted on the falling edge of S4. In this case, no "extra" wait cycles will be inserted prior to the recognition of VPA asserted and only the wait cycles inserted to synchronize with the E clock will determine the total length of the cycle. In any case, the synchronization delay will be some integral number of clock cycles within the following two extremes: - Best Case VPA is recognized as being asserted on the falling edge three clock cycles before E rises (or three clock cycles after E falls). - Worst Case -- VPA is recognized as being asserted on the falling edge two clock cycles before E rises(or four clock cycles after E falls). During a read cycle, the processor latches the peripheral data in state 6. For all cycles, the processor negates the address and data strobes one half clock cycle later in state 7, and the Enable signal goes low at this time. Another half clock later, the address bus is put in the high-impedance state. During a write cycle, the data bus is put in the high-impedance state 966 Figure 48 HD6800 Interface Flow Chart **@**HITACHI Figure 49 68000 to HD6800 Peripheral Timing—Best Case Figure 50 68000 to HD6800 Peripheral Timing-Worst Case Figure 51 68000 to HD6800 Peripheral Timing Diagram Figure 52 HD6800 Interface—Example 1 Hitachi America, Ltd. • Hitachi Plaza • 2000 Sierra Point Pkwy. • Brisbane, CA 94005-1819 • (415) 589-8300 968 **OHITACHI** ## HD68000/HD68HC000 and the read/write signal is switched high. The peripheral logic must remove VPA within one clock after address strobe is negated. Figure 51 shows the timing required by HD6800 peripherals, the timing specified for HD6800, and the corresponding timing for the 68000. Two example systems with HD6800 peripherals are shown in Figures 52 and 53. The system in Figure 52 reserves the upper eight megabytes of memory for HD6800 peripherals. The system in Figure 53 is more efficient with memory and easily expandable, but more complex. DTACK should not be asserted while VPA is asserted. Notice that the 68000 VMA is active low, contrasted with the active high HD6800 VMA. This allows the processor to put its buses in the high-impedance state on DMA requests without inadvertently selecting peripherals. #### • INTERRUPT OPERATION During an interrupt acknowledge cycle while the processor is fetching the vector, if $\overline{VPA}$ is asserted, the 68000 will assert $\overline{VMA}$ and complete a normal HD6800 read cycle as shown in Figure 54. The processor will then use an internally generated Although a vector number is one byte, both data strobes are asserted due to the microcode used for exception processing. The processor does not recognize anything on data lines D<sub>8</sub> through D<sub>15</sub> at this time. Figure 54 Autovector Operation Timing Diagram vector that is a function of the interrupt being serviced. This process is known as autovectoring. The seven autovectors are vector numbers 25 through 31 (decimal). This operates in the same fashion (but is not restricted to) HD6800 interrupt sequence. The basic difference is that there are six normal interrupt vectors and one NMI type vector. As with both the HD6800 and the 68000's normal vectored interrupt, the interrupt service routine can be located anywhere in the address space. This is due to the fact that while the vector numbers are fixed, the contents of the vector table entries are assigned by the user. Since $\overline{VMA}$ is asserted autovectoring, the HD6800 peripheral address decoding should prevent unintended accesses. 970 #### **= CONDITION CODES COMPUTATION** This provides a discussion of how the condition codes were developed, the meanings of each bit, how they are computed, and how they are represented in the instruction set details. #### CONDITION CODE REGISTER The condition code register portion of the status register contains five bits: N - Negative Z - Zero V - Overflow C - Carry X - Extend The first four bits are true condition code bits in that they reflect the condition of the result of a processor operation. The X-bit is an operand for multiprecision computations. The carry bit (C) and the multiprecision operand extend bit (X) are separate in the 68000 to simplify the programming model. ## ( HITACHI ## • CONDITION CODE REGISTER NOTATION In the instruction set details, the description of the effect on the condition codes is given in the following form: Condition Codes: Where N (negative) set if the most significant bit of the result is set. Cleared otherwise. Z (zero) set if the result equals zero. Cleared otherwise. V (overflow) set if there was an arithmetic overflow. This implies that the result is not representable in the operand size. Cleared otherwise. C (carry) set if a carry is generated out of the most significant bit of the operands for an addition. Also set if a borrow is generated in a subtraction. Cleared otherwise. transparent to data movement. When affect-X (extend) ed, it is set the same as the C-bit. The notational convention that appears in the representation of the condition code registers is: - set according to the result of the operation - not affected by the operation - 0 cleared - 1 set - undefined after the operation ## • CONDITION CODE COMPUTATION Most operations take a source operand and a destination operand, compute, and store the result in the destination location. Unary operations take a destination operand, compute, and store the result in the destination location. Table 22 details how each instruction sets the condition codes. **Table 22 Condition Code Computations** | Operations | × | N | Z | V | C | Special Definition | |------------------------------------------------------------------------------------|-----|---|---|---|----|-------------------------------------------------------------------------------------------------------------------------------------------------------| | ABCD | • | U | ? | U | ? | C = Decimal Carry<br>Z = Z · Rm · · RO | | ADD, ADDI,<br>ADDQ | • | • | • | ? | ? | V = Sm · Dm · Rm + Sm · Dm · Rm<br>C = Sm · Dm + Rm · Dm + Sm · Rm | | ADDX | • | • | ? | ? | 7 | V = Sm · Dm · Rm + Sm · Dm · Rm<br>C = Sm · Dm + Rm · Dm + Sm · Rm<br>Z = Z · Rm · · RO | | AND, ANDI,<br>EOR, EORI,<br>MOVEQ, MOVE,<br>OR, ORI,<br>CLR, EXT,<br>NOT, TAS, TST | - | • | • | 0 | 0 | | | CHK | - | • | C | J | U | | | SUB, SUBI<br>SUBQ | • | • | • | ? | ? | V = Sm · Dm · Rm + Sm · Dm · Rm<br>C = Sm · Dm + Rm · Dm + Sm · Rm | | SUBX | • | • | 7 | ? | ? | V = \$Sm \cdot Dm \cdot Rm + \Sm \cdot Dm \cdot Rm<br>C = \$m \cdot Dm + Rm \cdot Dm + \Sm \cdot Rm<br>Z = Z \cdot Rm \cdot \cdot RO | | CMP, CMPI,<br>CMPM | - | • | • | ? | ? | V = Sm · Dm · Rm + Sm · Dm · Rm<br>C = Sm · Dm + Rm · Dm + Sm · Rm | | DIVS, DIVU | - | • | • | 7 | 0 | V = Division Overflow | | MULS, MULU | | • | • | 0 | 0 | | | SBCD, NBCD | • | U | ? | U | ? | C = Decimal Borrow<br>Z = Z · Rm · · RO | | NEG<br>NEGX | : | : | , | ? | ? | V = Dm · Rm, C = Dm + Rm<br>V = Dm · Rm, C = Dm + Rm<br>Z = Z · Rm · · RO | | BTST, BCHG,<br>BSET, BCLR | - | - | ? | - | - | Z = Dn | | ASL | • | • | • | ? | ? | $V = Dm \cdot (\overline{D}_{m-1} + + \overline{D}_{m-r}) + \overline{Dm} \cdot (\overline{D}_{m-1} + + \overline{D}_{m-r}) C = \overline{D}_{m-r+1}$ | | ASL (r = 0) | T | • | • | 0 | 0 | | | LSL, ROXL | • | • | • | 0 | 7 | C = D <sub>m-r+1</sub> | | LSR (r = 0) | - | • | • | 0 | 0 | | | ROXL (r = 0) | - | • | • | 0 | 7 | C = X | | ROL | - | • | • | 0 | ? | C = D <sub>m-r+1</sub> | | ROL (r = 0) | - | • | • | 0 | 0_ | | | ASR, LSR, ROXR | • | • | • | 0 | 7 | C = D <sub>r-1</sub> | | ASR, LSR (r = 0) | - | • | • | 0 | 0 | | | ROXR (r = 0) | T - | • | • | 0 | 7 | C = X | | ROR | _ | • | • | 0 | ? | C = D <sub>r-1</sub> | | ROR (r = 0) | _ | • | • | 0 | 0 | I | X - C Dm - Destination operand most significant bit Rm - Result bit most significant bit n - bit number #### • CONDITIONAL TESTS Table 23 lists the condition names, encodings, and tests for the conditional branch and set instructions. The test associated with each condition is a logical formula based on the current state of the condition codes. If this formula evaluates to 1, the condition succeeds, or is true. If the formula evaluates to 0, the condition is unsuccessful, or false. For example, the T condition always succeeds, while the EQ condition succeeds only if the Z bit is currently set in the condition codes. Table 23 Conditional Tests | Mnemonic | Condition | Encoding | Test | |----------|------------------|----------|-------------------------------------------------------------------------------------| | T | true | 0000 | 1 | | F | false | 0001 | 0 | | HI | high | 0010 | ō· Z | | LS | low or same | 0011 | C+Z | | CC | carry clear | 0100 | Č. | | cs | carry set | 0101 | С | | NE | not equal | 0110 | Z | | EQ | equal | 0111 | Z | | VC | overflow clear | 1000 | ⊽ | | VS | overflow set | 1001 | V | | PL | plus | 1010 | Ñ | | MI | minus | 1011 | N | | GE | greater or equal | 1100 | $N \cdot V + \overline{N} \cdot \overline{V}$ | | LT | less than | 1101 | N • ∇ + N • ∨ | | GT | greater than | 1110 | $N \cdot V \cdot \overline{Z} + \overline{N} \cdot \overline{V} \cdot \overline{Z}$ | | LE | less or equal | 1111 | Z+N • 🗸 + N • V | #### ■ INSTRUCTION SET Control 972 The following paragraphs provide information about the addressing categories and instruction set of the 68000. ### • ADDRESSING CATEGORIES Effective address modes may be categorized by the ways in which they may used. The following classifications will be used in the instruction definitions. Data If an effective address mode may be used to refer to data operands, it is considered a data address- ing effective address mode. Memory If an effective address mode may be used to refer to memory operands, it is considered a memory addressing effective address mode. Alterable If an effective address mode may be used to refer to alterable (writeable) operands, it is considered an alterable addressing effective address mode. If an effective address mode may be used to refer to memory operands without an associated size, it is considered a control addressing effective address mode. Table 24 shows the various categories to which each of the effective address modes belong. Table 25 is the instruction set summary. The status register addressing mode is not permitted unless it is explicitly mentioned as a legal addressing mode. These categories may be combined so that additional, more restrictive, classifications may be defined. For example, the instruction descriptions use such classifications as alterable memory or data alterable. The former refers to those addressing modes which are both alterable and memory addresses, and the latter refers to addressing modes which are both data and alterable. #### INSTRUCTION PRE-FETCH The 68000 uses a 2-word tightly-coupled instruction prefetch mechanism to enhance performance. This mechanism is described in terms of the microcode operations involved. If the execution of an instruction is defined to begin when the microroutine for that instruction is entered, some features of the prefetch mechanism can be described. - When execution of an instruction begins, the operation word and the word following have already been fetched. The operation word is in the instruction decoder. - In the case of multi-word instructions, as each additional word of the instruction is used internally, a fetch is made to the instruction stream to replace it. - The last fetch from the instruction stream is made when the operation word is discarded and decoding is started on the next instruction. - 4) If the instruction is a single-word instruction causing a branch, the second word is not used. But because this word is fetched by the preceding instruction, it is impossible to avoid this superfluous fetch. In the case of an interrupt or trace exception, both words are not used. - The program counter usually points to the last word fetched from the instruction stream. ## **@HITACHI** Table 24 Effective Addressing Mode Categories | Effective | | | Data | Addressing Categories | | | | |------------------|------|-----------------|------|-----------------------|---------|-----------|--| | Address<br>Modes | Mode | Register | | Memory | Control | Alterable | | | Dn | 000 | register number | × | _ | _ | × | | | An | 001 | register number | - | _ | _ | × | | | An@ | 010 | register number | × | × | × | × | | | An@+ | 011 | register number | X | × | _ | X | | | An@ - | 100 | register number | × | X | _ | X | | | An@(d) | 101 | register number | X | × | X | X | | | An@(d, ix) | 110 | register number | × | × | × | X | | | xxx.W | 111 | 000 | × | × | X | X | | | xxx.L | 111 | 001 | X | X | × | X | | | PC@(d) | 111 | 010 | X | × | × | - | | | PC@(d, ix) | 111 | 011 | X | × | × | - | | | #xxx | 111 | 100 | X | × | | _ | | The following example illustrates many of the features of instruction prefetch. The contents of memory are assumed to be as illustrated in Figure 55. | | ORG | 0 | DEFINE RESTART VECTOR | |----------|--------------------------------|------------------------------|-------------------------------------------------------------------------------------------| | | DC.L<br>DC.L | INISSP<br>RESTART | INITIAL SYSTEM STACK POINTER<br>RESTART SYSTEM ENTRY POINT | | | ORG<br>DC.L | INTVECTOR<br>INTHANDLER | DEFINE AN INTERRUPT VECTOR<br>HANDLER ADDRESS FOR THIS VECTOR | | | ORG | | SYSTEM RESTART CODE | | RESTART: | NOP<br>BRA.S<br>ADD.W | LABEL<br>D0, D1 | NO OPERATION EXAMPLE<br>SHORT BRANCH<br>ADD REGISTER TO REGISTER | | LABEL: | SUB.W<br>CMP.W<br>SGE.B | DISP(A0), A1<br>D2, D3<br>D7 | SUBTRACT REGISTER INDIRECT WITH OFFSET<br>COMPARE REGISTER TO REGISTER<br>Scc TO REGISTER | | INTHANDL | ER:<br>MOVE.W<br>NOP<br>SWAP.W | LONGADR1, LONGADR2 | MOVE WORD FROM AND TO LONG ADDRESS<br>NO OPERATION<br>REGISTER SWAP | Figure 55 Instruction Prefetch Example, Memory Contents The sequence we shall illustrate consists of the power-up reset, the execution of NOP, BRA, SUB, the taking of an interrupt, and the execution of the MOVE.W xxx. L to yyy. L. The order of operations described within each microroutine is not exact, but is intended for illustrative purpose only. | Microroutine | Operation | Location | Operand | |--------------|------------------------|----------------------|---------------| | Reset | Read | 0 | SSP High | | | Read | 2 | SSP Low | | • | Read | 4 | PC High | | | Read | 6 | PC Low | | | Read | (PC) | NOP | | | Read | + (PC) | BRA | | | <br><br>begin NOP> | | | | NOP | Read | +(PC) | ADD | | | <br><br>begin BRA> | | | | BRA | PC=PC+d | | | | | Read | (PC) | SUB | | | Read | +(PC) | DISP | | | <begin sub=""></begin> | | | | SUB | Read | +(PC) | CMP | | | Read | DISP(A0) | <src></src> | | | Read | + (PC) | \$GE | | | <begin cmp=""></begin> | <take int=""></take> | | | INTERRUPT | Write | - (SSP) | PC Low | | | Read | <int ack=""></int> | Vector # | | | Write | - (SSP) | ŚR | | | Write | - (SSP) | PC High | | | Read | (VR) | PC High | | | Read | +(VR) | PC Low | | | Read | (PC) | MOVE | | | Read | + (PC) | xxx High | | | <br>begin MOVE> | | | | MOVE | Read | + (PC) | xxx Low | | | Read | + (PC) | yyy High | | | Read | XXX | <src></src> | | | Read | + (PC) | YYY LOW | | | Write | yyy . | <dest></dest> | | | Read | + (PC) | NOP | | | Read | + (PC) | SWAP | | | <begin nop=""></begin> | | | Figure 56 Instruction Prefetch Example #### • DATA PREFETCH Normally the 68000 prefetches only instructions and not data. However, when the MOVEM instruction is used to move data from memory to registers, the data stream is prefetched in | | | | MOVE TWO | |---|----------|----------|----------------| | | | | LONGWORDS | | | MOVEM. L | A, D0/D1 | INTO REGISTERS | | A | DC.W | 1 | WORD 1 | | 8 | DC.W | 2 | WORD 2 | | С | DC.W | 3 | WORD 3 | | D | DC.W | 4 | WORD 4 | | E | DC.W | 5 | WORD 5 | | F | DC.W | 6 | WORD 6 | Figure 57 MOVEM Example, Memory Contents order to optimize performance. As a result, the processor reads one extra word beyond the higher end of the source area. For example, the instruction sequence in Figure 57 will operate as shown in Figure 58. | Assume Effect | ive Address Ev | aluation is A | Already Done | |---------------|----------------|---------------|-------------------------------| | Microroutine | Operation | Location | Other Operations | | MOVEM | Read | A | | | | | | Prepare to Fill D0 | | | Read | В | A → DOH | | | Read | С | B → DOL | | | | | Prepare to Fill D1 | | | Read | Ð | C → D1H | | | Read | Ē | D → D1L | | | | | Detect Register List Complete | Figure 58 MOVEM Example, Operation Sequence Table 25 Instruction Set | Inemonic | Size | Addr | 10 | lrs. | Γ | Aπ | ŧ | An, | :д. | ٠, . | | An- | d, | Ani | d(A | n Xir | Abs | w/ | An: | | dip | c. | d(PC | XII | s = 'm<br>d - Sf | med <br>NCC | , | Opcode | 3rt Pa | ttern | | | 566 | 6.1h | | ngniy<br>Jodes | |-----------------------------|----------------|-------------------------------------------|----------------------------|-----------|-----|-------|---------------------------------------------------------------------------------------|---------------------|-------------|-----------------|---------------------------|----------------|----------|----------------|-----|------------------|------------------|----------------|-------------|-------------------|--------------|----------------|------|------------------|------------------|------------------|-------|--------------------------|------------------|------------|------------------------------|--------------|--------------------------|--------------|-------------|----------------| | Deration | Size | Mode | * | - | , | - | # | _ | * | | ø | - | " | | 2 | | * | | - 1 | - | " | - | | | £ | | 5437 | :09 | 2.6 | 5.4 | 4. 6 | | | | 1 | N 2 4 1 | | CD<br>d Digits | В | s Dn d<br>s ; An' d | 12 | 6 | | | П | _ | - | | <del>! - !</del><br>; 2 ; | | · · · | | | | | | | | | | , | ĺ | 1 | | : 100 | RRR<br>RRB | 1 00 | 0.0 | | 2.0 | | 1 - | • | • | | D<br>s<br>any | 9/9 | odk d<br>ddn s<br>s4n d | 121 | • | | | 2 | 12<br>8<br>20<br>14 | 2 2 | 8 20 | 2 2 2 2 | 14<br>10<br>22 | : | 16<br>12<br>24 | *** | 18<br>14<br>25 | *** | 16<br>12<br>24 | 6 6 6 | 20<br>16<br>28 | 4 | 12 | - 1 | 1 | - 1 | 8 | 1101 | DDD<br>DDD | SS | EE I | EEEE<br>EEEE | Да.<br>ф. | 0n →e<br>'s →0n<br>On →e | | | | | DA | | d An | | | 17 | | 2 7 | 14 | 2 | 14 | 2 | 16 | 1 | 16<br>18 | 4 | 18<br>20 | 4 | 16<br>18 | 6 | 22<br>30<br>27 | 4 | 18<br>16<br>18 | 4 | :8 1 | 4 | 14 <br>10<br>14 | 1103 | AAAA<br>AAA | ) [ | | | En - | s ⊶Dn | | | | | Address<br>)I<br>:mmed | i. | sima. d<br>sima d | | 8<br>16 | | EDA | 6 | 16<br>28 | 6 | 16<br>28 | 6 | 18<br>30 | 8 | 20<br>32 | 6 | 22 | 8 | 20<br>32 | 10 | 24°<br>36 | | | - | | 1 | | 0101 | 900 | 1 | | EEEE | d - | <b>#</b> → 6 | | ** | *** | | OQ<br> Quick<br>OX | 8 W | stmπ3 d<br>stmm3 d<br>seBs se<br>er (Aps) | 121 | 8 | 2 | 8 | 2<br>2<br>3<br>3<br>3 | i. | Ź | Ä<br>Jane | 1 | | 1 | 4 | | . A | 1 | :4<br>: 41 | 6 | | :<br> | 1 | . | 1 | į. | - | 1101 | RRR | 1.55 | | Orre<br>Lere | 6- | s + x | -d | • | *** | | Multi- | L | s=Bn d<br>s: (An) d | 2 | 8 | | | | | | | 2 | 18<br>30 | | | | | | - | | | | | | | | | 110 | RRR | 1 10 | 900 | Orrr<br>1rrr | | are si | | | | | )<br>ic And | 8 * | k0n d<br>d0n s<br>s0n d | 2 | 4 | | İ | 12 | ŝ<br>N | 1 2 | | 12 | 1 | 4 | 12 | 4 | 4 | 4 | 2 | 6 | 36 | 4 | | 4 | . 4 | 4 | ٠, | 1100 | DOD: | 1 8 | EE. | EFEE. | , ân<br>di | and -S | r | | • | | II<br>Immed | 2/4 | d Dn s<br>Silver and a<br>Silver | 2 | . 16 | 1 | | 12 | 16<br>28 | | 16 | - | 18<br>18 | | 20<br>30 | 5 | 20<br>22<br>24 | 4 | 20<br>32 | 10 | × | İ | .8 | 1 | x | 4 | 20 | 688 | 904: | 55 | SEE | EEEE | 4< | and > | 298<br>#48 | - | • • 0 | | ASR<br>imetic | 8 * | count Do c | 2 2 | 6 - 2 | n | • | | | , , | | , - , | | | _ | | | , - , | | | | | | | | | | 1 | ) , , , ,<br>) , , , , , | 1 3 | -00<br>5.0 | 61749<br>01800<br>6004 | 1 - | 15 | | | • • • | | nory | | count:#1-80 | 2 | 8 - 2 | | Ĺ., | 17. | | 2. | | 2. | 14 | 4 | 15 | 4- | 10 | 4 • <br> # • ‡ | . 16 | 6. | 20 | i i | į | i | | | | 11111 | ) QQQ<br>) 660<br> FFF | 6 j. 11 | LEE | eddi:<br>Eree<br><b>Reee</b> | [<br> -a | w()# | of d | ì<br>2. ( • | - * - | | iG<br>and<br>nge | 1 | 11 5 D | A 1 | <8<br><12 | 1 | | | 16 | 2 | 12<br>16 | 4 | iā | 6 | 16<br>20 | ě | 18<br>22 | 4 | 20 | 8 | 24 | | | | | | • | 908 | 108 | | EE | eeee<br>Eeee | -(1 | ★() #<br>() # o | ot d → | | | | . <b>R</b><br>I and | 6 | bit # On : | | | ì | | 2 | 1<br>; 16 | 1 2 | i ii | 1 | 1 | 1 4<br>6 | 1 15<br>2 27 | 4 | 15 | 6 | ;;<br>;; | 8 | 74 | | | | | | ' | 000 | ) | 11<br>0 , 10 | EE. | ERRE<br>ERRE<br>ERRE | į., | or, # | of dist | | • | | ar<br>ET | | bit#Dn i<br>bit#imm i<br>bet#simm i | 1 4 | < 10 | | 1 3 | 2 | 12 | | 12 | 2 | 14 | 14 | 16 | 1 | 18<br>22 | 1 • 1 | - 16 | 6 | 20 | 1 1 | | 1 | | l | ı | 996 | 0 100<br><b>0</b> ete | 9 19 | EE | EEEE<br>EEEE | 1~( | 缺) #( | of d→Z | . - | - * | | and | ı. | M # 40 | | V. | | | 1. | 16 | | 16 | 1 | 18 | • | 20 | • | | 1 | 20 | * | 24 | | | | 547 | | | 880 | 0 100<br>6 rer<br>0 100 | | EE | eeee<br>Feee | 1 | | B of d | . | | | est<br>Test | В | bit # Dn<br>bit # imm<br>bit # Dn | | 6 | | | 2 | 12 | . 2 | 12 | 2 | 10<br>,4 | 6 | 12 | 6 | 14<br>18 | 6 | 16 | 8 | 16<br>29 | 6 | 1?<br>16 | 6 | 1 <b>4</b><br>18 | 4 | 10 | 000 | 0 | 0 0 | OHE<br>OHE | EEEE<br>EEEE | 1 | b-! · = | 51 d 1. | | • | | t | , <b>M</b> /- | ibit≖lmm<br>(1.25.197.545 | 1 4<br>300 | 10 | ) | | | < | 1 | <b>K</b> • | 4, | < | 1 | < | | < 50 | 1.1 | <48 | | <\$ | | < 48 | | < <b>3</b> | | < 44 | 430 | e add | 1 7 | De i | **** | | h < 0.<br>>(bou | | 1 | <b>*</b> ¥ | | ck Reg<br>Against<br>nds | | (byan | ) | 10 | 1. | 1700 | . " | 14 | 1 | 14 | 1 | 16 | | 16 | Γ | 20 | | 18 | | 22 | | 18 | | 20 | | 14 | | 5 60 | | 44. | FFEE | The | e trap | | 1 | ē. | | r Operand | B W | | 1 ?<br>1 2<br>1 2 | 6 | 7 | | 2<br> 2<br> 2<br> 3<br> 3<br> 3<br> 3<br> 3<br> 3<br> 3<br> 3<br> 3<br> 3 | | 12 | * | 2 | 10 | | 12 | 1 | 2 2 | 4 | 12 | 1:1 | 英龙 | : | į. | * | 14<br>28 | : | # 14 | 1 | 900 | | | **** | 0 | -: | | . - | ** | | ipare<br>.ry<br>PA | | c An | 2 | • | 1, | | | " | 2 | .0 | 1. | ١, | + | 18 | 1 | ١., | 1 | 18 | 1, | 18 | 1 1 | 14 | | 16 | f | 17 | 191 | | | i e e | | 1 | | | 1. | * * | | npare<br>ress | -<br>- | d An | 5 2<br>6 2 | 6 | 12 | 6 | 2 | i<br>Red | 2 | 12 | | 16<br>15 (1) | | 18 | 16 | 20 | | 16. | ) 6<br>1.84 | 22<br>2 <b>20</b> | 1 1 | 38 | 1 | 20 | i | .4 | 10.0 | : AAA<br>B:536 | | | EEEE | 10- | * | | 1- | ** | | spare Imm<br>PM<br>spare | , S[□<br> B # | | | ú | 1 | CHIPA | 16 | X | 14 | 1 26<br>∷<br>20 | 16 | 1 27 | 1.8 | 24 | 18: | F 26 | 18 | 24 | 1 181 | 28 | ! ! | | 1 1 | | 1 1 | . , | 3. | RRE | | 500 | | | | | | • • | | nory<br>S | i | ! | k Z | 51 | | | 2 | <b>V</b> | <b>62</b> 2 | <= | 2 2 | < 16 | | × | 4 | < 10 | | < 100 | 6 | < 170 | * | < 166 | ٠ | < 168 | 1 | < <del>162</del> | 100 | o dde | 1 | lee | *** | On | 32/\$16<br>(rq) | - | - | •• | | de Signec<br><b>U</b><br>de | * | d Dr | s [ 2 | | 40 | ! | i z | '. · | 44 | ' : | и | • | 6 4 | . :4 | 8 4 | 1 :5<br>1 | 6 4 ' | - 14 | e' e ' | 5. | ( a ) | .49 | 4 | . 30 | | 1.1 | an- | 0 144 | e . | •• | | 3. | 30 K.F | | | * * | | agned<br>Iusive OR | 4 | <b>12</b> " | 7 7 | 1 | 1 | 1 | 7 | 1 | 1 | 12<br>20 | 2 | 18<br>22 | 1 | 18.<br>24 | 1 | 18<br>26 | 1 | 16<br>24 | 6 | 26<br>26 | | . 75 1 | | | | ٧. | 194 | Eeri | 1 5 | SEE | EEEE | 4 | Di- | ١. | - | ** | | pca:<br>RI<br>ousive DR | 8 4 | | d 4<br>d 6 | 8<br>16 | ľ | * | 4 | 1 | . 4 | 16 | ; b | | ,<br>, | 1.7 | 8 | | 16 | | 8 10 | | 1 | | | | 4 | 3. | 966 | 0 0 | . 0 - 8 | SF. F | 1111 | c | = . | | | • • | | nediate<br>B<br>:hange | 3 | 1279 | 1 | * | | | | 1 | 1 | | 1 | | | 133 | | 2 | | | | | 1 | 77 | 1 | 45° | 11 | Ji agg<br>Si | Eric | 4 AAI | 1110 | 100 | IAAA | 11 | 6 · | | 1 | | | psters<br>r<br>n Extend | * | 1 1 1 1 1 | <b>₽</b> ?<br>d ?<br>d j 2 | 4 | 1 | İ | | 1 | 1 | 1 | | 1 | I<br>L | ∓ °<br>Luc | 1 | l<br>Loc | ļ. | !<br> | 4 | le.as | )<br>deserve | 1104 | | L 2000 - | ا<br>الل | مراد الا | 010 | 0 :00 | 10 1<br>10 1 | 100 | 900t | ribr<br>Fybt | (5 t | e 5<br>at 16 | 31 . | •• | | d Effect<br>Address | * | • | 1 | | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | T | ľ | 1 | 1. | 1 | | | 12 | | | 1 | | | 18.0 | 1 | AA. | | 100 | 4000 | | | 92 | - | | | ik and<br>skand | | disp Imm | 5 | | ľ | · [ : | 5 | ! | i | | 1 | : | | | | | | į | | | 1 | | | | | | 0.10 | 10 1: | | 110 | DAA | 20<br>20 | - 30 | | | | | e Refer | te Car | ndition Code (3) | I | <br> | . 1 | | <b>i</b> | | | | | | 1_ | -i | 1 | Direct | | | de E | Bit P | | rn Ki<br>estoa | | • | | | | | • | | | | | | | | | | E BANGH | | | | | | | | . 700 | ess P | rior<br>Ter | | | | | Destin<br>Destin | at on | IA M. | ade | | - | | 8.1 | | | | 1154 | No. of the | | | | | | | | | (to be continued) # **OHITACHI** ## HD68000/HD68HC000 | Mnemonic<br>Operation | Size | Addr.<br>Mode | L | 0 | n | 1 | An | | <u> </u> | An) | + | \n) + | | - (An | 1 | d(Ar | 1) | d(A | n, Xi) | 1 | lbs. W | 1 | Abs. L | | d(PC) | | d(PC | Xi) | | mmed<br>SR/CC | 111 | 0pc | | it Patte | m | | | Boole. | an | Co | |----------------------------------------------------------------------------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|---------|----------------------------------|-----|--------------------------------------|----------------------|----------------------------|------------------------|---------|----------------------------------|---------|----------------|----------------|------|-------------------------------------------------------|-------------|----------------------------------|----------------|----------------------|------------|----------------------------------------------------------------------------------------|------------|--------------|-------|-------|----------|------------|-------------------|---------------------------------|--------------------------------------|----------------|------------------------------|-------------------------------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|----------|-----| | | | Mode | 1 | • [ | ~ | 1 | Ţ | - | # | - | # | - | * | Ţ | | 4 | ~ | * | ~ | # | Γ- | * | - | | Ţ | - [ | * | ~ | * | - | 543 | 2 10 | 98 | 765 | 4 32 | 10 | | | | X i | | L, LSA<br>gical Shift<br>emory<br>IVE | B W | count Dn d<br>count #1-8 d<br>count Dn d<br>count #1-8 d<br>count #1-8 d | | 2 6 | 5 - 2<br>5 - 2<br>5 - 2<br>5 - 2 | - | | EA: | 2. | | 2. | 8 | | | 4 4 | | 16 | 4. | :8 | 4. | 16 | | 2 | | | | | | | | | 0 rr<br>0 QQ<br>0 rr<br>0 QQ<br>0 00 | 191 | 101 | 0 1D1<br>0 1D1<br>0 1D1<br>0 1D1<br>E EE1 | DD <br>DD | 0- | Left<br>Right | ⊃: | *** | | e Data | l<br>I | s-An s<br>s-(An) d<br>s-(An) + d<br>s-(An) d<br>s-d(An) d<br>s-d(An) d | 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 | 2 | 8<br>8<br>10<br>12<br>14 | | MOV<br>MOV<br>MOV | EM<br>EA<br>EA<br>EA | 222244 | 12<br>12<br>12<br>16 8 | 2222 | 1 .6 | 2 2 4 4 | 3 | 24 6 8 | 6 | 12 15 16 16 18 14 14 14 14 14 14 14 14 14 14 14 14 14 | 4 4 4 6 6 | 18<br>20<br>27<br>24 | 4 6 6 | 18<br>18<br>20<br>20 | 8 | 21 | | | | | | | (2) | 2.734 | | | | | | | | | | | | 1 | s Abs W d s Abs L d s Abs L d s d(PC) d s d(PCX) d s imm d s Dn d s An d | | | 12 16 12 14 6 4 4 2 | | MOV<br>MOV<br>MOV<br>MOV<br>MOV | EA: | 4 4 4 7 2 2 | 16<br>18<br>18 | 44422 | 16<br>20<br>16<br>18<br>12 | 6 | 1 | 2 4 | 5 | 20<br>27<br>20<br>27<br>16 | 6 6 6 4 4 4 | 22<br>26<br>22<br>24<br>18<br>18 | 6666444 | 20 | 8 | 26<br>26<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20 | | | | | 1.1 | 4:3<br>1:4 | ge) | a Sign | | er<br>Stage | <br> -15.<br> -16. | | | d Vigor | | | | | | | SAC DE SA | 4 4 4 | | 2 14 16 18 16 70 16 | | MOVI<br>MOVI<br>MOVI<br>MOVI<br>MOVI | A CA | ?<br>2<br>4<br>4<br>6<br>4 | 27<br>24<br>26<br>24 | 24.4 | 22<br>24<br>26<br>24 | 2444 | 2 2 2 2 | 2 6 | | 26<br>28<br>30<br>28 | 4 6 6 6 6 5 | 28 30 32 30 | 4 4 6 6 8 8 6 | 24 | 6 6 8 8 10 | 33 | | | | | | | | | | ेश | riging ( | Jag. | | i, in | 34.7 | | | | E<br>to Con-<br>n Codes | | d COS s | 12 | ė. | 18<br>12 | | MOVI<br>WOVI | 4 | 2 | 16 | 2 | 16 | 2 | • | | | 20 | 5 9.4 | 22 | 1 | 20 | 6 | 24 | 1 | | 1 | 1 | 22 | 4 | 16 | 6/16 <sup>2</sup> | 0 01 | | fie. | er. | ्री | 001 | r<br>Na | | • | | E<br>e to from<br>us Reg<br>E<br>e to from | | d SP : | į | - | 127<br>6 | 1 2 | ! | 4 1 | ;<br> - 1 | 16 | {<br> | 16 | 7 | :<br> | 1 | | 20 | 4 | 22<br>18 | 1 | 20<br>15 | 6 | 74 | 1 | 21 | | 1 | 22 | 4 | 16 | 010 | | 00 | 8116 | E ÉÉÉ | E | SP +d | <b>b</b> | | ** | | SP (A7)<br>EA<br>Address | l t i | a Ar<br>d Ar<br>s XM - 4,50€ | | 1 | 4 | 1 | | 4<br>1<br>1000 | ابا | | | 2 | 1 | | | | 12<br>16 | 4 | 14<br>18<br>14/4 | 4 | 12 | 6 | 16<br>20 | 4 | 1 10 | | | 14<br>18 | 4 | 8<br>12<br>222.11 | 001<br>001 | 0 11<br>1 AA<br>0 AA<br>0 YW | 40 | 0100 | CAA | | An +US<br>s An | er<br>Line | NC TO SA | | | Multiple<br>sters | L | ditin s<br>s Xin d | | | | | | | • | 12 · 4<br>8 · 8n | • | 12 - | | 8 ( | 6 | 1 | - <b>6</b> 4 | 6 | 18 · 4 | 6 | 16 | 8<br>in 8 | 20 · | 1. | 16 | | 6 11 | • | | 14 | 010 | 40 | | 11EE | SEE | E | | | | | | EP | | do <b>Xn s</b><br>s Dr d<br>s d An | | - | S. | 1 | | . | • | 12-8 | • | 17 - 6 | | | 6 | 16 | -8 | | 18 - 8 | 6 | 16 - 1 | 8 | 20 - | 6 | 16- | 4 | 6 18 | -01 | | | 000 | DDI<br>O DDI | DI | 1000 | #07<br>#0<br>I IAA<br>I IAA | , i | o de la composición dela composición de la composición de la composición dela composición de la composición de la composición dela composición dela composición de la composición dela co | by by | r<br>les | | | heral<br>EQ<br>: Quick | | s mn8 d | 2 | 1 | 4 | | 1 | . | 2 1 | | | ) <sub>d</sub> | 1 | | ،<br>ا | 1 | .4<br>5.4 | 1 | | - | | l | ı | 1 | | + | 1 | ş. | | ar e | 000<br>000 | O DDI<br>O DD<br>I: <b>DD</b> I | DI<br>Di<br>De | 0100 | 144<br>999 | A I I<br>A : : | ۱ ۵۰ م€ | by by<br>by by | les | | | s !<br>ply !<br>ed<br>u ! | • [ | dDr s | 2 | | 70 | | 1 | 1 | 2. | :4<br>-: 74 | 2 | . 11 | 2 | ( < ) | 6 : 4<br>6 4 | 1. | 78 | 4 | · 80<br>< <b>80</b> | 4 | < <b>л</b> | 1 | - 8<br> < 8 | 2 4<br>2 4 | <1 | 8 4 | | 80 | 4 | < 74 | 110 | וחת כ<br>וחת כ | - ! | ilee<br>13 be | ••• | | | -On | | | | oly<br>ined<br>I<br>te Digit | 8 #1 | 4 | 1 2 | 1 | 6 | 1 | 1 | 1 | ् ।<br>21 | 12 | | 12 | 12 | 14 | 1.<br>14 | 1 | _ <br> 6 1 | 4 | 19<br>18 | | 16 | 6 | 20 | i i | | 1 | | | | | 0101 | 10 | i | 00EE | . 7 6 | E | | | | • U | | ive Multi | B # | | 2<br>2<br>2 | | 6<br>4<br>6 | | | | 2 | 20 | 2 2 2 | 20 | 2 2 | 22 | 4 | . 2 | 6 | 4 | 18<br>26<br>16<br>16 | 4 | 24<br>:6<br>:2 | 6 6 | 28<br>70<br>78 | | 1 | | | | | 34 | 0100 | | ٠. | 100 | EEE | 71 | | ٠. | | ••• | | al<br>lement | | s Dr. d. | 2 | | 6 | | | | 2 2 2 2 | 20 | 2 2 | 12<br>20 | 2 2 | 14<br>22<br>10 | 4 | 3 | • | • | 18 26 | 4 | 16<br>24<br>16<br>12 | 6 | 20<br>28 | | | | | 32 | | | 100 | DDI | ر<br>DI | SSEE | EEE! | E c | - <b>6 • 6</b> | Dn • | Kn7e | • | | sive OR<br>al<br>nmediate | i | s Dr d<br>a On s<br>s-Manna di | 4 | | 8 | | | | 5.2 | 16<br>30<br> 4 | 2 2 4 6 | 14<br>16<br>30 | 6 | 16<br>18<br>32 | 4 | 1 1 | 8 | 4 6 8 | 20<br>22<br>33<br>27 | 4 4 6 8 4 | 18<br>20<br>38 | 6 6 8 | 16<br>22<br>24<br>24<br>22 | 4 | 18<br>18 | | | 0 | 6 | 8<br>14 | 100<br>100<br>100<br>100<br>100 | DDI | DI<br>DO | SSee<br>10EE<br>10ee<br>35CE | EEE | E | n < or'<br> < or ><br>n < or'<br> <b>&lt; or</b> ≥<br> <b>&lt; or</b> ≥<br> <b>Cor</b> ≥<br> <b>Cor</b> ≥<br> <b>Cor</b> ≥ | Dn<br>>s | d<br>Dn | • | | Idress<br>ROL<br>e<br>ut X | | count Do di<br>count All & di<br>count Si ~ 8 di<br>count Si ~ 8 di | 3272 | 9 6 8 8 | 200 | 1 | | | 1 | 12 | 2• | 12 | 2- | H | • | , | 6 | | 18 | 200 | 16 | 6. | 20 | | | | 10.71 | 1 Sec. 1 | 1000 | 33 | fill<br>fill<br>fill | qqq | | 100)<br>100)<br>100) | 190 | 0 | | | | | | Refer to I<br>as for co-<br>ind only<br>eximum valid<br>imber of P<br>imber of C | ndition<br>ue | | rat-o | ons | | | • | | | * * | ddres: | Reg<br>onder-<br>egiste<br>Effec | ster | 5 | | | | | rectio<br>istinal | n, D<br>Ivon I | President Mo | 1 1 | Sit P | P | Dest<br>Size | natur | w R. | este | 1 | 1 | / ln I | | 1 | struct | | | | | | L | 976 (to be continued) **@HITACHI** e + The MPU goes through an extra null read cycle after a multiple read is done iThe last EA ± 21 # ( HITACHI ## HD68000/HD68HC000 #### ■ INSTRUCTION FORMAT SUMMARY This provides a summary of the first word in each instruction of the instruction set. Table 26 is an operation code (op-code) map which illustrates how bits 15 through 12 are used to specify the operations. The remaining paragraph groups the instructions according to the op-code map. where, Size; Byte = 00 Sz; Word = 0 Word = 01 Long Word = 1 Table 26 Operation Code Map | Bits<br>15 thru 12 | Operation | |--------------------|---------------------------------------------| | 0000 | Bit Manipulation/MOVEP/Immediate | | 0001 | Move Byte | | 0010 | Move Long | | 0011 | Move Word | | 0100 | Miscellaneous | | 0101 | ADDQ/SUBQ/S <sub>CC</sub> /DB <sub>CC</sub> | | 0110 | B <sub>CC</sub> | | 0111 | MOVEQ | | 1000 | OR/DIV/SBCD | | 1001 | SUB/SUBX | | 1010 | (Unassigned) | | 1011 | CMP/EOR | | 1100 | AND/MUL/ABCD/EXG | | 1101 | ADD/ADDX | | 1110 | Shift/Rotate | | 1111 | (Unassigned) | ## (1) BIT MANIPULATION, MOVE PERIPHERAL, IMMEDIATE INSTRUCTIONS ## Dynamic Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----------|---|---|----|----|---|---|----------|-------|------|---| | 0 | 0 | 0 | 0 | Ι | Register | | 1 | Ty | pe | | E | ffective | Addre | \$\$ | | #### Static Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|---|---|----|----|---|---|---------|-------|-----|---| | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | Ту | ре | | E | fective | Addre | 155 | | Bit Type Codes: TST = 00, CHG = 01, CLR = 10, SET = 11 #### MOVEP | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|---------|----------|---------|--------|----------|---------|--------|---------|---------|-------|----------|-------|-----|---------|---| | 0 | 0 | 0 | 0 | | Registe | r | ( | Op-Mod | le | 0 | 0 | 1 | | Registe | , | | Op-Mo | ode; Wo | ord to I | Reg = 1 | 00, Lo | ong to F | leg = 1 | 01, Wo | rd to N | fem = ° | 10, L | ong to I | Vem = | 111 | | | ## **OR** Immediate | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|---|---|---|----|---|---|---------|-------|----|---| | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | ze | | E | fective | Addre | 55 | | #### **AND Immediate** 978 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|---|---|----|----|---|---|----------|-------|------|---| | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | Si | ze | | E | ffective | Addre | \$\$ | | ## **OHITACHI** #### **SUB Immediate** | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | <u> </u> | |----|----|----|----|----|----|---|---|------|---|---|----|---------|-------|-----------|----------| | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | Size | • | | E. | fective | Addre | <b>55</b> | | #### **ADD Immediate** | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0_ | |---|----|----|----|----|----|----|---|---|---|----|---|---|----------|--------|----|----| | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | S | 20 | L | E | ffective | Addres | 58 | | ### **EOR Immediate** | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4' | 3 | 2 | 1_ | 0 | |----|----|----|----|----|----|---|---|----|----|---|----|---------|-------|----|---| | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | Si | Ze | | Ef | fective | Addre | 55 | | ### **CMP Immediate** | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5_ | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|---|---|---|-----|----------|---|----------|-------|----|---| | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | S | ize | <u> </u> | E | ffective | Addre | 88 | | ### (2) MOVE BYTE INSTRUCTION ### **MOVE Byte** | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1_ | | |---|----|----|----|-----------|----|---------|-------|---------|------|---|----------|------|----|----------------------------------------|---------|---| | ١ | | | | | | | Desti | nation | | | | | So | urce | | 1 | | - | 0 | 0 | 0 | <u>L'</u> | | Registe | • | <u></u> | Mode | | <u> </u> | Mode | | اـــــــــــــــــــــــــــــــــــــ | Registe | r | ## (3) MOVE LONG INSTRUCTION ### **MOVE Long** | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1_ | 0 | |---|----|----|-----|----|----|---------|--------|--------|------|---|---|------|----|------|---------|-----| | ſ | | _ | | | | | Destin | nation | | | | | So | urce | | - 1 | | ١ | 0 | 0 | ١ ١ | 0 | ' | Registe | r | | Mode | | | Mode | | L | Registe | r | ## (4) MOVE WORD INSTRUCTION ### **MOVE Word** | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|----|----|----|----|----|---------|-------|--------|------|---|----------|------|-----|-----|----------|---| | 1 | | | Γ. | Γ. | | | Desti | nation | | | | | Sou | | | İ | | | 0 | 0 | , | יו | 1 | Registe | r | 1 | Mode | | <u> </u> | Mode | | 1 1 | Register | | ## (5) MISCELLANEOUS INSTRUCTIONS ### NEGX | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8_ | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|---|----|---|-----|---|---|----------|-------|-----|---| | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | s | ize | ] | E | ffective | Addre | 188 | | ### MOVE from SR | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | | 1 | 0 | |----|----|----|----|----|----|---|---|---|---|----------|---|----------|-------|-----|---| | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | <u> </u> | | ffective | Addre | 195 | | ### CLR | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|---|---|----|-----|----------|---|---------|-------|--------------------------------------------|---| | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | Si | ize | <u> </u> | E | Hective | Addre | #88<br>——————————————————————————————————— | | ## **@HITACHI** ## HD68000/HD68HC000 NEG 13 12 11 Size **Effective Address** MOVE to CCR 12 0 **Effective Address** NOT 0 0 0 Size MOVE to SR 1 NBCD 0 Effective Address PEA Effective Address SWAP 13 12 11 10 7 6 Register MOVEM Registers to EA | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|---|---|---|----|---|---|----------|---|-----|---| | 0 | 1 | 0 | О | 1 | 0 | 0 | 0 | 1 | Sz | | | ffective | | \$5 | | **EXTW** | _ 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------|----|----|----|----|----|---|---|---|---|---|---|---|---|----------|---| | 0 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | | Register | | **EXTL** | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|---|---|---|---|---|---|---|---|----------|---| | 0 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | F | legister | | TST | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|---|---|---|----|---|---|----------|-------|----|---| | 0 | 1 | 0 | 0 | 1 | 0 | 1 | 0 | S | ze | | E | ffective | Addre | ss | | TAS | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|----|----|----|----|----|----|---|---|---|---|---|----|---------|-------|-----|---| | i | 0 | 1 | 0 | 0 | 1 | 0 | 1 | 0 | 1 | 1 | | Ef | fective | Addre | \$6 | | | MOVEM EA | to Re | gisters | 3 | | | | | | | | | | | | | | |-----------------------------------------|----------|---------|-----|-----|-----|----------|----------------------------------------------|------------|-------------|----------------------------------------------|----------|-------------|----------|----------|-------------------------|----------------------------------------------| | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | 0 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | Sz | | Eff | ective / | Addre | 988 | | | | | | | | | | | | | | | | | | | | | TRAP | | | | | | | | | | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | • | | | 0 | 1 | 0 | 0 | 1 ] | 1 | 1 | 0 | 0 | 1 | 0 | 0 | | Ve | ctor | | | | | | | | | | | | | | | | | | | | | LINK | | | | | | | | | | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0_ | | | <u> </u> | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 0 | | Register | | | | | | | | | | | | | | | | | | | | | UNLK | | | | | | | | | | _ | _ | | _ | _ | | • | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | <del></del> | 6 | 5 | 1 | 3 | 2_ | 1 | 0 | | | 0 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | | | | Register | | | MONTER | 160 | | | | | | | | | | | | | | | | | MOVE to L | | | | | | | _ | _ | - | | | | , | • | 1 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 1 | 0 | 3 | 2 | Register | | | | 0 | 1 | 0 | 0 | 1 | 1 | | <u> </u> | | 1 | ' | | | | riogistor | | | MOVE from | I ICD | | | | | | | | | | | | | | | | | MUVE TO | | | | | | | _ | _ | _ | _ | _ | | | • | | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | _ 2 | 1<br>Register | | | | 0 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | L | L.'1 | | | | Lagister | | | DECET | | | | | | | | | | | | | | | | | | RESET | | | | | | | _ | _ | _ | _ | _ | | • | | | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5<br>1 | 1 | 3 | 0 | 0 | 0 | | | 0 | 1 | 0 | 0 | 1_ | 1_ | 1 | 0 | 0 | | | | | | | | | NOD | | | | | | | | | | | | | | | | | | NOP | | | | | | | _ | _ | _ | _ | _ | | | • | | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 1 | 0 | 0 | 1 0 | 1 | | | 0 | 1 1 | 0 | 0 | 1 | 11 | 1 | 0 | 10 | 1 | <u> </u> | L- <u>'</u> | | | | <u>. </u> | | STOP | | | | | | | | | | | | | | | | | | 3101 | | | | | | | | | - | | | 4 | 3 | 2 | 1 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | <u>6</u><br>1 | 5 | 1 | 10 | 0 | $\overrightarrow{\Box}$ | 0 | | | 0 | 1 | 0 | 0 | 1 1 | <u> </u> | <u> </u> | | | <u> </u> | <u> </u> | <u> </u> | 1 | | | L | | RTE | | | | | | | | | | | | | | | | | | 1116 | | | | | | 10 | | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | To | T 6 | 1 1 | 1 | 1 | To | T 0 | | 1 | | | 0 | 1 1 | 1 0 | 10 | 1 | 1 | <u>ı.'.</u> | 1 . | | <u> </u> | L | <u>'</u> | 1 | 1 | <u> </u> | 1 | | RTS | | | | | | | | | | | | | | | | | | 1110 | | | 44 | 42 | 44 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | 15 | 14 | 13 | 12 | 11 | T 1 | 1 | т | T o | 11 | Ti | 1 | To | 1 | | 1 | | | 0 | '_ | 10 | 1 0 | 1. | ┸. | <u>. </u> | 1 | 1 | <u>. </u> | 1. | <u> </u> | | <u> </u> | | | | TRAPV | | | | | | | | | | | | | | | | | | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | | | | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | 15 | 14 | 13 | T 0 | 11 | 1 1 | T 1 | <b>⊤</b> 。 | Τ, | Ti | 11 | T 7 | To | 1 | | 0 | | | 0 | 11 | 1 " | 1. | | <u> </u> | <u> </u> | | | <u> </u> | <u> </u> | <u> </u> | | <u> </u> | | | ## **(D)** HITACHI #### HD68000/HD68HC000 RTR **JSR** Effective Address **JMP Effective Address** CHK Register Effective Address LEA Register (6) ADD QUICK, SUBTRACT QUICK, SET CONDITIONALLY, DECREMENT INSTRUCTIONS ADDQ Data **Effective Address** SUBQ Data Effective Address $S_{CC}$ Effective Address Condition $\mathsf{DB}_\mathsf{CC}$ Condition Register (7) BRANCH CONDITIONALLY, BRANCH TO SUBROUTINE INSTRUCTION $B_{CC}$ Condition 8 bit Displacement BSR | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----|---|---|---|---|-----|----------|--------|-----|---|---| | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | | | 8 6 | oit Disp | laceme | ent | | | #### (8) MOVE QUICK INSTRUCTION MOVEQ | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----|----|----|----|----|----------|---|---|---|---|---|---|-----|---|---|---| | 0 | 1 | 1 | 1 | | Register | | 0 | | | | U | eta | | | | ( HITACHI 983 ## **@HITACHI** ## HD68000/HD68HC000 | MULU | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------------|---------------|---------------------|-------------------|----------------------------|---------------|------------------|---------|--------|-------|----------|------------|-------|----------|--------|--------------|-------| | | 1 | 1 | 0 | 0 | Ī | Registe | r | 0 | 1 | 1 | 1 | E | ffective | Addre | | _ | | | | | | | | | | | | | | | | | | | | MULS | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | 1 | 1 | 0 | 0 | T | Registe | | 1 | 1 | 1 | Ť | | ffective | | | | | | | | | 1 | 1 | | | | | | <b></b> | • | | | · | _ | | ABCD | | | | | | | _ | _ | _ | _ | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10<br>estinati | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | 1 | 1 | 0 | 0 | | Registe | | ' | 0 | 0 | 0 | 0 | R/M | Sou | rce Req | jiste | | | R/M | regist | er/me | mory) | : regis | ter – i | egiste | r = 0, | memo | ry – r | nemo | y = 1 | | | | | | | | | | | | | | | | | | | | | | | | EXGD | | | | | | | _ | _ | _ | _ | _ | | | | | | | | 15 | 14 | 13 | 0 | 11 | 10<br>sta Regi | 9 | 8 | 7 | 6 | 5<br>0 | 0 | 3 | 2 | 1<br>ta Regi | | | | | <u> </u> | 1 | | | ita negi | | 1'_ | | <u> </u> | L <u>u</u> | 1.0 | 1 | Ua | ta riegi | ster | | XGA | | | | | | | | | | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | . 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | 1 | 1 | 0 | 0 | Add | ress Re | gister | 1 | 0 | 1 | 0 | 0 | 1 | Add | ess Re | jiste | | EXGM | | | | | | | | | | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | 1 | 1 | 0 | 0 | Da | ta Regi | ster | 1 | 1 | 0 | 0 | 0 | 1 | Addr | ess Re | jiste | | ADD | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4_ | 3 | 2 | 1 | 0 | | | | 1 | 0<br>p-Mode | 1_1_ | L | Registe | r | | p-Mod | e | l | E | ffective | Addre | ss | | | | 100 | W<br>001 0<br>101 1 | )10<br> 10<br> 10 | Dn + E<br>EA + E<br>An + E | On → E | Α | | | | | | | | | | | | XDDX | | | | | | | | | | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10<br>estination | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | 1 | 1 | 0 | 1 | | Register | | 1 | Siz | te . | 0 | 0 | R/M | Sour | ce Reg | ister | | | R/M ( | registe | er/men | nory): | regist | er – r | egister | = 0, r | nemor | y – m | nemor | y = 1 | | | | | | 14) SHIF | | | INST | RUCT | IONS | | | | | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | 1 | 1 | 1 | 0 | Cou | nt/Regi | ster | d | Siz | :e | i/r | Ту | pe | F | legister | | | lemory Shi | ifts | | | | | | | | | | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | 1 | 1 | 1 | 0 | 0 | Ту | pe | d | 1 | 1 | | E | fective | Addres | is | | | | Shift d (dire | Type ( | Codes:<br>): Rigi | AS =<br>ht = 0, | 00, L<br>Left | S = 01 | , ROX | = 10, | RO = | 11 | | Ef | | | | | ## **@HITACHI** Hitachi America, Ltd. • Hitachi Plaza • 2000 Sierra Point Pkwy. • Brisbane, CA 94005-1819 • (415) 589-8300 984 ### . INSTRUCTION EXECUTION TIMES The following paragraphs contain listings of the instruction execution times in terms of external clock (CLK) periods. In this timing data, it is assumed that both memory read and write cycle times are four clock periods. Any wait states caused by a longer memory cycle must be added to the total instruction time. The number of bus read and write cycles for each instruction is also included with the timing data. This data is enclosed in parenthesis following the execution periods and is shown as: (r/w) where r is the number of read cycles and w is the number of write cycles. (NOTE) The number of periods includes instruction fetch and all applicable operand fetches and stores. #### EFFECTIVE ADDRESS OPERAND CALCULATION TIMING Table 27 lists the number of clock periods required to compute an instruction's effective address. It includes fetching of any extension words, the address computation, and fetching of the memory operand. The number of bus read and write cycles is shown in parenthesis as (r/w). Note there are no write cycles involved in processing the effective address. ## . MOVE INSTRUCTION CLOCK PERIODS Table 28 and 29 indicate the number of clock periods for the move instruction. This data includes instruction fetch, operand reads, and operand writes. The number of bus read and write cycles is shown in parenthesis as: (r/w). ## • STANDARD INSTRUCTION CLOCK PERIODS The number of clock periods shown in Table 30 indicates the time required to perform the operations, store the results, and read the next instruction. The number of bus read and write cycles is shown in parenthesis as: (r/w). The number of clock periods and the number of read and write cycles must be added respectively to those of the effective address calculation where indicated. In Table 30 the headings have the following meanings: An = address register operand, Dn = data register operand, ea = an operand specified by an effective address, and M = memory effective address operand. ### . IMMEDIATE INSTRUCTION CLOCK PERIODS The number of clock periods shown in Table 31 includes the time to fetch immediate operands, perform the operations, store the results, and read the next operation. The number of bus read and write cycles is shown in parenthesis as: (r/w). The number of clock periods and the number of read and write cycles must be added respectively to those of the effective address calculation where indicated. In Table 31, the headings have the following meanings: # = immediate operand, On = data register operand, An = address register operand, M = memory operand, CCR = condition code register, and SR = status register. #### . SINGLE OPERAND INSTRUCTION CLOCK PERIODS Table 32 indicates the number of clock periods for the single operand instructions. The number of bus read and write cycles is shown in parenthesis as: (r/w). The number of clock periods and the number of read and write cycles must be added respectively to those of the effective address calculation where indicated Table 27 Effective Address Calculation Timing | | Addressing Mode | Byte, Word | Long | |-------------------|-------------------------------------------------------------------------------|-------------------|------------------| | Dn | Register Data Register Direct Address Register Direct | O(O/O) | 0(0/0) | | An | | O(O/O) | 0(0/0) | | An@ | Memory Address Register Indirect Address Register Indirect with Postincrement | 4(1/0) | 8(2/0 | | An@+ | | 4(1/0) | 8(2/0 | | An@ - | Address Register Indirect with Predecrement | 6(1/0) | 10(2/0 | | An@(d) | Address Register Indirect with Displacement | 8(2/0) | 12(3/0 | | An@(d, ix)* xxx.W | Address Register Indirect with Index Absolute Short | 10(2/0)<br>8(2/0) | 14(3/0<br>12(3/0 | | xxx. L | Absolute Long Program Counter with Displacement | 12(3/0) | 16(4/0 | | PC <b>@</b> (d) | | 8(2/0) | 12(3/0 | | PC@(d, ix)* #xxx | Program Counter with Index Immediate | 10(2/0)<br>4(1/0) | 14(3/0<br>8(2/0 | <sup>\*</sup> The size of the index register (ix) does not affect execution time. Table 28 Move Byte and Word Instruction Clock Periods | Source | | | | | Destination | | | | | |-------------|---------|---------|---------|---------|-------------|---------|-------------|---------|---------| | Source | Dn | An | An@ | An@ + | An@ - | An@(d) | An@(d, ix)* | xxx. W | xxx. L | | Dn | 4(1/0) | 4(1/0) | 8(1/1) | 8(1/1) | 8(1/1) | 12(2/1) | 14(2/1) | 12(2/1) | 16(3/1) | | An | 4(1/0) | 4(1/0) | 8(1/1) | 8(1/1) | 8(1/1) | 12(2/1) | 14(2/1) | 12(2/1) | 16(3/1) | | An@ | 8(2/0) | 8(2/0) | 12(2/1) | 12(2/1) | 12(2/1) | 16(3/1) | 18(3/1) | 16(3/1) | 20(4/1) | | An@+ | 8(2/0) | 8(2/0) | 12(2/1) | 12(2/1) | 12(2/1) | 16(3/1) | 18(3/1) | 16(3/1) | 20(4/1) | | An@ - | 10(2/0) | 10(2/0) | 14(2/1) | 14(2/1) | 14(2/1) | 18(3/1) | 20(3/1) | 18(3/1) | 22(4/1) | | An@(d) | 12(3/0) | 12(3/0) | 16(3/1) | 16(3/1) | 16(3/1) | 20(4/1) | 22(4/1) | 20(4/1) | 24(5/1) | | An@(d, ix)* | 14(3/0) | 14(3/0) | 18(3/1) | 18(3/1) | 18(3/1) | 22(4/1) | 24(4/1) | 22(4/1) | 26(5/1) | | xxx.W | 12(3/0) | 12(3/0) | 16(3/1) | 16(3/1) | 16(3/1) | 20(4/1) | 22(4/1) | 20(4/1) | 24(5/1) | | xxx. L | 16(4/0) | 16(4/0) | 20(4/1) | 20(4/1) | 20(4/1) | 24(5/1) | 26(5/1) | 24(5/1) | 28(6/1) | | PC@(d) | 12(0/0) | 12(3/0) | 16(3/1) | 16(3/1) | 16(3/1) | 20(4/1) | 22(4/1) | 20(4/1) | 24(5/1) | | PC@(d, ix)* | 14(3/0) | 14(3/0) | 18(3/1) | 18(3/1) | 18(3/1) | 22(4/1) | 24(4/1) | 22(4/1) | 26(5/1) | | #xxx | 8(2/0) | 8(2/0) | 12(2/1) | 12(2/1) | 12(2/1) | 16(3/1) | 18(3/1) | 16(3/1) | 20(4/1) | <sup>\*</sup> The size of the index register (ix) does not affect execution time Table 29 Move Long Instruction Clock Periods | Source | 1 | | | | Destination | | | | | |-------------|---------|---------|---------|---------|-------------|---------|-------------|---------|---------| | Source | Dn | An | An@ | An@ + | An@ - | An@(d) | An@(d, ix)* | xxx.W | xxx. L | | Dn | 4(1/0) | 4(1/0) | 12(1/2) | 12(1/2) | 12(1/2) | 16(2/2) | 18(2/2) | 16(2/2) | 20(3/2) | | An | 4(1/0) | 4(1/0) | 12(1/2) | 12(1/2) | 12(1/2) | 16(2/2) | 18(2/2) | 16(2/2) | 20(3/2) | | An@ | 12(3/0) | 12(3/0) | 20(3/2) | 20(3/2) | 20(3/2) | 24(4/2) | 26(4/2) | 24(4/2) | 28(5/2) | | An@ + | 12(3/0) | 12(3/0) | 20(3/2) | 20(3/2) | 20(3/2) | 24(4/2) | 26(4/2) | 24(4/2) | 28(5/2) | | An@ - | 14(3/0) | 14(3/0) | 22(3/2) | 22(3/2) | 22(3/2) | 26(4/2) | 28(4/2) | 26(4/2) | 30(5/2) | | An@(d) | 16(4/0) | 16(4/0) | 24(4/2) | 24(4/2) | 24(4/2) | 28(5/2) | 30(5/2) | 28(5/2) | 32(6/2) | | An@(d, ix)* | 18(4/0) | 18(4/0) | 26(4/2) | 26(4/2) | 26(4/2) | 30(5/2) | 32(5/2) | 30(5/2) | 34(6/2) | | xxx. W | 16(4/0) | 16(4/0) | 24(4/2) | 24(4/2) | 24(4/2) | 28(5/2) | 30(5/2) | 28(5/2) | 32(6/2) | | xxx. L | 20(5/0) | 20(5/0) | 28(5/2) | 28(5/2) | 28(5/2) | 32(6/2) | 34(6/2) | 32(6/2) | 36(7/2) | | PC@(d) | 16(4/0) | 16(4/0) | 24(4/2) | 24(4/2) | 24(4/2) | 28(5/2) | 30(5/2) | 28(5/2) | 32(6/2) | | PC@(d,ix)* | 18(4/0) | 18(4/0) | 26(4/2) | 26(4/2) | 26(4/2) | 30(5/2) | 32(5/2) | 30(5/2) | 34(6/2) | | #xxx | 12(3/0) | 12(3/0) | 20(3/2) | 20(3/2) | 20(3/2) | 24(4/2) | 26(4/2) | 24(4/2) | 28(5/2) | <sup>\*</sup> The size of the index register (ix) does not affect execution time. Table 30 Standard Instruction Clock Periods | Instruction | Size | op < ea >, An | op < ea >, Dn | op Dn, < M > | |-------------|------------|---------------|---------------|--------------| | ADD | Byte, Word | 8(1/0) + | 4(1/0) + | 8(1/1) + | | ADD | Long | 6(1/0) + ** | 6(1/0) + ** | 12(1/2) + | | AND | Byte, Word | _ | 4(1/0) + | 8(1/1) + | | AND | Long | - | 6(1/0) + ** | 12(1/2) + | | СМР | Byte, Word | 6(1/0) + | 4(1/0) + | _ | | CMP | Long | 6(1/0) + | 6(1/0) + | - | | DIVS | - | _ | 158(1/0) + * | _ | | DIVU | - | - | 140(1/0) + * | | | EOR | Byte, Word | - | 4(1/0) *** | 8(1/1) + | | EUN | Long | _ | 8(1/0) *** | 12(1/2) + | | MULS | - | _ | 70(1/0) + * | _ | | MULU | - | _ | 70(1/0) + * | _ | | OR | Byte, Word | - | 4(1/0) + | 8(1/1) + | | Un | Long | _ | 6(1/0) + ** | 12(1/2) + | | SUB | Byte, Word | 8(1/0) + | 4(1/0) + | 8(1/1) + | | 300 | Long | 6(1/0) + ** | 6(1/0) + ** | 12(1/2) + | <sup>+</sup> add effective address calculation time \* indicates maximum value MULS; n = concatanate the < ea > with a zero as the LSB; n is the resultant number of 10 or 01 patterns in the 17-bit source; i.e. worst case happens when the source is \$5555. <sup>\*\*</sup> total of 8 clock periods for instruction if the effective address is register direct \*\*\* only available effective address mode is data register direct DIVS, DIVU The divide algorithm used by the 68000 provides less than 10% difference between the best and worst case timings. MULS, MULU - The <sup>-</sup> The multiply algorithm requires 38+2n clocks when n is defined as MULU; n = the number of ones in the < ea > Table 31 Immediation Instruction Clock Periods | Instruction | Size | op #, Dn | op #, An | op #, M | op #, CCR/SF | |-------------|------------|----------|----------|-----------|--------------| | | Byte, Word | 8(2/0) | _ | 12(2/1) + | - | | ADDI | Long | 16(3/0) | _ | 20(3/2) + | - | | | Byte, Word | 4(1/0) | 8(1/0)* | 8(1/1) + | | | ADDQ | Long | 8(1/0) | 8(1/0) | 12(1/2) + | _ | | | Byte, Word | 8(2/0) | _ | 12(2/1) + | 20(3/0) | | ANDI | Long | 16(3/0) | | 20(3/1) + | - | | | Byte, Word | 8(2/0) | 8(2/0) | 8(2/0) + | - | | CMPI | Long | 14(3/0) | 14(3/0) | 12(3/0) + | _ | | | Byte, Word | 8(2/0) | _ | 12(2/1) + | 20(3/0) | | EORI | Long | 16(3/0) | _ | 20(3/2) + | _ | | MOVEQ | Long | 4(1/0) | _ | _ | - | | | Byte, Word | 8(2/0) | - | 12(2/1) + | 20(3/0) | | ORI | Long | 16(3/0) | _ | 20(3/2) + | - | | | Byte, Word | 8(2/0) | _ | 12(2/1) + | - | | SUBI | Long | 16(3/0) | _ | 20(3/2) + | - | | | Byte, Word | 4(1/0) | 8(1/0)* | 8(1/1) + | | | SUBQ | Long | 8(1/0) | 8(1/0) | 12(1/2) + | | <sup>+</sup> add effective address calculation time Table 32 Single Operand Instruction Clock Periods | Instruction | Size | Register | Memory | |-------------|-------------|----------|-----------| | | Byte, Word | 4(1/0) | 8(1/1) + | | CLR | Long | 6(1/0) | 12(1/2) + | | NBCD | Byte | 6(1/0) | 8(1/1) + | | | Byte, Word | 4(1/0) | 8(1/1) + | | NEG | Long | 6(1/0) | 12(1/2) + | | | Byte, Word | 4(1/0) | 8(1/1) + | | NEGX | Long | 6(1/0) | 12(1/2) + | | | Byte, Word | 4(1/0) | 8(1/1) + | | NOT | Long | 6(1/0) | 12(1/2) + | | | Byte, False | 4(1/0) | 8(1/1) + | | Scc | Byte, True | 6(1/0) | 8(1/1) + | | TAS | Byte | 4(1/0) | 10(1/1) + | | | Byte, Word | 4(1/0) | 4(1/0) + | | TST | Long | 4(1/0) | 4(1/0) + | <sup>+</sup> add effective address calculation time ## • SHIFT/ROTATE INSTRUCTION CLOCK PERIODS Table 33 indicates the number of clock periods for the shift and rotate instructions. The number of bus read and write cycles is shown in parenthesis as: (r/w). The number of clock periods and the number of read and write cycles must be added respectively to those of the effective address calculation where indicated. ## . BIT MANIPULATION INSTRUCTION CLOCK PERIODS Table 34 indicates the number of clock periods required for the bit manipulation instructions. The number of bus read and write cycles is shown in parenthesis as: (r/w). The number of clock periods and the number of read and write cycles must be added respectively to those of the effective address calculation where indicated. <sup>\*</sup> word only #### • CONDITIONAL INSTRUCTION CLOCK PERIODS Table 35 indicates the number of clock periods required for the conditional instructions. The number of bus read and write cycles is indicated in parenthesis as: (r/w). The number of clock periods and the number of read and write cycles must be added respectively to those of the effective address calculation where indicated. # • JMP, JSR, LEA, PEA, MOVEM INSTRUCTION CLOCK PERIODS Table 36 indicates the number of clock periods required for the jump, jump to subroutine, load effective address, push effective address, and move multiple registers instructions. The number of bus read and write cycles is shown in parenthesis as: (r/w). Table 33 Shift/Rotate Instruction Clock Periods | Instruction | Size | Register | Memory | | |-------------|------------|-------------|----------|--| | ACD AC | Byte, Word | 6 + 2n(1/0) | 8(1/1) + | | | ASR, ASL | Long | 8 + 2n(1/0) | | | | | Byte, Word | 6 + 2n(1/0) | 8(1/1) + | | | LSR, LSL | Long | 8 + 2n(1/0) | _ | | | | Byte, Word | 6 + 2n(1/0) | 8(1/1) + | | | ROR, ROL | Long | 8 + 2n(1/0) | _ | | | BOYD BOY! | Byte, Word | 6 + 2n(1/0) | 8(1/1) + | | | ROXR, ROXL | Long | 8 + 2n(1/0) | _ | | Table 34 Bit Manipulation Instruction Clock Periods | Instruction | Size | Dyn | amic | Static | | | |-------------|------|----------|----------|----------|-----------|--| | Instruction | Size | Register | Memory | Register | Memory | | | BCHG | Byte | - | 8(1/1)+ | _ | 12(2/1) + | | | вспо | Long | 8(1/0)* | _ | 12(2/0)* | <b>-</b> | | | BCLR | Byte | _ | 8(1/1) + | _ | 12(2/1) + | | | | Long | 10(1/0)* | _ | 14(2/0)* | - | | | DOCT | Byte | _ | 8(1/1) + | _ | 12(2/1) + | | | BSET | Long | 8(1/0)* | _ | 12(2/0)* | _ | | | | Byte | _ | 4(1/0) + | _ | 8(2/0) + | | | BTST | Long | 6(1/0) | _ | 10(2/0) | _ | | <sup>+</sup> add effective address calculation time Table 35 Conditional Instruction Clock Periods | Instruction | Displacement | Trap or Branch<br>Taken | Trap of Branch<br>Not Taken | |------------------|--------------|-------------------------|-----------------------------| | | Byte | 10(2/0) | 8(1/0) | | B <sub>CC</sub> | Word | 10(2/0) | 12(2/0) | | 004 | Byte | 10(2/0) | _ | | BRA | Word | 10(2/0) | _ | | BSR | Byte | 18(2/2) | + | | | Word | 18(2/2) | _ | | | CC true | - | 12(2/0) | | DB <sub>CC</sub> | CC false | 10(2/0) | 14(3/0) | | СНК | - | 40(5/3) + * | 10(1/0) + | | TRAP | _ | 34(4/3) | _ | | TRAPV | _ | 34(5/3) | 4(1/0) | <sup>+</sup> add effective address calculation time **OHITACHI** <sup>\*</sup> indicates maximum value <sup>\*</sup> indicates maximum value Table 36 JMP, JSR, LEA, PEA, MOMEM Instruction Clock Periods | Instr | Size | An@ | An@+ | An@ - | An@(d) | An@(d, ix) * | xxx.W | xxx. L | PC@(d) | PC@(d, ix) | |-------|------|-------------------|-------------------|----------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------| | JMP | _ | 8(2/0) | _ | _ | 10(2/0) | 14(3/0) | 10(2/0) | 12(3/0) | 10(2/0) | 14(3/0) | | JSR | _ | 16(2/2) | _ | _ | 18(2/2) | 22(2/2) | 18(2/2) | 20(3/2) | 18(2/2) | 22(2/2) | | LEA | | 4(1/0) | _ | _ | 8(2/0) | 12(2/0) | 8(2/0) | 12(3/0) | 8(2/0) | 12(2/0) | | PEA | _ | 12(1/2) | _ | _ | 16(2/2) | 20(2/2) | 16(2/2) | 20(3/2) | 16(2/2) | 20(2/2) | | MOVEM | Word | 12+4n<br>(3+n/0) | 12+4n<br>(3+n/0) | _ | 16+4n<br>(4+n/0) | 18+4n<br>(4+n/0) | 16+4n<br>(4+n/0) | 20+4n<br>(5+n/0) | 16+4n<br>(4+n/0) | 18+4n<br>(4+n/0) | | M → R | Long | 12+8n<br>(3+2n/0) | 12+8n<br>(3+2n/0) | - | 16+8n<br>(4+2n/0) | 18+8n<br>(4+2n/0) | 16+8n<br>(4+2n/0) | 20+8n<br>(5+2n/0) | 16+8n<br>(4+2n/0) | 18+8n<br>(4+2n/0) | | MOVEM | Word | 8+4n<br>(2/n) | - | 8+4n<br>(2/n) | 12+4n<br>(3/n) | 14+4n<br>(3/n) | 12+4n<br>(3/n) | 16+4n<br>(4/n) | = | = | | R→M | Long | 8+8n<br>(2/2n) | - | 8+8n<br>(2/2n) | 12+8n<br>(3/2n) | 14+8n<br>(3/2n) | 12+8n<br>(3/2n) | 16+8n<br>(4/2n) | = | = | n is the number of registers to move ### • MULTI-PRECISION INSTRUCTION CLOCK PERIODS Table 37 indicates the number of clock periods for the multiprecision instructions. The number of clock periods includes the time to fetch both operands, perform the operations, store the results, and read the next instructions. The number of read and write cycles is shown in parenthesis as: (r/w). In Table 37, the headings have the following meanings: Dn = data register operand and M = memory operand. Table 37 Multi-Precision Instruction Clock Periods | Instruction | Size | op Dn, Dn | ор М, М | |-------------|------------|-----------|---------| | | Byte, Word | 4(1/0) | 18(3/1) | | ADDX | Long | 8(1/0) | 30(5/2) | | СМРМ | Byte, Word | - | 12(3/0) | | | Long | _ | 20(5/0) | | | Byte, Word | 4(1/0) | 18(3/1) | | SUBX | Long | 8(1/0) | 30(5/2) | | ABCD | Byte | 6(1/0) | 18(3/1) | | SBCD | Byte | 6(1/0) | 18(3/1) | ### . MISCELLANEOUS INSTRUCTION CLOCK PERIODS Table 38 indicates the number of clock periods for the following miscellaneous instructions. The number of bus read and write cycles is shown in parenthesis as: (r/w). The number of clock periods plus the number of read and write cycles must be added to those of the effective address calculation where indicated. ### • EXCEPTION PROCESSING CLOCK PERIODS Table 39 indicates the number of clock periods for exception processing. The number of clock periods includes the time for all stacking, the vector fetch, and the fetch of the first instruction of the handler routine. The number of bus read and write cycles is shown in parenthesis as: (r/w). <sup>\*</sup> is the size of the index register (ix) does not affect the instruction's execution time Table 38 Miscellaneous Instruction Clock Periods | Instruction | Size | Register | Memory | Register → Memory | Memory → Register | |---------------|----------|----------|-----------|-------------------|-------------------| | MOVE from SR | | 6(1/0) | 8(1/1) + | - | - | | MOVE to CCR | _ | 12(2/0) | 12(2/0) + | _ | <del>-</del> | | MOVE to SR | _ | 12(2/0) | 12(2/0) + | _ | _ | | MOVED | Word | _ | _ | 16(2/2) | 16(4/0) | | MOVEP | Long | _ | _ | 24(2/4) | 24(6/0) | | EXG | _ | 6(1/0) | _ | _ | _ | | FVT | Word | 4(1/0) | _ | _ | _ | | EXT | Long | 4(1/0) | _ | _ | _ | | LINK | _ | 16(2/2) | _ | _ | _ | | MOVE from USP | <u> </u> | 4(1/0) | _ | _ | - | | MOVE to USP | _ | 4(1/0) | _ | _ | _ | | NOP | - | 4(1/0) | _ | - | _ | | RESET | | 132(1/0) | _ | - | _ | | RTE | <u> </u> | 20(5/0) | - | _ | _ | | RTR | - | 20(5/0 | - | - | - | | RTS | _ | 16(4/0) | _ | <u>-</u> | _ | | STOP | _ | 4(0/0) | - | - | _ | | SWAP | _ | 4(1/0) | _ | _ | - | | UNLK | _ | 12(3/0) | _ | _ | - | <sup>+</sup> add effective address calculation time Table 39 Exception Processing Clock Periods | Exception | Periods | | |----------------------|------------|--| | Reset * * | 38.5 (6/0) | | | Address Error | 50(4/7) | | | Bus Error | 50(4/7) | | | Interrupt | 44(5/3)* | | | Hiegal Instruction | 34(4/3) | | | Privileged Violation | 34(4/3) | | | Trace | 34(4/3) | | The interrupt acknowledge bus cycle is assumed to take four external clock periods. #### MASK VERSION | Mask version | |--------------| | | | | | 68000S1 | | | | | | | | | | 6000011 | | 68000U | | | The difference of function between mask version 68000S1 and 68000U is only as following (Figure 59). The function of HD68HC000 is as same as mask version 68000U. <sup>\*\*</sup> Indicates the time from when RES and HALT are first sampled as negated to when instruction execution starts. Figure 59 Address Error Timing - NOTE FOR USE - Power Supply Circuit When designing $V_{CC}$ and $V_{SS}$ pattern of the circuit board, the capacitors need to be located nearest to $V_{CC}$ and $V_{SS}$ as shown in the Figure 60. Figure 60 Power Supply Circuit **OHITACHI**