#### 查询SMJ320C80供应商

# 捷多邦,专业PCB打样工厂,24小时加急出货<mark>SMJ320C80</mark> DIGITAL SIGNAL PROCESSOR

SGUS025 - AUGUST 1998

- Single-Chip Parallel Multiple Instruction/Multiple Data (MIMD) Digital Signal Processor (DSP)
- More Than Two Billion RISC-Equivalent **Operations per Second** 
  - Master Processor (MP) - 32-Bit Reduced Instruction Set
    - Computing (RISC) Processor
    - IEEE-754 Floating-Point Capability COM
    - 4K-Byte Instruction Cache
    - 4K-Byte Data Cache
    - Four Parallel Processors (PP)
    - 32-Bit Advanced DSPs
    - 64-Bit Opcode Provides Many Parallel **Operations per Cycle**
    - 2K-Byte Instruction Cache and 8K-Byte Data RAM per PP
- Transfer Controller (TC)
  - 64-Bit Data Transfers
  - Up to 400 Megabytes per Second (MBps) Transfer Rate
  - 32-Bit Addressing
  - Direct DRAM / VRAM Interface With **Dynamic Bus Sizing**
  - Intelligent Queuing and Cycle **Prioritization**
- Video Controller (VC)
  - Provides Video Timing and Video Random-Access Memory (VRAM) Control
  - Dual-Frame Timers for Two Simultaneous Image-Capture and /or Display Systems
- **Big- or Little-Endian Operation**
- 50K-Byte On-Chip RAM
- **4G-Byte Address Space** 0
- 20-ns Cycle Time
- 3.3-V Operation
- IEEE Standard 1149.1<sup>†</sup> Test Access Port (JTAG)
- Military Operating Temperature Range – 55°C to 125°C WWW.DZSC.COM



#### **HFH PACKAGE** (TOP VIEW)





Please be aware that an important notice concerning availability, standard warranty, and use in critical applications of Texas Instruments semiconductor products and disclaimers thereto appears at the end of this data sheet.

FEFStandard 1149.1–1990, IEEE Standard Test Access Port and Boundary-Scan Architecture

RODUCTION DATA information is current as of publication date. Foducts conform to specifications per the terms of Texas Instruments standard warranty. Production processing does not necessarily include testing of all parameters.



Copyright © 1998, Texas Instruments Incorporated On products compliant to MIL-PRF-38535, all parameters are tested unless otherwise noted. On all other products, production processing does not necessarily include testing of all parameters.

SGUS025 – AUGUST 1998

|                                              | Table of C | Contents                                                  |     |
|----------------------------------------------|------------|-----------------------------------------------------------|-----|
| description                                  | 2          | SDRAM-type cycles                                         | 105 |
| GF Pin Assignments – Numerical Listing       | 3          | special register set cycles                               | 116 |
| GF Pin Assignments – Alphabetical Listing    | 5          | device reset                                              | 127 |
| HFH Pin Assignments – Numerical Listing      | 7          | absolute maximum ratings over specified temperature       |     |
| HFH Pin Assignments – Alphabetical Listing   | 9          | ranges                                                    | 128 |
| Terminal Functions                           | 13         | recommended operating conditions                          | 128 |
| architecture                                 | 14         | electrical characteristics over recommended ranges        |     |
| master processor (MP) architecture           | 17         | of supply voltage and operating case temperature          | 128 |
| MP control registers                         | 21         | signal transition levels                                  | 129 |
| MP parameter RAM                             | 28         | timing parameter symbology                                | 130 |
| MP interrupt vectors                         | 29         | general notes on timing parameters                        | 130 |
| MP opcode formats                            | 30         | CLKIN timing requirements                                 | 131 |
| MP opcode summary                            | 30         | local-bus switching characteristics over full operating   |     |
| PP architecture                              | 35         | range: CLKOUT                                             | 131 |
| PP registers                                 | 36         | device reset timing requirements                          | 132 |
| PP data-unit registers                       | 37         | local bus timing requirements: cycle configuration inputs | 133 |
| PP address-unit registers                    | 37         | local bus timing: cycle completion inputs                 | 134 |
| PP program flow control (PFC) unit registers | 38         | general output signal characteristics over                |     |
| PP cache architecture                        | 40         | operating conditions                                      | 137 |
| PP parameter RAM                             | 41         | data input timing                                         | 139 |
| PP-interrupt vectors                         | 41         | local bus timing: 2-cycle/column CAS timing               | 140 |
| PP data unit architecture                    | 42         | external interrupt timing                                 | 141 |
| PP multiplier                                | 43         | XPT input timing                                          | 142 |
| PP program-flow-control unit architecture    | 44         | host-interface timing                                     | 143 |
| PP address-unit architecture                 | 46         | video interface timing: SCLK timing                       | 144 |
| PP instruction set                           | 47         | video interface timing: FCLK input and video outputs      | 145 |
| PP opcode formats                            | 50         | video interface timing: external sync inputs              | 146 |
| EALU operations                              | 59         | emulator interface connection                             | 147 |
| TC architecture                              | 61         | MECHANICAL DATA                                           | 150 |
| local memory interface                       | 65         | MECHANICAL DATA                                           | 151 |
| external memory timing examples              | 71         |                                                           |     |

#### description

The SMJ320C80 is a single-chip, MIMD parallel processor capable of performing over two billion operations per second. It consists of a 32-bit RISC master processor with a 100-MFLOPS (million floating-point operations per second) IEEE floating-point unit, four 32-bit parallel processing digital signal processors (DSPs), a transfer controller with up to 400-MBps off-chip transfer rate, and a video controller. All the processors are coupled tightly through an on-chip crossbar that provides shared access to on-chip RAM. This performance and programmability make the 'C80 ideally suited for video, imaging, and high-speed telecommunications applications.



SGUS025 - AUGUST 1998

|        | BIN             | · · · · · | DIN             | 1      | DIN             | -       |                 |
|--------|-----------------|-----------|-----------------|--------|-----------------|---------|-----------------|
| NUMBER | PIN<br>NAME     | NUMBER    | PIN<br>NAME     | NUMBER | PIN<br>NAME     | NUMBER  | NAME            |
| A5     | CT1             | C21       | V <sub>DD</sub> | E33    | HSYNCO          | L5      | VSS             |
| A7     | V <sub>DD</sub> | C23       | <u></u>         | E35    | ТСК             | <br>L31 | VSS             |
| A9     | HACK            | C25       | DBEN            | F2     | V <sub>DD</sub> | L33     | TRST            |
| A11    | V <sub>SS</sub> | C27       | V <sub>SS</sub> | F4     | V <sub>SS</sub> | L35     | XPT1            |
| A13    | CAS/DQM7        | C29       | CAREA0          | F8     | V_DD            | M2      | V <sub>DD</sub> |
| A15    | CAS/DQM5        | C31       | CBLNK0 / VBLNK0 | F10    | V <sub>SS</sub> | M4      | VSS             |
| A17    | V <sub>DD</sub> | D2        | RETRY           | F12    | V <sub>DD</sub> | M32     | VSS             |
| A19    | V <sub>SS</sub> | D4        | VDD             | F14    | PS0             | M34     | V <sub>DD</sub> |
| A21    | RAS             | D6        | V <sub>SS</sub> | F16    | VSS             | N1      | VDD             |
| A23    | DSF             | D8        | AS0             | F18    | CT2             | N3      | A8              |
| A25    | V <sub>SS</sub> | D10       | UTIME           | F20    | V <sub>DD</sub> | N5      | VSS             |
| A27    | SCLK1           | D12       | V <sub>SS</sub> | F22    | V <sub>SS</sub> | N31     | VSS             |
| A29    | V <sub>DD</sub> | D14       | RESET           | F24    | V <sub>DD</sub> | N33     | TMS             |
| A31    | EINT1           | D16       | REQ0            | F26    | V <sub>SS</sub> | N35     | VDD             |
| B2     | NC              | D18       | V <sub>SS</sub> | F28    | V <sub>DD</sub> | P2      | A4              |
| B4     | BS1             | D20       | CAS/DQM0        | F32    | V <sub>SS</sub> | P4      | A9              |
| B6     | V <sub>DD</sub> | D22       | FCLK1           | F34    | V <sub>DD</sub> | P32     | TDO             |
| B8     | PS1             | D24       | V <sub>SS</sub> | G1     | V <sub>DD</sub> | P34     | XPT0            |
| B10    | REQ1            | D26       | CAREA1          | G3     | A2              | R1      | VSS             |
| B12    | V <sub>DD</sub> | D28       | SCLK0           | G5     | A1              | R3      | V <sub>DD</sub> |
| B14    | CAS/DQM6        | D30       | VSS             | G31    | EINT2           | R5      | V <sub>DD</sub> |
| B16    | CAS/DQM3        | D32       | V <sub>DD</sub> | G33    | CBLNK1 / VBLNK1 | R31     | V <sub>DD</sub> |
| B18    | V <sub>DD</sub> | D34       | VSYNC0          | G35    | V <sub>DD</sub> | R33     | V <sub>DD</sub> |
| B20    | CAS/DQM1        | E1        | AS1             | H2     | STATUS0         | R35     | V <sub>SS</sub> |
| B22    | TRG/CAS         | E3        | FAULT           | H4     | A3              | T2      | A5              |
| B24    | V <sub>DD</sub> | E5        | VSS             | H32    | CSYNC1 / HBLNK1 | T4      | A13             |
| B26    | DDIN            | E7        | STATUS2         | H34    | TDI             | T32     | D62             |
| B28    | FCLK0           | E9        | READY           | J1     | STATUS1         | T34     | EMU0            |
| B30    | V <sub>DD</sub> | E11       | BS0             | J3     | V <sub>SS</sub> | U1      | V <sub>DD</sub> |
| B32    | CSYNC0 / HBLNK0 | E13       | V <sub>SS</sub> | J5     | V <sub>DD</sub> | U3      | A10             |
| C3     | VSS             | E15       | HREQ            | J31    | V <sub>DD</sub> | U5      | PS3             |
| C5     | STATUS3         | E17       | CAS/DQM4        | J33    | VSS             | U31     | NC              |
| C7     | AS2             | E19       | RL              | J35    | EMU1            | U33     | D61             |
| C9     | VSS             | E21       | STATUS5         | K2     | STATUS4         | U35     | V <sub>DD</sub> |
| C11    | CT0             | E23       | V <sub>SS</sub> | K4     | A6              | V2      | V <sub>DD</sub> |
| C13    | PS2             | E25       | CLKOUT          | K32    | VSYNC1          | V4      | VSS             |
| C15    | V <sub>DD</sub> | E27       | LINT4           | K34    | HSYNC1          | V32     | V <sub>SS</sub> |
| C17    | CLKIN           | E29       | EINT3           | L1     | A0              | V34     | V <sub>DD</sub> |
| C19    | CAS/DQM2        | E31       | VSS             | L3     | A7              | W1      | A11             |

### **GF** Pin Assignments – Numerical Listing



SGUS025 – AUGUST 1998

| GF Pin Assignments – Numerical Listing (Continued) |                 |        |                 |        |                 |        |                 |  |
|----------------------------------------------------|-----------------|--------|-----------------|--------|-----------------|--------|-----------------|--|
| PI                                                 |                 | PI     |                 | PI     |                 | PI     |                 |  |
| NUMBER                                             | NAME            | NUMBER | NAME            | NUMBER | NAME            | NUMBER | NAME            |  |
| W3                                                 | A18             | AG1    | A16             | AL17   | D20             | AN29   | D35             |  |
| W5                                                 | V <sub>SS</sub> | AG3    | V <sub>SS</sub> | AL19   | D21             | AN31   | D45             |  |
| W31                                                | V <sub>SS</sub> | AG5    | V <sub>DD</sub> | AL21   | D24             | AN33   | V <sub>DD</sub> |  |
| W33                                                | D59             | AG31   | V <sub>DD</sub> | AL23   | VSS             | AP4    | A27             |  |
| W35                                                | D63             | AG33   | VSS             | AL25   | D29             | AP6    | VDD             |  |
| Y2                                                 | A12             | AG35   | D57             | AL27   | D32             | AP8    | D5              |  |
| Y4                                                 | A19             | AH2    | A20             | AL29   | D38             | AP10   | D8              |  |
| Y32                                                | XPT2            | AH4    | A30             | AL31   | VSS             | AP12   | V <sub>DD</sub> |  |
| Y34                                                | D56             | AH32   | D44             | AL33   | D48             | AP14   | D13             |  |
| AA1                                                | V <sub>SS</sub> | AH34   | D54             | AL35   | D53             | AP16   | D17             |  |
| AA3                                                | V <sub>DD</sub> | AJ1    | V <sub>DD</sub> | AM2    | A24             | AP18   | V <sub>DD</sub> |  |
| AA5                                                | V <sub>DD</sub> | AJ3    | A31             | AM4    | V <sub>DD</sub> | AP20   | D26             |  |
| AA31                                               | V <sub>DD</sub> | AJ5    | V <sub>SS</sub> | AM6    | VSS             | AP22   | D34             |  |
| AA33                                               | V <sub>DD</sub> | AJ31   | V <sub>SS</sub> | AM8    | D2              | AP24   | VDD             |  |
| AA35                                               | VSS             | AJ33   | D42             | AM10   | D6              | AP26   | D39             |  |
| AB2                                                | A14             | AJ35   | V <sub>DD</sub> | AM12   | V <sub>SS</sub> | AP28   | D41             |  |
| AB4                                                | A21             | AK2    | V <sub>DD</sub> | AM14   | D14             | AP30   | V <sub>DD</sub> |  |
| AB32                                               | D55             | AK4    | V <sub>SS</sub> | AM16   | D19             | AP32   | D47             |  |
| AB34                                               | D60             | AK8    | V <sub>DD</sub> | AM18   | VSS             | AR5    | D0              |  |
| AC1                                                | V <sub>DD</sub> | AK10   | VSS             | AM20   | D23             | AR7    | V <sub>DD</sub> |  |
| AC3                                                | A22             | AK12   | V <sub>DD</sub> | AM22   | D25             | AR9    | D7              |  |
| AC5                                                | VSS             | AK14   | VSS             | AM24   | VSS             | AR11   | VSS             |  |
| AC31                                               | V <sub>SS</sub> | AK16   | V <sub>DD</sub> | AM26   | D31             | AR13   | D11             |  |
| AC33                                               | D52             | AK18   | NC              | AM28   | D33             | AR15   | D15             |  |
| AC35                                               | V <sub>DD</sub> | AK20   | VSS             | AM30   | VSS             | AR17   | VSS             |  |
| AD2                                                | V <sub>DD</sub> | AK22   | D27             | AM32   | V <sub>DD</sub> | AR19   | V <sub>DD</sub> |  |
| AD4                                                | VSS             | AK24   | V <sub>DD</sub> | AM34   | D50             | AR21   | D30             |  |
| AD32                                               | VSS             | AK26   | VSS             | AN5    | A29             | AR23   | D36             |  |
| AD34                                               | V <sub>DD</sub> | AK28   | V <sub>DD</sub> | AN7    | D1              | AR25   | V <sub>SS</sub> |  |
| AE1                                                | A15             | AK32   | V <sub>SS</sub> | AN9    | V <sub>SS</sub> | AR27   | D40             |  |
| AE3                                                | A26             | AK34   | V <sub>DD</sub> | AN11   | D9              | AR29   | V <sub>DD</sub> |  |
| AE5                                                | VSS             | AL1    | A23             | AN13   | D12             | AR31   | D43             |  |
| AE31                                               | V <sub>SS</sub> | AL3    | A25             | AN15   | V <sub>DD</sub> |        |                 |  |
| AE33                                               | D51             | AL5    | V <sub>SS</sub> | AN17   | D18             |        |                 |  |
| AE35                                               | D58             | AL7    | D3              | AN19   | D22             |        |                 |  |
| AF2                                                | A17             | AL9    | D4              | AN21   | V <sub>DD</sub> |        |                 |  |
| AF4                                                | A28             | AL11   | D10             | AN23   | D28             |        |                 |  |
| AF32                                               | D46             | AL13   | V <sub>SS</sub> | AN25   | D37             |        |                 |  |
| AF34                                               | D49             | AL15   | D16             | AN27   | Vss             |        |                 |  |



SGUS025 - AUGUST 1998

|          | PIN    | PIN           |        |      | 'IN    | PI      | N      |
|----------|--------|---------------|--------|------|--------|---------|--------|
| NAME     | NUMBER | NAME          | NUMBER | NAME | NUMBER | NAME    | NUMBER |
| A0       | L1     | CAS/DQM1      | B20    | D24  | AL21   | DBEN    | C25    |
| A1       | G5     | CAS/DQM2      | C19    | D25  | AM22   | DDIN    | B26    |
| A2       | G3     | CAS/DQM3      | B16    | D26  | AP20   | DSF     | A23    |
| A3       | H4     | CAS/DQM4      | E17    | D27  | AK22   | EINT1   | A31    |
| A4       | P2     | CAS/DQM5      | A15    | D28  | AN23   | EINT2   | G31    |
| A5       | T2     | CAS/DQM6      | B14    | D29  | AL25   | EINT3   | E29    |
| A6       | K4     | CAS/DQM7      | A13    | D30  | AR21   | EMU0    | T34    |
| A7       | L3     | CBLNK0/VBLNK0 | C31    | D31  | AM26   | EMU1    | J35    |
| A8       | N3     | CBLNK1/VBLNK1 | G33    | D32  | AL27   | FAULT   | E3     |
| A9       | P4     | CLKIN         | C17    | D33  | AM28   | FCLK0   | B28    |
| A10      | U3     | CLKOUT        | E25    | D34  | AP22   | FCLK1   | D22    |
| A11      | W1     | CSYNC0/HBLNK0 | B32    | D35  | AN29   | HACK    | A9     |
| A12      | Y2     | CSYNC1/HBLNK1 | H32    | D36  | AR23   | HREQ    | E15    |
| A13      | T4     | CT0           | C11    | D37  | AN25   | HSYNC0  | E33    |
| A14      | AB2    | CT1           | A5     | D38  | AL29   | HSYNC1  | K34    |
| A15      | AE1    | CT2           | F18    | D39  | AP26   | LINT4   | E27    |
| A16      | AG1    | D0            | AR5    | D40  | AR27   | NC      | B2     |
| A17      | AF2    | D1            | AN7    | D41  | AP28   | NC      | U31    |
| A18      | W3     | D2            | AM8    | D42  | AJ33   | NC      | AK18   |
| A19      | Y4     | D3            | AL7    | D43  | AR31   | PS0     | F14    |
| A20      | AH2    | D4            | AL9    | D44  | AH32   | PS1     | B8     |
| A21      | AB4    | D5            | AP8    | D45  | AN31   | PS2     | C13    |
| A22      | AC3    | D6            | AM10   | D46  | AF32   | PS3     | U5     |
| A23      | AL1    | D7            | AR9    | D47  | AP32   | RAS     | A21    |
| A24      | AM2    | D8            | AP10   | D48  | AL33   | READY   | E9     |
| A25      | AL3    | D9            | AN11   | D49  | AF34   | REQ0    | D16    |
| A26      | AE3    | D10           | AL11   | D50  | AM34   | REQ1    | B10    |
| A27      | AP4    | D11           | AR13   | D51  | AE33   | RESET   | D14    |
| A28      | AF4    | D12           | AN13   | D52  | AC33   | RETRY   | D2     |
| A29      | AN5    | D13           | AP14   | D53  | AL35   | RL      | E19    |
| A30      | AH4    | D14           | AM14   | D54  | AH34   | SCLK0   | D28    |
| A31      | AJ3    | D15           | AR15   | D55  | AB32   | SCLK1   | A27    |
| AS0      | D8     | D16           | AL15   | D56  | Y34    | STATUS0 | H2     |
| AS1      | E1     | D17           | AP16   | D57  | AG35   | STATUS1 | J1     |
| AS2      | C7     | D18           | AN17   | D58  | AE35   | STATUS2 | E7     |
| BS0      | E11    | D19           | AM16   | D59  | W33    | STATUS3 | C5     |
| BS1      | B4     | D20           | AL17   | D60  | AB34   | STATUS4 | K2     |
| CAREA0   | C29    | D21           | AL19   | D61  | U33    |         |        |
| CAREA1   | D26    | D22           | AN19   | D62  | T32    |         |        |
| CAS/DQM0 | D20    | D23           | AM20   | D63  | W35    |         |        |

### GF Pin Assignments – Alphabetical Listing



SGUS025 – AUGUST 1998

| Р               | IN     | PIN PIN         |        |                 |        | Р               | IN     |
|-----------------|--------|-----------------|--------|-----------------|--------|-----------------|--------|
| NAME            | NUMBER | NAME            | NUMBER | NAME            | NUMBER | NAME            | NUMBER |
| STATUS5         | E21    | V <sub>DD</sub> | R31    | V <sub>DD</sub> | AR29   | V <sub>SS</sub> | AA35   |
| TCK             | E35    | V <sub>DD</sub> | R33    | VSS             | A11    | V <sub>SS</sub> | AC5    |
| TDI             | H34    | V <sub>DD</sub> | U1     | VSS             | A19    | V <sub>SS</sub> | AC31   |
| TDO             | P32    | V <sub>DD</sub> | U35    | V <sub>SS</sub> | A25    | V <sub>SS</sub> | AD4    |
| TMS             | N33    | V <sub>DD</sub> | V2     | VSS             | C3     | VSS             | AD32   |
| TRG/CAS         | B22    | V <sub>DD</sub> | V34    | VSS             | C9     | VSS             | AE5    |
| TRST            | L33    | V <sub>DD</sub> | AA3    | VSS             | C27    | VSS             | AE31   |
| UTIME           | D10    | V <sub>DD</sub> | AA5    | VSS             | D6     | VSS             | AG3    |
| V <sub>DD</sub> | A7     | V <sub>DD</sub> | AA31   | VSS             | D12    | VSS             | AG33   |
| V <sub>DD</sub> | A17    | V <sub>DD</sub> | AA33   | V <sub>SS</sub> | D18    | V <sub>SS</sub> | AJ5    |
| V <sub>DD</sub> | A29    | V <sub>DD</sub> | AC1    | VSS             | D24    | V <sub>SS</sub> | AJ31   |
| V <sub>DD</sub> | B6     | V <sub>DD</sub> | AC35   | VSS             | D30    | VSS             | AK4    |
| V <sub>DD</sub> | B12    | V <sub>DD</sub> | AD2    | VSS             | E5     | V <sub>SS</sub> | AK10   |
| VDD             | B18    | V <sub>DD</sub> | AD34   | VSS             | E13    | V <sub>SS</sub> | AK14   |
| VDD             | B24    | V <sub>DD</sub> | AG5    | VSS             | E23    | VSS             | AK20   |
| V <sub>DD</sub> | B30    | V <sub>DD</sub> | AG31   | VSS             | E31    | V <sub>SS</sub> | AK26   |
| V <sub>DD</sub> | C15    | V <sub>DD</sub> | AJ1    | VSS             | F4     | V <sub>SS</sub> | AK32   |
| V <sub>DD</sub> | C21    | V <sub>DD</sub> | AJ35   | VSS             | F10    | V <sub>SS</sub> | AL5    |
| VDD             | D4     | V <sub>DD</sub> | AK2    | VSS             | F16    | VSS             | AL13   |
| VDD             | D32    | V <sub>DD</sub> | AK8    | VSS             | F22    | V <sub>SS</sub> | AL23   |
| V <sub>DD</sub> | F2     | V <sub>DD</sub> | AK12   | VSS             | F26    | V <sub>SS</sub> | AL31   |
| VDD             | F8     | V <sub>DD</sub> | AK16   | VSS             | F32    | VSS             | AM6    |
| V <sub>DD</sub> | F12    | V <sub>DD</sub> | AK24   | VSS             | J3     | V <sub>SS</sub> | AM12   |
| V <sub>DD</sub> | F20    | V <sub>DD</sub> | AK28   | VSS             | J33    | V <sub>SS</sub> | AM18   |
| V <sub>DD</sub> | F24    | V <sub>DD</sub> | AK34   | VSS             | L5     | VSS             | AM24   |
| VDD             | F28    | V <sub>DD</sub> | AM4    | VSS             | L31    | V <sub>SS</sub> | AM30   |
| V <sub>DD</sub> | F34    | V <sub>DD</sub> | AM32   | VSS             | M4     | VSS             | AN9    |
| V <sub>DD</sub> | G1     | V <sub>DD</sub> | AN15   | VSS             | M32    | VSS             | AN27   |
| V <sub>DD</sub> | G35    | V <sub>DD</sub> | AN21   | V <sub>SS</sub> | N5     | V <sub>SS</sub> | AR11   |
| V <sub>DD</sub> | J5     | V <sub>DD</sub> | AN33   | V <sub>SS</sub> | N31    | V <sub>SS</sub> | AR17   |
| V <sub>DD</sub> | J31    | V <sub>DD</sub> | AP6    | VSS             | R1     | V <sub>SS</sub> | AR25   |
| V <sub>DD</sub> | M2     | V <sub>DD</sub> | AP12   | VSS             | R35    | VSYNC0          | D34    |
| V <sub>DD</sub> | M34    | V <sub>DD</sub> | AP18   | VSS             | V4     | VSYNC1          | K32    |
| V <sub>DD</sub> | N1     | V <sub>DD</sub> | AP24   | VSS             | V32    | W               | C23    |
| V <sub>DD</sub> | N35    | V <sub>DD</sub> | AP30   | VSS             | W5     | XPT0            | P34    |
| V <sub>DD</sub> | R3     | V <sub>DD</sub> | AR7    | VSS             | W31    | XPT1            | L35    |
| V <sub>DD</sub> | R5     | V <sub>DD</sub> | AR19   | V <sub>SS</sub> | AA1    | XPT2            | Y32    |

#### 10 ••



SGUS025 - AUGUST 1998

|        | BIN             |        | DIN             | 1      | DIN             |        |                 |
|--------|-----------------|--------|-----------------|--------|-----------------|--------|-----------------|
| NUMBER | PIN<br>NAME     | NUMBER | PIN<br>NAME     | NUMBER | PIN<br>NAME     | NUMBER | PIN<br>NAME     |
| 1      | STATUS3         | 41     | CAS/DQM6        | 81     | LINT4           | 121    | VDD             |
| 2      | VSS             | 42     | VSS             | 82     | EINT3           | 122    | D59             |
| 3      | STATUS2         | 43     | CAS/DQM5        | 83     | EINT2           | 123    | VSS             |
| 4      | STATUS1         | 44     | V <sub>DD</sub> | 84     | EINT1           | 124    | D58             |
| 5      | V <sub>DD</sub> | 45     | CAS/DQM4        | 85     | CBLNK1/VBLNK1   | 125    | V <sub>DD</sub> |
| 6      | STATUS0         | 46     | CAS/DQM3        | 86     | CBLNK0/VBLNK0   | 126    | D57             |
| 7      | AS2             | 47     | CT2             | 87     | VSS             | 127    | XPT2            |
| 8      | AS1             | 48     | CAS/DQM2        | 88     | VSS             | 128    | VSS             |
| 9      | AS0             | 49     | VSS             | 89     | CSYNC1/HBLNK1   | 129    | D56             |
| 10     | FAULT           | 50     | CAS/DQM1        | 90     | V <sub>DD</sub> | 130    | V <sub>DD</sub> |
| 11     | READY           | 51     | V <sub>DD</sub> | 91     | V <sub>DD</sub> | 131    | V <sub>DD</sub> |
| 12     | RETRY           | 52     | CAS/DQM0        | 92     | CSYNC0/HBLNK0   | 132    | D55             |
| 13     | UTIME           | 53     | RL              | 93     | VSYNC1          | 133    | VSS             |
| 14     | BS1             | 54     | RAS             | 94     | VSYNC0          | 134    | D54             |
| 15     | BS0             | 55     | VSS             | 95     | VSS             | 135    | V <sub>DD</sub> |
| 16     | CT1             | 56     | V <sub>SS</sub> | 96     | V <sub>SS</sub> | 136    | D53             |
| 17     | CT0             | 57     | V <sub>SS</sub> | 97     | HSYNC1          | 137    | V <sub>SS</sub> |
| 18     | PS2             | 58     | TRG/CAS         | 98     | V <sub>DD</sub> | 138    | V <sub>SS</sub> |
| 19     | PS1             | 59     | V <sub>DD</sub> | 99     | V <sub>DD</sub> | 139    | D52             |
| 20     | PS0             | 60     | FCLK1           | 100    | V <sub>DD</sub> | 140    | V <sub>DD</sub> |
| 21     | V <sub>DD</sub> | 61     | V <sub>DD</sub> | 101    | HSYNC0          | 141    | D51             |
| 22     | RESET           | 62     | V <sub>DD</sub> | 102    | TRST            | 142    | D50             |
| 23     | V <sub>SS</sub> | 63     | W               | 103    | TCK             | 143    | D49             |
| 24     | HREQ            | 64     | STATUS5         | 104    | TMS             | 144    | V <sub>SS</sub> |
| 25     | HACK            | 65     | V <sub>DD</sub> | 105    | TDI             | 145    | VSS             |
| 26     | VSS             | 66     | DSF             | 106    | TDO             | 146    | D48             |
| 27     | VSS             | 67     | V <sub>SS</sub> | 107    | EMU1            | 147    | V <sub>DD</sub> |
| 28     | REQ1            | 68     | DBEN            | 108    | XPT0            | 148    | V <sub>DD</sub> |
| 29     | REQ0            | 69     | V <sub>DD</sub> | 109    | XPT1            | 149    | V <sub>DD</sub> |
| 30     | V <sub>DD</sub> | 70     | DDIN            | 110    | V <sub>SS</sub> | 150    | D47             |
| 31     | V <sub>DD</sub> | 71     | CLKOUT          | 111    | VSS             | 151    | D46             |
| 32     | V <sub>SS</sub> | 72     | CAREA1          | 112    | EMU0            | 152    | D45             |
| 33     | V <sub>DD</sub> | 73     | V <sub>SS</sub> | 113    | V <sub>DD</sub> | 153    | VSS             |
| 34     | V <sub>SS</sub> | 74     | SCLK1           | 114    | D63             | 154    | VSS             |
| 35     | V <sub>SS</sub> | 75     | V <sub>DD</sub> | 115    | D62             | 155    | D44             |
| 36     | CLKIN           | 76     | FCLK0           | 116    | VSS             | 156    | V <sub>DD</sub> |
| 37     | V <sub>SS</sub> | 77     | V <sub>SS</sub> | 117    | D61             | 157    | V <sub>DD</sub> |
| 38     | CAS/DQM7        | 78     | SCLK0           | 118    | VSS             | 158    | V <sub>DD</sub> |
| 39     | V <sub>DD</sub> | 79     | V <sub>DD</sub> | 119    | D60             | 159    | D43             |
| 40     | V <sub>DD</sub> | 80     | CAREA0          | 120    | V <sub>DD</sub> | 160    | D42             |

### HFH Pin Assignments – Numerical Listing



SGUS025 – AUGUST 1998

|        | PIN             |        |                 | PIN PIN |                 |        |                 |
|--------|-----------------|--------|-----------------|---------|-----------------|--------|-----------------|
| NUMBER | NAME            | NUMBER | NAME            | NUMBER  | NAME            | NUMBER | NAME            |
| 161    | D41             | 201    | D20             | 241     | D0              | 281    | V <sub>DD</sub> |
| 162    | VSS             | 202    | V <sub>DD</sub> | 242     | V <sub>DD</sub> | 282    | VDD             |
| 163    | VSS             | 203    | V <sub>DD</sub> | 243     | V <sub>DD</sub> | 283    | V <sub>DD</sub> |
| 164    | D40             | 204    | D19             | 244     | A31             | 284    | A15             |
| 165    | V <sub>DD</sub> | 205    | V <sub>DD</sub> | 245     | VSS             | 285    | PS3             |
| 166    | D39             | 206    | D18             | 246     | A30             | 286    | A14             |
| 167    | D38             | 207    | VSS             | 247     | A29             | 287    | VSS             |
| 168    | D37             | 208    | D17             | 248     | VSS             | 288    | V <sub>DD</sub> |
| 169    | VSS             | 209    | VSS             | 249     | VSS             | 289    | A13             |
| 170    | D36             | 210    | V <sub>SS</sub> | 250     | A28             | 290    | V <sub>SS</sub> |
| 171    | VSS             | 211    | D16             | 251     | V <sub>DD</sub> | 291    | V <sub>SS</sub> |
| 172    | V <sub>DD</sub> | 212    | V <sub>DD</sub> | 252     | V <sub>DD</sub> | 292    | A12             |
| 173    | D35             | 213    | D15             | 253     | V <sub>DD</sub> | 293    | V <sub>DD</sub> |
| 174    | D34             | 214    | D14             | 254     | A27             | 294    | A11             |
| 175    | D33             | 215    | D13             | 255     | A26             | 295    | VSS             |
| 176    | V <sub>SS</sub> | 216    | V <sub>SS</sub> | 256     | A25             | 296    | A10             |
| 177    | D32             | 217    | V <sub>SS</sub> | 257     | V <sub>SS</sub> | 297    | V <sub>DD</sub> |
| 178    | V <sub>DD</sub> | 218    | D12             | 258     | V <sub>SS</sub> | 298    | A9              |
| 179    | V <sub>DD</sub> | 219    | V <sub>DD</sub> | 259     | VSS             | 299    | VSS             |
| 180    | D31             | 220    | V <sub>DD</sub> | 260     | A24             | 300    | A8              |
| 181    | D30             | 221    | V <sub>DD</sub> | 261     | V <sub>DD</sub> | 301    | V <sub>DD</sub> |
| 182    | D29             | 222    | D11             | 262     | V <sub>DD</sub> | 302    | A7              |
| 183    | V <sub>SS</sub> | 223    | D10             | 263     | V <sub>DD</sub> | 303    | A6              |
| 184    | V <sub>SS</sub> | 224    | D9              | 264     | A23             | 304    | V <sub>SS</sub> |
| 185    | VSS             | 225    | VSS             | 265     | A22             | 305    | VSS             |
| 186    | D28             | 226    | D8              | 266     | V <sub>DD</sub> | 306    | A5              |
| 187    | V <sub>DD</sub> | 227    | V <sub>DD</sub> | 267     | A21             | 307    | VSS             |
| 188    | V <sub>DD</sub> | 228    | V <sub>DD</sub> | 268     | VSS             | 308    | A4              |
| 189    | D27             | 229    | D7              | 269     | VSS             | 309    | V <sub>DD</sub> |
| 190    | D26             | 230    | D6              | 270     | A20             | 310    | V <sub>DD</sub> |
| 191    | D25             | 231    | D5              | 271     | V <sub>DD</sub> | 311    | V <sub>DD</sub> |
| 192    | VSS             | 232    | VSS             | 272     | V <sub>DD</sub> | 312    | A3              |
| 193    | D24             | 233    | VSS             | 273     | A19             | 313    | V <sub>DD</sub> |
| 194    | V <sub>DD</sub> | 234    | D4              | 274     | VSS             | 314    | A2              |
| 195    | V <sub>DD</sub> | 235    | V <sub>DD</sub> | 275     | A18             | 315    | VSS             |
| 196    | D23             | 236    | D3              | 276     | A17             | 316    | A1              |
| 197    | D22             | 237    | D2              | 277     | V <sub>SS</sub> | 317    | A0              |
| 198    | VSS             | 238    | VSS             | 278     | VSS             | 318    | V <sub>DD</sub> |
| 199    | D21             | 239    | D1              | 279     | Vss             | 319    | STATUS4         |
| 200    | VSS             | 240    | VSS             | 280     | A16             | 320    | VSS             |





SGUS025 - AUGUST 1998

| HFH Pin Assignments – Alphabetical Listing |        |               |        |      |        |         |        |  |
|--------------------------------------------|--------|---------------|--------|------|--------|---------|--------|--|
| PIN                                        |        | PIN           |        | PIN  |        | PIN     |        |  |
| NAME                                       | NUMBER | NAME          | NUMBER | NAME | NUMBER | NAME    | NUMBER |  |
| A0                                         | 317    | CAS/DQM1      | 50     | D30  | 181    | DBEN    | 68     |  |
| A1                                         | 316    | CAS/DQM2      | 48     | D31  | 180    | DDIN    | 70     |  |
| A10                                        | 296    | CAS/DQM3      | 46     | D32  | 177    | DSF     | 66     |  |
| A11                                        | 294    | CAS/DQM4      | 45     | D33  | 175    | EINT1   | 84     |  |
| A12                                        | 292    | CAS/DQM5      | 43     | D34  | 174    | EINT2   | 83     |  |
| A13                                        | 289    | CAS/DQM6      | 41     | D35  | 173    | EINT3   | 82     |  |
| A14                                        | 286    | CAS/DQM7      | 38     | D36  | 170    | EMU0    | 112    |  |
| A15                                        | 284    | CBLNK0/VBLNK0 | 86     | D37  | 168    | EMU1    | 107    |  |
| A16                                        | 280    | CBLNK1/VBLNK1 | 85     | D38  | 167    | FAULT   | 10     |  |
| A17                                        | 276    | CLKIN         | 36     | D39  | 166    | FCLK0   | 76     |  |
| A18                                        | 275    | CLKOUT        | 71     | D4   | 234    | FCLK1   | 60     |  |
| A19                                        | 273    | CSYNC0/HBLNK0 | 92     | D40  | 164    | HACK    | 25     |  |
| A2                                         | 314    | CSYNC1/HBLNK1 | 89     | D41  | 161    | HREQ    | 24     |  |
| A20                                        | 270    | CT0           | 17     | D42  | 160    | HSYNC0  | 101    |  |
| A21                                        | 267    | CT1           | 16     | D43  | 159    | HSYNC1  | 97     |  |
| A22                                        | 265    | CT2           | 47     | D44  | 155    | LINT4   | 81     |  |
| A23                                        | 264    | D0            | 241    | D45  | 152    | PS0     | 20     |  |
| A24                                        | 260    | D1            | 239    | D46  | 151    | PS1     | 19     |  |
| A25                                        | 256    | D10           | 223    | D47  | 150    | PS2     | 18     |  |
| A26                                        | 255    | D11           | 222    | D48  | 146    | PS3     | 285    |  |
| A27                                        | 254    | D12           | 218    | D49  | 143    | RAS     | 54     |  |
| A28                                        | 250    | D13           | 215    | D5   | 231    | READY   | 11     |  |
| A29                                        | 247    | D14           | 214    | D50  | 142    | REQ0    | 29     |  |
| A3                                         | 312    | D15           | 213    | D51  | 141    | REQ1    | 28     |  |
| A30                                        | 246    | D16           | 211    | D52  | 139    | RESET   | 22     |  |
| A31                                        | 244    | D17           | 208    | D53  | 136    | RETRY   | 12     |  |
| A4                                         | 308    | D18           | 206    | D54  | 134    | RL      | 53     |  |
| A5                                         | 306    | D19           | 204    | D55  | 132    | SCLK0   | 78     |  |
| A6                                         | 303    | D2            | 237    | D56  | 129    | SCLK1   | 74     |  |
| A7                                         | 302    | D20           | 201    | D57  | 126    | STATUS0 | 6      |  |
| A8                                         | 300    | D21           | 199    | D58  | 124    | STATUS1 | 4      |  |
| A9                                         | 298    | D22           | 197    | D59  | 122    | STATUS2 | 3      |  |
| AS0                                        | 9      | D23           | 196    | D6   | 230    | STATUS3 | 1      |  |
| AS1                                        | 8      | D24           | 193    | D60  | 119    | STATUS4 | 319    |  |
| AS2                                        | 7      | D25           | 191    | D61  | 117    | STATUS5 | 64     |  |
| BS0                                        | 15     | D26           | 190    | D62  | 115    | ТСК     | 103    |  |
| BS1                                        | 14     | D27           | 189    | D63  | 114    | TDI     | 105    |  |
| CAREA0                                     | 80     | D28           | 186    | D7   | 229    |         |        |  |
| CAREA1                                     | 72     | D29           | 182    | D7   | 229    |         |        |  |
| CAS/DQM0                                   | 52     | D23           | 236    | D0   | 220    |         |        |  |

## HFH Pin Assignments – Alphabetical Listing



SGUS025 – AUGUST 1998

| P               | N      | F               | PIN    | F               | PIN    | Р               | IN     |
|-----------------|--------|-----------------|--------|-----------------|--------|-----------------|--------|
| NAME            | NUMBER | NAME            | NUMBER | NAME            | NUMBER | NAME            | NUMBER |
| TDO             | 106    | V <sub>DD</sub> | 243    | VSS             | 110    | V <sub>SS</sub> | 259    |
| TMS             | 104    | V <sub>DD</sub> | 251    | Vss             | 111    | V <sub>SS</sub> | 26     |
| TRG/CAS         | 58     | V <sub>DD</sub> | 252    | VSS             | 116    | V <sub>SS</sub> | 268    |
| TRST            | 102    | V <sub>DD</sub> | 253    | V <sub>SS</sub> | 118    | V <sub>SS</sub> | 269    |
| UTIME           | 13     | V <sub>DD</sub> | 261    | VSS             | 123    | V <sub>SS</sub> | 27     |
| V <sub>DD</sub> | 100    | V <sub>DD</sub> | 262    | VSS             | 128    | V <sub>SS</sub> | 274    |
| V <sub>DD</sub> | 113    | V <sub>DD</sub> | 263    | VSS             | 133    | V <sub>SS</sub> | 277    |
| V <sub>DD</sub> | 120    | V <sub>DD</sub> | 266    | VSS             | 137    | V <sub>SS</sub> | 278    |
| V <sub>DD</sub> | 121    | V <sub>DD</sub> | 271    | VSS             | 138    | V <sub>SS</sub> | 279    |
| V <sub>DD</sub> | 125    | V <sub>DD</sub> | 272    | V <sub>SS</sub> | 144    | V <sub>SS</sub> | 287    |
| V <sub>DD</sub> | 130    | V <sub>DD</sub> | 281    | V <sub>SS</sub> | 145    | V <sub>SS</sub> | 290    |
| V <sub>DD</sub> | 131    | V <sub>DD</sub> | 282    | VSS             | 153    | VSS             | 291    |
| V <sub>DD</sub> | 135    | V <sub>DD</sub> | 283    | V <sub>SS</sub> | 154    | V <sub>SS</sub> | 295    |
| V <sub>DD</sub> | 140    | V <sub>DD</sub> | 288    | VSS             | 162    | VSS             | 299    |
| V <sub>DD</sub> | 147    | V <sub>DD</sub> | 293    | V <sub>SS</sub> | 163    | V <sub>SS</sub> | 304    |
| V <sub>DD</sub> | 148    | V <sub>DD</sub> | 297    | V <sub>SS</sub> | 169    | V <sub>SS</sub> | 305    |
| V <sub>DD</sub> | 149    | V <sub>DD</sub> | 30     | V <sub>SS</sub> | 171    | V <sub>SS</sub> | 307    |
| V <sub>DD</sub> | 156    | V <sub>DD</sub> | 301    | V <sub>SS</sub> | 176    | V <sub>SS</sub> | 315    |
| V <sub>DD</sub> | 157    | V <sub>DD</sub> | 309    | VSS             | 183    | VSS             | 320    |
| V <sub>DD</sub> | 158    | V <sub>DD</sub> | 310    | VSS             | 184    | VSS             | 34     |
| V <sub>DD</sub> | 165    | V <sub>DD</sub> | 311    | VSS             | 185    | VSS             | 35     |
| V <sub>DD</sub> | 172    | V <sub>DD</sub> | 313    | VSS             | 192    | V <sub>SS</sub> | 37     |
| V <sub>DD</sub> | 178    | V <sub>DD</sub> | 318    | V <sub>SS</sub> | 198    | V <sub>SS</sub> | 42     |
| V <sub>DD</sub> | 179    | V <sub>DD</sub> | 39     | V <sub>SS</sub> | 2      | V <sub>SS</sub> | 49     |
| V <sub>DD</sub> | 187    | V <sub>DD</sub> | 40     | VSS             | 200    | V <sub>SS</sub> | 55     |
| V <sub>DD</sub> | 188    | V <sub>DD</sub> | 33     | VSS             | 207    | VSS             | 56     |
| V <sub>DD</sub> | 194    | V <sub>DD</sub> | 44     | VSS             | 209    | V <sub>SS</sub> | 57     |
| V <sub>DD</sub> | 195    | V <sub>DD</sub> | 5      | VSS             | 216    | V <sub>SS</sub> | 67     |
| V <sub>DD</sub> | 202    | V <sub>DD</sub> | 51     | V <sub>SS</sub> | 217    | V <sub>SS</sub> | 73     |
| V <sub>DD</sub> | 203    | V <sub>DD</sub> | 59     | V <sub>SS</sub> | 225    | V <sub>SS</sub> | 77     |
| V <sub>DD</sub> | 205    | V <sub>DD</sub> | 61     | VSS             | 23     | V <sub>SS</sub> | 87     |
| V <sub>DD</sub> | 21     | V <sub>DD</sub> | 62     | VSS             | 232    | V <sub>SS</sub> | 88     |
| V <sub>DD</sub> | 212    | V <sub>DD</sub> | 65     | VSS             | 233    | V <sub>SS</sub> | 95     |
| V <sub>DD</sub> | 219    | V <sub>DD</sub> | 69     | VSS             | 238    | V <sub>SS</sub> | 96     |
| V <sub>DD</sub> | 220    | V <sub>DD</sub> | 75     | VSS             | 240    | VSYNC0          | 94     |
| V <sub>DD</sub> | 221    | V <sub>DD</sub> | 79     | VSS             | 245    | VSYNC1          | 93     |
| V <sub>DD</sub> | 227    | V <sub>DD</sub> | 90     | V <sub>SS</sub> | 248    | W               | 63     |
| V <sub>DD</sub> | 228    | V <sub>DD</sub> | 91     | VSS             | 249    | XPT0            | 108    |
| V <sub>DD</sub> | 235    | V <sub>DD</sub> | 98     | VSS             | 257    | XPT1            | 109    |
| V <sub>DD</sub> | 31     | V <sub>DD</sub> | 99     | VSS             | 210    | XPT2            | 127    |
| V <sub>DD</sub> | 242    | VSS             | 32     | VSS             | 258    |                 |        |





SGUS025 - AUGUST 1998

### **Terminal Functions**

| TERMINAL              |                   |                                                                                                                                                                                                                    |
|-----------------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| NAME                  | TYPE <sup>†</sup> | DESCRIPTION                                                                                                                                                                                                        |
|                       |                   | LOCAL MEMORY INTERFACE                                                                                                                                                                                             |
| A31-A0                | 0                 | Address bus. A31–A0 output the 32-bit byte address of the external memory cycle. The address can be multiplexed for DRAM accesses.                                                                                 |
| AS2-AS0               | I                 | Address-shift selection. AS2-AS0 determine how the column address appears on the address bus. Eight shift values are supported, including zero.                                                                    |
| BS1-BS0               | Ι                 | Bus size selection. BS1-BS0 indicate the bus size of the memory or other devices being accessed, allowing dynamic bus sizing for data buses less than 64 bits wide.                                                |
| CT2-CT0               | Ι                 | Cycle timing selection. CT2-CT0 signals determine the timing of the current memory access.                                                                                                                         |
| D63-D0                | I/O               | Data bus. D63–D0 transfer up to 64 bits of data per memory cycle into or out of the 'C80.                                                                                                                          |
| DBEN                  | 0                 | Data-buffer enable. DBEN drives the active-low output enables of bidirectional transceivers that can be used to buffer input and output data on D63–D0.                                                            |
| DDIN                  | 0                 | Data direction indicator. DDIN indicates the direction of the data that passes through the transceivers. When DDIN is low, the transfer is from external memory into the 'C80.                                     |
| FAULT                 | I                 | Fault. FAULT is driven low by external circuitry to inform the 'C80 that a fault has occurred on the current memory row access.                                                                                    |
| PS3-PS0               | I                 | Page size indication. PS3–PS0 indicate the page size of the memory device(s) being accessed by the current cycle. The 'C80 uses this information to determine when to begin a new row access.                      |
| READY                 | I                 | Ready. READY indicates that the external device is ready to complete the memory cycle. READY is driven low by external circuitry to insert wait states into a memory cycle.                                        |
| RL                    | 0                 | Row latch. The high-to-low transition of $\overline{RL}$ can be used to latch the valid 32-bit byte address that is present on A31 – A0.                                                                           |
| RETRY                 | I                 | Retry. RETRY is driven low by external circuitry to indicate that the addressed memory is busy. The 'C80 memory cycle is rescheduled.                                                                              |
| STATUS5-STATUS0       | 0                 | Status code. At row time, STATUS5-STATUS0 indicate the type of cycle being performed. At column time, they identify the processor and type of request that initiated the cycle.                                    |
| UTIME                 | I                 | User-timing selection. UTIME causes the timing of RAS and CAS/DQM7–CAS/DQM0 to be modified so that custom memory timings can be generated. During reset, UTIME selects the endian mode in which the 'C80 operates. |
|                       |                   | DRAM, VRAM, AND SDRAM CONTROL                                                                                                                                                                                      |
| CAS/DQM7-<br>CAS/DQM0 | 0                 | Column-address strobes. CAS/DQM7–CAS/DQM0 drive the CAS inputs of DRAMs and VRAMs, or the DQM input of synchronous dynamic random-access memories (SDRAMs). The eight strobes provide byte-write access to memory. |
| DSF                   | 0                 | Special function. DSF selects special VRAM functions such as block-write, load color register, split-register transfer, and synchronous graphics random-access memory (SGRAM) block write.                         |
| RAS                   | 0                 | Row-address strobe. RAS drives the RAS inputs of DRAMs, VRAMs, and SDRAMs.                                                                                                                                         |
| TRG/CAS               | 0                 | Transfer/output enable or column-address strobe. TRG/CAS is used as an output enable for DRAMs and VRAMs, and also as a transfer enable for VRAMs. TRG/CAS also drives the CAS inputs of SDRAMs.                   |
| W                     | 0                 | Write enable. $\overline{W}$ is driven low before $\overline{CAS}$ during write cycles. $\overline{W}$ controls the direction of the transfer during VRAM transfer cycles.                                         |

† I = input, O = output, Z = high-impedance
 ‡ This pin has an internal pullup and can be left unconnected during normal operation.
 § This pin has an internal pulldown and can be left unconnected during normal operation.

 $\P$  For proper operation, all  $V_{DD}$  and  $V_{SS}$  pins must be connected externally.



SGUS025 - AUGUST 1998

### **Terminal Functions (Continued)**

| TERMINAL                |                   | DECODIDION                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------------------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| NAME                    | TYPE <sup>†</sup> | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                         |                   | HOST INTERFACE                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| HACK                    | 0                 | Host acknowledge. The 'C80 drives HACK output low following an active HREQ to indicate that it has driven the local memory bus signals to the high-impedance state and is relinquishing the bus. HACK is driven high asynchronously following HREQ being detected inactive, and then the 'C80 resumes driving the bus.                                                                                                                              |
| HREQ                    | I                 | Host request. An external device drives HREQ low to request ownership of the local memory bus. When HREQ is high, the 'C80 owns and drives the bus. HREQ is synchronized internally to the 'C80's internal clock. Also, HREQ is used at reset to determine the power-up state of the MP. If HREQ is low at the rising edge of RESET, the MP comes up running. If HREQ is high, the MP remains halted until the first interrupt occurrence on EINT3. |
| REQ1, REQ0              | 0                 | Internal cycle request. REQ1 and REQ0 provide a two-bit code indicating the highest-priority memory cycle request that is being received by the TC. External logic can monitor REQ1 and REQ0 to determine if it is necessary to relinquish the local memory bus to the 'C80.                                                                                                                                                                        |
|                         |                   | SYSTEM CONTROL                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| CLKIN                   | I                 | Input clock. CLKIN generates the internal 'C80 clocks to which all processor functions (except the frame timers) are synchronous.                                                                                                                                                                                                                                                                                                                   |
| CLKOUT                  | 0                 | Local output clock. CLKOUT provides a way to synchronize external circuitry to internal timings. All 'C80 output signals (except the VC signals) are synchronous to this clock.                                                                                                                                                                                                                                                                     |
| EINT1, EINT2, EINT3     | I                 | Edge-triggered interrupts. EINT1, EINT2 and EINT3 allow external devices to interrupt the master processor (MP) on one of three interrupt levels (EINT1 is the highest priority). The interrupts are rising-edge triggered. EINT3 also serves as an unhalt signal. If the MP is powered-up halted, the first rising edge on EINT3 causes the MP to unhalt and fetch its reset vector (the EINT3 interrupt-pending bit is not set in this case).     |
| LINT4                   | I                 | Level-triggered interrupt. LINT4 provides an active-low level-triggered interrupt to the MP. Its priority falls below that of the edge-triggered interrupts. Any interrupt request should remain low until it is recognized by the 'C80.                                                                                                                                                                                                            |
| RESET                   | I                 | Reset. RESET is driven low to reset the 'C80 (all processors). During reset, all internal registers are set to their initial state and all outputs are driven to their inactive or high-impedance levels. During the rising edge of RESET, the MP reset mode and the 'C80's operating endian mode are determined by the levels of HREQ and UTIME pins, respectively.                                                                                |
| XPT2-XPT0               | I                 | External packet transfer. $\overline{XPT2} - \overline{XPT0}$ are used by external devices to request a high-priority XPT by the TC.                                                                                                                                                                                                                                                                                                                |
|                         |                   | EMULATION CONTROL                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| EMU0, EMU1 <sup>‡</sup> | I/O               | Emulation pins. EMU0 and EMU1 are used to support emulation host interrupts, special functions targeted at a single processor, and multiprocessor halt-event communications.                                                                                                                                                                                                                                                                        |
| тск‡                    | I                 | Test clock. TCK provides the clock for the 'C80 IEEE-1149.1 logic, allowing it to be compatible with other IEEE-1149.1 devices, controllers, and test equipment designed for different clock rates.                                                                                                                                                                                                                                                 |
| TDI‡                    | I                 | Test data input. TDI provides input data for all IEEE-1149.1 instructions and data scans of the 'C80.                                                                                                                                                                                                                                                                                                                                               |
| TDO                     | 0                 | Test data output. TDO provides output data for all IEEE-1149.1 instructions and data scans of the 'C80.                                                                                                                                                                                                                                                                                                                                             |
| TMS <sup>‡</sup>        | I                 | Test-mode select. TMS controls the IEEE-1149.1 state machine.                                                                                                                                                                                                                                                                                                                                                                                       |
| TRST§                   | Ι                 | Test reset. TRST resets the 'C80 IEEE-1149.1 module. When low, all boundary-scan logic is disabled, allowing normal 'C80 operation.                                                                                                                                                                                                                                                                                                                 |

† I = input, O = output, Z = high-impedance
 ‡ This pin has an internal pullup and can be left unconnected during normal operation.
 § This pin has an internal pulldown and can be left unconnected during normal operation.

 $\P$  For proper operation, all  $V_{DD}$  and  $V_{SS}$  pins must be connected externally.



SGUS025 - AUGUST 1998

### **Terminal Functions (Continued)**

| TERMINAL                                          |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------------------------------------------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| NAME                                              | TYPE <sup>†</sup> | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                                                   |                   | VIDEO INTERFACE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| CAREA0, CAREA1                                    | 0                 | Composite area. CAREA0 and CAREA1 define a special area such as an overscan boundary. This area represents the logical OR of the internal horizontal and vertical area signals.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| <u>CBLNK0</u> / <u>VBLNK0,</u><br>CBLNK1 / VBLNK1 | 0                 | Composite blanking/vertical blanking. Each of CBLNK0 / VBLNK0 and CBLNK1/VBLNK1 provides one<br>of two blanking functions, depending on the configuration of the CSYNC/HBLNK pin:<br>Composite blanking disables pixel display/capture during both horizontal and vertical retrace periods<br>and is enabled when CSYNC is selected for composite-sync video systems.<br><u>Vertical</u> blanking disables pixel display/capture during vertical retrace periods and is enabled when<br>HBLNK is selected for separate-sync video systems.<br>Following reset, CBLNK0 / VBLNK0 and CBLNK1 / VBLNK1 are configured as CBLNK0 and CBLNK1,<br>respectively.                                                                                                                                                                                                                                                               |
| <u>CSYNC0</u> / <u>HBLNK0,</u><br>CSYNC1 / HBLNK1 | I/O/Z             | Composite sync/horizontal blanking. CSYNC0 / HBLNK0 and CSYNC1 / HBLNK1 can be programmed for one of two functions:<br>Composite sync is for use on composite-sync video systems and can be programmed as an input, output, or high-impedance signal. As an input, the 'C80 extracts horizontal and vertical sync information from externally generated active-low sync pulses. As an output, the active-low composite-sync pulses are generated from either external HSYNC and VSYNC signals or the 'C80's internal video timers. In the high-impedance state, the pin is neither driven nor allowed to drive circuitry.<br>Horizontal blank disables pixel display/capture during horizontal retrace periods in separate-sync video systems and can be used as an output only.<br>Immediately following reset, CSYNC0 / HBLNK0 and CSYNC1 / HBLNK1 are configured as high-impedance CSYNC0 and CSYNC1, respectively. |
| FCLK0, FCLK1                                      | I                 | Frame clock. FCLK0 and FCLK1 are derived from the external video system's dotclock and are used to drive the 'C80 video logic for frame timer 0 and frame timer 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| HSYNCO,<br>HSYNC1                                 | I/O/Z             | Horizontal sync. HSYNC0 and HSYNC1 control the video system. They can be programmed as input, output, or high impedance signals. As an input, HSYNC synchronizes the video timer to externally generated horizontal sync pulses. As an output, HSYNC is an active-low horizontal sync pulse generated by the 'C80 on-chip frame timer. In the high-impedance state, the pin is not driven, and no internal synchronization is allowed to occur. Immediately following reset, HSYNC0 and HSYNC1 are in the high-impedance state.                                                                                                                                                                                                                                                                                                                                                                                        |
| SCLK0, SCLK1                                      | I                 | Serial data clock. SCLK0 and SCLK1 are used by the 'C80 shift register transfer (SRT) controller to track the VRAM tap point when using midline reload. SCLK0 and SCLK1 should be the same signals that clock the serial register on the VRAMs controlled by frame timer 0 and frame timer 1, respectively.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| VSYNCO,<br>VSYNC1                                 | I/O/Z             | Vertical sync. VSYNC0 and VSYNC1 control the video system. They can be programmed as inputs, outputs, or high-impedance signals. As inputs, VSYNCx synchronize the frame timer to externally generated vertical-sync pulses. As outputs, VSYNCx are active-low vertical-sync pulses generated by the 'C80 on-chip frame timer. In the high-impedance state, the pin is not driven and no internal synchronization is allowed to occur. Immediately following reset, VSYNCx is in the high-impedance state.                                                                                                                                                                                                                                                                                                                                                                                                             |
|                                                   |                   | POWER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| ∨ <sub>SS</sub> ¶                                 | 1                 | Ground. Electrical ground inputs                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| V <sub>DD</sub> ¶                                 | Ι                 | Power. Nominal 3.3-V power supply inputs                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

† I = input, O = output, Z = high-impedance
 ‡ This pin has an internal pullup and can be left unconnected during normal operation.

\$ This pin has an internal pulldown and can be left unconnected during normal operation. \$ For proper operation, all V<sub>DD</sub> and V<sub>SS</sub> pins must be connected externally.



SGUS025 – AUGUST 1998

| TERMINA                                                                                      | \L                | DECODIDEION |  |  |  |  |  |  |  |  |  |  |  |
|----------------------------------------------------------------------------------------------|-------------------|-------------|--|--|--|--|--|--|--|--|--|--|--|
| NAME                                                                                         | TYPE <sup>†</sup> | DESCRIPTION |  |  |  |  |  |  |  |  |  |  |  |
| NAME TYPET MISCELLANEOUS                                                                     |                   |             |  |  |  |  |  |  |  |  |  |  |  |
| NC No connect serves as an alignment key or is for factory use and must be left unconnected. |                   |             |  |  |  |  |  |  |  |  |  |  |  |

#### **Terminal Functions (Continued)**

 $\dagger I = input, O = output, Z = high-impedance$ 

<sup>‡</sup> This pin has an internal pullup and can be left unconnected during normal operation.

§ This pin has an internal pulldown and can be left unconnected during normal operation.

 $\P$  For proper operation, all V<sub>DD</sub> and V<sub>SS</sub> pins must be connected externally.

#### architecture

Figure 1 shows the major components of the 'C80: the master processor (MP), the parallel digital signal processors (PPs), the transfer controller (TC), and the IEEE-1149.1 emulation interface. Shared access to on-chip RAM is achieved through the crossbar. Crossbar connections are represented by  $\bigcirc$ . Each PP can perform three accesses per cycle through its local (L), global (G), and instruction (I) ports. The MP can access two RAMs per cycle through its crossbar/data (C/D) and instruction (I) ports, and the TC can access one RAM through its crossbar interface. Up to nine simultaneous accesses are supported in each cycle. Addresses can be changed every cycle, allowing the crossbar matrix to be changed on a cycle-by-cycle basis. Contention between processors for the same RAM in the same cycle is resolved by a round-robin priority scheme. In addition to the crossbar, a 32-bit data path exists between the MP and the TC and VC. This allows the MP to access TC control registers that are memory-mapped into the MP memory space.

The 'C80 has a 4G-byte address space as shown in Figure 2. The lower 32M bytes are used to address internal RAM and memory-mapped registers.



SGUS025 - AUGUST 1998

### architecture (continued)



L Local port

G Global port

I Instruction port

C/D Crossbar/data port

Figure 1. Block Diagram Showing Data Paths



SGUS025 – AUGUST 1998

### architecture (continued)

| ,                                         |                                        |
|-------------------------------------------|----------------------------------------|
| External Memory<br>(4064M bytes)          | 0xFFFFFFF                              |
| Reserved                                  | 0x02000000                             |
| (8063K bytes)                             | 0x01FFFFFF                             |
| Memory-Mapped VC Registers                | 0x01820400                             |
| (512 bytes)                               | 0x018203FF                             |
| Memory-Mapped TC Registers<br>(512 bytes) | 0x01820200<br>0x018201FF<br>0x01820000 |
| Reserved                                  | 0x01820000                             |
| (28K bytes)                               | 0x0181FFFF                             |
| MP Instruction Cache<br>(4K bytes)        | 0x01818FFF                             |
| Reserved<br>(28K bytes)                   | 0x01817FFF                             |
| MP Data Cache                             | 0x01810FFF                             |
| (4K bytes)                                | 0x01810000                             |
| Reserved                                  | 0x0180FFFF                             |
| (32K bytes)                               | 0x01808000                             |
| ADSP3 Instruction Cache                   | 0x01807FFF                             |
| (2K bytes)                                | 0x01807800                             |
| Reserved                                  | 0x018077FF                             |
| (6K bytes)                                | 0x01806000                             |
| ADSP2 Instruction Cache                   | 0x01805FFF                             |
| (2K bytes)                                | 0x01805800                             |
| Reserved                                  | 0x018057FF                             |
| (6K bytes)                                | 0x01804000                             |
| ADSP1 Instruction Cache                   | 0x01803FFF                             |
| (2K bytes)                                | 0x01803800                             |
| Reserved                                  | 0x018037FF                             |
| (6K bytes)                                | 0x01802000                             |
| ADSP0 Instruction Cache                   | 0x01801FFF                             |
| (2K bytes)                                | 0x01801800                             |
| Registers<br>(8132K bytes)                | 0x018017FF                             |
| MP Parameter RAM<br>(2K bytes)            | 0x01010800<br>0x010107FF<br>0x01010000 |
| Registers<br>(50K bytes)                  | 0x010000FFFF                           |
|                                           | 0.01003000                             |

| ADSP3 Parameter RAM<br>(2K bytes) | 0x010037FF               |
|-----------------------------------|--------------------------|
| Reserved                          | 0x01003000<br>0x01002FFF |
| (2K bytes)                        | 0x01002800               |
| ADSP2 Parameter RAM<br>(2K bytes) | 0x010027FF<br>0x01002000 |
| Reserved                          | 0x01002000<br>0x01001FFF |
| (2K bytes)                        | 0x01001800               |
| ADSP1 Parameter RAM<br>(2K bytes) | 0x010017FF<br>0x01001000 |
| Reserved<br>(2K bytes)            | 0x01000FFF<br>0x01000800 |
| ADSP0 Parameter RAM<br>(2K bytes) | 0x010007FF               |
| Reserved                          | 0x01000000<br>0x00FFFFFF |
| (16338K bytes)                    | 0x0000B800               |
| ADSP3 Data RAM2                   | 0x0000B000               |
| (2K bytes)                        | 0x0000B000               |
| Reserved                          | 0x0000AFFF               |
| (2K bytes)                        | 0x0000A800               |
| ADSP2 Data RAM2<br>(2K bytes)     | 0x0000A7FF<br>0x0000A000 |
| Reserved<br>(2K bytes)            | 0x00009FFF               |
| ADSP1 Data RAM2                   | 0x00009800<br>0x000097FF |
| (2K bytes)                        | 0x00009000               |
| Reserved<br>(2K bytes)            | 0x00008FFF               |
| ADSP0 Data RAM2                   | 0x00008800<br>0x000087FF |
| (2K bytes)                        | 0x00008000               |
| Reserved<br>(16K bytes)           | 0x000007FFF              |
| (Tok bytes)                       | 0x00004000               |
| ADSP3 Data RAM1<br>(2K bytes)     | 0x00003FFF<br>0x00003800 |
| ADSP3 Data RAM0<br>(2K bytes)     | 0x000037FF               |
| ADSP2 Data RAM1<br>(2K bytes)     | 0x00003000<br>0x00002FFF |
|                                   | 0x00002800<br>0x000027FF |
| ADSP2 Data RAM0<br>(2K bytes)     | 0x00002711               |
| ADSP1 Data RAM1<br>(2K bytes)     | 0x00001FFF<br>0x00001800 |
| ADSP1 Data RAM0<br>(2K bytes)     | 0x00001766               |
|                                   | 0x00001000<br>0x00000FFF |
| ADSP0 Data RAM1<br>(2K bytes)     | 0x00000FFF               |
| ADSP0 Data RAM0                   | 0x000007FF               |
| (2K bytes)                        | 0x00000000               |
|                                   |                          |

Figure 2. Memory Map



SG<u>US025 - AUGUST 1998</u>

#### master processor (MP) architecture

The master processor (MP) is a 32-bit RISC processor with an integral IEEE-754 floating-point unit. The MP is designed for effective execution of C code and is capable of performing at well over 130000 dhrystones/s. Major tasks which the MP typically performs are:

- Task control and user interface
- Information processing and analysis
- IEEE-754 floating point (including graphics transforms)

#### MP functional block diagram

Figure 3 shows a block diagram of the master processor. Key features of the MP include:

- 32-bit RISC processor
  - Load/store architecture
  - Three operand arithmetic and logical instructions
- 4K-byte instruction cache and 4K-byte data cache
  - Four-way set associative
  - Least-recently-used (LRU) information replacement
  - Data writeback
- 4K-byte noncached parameter RAM
- Thirty-one 32-bit general-purpose registers
- Register and accumulator scoreboard
- 15-bit or 32-bit immediate constants
- 32-bit byte addressing
- Scalable timer
- Leftmost-one and rightmost-one logic
- IEEE-754 floating-point hardware
  - Four double-precision floating-point vector accumulators
  - Vector floating-point instructions
     Floating-point operation and parallel load or store
     Multiply and accumulate
- High performance
  - 50 million instructions per second (MIPS)
  - 100 million floating-point operations per second (MFLOPS)
  - Over 130000 dhrystones/s



#### SGUS025 – AUGUST 1998

#### MP functional block diagram (continued)





#### MP general-purpose registers

The MP contains 31 32-bit general-purpose registers, R1–R31. Register R0 always reads as zero and writes to it are discarded. Double-precision values are always stored in an even-odd register pair with the higher-numbered register always holding the sign bit and exponent. The R0/R1 pair is not available for this use. A scoreboard keeps track of which registers are awaiting loads or the result of a previous instruction and stalls the instruction pipeline until the register contains valid data. As a recommended software convention, R1 is typically used as a stack pointer and R31 as a return-address link register.

Figure 4 shows the MP general-purpose registers.



SG<u>US025 - AUGUST 1998</u>



MP general-purpose registers (continued)



The 32-bit registers can contain signed-integer, unsigned-integer, or single-precision floating-point values. Signed and unsigned bytes and halfwords are sign-extended or zero-filled. Doublewords can be stored in a 64-bit even/odd register pair. Double-precision floating-point values are referenced using the even register number or the register pair. Figure 5 through Figure 7 show the register data formats.



Figure 5. MP Register 32-Bit Data Formats



SGUS025 - AUGUST 1998







SGUS025 - AUGUST 1998

#### MP double-precision floating-point accumulators

There are four double-precision floating-point registers (see Figure 8) to accumulate intermediate floating-point results.



Е

М Value

MS Most significant

LS Least signficant

#### Figure 8. Double-Precision Floating-Point Accumulators

#### **MP** control registers

In addition to the general-purpose registers, there are a number of control registers that are used to represent the state of the processor. Table 1 shows the control register numbers of the accessible registers.

| NUMBER | NAME    | DESCRIPTION                         | NUMBER          | NAME     | DESCRIPTION                            |
|--------|---------|-------------------------------------|-----------------|----------|----------------------------------------|
| 0x0000 | EPC     | Exception Program Counter           | 0x0015-0x001F   | —        | Reserved                               |
| 0x0001 | EIP     | Exception Instruction Pointer       | 0x0020          | SYSSTK   | System Stack Pointer                   |
| 0x0002 | CONFIG  | Configuration                       | 0x0021          | SYSTMP   | System Temporary Register              |
| 0x0003 | _       | Reserved                            | 0x0022-0x002F   | —        | Reserved                               |
| 0x0004 | INTPEN  | Interrupt Pending Register          | 0x0030          | MPC      | Emulator Exception Program Counter     |
| 0x0005 | _       | Reserved                            | 0x0031          | MIP      | Emulator Exception Instruction Pointer |
| 0x0006 | IE      | Interrupt Enable Register           | 0x0032          | —        | Reserved                               |
| 0x0007 | _       | Reserved                            | 0x0033          | ECOMCNTL | Emulator Communication Control         |
| 0x0008 | FPST    | Floating-Point Status               | 0x0034          | ANASTAT  | Emulation Analysis Status Register     |
| 0x0009 | _       | Reserved                            | 0x0035–0x0038   | —        | Reserved                               |
| 0x000A | PPERROR | PP Error Register                   | 0x0039          | BRK1     | Emulation Breakpoint 1 Register        |
| 0x000B | _       | Reserved                            | 0x003A          | BRK2     | Emulation Breakpoint 2 Register        |
| 0x000C | —       | Reserved                            | 0x003B-0x01FF   | —        | Reserved                               |
| 0x000D | PKTREQ  | Packet-Transfer Request<br>Register | 0x0200 – 0x020F | iCACHET  | Instruction Cache Tags 0 to 15         |
| 0x000E | TCOUNT  | Current Counter Value               | 0x0300          | iCACHEL  | Instruction Cache LRU Register         |
| 0x000F | TSCALE  | Counter Reload Value                | 0x0400-0x040F   | dCACHET  | Data Cache Tags 0 to 15                |
| 0x0010 | FLTOP   | Faulting Operation                  | 0x0500          | dCACHEL  | Data Cache LRU Register                |
| 0x0011 | FLTADR  | Faulting Address                    | 0x4000          | IN0P     | Vector Load Pointer 0                  |
| 0x0012 | FLTTAG  | Faulting Tag                        | 0x4001          | IN1P     | Vector Load Pointer 1                  |
| 0x0013 | FLTDTL  | Faulting Data (low)                 | 0x4002          | OUTP     | Vector Store Pointer                   |
| 0x0014 | FLTDTH  | Faulting Data (high)                |                 |          |                                        |

#### **Table 1. Control Register Numbers**



#### SGUS025 – AUGUST 1998

#### MP pipeline registers

The MP uses a three-stage fetch, execute, access (FEA) pipeline. The primary pipeline registers are manipulated implicitly by branch and trap instructions and are not accessible by the user. The exception and emulation pipeline registers are user-accessible as control registers. All pipeline registers are 32 bits.

|                      |        | Program Execution Mode |           |
|----------------------|--------|------------------------|-----------|
|                      | Normal | Exception              | Emulation |
| Program Counter      | PC     | EPC                    | MPC       |
| Instruction Pointer  | IP     | EIP                    | MIP       |
| Instruction Register | IR     |                        |           |

- Instruction register (IR) contains the instruction being executed.
- Instruction pointer (IP) points to the instruction being executed.
- Exception/emulator instruction pointer (EIP/MIP) points to the instruction that would have been executed had the exception / emulation trap not occurred.
- Program counter (PC) points to the instruction being fetched.
- Exception/emulator program counter (EPC/MPC) points to the instruction to be fetched on returning from the exception/emulation trap.

#### Figure 9. MP FEA Pipeline Registers

#### configuration (CONFIG) register (0x0002)

The CONFIG register controls or reflects the state of certain options as shown in Figure 10.

| 3 | 3 | 2 | 2 | 2 | 2 | 2                                                        | 2 | 2 | 2 | 2 | 2 | 1 | 1 | 1 | 1 | 1 | 1  | 1  | 1 | 1 | 1    | •    | 0 | 7 | 6    | F    | 4 | 2 | 2    |      | • |
|---|---|---|---|---|---|----------------------------------------------------------|---|---|---|---|---|---|---|---|---|---|----|----|---|---|------|------|---|---|------|------|---|---|------|------|---|
| 1 | 0 | 9 | 8 | 7 | 6 | 5                                                        | 4 | 3 | 2 | 1 | 0 | 9 | 8 | 7 | 6 | 5 | 4  | 3  | 2 | 1 | 0    | 9    | 0 | ' | 0    | 5    | 4 | 3 | 2    |      | U |
| E | R | Т | н | X |   | 2 2 2 2 2 2 2 2 1 1 1<br>6 5 4 3 2 1 0 9 8 7<br>Reserved |   |   |   |   |   |   |   |   |   |   | Ту | ре |   |   | Rese | erve | d |   | Rele | ease |   |   | Rese | erve | d |

E Endian mode; 0 = big-endian, 1 = little-endian, read only

- R PPData RAM round robin; 0 = fixed, 1 = variable, read/write
- T TC packet transfer (PT) round robin; 0 = variable, 1 = fixed, read/write
- H High priority MP events; 0 = disabled, 1 = enabled, read/write
- X Externally initiated packet transfers; 0 = disabled, 1 = enabled, read/write
- Type Number of PPs in device, read only
- Release SMJ320C80 version number

Figure 10. CONFIG Register



SGUS025 - AUGUST 1998

#### interrupt-enable (IE) register (0x0006)

The IE register contains enable bits for each of the interrupts/traps as shown in Figure 11. The global-interrupt-enable (ie) bit and the appropriate individual interrupt-enable bit must be set in order for an interrupt to occur.



#### interrupt-pending (INTPEN) register (0x0004)

The bits in INTPEN register show the current state of each interrupt/trap. Pending interrupts do not occur unless the ie bit and corresponding interrupt-enable bit are set. Software must write a 1 to the appropriate INTPEN bit to clear an interrupt. Figure 12 shows the INTPEN register locations.

| pxxbppmimxxxtiffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff <th< th=""><th>3<br/>1</th><th>3<br/>0</th><th>2<br/>9</th><th>2<br/>8</th><th>2<br/>7</th><th>2<br/>6</th><th>2<br/>5</th><th>2<br/>4</th><th>2<br/>3</th><th>2<br/>2</th><th>2<br/>1</th><th>2<br/>0</th><th>1<br/>9</th><th>1<br/>8</th><th>1<br/>7</th><th>1<br/>6</th><th>1<br/>5</th><th>1<br/>4</th><th>1<br/>3</th><th>1<br/>2</th><th>1<br/>1</th><th>1<br/>0</th><th>9</th><th>8</th><th>7</th><th>6</th><th>5</th><th>4</th><th>3</th><th>2</th><th>1</th><th>0</th></th<>                                                                                                                                                                                                                                                                                | 3<br>1 | 3<br>0                           | 2<br>9                             | 2<br>8                                       | 2<br>7                                         | 2<br>6                                   | 2<br>5                                 | 2<br>4                 | 2<br>3     | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8                           | 1<br>7                     | 1<br>6                                        | 1<br>5                                            | 1<br>4                                        | 1<br>3                            | 1<br>2                                 | 1<br>1         | 1<br>0 | 9 | 8                                | 7                               | 6                                                | 5                                                  | 4                                            | 3                                              | 2                                           | 1              | 0  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------------------------|------------------------------------|----------------------------------------------|------------------------------------------------|------------------------------------------|----------------------------------------|------------------------|------------|--------|--------|--------|--------|----------------------------------|----------------------------|-----------------------------------------------|---------------------------------------------------|-----------------------------------------------|-----------------------------------|----------------------------------------|----------------|--------|---|----------------------------------|---------------------------------|--------------------------------------------------|----------------------------------------------------|----------------------------------------------|------------------------------------------------|---------------------------------------------|----------------|----|
| e       4       3       p       b       c       1       3       2       1       0       6       1       1       0       x       u       0       1       1       0       x       u       0       1       1       0       x       u       0       1       1       0       x       u       0       1       1       0       x       u       0       1       1       0       x       u       0       1       1       0       x       u       0       1       1       0       x       u       0       1       1       0       x       u       0       1       1       0       x       u       0       1       1       0       x       u       0       1       1       0       x       u       0       1       1       0       x       u       0       1       1       0       x       u       0       1       1       0       x       u       0       1       1       0       x       u       0       1       1       0       x       u       0       1       1       0       1       1 | р      | x                                | x                                  | b                                            | р                                              | р                                        | m                                      |                        |            |        |        |        | р      |                                  | р                          | р                                             | i                                                 | m                                             |                                   |                                        |                | ti     | f | f                                | f                               | f                                                | f                                                  |                                              | f7                                             | fi                                          |                |    |
| x4External interrupt 4 (LINT4)p1PP1 message interruptf0Frame-timer 0 interruptx3External interrupt 3 (EINT3)p0PP0 message interruptfxFloating-point inexactbpBad packet transferioInteger overflowfuFloating-point underflowpbPacket transfer busymfMemory faultfoFloating-point overflowpcPacket transfer completex2External interrupt 2 (EINT2)fzFloating-point divide-by-zeromiMP message interruptx1External interrupt 1 (EINT1)fiFloating-point invalid                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | е      | 4                                | 3                                  | р                                            | b                                              | С                                        | i                                      |                        |            |        |        |        | 3      | 2                                | 1                          | 0                                             | 0                                                 | f                                             |                                   | 2                                      | 1              | "      | 1 | 0                                | х                               | u                                                | 0                                                  |                                              | 12                                             |                                             |                |    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |        | x4<br>x3<br>bp<br>pb<br>pc<br>mi | Ext<br>Ext<br>Ba<br>Pa<br>Pa<br>MP | terna<br>terna<br>d pa<br>cket<br>cket<br>me | al in<br>al in<br>cket<br>tran<br>tran<br>ssaç | terru<br>trai<br>isfer<br>isfer<br>ge in | upt 3<br>nsfei<br>bus<br>con<br>iterru | r<br>sy<br>nple<br>upt | NT3)<br>te |        |        |        |        | p1<br>p0<br>io<br>mf<br>x2<br>x1 | PI<br>PI<br>In<br>Ex<br>Ex | P1 m<br>P0 m<br>tege<br>emo<br>cterr<br>cterr | iess<br>iess<br>r ov<br>ry fa<br>nal ir<br>nal ir | age<br>age<br>erflo<br>ault<br>nterr<br>nterr | inter<br>inter<br>w<br>upt<br>upt | rrup<br>rrup<br>2 ( <u>El</u><br>1 (El | t<br>t<br>INT2 |        |   | f0<br>fx<br>fu<br>fo<br>fz<br>fi | Fra<br>Flo<br>Flo<br>Flo<br>Flo | ame<br>Datin<br>Datin<br>Datin<br>Datin<br>Datin | -time<br>1g-pe<br>1g-pe<br>1g-pe<br>1g-pe<br>1g-pe | er 0<br>bint<br>bint<br>bint<br>bint<br>bint | inter<br>inex<br>unde<br>over<br>divid<br>inva | rupt<br>act<br>erflo<br>flow<br>de-b<br>lid | w<br>/<br>y-ze | ro |





SGUS025 – AUGUST 1998

#### floating-point status (FPST) register (0x0008)

FPST contains status and control information for the floating-point unit (FPU) as shown in Figure 13. Bits 17–21 are read/write FPU control bits. Bits 22–26 are read/write accumulated status bits. All other bits show the status of the last FPU instruction to complete and are read only.

| 3<br>1 | 3<br>0 | 2<br>9 | 2<br>8                                        | 2<br>7                                       | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9      | 8      | 7    | 6    | 5    | 4    | 3     | 2     | 1 | 0 |
|--------|--------|--------|-----------------------------------------------|----------------------------------------------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|------|------|------|------|-------|-------|---|---|
|        |        | dest   |                                               |                                              | ai     | a<br>z | a<br>o | a<br>u | a<br>x | s<br>m | f<br>s | v<br>m | dr     | m      |        | орс    | ode    |        | е<br>1 | е<br>0 | р      | d      | r      | m    |      | mo   | i    | z     | 0     | u | x |
|        | c      | lest   |                                               |                                              | natio  |        | -      |        |        |        |        |        |        |        |        |        |        | e0     |        |        |        |        |        | ехро | onen | nt   |      |       |       |   |   |
|        |        | ai     |                                               |                                              | nula   |        |        |        |        |        |        |        |        |        |        |        |        | pd     | De     | estin  |        | n pr   |        |      |      |      |      |       |       |   |   |
|        |        | az     |                                               |                                              | nula   |        |        | -      |        |        |        |        |        |        |        |        |        |        |        |        |        |        | gle fl |      |      |      | •    | d int |       |   |   |
|        |        | ao     | A                                             | ccur                                         | nula   | ted    | over   | flow   | ,      |        |        |        |        |        |        |        |        |        | (      | 01 –   | dou    | ible f | float  | 11   | – ui | nsig | ned  | int   |       |   |   |
|        |        | au     | A                                             |                                              |        |        |        |        |        |        |        |        |        |        |        |        |        | rm     | Ro     | ound   | ding   | moo    | le     |      |      |      |      |       |       |   |   |
|        |        | ax     | A                                             | Accumulated underflow<br>Accumulated inexact |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        | (      | - 00   | nea    | rest |      | 10   | – pe | ositi | ve ∝  |   |   |
|        |        | sm     | Se                                            |                                              |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        | (      | )1 – 1 | zero   | С    |      | 11   | – ne | egati | ive ∘ | 0 |   |
|        |        | fs     | FI                                            | oati                                         | ng-p   | oint   | stal   | I I    |        |        |        |        |        |        |        |        |        | mo     | Int    | t mu   | Itipl  | y ov   | erfl   | ow   |      |      |      | -     |       |   |   |
|        |        | vm     | Ve                                            | ecto                                         | r fas  | t mo   | de     |        |        |        |        |        |        |        |        |        |        | i      | In     | valio  | ' k    | -      |        |      |      |      |      |       |       |   |   |
|        |        | drm    | R                                             | ound                                         | ding   | mod    | le     |        |        |        |        |        |        |        |        |        |        | z      | Di     | vide   | -by-   | zero   | )      |      |      |      |      |       |       |   |   |
|        |        |        | Rounding mode<br>00 – nearest 10 – positive ∞ |                                              |        |        |        |        |        |        |        |        |        |        |        |        |        | ο      | 0      | verfl  | ow     |        |        |      |      |      |      |       |       |   |   |
|        |        |        | $01 - zero$ $11 - negative \infty$            |                                              |        |        |        |        |        |        |        |        |        |        |        |        |        | u      | Ur     | nder   | flow   | ,      |        |      |      |      |      |       |       |   |   |
|        | opc    | ode    | Last opcode                                   |                                              |        |        |        |        |        |        |        |        |        |        |        |        |        | x      | _      | exac   |        |        |        |      |      |      |      |       |       |   |   |
|        | - 13 • | e1     | The tenth MSB of exponent                     |                                              |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |      |      |      |      |       |       |   |   |

#### Figure 13. FPST Register

#### PP error (PPERROR) register (0x000A)

The bits in the PPERROR register reflect parallel processor errors (see Figure 14). The MP can use these when a PP error interrupt occurs to determine the cause of the error.

| 3<br>1 | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9 | 8 | 7 | 6    | 5    | 4  | 3 | 2 | 1 | 0 |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|---|---|---|------|------|----|---|---|---|---|
|        |        |        |        | l      | Rese   | erve   | d      |        |        |        |        | h      | h      | h      | h      |        | Rese   | erve   | d      | i      | i      | i | i |   | Rese | erve | d  | f | f | f | f |
|        |        |        |        |        |        |        |        |        |        |        | PP#    | 3      | 2      | 1      | 0      |        |        | F      | PP#    | 3      | 2      | 1 | 0 |   |      | F    | P# | 3 | 2 | 1 | 0 |
| I      | h      | PPh    | alte   | d      |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |   |   |   |      |      |    |   |   |   |   |
|        | Ι      | PP i   | llega  | al in  | stru   | ctio   | n      |        |        |        |        |        |        |        |        |        |        |        |        |        |        |   |   |   |      |      |    |   |   |   |   |
|        | f      | PP f   | ault   | type   | e      |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |   |   |   |      |      |    |   |   |   |   |
|        | 0      | icac   | he     |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |   |   |   |      |      |    |   |   |   |   |

1 Direct external access (DEA)

#### Figure 14. PPERROR Register

#### packet-transfer request (PKTREQ) register (0x000D)

PKTREQ controls the submission and priority of packet-transfer requests as shown in Figure 15. It also indicates that a packet transfer is currently active.

| 3<br>1 |        | 3<br>0 | 2<br>9                                                         | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|--------|--------|--------|----------------------------------------------------------------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|---|---|---|---|---|---|---|---|---|---|
|        |        |        | Imm                                                            | odic   | oto (i | Irao   | nt) i  | orior  | ity c  |        | stod   |        | Re     | ser    | ved    |        |        |        |        |        |        |        |   |   |   |   |   | I | F | s | Q | Р |
|        | ÷      |        | Immediate (urgent) priority selected                           |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |   |   |   |   |   |   |   |   |   |   |
|        | C<br>C |        | High (foreground) priority selected<br>Suspend packet transfer |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |   |   |   |   |   |   |   |   |   |   |
|        | 0<br>0 |        | Pacl                                                           |        |        |        |        |        |        | d on   | Iv     |        |        |        |        |        |        |        |        |        |        |        |   |   |   |   |   |   |   |   |   |   |

P Submit packet-transfer request

#### Figure 15. PKTREQ Register



SGUS025 - AUGUST 1998



Figure 16. Memory-Fault Registers



#### SGUS025 - AUGUST 1998

### MP cache registers

The ILRU and DLRU registers track least-recently-used (LRU) information for the sixteen instruction-cache and sixteen data-cache blocks. The ITAGxx registers contain block addresses and the present flags for each sub-block. DTAGxx registers are identical to ITAGxx registers but include dirty bits for each sub-block. Figure 17 shows the cache registers.

|    |                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                   |        |      |        |        |        |      |      |        |     |       | ILR<br>DLR |       |          |      |        |        |     |        |          |     |    |     |      |    |     |    |    |    |
|----|------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------|--------|------|--------|--------|--------|------|------|--------|-----|-------|------------|-------|----------|------|--------|--------|-----|--------|----------|-----|----|-----|------|----|-----|----|----|----|
| 3  | 3                                                    | 2<br>9                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 2                                                                 | 2<br>7 | 2    | 2<br>5 | 2<br>4 | 2<br>3 | 2    | 2    | 2<br>0 | 1   | 1     | 1<br>7     | 1     | 1<br>5   | 1    | 1<br>3 | 1      | 1   | 1<br>0 | 9        | 8   | 7  | 6   | 5    | 4  | 3   | 2  | 1  | 0  |
| 1  | 0                                                    | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 8                                                                 |        | 6    | -      | -      | -      | 2    | 1    | -      | 9   | 8     | <u>, '</u> |       | <u> </u> | 4    | -      | 2      | 1   | ÷      |          |     |    |     |      |    |     |    |    |    |
| м  | RU                                                   | NN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | IRU                                                               |        | RU   |        | ิรบ    | M      | RU   | NM   |        |     | RU    | LF         | RU    | +        | RU   | NN     | IRU    |     | RU     |          | ิรบ |    | RU  | NM   |    |     | RU | LF | RU |
| ┥  |                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Se                                                                | et 3   |      |        | -      | ┫-     |      |      | Se     | t 2 |       |            | ->    | -•       |      |        | Se     | t 1 |        |          | -   | ┫— |     |      | Se | t 0 |    |    |    |
|    |                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                   |        |      |        |        |        |      |      |        |     |       |            |       |          |      |        |        |     |        |          |     |    |     |      |    |     |    |    |    |
|    |                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                   |        |      |        |        |        |      |      | I      | TAG | i0–I1 | 'AG        | 15 (0 | )x02     | 200- | -0x0   | 20F)   |     |        |          |     |    |     |      |    |     |    |    |    |
| 3  | 3                                                    | 2       2       2       2       2       2       2       2       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1 |                                                                   |        |      |        |        |        |      |      |        |     |       |            |       | 1        | 1    | 9      | 8      | 7   | 6      | 5        | 4   | 3  | 2   | 1    | 0  |     |    |    |    |
| 1  | 0                                                    | 9                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1<br>22-Bit Cache Tag Address |        |      |        |        |        |      |      |        |     |       |            |       |          | 1    | 0      | _      | ,   |        | <u> </u> |     |    | -   | -    |    |     |    |    |    |
|    |                                                      | 22-Bit Cache Tag Address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                   |        |      |        |        |        |      |      |        |     |       |            |       |          |      | Р      |        | Р   |        | Р        |     | Р  |     |      |    |     |    |    |    |
|    |                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                   |        |      |        |        |        |      |      |        |     |       |            |       |          |      | ;      | 3      | :   | 2      | 1        | I   | (  | )   |      |    |     |    |    |    |
|    |                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                   |        |      |        |        |        |      |      |        |     |       |            |       |          |      |        |        |     | Sub    | -Blo     | ck  |    |     |      |    |     |    |    |    |
|    |                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                   |        |      |        |        |        |      |      |        |     |       |            |       |          |      |        |        |     |        |          |     |    |     |      |    |     |    |    |    |
|    |                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                   |        |      |        |        |        |      |      | D      | TAG | 0-D   | TAG        | 615   | (0x0     | 400  | -0x    | 040F   | )   |        |          |     |    |     |      |    |     |    |    |    |
| 3  | 3                                                    | 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 2                                                                 | 2      | 2    | 2      | 2      | 2      | 2    | 2    | 2      | 1   | 1     | 1          | 1     | 1        | 1    | 1      | 1      | 1   | 1      | 9        | 8   | 7  | 6   | 5    | 4  | 3   | 2  | 1  | 0  |
| _1 | 0                                                    | 9                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 8                                                                 | 7      | 6    | 5      | 4      | 3      | 2    | 1    | 0      | 9   | 8     | 7          | 6     | 5        | 4    | 3      | 2      | 1   | 0      | 9        | 0   | '  | 0   | 5    | 4  | 3   | 2  | 1  | 0  |
|    |                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                   |        |      |        | :      | 22-Е   | it C | ache | Tag    | Add | dress | 5          |       |          |      |        |        |     |        | Р        | D   | Р  | D   | Р    | D  | Ρ   | D  |    |    |
|    |                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                   |        |      |        |        |        |      |      |        |     |       |            |       |          |      |        |        |     |        | ;        | 3   | :  | 2   | 1    |    | (   | )  |    |    |
|    |                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                   |        |      |        |        |        |      |      |        |     |       |            |       |          |      |        |        |     |        |          |     |    | Sub | -Blo | ck | •   |    | •  |    |
|    |                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                   |        |      |        |        |        |      |      |        |     |       |            |       |          |      |        |        |     |        |          |     |    |     |      |    |     |    |    |    |
|    |                                                      | IRII                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | м                                                                 | net-r  | ocon | tlv_i  | 150    | 4      |      |      |        |     |       |            |       |          | RII  | 16     | east-i |     | ntlv.  |          | Ч   |    |     |      |    |     |    |    |    |
|    | MRUMost-recently-usedLRUNMRUNext most-recently-usedP |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                   |        |      |        |        |        |      |      |        |     |       | ıb-bl      |       |          |      |        |        |     |        |          |     |    |     |      |    |     |    |    |    |
|    |                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                   |        |      |        |        |        |      |      |        | D   |       | ıb-bl      |       |          |      |        |        |     |        |          |     |    |     |      |    |     |    |    |    |

mru, nmru, nlru, and lru have the value 0, 1, 2, or 3 representing the block number and are mutually exclusive for each set.

Figure 17. Cache Registers



SGUS025 - AUGUST 1998

#### **MP** cache architecture

The MP contains two four-way set-associative, 4K caches for instructions and data. Each cache is divided into four sets with four blocks in each set. Each block represents 256 bytes of contiguous instructions or data and is aligned to a 256-byte address boundary. Each block is partitioned into four sub-blocks that each contain sixteen 32-bit words and are aligned to 64-byte boundaries within the block. Cache misses cause one sub-block to be loaded into cache. Figure 18 shows the cache architecture for one of the four sets in each cache. Figure 19 shows how addresses map into the cache using the cache tags and address bits.



LRU Least-recently-used

NLRU Next least-recently-used

NMRU Next most-recently-used MRU

Most-recently-used

#### Figure 18. MP Cache Architecture (x4 Sets)

|   |   |   |   |   |   |   |   |   |   |   |   |   | 32- | Bit L | _ogi | cal A | ٨ddr | ess |   |   |   |   |   |   |   |   |   |   |   |   |   |  |
|---|---|---|---|---|---|---|---|---|---|---|---|---|-----|-------|------|-------|------|-----|---|---|---|---|---|---|---|---|---|---|---|---|---|--|
| 3 | 3 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 1 | 1   | 1     | 1    | 1     | 1    | 1   | 1 | 1 | 1 | 0 | 0 | 7 | 6 | 5 | 4 | 2 | 2 | 4 | 0 |  |
|   |   |   |   |   |   |   |   |   |   |   |   |   |     |       |      |       |      |     |   |   |   |   |   |   |   |   |   |   |   |   |   |  |
| т | т | т | т | Т | т | Т | Т | т | т | Т | Т | т | Т   | Т     | Т    | Т     | Т    | т   | Т | т | Т | S | S | s | s | w | W | W | W | В | в |  |





### SGUS025 - AUGUST 1998

### **MP** parameter RAM

The parameter RAM is a noncachable, 2K-byte, on-chip RAM that contains MP interrupt vectors, MP-requested TC task buffers, and a general-purpose area. Figure 20 shows the parameter RAM address map.

|                        | Suspended PT Parameters                       | 1 / |                             | ו          |
|------------------------|-----------------------------------------------|-----|-----------------------------|------------|
| 0x001010000-0x0101007F | . ·                                           |     | XPTf Linked List Start Add. |            |
| 0.001010000-0.01010071 | (128 Bytes)                                   |     | XPTe Linked List Start Add. | 1          |
| 0x001010800-0x010100DF | Reserved<br>(64 Bytes)                        |     | XPTd Linked List Start Add. | -          |
|                        | XPT Linked List Start Addresses               | ſ   | XPTc Linked List Start Add. |            |
| 0x0010100E0-0x010100FB | (60 Bytes)                                    |     | XPTb Linked List Start Add. |            |
|                        | MP Linked List Start Address                  |     | XPTa Linked List Start Add. | ]          |
| 0x0010100FC-0x010100FF |                                               |     | XPT9 Linked List Start Add. | 1          |
| 0x001010100-0x0101017F | Off-Chip to Off-Chip PT Buffer<br>(128 Bytes) |     | XPT8 Linked List Start Add. |            |
|                        | Interrupt and Trap Vectors                    |     | XPT7 Linked List Start Add. | 0x010100E0 |
| 0x001010180-0x0101021F | (160 Bytes)                                   |     | XPT6 Linked List Start Add. | 0x010100E4 |
|                        | XPT Off-Chip to Off-Chip PT Buffer            |     | XPT5 Linked List Start Add. | 0x010100E8 |
| 0x001010220-0x0101029F | (128 Bytes)                                   |     | XPT4 Linked List Start Add. | 0x010100EC |
| 0x0010102A0-0x010107FF | General-Purpose RAM                           |     | XPT3 Linked List Start Add. | 0x010100F0 |
| 0X0010102A0-0X01010/FF | (3472 Bytes)                                  | J / | XPT2 Linked List Start Add. | 0x010100F4 |
|                        |                                               | \   | XPT1 Linked List Start Add. | 0x010100F8 |

Figure 20. MP Parameter RAM



### **MP** interrupt vectors

Table 2 and Table 3 show the MP interrupts and traps and their vector addresses.

| IE BIT  |      | VECTOR            |                               |  |  |  |  |  |  |
|---------|------|-------------------|-------------------------------|--|--|--|--|--|--|
| (TRAP#) | NAME | VECTOR<br>ADDRESS | MASKABLE INTERRUPT            |  |  |  |  |  |  |
| 0       | ie   | 0x01010180        |                               |  |  |  |  |  |  |
| 2       | fi   | 0x01010188        | Floating-point invalid        |  |  |  |  |  |  |
| 3       | fz   | 0x0101018C        | Floating-point divide-by-zero |  |  |  |  |  |  |
| 5       | fo   | 0x01010194        | Floating-point overflow       |  |  |  |  |  |  |
| 6       | fu   | 0x01010198        | Floating-point underflow      |  |  |  |  |  |  |
| 7       | fx   | 0x0101019C        | Floating-point inexact        |  |  |  |  |  |  |
| 8       | fO   | 0x010101A0        | Reserved                      |  |  |  |  |  |  |
| 9       | f1   | 0x010101A4        | Reserved                      |  |  |  |  |  |  |
| 10      | ti   | 0x010101A8        | MP timer interrupt            |  |  |  |  |  |  |
| 11      | x1   | 0x010101AC        | External interrupt 1 (EINT1)  |  |  |  |  |  |  |
| 12      | x2   | 0x010101B0        | External interrupt 2 (EINT2)  |  |  |  |  |  |  |
| 14      | mf   | 0x010101B8        | Memory fault                  |  |  |  |  |  |  |
| 15      | io   | 0x010101BC        | Integer overflow              |  |  |  |  |  |  |
| 16      | p0   | 0x010101C0        | PP0 message interrupt         |  |  |  |  |  |  |
| 17      | p1   | 0x010101C4        | PP1 message interrupt         |  |  |  |  |  |  |
| 18      | p2   | 0x010101C8        | Reserved                      |  |  |  |  |  |  |
| 19      | р3   | 0x010101CC        | Reserved                      |  |  |  |  |  |  |
| 25      | mi   | 0x010101E4        | MP message interrupt          |  |  |  |  |  |  |
| 26      | рс   | 0x010101E8        | Packet-transfer complete      |  |  |  |  |  |  |
| 27      | pb   | 0x010101EC        | Packet-transfer busy          |  |  |  |  |  |  |
| 28      | bp   | 0x010101F0        | Bad packet transfer           |  |  |  |  |  |  |
| 29      | x3   | 0x010101F4        | External interrupt 3 (EINT3)  |  |  |  |  |  |  |
| 30      | x4   | 0x010101F8        | External interrupt 4 (LINT4)  |  |  |  |  |  |  |
| 31      | ре   | 0x010101FC        | PP error                      |  |  |  |  |  |  |

### Table 2. Maskable Interrupts

| TRAP<br>NUMBER  | NAME | VECTOR<br>ADDRESS           | NONMASKABLE TRAP          |  |  |  |  |  |  |  |
|-----------------|------|-----------------------------|---------------------------|--|--|--|--|--|--|--|
| 32              | e1   | 0x01010200                  | Emulator trap1 (reserved) |  |  |  |  |  |  |  |
| 33              | e2   | 0x01010204                  | Emulator trap2 (reserved) |  |  |  |  |  |  |  |
| 34              | e3   | 0x01010208                  | Emulator trap3 (reserved) |  |  |  |  |  |  |  |
| 35              | e4   | 0x0101020C                  | Emulator trap4 (reserved) |  |  |  |  |  |  |  |
| 36              | fe   | 0x01010210                  | Floating-point error      |  |  |  |  |  |  |  |
| 37              |      | 0x01010214                  | Reserved                  |  |  |  |  |  |  |  |
| 38              | er   | 0x01010218                  | Illegal MP instruction    |  |  |  |  |  |  |  |
| 39              |      | 0x0101021C                  | Reserved                  |  |  |  |  |  |  |  |
| 72<br>to<br>415 |      | 0x010102A0 to<br>0x010107FC | System- or user-defined   |  |  |  |  |  |  |  |



#### SGUS025 – AUGUST 1998

#### **MP** opcode formats

The three basic classes of MP instruction opcodes are: short immediate, three register, and long immediate. Figure 21 shows the opcode structure for each class of instruction.

|                    | 31 |      | 27 | 26 |          | 22 | 21 |    | 15             | 14      |    |                  |          | 0 |
|--------------------|----|------|----|----|----------|----|----|----|----------------|---------|----|------------------|----------|---|
| Short<br>Immediate |    | Dest |    |    | Source 2 |    |    |    | Opcode         |         |    | 15-Bit Immediate |          |   |
|                    | 31 |      | 27 | 26 |          | 22 | 21 | 20 | 19             | 13      | 12 | 2 11 5           | 4        | 0 |
| Three<br>Register  |    | Dest |    |    | Source 2 |    | 1  | 1  | Opcode         |         | 0  | Options          | Source 1 |   |
|                    | 31 |      | 27 | 26 |          | 22 | 21 | 20 | 19             | 13      | 12 | 2 11 5           | 4        | 0 |
| Long<br>Immediate  |    | Dest |    |    | Source 2 |    | 1  | 1  | Opcode         |         | 1  | Options          | Source 1 |   |
|                    |    |      |    |    |          |    |    |    | 32-Bit Long Im | mediate | •  |                  |          |   |

#### Figure 21. MP Opcode Formats

#### MP opcode summary

Table 4 through Table 6 show the opcode formats for the MP. Table 7 summarizes the master processor instruction set.



SGUS025 - AUGUST 1998

#### MP opcode summary (continued)

#### 3 3 2 2 2 2 2 2 2 2 2 2 1 1 1 1 1 1 1 1 0 0 0 0 0 0 0 0 0 0 2 0 9 7 6 4 0 7 6 0 8 5 3 1 8 4 3 2 9 8 7 6 5 4 0 1 9 5 1 3 2 1 illop0 Dest Source 0 0 0 0 0 0 0 **Unsigned Immediate** Е 0 Unsigned Trap Number trap 0 0 0 0 0 1 \_ \_ 0 0 0 0 0 1 0 **Unsigned Immediate** cmnd \_ \_ \_ \_ 0 0 0 0 1 0 0 Unsigned Control Register Number rdcr Dest swcr Dest Source 0 0 0 0 1 0 1 Unsigned Control Register Number brcr 0 0 0 0 1 1 0 Unsigned Control Register Number \_ \_ \_ shift.dz Dest Source 0 0 0 1 0 0 0 n Endmask Rotate 0 Endmask shift.dm Dest Source 0 0 1 0 n Rotate 0 1 shift.ds Dest Source 0 0 0 1 0 1 0 i n Endmask Rotate shift.ez Dest Source 0 0 1 0 1 i n Endmask Rotate 0 1 shift.em Dest Source 0 0 0 0 i. n Endmask Rotate 0 1 1 shift.es 0 0 0 Endmask Rotate Dest Source 0 1 1 1 n i shift.iz Source 0 Endmask Rotate Dest 0 0 1 0 n 1 1 i. shift.im Dest Source 0 0 0 1 1 1 Endmask Rotate 1 n 0 0 and.tt Source2 0 0 0 **Unsigned Immediate** Dest 1 1 Source2 0 0 and.tf Dest 0 1 0 1 0 **Unsigned Immediate** and.ft Dest Source2 0 0 0 1 0 0 **Unsigned Immediate** Dest Source2 0 0 0 1 0 **Unsigned Immediate** xor 1 or.tt Dest Source2 0 0 0 1 1 **Unsigned Immediate** 1 1 and.ff Dest Source2 0 0 0 0 0 **Unsigned Immediate** 1 1 Dest Source2 0 0 0 0 **Unsigned Immediate** xnor 1 1 1 or.tf Dest Source2 0 0 1 1 0 1 1 **Unsigned Immediate** Source2 0 **Unsigned Immediate** or.ft Dest 0 0 1 1 1 1 or.ff Dest Source2 **Unsigned Immediate** 0 0 1 1 1 1 0 ld Dest Base 0 1 0 0 Μ SZ Signed Offset 0 1 Μ SZ Signed Offset ld.u Dest Base 0 1 st Source Base 0 1 1 0 Μ SZ Signed Offset \_ \_ F 0 1 1 1 Μ 0 0 Signed Offset dcache \_ Source2 Link 0 0 0 0 0 А Signed Offset 1 bsr 0 0 0 0 Signed Offset jsr Link Base 1 1 А 0 BITNUM 0 0 1 0 А Signed Offset bbz Source 1 bbo BITNUM Source 0 0 1 0 1 А Signed Offset 1 bcnd Cond Source 0 0 1 1 0 A Signed Offset 1 Source2 0 0 0 Signed Immediate cmp Dest 1 1 1 0 add Dest Source2 1 0 1 1 0 0 U Signed Immediate sub Dest Source2 1 0 U Signed Immediate 1 0 1 1

#### **Table 4. Short-Immediate Opcodes**

Reserved bit (code as 0)

A Annul delay slot instruction if branch taken

E Emulation trap bit

F Clear present flags

i Invert endmask

M Modify, write modified address back to register

n Rotate sense for shifting

SZ Size (0 = byte, 1 = halfword, 2 = word, 3 = doubleword)

U Unsigned form



#### SGUS025 - AUGUST 1998

### MP opcode summary (continued)

|          |            |        |        |        |        |        |        |        |        |        | 5      |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |            |           |        |        |            |   |
|----------|------------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|------------|-----------|--------|--------|------------|---|
|          | 3<br>1     | 3<br>0 | 2<br>9 | 2<br>8 | 2<br>7 | 2<br>6 | 2<br>5 | 2<br>4 | 2<br>3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3 | 1<br>2 | 1<br>1 | 1<br>0 | 0<br>9 | 0<br>8 | 0<br>7 | 0<br>6 | 0<br>5     | 0<br>4    | 0<br>3 | 0<br>2 | 0 0<br>1 0 |   |
| trap     | <u> </u>   | _      | _      | _      | Ē      |        | _      | _      | _      | _      | 1      | 1      | 0      | 0      | 0      | 0      | 0      | 0      | 1      |        | _      | _      | _      | _      | _      | _      | _          | Ē         |        | ID TF  |            | ٦ |
| cmnd     | <u> </u> _ | _      | _      | _      | -      | -      | _      | _      | _      | _      | 1      | 1      | 0      | 0      | 0      | 0      | 0      | 1      | 0      | 1      | -      | _      | _      | _      | _      | _      | _          |           | Sc     |        |            |   |
| rdcr     |            |        | Dest   |        |        | -      | _      | _      | _      | _      | 1      | 1      | 0      | 0      | 0      | 0      | 1      | 0      | 0      |        | -      | _      | _      | _      | _      | _      | _          |           | IN     | ID CF  | 2          | 1 |
| swcr     |            |        | Dest   |        |        |        | S      | ouro   | e      |        | 1      | 1      | 0      | 0      | 0      | 0      | 1      | 0      | 1      | 1      | _      | _      | _      | _      | _      | _      | _          |           |        | ID CF  |            |   |
| brcr     | -          | _      | _      | _      | _      | -      | _      | _      | _      | _      | 1      | 1      | 0      | 0      | 0      | 0      | 1      | 1      | 0      | I      | -      | _      | _      | _      | _      | _      | _          |           | IN     | ID CF  | ۲          | 1 |
| shift.dz |            |        | Dest   |        |        |        | S      | our    | e      |        | 1      | 1      | 0      | 0      | 0      | 1      | 0      | 0      | 0      | T      | i      | n      |        | En     | dma    | ısk    |            |           | R      | otate  |            | ٦ |
| shift.dm |            |        | Dest   |        |        |        | S      | ouro   | e      |        | 1      | 1      | 0      | 0      | 0      | 1      | 0      | 0      | 1      | 1      | l i    | n      |        | En     | dma    | sk     |            |           | R      | otate  | J          |   |
| shift.ds |            |        | Dest   |        |        |        | S      | ouro   | e      |        | 1      | 1      | 0      | 0      | 0      | 1      | 0      | 1      | 0      | 1      | l i    | n      |        | En     | dma    | sk     |            |           | R      | otate  | ,          |   |
| shift.ez |            |        | Dest   |        |        |        | S      | ouro   | e      |        | 1      | 1      | 0      | 0      | 0      | 1      | 0      | 1      | 1      | 1      | l i    | n      |        | En     | dma    | sk     |            |           | R      | otate  |            |   |
| shift.em |            |        | Dest   |        |        |        | S      | ouro   | e      |        | 1      | 1      | 0      | 0      | 0      | 1      | 1      | 0      | 0      | 1      | l i    | n      |        | En     | dma    | ısk    |            |           | R      | otate  |            |   |
| shift.es |            |        | Dest   |        |        |        | S      | ouro   | e      |        | 1      | 1      | 0      | 0      | 0      | 1      | 1      | 0      | 1      | 1      | l i    | n      |        | En     | dma    | sk     |            |           | R      | otate  | ł          |   |
| shift.iz |            |        | Dest   |        |        |        | S      | ouro   | e      |        | 1      | 1      | 0      | 0      | 0      | 1      | 1      | 1      | 0      | 1      | l i    | n      |        | En     | dma    | sk     |            |           | R      | otate  | l.         |   |
| shift.im |            |        | Dest   |        |        |        | S      | ouro   | e      |        | 1      | 1      | 0      | 0      | 0      | 1      | 1      | 1      | 1      | I.     | i      | n      |        | En     | dma    | isk    |            |           | R      | otate  |            |   |
| and.tt   |            |        | Dest   |        |        |        | S      | ourc   | e2     |        | 1      | 1      | 0      | 0      | 1      | 0      | 0      | 0      | 1      | 1      | -      | -      | -      | -      | -      | -      | -          |           | Sc     | ource  | 1          |   |
| and.tf   |            |        | Dest   |        |        |        | S      | ourc   | e2     |        | 1      | 1      | 0      | 0      | 1      | 0      | 0      | 1      | 0      | 1      | -      | -      | -      | -      | -      | -      | -          | - Source1 |        |        | 1          |   |
| and.ft   |            |        | Dest   |        |        |        | S      | ourc   | e2     |        | 1      | 1      | 0      | 0      | 1      | 0      | 1      | 0      | 0      | 1      | -      | -      | -      | -      | -      | -      | -          | - Source1 |        |        | 1          |   |
| xor      |            |        | Dest   |        |        |        | S      | ourc   | e2     |        | 1      | 1      | 0      | 0      | 1      | 0      | 1      | 1      | 0      | 1      | -      | -      | -      | -      | -      | -      | -          |           | Sc     | ource  | 1          |   |
| or.tt    |            |        | Dest   |        |        |        | S      | ourc   | e2     |        | 1      | 1      | 0      | 0      | 1      | 0      | 1      | 1      | 1      | 1      | -      | -      | -      | -      | -      | -      | -          |           | Sc     | ource  | 1          |   |
| and.ff   |            |        | Dest   |        |        |        | S      | ourc   | e2     |        | 1      | 1      | 0      | 0      | 1      | 1      | 0      | 0      | 0      | 1      | -      | _      | _      | —      | -      | _      | -          |           | Sc     | ource  | 1          |   |
| xnor     |            |        | Dest   |        |        |        | S      | ourc   | e2     |        | 1      | 1      | 0      | 0      | 1      | 1      | 0      | 0      | 1      | 1      | -      | _      | _      | —      | -      | _      | -          |           | Sc     | ource  | 1          |   |
| or.tf    |            |        | Dest   |        |        |        | S      | ourc   | e2     |        | 1      | 1      | 0      | 0      | 1      | 1      | 0      | 1      | 1      | 1      | -      | -      | -      | -      | -      | -      | -          |           | Sc     | ource  | 1          |   |
| or.ft    |            |        | Dest   |        |        |        | S      | ourc   | e2     |        | 1      | 1      | 0      | 0      | 1      | 1      | 1      | 0      | 1      | 1      | -      | -      | -      | -      | -      | -      | -          |           | Sc     | ource  | 1          |   |
| or.ff    |            |        | Dest   |        |        |        | S      | ourc   | e2     |        | 1      | 1      | 0      | 0      | 1      | 1      | 1      | 1      | 0      | I      | _      | -      | _      | -      | -      | -      | _          |           | Sc     | ource  | 1          |   |
| ld       |            |        | Dest   |        |        |        | ļ      | Base   | Э      |        | 1      | 1      | 0      | 1      | 0      | 0      | м      | s      | Z      | 1      | s      | D      | -      | -      | -      | -      | -          |           | C      | Offset |            |   |
| ld.u     |            |        | Dest   |        |        |        | ļ      | Base   | Э      |        | 1      | 1      | 0      | 1      | 0      | 1      | м      | s      | Z      | 1      | s      | D      | -      | -      | -      | -      | -          |           | C      | Offset |            |   |
| st       |            | S      | ourc   | e      |        |        |        | Base   | Э      |        | 1      | 1      | 0      | 1      | 1      | 0      | м      | s      | Z      | 1      | s      | D      | -      | -      | -      | -      | _          |           | 0      | Offset |            |   |
| dcache   | <u> </u>   | -      | -      | -      | F      |        | S      | ourc   | e2     |        | 1      | 1      | 0      | 1      | 1      | 1      | М      | 0      | 0      | 1      | 0      | 0      | -      | -      | -      | -      | _          |           | S      | ource  | ;          |   |
| bsr      |            |        | Link   |        |        | -      | -      | -      | -      | -      | 1      | 1      | 1      | 0      | 0      | 0      | 0      | 0      | А      | 1      | -      | -      | -      | -      | -      | -      | -          |           | C      | Offset |            |   |
| jsr      |            |        | Link   |        |        |        |        | Base   | Э      |        | 1      | 1      | 1      | 0      | 0      | 0      | 1      | 0      | А      | 1      | _      | -      | -      | -      | -      | -      | -          |           | C      | Offset |            |   |
| bbz      |            | BI     | TNU    | Μ      |        |        | S      | ouro   | e      |        | 1      | 1      | 1      | 0      | 0      | 1      | 0      | 0      | А      | 1      | -      | -      | -      | -      | -      | -      | -          |           | Т      | arget  |            |   |
| bbo      |            | BI     | TNU    | Μ      |        |        | S      | Sourc  | e      |        | 1      | 1      | 1      | 0      | 0      | 1      | 0      | 1      | А      | 1      | -      | -      | -      | -      | -      | -      | -          | Target    |        |        |            |   |
| bcnd     |            | (      | Cond   | 1      |        |        | S      | Sourc  | e      |        | 1      | 1      | 1      | 0      | 0      | 1      | 1      | 0      | А      | 1      | _      | -      | -      | -      | -      | -      | _          | - Target  |        |        |            |   |
| cmp      |            |        | Dest   |        |        |        | S      | ourc   | e2     |        | 1      | 1      | 1      | 0      | 1      | 0      | 0      | 0      | 0      | 1      | -      | -      | -      | -      | -      | -      | _          | - Source1 |        |        | 1          |   |
| add      |            |        | Dest   |        |        |        | S      | ourc   | e2     |        | 1      | 1      | 1      | 0      | 1      | 1      | 0      | 0      | U      | 1      | -      | -      | -      | -      | -      | -      | -          |           | Sc     | ource  | 1          |   |
| sub      |            |        | Dest   |        |        |        | S      | ourc   | e2     |        | 1      | 1      | 1      | 0      | 1      | 1      | 0      | 1      | U      | Ι      | -      | -      | -      | -      | -      | -      | – – Source |           |        |        | 1          |   |

### Table 5. Long-Immediate and Three-Register Opcodes

Reserved bit (code as 0)

D Direct external access bit

E Emulation trap bit

F Clear present flags

i Invert endmask

Long immediate

L

M Modify, write modified address back to register

n Rotate sense for shifting

S Scale offset by data size

SZ Size (0 = byte, 1 = halfword, 2 = word, 3 = doubleword



SGUS025 - AUGUST 1998

#### MP opcode summary (continued)

| Table 6. Miscellaneous | Instruction | Opcodes |
|------------------------|-------------|---------|
|------------------------|-------------|---------|

|           | 3 3<br>1 0 | 2 2<br>9 8 | 2<br>7 | 2<br>6 | 2 2   | 2 2<br>4 3 | 2<br>2 | 2<br>1 | 2<br>0 | 1<br>9 | 1<br>8 | 1<br>7 | 1<br>6 | 1<br>5 | 1<br>4 | 1<br>3  | 1<br>2 | 1<br>1 | 1<br>0 | 0<br>9 | 0<br>8 | 0<br>7 | 0<br>6 | 0<br>5 | 0<br>4  | 0<br>3 | 0<br>2 | 0<br>1 | 0<br>0 |
|-----------|------------|------------|--------|--------|-------|------------|--------|--------|--------|--------|--------|--------|--------|--------|--------|---------|--------|--------|--------|--------|--------|--------|--------|--------|---------|--------|--------|--------|--------|
| vadd      | Mem        | Src/D      | st     | So     | ource | 2/De       | est    | 1      | 1      | 1      | 1      | 0      | _      | 0      | 0      | 0       | Ι      | -      | m      | Ρ      | -      | d      | m      | s      | Source1 |        |        |        |        |
| vsub      | Mem        | Src/D      | st     | So     | ource | 2/De       | est    | 1      | 1      | 1      | 1      | 0      | _      | 0      | 0      | 1       | Т      | -      | m      | Р      | -      | d      | m      | s      |         | So     | ource  | ÷1     |        |
| vmpy      | Mem        | Src/D      | st     | So     | ource | 2/De       | est    | 1      | 1      | 1      | 1      | 0      | _      | 0      | 1      | 0       | Т      | -      | m      | Р      | -      | d      | m      | s      |         | So     | ource  | ÷1     |        |
| vmsub     | Mem        | Src/D      | st     |        | D     | est        |        | 1      | 1      | 1      | 1      | 0      | а      | 0      | 1      | 1       | Т      | а      | m      | Р      | z      | -      | m      | -      |         | So     | ource  | ÷1     |        |
| vrnd(FP)  | Mem        | Src/D      | st     |        | D     | est        |        | 1      | 1      | 1      | 1      | 0      | а      | 1      | 0      | 0       | T      | а      | m      | Р      | P      | D      | m      | s      |         | So     | ource  | ÷1     |        |
| vrnd(Int) | Mem        | Src/D      | st     |        | D     | est        |        | 1      | 1      | 1      | 1      | 0      | _      | 1      | 0      | 1       | Т      | -      | m      | Р      | -      | d      | m      | s      |         | So     | ource  | ÷1     |        |
| vmac      | Mem        | Src/D      | st     |        | Sou   | rce2       |        | 1      | 1      | 1      | 1      | 0      | а      | 1      | 1      | 0       | Ι      | а      | m      | Ρ      | Ζ      | -      | m      | -      |         | So     | ource  | ÷1     |        |
| vmac      | Mem        | Src/D      | st     |        | Sou   | rce2       |        | 1      | 1      | 1      | 1      | 0      | а      | 1      | 1      | 1       | Ι      | а      | m      | Ρ      | Ζ      | -      | m      | -      | Source1 |        |        |        |        |
| fadd      | 0          | Dest       |        |        | Sou   | rce2       |        | 1      | 1      | 1      | 1      | 1      | 0      | 0      | 0      | 0       | Ι      | -      | PI     | D      | P      | 2      | Р      | 1      | Source1 |        |        |        |        |
| fsub      | C          | Dest       |        |        | Sou   | rce2       |        | 1      | 1      | 1      | 1      | 1      | 0      | 0      | 0      | 1       | Т      | -      | PI     | D      | P      | 2      | P      | 1      |         | So     | ource  | ÷1     |        |
| fmpy      | C          | Dest       |        |        | Sou   | rce2       |        | 1      | 1      | 1      | 1      | 1      | 0      | 0      | 1      | 0       | Т      | -      | PI     | D      | P      | 2      | P      | 1      |         | So     | ource  | ÷1     |        |
| fdiv      | C          | Dest       |        |        | Sou   | rce2       |        | 1      | 1      | 1      | 1      | 1      | 0      | 0      | 1      | 1       | Т      | -      | PI     | D      | P      | 2      | P      | 1      |         | So     | ource  | ÷1     |        |
| frndx     | C          | Dest       |        | -      |       |            | _      | 1      | 1      | 1      | 1      | 1      | 0      | 1      | 0      | 0       | Т      | -      | PI     | D      | RI     | М      | P      | 1      |         | So     | ource  | ÷1     |        |
| fcmp      | C          | Dest       |        |        | Sou   | rce2       | 1 1    |        | 1      | 1      | 1      | 1      | 0      | 1      | 0      | 0 1 1 – |        | -      | -      | -      | P      | 2      | P1     |        | Source1 |        |        |        |        |
| fsqrt     | 0          | Dest       |        | -      |       |            | -      | 1      | 1      | 1      | 1      | 1      | 0      | 1      | 1      | 1       | Т      | -      | P      | D      | -      | -      | Р      | 1      |         | So     | ource  | ÷1     |        |
| lmo       | C          | Dest       |        |        | Sou   | urce       |        | 1      | 1      | 1      | 1      | 1      | 1      | 0      | 0      | 0       | -      | -      | -      | -      | -      | -      | -      | -      | -       | -      | -      | -      | -      |
| rmo       | C          | Dest       |        |        | Sou   | urce       |        | 1      | 1      | 1      | 1      | 1      | 1      | 0      | 0      | 1       | -      | -      | -      | -      | -      | -      | -      | -      |         |        |        | -      |        |
| estop     |            |            | -      | -      |       |            | _      | 1      | 1      | 1      | 1      | 1      | 1      | 1      | 1      | 0       | -      | -      | _      | -      | _      | -      | -      | -      |         |        |        | -      |        |
| illopF    |            |            | -      | -      |       |            | _      | 1      | 1      | 1      | 1      | 1      | 1      | 1      | 1      | 1       | С      | -      | _      | -      | -      | -      | _      | -      |         |        |        | _      |        |

Reserved bit (code as 0) \_

Floating-point accumulator select а

Constant operands rather than register С

- d Destination precision for vector (0 = sp, 1 = dp)
- Long immediate 32-bit data Ι
- m Parallel memory operation specifier
- Mem Src/Dst Vector store or load source/dst register

Dest Destination register

- Ρ Destination precision for parallel load/store (0 = single, 1 = double)
- P1 Precision of source1 operand

P2 Precision of source2 operand

- Precision of destination result PD
- Rounding Mode (0 = N, 1 = Z, 2 = P, 3 = M) RM
- S Scale offset by data size
- Ζ Use 0 rather than accumulator



SGUS025 – AUGUST 1998

### MP opcode summary (continued)

| INSTRUCTION | DESCRIPTION                    | INSTRUCTION | DESCRIPTION                                                  |
|-------------|--------------------------------|-------------|--------------------------------------------------------------|
| add         | Signed integer add             | or.ff       | Bitwise OR with 1s complement                                |
| and.tt      | Bitwise AND                    | or.ft       | Bitwise OR with 1s complement                                |
| and.ff      | Bitwise AND with 1s complement | or.tf       | Bitwise OR with 1s complement                                |
| and.ft      | Bitwise AND with 1s complement | rdcr        | Read control register                                        |
| and.tf      | Bitwise AND with 1s complement | rmo         | Rightmost one                                                |
| bbo         | Branch bit one                 | shift.dz    | Shift, disable mask, zero extend                             |
| bbz         | Branch bit zero                | shift.dm    | Shift, disable mask, merge                                   |
| bcnd        | Branch conditional             | shift.ds    | Shift, disable mask, sign extend                             |
| br          | Branch always                  | shift.ez    | Shift, enable mask, zero extend                              |
| brcr        | Branch control register        | shift.em    | Shift, enable mask, merge                                    |
| bsr         | Branch and save return         | shift.es    | Shift, enable mask, sign extend                              |
| cmnd        | Send command                   | shift.iz    | Shift, invert mask, zero extend                              |
| cmp         | Integer compare                | shift.im    | Shift, invert mask, merge                                    |
| dcache      | Flush data cache sub-block     | st          | Store register into memory                                   |
| estop       | Emulation stop                 | sub         | Signed integer subtract                                      |
| fadd        | Floating-point add             | swcr        | Swap control register                                        |
| fcmp        | Floating-point compare         | trap        | Тгар                                                         |
| fdiv        | Floating-point divide          | vadd        | Vector floating-point add                                    |
| fmpy        | Floating-point multiply        | vmac        | Vector floating-point multiply and add to accumulator        |
| frndx       | Floating-point convert/round   | vmpy        | Vector floating-point multiply                               |
| fsqrt       | Floating-point square root     | vmsc        | Vector floating-point multiply and subtract from accumulator |
| fsub        | Floating-point subtract        | vmsub       | Vector floating-point subtract accumulator<br>from source    |
| illop       | Illegal operation              | vrnd(FP)    | Vector round with floating-point input                       |
| jsr         | Jump and save return           | vrnd(Int)   | Vector round with integer input                              |
| ld          | Load signed into register      | vsub        | Vector floating-point subtract                               |
| ld.u        | Load unsigned into register    | xnor        | Bitwise exclusive NOR                                        |
| Imo         | Leftmost one                   | xor         | Bitwise exclusive OR                                         |
| or.tt       | Bitwise OR                     |             |                                                              |

### Table 7. Summary of MP Opcodes



SGUS025 - AUGUST 1998

### **PP** architecture

The parallel processor (PP) is a 32-bit integer DSP optimized for imaging and graphics applications. Each PP can execute in parallel: a multiply, ALU operation, and two memory accesses within a single instruction. This internal parallelism allows a single PP to achieve over 500 million operations per second for certain algorithms. The PP has a three-input ALU that supports all 256 three input Boolean combinations and many combinations of arithmetic and Boolean functions. Data-merging and bit-to-byte, bit-to-word, and bit-to-halfword translations are supported by hardware in the input data path to the ALU. Typical tasks performed by a PP include:

- Pixel-intensive processing
  - Motion estimation
  - Convolution
  - PixBLTs
  - Warp
  - Histogram
  - Mean square error
- Domain transforms
  - Discrete Cosine Transform (DCT)
  - Fast Fourier Transform (FFT)
  - Hough
- Core graphics functions
  - Line
  - Circle
  - Shaded fills
  - Fonts
- Image analysis
  - Segmentation
  - Feature extraction
- Bit-stream encoding/decoding
  - Data merging
  - Table look-ups



#### SGUS025 – AUGUST 1998

#### PP functional block diagram

Figure 22 shows a block diagram of a parallel processor. Key features of the PP include:

- 64-bit instruction word (supports multiple parallel operations)
- Three-stage pipeline for fast instruction cycle
- Numerous registers
  - 8 data, 10 address, 6 index registers
  - 20 other user-visible registers
- Data Unit
  - 16 x 16 integer multiplier (optional dual 8 x 8)
  - Splittable 3-input ALU
  - 32-bit barrel rotator
  - Mask generator
  - Multiple status flag expander for translations to/from 1 bit-per-pixel space.
  - Conditional assignment of data unit results
  - Conditional source selection
  - Special processing hardware
     Leftmost one/rightmost one
     Leftmost bit change/rightmost bit change
- Memory addressing
  - Two address units (global and local) provide up to two 32-bit accesses in parallel with data unit operation.
  - 12 addressing modes (immediate and indexed)
  - Byte, halfword, and word addressability
  - Scaled indexed addressing
  - Conditional assignment for loads
  - Conditional source selection for stores
- Program flow
  - Three hardware loop controllers Zero overhead looping/ branching Nested loops Multiple loop endpoints
  - Instruction cache management
  - PC mapped to register file
  - Interrupts for messages and context switching
- Algebraic assembly language



SGUS025 - AUGUST 1998







#### SGUS025 - AUGUST 1998

### **PP registers**

The PP contains many general-purpose registers, status registers, and configuration registers. All PP registers are 32-bit registers. Figure 23 shows the accessible registers of the PP blocks.

#### **Data-Unit Registers**



#### Address-Unit Registers



Prgram Flow Control (PFC) Unit Registers

**PC-Related Registers** 

| 0               |
|-----------------|
| pc (br, call)   |
| iprs            |
| ipa (read only) |
| ipe (read only) |
|                 |

Cache Tags tag0 (read only)

tag1 (read only) tag2 (read only)

tag3 (read only)

Loop Addresses Is0 Is1 Is2 Ie0 Ie1 Ie2

Loop Control

lctl



| Communications |
|----------------|
| comm           |
| Interrupts     |

Intflg

Figure 23. PP Registers



### PP data-unit registers

The data unit contains eight 32-bit general-purpose data registers (d0–d7) referred to as the D registers. The d0 register also acts as the control register for extended ALU (EALU) operations.

### d0 register

Figure 24 shows the format when d0 is used as the EALU control register.

| 31 | 30  | 29                          | 28                 | 27                   | 26                                         | 25                         | 24            | 23  | 22   | 21   | 20  | 19 | 18 | 17 | 16 | 15 | 14                            | 13                   | 12                            | 11                         | 10                          | 9                                   | 8                   | 7            | 6        | 5 | 4 | 3 | 2   | 1  | 0 |
|----|-----|-----------------------------|--------------------|----------------------|--------------------------------------------|----------------------------|---------------|-----|------|------|-----|----|----|----|----|----|-------------------------------|----------------------|-------------------------------|----------------------------|-----------------------------|-------------------------------------|---------------------|--------------|----------|---|---|---|-----|----|---|
|    | FΜ  | OD                          |                    | А                    |                                            | ΕA                         | LU            | Fun | ctio | n Co | ode |    | С  | Ι  | S  | Ν  | Е                             | F                    | Т                             | -                          | -                           | DN                                  | /IS                 | М            | R        | U |   |   | DBR | ۲. |   |
|    | FMG | DD<br>A<br>C<br>I<br>S<br>N | A<br>E<br>In<br>Si | rithr<br>ALU<br>vert | tion<br>netio<br>car<br>car<br>car<br>exte | c er<br>ry-l<br>ry-l<br>nd | nab<br>n<br>n | le  |      |      |     |    | -  | -  |    |    | E<br>F<br>//S<br>M<br>R<br>3R | E)<br>De<br>Sp<br>Re | kpai<br>efau<br>olit i<br>oun | nde<br>ilt m<br>mul<br>ded | d m<br>nulti<br>tiply<br>mu | iple<br>ultip<br>ply<br>(<br>ultipl | ole f<br>shif<br>ly | lags<br>t an | s<br>nou |   |   |   |     |    |   |

## Figure 24. d0 Format for EALU Operations

### multiple flags (mf) register

The mf register records status information from each split ALU segment for multiple arithmetic operations. The mf register can be expanded to generate a mask for the ALU. Figure 25 shows the mf register format.

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0         |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----------|
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | $\square$ |

# Figure 25. mf Register Format

## status register (sr)

The sr contains status and control bits for the PP ALU. See Figure 26.



### Figure 26. sr Format

# PP address-unit registers

#### address registers

The address unit contains ten 32-bit address registers which contain the base address for address computations or which can be used for general-purpose data. The registers a0 – a4 are used for local-address computations and registers a8–a12 are used for global-address computations.



#### SGUS025 – AUGUST 1998

#### index registers

The six 32-bit index registers contain index values for use with the address registers in address computations or they can be used for general-purpose data. Registers x0-x3 are used by the local-address unit and registers x8-x9 are used by the global-address unit.

### stack pointer (sp)

The sp contains the address of the top of the PP's system stack. The stack pointer is addressed as a6 by the local-address unit and as a14 by the global-address unit. Figure 27 shows the sp register format.

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18   | 17   | 16   | 15   | 14  | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|------|------|------|------|-----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|    |    |    |    |    |    |    |    |    |    |    |    | Wo | rd-A | lign | ed A | \ddr | ess |    |    |    |    |   |   |   |   |   |   |   |   | 0 | 0 |

## Figure 27. sp Register Format

#### zero registers

The zero registers are read-as-zero address registers for the local address unit (a7) and global-address unit (a15). Writes to the registers are ignored and can be specified when operational results are to be discarded.

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

### Figure 28. Zero Registers

# PP program flow control (PFC) unit registers

### loop registers

The loop registers control three levels of zero-overhead loops. The 32-bit loop-start registers (|s0 - |s2) and loop-end registers (|e0 - |e2) contain the starting and ending addresses for the loops. The loop-counter registers (|c0 - |c2) contain the number of repetitions remaining in their associated loops. The |r0 - |r2 registers are loop reload registers used to support nested loops. The format for the loop-control (|ct|) register is shown in Figure 29. There are also six special write-only mappings of the loop-reload registers. The |rs0 - |rs2 codes are used for fast initialization of |sn, |rn, and |cn registers for multi-instruction loops while the |rse0 - |rse2 codes are used for single instruction-loop fast initialization.



### Figure 29. Ictl Register

## pipeline registers

The PFC unit contains a pointer to each stage of the PP pipeline. The pc contains the program counter which points to the instruction being fetched. The ipa points to the instruction in the address stage of the pipeline and the ipe points to the instruction in the execute stage of the pipeline. The instruction pointer return-from-subroutine (iprs) register contains the return address for a subroutine call.



SGUS025 - AUGUST 1998



# **Figure 30. Pipeline Registers**

### interrupt registers

The interrupt-enable (inten) register allows individual interrupts to be enabled and configures the interrupt flag (intflg) register operation. The intflg register contains the interrupt flag bits. Interrupt priority increases moving from left to right on intflg.







#### SGUS025 – AUGUST 1998

### communication (comm) register

The comm register contains the packet-transfer handshake bits and PP indicator bits.

| 31 30 29 | 28 27 26   | 25 24    | 23    | 22 21  | 20   | 19         | 18 | 17 | 16 | 15 | 14 | 13 | 12   | 11   | 10   | 9    | 8    | 7    | 6 | 5 | 4 | 3 | 2 | 1   | 0 |
|----------|------------|----------|-------|--------|------|------------|----|----|----|----|----|----|------|------|------|------|------|------|---|---|---|---|---|-----|---|
| H S Q    | P – –      |          | -     |        | -    | -          | -  | -  | -  | -  | -  | -  | -    | -    | -    | -    | -    | -    | - | - | - | - |   | PP# |   |
| Н        | High-prio  | ority pa | acket | trans  | fer  | -          |    |    |    | P  | P# | PF | P Nu | umb  | er ( | read | d or | nlv) |   |   |   |   |   |     |   |
|          | Packet-tr  |          |       |        |      |            |    |    |    |    |    |    |      | – Pl | •    |      |      |      | 2 |   |   |   |   |     |   |
| Q        | Packet tra | ansfer   | que   | ued    |      |            |    |    |    |    |    | (  | 001  | – Pł | P1   | 01   | 1 –  | PP3  | ; |   |   |   |   |     |   |
| Р        | Submit p   | acket    | trans | fer re | ques | t          |    |    |    |    |    | 1x | x –  | Not  | im   | plen | nen  | ted  |   |   |   |   |   |     |   |
|          |            |          |       |        |      | <b>F</b> : |    | 20 |    |    |    |    |      |      |      |      |      |      |   |   |   |   |   |     |   |

Figure 32. comm Register

### cache-tag registers

The tag0 – tag3 registers contain the tag address and sub-block present bits for each cache block.

| 23-Bit Tag Address P P P P L | 31 30 29 28 | 28 27 26 25 | 24 23 | 22  | 21    | 20   | 19   | 18   | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 0 |
|------------------------------|-------------|-------------|-------|-----|-------|------|------|------|----|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-----|
|                              |             |             |       | 23- | Bit T | ag A | Addı | ress |    |    |    |    |    |    |    |    |   | Ρ | Р | Р | Ρ | - | - | - | LRU |

P Present bit

LRU Least-recently-used code 00 – Most-recently-used (MRU) 10 – next LRU 01 – next MRU (NMRU) 11 – LRU Sub-Block # 3 2 1 0

### Figure 33. Cache-Tag Registers

# PP cache architecture

Each PP has its own 2K-byte instruction cache. Each cache is divided into four blocks and each block is divided into four sub-blocks containing 16 64-bit instructions each. Cache misses cause one sub-block to be loaded into cache. Figure 34 shows the cache architecture for one of the four sets in each cache. Figure 35 shows how addresses map into the cache using the cache tags and address bits.



# Figure 34. PP Cache Architecture



sub-sub-block





## PP parameter RAM

The parameter RAM is a 2K-byte, on-chip RAM which contains PP-interrupt vectors, PP-requested TC task buffers, and a general-purpose area. The parameter RAM does not use the cache memory. Figure 35 shows the parameter RAM address map.



Figure 36. PP Parameter RAM Address Map

# **PP-interrupt vectors**

The PP interrupts and their vector addresses are shown in Table 8.

| Table 8. PP-Interrupt Vectors | Table | 8. PP | -Interrupt | Vectors |
|-------------------------------|-------|-------|------------|---------|
|-------------------------------|-------|-------|------------|---------|

| NAME   | VECTOR<br>ADDRESS | INTERRUPT              |
|--------|-------------------|------------------------|
| TASK   | 0x0100#1B8        | Task Interrupt         |
| PTQ    | 0x0100#1C4        | Packet Transfer Queued |
| PTERR  | 0x0100#1C8        | Packet-Transfer Error  |
| PTEND  | 0x0100#1CC        | Packet Transfer End    |
| MPMSG  | 0x0100#1D0        | MP Message             |
| PP0MSG | 0x0100#1E0        | PP0 Message            |
| PP1MSG | 0x0101#1E4        | PP1 Message            |



SGUS025 - AUGUST 1998

## PP data-unit architecture

The data unit has independent data paths for the ALU and the multiplier, each with its own set of hardware functions. The multiplier data path includes a  $16 \times 16$  multiplier, a halfword swapper, and rounding hardware. The ALU data path includes a 32-bit three-input ALU, a barrel rotator, mask generator, multiple flag (mf) expander, left/rightmost one and left/rightmost bit-change logic, and several multiplexers. Figure 37 shows the data-unit block diagram.



D reg or sometimes 5/32-bit immediate dst2 D reg only scr2 scr3 D reg only dstc D reg only (destination companion reg source) scr4 D reg only 0x1 Constant 0

dst/dst1 Any register

- Constant
- d0 5 LSBs of d0

Figure 37. Data-Unit Block Diagram



# PP data-unit architecture (continued)

The PP's ALU can be split into one 32-bit ALU, two 16-bit ALUs, or four 8-bit ALUs. Figure 38 shows the multiple arithmetic data flow for the case of a four 8-bit split of the ALU (called multiple-byte arithmetic). The ALU operates as independent parallel ALUs where each ALU receives the same function code.



Figure 38. Multiple-Byte Arithmetic Data Flow

# **PP** multiplier

The PP's hardware multiplier can perform one 16x16 multiply with a 32-bit result or two 8x8 multiplies with two 16-bit results in a single cycle. A 16x16 multiply can use signed or unsigned operands as shown in Figure 39.

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18          | 17    | 16  | 15   | 14  | 13   | 12    | 11 | 10 | 9 | 8    | 7     | 6    | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------|-------|-----|------|-----|------|-------|----|----|---|------|-------|------|---|---|---|---|---|---|
| X  | X  | Х  | Х  | Х  | Х  | Х  | Х  | Х  | Х  | Х  | Х  | Х  | Х           | Х     | Х   | s    |     |      |       |    |    | ç | Sigr | ned   | npu  | t |   |   |   |   |   |
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18          | 17    | 16  | 15   | 14  | 13   | 12    | 11 | 10 | 9 | 8    | 7     | 6    | 5 | 4 | 3 | 2 | 1 | 0 |
| S  | S  |    |    |    |    |    |    |    |    |    |    |    |             | Sigr  | ned | × Si | gne | d Re | esuli | t  |    |   |      |       |      |   |   |   |   |   |   |
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18          | 17    | 16  | 15   | 14  | 13   | 12    | 11 | 10 | 9 | 8    | 7     | 6    | 5 | 4 | 3 | 2 | 1 | 0 |
| X  | X  | X  | X  | X  | X  | X  | X  | X  | X  | X  | X  | X  | X           | X     | X   |      |     |      |       |    | 10 | - | -    | ed li | nput | - |   |   | _ |   | Ĵ |
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 40          | 17    | 16  | 15   | 14  | 13   | 12    | 44 | 10 | 9 | 8    | 7     | 6    | 5 | 4 |   | 2 | 4 |   |
|    | 30 | 29 | 28 | 21 | 20 | 20 | 24 | 23 | 22 | 21 | 20 | -  | 18<br>Isiar | ned : | -   | -    |     | -    |       | 11 | 10 | э | 0    | 1     | 6    | э | 4 | 3 | 2 | 1 | 0 |
|    |    |    | -  | -  |    |    | -  | -  | -  | -  | -  |    |             |       |     |      |     |      |       |    | -  |   | -    | _     | -    |   | - | - |   | _ |   |

Figure 39. 16 x 16 Multiplier Data Formats



SGUS025 – AUGUST 1998

# **PP** multiplier (continued)

When performing two simultaneous 8x8 split multiplies, the first input word contains unsigned byte operands and the second input word contains signed or unsigned byte operands. These formats are shown in Figure 40 and Figure 41.

| 31      | 30      | 29      | 28      | 27      | 26      | 25      | 24      | 23      | 22      | 21      | 20      | 19      | 18 | 17 | 16      | 15      | 14 | 13       | 12   | 11         | 10    | 9       | 8 | 7 | 6 | 5     | 4    | 3     | 2     | 1  | 0 |
|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|----|----|---------|---------|----|----------|------|------------|-------|---------|---|---|---|-------|------|-------|-------|----|---|
| X       | Х       | Х       | Х       | X       | X       | Х       | Х       | Х       | X       | X       | Х       | Х       | Х  | X  | X       |         | U  | Insig    | gneo | d Inp      | out 1 | b       |   |   | ι | Insig | gneo | d Inp | out ' | la |   |
| 31      | 30      | 29      | 28      | 27      | 26      | 25      | 24      | 23      | 22      | 21      | 20      | 19      | 18 | 17 | 16      | 15      | 14 | 13       | 12   | 11         | 10    | 9       | 8 | 7 | 6 | 5     | 4    | 3     | 2     | 1  | 0 |
|         |         |         |         |         |         |         |         |         |         |         |         |         |    |    |         |         |    |          |      |            |       |         |   |   |   |       |      |       |       |    |   |
| Х       | Х       | Х       | Х       | Х       | Х       | Х       | Х       | Х       | Х       | Х       | Х       | Х       | Х  | Х  | Х       | S       |    | Si       | gne  | d In       | put 2 | 2b      |   | S |   | Si    | gne  | d In  | put   | 2a |   |
| X<br>31 | X<br>30 | X<br>29 | X<br>28 | X<br>27 | X<br>26 | X<br>25 | X<br>24 | X<br>23 | X<br>22 | X<br>21 | X<br>20 | X<br>19 |    | X  | X<br>16 | S<br>15 | 14 | Si<br>13 | gne  | d In<br>11 | -     | 2b<br>9 | 8 | - | 6 |       | -    |       |       |    | 0 |

# Figure 40. Signed Split Multiply Data Formats

| 31      | 30      | 29      | 28      | 27      | 26      | 25      | 24      | 23      | 22      | 21      | 20      | 19      | 18 | 17      | 16      | 15 | 14      | 13         | 12         | 11          | 10    | 9       | 8 | 7 | 6      | 5          | 4         | 3          | 2          | 1       | 0 |
|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|----|---------|---------|----|---------|------------|------------|-------------|-------|---------|---|---|--------|------------|-----------|------------|------------|---------|---|
| Х       | Х       | Х       | Х       | X       | Х       | Х       | Х       | Х       | Х       | X       | Х       | Х       | Х  | X       | Х       |    | U       | nsię       | gneo       | d Inp       | out 1 | b       |   |   | ι      | Jnsię      | gneo      | d Inp      | out 1      | la      |   |
| 31      | 30      | 29      | 28      | 27      | 26      | 25      | 24      | 23      | 22      | 21      | 20      | 19      | 18 | 17      | 16      | 15 | 14      | 13         | 12         | 11          | 10    | 9       | 8 | 7 | 6      | 5          | 4         | 3          | 2          | 1       | 0 |
|         |         |         |         |         |         |         |         |         |         |         |         |         |    |         |         |    |         |            |            |             |       |         |   |   |        |            |           |            |            |         |   |
| Х       | Х       | Х       | Х       | Х       | Х       | Х       | Х       | Х       | Х       | Х       | Х       | Х       | Х  | Х       | Х       |    | U       | nsię       | gneo       | d Inp       | out 2 | b!      |   |   | ι      | Jnsig      | gneo      | d Inp      | out 2      | 2a      |   |
| X<br>31 | X<br>30 | X<br>29 | X<br>28 | X<br>27 | X<br>26 | X<br>25 | X<br>24 | X<br>23 | X<br>22 | X<br>21 | X<br>20 | X<br>19 |    | X<br>17 | X<br>16 | 15 | U<br>14 | nsię<br>13 | gneo<br>12 | d Inp<br>11 | out 2 | 2b<br>9 | 8 | 7 | ل<br>6 | Insię<br>5 | gneo<br>4 | d Inp<br>3 | out 2<br>2 | 2a<br>1 | 0 |

# Figure 41. Unsigned Split Multiply Data Formats

# PP program-flow-control unit architecture

The program-flow-control (pfc) unit performs instruction fetching and decoding, loop control, and handshaking with the transfer controller. The pfc unit architecture is shown in Figure 43.

The PP has a three-stage fetch, address, execute (FAE) pipeline as shown in Figure 42. The pc, ipa, and ipe registers point to the address of the instruction in each stage of the pipeline. On each cycle in which the pipeline advances, ipa is copied into ipe, pc is copied into ipa, and the pc is incremented by one instruction (8 bytes).





Figure 42. FAE-Instruction Pipeline



SGUS025 - AUGUST 1998



PP program-flow-control unit architecture (continued)

Figure 43. Program-Flow-Control Unit Block Diagram



SGUS025 – AUGUST 1998

## **PP** address-unit architecture

The PP has both a local- and global-address unit which operate independently of each other. The address units support twelve different addressing modes. In place of performing a memory access, either or both of the address units can perform an address computation that is written directly to a PP register instead of being used for a memory access. This address unit arithmetic provides additional arithmetic operation to supplement the data unit during compute-intensive algorithms.



Figure 44. Address-Unit Architecture



SGUS025 - AUGUST 1998

# **PP** instruction set

PP instructions are represented by algebraic expressions for the operations performed in parallel by the multiplier, ALU, global-address unit, and local-address unit. The expressions use the || symbol to indicate operations that are to be performed in parallel. The PP ALU operator syntax is shown in Table 9. The data unit operations (multiplier and ALU) are summarized in Table 10 and the parallel transfers (global and local) are summarized in Table 11.

| OPERATOR        | FUNCTION                                                                                              |
|-----------------|-------------------------------------------------------------------------------------------------------|
| src1 [n] src1–1 | Select odd (n=true) or even (n=false) register of D register pair<br>based on negative condition code |
| ()              | Subexpression delimiters                                                                              |
| @mf             | Expander operator                                                                                     |
| %               | Mask generator                                                                                        |
| %%              | Nonmultiple mask generator (EALU only)                                                                |
| %!              | Modified mask generator (0xFFFFFFF output for 0 input)                                                |
| %%!             | Nonmultiple shift right mask generator (EALU only)                                                    |
| //              | Rotate left                                                                                           |
| <<              | Shift left (pseudo-op for rotate and mask)                                                            |
| >>u             | Unsigned shift right                                                                                  |
| >> or >>s       | Signed shift right                                                                                    |
| &               | Bitwise AND                                                                                           |
| ٨               | Bitwise XOR                                                                                           |
|                 | Bitwise OR                                                                                            |
| +               | Addition                                                                                              |
| -               | Subtraction                                                                                           |
| =[cond]         | Conditional assignment                                                                                |
| =[cond.pro]     | Conditional assignment with status protection                                                         |
| =               | Equate                                                                                                |

SGUS025 - AUGUST 1998

# PP instruction set (continued)

Use 1s complement of d0

f

| Operation                  | Base set ALUs                                                                                                                                                                                                                                                                                                                                                                       |
|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Description                | Perform an ALU operation specifying ALU function, 2 src and 1 dest operand, and operand routing. ALU function is one of 256 three-input Boolean operations or one of 16 arithmetic operations combined with one of 16 function modifiers.                                                                                                                                           |
| Syntax                     | dst = [fmod] [ [[cond [.pro] ]] ] ALU_EXPRESSION                                                                                                                                                                                                                                                                                                                                    |
| Examples                   | $d6 = (d6 ^ d4) \& d2$                                                                                                                                                                                                                                                                                                                                                              |
|                            | d3 = [nn.nv] d1 -1                                                                                                                                                                                                                                                                                                                                                                  |
| Operation                  |                                                                                                                                                                                                                                                                                                                                                                                     |
| Description                | Perform an extended ALU (EALU) operation (specified in d0) with one of two data routings to the ALU and optionally write the barrel rotator output to a second dest register. ALU function is one of 256 Boolean or 256 arithmetic.                                                                                                                                                 |
| Syntax                     | dst1 = [ [[cond [.pro] ]] ] ealu (src2, [dst2 = ] [ [[cond]] src1 [[[n]] src1-1] \\ src3, [%] src4)<br>dst1 = [fmod] [ [[cond [.pro] ]] ] ealu (label:EALU_EXPRESSION [    dst2 = [[cond]] src1 [ [[n]] src1-1] \\ src3])                                                                                                                                                           |
| Examples                   | d7 = [nn] ealu(d2, d6 = [nn] d3\\d1, %d4)<br>d3 = mzc ealu(mylabel: d4 + (d5\\d6 & %d7)    d1 = d5\\d6)                                                                                                                                                                                                                                                                             |
| Operation                  | MPY    ADD                                                                                                                                                                                                                                                                                                                                                                          |
| Description                | Perform a 16x16 multiply with optional parallel add or subtract. Condition code applies to both multiply and add.                                                                                                                                                                                                                                                                   |
| Syntax                     | dst2 = [sign] [ [[cond]] ] src3 * src4 [    dst = [ [[cond[.pro] ]] ] src2 + src1 [ [[n]] src1 -1] ]<br>dst2 = [sign] [ [[cond]] ] src3 * src4 [    dst = [ [[cond[.pro] ]] ] src2 - src1 [ [[n]] src1 -1] ]                                                                                                                                                                        |
| Example                    | d7 = u d6 * d5    d5 = d4 - d1                                                                                                                                                                                                                                                                                                                                                      |
| Operation                  | MPY    SADD                                                                                                                                                                                                                                                                                                                                                                         |
| Description                | Perform a 16x16 multiply with a parallel right-shift and add or subtract. Condition code applies to multiply, shift, and add.                                                                                                                                                                                                                                                       |
| Syntax                     | dst2 = [sign] [ [[cond]] ] src3 * src4    dst = [ [[ cond [.pro] ]] ] src2 + src1 [ [[n]] src1 -1] >> -d0<br>dst2 = [sign] [ [[cond]] ] src3 * src4    dst = [ [[ cond [.pro] ]] ] src2 - src1 [ [[n]] src1 -1] >> -d0                                                                                                                                                              |
| Examples                   | d7 = u d6 * d5    d5 = d4 - d1 >> -d0                                                                                                                                                                                                                                                                                                                                               |
| Operation                  | MPY    EALU                                                                                                                                                                                                                                                                                                                                                                         |
| Description                | Perform a multiply and an optional parallel EALU. Multiply can use rounding, scaling, or splitting features.                                                                                                                                                                                                                                                                        |
| Syntax                     | Generic Form:<br>dst2 = [sign] [ [[cond]] ] src3 * src4    dst = [ [[cond [.pro] ]] ] ealu[f] (src2, src1 [ [[n]] src1 -1] \\ d0, %d0)<br>dst2 = [sign] [ [[cond]] ] src3 * src4    ealu()<br>Explicit Form:<br>dst2 = [sign] [opt] [ [[cond]] ] src3 * src4 [< <dms] (label:="" [="" [.pro]="" [[cond="" ]="" ]]="" dst1="[fmod]" ealu="" ealu_expression)<="" td=""   =""></dms]> |
|                            | dst2 = [sign] [opt] [ [[cond]] ] src3 * src4 [< <dms] (label)<="" ealu="" td=""   =""></dms]>                                                                                                                                                                                                                                                                                       |
| Examples                   | d7 = [p] d5 * d3    d2 = [p] ealu(d1, d6\\d0, %d0) ; generic form<br>d2 = m d4 * d7    d3 = ealu (mylabel: d3 + d2 >> 9) ; explicit form                                                                                                                                                                                                                                            |
| Operation                  | divi                                                                                                                                                                                                                                                                                                                                                                                |
| Description                | Perform one iteration of unsigned divide algorithm. Generates one quotient bit per execution using iterative subtraction.                                                                                                                                                                                                                                                           |
| Syntax                     | dst1 = [ [[cond [.pro] ]] ] divi (src2, dst2 = [[cond]] src1 [ [[n]] src1 -1])                                                                                                                                                                                                                                                                                                      |
| Examples                   | d3 = divi (d1, d2 = d2)<br>d3 = divi (d1, d2 = d3[n]d2)                                                                                                                                                                                                                                                                                                                             |
| Misc. Operations           | dint; eint; nop                                                                                                                                                                                                                                                                                                                                                                     |
| Description                | Globally disable interrupts; globally enable interrupts; do nothing in the data unit                                                                                                                                                                                                                                                                                                |
| Syntax                     | dint<br>eint<br>nop                                                                                                                                                                                                                                                                                                                                                                 |
| [[]] Square<br>pro Protect | Inop         al parameter extension       cond       Condition code         brackets ([]) must be used       fmod       Function modifier         status bits       dms       Default multiply shift amount         complement of d0       signed       e_signed                                                                                                                    |

# Table 10. Summary of Data-Unit Operations



sign

u = unsigned, s = signed

SGUS025 - AUGUST 1998

# PP instruction set (continued)

| Operation           | Load                                                                                                                     |
|---------------------|--------------------------------------------------------------------------------------------------------------------------|
| Description         | Transfer from memory into PP register                                                                                    |
| Syntax              | dst = [sign] [size] [ [[cond]] ]* addrexp<br>dst = [sign] [size] [ [[cond]] ]* an.element                                |
| Examples            | d3 = uh[n]* (a9++=[2])<br>d1 = * a2.sMY_ELEMENT                                                                          |
| Operation           | Store                                                                                                                    |
| Description         | Transfer from PP register into memory                                                                                    |
| Syntax              | * addrexp = [size] src [ [[n]] src-1]<br>* an.element = [size] src [ [[n]] src-1]                                        |
| Examples            | *a2 = d3<br>*a9.sMY_ELEMENT = a3                                                                                         |
| Operation           | Address unit arithmetic                                                                                                  |
| Description         | Compute address and store in PP register                                                                                 |
| Syntax              | dst = [size] [ [[cond]] ] & * addrexp<br>dst = [size] [ [[cond]] ] & * an.element                                        |
| Examples            | d2 = &*(a3 + x0)<br>a1 = &*a9.sMY_ELEMENT                                                                                |
| Operation           | Move                                                                                                                     |
| Description         | Transfer from PP register to PP register                                                                                 |
| Syntax              | dst = [g] [ [[cond]] ] src                                                                                               |
| Examples            | x2 = mf<br>d1 = g d3                                                                                                     |
| Operation           | Field extract move                                                                                                       |
| Description         | Transfer from PP register to PP register extracting and right-aligning one byte or halfword                              |
| Syntax              | dst = [sign] [size item]                                                                                                 |
| Example             | d3 = ub2 d1                                                                                                              |
| Operation           | Field replicate move                                                                                                     |
| Description         | Transfer from PP register to PP register replicating the least significant byte or least significant halfword to 32 bits |
| Syntax              | dst = r [size] [[cond]] src                                                                                              |
| Example             | d7 = rh d3                                                                                                               |
| Legend:<br>[] Optio | onal parameter extension cond Condition code                                                                             |

# Table 11. Summary of Parallel Transfers

Square brackets ([]) must be used [[ ]] sign Use global unit g size

item 0 = byte0/halfword0, 1 = byte1/halfword1, 2 = byte2, 3 = byte3



b = byte, h = halfword, w = word (default)



#### SGUS025 – AUGUST 1998

# **PP** opcode formats

A PP instruction uses a 64-bit opcode. The opcode is divided essentially into a data unit portion and a parallel transfer portion. There are five data unit opcode formats comprising bits 38–63 of the opcode. Bits 0–38 of the opcode specify one of 10 parallel transfer formats. An alphabetical list of the mnemonics used in Figure 45 for the data unit and parallel transfer portions of the opcode are shown in Table 12 and Table 13, respectively.

#### **Data Unit Formats**

| 6<br>3 | 6 6 0<br>2 1 0 | 65<br>09 | 5<br>8 | 55<br>76 | 55<br>55 | 5<br>4 | 5<br>3 |     |   |    | 44<br>98 |   | 4<br>6 | 4<br>5 | 4<br>4 | 4<br>3 | 4<br>2 | 4<br>1 |      |   |   |     |    |    |     |      |      | 3<br>0 |      |    | 3  | 2 '  | 1 ( | 0 |                   |
|--------|----------------|----------|--------|----------|----------|--------|--------|-----|---|----|----------|---|--------|--------|--------|--------|--------|--------|------|---|---|-----|----|----|-----|------|------|--------|------|----|----|------|-----|---|-------------------|
| 0      | 1 1            | op       | er     |          | src      | 3      | c      | st2 |   | ds | st1      | 5 | src1   |        | s      | src4   | 1      | 5      | src2 | 2 |   |     |    | Ρ  | ara | lle  | Tr   | ans    | sfer | s  | 55 |      |     |   | A. Six-Operand (M |
| 1      | class          | А        |        | AL       | U Op     | bera   | atio   | n   |   | d  | st       | 5 | src1   |        | 0      | i      | mn     | n. s   | rc2  | 2 |   |     |    | Ρ  | ara | llel | Tr   | ans    | sfer | s  | 22 |      |     |   | B. Base Set ALU ( |
| 1      | class          | А        |        | AL       | U Op     | bera   | atio   | n   |   | d  | st       | 5 | src1   |        | 1      | 0      | -      | 5      | src2 | 2 |   |     |    | Ρ  | ara | lle  | l Tr | ans    | sfer | s  | 22 |      |     |   | C. Base Set ALU ( |
| 1      | class          | А        |        | AL       | U Op     | pera   | atio   | n   |   | d  | st       | 1 | src1   |        | 1      | 1      | d      | lstb   | an   | k | s | lbn | ık | со | nd  |      |      | 32     | -Bit | Im | me | diat | te  |   | D. Base Set ALU ( |
| 1      | 00             | 0 1      | -      | 0 -      | - 0      | -      | 0      | -   | 0 |    |          | - | -      | -      | 0      |        | Эр     | era    | tior | ۱ |   |     |    | Ρ  | ara | lle  | Tr   | ans    | sfer | s  | 55 |      |     |   | E. Miscellaneous  |
| 0      | 0              |          |        |          |          |        |        |     |   |    |          |   |        |        | R      | ese    | erve   | ed     |      |   |   |     |    |    |     |      |      |        |      |    | 55 |      |     |   |                   |
| 0      | 1 0            |          |        |          |          |        |        |     |   |    |          |   |        |        | F      | Res    | ser    | vec    | 1    |   |   |     |    |    |     |      |      |        |      |    | 55 |      |     |   |                   |
| _      |                |          |        |          |          |        |        |     |   |    |          |   |        |        |        |        |        |        |      |   |   |     |    |    |     |      |      |        |      |    | 55 |      |     | _ |                   |

Six-Operand (MPYIIADD, etc.) Base Set ALU (5-Bit Immediate) Base Set ALU (Register src2) Base Set ALU (32-Bit Immediate)

#### **Transfer Formats**

| 3 | 3 | 3 | 3 | 3 | 3 | 3 | 3 | 3 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | ~ | ~ | - | ~ | - |   | ~ | ~ |   | ~ |  |
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|--|
| 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 9 | 8 | 1 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |

| 8765  | 432  | 1   | 0 9    | 9   | 8 7  | 65     | 4 | 32    | 1  | 0 9 8   | 7 | 6 5 | 5 4 | 43  | 2 1 0 |    |          |    |         | _ |       |                                             |
|-------|------|-----|--------|-----|------|--------|---|-------|----|---------|---|-----|-----|-----|-------|----|----------|----|---------|---|-------|---------------------------------------------|
| Lmode | d    | е   | size   | ÷   | s    | La     | Ģ | im/X  | L  | 0bank   | L | Gr  | no  | de  | reg   | ŀ  | e size   | s  | Ga      | L | _im/X | 1. Double Parallel                          |
| Lmode | d    | е   | size   | ÷   | s    | La     | 0 | Lrm   | d  | stbank  | L | 0 0 |     | 0 0 | src   |    | srcban   | <  | dst     | L | _im/X | 2. Move II Local                            |
| Lmode | d    | е   | size   | )   | s    | La     | 0 | Lrm   | d  | stbank  | L | 0 0 |     | ) 1 | src   | ŀ  | e size   | D  | dst     | L | _im/X | 3. Field Move II Local                      |
| Lmode | reg  | е   | size   | )   | s    | La     | 1 | Lrm   |    | bank    | L | 0 0 |     |     | L     | oc | cal Long | Of | set / X |   |       | 4. Local (Long Offset)                      |
| 0 0   | Gl   | oba | al Lor | ng  | Offs | set /X |   |       |    | bank    | L | Gr  | no  | de  | reg   | ŀ  | e size   | s  | Ga      | 0 | Grm   | 5. Global (Long Offset)                     |
| Lmode | d    | е   | size   | )   | s    | La     | 0 | Lrm   | Ac | dstbank | L | 0 0 | ) / | 1 – |       | T  | As1ban   | k  |         | L | _im/X | 6. Non-D DU II Local                        |
| 00-   | cond | с   | rę     | g I | NC   | v z    | 0 |       | d  | stbank  | - | 0 0 |     | 0 0 | src   | Τ  | srcban   | <  | dst     | - |       | 7. Conditional DU II Conditional Mode       |
| 00-   | cond | с   | rę     | g I | NC   | ∶∨ z   | 0 | itm   | d  | stbank  | - | 0 0 |     | ) 1 | src   | e  | e size   | D  | dst     | - |       | 8. Conditional DU II Conditional Field Move |
| 00-   | cond | с   | rę     | g l | NC   | v z    | Ģ | 3im/X |    | bank    | L | Gr  | no  | de  | reg   | ŀ  | e size   | s  | Ga      | 1 | Grm   | 9. Conditional DU II Conditional Global     |
| 00-   | cond | с   | r -    | -   | NC   | V Z    | 0 |       | Ad | dstbank | - | 0 0 | ) / | 1 – |       |    | As1ban   | k  |         | - |       | 10. Conditional Non-D DU                    |

Figure 45. PP Opcode Formats



SGUS025 - AUGUST 1998

# PP opcode formats (continued)

# Table 12. Data Unit Mnemonics

| MNEMONIC         | FUNCTION                                                                                                                                                                                   |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| А                | A = 1 selects arithmetic operations, A = 0 selects Boolean operations                                                                                                                      |
| ALU Operation    | For Boolean operation (A = 0), select the eight ALU function signals. For arithmetic operation (A = 1), odd bits specify the ALU function and even bits define the ALU function modifiers. |
| class            | Operation class: determines routing of ALU operands                                                                                                                                        |
| cond             | condition code                                                                                                                                                                             |
| dst              | D register destination or lower 3 bits of non-D register code                                                                                                                              |
| dst1             | ALU dest. for MPY  ADD, MPY  EALU, or EALU  ROTATE operation. D register or lower 3 bits of non-D register code                                                                            |
| dst2             | Multiply dest. for MPY  ADD or MPY  EALU operation, or rotate dest. for EALU  ROTATE operation. D register                                                                                 |
| dstbank          | ALU register bank                                                                                                                                                                          |
| imm.src2         | 5-bit immediate for src2 of ALU operation                                                                                                                                                  |
| 32-Bit Immediate | 32-bit immediate for src2 of ALU operation                                                                                                                                                 |
| oper             | Six-operand data unit operation (MPY  ADD, MPY  SADD, MPY  EALU, EALU  ROTATE, divi)                                                                                                       |
| Operation        | Miscellaneous operation                                                                                                                                                                    |
| src1             | ALU source 1 register code (D register unless srcbank or s1bnk is used)                                                                                                                    |
| src2             | D register used as ALU source 2                                                                                                                                                            |
| src3             | D register for multiplier source (MPY  ADD or MPY  EALU) or rotate amount (EALU  ROTATE)                                                                                                   |
| src4             | D reg. for ALU C port operand or EALU  ROTATE mask generator input or multiplier source 2 for MPY  ADD, MPY  EALU                                                                          |
| s1bnk            | Bits 5-3 of src1 register code (bit 6 assumed to be 0)                                                                                                                                     |



SGUS025 – AUGUST 1998

# PP opcode formats (continued)

| Table 13. | Parallel | Transfer | Mnemonics |
|-----------|----------|----------|-----------|
|-----------|----------|----------|-----------|

| MNEMONIC | FUNCTION                                                                                                                  |
|----------|---------------------------------------------------------------------------------------------------------------------------|
| 0bank    | Bits 5–3 of global transfer source/destination register code (bit 6 assumed to be 0)                                      |
| Adstbank | Bits 6–3 of ALU destination register code                                                                                 |
| As1bank  | Bits 6–3 of ALU source 1 register code                                                                                    |
| bank     | Bits 6–3 of global (or local) store source or load destination                                                            |
| с        | Conditional choice of D register for src1 operand of the ALU                                                              |
| С        | Protect status register's carry bit                                                                                       |
| cond     | Condition code                                                                                                            |
| d        | D register or lower 3 bits of register code for local transfer source/destination                                         |
| D        | Duplicate least significant data during moves                                                                             |
| dst      | The three lowest bits of the register code for move or field-move destination                                             |
| dstbank  | Bits 6–3 of move destination register code                                                                                |
| е        | Sign-extend local (bit 31), sign-extend global (bit 9)                                                                    |
| g        | Conditional global transfer                                                                                               |
| Ga       | Global address register for load, store, or address unit arithmetic                                                       |
| Gim / X  | Global address unit immediate offset or index register                                                                    |
| Gmode    | Global unit addressing mode                                                                                               |
| Grm      | Global PP-relative addressing mode                                                                                        |
| itm      | Number of items selected for field-extract move                                                                           |
| L        | L = 1 selects load operation, L = 0 selects store/address unit arithmetic operation                                       |
| La       | Local address register for load, store, or address unit arithmetic                                                        |
| Lim / X  | Local address unit immediate offset or index register                                                                     |
| Lmode    | Local unit addressing mode                                                                                                |
| Lrm      | Local PP-relative addressing mode                                                                                         |
| Ν        | Protect status register's negative bit                                                                                    |
| r        | Conditional write of ALU result                                                                                           |
| reg      | Register number used with bank or 0bank for global load, store, or address unit arithmetic                                |
| S        | Enable index scaling. Additional index bit for byte accesses or arithmetic operations (bit 28, local; bit 6, global)      |
| size     | Size of data transfer (bits 30–29, local; bits 8–7, global)                                                               |
| src      | Three lowest bits of register code for register-register move source or non-field moves. D register source for field move |
| srcbank  | Bits 6–3 of register code for register-register move source                                                               |
| V        | Protect status register's overflow bit                                                                                    |
| Z        | Protect status register's zero bit                                                                                        |
| -        | Unused bit (fill with 0)                                                                                                  |



# PP opcode formats (continued)

Table 14 summarizes the supported parallel-transfer formats and indicates whether the transfers are local or global. It also lists the allowed ALU operations and states whether conditions and status protection are supported.

|                        | AI   | _U    |      |                      | GLC                                     | BAL TR | ANSFER    |     | L   | OCAL TR  | ANSFE  | R      |
|------------------------|------|-------|------|----------------------|-----------------------------------------|--------|-----------|-----|-----|----------|--------|--------|
| FORMAT                 | OPER | ANDS  | Cond | Status<br>Protection | Move                                    | Load   | I/Store/A | UA  |     | Load/Sto | re/AU/ | 4      |
|                        | dst1 | src1  |      | Troteotion           | $\textbf{src} \rightarrow \textbf{dst}$ | s/d    | Index     | Rel | s/d | Index    | Rel    | Port   |
| Double parallel        | D    | D     | No   | No                   | —                                       | Lower  | X/short   | No  | D   | X/short  | No     | Local  |
| Move    Local          | D    | D     | No   | No                   | Any→Any                                 | —      | _         | _   | D   | X/short  | Yes    | Local  |
| Field move    Local    | D    | D     | No   | No                   | D→Any                                   | —      | _         | _   | D   | X/short  | No     | Local  |
| Global (long offset)   | D    | D     | No   | No                   | _                                       | Any    | X/long    | Yes | _   | -        | _      | _      |
| Local (long offset)    | D    | D     | No   | No                   | _                                       | _      | _         | _   | Any | X/long   | Yes    | Global |
| Non-D DU    Local      | Any  | Any   | No   | No                   | _                                       | —      | _         | _   | D   | X/short  | Yes    | Global |
| Conditional move       | D    | D     | Yes  | Yes                  | Any→Any                                 | —      | _         | _   | _   | -        | —      | _      |
| Conditional field move | D    | D     | Yes  | Yes                  | D→Any                                   | —      | _         | _   | _   | -        | _      | _      |
| Conditional global     | D    | D     | Yes  | Yes                  | _                                       | Any    | X/short   | Yes | _   | -        | _      | _      |
| Conditional non-D DU   | Any  | Any   | Yes  | Yes                  | —                                       | —      | —         | _   | _   | —        | _      | —      |
| 32-bit imm. base ALU   | Any  | Lower | Yes  | No                   |                                         |        |           | _   |     |          |        |        |

| Table 14. Parallel-Transfer Format Summary | Table 14. | Parallel-Transfer | Format | Summary |
|--------------------------------------------|-----------|-------------------|--------|---------|
|--------------------------------------------|-----------|-------------------|--------|---------|

Legend:

DU Data unit

AUA Address unit arithmetic

s/d Source/destination register

Rel Relative addressing support



SGUS025 - AUGUST 1998

# PP opcode formats (continued)

Table 15 shows the encoding used in the opcodes to specify particular PP registers. A 3-bit register field contains the three least significant bits (LSBs). The register codes are used for the src, src1, src2, src3, src4, dst, dst1, dst2, d, reg, Ga, La, Gim/X, and Lim/X opcode fields. The four most significant bits (MSBs) specify the register bank which is concatenated to the register field for the full 7-bit code. The register bank codes are used for the dstbank, s1bnk, srcbank, 0bank, bank, Adstbank, and As1bank opcode fields. When no associated bank is specified for a register field in the opcode, the D register bank is assumed. When the MSB of the bank code is not specified in the opcode (as in 0bank and s1bnk), it is assumed to be 0, indicating a lower register.

|      | LOWER REGISTERS (MSB OF BANK = 0) |            |      |     |          |  |  |  |
|------|-----------------------------------|------------|------|-----|----------|--|--|--|
| COD  | NG                                | REGISTER   | COD  | NG  | DECISTED |  |  |  |
| BANK | REG                               | REGISTER   | BANK | REG | REGISTER |  |  |  |
| 0000 | 000                               | a0         | 0100 | 000 | d0       |  |  |  |
| 0000 | 001                               | a1         | 0100 | 001 | d1       |  |  |  |
| 0000 | 010                               | a2         | 0100 | 010 | d2       |  |  |  |
| 0000 | 011                               | a3         | 0100 | 011 | d3       |  |  |  |
| 0000 | 100                               | a4         | 0100 | 100 | d4       |  |  |  |
| 0000 | 101                               | reserved   | 0100 | 101 | d5       |  |  |  |
| 0000 | 110                               | a6 (sp)    | 0100 | 110 | d6       |  |  |  |
| 0000 | 111                               | a7 (zero)  | 0100 | 111 | d7       |  |  |  |
| 0001 | 000                               | a8         | 0101 | 000 | reserved |  |  |  |
| 0001 | 001                               | a9         | 0101 | 001 | sr       |  |  |  |
| 0001 | 010                               | a10        | 0101 | 010 | mf       |  |  |  |
| 0001 | 011                               | a11        | 0101 | 011 | reserved |  |  |  |
| 0001 | 100                               | a12        | 0101 | 100 | reserved |  |  |  |
| 0001 | 101                               | reserved   | 0101 | 101 | reserved |  |  |  |
| 0001 | 110                               | a14 (sp)   | 0101 | 110 | reserved |  |  |  |
| 0001 | 111                               | a15 (zero) | 0101 | 111 | reserved |  |  |  |
| 0010 | 000                               | x0         | 0110 | 000 | reserved |  |  |  |
| 0010 | 001                               | x1         | 0110 | 001 | reserved |  |  |  |
| 0010 | 010                               | x2         | 0110 | 010 | reserved |  |  |  |
| 0010 | 011                               | reserved   | 0110 | 011 | reserved |  |  |  |
| 0010 | 100                               | reserved   | 0110 | 100 | reserved |  |  |  |
| 0010 | 101                               | reserved   | 0110 | 101 | reserved |  |  |  |
| 0010 | 110                               | reserved   | 0110 | 110 | reserved |  |  |  |
| 0010 | 111                               | reserved   | 0110 | 111 | reserved |  |  |  |
| 0011 | 000                               | x8         | 0111 | 000 | pc/call  |  |  |  |
| 0011 | 001                               | x9         | 0111 | 001 | ipa/br   |  |  |  |
| 0011 | 010                               | x10        | 0111 | 010 | ipe †    |  |  |  |
| 0011 | 011                               | reserved   | 0111 | 011 | iprs     |  |  |  |
| 0011 | 100                               | reserved   | 0111 | 100 | inten    |  |  |  |
| 0011 | 101                               | reserved   | 0111 | 101 | intflg   |  |  |  |
| 0011 | 110                               | reserved   | 0111 | 110 | comm     |  |  |  |
| 0011 | 111                               | reserved   | 0111 | 111 | lctl     |  |  |  |

| Table 15 | . PP | Register | Codes |
|----------|------|----------|-------|
|----------|------|----------|-------|

|      |     | R REGISTERS | i – – – |     | = 1)     |  |  |
|------|-----|-------------|---------|-----|----------|--|--|
| COD  | -   | REGISTER    | COD     |     | REGISTER |  |  |
| BANK | REG |             | BANK    | REG |          |  |  |
| 1000 | 000 | reserved    | 1100    | 000 | lc0      |  |  |
| 1000 | 001 | reserved    | 1100    | 001 | lc1      |  |  |
| 1000 | 010 | reserved    | 1100    | 010 | lc2      |  |  |
| 1000 | 011 | reserved    | 1100    | 011 | reserved |  |  |
| 1000 | 100 | reserved    | 1100    | 100 | IrO      |  |  |
| 1000 | 101 | reserved    | 1100    | 101 | lr1      |  |  |
| 1000 | 110 | reserved    | 1100    | 110 | lr2      |  |  |
| 1000 | 111 | reserved    | 1100    | 111 | reserved |  |  |
| 1001 | 000 | reserved    | 1101    | 000 | lrse0    |  |  |
| 1001 | 001 | reserved    | 1101    | 001 | lrse1    |  |  |
| 1001 | 010 | reserved    | 1101    | 010 | lrse2    |  |  |
| 1001 | 011 | reserved    | 1101    | 011 | reserved |  |  |
| 1001 | 100 | reserved    | 1101    | 100 | lrs0     |  |  |
| 1001 | 101 | reserved    | 1101    | 101 | lrs1     |  |  |
| 1001 | 110 | reserved    | 1101    | 110 | lrs2     |  |  |
| 1001 | 111 | reserved    | 1101    | 111 | reserved |  |  |
| 1010 | 000 | reserved    | 1110    | 000 | ls0      |  |  |
| 1010 | 001 | reserved    | 1110    | 001 | ls1      |  |  |
| 1010 | 010 | reserved    | 1110    | 010 | ls2      |  |  |
| 1010 | 011 | reserved    | 1110    | 011 | reserved |  |  |
| 1010 | 100 | reserved    | 1110    | 100 | le0      |  |  |
| 1010 | 101 | reserved    | 1110    | 101 | le1      |  |  |
| 1010 | 110 | reserved    | 1110    | 110 | le2      |  |  |
| 1010 | 111 | reserved    | 1110    | 111 | reserved |  |  |
| 1011 | 000 | reserved    | 1111    | 000 | reserved |  |  |
| 1011 | 001 | reserved    | 1111    | 001 | reserved |  |  |
| 1011 | 010 | reserved    | 1111    | 010 | reserved |  |  |
| 1011 | 011 | reserved    | 1111    | 011 | reserved |  |  |
| 1011 | 100 | reserved    | 1111    | 100 | tag0 †   |  |  |
| 1011 | 101 | reserved    | 1111    | 101 | tag1 †   |  |  |
| 1011 | 110 | reserved    | 1111    | 110 | tag2 †   |  |  |
| 1011 | 111 | reserved    | 1111    | 111 | tag3 †   |  |  |

<sup>†</sup>Read only



## data unit operation code

For data unit opcode format A, a 4-bit operation code specifies one of 16 six-operand operations and an associated data path. See Figure 45.

|    | oper FIE | ELD BIT |    | OPERATION TYPE |
|----|----------|---------|----|----------------|
| 60 | 59       | 58      | 57 | OPERATION TIPE |
| 0  | u        | 0       | S  | MPY    ADD     |
| 0  | u        | 1       | f  | MPYU    EALU   |
| 1  | 0        | f       | k  | EALU    ROTATE |
| 1  | 0        | 1       | 0  | divi           |
| 1  | 1        | u       | S  | SPY    SADD    |

**Table 16. Six-Operand Format Operation Codes** 

Legend:

u Unsigned

f 1s complement EALU function code

s Subtract

k Use mask or mf expander

### operation class code

The base set ALU opcodes (formats B, C, D) use an operation-class code to specify one of eight different routings to the A, B, and C ports of the ALU. See Figure 45.

| CLASS | DESTINATION | A PORT |      | <b>B PORT</b> |      | C PORT |
|-------|-------------|--------|------|---------------|------|--------|
| 000   | dst         | src2   | src1 | //            |      | @mf    |
| 001   | dst         | dstc   | src1 |               | d0   | src2   |
| 010   | dst         | dstc   | src1 | //            |      | %src2  |
| 011   | dst         | dstc   | src1 | //            | src2 | %src2  |
| 100   | dst         | src2   | src1 | //            | d0   | %d0    |
| 101   | dst         | src2   | src1 | //            | d0   | @mf    |
| 110   | dst         | dstc   | src1 |               |      | src2   |
| 111   | dst         | src1   | 1    | //            | src2 | src2   |

#### Table 17. Base Set ALU Class Summary

Legend:

\\ Rotate left

@mf Expand function

% Mask generation

dstc Companion D register

dst Destination D register or any register if dstbank or Adstbank is used with destination.

src2 Source D register or immediate

srd1 Source D register or any register if As1bank is used or any lower register if s1bnk is used



SGUS025 - AUGUST 1998

#### ALU operation code

For base set ALU Boolean opcodes (A=0), the ALU function is formed by a sum of Boolean products selected by the ALU operation opcode bits as shown in Table 18. For base set arithmetic opcodes (A=1), the four odd ALU operation bits specify an arithmetic operation as described in Table 19 while the four even bits specify one of the ALU function modifiers as shown in Table 20. See Table 9 for a list of PP operators and Figure 45 for PP opcode formats.

| OPCODE BIT | PRODUCT TERM |
|------------|--------------|
| 58         | A & B & C    |
| 57         | ~A & B & C   |
| 56         | A & ~B & C   |
| 55         | ~A & ~B & C  |
| 54         | A & B & ~C   |
| 53         | ~A & B & ~C  |
| 52         | A & ~B & ~C  |
| 51         | ~A & ~B & ~C |

| Table 18. | Base-Set        | ALU Boolean  | Function Codes |
|-----------|-----------------|--------------|----------------|
|           | <b>Duoo oot</b> | ALC BOOIDAII |                |

# Table 19. Base Set Arithmetics

| O  | PCODE BITS CARRY |    |    | CARRY |                           | NATURAL       |                                         |
|----|------------------|----|----|-------|---------------------------|---------------|-----------------------------------------|
| 57 | 55               | 53 | 51 | IN    | ALGEBRAIC DESCRIPTION     | FUNCTION      | (IF DIFFERENT FROM<br>NATURAL FUNCTION) |
| 0  | 0                | 0  | 0  | х     |                           |               |                                         |
| 0  | 0                | 0  | 1  | 1     | A – (B   C)               | A – B <1<     |                                         |
| 0  | 0                | 1  | 0  | 0     | A + (B & ~C)              | A + B <0<     |                                         |
| 0  | 0                | 1  | 1  | 1     | A – C                     | A – C         |                                         |
| 0  | 1                | 0  | 0  | 1     | A – (B   ~C)              | A – B >1>     | (A – (B & C)) if sign=0                 |
| 0  | 1                | 0  | 1  | 1     | A – B                     | A – B         |                                         |
| 0  | 1                | 1  | 0  | C(n)  | A – (B & @mf   –B & ~@mf) | A + B / A – B | if class 0 or 5                         |
|    |                  |    |    | 1/0   | A +  B                    | A + B / A – B | if class 1–4 or 6–7, A–B if sign=1      |
| 0  | 1                | 1  | 1  | 1     | A – (B & C)               | A – B>0>      |                                         |
| 1  | 0                | 0  | 0  | 0     | A + (B & C)               | A + B>0>      |                                         |
| 1  | 0                | 0  | 1  | ~C(n) | A + (B & @mf   -B & ~@mf) | A – B / A + B | if class 0 or 5                         |
|    |                  |    |    | 0/1   | A –  B                    | A – B / A + B | if class 1–4 or 6–7, A+B if sign=1      |
| 1  | 0                | 1  | 0  | 0     | A + B                     | A + B         |                                         |
| 1  | 0                | 1  | 1  | 0     | A + (B   ~C)              | A + B >1>     | (A + (B & C)) if sign=0                 |
| 1  | 1                | 0  | 0  | 0     | A + C                     | A + C         |                                         |
| 1  | 1                | 0  | 1  | 1     | A – (B & ~C)              | A – B <0<     |                                         |
| 1  | 1                | 1  | 0  | 0     | A + (B   C)               | A + B <1<     |                                         |
| 1  | 1                | 1  | 1  | 0     | (A & C) + (B & C)         | field A + B   |                                         |

Legend:

C(n) LSB of each part of C port register

>0> Zero-extend shift right

<0< Zero-extend shift left

>1> One-extend shift right

<1< One-extend shift left



SGUS025 - AUGUST 1998

# ALU-operation code (continued)

| м  | FUNC<br>DDIFI            |     | -  | MODIFICATION PERFORMED                                                                    |  |  |  |  |  |
|----|--------------------------|-----|----|-------------------------------------------------------------------------------------------|--|--|--|--|--|
| 58 | 56                       | 54  | 52 |                                                                                           |  |  |  |  |  |
| 0  | 0                        | 0   | 0  | Normal operation                                                                          |  |  |  |  |  |
| 0  | 0                        | 0   | 1  | cin                                                                                       |  |  |  |  |  |
| 0  | 0                        | 1   | 0  | %! if maskgen instruction, Imo if not maskgen                                             |  |  |  |  |  |
| 0  | 0                        | 1   | 1  | %! and cin if maskgen instruction, rmo if not maskgen                                     |  |  |  |  |  |
| 0  | 1                        | 0   | 0  | A port = 0                                                                                |  |  |  |  |  |
| 0  | 1                        | 0   | 1  | A port = 0 and cin                                                                        |  |  |  |  |  |
| 0  | 1                        | 1   | 0  | A port = 0 and %! if maskgen, Imbc if not maskgen                                         |  |  |  |  |  |
| 0  | 1                        | 1   | 1  | A port = 0, %! and cin if maskgen, rmbc if not maskgen                                    |  |  |  |  |  |
| 1  | 0                        | 0   | 0  | mf bit(s) set by carry out(s). (mc)                                                       |  |  |  |  |  |
| 1  | 0                        | 0   | 1  | mf bit(s) set based on status register MSS field. (me)                                    |  |  |  |  |  |
| 1  | 0                        | 1   | 0  | Rotate mf by Asize, mf bit(s) set by carry out(s). (mrc)                                  |  |  |  |  |  |
| 1  | 0                        | 1   | 1  | Rotate mf by Asize, mf bit(s) set based on status register MSS field. (mre)               |  |  |  |  |  |
| 1  | 1                        | 0   | 0  | Clear mf, mf bit(s) set by carry out(s). (mzc)                                            |  |  |  |  |  |
| 1  | 1                        | 0   | 1  | Clear mf, mf bit(s) set based on status register MSS field. (mze)                         |  |  |  |  |  |
| 1  | 1                        | 1   | 0  | No setting of bits in mf register. (mx)                                                   |  |  |  |  |  |
| 1  | 1                        | 1   | 1  | Reserved                                                                                  |  |  |  |  |  |
| I  | end:<br>;in<br>mbc<br>mo | Lef |    | from sr(C)%!Modified mask generator-bit changermbcRightmost-bit changeonermoRightmost one |  |  |  |  |  |

# **Table 20. Function Modifier Codes**

## miscellaneous operation code

х х

х

х

For data-unit opcode format E, the operation field selects one of the miscellaneous operations.

|    | Table 21. Miscellaneous Operation Codes |    |          |           |           |                                             |  |  |  |  |
|----|-----------------------------------------|----|----------|-----------|-----------|---------------------------------------------|--|--|--|--|
| Γ  | OPCODE BITS                             |    | MNEMONIC | OPERATION |           |                                             |  |  |  |  |
| 43 | 3 42                                    | 41 | 40       | 39        | MINEMONIC | OPERATION                                   |  |  |  |  |
| 0  | 0                                       | 0  | 0        | 0         | nop       | No data-unit operation. Status not modified |  |  |  |  |
| 0  | 0                                       | 0  | 0        | 1         | reserved  |                                             |  |  |  |  |
| 0  | 0                                       | 0  | 1        | 0         | eint      | Global-interrupt enable                     |  |  |  |  |
| 0  | 0                                       | 0  | 1        | 1         | dint      | Global-interrupt disable                    |  |  |  |  |
| 0  | 0                                       | 1  | х        | х         | reserved  |                                             |  |  |  |  |
| 0  | 1                                       | х  | х        | х         | reserved  |                                             |  |  |  |  |

reserved



#### SGUS025 – AUGUST 1998

#### addressing mode codes

The Lmode (bits 35–38) and Gmode (bits 13–16) of the opcode specify the local and global transfer for various parallel transfer opcode formats (Lmode in formats 1, 2, 3, 4, and 6 and Gmode in formats 1, 5, and 9). See Figure 45 for PP opcode formats. Table 22 shows the coding for the addressing mode fields.

| CODING | EXPRESSION     | DESCRIPTION                                    |
|--------|----------------|------------------------------------------------|
| 00xx   |                | Nop (nonaddressing mode operation)             |
| 0100   | *(an ++= xm)   | Postaddition of index register, with modify    |
| 0101   | *(an= xm)      | Postsubtraction of index register, with modify |
| 0110   | *(an ++= imm)  | Postaddition of immediate, with modify         |
| 0111   | *(an – –= imm) | Postsubtraction of immediate, with modify      |
| 1000   | *(an + xm)     | Preaddition of index register                  |
| 1001   | *(an – xm)     | Presubtraction of index register               |
| 1010   | *(an + imm)    | Preaddition of immediate                       |
| 1011   | *(an – imm)    | Presubtraction of immediate                    |
| 1100   | *(an += xm)    | Preaddition of index register, with modify     |
| 1101   | *(an -= xm)    | Presubtraction of index register, with modify  |
| 1110   | *(an += imm)   | Preaddition of immediate, with modify          |
| 1111   | *(an -= imm)   | Presubtraction of immediate, with modify       |

### Table 22. Addressing Mode Codes

Legend:

an Address register in local/global (I/g) address unit

imm Immediate offset

xm Index register in same unit as an register

### L, e codes

The L and e bits combine to specify the type of parallel transfer performed. For the local transfer, L and e are bits 21 and 31, respectively. For the global transfer, L and e are bits 17 and 9, respectively. See Figure 45 for PP opcode formats.

# Table 23. Parallel Transfer Type

| L | е | PARALLEL TRANSFER       |
|---|---|-------------------------|
| 0 | 0 | Store                   |
| 0 | 1 | Address unit arithmetic |
| 1 | 0 | Zero-extend load        |
| 1 | 1 | Sign-extend load        |

## size codes

The size code specifies the data transfer size. For field moves (parallel transfer format 3), only byte and halfword data sizes are valid.

| Table 24. | Transfer | Data | Size |
|-----------|----------|------|------|
|-----------|----------|------|------|

| CODING | DATA SIZE          |
|--------|--------------------|
| 00     | Byte (8 bits)      |
| 01     | Halfword (16 bits) |
| 10     | Word (32 bits)     |
| 11     | Reserved           |



#### relative-addressing mode codes

The Lrm and Grm opcode fields allow the local-address or global-address units, respectively, to select PP-relative addressing as shown in Table 25.

| CODING | RELATIVE-ADDRESSING<br>MODE  |
|--------|------------------------------|
| 00     | Normal (absolute addressing) |
| 01     | Reserved                     |
| 10     | PP-relative dba              |
| 11     | PP-relative pba              |

#### Table 25. Relative-Addressing Mode Codes

Legend:

dba – Data RAM 0 base is base address

pba – Paramater RAM base is base address

#### condition codes

In the four conditional parallel transfer opcodes (formats 7–10), the condition code field specifies one of 16 condition codes to be applied to the data unit operation source, data unit result, or global transfer based on the settings of the c, r, and g bits, respectively. Table 26 shows the condition codes. For the 32-bit immediate data unit opcode (format D), the condition applies to the data unit result only. See Figure 45 for PP opcode formats.

|    | CONE<br>BI | DITIO<br>TS | N  | MNEMONIC | DESCRIPTION                | STATUS BIT COMBINATION        |
|----|------------|-------------|----|----------|----------------------------|-------------------------------|
| 35 | 34         | 33          | 32 |          |                            |                               |
| 0  | 0          | 0           | 0  | u        | Unconditional (default)    | None                          |
| 0  | 0          | 0           | 1  | р        | Positive                   | ~N & ~Z                       |
| 0  | 0          | 1           | 0  | ls       | Lower than or same         | ~C   Z                        |
| 0  | 0          | 1           | 1  | hi       | Higher than                | C & ~Z                        |
| 0  | 1          | 0           | 0  | lt       | Less than                  | (N & ~V)   (~N & V)           |
| 0  | 1          | 0           | 1  | le       | Less than or equal         | (N & ~V)   (~N & V)   Z       |
| 0  | 1          | 1           | 0  | ge       | Greater than or equal      | (N & V)   (~N & ~V)           |
| 0  | 1          | 1           | 1  | gt       | Greater than               | (N & V & ~Z)   (~N & ~V & ~Z) |
| 1  | 0          | 0           | 0  | hs, c    | Higher than or same, carry | С                             |
| 1  | 0          | 0           | 1  | lo, nc   | Lower than, no carry       | ~C                            |
| 1  | 0          | 1           | 0  | eq, z    | Equal, zero                | Z                             |
| 1  | 0          | 1           | 1  | ne, nz   | Not equal, not zero        | ~Z                            |
| 1  | 1          | 0           | 0  | V        | Overflow                   | V                             |
| 1  | 1          | 0           | 1  | nv       | No overflow                | ~V                            |
| 1  | 1          | 1           | 0  | n        | Negative                   | Ν                             |
| 1  | 1          | 1           | 1  | nn       | Nonnegative                | ~N                            |

### Table 26. Condition Codes

# EALU operations

Extended ALU (EALU) operations allow the execution of more advanced ALU functions than those specified in the base set ALU opcodes. The opcode for EALU instructions contains the operands for the operation while the d0 register extends the opcode by specifying the EALU operation to be performed. The format of d0 for EALU operations is shown in Figure 24.



#### SGUS025 – AUGUST 1998

### **EALU Boolean functions**

EALU operations support all 256 Boolean ALU functions plus the flexibility to add 1 or a carry-in to Boolean sum. The Boolean function performed by the ALU is:

(F0 & (~A & ~B & ~C)) | (F1 & (A & ~B & ~C)) | (F2 & (~A & B & ~C)) | (F3 & (A & B & ~C)) | (F4 & (~A & ~B & C)) | (F5 & (A & ~B & C)) | (F6 & (~A & B & C)) | (F7 & (A & B & C)) [+1 | +cin]

| d0 BIT | ALU FUNCTION SIGNAL | PRODUCT TERM |
|--------|---------------------|--------------|
| 26     | F7                  | A & B & C    |
| 25     | F6                  | ~A & B & C   |
| 24     | F5                  | A & ~B & C   |
| 23     | F4                  | ~A & ~B & C  |
| 22     | F3                  | A & B & ~C   |
| 21     | F2                  | ~A & B & ~C  |
| 20     | F1                  | A & ~B & ~C  |
| 19     | F0                  | ~A & ~B & ~C |

Table 27. EALU Boolean Function Codes

#### **EALU** arithmetic functions

EALU operations support all 256 arithmetic functions provided by the three-input ALU plus the flexibility to add 1 or a carry-in to the result. The arithmetic function performed by the ALU is:

$$f(A,B,C) = A \& f1(B,C) + f2(B,C) [+1 | cin]$$

f1(B,C) and f2(B,C) are independent Boolean combinations of the B and C ALU inputs. The ALU function is specified by selecting the desired f1 and f2 subfunction and then XORing the f1 and f2 code from Table 28 to create the ALU function code for bits 19–26 of d0. Additional operations such as absolute values and signed shifts can be performed using d0 bits which control the ALU function based on the sign of one of the inputs.

| f1<br>CODE | f2<br>CODE | SUBFUNCTION               | COMMON USAGE                                          |
|------------|------------|---------------------------|-------------------------------------------------------|
| 00         | 00         | 0                         | Zero the term                                         |
| AA         | FF         | -1                        | -1 (All 1s)                                           |
| 88         | СС         | В                         | В                                                     |
| 22         | 33         | -B -1                     | Negate B                                              |
| A0         | F0         | С                         | с                                                     |
| 0A         | 0F         | -C -1                     | Negate C                                              |
| 80         | C0         | B & C                     | Force bits in B to 0 where bits in C are 0            |
| 2A         | 3F         | -(B & C) - 1              | Force bits in B to 0 where bits in C are 0 and negate |
| A8         | FC         | B C                       | Force bits in B to 1 where bits in C are 1            |
| 02         | 03         | -(B   C) - 1              | Force bits in B to 1 where bits in C are 1 and negate |
| 08         | 0C         | В&~С                      | Force bits in B to 0 where bits in C are 1            |
| A2         | F3         | −(B & ~C) −1              | Force bits in B to 0 where bits in C are 1 and negate |
| 8A         | CF         | B   ~C                    | Force bits in B to 1 where bits in C are 0            |
| 20         | 30         | −(B   ~C) −1              | Force bits in B to 1 where bits in C are 0 and negate |
| 28         | 3C         | (B & ~C)   ((–B – 1) & C) | Choose B if C = all 0s and $-B$ if C = all 1s         |
| 82         | C3         | (B & C)   ((–B – 1) & ~C) | Choose B if C = all 1s and $-B$ if C = all 0s         |

Table 28. ALU f1(B,C) and f2(B,C) Subfunctions



SGUS025 - AUGUST 1998

# TC architecture

The transfer controller (TC) is a combined memory controller and DMA (direct memory access) machine. It handles the movement of data within the 'C80 system as requested by the master processor, parallel processors, and external devices. The transfer controller performs the following data movement and memory control functions:

- MP and PP instruction cache fills
- MP data-cache fills and dirty block write-back
- MP and PP direct external accesses (DEAs)
- MP and PP packet transfers
- Externally initiated packet transfers (XPTs)
- Shift register transfer (SRT) packet transfers for updating VRAM-based frame buffers
- DRAM refresh
- Host bus request

### TC functional block diagram

Figure 46 shows a functional block diagram of the transfer controller. Key features of the TC include:

- Crossbar interface
  - 64-bit data path
  - Single-cycle access
- External memory interface
  - 4G-Byte address range
  - Programmable:

bus size: 8-, 16-, 32-, or 64-bits page size bank size address multiplexing cycle timing block-write mode bank priority

- Big- or little-endian operation
- Cache, VRAM, refresh controller
  - Programmable refresh rate
  - VRAM block-write support
- Independent Src and Dst addressing
  - Autonomous addressing based on packet-transfer parameters
  - Data read and write at different rates
  - Numerous data merging and alignment functions performed during transfer
- Intelligent request prioritization



SGUS025 - AUGUST 1998

# TC functional block diagram (continued)





# **TC registers**

The TC contains four on-chip memory-mapped registers accessible by the MP.

# refresh control (REFCNTL) register (0x01820000)

The REFCNTL register controls refresh cycles.

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23  | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8    | 7   | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|----|-----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|------|-----|---|---|---|---|---|---|---|
|    |    |    |    |    |    |    | RPA | RLD | )  |    |    |    |    |    |    |    |    |    |    |    |    | F | REFI | RAT | E |   |   |   |   |   |   |

RPARLD Refresh Pseudo-Address Reload Value REFRATE Refresh Interval (in clock cycles)

### Figure 47. REFCNTL Register

# packet-transfer minimum (PTMIN) register (0x01820004)

The PTMIN register determines the minimum number of cycles that a packet transfer executes before being suspended by a higher priority packet transfer.

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12  | 11  | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|----|---|---|---|---|---|---|---|---|---|---|
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | PTI | MIN |    |   |   |   |   |   |   |   |   |   |   |

Figure 48. PTMIN Register



SGUS025 - AUGUST 1998

### PT maximum (PTMAX) register (0x01820008)

The PTMAX register determines the maximum number of cycles after PTMIN has elapsed that a packet transfer executes before timing out.

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11  | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|---|---|---|---|---|---|---|---|---|---|
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | MAX |    |   |   |   |   |   |   |   |   |   |   |

## Figure 49. PTMAX Register

### fault status (FLTSTS) register (0x0182000C)

The FLTSTS register indicates the cause of a memory access fault. Fault status bits are cleared by writing a 1 to the appropriate bit.

| 31 | 30 | 29       | 28 | 27           | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14       | 13 | 12 | 11             | 10          | 9    | 8     | 7   | 6   | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----------|----|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----------|----|----|----------------|-------------|------|-------|-----|-----|---|---|---|---|---|---|
|    |    |          |    | Ρ            | Ρ  | Р  | Р  |    |    |    |    | Р  | Ρ  | Ρ  | Р  |    |          |    |    |                |             |      |       |     | ХРТ | - |   |   |   |   | м |
|    |    |          |    | С            | С  | С  | С  |    |    |    | -  | Ρ  | Ρ  | Ρ  | Ρ  |    |          |    |    |                |             |      |       |     |     |   |   |   | - | - |   |
|    |    |          |    | 3            |    |    |    |    |    | F  | P# | 3  | 2  | 1  | 0  |    | (D.T.    | _  |    |                |             |      |       |     |     |   |   |   |   |   |   |
|    |    | PC<br>PP |    | Px C<br>Px P |    |    |    |    |    |    |    |    |    |    |    | Х  | (PT<br>M |    |    | ng XI<br>acket | PT<br>t-Tra | nsfe | r Fai | ult |     |   |   |   |   |   |   |

### Figure 50. FLTSTS Register

### packet-transfer parameters

The most efficient method for data movement in a SMJ320C80 system is through the use of packet transfers (PTs). Packet transfers allow the TC to move blocks of data autonomously between a specified src and dst memory region. Requests for the TC to execute a packet transfer may be made by the MP, PPs, or external devices. A packet-transfer parameter table describing the data packet and how it is to be transferred must be programmed in on-chip memory before the transfer is requested. The TC on the SMJ320C80 supports short-and long-form packet transfers. The PT parameter table format is shown in Figure 51.

| 31                   | 0                           | _       | 31                                                 | 0        |
|----------------------|-----------------------------|---------|----------------------------------------------------|----------|
| Next E               | ntry Address                | PT      | Src B Pitch                                        | PT + 32  |
| PT                   | Options                     | PT + 4  | Dst B Pitch                                        | PT + 36  |
| Src Start            | /Base Address               | PT + 8  | Src C Pitch/Guide Table Pointer                    | PT + 40  |
| Dst Start            | /Base Address               | PT + 12 | Dst C Pitch/Guide Table Pointer                    | PT + 44  |
| Src B Count          | Src A Count                 | PT + 16 | Transparency / Color Word 0                        | PT + 48† |
| Dst B Count          | Dst A Count                 | PT + 20 | Transparency / Color Word 1                        | PT + 52† |
| Src C Cou            | unt/# of Entries            | PT + 24 | Reserved                                           | PT + 56  |
| Dst C Cou            | unt/# of Entries            | PT + 28 | Reserved                                           | PT + 60  |
| PT – 64-byte aligned | on-chip starting address of |         | <sup>+</sup> Wards are averaged in his andian mode |          |

PT – 64-byte aligned on-chip starting address of parameter table

<sup>†</sup>Words are swapped in big-endian mode

Figure 51. Packet-Transfer Parameter Table



SGUS025 – AUGUST 1998

## **PT-options field**

The PT-options field of the parameter table controls the type of src and dst transfer that the TC performs. The format of the options field is shown in Figure 52.

|    |                                                 |                                       |                                                   |    |                                                  |                                              |                                     |                           |             |                | 0  |    |      |    |     |     |     |                                                                                                   |                                                                      |                                                                                                          |                                                                               |                                      |                 |                                                       |                                                        |                                                            |       |                                               |                   |    |
|----|-------------------------------------------------|---------------------------------------|---------------------------------------------------|----|--------------------------------------------------|----------------------------------------------|-------------------------------------|---------------------------|-------------|----------------|----|----|------|----|-----|-----|-----|---------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------|--------------------------------------|-----------------|-------------------------------------------------------|--------------------------------------------------------|------------------------------------------------------------|-------|-----------------------------------------------|-------------------|----|
| 31 | 30 29                                           | 28                                    | 27                                                | 26 | 25                                               | 24                                           | 23                                  | 22                        | 21          | 20             | 19 | 18 | 8 17 | 16 | 15  | 14  | 13  | 12                                                                                                | 11                                                                   | 10                                                                                                       | 9                                                                             | 8                                    | 7               | 6                                                     | 5                                                      | 4                                                          | 3     | 2                                             | 1                 | 0  |
| S  | PTS                                             | I                                     |                                                   |    | R<br>C<br>D                                      | R<br>D<br>B                                  | R<br>A                              | R<br>S<br>C               | R<br>S<br>B |                | х  |    | PAN  | 1  |     |     | STM | 1                                                                                                 |                                                                      |                                                                                                          | ຣເ                                                                            | JM                                   |                 |                                                       | DTM                                                    | 1                                                          |       |                                               | DL                | JM |
|    | S<br>PTS<br>RDC<br>RDB<br>RA<br>RSC<br>RSB<br>X | PT<br>(<br>(<br>Int<br>Re<br>Re<br>Re | 01 –<br>terru<br>evers<br>evers<br>evers<br>evers |    | benc<br>hen<br>st C<br>st B<br>add<br>c C<br>c B | com<br>addr<br>addr<br>ressi<br>addr<br>addr | essi<br>essi<br>ing<br>essi<br>essi | 1<br>ng<br>ng<br>ng<br>ng | 1 — F       | Fault<br>Fault |    |    |      |    | STI | M/D |     | (<br>(<br>(<br>(<br>(<br>(<br>(<br>(<br>(<br>(<br>(<br>(<br>(<br>(<br>(<br>(<br>(<br>(<br>()))))) | 000<br>001<br>010<br>011<br>c/ds<br>000<br>001<br>010<br>011<br>c/ds | ccess<br>– No<br>– PD<br>– Blo<br>– SR<br>– SR<br>Tra<br>– Cir<br>– Cir<br>– Re<br>– LU<br>st upo<br>Non | rmal<br>DT<br>Dck V<br>T<br>ansfe<br>mens<br>t<br>serv<br>T<br>t<br>date<br>e | Vrite<br>er Mo<br>sione<br>ed<br>moc | ode<br>ed<br>le | 101<br>110<br>111<br>100<br>101<br>110<br>111<br>01 - | - 16<br>- 32<br>- 64<br>- Va<br>- Va<br>- Fix<br>- Fix | Bit<br>bit T<br>Bit T<br>ar De<br>ar Off<br>ced I<br>ced C |       | sfer<br>fer<br>dide<br>Guide<br>Guid<br>-Guid | ed<br>ded<br>ided |    |
|    | l for oro c                                     | -                                     |                                                   |    |                                                  |                                              |                                     |                           |             |                |    |    |      |    |     |     |     | (                                                                                                 | 01-                                                                  | Add                                                                                                      | БΡ                                                                            | nch                                  |                 |                                                       | Add                                                    | U P                                                        | itch/ | Rev                                           | erse              | ;  |

<sup>†</sup> Valid for src only.

Figure 52. PT-Options Field



## local memory interface

### status codes

Status codes are output on STATUS[5:0] to describe the cycle being performed. During row time, STATUS[5:0] pins indicate the type of cycle being performed. The cycle type can be latched using RL or RAS and used by external logic to perform memory bank decoding or to enable special hardware features. During column time, the STATUS[5:0] pins indicate the requesting processor or special column information.

| STATUS[5:0] | CYCLE TYPE                   | STATUS[5:0] | CYCLE TYPE           |
|-------------|------------------------------|-------------|----------------------|
| 0 0 0 0 0 0 | Normal Read                  | 1 0 0 0 0 0 | Reserved             |
| 0 0 0 0 0 1 | Normal Write                 | 100001      | Reserved             |
| 0 0 0 0 1 0 | Refresh                      | 100010      | Reserved             |
| 000011      | SDRAM DCAB                   | 100011      | Reserved             |
| 0 0 0 1 0 0 | Peripheral Device PT Read    | 100100      | XPT1 Read            |
| 0 0 0 1 0 1 | Peripheral Device PT Write   | 100101      | XPT1 Write           |
| 0 0 0 1 1 0 | Reserved                     | 100110      | XPT1 PDPT Read       |
| 0 0 0 1 1 1 | Reserved                     | 100111      | XPT1 PDPT Write      |
| 0 0 1 0 0 0 | Reserved                     | 101000      | XPT2 Read            |
| 001001      | Block-Write PT               | 101001      | XPT2 Write           |
| 0 0 1 0 1 0 | Reserved                     | 101010      | XPT2 PDPT Read       |
| 001011      | Reserved                     | 101011      | XPT2 PDPT Write      |
| 0 0 1 1 0 0 | SDRAM MRS                    | 101100      | XPT3 Read            |
| 0 0 1 1 0 1 | Load Color Register          | 101101      | XPT3 Write           |
| 0 0 1 1 1 0 | Reserved                     | 101110      | XPT3 PDPT Read       |
| 0 0 1 1 1 1 | Reserved                     | 101111      | XPT3 PDPT Write      |
| 0 1 0 0 0 0 | Frame 0 Read Transfer        | 1 1 0 0 0 0 | XPT4/SAM1 Read       |
| 0 1 0 0 0 1 | Frame 0 Write Transfer       | 1 1 0 0 0 1 | XPT4/SAM1 Write      |
| 0 1 0 0 1 0 | Frame 0 Split-Read Transfer  | 1 1 0 0 1 0 | XPT4/SAM1 PDPT Read  |
| 0 1 0 0 1 1 | Frame 0 Split-Write Transfer | 1 1 0 0 1 1 | XPT4/SAM1 PDPT Write |
| 0 1 0 1 0 0 | Frame 1 Read Transfer        | 1 1 0 1 0 0 | XPT5/SOF1 Read       |
| 0 1 0 1 0 1 | Frame 1 Write Transfer       | 1 1 0 1 0 1 | XPT5/SOF1 Write      |
| 0 1 0 1 1 0 | Frame 1 Split-Read Transfer  | 1 1 0 1 1 0 | XPT5/SOF1 PDPT Read  |
| 0 1 0 1 1 1 | Frame 1 Split-Write Transfer | 1 1 0 1 1 1 | XPT5/SOF1 PDPT Write |
| 0 1 1 0 0 0 | Reserved                     | 1 1 1 0 0 0 | XPT6/SAM0 Read       |
| 0 1 1 0 0 1 | Reserved                     | 1 1 1 0 0 1 | XPT6/SAM0 Write      |
| 0 1 1 0 1 0 | Reserved                     | 1 1 1 0 1 0 | XPT6/SAM0 PDPT Read  |
| 0 1 1 0 1 1 | Reserved                     | 1 1 1 0 1 1 | XPT6/SAM0 PDPT Write |
| 0 1 1 1 0 0 | PT Read Transfer             | 1 1 1 1 0 0 | XPT7/SOF0 Read       |
| 0 1 1 1 0 1 | PT Write Transfer            | 1 1 1 1 0 1 | XPT7/SOF0 Write      |
| 0 1 1 1 1 0 | Reserved                     | 1 1 1 1 1 0 | XPT7/SOF0 PDPT Read  |
| 0 1 1 1 1 1 | Idle                         | 1 1 1 1 1 1 | XPT7/SOF0 PDPT Write |

## Table 29. Row-Time Status Codes



SGUS025 – AUGUST 1998

# local memory interface (continued)

| STATUS[5:0] | CYCLE TYPE                        | STATUS[5:0] | CYCLE TYPE               |
|-------------|-----------------------------------|-------------|--------------------------|
| 0 0 0 0 0 0 | PP0 Low-Priority Packet Transfer  | 1 0 0 0 0 0 | Reserved                 |
| 0 0 0 0 0 1 | PP0 High-Priority Packet Transfer | 100001      | Reserved                 |
| 0 0 0 0 1 0 | PP0 Instruction Cache             | 100010      | Reserved                 |
| 0 0 0 0 1 1 | PP0 DEA                           | 100011      | Reserved                 |
| 0 0 0 1 0 0 | PP1 Low-Priority Packet Transfer  | 100100      | Reserved                 |
| 0 0 0 1 0 1 | PP1 High-Priority Packet Transfer | 100101      | Reserved                 |
| 0 0 0 1 1 0 | PP1 Instruction Cache             | 100110      | Reserved                 |
| 0 0 0 1 1 1 | PP1 DEA                           | 100111      | Reserved                 |
| 0 0 1 0 0 0 | PP2 Low-Priority Packet Transfer  | 101000      | Reserved                 |
| 0 0 1 0 0 1 | PP2 High-Priority Packet Transfer | 101001      | Reserved                 |
| 0 0 1 0 1 0 | PP2 Instruction Cache             | 101010      | Reserved                 |
| 0 0 1 0 1 1 | PP2 DEA                           | 101011      | Reserved                 |
| 0 0 1 1 0 0 | PP3 Low-Priority Packet Transfer  | 101100      | Reserved                 |
| 0 0 1 1 0 1 | PP3 High-Priority Packet Transfer | 101101      | Reserved                 |
| 0 0 1 1 1 0 | PP3 Instruction Cache             | 101110      | Reserved                 |
| 0 0 1 1 1 1 | PP3 DEA                           | 101111      | Reserved                 |
| 0 1 0 0 0 0 | MP Low-Priority Packet Transfer   | 1 1 0 0 0 0 | Reserved                 |
| 0 1 0 0 0 1 | MP High-Priority Packet Transfer  | 1 1 0 0 0 1 | Reserved                 |
| 0 1 0 0 1 0 | MP Urgent Packet Transfer (Low)   | 1 1 0 0 1 0 | Reserved                 |
| 0 1 0 0 1 1 | MP Urgent Packet Transfer (High)  | 1 1 0 0 1 1 | Reserved                 |
| 0 1 0 1 0 0 | XPT/VCPT in Progress              | 1 1 0 1 0 0 | Reserved                 |
| 0 1 0 1 0 1 | XPT/VCPT Complete                 | 1 1 0 1 0 1 | Reserved                 |
| 0 1 0 1 1 0 | MP Instruction Cache (Low)        | 1 1 0 1 1 0 | Reserved                 |
| 0 1 0 1 1 1 | MP Instruction Cache (High)       | 1 1 0 1 1 1 | Reserved                 |
| 0 1 1 0 0 0 | MP DEA (Low)                      | 1 1 1 0 0 0 | Reserved                 |
| 0 1 1 0 0 1 | MP DEA (High)                     | 1 1 1 0 0 1 | Reserved                 |
| 0 1 1 0 1 0 | MP Data Cache (Low)               | 1 1 1 0 1 0 | Reserved                 |
| 0 1 1 0 1 1 | MP Data Cache (High)              | 1 1 1 0 1 1 | Reserved                 |
| 0 1 1 1 0 0 | Frame 0                           | 1 1 1 1 0 0 | Reserved                 |
| 0 1 1 1 0 1 | Frame 1                           | 1 1 1 1 0 1 | Reserved                 |
| 0 1 1 1 1 0 | Refresh                           | 1 1 1 1 1 0 | Reserved                 |
| 0 1 1 1 1 1 | Idle                              | 1 1 1 1 1 1 | Write Drain / SDRAM DCAB |

# Table 30. Column-Time Status Codes

Low – MP operating in low-(normal) priority mode High – MP operating in high-priority mode



SGUS025 - AUGUST 1998

### address multiplexing

To support various RAM devices, the SMJ320C80 can provide multiplexed row and column addresses on its address bus. A full 32-bit address is always output at row time. The alignment of column addresses is configured by the value input on the AS[2:0] pins at row time.

|    |    |    |    |    |    |    |    |    |    |    |    |    |    | ΑP  | ins |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17  | 16  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17  | 16  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|    |    |    |    |    |    |    |    |    |    |    |    |    | F  | Row | Tim | e  |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    | AΡ | ins |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| AS [2:0] | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 000      | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 001      | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8   | 7  | 6  | 5  | 4  | 3  | 2  | 1 | 0 | х | х | х | х | х | 2 | 1 | 0 |
| 010      | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7   | 6  | 5  | 4  | 3  | 2  | 1  | 0 | х | х | х | х | х | х | 2 | 1 | 0 |
| 100      | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6   | 5  | 4  | 3  | 2  | 1  | 0  | х | х | х | х | х | х | х | 2 | 1 | 0 |
| 011      | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5   | 4  | 3  | 2  | 1  | 0  | х  | х | х | х | х | х | х | х | 2 | 1 | 0 |
| 100      | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4   | 3  | 2  | 1  | 0  | х  | х  | х | х | х | х | х | х | х | 2 | 1 | 0 |
| 110      | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3   | 2  | 1  | 0  | х  | х  | х  | х | х | х | х | х | х | х | 2 | 1 | 0 |
| 111      | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2   | 1  | 0  | х  | х  | х  | х  | х | х | х | х | х | х | х | 2 | 1 | 0 |

A Dinc

Column Time

#### Figure 53. Address Multiplexing

#### dynamic bus sizing

The 'C80 supports data bus sizes of 8, 16, 32, or 64 bits. The value input on the BS[1:0] pins at row time indicates the bus size of the addressed memory. This determines the maximum number of bytes which the 'C80 can transfer during each column access. If the number of bytes to be transferred exceeds the bus size, multiple accesses are performed automatically to complete the transfer.

| BS[1:0] | BUS SIZE |
|---------|----------|
| 0 0     | 8 bits   |
| 0 1     | 16 bits  |
| 10      | 32 bits  |
| 11      | 64 bits  |

#### Table 31. Bus Size Selection

The selected bus size also determines which portion of the data bus is used for the transfer. For 64-bit memory, the entire data bus is used. For 32-bit memory, D[31:0] are used in little-endian mode and D[63:32] are used in big-endian mode. 16-bit buses use D[15:0] and D[63:48] and 8-bit buses use D[7:0] and D[63:56] for littleand big-endian modes, respectively. The 'C80 always aligns data to the proper portion of the bus and activates the appropriate CAS strobes to ensure that only valid bytes are transferred.



#### SGUS025 - AUGUST 1998

#### cycle time selection

The 'C80 supports eight basic sets of memory timings to support various memory types directly. The cycle timing is selected by the value input on the CT[2:0] pins at row time. The selected timing remains in effect until the next row access.

| CT[2:0] | MEMORY TIMING                                        |
|---------|------------------------------------------------------|
| 000     | Pipelined (Burst Length 1) SDRAM, CAS Latency of 2   |
| 001     | Pipelined (Burst Length 1) SDRAM, CAS Latency of 3   |
| 010     | Interleaved (Burst Length 2) SDRAM, CAS Latency of 2 |
| 011     | Interleaved (Burst Length 2) SDRAM, CAS Latency of 3 |
| 100     | Pipelined 1 Cycle/Column                             |
| 101     | Nonpipelined 1 Cycle/Column                          |
| 110     | 2 Cycle/Column                                       |
| 111     | 3 Cycle/Column                                       |

### Table 32. Cycle-Timing Selection

### page sizing

Whenever an external memory access occurs, the TC records the 22 most significant bits of the address in its internal LASTPAGE register. The address of each subsequent (column) access is compared to this value. The page size value input on the PS[3:0] pins determines which bits of LASTPAGE are used for this comparison. If a difference exists between the enabled LASTPAGE bits and the corresponding bits of the next access, then the page has changed and the next memory access begins with a new row-address cycle.

| PS[3:0] | ADDRESS BITS COMPARED | PAGE SIZE (BYTES) |
|---------|-----------------------|-------------------|
| 0000    | A[31:6]               | 64                |
| 0001    | A[31:7]               | 128               |
| 0010    | A[31:8]               | 256               |
| 0011    | A[31:9]               | 512               |
| 0100    | A[31:10]              | 1K                |
| 0101    | A[31:18]              | 256K              |
| 0110    | A[31:19]              | 512K              |
| 0111    | A[31:20]              | 1M                |
| 1000    | A[31:0]               | 1-8†              |
| 1001    | A[31:11]              | 2K                |
| 1010    | A[31:12]              | 4K                |
| 1011    | A[31:13]              | 8K                |
| 1 1 0 0 | A[31:14]              | 16K               |
| 1 1 0 1 | A[31:15]              | 32K               |
| 1 1 1 0 | A[31:16]              | 64K               |
| 1111    | A[31:17]              | 128K              |

#### Table 33. Page-Size Selection

<sup>†</sup> PS[3:0] = 1000 disables page-mode cycles so that the effective page size is the same as the bus size



### block-write support

The SMJ320C80 supports three modes of VRAM block-write. The block-write mode is dynamically selectable so that software can specify block-writes regardless of the type of block-write the addressed memory supports. Block-writes are supported only for 64-bit buses. During block-write and load-color-register cycles, the BS[1:0] inputs determine which block mode will be used.

| Table | 34. | Bloc | k-Wri | te Sel | ection |
|-------|-----|------|-------|--------|--------|
|       |     |      |       |        |        |

| BS[1:0] | BLOCK-WRITE MODE |
|---------|------------------|
| 0 0     | Simulated        |
| 0 1     | Reserved         |
| 1 0     | 4x               |
| 1 1     | 8x               |

## **SDRAM** support

The SMJ320C80 provides direct support for synchronous DRAM (SDRAM), synchronous VRAM (SVRAM), and synchronous graphics RAM (SGRAM). During 'C80 power-up refresh cycles, the external system must signal the presence of these memories by inputting a CT2 value of 0. This causes the 'C80 to perform special deactivate (DCAB) and mode register set (MRS) commands to initialize the synchronous RAMs. Figure 54 shows the MRS value generated by the 'C80.



CT0, CT1 as input at the start of the MRS cycle

### Figure 54. MRS Value

Because the MRS register is programmed through the SDRAM address inputs, the alignment of the MRS data to the 'C80 logical-address bits is adjusted for the bus size (see Figure 55). The appearance of the MRS bits on the 'C80 physical-address bus is dependent on the address multiplexing as selected by the AS[2:0] inputs.

|         |     |     |     |     |     | 'C8 | 0 LOG | ICAL | ADDRE | ESS BI | тѕ |    |    |    |    |    |
|---------|-----|-----|-----|-----|-----|-----|-------|------|-------|--------|----|----|----|----|----|----|
| BS[1:0] | A15 | A14 | A13 | A12 | A11 | A10 | A9    | A8   | A7    | A6     | A5 | A4 | A3 | A2 | A1 | A0 |
| 0 0     | Х   | Х   | Х   | Х   | 11  | 10  | 9     | 8    | 7     | 6      | 5  | 4  | 3  | 2  | 1  | 0  |
| 01      | Х   | Х   | Х   | 11  | 10  | 9   | 8     | 7    | 6     | 5      | 4  | 3  | 2  | 1  | 0  | Х  |
| 1 0     | Х   | Х   | 11  | 10  | 9   | 8   | 7     | 6    | 5     | 4      | 3  | 2  | 1  | 0  | Х  | Х  |
| 1 1     | Х   | 11  | 10  | 9   | 8   | 7   | 6     | 5    | 4     | 3      | 2  | 1  | 0  | Х  | Х  | Х  |

### memory cycles

SMJ320C80 external memory cycles are generated by the TC's external memory controller. The controller's state machine generates a sequence of states which define the transition of the memory interface signals. The state sequence is dependent on the cycle timing selected for the memory access being performed as shown in Figure 56. Memory cycles consist of row states and the column pipeline.



#### SGUS025 - AUGUST 1998

# memory cycles (continued)



Figure 56. Memory Cycle State Diagram



#### row states

The row states make up the row time of each memory access. They occur when each new page access begins. The transition indicators determine the conditions that cause transitions to another state.

### Table 35. Row States

| STATE | DESCRIPTION                                                                                                                                                                                                                                                                                              |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| r1    | Beginning state for all memory accesses. Outputs row address (A[31:0]) and cycle type (STATUS[5:0]) and drives control signals to their inactive state                                                                                                                                                   |
| r2    | Common to all memory accesses. Asserts RL and drives DDIN according to the data transfer direction. AS[2:0], BS[1:0], CT[2:0], PS[3:0], and UTIME inputs are sampled                                                                                                                                     |
| r3    | Common to all memory accesses. DBEN is driven to its active level. For non-SDRAM, $\overline{W}$ , $\overline{TRG}/\overline{CAS}$ , and DSF are driven to their active levels, and for non-SDRAM refreshes, all $\overline{CAS}/DQM$ strobes are activated. FAULT, READY, and RETRY inputs are sampled. |
| r4    | Inserted for 3 cycle/column accesses (CT=111) only. No signal transitions occur. RETRY input is sampled.                                                                                                                                                                                                 |
| r5    | Common to SDRAM and 2 or 3 cycle/column accesses (CT=0xx or 11x). RAS is driven low. $\overline{W}$ is driven low for DCAB and MRS cycles and TRG/CAS is driven low for MRS and SDRAM refresh cycles.                                                                                                    |
| r6    | Common to all memory accesses. For SDRAM cycles, RAS, TRG/CAS, and W are driven high. For non-SDRAM, RAS is driven low (if not already) and W, TRG / CAS, and DSF are driven to their appropriate levels. DBEN is driven low and READY and RETRY are sampled.                                            |
| rspin | Additional state to allow TC column time pipeline to load. No signal transitions occur. RETRY is sampled. The rspin state can, on occasion, repeat multiple times.                                                                                                                                       |
| r7    | Common to 2 and 3 cycle/column refreshes (CT=11x). Processor activity code is output on STATUS[5:0]. RETRY input is sampled.                                                                                                                                                                             |
| r8    | For 3 cycle/column refreshes only (CT=111). No signal transitions occur. RETRY input is sampled.                                                                                                                                                                                                         |
| r9    | Common to all refresh cycles. Processor activity code is output on STATUS[5:0] and RETRY input is sampled.                                                                                                                                                                                               |
| drn   | Occurs for SDRAM cycles (CT = 0xx) and pipelined 1 cycle/column writes only. For SDRAM cycles, $\overline{RAS}$ , and $\overline{W}$ are activated to perform a DCAB command. For pipelined writes, all $\overline{CAS}$ /DQM strobes are activated.                                                     |
| rhiz  | High-impedance state. Occurs during host requests and repeats until bus is released by the host                                                                                                                                                                                                          |

### Table 36. State Transition Indicators

| INDICATOR | DESCRIPTION                                                                    |
|-----------|--------------------------------------------------------------------------------|
| any cycle | Continuation of current cycle                                                  |
| CT=xxx    | State change occurs for indicated CT[2:0] value (as latched in r2 state)       |
| abort     | Current cycle aborted by TC in favor of higher-priority cycle                  |
| fault     | FAULT input sampled low (in r3 state), memory access faulted                   |
| retry     | RETRY input sampled low (in r3 state), row-time retry                          |
| wait      | READY input sampled low (in r3, r6, or last column state) repeat current state |
| spin      | Internally generated wait state to allow TC pipeline to load                   |
| new page  | The next access requires a page change (new row access)                        |

### external memory timing examples

The following sections contain descriptions of the 'C80 memory cycles and illustrate the signal transitions for those cycles. Memory cycles can be separated into two basic categories: DRAM-type cycles for use with DRAM-like devices, SRAM, and peripherals, and SDRAM-type cycles for use with SDRAM-like devices.



#### SGUS025 – AUGUST 1998

### DRAM-type cycles

The DRAM-type cycles are page-mode accesses consisting of a row access followed by one or more column accesses. Column accesses may be one, two, or three clock cycles in length with two and three cycle accesses allowing the insertion of wait states to accommodate slow devices. Idle cycles can occur after necessary column accesses have completed or between column accesses due to "bubbles" in the TC data-flow pipeline. The pipeline diagrams in Figure 57 show the pipeline stages for each access type and when the CAS/DQM signal corresponding to the column access is activated.







SGUS025 - AUGUST 1998

### read cycles

Read cycles transfer data or instructions from external memory to the 'C80. The cycles can occur as a result of a packet transfer, cache request, or DEA request. During the cycle,  $\overline{W}$  is held high,  $\overline{TRG}/\overline{CAS}$  is driven low after  $\overline{RAS}$  to enable memory output drivers and  $\overline{DBEN}$  and  $\overline{DDIN}$  are low so that data transceivers can drive into the 'C80. During column time, the TC places D[63:0] into the high-impedance state, allowing it to be driven by the memory and latches input data during the appropriate column state. The TC always reads 64 bits and extracts and aligns the appropriate bytes. Invalid bytes for bus sizes of less than 64 bits are discarded. During peripheral device packet transfers,  $\overline{DBEN}$  and  $\overline{DDIN}$  remain high.















SGUS025 - AUGUST 1998

### read cycles (continued)



Internally generated pipeline bubble (example)





SGUS025 - AUGUST 1998



<sup>†</sup> Wait state inserted by external logic (example)

<sup>‡</sup> Internally generated pipeline bubble (example)

### Figure 61. 3-Cycle/Column Read-Cycle Timing

### write cycles

Write cycles transfer data from the 'C80 to external memory. These cycles can occur as a result of a packet transfer, a DEA request, or an MP data cache write-back. During the cycle TRG/CAS is held high,  $\overline{W}$  is driven low after the fall of RAS to enable early-write cycles, and DDIN is high so that data transceivers drive toward memory. The TC drives data out on D[63:0] and indicates valid bytes by activating the appropriate CAS/DQM strobes. During peripheral device packet transfers, DBEN remains high and D[63:0] is placed in high impedance so that the peripheral device can drive data into the memory.















#### SGUS025 – AUGUST 1998

### write cycles (continued)



<sup>‡</sup> Internally generated pipeline bubble (example)





SGUS025 - AUGUST 1998



<sup>†</sup> Wait state inserted by external logic (example)

<sup>‡</sup> Internally generated pipeline bubble (example)





#### SGUS025 – AUGUST 1998

### load-color-register cycles

Load-color-register (LCR) cycles are used to load a VRAM's color register prior to performing a block-write. LCR cycles are supported only on 64-bit data buses. An LCR cycle closely resembles a normal write cycle because it writes into a VRAM. The difference is that the DSF output is high at both the fall of  $\overline{RAS}$  and the fall of  $\overline{CAS}$ /DQM. Also, because the VRAM color register is a single location, only one column access occurs.

The row address that is output by the TC is used for bank-decode only. Normally, all VRAM banks should be selected during an LCR cycle because another LCR cycle cannot occur when a block-write memory-page change occurs. The column address that is output during an LCR is likewise irrelevant because the VRAM color register is the only location written. All CAS/DQM strobes are active during an LCR cycle.

If exception support for a given bank is enabled, the  $\overline{\text{EXCEPT}}$  [1:0] inputs are sampled during LCR column states and must be at valid levels. A retry code ( $\overline{\text{EXCEPT}}$  [1:0] = 10) at column time has no effect, however, because only one column access is performed.

If the BW field of the configuration cache entry for the given bank indicates that the addressed memory supports only simulated block-writes, the LCR cycle will be changed into a normal write cycle at the start of the simulated block-write.





Figure 66. Pipelined 1-Cycle/Column Load-Color-Register-Cycle Timing





















### block-write cycles

Block-write cycles cause the data stored in the VRAM color registers to be written to the memory locations enabled by the appropriate data bits output on the D[63:0] bus. This allows up to a total of 64 bytes (depending on the type of block-write being used) to be written in a single-column access. This cycle is identical to a standard write cycle with the following exceptions:

- DSF is active (high) at the fall of CAS, enabling the block-write function within the VRAMs.
- Only 64-bit bus sizes are supported during block-write; therefore, BS[1:0] inputs are used to indicate the type of block-write that is supported by the addressed VRAMs, rather than the bus size.
- The two or three LSBs (depending on the type of block-write) of the column address are ignored by the VRAMs because these column locations are specified by the data inputs.
- The values output by the TC on D[63:0] represent the column locations to be written to, using the color register value. Depending on the type of block-write supported by the VRAM, all of the data bits are not necessarily used by the VRAMs.
- Block-writes always begin with a row access. Upon completion of a block-write, the memory interface returns to state r1 to await the next access.





















SGUS025 - AUGUST 1998



<sup>†</sup> Wait state inserted by external logic (example)

<sup>‡</sup> Internally generated pipeline bubble (example)

Figure 73. 3-Cycle/Column Block-Write-Cycle Timing



#### SGUS025 – AUGUST 1998

### transfer cycles

Read-transfer (memory-to-register) cycles transfer a row from the VRAM memory array into the VRAM shift register (sequential-access memory, or SAM). This causes the entire SAM (both halves of the split SAM) to be loaded with the array data.

Split-register read-transfer (memory-to-split-register) cycles also transfer data from a row in the memory array to the SAM. However, these transfers cause only half of the SAM to be written. Split-register read transfers allow the inactive half of the SAM to be loaded with the new data while the other active half continues to shift data in or out.

Write-transfer (register-to-memory) cycles transfer data from the SAM into a row of the VRAM array. This transfer causes the entire SAM (both halves of the split SAM) to be written into the array.

Split-register write-transfer (split-register-to-memory) cycles also transfer data from the SAM to a row in the memory array. However, these transfers write only half of the SAM into the array. Split-register write transfers allow the inactive half of the SAM to be transferred into memory while the other (active) half continues to shift serial data in or out.

Read and split-read transfers resemble a standard read cycle. Write and split-write transfers resemble a standard write cycle. The  $\overline{TRG}/\overline{CAS}$  output is driven low prior to the fall of  $\overline{RAS}$  to indicate a transfer cycle. Only a single column access is performed so  $\overline{RETRY}$ , while required to be at a valid level, has no effect if asserted at column time. The value output on A[31:0] at column time represents the SAM tap point.











Figure 75. Nonpipelined 1-Cycle/Column Read-Transfer and Split-Register Read-Transfer-Cycle Timing

















Figure 78. Pipelined 1-Cycle/Column Write-Transfer and Split-Register Write-Transfer-Cycle Timing





Figure 79. Nonpipelined 1-Cycle/Column Write-Transfer and Split-Register Write-Transfer-Cycle Timing





Figure 80. 2-Cycle/Column Write-Transfer and Split-Register Write-Transfer-Cycle Timing





Figure 81. 3-Cycle/Column Write-Transfer and Split-Register Write-Transfer-Cycle Timing



### refresh cycles

Refresh cycles are generated by the TC at the programmed refresh interval. They are characterized by the following signal activity:

- CAS falls prior to RAS.
- All  $\overline{CAS}$  pins ( $\overline{CAS[7:0]}$ ) are active.
- TRG, W, and DBEN all remain inactive (high) because no data transfer occurs.
- DSF is active (high) at the fall of  $\overline{CAS}$  and is driven inactive prior to the fall of  $\overline{RAS}$ .
- The data bus is driven to the high-impedance state.
- The upper half of the address bus (A[31:16]) contains the refresh pseudo-address and the lower half (A[15:0]) is driven to all zeros.
- If RETRY is asserted at any sample point during the cycle, the cycle timing is not modified. Instead, the pseudo-address and backlog counters are simply not decremented.
- Selecting user-modified timing has no effect on the cycles.
- Upon completion of the refresh cycle, the memory interface returns to state r1 to await the next access.











Figure 83. 2-Cycle/Column Refresh-Cycle Timing









SGUS025 - AUGUST 1998

### SDRAM-type cycles

The SDRAM-type cycles support the use of SDRAM, SGRAM, or SVRAM devices for single-cycle memory accesses. While SDRAM cycles use the same state sequences as DRAM cycles, the memory-control signal transitions are modified to perform SDRAM command cycles. The supported SDRAM commands are:

- DCAB Deactivate (precharge) all banks
- ACTV Activate the selected bank and select the row
- READ Input starting column address and start read operation
- WRT Input starting column address and start write operation
- MRS Set SDRAM mode register
- REFR Auto-refresh cycle with internal address
- SRS Set special register (color register)
- BLW Block write

SDRAM cycles begin with an activate (ACTV) command followed by the requested column accesses. When a memory-page change occurs, the selected bank is deactivated with a DCAB command.

The SMJ320C80 supports CAS latencies of 2 or 3 cycles and burst lengths of 1 or 2. These are selected by the CT code input at the start of the access.

The column pipelines for SDRAM accesses are shown in Figure 85. Idle cycles can occur after necessary column accesses have completed or between column accesses due to "bubbles" in the TC data flow pipeline. The pipeline diagrams show the pipeline stages for each access type and when the CAS/DQM signal corresponding to the column access is activated.



SGUS025 – AUGUST 1998



Figure 85. SDRAM Column Pipelines

### special SDRAM cycles

Burst-length 2, 3-cycle latency block-writes, write transfers, split-write transfers

To initialize the SDRAM properly, the SMJ320C80 performs two special SDRAM cycles after reset. The 'C80 first performs a deactivate cycle on all banks (DCAB) and then initializes the SDRAM mode register with a mode register set (MRS) cycle. The CT code input at the start of the MRS cycle determines the burst length and latency that is programmed into the SDRAM mode register.



SGUS025 - AUGUST 1998



Figure 86. SDRAM Power-Up Deactivate Cycle Timing



SGUS025 – AUGUST 1998



Figure 87. SDRAM Mode-Register-Set Cycle Timing



SGUS025 - AUGUST 1998

#### SDRAM read cycles

Read cycles begin with an activate (ACTV) command to activate the bank and to select the row. The TC outputs the column address and activates the TRG/CAS strobe for each read command. For burst-length 1 accesses, a read command can occur on each cycle. For burst-length 2 accesses, a read command can occur every two cycles. The TC places D[63:0] into the high-impedance state, allowing it to be driven by the memory, and latches input data during the appropriate column state. The TC always reads 64 bits and extracts and aligns the appropriate bytes. Invalid bytes for bus sizes of less than 64 bits are discarded. The CAS/DQM strobes are activated two cycles before input data is latched. If the second column in a burst is not required, then CAS/DQM is not activated. During peripheral device packet transfers, DBEN remains high.



SGUS025 - AUGUST 1998





SGUS025 - AUGUST 1998





SGUS025 - AUGUST 1998



Figure 90. SDRAM Burst-Length 2, 2-Cycle Latency Read-Cycle Timing



SGUS025 - AUGUST 1998



Figure 91. SDRAM Burst-Length 2, 3-Cycle Latency Read-Cycle Timing



SGUS025 - AUGUST 1998

#### SDRAM write cycles

Write cycles begin with an activate (ACTV) command to activate the bank and select the row. The TC outputs the column address and activates the  $\overline{TRG}/\overline{CAS}$  and  $\overline{W}$  strobes for each write command. For burst-length 1 accesses, a write command can occur on each cycle. For burst-length 2 accesses, a write command can occur every two cycles. The TC drives data out on D[63:0] during each cycle of an active-write command and indicates valid bytes by driving the appropriate  $\overline{CAS}/DQM$  strobes low. During peripheral device packet transfers,  $\overline{DBEN}$  remains high and D[63:0] are placed in the high-impedance state so that the peripheral can drive data into the memories.



SGUS025 - AUGUST 1998



Figure 92. SDRAM Burst-Length 1 Write-Cycle Timing



SGUS025 - AUGUST 1998



Figure 93. SDRAM Burst-Length 2 Write-Cycle Timing



SGUS025 - AUGUST 1998

#### special register set cycles

Special register set (SRS) cycles are used to program control registers within an SVRAM or SGRAM. The 'C80 only supports programming of the color register for use with block-writes. The cycle is similar to a single burst length 1 write cycle but DSF is driven high. The values output on the 'C80 address bits cause the color register to be selected as shown in Figure 94.



Figure 95. SDRAM SRS-Cycle Timing



#### SGUS025 – AUGUST 1998

#### SDRAM block-write cycles

Block-write cycles allow SVRAMs and SGRAMs to write a stored color value to multiple column locations in a single access. Block-write cycles are similar to write cycles except that DSF is driven high to indicate a block-write command. Because burst is not supported for block-write, burst-length 2 accesses generate a single block-write every other clock cycle.





SGUS025 - AUGUST 1998





#### SGUS025 – AUGUST 1998

#### SVRAM transfer cycles

The SVRAM read- and write-transfer cycles transfer data between the SVRAM memory-array and the serial register (SAM). The SMJ320C80 supports both normal and split transfers for SVRAMs. Read- and split-read transfers resemble a standard read cycle. Write- and split-write transfers resemble a standard write cycle. Because the 'C80's TRG output is used as CAS, external logic must generate a TRG signal (by decoding STATUS) to enable the SVRAM transfer cycle. The value output on A[31:0] at column time represents the SAM trap point.



Figure 98. SVRAM Burst-Length 1, 2-Cycle Latency Read-Transfer Cycle Timing



SGUS025 - AUGUST 1998



Figure 99. SVRAM Burst-Length 1, 3-Cycle Latency Read-Transfer Cycle Timing



SGUS025 - AUGUST 1998



Figure 100. SVRAM Burst-Length 2, 2-Cycle Latency Read-Transfer Cycle Timing



SGUS025 - AUGUST 1998



Figure 101. SVRAM Burst-Length 2, 3-Cycle Latency Read-Transfer Cycle Timing



SGUS025 - AUGUST 1998



Figure 102. SVRAM Burst-Length 1, Write-Transfer Cycle Timing



SGUS025 - AUGUST 1998



Figure 103. SVRAM Burst-Length 2, Write-Transfer Cycle Timing

#### SDRAM refresh cycle

The SDRAM refresh cycle is performed when the TC receives an SDRAM cycle timing input (CT=0xx) at the start of a refresh cycle. The RAS and TRG/CAS outputs are driven low for one cycle to strobe a refresh command (REFR) into the SDRAM. The refresh address is generated internal to the SDRAM. The 'C80 outputs a 16-bit pseudo-address (used for refresh bank decode) on A[31:16] and drives A[15:0] low.



#### SGUS025 - AUGUST 1998



Figure 104. SDRAM Refresh Cycle Timing



SGUS025 - AUGUST 1998

#### host interface

The 'C80 contains a simple four-pin mechanism by which a host or another device can gain control of the 'C80 local memory bus. The HREQ input can be driven low by the host to request the 'C80's bus. Once the TC has completed the current memory access, it places the local bus (except CLKOUT) into a high-impedance state. It then drives the HACK output low to indicate that the host device owns the bus and can drive it. The REQ[1:0] outputs reflect the highest-priority cycle request being received internally by the TC. The host can monitor these outputs to determine if it needs to relinquish the local bus back to the 'C80.

| REQ[1:0] | ASSOCIATED INTERNAL TC REQUEST                      |
|----------|-----------------------------------------------------|
| 11       | SRT, urgent refresh, XPT, or VCPT                   |
| 10       | Cache/DEA request, urgent packet transfer           |
| 01       | High-priority packet transfer                       |
| 00       | Low-priority packet transfer, trickle refresh, idle |

| Table | 37.   | тс | Priority | Cvcles |
|-------|-------|----|----------|--------|
| 10010 | • • • |    |          | 0,0.00 |

#### device reset

The SMJ320C80 is reset when the  $\overline{\text{RESET}}$  input is driven low. The 'C80 outputs immediately go into a high-impedance state with the exception of CLKOUT,  $\overline{\text{HACK}}$ , and REQ[1:0]. While  $\overline{\text{RESET}}$  is low, all internal registers are set to their default values and internal logic is reset.

On the rising edge of  $\overline{\text{RESET}}$ , the state of  $\overline{\text{UTIME}}$  is sampled to determine if big-endian ( $\overline{\text{UTIME}} = 0$ ) or little-endian ( $\overline{\text{UTIME}} = 1$ ) operation is selected. Also, on the rising edge of  $\overline{\text{RESET}}$ , the state of  $\overline{\text{HREQ}}$  is sampled to determine if the master processor comes up running ( $\overline{\text{HREQ}} = 0$ ) or halted ( $\overline{\text{HREQ}} = 1$ ).

Once  $\overrightarrow{\text{RESET}}$  is high, the 'C80 drives the high-impedance signals to their inactive values. The TC then performs 32 refresh cycles to initialize system memory. If, during initialization refresh, the TC receives an SDRAM cycle timing code (CT = 0xx), it performs an SDRAM DCAB cycle and a MRS cycle to initialize the SDRAM, and then continues the refresh cycles.

After completing initialization refresh, if the MP is running, the TC performs its instruction-cache-fill request to fetch the cache block beginning at 0xFFFFFC0. This block contains the starting MP instruction located at 0xFFFFFF8. If the MP comes up halted, the instruction cache fill does not take place until the first occurrence of an EINT3 interrupt to unhalt the MP.



SGUS025 – AUGUST 1998

#### absolute maximum ratings over specified temperature ranges (unless otherwise noted)<sup>†</sup>

| Supply voltage range, V <sub>DD</sub> (see Note 1) – 0.3 V to 4 V |
|-------------------------------------------------------------------|
| Input voltage range, V <sub>1</sub> – 0.3 V to 4 V                |
| Output voltage range                                              |
| Ambient air temperature, T <sub>A</sub> – 55°C to 125°C           |
| Storage temperature range, T <sub>stg</sub> – 55°C to 150°C       |

† Stresses beyond those listed under "absolute maximum ratings" may cause permanent damage to the device. These are stress ratings only, and functional operation of the device at these or any other conditions beyond those indicated under "recommended operating conditions" is not implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability.

NOTE 1: All voltage values are with respect to  $V_{SS}$ .

#### recommended operating conditions

|                 |                             | MIN   | NOM | MAX   | UNIT |
|-----------------|-----------------------------|-------|-----|-------|------|
| V <sub>DD</sub> | Supply voltage              | 3.135 | 3.3 | 3.465 | V    |
| VSS             | Supply voltage (see Note 2) | 0     | 0   | 0     | V    |
| IOH             | High-level output current   |       |     | - 400 | μA   |
| IOL             | Low-level output current    |       |     | 2     | mA   |
| ТС              | Case temperature            |       |     | 125   | °C   |
| ТА              | Ambient-air temperature     | - 55  |     |       | °C   |

NOTE 2: To minimize noise on VSS, care should be taken to provide a minimum inductance path between the VSS pins and system ground.

# electrical characteristics over recommended range of supply voltage and specified temperature (unless otherwise noted)

|     | PARAMETER                                                          | TEST CONDITIONS <sup>‡</sup>         | MIN   | TYP§ MAX              | UNIT |
|-----|--------------------------------------------------------------------|--------------------------------------|-------|-----------------------|------|
| VIH | High-level input voltage                                           |                                      | 2     | V <sub>DD</sub> + 0.3 | V    |
| VIL | Low-level input voltage                                            |                                      | - 0.3 | 0.8                   | V    |
| VOH | High-level output voltage                                          | $V_{DD} = MIN, \qquad I_{OH} = MAX$  | 1.85  |                       | V    |
| VOL | Low-level output voltage                                           | V <sub>DD</sub> = MAX                |       | 0.9                   | V    |
|     | Output current, leakage (high impedance)<br>(except EMU0 and EMU1) | $V_{DD} = MAX, \qquad V_O = 2.8 V$   |       | 20                    | uА   |
| 10  |                                                                    | $V_{DD} = MAX, \qquad V_{O} = 0.6 V$ |       | - 20                  | μΑ   |
| lj  | Input current (except TCK, TDI, and TMS), TRST                     | $V_I = V_{SS}$ to $V_{DD}$           |       | ±20                   | μΑ   |
| IDD | Supply current (see Note 3)                                        | V <sub>DD</sub> = MAX, 50 MHz        |       | 1§ 2.5                | А    |
| Ci  | Input capacitance                                                  |                                      |       | 10§                   | pF   |
| Co  | Output capacitance                                                 |                                      |       | 10§                   | pF   |

<sup>‡</sup> For conditions shown as MIN/MAX, use the appropriate value specified under the recommended operating conditions.

All typical values are at V<sub>DD</sub> = 3.3 V, T<sub>A</sub> = 25°C

 $\P$  Typical steady-state V<sub>OH</sub> will not exceed V<sub>DD</sub>

NOTE 3: Maximum supply current is derived from a test case that generates the theoretical maximum data flow using a worst case checkerboard data pattern on a sustained cycle by cycle basis. Actual maximum I<sub>DD</sub> varies in real applications based on internal and external data flow and transitions. Typical supply current is derived from a test case which attempts to emulate typical use conditions of the on-chip processors with random data. Typical I<sub>DD</sub> varies from application to application based on data flow and transitions and on-chip processor utilization.



SGUS025 - AUGUST 1998



#### PARAMETER MEASUREMENT INFORMATION

#### signal transition levels

TTL-output levels are driven to a minimum logic-high level of 1.85 V and to a maximum logic-low level of 0.9 V. Figure 106 shows the TTL-level outputs.



Figure 106. TTL-Level Outputs

TTL-output transition times are specified as follows:

- For a high-to-low transition, the level at which the output is said to be no longer high is 1.75 V, and the level at which the output is said to be low is 1.0 V.
- For a low-to-high transition, the level at which the output is said to be no longer low is 1.0 V, and the level at which the output is said to be high is 1.75 V.

Figure 107 shows the TTL-level inputs.





TTL-compatible input transition times are specified as follows:

- For a high-to-low transition on an input signal, the level at which the input is said to be no longer high is 2 V, and the level at which the input is said to be low is 0.8 V.
- For a low-to-high transition on an input signal, the level at which the input is said to be no longer low is 0.8 V, and the level at which the input is said to be high is 2 V.



SGUS025 - AUGUST 1998

#### PARAMETER MEASUREMENT INFORMATION

#### timing parameter symbology

transition time

pulse duration (width)

t w

Timing parameter symbols used herein were created in accordance with JEDEC Standard 100-A. In order to shorten the symbols, some of the pin names and other related terminology have been abbreviated as follows:

| А       | A[31:0]                                                                                                      | RDY | READY                                                                                                                  |
|---------|--------------------------------------------------------------------------------------------------------------|-----|------------------------------------------------------------------------------------------------------------------------|
| CAS     | CAS/DQM[7:0]                                                                                                 | RST | RESET                                                                                                                  |
| CFG     | AS[2:0], BS[1:0], CT[2:0], PS[3:0], UTIME                                                                    | RTY | RETRY                                                                                                                  |
| CKI     | CLKIN                                                                                                        | REQ | REQ[1:0]                                                                                                               |
| СКО     | CLKOUT                                                                                                       | RL  | RL                                                                                                                     |
| CMP     | RETRY, READY, FAULT                                                                                          | RR  | READY, RETRY                                                                                                           |
| D       | D[63:0]                                                                                                      | SCK | SCLK0, SCLK1                                                                                                           |
| EIN     | EINT1, EINT2, EINT3, or EINTx                                                                                | тск | ТСК                                                                                                                    |
| EMU     | EMU0, EMU1                                                                                                   | TDI | TDI                                                                                                                    |
| FCK     | FCLK0, FCLK1                                                                                                 | TDO | TDO                                                                                                                    |
| HAK     | HACK                                                                                                         | TMS | TMS                                                                                                                    |
| HRQ     | HREQ                                                                                                         | TRS | TRST                                                                                                                   |
| LIN     | LINT4                                                                                                        | UTM | UTIME                                                                                                                  |
| MID     | A[31:0], STATUS[5:0]                                                                                         | SI  | HSYNCO, VSYNCO, CSYNCO, HSYNC1, VSYNC1, or CSYNC1                                                                      |
| OUT     | A[31:0], <u>CAS</u> /DQM[7:0], D[6 <u>3:0], DBEN</u> , <u>DDIN,</u><br>DSF, RAS, RL, STATUS[5:0], TRG/CAS, W | SY  | HSYNCO, VSYNCO, CSYNCO/HBLNKO,<br>CBLNKO/VBLNKO, HSYNC1, VSYNC1,<br>CSYNC1/HBLNK1, CBLNK1/VBLNK1, CAREAO,<br>or CAREA1 |
| RAS     | RAS                                                                                                          | XPT | XPT[2:0] OR XPTx                                                                                                       |
| Lowerca | ase subscripts and their meanings are:                                                                       |     | The following letters and symbols and their meanings are:                                                              |
| а       | access time                                                                                                  |     | H High                                                                                                                 |
| С       | cycle time (period)                                                                                          |     | L Low                                                                                                                  |
| d       | delay time                                                                                                   |     | V Valid                                                                                                                |
| h       | hold time                                                                                                    |     | Z High impedance                                                                                                       |
| su      | setup time                                                                                                   |     | X Unknown, changing, or don't care level                                                                               |
|         |                                                                                                              |     |                                                                                                                        |



#### general notes on timing parameters

The period of the output clock (CLKOUT) is twice the period of the input clock (CLKIN), or  $2 \times t_{c(CKI)}$ . The half cycle time (t<sub>H</sub>) that appears in the following tables is one-half of the output clock period, or equal to the input clock period,  $t_{c(CKI)}$ .

All output signals from the 'C80 (including CLKOUT) are derived from an internal clock such that all output transitions for a given half cycle occur with a minimum of skewing relative to each other.

The signal combinations shown in the following timing diagrams may not necessarily represent actual cycles. For actual cycle examples, refer to the appropriate cycle description section of this data sheet.

CLKIN timing requirements (see Figure 108)

| NO |                                                       | MIN | MAX  | UNIT |
|----|-------------------------------------------------------|-----|------|------|
| 1  | t <sub>c(CKI)</sub> Period of CLKIN (t <sub>H</sub> ) | 10  |      | ns   |
| 2  | tw(CKIH) Pulse duration of CLKIN high                 | 4.2 |      | ns   |
| 3  | t <sub>w(CKIL)</sub> Pulse duration of CLKIN low      | 4.2 |      | ns   |
| 4  | t <sub>t(CKI)</sub> Transition time of CLKIN          |     | 1.5* | ns   |

\* This parameter is not production tested.



Figure 108. CLKIN Timing

#### local-bus switching characteristics over full operating range: CLKOUT<sup>†</sup> (see Figure 109)

| NO |                                      | PARAMETER MIN                      | MAX  | UNIT |
|----|--------------------------------------|------------------------------------|------|------|
| 5  | t <sub>c(CKO)</sub> Period of CLKOUT | <sup>2t</sup> c(CKI) <sup>‡*</sup> |      | ns   |
| 6  | tw(CKOH) Pulse duration of Cl        | _KOUT high t <sub>H</sub> -4.5     |      | ns   |
| 7  | tw(CKOL) Pulse duration of Cl        | LKOUT low t <sub>H</sub> -4.5      |      | ns   |
| 8  | tt(CKO) Transition time of C         | LKOUT                              | 2.5* | ns   |

<sup>†</sup> The CLKOUT output has twice the period of CLKIN. No propagation delay or phase relationship to CLKIN is ensured. Each state of a memory access begins on the falling edge of CLKOUT.

<sup>‡</sup> This parameter can also be specified as 2t<sub>H</sub>.

\* This parameter is not production tested.



Figure 109. CLKOUT Timing



SGUS025 - AUGUST 1998

#### device reset timing requirements (see Figure 110)

| NO      |                                               |                                                                         |                               |                 |    |    |  |
|---------|-----------------------------------------------|-------------------------------------------------------------------------|-------------------------------|-----------------|----|----|--|
| 9 tw/PS | t (DOTI)                                      |                                                                         | Initial reset during power-up | 6t <sub>h</sub> |    | ns |  |
| 9       | <sup>t</sup> w(RSTL) Pulse duration, RESET lo | Pulse duration, RESET low                                               | Reset during active operation | 6t <sub>h</sub> |    | ns |  |
| 10      | <sup>t</sup> su(HRQL-RSTH)                    | Setup time of HREQ low to RESET high to configure s                     | 4t <sub>h</sub>               |                 | ns |    |  |
| 11      | <sup>t</sup> h(RSTH-HRQL)                     | Hold time, HREQ low after RESET high to configure s                     | elf-bootstrap mode            | 0               |    | ns |  |
| 12      | <sup>t</sup> su(UTML-RSTH)                    | Betup time of UTIME low to RESET high to configure big-endian operation |                               |                 |    | ns |  |
| 13      | <sup>t</sup> h(RSTH-UTML)                     | Hold time, UTIME low after RESET high to configure b                    | 0                             |                 | ns |    |  |



Figure 110. Device-Reset Timing



#### local bus timing requirements: cycle configuration inputs (see Figure 111)

The cycle configuration inputs are sampled at the beginning of each row access during the r2 state. The inputs typically are generated by a static decode of the A[31:0] and STATUS[5:0] outputs.

| NO                         |               |                           |                                       |             |                |            |                         |        | MIN                             | MAX                  | UNIT |
|----------------------------|---------------|---------------------------|---------------------------------------|-------------|----------------|------------|-------------------------|--------|---------------------------------|----------------------|------|
| 14 t <sub>su</sub> (CFGV-C | KOH) Setup ti | ime, AS, B                | S, CT, PS                             | , and UTIM  | E valid to CL  | KOUT no le | onger lov               | V      | 8                               |                      | ns   |
| 15 th(CKOH-C               |               |                           |                                       |             | valid after C  | -          | -                       |        | 2                               |                      | ns   |
| 16 t <sub>a(MIDV-CF</sub>  |               | time, AS, I<br>TUS) valid |                                       | S, and UTII | ME valid after | memory id  | dentificat              | ion    |                                 | 3t <sub>H</sub> – 10 | ns   |
|                            | CLKOUT        |                           | tH                                    | tH          | tH             |            | tH '                    | tH     | t <sub>1</sub>                  | ·                    |      |
|                            | STATUS[5:0]   |                           |                                       | X           |                | Cycle      | Туре                    |        | 1                               | _                    |      |
|                            | A[31:0]       |                           |                                       |             |                | Row Ac     | ddress                  |        |                                 | _                    |      |
|                            | RL            |                           | , , , , , , , , , , , , , , , , , , , |             | 16             |            |                         | 4 15 - | ▶<br> -<br> -<br> -<br> -<br> - | _                    |      |
|                            | AS[2:0]       |                           |                                       |             |                |            | - 14 — <b>&gt;</b><br>V | alid   |                                 | $\mathbf{X}$         |      |
|                            | BS[1:0]       |                           |                                       |             |                |            | v                       | alid   |                                 | $\bigotimes$         |      |
|                            | CT[2:0]       |                           |                                       |             |                |            | V                       | alid   |                                 | $\bigotimes$         |      |
|                            | PS[3:0]       |                           |                                       |             |                |            | V                       | alid   |                                 | $\bigotimes$         |      |
|                            | UTIME         |                           |                                       |             |                |            | V                       | alid   |                                 | $\bigotimes$         |      |

Figure 111. Local Bus Timing: Cycle Configuration Inputs



SGUS025 - AUGUST 1998

#### local bus timing: cycle completion inputs (see Figure 112 and Figure 113)

The cycle completion inputs are sampled at the beginning of each row access at the start of the r3 state. The READY input is sampled also at the start of the r6 state and during each column access (2 and 3 cyc/col accesses only). The RETRY input is sampled on each CLKOUT falling edge following r3. The value *n* as used in the parameters represents the integral number of half cycles between the transitions of the two signals in question.

| NO |                             |                                                                     |                    | MIN | MAX                  | UNIT |
|----|-----------------------------|---------------------------------------------------------------------|--------------------|-----|----------------------|------|
| 17 | <sup>t</sup> a(MIDV-CMPV)   |                                                                     |                    |     |                      |      |
| 18 | t <sub>su</sub> (CMPV-CKOL) | (OL) Setup time, RETRY, READY, FAULT valid to CLKOUT no longer high |                    |     |                      | ns   |
| 19 | <sup>t</sup> h(CKOL-CMPV)   | Hold time, RETRY, READY, FAULT valid after CLKOUT low               | 1.2                |     | ns                   |      |
| 20 | <sup>t</sup> a(RASL-RRV)    | SL-RRV) Access time RETRY, READY valid from RAS low                 |                    |     |                      | ns   |
| 21 | <sup>t</sup> a(RLL-RRV)     | Access time, RETRY, READY valid from RL low                         | -                  |     | nt <sub>H</sub> -7.5 | ns   |
| 22 |                             | SL-RRV) Access time, READY valid from CAS low                       | 2 cyc/col accesses |     | t <sub>H</sub> -12   | ns   |
|    | <sup>t</sup> a(CASL-RRV)    |                                                                     | 3 cyc/col accesses |     | 2t <sub>H</sub> -8   | 115  |



SGUS025 - AUGUST 1998



Figure 112. Local Bus Timing: Row-Time Cycle Completion Inputs



#### SGUS025 – AUGUST 1998



#### local bus timing: cycle completion inputs (continued)





SGUS025 - AUGUST 1998

#### general output signal characteristics over operating conditions

The following general timing parameters apply to all SMJ320C80 output signals unless otherwise specifically given. The value *n* as used in the parameters represents the integral number of half cycles between the transitions of the two outputs in question. For timing purposes, outputs fall into one of three groups – the data bus (D[63:0]); the other output buses (A[31:0], STATUS[5:0], CAS/DQM[7:0]; and non-bus outputs (DBEN, RL, DDIN, DSF, RAS, TRG/CAS, W). When measuring output to output, the named group refers to the second output to transition (output B), and the first output (output A) refers to any output group.

| NO |                           | PARAMETER                                                                                                                                      | MIN                                                                               | MAX                                                                             | UNIT |
|----|---------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|---------------------------------------------------------------------------------|------|
| 23 | <sup>t</sup> h(OUTV-CKOL) | Hold time, CLKOUT high after output valid D[63:0]<br>A[31:0], STATUS[5:0], CAS/DQM[7:0]<br>DBEN, DDIN, DSF, RAS, TRG/CAS, W, RL                | nt <sub>H</sub> –5.6<br>nt <sub>H</sub> –5.0†<br>nt <sub>H</sub> –4.3             |                                                                                 | ns   |
| 24 | <sup>t</sup> h(OUTV-CKOH) | Hold time, CLKOUT low after output valid D[63:0]<br>A[31:0], STATUS[5:0], CAS/DQM[7:0]<br>DBEN, DDIN, DSF, RAS, TRG/CAS, W, RL                 | nt <sub>H</sub> –5.6<br>nt <sub>H</sub> –5.0 <sup>†</sup><br>nt <sub>H</sub> –4.3 |                                                                                 | ns   |
| 25 | <sup>t</sup> h(CKOL-OUTV) | Hold time, output valid after CLKOUT low                                                                                                       | nt <sub>H</sub> -5.5                                                              |                                                                                 | ns   |
| 26 | <sup>t</sup> h(CKOH-OUTV) | Hold time, output valid after CLKOUT high                                                                                                      | nt <sub>H</sub> –5                                                                |                                                                                 | ns   |
| 27 | <sup>t</sup> h(OUTV-OUTV) | Hold time, output valid <u>after</u> output valid D[63:0]<br><u>A[31:0], STATUS[5:0], CAS/DQM[7:0]</u><br>DBEN, DDIN, DSF, RAS, TRG/CAS, W, RL | nt <sub>H</sub> –6.5<br>nt <sub>H</sub> –6.0 <sup>†</sup><br>nt <sub>H</sub> –5   |                                                                                 | ns   |
| 28 | <sup>t</sup> d(CKOH-OUTV) | Delay time, CLKOUT no longer low to output valid D[63:0]<br>A[31:0], STATUS[5:0], CAS/DQM[7:0]<br>DBEN, DDIN, DSF, RAS,TRG/CAS, W, RL          |                                                                                   | nt <sub>H</sub> +6.5<br>nt <sub>H</sub> +5.5 <sup>†</sup><br>nt <sub>H</sub> +5 | ns   |
| 29 | <sup>t</sup> d(CKOL-OUTV) | Delay time, CLKOUT no longer high to output valid D[63:0]<br>A[31:0], STATUS[5:0], CAS/DQM[7:0]<br>DBEN, DDIN, DSF, RAS,TRG/CAS, W, RL         |                                                                                   | nt <sub>H</sub> +6.5<br>nt <sub>H</sub> +5.5 <sup>†</sup><br>nt <sub>H</sub> +5 | ns   |
| 30 | <sup>t</sup> d(OUTV-CKOH) | Delay time, output no longer valid to CLKOUT high                                                                                              |                                                                                   | nt <sub>H</sub> +5                                                              | ns   |
| 31 | <sup>t</sup> d(OUTV-CKOL) | Delay time, output no longer valid to CLKOUT low                                                                                               |                                                                                   | nt <sub>H</sub> +5.5                                                            | ns   |
| 32 | <sup>t</sup> d(OUTV-OUTV) | Delay time, output no longer valid to output valid D[63:0]<br>A[31:0], STATUS[5:0], CAS/DQM[7:0]<br>DBEN, DDIN, DSF, RAS, TRG/CAS, W, RL       |                                                                                   | nt <sub>H</sub> +6.5<br>nt <sub>H</sub> +6.0 <sup>†</sup><br>nt <sub>H</sub> +5 | ns   |
| 33 | <sup>t</sup> w(OUTV)      | Pulse duration, output valid D[63:0]<br>A[31:0], STATUS[5:0], CAS/DQM[7:0]<br>DBEN, DDIN, DSF, RAS, TRG/CAS, W, RL                             | nt <sub>H</sub> –6.5<br>nt <sub>H</sub> –6.0 <sup>†</sup><br>nt <sub>H</sub> –5.0 |                                                                                 | ns   |

<sup>†</sup> Except for CAS/DQM[7:0] during nonuser-timed 2-cycle/column accesses



SGUS025 – AUGUST 1998



general output signal characteristics over operating conditions (continued)

Figure 114. General Output-Signal Timing



#### data input timing (see Figure 115)

The following general timing parameters apply to the D[63:0] inputs unless otherwise specifically given. The value n as used in the parameters represents the integral number of half cycles between the transitions of the output and input in question.

| NO |                                      | PARAMETER                                                                                                                                         | MIN | MAX                                        | UNIT |
|----|--------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|-----|--------------------------------------------|------|
| 34 | <sup>t</sup> a(CKOH-DV)              | Access time, CLKOUT high to D[63:0] valid                                                                                                         |     | nt <sub>H</sub> -5.3                       | ns   |
| 35 | <sup>t</sup> a(CKOL-DV)              | Access time, CLKOUT low to D[63:0] valid                                                                                                          |     | nt <sub>H</sub> -6.5                       | ns   |
| 36 | t <sub>su</sub> (DV-CKOH)            | Setup time, D[63:0] valid to CLKOUT no longer low                                                                                                 | 6.1 |                                            | ns   |
| 37 | t <sub>su</sub> (DV-CKOL)            | Setup time, D[63:0] valid to CLKOUT no longer high                                                                                                | 6.1 |                                            | ns   |
| 38 | <sup>t</sup> h(CKOL-DV)              | Hold time, D[63:0] valid after CLKOUT low                                                                                                         | 2   |                                            | ns   |
| 39 | <sup>t</sup> h(CKOH-DV)              | Hold time, D[63:0] valid after CLKOUT high                                                                                                        | 2   |                                            | ns   |
| 40 | <sup>t</sup> a(OUTV-DV)              | Access time, output valid to D[63:0] inputs valid A[31:0], CAS/DQM[7:0] <sup>†</sup> ,<br>STATUS[5:0], RL<br>DBEN, DDIN, DSF, RAS, RL, TRG/CAS, W |     | nt <sub>H</sub> –7<br>nt <sub>H</sub> –6.5 | ns   |
| 41 | <sup>t</sup> h(OUTV-DV) <sup>‡</sup> | Hold time, D[63:0] valid after output valid RAS, CAS/DQM[7:0], A[31:0]                                                                            | 3   |                                            | ns   |

<sup>†</sup> Except CAS/DQM[7:0] during nonuser-timed 2-cycle/column accesses
 <sup>‡</sup> Applies to RAS, CAS/DQM[7:0], and A[31:0] transitions that occur on CLKOUT edge coincident with input data sampling



Figure 115. Data-Input Timing



SGUS025 - AUGUST 1998

#### local bus timing: 2-cycle/column CAS timing

These timing parameters apply to the  $\overline{CAS}/DQM[7:0]$  signals during 2-cycle-per-column memory accesses only. They should be used in place of the general output and data input timing parameters when the 2-cycle/column (nonuser-timed) cycle timing is selected (CT[2:0] inputs = 0b110). The value *n* as used in the parameters represents the integral number of half cycles between the transitions of the signals in question.

| NO |                           |                                                                                                                               | MIN                                                                | MAX                 | UNIT |
|----|---------------------------|-------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|---------------------|------|
| 42 | <sup>t</sup> w(CASH)      | Pulse duration, CAS/DQM high                                                                                                  | t <sub>H</sub> -2                                                  |                     | ns   |
| 43 | <sup>t</sup> w(CASL)      | Pulse duration, CAS/DQM low                                                                                                   | 3t <sub>H</sub> –9.5                                               |                     | ns   |
| 44 | <sup>t</sup> h(OUTV-CASL) | Hold time, <u>CAS</u> /DQM high after output valid<br>D[63:0]<br>A[31:0], STATUS[5:0]<br>DBEN, DDIN, DSF, RAS, RL, TRG/CAS, W | nt <sub>H</sub> –4.5<br>nt <sub>H</sub> –4.0<br>nt <sub>H</sub> –3 |                     | ns   |
| 45 | <sup>t</sup> h(CASL-OUTV) | Hold time, output valid after CAS/DQM low                                                                                     | nt <sub>H</sub> –9.5                                               |                     | ns   |
| 46 | <sup>t</sup> a(CASL-DV)   | Access time, data valid from CAS/DQM low                                                                                      |                                                                    | 3t <sub>H</sub> -12 | ns   |
| 47 | <sup>t</sup> h(CASH-DV)   | Hold time, data valid after CAS/DQM high                                                                                      | 2                                                                  |                     | ns   |





SGUS025 - AUGUST 1998

#### external interrupt timing (see Figure 117)

The following description defines the timing of the edge-triggered interrupts  $\overline{\text{EINT1}} - \overline{\text{EINT3}}$  and the level-triggered interrupt  $\overline{\text{LINT4}}$  (see Note 4).

| NO |                             |                                                    | MIN  | MAX | UNIT |
|----|-----------------------------|----------------------------------------------------|------|-----|------|
| 48 | <sup>t</sup> w(EINL)        | Pulse duration, EINTx low                          | 6*   |     | ns   |
| 49 | <sup>t</sup> su(EINH-CKOH)  | Setup time, EINTx high before CLKOUT no longer low | 9.5† |     | ns   |
| 50 | <sup>t</sup> w(EINH)        | Pulse duration, EINTx high                         | 6*   |     | ns   |
| 51 | t <sub>su</sub> (LINL-CKOL) | Setup time, LINT4 low before CLKOUT no longer high | 9.5† |     | ns   |

<sup>†</sup> This parameter must only be met to ensure that the interrupt is recognized on the indicated cycle.

\* This parameter is not production tested.

NOTE 4: In order to ensure recognition, LINT4 must remain low until cleared by the interrupt service routine.



Figure 117. External Interrupt Timing



SGUS025 - AUGUST 1998

#### XPT input timing (see Figure 118 and Figure 119)

The following description defines the sampling of the  $\overline{XPT[2:0]}$  inputs. The value encoded on the  $\overline{XPT[2:0]}$  inputs is synchronized over multiple cycles to ensure that a stable value is present.

| NO |                             |                                                        | MIN                | MAX                | UNIT |
|----|-----------------------------|--------------------------------------------------------|--------------------|--------------------|------|
| 52 | <sup>t</sup> w(XPTV)        | Pulse duration, XPTx valid                             | 12t <sub>H</sub> * |                    | ns   |
| 53 | t <sub>su</sub> (XPTV-CKOH) | Setup time, XPT[2:0] valid before CLKOUT no longer low | 12†                |                    | ns   |
| 54 | <sup>t</sup> h(CKOH-XPTV)   | Hold time, XPT[2:0] valid after CLKOUT high            | 5                  |                    | ns   |
| 55 | <sup>t</sup> h(RLL-XPTV)    | Hold time, XPT[2:0] valid after RL low                 |                    | 6t <sub>H</sub> ‡* | ns   |

<sup>†</sup> This parameter must only be met to ensure that the XPT input is recognized on the indicated cycle.

<sup>‡</sup>This parameter must be met to ensure that a second XPT request does nor occur.

\* This parameter is not production tested.







Figure 119. XPT Input Timing – XPT Service



SGUS025 - AUGUST 1998

| host | nost-interface timing (see Figure 120) |                                                      |                                                     |                       |     |       |  |  |  |  |
|------|----------------------------------------|------------------------------------------------------|-----------------------------------------------------|-----------------------|-----|-------|--|--|--|--|
| NO   |                                        |                                                      |                                                     | 'C80-4                | 40  | LINUT |  |  |  |  |
| NO   |                                        |                                                      |                                                     | MIN                   | MAX | UNIT  |  |  |  |  |
| 56   | t <sub>su</sub> (REQV-CKOH)            | Setup time, REQ1-REQ0 valid to CLKOUT no lo          | Setup time, REQ1-REQ0 valid to CLKOUT no longer low |                       |     |       |  |  |  |  |
| 57   | <sup>t</sup> h(CKOH-REQV)              | Hold time, REQ1-REQ0 valid after CLKOUT high         | t <sub>H</sub> – 7                                  |                       | ns  |       |  |  |  |  |
| 58   | <sup>t</sup> h(HRQL-HAKL)              | Hold time for HACK high after HREQ goes low*         |                                                     | 4t <sub>H</sub> – 12* |     | ns    |  |  |  |  |
| 59   |                                        |                                                      | All signals except D[63:0]                          |                       | 1*  |       |  |  |  |  |
| 59   | <sup>t</sup> d(HAKL-OUTZ)              | Delay time, HACK low to output hi-Z                  | D[63:0]                                             |                       | 1*  | ns    |  |  |  |  |
| 60   | <sup>t</sup> d(HRQH-HAKH)              | Delay time, HREQ high to HACK no longer low          |                                                     |                       | 10  | ns    |  |  |  |  |
| 61   | td(HAKH-OUTD)                          | Delay time, HACK high to outputs driven <sup>†</sup> | 6t <sub>H</sub>                                     |                       |     |       |  |  |  |  |
| 62   | t <sub>su</sub> (HRQL-CKOH)            | Setup time, HREQ low to CLKOUT no longer low         | (see Note 5)                                        | 8.5                   |     | ns    |  |  |  |  |

\* This parameter is not production tested. NOTE 5: Parameter must be met only to ensure HREQ recognition during the indicated clock cycle.







SGUS025 - AUGUST 1998

#### video interface timing: SCLK timing (see Figure 121)

| NO |                      |                                       | MIN | MAX | UNIT |
|----|----------------------|---------------------------------------|-----|-----|------|
| 63 | <sup>t</sup> c(SCK)  | SCLK period                           | 13  |     | ns   |
| 64 | <sup>t</sup> w(SCKH) | Pulse duration, SCLK high             | 5   |     | ns   |
| 65 | <sup>t</sup> w(SCKL) | Pulse duration, SCLK low              | 5   |     | ns   |
| 66 | <sup>t</sup> t(SCK)  | Transition time, SCLK (rise and fall) |     | 2*  | ns   |

\* This parameter is not production tested.







SGUS025 - AUGUST 1998

| video interface timing: FCLK input and video outputs (see Note 6 and Figure 122) |                          |                                                                                          |     |     |      |  |  |  |
|----------------------------------------------------------------------------------|--------------------------|------------------------------------------------------------------------------------------|-----|-----|------|--|--|--|
| NO                                                                               |                          |                                                                                          | MIN | MAX | UNIT |  |  |  |
| 67                                                                               | <sup>t</sup> c(FCK)      | FCLK period                                                                              | 25  |     | ns   |  |  |  |
| 68                                                                               | <sup>t</sup> w(FCKH)     | Pulse duration, FCLK high                                                                | 8   |     | ns   |  |  |  |
| 69                                                                               | <sup>t</sup> w(FCKL)     | Pulse duration, FCLK low                                                                 | 8   |     | ns   |  |  |  |
| 70                                                                               | <sup>t</sup> t(FCK)      | Transition time, FCLK (rise and fall)                                                    |     | 2*  | ns   |  |  |  |
| 71                                                                               | <sup>t</sup> h(FCKL-SYL) | Hold time, HSYNC, VSYNC, CSYNC/HBLNK, CBLNK/VBLNK, or CAREA high after FCLK low          | 0   |     | ns   |  |  |  |
| 72                                                                               | <sup>t</sup> h(FCKL-SYH) | Hold time, HSYNC, VSYNC, CSYNC/HBLNK, CBLNK/VBLNK, or CAREA low after FCLK<br>low        | 0   |     | ns   |  |  |  |
| 73                                                                               | <sup>t</sup> d(FCKL-SYL) | Delay time, FCLK no longer high to HSYNC, VSYNC, CSYNC/HBLNK, CBLNK/VBLNK, or CAREA low  |     | 20  | ns   |  |  |  |
| 74                                                                               | <sup>t</sup> d(FCKL-SYH) | Delay time, FCLK no longer high to HSYNC, VSYNC, CSYNC/HBLNK, CBLNK/VBLNK, or CAREA high |     | 20  | ns   |  |  |  |

#### \_

\* This parameter is not production tested.

NOTE 6: Under certain circumstances, these outputs also can transition asynchronously. These transitions occur when controller timing register values are modified by user programming. If the new register value forces the output to change states, then this transition occurs without regard to FCLK inputs.



Figure 122. Video Interface Timing: FCLK Input and Video Outputs



#### SGUS025 - AUGUST 1998

#### video interface timing: external sync inputs (see Figure 123)

When configured as inputs, the HSYNCn, VSYNCn, and CSYNCn signals may be driven asynchronously. The following parameters apply only when the inputs are being generated synchronous to FCLKn in order to ensure recognition on a particular FLCKn edge.

| NO |                            |                                                                                                 | MIN | MAX | UNIT |
|----|----------------------------|-------------------------------------------------------------------------------------------------|-----|-----|------|
| 75 | t <sub>su</sub> (SIL-FCKH) | Setup time, HSYNC, VSYNC, or CSYNC low to FCLK no longer low <sup>†</sup>                       | 5   |     | ns   |
| 76 | <sup>t</sup> h(FCKH-SIL)   | Hold time, HSYNC, VSYNC, or CSYNC high after FCLK high <sup>‡</sup>                             | 7   |     | ns   |
| 77 | t <sub>su</sub> (SIH-FCKH) | Setup time, HSYNC, VSYNC, or CSYNC high to FCLK no longer low§                                  | 5   |     | ns   |
| 78 | <sup>t</sup> h(FCKH-SIH)   | Hold time, $\overline{HSYNC}$ , $\overline{VSYNC}$ , or $\overline{CSYNC}$ low after FCLK high¶ | 7   |     | ns   |

<sup>†</sup> This parameter must be met only to ensure the input is recognized as low at FLCK edge B.

<sup>‡</sup> This parameter must be met only to ensure the input is recognized as high at FLCK edge A.

§ This parameter must be met only to ensure the input is recognized as high at FLCK edge D.

 $\P$  This parameter must be met only to ensure the input is recognized as low at FLCK edge C.



Figure 123. Video Interface Timing: External Sync Inputs



SGUS025 - AUGUST 1998

#### emulator interface connection

The 'C80 supports emulation through a dedicated emulation port that is a superset of the IEEE Standard 1149.1 (JTAG) Standard. To support the 'C80 emulator, a target system must include a 14-pin header (2 rows of 7 pins) with the connections shown in Figure 124. Table 38 describes the emulation signal.



#### Figure 124. Target System Header

#### **Table 38. Target Connectors**

| XDS510™<br>SIGNAL | XDS510<br>STATE | TARGET<br>STATE | DESCRIPTION                                                                                                         |
|-------------------|-----------------|-----------------|---------------------------------------------------------------------------------------------------------------------|
| TMS               | 0               | I               | Test-mode select <sup>†</sup>                                                                                       |
| TDI               | 0               | I               | Test-data input <sup>†</sup>                                                                                        |
| TDO               | I               | 0               | Test-data output <sup>†</sup>                                                                                       |
| ТСК               | 0               | I               | Test clock – 10-MHz clock source from emulator. Can be used to drive system-test clock. $^{\dagger}$                |
| TRST              | 0               | I               | Test reset <sup>†</sup>                                                                                             |
| EMU0              | I               | I/O             | Emulation pin 0                                                                                                     |
| EMU1              | I               | I/O             | Emulation pin 1                                                                                                     |
| PD (3.3 V)        | I               | 0               | Presence detect. Indicates that the target is connected and powered up. Should be tied to + 3.3 V on target system. |
| TCKRET            | I               | 0               | Test clock return. Test clock input to the XDS510 emulator. Can be buffered or unbuffered version of TCK.†          |

<sup>†</sup> IEEE Standard 1149.1

For best results, the emulation header should be located as close as possible to the 'C80. If the distance exceeds six inches, the emulation signals should be buffered. See Figure 125.



SGUS025 – AUGUST 1998



### emulator-interface connection (continued)



The target system also can generate the test clock. This allows the user to:

- Set the test clock frequency to match the system requirements. (The emulator provides only a 10-MHz test clock.)
- Have other devices in the system that require a test clock when the emulator is not connected







#### emulator-interface connection (continued)

For multiprocessor applications, the following conditions are recommended:

- To reduce timing skew, buffer TMS, TDI, TDO, and TCK through the same physical package.
- If buffering is used, 4.7-kΩ resistors are recommended for TMS, TDI, and TCK, which should be pulled high (3.3 V).
- Buffering EMU0 and EMU1 is recommended highly to provide isolation. The buffers need not be in the same physical package as TMS, TCK, TDI, or TDO. Pullups to 3.3 V are required and should provide a signal rise time of less than 10 μs. A 4.7-kΩ resistor is suggested for most applications.
- To ensure high-quality signals, special printed wire board (PWB) routing and use of termination resistors may be required. The emulator provides fixed series termination (33 Ω) on TMS and TDI, and optional parallel terminators (180-Ω pullup and 270-Ω pulldown) on TCKRET and TDO.



Figure 127. Emulation Header Connections – Multiprocessor Applications



SGUS025 - AUGUST 1998

#### **MECHANICAL DATA**

#### GF (S-CPGA-P305)

#### **CERAMIC PIN GRID ARRAY PACKAGE**



NOTES: A. All linear dimensions are in inches (millimeters).

B. This drawing is subject to change without notice.

C. Package thickness of 0.150 (3,81) / 0.110 (2,79) includes package body and lid, but does not include integral heatsink or attached features.



SGUS025 - AUGUST 1998

**MECHANICAL DATA** 

#### HFH (R-CQFP-F320)

#### CERAMIC QUAD FLATPACK WITH NCTB



NOTES: A. All linear dimensions are in millimeters.

- B. This drawing is subject to change without notice.
- C. This package can be hermetically sealed with a metal lid.
- D. The terminals will be gold plated.
- E. Falls within JEDEC MO-134 AD



#### **IMPORTANT NOTICE**

Texas Instruments and its subsidiaries (TI) reserve the right to make changes to their products or to discontinue any product or service without notice, and advise customers to obtain the latest version of relevant information to verify, before placing orders, that information being relied on is current and complete. All products are sold subject to the terms and conditions of sale supplied at the time of order acknowledgement, including those pertaining to warranty, patent infringement, and limitation of liability.

TI warrants performance of its semiconductor products to the specifications applicable at the time of sale in accordance with TI's standard warranty. Testing and other quality control techniques are utilized to the extent TI deems necessary to support this warranty. Specific testing of all parameters of each device is not necessarily performed, except those mandated by government requirements.

CERTAIN APPLICATIONS USING SEMICONDUCTOR PRODUCTS MAY INVOLVE POTENTIAL RISKS OF DEATH, PERSONAL INJURY, OR SEVERE PROPERTY OR ENVIRONMENTAL DAMAGE ("CRITICAL APPLICATIONS"). TI SEMICONDUCTOR PRODUCTS ARE NOT DESIGNED, AUTHORIZED, OR WARRANTED TO BE SUITABLE FOR USE IN LIFE-SUPPORT DEVICES OR SYSTEMS OR OTHER CRITICAL APPLICATIONS. INCLUSION OF TI PRODUCTS IN SUCH APPLICATIONS IS UNDERSTOOD TO BE FULLY AT THE CUSTOMER'S RISK.

In order to minimize risks associated with the customer's applications, adequate design and operating safeguards must be provided by the customer to minimize inherent or procedural hazards.

TI assumes no liability for applications assistance or customer product design. TI does not warrant or represent that any license, either express or implied, is granted under any patent right, copyright, mask work right, or other intellectual property right of TI covering or relating to any combination, machine, or process in which such semiconductor products or services might be or are used. TI's publication of information regarding any third party's products or services does not constitute TI's approval, warranty or endorsement thereof.

Copyright © 1998, Texas Instruments Incorporated