# 80960XA EMBEDDED 32-BIT MICROPROCESSOR WITH 33RD TAG BIT TO SUPPORT OBJECT-ORIENTED PROGRAMMING AND DATA SECURITY Military - Implements JIAWG 32-Bit ISA Standard - High-Performance Embedded Architecture - 25 MIPS Burst Execution at 25 MHz - 9.4 MIPS\* Sustained Execution at 25 MHz - On-Chip Floating-Point Unit - Supports IEEE 754 Floating-Point Standard - Full Transcendental Support - Four 80-Bit Registers - 5.2 Million Whetstones/Second at 25 MHz - Multiple Register Sets - Sixteen Global 32-Bit Registers - Sixteen Local 32-Bit Registers - Four Local Register Sets Stored On-Chip (Sixteen 32-Bit Registers per Set) - Register Scoreboarding - Object Oriented Programming and Data Security Supported within Hardware - 33rd Tag Bit to Distinguish Data from Object Pointer - Unforgeable Pointers to Memory - On-Chip Memory Management Unit - 4 Gigabyte Linear Address Space per Task - 4 Kbyte Pages with Supervisor/User Protection - 2<sup>58</sup> Virtual Address Space for Object Addressing and Protection - Built-In Interrupt Controller - 32 Priority Levels - 248 Vectors - Supports M8259A - 3.4 μs Latency - Easy to Use, High Bandwidth 32-Bit Bus - 66.7 MBytes/s Burst at 25 MHz - Up to 16-Bytes Transferred per Burst - Multitasking Support - Automatic Task Dispatching - Prioritized Task Queues - Advanced Package Technology - 132 Lead Ceramic Pin Grid Array - 164 Lead Ceramic Quad Flatpack - Military Temperature Range — -55°C to + 125°C (T<sub>C</sub>) The 80960XA is the second military member of Intel's 32-bit i960® microprocessor family designed especially for embedded applications. It is based on the high performance, common core architecture of the i960 family. As a superset of the military 80960MC, the 80960XA contains the same 512-byte instruction cache, on-chip interrupt controller, integrated floating-point unit and memory management unit of the 80960MC. In addition to the features of the 80960MC, the 80960XA supports object-oriented programming via a 33rd tag bit within the hardware. This tag bit provides the distinction between a 32-bit data word and a 32-bit pointer to memory. In a high level of data security within the architecture. The 80960XA implements the Extended Architecture chosen by the Joint Integrated Avionics Working Group (JIAWG) as a 32-bit Instruction Set Architecture (ISA) standard. Thus, the 80960XA is well-suited for military and other high reliability applications which require high levels of data security or require compliance to JIAWG standards. \*Relative to Digital Equipment Corporation's VAX-11/780\*\* at 1 MIPS \*\*VAX-11 is a trademark of Digital Equipment Corporation. October 1992 Order Number: 271159-003 Figure 1. The 80960XA's Highly Parallel Microarchitecture ### THE 960 SERIES The 80960XA is an enhanced military member of the family of 32-bit microprocessors from Intel known as the i960 Processor Series. This series was especially designed to serve the needs of embedded applications. The embedded market includes applications as diverse as industrial automation, avionics, image processing, graphics, robotics, telecommunications, and automobiles. These types of applications require high integration, low power consumption, quick interrupt response times, and high performance. Since time to market is critical, embedded microprocessors need to be easy to use in both hardware and software designs. All members of the 80960 series share a common core architecture which utilizes RISC technology so that, except for special functions, the family members are object code compatible. Each new processor in the series will add its own special set of functions to the core to satisfy the needs of a specific application or range of applications in the embedded market. The present generation of the i960 family features four distinct architectures. Figure 2 depicts the four architectures in a ring structure to indicate upward binary compatibility. Thus, the inner ring architectures are fully binary compatible to the outer ring architectures. Future implementations of these i960 architectures will maintain this binary compatibility. There are currently five i960 microprocessor products representing the four architectures of the family. The Core architecture is featured in Intel's commercial product line by the 80960KA and 80960CA products. The Core architecture contains the basic i960 processor instruction set. The Numerics architecture is featured in Intel's commercial product line by the 80960KB. This architecture contains the Core architecture plus an on-chip IEEE 754 Standard Floating Point Unit (FPU). The Protected architecture is represented in Intel's military product line by the 80960MC. This architecture contains the Numerics architecture plus an on-chip Memory Management Unit (MMU) and multitasking capabilities to support the Ada programming language. The Extended architecture, implemented by the 80960XA, was defined to support object addressing and protection in response to the increasing popularity of object-oriented computing. A superset of the Protected architecture, the Extended architecture features a 33rd tag bit on the data bus. This 33rd tag bit allows a 32-bit word to be defined as either a data word or a pointer to an object in memory, thus supporting object addressing. In addition, the tag bit provides a high level of data security by making it impossible to forge pointers to protected objects within memory. The Extended architecture was chosen by the Joint Integrated Avionics Working Group (JIAWG) as a 32-bit Instruction Set Architecture (ISA) standard for use in Military avionics applications. Thus, the 80960XA is an ideal fit in applications for which JIAWG ISA compliance is required. 10-102 Figure 2. i960® Product Family Figure 3. Register Set advance information # **KEY PERFORMANCE FEATURES** The 80960XA's architecture is based on the most recent advances in RISC technology and is grounded in Intel's long experience in designing embedded controllers. Many features contribute to the 80960XA's exceptional performance: - 1. Large Register Set. Having a large number of registers reduces the number of times that a processor needs to access memory. Modern compilers can take advantage of this feature to optimize execution speed. For maximum flexibility, the 80960XA provides thirty-two 32-bit registers (sixteen local and sixteen global) and four 80-bit floating-point global registers. (See Figure 3.) - 2. Fast Instruction Execution. Simple functions make up the bulk of instructions in most programs, so that execution speed can be greatly improved by ensuring that these core instructions execute in as short a time as possible. The most-frequently executed instructions such as register-register moves, add/subtract, logical operations, and shifts execute in one to two cycles (Table 1 contains a list of instructions.) - 3. Load/Store Architecture. Like other processors based on RISC technology, the 80960XA has a Load/Store architecture. Only the LOAD and STORE instructions reference memory; all other instructions operate on registers. This type of architecture simplifies instruction decoding and is used in combination with other techniques to increase parallelism. - 4. Simple Instruction Formats. All instructions in the 80960XA are 32-bits long and must be aligned on word boundaries. This alignment makes it possible to eliminate the instruction-alignment stage in the pipeline. To simplify the instruction decoder further, there are only five instruction formats and each instruction uses only one format. (See Figure 4.) - 5. Overlapped Instruction Execution. A load operation allows execution of subsequent instructions to continue before the data has been returned from memory, so that these instructions can overlap the load. The 80960XA manages this process transparently to software through the use of a register scoreboard. Conditional instructions also make use of a scoreboard so that subsequent unrelated instructions can be executed while the conditional instruction is pending. Figure 4. Instruction Formats Table 1. 80960XA Instruction Set | Data Movement | Arithmetic | Floating<br>Point | Logical | |-------------------------|--------------------------|----------------------|-------------------| | Load | Add | Add | And | | Store | Subtract | Subtract | • | | Move | Multiply | 1 | Not And | | Load Address | Divide | Multiply | And Not | | | | Divide | Or | | Load Physical | Remainder | Remainder | Exclusive Or | | Address | Modulo | Scale | Not Or | | Load Virtual | Shift | Round | Or Not | | Load Mixed | İ | Square Root | | | Load Virtual | i | Sine | Nor | | Mixed | | | Exclusive Nor | | Store Virtual | | Cosine | Not | | Store Mixed | | Tangent | Nand | | | | Arctangent | Rotate | | Store Virtual | | Log | | | Mixed | | Log Binary | ļ | | Move Mixed | | Log Natural | l | | Load TDO | 1 | | | | Load Control | 1 | Exponent | | | Stack Pointer | 1 | Classify | 1 | | | 1 | Copy Real | | | Load from Process | | Extended | | | Globals | | Compare | 1 | | Comparison | Branch | Bit and<br>Bit Field | String | | Compare | Unconditional | | | | Conditional | | Set Bit | Move String | | | Branch | Clear Bit | Move Quick String | | Compare | Conditional Branch | Not Bit | Fill String | | Compare and | Compare and | Check Bit | Compare String | | Increment | Branch | Alter Bit | Scan Byte for | | Compare and | | Scan for Bit | Equal | | Decrement | | Scan over Bit | Equal | | Compare Mixed | l | Extract | 1 | | | | Modify | | | Conversion | Decimal | Call/Return | Process | | Convert Real to | | | Management | | | Move | Call | Schedule Process | | Integer | Add with Carry | Call Extended | Saves Process | | Convert Integer to | Subtract with Carry | Call System | Resume Process | | Real | • | Return | Load Process Time | | Convert Address | | Branch and Link | | | | | | Modify Process | | | | Call Domain | Controls | | | | 1 | Wait | | i | | 1 | Conditional Wait | | | | 1 | Signal | | | | 1 | Receive | | I | | İ | Conditional | | | | 1 | | | | | | Receive | | l | | | Send | | | | | Send Service | | 1 | | l | Atomic Add | | į | | 1 | Atomic Modify | | ļ | | | Atomic Replace | | | | | Mixed | | Fault Conditional Fault | Debug Madit Town | Miscellaneous | AD Manipulation | | Synchronize Faults | Modify Trace<br>Controls | Flush Local | Amplify Rights | | -, | | Registers | Restrict Rights | | 1 | Mark | Inspect Access | Create AD | | ł | Force Mark | Modify Arithmetic | Check Tag | | ľ | | Controls | | | I | İ | Test Condition | | | | | | | - **6. Integer Execution Optimization.** When the result of an operation is used as an operand in a subsequent calculation, the value is sent immediately to its destination register. Yet at the same time, the value is put back on a bypass path to the ALU, thereby saving the time that otherwise would be required to retrieve the value for the next operation. - 7. Bandwidth Optimizations. The 80960XA gets optimal use of its memory bus bandwidth because the bus is tuned for use with the cache: the line size of the instruction cache matches the maximum burst size for instruction fetches. The 80960XA automatically fetches four words in a burst and stores them directly in the cache. Due to the size of the cache and the fact that it is continually filled in anticipation of needed instructions in the program flow, the 80960XA is exceptionally insensitive to memory wait states. The benefit is that the 80960XA will deliver outstanding performance even with a low cost memory system. - **8.** Cache Bypass. If there is a cache miss, the processor fetches the needed instruction, then sends it on to the instruction decoder at the same time it updates the cache. Thus, no extra time is taken to load and read the cache. # **Memory Space and Addressing Modes** The 80960XA allows each process to address a linear memory space of up to 4 Gbytes. This address space is divided into four 1-Gbyte regions. Each of these regions can be mapped to physical addresses by zero, one or two levels of page tables. The region with the highest addresses (Region 3) is common to all processes. By utilizing object addressing, the linear address space of the 80960XA for a single process is extended to a virtual address space of 2<sup>58</sup> bytes. In addition, the number of distinct address spaces within a running process is effectively unlimited so that each software module can be placed in its own address space. The processor provides two address-interpretation modes: physical-addressing mode and virtual-addressing mode. When operating in physical-addressing mode, the processor interprets each address operand in an instruction as a physical address and sends the address out to the bus unchanged. In virtual-addressing mode, the processor interprets each address operand as a virtual address. The on-chip memory management unit (MMU) translates the virtual address into a physical address, which the processor sends out to the bus. The physical addresses of the most recently accessed pages in memory are stored on-chip within the translation lookaside buffer (TLB). The 80960XA provides a rich set of addressing modes to support efficient execution of the Ada progamming language. Table 2 lists these memory addressing modes. # **Data Types** The 80960XA recognizes the following data types: ### Numeric: - 8-, 16-, 32- and 64-bit ordinals - 8-, 16, 32- and 64-bit integers - 32-, 64- and 80-bit real numbers ### Non-Numeric: - Bit - Bit Field - Triple-Word (96 bits) - Quad-Word (128 bits) - Mixed (33 bits) # Large Register Set The programming environment of the 80960XA includes a large number of registers. In fact, 36 registers are available at any time. The availability of this many registers greatly reduces the number of memory accesses required to execute most programs, which leads to greater instruction processing speed. There are two types of general-purpose registers: local and global. The 20 global registers consist of sixteen 32-bit registers (G0 through G15) and four 80-bit registers (FP0 through FP3). These registers perform the same function as the general-purpose registers provided in other popular microprocessors. The term global refers to the fact that these registers retain their contents across procedure calls. The local registers, on the other hand, are procedure specific. For each procedure call, the 80960XA allocates 16 local registers (R0 through R15). Each local register is 32 bits wide. Any register can also be used for floating-point operations; the 80-bit floating-point registers are provided for extended precision. # **Multiple Register Sets** To further increase the efficiency of the register set, multiple sets of local registers are stored on-chip. This cache holds up to four local register frames, which means that up to three procedure calls can be made without having to access the procedure stack resident in memory. ADVANCE INFORMATION **Table 2. Memory Addressing Modes** - 12-Bit Offset - 32-Bit Offset - Register-Indirect - Register + 12-Bit Offset - Register + 32-Bit Offset - Register + (Index-Register × Scale-Factor) - Register × Scale Factor + 32-Bit Displacement - Register + (Index-Register × Scale-Factor) + 32-Bit Displacement - Object Pointer + 12-Bit Offset - Object Pointer + 32-Bit Offset - Object Pointer + (Index-Register × Scale-Factor) - Object Pointer × Scale Factor + 32-Bit Displacement Scale-Factor is 1, 2, 4, 8 or 16 If there are four or more active procedures and a new procedure is called, the processor moves the oldest set of local registers in the register cache to a procedure stack in memory to make room for a new set of registers. Global register G15 is used by the processor as the frame pointer (FP) for the procedure stack. Note that the global and floating-point registers are not exchanged on a procedure call, but retain their contents, making them available to all procedures for fast parameter passing. An illustration of the register cache is shown in Figure 5. Figure 5. Multiple Register Sets Are Stored On-Chip advance information # intel. # **Instruction Cache** To further reduce memory accesses, the 80960XA includes a 512-byte on-chip instruction cache. The instruction cache is based on the concept of locality of reference; that is, most programs are not usually executed in a steady stream but consist of many branches and loops that lead to jumping back and forth within the same small section of code. Thus, by maintaining a block of instructions in a cache, the number of memory references required to read instructions into the processor can be greatly reduced. To load the instruction cache, instructions are fetched in 16-byte blocks, so that up to four instructions can be fetched at one time. An efficient prefetch algorithm increases the probability that an instruction will already be in the cache when it is needed. Code for small loops will often fit entirely within the cache, leading to a great increase in processing speed since further memory references might not be necessary until the program exits the loop. Similarly, when calling short procedures, the code for the calling procedure is likely to remain in the cache, so it will be there upon the procedure's return. # Register Scoreboarding The instruction decoder has been optimized in several ways. One of these optimizations is the ability to do instruction overlapping by means of register scoreboarding. Register scoreboarding occurs when a LOAD instruction is executed to move a variable from memory into a register. When the instruction is initiated, a scoreboard bit on the target register is set. When the register is actually loaded, the bit is reset. In between, any reference to the register contents is accompanied by a test of the scoreboard bit to insure that the load has completed before processing continues. Since the processor does not have to wait for the LOAD to be completed, it can go on to execute additional instructions placed in between the LOAD instruction and the instruction that uses the register contents, as shown in the following example: LOAD R4, address 1 LOAD R5, address 2 Unrelated instruction Unrelated instruction ADD R4, R5, R6 In essence, the two unrelated instructions between the LOAD and ADD instructions are executed for free (i.e., take no apparent time to execute) because they are executed while the register is being loaded. Up to three LOAD instructions can be pending at one time with three corresponding scoreboard bits set. By exploiting this feature, system programmers and compilers have a useful tool for optimizing execution speed. # Memory Management, Object Addressing and Protection The 80960XA is especially useful for multitasking applications that require software protection and a very large address space. To ensure a high level of integration, the memory management unit and the translation look-aside buffer are contained on-chip. The 80960XA supports a conventional form of demand-paged linear memory in which each process is designated its own address space of up to 4 Gbytes. This address space is divided into 4 Kbyte pages. Studies have shown that a 4 Kbyte page is the optimum size for a broad range of applications. The memory locations of the pages are kept within a page table. Each page table entry includes a 2-bit page rights field that specifies whether the page is a no-access, read-only, or read-write page. This field is interpreted differently depending on whether the current process is executing in user or supervisor mode, as shown below: | Rights | User | Supervisor | |--------|------------|------------| | 00 | No Access | Read-Only | | 01 | No Access | Read-Write | | 10 | Read-Only | Read-Write | | 11 | Read-Write | Read-Write | In addition, the 80960XA supports an object-oriented form of addressing and protection. With object-oriented programming, the 2<sup>32</sup> byte linear address space can be expanded to a 2<sup>58</sup> byte virtual address space. This virtual space is divided into typed, protected segments of memory known as **objects**. An object ranges in size from 64 bytes to 2<sup>32</sup> bytes. Up to 2<sup>26</sup> objects can be addressed, thus resulting in the 2<sup>58</sup> byte virtual address space. 10-108 The objects are addressed with a 33-bit memory pointer called an access descriptor (see Figure 6). In a 33-bit memory word, the 33rd bit, called the tag bit, identifies the contents of the word as either data or an access descriptor. The creation and modification techniques of access descriptors are carefully controlled. Any unauthorized attempts to modify a data word into an access descriptor will turn the tag bit off, thus making it impossible to forge a pointer to memory. Because the access descriptors are unforgeable, an added level of data security is introduced with this architecture. The protection provided by the tag bit isolates the individual address spaces and ensures that an error introduced in one software task cannot corrupt the reliability and security of other tasks. # Floating-Point Arithmetic In the 80960XA, floating-point arithmetic has been made an integral part of the architecture. Having the floating-point unit integrated on-chip provides two advantages. First, it improves the performance of the chip for floating-point applications, since no additional bus overhead is associated with floating-point calculations, thereby leaving more time for other bus operations such as I/O. Second, the cost of using floating-point operations is reduced because a separate coprocessor chip is not required. The 80960XA floating-point (real number) data types include single-precision (32-bit), double-precision (64-bit), and extended precision (80-bit) floating-point numbers. Any register may be used to execute floating-point operations. Figure 6. Virtual Addressing intel<sub>®</sub> The processor provides hardware support for both mandatory and recommended portions of IEEE Standard 754 for floating-point arithmetic, including all arithmetic, exponential, logarithmic, and other transcendental functions. Table 3 shows execution times for some representative instructions. Table 3. Sample Floating-Point Execution Times (μs) at 25 MHz | | 32-Bit | 64-Bit | |-------------|--------|--------| | Add | 0.4 | 0.5 | | Subtract | 0.4 | 0.5 | | Multiply | 0.7 | 1.3 | | Divide | 1.3 | 2.9 | | Square Root | 3.7 | 3.9 | | Arctangent | 10.1 | 13.1 | | Exponent | 11.3 | 12.5 | | Sine | 15.2 | 16.6 | | Cosine | 15.2 | 16.6 | # **Multitasking Support** Multitasking programs commonly involve the monitoring and control of an external operation, such as the activities of a process controller or the movements of a machine tool. These programs generally consist of a number of processes that run independently of one another, but share a common database or pass data among themselves. The 80960XA offers several hardware functions designed to support multitasking systems. One unique feature, called self-dispatching, allows a processor to switch itself automatically among scheduled tasks. When self-dispatching is used, all the operating system is required to do is place the task in the scheduling queue. When the processor becomes available, it dispatches the task from the beginning of the queue and then executes it until it becomes blocked, interrupted, or until its time-slice expires. It then returns the task to the end of the queue (i.e., automatically reschedules it) and dispatches the next ready task. During these operations, no communication between the processor and the operating system is necessary until the running task is complete or an interrupt is issued. # **Synchronization and Communication** The 80960XA also offers instructions to set up and test semaphores to ensure that concurrent tasks remain synchronized and no data inconsistency results. Special data structures, known as communication ports, provide the means for exchanging parameters and data structures. Transmission of information by means of communication ports is asynchronous and automatically buffered by the processor. Communication between tasks by means of ports can be carried out independently of the operating system. Once the ports have been set up by the programmer, the processor handles the message passing automatically. # High Bandwidth Local Bus An 80960XA CPU resides on a high-bandwidth address/data bus known as the local bus (L-Bus). The L-Bus provides a direct communication path between the processor and the memory and I/O subsystem interfaces. The processor uses the local bus to fetch instructions, manipulate memory, and respond to interrupts. Its features include: - · 32-bit multiplexed address/data path - Four-word burst capability, which allows transfers from 1 to 16 bytes at a time - High bandwidth reads and writes at 66.7 MBytes per second - Special signal to indicate whether a memory transaction can be cached Figure 7 identifies the groups of signals which constitute the L-Bus. Table 4 lists the function of the L-Bus and other processor-support signals, such as the interrupt lines. 10-110 Figure 7. Local Bus Signal Groups # **Multiple Processor Support** One means of increasing the processing power of a system is to run two or more processors in parallel. Since microprocessors are not generally designed to run in tandem with other processors, designing such a system is usually difficult and costly. The 80960XA solves this problem by offering a number of functions to coordinate the actions of multiple processors. First, messages can be passed between processors to initiate actions such as flushing a cache, stopping or starting another processor, or preempting a task. The messages are passed on the bus and allow multiple processors to run together smoothly, with rare need to lock the bus or memory. Second, a set of synchronization instructions help maintain the coherency of memory. These instructions permit several processors to modify memory at the same time without inserting inaccuracies or ambiguities into shared data structures. The self-dispatching mechanism, in addition to being used in single-processor systems, provides the means to increase the performance of a system merely by adding processors. Each processor can either work on the same pool of tasks (sharing the same queue with other processors) or can be restricted to its own queue. When processors perform system operations, they synchronize themselves by using atomic operations and sending special messages between each other. And changing the number of processors in a system never requires a software change. Software will execute correctly regardless of the number of processors in the system; systems with more processors simply execute faster. # **Interrupt Handling** The 80960XA can be interrupted in one of two ways: by the activation of one of four interrupt pins or by sending a message on the processor's data bus. The 80960XA is unusual in that it automatically handles interrupts on a priority basis and tracks pending interrupts through its on-chip interrupt controller. Two of the interrupt pins can be configured to provide M8259A handshaking for expansion beyond four interrupt lines. An interrupt message is made up of a vector number and an interrupt priority. If the interrupt priority is greater than that of the currently running task, the processor accepts the interrupt and uses the vector as an index into the interrupt table. If the priority of the interrupt message is below that of the current task, the processor saves the information in a section of the interrupt table reserved for pending interrupts. # **Debug Features** The 80960XA has built-in debug capabilities. There are two types of breakpoints and six different trace modes. The debug features are controlled by two internal 32-bit registers, the Process-Controls Word and the Trace-Controls Word. By setting bits in these control words, a software debug monitor can closely control how the processor responds during program execution. The 80960XA has both hardware and software breakpoints. It provides two hardware breakpoint registers on-chip which can be set by a special command to any value. When the instruction pointer matches the value in one of the breakpoint registers, the breakpoint will fire, and a breakpoint handling routine is called automatically. The 80960XA also provides software breakpoints through the use of two instructions, MARK and FMARK. These instructions can be placed at any point in a program and will cause the processor to halt execution at that point and call the breakpoint handling routine. The breakpoint mechanism is easy to use and provides a powerful debugging tool. Tracing is available for instructions (single-step execution), calls and returns, and branching. Each different type of trace may be enabled separately by a special debug instruction. In each case, the 80960XA executes the instruction first and then calls a trace handling routine (usually part of a software debug monitor). Further program execution is halted until the trace routine is completed. When the trace event handling routine is completed, instruction execution resumes at the next instruction. The 80960XA's tracing mechanisms, which are implemented completely in hardware, greatly simplify the task of testing and debugging software. # **FAULT DETECTION** The 80960XA has an automatic mechanism to handle faults. There are fourteen fault types including trace, arithmetic, and floating-point faults. When the processor detects a fault, it automatically calls the appropriate fault handling routine and saves the current instruction pointer and necessary state information to make efficient recovery possible. The processor posts diagnostic information on the type of fault to a Fault Record. Like interrupt handling routines, fault handling routines are usually written to meet the needs of a specific application and are often included as part of the operating system or kernel For each of the fourteen fault types, there are numerous subtypes that provide specific information about a fault. For example, a floating-point fault may have its subtype set to an Overflow or Zero-Divide fault. The fault handler can use this specific information to respond correctly to the fault. # Interagent Communications (IAC) In order to coordinate their actions, processors in a multiple processor system need a means for communicating with each other. The 80960XA does this through a mechanism known as Interagent Communication messages or IACs. IAC messages cause a variety of actions including starting and stopping processors, flushing instruction caches and TLBs, and sending interrupts to other processors in the system. The upper 16 Mbytes of the processor's physical memory space is reserved for sending and receiving IAC messages. # **BUILT-IN TESTABILITY** Upon reset, the 80960XA automatically conducts an exhaustive internal test of its major blocks of logic. Then, before executing its first instruction, it does a zero check sum on the first eight words in memory to ensure that the system has been loaded correctly. If a problem is discovered at any point during the self-test, the 80960XA will assert its FAILURE pin and will not begin program execution. The self-test takes approximately 47,000 cycles to complete. System manufacturers can use the 80960XA's selftest feature during incoming parts inspection. No special diagnostic programs need to be written, and the test is both thorough and fast. The self-test capability helps ensure that defective parts will be discovered before systems are shipped, and once in the field, the self-test makes it easier to distinguish between problems caused by processor failure and problems resulting from other causes. # COMPATIBILITY WITH OTHER 1960® PROCESSOR PRODUCTS Application programs written for the 80960K-Series and the 80960MC microprocessors can be run on the 80960XA without modification. The 80960K-Series and 80960MC instruction sets form a subset of the 80960XA's instructions, so binary compatibility is assured. 10-112 # **CHMOS** The 80960XA is fabricated using Intel's CHMOS IV (Complementary High Speed Metal Oxide Semiconductor) process. This advanced technology eliminates the frequency and reliability limitations of older CMOS processes and opens a new era in microprocessor performance. It combines the high performance capabilities of Intel's industry-leading HMOS III technology with the high density and low power characteristics of CMOS. The 80960XA is available at 16, 20 and 25 MHz versions. Table 4a. 80960XA Pin Description: L-Bus Signals | Symbol | Туре | Name and Function | | | | | | | |----------------------------------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--| | CLK2 | ł | SYSTEM CLOCK provides the fundamental timing for 80960XA systems. It is divided by two inside the 80960XA to generate the internal processor clock. CLK2 is shown in Figure 11. | | | | | | | | LAD <sub>31</sub><br>-LAD <sub>0</sub> | I/O<br>T.S. | LOCAL ADDRESS/DATA BUS carries 32-bit physical addresses and data to and from memory. During an address (T <sub>a</sub> ) cycle, bits 2–31 contain a physical word address (bits 0–1 indicate SIZE; see below). During a data (T <sub>d</sub> ) cycle, bits 0–31 contain read or write data. The LAD lines are active HIGH and float to a high impedance state when not active. | | | | | | | | | | SIZE, which is comprised of bits 0-1 of the LAD lines during a T <sub>a</sub> cycle, specifies the size of a transfer in words for a burst transaction. LAD 1 LAD 0 | | | | | | | | | | 0 0 1 Word<br>0 1 2 Words<br>1 0 3 Words<br>1 1 4 Words | | | | | | | | ĀLĒ | O<br>T.S. | <b>ADDRESS-LATCH ENABLE</b> indicates the transfer of a physical address. ALE is asserted during a $T_a$ cycle and deasserted before the beginning of the $T_d$ state. It is active LOW and floats to a high impedance state when the processor is idle or is at the end of any bus access. | | | | | | | | ĀDS | O<br>O.D. | <b>ADDRESS STATUS</b> indicates an address state. ADS is asserted every $T_a$ state and deasserted during the the following $T_d$ state. For a burst transaction, ADS is asserted again every $T_d$ state where READY was asserted in the previous cycle. | | | | | | | | W/R | O<br>O.D. | <b>WRITE/READ</b> specifies, during a $T_a$ cycle, whether the operation is a write or read. It is latched on-chip and remains valid during $T_d$ and $T_w$ states. | | | | | | | | DT/Ř | O<br>O.D. | <b>DATA TRANSMIT/RECEIVE</b> indicates the direction of data transfer to and from the L-Bus. It is low during $T_a$ , $T_w$ and $T_d$ cycles for a read or interrupt acknowledgement; it is high during $T_a$ , $T_w$ and $T_d$ cycles for a write. $DT/\overline{R}$ never changes state when $\overline{DEN}$ is asserted (see Timing Diagrams). | | | | | | | | DEN | O<br>O.D. | DATA ENABLE is asserted during T <sub>d</sub> and T <sub>w</sub> cycles and indicates transfer of data on the LAD bus lines. | | | | | | | | READY | I | <b>READY</b> indicates that data on LAD lines can be sampled or removed. If $\overline{READY}$ is not asserted during a $T_d$ cycle, the $T_d$ cycle is extended to the next cycle by inserting wait states ( $T_w$ ), and $\overline{ADS}$ is not asserted in the next cycle. | | | | | | | | LOCK | I/O<br>O.D. | BUS LOCK prevents other bus masters from gaining control of the L-Bus following the current cycle (if they would assert LOCK to do so). LOCK is used by the processor or any bus agent when it performs indivisible Read/Modify/Write (RMW) operations. | | | | | | | | | | For a read that is designated as a RMW-read, $\overline{\text{LOCK}}$ is examined. if asserted, the processor waits until it is not asserted; if not asserted, the processor asserts $\overline{\text{LOCK}}$ during the T <sub>a</sub> cycle and leaves it asserted. | | | | | | | | | | | | | | | | | I/O = Input/Output, O = Output, I = Input, O.D. = Open-Drain, T.S. = three state $T_a = T_{Address}$ , $T_d = T_{Data}$ , $T_W = T_{Wait}$ , $T_r = T_{Recovery}$ , $T_i = T_{Idle}$ , $T_h = T_{Hold}$ Table 4a. 80960XA Pin Description: L-Bus Signals (Continued) | Symbol | Туре | Name and Function | |----------------------------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | BE <sub>3</sub> -BE <sub>0</sub> | O<br>O.D. | BYTE ENABLE LINES specify which data bytes (up to four) on the bus take part in the current bus cycle. BE <sub>3</sub> corresponds to LAD <sub>31</sub> -LAD <sub>24</sub> and BE <sub>0</sub> corresponds to LAD <sub>7</sub> -LAD <sub>0</sub> . | | | | The byte enables are provided in advance of data. The byte enables asserted during $T_a$ specify the bytes of the first data word. The byte enables asserted during $T_d$ specify the bytes of the next data word (if any), that is, the word to be transmitted following the next assertion of $\overline{READY}$ . The byte enables during the $T_d$ cycles preceding the last assertion of $\overline{READY}$ are undefined. The byte enables are latched on-chip and remain constant from one $T_d$ cycle to the next when $\overline{READY}$ is not asserted. | | | | For reads, the byte enables specify the byte(s) that the processor will actually use. 80960XA's will assert only adjacent byte enables (e.g., asserting just $\overline{BE_0}$ and $\overline{BE_2}$ is not permitted), and are required to assert at least one byte enable. Accesses must also be naturally aligned (e.g., asserting $\overline{BE_1}$ and $\overline{BE_2}$ is not allowed even though they are adjacent). To produce address bits $A_0$ and $A_1$ externally, they can be decoded from the byte enables. | | HOLD<br>(HLDAR) | ı | <b>HOLD</b> indicates a request from a secondary bus master to acquire the bus. If the processor is initialized as the primary bus master this input will be interpreted as HOLD. When the processor receives HOLD and grants another master control of the bus, it floats its three-state bus lines, asserts HOLD ACKNOWLEDGE, and enters the $T_h$ state. When HOLD is deasserted, the processor will deassert HOLD ACKNOWLEDGE and go to either the $T_i$ or $T_a$ state. | | | | HOLD ACKNOWLEDGE RECEIVED indicates that the processor has acquired the bus. If the processor is initialized as the secondary bus master this input is interpreted as HLDAR. | | | | HOLD timing is shown in Figure 13. | | HLDA<br>(HOLDR) | O<br>T.S. | <b>HOLD ACKNOWLEDGE</b> relinquishes control of the bus to another bus master. If the processor is initialized as the primary bus master this output will be interpreted as HLDA. When HOLD is deasserted, the processor will deassert HLDA and go to either the $T_i$ or $T_a$ state. | | | | HOLD REQUEST indicates a request to acquire the bus. If the processor is initialized as the secondary bus master this output will be interpreted as HOLDR. | | | | HOLD timing is shown in Figure 13. | | CACHE/TAG | I/O<br>T.S. | <b>CACHE</b> is an output signal that indicates if an access is cacheable during a $T_a$ cycle. The CACHE signal floats to a high impedance state when the processor is idle. TAG is an input/output signal that during $T_d$ and $T_w$ cycles identifies the contents of a 32-bit word as either data (TAG = 0) or an access descriptor (TAG = 1). | $\begin{aligned} &|/O = \text{Input/Output, O} = \text{Output, I} = \text{Input, O.D.} = \text{Open-Drain, T.S.} = \text{three state} \\ &T_a = T_{\text{Address, T}_d} = T_{\text{Data, T}_W} = T_{\text{Wait, T}_r} = T_{\text{Recovery, T}_i} = T_{\text{Idle, T}_h} = T_{\text{Hold}} \end{aligned}$ 10-114 Table 4b. 80960XA Pin Description: Module Support Signals | Symbol | Tuna | Table 40. 60960XA PIn Description: Module Support Signals | |----------------------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | BADAC | Туре | Name and Function | | BADAC | | BAD ACCESS, if asserted in the cycle following the one in which the last READY of a transaction is asserted, indicates that an unrecoverable error has occurred on the current bus transaction, or that a synchronous load/store instruction has not been acknowledged. | | | | STARTUP: During system reset, the BADAC signal is interpreted differently. If the signal is high, it indicates that this processor will perform system initialization. If it is low, another processor in the system will perform system initialization instead. | | RESET | 1 | RESET clears the internal logic of the processor and causes it to re-initialize. | | | | During RESET assertion, the input pins are ignored (except for BADAC and IAC/INT <sub>0</sub> ), the tri-state output pins are placed in a high impedance state, and other output pins are placed in their non-asserted state. | | | | RESET must be asserted for at least 41 CLK2 cycles for a predictable RESET. The HIGH to LOW transition of RESET should occur after the rising edge of both CLK2 and the external bus CLK, and before the next rising edge of CLK2. | | | | RESET timing is shown in Figure 12. | | FAILURE | O<br>O.D. | INITIALIZATION FAILURE indicates that the processor has failed to initialize correctly. After RESET is deasserted and before the first bus transaction begins, FAILURE is asserted while the processor performs a self-test. If the self-test completes successfully, then FAILURE is deasserted. Next, the processor performs a zero checksum on the first eight words of memory. If it fails, FAILURE is asserted for a second time and remains asserted; if it passes, system initialization continues and FAILURE remains deasserted. | | N.C. | N/A | <b>NOT CONNECTED</b> indicates pins should not be connected. Never connect any pin marked N.C. | | IAC<br>(INT <sub>0</sub> ) | | INTERAGENT COMMUNICATION REQUEST/INTERRUPT 0 indicates either that there is a pending IAC message for the processor or an interrupt. The bus interrupt control register determines in which way the signal should be interpreted. To signal an interrupt or IAC request in a synchronous system, this pin (as well as the other interrupt pins) must be enabled by being deasserted for at least one bus cycle and then asserted for at least one additional bus cycle; in an asynchronous system, the pin must remain deasserted for at least two bus cycles and then be asserted for at least two more bus cycles. | | | | LOCAL PROCESSOR NUMBER: This signal is interpreted differently during system reset. If the signal is at a high voltage level, it indicates that this processor is a primary bus master (Local Processor Number = 0); if it is at a low voltage level, it indicates that this processor is a secondary bus master (Local Processor Number = 1). | | INT <sub>1</sub> | 1 | INTERRUPT 1, like INT <sub>0</sub> , provides direct interrupt signaling. | | INT <sub>2</sub><br>(INTR) | İ | <b>INTERRUPT 2/INTERRUPT REQUEST:</b> The bus control registers determines how this pin is interpreted. If $INT_2$ , it has the same interpretation as the $\overline{INT_0}$ and $INT_1$ pins. If $INT_R$ , it is used to receive an interrupt request from an external interrupt controller. | | INT <sub>3</sub><br>(INTA) | I/O<br>O.D. | <b>INTERRUPT 3/INTERRUPT ACKNOWLEDGE:</b> The bus interrupt control register determines how this pin is interpreted. If $\overline{\text{INT}_3}$ , it has the same interpretation as the $\overline{\text{INT}_0}$ , $\overline{\text{INT}_1}$ , and $\overline{\text{INT}_2}$ pins. If $\overline{\text{INTA}}$ , it is used as an output to control interrupt-acknowledge bus transactions. The $\overline{\text{INTA}}$ output is latched on-chip and remains valid during $T_d$ cycles; as an output, it is open-drain. | ADVANCE INFORMATION # ELECTRICAL SPECIFICATIONS Power and Grounding The 80960XA is implemented in CHMOS IV technology and has modest power requirements. Its high clock frequency and numerous output buffers (address/data, control, error and arbitration signals) can cause power surges as multiple output buffers drive new signal levels simultaneously. For clean on-chip power distribution at high frequency, 12 V<sub>CC</sub> and 13 V<sub>SS</sub> pins separately feed functional units of the 80960XA. Power and ground connections must be made to all power and ground pins of the 80960XA. On the circuit board, all V<sub>CC</sub> pins must be strapped closely together, preferably on a power plane. Likewise, all V<sub>SS</sub> pins should be strapped together, preferably on a ground plane. # **Power Decoupling Recommendations** Liberal decoupling capacitance should be placed near the 80960XA. The processor can cause transient power surges when driving the L-Bus, particularly when it is connected to a large capacitive load. Low inductance capacitors and interconnects are recommended for best high frequency electrical performance. Inductance can be reduced by shortening the board traces between the processor and decoupling capacitors as much as possible. # **Connection Recommendations** For reliable operation, always connect unused inputs to an appropriate signal level. In particular, if one or more interrupt lines are not used, they should be pulled up or down to their respective deasserted states. No inputs should ever be left floating. All open-drain outputs require a pullup device. While in some cases a simple pullup resistor will be adequate, we recommend a network of pullup and pull-down resistors biased to a valid $V_{IH}~(\geq~3.4V)$ and terminated in the characteristic impedance of the circuit board. Figure 8 shows our recommendations for the resistor values for both a low and high current drive network, which assumes that the circuit board has a characteristic impedance of $100\Omega.$ The advantage of terminating the output signals in this fashion is that it limits signal swing and reduces AC power consumption. # **Characteristic Curves** Figure 9 shows the typical supply current requirements over the operating temperature range of the processor at supply voltage ( $V_{CC}$ ) of 5V. Figure 10 shows the typical power supply current ( $I_{CC}$ ) required by the 80960XA at various operating frequencies when measured at three input voltage ( $V_{CC}$ ) levels. Figure 11 shows the typical capacitive derating curve for the 80960XA measured from 1.5V on the system clock (CLK) to 0.8V on the falling edge and 2.0V on the rising edge of the L-Bus address/data (LAD) signals. Figure 8. Connection Recommendations for Low and High Current Drive Networks 10-116 Figure 9. Typical Supply Current (I<sub>CC</sub>) 10 Figure 10. Typical Current vs Frequency # **Test Load Circuit** Figure 12 illustrates the load circuit used to test the 80960XA's tristate pins, and Figure 13 shows the load circuit used to test the open drain outputs. The open drain test uses an active load circuit in the form of a matched diode bridge. Since the open-drain outputs sink current, only the $I_{OL}$ legs of the bridge are necessary and the $I_{OH}$ legs are not used. When the 80960XA driver under test is turned off, the output pin is pulled up to $V_{REF}$ (i.e., $V_{OH}$ ). Diode $D_1$ is turned off and the $I_{OL}$ current source flows through diode $D_2$ . When the 80960XA open-drain driver under test is on, diode $D_1$ is also on, and the voltage on the pin being tested drops to $V_{OL}$ . Diode $D_2$ turns off and $I_{OL}$ flows through diode $D_1$ . Figure 11. Capacitive Derating Curve Figure 12. Test Load Circuit for Tri-State Output Pins Figure 13. Test Load Circuit for Open-Drain Output Pins # **ABSOLUTE MAXIMUM RATINGS\*** Case Temperature under Bias(6) −55°C to + 125°C Storage Temperature −65°C to + 150°C Voltage on Any Pin −0.5V to V<sub>CC</sub> + 0.5V Power Dissipation 2.6W (25 MHz) NOTICE: This data sheet contains information on products in the sampling and initial production phases of development. The specifications are subject to change without notice. Verify with your local Intel Sales office that you have the latest data sheet before finalizing a design. \*WARNING: Stressing the device beyond the "Absolute Maximum Ratings" may cause permanent damage. These are stress ratings only. Operation beyond the "Operating Conditions" is not recommended and extended exposure beyond the "Operating Conditions" may affect device reliability. # **DC CHARACTERISTICS** 80960XA: $T_{CASE}(6) = -55^{\circ}C$ to $+ 125^{\circ}C$ , $V_{CC} = 5V \pm 5\%$ | Symbol | Parameter | Min | Max | Units | Test Conditions | |----------------------|----------------------------------------------------------------------------------------|----------------------|-----------------------|----------------|-----------------------------------------| | V <sub>I</sub> L | Input Low Voltage | -0.3 | +0.8 | ٧ | | | V <sub>IH</sub> | Input High Voltage | 2.0 | V <sub>CC</sub> + 0.3 | V | | | V <sub>CL</sub> | CLK2 Input Low Voltage | -0.3 | +0.8 | V | | | V <sub>CH</sub> | CLK2 Input High Voltage | 0.55 V <sub>CC</sub> | V <sub>CC</sub> + 0.3 | V | | | VOL | Output Low Voltage | | 0.45 | V | (1, 5) | | V <sub>OH</sub> | Output High Voltage | 2.4 | | V | (2, 4) | | lcc | Power Supply Current:<br>16 MHz<br>20 MHz<br>25 MHz | | 375<br>420<br>480 | mA<br>mA<br>mA | | | 1 <sub>LI</sub> | Input Leakage Current | | ±15 | μА | 0 ≤ V <sub>O</sub> ≤ V <sub>CC</sub> | | ILO | Output Leakage Current | | ±15 | μА | 0.45 ≤ V <sub>O</sub> ≤ V <sub>CC</sub> | | C <sub>IN</sub> | Input Capacitance | | 10 | pF | f <sub>C</sub> = 1 MHz(3) | | Co | I/O or Output Capacitance | | 12 | ρF | f <sub>C</sub> = 1 MHz <sup>(3)</sup> | | C <sub>CLK</sub> | Clock Capacitance | | 10 | pF | f <sub>C</sub> = 1 MHz(3) | | $ heta_{ extsf{JA}}$ | Thermal Resistance<br>(Junction-to-Ambient)<br>Pin Grid Array<br>Ceramic Quad Flatpack | | 21<br>29 | °C/W<br>°C/W | | | θJC | Thermal Resistance<br>(Junction-to-Case)<br>Pin Grid Array<br>Ceramic Quad Flatpack | | 4<br>8 | *C/W | | # NOTES: | For three-state outputs, this parameter is measured at: Address (Note). | | |--------------------------------------------------------------------------|---------| | Address/Data | 4.0 mA | | 2. This parameter is measured at: | | | Address/Data | 1.0 mA | | Controls | O a m A | | ALE | 5.0 mA | | 4. Not measured on open-drain outputs. | | | 5. For open-drain outputs | .25 mA | | 6. Case temperatures are "instant on". | //// | 10-118 # **AC SPECIFICATIONS** This section describes the AC specifications for the 80960XA pins. All input and output timings are specified relative to the 1.5V level of the rising edge of CLK2, and refer to the time at which the signal reaches (for output delay and input setup) or leaves (for hold time) the TTL levels of LOW (0.8V) or HIGH (2.0V). All AC testing should be done with input voltages of 0.4V and 2.4V, except for the clock (CLK2), which should be tested with input voltages of 0.45V and 0.55 $V_{CC}. \label{eq:controller}$ Figure 15. Timing Relationship of L-Bus Signals # **AC Specification Tables** 80960XA AC Characteristics (16 MHz) $T_{CASE}^{(3)} = -55^{\circ}C$ to $+125^{\circ}C$ , $V_{CC} = 5V \pm 5\%$ | Symbol | Parameter | Min | Max | Units | Test Conditions | |------------------|-------------------------------------|-------|-----|-------|----------------------------------------------------------------------| | T <sub>1</sub> | Processor Clock<br>Period (CLK2) | 31.25 | 125 | ns | V <sub>IN</sub> = 1.5V | | T <sub>2</sub> | Processor Clock<br>Low Time (CLK2) | 8 | | ns | V <sub>IL</sub> = 10% Point<br>= 1.2V | | Т3 | Processor Clock<br>High Time (CLK2) | 8 | | ns | V <sub>IH</sub> = 90% Point<br>= 0.1V + 0.5 V <sub>CC</sub> | | T <sub>4</sub> | Processor Clock<br>Fall Time (CLK2) | | 10 | ns | V <sub>IN</sub> = 90% Point to 10%<br>Point | | T <sub>5</sub> | Processor Clock<br>Rise Time (CLK2) | | 10 | ns | V <sub>IN</sub> = 10% Point to 90%<br>Point | | T <sub>6</sub> | Output Valid<br>Delay | 2 | 25 | ns | C <sub>L</sub> = 100 pF (LAD)<br>C <sub>L</sub> = 75 pF (Controls) | | T <sub>6H</sub> | HOLDA Output<br>Valid Delay | 4 | 31 | ns | C <sub>L</sub> = 75 pF | | Т7 | ALE Width | 15 | | ns | C <sub>L</sub> = 75 pF | | T <sub>8</sub> | ALE Invalid Delay | 0 | 20 | ns | $C_L = 75 pF(2)$ | | Tg | Output Float<br>Delay | 2 | 20 | ns | $C_L = 100 \text{ pF (LAD)}$<br>$C_L = 75 \text{ pF (Controls)}$ (2) | | T <sub>9H</sub> | HOLDA Output<br>Float Delay | 4 | 20 | ns | C <sub>L</sub> = 75 pF | | T <sub>10</sub> | Input Setup 1 | 3 | | ns | (Note 1) | | T <sub>11</sub> | Input Hold | 5 | | ns | (Note 1) | | T <sub>11H</sub> | HOLD Input Hold | 4 | | ns | | | T <sub>12</sub> | Input Setup 2 | 8 | | ns | | | T <sub>13</sub> | Setup to ALE<br>Inactive | 10 | | ns | $C_L = 100 \text{ pF (LAD)}$<br>$C_L = 75 \text{ pF (Controls)}$ | | T <sub>14</sub> | Hold after ALE<br>Inactive | 8 | | ns | $C_L = 100 \text{ pF (LAD)}$<br>$C_L = 75 \text{ pF (Controls)}$ | | T <sub>15</sub> | Reset Hold | 3 | | ns | | | T <sub>16</sub> | Reset Setup | 5 | | ns | | | T <sub>17</sub> | Reset Width | 1281 | | ns | 41 CLK2 Periods Minimum | NOTES: 1. IAC/INT<sub>0</sub>, INT<sub>1</sub>, INT<sub>2</sub>/INTR, INT<sub>3</sub> can be asynchronous. 2. A float condition occurs when the maximum output current becomes less than I<sub>LO</sub>. Float delay is not tested, but should be no longer than the valid delay. 3. Case temperatures are "instant on". # **AC Specification Tables (Continued)** 80960XA AC Characteristics (20 MHz) $T_{CASE}^{(3)} = -55^{\circ}C$ to $+125^{\circ}C$ , $V_{CC} = 5V \pm 5\%$ | Symbol | Parameter | Min | Max | Units | Test Conditions | |------------------|-------------------------------------|------|-------------|-------|--------------------------------------------------------------------| | T <sub>1</sub> | Processor Clock<br>Period (CLK2) | 25 | 125 | ns | V <sub>IN</sub> = 1.5V | | T <sub>2</sub> | Processor Clock<br>Low Time (CLK2) | 6 | | ns | V <sub>IL</sub> = 10% Point<br>= 1.2V | | Т3 | Processor Clock<br>High Time (CLK2) | 6 | | ns | V <sub>IH</sub> = 90% Point<br>= 0.1V + 0.5 V <sub>CC</sub> | | T <sub>4</sub> | Processor Clock<br>Fall Time (CLK2) | | 10 | ns | V <sub>IN</sub> = 90% Point to 10%<br>Point | | T <sub>5</sub> | Processor Clock<br>Rise Time (CLK2) | | 10 | ns | V <sub>IN</sub> = 10% Point to 90%<br>Point | | T <sub>6</sub> | Output Valid<br>Delay | 2 | 20 | ns | $C_L = 60 \text{ pF (LAD)}$<br>$C_L = 50 \text{ pF (Controls)}$ | | Т <sub>6Н</sub> | HOLDA Output<br>Valid Delay | 4 | 26 | ns | $C_L = 50 \text{ pF}$ | | Т7 | ALE Width | 12 | | ns | C <sub>L</sub> = 50 pF | | T <sub>8</sub> | ALE Invalid Delay | 0 | 20 | ns | $C_L = 50 \text{pF}(2)$ | | Т9 | Output Float<br>Delay | 2 | 20 | ns | $C_L = 60 \text{ pF (LAD)}$<br>$C_L = 50 \text{ pF (Controls)}(2)$ | | T <sub>9H</sub> | HOLDA Output<br>Float Delay | 4 | 20 | ns | $C_L = 50 \text{ pF}$ | | T <sub>10</sub> | Input Setup 1 | 3 | | ns | (Note 1) | | T <sub>11</sub> | Input Hold | 5 | 1 | ns | (Note 1) | | T <sub>11H</sub> | HOLD Input Hold | 4 | | ns | | | T <sub>12</sub> | Input Setup 2 | 7 | | ns | | | T <sub>13</sub> | Setup to ALE<br>Inactive | 10 | | ns | C <sub>L</sub> = 60 pF (LAD)<br>C <sub>L</sub> = 50 pF (Controls) | | T <sub>14</sub> | Hold after ALE<br>Inactive | 8 | | ns | C <sub>L</sub> = 60 pF (LAD)<br>C <sub>L</sub> = 50 pF (Controls) | | T <sub>15</sub> | Reset Hold | 3 | | ns | -L copi (controls) | | T <sub>16</sub> | Reset Setup | 5 | | ns | | | T <sub>17</sub> | Reset Width | 1025 | <del></del> | ns | 41 CLK2 Periods Minimum | 10-122 NOTES: 1. IAC/INT<sub>0</sub>, INT<sub>1</sub>, INT<sub>2</sub>/INTR, INT<sub>3</sub> can be asynchronous. 2. A float condition occurs when the maximum output current becomes less than I<sub>LO</sub>. Float delay is not tested, but should be no longer than the valid delay. 3. Case temperatures are "instant on". # **AC Specification Tables (Continued)** 80960XA AC Characteristics (25 MHz) $T_{CASE}^{(3)} = -55^{\circ}C$ to $+125^{\circ}C$ , $V_{CC} = 5V \pm 5\%$ | Symbol | Parameter | Min | Max | Units | Test Conditions | |------------------|-------------------------------------|-----|-----|-------|--------------------------------------------------------------------| | Т1 | Processor Clock<br>Period (CLK2) | 20 | 125 | ns | V <sub>IN</sub> = 1.5V | | Т2 | Processor Clock<br>Low Time (CLK2) | 5 | | ns | V <sub>IL</sub> = 10% Point<br>= 1.2V | | Т3 | Processor Clock<br>High Time (CLK2) | 5 | | ns | V <sub>IH</sub> = 90% Point<br>= 0.1V + 0.5 V <sub>CC</sub> | | T <sub>4</sub> | Processor Clock<br>Fall Time (CLK2) | | 10 | ns | V <sub>IN</sub> = 90% Point to<br>10% Point | | T <sub>5</sub> | Processor Clock<br>Rise Time (CLK2) | | 10 | ns | V <sub>IN</sub> = 10% Point to<br>90% Point | | Т <sub>6</sub> | Output Valid<br>Delay | 2 | 19 | ns | $C_L = 60 \text{ pF (LAD)}$<br>$C_L = 50 \text{ pF (Controls)}$ | | T <sub>6H</sub> | HOLDA Output<br>Valid Delay | 4 | 24 | ns | C <sub>L</sub> = 50 pF | | T <sub>7</sub> | ALE Width | 12 | | ns | C <sub>L</sub> = 50 pF | | T <sub>8</sub> | ALE Invalid<br>Delay | 0 | 20 | ns | $C_L = 50 pF(2)$ | | T <sub>9</sub> | Output Float<br>Delay | 2 | 19 | ns | $C_L = 60 \text{ pF (LAD)}$<br>$C_L = 50 \text{ pF (Controls)}(2)$ | | T <sub>9H</sub> | HOLDA Output<br>Float Delay | 4 | 20 | ns | C <sub>L</sub> = 50 pF | | T <sub>10</sub> | Input Setup 1 | 3 | | ns | (Note 1) | | T <sub>11</sub> | Input Hold | 5 | | ns | (Note 1) | | T <sub>11H</sub> | HOLD Input Hold | 4 | | ns | | | T <sub>12</sub> | Input Setup 2 | 7 | | ns | | | T <sub>13</sub> | Setup to ALE<br>Inactive | 8 | | ns | $C_L = 60 \text{ pF (LAD)}$<br>$C_L = 50 \text{ pF (Controls)}$ | | T <sub>14</sub> | Hold after ALE<br>Inactive | 8 | | ns | $C_L = 60 \text{ pF (LAD)}$<br>$C_L = 50 \text{ pF (Controls)}$ | | T <sub>15</sub> | Reset Hold | 3 | | ns | | | T <sub>16</sub> | Reset Setup | 5 | | ns | | | T <sub>17</sub> | Reset Width | 820 | | ns | 41 CLK2 Periods Minimum | NOTES: 1. IAC/INT<sub>0</sub>, INT<sub>1</sub>, INT<sub>2</sub>/INTR, INT<sub>3</sub> can be asynchronous. 2. A float condition occurs when the maximum output current becomes less than I<sub>LO</sub>. Float delay is not tested, but should be no longer than the valid delay. <sup>3.</sup> Case temperatures are "instant on". Figure 16. Processor Clock Pulse (CLK2) Figure 17. RESET Signal Timing 10-124 Figure 18. Hold Timing # **Design Considerations** Input hold times can be disregarded by the designer whenever the input is removed because a subsequent output from the processor is deasserted (e.g., $\overline{\text{DEN}}$ becomes deasserted). In other words, whenever the processor generates an output that indicates a transition into a subsequent state, the processor must have sampled any inputs for the previous state. Similarly, whenever the processor generates an output that indicates a transition into a subsequent state, any outputs that are specified to be three stated in this new state are guaranteed to be three stated. # **MECHANICAL DATA** # Pin Assignment The 80960XA is packaged in a 132-lead ceramic pin grid array and a 164-lead ceramic quad flatpack. The 80960XA pin grid array pinout as viewed from the substrate side of the component is shown in Figure 19 and from the pin side in Figure 20. The 80960XA ceramic quad flatpack pinout as viewed from the top of the package is shown in Figure 21. $V_{CC}$ and GND connections must be made to multiple $V_{CC}$ and GND pins. Each $V_{CC}$ and GND pin must be connected to the appropriate voltage or ground and externally strapped close to the package. Preferably, the circuit board should include power and ground planes for power distribution. Tables 5, 6, 7 and 8 list the function of each pin. # NOTE: Pins identified as N.C., "No Connect," should never be connected under any circumstances. # **Package Dimensions and Mounting** Pins in the pin grid array package are arranged 0.100 inch (2.54mm) center-to-center, in a 14 by 14 matrix, three rows around. (See Figure 22.) advance information A wide variety of available sockets allow low-insertion or zero-insertion force mountings, and a choice of terminals such as soldertail, surface mount, or wire wrap. Several applicable sockets are shown in Figure 23. measured at the center of the top surface opposite the pins as shown in Figure 24. The ceramic quad flatpack case temperature should be measured at the center of the lid on the top surface of the package. # **Package Thermal Specification** # The 80960XA is specified for operation when its case temperature is within the range of -55°C to +125°C. The PGA case temperature should be # **WAVEFORMS** Figures 25 through 31 show the waveforms for various transactions on the 80960XA's local bus. Figure 19. MG80960XA Pinout—View from Top (Pins Facing Down) 10-126 Figure 20. MG80960XA Pinout--View from Bottom (Pins Facing Up) Figure 21. MQ80960XA Pinout—View from Top of Package 10-128 # int<sub>el</sub>. Table 5. MG80960XA (PGA) Pinout—In Pin Order | Pin | Signal | Pin | Signal | Pin | Signal | Pin | Signal | |-----|------------------------|-----|------------------------|-----|-----------------|-----|-----------------| | A1 | V <sub>CC</sub> | C6 | LAD <sub>20</sub> | H1 | W/R | M10 | V <sub>SS</sub> | | A2 | V <sub>SS</sub> | C7 | LAD <sub>13</sub> | H2 | BE <sub>0</sub> | M11 | V <sub>CC</sub> | | A3 | LAD <sub>19</sub> | C8 | LAD <sub>8</sub> | НЗ | LOCK | M12 | N.C. | | A4 | LAD <sub>17</sub> | C9 | LAD <sub>3</sub> | H12 | N.C | M13 | N.C. | | A5 | LAD <sub>16</sub> | C10 | V <sub>CC</sub> | H13 | N.C. | M14 | N.C. | | A6 | LAD <sub>14</sub> | C11 | V <sub>SS</sub> | H14 | N.C. | N1 | V <sub>SS</sub> | | A7 | LAD <sub>11</sub> | C12 | INT <sub>3</sub> /INTA | J1 | DT/R | N2 | N.C. | | A8 | LAD <sub>9</sub> | C13 | INT <sub>1</sub> | J2 | BE <sub>2</sub> | N3 | N.C. | | A9 | LAD <sub>7</sub> | C14 | IAC/INT <sub>0</sub> | J3 | Vss | N4 | N.C. | | A10 | LAD <sub>5</sub> | D1 | ALE | J12 | N.C | N5 | N.C. | | A11 | LAD <sub>4</sub> | D2 | ADS | J13 | N.C. | N6 | N.C. | | A12 | LAD <sub>1</sub> | D3 | HLDA/HLDR | J14 | N.C. | N7 | N.C. | | A13 | INT <sub>2</sub> /INTR | D12 | Vcc | K1 | BE <sub>3</sub> | N8 | N.C. | | A14 | V <sub>CC</sub> | D13 | N.C. | K2 | FAILURE | N9 | N.C. | | B1 | LAD <sub>23</sub> | D14 | N.C. | К3 | V <sub>SS</sub> | N10 | N.C. | | B2 | LAD <sub>24</sub> | E1 | LAD <sub>28</sub> | K12 | Vcc | N11 | N.C. | | B3 | LAD <sub>22</sub> | E2 | LAD <sub>26</sub> | K13 | N.C. | N12 | N.C. | | B4 | LAD <sub>21</sub> | E3 | LAD <sub>27</sub> | K14 | N.C. | N13 | N.C. | | B5 | LAD <sub>18</sub> | E12 | N.C. | L1 | DEN | N14 | N.C. | | B6 | LAD <sub>15</sub> | E13 | V <sub>SS</sub> | L2 | N.C. | P1 | V <sub>CC</sub> | | B7 | LAD <sub>12</sub> | E14 | N.C. | L3 | V <sub>CC</sub> | P2 | N.C. | | B8 | LAD <sub>10</sub> | F1 | LAD <sub>29</sub> | L12 | V <sub>SS</sub> | P3 | N.C. | | B9 | LAD <sub>6</sub> | F2 | LAD <sub>31</sub> | L13 | N.C. | P4 | N.C. | | B10 | LAD <sub>2</sub> | F3 | CACHE/TAG | L14 | N.C. | P5 | N.C. | | B11 | CLK2 | F12 | N.C. | M1 | N.C. | P6 | N.C. | | B12 | LAD <sub>0</sub> | F13 | N.C. | M2 | Vcc | P7 | N.C. | | B13 | RESET | F14 | N.C. | МЗ | V <sub>SS</sub> | P8 | N.C. | | B14 | V <sub>SS</sub> | G1 | LAD <sub>30</sub> | M4 | V <sub>SS</sub> | P9 | N.C. | | C1 | HOLD/HLDAR | G2 | READY | M5 | V <sub>CC</sub> | P10 | N.C. | | C2 | LAD <sub>25</sub> | G3 | BE <sub>1</sub> | М6 | N.C. | P11 | N.C. | | C3 | BADAC | G12 | N.C. | M7 | N.C. | P12 | N.C. | | C4 | V <sub>CC</sub> | G13 | N.C. | M8 | N.C. | P13 | V <sub>SS</sub> | | C5 | V <sub>SS</sub> | G14 | N.C. | М9 | N.C. | P14 | V <sub>CC</sub> | NOTE: Pins identified as N.C. ("No Connect") should never be connected under any circumstances. **ADVANCE INFORMATION** Table 6. MG80960XA (PGA) Pinout—In Signal Order | Signal | Pin | Signal | Pin | Signal | Pin | Signal | Pin | |------------------------|-----|-------------------|-----|--------|-----|-----------------|-----| | ADS | D2 | LAD <sub>15</sub> | В6 | N.C. | J14 | N.C. | P9 | | ALE | D1 | LAD <sub>16</sub> | A5 | N.C. | K13 | N.C. | P10 | | BADAC | C3 | LAD <sub>17</sub> | A4 | N.C. | K14 | N.C. | P11 | | BE <sub>0</sub> | H2 | LAD <sub>18</sub> | B5 | N.C. | L13 | N.C. | P12 | | BE <sub>1</sub> | G3 | LAD <sub>19</sub> | А3 | N.C. | L14 | N.C. | L2 | | BE <sub>2</sub> | J2 | LAD <sub>20</sub> | C6 | N.C. | M1 | READY | G2 | | BE <sub>3</sub> | K1 | LAD <sub>21</sub> | B4 | N.C. | M6 | RESET | B13 | | CACHE/TAG | F3 | LAD <sub>22</sub> | B3 | N.C. | M7 | Vcc | A1 | | CLK2 | B11 | LAD <sub>23</sub> | B1 | N.C. | M8 | Vcc | A14 | | DEN | L1 | LAD <sub>24</sub> | B2 | N.C. | M9 | V <sub>CC</sub> | C4 | | DT/R | J1 | LAD <sub>25</sub> | C2 | N.C. | M12 | V <sub>CC</sub> | C10 | | FAILURE | K2 | LAD <sub>26</sub> | E2 | N.C. | M13 | V <sub>CC</sub> | D12 | | HLDA/HOLDR | D3 | LAD <sub>27</sub> | E3 | N.C. | M14 | V <sub>CC</sub> | K12 | | HOLD/HLDAR | C1 | LAD <sub>28</sub> | E1 | N.C. | N2 | V <sub>CC</sub> | L3 | | IAC/INT <sub>0</sub> | C14 | LAD <sub>29</sub> | F1 | N.C. | N3 | V <sub>CC</sub> | M2 | | INT <sub>1</sub> | C13 | LAD <sub>30</sub> | G1 | N.C. | N4 | V <sub>CC</sub> | M5 | | INT <sub>2</sub> /INTR | A13 | LAD <sub>31</sub> | F2 | N.C. | N5 | V <sub>CC</sub> | M11 | | INT <sub>3</sub> /INTA | C12 | LOCK | НЗ | N.C. | N6 | V <sub>CC</sub> | P1 | | LAD <sub>0</sub> | B12 | N.C. | D13 | N.C. | N7 | Vcc | P14 | | LAD <sub>1</sub> | A12 | N.C. | D14 | N.C. | N8 | V <sub>SS</sub> | A2 | | LAD <sub>2</sub> | B10 | N.C. | E12 | N.C. | N9 | V <sub>SS</sub> | B14 | | LAD <sub>3</sub> | C9 | N.C. | E14 | N.C. | N10 | V <sub>SS</sub> | C5 | | LAD <sub>4</sub> | A11 | N.C. | F12 | N.C. | N11 | V <sub>SS</sub> | C11 | | LAD <sub>5</sub> | A10 | N.C. | F13 | N.C. | N12 | V <sub>SS</sub> | E13 | | LAD <sub>6</sub> | B9 | N.C. | F14 | N.C. | N13 | V <sub>SS</sub> | J3 | | LAD <sub>7</sub> | A9 | N.C. | G12 | N.C. | N14 | V <sub>SS</sub> | КЗ | | LAD <sub>8</sub> | C8 | N.C. | G13 | N.C. | P2 | V <sub>SS</sub> | L12 | | LAD <sub>9</sub> | A8 | N.C. | G14 | N.C. | P3 | V <sub>SS</sub> | M3 | | LAD <sub>10</sub> | B8 | N.C. | H12 | N.C. | P4 | V <sub>SS</sub> | M4 | | LAD <sub>11</sub> | A7 | N.C. | H13 | N.C. | P5 | V <sub>SS</sub> | M10 | | LAD <sub>12</sub> | B7 | N.C. | H14 | N.C. | P6 | V <sub>SS</sub> | N1 | | LAD <sub>13</sub> | C7 | N.C. | J12 | N.C. | P7 | V <sub>SS</sub> | P13 | | LAD <sub>14</sub> | A6 | N.C. | J13 | N.C. | P8 | W/R | H1 | **NOTE:** Pins identified as N.C. ("No Connect") should never be connected under any circumstances. 10-130 Table 7. MQ80960XA (CQP) Pinout—In Pin Order | Table 7. MQ80960XA (CQP) Pinout—In Pin Order | | | | | | | | |----------------------------------------------|-------------------|-----|-------------------|-----|-----------------|-----|-----------------| | 1 | Signal | Pin | Signal | Pin | Signal | Pin | Signal | | <u> </u> | BE <sub>0</sub> | 42 | LAD <sub>11</sub> | 83 | N.C. | 124 | N.C. | | 3 | BE <sub>3</sub> | 43 | LAD <sub>12</sub> | 84 | Vcc | 125 | V <sub>SS</sub> | | 4 | READY | 44 | LAD <sub>9</sub> | 85 | N.C. | 126 | Vcc | | <u> </u> | BE <sub>1</sub> | 45 | LAD <sub>10</sub> | 86 | N.C. | 127 | N.C. | | 5 | CACHE/TAG | 46 | LAD <sub>7</sub> | 87 | V <sub>SS</sub> | 128 | N.C. | | 6. | DT/R | 47 | LAD <sub>8</sub> | 88 | N.C. | 129 | N.C. | | 7 | LAD <sub>31</sub> | 48 | LAD <sub>5</sub> | 89 | N.C. | 130 | N.C. | | 8 | W/R | 49 | LAD <sub>6</sub> | 90 | N.C. | 131 | N.C. | | 9 | LAD <sub>29</sub> | 50 | LAD <sub>4</sub> | 91 | N.C. | 132 | N.C. | | 10 | LAD <sub>30</sub> | 51 | LAD <sub>1</sub> | 92 | N.C. | 133 | N.C. | | 11 | LAD <sub>27</sub> | 52 | CLK <sub>2</sub> | 93 | N.C. | 134 | N.C. | | 12 | LAD <sub>28</sub> | 53 | INT <sub>2</sub> | 94 | N.C. | 135 | N.C. | | 13 | ALE | 54 | LAD <sub>3</sub> | 95 | N.C. | 136 | N.C. | | 14 | LAD <sub>26</sub> | 55 | LAD <sub>2</sub> | 96 | N.C. | 137 | N.C. | | 15 | ADS | 56 | LAD <sub>0</sub> | 97 | N.C. | 138 | N.C. | | 16 | HLDA | 57 | RESET | 98 | N.C. | 139 | N.C. | | 17 | N.C. | 58 | INT <sub>3</sub> | 99 | N.C. | 140 | N.C. | | 18 | V <sub>SS</sub> | 59 | INT <sub>1</sub> | 100 | Vcc | 141 | N.C. | | 19 | V <sub>CC</sub> | 60 | V <sub>SS</sub> | 101 | N.C. | 142 | N.C. | | 20 | V <sub>SS</sub> | 61 | V <sub>CC</sub> | 102 | N.C. | 143 | N.C. | | 21 | V <sub>CC</sub> | 62 | V <sub>SS</sub> | 103 | V <sub>SS</sub> | 144 | N.C. | | 22 | V <sub>CC</sub> | 63 | Vcc | 104 | N.C. | 145 | N.C. | | 23 | V <sub>SS</sub> | 64 | V <sub>SS</sub> | 105 | N.C. | 146 | N.C. | | 24 | V <sub>CC</sub> | 65 | V <sub>CC</sub> | 106 | N.C. | 147 | N.C. | | 25 | V <sub>SS</sub> | 66 | V <sub>SS</sub> | 107 | N.C. | 148 | N.C. | | 26 | Vcc | 67 | Vcc | 108 | N.C. | 149 | N.C. | | 27 | HOLD | 68 | N.C. | 109 | N.C. | 150 | N.C. | | 28 | BADAC | 69 | N.C. | 110 | N.C. | 151 | N.C. | | 29 | LAD <sub>25</sub> | 70 | N.C. | 111 | N.C. | 152 | N.C. | | 30 | LAD <sub>24</sub> | 71 | N.C. | 112 | N.C. | 153 | V <sub>SS</sub> | | 31 | LAD <sub>23</sub> | 72 | N.C. | 113 | N.C. | 154 | V <sub>CC</sub> | | 32 | LAD <sub>21</sub> | 73 | N.C. | 114 | N.C. | 155 | N.C. | | 33 | LAD <sub>22</sub> | 74 | N.C. | 115 | N.C. | 156 | N.C. | | 34 | LAD <sub>19</sub> | 75 | ĪNT <sub>0</sub> | 116 | N.C. | 157 | N.C. | | 35 | LAD <sub>20</sub> | 76 | N.C. | 117 | N.C. | 158 | V <sub>SS</sub> | | 36 | LAD <sub>17</sub> | 77 | N.C. | 118 | N.C. | 159 | N.C. | | 37 | LAD <sub>18</sub> | 78 | N.C. | 119 | V <sub>SS</sub> | 160 | LOCK | | 38 | LAD <sub>16</sub> | 79 | N.C. | 120 | V <sub>CC</sub> | 161 | FAIL | | 39 | LAD <sub>15</sub> | 80 | N.C. | 121 | N.C. | 162 | DEN | | 40 | LAD <sub>14</sub> | 81 | N.C. | 122 | N.C. | 163 | BE <sub>2</sub> | | 41 | LAD <sub>13</sub> | 82 | N.C. | 123 | N.C. | 164 | | | | | | | 0 | 14.0. | 104 | $V_{SS}$ | NOTE: Pins identified as N.C. ("No Connect") should never be connected under any circumstances. ADVANCE INFORMATION Table 8. MQ80960XA (CQP) Pinout—In Signal Order | Signal | Pin | Signal | Pin | Signal | Pin | Signal | Pin | |------------------------|-----|-------------------|-----|--------|-----|-----------------|-----| | ĀDS | 15 | LAD <sub>23</sub> | 31 | N.C. | 102 | N.C. | 148 | | ALE | 13 | LAD <sub>24</sub> | 30 | N.C. | 104 | N.C. | 149 | | BADAC | 28 | LAD <sub>25</sub> | 29 | N.C. | 105 | N.C. | 150 | | BE <sub>0</sub> | 1 | LAD <sub>26</sub> | 14 | N.C. | 106 | N.C. | 151 | | BE <sub>1</sub> | 4 | LAD <sub>27</sub> | 11 | N.C. | 107 | N.C. | 152 | | BE <sub>2</sub> | 163 | LAD <sub>28</sub> | 12 | N.C. | 108 | N.C. | 155 | | BE <sub>3</sub> | 2 | LAD <sub>29</sub> | 9 | N.C. | 109 | N.C. | 156 | | CACHE/TAG | 5 , | LAD <sub>30</sub> | 10 | N.C. | 110 | N.C. | 157 | | CLK2 | 52 | LAD <sub>31</sub> | 7 | N.C. | 111 | N.C. | 159 | | DÉN | 162 | LOCK | 160 | N.C. | 112 | READY | 3 | | DT/R | 6 | N.C. | 17 | N.C. | 113 | RESET | 57 | | FAILURE | 161 | N.C. | 68 | N.C. | 114 | Vcc | 19 | | HLDA/HOLDR | 16 | N.C. | 69 | N.C. | 115 | Vcc | 21 | | HOLD/HLDAR | 27 | N.C. | 70 | N.C. | 116 | Vcc | 22 | | IAC/INT <sub>0</sub> | 75 | N.C. | 71 | N.C. | 117 | Vcc | 24 | | INT <sub>1</sub> | 59 | N.C. | 72 | N.C. | 118 | V <sub>CC</sub> | 26 | | INT <sub>2</sub> /INTR | 53 | N.C. | 73 | N.C. | 121 | V <sub>CC</sub> | 61 | | INT <sub>3</sub> /INTA | 58 | N.C. | 74 | N.C. | 122 | Vcc | 63 | | LAD <sub>0</sub> | 56 | N.C. | 76 | N.C. | 123 | V <sub>CC</sub> | 65 | | LAD <sub>1</sub> | 51 | N.C. | 77 | N.C. | 124 | V <sub>CC</sub> | 67 | | LAD <sub>2</sub> | 55 | N.C. | 78 | N.C. | 127 | V <sub>CC</sub> | 84 | | LAD <sub>3</sub> | 54 | N.C. | 79 | N.C. | 128 | Vcc | 100 | | LAD <sub>4</sub> | 50 | N.C. | 80 | N.C. | 129 | V <sub>CC</sub> | 120 | | LAD <sub>5</sub> | 48 | N.C. | 81 | N.C. | 130 | V <sub>CC</sub> | 126 | | LAD <sub>6</sub> | 49 | N.C. | 82 | N.C. | 131 | V <sub>CC</sub> | 154 | | LAD <sub>7</sub> | 46 | N.C. | 83 | N.C. | 132 | V <sub>SS</sub> | 18 | | LAD <sub>8</sub> | 47 | N.C. | 85 | N.C. | 133 | V <sub>SS</sub> | 20 | | LAD <sub>9</sub> | 44 | N.C. | 86 | N.C. | 134 | V <sub>SS</sub> | 23 | | LAD <sub>10</sub> | 45 | N.C. | 88 | N.C. | 135 | V <sub>SS</sub> | 25 | | LAD <sub>11</sub> | 42 | N.C. | 89 | N.C. | 136 | V <sub>SS</sub> | 60 | | LAD <sub>12</sub> | 43 | N.C. | 90 | N.C. | 137 | V <sub>SS</sub> | 62 | | LAD <sub>13</sub> | 41 | N.C. | 91 | N.C. | 138 | V <sub>SS</sub> | 64 | | LAD <sub>14</sub> | 40 | N.C. | 92 | N.C. | 139 | V <sub>SS</sub> | 66 | | LAD <sub>15</sub> | 39 | N.C. | 93 | N.C. | 140 | V <sub>SS</sub> | 87 | | LAD <sub>16</sub> | 38 | N.C. | 94 | N.C. | 141 | V <sub>SS</sub> | 103 | | LAD <sub>17</sub> | 36 | N.C. | 95 | N.C. | 142 | V <sub>SS</sub> | 119 | | LAD <sub>18</sub> | 37 | N.C. | 96 | N.C. | 143 | V <sub>SS</sub> | 125 | | LAD <sub>19</sub> | 34 | N.C. | 97 | N.C. | 144 | V <sub>SS</sub> | 153 | | LAD <sub>20</sub> | 35 | N.C. | 98 | N.C. | 145 | V <sub>SS</sub> | 158 | | LAD <sub>21</sub> | 32 | N.C. | 99 | N.C. | 146 | V <sub>SS</sub> | 164 | | LAD <sub>22</sub> | 33 | N.C. | 101 | N.C. | 147 | W/R | 8 | NOTE: Pins identified as N.C. ("No Connect") should never be connected under any circumstances. 10-132 Figure 22. A 132-Lead Pin-Grid Array (PGA) Used to Package the MG80960XA Figure 23. Several Socket Options for Mounting the MG80960XA 10-134 ADVANCE INFORMATION Courtesy Advanced Interconnections (Peel-A-Way Terminal Carriers U.S. Patent No. 4442938) \*Peel-A-Way is a trademark of Advanced Interconnections. # intel. # 80960XA Figure 25. System and Processor Clock Relationship Figure 24. Measuring MG80960XA PGA Case Temperature (T<sub>C</sub>) Figure 26. Read Transaction Figure 27. Write Transaction with One Wait State 10% Figure 28. Burst Read Transaction Figure 29. Burst Write Transaction with One Wait State advance information Figure 30. Interrupt Acknowledge Transaction Figure 31. Bus Exchange Transaction (PBM = Primary Bus Master, SBM = Secondary Bus Master) # **DOMESTIC SERVICE OFFICES** ### ALABAMA \*Intel Corp. 5015 Bradford Dr., Sulte 2 Huntsville 35805 Tel: (205) 830-4010 Intel Corp. c/o TransAlaska Data Systems 300 Old Steese Hwy. Fairbanks 99701-3120 Tel: (907) 452-4401 Intel Corp. c/o TransAlaska Data Systems 1551 Lore Road Anchorage 99507 Tel: (907) 522-1776 ### ARIZONA \*Intel Corp. 11225 N. 28th Dr. Suite D-214 Phoenix 85029 Tel: (602) 869-4980 \*Intel Corp. 500 E, Fry Blvd., Suite M-15 Sierra Vista 85635 Tel: (602) 459-5010 ### CALIFORNIA †Intel Corp. 21515 Vanowen St., Ste. 116 Canoga Park 91303 Tel: (818) 704-8500 \*Intel Corp. 2250 E. Imperial Hwy., Ste. 218 El Segundo 90245 Tel: (213) 640-6040 \*Intel Corp. 1900 Prairie City Rd. Folsom 95630-9597 Tel: (916) 351-6143 1-800-468-3548 Intel Corp. 9665 Cheasapeake Dr., Suite 325 San Diego 92123-1326 Tel: (619) 292-8086 \*\*Intel Corp. 400 N. Tustin Avenue Suite 450 Santa Ana 92705 Tel: (714) 835-9642 \*\*fintel Corp. San Tomas 4 2700 San Tomas Exp., 2nd Floor Santa Clara 95051 Tel: (408) 986-8086 ### COLORADO \*Intel Corp. 650 S, Cherry St., Suite 915 Denver 80222 Tel: (303) 321-8086 ### CONNECTICUT \*Intel Corp. 301 Lee Farm Corporate Park 83 Wooster Heights Rd. Danbury 06810 Tel: (203) 748-3130 ### FLORIDA \*\*Intel Corp. 6363 N.W. 6th Way, Ste. 100 Ft. Lauderdale 33309 Tel: (305) 771-0600 \*Intel Corp. 5850 T.G. Lee Blyd., Ste. 340 Orlando 32822 Tel: (407) 240-8000 # GEORGIA \*Intel Corp. 3280 Pointe Pkwy., Ste. 200 Norcross 30092 Tel: (404) 449-0541 ### HAWAII \*Intel Corp. U.S.I.S.C. Signal Batt. Building T-1521 Shafter Plats Shafter 96856 ### ILLINOIS \*\*fintel Corp. 300 N. Martingale Rd., Ste. 400 Schaumburg 60173 Tel: (312) 605-8031 ### ΙΝΠΙΔΝΔ \*Intel Corp. 8777 Purdue Rd., Ste. 125 Indianapolis 46268 Tel: (317) 875-0623 \*Intel Corp. 10985 Cody, Suite 140 Overland Park 66210 Tel: (913) 345-2727 ### MARYLAND \*\*fintel Corp. 10010 Junction Dr., Sulte 200 Annapolis Junction 20701 Tel: (301) 206-2860 FAX: 301-206-3677 ### MASSACHUSETTS \*\*†Intel Corp. 3 Carlisle Rd., 2nd Floor Westford 01886 Tel: (508) 692-1060 ### MICHIGAN \*†Intel Corp. 7071 Orchard Lake Rd., Ste. 100 West Bloomfield 48322 Tel: (313) 851-8905 ### MINNESOTA \*†Intel Corp. 3500 W. 80th St., Suite 360 Bloomington 55431 Tel: (612) 835-6722 ### MISSOURI \*Intel Corp. 4203 Earth City Exp., Ste. 131 Earth City 63045 Tel: (314) 291-1990 ### **NEW JERSEY** \*\*Intel Corp. 300 Sylvan Avenue Englewood Cliffs 07632 Tel: (201) 567-0821 \*Intel Corp. Parkway 109 Office Center 328 Newman Springs Road Red Bank 07701 Tel: (201) 747-2233 \*Intel Corp. 280 Corporate Center 75 Livingston Ave., 1st Floor Roseland 07068 Tel: (201) 740-0111 \*†Intel Corp. 2950 Expressway Dr. South Islandla 11722 Tel: (516) 231-3300 \*Intel Corp. Westage Business Center Bidg. 300, Route 9 Fishkill 12524 Tel: (914) 897-3860 ### NORTH CAROLINA \*Intel Corp. 5800 Executive Dr., Ste. 105 Charlotte 28212 Tel: (704) 568-8966 \*\*Intel Corp. 2700 Wydiff Road Suite 102 Raleigh 27607 Tel; (919) 781-8022 ### OHO \*\*†Intel Corp. 3401 Park Center Dr., Ste. 220 Dayton 45414 Tel: (513) 890-5350 \*†Intel Corp. 25700 Science Park Dr., Ste. 100 Beachwood 44122 Tel: (216) 464-2736 ### OREGON Intel Corp. 15254 N.W. Greenbrier Parkway Building B Beaverton 97005 Tel: (503) 645-8051 \*Intel Corp. 5200 N.E. Elam Young Parkway Hillsboro 97123 Tel: (503) 681-8080 ### PENNSYLVANIA \*†Intel Corp. 455 Pennsylvania Ave., Ste. 230 Fort Washington 19034 Tel: (215) 641-1000 †Intel Corp. 400 Penn Center Blvd., Ste. 610 Pittsburgh 15235 Tel: (412) 823-4970 Intel Corp. 1513 Cedar Cliff Dr. Camp Hill 17011 Tel: (717) 761-0860 # PUERTO RICO Intel Corp. South Industrial Park P.O. Box 910 Las Piedras 00671 Tel: (809) 733-8616 # TEXAS Intel Corp. 8815 Dyer St., Suite 225 El Paso 79904 Tel: (915) 751-0186 \*Intel Corp. 313 E. Anderson Lane, Suite 314 Austin 78752 Tel: (512) 454-3628 \*\*†Intel Corp. 12000 Ford Rd., Suite 401 Dallas 75234 Tel: (214) 241-8087 \*Intel Corp. 7322 S.W. Freeway, Ste. 1490 Houston 77074 Tel: (713) 988-8086 # UTAH Intel Corp. 428 East 6400 South, Ste. 104 Murray 84107 Tel: (801) 263-8051 VIRGINIA \*Intel Corp. 1504 Santa Rosa Rd., Ste. 108 Richmond 23288 Tel: (804) 282-5668 ### WASHINGTON \*Intel Corp. 155 108th Avenue N.E., Ste. 386 Bellevue 98004 Tel: (206) 453-8086 # **CANADA** ### ONTARIO Intel Semiconductor of Tel: (613) 829-9714 FAX: 613-820-5936 Intel Semiconductor of Intel Semiconductor of Canada, Ltd. 190 Attwell Dr., Ste. 102 Rexdale M9W 6H8 Tel: (416) 675-2105 FAX: 416-675-2438 # **CUSTOMER TRAINING CENTERS** # CALIFORNIA 2700 San Tomas Expressway Santa Clara 95051 Tel: (408) 970-1700 1-800-421-0386 ### ILLINOIS 300 N. Martingale Road 300 N. Martingaro N. Suite 300 Schaumburg 60173 Tel: (708) 706-5700 1-800-421-0386 # MASSACHUSETTS 3 Carlisle Road, First Floor Westford 01886 Tel: (301) 220-3380 1-800-328-0386 # MARYLAND 10010 Junction Dr. Suite 200 Annapolis Junction 20701 Tel: (301) 206-2860 1-800-328-0386 # SYSTEMS ENGINEERING MANAGERS OFFICES # MINNESOTA 3500 W. 80th Street Suite 360 Bloomington 55431 Tel: (612) 835-6722 2950 Expressway Dr., South Islandia 11722 Tel: (506) 231-3300 †System Engineering locations \*Carry-in locations \*\*Carry-In/mail-In locations CG/SALE/101789