# 930 Series 32-BIT RISC EMBEDDED PROCESSOR MAY 25, 1994 ## FEATURES - 40 MHz (25ns/cycle) operating frequency - SPARC• high performance RISC architecture - 8 Kbytes 2-way set associative instruction cache - 2 Kbytes 2-way set associative data cache - Support for burst mode cache fills - Flexible locking mechanism for data and instruction cache entries - Harvard-style separate instruction and data buses on-chip - 8 window, 136 word register file - Fast interrupt response time - 247 address spaces, 4 Gbyte each - 16 entry TLB (Translation Lookaside Buffer) - Buffered writes and instruction pre-fetching - Fast page-mode DRAM support - 2 channel DMA controller - Support for execution out of 8, 16, or 32-bit wide boot memory - Parity generation and checking - Programmable address decoder and wait-state generator - 16-bit auto reload timer - On-chip clock generator circuit - TAG test interface - Emulator support hardware - Single vector trapping - 0.8 micron gate, 3 level metal CMOS technology #### **GENERAL DESCRIPTION** The MB86932 is the fourth of the 930 series of RISC processors which offers high performance and high integration for a wide range of embedded applications. The processor is based on the SPARC architecture and is upward code compatible with previous implementations. At 40 MHz, the processor executes with 40 MIPs peak and 37 MIPs sustained performance. On-chip data and instruction caches are included to help decouple the processor from external memory latency. Separate on-chip instruction and data paths provide a high bandwidth interface between the IU and caches. An on-chip 2-channel DMA controller makes use of the processor bus even while the integer unit is executing out of cache. Support for virtual memory and access protection is provided through the on-chip Translation Lookaside Buffer (TLB). Included to maximize the performance of the system with minimum glue logic, are chip select outputs, programmable wait state generation, built-in support for a high performance connection to page-mode DRAM and support for booting from 8 and 16-bit memory. See MB86932 block diagram on page 3. Support for debug and diagnostic tools has been included on-chip and allows for direct connection to hardware emulators and improves debug capability when using ROM based monitors. These features combine to give the MB86932 superior speed, flexibility and efficiency to make it the ideal choice for a wide variety of low cost, high performance embedded systems. #### PIN CONFIGURATION PIN ASSIGNMENT - 208-LEAD QFP | PIN<br>NO. | PIN NAME | TYPE | PIN<br>NO. | PIN NAME | TYPE | PIN<br>NO. | PIN NAME | TYPE | PIN<br>NO. | PIN NAME | TYPE | |------------|-------------------|----------|------------|-----------------|------|------------|---------------------|------|------------|-------------------|------| | 1 | ADR < 28 > | 0 | 53 | EMU_D < 0 > | I/O | 105 | D < 4 > | 1/0 | 157 | VDD | _ | | 2 | ADR < 29 > | 0 | 54 | VSS | _ | 106 | VSS | _ | 158 | -DACK1 | 0 | | 3 | ADR < 30 > | 0 | 55 | -EMU_ENB | 1 | 107 | VDD | _ | 159 | ASI < 4 > | 0 | | 4 | ADR < 31> | 0 | 56 | VSS | _ | 108 | D < 3 > | 1/0 | 160 | ASI < 5 > | 0 | | 5 | VDD | _ | 57 | VDD | _ | 109 | D < 2 > | I/O | 161 | ASI < 6 > | 0 | | 6 | VSS | | 58 | D < 31 > | I/O | 110 | D < 1 > | 1/0 | 162 | ASI < 7 > | 0 | | 7 | VDD | ~~~ | 59 | D < 30 > | 1/0 | 111 | D < 0 > | 1/0 | 163 | ADR < 2 > | 0 | | 8 | IRL < 3> | 1 | 60 | D < 29 > | I/O | 112 | VDD | _ | 164 | ADR < 3 > | 0 | | 9 | IRL < 2 > | 1 | 61 | VDD | _ | 113 | -RESET | 1 | 165 | ADR < 4 > | 0 | | 10 | IRL < 1 > | 1 ' | 62 | D < 28 > | 1/0 | 114 | -BREQ | 1 | 166 | ADR < 5 > | 0 | | 11 | IRL < 0 > | 1 | 63 | D < 27 > | 1/0 | 115 | VSS | | 167 | VDD | | | 12 | VSS | | 64 | V\$S | | 116 | -MEXC | I | 168 | VSS | | | 13 | CLK_ECB | 1 | 65 | D < 26 > | I/O | 117 | -READY | i | 169 | ADR < 6 > | 0 | | 14 | TDI | i | 66 | D < 25 > | 1/0 | 118 | VSS | _ | 170 | ADR < 7 > | Ō | | 15 | -TRST | i | 67 | D < 24 > | 1/0 | 119 | VDD | | 171 | -EOP0 | 1/0 | | 16 | TCK | i | 68 | VSS | _ | 120 | -BGRNT | 0 | 172 | ADR < 8 > | 0 | | 17 | TMS | i | 69 | VDD | _ | 121 | VDD | | 173 | ADR < 9 > | ō | | 18 | VDD | <u> </u> | 70 | VDD | _ | 122 | -ERROR | 0 | 174 | VSS | _ | | 19 | VSS | _ | 71 | VDD | | 123 | -LOCK | Ö | 175 | VDD | | | 20 | VSS | _ | 72 | D < 23 > | 1/0 | 124 | -BMACK | Ĭ | 176 | ADR < 10 > | 0 | | 21 | VDD | _ | 73 | D < 22 > | 1/0 | 125 | RD/–WR | Ö | 177 | -EOP1 | 1/0 | | 22 | VDD | | 74 | VSS | | 126 | -AS | Ö | 178 | ADR < 11 > | 0 | | 23 | VSS | | 75 | D < 21 > | 1/0 | 127 | -PBREQ | 0 | 179 | ADR < 12 > | 0 | | 24 | TDO | 0 | 76 | D < 20 > | 1/0 | 128 | VSS | _ | 180 | VDD | _ | | 25 | -TIMER_OVF | 0 | 77 | VDD | | 129 | VSS | _ | 181 | ADR < 13 > | 0 | | 26 | VDD | 0 | 78 | D < 19 > | 1/0 | 130 | VSS | _ | 182 | VDD | _ | | 27 | VSS | _ | 79 | VSS | | 131 | -CS < 0 > | 0 | 183 | VSS | _ | | 28 | | _ | 80 | vss<br>D < 18 > | 1/0 | 132 | -CS < U ><br>-DREQ0 | Ī | 184 | VSS<br>ADR < 14 > | 0 | | | VDD | 0 | 81 | -BMODE16 | 1/0 | 132 | -DREQU<br>-CS < 1 > | 0 | 185 | VSS | U | | 29 | XTAL2 | • | | | | 1 | | O | 1 | | _ | | 30 | XTAL1 | ı | 82 | D < 17 > | 1/0 | 134 | VSS | _ | 186 | ADR < 15 > | - | | 31 | VSS | _ | 83 | D < 16 > | 1/0 | 135 | -CS < 2 > | 0 | 187 | ADR < 16 > | 0 | | 32 | TEST <sup>1</sup> | _ | 84 | VDD | _ | 136 | -CS < 3 > | 0 | 188 | PARITY < 0 > | 1/0— | | 33 | CLKOUT1 | 0 | 85 | VSS | | 137 | -CS < 4 > | 0 | 189 | ADR < 17 > | 0 | | 34 | VDD | - | 86 | VDD | | 138 | -DREQ1 | ı | 190 | VSS | _ | | 35 | CLKOUT2 | 0 | 87 | D < 15 > | 1/0 | 139 | VDD | _ | 191 | VDD | _ | | 36 | VSS | | 88 | -BMODE8 | ı | 140 | -CS <5> | 0 | 192 | ADR < 18 > | 0 | | 37 | PARITY < 2 > | I/O | 89 | D < 14 > | I/O | 141 | -SAME_PAGE | 0 | 193 | ADR < 19 > | 0 | | 38 | VDD | _ | 90 | D < 13 > | 1/0 | 142 | VDD | _ | 194 | ADR < 20 > | 0 | | 39 | VSS | _ | 91 | D < 12 > | 1/0 | 143 | VSS | _ | 195 | PARITY < 1 > | 1/0 | | 40 | PARITY < 3 > | I/O | 92 | D < 11 > | 1/0 | 144 | VDD | _ | 196 | ADR < 21 > | 0 | | 41 | -EMU_BRK | - 1 | 93 | VSS | _ | 145 | -DACK0 | 0 | 197 | VDD | | | 42 | VSS | _ | 94 | D < 10 > | I/O | 146 | -BE < 3 > | 0 | 198 | VSS | | | 43 | VDD | _ | 95 | D < 9 > | I/O | 147 | VSS | _ | 199 | ADR < 22 > | 0 | | 44 | EMU_SD < 3 > | I/O | 96 | D < 8 > | 1/0 | 148 | -BE < 2 > | 0 | 200 | ADR < 23 > | 0 | | 45 | EMU_SD < 2 > | I/O | 97 | VDD | _ | 149 | -BE < 1 > | 0 | 201 | ADR < 24 > | 0 | | 46 | EMU_SD < 1 > | 1/0 | 98 | VSS | | 150 | -BE < 0 > | 0 | 202 | ADR < 25 > | 0 | | 47 | VSS | | 99 | VSS | | 151 | AS1 < 0 > | 0 | 203 | VSS | | | 48 | VDD | _ | 100 | VDD | _ | 152 | VSS | _ | 204 | VDD | _ | | 49 | EMU_SD < 0 > | I/O | 101 | D < 7 > | I/O | 153 | VDD | | 205 | VDD | _ | | 50 | EMU_D < 3 > | I/O | 102 | D < 6 > | I/O | 154 | ASI < 1 > | 0 | 206 | VSS | | | 51 | EMU_D < 2 > | I/O | 103 | -BMREQ | 0 | 155 | ASI < 2 > | 0 | 207 | ADR < 26 > | 0 | | 52 | EMU_D < 1 > | 1/0 | 104 | D < 5 > | 1/0 | 156 | ASI < 3 > | Ó | 208 | ADR < 27 > | Ö | Note: 1. Factory Test Pin. This pin should be tied high during normal operations. #### **ORDERING CODE** | Clock Frequency (MHz) | Ordering Code | Package Type | Package Marking | |-----------------------|----------------|------------------------|-----------------| | 20 | MB86932-20ZF-G | CQFP 208 | MB86932-20 | | 40 | MB86932-40ZF-G | CQFP 208 with Heatsink | MB86932-40 | Note: The ordering code is for production level product. Early shipments of this device may be marked with "ES" to indicate that the part is not yet at full production status. Contact your local Fujitsu representative for additional information on "ES" level products. #### SIGNAL DESCRIPTIONS | SYMBOL | TYPE | DESCRIPTION | |-----------------------------|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | RESET | i | SYSTEM RESET: Asserting reset for at least 4 processor cycles after the clock has stabilized, causes the MB86930 to be initialized. | | XTAL1,<br>(CLK_IN)<br>XTAL2 | I/O<br>O<br>G (Q)<br>I (Q) | <b>EXTERNAL OSCILLATOR:</b> The crystal inputs determine execution rate and timing of the MB86930 processor. Connecting a crystal to these pins forms a complete crystal oscillator circuit. The crystal oscillator frequency is the same as the processor operating frequency. When driving the processor with an external clock, XTAL2 pin should be left floating. | | CLKOUT1 | O<br>G (Q)<br>I (Q) | CLOCK OUTPUT 1: This is an output signal against which MB86930 bus transactions can be referenced. The CLKOUT1 frequency is the same as the frequency applied to XTAL1 and is the same as the processor operating frequency. CLKOUT1 is in phase with CLK_IN. | | CLKOUT2 | O<br>G (Q)<br>I (Q) | CLOCK OUTPUT 2: This is an output signal against which MB86930 bus transactions can be referenced. The CLKOUT2 frequency is the same as the frequency applied to XTAL1 and is the same as the processor operating frequency, CLKOUT2 is out of phase with CLK_IN. | | -LOCK | O<br>S (L)<br>G (Z)<br>I (1) | BUS LOCK: This is a control signal asserted by the processor to indicate to the system that the current bus transaction requires more than one transfer on the bus. The Atomic Load Store instruction for example requires contiguous bus transactions which cause the assertion of the bus lock signal. The bus may not be granted to another bus owner as long as –LOCK is active. –LOCK is asserted with the assertion of –AS and remains active until –READY is asserted at the end of the locked transaction. | | -BREQ | l<br>S (L) | BUSREQUEST: Asserted by another device on the bus to indicate that it wants ownership of the bus. The request must be answered with a bus grant (-BGRNT) from the MB86930 before the device can proceed by driving the bus. Once the bus has been granted, the device has ownership of the bus until it de-asserts -BREQ. The user should ensure that devices on the bus cannot monopolize the bus to the exclusion of the CPU. Inputs to -BREQ while -RESET is active are valid and cause Bus Grant to be asserted. | | -BGRNT | O<br>S (L)<br>G (0)<br>I (Q) | <b>BUS GRANT:</b> Asserted by the CPU in response to a request from a device wanting ownership of the bus. The CPU grants the bus to other devices only after all transfers for the current transaction are completed. All bus drivers are three-stated with the assertion of the bus grant signal. | | -ERROR | O<br>S (L)<br>G (Q)<br>I (Q) | ERROR SIGNAL: Asserted by the CPU to indicate that it has halted in an error state as a result of encountering a synchronous trap while traps are disabled. In this situation the CPU saves the PC and nPC registers, sets the tt value in the TBR, enters into an error state and asserts the –ERROR signal. The system can monitor the –ERROR pin and initiate a reset under the error condition. This pin is high on reset. | | -MEXC | I<br>S(L) | <b>MEMORY EXCEPTION:</b> Asserted by the memory system to indicate a memory error on either a data or instruction access. Assertion of this signal initiates either a data or instruction access exception trap in the IU. The current bus access is invalidated by asserting the –MEXC in the same cycle as the –READY signal. Assertion in any other bus cycle gives indeterminate results. The IU ignores the contents of the data bus in cycles where –MEXC is asserted. | | IRL <3:0 > | I<br>A (L) | INTERRUPT REQUEST BUS: The value on these pins defines the external interrupt level. IRL < 3:0 >=1111 forces a non-maskable interrupt. IRL value of 0000 indicates no pending interrupts. All other values indicate maskable interrupts as enabled in the PIL field of the processor status register (PSR). Interrupts should be latched and prioritized by external logic and should be held pending until acknowledged by the processor. An interrupt controller is available on the MB86940. | SIGNAL DESCRIPTIONS (Continued) | | IPTIONS (Continued) | | | | | | | |------------------------------------------|------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | SYMBOL | TYPE | DESCRIPTION | | | | | | | -TIMER_OVF | O<br>S (L)<br>G (Q)<br>I (Q) | TIMER UNDERFLOW: Asserted by the processor to indicate that the internal 16-bit timer has underflowed. This signal can be used to initiate a DRAM refresh cycle or a one cycle periodic waveform. On reset, the timer is turned off and –TIMER_OVF is high. | | | | | | | -SAME_PAGE | O<br>S (L)<br>G (1)<br>I (1) | SAME-PAGE DETECT: The —SAME_PAGE is used to take advantage of fast consecutive accesses within Fast Page Mode DRAM page boundaries. This signal is an output asserted by the processor when the current address is within the same page as the previous memory access. The —SAME_PAGE signal is asserted with —AS and remains active for one processor cycle. —SAME_PAGE is never asserted in the first transaction following a transaction by another device on the bus. The page size is specified by writing the SAME-PAGE MASK register. | | | | | | | -CS0, -CS1,<br>-CS2, -CS3,<br>-CS4, -CS5 | O<br>S (L)<br>G (1)<br>I (1) | CHIP SELECTS: These outputs are asserted when the value on the address bus matches the address range in one of the corresponding ADDRESS RANGE registers. The signals are used to decode the current address into one of six address ranges. Address ranges should not overlap. Each address range has a corresponding wait specifier which is used to automatically assert the –READY signal after a user defined number of processor clock cycles. This allows a variety of memory and I/O devices with different access times to be connected to the MB86930 without the need for additional logic. | | | | | | | ADR < 31:2 > | O<br>S (L)<br>G (Z)<br>I (1) | ADDRESS BUS: The 30-bit ADDRESS BUS (A31-A2) is an output which identifies the data or instruction address of a 32-bit word. Reads are always one word in size while byte, half-word, or word transaction sizes for writes is identified by separate byte-enable signals (–BE0-3). The address bus is valid for the duration of the bus transaction. | | | | | | | ASI < 7:0 > | O<br>S (L)<br>G (Z)<br>I (1) | ADDRESS SPACE IDENTIFIERS: The ADDRESS SPACE IDENTIFIERS are outputs which indicate to which of 256 available spaces the current ADDRESS BUS value corresponds. The ASI values are defined as follows: | | | | | | | | | ASI < 7:0 > ADDRESS SPACE | | | | | | | | | Ox1 Control Registers Ox2 Instruction Cache Lock Ox3 Data Cache Lock Ox4 - 0x7 Application Definable Ox8 User Instruction Space Ox9 Supervisor Instruction Space OxA User Data Space OxB Supervisor Data Space OxC Instruction Cache Tag RAM OxD Instruction Cache Data RAM OxE Data Cache Tag RAM OxF Data Cache Data RAM OxF Data Cache Data RAM OxF Data Cache Data RAM OxF Data Cache Data RAM OxTO - 0xFD Application Definable OxFE - 0xFF Reserved for Debug Hardware The ASI values specified as "application definable" can be used by supervisor mode instructions such as Load Alternate and Store Alternate. The ASI value is available in the | | | | | | | | | same cycle in which the corresponding address value is asserted on the address bus. The ASI pins are valid for the duration of the bus transaction. ASI values 0x8, 0x9, 0xA, and 0xB are cacheable. | | | | | | SIGNAL DESCRIPTIONS (Continued) | SIGNAL DESCRI | THONS | (Continued) | | | | | |---------------|--------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | SYMBOL | TYPE | DESCRIPTION | | | | | | -BMODE8 | I<br>S (L) | <b>8-BIT BOOTMODE:</b> This signal is sampled during reset and causes read accesses memory mapped to –CS0 to assume 8-bit ROM memory. The MB86932 generates four sequential fetches to assemble a complete instruction or data word before continuing. Bytes are fetched in sequence (0,1,2,3) as encoded by –BE[2] and –BE[3] (00, 01, 02, 03). Writes to –CS0 are unaffected by boot mode selection. If left unconnected, a weak pull-up on this pin (and –BMODE16 pin) causes the processor to default to 32-bit mode. | | | | | | -BMODE16 | 1<br>S (L) | 16-BIT BOOT MODE: This signal is sampled during reset and causes read accesses memory mapped to -CS0 to assume 16-bit ROM memory. The MB86932 generates two sequential fetches to assemble a complete instruction or data word before continuing. Half words are fetched in sequence (0,1) as encoded by -BE[2]. Writes to -CS0 are unaffected by boot mode selection. If left unconnected, a weak pull-up on this pin (and -BMODE8 pin) causes the processor to default to 32-bit mode. | | | | | | -BE3-0 | O<br>S (L)<br>G (Z)<br>I (O) | BYTE ENABLES: These pins indicate whether the current store transaction is a byte, half-word or word transaction. —BE3-0 signals are available in the same cycle in which the corresponding address value is asserted on the address bus and is valid for the duration of the bus transaction. This bus should be used only to qualify store transactions. For load transactions all sub-word requests are read (and replaced in the cache) as words and then the appropriate byte or half-word is extracted by the integer unit. Possible values for —BE3-0 are as follows: Byte Writes Half-Word Writes Word Writes BE < 2:3 > are also used in 8 and 16-bit ROM accesses as follows: Bus Mode Byte BE < 2:3 > Bus Mode Byte BE < 2:3 > Bus Mode Byte BE < 2:3 > B-bit 0 0 00 2 10 2 10 3 11 16-bit 0 4 1 00 2 8 3 10 | | | | | | D <31:0> | I/O<br>S (L)<br>G (Z)<br>I (Z) | DATA BUS: The bus interface has 32 bidirectional data pins (D31-D0) to transfer data in thirty-two bit quantities. D (31) corresponds to the most significant bit of the least significant byte of the 32-bit word. A double word is aligned on an 8-byte boundary, a word is aligned on a 4-byte boundary, and a half-word is aligned on a 2-byte boundary. If a load or store of any of these quantities is not properly aligned, a Not Aligned Trap will occur in the processor. In write bus cycles, the point at which data is driven onto the bus depends on the type of the preceding cycle. If the preceding cycle was a write, data is driven in the cycle immediately following the cycle in which—READY was asserted. If the preceding cycle was a read, data is driven one cycle after the cycle in which—READY was asserted to minimize bus contention between the processor and the system. All bits of the data bus are driven regardless of word size. The values on the pins not corresponding to the byte or half-word being written are undefined. | | | | | | SYMBOL | TYPE | DESCRIPTION | |----------|------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | AS | O<br>S (L)<br>G (Z)<br>I (1) | ADDRESS STROBE: A control signal asserted by the MB86932 or other bus master to indicate the start of a new bus transaction. Abus transaction begins with the assertion of –AS and ends with the assertion of –READY. –AS remains asserted for 1 clock cycle. During cycles in which neither the processor nor another bus master is driving the bus the bus is idle, and –AS remains de–asserted. | | RD/–WR | O<br>S (L)<br>G (Z)<br>I (1) | READ/BUS TRANSACTION: This signal specifies whether the current bus transaction is a read or a write operation. When -AS is asserted and RD/-WR is low, then the current transaction is a write. With -AS asserted and RD/-WR high, the current transaction is a read. RD/-WR remains active for the duration of the bus transaction and is de-asserted with the assertion of -READY. | | -READY | S (L) | READY: This is a control signal asserted by the external memory system to indicate that the current bus transaction is being completed and that it is ready to start with the next bus transaction in the following cycle. In case of a fetch from memory, the processor will strobe the value on the data bus at the rising edge of CLK_IN following the assertion of -READY. For the case of a write, the memory system will assert—READY when the appropriate access time has been met. In most cases, no additional logic is required to generate the -READY signal. On—chip circuitry can be programmed to assert—READY based on the address of the current transaction. The external system can override the internal ready generator to terminate the current bus cycle early. Up to 6 address ranges each with different transaction times can be programmed. | | -DREQ0-1 | A(L) | DMA REQUEST: Indicates that an external device is requesting a DMA transfer. This signal is edge sensitive for single transfers and level sensitive for demand transfer. -DREQ0 corresponds to DMA channel 0, while -DREQ1 corresponds to DMA channel 1. | | DACK0-1 | 0 | <b>DMA ACKNOWLEDGE:</b> This signal is asserted when an external device asserts –DREQ and the processor accessed the external device. –DACK1 corresponds to DMA channel 0, while –DACK1 corresponds to DMA channel 1. | | -EOP0-1 | 1/0 | <b>END OF PROCESS:</b> This signal is asserted by the external device when it wants to terminate a DMA transfer. Alternately, the processor drives this signal when the byte count reaches zero. –EOP0 corresponds to DMA channel 0, while –EOP1 corresponds to CMA channel 1. A pull–up holds –EOP0–1 high when it is not being driven. | | -PBREQ | 0 | PROCESSOR BUS REQUEST: This signal is asserted by the processor to indicate to an external bus arbiter that it needs to regain control of the bus. This provides a handshake between the arbiter and the processor to allow the bus to allocated based on demand. | | -BMREQ | 0 | BURST MODE REQUEST: This signal is asserted by the processor to indicate to the external system that the processor's burst mode is enabled and the current transaction can be a burst. If the external system supports burst mode, it asserts –BMACK is concurrently with –RDY to begin the burst mode transfer. | | -BMACK | - | BURST MODE ACKNOWLEDGE: This signal is asserted by the system to indicate that it can support burst mode for the address currently on the bus. The system asserts –BMACK in response to the processor asserting –BMREQ. | | CLK_ECB | Ι | <b>EXTERNAL CLOCK BYPASS:</b> Tying this signal high causes the CLK_IN signal to bypass the Phases Lock Loop (PLL). This signal is used for testing of the chip. | SIGNAL DESCRIPTIONS (Continued) | SIGNAL DESCRI | 110110 | (Continued) | |----------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------| | SYMBOL | TYPE | DESCRIPTION | | PARITY < 3:0 > | 1/0 | PARITY: When enabled, this signal provides even or odd parity checking and generation for data bus accesses. | | EMU_SD < 3:0 > | 1/0 | EMULATOR STATUS/DATA BITS: Bi-directional pins used by a hardware emulator to control and monitor MB86932 execution. These pins should be left unconnected. | | EMU_D < 3:0 > | 1/0 | EMULATOR DATA BITS: Bi-directional pins used by a hardware emulator to control and monitor MB86932 execution. These pins should be left unconnected. | | EMU_BRK | ľ | EMULATOR BREAK REQUEST LINE: Input used by a hardware emulator to request a trap when emulation is enabled. This pin should be left unconnected. | | -EMU_ENB | 1 | <b>EMULATOR ENABLE:</b> Tied low while the MB86932 is being reset to enable hardware emulator mode on the chip. This pin should be left unconnected. | | тск | 1 | TEST CLOCK: JTAG compatible test clock input. | | TMS | ı | TEST MODE: JTAG compatible test mode select pin. | | TDI | ı | TEST DATA IN: JTAG compatible test data input. | | TDO | 0 | TEST DATA OUT: JTAG compatible test data output. | | -TRST | l | <b>TEST RESET:</b> Asynchronous reset for JTAG logic. If not using JTAG, this signal must be pulled low. | In the following descriptions, signal names preceded by a minus sign (--) indicate an active low state. Dual function pins have two names separated by a slash (/). NOTE: I = Input Only Pin O = Output Only Pin I/O = Either Input or Output Pin - = Pins "must be" connected as described A (L) = Asynchronous: Inputs may be asynchronous to CLKOUT. S (L) = Synchronous; Inputs must meet setup and hold times relative to CLK\_IN Outputs are Synchronous to CLK\_IN G (...) = While the bus is granted to another bus master (-BGRNT=asserted), G (1) is driven to V<sub>CC</sub> G (0) is driven to V<sub>SS</sub> G (Z) floats G (Q) is a valid output I (...) = While the bus is between bus cycles (or being reset) and is not granted to another bus master, the pin is I (1) is driven to V<sub>CC</sub> I (0) is driven to V<sub>SS</sub> l (Z) floats l (Q) is a valid output #### OVERVIEW The Fujitsu MB86932 is a high performance, 32-bit RISC processor which executes at 40 MIPs peak and 37 MIPs sustained performance with 40 MHz clock frequency. It is a fourth generation version of Fujitsu's SPARClite embedded processor family. Like its predecessors, the MB86932 is based on the SPARC architecture and is upward code compatible with previous implementations. The MB86932 has been developed specifically with the needs of embedded applications in mind and offers high performance and high integration for these applications. The MB86932 instruction set is streamlined and hardwired for fast execution with most instructions executing in a single cycle. The Integer Unit (IU) features a 5-stage pipeline which has been designed to handle data interlocks, has an optimized branch handler for efficient control transfers, and a bus interface to handle single cycle bus accesses to on-chip memory. An internal register file consisting of 136 registers organized into eight overlapping windows speeds interruptresponse time and contexts witches. The register file minimizes accesses to memory during procedure linkages and facilitates passing of parameters and assignment of variables. On-chip 8 Kbyte instruction and 2 Kbyte data caches have been added to decouple the processor from external memory. These caches have been designed with maximum flexibility in mind and allow entries to be locked to improve overall system performance. Separate 32-bit on-chip instruction and data paths provide a high bandwidth interface between the IU and on-chip cache. These buses support single cycle instruction execution as well as single cycle data transfers with the cache. The MB86932 also includes hardware for integer multiply and divide. The hardware support significantly improves the performance of these operations with 32-bit integer multiplies executing in 5 clock cycles, 16-bit integer multiplies in 3 cycles, 8-bit integer multiplies in 2 cycles, and a multiply by zero can complete in a single cycle. #### **KEY FEATURES** Fast Instruction Execution: Simple functions make up the bulk of instructions in most programs so that execution speed can be greatly improved by designing these instructions to execute in as short a time as possible. The majority of instructions execute in one cycle with only a few of the more complex, such as integer multiply, taking additional cycles. Large Register Set: The large register set reduces the number of required accesses to data memory. The registers are organized in overlapping groups called register windows which allows registers to be reserved for high priority tasks, such as interrupts, or for recurring requirements such as operating system working registers. The overlapping windows also simplify parameter passing during procedure linkage and reduce code in most programs. On-Chip Caches: To decouple the speed of the processor from the memory sub-system, data and instructions caches have been added. The caches are organized as two-way set-associative for improved hit rates. In addition, the set-associative caches organization allows entries to be locked, while the rest of the cache performs normally. Cache Locking: Both data and instruction entries can be locked into their respective caches to ensure deterministic response and highest performance for critical or frequently recurring routines. Maximum flexibility has been designed into the cache to allow all or selected portions to be locked. Translation Lookaside Buffer: A 16-entry TLB provides a mechanism to translate virtual to physical addresses. Page sizes of 4K, 256K and 16M are supported. 64 different process context IDs can be defined. Bus Interface: The requirement for glue logic between the MB86932 and the system is minimized by providing programmable chip selects, programmable wait state circuitry, and support for connection to fast page—mode DRAM. Multiple bus masters are supported through a simple handshake protocol. The MB86932 can boot from either 8, 16 or 32—bit wide memory. On-Chip DMA: Two DMA channels support contiguous block and chained block transfers. Byte, halfword, word, and quad-word data types are supported. Either fly-by or flow through addressing modes can be selected. Clock Generator: To simplify the clock design a crystal can be connected directly to the on-chip oscillator or an external clock source can be used. A built in phase-locked loop minimizes the skew between on and off-chip clocks. Enhanced Instruction Set: The MB86932 incorporates a fast integer multiply instruction which executes in a fast 5, 3 or 2 cycles for 32-bit, 16-bit or 8-bit multiplicands. An integer divide-step instruction cuts divide times by a factor of 10 over previous SPARC implementations. A scan instruction supports a single cycle search for the most significant 1 or 0 in a word. Fully Static Circuit Design: Embedded applications that need a means to reduce power consumption can take advantage of the MB86932's fully static design. The processor clock can be slowed or stopped for arbitrary periods of time to reduce operating current with no loss of internal state. Noise immunity is improved as well. (note: stopping the clock will result in the Phase–Lock Loop losing lock. Lock must be re–established before normal operation can be resumed.) Test and Debug Interface: The MB86932 supports production test through industry standard JTAG boundary scan. Hardware emulation is supported with on-chip breakpoint and single step logic. A dedicated emulator bus provides a means to trace transactions between the integer unit and on-chip cache. #### **CPU** The MB86932 core is a high performance fully custom implementation of the SPARC architecture. The core is compact to leave room for peripheral integration and yet is designed in a way to allow the major blocks to be customized for varying application requirements. The core is made up of three functional units: the Instruction block, the Address block and the Execute block. (see Figure 1) A five stage instruction pipeline is responsible for decoding all instructions and generating the control TABLE 1. MB86932 Instruction Set | TABLE 1. MB86932 Instruction Set | | | | | | | | |----------------------------------|-----------------------------------------|-------------------------------------|--|--|--|--|--| | LOGICAL | ARITHMETIC/SHIFT | DATA MOVEMENT | | | | | | | CONDITION CODES UNCHANGED | CONDITION CODES UNCHANGED | TO USER/SUPERVISOR SPACE SIGNED | | | | | | | AND | ADD | LOAD BYTE | | | | | | | OR | SUBTRACT | LOAD HALF-WORD | | | | | | | XOR | MULTIPLY (SIGNED/UNSIGNED) | LOAD WORD | | | | | | | AND | SCAN | LOAD DOUBLE WORD | | | | | | | NOT | SETHI | STORE BYTE | | | | | | | OR NOT | SHIFT LEFT LOGICAL | STORE HALF-WORD | | | | | | | XNOR | SHIFT RIGHT LOGICAL | STORE WORD | | | | | | | | SHIFT RIGHT ARITHMETIC | STORE DOUBLE WORD | | | | | | | CONDITION CODES SET | CONDITION CODES SET | TO USER SPACE UNSIGNED | | | | | | | AND | ADD | LOAD BYTE | | | | | | | OR | SUBTRACT | LOAD HALF-WORD | | | | | | | XOR | MULTIPLY (signed/unsigned) | | | | | | | | AND NOT | MULTIPLY STEP | TO ALTERNATE SPACE SIGNED | | | | | | | OR NOT | DIVIDE STEP | LOAD BYTE | | | | | | | XNOR | | LOAD HALF-WORD | | | | | | | | EXTENDED AND CONDITION CODES | LOAD WORD | | | | | | | CONTROL TRANSFER | UNCHANGED | LOAD DOUBLE WORD | | | | | | | CONDITIONAL BRANCH | ADD | STORE BYTE | | | | | | | CONDITIONAL TRAP | SUBTRACT | STORE HALF-WORD | | | | | | | CALL | EXTENDED AND CONDITION CODES | STORE WORD | | | | | | | RETURN | SET SET | STORE DOUBLEWORD | | | | | | | SAVE | ADD | TO ALTERNATE SPACE UNSIGNED | | | | | | | RESTORE | | LOAD BYTE | | | | | | | JUMP AND LINK | SUBTRACT TAGGED AND CONDITION CODES SET | LOAD HALF-WORD | | | | | | | | (WITH AND WITHOUT TRAP ON | ATOMIC OPERATION IN USER SPACE | | | | | | | | OVERFLOW) ADD | SWAP WORD | | | | | | | | ADD | LOAD/STORE UNSIGNED BYTE | | | | | | | READ/WRITE CO | READ/WRITE CONTROL REGISTER | | | | | | | | READ PSR READ | WIM RDASR | ATOMIC OPERATION IN ALTERNATE SPACE | | | | | | | | E WIM WRASR | SWAP WORD | | | | | | | | AD Y | LOAD/STORE UNSIGNED BYTE | | | | | | | | TE Y | 25. 15. 51 51 12 51 51 GIVED DI 12 | | | | | | | <b>VIII</b> | | <u></u> | | | | | | signals to the other blocks. The 5-stage pipeline consists of Fetch (F), Decode (D), Execute (E), Memory (M) and Writeback (W). Instruction memory is addressed and returns instructions in the (F) stage, the register file is addressed and returns operands in the (D) stage, the ALU computes results in the (E) stage, external memory is addressed in the (M) stage, and the register file is written back in the (W) stage. #### **ADDRESS SPACE** The MB86932 offers a large addressing range and allows separate user and supervisor spaces to be defined. In addition to 32 address lines, 8 alternate address space identifiers (ASIs) distinguish between protected and unprotected space. Of the 256 possible ASI values, two define accesses to user data and user instruction space while the remaining ASI values define supervisor space. Anytime a reset, synchronous trap or asynchronous trap occurs, the processor is placed into the supervisor mode. In this mode, the processor executes instructions and moves data out of supervisor space. While in supervisor mode, the processor also has access to the remaining ASI values. Except for those mentioned and those reserved for control register space, the remaining ASI values can be used to access other alternate data spaces defined by the application. The distinction of user versus supervisor space allows the hardware to protect against accidental or un-authorized access to system resources. For real time operating system (RTOS) development for example, the separate spaces provide a mechanism for effectively partitioning RTOS space from user space. #### **REGISTERS** The MB86932 register set is divided into those used for general purpose functions and those used for control and status. The 136 general purpose registers are divided into 8 global registers and 8 overlapping blocks or "windows". Each window contains 24 registers. Of these, 8 are local to the window, 8 "out" registers overlap with the next window and 8 "in" registers overlap with the previous window (see Figure 2). This organization makes it easy to pass parameters to subroutines. Parameters that are to be passed along are written to the "out" registers and the subsequent procedure call decrements the window pointer to make a new set of registers available. The passed parameters are now available to the subroutine in the current window's "in" registers. Register windows improve performance in embedded applications because they function as local variable caches which retain either interrupt, subroutine, context or operating system variables with no additional overhead. In addition, code can be reduced by exploiting the efficient execution of procedure linkage by preventing in–lining compiler optimizations. The registers that make up the register file each have three read—only and one write—only port. The use of a four port register file allows even store instructions, which may require that three operands be read out of the register file, to proceed at one instruction per cycle. The control and status registers include those defined by the SPARC architecture (See Table 1) and those mapped into alternate address space to control peripheral functions (See Table 2). #### **INSTRUCTION SET** The MB86932 is upward code compatible with other SPARC processors. Additional instructions, previously not directly supported, have been added to improve performance in embedded applications. Integer multiply, integer divide step, and scan for first changed bit have been added to the already powerful SPARC instruction set. See Table 1 for a list of supported instructions. Figure 2. General Purpose Register Organization #### **INTERRUPTS** A key measure of a processor's suitability for use in embedded application is in its ability to handle interrupts with a minimum of delay and in a deterministic fashion. The MB86932 implementation has been tailored to insure not only low average latency but low maximum latency as well. Interrupt response time is made up of the sum of the times it takes the processor to finish its current task after recognizing an interrupt, and the time it takes to begin executing interrupt service routine instructions. The MB86932 implements numerous features to minimize both factors. To minimize the time it takes to finish the current task, the MB86932 is designed so that tasks can either be interrupted or completed in a minimum of cycles. Implementation details that accomplish this aim include cache line misses that are filled one word at a time through a pre-fetch buffer, integer divide that is interruptible through the use of a divide step instruction, fast multiply and a 1 word write buffer to limit pending bus transactions. To minimize the time required to start executing the interrupt service routine the processor switches to a new register window when an interrupt is detected. This feature allows the service routine to be executed without first requiring that the current registers be saved. The user can also elect to lock the service routine into the cache. This makes the routine available for immediate access. The on-chip data cache can also serve the service routine as a fast local stack for minimum delay in accessing routine variables. The MB86932 provides for up to 15 different interrupt levels and direct support for 15 separate interrupt sources. The highest interrupt level is non-maskable. #### CACHE The MB86932 has separate on-chip data and instruction caches. This allows the user to build a high performance system without incurring the cost of requiring fast external memory and the associated control logic. The caches are physically mapped. The instruction cache is organized as two banks of one hundred twenty-eight 32-byte lines (See Figure 4). The data cache is organized as two banks of sixty-four 16-byte lines (See Figure 5). The lines are organized as two-way set-associative for good performance even when cache locking is in effect. Lines are divided into sub-blocks each four bytes wide. On a cache miss, the caches are updated either 1 word (4 bytes) at a time, or 4 words at a time using the processor's burst mode feature. Single word updates minimize interrupt latency associated with long cache line replacements, while 4 word burst refills maximize the use of available bus bandwidth. An instruction pre-fetch buffer fetches the next sequential instruction anticipating that it will be needed to fill the next instruction cache miss. The caches can be used in either normal or one of two lock modes. In normal mode, the caches use an LRU (least recently used) algorithm to replace one of the two appropriate entries. Alternately, the two locking modes allow the entire cache or just selected entries to be locked. The lock modes allow time critical routines to be locked in cache Global locking allows the entire content of either the instruction or data cache to be frozen. Two control bits in the cache control register enable or disable locking for either cache. With the entire cache locked, no valid entry can be replaced. To insure best possible performance however, invalid entries will be updated if they are accessed. This is done automatically and incurs no time penalty. Local cache locking makes it possible to dynamically lock selected instructions or data entries into the appropriate cache. This feature gives the flexibility, for example, to assure deterministic response for certain critical interrupt routines by locking the routine's code into the cache. Entries can also be locked where it is desirable to give performance priority to certain often used routines which might otherwise be removed from cache. The 2-way set-associativity allows the cache to perform effectively even with some locked entries. In local lock mode, each entry can either be locked individually by software or automatically with hardware assist. For individual locking, software writes the lock bit in the appropriate cache tag line. For automatic locking, a bit in each cache control register enables or disables the feature. The enable bit is set at the beginning of a routine for which the entries are to be locked. This causes the location of any cache access occurring while the bit is enabled to be locked into the cache. In addition to requiring just one initial cycle to enable, automatic entry locking incurs no overhead while in effect. Locked locations can be cleared with a single write to a control register. In unlocked operation, the data cache uses a write-through update policy and allocates a cache entry only on a load. Writes are buffered so that the processor can continue executing while data is written back to memory. In contrast, writes to locked data cache locations are not written through to main memory. Besides reducing external bus activity, this design supports configuring a portion of data cache as on-chip RAM which does not map to external memory. The data and instruction caches are designed to be accessed independently over separate data and instruction buses to allow data to be loaded from and stored to cache at peak rates of 1 CPI. #### TRANSLATION LOOKASIDE BUFFER A 16-entry TLB supports virtual to physical address mapping and provides a mechanism for memory protection. Although it is by no means the only memory management model supported, the MB86932 TLB design allows the SPARC reference MMU specification to be implemented (see Figure 6). The MB86932 TLB supports 4K, 256K 16M and 4G page sizes. Pages can be marked to disable caching and to enable or disable translation. Access protection to enable combinations of read, write and access protection is also provided (See Table 1). Access protection can be set on 1K as well as the standard page size boundaries. Six context bits in each TLB entry provide for up to 64 separate context IDs. The 16-entry fully associative TLB caches physical table entries for both instruction and data address translation. A separate entry, the ITLB, is used only for instruction address translation. Together the TLB and the ITLB allow for simultaneous translation of two addresses, one data address and one instruction address. This allows the processor to continue to perform loads and stores in a single clock cycle. The ITLB works by caching the most recently used instruction translation entry. Because of the sequential nature of instruction addresses, this single entry provides a high hit rate for instruction address translation. If a miss occurs in the ITLB the TLB is accessed in the next cycle to do an instruction translation. Table walking to handle TLB misses is handled in software. **Table 1. TLB Access Protection** | Accesses Allowed | | | | | | | |-------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | User Access Supervisor Access | | | | | | | | Read Only Read/Write Read/Execute Read/Write/Execute Execute Only Read Only No Access No Access | Read Only Read/Write Read/Execute Read/Write/Execute Execute Only Read Only Read/Execute Read/Write/Execute | | | | | | #### **BUS INTERFACE** The Bus Interface Unit (BIU) is designed to simplify the interface between the MB86932 and the rest of the system. Separate address and data buses make it easy to build fast systems. At the same time, on-chip circuitry allows these systems to be built with a minimum of external hardware. Two DMA channels provide high speed memory-to-memory and memory-to-peripheral data transfers. The DMA channels execute independently of the processor and make it possible for the processor to continue to execute from cache while the DMA transfers are taking place. Flexible priority allows the processor to suspend transfers if it needs to use the bus (on a cache miss for example). The MB86932 DMA controller supports byte, halfword, word and quad-word transfers. Either fly-by or flow-through transfers are possible under single, block and demand transfer modes. Transfers can be chained to support scatter/gather operations. The DMA transfers are initiated either by software or by external hardware handshake. The bus interface supports fully programmable wait state generation, address decoding with chip select outputs, same page detection to support page-mode DRAM, booting from 8 and 16-bit wide memory, and an auto-reload timer. A burst mode bus supports fast cache line fills. #### **CLOCK GENERATOR** The on-chip clock generator provides a means to directly connect the MB86932 to either a crystal oscillator or an external clock source. For either case, the external frequency is the same as the chip operating frequency. A clock output signal provides the system with a reference by which external timing can be synchronized when not using an external clock source. The skew between the internal clock and an external input clock source is minimized by the inclusion of an on-chip phase lock loop circuit. TABLE 1. MB86932 Control and Status Register (All registers are read/write) TABLE 2. MB86932 Memory Mapped Control Registers (All register are read/write) | San | ne Page Mask | 31 30 23 22 1 0 | | | | | |---------------|-------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | ASI | ADDRESS | ASI Mask Address Mask [[Care=0, Don't Care=1, RST=0] [Care=0, Don't Care=1, RST=0] | | | | | | 0x 1 | 0x 0000 0120 | [Calado, Bolt Caladi, 101-0] | | | | | | Add | iress Range <sup>†</sup> | 31 30 23 22 1 0 | | | | | | ASI | ADDRESS | ASI < 7:0 > ADR < 31:10 > (RST=Undefined) (RST=Undefined) | | | | | | 0x 1 | CS1 0x 0000 0124<br>CS2 0x 0000 0128<br>CS3 0x 0000 012C<br>CS4 0x 0000 0130<br>CS5 0x 0000 0134 | NOTE: CS0 is hardwired to ASI=0x9 ADR < 31:10 > = < 00 > | | | | | | Ac | ldress Mask | 31 30 23 22 1 0 | | | | | | ASI | ADDRESS | ASI Mask ADR < 31:10 > Mask (0=Care, 1=Don't Care, RST=Undefined ) | | | | | | 0x 1 | CS0 0x 0000 0140 CS1 0x 0000 0144 CS2 0x 0000 0148 CS3 0x 0000 0146 CS4 0x 0000 0150 CS5 0x 0000 0154 | NOTE: CS0 ADR < 14:10 > = 1, ADR < 31:15 > = 0, ASI = 0x9 at reset. | | | | | | Wait | State Specifier | 31 2726 25 24 23 22 21 20 19 18 14 13 9 8 7 6 5 4 3 2 1 0 | | | | | | ASI | ADDRESS | Count1 Count2 Count1 Count2 | | | | | | 0x 1 | CS1,CS0 0x 0000 0160<br>CS3,CS2 0x 0000 0164<br>CS5,CS4 0x 0000 0168 | Wait Enable (On=1, Off=0, RST=0) Single Cycle Non Burst Mode (On=1, Off=0, RST=0) Single Cycle Burst Mode (On=1, Off=0, RST=0) Override (On=1, Off=0, RST=1) Parity Enable for odd CS Parity Enable for even CS | | | | | | | Timer | 31 16 15 0 | | | | | | ASI | ADDRESS | reserved Timer Value | | | | | | 0x 1 | 0x 0000 0174 | (RST=Undefined) | | | | | | Tim | er Pre-Load | 31 16 15 0 | | | | | | ASI | ADDRESS | reserved Timer Pre-Load Value | | | | | | 0x 1 | 0x 0000 0178 | (RST=Undefined) | | | | | | Source | /Destination ASI | 31 24 23 16 15 8 7 0 | | | | | | ASI | ADDRESS | Descriptor Pointer Source ASI Destination ASI (RST=Undefined) (RST=Undefined) (RST=Undefined) | | | | | | 0x 1 | 0x 0000 0180 DMA0<br>0x 0000 01A0 DMA1 | Source Alternate Space Identifier Destination Alternate Space Identifier | | | | | | 1 This regist | ter is Write Only | | | | | | TABLE 2. MB86932 Memory Mapped Control registers (Continued) TABLE 2. MB86932 Memory Mapped Control registers (Continued) TABLE 2. MB86932 Memory Mapped Control registers (Continued) TABLE 2. MB86932 Memory Mapped Control registers (Continued) #### **FEATURES** The Bus Interface Unit (BIU) has the logic which allows the MB86932 to interface with the system. The system interface is made up of the address and data buses, the interrupt request bus and various control signals. The BIU is either handling requests for external memory operations, arbitrating for bus access, or idle. #### Operation of the BIU In the case of a write to external memory, the BIU makes use of a write buffer which can hold a one word write transaction. When the BIU receives a request for a write transaction it stores the write data and address in the write buffer allowing the IU to continue operating out of on—chip cache and/or its register file. The BIU then proceeds to complete the write to external memory. In most cases the write buffer will hide external memory latency from the IU. The exceptions are in cases where the write buffer is still filled from a previous transaction or if the subsequent IU cycle results in an instruction cache miss. In these cases, IU execution is held until the write buffer is emptied. The BIU includes a one stage prefetch buffer for instruction fetches. This buffer is used to fetch the next sequential instruction after an instruction cache miss. The instruction is prefetched only if the BIU does not have a request for a bus transaction from the IU nor is any external device requesting use of the bus. The prefetch buffer operation is suspended if the buffer is full. This occurs if the prefetched instruction is a hit in the instruction cache. The buffer restarts after another instruction cache miss. If an exception occurs during an instruction prefetch, the exception is not sent to the IU unless the instruction is actually requested by the IU. The prefetch buffer operates only when the instruction cache is on. In any cycle the BIU can receive a request for accesses to either or both instruction and/or data memory. If it receives a request for both in the same cycle, it completes the data memory transaction first. #### **Exception Handling** The external memory system can indicate an exception during a memory operation. Parity errors cause an exception as well. The BIU signals the appropriate data or instruction exception to the IU which will trap accordingly. As mentioned above, the IU can continue operation after putting the data and address for a store in the write buffer. If an exception is detected while completing this buffered write, then the BIU indicates a data access exception to the III Any system which needs to recover from this error should store the address and data of such write transactions in hardware. If the system can generate both read and write exceptions, then the system must also provide a status bit which indicates whether the exception was generated on a read or on a write transaction. With access to this information the data access exception service routine can determine the cause of the exception and recover accordingly. #### **Bus Cycles** Timings 1 through 9 illustrate representative combinations of bus cycles. #### Load Whenever an instruction fetch or a load from data memory has a miss in the cache, the BIU performs a read from external memory. A read transaction begins with the BIU asserting -AS, to indicate a new bus transaction. The -AS signal is de-asserted after one cycle. At the same time the ADR < 31:2 > and ASI < 7:0 > bits are driven with the location to be read. The BIU drives the RD/-WR signal high to indicate a read transaction. The external memory system responds with the read data on pins D < 31:0 >. It also asserts the -READY signal when the data is ready. For slow memory, the -READY signal can be delayed until data is valid. A load double operation is treated as back-to-back reads. #### Load with Exception If the external memory system sees a memory exception it can terminate the current memory transaction by asserting the –MEXC and –READY signals. The data on the data bus is ignored by the MB86932. #### Store A write transaction begins with the BIU asserting -AS, to indicate a new bus transaction. The -AS signal is de-asserted after one phase. At the same time the ADR < 31:2 > and ASI < 7:0 > pins are driven with the location to be written while the D < 31:0 > pins has corresponding write data. The -BE0-3 pins indicate byte, half-word or word transaction width. The BIU drives the RD/-WR signal low to indicate a write transaction. The external memory system responds by asserting the -READY signal when it has stored the data. A store double operation is treated as back-to-back writes. #### Store with Exception If an access exception occurs on a write, the external memory system can terminate the current memory transaction by asserting the -MEXC and -READY signals. The external memory system is expected to ignore the data on the data bus in this situation. #### **Atomic Load Store** An atomic load store executes as a load followed by a store with no operation allowed in between. The –LOCK signal is asserted to indicate that the bus is being used for more than one external memory operation. There is one cycle between the termination of the read and the beginning of the write to provide time for the switching of the data bus drivers. #### **External Bus Request and Grant** Any external device can request ownership of the bus by asserting the -BREQ signal. The BIU asserts the -BGRNT signal to indicate that it is relinquishing control of the bus and also three-states all of its bus drivers. In the following cycle, the external device can begin its transaction. On completion of its transaction the external device de-asserts the -BREQ signal. The BIU responds by de-asserting the -BGRNT signal in the following cycle. A separate signal, -PBREQ, is asserted by the processor to indicate to a bus arbiter that it needs the bus back. This allows the bus to be allocated based on demand. The MB86932 is the default owner of the bus. #### 8-Bit and 16-Bit Bus Modes The MB86932 supports chip select zero (CS0 to be mapped into memory that can be either 8, 16, or 32-bits wide). Memory width for CS0 is selected at system reset. Transactions of 8 and 16-bit widths are similar to 32-bit transactions except that -AS is asserted only once at the beginning of the bus cycle and -READY is asserted after each byte or halfword is available. -BE[0:3] indicates the byte or halfword being read or written (see Timing diagrams 7 and 8). #### **Burst Mode Transactions** For systems that can support burst mode transactions, the MB86932 can be programmed to support 4 word bursts. When burst mode is enabled, –BMREQ is asserted at the beginning of each bus cycle for which a burst access can be done (see timing diagram 9). If the memory system can support a burst for the current bus address, it asserts –BMACK to begin the burst transaction. –BMACK is asserted on the first word of the burst transaction only. –READY is asserted with each word of the burst. Systems that do not support burst mode for the current address should not assert–BMACK (see timing diagram 10). If –BMREQ is not asserted for a transaction the memory should return only one word. #### **Direct Memory Access** For systems that can support burst mode transactions, the MB86932 can support a number of different DMA modes. (See timing diagrams 11 through 15 for details. #### **ELECTRICAL CHARACTERISTICS** #### **ABSOLUTE MAXIMUM RATINGS** | Symbol | Rating | Conditions | Min | Max | Units | |-----------------|--------------------------------|------------|------|-----------------------|-------| | V <sub>CC</sub> | Supply voltage | | -0.3 | 6 | ٧ | | V <sub>I</sub> | Input voltage | | -0.3 | V <sub>CC</sub> + 0.3 | ٧ | | TJ | Operating junction temperature | | | 125 | С | Stresses above 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 condition above those indicated in the operation section of this specification is not implied. Exposure to Absolute Maximum Ratings conditions for extended periods may affect device reliability. Recommended Connections: - Power and ground connections must be made to multiple V<sub>CC</sub> and V<sub>SS</sub> pins. Every MB86932 based circuit board should include power (V<sub>CC</sub>) and ground (V<sub>SS</sub>) planes for power distribution. Every V<sub>CC</sub> pin must be connected to the power plane, and every V<sub>SS</sub> pin must be connected to the ground plane. Pins identified as "N.C." must not be connected in the system. - 2. Liberal decoupling capacitance should be placed near the MB86932. The processor can cause transient power surges when its numerous output buffers transition, particularly when connected to large capacitive loads. - Low inductance capacitors and interconnections are recommended for best high frequency electrical performance. Inductance can be reduced by shortening the board traces between the processor and decoupling capacitors as much as possible. Capacitors specifically designed for PGA and QFP packages will offer the lowest possible inductance. - 4. For reliable operation, afternate bus masters must drive any pins that are three-stated by the MB86932 when it has granted the bus, in particular -LOCK, ADR < 31:2 >, ASI < 7:0 >, -BE0-3, D < 31:0 >, -AS, and RD/-WR must be driven by afternate bus masters. These pins are normally driven by the processor during active and idle bus states and don't require external pullups. N.C. pins must always remain unconnected. #### PACKAGE THERMAL CHARACTERISTICS | Symbol | Parameter | Package | | Units | | | |------------------|----------------------------------------|-------------------------------------------------|----------|----------|---------|------| | Ø <sub>JC</sub> | Thermal resistance junction to case | 208 Ceramic QFP<br>208 Ceramic QFP w/ Heat Sink | | °C/W | | | | | | | 0 m/s | 1 m/s | 3 m/s | | | $\emptyset_{JA}$ | Thermal resistance junction to ambient | 208 Ceramic QFP<br>208 Ceramic QFP w/ Heat Sink | 19<br>16 | 15<br>12 | 13<br>8 | ∘c/W | Note: All numbers for package thermal characteristics assumes multilayer PCB. #### DC SPECIFICATIONS<sup>3</sup> $V_{CC} = 5V \pm 5\%$ | Symbol | Parameter | Conditions | Freq. | Min. | Typ. | Max. | Units | |------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|--------|------|------|-----------------|-------| | V <sub>IL</sub> | Input low voltage | | _ | 0 | - | 0.8 | ٧ | | $V_{IH}$ | Input high voltage (All pins except XTAL1) | | _ | 2.0 | - | V <sub>CC</sub> | V | | | Input high voltage (Pin XTAL1) | | _ | 2.8 | - | V <sub>CC</sub> | V | | V <sub>OL</sub> | Output low voltage | I <sub>OL</sub> = 3.2mA | - | 0 | - | 0.45 | V | | V <sub>OH</sub> | Output high voltage | I <sub>OH</sub> = -0.4mA | - | 2.4 | - | Vcc | V | | ILI | Input leakage current | V <sub>IN</sub> = 0 or V <sub>CC</sub> | _ | -10 | _ | 10 | μА | | I <sub>LZ</sub> | 3-state output leakage current | V <sub>OUT</sub> = 0 or V <sub>CC</sub> | _ | 10 | _ | 10 | Aμ | | Icc *1 | Operating power supply current *1 Note: Use I <sub>CC</sub> (typ) values to calculate maximum case and ambient temperature | | 20 MHz | - | 465 | 586 | mA | | | allowed. Note that maximum junction temperature of die is 125°C. For example, Allowed ambient temp = 125°C. − (I <sub>CC</sub> ) • (5.25V) • Ø <sub>JA</sub> | | 40 MHz | | 665 | 876 | mA | | C <sub>PIN</sub> | Pin capacitance (All pins except XTAL2) | $V_{CC} = V_I = 0$ | _ | _ | _ | 13 | pF | | | Pin capacitance (Pin XTAL2) | f = 1 MHz | _ | - | _ | 16 | pF | #### AC CHARACTERISTICS<sup>1,2,4</sup> V<sub>CC</sub> = 5V ± 5% | Cremb - I | Parameter Description | | 20 MHz | | 40 MHz | | | |-----------|----------------------------------------|----------------------------------------|------------|------|-------------|------|-------| | Symbol | | | Min. | Max. | Min. | Max. | Units | | t1 | CLKIN period | | 50 | 100 | 25 | 100 | ns | | t2 | CLKIN high Time | | 10 | | 6 | | ns | | t3 | CLKIN low time | | 14 | | 10 | | ns | | t4 | CLKIN rise time | | | 4 | | 2 | ns | | t5 | CLKIN fall time | | | 4 | | 2 | ns | | t6 | CLKIN to CLKOUT of | CLKIN to CLKOUT delay 7 | | 8 | 0 | 7 | ns | | t7 | CLKIN to CLKOUT2 delay 7 | | 25 | 33 | 13 | 20 | ns | | t8 | CLKOUT1, CLKOUT | CLKOUT1, CLKOUT2 high time 7 | | | 0.25xPeriod | | ns | | t9 | CLKOUT1, CLKOUT2 low time <sup>7</sup> | | 0.4xPeriod | | 0.4xPeriod | | ns | | t10 | CLKOUT1, CLKOUT | LKOUT1, CLKOUT2 fall time <sup>7</sup> | | 3 | | 3 | ns | | t11 | CLKOUT1, CLKOUT | <sup>7</sup> rise time <sup>7</sup> | | 4 | | 3 | ns | | t12 | D < 31:0 > | Output valid delay | | 21 | | 17 | ns | | | | Output hold | 2 | | 2 | | | | | ADR < 31:2 > | Output valid delay | | 24 | | 20 | ns | | | | Output hold | 2 | | 2 | | | | | -BE0-3 | Output valid delay | | 19 | | 17 | ns | | | | Output hold | 2 | | 2 | | | | | ASI < 7:0 > | Output valid delay | | 22 | | 18 | ns | | | | Output hold | 2 | | 2 | | | | t13 | -cs | Output valid delay | | 24 | | 20 | ns | | | | Output hold | 2 | | 2 | | | | t14 | -SAME_PAGE | Output valid delay | | 23 | | 20 | ns | | | | Output hold | 2 | | 2 | | | | t15 | RD/–WR | Output valid delay | | 18 | | 16 | ns | | | | Output hold | 2 | | 2 | | | | t16 | -LOCK | Output valid delay | | 19 | | 17 | ns | | | | Output hold | 2 | | 2 | | | | t17 | -AS | Output valid delay | | 21 | | 18 | ns | | | | Output hold | 2 | | 2 | | | | t18 | TIMED OVE | Output valid delay | | 20 | | 18 | ns | | | TIMER_OVF | Output hold | 2 | | 2 | | | | t19 | -BGRNT | Output valid delay | | 20 | | 16 | | | | -agnivi | Output hold | 2 | | 2 | | ns | ### AC CHARACTERISTICS<sup>1,2,4</sup> $V_{CC} = 5V \pm 5\%$ (Continued) | Orana hari | Parameter Description | | 20 MHz | | 40 MHz | | T | |------------|-------------------------------------------|--------------------|--------|------|--------|------|-------| | Symbol | | | Min. | Max. | Min. | Max. | Units | | t20 | -MEXC input setup time | | 16 | | 14 | | ns | | t21 | -READY input setup time | | 16 | | 14 | | ns | | t22 | D < 31:0 >input setup<br>time | Parity Enabled | 17 | | 15 | | ns | | | | Parity Disabled | 15 | | 12 | | ns | | t23 | -BREQ input setup time | | 10 | | 8 | | ns | | t24 | IRL < 3:0 > input setup time <sup>6</sup> | | _ | | _ | | ns | | t25 | -MEXC input hold time | | 2 | | 1 | | ns | | t26 | -READY input hold time | | 2 | | 1 | | ns | | t27 | D < 31:0 > input hold time | | 3 | | 2 | | ns | | t28 | -BREQ input hold time | | 3 | | 3 | | ns | | +00 | -DREQ0, -DREQ1 | Input Setup Time | 10 | | 8 | | ns | | t20 | | Input hold time | 2 | | 2 | | ns | | t14 | -DACK0, -DACK1 | Output valid delay | | 18 | | 15 | ns | | | | Output hold | 2 | | 2 | | ns | | t20 | –EOP0, –EOP1 | Input Setup Time | 10 | | 8 | | ns | | | | Input hold time | 2 | | 2 | | ns | | t14 | –EOP0, –EOP1 | Output valid delay | | 20 | | 18 | ns | | | | Output hold | 2 | | 2 | | ns | | t20 | ВМАСК | Input Setup Time | 14 | | 12 | | ns | | | | Input hold time | 2 | | 2 | | ns | | t14 | -BMREQ | Output valid delay | | 20 | | 18 | ns | | | | Output hold | 2 | | 2 | | ns | | t14 | -PBREQ | Output valid delay | | 15 | | 12 | ns | | | | Output hold | 2 | | 2 | | ns | | t22 | Parity < 3:0 > | Input setup time | 17 | | 15 | | ns | | | | Input hold time | 2 | | 2 | | ns | | t22 | Parity < 3:0 > | Output valid delay | | 21 | | 18 | ns | | | , any 10,00 | Output hold | 2 | | 2 | | ns | <sup>1.</sup> Parameters are valid over specified temperature range and supply voltage range unless otherwise noted. - 4. Timing specifications apply to frequency of operation listed at top of column - 5. All output timings are based on a 50pF load. - 6. IRL Pins on the MB86932 can be Asynchronous - 7. These specs will be improved in the future. - 8. Data bus output driver control is same as for RD/-WR so timing is similar. All voltage measurements are referenced to ground. All time measurements are referenced at input and output levels of 1.5V. For testing, all inputs swing between 0.4V and 2.4V (Except XTAL1 which swings from 0.4V to 3.0V). Input rise and fall times are 2ns or less. <sup>3.</sup> Not more than one output may be shorted at a time for a maximum duration of one second. Ordering Information: MB86932-20ZF-G ## Ordering Info MB86932-40ZF-G (w/ heatsink)