REV.0

PewerPe

# Application Note Designing G4 Systems

Kalpesh Gala and Jim Robertson risc10@email.sps.mot.com

This application note describes the differences between the 60x bus and the native bus mode of the G4 processor (a new bus interface that is derived from the 60x bus). It also briefly describes the 360-pin G4 processor that is pin-compatible with the MPC750 microprocessor. This document assumes that the reader has a working knowledge of the MPC750 microprocessor and the 60x bus protocol.

The G4 provides a mode switch (via the  $\overline{\text{EMODE}}$  signal) that allows either the G4 native bus or 60x bus operation. The G4 native bus mode includes several additional features that allow it to provide higher memory bandwidth than the 60x bus. A summary of 60x bus interface features are listed below:

- 32-bit address bus (plus 4 bits of odd parity)
- 64-bit data bus (plus 8 bits of odd parity)
- Support for a 3-state MEI coherency protocol similar to the MPC750
- Support for a 4-state MESI protocol similar to the MPC604 processors
- On-chip snooping to maintain data cache coherency for MP applications
- Support for address-only transfers
- Support for limited out-of-order transactions
- TTL compatible interface



In addition to the 60x bus features, to gain increased performance, the G4 native bus mode has the following features:

- Increased address bus bandwidth by eliminating dead cycles under some circumstances
- Full data streaming for burst reads and writes
- Increased levels of address pipelining
- Support for full out-of-order transactions
- Support for data intervention in MP systems (5-state MERSI)
- Support for up to seven outstanding transactions (six pending plus one data tenure in progress).

# 1.1 G4 Native Bus Mode Signals

The G4 native bus mode protocol defines several new signals not present in the 60x bus protocol. Also, there are G4 signals not supported by the G4 native bus mode protocol. These signal differences are summarized in Table 1.

| 60x Bus Signals<br>not in G4 Native Bus Mode | 60x Bus Signals<br>Expanded for G4 Native Bus<br>Mode | New G4 Native Bus Mode Signals |
|----------------------------------------------|-------------------------------------------------------|--------------------------------|
| Address Bus Busy<br>ABB                      | Data Bus Write Only<br>DBWO                           | Address Monitor<br>AMON        |
| Data Bus Busy<br>DBB                         | Shared<br>SHD                                         | Data Monitor<br>DMON           |
| Data Retry<br>DRTRY                          |                                                       | Hit<br>HIT                     |
| Extended Transfer Protocol<br>XATS           |                                                       | Data Ready<br>DRDY             |
| Transfer Code<br>TC[0:1]                     |                                                       | Enhanced Mode<br>EMODE         |
| Cache Set Element<br>CSE[0:1]                |                                                       | L2 Address<br>L2A17,L2A18      |
| Address Parity Error<br>APE                  |                                                       | Check<br>CHK                   |
| Data Parity Error<br>DPE                     |                                                       | Bus Voltage Select<br>BVSEL    |
|                                              |                                                       | L2 Voltage Select<br>L2VSEL    |

#### Table 1. Signal Summary

The three types of signals in Table 1 (shown in the column headings) are discussed in the following three sections.

# 1.1.1 60x Bus Signals Not in the G4 Native Bus Mode

Several signals defined in the 60x bus protocol are no longer required by the G4 native bus mode protocol.

Most of these signals are not implemented in G4, however, new signals provide similar functionality for compatibility reasons. These signals are identified and described below:

# 1.1.1.1 Address Bus Busy and Data Bus Busy ( $\overline{ABB}$ and $\overline{DBB}$ )

The G4 does not use the  $\overline{ABB}$  or  $\overline{DBB}$  signals as inputs. G4 tracks its own outstanding transactions, and will rely on the system arbiter to provide grants for the address and data buses only when the bus is available and the grant may be accepted.

For compatibility with 60x system arbitrs, G4 will generate  $\overline{ABB}$  and  $\overline{DBB}$  signals as outputs in the form of AMON and DMON respectively. This means that the system arbitr must not assume that a master knows that the bus is busy with a transaction for another master.

A G4 native bus mode system arbiter must synthesize its own  $\overline{ABB}$  and  $\overline{DBB}$  signals internally because the processor is not required to generate them.

# 1.1.1.2 Data Retry (DRTRY)

The data retry input does not exist in the G4 native bus mode specification, so the  $\overline{\text{DRTRY}}$  signal is not supported.

# 1.1.1.3 Extended Transfer Protocol (XATS)

Extended transfer protocol, used for accesses to direct-store segments, is not supported by the native bus mode of the G4 processor interface.

# 1.1.1.4 Transfer Code (TC[0:1])

The transfer code signals have been removed from the G4 native bus mode interface. The information provided by these signals in the 60x bus during read operations was code versus data. This information is now provided on the write-through  $(\overline{WT})$  signal during read operations.

# 1.1.1.5 Cache Set Element (CSE[0:1])

The cache set element signals have been removed because G4 does not support snoop-filtering devices. Note: Snoop filtering devices filter system coherency traffic.

# 1.1.1.6 Address Parity Error and Data Parity Error (APE and DPE)

The address parity error and data parity error signals have been removed from G4.

# 1.1.2 60x Bus Signals Expanded for G4 Native Bus Mode

The G4 native bus mode support of full out-of-order transactions and increased address bus bandwidth is realized through the expanded definitions of  $\overline{DBWO}$  and  $\overline{SHD}$ . The  $\overline{DBWO}$  signal was expanded to DTI for support of full out-of order transactions. The  $\overline{SHD}$  expansion to  $\overline{SHD0}$  and  $\overline{SHD1}$  allows for increased levels of address pipelining. Both of these expanded signals are discussed below.

# 1.1.2.1 Data Bus Write Only (DBWO) to Data Transfer Index (DTI[0–2])

The 60x bus transaction reordering scheme was implemented with the  $\overline{\text{DBWO}}$  signal. The G4 native bus mode can be configured to support a generalized reordering scheme using the new 3-bit data transfer index (DTI) signal.

DTI is a signal from the system arbiter to G4 that supports reordered data tenures. This signal can be bused or point-to-point. It must be driven valid by the system arbiter on the cycle before a data bus grant ( $\overline{DBG}$ ). It is sampled each cycle by G4, and is qualified by the assertion of  $\overline{DBG}$  on the following cycle.

The data transfer index is a pointer into G4's queue of outstanding transactions, indicating which transaction is to be serviced by the subsequent data tenure. Note that this protocol is a generalization of the  $\overline{DBWO}$  protocol in which the assertion of  $\overline{DBWO}$  indicated that the first write operation in the queue was to be serviced. For example, DTI = '000' means that the oldest transaction is to be serviced, DTI = '001' means the second oldest transaction is to be serviced, etc., up to DTI = '101' meaning the 6th oldest transaction is to be serviced. Note that since G4 only supports six outstanding data transactions a maximum setting for DTI of '101' is allowed.

Data tenure reordering can be disabled by setting DTI[0-2] to b'000'. This will always select the oldest transaction in the outstanding transaction queue.

# 1.1.2.2 Shared (SHD) to Shared (SHD0, SHD1)

The G4 native bus mode interface allows a given master to drive a new address tenure every other cycle, so the shared signal must be able to be driven every other cycle too. But, since it must be actively negated and might be driven by multiple masters at any given time, electrical requirements dictate that two versions of the SHD signal be implemented. When signaling a snoop response of shared, G4 must assert SHD0 unless SHD0 was asserted in any of the 3 cycles prior to the snoop response window for the current transaction. In that case, G4 must assert SHD1. This way SHD0 or SHD1 can be three-stated, driven negated, then three-stated again before it will need to be reasserted. When G4 is a bus master, G4 must consider the snoop response to be shared if either SHD0 or SHD1 is asserted.

# 1.1.3 New G4 Native Bus Mode Signals

The G4 native bus mode's support for data intervention in microprocessor systems and full data streaming for burst reads and writes is realized through the addition of two new signals— $\overline{\text{HIT}}$  and  $\overline{\text{DRDY}}$ . Other new signals include support for enabling the G4 native bus mode, larger L2 cache sizes, entering a diagnostics mode, and I/O voltage configuration. These new signals are discussed below.

# 1.1.3.1 Hit (HIT)

The  $\overline{\text{HIT}}$  signal is a point-to-point signal output from the processor or local bus slave to the system arbiter. This signal is a snoop response valid in the address retry ( $\overline{\text{ARTRY}}$ ) window (the cycle after an address acknowledge ( $\overline{\text{AACK}}$ )) that indicates G4 will supply intervention data. That is, G4 has found the data in its cache that has been requested by another master's bus transaction. Instead of asserting  $\overline{\text{ARTRY}}$  and flushing the data to memory, G4 asserts  $\overline{\text{HIT}}$  to indicate that it can supply the data directly to the other master.

Like other snoop responses,  $\overline{\text{HIT}}$  can be driven as soon as the second cycle after  $\overline{\text{TS}}$ . If  $\overline{\text{AACK}}$  is delayed, the response needs to be held until the cycle after  $\overline{\text{AACK}}$ .

The G4 implements the optional protocol of native bus mode of the G4 processor to communicate to the system whether or not the intervention data needs to be forwarded to memory. If G4 intervenes with shared or exclusive data rather than modified data, it can indicate this to the processor by asserting the  $\overline{\text{HIT}}$  signal for a second cycle after  $\overline{\text{AACK}}$ . If the data is modified, G4 negates  $\overline{\text{HIT}}$  on the second cycle after  $\overline{\text{AACK}}$ , and the system will "snarf" the data and forward it to memory. (Snarfing is when a device provides data specifically for another device and a third device reads the data also.)

Note that it is possible for G4 to assert both  $\overline{\text{ARTRY}}$  and  $\overline{\text{HIT}}$  simultaneously for the same snoop response. When simultaneously asserted,  $\overline{\text{ARTRY}}$  supersedes  $\overline{\text{HIT}}$ .

# 1.1.3.2 Data Ready (DRDY)

The  $\overline{\text{DRDY}}$  signal is a point-to-point signal from G4 to the system arbiter. It is a data bus request indicating to the arbiter that data for an outstanding intervention transaction previously signaled with a  $\overline{\text{HIT}}$  is ready. The arbiter will respond by granting the data bus to all devices participating in the transaction.

# 1.1.3.3 Enhanced Mode (EMODE)

The assertion of the  $\overline{\text{EMODE}}$  signal at hard reset's ( $\overline{\text{HRESET}}$ ) negation will select G4 native bus mode, otherwise 60x bus mode is selected. After the negation of  $\overline{\text{HRESET}}$ , if  $\overline{\text{EMODE}}$  is asserted it selects address bus drive mode<sup>1</sup> (only for native bus mode of the G4 processor mode).  $\overline{\text{EMODE}}$  negation selects normal address bus drive mode.

## 1.1.3.4 Additional L2 Address Signals (L2A17, L2A18)

The L2 cache interface of G4 provides an 18-bit address bus that controls a maximum of 2 Mbytes of external SRAM memory. The L2A17 address pin allows for 2 Mbytes SRAM addressing. In G4 the L2A18 address pin (which could allow 4 Mbytes addressable L2 cache) is not supported.

#### 1.1.3.5 Check (CHK)

This signal is for G4 testing purposes and supports three modes of operation:

- A post power-on-reset internal memory test and initialization can be selected by tying  $\overline{CHK}$  to  $\overline{HRESET}$ .
- Tying  $\overline{\text{CHK}}$  low enables engineering diagnostic mode.
- For normal operation tie  $\overline{CHK}$  high.

#### 1.1.3.6 Bus Voltage Select (BVSEL)/L2 Voltage Select (L2VSEL)

The G4 provides several I/O voltages to support both compatibility with existing systems and migration to future systems. The G4's core voltage must always be provided at 1.8V. Voltage to the L2 and processor I/O pins is provided through a separate sets of supply pins according to the configurations shown in Table 2. The voltage configuration for each bus is selected by sampling the state of the voltage select pins before and after the negation of HRESET.

| BVSEL Pin | L2VSEL Pin | Processor Interface<br>Voltage (V) | L2 Interface<br>Voltage (V) |
|-----------|------------|------------------------------------|-----------------------------|
| 0         | 0          | 1.8                                | 1.8                         |
| 0         | 1          | 1.8                                | 3.3                         |
| 0         | HRESET     | 1.8                                | 2.5                         |
| 1         | 0          | 3.3                                | 1.8                         |
| 1         | 1          | 3.3                                | 3.3                         |
| 1         | HRESET     | 3.3                                | 2.5                         |

Table 2. I/O Voltages

# 1.1.3.7 Bus Monitor Signals (AMON, DMON)

The AMON and DMON signals are outputs from G4. AMON replaces the functionality of the 60x bus's  $\overline{\text{ABB}}$  signal. Likewise, DMON replaces the  $\overline{\text{DBB}}$  signal of the 60x bus.

<sup>&</sup>lt;sup>1</sup>Address Bus Drive mode causes G4 to drive the address bus whenever BG is asserted independent of whether G4 has a bus transaction to run or not.

# 1.1.4 G4 Pin Locations

1

Table 3 summarizes the pin differences between the G4 processor and the MPC750.

| Pin               | MPC750 Signal          | G4 Signal                  |
|-------------------|------------------------|----------------------------|
| D01<br>H06<br>G01 | DBWO<br>DRTRY<br>DBDIS | DTI[0]<br>DTI[1]<br>DTI[2] |
| A03               | TLBISYNC               | EMODE                      |
| B03               | No-connect             | SHD0                       |
| B04               | No-connect             | SHD1                       |
| K09               | No-connect             | DRDY                       |
| B05               | No-connect             | HIT                        |
| K19               | No-connect             | L2A17                      |
| W19               | No-connect             | L2ASPARE                   |
| W01               | No-connect             | BVSEL <sup>1</sup>         |
| A19               | No-connect             | L2VSEL <sup>1</sup>        |
| K11               | No-connect             | СНК <sup>1</sup>           |

Table 3. New G4 Signal Locations

BVSEL, L2VSEL, and CHK signals are either connected to Vdd, Vss, or HRESET, depending on configuration.

# **1.2 Transaction Timing Changes**

The following sections describe the transaction timing changes between the 60x bus mode and the G4 native bus mode.

# 1.2.1 Address Tenure Timing Changes

The 60x bus requires an idle cycle between address tenures. The G4 native bus removes this restriction for address tenures by allowing back-to-back address tenures to be initiated by the same bus master. The master must ensure that it is still the bus master by checking the bus grant ( $\overline{BG}$ ) signal on the cycle in which the end of the first transaction occurs (the cycle when the address acknowledge ( $\overline{AACK}$ ) is sent to the master).

Because the native bus mode of the G4 processor protocol allows new address tenures to begin without a dead cycle in between, a new tenure can begin (via the transfer start ( $\overline{TS}$ ) signal) on the same cycle that another device asserts the address retry ( $\overline{ARTRY}$ ) signal for the tenure that had just ended. If this happens, the system and all bus devices must recognize that the second  $\overline{TS}$  is implicitly retried as well. Both behaviors (back-to-back address tenures and  $\overline{ARTRY}$  assertion) are shown in Figure 1.



- Cycle 1: The master has requested the bus and receives a qualified bus grant
- Cycle 2: The master begins the address tenure by driving  $\overline{TS}$  and the address
- Cycle 3: The system responds with AACK, ending the address tenure. The master receives another (parked) address bus grant.
- Cycle 4: The master begins a new address tenure by driving TS and a new address. Some snooping device, however, asserts ARTRY for the first transaction. Bus grant remains parked to processor 0.
- Cycle 5: The system delays AACK for the second transaction for some reason. BG0 is negated to allow the retrying processor to request the bus. Processor 1 takes advantage of this "window of opportunity" and requests the bus to perform a push of the data that caused the retry.
- Cycle 6: The system asserts AACK to terminate the second address tenure. Since the "window of opportunity" has passed, processor 0 requests the address bus again to retry its transaction. But the arbiter may not rearbitrate and grant the address bus to processor 0 before the push requested in the window of opportunity.
- Cycle 7: Even though this cycle would be the snoop response window for the second address tenure, no processor may assert ARTRY, because that transaction was canceled by the ARTRY. (If AACK had not been delayed, an assertion of ARTRY here could run into contention with the snooper that would be driving ARTRY negated from the snoop response window of the first address tenure.) A bus grant is given to processor 1 to perform its push.
- Cycle 8: Processor 1 begins its snoop push.
- Cycle 9: The snoop push address tenure is acknowledged and terminated
- Cycle 10: The arbiter now grants processor 0 the address bus to retry its transaction.

#### Figure 1. Address Tenure Example

# **1.2.2 Data Tenure Timing Changes**

The 60x bus is also required to have an idle cycle between data tenures. The G4 native bus mode removes this requirement by allowing data streaming from one data tenure to the next. Data streaming allows burst data tenures from a single source to be driven back-to-back without a dead cycle in between. A dead cycle must be placed between two adjacent data tenures in which the data is driven from different agents. For example, if the first data transfer is a processor read from memory and the second data transfer is a processor write to memory, data streaming is not allowed. In addition, data streaming from one data transfer to a second is only allowed if the first transfer is a multiple beat transfer. Streaming from a multiple beat transaction to a single beat transaction is illegal.

Mfax is a trademark of Motorola, Inc.

The PowerPC name, and the PowerPC logotype are trademarks of International Business Machines Corporation used by Motorola under license from International Business Machines Corporation.

Information in this document is provided solely to enable system and software implementers to use PowerPC microprocessors. There are no express or implied copyright licenses granted hereunder to design or fabricate PowerPC integrated circuits or integrated circuits based on the information in this document.

Motorola reserves the right to make changes without further notice to any products herein. Motorola makes no warranty, representation or guarantee regarding the suitability of its products for any particular purpose, nor does Motorola assume any liability arising out of the application or use of any product or circuit, and specifically disclaims any and all liability, including without limitation consequential or incidental damages. "Typical" parameters can and do vary in different applications. All operating parameters, including "Typicals" must be validated for each customer application by customer's technical experts. Motorola does not convey any license under its patent rights nor the rights of others. Motorola products are not designed, intended, or authorized for use as components in systems intended for surgical implant into the body, or other applications intended to support or sustain life, or for any other application in which the failure of the Motorola product could create a situation where personal injury or death may occur. Should Buyer purchase or use Motorola products for any such unintended or unauthorized application, Buyer shall indemnify and hold Motorola and its officers, employees, subsidiaries, affiliates, and distributors harmless against all claims, costs, damages, and expenses, and reasonable attorney fees arising out of, directly or indirectly, any claim of personal injury or death associated with such unintended or unauthorized use, even if such claim alleges that Motorola was negligent regarding the design or manufacture of the part.

Motorola and (A) are registered trademarks of Motorola, Inc. Motorola, Inc. is an Equal Opportunity/Affirmative Action Employer.

#### Motorola Literature Distribution Centers:

USA/EUROPE: Motorola Literature Distribution; P.O. Box 5405; Denver, Colorado 80217; Tel.: 1-800-441-2447 or 1-303-675-2140; World Wide Web Address: http://ldc.nmd.com/

JAPAN: Nippon Motorola Ltd SPD, Strategic Planning Office 4-32-1, Nishi-Gotanda Shinagawa-ku, Tokyo 141, Japan Tel.: 81-3-5487-8488 ASIA/PACIFIC: Motorola Semiconductors H.K. Ltd Silicon Harbour Centre 2, Dai King Street Tai Po Industrial Estate Tai Po, New Territories, Hong Kong

Mfax<sup>™</sup>: RMFAX0@email.sps.mot.com; TOUCHTONE 1-602-244-6609; US & Canada ONLY (800) 774-1848; World Wide Web Address: http://sps.motorola.com/mfax INTERNET: http://motorola.com/sps

Technical Information: Motorola Inc. SPS Customer Support Center 1-800-521-6274; electronic mail address: crc@wmkmail.sps.mot.com. Document Comments: FAX (512) 895-2638, Attn: RISC Applications Engineering. World Wide Web Addresses: http://www.motorola.com/PowerPC/ http://www.motorola.com/netcomm/

