

#### 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

| Product Status                  | Obsolete                                                    |
|---------------------------------|-------------------------------------------------------------|
| Core Processor                  | 68040                                                       |
| Number of Cores/Bus Width       | 1 Core, 32-Bit                                              |
| Speed                           | 25MHz                                                       |
| 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                  | 179-BPGA                                                    |
| Supplier Device Package         | 179-PGA (47.24x47.24)                                       |
| Purchase URL                    | https://www.e-xfl.com/pro/item?MUrl=&PartUrl=mc68lc040rc25a |
|                                 |                                                             |

Email: info@E-XFL.COM

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



# LIST OF ILLUSTRATIONS (Continued)

| Figure<br>Numbe | er Title                                                   | Page<br>Number |
|-----------------|------------------------------------------------------------|----------------|
| 7-26            | Word Write Access Terminated with TEA Timing               | 7-39           |
| 7-27            | Line Read Access Terminated with TEA Timing                | 7-40           |
| 7-28            | Retry Read Transfer Timing                                 | 7-41           |
| 7-29            | Retry Operation on Line Write                              | 7-42           |
| 7-30            | M68040 Internal Interpretation State Diagram and           | 7 47           |
| 7-31            | Lock Violation Example                                     | 7-47           |
| 7-31            | Processor Bus Request Timing                               | 7-50           |
| 7-32            | Arbitration During Relinquish and Retry Timing             | 7-51           |
| 7-34            | Implicit Bus Ownership Arbitration Timing                  | 7-52           |
| 7-34            | Dual M680/0 Eaimess Arbitration State Diagram              | 7-52<br>7-53   |
| 7-36            | Dual M68040 Prioritized Arbitration State Diagram          | 7-55<br>7-55   |
| 7-30            | M68040 Synchronous DMA Arbitration                         | 7-55           |
| 7-38            | Sample Synchronizer Circuit                                | 7-50<br>7-57   |
| 7-30            | M68040 Asynchronous DMA Arbitration                        | 7-57<br>7-58   |
| 7- <u>3</u> 3   | Snoon-Inhibited Bus Cycle                                  | 7-50<br>7-61   |
| 7-40            | Snoop Access with Memory Response                          | 7-62           |
| 7-42            | Snooped Line Read Memory Inhibited                         | 7-64           |
| 7-43            | Snooped Long-Word Write Memory Inhibited                   | 7-65           |
| 7-44            | Initial Power-On Reset Timing                              | 7-66           |
| 7-45            | Normal Reset Timing                                        | 7-67           |
| 7-46            | Multiplexed Address and Data Bus (Line Write)              | 7-69           |
| 7-47            | DI E Mode Block Diagram                                    | 7-70           |
| 7-48            | DI E versus Normal Data Read Timing                        | 7-71           |
| 7 40            |                                                            |                |
| 8-1             | General Exception Processing Flowchart                     | 8-3            |
| 8-2             | General Form of Exception Stack Frame                      | 8-4            |
| 8-3             | Interrupt Recognition Examples                             | 8-14           |
| 8-4             | Interrupt Exception Processing Flowchart                   | 8-16           |
| 8-5             | Reset Exception Processing Flowchart                       | 8-18           |
| 8-6             | Flowchart of RTE Instruction for Throwaway Four-Word Frame | 8-22           |
| 8-7             | Special Status Word Format                                 | 8-24           |
| 8-8             | Write-Back Status Format                                   | 8-26           |
| 9-1             | Floating-Point User Programming Model                      | 9-2            |
| 9-2             | Floating-Point Control Register                            | 9-4            |
| 9-3             | FPSR Condition Code Byte                                   | 9-4            |
| 9-4             | FPSR Quotient Byte                                         | 9-5            |
| 9-5             | FPSR Exception Status Byte                                 | 9-5            |
| 9-6             | FPSR Accrued Exception Byte                                | 9-6            |
| 9-7             | Intermediate Result Format                                 | 9-12           |
| 9-8             | Rounding Algorithm Flowchart                               | 9-14           |



# LIST OF ILLUSTRATIONS (Continued)

| Figuro<br>Numbo | er Title                                              | Page<br>Number |
|-----------------|-------------------------------------------------------|----------------|
| B-10            | Snoop Hit Timing                                      | B-19           |
| B-11            | Snoop Miss Timing                                     | B-20           |
| B-12            | Other Signal Timing                                   | B-21           |
| C-1             | MC68040V and MC68EC040V Functional Signal Groups      | C-3            |
| C-2             | MC68040V and MC68EC040V Initial Power-On Reset Timing | C-8            |
| C-3             | MC68040V and MC68EC040V Normal Reset Timing           | C-9            |
| C-4             | MC68040V and MC68EC040V Test Logic Block Diagram      | C-11           |
| C-5             | Bypass Register                                       | C-13           |
| C-6             | Output Latch Cell (O.Latch)                           | C-14           |
| C-7             | Input Pin Cell (I.Pin)                                | C-14           |
| C-8             | Output Control Cells (IO.Ctl)                         | C-15           |
| C-9             | General Arrangement of Bidirectional Pins             | C-15           |
| C-10            | Circuit Disabling IEEE Standard 1149.1A               | C-17           |
| C-11            | Drive Levels and Test Points for AC Specifications    | C-18           |
| C-12            | Clock Input Timing Diagram                            | C-21           |
| C-13            | Read/Write Timing                                     | C-24           |
| C-14            | Bus Arbitration Timing                                | C-25           |
| C-15            | Snoop Hit Timing                                      | C-26           |
| C-16            | Snoop Miss Timing                                     | C-27           |
| C-17            | Other Signal Timing                                   | C-28           |
| C-18            | Going into LPSTOP with Arbitration                    | C-29           |
| C-19            | LPSTOP no Arbitration, CPU is Master                  | C-30           |
| C-20            | Exiting LPSTOP with Interrupt                         | C-31           |
| C-21            | Exiting of LPSTOP with RESET                          | C-31           |



### **3.2.6 Address Translation Protection**

The M68040 MMUs provide separate translation tables for supervisor and user address spaces. The translation tables contain both mapping and protection information. Each table and page descriptor includes a write-protect (W) bit that can be set to provide write protection at any level. Page descriptors also contain a supervisor-only (S) bit that can limit access to programs operating at the supervisor privilege level.

The protection mechanisms can be used individually or in any combination to protect:

- Supervisor address space from accesses by user programs.
- User address space from accesses by other user programs.
- Supervisor and user program spaces from write accesses (implicitly supported by designating all memory pages used for program storage as write protected).
- One or more pages of memory from write accesses.

**3.2.6.1 SUPERVISOR AND USER TRANSLATION TABLES.** One way of protecting supervisor and user address spaces from unauthorized accesses is to use separate supervisor and user translation tables. Separate trees protect supervisor programs and data from accesses by user programs and user programs and data from accesses by supervisor programs. Access is granted to the supervisor programs that can accesses any area of memory with MOVES. The translation table pointed to by the SRP is selected for all other supervisor mode accesses. This translation table can be common to all tasks. Figure 3-17 illustrates separate translation tables for supervisor accesses and for two user tasks that share the common supervisor space. Each user task has an translation table with unique mappings for the logical addresses in its user address space.

**3.2.6.2 SUPERVISOR ONLY.** A second mechanism protects supervisor programs and data without requiring segmenting of the logical address space into supervisor and user address spaces. Page descriptors contain S-bits to protect areas of memory from access by user programs. When a table search for a user access encounters an S-bit set in a page descriptor, the table search ends, and an ATC descriptor corresponding to the logical address is created with the S-bit set. A subsequent retry of the user access results in an access error exception being taken. The S-bit can be used to protect one or more pages from user program access. Supervisor and user mode accesses can share descriptors by using indirect descriptors or by sharing tables. The entire user and supervisor address spaces can be mapped together by loading the same root pointer address into both the SRP and URP registers.





\* Refers to either instruction or data transparent translation register.

Figure 3-22. Address Translation Flowchart



MC68030 and MC68851 cause F-line unimplemented instruction exceptions if executed in either supervisor or user mode by the M68040.

### 3.7.4 Register Programming Considerations

If the entries in the ATCs are no longer valid when a reset operation occurs (as is normally expected), an explicit flush operation must be specified by the system software. The assertion of RSTI disables translation by clearing the E-bits of the TCR, DTTRx, and ITTRx, but it does not flush the ATCs. Reading or writing any of the MMU registers (URP, SRP, TCR, MMUSR, DTTR0, DTTR1, ITTR0, ITTR1) does not flush the ATCs. Since a write to these registers can cause some or all the address translations to change, the write should be followed by a PFLUSH operation to flush the ATCs if necessary.

The status bits in the MMUSR indicate conditions to which the operating system should respond. In a typical access error exception handler, the flowchart illustrated in Figure 3-23 can be used to determine the cause of an MMU fault. The PTEST instruction sets the bits in the MMUSR appropriately, and the program can branch to the appropriate code segment for the condition.



# Freescale Semiconductor, Inc.

|                                                                    | Current State |                                                                                                                              |             |                                                                                                                               |    |                                                                                                                                                                          |  |  |
|--------------------------------------------------------------------|---------------|------------------------------------------------------------------------------------------------------------------------------|-------------|-------------------------------------------------------------------------------------------------------------------------------|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Cache Operation                                                    |               | Invalid Cases                                                                                                                | Valid Cases |                                                                                                                               |    | Dirty Cases                                                                                                                                                              |  |  |
| CPU Read Miss                                                      | 11            | Read line from<br>memory; supply data<br>to CPU and update<br>cache; go to valid<br>state.                                   | V1          | Read line from<br>memory; supply data<br>to CPU and update<br>cache (replacing old<br>line); remain in current<br>state.      | D1 | Buffer dirty cache line;<br>read new line from<br>memory; supply data<br>to CPU and update<br>cache; write buffered<br>dirty data to memory;<br>go to valid state.       |  |  |
| CPU Read Hit                                                       | 12            | Not Possible                                                                                                                 | V2          | Supply data to CPU; remain in current state.                                                                                  | D2 | Supply data to CPU; remain in current state.                                                                                                                             |  |  |
| CPU Write Miss<br>(Copyback)                                       | 13            | Read line from<br>memory into cache;<br>write data to cache;<br>set Dn bits of modified<br>long words; go to dirty<br>state. | V3          | Read line from<br>memory into cache<br>(replacing old line);<br>write data to cache<br>and set Dn bits; go to<br>dirty state. | D3 | Buffer dirty cache line;<br>read new line from<br>memory; write data to<br>cache and set Dn bits;<br>write buffered dirty<br>data to memory;<br>remain in current state. |  |  |
| CPU Write Miss<br>(Write-through)                                  | 14            | Write data to memory;<br>remain in current state.                                                                            | V4          | Write data to memory;<br>remain in current state.                                                                             | D4 | Write data to memory;<br>remain in current state<br>(see note).                                                                                                          |  |  |
| CPU Write Hit<br>(Copyback)                                        | 15            | Not Possible                                                                                                                 | V5          | Write data into cache;<br>set Dn bits of modified<br>long words; go to dirty<br>state.                                        | D5 | Write data in cache;<br>set Dn bits of modified<br>long words; remain in<br>current state.                                                                               |  |  |
| CPU Write Hit<br>(Write-through)                                   | 16            | Not Possible                                                                                                                 | V6          | Write data to cache;<br>write data to memory;<br>remain in current state.                                                     | D6 | Write data into cache<br>(no change to Dn bits);<br>write data to memory;<br>remain in current state<br>(see note).                                                      |  |  |
| Cache Invalidate<br>(CINV)                                         | 17            | No action; remain in current state.                                                                                          | V7          | No action; go to invalid state.                                                                                               | D7 | No action (dirty data<br>lost); go to invalid<br>state.                                                                                                                  |  |  |
| Cache Push<br>(CPUSH)                                              | 18            | No action; remain in current state.                                                                                          | V8          | No action; go to invalid state.                                                                                               | D8 | Write dirty data to<br>memory; go to invalid<br>state.                                                                                                                   |  |  |
| Alternate Master Read Hit<br>(Snoop Control = 01<br>— Leave Dirty) | 19            | Not Possible                                                                                                                 | V9          | No action; remain in current state.                                                                                           | D9 | Inhibit memory and source data; remain in current state.                                                                                                                 |  |  |

#### Table 4-4. Data-Cache Line State Transitions

NOTE: Dirty state transitions D4 and D6 are the result of a system programming error and should be avoided even though they are technically valid.



### 5.3.2 Transfer Modifier (TM2–TM0)

These three-state outputs provide supplemental information for each transfer type. Table 5-3 lists the encoding for normal and MOVE16 transfers, and Table 5-4 lists the encoding for alternate access transfers. For interrupt acknowledge transfers, the TMx signals carry the interrupt level being acknowledged; for breakpoint acknowledge transfers and LPSTOP broadcast cycles on the MC68040V and MC68EC040V, the TMx signals are low. When the M68040 is not the bus master, the TMx signals are set to a high-impedance state.

| TM2 | TM1 | ТМО | Transfer Modifier            |
|-----|-----|-----|------------------------------|
| 0   | 0   | 0   | Data Cache Push Access       |
| 0   | 0   | 1   | User Data Access*            |
| 0   | 1   | 0   | User Code Access             |
| 0   | 1   | 1   | MMU Table Search Data Access |
| 1   | 0   | 0   | MMU Table Search Code Access |
| 1   | 0   | 1   | Supervisor Data Access*      |
| 1   | 1   | 0   | Supervisor Code Access       |
| 1   | 1   | 1   | Reserved                     |

# Table 5-3. Normal and MOVE16 AccessTransfer Modifier Encoding

\* MOVE16 accesses use only these encodings.

| TM2 | TM1 | TM0 | Transfer Modifier       |
|-----|-----|-----|-------------------------|
| 0   | 0   | 0   | Logical Function Code 0 |
| 0   | 0   | 1   | Reserved                |
| 0   | 1   | 0   | Reserved                |
| 0   | 1   | 1   | Logical Function Code 3 |
| 1   | 0   | 0   | Logical Function Code 4 |
| 1   | 0   | 1   | Reserved                |
| 1   | 1   | 0   | Reserved                |
| 1   | 1   | 1   | Logical Function Code 7 |

### 5.3.3 Transfer Line Number (TLN1, TLN0)

These three-state outputs indicate which line in the set of four data cache lines is being accessed for normal push and line data read accesses. TLNx signals are undefined for all other accesses to instruction space and are placed in a high-impedance state when the processor relinquishes the bus.



### Freescale Semiconductor, Inc.

| Hex | PST3 | PST2 | PST1 | PST0 | Internal Status                                      |  |
|-----|------|------|------|------|------------------------------------------------------|--|
| 0   | 0    | 0    | 0    | 0    | User, Start/Continue Current Instruction             |  |
| 1   | 0    | 0    | 0    | 1    | User, End Current Instruction                        |  |
| 2   | 0    | 0    | 1    | 0    | User, Branch Not Taken/End Current Instruction       |  |
| 3   | 0    | 0    | 1    | 1    | User, Branch Taken/End Current Instruction           |  |
| 4   | 0    | 1    | 0    | 0    | User, Table Search                                   |  |
| 5   | 0    | 1    | 0    | 1    | Halted State (Double Bus Fault)                      |  |
| 6   | 0    | 1    | 1    | 0    | Low-Power Stop Mode (Supervisor Instruction)*        |  |
| 7   | 0    | 1    | 1    | 1    | Reserved                                             |  |
| 8   | 1    | 0    | 0    | 0    | Supervisor, Start/Continue Current Instruction       |  |
| 9   | 1    | 0    | 0    | 1    | Supervisor, End Current Instruction                  |  |
| А   | 1    | 0    | 1    | 0    | Supervisor, Branch Not Taken/End Current Instruction |  |
| В   | 1    | 0    | 1    | 1    | Supervisor, Branch Taken/End Current Instruction     |  |
| С   | 1    | 1    | 0    | 0    | Supervisor, Table Search                             |  |
| D   | 1    | 1    | 0    | 1    | Stopped State (Supervisor Instruction)               |  |
| E   | 1    | 1    | 1    | 0    | RTE Executing                                        |  |
| F   | 1    | 1    | 1    | 1    | Exception Stacking                                   |  |

#### Table 5-6. Processor Status Encoding

NOTE: \*MC68040V and MC68EC040V only.

When a 'branch taken/end current instruction' is indicated, it means that a change of instruction flow is pending. Along with the following instructions, an exception stacking (encoding F) sequence is ended with the 'supervisor, branch taken/end current instruction' encoding as though it were a virtual JMP instruction. This includes all the possible exceptions listed in the processor's vector table. Instructions that cause a 'branch taken/end current instruction' encoding when they are executed are as follows:

| ANDI to SR  | DBcc (Taken)   | MOVE to SR | RTD  |
|-------------|----------------|------------|------|
| Bcc (Taken) | FBcc (Taken)   | MOVE USP   | RTE  |
| BRA         | FDBcc (Always) | MOVEC      | RTR  |
| BSR         | FMOVEM Rc,MRn  | MOVES      | RTS  |
| CAS         | FMOVEM FPm,MRn | NOP        | STOP |
| CAS2        | FSAVE          | ORI to SR  | TAS  |
| CINV        | JMP            | PFLUSH     |      |
| CPUSH       | JSR            | PTEST      |      |

The Bcc (not taken) and DBcc (not taken) are the only instructions that cause a 'branch not taken/end current instruction' encoding. Note that the FBcc (not taken) is not included in this category. The FBcc (not taken) instruction ends with an 'end current instruction' encoding. All other instructions and conditions end with the 'end current instruction' encoding. For instance, if the processor is running back-to-back single clock instructions, the encoding 'end current instruction' remains asserted for as many clock cycles as instructions.

#### M68040 USER'S MANUAL For More Information On This Product, Go to: www.freescale.com





Figure 8-3. Interrupt Recognition Examples

Note that a mask value of 6 and a mask value of 7 both inhibit request levels of 1–6 from being recognized. In addition, neither masks a transition to an interrupt request level of 7. The only difference between mask values of 6 and 7 occurs when the interrupt request level is 7 and the mask value is 7. If the mask value is lowered to 6, a second level 7 interrupt is recognized.

External circuitry can chain or otherwise merge signals from devices at each level, allowing an unlimited number of devices to interrupt the processor. When several devices are connected to the same interrupt level, each device should hold its interrupt priority level constant until its corresponding interrupt acknowledge bus cycle ensures that all requests are processed. Refer to **Section 7 Bus Operation** for details on the interrupt acknowledge cycle.





Figure 8-5. Reset Exception Processing Flowchart

After the initial instruction is prefetched, program execution begins at the address in the PC. The reset exception does not flush the ATCs or invalidate entries in the instruction or data caches; it does not save the value of either the PC or the SR. If an access fault or address error occurs during the exception processing sequence for a reset, a double bus fault is generated. The processor halts, and the processor status (PST3–PST0) signals indicate \$5. Execution of the reset instruction does not cause a reset exception, or affect



### **Freescale Semiconductor, Inc.**

exception instead of executing the exception handler for the original exception condition. For example, if simultaneous interrupt and trap exceptions are pending, the exception processing for the trap exception occurs first, followed immediately by exception processing for the interrupt. When the processor resumes normal instruction execution, it is in the interrupt handler, which returns to the trap exception handler.

- Exception processing for access error exceptions creates a format \$7 stack frame that contains status information that can indicate a pending trace, floating-point post-instruction, or unimplemented floating-point instruction exception. The RTE instruction used to return from the access error exception handler checks the status bits for one of these pending exceptions. If one is indicated, the RTE changes the access error stack frame to match the pending exception and fetches the vector for the exception. Instruction exception the new exception handler.
- If an access error, trace, and one of the two (mutually exclusive) floating-point exceptions occur simultaneously, the pending floating-point exception is indicated in the access error stack and the trace exception flag is undefined. The exception handler for the floating-point exception must check the trace bits on the stack and call the trace handler directly (after adjusting the stack frame to match the format for the trace exception).
- If a trace exception is pending at the same time an exception priority level 3 or floating-point post-instruction exception is pending, the trace exception is not reported, and the exception handler for the other exception condition must check for the trace condition.

# **8.4 RETURN FROM EXCEPTIONS**

After the processor has completed executing the exception handlers for all pending exceptions, the processor resumes normal instruction execution at the address in the processor's vector table for the last exception processed. Once the exception handler has completed execution, if possible the processor must return the system context as it was prior to the exception using the RTE instruction. (If the internal data of the exception stack frames are manipulated, M68040 may enter into an undefined state; this applies specifically to the SSW on the access error stack frames.)

When the processor executes an RTE instruction, it examines the stack frame on top of the active supervisor stack to determine if it is a valid frame and what type of context restoration it requires. If during restoration, a stack frame has an odd address PC and an SR that indicates user trace mode enabled, then an address error is taken. The SR stacked for the address error has the SR S-bit set. For previous members of the M68000 family the S-bit is clear. When the M68040 writes or reads a stack frame, it uses longword operand transfers wherever possible. Using a long-word-aligned stack pointer greatly enhances exception processing performance. The processor does not necessarily read or write the stack frame data in sequential order. The system software should not depend on a particular exception generating a particular stack frame. For compatibility with future devices, the software should be able to handle any format of stack frame for any type of exception. The following paragraphs discuss in detail each stack frame format.



# Freescale Semiconductor, Inc.

| FSAVE State<br>Frame Field | Contents                                                                                                        |  |  |  |  |  |
|----------------------------|-----------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
|                            | OVFL (FMOVE to Memory)                                                                                          |  |  |  |  |  |
| CMDREG1B                   | FMOVE instruction command word                                                                                  |  |  |  |  |  |
| FPTEMP                     | Intermediate result with mantissa rounded to correct precision.                                                 |  |  |  |  |  |
| STAG                       | Source Operand Tag = Normalized                                                                                 |  |  |  |  |  |
| E1                         | Always 1                                                                                                        |  |  |  |  |  |
| Т                          | Always 1                                                                                                        |  |  |  |  |  |
|                            | UNFL (FMOVE to Register, FABS, and FNEG)                                                                        |  |  |  |  |  |
| CMDREG1B                   | Exception Instruction Command Word                                                                              |  |  |  |  |  |
| FPTEMP                     | Unrounded, Extended-Precision Intermediate Result                                                               |  |  |  |  |  |
| STAG                       | Source Operand Tag = Normalized                                                                                 |  |  |  |  |  |
| E1                         | Always 1                                                                                                        |  |  |  |  |  |
| Т                          | Always 0                                                                                                        |  |  |  |  |  |
|                            | UNFL (FADD, FSUB, FMUL, FDIV, and FSQRT)                                                                        |  |  |  |  |  |
| CMDREG3B                   | Encoded Exception Instruction Command Word                                                                      |  |  |  |  |  |
| WBTEMP                     | WBTS, WBTE, and WBTM = intermediate result sign, biased 15-bit exponent, and 64-bit mantissa prior to rounding. |  |  |  |  |  |
| WBTE15                     | Bit 15 of the intermediate result's 16-bit exponent = 1 for underflow.                                          |  |  |  |  |  |
| WBTM1, WBTM0,<br>SBIT      | Guard, round, and sticky of intermediate result's 67-bit mantissa.                                              |  |  |  |  |  |
| E3                         | Always 1                                                                                                        |  |  |  |  |  |
| Т                          | Either 1 or 0                                                                                                   |  |  |  |  |  |
|                            | UNFL (FMOVE to Memory)                                                                                          |  |  |  |  |  |
| CMDREG1B                   | FMOVE Instruction Command Word                                                                                  |  |  |  |  |  |
| FPTEMP                     | Intermediate result with mantissa prior to rounding.                                                            |  |  |  |  |  |
| STAG                       | Source Operand Tag = Normalized                                                                                 |  |  |  |  |  |
| E1                         | Always 1                                                                                                        |  |  |  |  |  |
| Т                          | Always 1                                                                                                        |  |  |  |  |  |
|                            | DZ                                                                                                              |  |  |  |  |  |
| CMDREG1B                   | M68040FPSP divide by zero can generate.                                                                         |  |  |  |  |  |
| ETEMP                      | Source operand is converted to extended precision.                                                              |  |  |  |  |  |
| STAG                       | Source Operand Tag                                                                                              |  |  |  |  |  |
| FPTEMP                     | Destination operand is converted to extended precision.                                                         |  |  |  |  |  |
| E1                         | Always 1                                                                                                        |  |  |  |  |  |
| Т                          | Always 0                                                                                                        |  |  |  |  |  |

#### Table 9-16. State Frame Field Information (Continued)



|                         | BFF                     | FO <sup>a,b</sup>   | BFINS <sup>a,c</sup>    |                     | BFTST <sup>a</sup>      |                     |  |
|-------------------------|-------------------------|---------------------|-------------------------|---------------------|-------------------------|---------------------|--|
| Addressing<br>Mode      | <ea><br/>Calculate</ea> | Execute             | <ea><br/>Calculate</ea> | Execute             | <ea><br/>Calculate</ea> | Execute             |  |
| Dn                      | <sub>3/4</sub> d        | 6/7 <sup>d</sup>    | 2/3 <sup>d</sup>        | 5/6 <sup>d</sup>    | 1/2 <sup>d</sup>        | 3/4 d               |  |
| An                      | _                       | —                   | _                       | —                   | —                       | —                   |  |
| (An)                    | 9                       | 2L + 9              | 9                       | 2L + 7              | 9                       | 2L + 7              |  |
| (An)+                   | —                       | —                   | —                       | —                   | —                       | —                   |  |
| –(An)                   | —                       | _                   | —                       | —                   | —                       | —                   |  |
| (d <sub>16</sub> ,An)   | 9                       | 2 <sub>L</sub> + 9  | 9                       | 2 <sub>L</sub> + 7  | 9                       | 2L + 7              |  |
| (d <sub>16</sub> ,PC)   | 10                      | 3L + 9              | —                       | —                   | 10                      | 3L + 7              |  |
| (xxx).W, (xxx).L        | 9                       | 2 <sub>L</sub> + 9  | 9                       | 2 <sub>L</sub> + 7  | 9                       | 2 <sub>L</sub> + 7  |  |
| # <xxx></xxx>           | —                       | _                   | —                       | —                   | _                       | _                   |  |
| (dg,An,Xn)              | 10                      | 12                  | 10                      | 10                  | 10                      | 10                  |  |
| (d <sub>8</sub> ,PC,Xn) | 11                      | 1 <sub>L</sub> + 12 | —                       | —                   | 11                      | 1 <sub>L</sub> + 10 |  |
| (BR,Xn)                 | 13                      | 1 <sub>L</sub> + 14 | 13                      | 1 <sub>L</sub> + 12 | 13                      | 1 <sub>L</sub> + 12 |  |
| (bd,BR,Xn)              | 14                      | 1 <sub>L</sub> + 15 | 14                      | 1 <sub>L</sub> + 13 | 14                      | 1 <sub>L</sub> + 13 |  |
| ([bd,BR,Xn])            | 16                      | 1 <sub>L</sub> + 17 | 16                      | 1 <sub>L</sub> + 15 | 16                      | 1 <sub>L</sub> + 15 |  |
| ([bd,BR,Xn],od)         | 17                      | 1 <sub>L</sub> + 18 | 17                      | 1 <sub>L</sub> + 16 | 17                      | 1 <sub>L</sub> + 16 |  |
| ([bd,BR],Xn)            | 17                      | 3L + 16             | 17                      | 3L + 14             | 17                      | 3L + 14             |  |
| ([bd,BR],Xn,od)         | 18                      | 3 <sub>L</sub> + 17 | 18                      | 3L + 15             | 18                      | 3L + 15             |  |

### **10.6 INTEGER UNIT INSTRUCTION TIMINGS (Continued)**

NOTES:

a. This instruction interlocks the <ea> calculate and execute stages.

b. If the bit field spans a long-word boundary, add two clocks to the execute time. Two memory addresses are accessed in this case.

c. If the bit field spans a long-word boundary, add seven clocks to both the <ea> calculate and execute times. Two memory addresses are accessed in this case.

d. If the bit field spans a long-word boundary, add ten and nine clocks to both the <ea> calculate and execute times, respectively. Two memory addresses are accessed in this case.



|                       | DIVS.W                  | , DIVU.W <sup>*</sup> | DIVS.I<br>DIVSL.I       | _, DIVU.L,<br>_, DIVUL.L <sup>*</sup> | JMP                     |                    |
|-----------------------|-------------------------|-----------------------|-------------------------|---------------------------------------|-------------------------|--------------------|
| Addressing<br>Mode    | <ea><br/>Calculate</ea> | Execute               | <ea><br/>Calculate</ea> | Execute                               | <ea><br/>Calculate</ea> | Execute            |
| Dn                    | 8                       | 27                    | 9                       | 44                                    | —                       | _                  |
| An                    | _                       | —                     | _                       | —                                     | —                       | _                  |
| (An)                  | 8                       | 27                    | 9                       | 44                                    | 3                       | 2 <sub>L</sub> + 1 |
| (An)+                 | 8                       | 27                    | 9                       | 44                                    | —                       | —                  |
| –(An)                 | 8                       | 27                    | 9                       | 44                                    | —                       | _                  |
| (d <sub>16</sub> ,An) | 8                       | 27                    | 11                      | 2 <sub>L</sub> + 44                   | 4                       | 3L + 1             |
| (d <sub>16</sub> ,PC) | 11                      | 3L + 27               | 12                      | 3L + 44                               | 6                       | 5L + 1             |
| (xxx).W, (xxx).L      | 8                       | 27                    | 11                      | 2 <sub>L</sub> + 44                   | 3                       | 2L + 1             |
| # <xxx></xxx>         | 8                       | 27                    | 10                      | 1 <sub>L</sub> + 44                   | —                       | —                  |
| (dg,An,Xn)            | 11                      | 30                    | 12                      | 47                                    | 6                       | 6                  |
| (dg,PC,Xn)            | 12                      | 1L + 30               | 13                      | 1L + 47                               | 7                       | 1L + 6             |
| (BR,Xn)               | 13                      | 1 <sub>L</sub> + 31   | 14                      | 1 <sub>L</sub> + 48                   | 8                       | 1 <sub>L</sub> + 7 |
| (bd,BR,Xn)            | 14                      | 1 <sub>L</sub> + 32   | 15                      | 1 <sub>L</sub> + 49                   | 9                       | 1L + 8             |
| ([bd,BR,Xn])          | 17                      | 1L + 35               | 18                      | 1 <sub>L</sub> + 52                   | 12                      | 1L + 11            |
| ([bd,BR,Xn],od)       | 18                      | 1 <sub>L</sub> + 36   | 19                      | 1 <sub>L</sub> + 53                   | 12                      | 1L + 11            |
| ([bd,BR],Xn)          | 18                      | 3L + 34               | 19                      | 3L + 51                               | 13                      | 3L + 10            |
| ([bd,BR],Xn,od)       | 19                      | 3L + 35               | 20                      | 3L + 52                               | 14                      | 3L + 11            |

# **10.6 INTEGER UNIT INSTRUCTION TIMINGS (Continued)**

\*This instruction interlocks the <ea> calculate and execute stages. Execution time for a DIV/0 exception taken and exception processing is approximately 16 + <ea> calculate clocks. For example, DIV.W #0,Dn takes approximately 24 clocks in both the <ea> calculate and execute times to execute the divide instruction, perform exception stacking, fetch the exception vector, and prefetch the next instruction.



# 11.3 DC ELECTRICAL SPECIFICATIONS (V $_{CC}$ = 5.0 VDC $\pm 5$ %)

| Characteristic                                                                                                                       | Symbol          | Min   | Max   | Unit |
|--------------------------------------------------------------------------------------------------------------------------------------|-----------------|-------|-------|------|
| Input High Voltage                                                                                                                   | VIH             | 2     | VCC   | V    |
| Input Low Voltage                                                                                                                    | VIL             | GND   | 0.8   | V    |
| Undershoot                                                                                                                           | —               | —     | 0.8   | V    |
| Input Leakage Current @ 0.5/2.4 V<br>AVEC, BCLK, BG, CDIS, MDIS, IPLx, PCLK, RSTI, SCx,<br>TBI, TLNx, TCI, TCK, TEA                  | lin             | 20    | 20    | μA   |
| Hi-Z (Off-State) Leakage Current @ 0.5/2.4 V<br>An, BB, CIOUT, Dn, LOCK, LOCKE, R/W, SIZx, TA, TDO,<br>TIP, TMx, TLNx, TS, TTx, UPAx | ITSI            | 20    | 20    | μΑ   |
| Signal Low Input Current, VIL = 0.8 V<br>TMS, TDI, TRST                                                                              | IIL             | -1.1  | -0.18 | mA   |
| Signal High Input Current, VIH = 2.0 V<br>TMS, TDI, TRST                                                                             | ΙН              | -0.94 | -0.16 | mA   |
| Output High Voltage, I <sub>OH</sub> = 5 mA (Small Buffer Mode)                                                                      | VOH             | 2.4   | —     | V    |
| Output Low Voltage, IOL = 5 mA (Small Buffer Mode)                                                                                   | VOL             | —     | 0.5   | V    |
| Output High Voltage, I <sub>OH</sub> = 55 mA (Large Buffer Mode)                                                                     | VOH             | 2.4   | —     | V    |
| Output Low Voltage, IOL = 55 mA (Large Buffer Mode)                                                                                  | VOL             | —     | 0.5   | V    |
| Capacitance*, V <sub>in</sub> = 0 V, f = 1 MHz                                                                                       | C <sub>in</sub> | _     | 25    | pF   |

\*Capacitance is periodically sampled rather than 100% tested.

### **11.4 POWER DISSIPATION**

| Buffer Mode                                                                      | 25 MHz | 33 MHz | 40 MHz |  |  |  |
|----------------------------------------------------------------------------------|--------|--------|--------|--|--|--|
| Worst Case (V <sub>CC</sub> = 5.25 V , T <sub>A</sub> = 0°C)                     |        |        |        |  |  |  |
| Small Unterminated, $I_{OL} = I_{OH} = 5 \text{ mA}$                             | 4.9 W  | 6.2 W  | 7.2 W  |  |  |  |
| Large Unterminated, $I_{OL} = I_{OH} = 5 \text{ mA}$                             | 5.1 W  | 6.6 W  | 7.7 W  |  |  |  |
| Large Terminated, 50 $\Omega$ , 2.5 V, I <sub>OL</sub> = I <sub>OH</sub> = 55 mA | 6.5 W  | 8.0 W  | 9.1 W  |  |  |  |
| Typical Values (V <sub>CC</sub> = 5 V, T <sub>J</sub> = 90°C)*                   |        |        |        |  |  |  |
| Small                                                                            | 3.0 W  | 4.1 W  | 4.5 W  |  |  |  |
| Large Unterminated                                                               | 3.3 W  | 4.4 W  | 4.8 W  |  |  |  |
| Large Terminated, 50 $\Omega$ , 2.5 V                                            | 4.7 W  | 5.8 W  | 6.2 W  |  |  |  |

\*This information is for system reliability purposes.





NOTES:

- 1. This output timing is applicable to all parameters specified relative to the rising edge of the clock.
- 2. This input timing is applicable to all parameters specified relative to the rising edge of the clock.
- 3. This timing is applicable to all parameters specified relative to the negation of the RSTI signal.

LEGEND:

- A. Maximum output delay specification.
- B. Minimum output hold time.
- C. Minimum input setup time specification.
- D. Minimum input hold time specification.
- E. Mode select setup time to RSTI negated.
- F. Mode select hold time from RSTI negated.

#### Figure 11-2. Drive Levels and Test Points for AC Specifications



# APPENDIX B MC68EC040

#### NOTE

Rev. 2.3 contains timing informationg for 40 MHz operation. Refer to chang bars for these additions.

All references to MC68EC040 also apply to the MC68EC040V. Refer to **Appendix C MC68040V and MC68EC040V** for more information on the MC68EC040V.

The MC68EC040 is Motorola's third generation of M68000-compatible, high-performance, 32-bit microprocessors. The MC68EC040 is an embedded controller employing a highly integrated architecture to provide very high performance in a monolithic HCMOS device. The MC68EC040 integrates an MC68040-compatible integer unit, an access control unit (ACU), and independent 4-Kbyte instruction and data caches. A six-stage instruction pipeline, multiple internal buses, and a full internal Harvard architecture, including separate caches for both instruction and data accesses, provides a high degree of instruction execution parallelism. The inclusion of on-chip bus snooping logic, which directly supports cache coherency in multimaster applications, enhances cache functionality.

The MC68EC040 is user-object-code compatible with previous members of the M68000 family and is specifically optimized to reduce the execution time of compiler-generated code. The MC68EC040 is pin compatible with the MC68040 and MC68LC040. The MC68EC040 is implemented in Motorola's latest HCMOS technology, providing an ideal balance between speed, power, and physical device size. Figure B-1 provides a simplified block diagram of the MC68EC040.

The main features of the MC68EC040 include:

- MC68040-Compatible Integer Execution Unit
- 4-Kbyte Instruction Cache and 4-Kbyte Data Cache Accessible Simultaneously
- 32-Bit, Nonmultiplexed External Address and Data Buses with Synchronous Bursting Interface
- User-Object-Code Compatible with All M68000 Microprocessors
- Concurrent Integer Unit, ACU, and Bus Controller Operation Maximizes Throughput
- Low-Latency Bus Accesses for Reduced Cache-Miss Penalty
- Multimaster/Multiprocessor Support via Bus Snooping
- 4-Gbyte Direct Addressing Range

MOTOROLA

M68040 USER'S MANUAL

B-1



I

I

#### MC68EC040 REV2.3 (01/31/2000)







Figure B-6. MC68EC040 Normal Reset Timing

When a RESET instruction is executed, the processor drives the reset out ( $\overline{RSTO}$ ) signal for 512 BCLK cycles. In this case, the processor resets the external devices of the system, and the internal registers of the processor are unaffected. The external devices connected to

M68040 USER'S MANUAL

MOTOROLA

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

T



#### MC68EC040 REV2.3 (01/31/2000)

# **B.7.3 DC Electrical Specifications** $(V_{CC} = 5.0 \text{ Vdc} \pm 5 \text{ \%})$

| Characteristic                                                                                                                       | Symbol           | Min   | Max             | Unit |
|--------------------------------------------------------------------------------------------------------------------------------------|------------------|-------|-----------------|------|
| Input High Voltage                                                                                                                   | V <sub>IH</sub>  | 2     | V <sub>CC</sub> | V    |
| Input Low Voltage                                                                                                                    | V <sub>IL</sub>  | GND   | 0.8             | V    |
| Undershoot                                                                                                                           | _                | —     | 0.8             | V    |
| Input Leakage Current @ 0.5–2.4 V<br>AVEC, BCLK, BG, CDIS, IPLÅ, PCLK, RSTI, SCx, TBI,<br>TLNx, TCI, TCK, TEA                        | l <sub>in</sub>  | 20    | 20              | mA   |
| Hi-Z (Off-State) Leakage Current @ 0.5–2.4 V<br>An, BB, CIOUT, Dn, LOCK, LOCKE, R/W, SIZx, TA, TDO, TIP,<br>TMx, TLNx, TS, TTx, UPAx | I <sub>TSI</sub> | 20    | 20              | mA   |
| Signal Low Input Current, V <sub>IL</sub> = 0.8 V<br>TMS, TDI, TRST                                                                  | IIL              | -1.1  | -0.18           | mA   |
| Signal High Input Current, V <sub>IH =</sub> 2.0 V<br>TMS, TDI, TRST                                                                 | IIH              | -0.94 | -0.16           | mA   |
| Output High Voltage, I <sub>OH = 5 mA</sub>                                                                                          | V <sub>OH</sub>  | 2.4   | —               | V    |
| Output Low Voltage, I <sub>OL</sub> = 5 mA                                                                                           | V <sub>OL</sub>  | _     | 0.5             | V    |
| Capacitance*, V <sub>in =</sub> 0 V, f = 1 MHz                                                                                       | C <sub>in</sub>  | _     | 25              | pF   |

\*Capacitance is periodically sampled rather than 100% tested.

#### **B.7.4 Power Dissipation**

| Frequency                                                      | Watts |  |  |  |
|----------------------------------------------------------------|-------|--|--|--|
| Maximum Values ( $V_{CC}$ = 5.25 V, T <sub>A</sub> = 0°C)      |       |  |  |  |
| 20 MHz                                                         | 3.2   |  |  |  |
| 25 MHz                                                         | 3.9   |  |  |  |
| 33 MHz                                                         | 4.9   |  |  |  |
| 40 MHz                                                         | 5.5   |  |  |  |
| Typical Values (V <sub>CC</sub> = 5 V, T <sub>A</sub> = 25°C)* |       |  |  |  |
| 20 MHz                                                         | 2.0   |  |  |  |
| 25 MHz                                                         | 2.4   |  |  |  |
| 33 MHz                                                         | 3.0   |  |  |  |
| 40 MHz                                                         | 3.5   |  |  |  |

\*This information is for system reliability purposes.

I

L

M68040 USER'S MANUAL

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



#### C.7.6 Output AC Timing Specifications (see Figures C-13\* to C-21)

| PRELIMINARY |                                                                                              |             |     |        |     |        |     |      |
|-------------|----------------------------------------------------------------------------------------------|-------------|-----|--------|-----|--------|-----|------|
|             |                                                                                              | 0–16.67 MHz |     | 25 MHz |     | 33 MHz |     |      |
| Num         | Characteristic                                                                               | Min         | Max | Min    | Max | Min    | Max | Unit |
| 11          | BCLK to Address, CIOUT, LOCK, LOCKE,<br>PSTx, R/W, SIZx, TLNx, TMx, TTx, UPAx<br>Valid       | 9           | 30  | 9      | 30  | 6.5    | 25  | ns   |
| 12          | BCLK to Output Invalid (Output Hold)                                                         | 9           |     | 9      |     | 6.5    |     | ns   |
| 13          | BCLK to TS Valid                                                                             | 9           | 30  | 9      | 30  | 6.5    | 25  | ns   |
| 14          | BCLK to TIP Valid                                                                            | 9           | 30  | 9      | 30  | 6.5    | 25  | ns   |
| 18          | BCLK to Data-Out Valid                                                                       | 9           | 32  | 9      | 32  | 6.5    | 27  | ns   |
| 19          | BCLK to Data-Out Invalid (Output Hold)                                                       | 9           | _   | 9      | _   | 6.5    | _   | ns   |
| 20          | BCLK to Output Low Impedance                                                                 | 9           | _   | 9      | _   | 6.5    | _   | ns   |
| 21          | BCLK to Data-Out High Impedance                                                              | 9           | 20  | 9      | 20  | 6.5    | 17  | ns   |
| 38          | BCLK to Address, CIOUT, LOCK, LOCKE,<br>RW, SIZx, TS, TLNx, TMx, TTx, UPAx High<br>Impedance | 9           | 18  | 9      | 18  | 6.5    | 15  | ns   |
| 39          | BCLK to BB, TA, TIP High Impedance                                                           | 19          | 28  | 19     | 28  | 14     | 25  | ns   |
| 40          | BCLK to BR, BB Valid                                                                         | 9           | 30  | 9      | 30  | 6.5    | 23  | ns   |
| 43          | BCLK to MI Valid                                                                             | 9           | 30  | 9      | 30  | 6.5    | 25  | ns   |
| 48          | BCLK to TA Valid                                                                             | 9           | 30  | 9      | 30  | 6.5    | 25  | ns   |
| 50          | BCLK to IPEND, PSTx, RSTO Valid                                                              | 9           | 30  | 9      | 30  | 6.5    | 25  | ns   |
| W           | RSTI active to SCD inactive.                                                                 | 8           | 100 | 8      | 100 | 8      | 100 | ns   |
| A           | IPLx to SCD invalid                                                                          | 8           | 100 | 8      | 100 | 8      | 100 | ns   |

NOTE:

\* Output timing is specified for a valid signal measured at the pin. Timing is specified driving an unterminated 30- $\Omega$  transmission line with a length characterized by a 2.5-ns one-way propagation delay. Buffer output impedance is typically 30  $\Omega$ ; the buffer specifications include approximately 5 ns for the signal to propagate the length of the transmission line and back.