# Intel® 80960 QUICKval **Quick Reference Card** January 2001 Order Number: 649788-004 Information in this document is provided in connection with Intel<sup>®</sup> products. No license, express or implied, by estoppel or otherwise, to any intellectual property rights is granted by this document. Except as provided in Intel's Terms and Conditions of Sale for such products, Intel assumes no liability whatsoever, and Intel disclaims any express or implied warranty, relating to sale and/or use of Intel<sup>®</sup> products including liability or warranties relating to fitness for a particular purpose, merchantability, or infringement of any patent, copyright or other intellectual property right. Intel<sup>®</sup> products are not intended for use in medical, life saving, or life sustaining applications. Intel may make changes to specifications and product descriptions at any time, without notice. Designers must not rely on the absence or characteristics of any features or instructions marked "reserved" or "undefined." Intel reserves these for future definition and shall have no responsibility whatsoever for conflicts or incompatibilities arising from future changes to them. The Intel<sup>®</sup> 80960 may contain design defects or errors known as errata which may cause the product to deviate from published specifications. Current characterized errata are available on request. Contact your local Intel sales office or your distributor to obtain the latest specifications and before placing your product order. Copies of documents which have an ordering number and are referenced in this document, or other Intel literature may be obtained by calling 1-800-548-4725 or by visiting Intel's website at http://www.intel.com. Copyright © Intel Corporation, 2001 \*Other names and brands may be claimed as the property of others. | 1.0 | Wher | e Do I Start? | 5 | |---------|--------------------------|---------------------------------------------------------------------------------------------------------------------|--------------| | | 1.1<br>1.2<br>1.3 | For Intel® i960® Rx Processor Developers: Which Strategy Should You Use? Writing Assembly with the 80960Rx Strategy | 7 | | 2.0 | QUIC | Kreference Contact Guide | 8 | | | 2.1<br>2.2<br>2.3 | Important Phone Numbers | 8 | | 3.0 | QUIC | K <i>val</i> Example Programs | 9 | | 4.0 | Intel® | Intel® i960® Cx/Jx/Hx Processor Features Summary1 | | | Figures | | | | | | 1<br>2 | If You Have an Intel® i960® Rx Processor QUICK val Kit | | | Tables | | | | | | 3-1<br>3-2<br>4-3<br>4-4 | Programs/Source Files Needed | . 12<br>. 13 | #### 1.0 Where Do I Start? Figure 1. If You Have an Intel® i960® Rx Processor QUICK val Kit #### NOTES: - 1. All chapter references refer to "Getting Started with the 80960 QUICKval Kit". - 2. See Section 1.1, "For Intel® i960® Rx Processor Developers: Which Strategy Should You Use?" on page 6 for more information. Figure 2. If You Have an Intel® i960® Hx/Jx/Cx/Sx Processor QUICK val Kit NOTE: 1. All chapter references refer to "Getting Started with the 80960 QUICKval Kit". # 1.1 For Intel® i960® Rx Processor Developers: Which Strategy Should You Use? When writing software for the 80960RP/RD processors, you have two choices for the architecture setting that you use when generating code. You can specify the 80960Rx architecture ("80960Rx Strategy"), or you can specify the 80960JF architecture ("80960Jx Strategy"). Use these questions to help you decide which of the two development paths you should follow: - 1. How important is forward-compatibility with future 80960 processors? Use the 80960Rx Strategy if you wish to minimize the effort involved in moving to future 80960Rx processors. - 2. Will you be writing your code from scratch? When writing new applications, follow the 80960Rx Strategy when possible. Tests have shown that there is seldom a significant performance or code size penalty. - 3. How important is backward-compatibility with other 80960 core processors (e.g., 80960Kx/Cx/Jx)? If you have legacy code that you wish to use with the 80960Rx processors, you may wish to use the 80960Jx Strategy. This gives the most flexibility in terms of available instructions and addressing modes. - 4. How much low-level processor access do you need? If you need access to low-level processor resources beyond that provided in the updated assembler pseudo-instructions, you must use the 80960Jx Strategy. #### 1.2 Writing Assembly with the 80960Rx Strategy - Use -ARx (e.g., -ARP) switch to get CTOOLS 80960Rx Strategy enhancements. - If migrating code written for other 80960 core processors, use the xlate960 utility as a starting point. xlate960: generates 80960Rx Strategy compatible code to replace instructions and addressing modes that appear in the80960JF processor only. • If you need to use some 80960JF processor specific features not supported in the 80960Rx Strategy, use the new assembler pseudo-instructions whenever possible. The assembler pseudo instructions provide an architecture-independent method of performing some of the more common low-level processing operations. Benefit: The pseudo-instructions should not require modification when the source code is re-assembled for future80960Rx processors. #### 1.3 Writing Assembly without the 80960Rx Strategy - Use -AJF switch to write code that is designed for the 80960JF-based Rx (e.g., 80960RP/RD) processors only. You can still simplify future migration efforts by staying within the boundaries of the 80960Rx Strategy whenever possible. - For low-level processor functionality, you may wish to use the new assembler pseudo-instructions. This eases future migration without excluding use of 80960Jx-Specific constructs. Please refer to the i960® Processor Assembler User's Guide for more information. ### 2.0 QUICKreference Contact Guide #### 2.1 Important Phone Numbers - Technical Support Group 1-800-628-8686 - Intel Literature Center 1-800-548-4725 ### 2.2 Important E-Mail Addresses - 80960 Technical Support Group - 960tools@intel.com #### 2.3 Important Internet Sites - Embedded Design Products http://developer.intel.com/design/product.htm - Technical Support Page http://developer.intel.com/design/i960/index.htm - i960® Processor Software Tools Patches Page http://developer.intel.com/design/i960/patches/ ## 3.0 QUICK*val* Example Programs ### Table 3-1. Programs/Source Files Needed (Sheet 1 of 3) | Description | Source Files Needed | |---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------| | Hello World: | hello.c: source | | Uses simple printf statement to verify system integrity. | filesystem.c: system file | | Memory Test: Used for system verification of external memory. The programs perform byte, short, or word writes to external memory, and then they check the addresses written for correctness. | memtst8.c: 8-bit memory test memtst16.c: 16-bit memory test memtst32.c: 32-bit memory test system.c: system file | | Data Cache: | | | Uses the Minimum Edit Distance Algorithm to demonstrate the effectiveness of the on-chip data cache. This example also shows how to enable and disable the data cache; furthermore, it demonstrates how to configure an area of memory for caching. | dcache.c: source file system.c: system file | | Instruction Cache: | | | Uses simple loop to demonstrate how to enable and disable the instruction cache. It also highlights the performance advantage obtained when using the on-chip instruction cache. | loop.c: source file system.c: system file | | External Interrupts: Shows how to configure the Cyclone board timers to trigger hardware interrupts. This is also an example of using interrupt handlers and placing the handlers in the interrupt table. | cyint.c: source file asm_fns.s: interrupt handler-SX int_proc.s: interrupt handler-allprocessors but SX t85c36.c: eval board timer file system.c: system file | | Internal Interrupts: | timrcntr.c: source file | | Simple timer example that is used to show how to overlay the memory mapped registers with a structure to program the on-chip timers. It also includes routines to instruct you on how to set up interrupt routines using the timers. | timers.c: on-chip timer file system.c: system file | | Halt Mode: | | | This program shows how to make the processor enter halt mode, a power saving state that reduces energy consumption and heat dissipation as it waits to continue code execution. The example uses the on-chip timers to trigger interrupts and "wake" the processor. | halt.c: source file incremen.s: interrupt handler system.c: system file | | Foult Lloading | fault.c: source file | | Fault Handling: Shows the steps taken in setting up the fault handling procedures in the fault and system procedure tables. The faults shown are : arithmetic, constraint, operation, protection, parallel, & type. | flt_proc.c: fault procedures asm_flt.s: assembly functions to help generate fault ssystem.c: system file | | | reg_int.c: source file | | Register Cache: | low_int.s: interrupt handler for low priority | | Demonstrates the use of the on-chip register cache in reducing the interrupt latency for high priority interrupts. | high_int.s: interrupt handler for high priority | | | system.c: system file | | CheckSum: | ahlawa ayawa Si | | Uses typical checksum routine to show how to add benchmarking routines into source code. It is then used to show you the performance advantage of optimizing compilers and two-pass compilations. | chksum.c: source file<br>system.c: system file | #### Table 3-1. Programs/Source Files Needed (Sheet 2 of 3) | | dma.c: source file | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------| | DMA (80960Cx): | <pre>int_rout.c: DMA interrupt handling routines</pre> | | Provides an example of programming the DMA controller of the 80960CX microprocessor. This example is setup for block mode chaining transfer. | dma.s: will configure DMA channel 0 and provide chainedlinked buffers | | | system.c: system file | | DMA (80960Rx) Tutorial: | | | Demonstrates how to set-up the DMA controller, the Primary Address Translation Unit (ATU), the Secondary ATU, and the PCI-To-PCI Bridge Unit. | rpdma.c. source file | | Messaging Unit Tutorial: | hostcode.c: source file | | Demonstrates the messaging unit of the 80960Rx processor | rp_code.c: source file | | Cave Tutorial: | | | Uses a tic tac toe game to show how to reduce target memory requirements. The text sections of compressed and uncompressed tic tac toe executables are compared. Additionally, this example demonstrates how to specify functions for compression. | ttt.c: source file | | Profiling Lab: | chksum.c: Source file | | Teaches you how to use some of CTOOLS advanced profiling features. | Criksum.c. Source lile | | Self-Contained Profile Tutorial: | | | Teaches you how to create a self-contained profile that captures the program structure and associates it with the program counters from a raw profile. When the source program changes, the global decision making step interpolates or stretches the counters in the self-contained profile to fit the changed program. | quick.c: Source file | | Incremental Profiling Tutorial: | | | Teaches you how to profile a program in pieces and then re-combine them later, a useful methodology when the target execution environment is memory limited | fault.c flt_proc.c asm_flt.s system.c: Source files | | Local Optimizations: | | | Shows how to use the C compiler with high levels of static optimization for improved runtime performance. | chksum.c system.c Source files | | Global Optimizations: | | | Shows how to use program-wide optimizations of the C compiler for increased performance. | chksum.c system.c Source files | | C++ Local Optimizations: | | | Shows how to use the C++ compiler with high levels of static optimization for improved runtime performance. | optimize.cpp: Source file | | C++ Global Optimizations: | | | Shows how to use program-wide optimizations of the C++ compiler for increased performance. | optimize.cpp: Source file | | C++ Virtual Function Optimizations: | | | In many situations, a call to a virtual function can be replaced by a direct call to a member function, and, if possible, it may be inlined at the call site. This improves the runtime performance of the code. | optimize.cpp: Source file | | C++ Cave Tutorial: | | | Uses a C++ program to show how to reduce target memory requirements. The text sections of compressed and uncompressed C++ executables are compared. Additionally, this example demonstrates how to specify functions for compression. | cavecpp.cpp: Source file | | Teaches you how to create a self-contained profile that captures the program structure and associates it with the program counters from a raw profile. When the source program changes, the global decision making step interpolates or stretches the counters in the self-contained profile to fit the changed program. Incremental Profiling Tutorial: Teaches you how to profile a program in pieces and then re-combine them later, a useful methodology when the target execution environment is memory limited Local Optimizations: Shows how to use the C compiler with high levels of static optimization for improved runtime performance. Global Optimizations: Shows how to use program-wide optimizations of the C compiler for increased performance. C++ Local Optimizations: Shows how to use the C++ compiler with high levels of static optimization for improved runtime performance. C++ Global Optimizations: Shows how to use program-wide optimizations of the C++ compiler for increased performance. C++ Virtual Function Optimizations: In many situations, a call to a virtual function can be replaced by a direct call to a member function, and, if possible, it may be inlined at the call site. This improves the runtime performance of the code. C++ Cave Tutorial: Uses a C++ program to show how to reduce target memory requirements. The text sections of compressed and uncompressed C++ executables are compared. Additionally, this example demonstrates how | fault.c flt_proc.c asm_flt.s system.c: Source file chksum.c system.c: Source file chksum.c system.c: Source file optimize.cpp: Source file optimize.cpp: Source file | #### Table 3-1. Programs/Source Files Needed (Sheet 3 of 3) | xlate960 Assembly Language Converter Tutorial: Shows you how you can use xlate960 to convert assembly language code written for one 80960 processor family member to that of another. | xlt.s: Source file | |---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------| | 80960 Processor Assembler Pseudo-Instruction Support Tutorial: A tutorial that shows you how to use the new pseudo-ops that have been added to the assembler. | pseudop.c: Source file | | Linker Directive Language: | | | A hyperlinked manual that describes the linker command options. | | | Linker Consumption Tutorial: Shows the ability of the linker, gld960, to consume b.out-format, COFF, or ELF object files and libraries in any combination. | cyint.c int_proc.s<br>t85c36.c system.c: Source files | | Debugging with gdb960 Tutorial: | fish.c: source file | | Uses the Go Fish card game to teach a few useful debugger commands. | system.c: system file | | ELF/DWARF Debugging Format Tutorial: | | | Demonstrates that at the highest level of module-local optimization, it is possible to set a breakpoint on an in-line function. | swap.c: Source file | | C++ DWARF-2 Debugging Format Tutorial: | | | Demonstrates that at the highest level of module-local optimization, it is possible to debug aC++ application. | cppdwarf.cpp: Source file | | Retargeting MON960: | | | The Retargeting MON960 chapter is hyperlinked for your convenience. | | | Writing Flash Tutorial: Demonstrates how to update the version of MON960 on your evaluation board. | | | 80960Rx Processor Initialization Code: | | | Shows the Memory Controller, System Init, and Hardware Init Code. | | | 80960 Family Benchmark: | | | Used to compare your processor's performance with other i960 family members. | chksum.c system.c: Source files | | Remote Evaluation Facility: | | | Guides you through the use of this new benchmarking facility on the World-Wide Web. | | | | | Table 3-2. Processor/Compile Line | Processors Supported | Compile Line <arch> = RD, RP, HD, JF, CF, or SA</arch> | | |------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|--| | ALL | gcc960 -Fcoff -A <arch> -c hello.c system.c</arch> | | | ALL | gcc960 -Fcoff -A <arch> -c memtst*.c system.c NOTE: * refers to 8, 16, or 32.</arch> | | | 80960Rx, 80960Hx,<br>80960Jx and 80960Cx | gcc960 -Fcoff -A <arch> -c dcache.c system.c</arch> | | | 80960Rx, 80960Hx,<br>80960Jx and 80960Cx | gcc960 -Fcoff -A <arch> -c loop.c system.c</arch> | | | 80960Hx, 80960Jx,<br>80960Sx and 80960Cx | 80960Sx: gcc960 -Fcoff -ASA -ccyint.c asm_fns.s t85c36.c system.c Other: gcc960 -Fcoff -A <arch> -ccyint.c int_proc.s t85c36.c system.c</arch> | | | 80960Hx and 80960Jx | gcc960 -Fcoff -A <arch> -ctimrcntr.c timers.c system.c</arch> | | | 80960Jx | gcc960 -Fcoff -A <arch> -chalt.c incremen.s system.c</arch> | | | 80960Hx, 80960Jx<br>and 80960Cx | gcc960 -Fcoff -A <arch> -cfault.c flt_proc.c asm_flt.s system.c</arch> | | | 80960Hx and 80960Jx | gcc960 -Fcoff -A <arch> -creg_int.c low_int.s high_int.s system.c</arch> | | | ALL | gcc960 -Fcoff -A <arch> -O* -c chksum.c system.c NOTE: * refers to [0-4] depending on the level of static optimization.</arch> | | | 80960Cx ONLY | gcc960 -Fcoff -ACF -c dma.c int_rout.c sdma.s system.c | | | 80960Rx ONLY | NA NA | | | 80960Rx ONLY | NA | | | ALL | NA | | | ALL | NA | | | ALL | NA | | | 80960Hx, 80960Jx<br>and 80960Cx | NA | | | ALL | NA | | | ALL | NA | | | ALL | NA | | | ALL | NA | | | ALL | NA | | | ALL | NA | | | 80960Rx, 80960Jx | NA | | | 80960Rx, 80960Hx,<br>80960Jx and 80960Cx | NA NA | | | ALL | NA | | | 80960Hx, 80960Jx<br>and 80960Cx | NA | | | ALL | gcc960 -Fcoff -A <arch> -cfish.c system.c</arch> | | | ALL | NA NA | | | ALL | NA | | | ALL | NA | | | ALL | NA | | | RP | NA NA | | | 80960Rx, 80960Hx,<br>80960Jx and 80960Cx | NA | | | 80960Rx, 80960Hx,<br>80960Jx and 80960Cx | NA | | ### 4.0 Intel® i960® Cx/Jx/Hx Processor Features Summary #### Table 4-3. Feature/Devices | Feature | 80960Cx | 80960Jx | 80960Hx | |---------------------------------------|---------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------| | Core | Superscalar<br>(maximum 3 inst/clk) | Scalar clock doubled clock tripled | Superscalar (maximum 3 inst/clk) clock doubled clock tripled | | External Bus | 32-bit demultiplexed<br>address and data | 32-bit multiplexed address/data | <ul><li>32-bit demultiplexed<br/>address and data</li><li>parity on data</li></ul> | | Instruction Cache | 80960CA: | 80960JA/JF/JD: | 16 Kbytes 4-way | | Data Cache | 80960CA: • None 80960CF: • 1Kbyte • direct map • write-through | 80960JA/JF/JD: • 2 Kbytes • direct map • write-through 80960JT: • 4 Kbytes direct map • write-through | 8 Kbytes 4-way write-through | | Data RAM | 1 Kbyte mapped from 000H to 3FFH | 1 Kbyte mapped from 000H to 3FFH | 2 Kbytes mapped from 000H to 7FFH | | Register Cache | 5 frames programmable to 15 frames (more than five used Data RAM) | eight frames | five frames programmable to 15 frames (more than five uses Data RAM) | | Memory-mapped<br>Registers | No | Yes | Yes | | Direct Memory Access (DMA) Controller | Yes | No | No | | Interrupt Controller | Yes | Yes | Yes | | Guarded Memory Unit | No | No | Yes | | Timers | None | Two | Two | | Power Supply | • 5V | • 5V<br>• 3.3V<br>• or 3.3V with 5V tolerant | • 3.3V<br>• 5V tolerant | | JTAG | No | Yes | Yes | #### Table 4-4. Intel® i960® Processor Features Summary | Frequencies Supported | <ul> <li>33 MHz, 3.3V Version (80960RP 33/3.3)</li> <li>66 MHz, 3.3V Version (80960RD 66/3.3) - Clock Doubled 80960JF Core</li> </ul> | |-----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Compatibility | Complies with PCI Local Bus Specification, Revision 2.1 | | High Performance<br>80960Jx Core | <ul> <li>Sustained One Instruction/Clock Execution</li> <li>4 Kbyte Two-Way Set-Associative Instruction Cache</li> <li>2 Kbyte Direct-Mapped Data Cache</li> <li>Sixteen 32-Bit Global Registers</li> <li>Sixteen 32-Bit Local Registers</li> <li>Programmable Bus Widths: 8-, 16-, 32-Bit</li> <li>1 Kbyte Internal Data RAM-</li> <li>Local Register Cache (Eight Available Stack Frames)</li> <li>Two 32-Bit On-Chip Timer Units</li> </ul> | | PCI-to-PCI Bridge Unit | <ul> <li>Primary and Secondary PCI Interfaces</li> <li>Two 64-Byte Posting Buffers</li> <li>Delayed and Posted Transaction Support</li> <li>Forwards Memory, I/O, Configuration Commands from PCI Bus to PCI Bus</li> </ul> | | Two Address<br>Translation Units | <ul> <li>Connects Local Bus to PCI Buses</li> <li>Inbound/Outbound Address Translation Support</li> <li>Direct Outbound Addressing Support</li> </ul> | | Messaging Unit | <ul> <li>Four Message Registers</li> <li>Two Doorbell Registers</li> <li>Four Circular Queues</li> <li>1004 Index Registers</li> </ul> | | Memory Controller | <ul> <li>256 Mbytes of 32- or 36-Bit DRAM</li> <li>Interleaved or Non-Interleaved DRAM</li> <li>Fast Page-Mode DRAM Support</li> <li>Extended Data Out and Burst</li> <li>Extended Data Out DRAM Support</li> <li>Two Independent Banks for SRAM/ROM/Flash (16 Mbytes/Bank; 8- or 32-Bit)</li> </ul> | | DMA Controller | <ul> <li>Three Independent Channels</li> <li>PCI Memory Controller Interface</li> <li>32-Bit Local Bus Addressing</li> <li>64-Bit PCI Bus Addressing</li> <li>Independent Interface to Primary and Secondary PCI Buses</li> <li>132Mbyte/sec Burst Transfers to PCI and Local Buses</li> <li>Direct Addressing to and from PCI Buses</li> <li>Unaligned Transfers Supported in Hardware</li> <li>Two Channels Dedicated to Primary PCI Bus</li> <li>One Channel Dedicated to Secondary PCI Bus</li> </ul> | | I/O APIC Bus Interface<br>Unit | <ul> <li>Multiprocessor Interrupt Management for Intel Architecture CPUs<br/>(Intel® Pentium® and Intel® Pentium® Pro Processors)</li> <li>Dynamic Interrupt Distribution</li> <li>Multiple I/O Subsystem Support</li> </ul> | | I2C Bus Interface Unit | <ul><li>Serial Bus</li><li>Master/Slave Capabilities</li><li>System Management Functions</li></ul> | | Secondary PCI<br>Arbitration Unit | <ul> <li>Supports Six Secondary PCI Devices</li> <li>Multi-priority Arbitration Algorithm</li> <li>External Arbitration Support Mode</li> </ul> | | Private PCI Device<br>Support | <ul><li>SuperBGA* Package</li><li>352Ball-Grid Array (HL-PBGA)</li></ul> | | | |