

#### Welcome to E-XFL.COM

#### Understanding Embedded - Microprocessors

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

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

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

#### Details

| Purchase URL                    | https://www.e-xfl.com/product-detail/renesas-electronics-america/idt79r3041-33pfg |
|---------------------------------|-----------------------------------------------------------------------------------|
| Supplier Device Package         | 100-TQFP (14x14)                                                                  |
| Package / Case                  | 100-LQFP                                                                          |
| Security Features               | -                                                                                 |
| Operating Temperature           | 0°C ~ 85°C (TC)                                                                   |
| Voltage - I/O                   | 5.0V                                                                              |
| USB                             | -                                                                                 |
| SATA                            | -                                                                                 |
| Ethernet                        | -                                                                                 |
| Display & Interface Controllers | -                                                                                 |
| Graphics Acceleration           | No                                                                                |
| RAM Controllers                 | DRAM                                                                              |
| Co-Processors/DSP               | System Control; CP0                                                               |
| Speed                           | 33MHz                                                                             |
| Number of Cores/Bus Width       | 1 Core, 32-Bit                                                                    |
| Core Processor                  | MIPS-I                                                                            |
| Product Status                  | Obsolete                                                                          |

Email: info@E-XFL.COM

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

### INTRODUCTION

The IDT RISController family is a series of high-performance 32-bit microprocessors featuring a high-level of integration, and targeted to high-performance but cost sensitive embedded processing applications. The RISController family is designed to bring the high-performance inherent in the MIPS RISC architecture into low-cost, simplified, power sensitive applications.

Thus, functional units have been integrated onto the CPU core in order to reduce the total system cost, rather than to increase the inherent performance of the integer engine. Nevertheless, the RISController family is able to offer 35MIPS of integer performance at 40MHz without requiring external SRAM or caches.

Further, the RISController family brings dramatic power reduction to these embedded applications, allowing the use of low-cost packaging. Thus, the RISController family allows customer applications to bring maximum performance at minimum cost.

The R3041 extends the range of price/performance achiev-

able with the RISController family, by dramatically lowering the cost of using the MIPS architecture. The R3041 is designed to achieve minimal system and components cost, yet maintain the high-performance inherent in the MIPS architecture. The R3041 also maintains pin and software compatibility with the RISController and R3081.

The RISController family offers a variety of price/performance features in a pin-compatible, software compatible family. Table 1 provides an overview of the current members of the RISController family. Note that the R3051, R3052, and R3081 are also available in pin-compatible versions that include a full-function memory management unit, including 64-entry TLB. The R3051/2 and R3081 are described in separate manuals and data sheets.

Figure 1 shows a block level representation of the functional units within the R3041. The R3041 can be viewed as the embodiment of a discrete solution built around the R3000A. By integrating this functionality on a single chip, dramatic cost and power reductions are achieved.

An overview of these blocks is presented here, followed with detailed information on each block.

| Device<br>Name | Instruction<br>Cache | Data<br>Cache | Floating<br>Point                                 | Bus<br>Options                         |
|----------------|----------------------|---------------|---------------------------------------------------|----------------------------------------|
| R3051          | 4kB                  | 2kB           | Software Emulation                                | Mux'ed A/D                             |
| R3052          | 8kB                  | 2kB           | Software Emulation                                | Mux'ed A/D                             |
| R3071<br>R3081 | 16kB<br>or 8kB       | 4kB<br>or 8kB | On-chip Hardware                                  | 1/2 frequency bus option               |
| R3041          | 2kB                  | 512B          | Software Emulation<br>Programmable timing support | 8-, 16-, and 32-bit port width support |
|                |                      |               |                                                   | 2905 tbl 01                            |

Table 1. Pin-Compatible RISController Family

#### **CPU Core**

The CPU core is a full 32-bit RISC integer execution engine, capable of sustaining close to a single cycle execution rate. The CPU core contains a five stage pipeline, and 32 orthogonal 32-bit registers. The RISController family implements the MIPS-I Instruction Set Architecture (ISA). In fact, the execution engine of the R3041 is the same as the execution engine of the R3000A. Thus, the R3041 is binary compatible with those CPU engines, as well as compatible with other members of the RISController family. The execution engine of the RISController family uses a five-stage pipeline to achieve close to single cycle execution. A new instruction can be started in every clock cycle; the execution engine actually processes five instructions concurrently (in various pipeline stages). The five parts of the pipeline are the Instruction Fetch, Read register, ALU execution, Memory, and Write Back stages. Figure 2 shows the concurrency achieved by the RISController family pipeline.





#### **Clock Generation Unit**

The R3041 is driven from a single 2x frequency input clock, capable of operating in a range of 40%-60% duty cycle. Onchip, the clock generator unit is responsible for managing the interaction of the CPU core, caches, and bus interface. The clock generator unit replaces the external delay line required in R3000A based applications.

#### Instruction Cache

The R3041 integrates 2kB of on-chip Instruction Cache, organized with a line size of 16 bytes (four 32-bit entries) and is direct mapped. This relatively large cache substantially contributes to the performance inherent in the R3041, and allows systems based on the R3041 to achieve high-performance even from low-cost memory systems. The cache is implemented as a direct mapped cache, and is capable of caching instructions from anywhere within the 4GB physical addresses and physical tags (rather than virtual addresses or tags), and thus does not require flushing on context switch.

#### **Data Cache**

The R3041 incorporates an on-chip data cache of 512B, organized as a line size of 4 bytes (one word) and is direct mapped. This relatively large data cache contributes substantially to the performance inherent in the RISController family. As with the instruction cache, the data cache is implemented as a direct mapped physical address cache. The cache is capable of mapping any word within the 4GB physical address space.

The data cache is implemented as a write through cache, to insure that main memory is always consistent with the internal cache. In order to minimize processor stalls due to data write operations, the bus interface unit incorporates a 4deep write buffer which captures address and data at the processor execution rate, allowing it to be retired to main memory at a much slower rate without impacting system performance.

### **Bus Interface Unit**

The RISController family uses its large internal caches to provide the majority of the bandwidth requirements of the execution engine, and thus can utilize a simple bus interface connected to slow memory devices.

The RISController family bus interface utilizes a 32-bit address and data bus multiplexed onto a single set of pins. The bus interface unit also provides an ALE (Address Latch Enable) output signal to de-multiplex the A/D bus, and simple handshake signals to process CPU read and write requests. In addition to the read and write interface, the R3041 incorporates a DMA arbiter, to allow an external master to control the external bus.

The R3041 augments the basic RISController bus interface capability by adding the ability to directly interface with varying memory port widths, for instructions or data. For example, the R3041 can be used in a system with an 8-bit boot PROM, 16-bit font/program cartridges, and 32-bit main memory, transparently to software, and without requiring external data packing, rotation, and unpacking.

In addition, the R3041 incorporates the ability to change some of the interface timing of the bus. These features can be used to eliminate external data buffers and take advantage of lower speed and lower cost interface components.

One of the bus interface options is the Extended Address Hold mode which adds 1/2 clock of extra address hold time from ALE falling. This allows easier interfacing to FPGAs and ASICs.

The R3041 incorporates a 4-deep write buffer to decouple the speed of the execution engine from the speed of the memory system. The write buffers capture and FIFO processor address and data information in store operations, and present it to the bus interface as write transactions at the rate the memory system can accommodate. During main memory writes, the R3041 can break a large datum (e.g. 32-bit word) into a series of smaller transactions (e.g. bytes), according to the width of the memory port being written. This operation is transparent to the software which initiated the store, insuring that the same software can run in true 32-bit memory systems.

The RISController family read interface performs both single word reads and quad word reads. Single word reads work with a simple handshake, and quad word reads can either utilize the simple handshake (in lower performance, simple systems) or utilize a tighter timing mode when the memory system can burst data at the processor clock rate. Thus, the system designer can choose to use page or static column mode DRAMs (and possibly use interleaving, if desired, in high-performance systems), or even to use simpler SRAM techniques to reduce complexity.

In order to accommodate slower quad word reads, the RISController family incorporates a 4-deep read buffer FIFO, so that the external interface can queue up data within the processor before releasing it to perform a burst fill of the internal caches.

In addition, the R3041 can perform on-chip data packing when performing large datum reads (e.g., quad words) from narrower memory systems (e.g., 16-bits). Once again, this operation is transparent to the actual software, simplifying migration of software to higher performance (true 32-bit) systems, and simplifying field upgrades to wider memory. Since this capability works for either instruction or data reads, using 8-, 16-, or 32-bit boot PROMs is easily supported by the R3041.

### SYSTEM USAGE

The IDT RISController family is specifically designed to easily connect to low-cost memory systems. Typical low-cost memory systems use inexpensive EPROMs, DRAMs, and application specific peripherals.

Figure 4 shows some of the flexibility inherent in the R3041. In this example system, which is typical of a laser printer, a 32bit PROM interface is used due to the size of the PDL interpreter. An embedded system can optionally use an 8-bit boot PROM instead. A 16-bit font/program cartridge interface is provided for add-in cards. A 16-bit DRAM interface is used for a low-cost page frame buffer. In this system example, a field or manufacturing upgrade to a 32-bit page frame buffer is supported by the boot software and DRAM controller. Embedded systems may optionally substitute SRAMs for the DRAMs. Finally various 8/16/32-bit I/O ports such as RS-232/ 422, SCSI, and LAN as well as the laser printer engine interface are supported. Such a system features a very low entry price, with a range of field upgrade options including the ability to upgrade to a more powerful member of the RISController family.



Figure 4. Typical R3041-Based Application

### **DEVELOPMENT SUPPORT**

The IDT RISController family is supported by a rich set of development tools, ranging from system simulation tools through PROM monitor and debug support, applications software and utility libraries, logic analysis tools, and sub-system modules.

Figure 5 is an overview of the system development process typically used when developing R3041 applications. The RISController family is supported in all phases of project development. These tools allow timely, parallel development of hardware and software for RISController family based applications, and include tools such as:

· Optimizing compilers from MIPS Technology, the acknowl-

edged leader in optimizing compiler technology.

- Cross development tools, available in a variety of development environments.
- The high-performance IDT floating point emulation library software.
- The IDT Evaluation Board, which includes RAM, EPROM, I/O, and the IDT PROM Monitor.
- IDT Laser Printer System boards, which directly drive a lowcost print engine, and runs Adobe PostScript<sup>™</sup> Page Description Language
- Adobe PostScript Page Description Language running on the IDT RISController family.
- The IDT/sim<sup>™</sup> PROM Monitor, which implements a full PROM monitor (diagnostics, remote debug support, peek/



2905 drw 05

Figure 5. R3041 Development Environment

poke, etc.).

IDT/kit<sup>™</sup> (Kernel Integration Toolkit), providing library support and a frame work for the system run time environment.

### PERFORMANCE OVERVIEW

The RISController family achieves a very high-level of performance. This performance is based on:

- An efficient execution engine: The CPU performs ALU operations and store operations in a single cycle, and has an effective load time of 1.3 cycles, and branch execution rate of 1.5 cycles (based on the ability of the compilers to avoid software interlocks). Thus, the R3041 achieves 20 MIPS performance at 25MHz when operating out of cache.
- Large on-chip caches: The RISController family contains caches which are substantially larger than those on the majority of embedded microprocessors. These large caches minimize the number of bus transactions required, and allow the RISController family to achieve actual sustained performance very close to its peak execution rate, even with low-cost memory systems.
- Autonomous multiply and divide operations: The RISController family features an on-chip integer multiplier/ divide unit which is separate from the other ALU. This allows the R3041 to perform multiply or divide operations in parallel with other integer operations, using a single multiply or divide instruction rather than using "step" operations.
- Integrated write buffer: The R3041 features a four deep write buffer, which captures store target addresses and data at the processor execution rate and retires it to main memory at the slower main memory access rate. Use of on-chip write buffers eliminates the need for the processor to stall when performing store operations.
- Burst read support: The R3041 enables the system designer to utilize page mode, static column, or nibble mode RAMs when performing read operations to minimize the main memory read penalty and increase the effective cache hit rates.

The performance differences among the various RISController family members depends on the application software and the design of the memory system. Different family members feature different cache sizes, and the R3081 features a hardware floating point accelerator. Since all these devices can be used in a pin and software compatible fashion, the system designer has maximum freedom in trading between performance and cost. The memory simulation tools (e.g. Cache3041) allows the system designers to analyze and understand the performance differences among these de-

vices in their application.

### SELECTABLE FEATURES

The RISController family uses two methods to allow the system designer to configure bus interface operation options.

The first set of options are established via the Reset Configuration Mode inputs, sampled during the device reset. After reset, the Reset Mode inputs become regular input or output signals.

The second set of configuration options are contained in the System Control Co-Processor registers. These Co-processor registers configuration options are typically initialized with the boot PROM and can also be changed dynamically by the kernel software.

Selectable features include:

- **Big Endian vs. Little Endian operation**: The part can be configured to operate with either byte ordering convention, and in fact may also be dynamically switched between the two conventions. This facilitates the porting of applications from other processor architectures, and also permits intercommunication between various types of processors and databases.
- Data Cache Refill of one or four words: The memory system must be capable of performing 4 word transfers to satisfy instruction cache misses and 1 word transfers to satisfy uncached references. The data cache refill size option allows the system designers to choose between one and four word refill on data cache misses, depending on the performance each option brings to their application.
- **Bus Turn Around speed**: The R3041 allows the kernel to increase the amount of time between bus transactions when changes in direction of the A/D bus occur (e.g., at the end of reads followed by writes). This allows transceivers and buffers to be eliminated from the system.
- Extended Address Hold Time: The R3041 allows the system designer to increase the amount of hold time available for address latching, thus allowing slower speed (low cost) address latches, FPGAs and ASICs to be used.
- **Programmable control signals**: The R3041 allows the system designer to optimally configure various memory control signals to be active on reads only, writes only, or on both reads and writes. This allows the simplification of external logic, thus reducing system cost.

### **PIN DESCRIPTION**

| PIN NAME  | I/O          | DESCRIPTION                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |
|-----------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| A/D(31:0) | I/O          |                                                                                                                                                       | e multiplexed bus which indicates the desired address for a bus transaction<br>and to transmit data between the CPU and external memory resources during                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |
|           |              |                                                                                                                                                       | are logically separated into two phases: during the first phase, information ted to the memory system to be captured using the ALE output. This                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |
|           |              | Address(31:4):                                                                                                                                        | The high-order address for the transfer is presented on A/D(31:4).                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
|           |              | BE(3:0):                                                                                                                                              | These strobes indicate which bytes of the 32-bit bus will be involved in the transfer, and are presented on A/D(3:0). $\overline{BE(3)}$ indicates that A/D(31:24) will be used, and $\overline{BE(0)}$ corresponds to A/D(7:0). These strobes are only valid for accesses to 32-bit wide memory ports. Note that $\overline{BE(3:0)}$ can be held in-active during reads by setting the appropriate bit of CP0; thus when latched, these signals can be directly used as Write Enable strobes.                          |  |  |  |  |  |  |
|           |              | During the second phase, the                                                                                                                          | nese signals are the data bus for the transaction.                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
|           |              | Data(31:0):                                                                                                                                           | During write cycles, the bus contains the data to be stored and is driver<br>from the internal write buffer.<br>On read cycles, the bus receives the data from the external resource, in<br>either a single data transaction or in a burst of four words, and places is<br>into the on-chip read buffer.                                                                                                                                                                                                                 |  |  |  |  |  |  |
|           |              |                                                                                                                                                       | The byte lanes used during the transfer are a function of the datum size the memory port width, and the system byte-ordering.                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |
| Addr(3:0) | 0            | processor. For 32-bit port w<br>Addr(3:1) are valid; for 8-bit<br>the address of the current da<br>output the specific target ad                      | bus which indicates which word/halfword/byte is currently expected by the<br>vidths, only Addr(3:2) is valid during the transfer; for 16-bit port widths, only<br>port widths, all of Addr(3:0) are valid. These address lines always contain<br>rum to be transferred. In writes and single datum reads, the addresses initially<br>dress, and will increment if the size of the datum is wider than the target<br>d reads, these outputs function as a counter starting at '0000', and<br>he width of the memory port. |  |  |  |  |  |  |
|           | <b>I</b> (1) | During Reset, the Addr(3:0) pins act as Reset Configuration Mode bit inputs for the $\overline{Bo}$ BootProm8, ReservedHigh, and ExtAddrHold options. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |
|           |              | The R3041 Addr(1:0) outpu<br>R3081.                                                                                                                   | pins are designated as the unconnected Rsvd(1:0) pins in the R3051 and                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |
| Diag      | 0            | •                                                                                                                                                     | It indicates whether the current bus read transaction is due to an on-<br>the read is an instruction or data. It is time multiplexed as described below                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |
|           |              | Cached/Uncached:                                                                                                                                      | During the phase in which the A/D bus presents address information, this pin is an active high output which indicates whether or not the current read is a result of a cache miss. The value of this pin at this time othe than in read cycles is undefined.                                                                                                                                                                                                                                                             |  |  |  |  |  |  |
|           |              | ₩ <u>D</u> :                                                                                                                                          | A high at this time indicates an instruction reference, and a low indicates<br>a data reference. The value of this pin at this time other than in read<br>cycles is undefined.                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |
|           |              | The R3041 Diag output pin                                                                                                                             | is designated as the Diag(1) output pin in the R3051 and R3081.                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |
| ALE       | 0            |                                                                                                                                                       | sed to indicate that the A/D bus contains valid address information for<br>nal is used by external logic to capture the address for the transfer, typically<br>s.                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |
| DataEn    | O            |                                                                                                                                                       | dicates that the A/D bus is no longer being driven by the processor memory system may enable the drivers of the memory                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |
|           |              | hout having a bus conflict occur. D                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |

1. Reset Configuration Mode bit input when Reset is asserted, normal signal function when Reset is de-asserted.

## **PIN DESCRIPTION (Continued):**

| PIN NAME                 | I/O | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|--------------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Burst/<br>WrNear         | 0   | <b>Burst Transfer/Write Near:</b> On read transactions, the Burst signal indicates that the current bus read is requesting a block of four contiguous words from memory. This signal is asserted only in read cycles due to cache misses; it is asserted for all I-Cache miss read cycles, and for D-Cache miss read cycles if the 4-word data block refill option is selected in the CP0 Cache Config Register.                                                                                                          |
|                          |     | On write transactions, the $\overline{WrNear}$ output tells the external memory system that the bus interface unit is performing back-to-back write transactions to an address within the same 256 byte page as the prior write transaction. This signal is useful in memory systems which employ page mode or static column DRAMs, and allows nearby writes to be retired quickly.                                                                                                                                       |
| Rd                       | 0   | Read: An output which indicates that the current bus transaction is a read.                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Wr                       | 0   | Write: An output which indicates that the current bus transaction is a write.                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Āck                      | Ι   | <b>Acknowledge:</b> An input which indicates to the device that the memory system has sufficiently processed the bus transaction. On write transactions, this signal indicates that the CPU may either progress to the next data item (for mini-burst writes of wide datums to narrow memories), or terminate the write cycle. On read transactions, this signal indicates that the memory system has sufficiently processed the read, and that the processor core may begin processing the data from this read transfer. |
| RdCEn                    | I   | <b>Read Buffer Clock Enable:</b> An input which indicates to the device that the memory system has placed valid data on the A/D bus, and that the processor may move the data into the on-chip Read Buffer.                                                                                                                                                                                                                                                                                                               |
| SysClk                   | 0   | System Reference Clock: An output from the CPU which reflects the timing of the internal processor "System" clock. This clock is used to control state transitions in the read buffer, write buffer, memory controller, and bus interface unit.                                                                                                                                                                                                                                                                           |
| BusReq                   | Ι   | <b>DMA Arbiter Bus Request:</b> An input to the device which requests that the CPU tri-state its bus interface signals so that they may be driven by an external master. The negation of this input relinquishes mastership back to the CPU.                                                                                                                                                                                                                                                                              |
| BusGnt                   | 0   | <b>DMA Arbiter Bus Grant.</b> An output from the CPU used to acknowledge that a BusReq has been detected, and that the bus is relinquished to the external master.                                                                                                                                                                                                                                                                                                                                                        |
|                          |     | The R3041 adds an additional DMA protocol, under the control of CP0. If the DMA Protocol is enabled, the R3041 can request that the external master relinquish bus mastership back to the processor by negating the BusGnt output early, and waiting for the BusReq input to be negated.                                                                                                                                                                                                                                  |
| SBrCond(3)/<br>IOStrobe  | I/O | <b>Branch Condition Port/IO Strobe:</b> The use of this signal depends on the setting of various bits of the CP0 Bus Control register. If BrCond mode is selected, this input is logically connected to CpCond(3), and can be used by the branch on co-processor condition instructions as an input port. The SBrCond(3) input has special internal logic to synchronize the input, and thus may be driven by asynchronous agents.                                                                                        |
|                          |     | If this pin is selected to function as IOStrobe, it may be asserted as an output on reads, writes, or both, as programmed into CP0. This strobe asserts in the second clock cycle of a transfer, and thus can be used to strobe various control signals on the bus interface.                                                                                                                                                                                                                                             |
| SBrCond(2)/<br>ExtDataEn | I/O | <b>Branch Condition Port/Extended Data Enable:</b> The use of this signal depends on the settings in the CP0 Bus Control register. If BrCond mode is selected, this input is logically connected to CpCond(2), and can be used by the branch on co-processor condition instructions as an input port. The SBrCond(2) input has special internal logic to synchronize the input, and thus may be driven by asynchronous agents.                                                                                            |
|                          |     | If this pin is selected to function as Extended Data Enable, it may be asserted as an output on reads, writes, or both, as programmed into CP0. This strobe can be used as an extended data enable strobe, in that it is held asserted for one-half clock cycle after the negation of Rd or Wr. This signal may typically be used as a write enable control line for transceivers, as a write line for I/O, or as an address mux select for DRAMs.                                                                        |
| MemStrobe                | 0   | <b>Memory Strobe:</b> This active low output pulses low for each data read or written, as configured in the CP0 Bus Control register. Thus, it can be used as a read strobe, write strobe, or both, for SRAM type memories or for I/O devices.                                                                                                                                                                                                                                                                            |
|                          |     | The R3041 MemStrobe output pin is designated as the BrCond(0) input pin in the R3051 and R3081.                                                                                                                                                                                                                                                                                                                                                                                                                           |

2905 tbl 04

## **PIN DESCRIPTION (Continued):**

| PIN NAME              | I/O                     | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----------------------|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BE16(1:0)             | 0                       | Byte Enable Strobes for 16-bit Memory Port: These active low outputs are the byte lane strobes for accesses to 16-bit wide memory ports; they are not necessarily valid for 8- or 32-bit wide ports. If $\overline{BE16(1)}$ is asserted, then the most significant byte (either D(31:24) or D(15:8), depending on system endianness) is going to be used in this transfer. If $\overline{BE16(0)}$ is asserted, the least significant byte (D(23:16) or D(7:0)) will be used.                 |
|                       |                         | $\overline{\text{BE16(1:0)}}$ can be held inactive (masked) during read transfers, according to the programming of the CP0 Bus Control register.                                                                                                                                                                                                                                                                                                                                               |
|                       | <b>I</b> <sup>(1)</sup> | During $\overline{\text{Reset}}$ , the $\overline{\text{BE16}(1:0)}$ act as Reset Configuration Mode bit inputs for two ReservedHigh options.                                                                                                                                                                                                                                                                                                                                                  |
|                       |                         | The $\overline{\text{BE16}(1:0)}$ output pins are designated as the unconnected Rsvd(3:2) pins in the R3051 and R3081.                                                                                                                                                                                                                                                                                                                                                                         |
| Last                  | 0                       | <b>Last Datum in Mini-Burst:</b> This active low output indicates that this is the last datum transfer in a given transaction. It is asserted after the next to last $\overline{RdCEn}$ (reads) or $\overline{Ack}$ (writes), and is negated when $\overline{Rd}$ or $\overline{Wr}$ is negated.                                                                                                                                                                                               |
|                       |                         | The Last output pin is designated in the R3051 and R3081 as the Diag(0) output pin.                                                                                                                                                                                                                                                                                                                                                                                                            |
| TC                    | 0                       | <b>Terminal Count:</b> This is an active low output from the processor which indicates that the on-chip timer has reached its terminal count. It will remain low for either 1.5 clock cycles, or until software resets the timer, depending on the mode selected in the CP0 Bus Control register. Thus, the on-chip timer can function either as a free running timer for system functions such as DRAM refresh, or can operate as a software controlled time-slice timer, or real-time clock. |
|                       |                         | The $\overline{\text{TC}}$ output pin is designated in the R3051 as the BrCond(1) input pin, and in the R3081 as the Run pin output.                                                                                                                                                                                                                                                                                                                                                           |
| BusError              | I                       | <b>Bus Error:</b> Input to the bus interface unit to terminate a bus transaction due to an external bus error. This signal is only sampled during read and write operations. If the bus transaction is a read operation, then the CPU will take a bus error exception.                                                                                                                                                                                                                         |
| Int(5:3)<br>SInt(2:0) | 1                       | <b>Processor Interrupt:</b> During normal operation, these signals are logically the same as the $\overline{Int}(5:0)$ signals of the R3000A. During processor reset, these signals perform mode initialization of the CPU, but in a different (simpler) fashion than the interrupt signals on the original R3000A.                                                                                                                                                                            |
|                       | <b>I</b> <sup>(1)</sup> | During Reset, Int(3) and SInt(0) act as Reset Configuration Mode bit inputs for the AddrDisplayAndForceCacheMiss and BigEndian options.                                                                                                                                                                                                                                                                                                                                                        |
|                       |                         | There are two types of interrupt inputs: the $\overline{SInt}$ inputs are internally synchronized by the processor, and may be driven by an asynchronous external agent. The direct interrupt inputs are not internally synchronized, and thus must be externally synchronized to the CPU. The direct interrupt inputs have one cycle lower latency than the synchronized interrupts.                                                                                                          |
| ClkIn                 | I                       | Master Clock Input: This is a double frequency input used to control the timing of the CPU.                                                                                                                                                                                                                                                                                                                                                                                                    |
| Reset                 | I                       | <b>Master Processor Reset:</b> This signal initializes the CPU. Reset initialization mode selection is performed during the last cycle of Reset.                                                                                                                                                                                                                                                                                                                                               |
| TriState              | 1                       | <b>Tri-State:</b> This input to the R3041 requests that the R3041 tri-state all of its outputs. In addition to those outputs tri-stated during DMA, tri-state will cause SysClk, TC, and BusGnt to tri-state. This signal is intended for use during board testing and emulation during debug and board manufacture.                                                                                                                                                                           |
|                       |                         | The TriState input pin is designated as the unconnected Rsvd(4)pin in the R3051 and R3081.                                                                                                                                                                                                                                                                                                                                                                                                     |
| Vcc                   | 1                       | <b>Power:</b> These inputs must be supplied with the rated supply voltage (VCC). All Vcc inputs must be connected to insure proper operation.                                                                                                                                                                                                                                                                                                                                                  |
| Vss                   | 1                       | <b>Ground:</b> These inputs must be connected to ground (GND). All Vss inputs must be connected to insure proper operation.                                                                                                                                                                                                                                                                                                                                                                    |

1. Reset Configuration Mode bit input when Reset is asserted, normal signal function when Reset is de-asserted.

## ABSOLUTE MAXIMUM RATINGS<sup>(1, 3)</sup> R3041

| Symbol | Rating                                  | Commercial   | Unit |
|--------|-----------------------------------------|--------------|------|
| Vterm  | Terminal Voltage with<br>Respect to GND | -0.5 to +7.0 | V    |
| Тс     | Operating Case Temperature              | 0 to +85     | °C   |
| TBIAS  | Temperature Under Bias                  | –55 to +125  | °C   |
| Тѕтс   | Storage Temperature                     | -55 to +125  | °C   |
| Vin    | Input Voltage                           | -0.5 to +7.0 | V    |

#### NOTES:

2905 tbl 06 1. Stresses greater than those listed under ABSOLUTE MAXIMUM RATINGS

may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability.

2. VIN minimum = -3.0V for pulse width less than 15ns. VIN should not exceed Vcc +0.5 Volts.

3. Not more than one output should be shorted at a time. Duration of the short should not exceed 30 seconds.

## **AC TEST CONDITIONS R3041**

| Symbol | Parameter          | Min. | Max. | Unit        |
|--------|--------------------|------|------|-------------|
| Viн    | Input HIGH Voltage | 3.0  |      | V           |
| VIL    | Input LOW Voltage  | —    | 0    | V           |
| Vihs   | Input HIGH Voltage | 3.5  | —    | V           |
| VILS   | Input LOW Voltage  | —    | 0    | V           |
|        |                    |      |      | 2905 tbl 08 |

## **RECOMMENDED OPERATING TEMPERATURE AND SUPPLY VOLTAGE**

| Grade      | Temperature  | GND | Vcc     |
|------------|--------------|-----|---------|
| Commercial | 0°C to +85°C | 0V  | 5.0 ±5% |
|            | (Case)       |     |         |

2905 tbl 07

## **OUTPUT LOADING FOR AC TESTING**



| Signal      | Cld         |
|-------------|-------------|
| All Signals | 25 pF       |
|             | 2905 tbl 09 |

## DC ELECTRICAL CHARACTERISTICS R3041 — (Tc = 0°C to +85°C, Vcc = +5.0V ±5%)

|        |                                     |                        | 16.67MHz |      | 20MHz |      | 25MHz |      | 33MHz |      |      |
|--------|-------------------------------------|------------------------|----------|------|-------|------|-------|------|-------|------|------|
| Symbol | Parameter                           | Test Conditions        | Min.     | Max. | Min.  | Max. | Min.  | Max. | Min.  | Max. | Unit |
| Vон    | Output HIGH Voltage                 | Vcc = Min., Iон = -4mA | 3.5      | —    | 3.5   | —    | 3.5   | —    | 3.5   |      | V    |
| Vol    | Output LOW Voltage                  | Vcc = Min., IoL = 4mA  | —        | 0.4  | _     | 0.4  |       | 0.4  |       | 0.4  | V    |
| Vih    | Input HIGH Voltage <sup>(3)</sup>   | _                      | 2.0      | —    | 2.0   | —    | 2.0   | _    | 2.0   | ų    | V    |
| VIL    | Input LOW Voltage <sup>(1)</sup>    | _                      | —        | 0.8  |       | 0.8  |       | 0.8  | —     | 0.8  | V    |
| Vihs   | Input HIGH Voltage <sup>(2,3)</sup> | _                      | 3.0      |      | 3.0   | _    | 3.0   | _    | 3.0   |      | V    |
| VILS   | Input LOW Voltage <sup>(1,2)</sup>  | _                      | —        | 0.4  |       | 0.4  | _     | 0.4  |       | 0.4  | V    |
| CIN    | Input Capacitance <sup>(4)</sup>    | _                      | —        | 10   | _     | 10   |       | 10   |       | 10   | pF   |
| Соит   | Output Capacitance <sup>(4)</sup>   | _                      | —        | 10   | _     | 10   |       | 10   | +     | 10   | pF   |
| lcc    | Operating Current                   | Vcc = 5V, Tc = 25°C    | _        | 225  | _     | 250  | _     | 300  | T     | 370  | mA   |
| Ін     | Input HIGH Leakage                  | VIH = VCC              | _        | 100  | —     | 100  | _     | 100  |       | 100  | μΑ   |
| lı∟    | Input LOW Leakage                   | VIL = GND              | -100     | _    | -100  | _    | -100  | _    | -100  |      | μΑ   |
| loz    | Output Tri-state Leakage            | VOH = 2.4V, VOL = 0.5V | -100     | 100  | -100  | 100  | -100  | 100  | -100  | 100  | μΑ   |

#### NOTES:

1. VIL Min. = -3.0V for pulse width less than 15ns. VIL should not fall below -0.5 volts for larger periods.

2. VIHS and VILS apply to ClkIn and Reset.

3. VIH should not be held above Vcc + 0.5 volts.

4. Guaranteed by design.

2905 tbl 10

## **DC ELECTRICAL CHARACTERISTICS RV3041** — (TC = $0^{\circ}$ C to +85°C, VCC = +3.3V ±5%)

|        |                                     |                        | 16.67 | 16.67MHz |      | MHz  | 25MHz |      | 33MHz     |      |
|--------|-------------------------------------|------------------------|-------|----------|------|------|-------|------|-----------|------|
| Symbol | Parameter                           | Test Conditions        | Min.  | Max.     | Min. | Max. | Min.  | Max. | Min. Max. | Unit |
| Vон    | Output HIGH Voltage                 | Vcc = Min., Iон = –4mA | 2.4   | _        | 2.4  | —    | 2.4   | —    | 2.4 —     | V    |
| Vol    | Output LOW Voltage                  | Vcc = Min., IoL = 4mA  | —     | 0.4      |      | 0.4  | —     | 0.4  | 0.4       | V    |
| Vih    | Input HIGH Voltage <sup>(3)</sup>   | —                      | 2.0   |          | 2.0  | _    | 2.0   | _    | 2.0 —     | V    |
| VIL    | Input LOW Voltage <sup>(1)</sup>    | —                      | —     | 0.8      | —    | 0.8  | —     | 0.8  | 0.8       | V    |
| Vihs   | Input HIGH Voltage <sup>(2,3)</sup> | —                      | 2.5   | —        | 2.5  | —    | 2.5   | —    | 2.5 —     | V    |
| VILS   | Input LOW Voltage <sup>(1,2)</sup>  | —                      | —     | 0.4      | —    | 0.4  | —     | 0.4  | — 0.4     | V    |
| CIN    | Input Capacitance <sup>(4)</sup>    | —                      | —     | 10       | —    | 10   | —     | 10   | 10        | pF   |
| Соит   | Output Capacitance <sup>(4)</sup>   | —                      | —     | 10       | _    | 10   | —     | 10   | 10        | pF   |
| lcc    | Operating Current                   | Vcc = 3.3V, Tc = 25°C  | —     | 130      | _    | 150  | —     | 180  | — 225     | mA   |
| Ін     | Input HIGH Leakage                  | VIH = VCC              | —     | 100      | _    | 100  | —     | 100  | — 100     | mA   |
| lı∟    | Input LOW Leakage                   | VIL = GND              | -100  | _        | -100 |      | -100  |      | -100      | mA   |
| loz    | Output Tri-state Leakage            | Voh = 2.4V, Vol = 0.5V | -100  | 100      | -100 | 100  | -100  | 100  | -100 100  | mA   |

NOTES:

1. VIL Min. = -3.0V for pulse width less than 15ns. VIL should not fall below -0.5 volts for larger periods.

2. VIHS and VILS apply to ClkIn and Reset.

3. VIH should not be held above Vcc + 0.5 volts.

4. Guaranteed by design.

# AC ELECTRICAL CHARACTERISTICS RV3041 (1, 2, 3) (Tc = 0°C to +85°C, Vcc = +3.3V ±5%)

|        |                                                      |                                                           | 16.6 | 7MHz | Hz 20MHz |      | 25MHz |      | 33MHz |      |      |
|--------|------------------------------------------------------|-----------------------------------------------------------|------|------|----------|------|-------|------|-------|------|------|
| Symbol | Signals                                              | Description                                               | Min. | Max. | Min.     | Max. | Min.  | Max. | Min.  | Max. | Unit |
| t1     | BusReq, Ack, BusError,<br>RdCEn                      | Set-up to SysClk rising                                   | 11   | _    | 8        | —    | 5.5   | —    | 5.5   | -    | ns   |
| t1a    | A/D                                                  | Set-up to SysClk falling                                  | 12   |      | 9        |      | 7     | _    | 7     |      | ns   |
| t2     | BusReq, Ack, BusError,<br>RdCEn                      | Hold from SysClk rising                                   | 4    | —    | 3        | —    | 2.5   | —    | 2.5   | 1    | ns   |
| t2a    | A/D                                                  | Hold from SysClk falling                                  | 2    | _    | 2        | _    | 1     | _    | 1     |      | ns   |
| t3     | A/D, Addr, Diag, ALE, Wr<br>Burst/WrNear, Rd, DataEn | Tri-state from SysClk rising (after driven condition)     | —    | 13   | —        | 10   | —     | 10   | 7     | 10   | ns   |
| t4     | A/D, Addr, Diag, ALE, Wr<br>Burst/WrNear, Rd, DataEn | Driven from SysClk falling<br>(after tri-state condition) | —    | 13   | —        | 10   | —     | 10   |       | 10   | ns   |
| t5     | BusGnt                                               | Asserted from SysClk rising                               | _    | 10   | _        | 8    | _     | 7    | 5     | 7    | ns   |
| t6     | BusGnt                                               | Negated from SysClk falling                               |      | 10   | _        | 8    |       | 7    | -     | 7    | ns   |
| t7     | Wr, Rd, Burst/WrNear, TC                             | Valid from SysClk rising                                  | _    | 8    |          | 6    | _     | 5    |       | 5    | ns   |
| t7a    | A/D                                                  | Valid from SysClk rising                                  |      | 12   |          | 9    | _     | 8    |       | 8    | ns   |
| t7b    | Last                                                 | Valid from SysClk rising                                  |      | 12   |          | 9    | _     | 8    | М     | 8    | ns   |
| t8     | ALE                                                  | Asserted from SysClk rising                               | —    | 5    |          | 4    | _     | 4    | 1     | 4    | ns   |
| t9     | ALE                                                  | Negated from SysClk falling                               | —    | 5    | —        | 4    | _     | 4    |       | 4    | ns   |
| t10    | A/D                                                  | Hold from ALE negated                                     | 2    |      | 2        | —    | 2     | _    | 1.5   |      | ns   |
| t11    | DataEn                                               | Asserted from SysClk                                      | —    | 19   | _        | 15   | —     | 15   |       | 15   | ns   |
| t12    | DataEn                                               | Asserted from A/D tri-state <sup>(4)</sup>                | 0    |      | 0        |      | 0     | _    | 0     |      | ns   |
| t14    | A/D                                                  | Driven from SysClk rising <sup>(4)</sup>                  | 0    |      | 0        |      | 0     | _    | 0     | -    | ns   |
| t15    | Wr, Rd, DataEn,<br>Burst/WrNear, Last, TC            | Negated from SysClk falling                               | —    | 9    | —        | 7    |       | 6    |       | 6    | ns   |
| t16    | Addr(3:0), BE 16(1:0)                                | Valid from SysClk                                         | _    | 11   | _        | 8    | _     | 7    | -     | 7    | ns   |
| t17    | Diag                                                 | Valid from SysClk                                         | —    | 15   |          | 12   | _     | 11   | _     | 11   | ns   |

2905 tbl 11

2905 tbl 10

|         |                     |                                                          | 16.67 MHz |         | 20 MHz  |         | 25MHz   |         | 33MHz    |         |             |
|---------|---------------------|----------------------------------------------------------|-----------|---------|---------|---------|---------|---------|----------|---------|-------------|
| Symbol  | Signals             | Description                                              | Min.      | Max.    | Min.    | Max.    | Min.    | Max.    | Min.     | Max.    | Uni         |
| t18     | A/D                 | Tri-state from SysClk                                    | _         | 13      |         | 10      | _       | 10      | —        | 10      | ns          |
| t19     | A/D                 | SysClk to data out                                       | _         | 16      | _       | 13      | _       | 12      | _        | 12      | ns          |
| t20     | ClkIn               | Pulse Width High                                         | 12        |         | 10      | _       | 8       |         | 6.5      | -       | ns          |
| t21     | ClkIn               | Pulse Width Low                                          | 12        | _       | 10      | _       | 8       |         | 6.5      |         | ns          |
| t22     | ClkIn               | Clock Period                                             | 30        | 250     | 25      | 250     | 20      | 250     | 15       | 250     | ns          |
| t23     | Reset               | Pulse Width from Vcc valid                               | 200       |         | 200     |         | 200     |         | 200      |         | μs          |
| t24     | Reset               | Minimum Pulse Width                                      | 32        |         | 32      | _       | 32      |         | 32       |         | sys         |
| t25     | Reset               | Set-up to SysClk falling                                 | 8         |         | 6       |         | 5       |         | 5        | 1       | ns          |
| t26     | Int                 | Mode set-up to Reset rising                              | 8         | —       | 6       | _       | 5       |         | 5        | +       | ns          |
| t27     | Int                 | Mode hold from Reset rising                              | 2.5       |         | 2.5     |         | 2.5     |         | 2.5      | -       | ns          |
| t28     | SInt, SBrCond       | Set-up to SysClk falling                                 | 8         | _       | 6       | _       | 5       |         | 5        |         | ns          |
| t29     | SInt, SBrCond       | Hold from SysClk falling                                 | 4         | _       | 3       | _       | 3       |         | 3        |         | ns          |
| t30     | Int, BrCond         | Set-up to SysClk falling                                 | 8         | _       | 6       | _       | 5       |         | 5        | -       | ns          |
| t31     | Int, BrCond         | Hold from SysClk falling                                 | 4         |         | 3       |         | 3       |         | 3        |         | ns          |
| tsys    | SysClk              | Pulse Width                                              | 2*t22     | 2*t22   | 2*t22   | 2*t22   | 2*t22   | 2*t22   | 2*t22    | 2*t22   | ns          |
| t32     | SysClk              | Clock High Time                                          | t22 - 2   | t22 + 2 | t22 - 2 | t22 + 2 | t22 - 2 | t22 + 2 | t22 - 2  | t22 + 2 | ns          |
| t33     | SysClk              | Clock Low Time                                           | t22 - 2   | t22 + 2 | t22 - 2 | t22 + 2 | t22 - 2 | t22 + 2 | t22 - 2  | t22 + 2 | ns          |
| t45     | ExtDataEn           | Tri-state from SysClk rising<br>(after driven condition) | _         | 13      | —       | 10      | —       | 10      |          | 10      | ns          |
| t46     | ExtDataEn           | Driven from SysClk falling<br>(after driven condition)   | _         | 13      | —       | 10      | —       | 10      |          | 10      | ns          |
| t47     | IOStrobe            | Valid from SysClk falling                                |           | 10      | —       | 8       | —       | 7       |          | 7       | ns          |
| t48     | ExtDataEn,          | Asserted from SysClk rising                              |           | 15      | —       | 12      | —       | 9       | _        | 9       | ns          |
| t49     | ExtDataEn<br>DataEn | Negated from SysClk rising                               | _         | 9       | _       | 7       | —       | 6       | _        | 6       | ns          |
| t50     | MemStrobe           | Asserted from SysClk rising                              | _         | 19      | _       | 15      | —       | 15      | <u> </u> | 15      | ns          |
| t51     | MemStrobe           | Negated from SysClk falling                              | —         | 19      | —       | 15      |         | 15      | —        | 15      | ns          |
| t52     | MemStrobe           | Asserted from Addr(3:0) valid <sup>(4)</sup>             | 0         | _       | 0       |         | 0       |         | 0        | -       | ns          |
| tderate | All outputs         | Timing deration for loading over $25pF^{(4, 5)}$         |           | 0.5     | -       | 0.5     | -       | 0.5     | -        | 0.5     | ns/<br>25pl |

## AC ELECTRICAL CHARACTERISTICS RV3041 (CONT.)

1. All timings referenced to 1.5 Volts, with a rise and fall time of less than 2.5ns.

2. All outputs tested with 25pF loading.

3. The AC values listed here reference timing diagrams contained in the R3041 Hardware User's Manual.

4. Guaranteed by design.

5. This parameter is used to derate the AC timings according to the loading of the system. This parameter provides a deration for loads over the specified test condition; that is, the deration factor is applied for each 25pF over the specified test load condition.

6. Timings t34 - t44 are reserved for other RISController family members.



Figure 12(c). Start of Write Timing with Non-Extended Address Hold Option



Figure 12(d). Start of Write Timing with Extended Address Hold Option



Figure 14. Mini-burst read of 32-bit datum from 8-bit wide memory port



Figure 15. R3041 Quad Word Read



Figure 16(a). Quad Word Read to 16-bit wide Memory Port







Figure 17. Basic Write to 32-bit Memory Port



Figure 20. R3041 Regaining Bus Mastership



## 84 LEAD PLCC (SQUARE)





2905 drw 31

| DWG #      | J84-1     |       |  |  |  |  |
|------------|-----------|-------|--|--|--|--|
| # of Leads | 84        |       |  |  |  |  |
| Symbol     | Min.      | Max.  |  |  |  |  |
| А          | 165       | .180  |  |  |  |  |
| A1         | .095      | .115  |  |  |  |  |
| В          | .026      | .032  |  |  |  |  |
| b1         | .013      | .021  |  |  |  |  |
| С          | .020      | .040  |  |  |  |  |
| C1         | .008      | .012  |  |  |  |  |
| D          | 1.185     | 1.195 |  |  |  |  |
| D1         | 1.150     | 1.156 |  |  |  |  |
| D2/E2      | 1.090     | 1.130 |  |  |  |  |
| D3/E3      | 1.000 REF |       |  |  |  |  |
| E          | 1.185     | 1.195 |  |  |  |  |
| E1         | 1.150     | 1.156 |  |  |  |  |
| е          | .050 BSC  |       |  |  |  |  |
| ND/NE      | 21        |       |  |  |  |  |

### NOTES:

- 1. All dimensions are in inches, unless otherwise noted.
- 2. BSC—Basic lead Spacing between Centers.
  3. D & E do not include mold flash or protutions.
- 4. Formed leads shall be planar with respect to one another and within .004" at the seating plane.
- 5. ND & NE represent the number of leads in the D & E directions respectively.
- 6. D1 & E1 should be measured from the bottom of the package.7. PLCC is pin & form compatible with MQUAD; the MQUAD package is used in other RISController family members.

### **ORDERING INFORMATION**



2905 drw 32

## VALID COMBINATIONS

| 79R3041 - 16  | TQFP, PLCC Package |
|---------------|--------------------|
| 79R3041 - 20  | TQFP, PLCC Package |
| 79R3041 - 25  | TQFP, PLCC Package |
| 79R3041 - 33  | PLCC Package Only  |
| 79RV3041 - 16 | TQFP, PLCC Package |
| 79RV3041 - 20 | TQFP, PLCC Package |
| 79RV3041 - 25 | TQFP, PLCC Package |
| 79RV3041 - 33 | TQFP, PLCC Package |