MC68030 # Technical Summary # SECOND-GENERATION 32-BIT ENHANCED MICROPROCESSOR The MC68030 is a 32-bit virtual memory microprocessor that integrates the functionality of an MC68020 core with the added capabilities of an on-chip paged memory management unit (MMU) and an on-chip 256-byte data cache. Additionally, the MC68030 is enhanced with multiple internal address and data buses as well as a more versatile bus controller that can support two-clock bus accesses and one-clock burst accesses to maximize performance. The rich instruction set and addressing mode capabilities of the MC68020 have been maintained, allowing a clear migration path for M68000 systems. For detailed information on the MC68030, refer to MC68030 UM/AD, *MC68030 Enhanced 32-Bit Microprocessor User's Manual*. The main features of the MC68030 are as follows: - Object-Code Compatible with the MC68020 and Earlier M68000 Microprocessors - Complete 32-Bit Nonmultiplexed Address and Data Buses - 16 32-Bit General-Purpose Data and Address Registers - Two 32-Bit Supervisor Stack Pointers and 10 Special-Purpose Control Registers - 256-Byte Instruction Cache and 256-Byte Data Cache Can Be Accessed Simultaneously - Paged MMU Translates Addresses in Parallel with Instruction Execution - Two Transparent Segments Allow Untranslated Blocks To Be Defined for Systems That Transfer Large Blocks of Data to Predefined Addresses i.e., Graphics Applications - Pipelined Architecture with Increased Parallelism Allows Accesses from Internal Caches to Occur in Parallel with Bus Transfers and Instruction Execution To Be Overlapped This document contains information on a new product. Specifications and information herein are subject to change without notice. - Enhanced Bus Controller Supports Asynchronous Bus Cycles, (three clocks minimum), Synchronous Bus Cycles, (two clocks minimum), and Burst Data Transfers (one cock minumum), all to the Physical Address Space - Dynamic Bus Sizing Supports 8-/16-/32-Bit Memories and Peripherals - Complete Support for Coprocessors with the M68000 Coprocessor Interface - Internal Status Indication for Hardware Emulation Support - 4-Gbyte Direct Addressing Range - Implemented in Motorola's HCMOS Technology That Allows CMOS and HMOS (High-Density NMOS) Gates To Be Combined for Maximum Speed, Low Power, and Small Die Size - Processor Speeds Beyond 20 MHz # INTRODUCTION The MC68030 is an integrated processor that incorporates the capabilities of the MC68020 microprocessor, the memory management structure defined by the MC68851 paged memory management unit (PMMU), data cache, an instruction cache, and an improved bus controller on one VLSI device. It maintains the 32-bit registers available with the entire M68000 Family as well as the 32-bit address and data paths, rich instruction set, versatile addressing modes, and flexible coprocessor interface provided with the MC68020. In addition, the internal operations of this integrated processor are designed to operate in parallel, allowing multiple instructions to be executed concurrently. It allows instruction execution to proceed in parallel with accesses to the internal caches, the on-chip MMU, and the bus controller. The MC68030 fully supports the nonmultiplexed asynchronous bus of the MC68020 as well as the dynamic bus sizing mechanism that allows the processor to transfer operands to or from external devices while automatically determining device port size on a cycle-by-cycle basis. In addition to the asynchronous bus, the MC68030 also supports a fast synchronous bus for off-chip caches and fast memories. Furthermore, the MC68030 bus is capable of fetching up to four long words of data in a burst mode compatible with DRAM chips that have burst capability. Burst mode can reduce (up to 50 percent) the time necessary to fetch the four long words. The four long words are used to prefill the on-chip instruction and data caches so that the hit ratio of the caches is improved and the average access time for operand fetches is minimized. The block diagram shown in Figure 1 depicts the major sections of the MC68030 and illustrates the autonomous nature of these blocks. The bus controller consists of the address and data pads, the multiplexers required to support dynamic bus sizing, and a microbus controller that schedules the bus cycles on the basis of priority. The micromachine contains the execution unit and all related control logic. Microcode control is provided by a modified two-level store of microROM and nanoROM contained in the micromachine. Programmed logic arrays (PLAs) are used to provide instruction decode and sequencing information. The instruction pipe and other individual control sections provide the secondary decode of instructions and generate the actual control signals that result in the decoding and interpretation of nanoROM and microROM information. The instruction and data cache blocks operate independently from the rest of the machine, storing information read by the bus controller for future use with very fast access time. Each cache resides on its own address bus and data bus, allowing simultaneous access to both. Both caches are organized as a total of 64 long-word entries (256 bytes) with a line size of four long words. The data cache uses a write-through policy with programmable write allocation for cache misses. Finally, the MMU controls the mapping of addresses for page sizes ranging from 256 bytes to 32K bytes. Mapping information stored in descriptors resides in translation tables in memory that are automatically searched by the MC68030 on demand. Recently used descriptors are maintained in a 22-entry fully associative cache called the address translation cache (ATC), allowing address translation and other MC68030 functions to occur simultaneously. Additionally, the MC68030 contains two transparent translation registers that can be used to define a one-to-one mapping for two segments ranging in size from 16 Mbytes to 2 Gbytes each. Figure 1. MC68030 Block Diagram # PROGRAMMING MODEL As shown in the programming models (see Figures 2 and 3), the MC68030 has 16 32-bit general-purpose registers, a 32-bit program counter, two 32-bit supervisor stack pointers, a 16-bit status register, a 32-bit vector base register, two 3-bit alternate function code registers, two 32-bit cache handling (address and control) registers, two 64-bit root pointer registers used by the MMU, a 32-bit translation control register, two 32-bit transparent translation registers, and a 16-bit MMU status register. Registers D0-D7 are used as data registers for bit and bit field (1 to 32 bit), byte (8 bit), word (16 bit), long-word (32 bit), and quad-word (64 bit) operations. Registers A0-A6 and the user, interrupt, and master stack pointers are address registers that may be used as software stack pointers or base address registers. In addition, the address registers may be used for word and long-word operations. All 16 general-purpose registers (D0-D7, A0-A7) can used as index registers. Figure 2. User Programming Model Figure 3. Supervisor Programming Model Supplement The status register (see Figure 4) contains the interrupt priority mask (three bits) as well as the following condition codes: extend (X), negate (N), zero (Z), overflow (V), and carry (C). Additional control bits indicate that the processor is in the trace mode (T1 or T0), supervisor/user state (S), and master/interrupt state (M). Figure 4. Status Register All microprocessors of the M68000 Family support instruction tracing (via the T0 status bit in the MC68030) where each executed instruction is followed by a trap to a user-defined trace routine. The MC68030 also has the capability to trace only on change-of-flow instructions (branch, jump, subroutine call and return, etc.) using the T1 status bit. These features are important for software program development and debug. Since the vector base register is used to determine the run-time location of the exception vector table in memory, it supports multiple vector tables; thus, each process or task can properly manage exceptions independent of each other. The M68000 Family processors distinguish address spaces as supervisor/user, program/data, and CPU space. These five combinations are specified by the function code pins (FC0/FC1/FC2) during bus cycles, indicating the particular address space. Using the function codes, the memory subsystem (hardware) can distinguish between supervisor accesses and user accesses as well as program accesses, data accesses, and CPU space accesses. Additionally, the system software can configure the on-chip MMU so that supervisor/user privilege checking is performed by the address translation mechanism, and the lookup of translation descriptors can be differentiated on the basis of function code. To support the full privileges of the supervisor, the alternate function code registers allow the supervisor to specify the function code for an access by appropriately preloading the SFC/DFC registers. The cache registers allow supervisor software manipulation of the on-chip instruction and data caches. Control and status accesses to the caches are provided by the cache control register (CACR); the cache address register (CAAR) specifies the address for those cache control functions that require an address. All MMU registers (CRP, SRP, TC, TT0, TT1, and MMUSR) are accessible by the supervisor only. The central processor unit (CPU) root pointer contains a descriptor for the first pointer to be used in the translation table search for page descriptors pertaining to the current task. If the supervisor root pointer enable (SRE) bit of the translation control register is set, the supervisor root pointer is used as a pointer to the translation tables for all supervisor accesses. If the SRE bit is clear, this register is unused, and the CPU root pointer is used for both supervisor and user translations. The translation control register configures the table lookup mechanism to be used for all table searches as well as the page size and any initial shift of logical address required by the operating system. In addition, this register has an enable bit that enables the MMU. The transparent translation registers can be used to define two transparent windows for transferring large blocks of data with untranslated addresses. Finally, the MMU status register (MMUSR) contains status information related to a specific address translation and the results generated by the PTEST instruction. This information can be useful in locating the cause of an MMU fault. # DATA TYPES AND ADDRESSING MODES Seven basic data types are supported by the MC68030: - 1. Bits - 2. Bit Fields (String of consecutive bits, 1-32 bits long) - 3. BCD Digits (Packed: 2 digits/byte, Unpacked: 1 digit/byte) - 4. Byte Integers (8 bits) - 5. Word Integers (16 bits) - 6. Long-Word Integers (32 bits) - 7. Quad-Word Integers (64 bits) In addition, operations on other data types, such as memory addresses, status word data, etc., are provided in the instruction set. The coprocessor mechanism allows direct support of floating-point data types with the MC68881/MC68882 floating-point coprocessors as well as specialized user-defined data types and functions. The 18 addressing modes listed in Table 1 include nine basic types: - 1. Register Direct - 2. Register Indirect - 3. Register Indirect with Index - 4. Memory Indirect - 5. Program Counter Indirect with Displacement - 6. Program Counter Indirect with Index - 7. Program Counter Memory Indirect - 8. Absolute - 9. Immediate The register indirect addressing modes support postincrement, predecrement, offset, and indexing. These capabilities are particularly useful for handling advanced data structures common to sophisticated applications and high-level languages. The program counter relative mode also has index and offset capabilities; this addressing mode is generally required to support position-independent software. In addition to these addressing modes, the MC68030 provides data operand sizing and scaling; these features provide performance enhancements for the programmer. Table 1. Addressing Modes | Addressing Modes | Syntax | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------| | Register Direct Data Register Direct Address Register Direct | Dn<br>An | | Register Indirect Address Register Indirect Address Register Indirect with Postincrement Address Register Indirect with Predecrement Address Register Indirect with Displacement | (An)<br>(An) +<br>- (An)<br>(d <sub>16</sub> ,An) | | Register Indirect with Index Address Register Indirect with Index (8-Bit Displacement) Address Register Indirect with Index (Base Displacement) | (dg,An,Xn)<br>(bd,An,Xn) | | Memory Indirect Memory Indirect Postindexed Memory Indirect Preindexed | ([bd,An],Xn,od)<br>([bd,An,Xn],od) | | Program Counter Indirect with Displacement | (d <sub>16</sub> ,PC) | | Program Counter Indirect with Index PC Indirect with Index (8-Bit Displacement) PC Indirect with Index (Base Displacement) | (dg,PC,Xn)<br>(bd,PC,Xn) | | Program Counter Memory Indirect PC Memory Indirect Postindexed PC Memory Indirect Preindexed | ([bd,PC],Xn,od)<br>([bd,PC,Xn],od) | | Absolute Absolute Short Absolute Long | (xxx).W<br>(xxx).L | | Immediate | #(data) | #### NOTES: - Dn = Data Register, D0-D7 - An = Address Register, A0-A7 - d8, d16 = A twos-complement or sign-extended displacement; added as part of the effective address calculation; size is 8 (d8) or 16 (d16) bits; when omitted, assemblers use a value of zero. - Xn = Address or data register used as an index register; form is Xn.SIZE\*SCALE, where SIZE is .W or .L (indicates index register size) and SCALE is 1, 2, 4, or 8 (index register is multiplied by SCALE); use of SIZE and/or SCALE is optional. - bd = A twos-complement base displacement; when present, size can be 16 or 32 bits. # Table 1. Addressing Modes (Continued) od = Outer displacement, added as part of effective address calculation after any memory indirection; use is optional with a size of 16 or 32 bits. PC = Program Counter (data) = Immediate value of 8, 16, or 32 bits () = Effective Address [] = Use as indirect access to long-word address. ### INSTRUCTION SET OVERVIEW The MC68030 instruction set is listed in Table 2. Each instruction, with few exceptions, operates on bytes, words, and long words, and most instructions can use any of the 18 addressing modes. The MC68030 is upward source- and object-code compatible with the M68000 Family because it supports all instructions of previous family members. Included in this set are the bit field operations, binary-coded decimal support, bounds checking, additional trap conditions, and additional multiprocessing support (CAS and CAS2 instructions) offered by the MC68020. The new instructions supported by the MC68030, a subset of the instructions introduced by the MC68851 PMMU, are used to communicate with the MMU. For detailed information on the MC68030 instruction set, refer to M68000 PM/AD, M68000 Programmer's Reference Manual. Table 2. Instruction Set | Mnemonic | Description | |----------|---------------------------------| | ABCD | Add Decimal with Extend | | ADD | Add | | ADDA | Add Address | | ADDI | Add Immediate | | ADDQ | Add Quick | | ADDX | Add with Extend | | AND | Logical AND | | ANDI | Logical AND Immediate | | ASL, ASR | Arithmetic Shift Left and Right | | Bcc | Branch Conditionally | | BCHG | Test Bit and Change | | BCLR | Test Bit and Clear | | BFCHG | Test Bit Field and Change | | BFCLR | Test Bit Field and Clear | | BFEXTS | Signed Bit Field Extract | | BFEXTU | Unsigned Bit Field Extract | | BFFFO . | Bit Field Find First One | | BFINS | Bit Field Insert | | BFSET | Test Bit Field and Set | | BFTST | Test Bit Field | | BKPT | Breakpoint | | BRA | Branch | | BSET | Test Bit and Set | | BSR | Branch to Subroutine | | BTST | Test Bit | | Mnemonic | Description | |-------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | tCAS<br>CAS2<br>CHK<br>CHK2<br>CLR<br>CMP<br>CMPA<br>CMPI<br>CMPM | Compare and Swap Operands Compare and Swap Dual Operands Check Register Against Bound Check Register Against Upper and Lower Bounds Clear Compare Compare Address Compare Immediate Compare Memory to Memory Compare Register Against Upper | | | and Lower Bounds | | DBcc<br>DIVS, DIVSL<br>DIVU, DIVUL | Test Condition, Decrement and<br>Branch<br>Signed Divide<br>Unsigned Divide | | EOR<br>EORI<br>EXG<br>EXT, EXTB | Logical Exclusive OR Logical Exclusive OR Immediate Exchange Registers Sign Extend | | ILLEGAL | Take Illegal Instruction Trap | | JMP<br>JSR | Jump<br>Jump to Subroutine | Table 2. Instruction Set (Continued) | | <del></del> | |-----------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------| | Mnemonic | Description | | LEA | Load Effective Address | | LINK | Link and Allocate | | LSL, LSR | Logical Shift Left and Right | | MOVE | Move | | MOVEA | Move Address | | MOVE CCR | Move Condition Code Register | | MOVE SR | Move Status Register | | MOVE USP<br>MOVEC<br>MOVEM<br>MOVEP<br>MOVEQ<br>MOVES<br>MULS<br>MULU | Move User Stack Pointer Move Control Register Move Multiple Registers Move Peripheral Move Quick Move Alternate Address Space Signed Multiply Unsigned Multiply | | NBCD | Negate Decimal with Extend | | NEG | Negate | | NEGX | Negate with Extend | | NOP | No Operation | | NOT | Logical Complement | | OR<br>ORI<br>ORI CCR<br>ORI SR | Logical Inclusive OR Logical Inclusive OR Immediate Logical Inclusive OR Immediate to Condition Codes Logical Inclusive OR Immediate to Status Register | | PACK | Pack BCD | | PEA | Push Effective Address | | Mnemonic | Description | |--------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | PFLUSH PFLUSHA PLOADR, PLOADW PMOVE PMOVEFD PTESTR, PTESTW | Flush Entry(ies) in the ATC Flush All Entries in the ATC Load Entry into the ATC Move to/from MMU Registers Move to/from MMU Registers with Flush Disable Test a Logical Address | | RESET<br>ROL, ROR<br>ROXL, ROXR<br>RTD<br>RTE<br>RTR<br>RTS | Reset External Devices Rotate Left and Right Rotate with Extend Left and Right Return and Deallocate Return from Exception Return and Restore Codes Return from Subroutine | | SBCD<br>Scc<br>STOP<br>SUB<br>SUBA<br>SUBI<br>SUBQ<br>SUBX<br>SWAP | Subtract Decimal with Extend Set Conditionally Stop Subtract Subtract Address Subtract Immediate Subtract Quick Subtract with Extend Swap Register Words | | TAS TRAP TRAPcc TRAPV TST UNLK UNPK | Test Operand and Set Trap Trap Conditionally Trap on Overflow Test Operand Unlink Unpack BCD | # **Coprocessor Instructions** | срВСС | Branch Conditionally | |--------|---------------------------------| | cpDBcc | Test Coprocessor Condition, | | | Decrement and Branch | | cpGEN | Coprocessor General Instruction | | cpRESTORE | Restore Internal State of Coproces- | |-----------|-------------------------------------| | | sor | | cpSAVE | Save Internal State of Coprocessor | | cpScc | Set Conditionally | | cpTRAPcc | Trap Conditionally | # INSTRUCTION AND DATA CACHES Studies have shown that typical programs spend most of their execution time in a few main routines or tight loops. This phenomenon, known as locality of reference, has an impact on program performance. The MC68010 takes limited advantage of this phenomenon with the loop mode of operation that can be used with the DBcc instruction. The MC68030 takes further advantage of cache technology to provide the system with two on-chip caches, one for instructions and one for data. # MC68030 CACHE GOALS Similar to the MC68020, there were two primary design goals for the MC68030 microprocessor caches. The first design goal was to reduce the processor external bus activity even more than what was accomplished with the MC68020. The second design goal was to increase effective CPU throughput as larger memory sizes or slower memories increased average access time. By placing a high-speed cache between the processor and the rest of the memory system, the effective memory access time becomes: $$t_{acc} = h * t_{cache} + (1 - h) * t_{ext}$$ where $t_{acc}$ is the effective system access time, $t_{cache}$ is the cache access time, $t_{ext}$ is the access time of the rest of the system, and h is the hit ratio or the percentage of time that the data is found in the cache. Thus, for a given system design, two MC68030 on-chip caches provide an even more substantial CPU performance increase over that obtainable with the MC68020 instruction cache. Alternately, slower and less expensive memories can be used for the same processor performance. The throughput increase in the MC68030 is gained in three ways. First, the MC68030 caches are accessed in less time than is required for external accesses, providing improvement in the access time for items residing in the cache. Second, the burst filling of the caches allows instruction and data words to be found in the on-chip caches the first time they are accessed by the micromachine, minimizing time required to bring those items into the cache. Burst filling lowers the average access time for items found in the caches even further. Third, the autonomous nature of the caches allows instruction stream fetches, data fetches, and a third external access to occur simultaneously with instruction execution. For example, if the MC68030 requires both an instruction stream access and an external peripheral access and if the instruction is resident in the on-chip cache, the peripheral access proceeds unimpeded rather than being queued behind the instruction fetch. If a data operand is also required and is resident in the data cache, it can also be accessed without hindering either the instruction access or the external peripheral access. The parallelism designed into the MC68030 also allows multiple instructions to execute concurrently so that several internal instructions (those that do not require any external accesses) can execute while the processor is performing an external access for a previous instruction. #### **INSTRUCTION CACHE** The MC68030 instruction cache is a 256-byte direct-mapped cache organized as 16 lines consisting of four long words per line. Each long word is independently accessible, yielding 64 possible entries, with address bit A1 selecting the correct word during an access. Thus, each line has a tag field composed 24 address bits, the FC2 (supervisor/user) value, four valid bits (one for each long-word entry), and the four long-word entries (see Figure 5). The instruction cache is automatically filled by the MC68030 whenever a cache miss occurs; using the burst transfer capability, up to four long words can be filled in one burst operation. The caches can not be manipulated directly by the programmer except by the use of the CACR, which provides cache clearing and cache entry clearing facilities. The caches can also be enabled/disabled by this register. Finally, the system hardware can disable the on-chip caches at any time by asserting of the $\overline{\text{CDIS}}$ signal. Figure 5. On-Chip Instruction Cache Organization #### DATA CACHE The organization of the data cache (see Figure 6) is similar to that of the instruction cache. However, the tag is composed of the upper 24 address bits, the four valid bits, and all three function code bits, explicitly specifying the address space associated with each line. The data cache employs a write-through policy with programmable write allocation of data writes i.e., if a cache hit occurs on a write cycle, both the data cache and the external device are updated with the new data. If a write cycle generates a cache miss, the external device is updated, and a new data cache entry can be replaced or allocated for that address, depending on the state of the write-allocate (WA) bit in the CACR. Figure 6. On-Chip Data Cache Organization # **OPERAND TRANSFER MECHANISM** The MC68030 offers three different mechanisms by which data can be transferred into and out of the chip. Asynchronous bus cycles, compatible with the asynchronous bus on the MC68020, can transfer data in a minimum of three clock cycles; the amount of data transferred on each cycle is determined by the dynamic bus sizing mechanism on a cycle-by-cycle basis with the data transfer and size acknowledge (DSACKx) signals. Synchronous bus cycles are terminated with the synchronous termination (STERM) signal and always transfer 32-bits of data in a minimum of two clock cycles, increasing the bus bandwidth available for other bus masters, therefore increasing possible performance. Burst mode transfers can be used to fill lines of the instruction and data caches when the MC68030 asserts cache burst request (CBREQ). After completing the first cycle with STERM, subsequent cycles may accept data on every clock cycle where STREM is asserted until the burst is completed. Use of this mode can further increase the available bus bandwidth in systems that use DRAMs with page, nibble, or static-column mode operation. ### ASYNCHRONOUS TRANSFERS Though the MC68030 has a full 32-bit data bus, it offers the ability to automatically and dynamically downsize its bus to 8 or 16 bits if peripheral devices are unable to accommodate the entire 32 bits. This feature allows the programmer to write code that is not bus-width specific. For example, long-word (32 bit) accesses to peripherals may be used in the code; yet, the MC68030 will transfer only the amount of data that the peripheral can manage at one time. This feature allows the peripheral to define its port size as 8, 16, or 32 bits wide, and the MC68030 will dynamically size the data transfer accordingly, using multiple bus cycles when necessary. Hence, programmers are not required to program for each device port size or know the specific port size before coding; hardware designers have the flexibility to choose hardware implementations regardless of software implementations. The dynamic bus sizing mechanism is invoked by DSACKx and occurs on a cycle-by-cycle basis. For example, if the processor is executing an instruction that requires the reading of a long-word operand, it will attempt to read 32 bits during the first bus cycle to a long-word address boundary. If the port responds that it is 32 bits wide, the MC68030 latches all 32 bits of data and continues. If the port responds that it is 16 bits wide, the MC68030 latches the 16 valid bits of data and runs a second cycle to obtain the remaining 16 bits of data. An 8-bit port is handled similarly but has four bus read cycles. Each port is fixed in the assignment to particular sections of the data bus. However, the MC68030 has no restrictions concerning the alignment of operands in memory; longword operands need not be aligned to long-word address boundaries. When misaligned data requires multiple bus cycles, the MC68030 automatically runs the minimum number of bus cycles. Instructions must still be aligned to word boundaries. The timing of asynchronous bus cycles is also determined by the assertion of the DSACKx signals on a cycle-by-cycle basis. If the DSACKx signals are valid 1.5 clocks after the beginning of the bus cycle (with the appropriate setup time), the cycle terminates in the minimum amount of time (corresponding to three clock cycles total). The cycle can be lengthened by delaying DSACKx (effectively inserting wait states in one-clock increments) until the device being accessed is able to terminate the cycle. This flexibility gives the processor the ability to communicate with devices of varying speeds while operating at the fastest rate possible for each device. The asynchronous transfer mechanism allows external errors to abort cycles upon the assertion of bus error (BERR), or allows individual bus cycles to be retried with the simultaneous assertion of BERR and HALT. # SYNCHRONOUS TRANSFERS Synchronous bus cycles are terminated by asserting STERM, which automatically indicates that the port size is 32 bits. Since this is asynchronous input, two-clock-cycle bus accesses can be performed if the signal is valid one clock after the beginning of the bus cycle with the appropriate setup time. However, the bus cycle may be lengthened by delaying STERM (inserting wait states in one-clock increments) until the device being accessed is able to terminate the cycle. Additionally, these cycles may be aborted upon the assertion of BERR, or they may be retried with the simultaneous assertion of BERR and HALT. ### **BURST READ CYCLES** The MC68030 provides support for burst filling of its on-chip instruction and data caches, adding to the overall system performance. The on-chip caches are organized with a line size of four long words with one tag for the four long words in a line. Since locality of reference is present to some degree in most programs, filling of all four entries when a single entry misses can be advantageous, especially if the time spent filling the additional entries is minimal. When the caches are burst filled, data can be latched by the processor in as little as one clock for each 32 bits. Burst read cycles can be performed only when the MC68030 requests them (with the assertion of $\overline{\text{CBREQ}}$ ) and only when the first cycle is a synchronous cycle as previously described. If the cache burst acknowledge ( $\overline{\text{CBACK}}$ ) input is valid at the appropriate time in the synchronous bus cycle, the processor keeps the original $\overline{\text{AS}}$ , $\overline{\text{DS}}$ , $R/\overline{\text{W}}$ , address, function code, and size outputs asserted and latches 32 bits from the data bus at the end of each subsequent clock cycle that has $\overline{\text{STERM}}$ asserted. This procedure continues until the burst is complete (the entire block has been transferred), $\overline{\text{BERR}}$ is asserted in lieu of or after $\overline{\text{STERM}}$ , the cache inhibit in ( $\overline{\text{CIIN}}$ ) input is asserted, or the $\overline{\text{CBACK}}$ input is negated. The types of exceptions and the exception processing sequence are discussed in the following paragraphs. # **TYPES OF EXCEPTIONS** Exceptions can be generated by either internal or external causes. The externally generated exceptions are interrupts, bus error (BERR), and reset (RESET). Interrupts are requests from peripheral devices for processor action; whereas, BERR and RESET are used for access control and processor restart. The internally generated exceptions come from instructions, address errors, tracing, or breakpoints. The TRAP, TRAPcc, TRAPvcc, cpTRAPcc, CKH, CKH2, and DIV instructions can all generate exceptions as part of instruction execution. Tracing behaves like a very high-priority, internally generated interrupt whenever it is processed. The other internally generated exeptions are caused by illegal instructions, instruction fetches from odd addresses, and privilege violations. Finally, the MMU can generate exceptions when it detects an invalid translation in the address translation cache (ATC) and an access to the corresponding address is attempted, or when it is unable to locate a valid translation for an address in the translation tables. # **EXCEPTION PROCESSING SEQUENCE** Exception processing occurs in four steps. During the first step, an internal copy is made of the status register. After the copy is made, the special processor state bits in the status register are changed. The S bit is set, putting the processor into the supervisor state. Also, the T1 and T0 bits are negated, allowing the exception handler to execute unhindered by tracing. For the reset and interrupt exceptions, the interrupt priority mask is also updated. In the second step, the vector number of the exception is determined. For interrupts, the vector number is obtained by a processor read that is classified as an interrupt acknowledge cycle. For coprocessor-detected exceptions, the vector number is included in the coprocessor exception primitive response. For all other exceptions, internal logic provides the vector number. This vector number is then used to generate the address of the exception vector. The third step is to save the current processor status. The exception stack frame is created and filled on the current supervisor stack. To minimize the amount of machine state that is saved, various stack frame sizes are used to contain the processor state, depending on the type of exception and where it occurred during instruction execution. If the exception is an interrupt and the M bit is set, the M bit is then cleared, and the short four-word exception stack frame that is saved on the master stack is also saved on the interrupt stack. If the exception is a reset, the M bit is simply cleared, and the reset vector is accessed. The MC68030 provides the same extensions to the exeption stacking process as the MC68020. If the M bit is set, the master stack pointer (MSP) is used for all task-related exceptions. When a nontask-related exception occurs (i.e., an interrupt), the M bit is cleared, and the interrupt stack pointer (ISP) is used. This feature allows all the task's stack area to be carried within a single processor control block, and new tasks can be initiated by simply reloading the master stack pointer and setting the M bit. The fourth and last step of exception processing is the same for all exceptions. The exception vector offset is determined by mutliplying the vector number by four. This offset is then added to the contents of the vector base register (VBR) to determine the memory address of the exception vector. The new program counter is fetched from the exception vector. The instruction at the address given in the exception vector is fetched, and normal instruction decoding and execution is started. # STATUS and REFILL The MC68030 provides the STATUS and REFILL signals to identify internal microsequencer activity associated with the processing of pipelined data. Since bus cycles are independently controlled and scheduled by the bus controller, information concerning the processing state of the microsequencer is not available by monitoring bus signals by themselves. The internal activity identified by the STATUS and REFILL signals include instruction boundaries, some exception conditions, when the microsequencer has halted, and instruction pipeline refills. STATUS and REFILL track only the internal microsequencer activity and are not directly related to bus activity. # **ON-CHIP MEMORY MANAGEMENT UNIT** The full addressing range of the MC68030 is 4 Gbytes (4,294,967,296 bytes); however, most MC68030 systems implement a smaller physical memory. Nonetheless, by using virtual memory techniques, the system can be made to appear to have the full 4 Gbytes of physical memory available to each user program. In a similar fashion, a virtual system provides user-program access to other devices not physically present in the system, such as tape drives, disk drives, printers, or terminals. The MC68030 MMU provides support for a virtual system and virtual memory. In addition, it protects supervisor areas from accesses by user programs and provides write protection on a page basis. All this capability is provided as well as maximum performance because address translations occur in parallel with other processor activities. ### **DEMAND-PAGED IMPLEMENTATION** A typical MC68030 system with a large addressing range provides a limited amount of high-speed physical memory that can be accessed directly by the processor while maintaining an image of a much larger virtual memory on secondary storage devices such as large-capacity disk drives. When the processor attempts to access a location in the virtual memory map that is not resident in physical memory, the access to that location is temporarily suspended while the necessary data is fetched from secondary storage and placed in physical memory; the suspended access is then either restarted or continued. A paged system is one in which the physical memory is subdivided into equalsized blocks called page frames and the logical (untranslated) address space of a task is divided into pages having the same size as the page frames. The operating system controls the allocation of pages to page frames, bringing in data on a page basis as it is needed from the secondary storage device. The MC68030 memory management scheme is called a demand implementation because a process does not need to specify in advance the required areas of its logical address space. An access to a logical address is interpreted by the system as a request for the corresponding page. The MC68030 MMU employs the same address translation mechanism introduced by the MC68851 PMMU, with possible page sizes ranging from 256 bytes to 32K bytes. #### TRANSLATION MECHANISM Since logical-to-physical address translation is the most frequently executed operation of the MC68030 MMU, this task has been optimized and can function autonomously. The MMU initiates address translation by searching for the address translation information (a page descriptor) in the on-chip address translation cache (ATC). The ATC is a very fast fully associative cache memory that stores recently used page descriptors. If the descriptor does not reside in the ATC, then the MMU requests external bus cycles of the bus controller to search the translation tables in physical memory. After being located, the page descriptor is loaded into the ATC, and the address is correctly translated for the access if no exception conditions are encountered. The status of the page in question is easily maintained in the translation tables. When a page must be brought in from a secondary storage device, the table entry can signal that this descriptor is invalid so that the table search results in an invalid descriptor being loaded into the ATC. In this way, the access to the page is aborted, and the processor initiates bus error exception processing for this address. The operating system can then control the allocation of a new page in physical memory and can load the page during the bus error handling routine. # **ADDRESS TRANSLATION CACHE** An integral part of the translation function previously described is the cache memory that stores recently used logical-to-physical address translation information or page descriptors. This cache consists of 22 entries and is fully associative. The ATC compares the logical address and function code of the incoming access against its entries. If one of the entries matches, there is a hit, and the ATC sends the physical address to the bus controller, which then starts the external bus cycle (provided no hit occurred in the instruction or data caches for the access). The ATC is composed of three major components: the content-addressable memory (CAM) containing the logical address and function code information to be compared against incoming logical addresses, the physical address store containing the physical address associated with a particular CAM entry, and the control section containing the entry replacement circuitry that implements the replacement algorithm (a variation of the least recently used algorithm). #### TRANSLATION TABLES The translation tables supported by the MC68030 have a tree structure, minimizing the amount of memory necessary to set up the tables for most programs since only a portion of the complete tree needs to exist at any one time. The root of a translation table tree is pointed to by one or two root pointer registers that are part of the programmer's model: the CPU and supervisor. Table entries at the higher levels of the tree (pointer tables) contain pointers to other tables. Entries at the leaf level (page tables) contain page descriptors. The mechanism for performing table searches uses portions of the logical address as indices for each level of the lookup. All addresses in the translation table entries are physical addresses. Figure 7 illustrates the translation table structure. Several determinants of the detailed table structure are software selectable. The first level of lookup in the table normally uses the function codes as an index, but this may be suppressed if desired. In addition, up to 15 of the logical address lines can be ignored for the purposes of the table searching. The number of levels in the table indexed by the logical address can be set from one to four, and up to 15 logical address bits can be used as an index at each level. A major advantage to using this tree structure for the translation tables is the ability to deallocate large portions of the logical address space with a single entry at the higher levels of the tree. Additionally, portions of the tree itself may reside on a secondary storage device or may not exist at all until they are required by the system. Figure 7. MMU Translation Table Structure The entries in the translation tables contain status information pertaining to the pointers for the next level of lookup or for the pages themselves. These bits can be used to designate certain pages or blocks of pages as supervisoronly, write-protected, or noncachable. If a page is marked as noncachable, accesses within the page will not be cached by the instruction or data caches, and the cache inhibit out (CIOUT) signal is asserted for those accesses. In addition, the MMU automatically maintains history information for the pointers and pages in the descriptors via the used (U) and modified (M) bits. # **MMU INSTRUCTIONS** The MMU instructions supported by the MC68030, the PMOVE, PTEST, PLOAD, PFLUSH, and PFLUSHA instructions, are completely compatible with the corresponding instructions introduced by the MC68851 PMMU. Whereas the MC68851 required the coprocessor interface to execute its instructions, the MC68030 MMU instructions execute just like all other CPU instructions. All MMU instructions are privileged (can be executed by the supervisor only) and are summarized as follows: PMOVE Used to move data to or from MMU registers. PTEST Takes an address and function code and searches the ATC or the translation tables for the corresponding entry. The results of the search are available in the MMU status register (MMUSR) and are often useful in determining the cause of a fault. PLOAD Takes an address and function code and searches the translation tables for the corresponding page descriptor. It then loads the ATC with the appropriate information. PFLUSH Flushes the ATC by function code or function code and logical address. PFLUSHA Flushes all ATC entries. # TRANSPARENT TRANSLATION Two transparent translation registers are provided on the MC68030 MMU to allow portions of the logical address space to be transparently mapped and accessed without corresponding entries resident in the ATC. Each register is used to define a range of logical addresses from 16 Mbytes to 2 Gbytes with a base address and a mask. All addresses within these ranges will not be mapped, and protection is provided only on a basis of read/write and function code. # **COPROCESSOR INTERFACE** The coprocessor interface is a mechanism for extending the instruction set of the M68000 Family. The interface provided on the MC68030 is the same as that on the MC68020. Examples of these extensions are the addition of specialized data operands for the existing data types or, for the case of floating point, the inclusion of new data types and operations implemented by the MC68881/MC68882 floating-point coprocessors. Coprocessors are divided into two types by their bus-utilization characteristics. A DMA coprocessor can control the bus independent of the main processor. A non-DMA coprocessor cannot control the bus. Both coprocessor types utilize the same protocol and main processor resources. Implementation of a coprocessor as a DMA or non-DMA is based primarily on coprocessor bus bandwidth requirements, performance, and cost. The communication protocol between the main processor and the coprocessor necessary to execute a coprocessor instruction is based on a group of coprocessor interface registers (CIRs), which are defined for the M68000 Family (see Table 3) and are implemented on the coprocessor. The MC68030 hardware uses standard read and write cycles to access the registers. Thus, the coprocessor interface does not require special bus hardware; the bus interface implemented by a coprocessor for its interface register set must only satisfy the MC68030 address, data, and control signal timing to guarantee proper communication with the CPU. Since the MC68030 implements the communication protocol with all coprocessors in hardware (and microcode) and handles all operations automatically, the programmer is only concerned with the instructions and data types provided by the coprocessor as extensions to the MC68030 instruction set and data types. **Table 3. Coprocessor Interface Registers** | Register | Function | R/W | |---------------------|------------------------------------|----------------| | Response | Requests Action from CPU | R | | Control | CPU Directed Control | $\overline{w}$ | | Save | Initiate Save of Internal State | R | | Restore | Initiate Restore of Internal State | R/W | | Operation Word | Current Coprocessor Instruction | $\overline{w}$ | | Command Word | Coprocessor Specific Command | Ŵ | | Condition Word | Condition to be Evaluated | w | | Operand | 32-Bit Operand | R/W | | Register Select | Specifies CPU Register or Mask | R | | Instruction Address | Pointer to Coprocessor Instruction | R/W | | Operand Address | Pointer to Coprocessor Operand | R/W | Since the CIRs are accessed via normal read and write cycles, coprocessors can be used as peripheral devices by other M68000 Family members that do not support the coprocessor interface. The communication protocol can be easily emulated by appropriately addressing the CIRs and by passing the required coprocessor commands and operands. In addition to the CIRs, the coprocessor contains those registers added to the MC68030 programmer's model for specific coprocessor operations. For example, the Motorola floating-point coprocessors contain the CIRs as well as eight 80-bit floating-point data registers and three 32-bit control/status registers. Up to eight coprocessors are supported in a single MC68030 system with a system-unique coprocessor identifier encoded in the coprocessor instruction. When accessing a coprocessor, the MC68030 executes standard bus cycles in CPU address space, as encoded by the function codes, and places the coprocessor identifier on the address bus to be used by chip-select logic to select the particular coprocessor. Since standard bus cycles are used, the coprocessor may be located according to system design requirements, whether it is located on the microprocessor local bus, on another board on the system bus, or any other place supported by the chip-select and coprocessor protocol using standard bus cycles. # COPROCESSOR PROTOCOL Interprocessor transfers are all initiated by the main processor during coprocessor instruction execution. When processing a coprocessor instruction, the main processor transfers instruction information and data to the associated coprocessor and receives data, requests, and status information from the coprocessor. These transfers are all based on standard read and write bus cycles. The typical coprocessor protocol for the main processor is as follows: - A. The main processor initiates the communication by writing command information to a location in the coprocessor interface. - B. The main processor reads the coprocessor response to that information. - 1. The response may indicate that the coprocessor is busy, and the main processor should requery the coprocessor, allowing the main processor and coprocessor to synchronize their concurrent operations. - 2. The response may indicate some exception condition; the main processor acknowledges the exception and begins exception processing. - 3. The response may indicate that the coprocessor needs the main processor to perform some service such as transferring data to or from the coprocessor. The coprocessor may also request that the main processor requery the coprocessor after the service is complete. - 4. The response may indicate that the main processor is not needed for further processing of the instruction. The communication is terminated, and the main processor is free to begin execution of the next instruction. At this point in the coprocessor protocol, as the main processor continues to execute the instruction stream, the main processor may operate concurrently with the coprocessor. Each coprocessor instruction type has specific requirements based on this simplified protocol. The coprocessor interface may use as many extension words as required to implement a coprocessor instruction. # PRIMITIVE/RESPONSE The coprocessor response register communicates service requests to the main processor. The content of the coprocessor response register is a primitive instruction to the main processor, which is read during coprocessor communication by the main processor. The main processor executes this primitive, thereby providing the services required by the coprocessor. Table 4 summarizes the coprocessor primitives accepted by the MC68030. **Table 4. Coprocessor Primitives** | Primitive | Function | |---------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Processor Synchronization | Busy with Current Instruction Proceed with Next Instruction If No Trace Service Interrupts and Requery If Trace Enabled Proceed with Execution, Condition True/False | | Instruction Manipulation | Transfer Operation Word Transfer Words from Instruction Stream | | Exception Handling | Take Privilege Violation If S Bit Not Set Take Pre-Instruction Exception Take Mid-Instruction Exception Take Post-Instruction Exception | | General Operand Transfer | Evaluate and Pass (ea) Evaluate (ea) and Transfer Data Write to Previously Evaluated (ea) Take Address and Transfer Data Transfer to/from Top of Stack | | Register Transfer | Transfer CPU Register Transfer CPU Control Register Transfer Multiple CPU Registers Transfer Multiple Coprocessor Registers Transfer CPU SR and/or ScanPC | 3 # SIGNAL DESCRIPTION Figure 8 illustrates the functional signal groups, and Table 5 describes the signals and their function. Figure 8. Functional Signal Groups 3 Table 5. Signal Index | Signal Name | Mnemonic | Function | | |---------------------------------------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Function Codes | FC0-FC2 | 3-bit function code used to identify the address space of each bus cycle. | | | Address Bus | A0-A31 | 32-bit address bus. | | | Data Bus | D0-D31 | 32-bit data bus used to transfer 8, 16, 24, or 32 bits of data per bus cycle. | | | Size | SIZ0/SIZ1 | Indicates the number of bytes remaining to be transferred for this cycle. These signals, together with A0 and A1, define the active sections of the data bus. | | | Operand Cycle Start | <u>ocs</u> | Identical operation to that of $\overline{\text{ECS}}$ except that $\overline{\text{OCS}}$ is asserted only during the first bus cycle of an operand transfer. | | | External Cycle Start | ECS | Provides an indication that a bus cycle is beginning. | | | Read/Write | R/W | Defines the bus transfer as a processor read or write. | | | Read-Modify-Write Cycle | RMC | Provides an indicator that the current bus cycle is part of an indivisible read-modify-write operation. | | | Address Strobe | AS | Indicates that a valid address is on the bus. | | | Data Strobe | DS | Indicates that valid data is to be placed on the data bus by an external device or has been placed on the data bus by the MC68030. | | | Data Buffer Enable | DBEN | Provides an enable signal for external data buffers. | | | Data Transfer and Size<br>Acknowledge | DSACKO/<br>DSACK1 | Bus response signals that indicate the requested of transfer operation has been completed. In additionable these two lines indicate the size of the external port on a cycle-by-cycle basis and are used for as chronous transfers. | | | Synchronous Termination | STERM | Bus response signal that indicates a port size of 3 bits and that data may be latched on the next fallin clock edge. | | | Cache Inhibit In | CIIN | Prevents data from being loaded into the MC68030 instruction and data caches. | | | Cache Inhibit Out | CIOUT | Reflects the CI bit in ATC entries or TTx register; indicates that external caches should ignore these accesses. | | | Cache Burst Request | CBREQ | Indicates a burst request for the instruction or data cache. | | | Cache Burst Acknowledge | CBACK | Indicates that the accessed device can operate in burs mode. | | | Interrupt Priority Level | IPL0-IPL2 | Provides an encoded interrupt level to the processor | | | Interrupt Pending | ĪPEND | Indicates that an interrupt is pending. | | | Autovector | AVEC | Requests an autovector during an interrupt acknowledge cycle. | | | Bus Request | BR | Indicates that an external device requires bus mastership. | | | Bus Grant | BG | Indicates that an external device may assume bus mastership. | | Table 5. Signal Index (Continued) | Signal Name | Mnemonic | Function | | |-----------------------|-----------------|---------------------------------------------------------------------|--| | Bus Grant Acknowledge | BGACK | Indicates that an external device has assumed bus mastership. | | | Reset | RESET | System reset. | | | Halt | HALT | Indicates that the processor should suspend bus activity. | | | Bus Error | BERR | Indicates that an erroneous bus operation is being attempted. | | | Cache Disable | CDIS | Dynamically disables the on-chip cache to assist er ulator support. | | | MMU Disable | MMUDIS | Dynamically disables the translation mechanism of the MMU. | | | Pipe Refill | REFILL | Indicates when the MC68030 is beginning to fill pipeline. | | | Microsequencer Status | STATUS | Indicates the state of the microsequencer. | | | Clock | CLK | Clock input to the processor. | | | Power Supply | v <sub>cc</sub> | Power supply. | | | Ground | GND | Ground connection. | | # **ELECTRICAL SPECIFICATIONS** #### MAXIMUM RATINGS — MC68030 | Rating | Symbol | Value | Unit | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|-----------------------|------| | Supply Voltage* | v <sub>cc</sub> | -0.3 to +7.0 | > | | Input Voltage | v <sub>in</sub> | -0.5 to +7.0 | V | | Operating Temperature Range<br>Minimum Ambient Temperature<br>Maximum Ambient Temperature<br>PGA ≰ = 33 MHz*, PPGA<br>Maximum Junction Temperature<br>PGA 40 and 50 MHz*<br>CQFP | TA<br>TA<br>TJ | 0<br>70<br>TBD<br>TBD | °C | | Storage Temperature Range | T <sub>stg</sub> | -55 to 150 | °C | This device contains protective circuitry against damage due to high static voltages or electrical fields; however, it is advised that normal precautions be taken to avoid application of any voltages higher than maximum-rated voltages to this highimpedance circuit. Reliability of operation is enhanced if unused inputs are tied to an appropriate logic voltage level (e.g., either GND or V<sub>CC</sub>). # THERMAL CHARACTERISTICS | Characteristic | Symbol | Value | Rating | |--------------------------------------------------------------------------------|-----------------|-------------------|--------| | Thermal Resistance — Junction to Ambient PGA Package PPGA Package CQFP Package | θJA | 30*<br>TBD<br>TBD | °C/W | | Thermal Resistance — Junction to Case PGA Package PPGA Package CQFP Package | <sub>H</sub> JC | 15*<br>TBD<br>TBD | | <sup>\*</sup>Estimated # **POWER CONSIDERATIONS** The average chip-junction temperature, T<sub>J</sub>, in °C can be obtained from: $$T_{J} = T_{A} + (P_{D} \cdot \theta_{JA}) \tag{1}$$ where: T<sub>A</sub> = Ambient Temperature, °C θ<sub>JA</sub> = Package Thorner = Package Thermal Resistance, Junction-to-Ambient, °C/W PD = PINT + PI/O = I<sub>CC</sub>×V<sub>CC</sub>, Watts — Chip Internal Power PINT = Power Dissipation on Input and Output Pins User Determined For most applications P<sub>I/O</sub><P<sub>INT</sub> and can be neglected. <sup>\*</sup>Rated clock speed of device (not operating frequency) The following is an approximate relationship between $P_D$ and $T_J$ (if $P_{I/O}$ is neglected): $$P_D = K \div (T_A + 273^{\circ}C)$$ (2) Solving equations (1) and (2) for K gives: $$K = P_D \cdot (T_A + 273^{\circ}C) + \theta_{JA} \cdot P_D^2$$ (3) where K is a constant pertaining to the particular part. K can be determined from equation (3) by measuring $P_D$ (at equilibrium) for a known $T_A$ . Using this value of K, the values of $P_D$ and $P_D$ and $P_D$ are obtained by solving equations (1) and (2) iteratively for any value of $P_D$ . The total thermal resistance of a package $(\theta_{JA})$ can be separated into two components, $\theta_{JC}$ and $\theta_{CA}$ , representing the barrier to heat flow from the semiconductor junction to the package (case) surface $(\theta_{JC})$ and from the case to the outside ambient $(\theta_{CA})$ . These terms are related by the equation: $$\theta J A = \theta J C + \theta C A \tag{4}$$ $\theta$ JC is device related and cannot be influenced by the user. However, $\theta$ CA is user dependent and can be minimized by such thermal management techniques as heat sinks, ambient air cooling, and thermal convection. Thus, good thermal management on the part of the user can significantly reduce $\theta$ CA so that $\theta$ JA approximately equals $\theta$ JC. Substitution of $\theta$ JC for $\theta$ JA in equation (1) will result in a lower semiconductor junction temperature. Values for thermal resistance presented in this document, unless estimated, were derived using the procedure described in Motorola Reliability Report 7843, "Thermal Resistance Measurement Method for MC68XX Microcomponent Devices," and are provided for design purposes only. Thermal measurements are complex and dependent on procedure and setup. User-derived values for thermal resistance may differ. #### AC ELECTRICAL SPECIFICATIONS DEFINITIONS The AC specifications presented consist of output delays, input setup and hold times, and signal skew times. All signals are specified relative to an appropriate edge of the MC68030 clock input and, possibly, relative to one or more other signals. The measurement of the AC specifications is defined by the waveforms in Figure 9. To test the parameters guaranteed by Motorola, inputs must be driven to the voltage levels specified in Figure 9. Outputs of the MC68030 are specified with minimum and/or maximum limits, as appropriate, and are measured as shown. Inputs to the MC68030 are specified with minimum and, as appropriate, Note that the testing levels used to verify conformance of the MC68030 to the AC specifications does not affect the guaranteed DC operation of the device as specified in the DC electrical characteristics. # **DC ELECTRICAL SPECIFICATIONS** ( $V_{CC} = 5.0 \text{ Vdc} \pm 5\%$ ; GND = 0 Vdc; Temperature in defined ranges) | Characteristic | Symbol | Min | Max | Unit | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------------|--------------------------|------| | Input High Voltage | V <sub>IH</sub> | 2.0 | Vcc | ٧ | | Input Low Voltage | V <sub>IL</sub> | GND<br>-0.5 | 0.8 | ٧ | | $ \begin{array}{llllllllllllllllllllllllllllllllllll$ | CK1 "" | - 2.5<br>- 20 | 2.5<br>20 | μΑ | | Hi-Z (Off-State) Leakage Current A0-A31, AS, DBEN, DS, D0-D31, FC0-F R/W, RMC, SIZ0-S | | - 20 | 20 | μА | | Output High Voltage A0-A31, $\overline{AS}$ , $\overline{BG}$ , D0-D31, $\overline{DBEN}$ , $\overline{DS}$ , $\overline{ECS}$ , $R.W$ , $\overline{IPE}$ $OCS$ , $\overline{RMC}$ , $SIZO$ - $SIZ1$ , $FCO$ - $\overline{CBREQ}$ , $\overline{CIOUT}$ , $\overline{STATUS}$ , $\overline{REI}$ | -C2, | 2.4 | - | ٧ | | Output Low Voltage $ \begin{array}{ccccccccccccccccccccccccccccccccccc$ | ND | _<br>_<br>_<br>_ | 0.5<br>0.5<br>0.5<br>0.5 | ٧ | | Power Dissipation (T <sub>A</sub> = 0°C) | PD | _ | 2.6 | W | | Capacitance (see Note) V <sub>in</sub> = 0 V, T <sub>A</sub> = 25°C, f = 1 MHz | C <sub>in</sub> | _ | 20 | pF | | Load Capacitance ECS, CCIOUT, STATUS, REI | FILL | _ | 50<br>70<br>130 | pF | NOTE: Capacitance is periodically sampled rather than 100% tested. - 1. This output timing is applicable to all parameters specified relative to the rising edge of the clock. 2. This output timing is applicable to all parameters specified relative to the falling edge of the clock. - 3. This input timing is applicable to all parameters specified relative to the rising edge of the clock. - This input timing is applicable to all parameters specified relative to the falling edge of the clock. This timing is applicable to all parameters specified relative to the assertion/negation of another 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. Signal valid to signal valid specification (maximum or minimum). F. Signal valid to signal invalid specification (maximum or minimum). Figure 9. Drive Levels and Test Points for AC Specifications | Num. | Characteristic | 20 ( | 20 MHz | | 25 MHz | | 33.33 MHz | | 40 MHz | | 50 MHz | | |------|---------------------------------------------------|------|--------|------|--------|-----|-----------|------|--------|-----|--------|------| | | | Min | Max | Min | Max | Min | Max | Min | Max | Min | Max | Unit | | - | Frequency of Operation | 12.5 | 20 | 12.5 | 25 | 20 | 33.33 | 25 | 40 | 25 | 50 | MHz | | 1 | Cycle Time Clock | 50 | 80 | 40 | 80 | 30 | 50 | 25 | 40 | 20 | 40 | ns | | 2, 3 | Clock Pulse Width Measured<br>from 1.5 V to 1.5 V | 23 | 57 | 19 | 61 | 14 | 36 | 11.5 | 29 | 9.5 | 30.5 | ns | | 4, 5 | Clock Rise and Fall Times | - | 5 | _ | 4 | _ | 3 | - | 2 | _ | 2 | ns | 2.0 V 0.8 V NOTE: Timing measurements are referenced to and from a low voltage of 0.8 V and a high voltage of 2.0 V, unless otherwise noted. The voltage swing through this range should start outside and pass through the range such that the rise or fall will be linear between 0.8 V and 2.0 V. Figure 10. Clock Input Timing Diagram #### G # AC ELECTRICAL SPECIFICATIONS — READ AND WRITE CYCLES $(V_{CC} = 5.0 \text{ Vdc} \pm 5\%; \text{ GND} = 0 \text{ Vdc}; \text{ Temperature in defined ranges})$ | | | 20 MHz | | 25 MHz | | 33.33 MHz | | 40 MHz* | | 50 MHz | | Unit | |-------------------|---------------------------------------------------------------------------------------------------------|--------|-----|--------|-----|-----------|-----|---------|-----|--------|----------|------| | Num. | Characteristic | Min | Max | Min | Max | Min | Max | Min | Max | Min | Max | Onit | | 6 | Clock High to Function Code,<br>Size, RMC, IPEND,<br>CIOUT, Address Valid | 0 | 25 | 0 | 20 | 0 | 14 | 0 | 14 | 0 | 14 | ns | | 6A | Clock High to ECS, OCS Asserted | 0 | 15 | 0 | 15 | 0 | 12 | 0 | 10 | 0 | 10 | ns | | 6B | Function Code, Size, RMC,<br>IPEND, CIOUT, Address<br>Valid to Negating Edge of ECS | 4 | 1 | 3 | - | 3 | 1 | 3 | _ | 3 | _ | ns | | 7 | Clock High to Function Code, Size,<br>RMC, ClOUT, Address,<br>Data High Impedance | 0 | 50 | 0 | 40 | 0 | 30 | 0 | 25 | ٥ | 20 | ns | | 8 | Clock High to Function Code,<br>Size, RMC, IPEND,<br>CIOUT, Address Invalid | 0 | | 0 | _ | 0 | | 0 | - | 0 | | ns | | 9 | Clock Low to AS, DS Asserted, CBREQ Valid | 3 | 20 | 3 | 18 | 2 | 10 | 2 | 10 | 2 | 10 | ns | | 9A <sup>1</sup> | AS to DS Assertion Skew (Read) | - 10 | 10 | - 10 | 10 | -8 | 8 | -6 | 6 | - 6 | 6 | ns | | 9B <sup>14</sup> | AS Asserted to DS Asserted (Write) | 32 | _ | 27 | _ | 22 | _ | 16 | _ | 14 | | ns | | 10 | ECS Width Asserted | 15 | | 10 | _ | 8 | _ | 5 | _ | 4 | | ns | | 10A | OCS Width Asserted | 15 | _ | 10 | _ | 8 | _ | 5 | _ | 4 | - | ns | | 10B <sup>7</sup> | ECS, OCS Width Negated | 10 | _ | 5 | _ | 5 | _ | 5 | _ | 4 | | ns | | 11 | Function Code, Size, RMC, CIOUT, Address Valid to Asserting Edge of AS Asserted (and DS Asserted, Read) | 10 | | 7 | | 5 | | 5 | - | 3 | | ns | | 12 | Clock Low to AS, DS, CBREQ<br>Negated | 0 | 20 | 0 | 18 | 0 | 10 | 0 | 10 | 0 | 10 | ns | | 12A | Clock Low to ECS/OCS Negated | 0 | 20 | 0 | 18 | 0 | 15 | 0 | 12 | 0 | 11 | ns | | 13 | AS, DS Negated to Function<br>Code, Size, RMC, CIOUT,<br>Address Invalid | 10 | _ | 7 | - | 5 | _ | 3 | _ | 3 | _ | ns | | 14 | AS (and DS Read) Width Asserted (Asynchronous Cycle) | 85 | _ | 70 | _ | 45 | _ | 30 | - | 25 | _ | ns | | 14A <sup>?1</sup> | DS Width Asserted (Write) | 38 | _ | 30 | _ | 23 | | 18 | _ | 13 | _ | ns | | 148 | AS (and DS, Read) Width Asserted (Synchronous Cycle) | 35 | _ | 30 | _ | 23 | _ | 18 | _ | 13 | _ | ns | | 15 | AS, DS Width Negated | 38 | | 30 | | 23 | _ | 18 | | 13 | <u> </u> | ns | | 15A <sup>8</sup> | DS Negated to AS Asserted | 30 | | 25 | | 18 | _ | 16 | | 14 | _ | ns | | 16 | Clock High to AS, DS, R/W, DBEN, CBREQ High Impedance | _ | 50 | _ | 40 | _ | 30 | | 25 | | 20 | ns | | 17 | AS, DS Negated to R/W Invalid | 10 | L- | 7 | _ | 5 | _ | 3 | | 3 | | ns | | 18 | Clock High to R/W High | 0 | 25 | 0 | 20 | 0 | 15 | 0 | 14 | 0 | 14 | ns | | 20 | Clock High to R/W Low | 0 | 25 | 0 | 20 | 0 | 15 | 0 | 14 | 0 | 14 | ns | | 21 | R/W High to AS Asserted | 10 | _ | 7 | _ | 5 | _ | 5 | L- | 3 | _ | ns | # AC ELECTRICAL SPECIFICATIONS (Continued) | | Characteristic | 20 MHz | | 25 MHz | | 33.33 MHz | | 40 MHz | | 50 MHz | | Unit | |---------------------|------------------------------------------------------------------------------|--------|-----|--------|-----|-----------|-----|--------|-----|--------|-----|------| | Num. | | Min | Max | Min | Max | Min | Max | Min | Max | Min | Max | | | 22 | R/W Low to DS Asserted (Write) | 60 | _ | 47 | _ | 35 | 1 | 24 | | 23 | _ | ns | | 23 | Clock High to Data-Out Valid | | 25 | _ | 20 | _ | 14 | | 14 | | 14 | ns | | 24 | Data-Out Valid to Negating<br>Edge of AS | 8 | | 5 | 1 | 3 | | 3 | - | 3 | _ | ns | | 25 <sup>11</sup> | AS, DS Negated to Data-Out<br>Invalid | 10 | _ | 7 | - | 5 | + | 3 | _ | 3 | _ | ns | | 25A <sup>9,11</sup> | DS Negated to DBEN Negated (Write) | 10 | _ | 7 | _ | 5 | _ | 3 | | 3 | _ | ns | | 26 <sup>11</sup> | Data-Out Valid to Asserting Edge of DS Asserted (Write) | 10 | _ | 7 | _ | 5 | _ | 3 | _ | 3 | _ | ns | | 27 | Data-In Valid to Clock Low<br>(Setup) | 4 | | 2 | - | 1 | _ | 1 | _ | 1 | _ | ns | | 27A | Late BERR/HALT Asserted to<br>Clock Low (Setup) | 10 | _ | 5 | _ | 3 | _ | 3 | _ | 3 | _ | ns | | 28 <sup>12</sup> | AS, DS Negated to DSACKx,<br>BERR, HALT, AVEC<br>Negated (Asynchronous Hold) | 0 | 50 | 0 | 40 | 0 | 30 | 0 | 20 | 0 | 15 | ns | | 28A <sup>12</sup> | Clock Low to DSACKx, BERR,<br>HALT, AVEC Negated<br>(Synchronous Hold) | 12 | 85 | 8 | 70 | 6 | 50 | 6 | 40 | 6 | 35 | ns | | 29 <sup>12</sup> | AS, DS Negated to Data-In<br>Invalid (Asynchronous Hold) | 0 | - | 0 | _ | 0 | _ | 0 | - | 0 | _ | กร | | 29A <sup>12</sup> | AS, DS Negated to Data-In<br>High Impedance | _ | 50 | | 40 | _ | 30 | _ | 25 | _ | 20 | ns | | 30 <sup>12</sup> | Clock Low to Data-In Invalid<br>(Synchronous Hold) | 12 | _ | 8 | _ | 6 | | 6 | _ | 6 | _ | ns | | 30A <sup>12</sup> | Clock Low to Data-In High<br>Impedance (Read followed<br>by Write) | - | 75 | | 60 | | 45 | _ | 30 | _ | 25 | ns | | 31 <sup>2</sup> | DSACKx Asserted to Data-In<br>Valid (Asynchronous Data Setup) | - | 43 | _ | 28 | | 20 | _ | 14 | _<br> | 13 | ns | | 31A <sup>3</sup> | DSACKx Asserted to DSACKx<br>Valid (Skew) | _ | 10 | | 7 | | 5 | | 3 | _ | 3 | ns | | 32 | RESET Input Transition Time | _ | 1.5 | _ | 1.5 | | 1.5 | | 1.5 | | 1.5 | Clks | | 33 | Clock Low to BG Asserted | 0 | 25 | 0 | 20 | 0 | 15 | 0 | 14 | 0 | 14 | ns | | 34 | Clock Low to BG Negated | 0 | 25 | 0 | 20 | 0 | 15 | 0 | 14 | 0 | 14 | ns | | 35 | BR Asserted to BG Asserted (RMC Not Asserted) | 1.5 | 3.5 | 1.5 | 3.5 | 1.5 | 3.5 | 1.5 | 3.5 | 1.5 | 3.5 | Clks | | 37 | BGACK Asserted to BG Negated | 1.5 | 3.5 | 1.5 | 3.5 | 1.5 | 3.5 | 1.5 | 3.5 | 1.5 | 3.5 | Clks | | 37A <sup>6</sup> | BGACK Asserted to BR Negated | 0 | 1.5 | 0 | 1.5 | 0 | 1.5 | 0 | 1.5 | 0 | 1.5 | Clks | | 39 | BG Width Negated | 75 | | 60 | _ | 45 | _ | 30 | _ | 30 | | ns | | 39A | BG Width Asserted | 75 | | 60 | | 45 | | 30 | _ | 30 | _ | ns | | 40 | Clock High to DBEN Asserted (Read) | 0 | 25 | 0 | 20 | 0 | 18 | 0 | 16 | 0 | 14 | ns | # AC ELECTRICAL SPECIFICATIONS (Continued) | Num. | Characteristic | 20 1 | VIHz | 25 MHz | | 33.33 MHz | | z 40 MHz | | 50 MHz* | | Unit | |------------------|----------------------------------------------------------------|-----------|------|----------|--------------|-----------|-----|----------|-----|----------|--------|------| | ivum. | | Min | Max | Min | Max | Min | Max | Min | Max | Min | Max | Unit | | 41 | Clock Low to DBEN Negated (Read) | 0 | 25 | 0 | 20 | 0 | 18 | 0 | 16 | 0 | 14 | ns | | 42 | Clock Low to DBEN Asserted (Write) | 0 | 25 | 0 | 20 | 0 | 18 | 0 | 16 | 0 | 14 | ns | | 43 | Clock High to DBEN Negated (Write) | 0 | 25 | 0 | 20 | 0 | 18 | 0 | 16 | 0 | 14 | пѕ | | 44 | R/W Low to DBEN Asserted (Write) | 10 | | 7 | ı | 5 | _ | 5 | _ | 5 | _ | ns | | 45 <sup>5</sup> | DBEN Width Asserted<br>Asynchronous Read<br>Asynchronous Write | 50<br>100 | _ | 40<br>80 | <del>-</del> | 30<br>60 | | 22<br>45 | _ | 20<br>40 | _<br>_ | ns | | 45A <sup>9</sup> | DBEN Width Asserted Synchronous Read Synchronous Write | 10<br>50 | _ | 5<br>40 | _ | 5<br>30 | 1 1 | 5<br>22 | _ | 5<br>20 | _ | ns | | 46 | R/W Width Asserted<br>(Asynchronous Write or Read) | 125 | _ | 100 | _ | 75 | - | 50 | _ | 40 | _ | ns | | 46A | R/W Width Asserted (Synchronous Write or Read) | 75 | _ | 60 | | 45 | - | 30 | _ | 25 | _ | ns | | 47A | Asynchronous Input Setup Time to Clock Low | 4 | - | 2 | - | 2 | - | 2 | _ | 2 | | ns | | 47B | Asynchronous Input Hold Time from Clock Low | 12 | _ | 8 | _ | 6 | - | 6 | _ | 6 | _ | ns | | 48 <sup>4</sup> | DSACKx Asserted to BERR,<br>HALT Asserted | - | 20 | _ | 25 | _ | 18 | - | 14 | _ | 13 | ns | | 53 | Data-Out Hold from Clock High | 3 | _ | 3 | _ | 2 | | 2 | _ | 2 | | ns | | 55 | R/W Asserted to Data Bus<br>Impedance Change | 25 | _ | 20 | _ | 15 | _ | 11 | _ | 11 | _ | ns | | 56 | RESET Pulse Width<br>(Reset Instruction) | 512 | _ | 512 | _ | 512 | | 512 | _ | 512 | | Clks | | 57 | BERR Negated to HALT<br>Negated (Rerun) | 0 | _ | 0 | _ | 0 | - | 0 | _ | 0 | _ | ns | | 58 <sup>10</sup> | BGACK Negated to Bus Driven | 1 | _ | 1 | _ | 1 | _ | 1 | _ | 1 | _ | Clks | | 59 <sup>10</sup> | BG Negated to Bus Driven | 1 | | 1 | _ | 1 | 1 | 1 | _ | 1 | _ | Clks | | 60 <sup>13</sup> | Synchronous Input Valid to<br>Clock High (Setup Time) | 4 | _ | 2 | _ | 2 | _ | 2 | _ | 2 | | ns | | 61 <sup>13</sup> | Clock High to Synchronous<br>Input Invalid (Hold Time) | 12 | _ | 8 | _ | 6 | _ | 6 | _ | 6 | _ | ns | | 62 | Clock Low to STATUS,<br>REFILL Asserted | 0 | 25 | 0 | 20 | 0 | 15 | 0 | 15 | 0 | 15 | пѕ | | 63 | Clock Low to STATUS,<br>REFILL Negated | 0 | 25 | 0 | 20 | 0 | 15 | 0 | 15 | 0 | 15 | ns | #### AC ELECTRICAL SPECIFICATIONS (Concluded) #### NOTES: Temperature must be in range described in the Maximum Ratings. - 1. This number can be reduced to 5 ns if strobes have equal loads. - If the asynchronous setup time (#47A) requirements are satisfied, the DSACKx low to data setup time (#31) and DSACKx low to BERR low setup time (#48) can be ignored. The data must only satisfy the data-in clock low setup time (#27) for the following clock cycle, and BERR must only satisfy the late BERR low to clock low setup time (#27A) for the following clock cycle. - This parameter specifies the maximum allowable skew between DSACK0 to DSACK1 asserted or DSACK1 to DSACK1 asserted or DSACK1 to DSACK0 asserted; specification #47A must be met by DSACK0 or DSACK1. - 4. This specification applies to the first (DSACKO or DSACK1) DSACKx signal asserted. In the absence of DSACKx, BERR is an asynchronous input using the asynchronous input setup time (#47A). - 5. DBEN may stay asserted on consecutive write cycles. - The minimum values must be met to guarantee proper operation. If this maximum value is exceeded, BG may be reasserted. - 7. This specification indicates the minimum high time for ECS and OCS in the event of an internal cache hit followed immediately by another cache hit, a cache miss, or an operand cycle. - This specification guarantees operation with the MC68881/MC68882, which specifies a minimum time for DS negated to AS asserted (specification #13A in the MC68881/MC68882 User's Manual). Without this specification, incorrect interpretation of specifications #9A and #15 would indicate that the MC68030 does not meet the MC68881/MC68882 requirements. - This specification allows a system designer to guarantee data hold times on the output side of data buffers that have output enable signals generated with DBEN. The timing on DBEN precludes its use for synchronous READ cycles with no wait states. - 10. These specifications allow system designers to guarantee that an alternate bus master has stopped driving the bus when the MC68030 regains control of the bus after an arbitration sequence. - 11. DS will not be asserted for synchronous write cycles with no wait states. - 12. These hold times are specified with respect to strobes (asynchronous) and with respect to the clock (synchronous). The designer is free to use either time. - 13. Synchronous inputs must meet specifications #60 and #61 with stable logic levels for all rising edges of the clock while AS is asserted. These values are specified relative to the high level of the rising clock edge. The values originally published were specified relative to the low level of the rising clock edge. - 14. This specification allows system designers to qualify the $\overline{\text{CS}}$ signal of an MC68881/MC68882 with $\overline{\text{AS}}$ (allowing 7 ns for a gate delay) and still meet the $\overline{\text{CS}}$ to $\overline{\text{DS}}$ setup time requirement (specification 8B of the MC68881/MC68882 User's Manual). Figure 11. Asynchronous Read Cycle Timing Diagram Figure 12. Asynchronous Write Cycle Timing Diagram Figure 13. Synchronous Read Cycle Timing Diagram Figure 14. Synchronous Write Cycle Timing Diagram NOTE: Timing measurements are referenced to and from a low voltage of 0.8 V and a high voltage of 2.0 V, unless otherwise noted. The voltage swing through this range should start outside and pass through the range such that the rise or fall will be linear between 0.8 V and 2.0 V. Figure 15. Bus Arbitration Timing Diagram Figure 16. Other Signal Timings # 3 # **PIN ASSIGNMENTS** # 128-LEAD PIN GRID ARRAY (RC AND RP SUFFIX) # 132-LEAD CERAMIC SURFACE MOUNT (FE SUFFIX) \*NC - Do not connect to this pin.