# E·XFL

#### NXP USA Inc. - MC68HC000RC16 Datasheet



#### Welcome to E-XFL.COM

#### **Understanding Embedded - Microprocessors**

Embedded microprocessors are specialized computing chips designed to perform specific tasks within an embedded system. Unlike general-purpose microprocessors found in personal computers, embedded microprocessors are tailored for dedicated functions within larger systems, offering optimized performance, efficiency, and reliability. These microprocessors are integral to the operation of countless electronic devices, providing the computational power necessary for controlling processes, handling data, and managing communications.

#### Applications of **Embedded - Microprocessors**

Embedded microprocessors are utilized across a broad spectrum of applications, making them indispensable in

#### Details

| 20000                           |                                                                       |
|---------------------------------|-----------------------------------------------------------------------|
| Product Status                  | Obsolete                                                              |
| Core Processor                  | EC000                                                                 |
| Number of Cores/Bus Width       | 1 Core, 32-Bit                                                        |
| Speed                           | 16MHz                                                                 |
| Co-Processors/DSP               | -                                                                     |
| RAM Controllers                 | -                                                                     |
| Graphics Acceleration           | No                                                                    |
| Display & Interface Controllers | -                                                                     |
| Ethernet                        | -                                                                     |
| SATA                            | -                                                                     |
| USB                             | -                                                                     |
| Voltage - I/O                   | 5.0V                                                                  |
| Operating Temperature           | 0°C ~ 70°C (TA)                                                       |
| Security Features               | -                                                                     |
| Package / Case                  | 68-BCPGA                                                              |
| Supplier Device Package         | 68-PGA (26.92x26.92)                                                  |
| Purchase URL                    | https://www.e-xfl.com/product-detail/nxp-semiconductors/mc68hc000rc16 |
|                                 |                                                                       |

Email: info@E-XFL.COM

Address: Room A, 16/F, Full Win Commercial Centre, 573 Nathan Road, Mongkok, Hong Kong



### 1.4 MC68HC000

The primary benefit of the MC68HC000 is reduced power consumption. The device dissipates an order of magnitude less power than the HMOS MC68000.

The MC68HC000 is an implementation of the M68000 16/-32 bit microprocessor architecture. The MC68HC000 has a 16-bit data bus implementation of the MC68000 and is upward code-compatible with the MC68010 virtual extensions and the MC68020 32-bit implementation of the architecture.

### 1.5 MC68HC001

The MC68HC001 provides a functional extension to the MC68HC000 HCMOS 16-/32-bit microprocessor with the addition of statically selectable 8- or 16-bit data bus operation. The MC68HC001 is object-code compatible with the MC68HC000, and code written for the MC68HC001 can be migrated without modification to any member of the M68000 Family.

# 1.6 MC68EC000

The MC68EC000 is an economical high-performance embedded controller designed to suit the needs of the cost-sensitive embedded controller market. The HCMOS MC68EC000 has an internal 32-bit architecture that is supported by a statically selectable 8- or 16-bit data bus. This architecture provides a fast and efficient processing device that can satisfy the requirements of sophisticated applications based on high-level languages.

The MC68EC000 is object-code compatible with the MC68000, and code written for the MC68EC000 can be migrated without modification to any member of the M68000 Family.

The MC68EC000 brings the performance level of the M68000 Family to cost levels previously associated with 8-bit microprocessors. The MC68EC000 benefits from the rich M68000 instruction set and its related high code density with low memory bandwidth requirements.



Notation for operands:

- PC Program counter
- SR Status register
- V Overflow condition code
- Immediate Data Immediate data from the instruction
  - Source Source contents
  - Destination Destination contents
    - Vector Location of exception vector
      - +inf Positive infinity
      - -inf Negative infinity
      - <fmt> Operand data format: byte (B), word (W), long (L), single (S), double (D), extended (X), or packed (P).
      - FPm One of eight floating-point data registers (always specifies the source register)
      - FPn One of eight floating-point data registers (always specifies the destination register)

Notation for subfields and qualifiers:

- <br/>
  <br/>
- <ea>{offset:width} Selects a bit field
  - (<operand>) The contents of the referenced location
- (<address register>) The register indirect operator
- -(<address register>) Indicates that the operand register points to the memory
- (<address register>)+ Location of the instruction operand—the optional mode qualifiers are –, +, (d), and (d, ix)
  - #xxx or #<data> Immediate data that follows the instruction word(s)

Notations for operations that have two operands, written <operand> <op> <operand>, where <op> is one of the following:

- $\rightarrow$  The source operand is moved to the destination operand
- $\leftrightarrow$  The two operands are exchanged
- + The operands are added
- The destination operand is subtracted from the source operand
- $\times$  The operands are multiplied
- The source operand is divided by the destination operand
- Relational test, true if source operand is less than destination operand
- Relational test, true if source operand is greater than destination operand
- V Logical OR
- ⊕ Logical exclusive OR
- $\Lambda$  Logical AND

M68000 8-/16-/32-BIT MICROPROCESSOR USER'S MANUAL

For More Information On This Product, Go to: www.freescale.com



# SECTION 3 SIGNAL DESCRIPTION

This section contains descriptions of the input and output signals. The input and output signals can be functionally organized into the groups shown in Figure 3-1 (for the MC68000, the MC68HC000 and the MC68010), Figure 3-2 (for the MC68HC001), Figure 3-3 (for the MC68EC000), Figure 3-4 (for the MC68008, 48-pin version), and Figure 3-5 (for the MC68008, 52-pin version). The following paragraphs provide brief descriptions of the signals and references (where applicable) to other paragraphs that contain more information about the signals.

#### NOTE

The terms **assertion** and **negation** are used extensively in this manual to avoid confusion when describing 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, independently of whether that level is represented by a high or low voltage. The term negate or negation is used to indicate that a signal is inactive or false.



Figure 3-1. Input and Output Signals (MC68000, MC68HC000 and MC68010)

#### M68000 8-/16-/32-BIT MICROPROCESSORS USER'S MANUAL For More Information On This Product, Go to: www.freescale.com



# **3.11 SIGNAL SUMMARY**

Table 3-4 summarizes the signals discussed in the preceding paragraphs.

|                              |                                                |              |                        |         | i-Z                  |
|------------------------------|------------------------------------------------|--------------|------------------------|---------|----------------------|
| Signal Name                  | Mnemonic                                       | Input/Output | Active State           | On HALT | On Bus<br>Relinquish |
| Address Bus                  | A0–A23                                         | Output       | High                   | Yes     | Yes                  |
| Data Bus                     | D0–D15                                         | Input/Output | High                   | Yes     | Yes                  |
| Address Strobe               | ĀS                                             | Output       | Low                    | No      | Yes                  |
| Read/Write                   | R/W                                            | Output       | Read-High<br>Write-Low | No      | Yes                  |
| Data Strobe                  | DS                                             | Output       | Low                    | No      | Yes                  |
| Upper and Lower Data Strobes | $\overline{\text{UDS}}, \overline{\text{LDS}}$ | Output       | Low                    | No      | Yes                  |
| Data Transfer Acknowledge    | DTACK                                          | Input        | Low                    | No      | No                   |
| Bus Request                  | BR                                             | Input        | Low                    | No      | No                   |
| Bus Grant                    | BG                                             | Output       | Low                    | No      | No                   |
| Bus Grant Acknowledge        | BGACK                                          | Input        | Low                    | No      | No                   |
| Interrupt Priority Level     | ĪPĒ0, ĪPĒ1,<br>ĪPĒ2                            | Input        | Low                    | No      | No                   |
| Bus Error                    | BERR                                           | Input        | Low                    | No      | No                   |
| Mode                         | MODE                                           | Input        | High                   | _       | -                    |
| Reset                        | RESET                                          | Input/Output | Low                    | No*     | No*                  |
| Halt                         | HALT                                           | Input/Output | Low                    | No*     | No*                  |
| Enable                       | E                                              | Output       | High                   | No      | No                   |
| Valid Memory Address         | VMA                                            | Output       | Low                    | No      | Yes                  |
| Valid Peripheral Address     | VPA                                            | Input        | Low                    | No      | No                   |
| Function Code Output         | FC0, FC1,<br>FC2                               | Output       | High                   | No      | Yes                  |
| Clock                        | CLK                                            | Input        | High                   | No      | No                   |
| Power Input                  | VCC                                            | Input        | _                      | _       | _                    |
| Ground                       | GND                                            | Input        | _                      |         | _                    |

| Table 3-4. | Signal | Summary |
|------------|--------|---------|
|------------|--------|---------|

\*Open drain.



The descriptions of the eight states of a write cycle are as follows:

- STATE 0 The write cycle starts in S0. The processor places valid function codes on FC2-FC0 and drives R/W high (if a preceding write cycle has left R/W low).
- STATE 1 Entering S1, the processor drives a valid address on the address bus.
- STATE 2 On the rising edge of S2, the processor asserts  $\overline{AS}$  and drives  $R/\overline{W}$  low.
- STATE 3 During S3, the data bus is driven out of the high-impedance state as the data to be written is placed on the bus.
- STATE 4 At the rising edge of S4, the processor asserts  $\overline{LDS}$ , or  $\overline{DS}$ . The processor waits for a cycle termination signal ( $\overline{DTACK}$  or  $\overline{BERR}$ ) or  $\overline{VPA}$ , an M6800 peripheral signal. When  $\overline{VPA}$  is asserted during S4, the cycle becomes a peripheral cycle (refer to **Appendix B M6800 Peripheral Interface**). If neither termination signal is asserted before the falling edge at the end of S4, the processor inserts wait states (full clock cycles) until either  $\overline{DTACK}$  or  $\overline{BERR}$  is asserted.
- STATE 5 During S5, no bus signals are altered.
- STATE 6 During S6, no bus signals are altered.
- STATE 7 On the falling edge of the clock entering S7, the processor negates  $\overline{AS}$ ,  $\overline{LDS}$ , and  $\overline{DS}$ . As the clock rises at the end of S7, the processor places the address and data buses in the high-impedance state, and drives R/W high. The device negates  $\overline{DTACK}$  or  $\overline{BERR}$  at this time.

# 4.1.3 Read-Modify-Write Cycle.

The read-modify-write cycle performs a read operation, modifies the data in the arithmetic logic unit, and writes the data back to the same address. The address strobe ( $\overline{AS}$ ) remains asserted throughout the entire cycle, making the cycle indivisible. The test and set (TAS) instruction uses this cycle to provide a signaling capability without deadlock between processors in a multiprocessing environment. The TAS instruction (the only instruction that uses the read-modify-write cycle) only operates on bytes. Thus, all read-modify-write cycles are byte operations. Figure 4-5 and 4-6 illustrate the read-modify-write cycle operation.



# SECTION 5 16-BIT BUS OPERATION

The following paragraphs describe control signal and bus operation for 16-bit bus operations during data transfer operations, bus arbitration, bus error and halt conditions, and reset operation. The 16-bit bus operation devices are the MC68000, MC68HC000, MC68010, and the MC68HC001 and MC68EC000 in 16-bit mode. The MC68HC001 and MC68EC000 select 16-bit mode by pulling mode high or leave it floating during reset.

# **5.1 DATA TRANSFER OPERATIONS**

Transfer of data between devices involves the following signals:

- 1. Address bus A1 through highest numbered address line
- 2. Data bus D0 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 cases, the bus master must deskew all signals it issues at both the start and end of a bus cycle. In addition, the bus master must deskew the acknowledge and data signals from the slave device.

The following paragraphs describe the read, write, read-modify-write, and CPU space cycles. The indivisible read-modify-write cycle implements interlocked multiprocessor communications. A CPU space cycle is a special processor cycle.

# 5.1.1 Read Cycle

During a read cycle, the processor receives either one or two bytes of data from the memory or from a peripheral device. If the instruction specifies a word or long-word operation, the MC68000, MC68HC000, MC68HC001, MC68EC000, or MC68010 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 the internal A0 bit to determine which byte to read and issues the appropriate data strobe. When A0 equals zero, the upper data strobe is issued; when A0 equals one, the lower data strobe is issued. When the data is received, the processor internally positions the byte appropriately.

The word read-cycle flowchart is shown in Figure 5-1 and the byte read-cycle flowchart is shown in Figure 5-2. The read and write cycle timing is shown in Figure 5-3 and the word and byte read-cycle timing diagram is shown in Figure 5-4.





#### Figure 5-7. Word and Byte Write-Cycle Timing Diagram

The descriptions of the eight states of a write cycle are as follows:

- STATE 0 The write cycle starts in S0. The processor places valid function codes on FC2-FC0 and drives R/W high (if a preceding write cycle has left R/W low).
- STATE 1 Entering S1, the processor drives a valid address on the address bus.
- STATE 2 On the rising edge of S2, the processor asserts  $\overline{AS}$  and drives R/W low.
- STATE 3 During S3, the data bus is driven out of the high-impedance state as the data to be written is placed on the bus.
- STATE 4 At the rising edge of S4, the processor asserts UDS, or LDS. The processor waits for a cycle termination signal (DTACK or BERR) or VPA, an M6800 peripheral signal. When VPA is asserted during S4, the cycle becomes a peripheral cycle (refer to **Appendix B M6800 Peripheral Interface**. If neither termination signal is asserted before the falling edge at the end of S4, the processor inserts wait states (full clock cycles) until either DTACK or BERR is asserted.
- STATE 5 During S5, no bus signals are altered.
- STATE 6 During S6, no bus signals are altered.

**Freescale Semiconductor, Inc** 





#### Figure 5-18. Bus Arbitration Unit State Diagrams

Figures 5-19, 5-20, and 5-21 applies to all processors using 3-wire bus arbitration. Figures 5-22, 5-23, and 5-24 applies to all processors using 2-wire bus arbitration.

MOTOROLA

M68000 8-/16-/32-BIT MICROPROCESSORS USER'S MANUAL For More Information On This Product, Go to: www.freescale.com





Figure 5-20. 3-Wire Bus Arbitration Timing Diagram—Bus Inactive





Figure 5-29. Halt Operation Timing Diagram

While the processor is halted, the address bus and the data bus signals are placed in the high-impedance state. Bus arbitration is performed as usual. Should a bus error occur while HALT is asserted, the processor performs the retry operation previously described.

The single-step mode is derived from correctly timed transitions of HALT. HALT is negated to allow the processor to begin a bus cycle, then asserted to enter the halt mode when the cycle completes. The single-step mode proceeds through a program one bus cycle at a time for debugging purposes. The halt operation and the hardware trace capability allow tracing of either bus cycles or instructions one at a time. These capabilities and a software debugging package provide total debugging flexibility.

# 5.4.4 Double Bus Fault

When a bus error exception occurs, the processor begins exception processing by stacking information on the supervisor stack. If another bus error occurs during exception processing (i.e., before execution of another instruction begins) the processor halts and asserts  $\overrightarrow{HALT}$ . This is called a double bus fault. Only an external reset operation can restart a processor halted due to a double bus fault.

A retry operation does not initiate exception processing; a bus error during a retry operation does not cause a double bus fault. The processor can continue to retry a bus cycle indefinitely if external hardware requests.



### **6.2 EXCEPTION PROCESSING**

The processing of an exception occurs in four steps, with variations for different exception causes:

- 1. Make a temporary copy of the status register and set the status register for exception processing.
- 2. Obtain the exception vector.
- 3. Save the current processor context.
- 4. Obtain a new context and resume instruction processing.

# **6.2.1 Exception Vectors**

An exception vector is a memory location from which the processor fetches the address of a routine to handle an exception. Each exception type requires a handler routine and a unique vector. All exception vectors are two words in length (see Figure 6-1), except for the reset vector, which is four words long. All exception vectors reside in the supervisor data space, except for the reset vector, which is in the supervisor program space. A vector number is an 8-bit number that is multiplied by four to obtain the offset of an exception vector. Vector numbers are generated internally or externally, depending on the cause of the exception. For interrupts, during the interrupt acknowledge bus cycle, a peripheral provides an 8-bit vector number (see Figure 6-2) to the processor on data bus lines D7–D0.

The processor forms the vector offset by left-shifting the vector number two bit positions and zero-filling the upper-order bits to obtain a 32-bit long-word vector offset. In the MC68000, the MC68HC000, MC68HC001, MC68EC000, and the MC68008, this offset is used as the absolute address to obtain the exception vector itself, which is shown in Figure 6-3.

#### NOTE

In the MC68010, the vector offset is added to the 32-bit vector base register (VBR) to obtain the 32-bit absolute address of the exception vector (see Figure 6-4). Since the VBR is set to zero upon reset, the MC68010 functions identically to the MC68000, MC68HC000, MC68HC001, MC68EC000, and MC68008 until the VBR is changed via the move control register MOVEC instruction.



Figure 6-1. Exception Vector Format





Figure 6-5. Group 1 and 2 Exception Stack Frame (MC68000, MC68HC000, MC68HC001, MC68EC000, and MC68008)



Figure 6-6. MC68010 Stack Frame



# 6.4 RETURN FROM EXCEPTION (MC68010)

In addition to returning from any exception handler routine on the MC68010, the RTE instruction resumes the execution of a suspended instruction by returning to the normal processing state after restoring all of the temporary register and control information stored during a bus error. For the RTE instruction to execute properly, the stack must contain valid and accessible data. The RTE instruction checks for data validity in two ways. First, the format/offset word is checked for a valid stack format code. Second, if the format code indicates the long stack format, the validity of the long stack data is checked as it is loaded into the processor. In addition, the data is checked for accessibility when the processor starts reading the long data. Because of these checks, the RTE instruction executes as follows:

- 1. Determine the stack format. This step is the same for any stack format and consists of reading the status register, program counter, and format/offset word. If the format code indicates a short stack format, execution continues at the new program counter address. If the format code is not an MC68010-defined stack format code, exception processing starts for a format error.
- 2. Determine data validity. For a long-stack format, the MC68010 begins to read the remaining stack data, checking for validity of the data. The only word checked for validity is the first of the 16 internal information words (SP + 26) shown in Figure 5-8. This word contains a processor version number (in bits 10–13) and proprietary internal information that must match the version number of the MC68010 attempting to read the data. This validity check is used to ensure that the data is properly interpreted by the RTE instruction. If the version number is incorrect for this processor, the RTE instruction is aborted and exception processing begins for a format error exception. Since the stack pointer is not updated until the RTE instruction has successfully read all the stack data, a format error occurring at this point does not stack new data over the previous bus error stack information.
- 3. Determine data accessibility. If the long-stack data is valid, the MC68010 performs a read from the last word (SP + 56) of the long stack to determine data accessibility. If this read is terminated normally, the processor assumes that the remaining words on the stack frame are also accessible. If a bus error is signaled before or during this read, a bus error exception is taken. After this read, the processor must be able to load the remaining data without receiving a bus error; therefore, if a bus error occurs on any of the remaining stack reads, the error becomes a double bus fault, and the MC68010 enters the halted state.



# 9.1 OPERAND EFFECTIVE ADDRESS CALCULATION TIMES

Table 9-1 lists the numbers of clock periods required to compute the effective addresses for instructions. The totals include fetching any extension words, computing the address, and fetching the memory operand. The total number of clock periods, the number of read cycles, and the number of write cycles (zero for all effective address calculations) are shown in the previously described format.

|                                               |                                                                                            | Byte                              | , Word                           | Long                               |                                  |  |
|-----------------------------------------------|--------------------------------------------------------------------------------------------|-----------------------------------|----------------------------------|------------------------------------|----------------------------------|--|
|                                               | Addressing Mode                                                                            | Fetch                             | No Fetch                         | Fetch                              | No Fetch                         |  |
|                                               | Register                                                                                   |                                   |                                  |                                    |                                  |  |
| Dn<br>An                                      | Data Register Direct<br>Address Register Direct                                            | <b>0</b> (0/0)<br><b>0</b> (0/0)  | -                                | <b>0</b> (0/0)<br><b>0</b> (0/0)   | _                                |  |
|                                               | Memory                                                                                     |                                   |                                  |                                    |                                  |  |
| (An)<br>(An)+                                 | Address Register Indirect<br>Address Register Indirect with Postincrement                  | <b>4</b> (1/0)<br><b>4</b> (1/0)  | <b>2</b> (0/0)<br><b>4</b> (0/0) | <b>8</b> (2/0)<br><b>8</b> (2/0)   | <b>2</b> (0/0)<br><b>4</b> (0/0) |  |
| –(An)<br>(d <sub>16</sub> , An)               | Address Register Indirect with Predecrement<br>Address Register Indirect with Displacement | <b>6</b> (1/0)<br><b>8</b> (2/0)  | <b>4</b> (0/0)<br><b>4</b> (0/0) | <b>10</b> (2/0)<br><b>12</b> (3/0) | <b>4</b> (0/0)<br><b>4</b> (1/0) |  |
| (d გ, An, Xn)*<br>(xxx).W                     | Address Register Indirect with Index<br>Absolute Short                                     | <b>10</b> (2/0)<br><b>8</b> (2/0) | <b>8</b> (1/0)<br><b>4</b> (1/0) | <b>14</b> (3/0)<br><b>12</b> (3/0) | <b>8</b> (1/0)<br><b>4</b> (1/0) |  |
| (xxx).L<br>(d <sub>16</sub> , PC)             | Absolute Long<br>Program Counter Indirect with Displacement                                | <b>12</b> (3/0)<br><b>8</b> (2/0) | <b>8</b> (2/0)                   | <b>16</b> (4/0)<br><b>12</b> (3/0) | <b>8</b> (2/0)                   |  |
| (d <sub>8</sub> , PC, Xn)*<br># <data></data> | Program Counter Indirect with Index<br>Immediate                                           | <b>10</b> (2/0)<br><b>4</b> (1/0) | -                                | <b>14</b> (3/0)<br><b>8</b> (2/0)  |                                  |  |

| Table 9-1. E | Effective | Address | Calculation | Times |
|--------------|-----------|---------|-------------|-------|
|--------------|-----------|---------|-------------|-------|

\*The size of the index register (Xn) does not affect execution time.

# 9.2 MOVE INSTRUCTION EXECUTION TIMES

Tables 9-2, 9-3, 9-4, and 9-5 list the numbers of clock periods for the move instructions. The totals include instruction fetch, operand reads, and operand writes. The total number of clock periods, the number of read cycles, and the number of write cycles are shown in the previously described format.



|             |      | Lo                   | op Continue     | ed              |                 | Loop Terminated |                 |                 |                 |                 |  |  |
|-------------|------|----------------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|--|--|
|             |      | Valid Count cc False |                 |                 | Valio           | Count cc T      | rue             | E               | pired Coun      | t               |  |  |
| Instruction | Size | (An)                 | (An)+           | –(An)           | (An)            | (An)+           | –(An)           | (An)            | (An)+           | –(An)           |  |  |
| ASR, ASL    | Word | <b>18</b> (1/1)      | <b>18</b> (1/1) | <b>20</b> (1/1) | <b>24</b> (3/1) | <b>24</b> (3/1) | <b>26</b> (3/1) | <b>22</b> (3/1) | <b>22</b> (3/1) | <b>24</b> (3/1) |  |  |
| LSR, LSL    | Word | <b>18</b> (1/1)      | <b>18</b> (1/1) | <b>20</b> (1/1) | <b>24</b> (3/1) | <b>24</b> (3/1) | <b>26</b> (3/1) | <b>22</b> (3/1) | <b>22</b> (3/1) | <b>24</b> (3/1) |  |  |
| ROR, ROL    | Word | <b>18</b> (1/1)      | <b>18</b> (1/1) | <b>20</b> (1/1) | <b>24</b> (3/1) | <b>24</b> (3/1) | <b>26</b> (3/1) | <b>22</b> (3/1) | <b>22</b> (3/1) | <b>24</b> (3/1) |  |  |
| ROXR, ROXL  | Word | <b>18</b> (1/1)      | <b>18</b> (1/1) | <b>20</b> (1/1) | <b>24</b> (3/1) | <b>24</b> (3/1) | <b>26</b> (3/1) | <b>22</b> (3/1) | <b>22</b> (3/1) | <b>24</b> (3/1) |  |  |

 Table 9-13. Shift/Rotate Instruction Loop Mode Execution Times

# 9.7 BIT MANIPULATION INSTRUCTION EXECUTION TIMES

Table 9-14 lists the timing data for the bit manipulation instructions. The total number of clock periods, the number of read cycles, and the number of write cycles are shown in the previously described format. The number of clock periods, the number of read cycles, and the number of write cycles, respectively, must be added to those of the effective address calculation where indicated by a plus sign (+).

|             |      | Dyna             | amic             | Static           |                  |  |  |  |
|-------------|------|------------------|------------------|------------------|------------------|--|--|--|
| Instruction | Size | Register         | Memory           | Register         | Memory           |  |  |  |
| BCHG        | Byte | _                | <b>8</b> (1/1)+  | —                | <b>12</b> (2/1)+ |  |  |  |
|             | Long | <b>8</b> (1/0)*  | —                | <b>12</b> (2/0)* | _                |  |  |  |
| BCLR        | Byte | —                | <b>10</b> (1/1)+ | —                | <b>14</b> (2/1)+ |  |  |  |
|             | Long | <b>10</b> (1/0)* | —                | <b>14</b> (2/0)* | _                |  |  |  |
| BSET        | Byte |                  | 8(1/1)+          |                  | <b>12</b> (2/1)+ |  |  |  |
|             | Long | <b>8</b> (1/0)*  | —                | <b>12</b> (2/0)* | _                |  |  |  |
| BTST        | Byte | _                | <b>4</b> (1/0)+  | _                | <b>8</b> (2/0)+  |  |  |  |
|             | Long | <b>6</b> (1/0)*  | _                | <b>10</b> (2/0)  | _                |  |  |  |

 Table 9-14. Bit Manipulation Instruction Execution Times

+Add effective address calculation time.

\* Indicates maximum value; data addressing mode only.

# 9.8 CONDITIONAL INSTRUCTION EXECUTION TIMES

Table 9-15 lists the timing data for the conditional instructions. The total number of clock periods, the number of read cycles, and the number of write cycles are shown in the previously described format.



| Num                 | Characteristic                                                                                                                     | 8 MHz* |     | 10 MHz* 12.5 M |     | MHz* | z* 16.67 MHz<br>12F |     | 16 MHz |     | 20 MHz* |     | Unit |      |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------|--------|-----|----------------|-----|------|---------------------|-----|--------|-----|---------|-----|------|------|
|                     |                                                                                                                                    | Min    | Max | Min            | Max | Min  | Max                 | Min | Max    | Min | Max     | Min | Max  |      |
| 47 <sup>5</sup>     | Asynchronous Input Setup<br>Time                                                                                                   | 10     |     | 10             | —   | 10   | —                   | 10  |        | 5   | —       | 5   | —    | ns   |
| 48 <sup>2, 3</sup>  | BERR Asserted to DTACK<br>Asserted                                                                                                 | 20     |     | 20             | —   | 20   | —                   | 10  |        | 10  | —       | 10  | —    | ns   |
| 48 <sup>2,3,5</sup> | DTACK Asserted to BERR<br>Asserted (MC68010 Only)                                                                                  | _      | 80  | —              | 55  | —    | 35                  | _   |        | —   | —       | —   | —    | ns   |
| 49 <sup>9</sup>     | $\overline{\text{AS}}$ , $\overline{\text{DS}}$ , Negated to E Low                                                                 | -70    | 70  | -55            | 55  | -45  | 45                  | -35 | 35     | -35 | 35      | -30 | 30   | ns   |
| 50                  | E Width High                                                                                                                       | 450    | _   | 350            | _   | 280  | _                   | 220 | _      | 220 | _       | 190 | _    | ns   |
| 51                  | E Width Low                                                                                                                        | 700    | _   | 550            | _   | 440  | —                   | 340 | _      | 340 | _       | 290 | _    | ns   |
| 53                  | Data-Out Hold from Clock<br>High                                                                                                   | 0      |     | 0              |     | 0    |                     | 0   |        | 0   | —       | 0   | _    | ns   |
| 54                  | E Low to Data-Out Invalid                                                                                                          | 30     |     | 20             | _   | 15   |                     | 10  |        | 10  | _       | 5   | _    | ns   |
| 55                  | R/W Asserted to Data Bus<br>Impedance Change                                                                                       | 30     | —   | 20             | —   | 10   | —                   | 0   | —      | 0   | —       | 0   | —    | ns   |
| 56 <sup>4</sup>     | HALT (RESET Pulse Width                                                                                                            | 10     | _   | 10             | _   | 10   | _                   | 10  | _      | 10  | _       | 10  | _    | clks |
| 57                  | $\overrightarrow{BGACK}$ Negated to $\overrightarrow{AS}$ , $\overrightarrow{DS}$ , $\overrightarrow{R}/\overrightarrow{W}$ Driven | 1.5    | _   | 1.5            | _   | 1.5  | —                   | 1.5 | _      | 1.5 | —       | 1.5 | _    | clks |
| 57A                 | BGACK Negated to FC, VMA Driven                                                                                                    | 1      | _   | 1              | _   | 1    | —                   | 1   | _      | 1   | —       | 1   |      | clks |
| 58 <sup>7</sup>     | $\overline{\text{BR}}$ Negated to $\overline{\text{AS}}$ , $\overline{\text{DS}}$ , $\text{R}/\overline{\text{W}}$ Driven          | 1.5    | _   | 1.5            | _   | 1.5  | _                   | 1.5 | _      | 1.5 | —       | 1.5 | _    | clks |
| 58A <sup>7</sup>    | $\overline{\text{BR}}$ Negated to FC, $\overline{\text{AS}}$ Driven                                                                | 1      | _   | 1              | _   | 1    | —                   | 1   | _      | 1   | _       | 1   | _    | clks |

\*These specifications represent improvement over previously published specifications for the 8-, 10-, and 12.5-MHz MC68000 and are valid only for product bearing date codes of 8827 and later.

\*\* This frequency applies only to MC68HC000 and MC68HC001.

#### NOTES:

- 1. For a loading capacitance of less than or equal to 50 pF, subtract 5 ns 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 ignored. In the absence of DTACK, BERR is an asynchronous input using the asynchronous input setup time (#47).
- 4. For power-up, the MC68000 must be held in the reset 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 processor.
- 5. If the asynchronous input setup time (#47) requirement is satisfied for DTACK, the DTACK asserted to data setup time (#31) requirement can be ignored. The data must only satisfy the data-in to clock low setup time (#27) for the following clock cycle.
- 6. When  $\overline{AS}$  and R/W are equally loaded (±20;pc), subtract 5 ns 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.
- 9. The falling edge of S6 triggers both the negation of the strobes (AS and DS) 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 E.
- 10. 245 ns for the MC68008.
- 11. 50 ns for the MC68008
- 12. 50 ns for the MC68008.



# 10.14 MC68EC000 AC ELECTRICAL SPECIFICATIONS — READ AND

**WRITE CYCLES** (VCC=5.0 VDC  $\pm$  5;PC; GND = 0 VDC; T<sub>A</sub> = T<sub>L</sub> TO T<sub>H</sub>; (See Figures

10-12 and 10-13)

| Num                | Characteristic                                                                               | 8 N | /IHz | 10 1 | ИHz | 12.5 | MHz | 16.67 MHz |     | 20 MHz |     | Unit |
|--------------------|----------------------------------------------------------------------------------------------|-----|------|------|-----|------|-----|-----------|-----|--------|-----|------|
|                    |                                                                                              | Min | Max  | Min  | Max | Min  | Max | Min       | Max | Min    | Max |      |
| 6                  | Clock Low to Address Valid                                                                   | _   | 35   | _    | 35  | _    | 35  | _         | 30  | —      | 25  | ns   |
| 6A                 | Clock High to FC Valid                                                                       | _   | 35   | _    | 35  | _    | 35  | _         | 30  | 0      | 25  | ns   |
| 7                  | Clock High to Address, Data Bus<br>High Impedance (Maximum)                                  | -   | 55   | —    | 55  | —    | 55  | —         | 50  | —      | 42  | ns   |
| 8                  | Clock High to Address, FC Invalid (Minimum)                                                  | 0   | —    | 0    | —   | 0    | —   | 0         |     | 0      | —   | ns   |
| 91                 | Clock High to AS, DS Asserted                                                                | 3   | 35   | 3    | 35  | 3    | 35  | 3         | 30  | 3      | 25  | ns   |
| 11 <sup>2</sup>    | Address Valid to AS, DS Asserted<br>(Read)/AS Asserted (Write)                               | 30  | —    | 20   | —   | 15   | —   | 15        | —   | 10     | _   | ns   |
| 11A <sup>2</sup>   | FC Valid to <del>AS</del> , <del>DS</del> Asserted<br>(Read)/ <del>AS</del> Asserted (Write) | 45  | —    | 45   | —   | 45   | —   | 45        | —   | 40     | _   | ns   |
| 12 <sup>1</sup>    | Clock Low to $\overline{AS}$ , $\overline{DS}$ Negated                                       | 3   | 35   | 3    | 35  | 3    | 35  | 3         | 30  | 3      | 25  | ns   |
| 13 <sup>2</sup>    | AS, DS Negated to Address, FC Invalid                                                        | 15  | —    | 15   | —   | 15   | _   | 15        |     | 10     | —   | ns   |
| 14 <sup>2</sup>    | AS (and DS Read) Width Asserted                                                              | 270 | _    | 195  | —   | 160  | -   | 120       |     | 100    | —   | ns   |
| 14A <sup>2</sup>   | DS Width Asserted (Write)                                                                    | 140 |      | 95   |     | 80   |     | 60        |     | 50     | —   | ns   |
| 15 <sup>2</sup>    | AS, DS Width Negated                                                                         | 150 | _    | 105  | _   | 65   | —   | 60        | _   | 50     | —   | ns   |
| 16                 | Clock High to Control Bus High<br>Impedance                                                  | —   | 55   | —    | 55  | —    | 55  | —         | 50  | -      | 42  | ns   |
| 17 <sup>2</sup>    | AS, DS Negated to R/W Invalid                                                                | 15  | _    | 15   |     | 15   | _   | 15        | _   | 10     | _   | ns   |
| 18 <sup>1</sup>    | Clock High to R/W High (Read)                                                                | 0   | 35   | 0    | 35  | 0    | 35  | 0         | 30  | 0      | 25  | ns   |
| 20 <sup>1</sup>    | Clock High to R/W Low (Write)                                                                | 0   | 35   | 0    | 35  | 0    | 35  | 0         | 30  | 0      | 25  | ns   |
| 20A <sup>2,6</sup> | $\overline{\text{AS}}$ Asserted to R/ $\overline{\text{W}}$ Low (Write)                      | -   | 10   | —    | 10  | _    | 10  | —         | 10  | —      | 10  | ns   |
| 21 <sup>2</sup>    | Address Valid to R/W Low (Write)                                                             | 0   | _    | 0    | _   | 0    | _   | 0         |     | 0      | —   | ns   |
| 21A <sup>2</sup>   | FC Valid to R/W Low (Write)                                                                  | 60  | _    | 50   | _   | 30   | _   | 30        | —   | 25     | —   | ns   |
| 22 <sup>2</sup>    | $R/\overline{W}$ Low to $\overline{DS}$ Asserted (Write)                                     | 80  | _    | 50   |     | 30   | _   | 30        | _   | 25     | _   | ns   |
| 23                 | Clock Low to Data-Out Valid<br>(Write)                                                       | —   | 35   | —    | 35  | _    | 35  | _         | 30  | -      | 25  | ns   |
| 25 <sup>2</sup>    | AS, DS Negated to Data-Out<br>Invalid (Write)                                                | 40  | _    | 30   | —   | 20   | _   | 15        |     | 10     | —   | ns   |
| 26 <sup>2</sup>    | Data-Out Valid to DS Asserted<br>(Write)                                                     | 40  | —    | 30   | —   | 20   | —   | 15        |     | 10     | —   | ns   |
| 27 <sup>5</sup>    | Data-In Valid to Clock Low (Setup Time on Read)                                              | 5   | _    | 5    | _   | 5    | —   | 5         |     | 5      | —   | ns   |
| 28 <sup>2</sup>    | AS, DS Negated to DTACK<br>Negated (Asynchronous Hold)                                       | 0   | 110  | 0    | 110 | 0    | 110 | 0         | 110 | 0      | 95  | ns   |
| 28A                | Clock High to DTACK Negated                                                                  | 0   | 110  | 0    | 110 | 0    | 110 | 0         | 110 | 0      | 95  | ns   |



# 10.15 MC68EC000 AC ELECTRICAL SPECIFICATIONS—BUS

**ARBITRATION** (VCC=5.0VDC  $\pm$  5%; GND=0 VDC; T<sub>A</sub> = T<sub>L</sub> TO T<sub>H</sub>; see Figure 10-14)

| Num              | Characteristic                                                              | 8 N | /IHz | 10  | MHz | 12.5 | MHz | 16.67 | 7 MHz | 20 MHz |     | Unit |
|------------------|-----------------------------------------------------------------------------|-----|------|-----|-----|------|-----|-------|-------|--------|-----|------|
|                  |                                                                             | Min | Max  | Min | Max | Min  | Max | Min   | Max   | Min    | Max |      |
| 7                | Clock High to Address, Data<br>Bus High Impedance<br>(Maximum)              | _   | 55   |     | 55  |      | 55  |       | 50    | _      | 42  | ns   |
| 16               | Clock High to Control Bus High<br>Impedance                                 |     | 55   |     | 55  |      | 55  |       | 50    | _      | 42  | ns   |
| 33               | Clock High to BG Asserted                                                   |     | 35   |     | 35  |      | 35  | 0     | 30    | 0      | 25  | ns   |
| 34               | Clock High to BG Negated                                                    | _   | 35   |     | 35  |      | 35  | 0     | 30    | 0      | 25  | ns   |
| 35               | BR Asserted to BG Asserted                                                  | 1.5 | 3.5  | 1.5 | 3.5 | 1.5  | 3.5 | 1.5   | 3.5   | 1.5    | 3.5 | Clks |
| 367              | BR Negated to BG Negated                                                    | 1.5 | 3.5  | 1.5 | 3.5 | 1.5  | 3.5 | 1.5   | 3.5   | 1.5    | 3.5 | Clks |
| 38               | BG Asserted to Control,<br>Address, Data Bus High<br>Impedance (AS Negated) | _   | 55   | _   | 55  | _    | 55  | _     | 50    | —      | 42  | ns   |
| 39               | BG Width Negated                                                            | 1.5 |      | 1.5 |     | 1.5  | _   | 1.5   | _     | 1.5    | _   | Clks |
| 47               | Asynchronous Input Setup<br>Time                                            | 5   | _    | 5   | _   | 5    | _   | 5     | _     | 5      | _   | ns   |
| 58 <sup>1</sup>  | BR Negated to AS, DS, R/W<br>Driven                                         | 1.5 | _    | 1.5 | —   | 1.5  | _   | 1.5   | _     | 1.5    | _   | Clks |
| 58A <sup>1</sup> | BR Negated to FC Driven                                                     | 1   | _    | 1   | _   | 1    | _   | 1     | _     | 1      | _   | Clks |

NOTES: 1.The minimum value must be met to guarantee proper operation. If the maximum value is exceeded, BG may be reasserted.

2. $\overline{\text{DS}}$  is used in this specification to indicate  $\overline{\text{UDS}}$  and  $\overline{\text{LDS}}$ .







M68000 8-/16-/32-BIT MICROPROCESSORS USER'S MANUAL



| Opcodes                                                                            | Applicable Addressing Modes                                                                                                                                       |
|------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MOVE [BWL]                                                                         | (Ay) to (Ax)<br>(Ay) to (Ax)+<br>(Ay) to $-(Ax)$<br>(Ay)+ to (Ax)<br>(Ay)+ to $-(Ax)$<br>-(Ay) to (Ax)<br>-(Ay) to (Ax)+<br>-(Ay) to $-(Ax)Ry to (Ax)Ry to (Ax)+$ |
| ADD [BWL]<br>AND [BWL]<br>CMP [BWL]<br>OR [BWL]<br>SUB [BWL]                       | (Ay) to Dx<br>(Ay)+ to Dx<br>–(Ay) to Dx                                                                                                                          |
| ADDA [WL]<br>CMPA [WL]<br>SUBA [WL]                                                | (Ay) to Ax<br>-(Ay) to Ax<br>(Ay)+ to Ax                                                                                                                          |
| ADD [BWL]<br>AND [BWL]<br>EOR [BWL]<br>OR [BWL]<br>SUB [BWL]                       | Dx to (Ay)<br>Dx to (Ay)+<br>Dx to –(Ay)                                                                                                                          |
| ABCD [B]<br>ADDX [BWL]<br>SBCD [B]<br>SUBX [BWL]                                   | -(Ay) to -(Ax)                                                                                                                                                    |
| CMP [BWL]                                                                          | (Ay)+ to (Ax)+                                                                                                                                                    |
| CLR [BWL]<br>NEG [BWL]<br>NEGX [BWL}<br>NOT [BWL]<br>TST [BWL]<br>NBCD [B]         | (Ay)<br>(Ay)+<br>–(Ay)                                                                                                                                            |
| ASL [W]<br>ASR [W]<br>LSL [W]<br>LSR [W]<br>ROL [W]<br>ROR [W]<br>ROXL [W]<br>ROXR | (Ay) by #1<br>(Ay)+ by #1<br>–(Ay) by #1                                                                                                                          |

#### Table A-1. MC68010 Loop Mode Instructions

NOTE: [B, W, or L] indicate an operand size of byte, word, or long word.