# DECchip 21171 Core Logic Chipset

# **Technical Reference Manual**

Order Number: EC-QE18B-TE

Revision/Update Information: Preliminar the DECch

Preliminary—This document supersedes the *DECchip 21171 Core Logic Chipset Technical Reference Manual* (EC-QE18A-TE).

Digital Equipment Corporation Maynard, Massachusetts

#### September 1995

While Digital believes the information in this publication is correct as of the date of publication, it is subject to change without notice.

Digital Equipment Corporation makes no representations that the use of its products in the manner described in this publication will not infringe on existing or future patent rights, nor do the descriptions contained in this publication imply granting of licenses to make, use, or sell equipment or software in accordance with the description.

© Digital Equipment Corporation 1995. All rights reserved. Printed in U.S.A.

DEC, DECchip, Digital, Digital Semiconductor, OpenVMS, VAX DOCUMENT, and the DIGITAL logo are trademarks of Digital Equipment Corporation.

Digital Semiconductor is a Digital Equipment Corporation business.

Intel is a trademark of Intel Corporation. OSF/1 is a registered trademark of Open Software Foundation, Inc. Prentice Hall is a registered trademark of Prentice-Hall, Inc. of Englewood Cliffs, NJ. Windows NT is a trademark of Microsoft Corporation.

All other trademarks and registered trademarks are the property of their respective owners.

This document was prepared using VAX DOCUMENT Version 2.1.

# Contents

| Preface |       | xiii                                               |     |
|---------|-------|----------------------------------------------------|-----|
| 1       | DECcl | nip 21171 Core Logic Chipset Overview              |     |
|         | 1.1   | Features                                           | 1–1 |
|         | 1.2   | System Overview                                    | 1–2 |
|         | 1.2.1 | DECchip 21171 Core Logic Chipset Microarchitecture | 1–4 |
|         | 1.3   | CIA Microarchitecture                              | 1–4 |
|         | 1.4   | DSW Microarchitecture                              | 1–6 |
|         | 1.5   | System Clocks                                      | 1–7 |
|         | 1.6   | DECchip 21171 Core Logic Chipset Characteristics   | 1–8 |
|         |       |                                                    |     |

## Part I DECchip 21171-CA (CIA) Information

# 2 DECchip 21171-CA Pin Descriptions

- -

| 2.1    | DECchip 21171-CA Pin List                           | 2–1  |
|--------|-----------------------------------------------------|------|
| 2.2    | DECchip 21171-CA Signal Descriptions                | 2–3  |
| 2.2.1  | sysBus Signals                                      | 2–3  |
| 2.2.2  | PCI Local Bus Signals                               | 2–4  |
| 2.2.3  | IOD Bus Signals                                     | 2–7  |
| 2.2.4  | Memory Control Signals                              | 2–10 |
| 2.2.5  | Phase-Locked Loop Signals                           | 2–11 |
| 2.2.6  | Miscellaneous Power Signals                         | 2–11 |
| 2.2.7  | Miscellaneous Signals                               | 2–12 |
| 2.2.8  | Reserved Signals                                    | 2–12 |
| 2.2.9  | DECchip 21171-CA Pin Name List (Alphabetic)         | 2–13 |
| 2.2.10 | DECchip 21171-CA Pin Assignment List (Alphanumeric) | 2–19 |
| 2.3    | DECchip 21171-CA Mechanical Specifications          | 2–24 |

## 3 DECchip 21171-CA Architecture Overview

| 3.1     | CIA Data Paths with Functional Units Description               | 3–1  |
|---------|----------------------------------------------------------------|------|
| 3.1.1   | System Functional Units                                        | 3–1  |
| 3.1.2   | CIA Functional Units                                           | 3–3  |
| 3.1.2.1 | 21164 Instruction and Address Logic                            | 3–4  |
| 3.1.2.2 | PCI Data Path Logic                                            | 3–4  |
| 3.1.2.3 | Memory Logic                                                   | 3–6  |
| 3.1.2.4 | I/O Address Logic                                              | 3–6  |
| 3.1.2.5 | DMA Address Logic                                              | 3–7  |
| 3.2     | CIA Transactions                                               | 3–7  |
| 3.2.1   | 21164 Read Miss Transaction                                    | 3–8  |
| 3.2.2   | 21164 Read Miss with Victim Transaction                        | 3–8  |
| 3.2.3   | 21164 Read Transaction to Noncacheable Space                   | 3–9  |
| 3.2.4   | 21164 Write Transaction to Noncacheable Space                  | 3–11 |
| 3.2.5   | DMA Transactions                                               | 3–12 |
| 3.2.6   | DMA Read Transaction                                           | 3–14 |
| 3.2.7   | DMA Read Transaction (Prefetch)                                | 3–14 |
| 3.2.8   | DMA Write Transaction                                          | 3–15 |
| 3.3     | System Data Coherency Issues                                   | 3–16 |
| 3.3.1   | Basic Properties of the System                                 | 3–16 |
| 3.3.2   | Post and Run I/O Write Data Coherency                          | 3–17 |
| 3.4     | CIA Memory <b>ras_h</b> , <b>cas_h</b> , and Address Operation | 3–18 |
| 3.4.1   | Traditional Mapping of 21164 Address to Memory                 |      |
|         | Address                                                        | 3–18 |
| 3.4.2   | CIA Mapping of 21164 Address to Memory Address                 | 3–20 |
| 3.5     | MB and LOCK Instructions                                       | 3–25 |
| 3.5.1   | MB Instruction                                                 | 3–25 |
| 3.5.2   | LOCK Instruction                                               | 3–25 |
| 3.5.3   | Locks to Uncached Space                                        | 3–27 |

# 4 DECchip 21171-CA Control and Status Registers

| 4–1 |
|-----|
| 4–2 |
| 4–2 |
| 4–3 |
| 4–3 |
| 4–4 |
|     |
| 4–5 |
| 4–6 |
| 4–8 |
|     |

| 4.2.1  | CIA Revision Register (CIA_REV)                                        | 4–8  |
|--------|------------------------------------------------------------------------|------|
| 4.2.2  | PCI Latency Register (PCI_LAT)                                         | 4–9  |
| 4.2.3  | CIA Control Register (CIA_CTRL)                                        | 4–10 |
| 4.2.4  | Hardware Address Extension Memory Register                             |      |
|        | (HAE_MEM)                                                              | 4–14 |
| 4.2.5  | Hardware Address Extension I/O Register (HAE_IO)                       | 4–16 |
| 4.2.6  | Configuration Register (CFG)                                           | 4–17 |
| 4.2.7  | CIA Acknowledgment Enable Register (CACK_EN)                           | 4–18 |
| 4.3    | DECchip 21171-CA Diagnostic Registers                                  | 4–19 |
| 4.3.1  | CIA Diagnostic Control Register (CIA_DIAG)                             | 4–19 |
| 4.3.2  | Diagnostic Check Register (DIAG_CHECK)                                 | 4–21 |
| 4.4    | DECchip 21171-CA Performance Monitor Registers                         | 4–22 |
| 4.4.1  | Performance Monitor Register (PERF_MONITOR)                            | 4–22 |
| 4.4.2  | Performance Control Register (PERF_CONTROL)                            | 4–23 |
| 4.5    | DECchip 21171-CA Error Registers                                       | 4–26 |
| 4.5.1  | CPU Error Information Register 0 (CPU_ERR0)                            | 4–26 |
| 4.5.2  | CPU Error Information Register 1 (CPU_ERR1)                            | 4–27 |
| 4.5.3  | CIA Error Register (CIA_ERR)                                           | 4–28 |
| 4.5.4  | CIA Status Register (CIA_STAT)                                         | 4–32 |
| 4.5.5  | CIA Error Mask Register (ERR_MASK)                                     | 4–34 |
| 4.5.6  | CIA Syndrome Register (CIA_SYN)                                        | 4–35 |
| 4.5.7  | CIA Memory Port Status Register 0 (MEM_ERR0)                           | 4–37 |
| 4.5.8  | CIA Memory Port Status Register 1 (MEM_ERR1)                           | 4–38 |
| 4.5.9  | PCI Error Register 0 (PCI_ERR0)                                        | 4–41 |
| 4.5.10 | PCI Error Register 1 (PCI_ERR1)                                        | 4–44 |
| 4.5.11 | PCI Error Register 2 (PCI_ERR2)                                        | 4–45 |
| 4.6    | DECchip 21171-CA System Configuration Registers                        | 4–46 |
| 4.6.1  | Memory Configuration Register (MCR)                                    | 4–46 |
| 4.6.2  | Memory Base Address Register <i>n</i> (MBA <i>n</i> )                  | 4–49 |
| 4.6.3  | Memory Timing Information Register <i>n</i> (TMG <i>n</i> )            | 4–52 |
| 4.7    | DECchip 21171-CA PCI Address and Scatter-Gather                        |      |
|        | Registers                                                              | 4–60 |
| 4.7.1  | Scatter-Gather Translation Buffer Invalidate Register                  |      |
|        | (TBIA)                                                                 | 4–60 |
| 4.7.2  | Window Base Register (Wn_BASE)                                         | 4–61 |
| 4.7.3  | Window Mask Register <i>n</i> (W <i>n</i> _MASK)                       | 4–63 |
| 4.7.4  | Translated Base Register <i>n</i> (T <i>n</i> _BASE)                   | 4–65 |
| 4.7.5  | Window Base DAC Register (W_DAC)                                       | 4–68 |
| 4.8    | DECchip 21171-CA Address Translation Registers                         | 4–69 |
| 4.8.1  | Lockable Translation Buffer Tag <i>n</i> Registers (LTB_TAG <i>n</i> ) | 4–69 |
| 4.8.2  | Translation Buffer Tag <i>n</i> Register (TB_TAG <i>n</i> )            | 4–70 |
| 4.8.3  | Translation Buffer $m$ Page $n$ Registers (TB $m$ _PAGE $n$ )          | 4–72 |

## 5 DECchip 21171-CA Power-Up and Initialization

| 5.1 | Power-Up                              | 5–1 |
|-----|---------------------------------------|-----|
| 5.2 | Internal Reset                        | 5–1 |
| 5.3 | State of Pins on Reset Assertion      | 5–1 |
| 5.4 | Configuration after Reset Deassertion | 5–3 |

## 6 DECchip 21171-CA Address Mapping

| 6.1 | 1 Address Mapping Overview                               | 6–1  |
|-----|----------------------------------------------------------|------|
| 6.1 | 1.1 21164 Address Space Configuration Supported by the   |      |
|     | CIA                                                      | 6–2  |
| 6.1 | 1.1.1 21164 Access to Address Space                      | 6–3  |
| 6.1 | 1.1.2 PCI Access to Address Space                        | 6–4  |
| 6.2 | 2 21164 Address Space                                    | 6–7  |
| 6.2 | 2.1 PCI Dense Memory Space                               | 6–9  |
| 6.2 | 2.2 PCI Sparse Memory Space                              | 6–11 |
| 6.2 | 2.3 PCI Sparse I/O Space                                 | 6–18 |
| 6.2 | 2.4 PCI Configuration Space                              | 6–22 |
| 6.2 | 2.4.1 Device Select (IDSEL)                              | 6–25 |
| 6.2 | 2.4.2 PCI Special/Interrupt Acknowledge Cycles           | 6–28 |
| 6.2 | 2.4.3 Hardware-Specific and Miscellaneous Register Space | 6–29 |
| 6.3 | 3 PCI to Physical Memory Addressing                      | 6–29 |
| 6.3 | 3.1 Address Mapping Windows                              | 6–29 |
| 6.3 | 3.1.1 PCI Device Address Space                           | 6–31 |
| 6.3 | 3.1.2 Address Mapping Example                            | 6–32 |
| 6.3 | 3.2 Direct Mapped Addressing                             | 6–34 |
| 6.3 | 3.3 Scatter-Gather Addressing                            | 6–35 |
| 6.3 | 3.3.1 Scatter-Gather Translation Lookaside Buffer (TLB)  | 6–37 |
| 6.3 | 3.3.1.1 Scatter-Gather TLB Hit Process                   | 6–39 |
| 6.3 | 3.3.1.2 Scatter-Gather TLB Miss Process                  | 6–39 |
| 6.3 | 3.4 Suggested Use of a PCI Window                        | 6–41 |
| 6.3 | 3.4.1 Peripheral Component Architecture Compatibility    |      |
|     | Addressing and Holes                                     | 6–42 |
| 6.3 | 3.4.2 Memory Chip Select Signal <b>mem_cs_l</b>          | 6–42 |

### Part II DECchip 21171-BA (DSW) Information

#### 7 DECchip 21171-BA Pin Descriptions

| 7.1   | DECchip 21171-BA Pin List                      | 7–1  |
|-------|------------------------------------------------|------|
| 7.2   | DECchip 21171-BA Signal Descriptions           | 7–2  |
| 7.2.1 | sysBus Signals                                 | 7–3  |
| 7.2.2 | IOD Bus Signals                                | 7–3  |
| 7.2.3 | MEMDATA Bus Signals                            | 7–6  |
| 7.2.4 | Phase-Locked Loop Signals                      | 7–6  |
| 7.2.5 | Miscellaneous Signals                          | 7–7  |
| 7.2.6 | DECchip 21171-BA Pin Name List (Alphabetic)    | 7–9  |
| 7.2.7 | DECchip 21171-BA Pin Assignment List (Numeric) | 7–12 |
| 7.3   | DECchip 21171-BA Mechanical Specifications     | 7–16 |
|       |                                                |      |

#### 8 DECchip 21171-BA Architecture Overview

| 8.1     | DSW Functional Units                 | 8–1 |
|---------|--------------------------------------|-----|
| 8.1.1   | Victim Buffer—64 Bytes               | 8–3 |
| 8.1.2   | I/O Read Buffer (IOR)—32 Bytes       | 8–3 |
| 8.1.3   | I/O Write (IOW) Buffers—4 * 32 Bytes | 8–4 |
| 8.1.4   | DMA Buffer Sets                      | 8–4 |
| 8.1.4.1 | Flush Buffer                         | 8–5 |
| 8.1.4.2 | PCI Buffer                           | 8–5 |

### A Technical Support and Ordering Information

| A.1 | Technical Support                          | A–1 |
|-----|--------------------------------------------|-----|
| A.2 | Ordering Digital Semiconductor Products    | A–1 |
| A.3 | Ordering Associated Third-Party Literature | A–2 |

#### Index

### Examples

| 3–1 21164 and PCI Device Lock Contention 3–2 | 26 |
|----------------------------------------------|----|
|----------------------------------------------|----|

# Figures

| 1–1  | DECchip 21171 Core Logic Chipset System Block          |      |
|------|--------------------------------------------------------|------|
|      | Diagram                                                | 1–3  |
| 1–2  | CIA Block Diagram                                      | 1–5  |
| 1–3  | DSW Block Diagram                                      | 1–7  |
| 2–1  | DECchip 21171-CA Package Dimensions                    | 2–25 |
| 3–1  | System Functional Block Diagram                        | 3–2  |
| 3–2  | CIA Functional Block Diagram                           | 3–3  |
| 3–3  | Address Space Overview                                 | 3–13 |
| 3–4  | Traditional Mapping to a Memory Address                | 3–18 |
| 3–5  | Traditional Victim Cache to Memory Correspondence      | 3–19 |
| 3–6  | Modified Mapping to a Memory Address                   | 3–20 |
| 3–7  | CIA Victim Cache to Memory Correspondence              | 3–21 |
| 3–8  | CIA Mapping to a Memory Address                        | 3–22 |
| 3–9  | Memory Address Maps for 128-Bit Data Path              | 3–23 |
| 3–10 | Memory Address Maps for 256-Bit Data Path              | 3–24 |
| 4–1  | CIA Revision Register (87.4000.0080)                   | 4–8  |
| 4–2  | PCI Latency Register (87.4000.00C0)                    | 4–9  |
| 4–3  | CIA Control Register (87.4000.0100)                    | 4–10 |
| 4–4  | Hardware Address Extension Memory Register             |      |
|      | (87.4000.0400)                                         | 4–14 |
| 4–5  | Hardware Address Extension I/O Register (87.4000.0440) | 4–16 |
| 4–6  | Configuration Register (87.4000.0480)                  | 4–17 |
| 4–7  | CIA Acknowledgment Enable Register (87.4000.0600)      | 4–18 |
| 4–8  | CIA Diagnostic Control Register (87.4000.2000)         | 4–19 |
| 4–9  | Diagnostic Check Register (87.4000.3000)               | 4–21 |
| 4–10 | Performance Monitor Register (87.4000.4000)            | 4–22 |
| 4–11 | Performance Control Register (87.4000.4040)            | 4–23 |
| 4–12 | CPU Error Information Register 0 (87.4000.8000)        | 4–26 |
| 4–13 | CPU Error Information Register 1 (87.4000.8040)        | 4–27 |
| 4–14 | CIA Error Register (87.4000.8200)                      | 4–29 |
| 4–15 | CIA Status Register (87.4000.8240)                     | 4–32 |
| 4–16 | CIA Error Mask Register (87.4000.8280)                 | 4–34 |
| 4–17 | CIA Syndrome Register (87.4000.8300)                   | 4–35 |
| 4–18 | CIA Memory Port Status Register 0 (87.4000.8400)       | 4–37 |
| 4–19 | CIA Memory Port Status Register 1 (87.4000.8440)       | 4–38 |
| 4–20 | PCI Error Register 0 (87.4000.8800)                    | 4–41 |

| 4–21 | PCI Error Register 1 (87.4000.8840)                 | 4–44 |
|------|-----------------------------------------------------|------|
| 4–22 | PCI Error Register 2 (87.4000.8880)                 | 4–45 |
| 4–23 | Memory Configuration Register (87.5000.0000)        | 4–46 |
| 4–24 | Memory Base Address Register <i>n</i>               | 4–49 |
| 4–25 | Memory Timing Information Register <i>n</i>         | 4–52 |
| 4–26 | Memory Read Timing Sample                           | 4–55 |
| 4–27 | Memory Write Timing Sample                          | 4–56 |
| 4–28 | Scatter-Gather TBIA Register (87.6000.0100)         | 4–60 |
| 4–29 | Window Base Register <i>n</i>                       | 4–61 |
| 4–30 | Window Mask Register <i>n</i>                       | 4–63 |
| 4–31 | Translated Base Register <i>n</i>                   | 4–65 |
| 4–32 | Window Base DAC Register (87.6000.07C0)             | 4–68 |
| 4–33 | Lockable Translation Buffer Tag <i>n</i> Registers  | 4–69 |
| 4–34 | Translation Buffer Tag <i>n</i> Registers           | 4–71 |
| 4–35 | Translation Buffer <i>m</i> Page <i>n</i> Registers | 4–73 |
| 6–1  | 21164 Address Space                                 | 6–1  |
| 6–2  | 21164 Address Space Configuration                   | 6–2  |
| 6–3  | Address Space Overview                              | 6–3  |
| 6–4  | Address Mapping Overview                            | 6–4  |
| 6–5  | 21164 and DMA Read and Write Transactions           | 6–6  |
| 6–6  | Dense Space Address Generation                      | 6–10 |
| 6–7  | PCI Memory Sparse Space Address Generation          |      |
|      | (Region 1)                                          | 6–15 |
| 6–8  | PCI Memory Sparse Space Address Generation          |      |
|      | (Region 2)                                          | 6–16 |
| 6–9  | PCI Memory Sparse Space Address Generation          |      |
|      | (Region 3)                                          | 6–17 |
| 6–10 | PCI Sparse I/O Space Address Translation (Region A) | 6–18 |
| 6–11 | PCI Sparse I/O Space Address Translation (Region B) | 6–19 |
| 6–12 | PCI Configuration Space Definition                  | 6–23 |
| 6–13 | 21164 System PCI Bus Hierarchy Example              | 6–27 |
| 6–14 | PCI DMA Address Example                             | 6–32 |
| 6–15 | PCI Target Window Compare                           | 6–33 |
| 6–16 | Direct Mapped Translation                           | 6–34 |
| 6–17 | Scatter-Gather PTE Format                           | 6–36 |
| 6–18 | Scatter-Gather Associative TLB                      | 6–38 |
| 6–19 | Scatter-Gather Map Translation                      | 6–40 |

| 6–20 | Default PCI Window Allocation                             | 6–41 |
|------|-----------------------------------------------------------|------|
| 6–21 | Memory Chip Select Signal ( <b>mem_cs_l</b> ) Decode Area | 6–44 |
| 6–22 | Memory Chip Select Signal ( <b>mem_cs_l</b> ) Logic       | 6–45 |
| 7–1  | DECchip 21171-BA Package Dimensions                       | 7–16 |
| 8–1  | DSW Functional Block Diagram                              | 8–2  |
|      |                                                           |      |

### Tables

| 1    | Register Field Notation                                | XV   |
|------|--------------------------------------------------------|------|
| 2    | Unnamed Register Field Notation                        | xvi  |
| 3    | Data Units                                             | xvii |
| 1–1  | DECchip 21171-CA (CIA) Chip Characteristics            | 1–8  |
| 1–2  | DECchip 21171-BA (DSW) Chip Characteristics            | 1–8  |
| 2–1  | DECchip 21171-CA Pin List                              | 2–1  |
| 2–2  | <pre>ioc_h&lt;6:0&gt; Control Functions</pre>          | 2–7  |
| 2–3  | cmc_h<8:0> Control Functions                           | 2–8  |
| 2–4  | Var Encodings for CMC Command 0                        | 2–9  |
| 2–5  | Var Encodings for CMC Commands 0, 8, A, and B $\ldots$ | 2–9  |
| 2–6  | Var Encodings for CMC Commands 2, 3, 4, 5, 6, and 7    | 2–9  |
| 2–7  | DSW Operating Modes                                    | 2–12 |
| 2–8  | DECchip 21171-CA Pin Names (Alphabetic)                | 2–13 |
| 2–9  | DECchip 21171-CA Pin Assignment (Alphanumeric)         | 2–19 |
| 2–10 | DECchip 21171-CA Package Dimensions                    | 2–26 |
| 3–1  | PCI Commands Recognized by the CIA                     | 3–5  |
| 3–2  | CIA Prefetch Strategy                                  | 3–14 |
| 4–1  | DECchip 21171-CA General Registers                     | 4–2  |
| 4–2  | DECchip 21171-CA Diagnostic Registers                  | 4–2  |
| 4–3  | DECchip 21171-CA Performance Monitor Registers         | 4–3  |
| 4–4  | DECchip 21171-CA Error Registers                       | 4–3  |
| 4–5  | DECchip 21171-CA System Configuration Registers        | 4–4  |
| 4–6  | DECchip 21171-CA PCI Address and Scatter-Gather        |      |
|      | Registers                                              | 4–5  |
| 4–7  | DECchip 21171-CA Address Translation Registers         | 4–6  |
| 4–8  | CIA Revision Register                                  | 4–8  |
| 4–9  | PCI Latency Register                                   | 4–9  |
| 4–10 | CIA Control Register                                   | 4–11 |
| 4–11 | CPU and I/O Flush Request                              | 4–13 |

| 4–12 | PCI READ Prefetch Algorithm                           | 4–13 |
|------|-------------------------------------------------------|------|
| 4–13 | HAE_MEM High-Order Sparse-Space Bits                  | 4–15 |
| 4–14 | Hardware Address Extension Memory Register            | 4–15 |
| 4–15 | Hardware Address Extension I/O Register               | 4–16 |
| 4–16 | Configuration Register                                | 4–17 |
| 4–17 | CIA Acknowledgment Enable Register                    | 4–18 |
| 4–18 | CIA Diagnostic Control Register                       | 4–19 |
| 4–19 | Diagnostic Check Register                             | 4–21 |
| 4–20 | Performance Monitor Register                          | 4–22 |
| 4–21 | Performance Control Register                          | 4–23 |
| 4–22 | PERF_CONTROL Low/High Select Encodings                | 4–24 |
| 4–23 | CPU Error Information Register 0                      | 4–26 |
| 4–24 | CPU Error Information Register 1                      | 4–27 |
| 4–25 | CIA Error Register                                    | 4–30 |
| 4–26 | CIA Status Register                                   | 4–32 |
| 4–27 | CIA Error Mask Register                               | 4–34 |
| 4–28 | CIA Syndrome Register                                 | 4–36 |
| 4–29 | ECC Syndromes for Single-Bit Errors                   | 4–36 |
| 4–30 | CIA Memory Port Status Register 0                     | 4–37 |
| 4–31 | CIA Memory Port Status Register 1                     | 4–38 |
| 4–32 | Memory Port Command Field (MEM_PORT_CMD)              | 4–39 |
| 4–33 | Memory Sequencer State Field (SEQ_ST)                 | 4–39 |
| 4–34 | Encoded Set Select Field (SET_SEL_ENC)                | 4–40 |
| 4–35 | PCI Error Register 0                                  | 4–42 |
| 4–36 | PCI Error Register 1                                  | 4–44 |
| 4–37 | PCI Error Register 2                                  | 4–45 |
| 4–38 | Memory Configuration Register                         | 4–47 |
| 4–39 | Memory Base Address Register <i>n</i>                 | 4–50 |
| 4–40 | Memory Timing Information Register <i>n</i>           | 4–53 |
| 4–41 | Memory Timing Parameters, Encoded Values              | 4–54 |
| 4–42 | Memory Control Signals Timing Limits                  | 4–57 |
| 4–43 | Memory Address Timing Limits                          | 4–58 |
| 4–44 | Memory Data Timing Limits                             | 4–59 |
| 4–45 | Scatter-Gather Translation Buffer Invalidate Register | 4–60 |
| 4–46 | Window Base Register $n$                              | 4–62 |
| 4–47 | Window Mask Register <i>n</i>                         | 4–64 |
| 4–48 | Translated Base Register <i>n</i>                     | 4–65 |

| 4–49 | PCI Address Translation—Scatter-Gather Mapping Enabled   | 4–66 |
|------|----------------------------------------------------------|------|
| 4–50 | PCI Address Translation—Scatter-Gather Mapping           |      |
|      | Disabled                                                 | 4–67 |
| 4–51 | Window Base DAC Register                                 | 4–68 |
| 4–52 | Lockable Translation Buffer Tag <i>n</i> Registers       | 4–70 |
| 4–53 | Translation Buffer Tag <i>n</i> Registers                | 4–71 |
| 4–54 | Translation Buffer <i>m</i> Page <i>n</i> Registers      | 4–73 |
| 5–1  | CIA Pin State During Reset                               | 5–2  |
| 5–2  | CIA Pin State After Reset                                | 5–3  |
| 5–3  | Registers Initialized by SROM Code                       | 5–4  |
| 6–1  | 21164 Address Space                                      | 6–7  |
| 6–2  | int4_valid_h<3:0> and addr_h<4:3> for Sparse Space Write |      |
|      | Transactions                                             | 6–13 |
| 6–3  | PCI Memory Sparse Space Read/Write Encodings             | 6–14 |
| 6–4  | HAE_MEM High Order Sparse Space Bits                     | 6–15 |
| 6–5  | PCI I/O Sparse Space Read/Write Encodings                | 6–20 |
| 6–6  | CIA PCI and (E)ISA I/O Map                               | 6–21 |
| 6–7  | PCI Configuration Space Read/Write Encodings             | 6–24 |
| 6–8  | Generating IDSEL Pin Signals                             | 6–25 |
| 6–9  | Primary 64-Bit PCI IDSEL Mapping                         | 6–28 |
| 6–10 | Hardware-Specific Register Address Space                 | 6–29 |
| 6–11 | PCI Target Window MASK Register (Wn_MASK)                | 6–30 |
| 6–12 | Direct-Mapped PCI Target Address Translation             | 6–35 |
| 6–13 | Scatter-Gather Mapped PCI Target Address Translation     | 6–37 |
| 6–14 | PCI Window Power-Up Configuration                        | 6–42 |
| 7–1  | DECchip 21171-BA Pin List                                | 7–1  |
| 7–2  | <pre>ioc_h&lt;6:0&gt; Control Functions</pre>            | 7–4  |
| 7–3  | cmc_h<8:0> Control Functions                             | 7–4  |
| 7–4  | Var Encodings for CMC Command 0                          | 7–5  |
| 7–5  | Var Encodings for CMC Commands 0, 8, A, and B $\ldots$   | 7–5  |
| 7–6  | Var Encodings for CMC Commands 2, 3, 4, 5, 6, and 7      | 7–6  |
| 7–7  | IOD Bus and MEMDATA Bus Data Width Selection             | 7–7  |
| 7–8  | DSW Operating Modes                                      | 7–8  |
| 7–9  | DECchip 21171-BA Pin Assignment List (Alphabetic)        | 7–9  |
| 7–10 | DECchip 21171-BA Pin Assignment (Numeric)                | 7–13 |
| 7–11 | DECchip 21171-BA Package Dimensions                      | 7–18 |
|      |                                                          |      |

# Preface

#### **Purpose and Audience**

The document is a support and reference document for engineers using the Alpha 21164 microprocessor to design uniprocessor systems.

#### Organization

This document contains the following parts, chapters, and appendix:

• Chapter 1, DECchip 21171 Core Logic Chipset Overview, provides an overview of the DECchip 21171-AA core logic chipset features.

#### Part I—DECchip 21171-CA (CIA) Information

- Chapter 2, DECchip 21171-CA Pin Descriptions, provides control, I/O interface, and address chip (CIA) pin descriptions.
- Chapter 3, DECchip 21171-CA Architecture Overview, provides the CIA architecture overview.
- Chapter 4, DECchip 21171-CA Control and Status Registers, provides a programmer's reference for control and status registers (CSRs).
- Chapter 5, DECchip 21171-CA Power-Up and Initialization, provides information on the behavior of CIA during power-up and initialization.
- Chapter 6, DECchip 21171-CA Address Mapping, provides information on system address mapping.

#### Part II—DECchip 21171-BA (DSW) Information

- Chapter 7, DECchip 21171-BA Pin Descriptions, provides data switch chip (DSW) pin descriptions.
- Chapter 8, DECchip 21171-BA Architecture Overview, provides an overview of the DSW architecture.

• Appendix A, Technical and Ordering Information, provides information on how to obtain technical support and how to order products and documentation.

#### **Document Conventions**

This section describes the abbreviation and notation conventions used throughout this guide.

#### Numbering

All numbers are decimal or hexadecimal unless otherwise specified. In cases of ambiguity, a subscript indicates the radix of nondecimal numbers. For example, 19 is decimal, but  $19_{16}$  and 19A are hexadecimal.

#### **UNPREDICTABLE and UNDEFINED Definitions**

Results specified as UNPREDICTABLE may vary from moment to moment, implementation to implementation, and instruction to instruction within implementations. Software can never depend on results specified as UNPREDICTABLE.

Operations specified as UNDEFINED may vary from moment to moment, implementation to implementation, and instruction to instruction within implementations. The operation may vary from nothing to stopping system operation. UNDEFINED operations must not cause the processor to hang, that is, reach a state from which there is no transition to a normal state where the machine can execute instructions.

Note the distinction between results and operations. Nonprivileged software cannot invoke UNDEFINED operations.

#### Ranges

Ranges are specified by a pair of numbers separated by two periods (..) and are inclusive. For example, a range of integers 0..4 includes the integers 0, 1, 2, 3, and 4.

#### Extents

Extents are specified by a pair of numbers in angle brackets (<>) separated by a (:) and are inclusive. For example, bits <7:3> specifies an extent including bits 7, 6, 5, 4, and 3.

#### **Must Be Zero**

Fields specified as must be zero (MBZ) must never be filled by software with a non-zero value. If the processor encounters a non-zero value in a field specified as MBZ, a reserved operand exception occurs.

#### **Should Be Zero**

Fields specified as should be zero (SBZ) should be filled by software with a zero value. These fields may be used at some future time. Non-zero values in SBZ fields produce UNPREDICTABLE results.

#### **Register and Memory Figures**

Register figures have bit and field position numbering starting at the right (low-order) and increasing to the left (high-order). Memory figures have addresses starting at the top and increasing toward the bottom.

#### **Register Field Notation**

Register figures and tabulated descriptions have a mnemonic that indicates the bit or field characteristic as described in Table 1.

| Notation | Description                                                                                                                                                                                                                                                                         |
|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RW       | A read-write bit or field. The value can be read and written by software, microcode, or hardware.                                                                                                                                                                                   |
| RO       | A read-only bit or field. The value can be read by software, microcode, or hardware. The bit is written by hardware. Software or microcode write operations to this bit are ignored.                                                                                                |
| WO       | A write-only bit. The value can be written by software and microcode.<br>The bit is read by hardware. Read operations to this bit by software or<br>microcode return an UNPREDICTABLE result.                                                                                       |
| WZ       | A write-only bit or field. The value can be written by software or microcode. The bit is read by hardware. Read operations to this bit by software or microcode return a zero.                                                                                                      |
| WC       | A write-to-clear bit. The value can be read by software or microcode.<br>Software or microcode write operations with a 1 to this bit cause the bit<br>to be cleared by hardware. Software or microcode write operations with<br>a 0 to this bit do not modify the state of the bit. |
| RC       | A read-to-clear field. The bit is written by hardware and remains<br>unchanged until the bit is read. The bit can be read by software or<br>microcode, at which point hardware can write a new value into the<br>field.                                                             |

#### Table 1 Register Field Notation

Other register fields that are unnamed may be labeled as specified in Table 2.

 Table 2
 Unnamed Register Field Notation

| Notation | Description                                                                                                                                                |
|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0        | A 0 in a bit position indicates a register bit that is read as a 0 and is ignored on a write operation.                                                    |
| 1        | A 1 in a bit position indicates a register bit that is read as a 1 and is ignored on a write operation.                                                    |
| x        | An x in a bit position indicates a register bit that does not exist in hardware. The value is UNPREDICTABLE when read and is ignored on a write operation. |

#### **Bit Notation**

Multiple bit fields are shown as extents (see Extents).

#### Warning

Warning provides information to prevent personal injury.

#### Caution

Caution indicates potential damage to equipment or data.

#### Note

Note provides general information that could be helpful.

#### **Data Units**

Table 3 defines the data unit terminology used throughout this manual.

| Term     | Words | Bytes | Bits | Other                                                                                                                                                             |
|----------|-------|-------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Byte     | 1     | _     | 8    | _                                                                                                                                                                 |
| Word     | 1     | 2     | 16   | _                                                                                                                                                                 |
| Tribyte  | _     | 3     | 24   | _                                                                                                                                                                 |
| Longword | 2     | 4     | 32   | _                                                                                                                                                                 |
| Quadword | 4     | 8     | 64   | _                                                                                                                                                                 |
| Octaword | 8     | 16    | 128  | Single read fill; that is, the cache space<br>that can be filled in a single read access.<br>It takes two read accesses to fill one<br>Bcache line (see Hexword). |
| Hexword  | 16    | 32    | 256  | Cache block, cache line. The space allocated to a single cache block.                                                                                             |

Table 3 Data Units

#### **Signal Name References**

Signal names in text are printed in boldface lowercase. Mixed-case and uppercase signal naming conventions are ignored. These two examples illustrate the conventions used in this document:

- MEM\_WE\_L[1] is shown as mem\_we\_l<1>.
- **TEST\_MODE[1]** is shown as **test\_mode\_h<1>**.

# 1

# DECchip 21171 Core Logic Chipset Overview

The DECchip 21171 core logic chipset (21171) is used to support the Alpha 21164 microprocessor (21164) in high-performance uniprocessor systems. The chipset includes an interface to the 64-bit peripheral component interconnect (PCI) bus, and associated control and data paths for the 21164, memory, and backup cache (Bcache). Little discrete logic is needed on the module.

#### 1.1 Features

The DECchip 21171 core logic chipset has the following features.

- Central processing unit—Supports Alpha 21164 microprocessor
- Components
  - One DECchip 21171-CA chip—The control, I/O interface, and address chip (CIA) has 383 pins and is in a plastic pin grid array (PPGA) package.
  - Four DECchip 21171-BA chips—The data switch chip (DSW) has 208 pins and is in a plastic quad flat pack (PQFP) package.
- Data paths
  - 64-bit, ECC-protected data path between CIA and DSW
  - 128-bit ECC-protected data path between the 21164 and DSW
  - 256-bit ECC-protected memory data path between DSW and memory
- Timing
  - Supports all 21164 clock frequencies
  - Supports system clock frequencies up to 33 MHz (PCI clock)
  - PCI clock, cache, and memory clock period are an integer multiple of the 21164 clock period

# DECchip 21171 Core Logic Chipset Overview 1.1 Features

- Bcache
  - Third-level cache for the 21164
  - Cache size from 2MB to 64MB
  - Write-back, ECC-protected cache
- Memory
  - Supports up to 8GB of ECC-protected physical memory
  - Industry-standard memory array configurations
- High-performance PCI
  - 64-bit multiplexed address and data
  - 64-bit PCI address handling
  - Scatter-gather map support
  - No glue logic required to connect PCI-compliant devices

#### 1.2 System Overview

To build a system, such as that shown in Figure 1–1, with the DECchip 21171 core logic chipset, the following additional components are required:

- Alpha 21164 microprocessor
- Bcache
- Memory arrays
- Serial ROM (SROM) (for 21164)
- Circuit to generate input clock for 21164
- Circuit to generate input clock for 21171
- Support logic
  - PCI interrupt controller
  - PCI arbiter
  - Reset logic
  - Console ROM logic and flash ROM

#### DECchip 21171 Core Logic Chipset Overview 1.2 System Overview

• PCI peripheral devices





The MEMDATA bus provides a 256-bit, ECC-protected data path between the four data path slices (DSWs) and the memory arrays. Each bit slice (DSW) connects to 64 bits of the MEMDATA bus.

The input/output data (IOD) bus provides a 64-bit, ECC-protected data path between the CIA and DSW chips.

The 21164 is connected to the CIA and DSW by the sysBus. The sysBus contains address, data, and command signal lines. The sysBus is the 21164 interface bus with several additional signals to handle direct memory access (DMA) transactions through the CIA and DSW.

Systems built with the DECchip 21171 core logic chipset have the capability to support up to 8GB of memory. The chipset supports the following industry standard dynamic RAMs (DRAM) in the memory arrays:

| 1MB * 36 | 2MB * 36 |
|----------|----------|
| 4MB * 36 | 8MB * 36 |

# DECchip 21171 Core Logic Chipset Overview 1.2 System Overview

#### 1.2.1 DECchip 21171 Core Logic Chipset Microarchitecture

As shown in Figure 1–1, the DECchip 21171 core logic chipset consists of the CIA and four DSW application-specific integrated circuits (ASICs).

- DECchip 21171-CA (CIA), 383-pin PPGA: Provides control functions to main memory, and a bridge to the 64-bit PCI bus. In addition, the CIA provides all control functions for the DSW and part of the I/O data path.
- DECchip 21171-BA (DSW), 208-pin PQFP: A bit slice ASIC (four required), provides the data path between the 21164, main memory, Bcache, and the CIA, and part of the I/O data path.

#### **1.3 CIA Microarchitecture**

The CIA provides control functions to main memory and the PCI interface. As shown in Figure 1–2, the CIA is divided into the following major functional logic blocks.

The instruction and address logic accepts commands from the 21164 and directs instructions to either the memory port or the I/O port. A 3-entry 21164 instruction queue provides buffering in the event that the memory and I/O ports are busy. A flush address register is also provided to allow DMA read and write operations to interrogate a supported Bcache for the most recent data.

The memory logic provides the row and column addresses for the supported memory banks and all memory control functions (row address select **[ras]**, column address select **[cas]**, write-enable, and so on). In addition, the memory logic provides control signals to the DSW to initiate data transactions to and from memory.

The I/O address logic handles I/O read and write addresses. The decode logic extracts the PCI address from the dense or sparse space 21164 address encoding, generates PCI I/O read or write addresses, and passes them to the PCI data path logic. The I/O logic can also increment the current address each data cycle. The incremented address provides a pointer to the next data item to be transferred to or from the I/O read/write buffers.

A 3-entry I/O address queue is provided together with a single-entry current address register. These components allow four I/O write operations to be outstanding. The DSW chip provides four corresponding I/O write data buffers.

#### DECchip 21171 Core Logic Chipset Overview 1.3 CIA Microarchitecture



Figure 1–2 CIA Block Diagram

In addition, a bypass path is provided for the special case of a dense space I/O write transaction with all 32 data bytes valid.

The PCI data path logic provides the interface to the 64-bit PCI, and contains a portion of the data path control logic. Its major functions are to provide:

- ECC code generation on data transactions to the DSW
- ECC code check and correction on data transactions from the DSW
- I/O read/write addresses to the PCI
- Buffers for all I/O and DMA read and write data transactions

# DECchip 21171 Core Logic Chipset Overview 1.3 CIA Microarchitecture

The DMA address logic converts PCI addresses to 21164 memory address space. Two address conversion methods are provided:

- A direct path where a base offset is concatenated with the PCI address
- A scatter-gather map, which maps any 8KB PCI page to any 8KB memory space page

The scatter-gather map translation lookaside buffer (TLB) has eight entries, with each entry containing four consecutive page table entries (PTEs).

#### **1.4 DSW Microarchitecture**

The DSW provides bidirectional data paths between the 21164, the memory arrays, and the CIA, as shown in Figure 1–3. Four DSW chips, using a bit slice design, provide the complete data path.

The majority of the DSW logic is comprised of data buffers and multiplexers. The CIA, using two encoded control fields, directs data flow to and from the DSW.

The victim buffer has a 64-byte single-entry buffer to contain victim data during a 21164 memory read transaction that generates a victim. Victim data is saved in the buffer, allowing the read transaction to fetch read data from memory and send it to the 21164. Later the victim data is written to memory.

The memory interface contains the data-out register and the data-in register. The data-out register buffers either 21164 victim data to memory, or DMA write data to memory. The data-in register accepts 21164 memory read data. The DSW clocks the register on optimum 15-ns clocks to minimize memory latency.

The I/O write buffer consists of four 32-byte buffers. The four buffers allow the chipset to sustain maximum bandwidth on a large copy operation from memory, through the 21164, to I/O space.

The 32-byte I/O read buffer is provided to assemble the 128-bit data required by the 21164 from the 64-bit data transfers from the IOD bus (CIA-DSW interface).

The DMA read/write buffers consist of two identical buffers (DMA buffer 0 and DMA buffer 1). Each buffer consists of three, 64-byte, single-entry data buffers used to hold data from memory, Bcache, and the PCI. When a buffer is written, its data valid bits are asserted, along with data, to the buffer. The valid bits are used to select appropriate read/write data.

#### DECchip 21171 Core Logic Chipset Overview 1.4 DSW Microarchitecture



Figure 1–3 DSW Block Diagram

LJ-04216.AI

#### 1.5 System Clocks

The 21164 internal clock will be divided by a programmable value to create an output clock, **sys\_clk\_out1\_h**, which is used as the system clock. The divisor must produce a clock between 25 MHz and 33 MHz.

The system designer must supply a circuit to maintain stability of the system clock and distribute it to PCI devices.

The system clock can be used as a source for a circuit that generates a clock for (E)ISA devices.

DECchip 21171 Core Logic Chipset Overview 1.6 DECchip 21171 Core Logic Chipset Characteristics

### 1.6 DECchip 21171 Core Logic Chipset Characteristics

Table 1–1 and Table 1–2 list the characteristics of the CIA and DSW chips.

| Characteristic                                            | Specification                        |  |
|-----------------------------------------------------------|--------------------------------------|--|
| Power supply                                              | <b>Vss</b> 0.0 V, <b>Vdd</b> 5 V ±5% |  |
| Operating temperature                                     | Tj maximum = $70^{\circ}$ C (154°F)  |  |
| Storage temperature range                                 | –55°C (–67°F) to 125°C (257°F)       |  |
| Power dissipation<br>@ <b>Vdd</b> = 5.25 V, Freq = 33 MHz | 2.75 W maximum                       |  |

Table 1–1 DECchip 21171-CA (CIA) Chip Characteristics

| Characteristic                                            | Specification                        |  |
|-----------------------------------------------------------|--------------------------------------|--|
| Power supply                                              | <b>Vss</b> 0.0 V, <b>Vdd</b> 5 V ±5% |  |
| Operating temperature                                     | Tj maximum = 100°C (212°F)           |  |
| Storage temperature range                                 | –55°C (–67°F) to 125°C (257°F)       |  |
| Power dissipation<br>@ <b>Vdd</b> = 5.25 V, Freq = 33 MHz | 1.0 W maximum                        |  |

Table 1–2 DECchip 21171-BA (DSW) Chip Characteristics

# **Part I** DECchip 21171-CA (CIA) Information

Part I contains five chapters that provide information about the DECchip 21171-CA (CIA) chip. The following table lists the topics described in each chapter:

| Chapter | Description                  |
|---------|------------------------------|
| 2       | Pin signals                  |
| 3       | Architecture                 |
| 4       | Control and status registers |
| 5       | Power-up and initialization  |
| 6       | System address mapping       |

# 2

# **DECchip 21171-CA Pin Descriptions**

This chapter provides a description of the DECchip 21171-CA pin signals.

### 2.1 DECchip 21171-CA Pin List

Table 2-1 lists the pin signals grouped by function. The information in the Type column identifies a signal as input (I), output (O), bidirectional (B), or power (P).

| Signal Name      | Quantity | Туре    | Signal Name           | Quantity | Туре |
|------------------|----------|---------|-----------------------|----------|------|
|                  |          | sysBus  | Signals (55 Total)    |          |      |
| addr_cmd_par_h   | 1        | В       | addr_h<39,34:4>       | 32       | В    |
| addr_res_h<1:0>  | 2        | Ι       | cmd_h<3:0>            | 4        | В    |
| addr_bus_req_h   | 1        | В       | cack_h                | 1        | 0    |
| dack_h           | 1        | 0       | error_ $\mathbf{h}^1$ | 1        | 0    |
| ill_h            | 1        | 0       | fill_id_h             | 1        | В    |
| ìll_error_h      | 1        | 0       | idle_bc_h             | 1        | 0    |
| nt4_valid_h<3:0> | 4        | Ι       | int_h <sup>1</sup>    | 1        | 0    |
| ag_dirty_h       | 1        | 0       | tag_ctl_par_h         | 1        | 0    |
| victim_pending   | 1        | Ι       | _                     | _        | —    |
|                  |          | IOD Bus | Signals (88 Total)    |          |      |
| cmc_h<8:0>       | 9        | 0       | ioc_h<6:0>            | 7        | 0    |
| iod_h<63:0>      | 64       | В       | iod_e_h<7:0>          | 8        | В    |

Table 2–1 DECchip 21171-CA Pin List

<sup>1</sup>See Section 2.2.1.

(continued on next page)

#### DECchip 21171-CA Pin Descriptions 2.1 DECchip 21171-CA Pin List

| Signal Name         | Quantity | Туре       | Signal Name             | Quantity | Туре |
|---------------------|----------|------------|-------------------------|----------|------|
|                     | Ме       | mory Con   | trol Signals (42 Total) |          |      |
| mem_ack_l           | 1        | 0          | mem_addr_h<12:0>        | 13       | 0    |
| set_sel_h<15:0>     | 16       | 0          | ras_h<3:0>              | 4        | 0    |
| cas_h<3:0>          | 4        | 0          | mem_we_l<1:0>           | 2        | 0    |
| mem_en_h            | 1        | 0          | mem_req_l               | 1        | Ι    |
|                     | PC       | l Local B  | us Signals (88 Total)   |          |      |
| ad_h<63:0>          | 64       | В          | cbe_l<7:0>              | 8        | В    |
| par_h               | 1        | В          | par64_h                 | 1        | В    |
| req64_l             | 1        | В          | ack64_l                 | 1        | В    |
| frame_l             | 1        | В          | irdy_l                  | 1        | В    |
| devsel_l            | 1        | В          | trdy_l                  | 1        | В    |
| stop_l              | 1        | В          | perr_l                  | 1        | В    |
| serr_l              | 1        | В          | req_l                   | 1        | 0    |
| rst_l               | 1        | 0          | gnt_l                   | 1        | Ι    |
| mem_cs_l            | 1        | Ι          | lock_l                  | 1        | Ι    |
|                     | Phas     | e-Locked   | Loop Signals (4 Total)  |          |      |
| pll_agnd_h          | 1        | 0          | pll_clk_h               | 1        | Ι    |
| pll_lp1_h           | 1        | Ι          | pll_vss_h               | 1        | Ι    |
| pll_test_h<3:0>     | 4        | Ι          | _                       | _        | —    |
| Miscellaneous Power | Signals  |            |                         |          |      |
|                     |          |            | (4 Total)               |          |      |
| aux_vdd_h           | 1        | Р          | aux_vss_h               | 1        | Р    |
| pll_vdd_h           | 1        | Р          | pll_lp2_h               | 1        | Р    |
|                     | М        | iscellaned | ous Signals (8 Total)   |          |      |
| count_out_h         | 1        | 0          | debug_h<1:0>            | 2        | Ι    |
| scan_in_h           | 1        | Ι          | sys_rst_l               | 1        | Ι    |
| test_mode_h<1:0>    | 2        | Ι          | test_or_scan_out_h      | 1        | 0    |

#### Table 2–1 (Cont.) DECchip 21171-CA Pin List

(continued on next page)

#### DECchip 21171-CA Pin Descriptions 2.1 DECchip 21171-CA Pin List

| Signal Name                     | Quantity    | Туре    | Signal Name         | Quantity | Туре |
|---------------------------------|-------------|---------|---------------------|----------|------|
|                                 |             | Reserve | d Signals (2 Total) |          |      |
| gru_ack_h                       | 1           | Ι       | gru_sel_h           | 1        | 0    |
| Pin Totals                      |             |         |                     |          |      |
| Total input pi                  | ins:        |         | 21                  |          |      |
| Total output                    |             |         | 72                  |          |      |
| Total bidirect                  | ional pins: |         | 196                 |          |      |
|                                 |             |         |                     |          |      |
| Total signal p                  | oins:       |         | 289                 |          |      |
| Total signal pins:              |             |         | 289                 |          |      |
| Total PWR5 pins:                |             |         | 36                  |          |      |
| Total GND pins:                 |             |         | 51                  |          |      |
| Total miscellaneous power pins: |             |         | 4                   |          |      |
| Total spare pins:               |             |         | 1                   |          |      |
| Total reserved                  | d pins:     |         | 2                   |          |      |
|                                 |             |         |                     |          |      |
| Total pins:                     |             |         | 383                 |          |      |

Table 2–1 (Cont.) DECchip 21171-CA Pin List

### 2.2 DECchip 21171-CA Signal Descriptions

This section provides a description of the pin function. Signal descriptions are grouped by function and correspond to the pin list (see Table 2-1).

\_ Note \_

The Alpha 21164 microprocessor uses the rising edge of **sys\_clk\_out1\_h** (clk1R) as a reference when generating and sampling the system interface signals.

#### 2.2.1 sysBus Signals

The *Alpha 21164 Microprocessor Hardware Reference Manual* defines and describes sysBus signals in detail, except for **int\_h** and **error\_h**. Those two signals are described here.

#### int\_h

The **int\_h** pin is connected to 21164 pin **irq<0**>. The CIA asserts **int\_h** to notify the 21164 that the CIA has detected a corrected ECC error.

#### error\_h

The **error\_h** pin is connected to 21164 pin **irq**<**3**>. The CIA asserts this signal line to notify the 21164 that the CIA has detected an error other than a corrected ECC error.

#### 2.2.2 PCI Local Bus Signals

The PCI local bus signals

#### ack64\_l

Acknowledge 64-bit transfer—Asserted by the device that has decoded its address as the target of the current access, indicating that the target device is willing to transfer 64-bit data.

#### ad\_h<63:0>

The 64-bit address and 64 bits of data are multiplexed on these signal lines. The upper 32 bits (<63:32>) are reserved except for those transfers where **req\_64\_l** is asserted.

#### cbe\_l<7:0>

Bus command and byte enable are multiplexed on the same signal lines. During an address phase (when using the DAC command and when **req\_64\_l** is aserted) the bus command is transferred on **cbe\_l**<**7:0**>. During a data phase these lines carry the byte enable bits, indicating which bytes have meaningful data.

#### devsel\_l

When asserted, indicates that the asserting device has decoded its address as the target of the current access. As an input, **devsel\_l** indicates whether any device on the bus has been selected.

#### frame\_l

The cycle frame signal is asserted by the current master to indicate the beginning and duration of an access. When **frame\_l** is deasserted, the final phase of the access has started.

#### gnt\_l

Assertion of **gnt\_l** indicates that access to the bus has been granted. This is a point-to-point signal. Every master has its own grant line.

#### irdy\_l

Assertion of **irdy\_l** (initiator ready) indicates that the bus master is ready to complete the current phase of the transaction. Signal **irdy\_l** is used in conjunction with **trdy\_l**. A data phase is completed on any clock where both signals are sampled asserted.

#### lock\_l

Assertion of **lock\_l** indicates an atomic operation that may require multiple transactions to complete. When **lock\_l** is asserted, nonexclusive transactions may proceed to an address that is not currently locked.

#### mem\_cs\_l

The *PCI Local Bus Specification* does not preclude product-specific function /performance enhancements by way of sideband signals. A sideband signal is loosely defined as any signal that is not part of the PCI specification and connects two or more PCI nodes and has meaning only to these nodes. Sideband signals lines must not violate PCI local bus specifications.

Signal **mem\_cs\_l** is a sideband signal line. It is used by the PCI-to-EISA bridge to help manage the EISA memory map and peripheral component architecture (PCA) compatibility holes (see Section 6.3.4.2).

#### par\_h

The **par\_h** signal is used to create even parity across **ad\_h<31:0>** and **cbe\_l<3:0>**. Signal **par\_h** is stable and valid one clock cycle after the address phase. Signal **par\_h** remains valid until one clock cycle after the completion of the current data phase. The master asserts **par\_h** for address and write data phases; the target asserts **par\_h** for read data phases.

#### par64\_h

The **par64\_h** signal is used to create even parity across **ad\_h<63:32>** and **cbe\_l<7:4>**. Signal **par64\_h** is stable and valid one clock cycle after the address phase. Signal **par64\_h** remains valid until one clock cycle after the completion of the current data phase. The master asserts **par64\_h** for address and write data phases; the target asserts **par64\_h** for read data phases.

#### perr\_l

The **perr\_l** signal (parity error) is used to report data parity errors that occur during all PCI transactions except a special cycle. Signal **perr\_l** is a tristate signal line that must be asserted by the data-receiving node two cycles after data with bad parity is detected. Signal **perr\_l** must be asserted for a minimum of one clock cycle for each phase during which bad data parity is detected. Signal **perr\_l**, like all sustained tristate signals, must be asserted high for at least one cycle before being returned from asserted to the tristate condition.

#### req\_l

Assertion of the **req\_l** signal line (request) indicates to the arbiter that this node wants to use the PCI bus. Every master node has its own **req\_l** pin.

#### req64\_l

The current bus master asserts **req64\_l** (request 64-bit transfer), indicating that it wants to transfer data by using 64 bits. Signal **req64\_l** has the same timing as **frame\_l**. Signal **req64\_l** is asserted low by the system reset signal. Nodes connected to the 64-bit PCI bus extension will see the line asserted low. Those nodes not connected to the 64-bit PCI bus extension will see the signal asserted high by a pull-up device.

#### rst\_l

The **rst\_l** signal line (reset) is used to bring PCI-specific registers, sequencers, and signals to a consistent state. When **rst\_l** is asserted, all PCI output pins must be driven to their benign state, usually tristated. Although the signal is asynchronous, deassertion must be a clean, bounce-free edge.

#### serr\_l

The **serr\_l** pin (system error) is used to report address parity errors, data parity errors on the special cycles command, or any other system error where the result will be catastrophic. If a node does not want a nonexistent memory (NMI) error to be generated, a different reporting mechanism is required. **serr\_l** is an open-drain signal line and is asserted for a minimum of one clock cycle by the node reporting the error.

#### stop\_l

The **stop\_l** pin indicates that the current target is requesting that the master stop the current transaction.

#### trdy\_l

When asserted, the **trdy\_l** (target ready) pin indicates the target node's ability to complete the current phase of the transaction. Signal **trdy\_l** is used in conjunction with **irdy\_l**. A data phase is completed on any clock assertion where both **trdy\_l** and **irdy\_l** are sampled asserted. During a read transaction, **trdy\_l** indicates that valid data is present on **ad<31:0**>. During a write transaction, **trdy\_l** indicates that the target is ready to accept data. Wait cycles are inserted until both **trdy\_l** and **irdy\_l** are asserted together.

#### 2.2.3 IOD Bus Signals

This section provides a description of the IOD bus signals.

#### iod\_h<63:0>

The **iod\_h<63:0**> signals carry data between the CIA and DSW on the IOD bus.

#### iod\_e\_h<7:0>

The **iod\_e\_h<7:0**> signals carry ECC between the CIA and DSW on the IOD bus. All ECC generation and detection is performed in the 21164 and CIA.

#### ioc\_h<6:0>

The **ioc\_h<6:0**> signals allow the CIA to control data flow on the IOD bus. The data transfers are between memory and the PCI bus. CIA control is encoded as shown in Table 2–2.

| ioc_h<br><6:4> | ioc_h<br><3>                         | ioc_h<br><2>                | ioc_h<br><1> | ioc_h<br><0> | Function                                  |
|----------------|--------------------------------------|-----------------------------|--------------|--------------|-------------------------------------------|
| 000            | Buffer n                             | х                           | х            | х            | Clear valid bits in PCI buffer <i>n</i> . |
| 001            | х                                    | x                           | x            | x            | Load the LW register (Reserved).          |
| 010            | Buffer n                             | Adr m2                      | Adr m1       | Adr m0       | Write PCI buffer <i>n</i> , adr m.        |
| 011            | Mask3                                | Mask2                       | Mask1        | Mask0        | Write IOR (QW mask).                      |
| 100            | Buffer n                             | Adr m2                      | Adr m1       | Adr m0       | Read DMA buffer <i>n</i> , adr m.         |
| 101            | Buffer n1                            | Buffer n0                   | Adr m1       | Adr m0       | Read IOW buffer <i>n</i> , adr m.         |
| 110            | Buffer <i>n</i> 1<br>Buffer <i>n</i> | Buffer <i>n</i> 0<br>Adr m2 | Adr m1       | Adr m0       | Read buffer (IOW or DMA) low longword.    |
| 111            | Mask3                                | Mask2                       | Mask1        | Mask0        | Start IOW (buffer mask).                  |

Table 2–2 ioc\_h<6:0> Control Functions

#### cmc\_h<8:0>

The **cmc\_h<8:0**> signal lines control flow of data between the 21164 and the memory arrays. They also start and stop loading of the free-running buffers (victim, flush, IOW buffers) in the DSW. In Table 2–3, A5 and A4 are address bits. The Var field encodes the transaction being performed as shown in Table 2–4, Table 2–5, and Table 2–6.

Table 2–3 cmc\_h<8:0> Control Functions

| cmc h | cmc h              | cmc h  | cmc h | cmc_h                  | cmc h                  |                                                                       |  |
|-------|--------------------|--------|-------|------------------------|------------------------|-----------------------------------------------------------------------|--|
| <8:5> | <4>                | <3>    | <2>   | <1>                    | <0>                    | Function                                                              |  |
| 0000  | Var 4 <sup>1</sup> | Var 3  | Var 2 | Var 1                  | Var 0                  | Start/stop the buffer.                                                |  |
| 0010  | х                  | $A4^2$ | Delay | Var 1                  | Var 0                  | Move fill data from memory to 21164.                                  |  |
| 0011  | Х                  | A4     | x     | Var 1                  | Var 0                  | Move IOR buffer data to 21164.                                        |  |
| 0100  | A5 <sup>2</sup>    | A4     | Delay | Var 1                  | Var 0                  | Move memory data to memory buffer 0.                                  |  |
| 0101  | A5                 | A4     | Delay | Var 1                  | Var 0                  | Move memory data to memory buffer 1.                                  |  |
| 0110  | A5                 | A4     | Delay | Stop<br>IOW <i>n</i> 1 | Stop<br>IOW <i>n</i> 0 | Move memory data to<br>memory buffer 0, stop<br>IOW buffer <i>n</i> . |  |
| 0111  | A5                 | A4     | Delay | Stop<br>IOW <i>n</i> 1 | Stop<br>IOW <i>n</i> 0 | Move memory data to<br>memory buffer 1, stop<br>IOW buffer <i>n</i> . |  |
| 1000  | A5                 | A4     | Var 2 | Var 1                  | Var 0                  | Write victim buffer to<br>memory.                                     |  |
| 1010  | A5                 | A4     | Var 2 | Var 1                  | Var 0                  | Write DMA0 buffer to memory.                                          |  |
| 1011  | A5                 | A4     | Var 2 | Var 1                  | Var 0                  | Write DMA1 buffer to memory.                                          |  |
|       |                    |        |       |                        |                        |                                                                       |  |

 $^1{\rm The}$  variable field encodes the transaction being performed. See Table 2–4, Table 2–5, and Table 2–6.  $^2{\rm A5}$  and A4 are address bits.

Table 2–4 Var Encodings for CMC Command 0

| Var<4:3> | Function                                         |
|----------|--------------------------------------------------|
| 00       | None.                                            |
| 01       | Start victim.                                    |
| 10       | Start flush buffer 0 and clear PCI 0 valid bits. |
| 11       | Start flush buffer 1 and clear PCI 0 valid bits. |

Table 2–5 Var Encodings for CMC Commands 0, 8, A, and B

| Var<2:0> | Function             |
|----------|----------------------|
| 000      | None.                |
| 001      | Stop victim.         |
| 010      | Stop flush buffer 0. |
| 011      | Stop flush buffer 1. |
| 100      | Stop IOW 0.          |
| 101      | Stop IOW 1.          |
| 110      | Stop IOW 2.          |
| 111      | Stop IOW 3.          |

Table 2–6 Var Encodings for CMC Commands 2, 3, 4, 5, 6, and 7

| Var<1:0> | Function             |
|----------|----------------------|
| 00       | None.                |
| 01       | Stop victim.         |
| 10       | Stop flush buffer 0. |
| 11       | Stop flush buffer 1. |

# 2.2.4 Memory Control Signals

This section provides a description of the memory control signals.

### cas\_h<3:0>

The **cas\_h<3:0**> signal lines select the column address in the memory arrays.

mem\_ack\_l

The **mem\_ack\_l** PCI sideband signal line is asserted by the CIA when it has cleared the transaction path in preparation to receive a transaction from the PCI-to-EISA bridge. See **mem\_req\_l**.

### mem\_addr\_h<12:0>

The **mem\_addr\_h<12:0>** signal lines carry the memory array address.

mem\_en\_h

The **mem\_en\_h** signal line enables operation of the memory arrays.

### mem\_req\_l

The **mem\_req\_l** signal line is asserted by the PCI-to-EISA bridge to notify the CIA that it has a transaction pending. The CIA completes all transactions in progress and then asserts **mem\_ack\_l** to the PCI-to-EISA bridge. The PCI-to-EISA bridge then starts the transaction. See **mem\_ack\_l**.

The PCI-to-EISA bridge set can be made using these two chips:

- Intel 82374EB EISA System Component (ESC)
- Intel 82375EB PCI-to-EISA Bridge (PCEB)

The PCEB allows a certain time period for a PCI transaction to complete. The **mem\_req\_l** and **mem\_ack\_l** PCI sideband signal lines are used to ensure that that the CIA performs transactions from the PCI-to-EISA bridge immediately.

### mem\_we\_l<1:0>

The **mem\_we\_l<1:0**> signal lines carry the write-enable signal to the memory arrays.

ras\_h<3:0>

The **ras\_h<3:0**> signal lines select the row address in the memory arrays.

### set\_sel\_h<15:0>

The set\_sel\_h<15:0> signal lines are used to select a memory array.

# 2.2.5 Phase-Locked Loop Signals

This section describes the phase-locked loop signals.

### pll\_agnd\_h

Signal **pll\_agnd\_h** is the analog ground input to the PLL and is connected to the system board ground.

#### pll\_clk\_h

The **pll\_clk\_h** signal is the system clock (or reference signal) input to the phase-locked loop (PLL) circuit. The **pll\_clk\_h** signal line is the source for CIA timing. It supplies a clock with the same frequency as that supplied to the PCI.

#### pll\_lp1\_h

Signal **pll\_lp1\_h** is an output of the PLL (phase detector output).

#### pll\_test\_h<3:0>

Signals **pll\_test\_h<3:0**> select which internal chip information is presented at output pins **debug\_h<1:0**>. These signal lines are reserved to Digital.

### pll\_vss\_h

Signal **pll\_vss\_h** is the ground input input to the PLL. It is connected to the system board ground.

### 2.2.6 Miscellaneous Power Signals

This section describes the miscellaneous power signals.

#### aux\_vdd\_h

Signal **aux\_vdd\_h** is modified (filtered) within the CIA chip before going to the PLL section of the CIA. Signal **aux\_vdd\_h** should be connected to **vdd\_h** on the module.

#### aux\_vss\_h

Signal **aux\_vss\_h** is modified (filtered) within the CIA chip before going to the PLL section of the CIA. Signal **aux\_vss\_h** should be connected to **vss\_h** on the module.

### pll\_vdd\_h

Signal **pll\_vdd\_h** is the power input to the PLL. It is connected to the system board power.

# pll\_lp2\_h

Signal **pll\_lp2\_h** is an input to the PLL, driving a VCO input.

# 2.2.7 Miscellaneous Signals

This section provides a description of the miscellaneous signals.

count\_out\_h

Signal **count\_out\_h** is used during PLL tests.

debug\_h<1:0>

Signals **debug\_h**<**1:0**> present internal CIA information selected by **pll\_test\_h**<**3:0**>. These signal lines are reserved to Digital.

scan\_in\_h

Signal **scan\_in\_h** is the enable pin for the scan chain.

sys\_rst\_l

The **sys\_rst\_l** signal line is the system reset input signal to the CIA. When **sys\_rst\_l** is asserted, the CIA resets its internal state.

test\_mode\_h<1:0>

Signals **test\_mode\_h<1:0**> define the four operating modes of the CIA as listed in Table 2–7.

| test_mode_h<1:0> | DSW Operating Mode |  |
|------------------|--------------------|--|
| 00               | Tristate mode      |  |
| 01               | Normal mode        |  |
| 10               | Scan mode          |  |
| 11               | PLL test mode      |  |

Table 2–7 DSW Operating Modes

#### test\_or\_scan\_out\_h

Signal **test\_or\_scan\_out\_h** is the TEST\_OUT output that is the end of the parametric NAND tree.

# 2.2.8 Reserved Signals

This section provides a description of the reserved signals.

# gru\_ack\_h

Signal gru\_ack\_h is reserved for use by Digital.

### gru\_sel\_h

Signal gru\_sel\_h is reserved for use by Digital.

# 2.2.9 DECchip 21171-CA Pin Name List (Alphabetic)

Table 2–8 lists the DECchip 21171-CA (CIA) pins by name in alphabetical order. The following abbreviations are used in the Type column of the table:

- B = Bidirectional
- I = Input
- P = Power
- O = Output

| ad_h<2>U14Bad_h<3>W16Bad_h<4>V14Bad_h<5>W14Bad_h<6>U13Bad_h<7>Y15Bad_h<8>V13Bad_h<9>W12Bad_h<10>AA14Bad_h<11>Y13Bad_h<10>AA14Bad_h<13>AA12Bad_h<12>AA13Bad_h<13>AA12Bad_h<14>AA11Bad_h<15>AA10Bad_h<16>V10Bad_h<17>U10Bad_h<20>V9Bad_h<21>W9Bad_h<22>W7Bad_h<22>Y5Bad_h<24>V8Bad_h<23>Y5Bad_h<24>W7Bad_h<23>Y5Bad_h<25W7Bad_h<23>Y5Bad_h<24>V8Bad_h<23>Y5Bad_h<24>Y7Bad_h<33>AA2Bad_h<35>W17Bad_h<33>AA18Bad_h<35>Y16Bad_h<37>W15Bad_h<36>Y16Bad_h<39>AA15Bad_h<40>Y14Bad_h<43>V12Bad_h<44>Y12Bad_h<43>V12Bad_h<44>Y12Bad_h<43>Y12Bad_h<44>Y12Bad_h<45>Y11Bad_h<46>W10Bad_                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Pin Name | Pin  | Type Pin Name |          | Pin  | Туре |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|------|---------------|----------|------|------|
| ad_h<2>U14Bad_h<3>W16Bad_h<4>V14Bad_h<5>W14Bad_h<6>U13Bad_h<7>Y15Bad_h<8>V13Bad_h<9>W12Bad_h<10>AA14Bad_h<11>Y13Bad_h<12>AA13Bad_h<13>AA12Bad_h<14>AA11Bad_h<15>AA10Bad_h<16>V10Bad_h<17>U10Bad_h<20>V9Bad_h<21>W9Bad_h<22>W7Bad_h<22>V8Bad_h<24>V8Bad_h<22>Y5Bad_h<28>AA3Bad_h<23>Y5Bad_h<30>U6Bad_h<33>AA18Bad_h<35>Y17Bad_h<35>AA17Bad_h<36>Y16Bad_h<37>W15Bad_h<38>AA16Bad_h<39>AA17Bad_h<38>AA16Bad_h<39>AA15Bad_h<40>Y14Bad_h<43>Y12Bad_h<44>Y12Bad_h<45>Y11Bad_h<46>W10Bad_h<47>Y10Bad_h<48>AA9Bad_h<49>Y9B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | ack64_l  | U5   | В             | —        | _    |      |
| ad_h<4>V14Bad_h<5>W14Bad_h<6>U13Bad_h<7>Y15Bad_h<8>V13Bad_h<9>W12Bad_h<10>AA14Bad_h<11>Y13Bad_h<12>AA13Bad_h<13>AA12Bad_h<14>AA11Bad_h<15>AA10Bad_h<16>V10Bad_h<17>U10Bad_h<18>AA8Bad_h<21>U9Bad_h<20>V9Bad_h<23>W8Bad_h<22>W7Bad_h<23>W5Bad_h<26>AA4Bad_h<27>W5Bad_h<28>AA3Bad_h<33>AA18Bad_h<30>U6Bad_h<33>AA18Bad_h<30>U6Bad_h<3>AA17Bad_h<36>Y16Bad_h<3>AA15Bad_h<38>AA16Bad_h<3>A117Bad_h<40>Y14Bad_h<43>V12Bad_h<40>Y14Bad_h<43>V12Bad_h<44>Y12Bad_h<45>Y11Bad_h<46>W10Bad_h<49>Y9B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | ad_h<0>  | Y18  | В             | ad_h<1>  | V15  | В    |
| ad_h<6>U13Bad_h<7>Y15Bad_h<8>V13Bad_h<9>W12Bad_h<10>AA14Bad_h<11>Y13Bad_h<12>AA13Bad_h<13>AA12Bad_h<12>AA13Bad_h<13>AA12Bad_h<14>AA11Bad_h<15>AA10Bad_h<16>V10Bad_h<17>U10Bad_h<20>V9Bad_h<21>U9Bad_h<22>W7Bad_h<23>W8Bad_h<24>V8Bad_h<27>W5Bad_h<26>AA4Bad_h<29>AA2Bad_h<28>AA3Bad_h<33>AA18Bad_h<30>U6Bad_h<33>AA18Bad_h<30>U6Bad_h<35>AA17Bad_h<36>Y16Bad_h<37>W15Bad_h<36>Y16Bad_h<39>AA15Bad_h<40>Y14Bad_h<41>W13Bad_h<40>Y14Bad_h<43>V12Bad_h<44>Y12Bad_h<45>Y11Bad_h<46>W10Bad_h<49>Y9B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | ad_h<2>  | U14  | В             | ad_h<3>  | W16  | В    |
| ad_h<8>       V13       B       ad_h<9>       W12       B         ad_h<10>       AA14       B       ad_h<11>       Y13       B         ad_h<12>       AA13       B       ad_h<13>       AA12       B         ad_h<12>       AA13       B       ad_h<13>       AA12       B         ad_h<14>       AA11       B       ad_h<15>       AA10       B         ad_h<16>       V10       B       ad_h<17>       U10       B         ad_h<18>       AA8       B       ad_h<19>       W9       B         ad_h<20>       V9       B       ad_h<21>       U9       B         ad_h<22>       W7       B       ad_h<23>       W8       B         ad_h<22>       W7       B       ad_h<25>       Y5       B         ad_h<26>       AA4       B       ad_h<27>       W5       B         ad_h<26>       AA3       B       ad_h<27>       W5       B         ad_h<28>       AA3       B       ad_h<29>       AA2       B         ad_h<30>       U6       B       ad_h<33>       AA18       B         ad_h<34>       Y17       B       ad_h<35>      | ad_h<4>  | V14  | В             | ad_h<5>  | W14  | В    |
| ad_h<10>AA14Bad_h<11>Y13Bad_h<12>AA13Bad_h<13>AA12Bad_h<14>AA11Bad_h<15>AA10Bad_h<16>V10Bad_h<15>AA10Bad_h<16>V10Bad_h<17>U10Bad_h<18>AA8Bad_h<21>U9Bad_h<20>V9Bad_h<21>U9Bad_h<22>W7Bad_h<23>W8Bad_h<24>V8Bad_h<25>Y5Bad_h<26>AA4Bad_h<27>W5Bad_h<28>AA3Bad_h<33>AA18Bad_h<30>U6Bad_h<33>AA18Bad_h<32>W17Bad_h<35>AA17Bad_h<36>Y16Bad_h<37>W15Bad_h<38>AA16Bad_h<49>A17Bad_h<40>Y14Bad_h<43>V12Bad_h<44>Y12Bad_h<43>V12Bad_h<44>Y12Bad_h<43>Y10Bad_h<48>AA9Bad_h<49>Y9B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | ad_h<6>  | U13  | В             | ad_h<7>  | Y15  | В    |
| ad_h<12>       AA13       B       ad_h<13>       AA12       B         ad_h<14>       AA11       B       ad_h<13>       AA10       B         ad_h<16>       V10       B       ad_h<15>       AA10       B         ad_h<16>       V10       B       ad_h<15>       AA10       B         ad_h<18>       AA8       B       ad_h<17>       U10       B         ad_h<20>       V9       B       ad_h<21>       U9       B         ad_h<22>       W7       B       ad_h<23>       W8       B         ad_h<22>       W7       B       ad_h<22>       Y5       B         ad_h<24>       V8       B       ad_h<27>       W5       B         ad_h<28>       AA3       B       ad_h<29>       AA2       B         ad_h<30>       U6       B       ad_h<31>       Y3       B         ad_h<32>       W17       B       ad_h<35>       AA18       B         ad_h<34>       Y17       B       ad_h<35>       AA17       B         ad_h<38>       AA16       B       ad_h<39>       AA15       B         ad_h<40>       Y14       B       ad_h<43>< | ad_h<8>  | V13  | В             | ad_h<9>  | W12  | В    |
| ad_h<14>       AA11       B       ad_h<15>       AA10       B         ad_h<16>       V10       B       ad_h<15>       U10       B         ad_h<18>       AA8       B       ad_h<19>       W9       B         ad_h<20>       V9       B       ad_h<21>       U9       B         ad_h<22>       W7       B       ad_h<23>       W8       B         ad_h<22>       W7       B       ad_h<23>       W5       B         ad_h<24>       V8       B       ad_h<25>       Y5       B         ad_h<26>       AA4       B       ad_h<27>       W5       B         ad_h<30>       U6       B       ad_h<31>       Y3       B         ad_h<30>       U6       B       ad_h<33>       AA18       B         ad_h<30>       U6       B       ad_h<35>       AA18       B         ad_h<30>       Y17       B       ad_h<35>       AA17       B         ad_h<36>       Y16       B       ad_h<37>       W15       B         ad_h<38>       AA16       B       ad_h<43>       V12       B         ad_h<40>       Y14       B       ad_h<43>          | ad_h<10> | AA14 | В             | ad_h<11> | Y13  | В    |
| ad_h<16>       V10       B       ad_h<17>       U10       B         ad_h<18>       AA8       B       ad_h<19>       W9       B         ad_h<20>       V9       B       ad_h<21>       U9       B         ad_h<22>       W7       B       ad_h<23>       W8       B         ad_h<22>       W7       B       ad_h<23>       W8       B         ad_h<24>       V8       B       ad_h<25>       Y5       B         ad_h<26>       AA4       B       ad_h<27>       W5       B         ad_h<28>       AA3       B       ad_h<29>       AA2       B         ad_h<30>       U6       B       ad_h<31>       Y3       B         ad_h<32>       W17       B       ad_h<33>       AA18       B         ad_h<34>       Y17       B       ad_h<35>       AA18       B         ad_h<36>       Y16       B       ad_h<39>       AA15       B         ad_h<40>       Y14       B       ad_h<43>       Y12       B         ad_h<42>       U12       B       ad_h<43>       Y12       B         ad_h<44>       Y12       B       ad_h<44>           | ad_h<12> | AA13 | В             | ad_h<13> | AA12 | В    |
| ad_h<18>       AA8       B       ad_h<19>       W9       B         ad_h<20>       V9       B       ad_h<21>       U9       B         ad_h<22>       W7       B       ad_h<23>       W8       B         ad_h<24>       V8       B       ad_h<25>       Y5       B         ad_h<26>       AA4       B       ad_h<27>       W5       B         ad_h<28>       AA3       B       ad_h<29>       AA2       B         ad_h<30>       U6       B       ad_h<31>       Y3       B         ad_h<32>       W17       B       ad_h<33>       AA18       B         ad_h<34>       Y17       B       ad_h<35>       AA17       B         ad_h<36>       Y16       B       ad_h<39>       AA15       B         ad_h<40>       Y14       B       ad_h<43>       Y12       B         ad_h<42>       U12       B       ad_h<43>       Y12       B         ad_h<44>       Y12       B       ad_h<45>       Y11       B         ad_h<44>       Y12       B       ad_h<45>       Y11       B         ad_h<48>       AA9       B       ad_h<49>         | ad_h<14> | AA11 | В             | ad_h<15> | AA10 | В    |
| ad_h<20>       V9       B       ad_h<21>       U9       B         ad_h<22>       W7       B       ad_h<23>       W8       B         ad_h<24>       V8       B       ad_h<25>       Y5       B         ad_h<26>       AA4       B       ad_h<27>       W5       B         ad_h<28>       AA3       B       ad_h<29>       AA2       B         ad_h<30>       U6       B       ad_h<31>       Y3       B         ad_h<32>       W17       B       ad_h<33>       AA18       B         ad_h<32>       W17       B       ad_h<35>       AA17       B         ad_h<36>       Y16       B       ad_h<37>       W15       B         ad_h<38>       AA16       B       ad_h<39>       AA15       B         ad_h<40>       Y14       B       ad_h<41>       W13       B         ad_h<42>       U12       B       ad_h<43>       V12       B         ad_h<44>       Y12       B       ad_h<45>       Y10       B         ad_h<46>       W10       B       ad_h<47>       Y10       B         ad_h<48>       AA9       B       ad_h<49>       | ad_h<16> | V10  | В             | ad_h<17> | U10  | В    |
| ad_h<22>       W7       B       ad_h<23>       W8       B         ad_h<24>       V8       B       ad_h<25>       Y5       B         ad_h<26>       AA4       B       ad_h<27>       W5       B         ad_h<28>       AA3       B       ad_h<29>       AA2       B         ad_h<30>       U6       B       ad_h<31>       Y3       B         ad_h<32>       W17       B       ad_h<33>       AA18       B         ad_h<32>       W17       B       ad_h<35>       AA17       B         ad_h<36>       Y16       B       ad_h<39>       AA15       B         ad_h<38>       AA16       B       ad_h<41>       W13       B         ad_h<40>       Y14       B       ad_h<43>       V12       B         ad_h<42>       U12       B       ad_h<43>       V12       B         ad_h<44>       Y12       B       ad_h<45>       Y11       B         ad_h<44>       M0       B       ad_h<47>       Y10       B         ad_h<48>       AA9       B       ad_h<49>       Y9       B                                                         | ad_h<18> | AA8  | В             | ad_h<19> | W9   | В    |
| ad_h<24>       V8       B       ad_h<25>       Y5       B         ad_h<26>       AA4       B       ad_h<27>       W5       B         ad_h<28>       AA3       B       ad_h<29>       AA2       B         ad_h<30>       U6       B       ad_h<31>       Y3       B         ad_h<32>       W17       B       ad_h<33>       AA18       B         ad_h<32>       W17       B       ad_h<35>       AA17       B         ad_h<36>       Y16       B       ad_h<37>       W15       B         ad_h<38>       AA16       B       ad_h<39>       AA15       B         ad_h<40>       Y14       B       ad_h<41>       W13       B         ad_h<42>       U12       B       ad_h<43>       V12       B         ad_h<44>       Y12       B       ad_h<45>       Y11       B         ad_h<48>       W10       B       ad_h<47>       Y10       B         ad_h<48>       AA9       B       ad_h<49>       Y9       B                                                                                                                          | ad_h<20> | V9   | В             | ad_h<21> | U9   | В    |
| ad_h<26>       AA4       B       ad_h<27>       W5       B         ad_h<28>       AA3       B       ad_h<29>       AA2       B         ad_h<30>       U6       B       ad_h<31>       Y3       B         ad_h<30>       U6       B       ad_h<31>       Y3       B         ad_h<32>       W17       B       ad_h<33>       AA18       B         ad_h<32>       Y17       B       ad_h<35>       AA17       B         ad_h<36>       Y16       B       ad_h<37>       W15       B         ad_h<38>       AA16       B       ad_h<39>       AA15       B         ad_h<40>       Y14       B       ad_h<41>       W13       B         ad_h<42>       U12       B       ad_h<43>       V12       B         ad_h<44>       Y12       B       ad_h<45>       Y11       B         ad_h<46>       W10       B       ad_h<47>       Y10       B         ad_h<48>       AA9       B       ad_h<49>       Y9       B                                                                                                                          | ad_h<22> | W7   | В             | ad_h<23> | W8   | В    |
| ad_h<28>       AA3       B       ad_h<29>       AA2       B         ad_h<30>       U6       B       ad_h<31>       Y3       B         ad_h<32>       W17       B       ad_h<33>       AA18       B         ad_h<32>       W17       B       ad_h<33>       AA18       B         ad_h<32>       Y17       B       ad_h<35>       AA17       B         ad_h<36>       Y16       B       ad_h<37>       W15       B         ad_h<38>       AA16       B       ad_h<39>       AA15       B         ad_h<40>       Y14       B       ad_h<41>       W13       B         ad_h<42>       U12       B       ad_h<43>       Y12       B         ad_h<44>       Y12       B       ad_h<45>       Y11       B         ad_h<46>       W10       B       ad_h<47>       Y10       B         ad_h<48>       AA9       B       ad_h<49>       Y9       B                                                                                                                                                                                          | ad_h<24> | V8   | В             | ad_h<25> | Y5   | В    |
| ad_h<30>       U6       B       ad_h<31>       Y3       B         ad_h<32>       W17       B       ad_h<33>       AA18       B         ad_h<32>       Y17       B       ad_h<35>       AA17       B         ad_h<36>       Y16       B       ad_h<37>       W15       B         ad_h<38>       AA16       B       ad_h<39>       AA15       B         ad_h<40>       Y14       B       ad_h<41>       W13       B         ad_h<42>       U12       B       ad_h<43>       V12       B         ad_h<44>       Y12       B       ad_h<45>       Y11       B         ad_h<46>       W10       B       ad_h<47>       Y10       B         ad_h<48>       AA9       B       ad_h<49>       Y9       B                                                                                                                                                                                                                                                                                                                                   | ad_h<26> | AA4  | В             | ad_h<27> | W5   | В    |
| ad_h<32>       W17       B       ad_h<33>       AA18       B         ad_h<34>       Y17       B       ad_h<35>       AA17       B         ad_h<36>       Y16       B       ad_h<35>       AA17       B         ad_h<36>       Y16       B       ad_h<37>       W15       B         ad_h<38>       AA16       B       ad_h<39>       AA15       B         ad_h<40>       Y14       B       ad_h<41>       W13       B         ad_h<42>       U12       B       ad_h<43>       V12       B         ad_h<44>       Y12       B       ad_h<45>       Y11       B         ad_h<46>       W10       B       ad_h<47>       Y10       B         ad_h<48>       AA9       B       ad_h<49>       Y9       B                                                                                                                                                                                                                                                                                                                                | ad_h<28> | AA3  | В             | ad_h<29> | AA2  | В    |
| ad_h<34>       Y17       B       ad_h<35>       AA17       B         ad_h<36>       Y16       B       ad_h<37>       W15       B         ad_h<38>       AA16       B       ad_h<39>       AA15       B         ad_h<40>       Y14       B       ad_h<41>       W13       B         ad_h<42>       U12       B       ad_h<43>       V12       B         ad_h<44>       Y12       B       ad_h<45>       Y11       B         ad_h<46>       W10       B       ad_h<47>       Y10       B         ad_h<48>       AA9       B       ad_h<49>       Y9       B                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | ad_h<30> | U6   | В             | ad_h<31> | Y3   | В    |
| ad_h<36>       Y16       B       ad_h<37>       W15       B         ad_h<38>       AA16       B       ad_h<39>       AA15       B         ad_h<40>       Y14       B       ad_h<41>       W13       B         ad_h<42>       U12       B       ad_h<43>       V12       B         ad_h<44>       Y12       B       ad_h<45>       Y11       B         ad_h<46>       W10       B       ad_h<47>       Y10       B         ad_h<48>       AA9       B       ad_h<49>       Y9       B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | ad_h<32> | W17  | В             | ad_h<33> | AA18 | В    |
| ad_h<38>       AA16       B       ad_h<39>       AA15       B         ad_h<40>       Y14       B       ad_h<41>       W13       B         ad_h<42>       U12       B       ad_h<43>       V12       B         ad_h<44>       Y12       B       ad_h<45>       Y11       B         ad_h<46>       W10       B       ad_h<47>       Y10       B         ad_h<48>       AA9       B       ad_h<49>       Y9       B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ad_h<34> | Y17  | В             | ad_h<35> | AA17 | В    |
| ad_h<40>     Y14     B     ad_h<41>     W13     B       ad_h<42>     U12     B     ad_h<43>     V12     B       ad_h<44>     Y12     B     ad_h<45>     Y11     B       ad_h<46>     W10     B     ad_h<47>     Y10     B       ad_h<48>     AA9     B     ad_h<49>     Y9     B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ad_h<36> | Y16  | В             | ad_h<37> | W15  | В    |
| ad_h<42>       U12       B       ad_h<43>       V12       B         ad_h<44>       Y12       B       ad_h<45>       Y11       B         ad_h<46>       W10       B       ad_h<47>       Y10       B         ad_h<48>       AA9       B       ad_h<49>       Y9       B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | ad_h<38> | AA16 | В             | ad_h<39> | AA15 | В    |
| ad_h<44>     Y12     B     ad_h<45>     Y11     B       ad_h<46>     W10     B     ad_h<47>     Y10     B       ad_h<48>     AA9     B     ad_h<49>     Y9     B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ad_h<40> | Y14  | В             | ad_h<41> | W13  | В    |
| ad_h<46>         W10         B         ad_h<47>         Y10         B           ad_h<48>         AA9         B         ad_h<49>         Y9         B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | ad_h<42> | U12  | В             | ad_h<43> | V12  | В    |
| ad_h<48> AA9 B ad_h<49> Y9 B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ad_h<44> | Y12  | В             | ad_h<45> | Y11  | В    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | ad_h<46> | W10  | В             | ad_h<47> | Y10  | В    |
| <b>ad_h&lt;50&gt;</b> Y8 B <b>ad_h&lt;51&gt;</b> AA7 B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | ad_h<48> | AA9  | В             | ad_h<49> | Y9   | В    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | ad_h<50> | Y8   | В             | ad_h<51> | AA7  | В    |

Table 2–8 DECchip 21171-CA Pin Names (Alphabetic)

| Table 2-0 (Conc.) Decchip 21171-CA Fin Names (Alphabetic) |           |      |                  |      |      |  |
|-----------------------------------------------------------|-----------|------|------------------|------|------|--|
| Pin Name                                                  | Pin       | Туре | Pin Name         | Pin  | Туре |  |
| ad_h<52>                                                  | Y7        | В    | ad_h<53>         | AA6  | В    |  |
| ad_h<54>                                                  | Y6        | В    | ad_h<55>         | AA5  | В    |  |
| ad_h<56>                                                  | W6        | В    | ad_h<57>         | U8   | В    |  |
| ad_h<58>                                                  | V7        | В    | ad_h<59>         | Y4   | В    |  |
| ad_h<60>                                                  | U7        | В    | ad_h<61>         | V6   | В    |  |
| ad_h<62>                                                  | <b>T6</b> | В    | ad_h<63>         | Y2   | В    |  |
| addr_h<4>                                                 | N18       | В    | addr_h<5>        | R21  | В    |  |
| addr_h<6>                                                 | R20       | В    | addr_h<7>        | T21  | В    |  |
| addr_h<8>                                                 | N17       | В    | addr_h<9>        | R19  | В    |  |
| addr_h<10>                                                | P19       | В    | addr_h<11>       | T20  | В    |  |
| addr_h<12>                                                | P18       | В    | addr_h<13>       | U21  | В    |  |
| addr_h<14>                                                | T19       | В    | addr_h<15>       | U20  | В    |  |
| addr_h<16>                                                | P17       | В    | addr_h<17>       | V21  | В    |  |
| addr_h<18>                                                | R18       | В    | addr_h<19>       | U19  | В    |  |
| addr_h<20>                                                | V20       | В    | addr_h<21>       | R17  | В    |  |
| addr_h<22>                                                | W21       | В    | addr_h<23>       | T18  | В    |  |
| addr_h<24>                                                | V19       | В    | addr_h<25>       | W20  | В    |  |
| addr_h<26>                                                | V26       | В    | addr_h<27>       | T17  | В    |  |
| addr_h<28>                                                | Y20       | В    | addr_h<29>       | U18  | В    |  |
| addr_h<30>                                                | U17       | В    | addr_h<31>       | E16  | В    |  |
| addr_h<32>                                                | B19       | В    | addr_h<33>       | F15  | В    |  |
| addr_h<34>                                                | C18       | В    | addr_h<39>       | D17  | В    |  |
| addr_bus_req_h                                            | D18       | В    | addr_cmd_par_h   | E15  | В    |  |
| addr_res_h<0>                                             | D10       | Ι    | addr_res_h<1>    | B11  | Ι    |  |
| aux_vdd_h                                                 | C4        | Р    | aux_vss_h        | D5   | Р    |  |
| cack_h                                                    | B21       | 0    | —                |      | —    |  |
| cas_h<0>                                                  | G19       | 0    | cas_h<1>         | F21  | 0    |  |
| cas_h<2>                                                  | H19       | 0    | cas_h<3>         | G20  | 0    |  |
| cbe_l<0>                                                  | AA19      | В    | cbe_l<1>         | AA20 | В    |  |
| cbe_l<2>                                                  | Y21       | В    | cbe_l<3>         | W18  | В    |  |
| cbe_l<4>                                                  | W2        | В    | cbe_l<5>         | T5   | В    |  |
| cbe_l<6>                                                  | V3        | В    | <b>cbe_l</b> <7> | U4   | В    |  |

Table 2–8 (Cont.) DECchip 21171-CA Pin Names (Alphabetic)

| Pin Name     | Pin  | Туре | Pin Name   | Pin  | Туре |
|--------------|------|------|------------|------|------|
| cmc_h<0>     | D14  | 0    | cmc_h<1>   | B16  | 0    |
| cmc_h<2>     | C15  | 0    | cmc_h<3>   | B15  | 0    |
| cmc_h<4>     | E13  | 0    | cmc_h<5>   | C14  | 0    |
| cmc_h<6>     | F12  | 0    | cmc_h<7>   | D13  | 0    |
| cmc_h<8>     | B14  | 0    | —          | —    | —    |
| cmd_h<0>     | B18  | В    | cmd_h<1>   | F14  | В    |
| cmd_h<2>     | C17  | В    | cmd_h<3>   | D16  | В    |
| count_out_h  | R6   | 0    | dack_h     | F16  | 0    |
| debug_h<0>   | T3   | Ι    | debug_h<1> | V5   | Ι    |
| devsel_l     | V17  | В    | error_h    | P5   | 0    |
| fill_error_h | M17  | 0    | fill_h     | C19  | 0    |
| fill_id_h    | P20  | В    | frame_l    | V18  | В    |
| GND          | A2   | Р    | GND        | A4   | Р    |
| GND          | A5   | Р    | GND        | A6   | Р    |
| GND          | A8   | Р    | GND        | A10  | Р    |
| GND          | A12  | Р    | GND        | A14  | Р    |
| GND          | A16  | Р    | GND        | A17  | Р    |
| GND          | A18  | Р    | GND        | A20  | Р    |
| GND          | A21  | Р    | GND        | B1   | Р    |
| GND          | C22  | Р    | GND        | D1   | Р    |
| GND          | D19  | Р    | GND        | E22  | Р    |
| GND          | F1   | Р    | GND        | F22  | Р    |
| GND          | G1   | Р    | GND        | G22  | Р    |
| GND          | J1   | Р    | GND        | J22  | Р    |
| GND          | K1   | Р    | GND        | M1   | Р    |
| GND          | M22  | Р    | GND        | N22  | Р    |
| GND          | P1   | Р    | GND        | R22  | Р    |
| GND          | T1   | Р    | GND        | U1   | Р    |
| GND          | U22  | Р    | GND        | V1   | Р    |
| GND          | W4   | Р    | GND        | W19  | Р    |
| GND          | W22  | Р    | GND        | Y1   | Р    |
| GND          | AA22 | Р    | GND        | AB2  | Р    |
| GND          | AB3  | Р    | GND        | AB5  | Р    |
| GND          | AB7  | Р    | GND        | AB9  | Р    |
| GND          | AB12 | Р    | GND        | AB13 | Р    |
| GND          | AB15 | Р    | GND        | AB17 | Р    |

Table 2–8 (Cont.) DECchip 21171-CA Pin Names (Alphabetic)

| Pin Name             | Pin  | Туре | Pin Name             | Pin  | Туре |
|----------------------|------|------|----------------------|------|------|
| GND                  | AB18 | Р    | GND                  | AB19 | Р    |
| GND                  | AB21 | Р    | _                    | —    | —    |
| gnt_l                | U3   | Ι    | _                    | _    | _    |
| gru_ack_h (Reserved) | L6   | I    | gru_sel_h (Reserved) | L5   | 0    |
| idle_bc_h            | B20  | 0    | int_h                | L17  | 0    |
| int4_valid_h<0>      | E14  | Ι    | int4_valid_h<1>      | C16  | Ι    |
| int4_valid_h<2>      | F13  | Ι    | int4_valid_h<3>      | D15  | Ι    |
| ioc_h<0>             | E12  | 0    | ioc_h<1>             | C13  | 0    |
| ioc_h<2>             | D12  | 0    | ioc_h<3>             | B13  | 0    |
| ioc_h<4>             | C12  | 0    | ioc_h<5>             | B12  | 0    |
| ioc_h<6>             | C11  | 0    | _                    | —    | —    |
| iod_h<0>             | B10  | В    | iod_h<1>             | C10  | В    |
| iod_h<2>             | E10  | В    | iod_h<3>             | B9   | В    |
| iod_h<4>             | F10  | В    | iod_h<5>             | C9   | В    |
| iod_h<6>             | B8   | В    | iod_h<7>             | C8   | В    |
| iod_h<8>             | D9   | В    | iod_h<9>             | B7   | В    |
| iod_h<10>            | E9   | В    | iod_h<11>            | C7   | В    |
| iod_h<12>            | D8   | В    | iod_h<13>            | B6   | В    |
| iod_h<14>            | D7   | В    | iod_h<15>            | C6   | В    |
| iod_h<16>            | F9   | В    | iod_h<17>            | B5   | В    |
| iod_h<18>            | E8   | В    | iod_h<19>            | D6   | В    |
| iod_h<20>            | C5   | В    | iod_h<21>            | E7   | В    |
| iod_h<22>            | B4   | В    | iod_h<23>            | F8   | В    |
| iod_h<24>            | N4   | В    | iod_h<25>            | P3   | В    |
| iod_h<26>            | P4   | В    | iod_h<27>            | N6   | В    |
| iod_h<28>            | T2   | В    | iod_h<29>            | N5   | В    |
| iod_h<30>            | M4   | В    | iod_h<31>            | F6   | В    |
| iod_h<32>            | D3   | В    | iod_h<33>            | E4   | В    |
| iod_h<34>            | G5   | В    | iod_h<35>            | D2   | В    |
| iod_h<36>            | H6   | В    | iod_h<37>            | E3   | В    |
| iod_h<38>            | F4   | В    | iod_h<39>            | H5   | В    |
| iod_h<40>            | E2   | В    | iod_h<41>            | H4   | В    |
| iod_h<42>            | F3   | В    | iod_h<43>            | G4   | В    |
| iod_h<44>            | F2   | В    | iod_h<45>            | J6   | В    |
| iod_h<46>            | G3   | В    | iod_h<47>            | J5   | В    |

# Table 2–8 (Cont.) DECchip 21171-CA Pin Names (Alphabetic)

| Pin Name       | Pin | Туре | Pin Name       | Pin  | Туре |
|----------------|-----|------|----------------|------|------|
| iod_h<48>      | G2  | В    | iod_h<49>      | J4   | В    |
| iod_h<50>      | H3  | В    | iod_h<51>      | H2   | В    |
| iod_h<52>      | J3  | В    | iod_h<53>      | K6   | В    |
| iod_h<54>      | J2  | В    | iod_h<55>      | K5   | В    |
| iod_h<56>      | K3  | В    | iod_h<57>      | K2   | В    |
| iod_h<58>      | K4  | В    | iod_h<59>      | L2   | В    |
| iod_h<60>      | L3  | В    | iod_h<61>      | M2   | В    |
| iod_h<62>      | M3  | В    | iod_h<63>      | N2   | В    |
| iod_e_h<0>     | F5  | В    | iod_e_h<1>     | C3   | В    |
| iod_e_h<2>     | G6  | В    | iod_e_h<3>     | C2   | В    |
| iod_e_h<4>     | M5  | В    | iod_e_h<5>     | N3   | В    |
| iod_e_h<6>     | M6  | В    | iod_e_h<7>     | P2   | В    |
| irdy_l         | V11 | В    | lock_l         | U15  | Ι    |
| mem_ack_l      | R4  | 0    | _              |      | _    |
| mem_addr_h<0>  | J20 | 0    | mem_addr_h<1>  | K17  | 0    |
| mem_addr_h<2>  | J21 | 0    | mem_addr_h<3>  | K18  | 0    |
| mem_addr_h<4>  | K20 | 0    | mem_addr_h<5>  | K21  | 0    |
| mem_addr_h<6>  | K19 | 0    | mem_addr_h<7>  | L21  | 0    |
| mem_addr_h<8>  | L20 | 0    | mem_addr_h<9>  | M21  | 0    |
| mem_addr_h<10> | M20 | 0    | mem_addr_h<11> | N21  | 0    |
| mem_addr_h<12> | M19 | 0    | —              | —    | —    |
| mem_cs_l       | U2  | Ι    | mem_en_h       | H21  | 0    |
| mem_req_l      | T4  | Ι    | mem_we_l<0>    | N20  | 0    |
| mem_we_l<1>    | M18 | 0    | par_h          | R5   | В    |
| par64_h        | V2  | В    | perr_l         | AA21 | В    |
| pll_agnd_h     | E6  | 0    | pll_clk_h      | F11  | Ι    |
| pll_test_h<0>  | E18 | Ι    | pll_test_h<1>  | L4   | Ι    |
| pll_test_h<2>  | R2  | Ι    | pll_test_h<3>  | R3   | Ι    |
| pll_lp1_h      | B3  | Ι    | pll_lp2_h      | F7   | Р    |
| pll_vdd_h      | E5  | Р    | pll_vss_h      | D4   | Ι    |
| PWR5           | A3  | Р    | PWR5           | A7   | Р    |
| PWR5           | A9  | Р    | PWR5           | A11  | Р    |
| PWR5           | A13 | Р    | PWR5           | A15  | Р    |
| PWR5           | A19 | Р    | PWR5           | A22  | Р    |

Table 2–8 (Cont.) DECchip 21171-CA Pin Names (Alphabetic)

| Pin Name       | Pin     | Туре | Pin Name           | Pin  | Туре |
|----------------|---------|------|--------------------|------|------|
| PWR5           | B2      | Р    | PWR5               | B22  | Р    |
| PWR5           | C1      | Р    | PWR5               | D22  | Р    |
| PWR5           | E1      | Р    | PWR5               | H1   | Р    |
| PWR5           | H22     | Р    | PWR5               | K22  | Р    |
| PWR5           | L1      | Р    | PWR5               | L22  | Р    |
| PWR5           | N1      | Р    | PWR5               | P22  | Р    |
| PWR5           | R1      | Р    | PWR5               | T22  | Р    |
| PWR5           | V22     | Р    | PWR5               | W1   | Р    |
| PWR5           | Y22     | Р    | PWR5               | AA1  | Р    |
| PWR5           | AB1     | Р    | PWR5               | AB4  | Р    |
| PWR5           | AB6     | Р    | PWR5               | AB8  | Р    |
| PWR5           | AB10    | Р    | PWR5               | AB11 | Р    |
| PWR5           | AB14    | Р    | PWR5               | AB16 | Р    |
| PWR5           | AB20    | Р    | PWR5               | AB22 | Р    |
| nog han        | J18     | 0    | noo hats           | G21  | 0    |
| ras_h<0>       |         |      | ras_h<1>           |      |      |
| ras_h<2>       | J19     | 0    | ras_h<3>           | H20  | 0    |
| req_l          | P6      | 0    | req64_l            | V4   | В    |
| rst_l          | U16     | 0    | scan_in_h          | L19  | Ι    |
| serr_l         | W3      | В    | —                  | —    | _    |
| set_sel_h<0>   | F17     | 0    | set_sel_h<1>       | G17  | 0    |
| set_sel_h<2>   | C20     | 0    | set_sel_h<3>       | F18  | 0    |
| set_sel_h<4>   | C21     | 0    | set_sel_h<5>       | D20  | 0    |
| set sel h<6>   | E19     | 0    | set sel h<7>       | H17  | 0    |
| set_sel_h<8>   | D21     | 0    | set_sel_h<9>       | G18  | Ő    |
| set_sel_h<10>  | E20     | 0    | set_sel_h<11>      | F19  | Ő    |
| set_sel_h<12>  | H18     | 0    | set_sel_h<13>      | E21  | Õ    |
| set_sel_h<14>  | J17     | 0    | set_sel_h<15>      | F20  | 0    |
|                | T 1 1 1 | т    | aton 1             | V10  | р    |
| spare1         | U11     | I    | stop_l             | Y19  | B    |
| sys_rst_l      | L18     | I    | tag_ctl_par_h      | P21  | 0    |
| tag_dirty_h    | N19     | 0    | test_mode_h<0>     | E11  | I    |
| test_mode_h<1> | D11     | I    | test_or_scan_out_h | E17  | 0    |
| trdy_l         | W11     | В    | victim_pending_h   | B17  | Ι    |

Table 2–8 (Cont.) DECchip 21171-CA Pin Names (Alphabetic)

# 2.2.10 DECchip 21171-CA Pin Assignment List (Alphanumeric)

Table 2–9 lists the DECchip 21171-CA pins in alphanumeric order. The following abbreviations are used in the Type column of the table:

- B = Bidirectional
- I = Input
- P = Power
- O = Output

| Pin | Pin Name         | Туре | Pin | Pin Name   | Туре |
|-----|------------------|------|-----|------------|------|
| _   | _                | _    | A2  | GND        | Р    |
| A3  | PWR5             | Р    | A4  | GND        | Р    |
| A5  | GND              | Р    | A6  | GND        | Р    |
| A7  | PWR5             | Р    | A8  | GND        | Р    |
| A9  | PWR5             | Р    | A10 | GND        | Р    |
| A11 | PWR5             | Р    | A12 | GND        | Р    |
| A13 | PWR5             | Р    | A14 | GND        | Р    |
| A15 | PWR5             | Р    | A16 | GND        | Р    |
| A17 | GND              | Р    | A18 | GND        | Р    |
| A19 | PWR5             | Р    | A20 | GND        | Р    |
| A21 | GND              | Р    | A22 | PWR5       | Р    |
| B1  | GND              | Р    | B2  | PWR5       | Р    |
| B3  | pll_lp1_h        | Ι    | B4  | iod_h<22>  | В    |
| B5  | iod_h<17>        | В    | B6  | iod_h<13>  | В    |
| B7  | iod_h<9>         | В    | B8  | iod_h<6>   | В    |
| B9  | iod_h<3>         | В    | B10 | iod_h<0>   | В    |
| B11 | addr_res_h<1>    | Ι    | B12 | ioc_h<5>   | 0    |
| B13 | ioc_h<3>         | 0    | B14 | cmc_h<8>   | 0    |
| B15 | cmc_h<3>         | 0    | B16 | cmc_h<1>   | 0    |
| B17 | victim_pending_h | Ι    | B18 | cmd_h<0>   | В    |
| B19 | addr_h<32>       | В    | B20 | idle_bc_h  | 0    |
| B21 | cack_h           | 0    | B22 | PWR5       | Р    |
| C1  | PWR5             | Р    | C2  | iod_e_h<3> | В    |
| C3  | iod_e_h<1>       | В    | C4  | aux_vdd    | Р    |
| C5  | iod_h<20>        | В    | C6  | iod_h<15>  | В    |
| C7  |                  | В    | C8  | iod_h<7>   | В    |

#### Table 2–9 DECchip 21171-CA Pin Assignment (Alphanumeric)

| Pin | Pin Name                      | Туре | Pin | Pin Name        | Туре |
|-----|-------------------------------|------|-----|-----------------|------|
| C9  | iod_h<5>                      | В    | C10 | iod_h<1>        | В    |
| C11 | ioc_h<6>                      | 0    | C12 | ioc_h<4>        | 0    |
| C13 | ioc_h<1>                      | 0    | C14 | cmc_h<5>        | 0    |
| C15 | cmc_h<2>                      | 0    | C16 | int4_valid_h<1> | Ι    |
| C17 | cmd_h<2>                      | В    | C18 | addr_h<34>      | В    |
| C19 | fill_h                        | 0    | C20 | set_sel_h<2>    | 0    |
| C21 | set_sel_h<4>                  | 0    | C22 | GND             | Р    |
| D1  | GND                           | Р    | D2  | iod_h<35>       | В    |
| D3  | iod_h<32>                     | В    | D4  | pll_vss_h       | Ι    |
| D5  | aux_vss                       | Р    | D6  | iod_h<19>       | В    |
| D7  | iod_h<14>                     | В    | D8  | iod_h<12>       | В    |
| D9  | iod_h<8>                      | В    | D10 | addr_res_h<0>   | Ι    |
| D11 | test_mode_h<1>                | Ι    | D12 | ioc_h<2>        | 0    |
| D13 | cmc_h<7>                      | 0    | D14 | cmc_h<0>        | 0    |
| D15 | int4_valid_h<3>               | Ι    | D16 | cmd_h<3>        | В    |
| D17 | addr_h<39>                    | В    | D18 | addr_bus_req    | В    |
| D19 | GND                           | Р    | D20 |                 | 0    |
| D21 | <pre>set_sel_h&lt;8&gt;</pre> | 0    | D22 | PWR5            | Р    |
| E1  | PWR5                          | Р    | E2  | iod_h<40>       | В    |
| E3  | iod_h<37>                     | В    | E4  | iod_h<33>       | В    |
| E5  | pll_vdd                       | Р    | E6  | pll_agnd_h      | 0    |
| E7  |                               | В    | E8  | iod_h<18>       | В    |
| E9  | iod_h<10>                     | В    | E10 | iod_h<2>        | В    |
| E11 | test_mode_h<0>                | Ι    | E12 | ioc_h<0>        | 0    |
| E13 | cmc_h<4>                      | 0    | E14 | int4_valid_h<0> | Ι    |
| E15 | addr_cmd_par                  | В    | E16 | addr_h<31>      | В    |
| E17 | test_or_scan_out_h            | 0    | E18 | pll_test_h<0>   | Ι    |
| E19 | set_sel_h<6>                  | 0    | E20 | set_sel_h<10>   | 0    |
| E21 | set_sel_h<13>                 | 0    | E22 | GND             | Р    |
| F1  | GND                           | Р    | F2  | iod_h<44>       | В    |
| F3  | iod_h<42>                     | В    | F4  | iod_h<38>       | В    |
| F5  | iod_e_h<0>                    | В    | F6  | iod_h<31>       | В    |
| F7  | pll_lp2_h                     | Р    | F8  | iod_h<23>       | В    |
| F9  | iod_h<16>                     | В    | F10 | iod_h<4>        | В    |
| F11 | _<br>pll_clk_h                | Ι    | F12 |                 | 0    |
| F13 | int4_valid_h<2>               | Ι    | F14 | cmd_h<1>        | В    |

# Table 2–9 (Cont.) DECchip 21171-CA Pin Assignment (Alphanumeric)

| Pin F       | Pin Name             | Туре | Pin | Pin Name             | Туре |
|-------------|----------------------|------|-----|----------------------|------|
| F15 a       | nddr_h<33>           | В    | F16 | dack_h               | 0    |
| F17 s       | set_sel_h<0>         | 0    | F18 | set_sel_h<3>         | 0    |
| F19 s       | et_sel_h<11>         | 0    | F20 | set_sel_h<15>        | 0    |
| F21 c       | cas_h<1>             | 0    | F22 | GND                  | Р    |
| G1 <b>(</b> | GND                  | Р    | G2  | iod_h<48>            | в    |
| G3 i        | od_h<46>             | В    | G4  | iod_h<43>            | в    |
| G5 i        | od_h<34>             | В    | G6  | iod_e_h<2>           | В    |
| G17 s       | set_sel_h<1>         | 0    | G18 | set_sel_h<9>         | 0    |
| G19 c       | cas_h<0>             | 0    | G20 | cas_h<3>             | 0    |
| G21 r       | ras_h<1>             | 0    | G22 | GND                  | Р    |
| H1 <b>I</b> | PWR5                 | Р    | H2  | iod_h<51>            | В    |
| H3 i        | od_h<50>             | В    | H4  | iod_h<41>            | В    |
| H5 i        | od_h<39>             | В    | H6  | iod_h<36>            | в    |
| H17 s       | set_sel_h<7>         | 0    | H18 | set_sel_h<12>        | 0    |
| H19 c       | cas_h<2>             | 0    | H20 | ras_h<3>             | 0    |
| H21 r       | nem_en_h             | 0    | H22 | PWR5                 | Р    |
| J1 <b>(</b> | GND                  | Р    | J2  | iod_h<54>            | В    |
| J3 i        | od_h<52>             | В    | J4  | iod_h<49>            | В    |
|             | od_h<47>             | В    | J6  | iod_h<45>            | в    |
|             | set_sel_h<14>        | 0    | J18 | ras_h<0>             | 0    |
|             | ras_h<2>             | 0    | J20 | mem_addr_h<0>        | 0    |
| J21 r       | nem_addr_h<2>        | 0    | J22 | GND                  | Р    |
|             | GND                  | Р    | K2  | iod_h<57>            | В    |
|             | od_h<56>             | В    | K4  | iod_h<58>            | в    |
|             | od_h<55>             | В    | K6  | iod_h<53>            | В    |
|             | nem_addr_h<1>        | 0    | K18 | mem_addr_h<3>        | 0    |
|             | nem_addr_h<6>        | 0    | K20 | mem_addr_h<4>        | 0    |
| K21 r       | nem_addr_h<5>        | 0    | K22 | PWR5                 | Р    |
|             | PWR5                 | Р    | L2  | iod_h<59>            | В    |
|             | od_h<60>             | В    | L4  | pll_test_h<1>        | Ι    |
|             | gru_sel_h (Reserved) | 0    | L6  | gru_ack_h (Reserved) | Ι    |
|             | nt_h                 | 0    | L18 | sys_rst_l            | Ι    |
|             | scan_in_h            | Ι    | L20 | mem_addr_h<8>        | 0    |
| L21 r       | nem_addr_h<7>        | 0    | L22 | PWR5                 | Р    |

Table 2–9 (Cont.) DECchip 21171-CA Pin Assignment (Alphanumeric)

| Pin | Pin Name       | Туре | Pin       | Pin Name         | Туре |
|-----|----------------|------|-----------|------------------|------|
| M1  | GND            | Р    | M2        | iod_h<61>        | В    |
| M3  | iod h<62>      | B    | M4        | iod h<30>        | B    |
| M5  | iod_e_h<4>     | B    | M6        | iod_e_h<6>       | B    |
| M17 | fill_error_h   | 0    | M18       | mem_we_l<1>      | 0    |
| M19 | mem_addr_h<12> | 0    | M20       | mem_addr_h<10>   | 0    |
| M21 | mem_addr_h<9>  | 0    | M22       | GND              | Р    |
| N1  | PWR5           | Р    | N2        | iod_h<63>        | В    |
| N3  | iod_e_h<5>     | В    | N4        | iod_h<24>        | В    |
| N5  | iod_h<29>      | В    | N6        | iod_h<27>        | В    |
| N17 | addr_h<8>      | В    | N18       | addr_h<4>        | В    |
| N19 | tag_dirty_h    | 0    | N20       | mem_we_l<0>      | 0    |
| N21 | mem_addr_h<11> | 0    | N22       | GND              | Р    |
| P1  | GND            | Р    | P2        | iod_e_h<7>       | В    |
| 23  | iod_h<25>      | В    | P4        | iod_h<26>        | В    |
| 25  | error_h        | 0    | P6        | req_l            | 0    |
| P17 | addr_h<16>     | В    | P18       | addr_h<12>       | В    |
| P19 | addr_h<10>     | В    | P20       | fill_id_h        | В    |
| P21 | tag_ctl_par_h  | 0    | P22       | PWR5             | Р    |
| R1  | PWR5           | Р    | R2        | pll_test_h<2>    | Ι    |
| R3  | pll_test_h<3>  | I    | R4        | mem_ack_l        | 0    |
| R5  | par_h          | В    | R6        | count_out_h      | 0    |
| R17 | addr_h<21>     | В    | R18       | addr_h<18>       | В    |
| R19 | addr_h<9>      | В    | R20       | addr_h<6>        | В    |
| R21 | addr_h<5>      | В    | R22       | GND              | Р    |
| Г1  | GND            | Р    | T2        | iod_h<28>        | В    |
| Г3  | debug_h<0>     | Ι    | T4        | mem_req_l        | Ι    |
| Г5  | cbe_l<5>       | В    | <b>T6</b> | ad_h<62>         | В    |
| Г17 | addr_h<27>     | В    | T18       | addr_h<23>       | В    |
| Г19 | addr_h<14>     | В    | T20       | addr_h<11>       | В    |
| Г21 | addr_h<7>      | В    | T22       | PWR5             | Р    |
| U1  | GND            | Р    | U2        | mem_cs_l         | Ι    |
| U3  | gnt_l          | Ι    | U4        | <b>cbe_l</b> <7> | В    |
| U5  | ack64_l        | В    | U6        | ad_h<30>         | В    |

# Table 2–9 (Cont.) DECchip 21171-CA Pin Assignment (Alphanumeric)

| Pin         | Pin Name   | Туре | Pin | Pin Name   | Туре |
|-------------|------------|------|-----|------------|------|
| U7          | ad_h<60>   | В    | U8  | ad_h<57>   | В    |
| J <b>9</b>  | ad_h<21>   | В    | U10 | ad_h<17>   | В    |
| J <b>11</b> | spare1     | Ι    | U12 | ad_h<42>   | В    |
| J <b>13</b> | ad_h<6>    | В    | U14 | ad_h<2>    | В    |
| J <b>15</b> | lock_l     | Ι    | U16 | rst_l      | 0    |
| J <b>17</b> | addr_h<30> | В    | U18 | addr_h<29> | В    |
| J19         | addr_h<19> | В    | U20 | addr_h<15> | В    |
| J <b>21</b> | addr_h<13> | В    | U22 | GND        | Р    |
| /1          | GND        | Р    | V2  | par64      | В    |
| /3          | cbe_l<6>   | В    | V4  | req64_l    | В    |
| /5          | debug_h<1> | Ι    | V6  | ad_h<61>   | В    |
| 7           | ad_h<58>   | В    | V8  | ad_h<24>   | В    |
| /9          | ad_h<20>   | В    | V10 | ad_h<16>   | В    |
| /11         | irdy_l     | В    | V12 | ad_h<43>   | В    |
| /13         | ad_h<8>    | В    | V14 | ad_h<4>    | В    |
| /15         | ad_h<1>    | В    | V16 | addr_h<26> | В    |
| /17         | devsel_l   | В    | V18 | frame_l    | В    |
| /19         | addr_h<24> | В    | V20 | addr_h<20> | В    |
| /21         | addr_h<17> | В    | V22 | PWR5       | Р    |
| V1          | PWR5       | Р    | W2  | cbe_l<4>   | В    |
| V3          | serr_l     | В    | W4  | GND        | Р    |
| V5          | ad_h<27>   | В    | W6  | ad_h<56>   | В    |
| V7          | ad_h<22>   | В    | W8  | ad_h<23>   | В    |
| V9          | ad_h<19>   | В    | W10 | ad_h<46>   | В    |
| V11         | trdy_l     | В    | W12 | ad_h<9>    | В    |
| V13         | ad_h<41>   | В    | W14 | ad_h<5>    | В    |
| V15         | ad_h<37>   | В    | W16 | ad_h<3>    | В    |
| V17         | ad_h<32>   | В    | W18 | cbe_l<3>   | В    |
| V19         | GND        | Р    | W20 | addr_h<25> | В    |
| V21         | addr_h<22> | В    | W22 | GND        | Р    |
| /1          | GND        | Р    | Y2  | ad_h<63>   | В    |
| (3          | ad_h<31>   | В    | Y4  | ad_h<59>   | В    |
| (5          | ad_h<25>   | В    | Y6  | ad_h<54>   | В    |
| 7           | ad_h<52>   | В    | Y8  | ad_h<50>   | В    |
| <b>/9</b>   | ad_h<49>   | В    | Y10 | ad_h<47>   | В    |
| /11         | ad_h<45>   | В    | Y12 | ad_h<44>   | В    |

Table 2–9 (Cont.) DECchip 21171-CA Pin Assignment (Alphanumeric)

| Pin | Pin Name | Туре | Pin  | Pin Name   | Туре |
|-----|----------|------|------|------------|------|
| Y13 | ad_h<11> | В    | Y14  | ad_h<40>   | В    |
| Y15 | ad_h<7>  | В    | Y16  | ad_h<36>   | В    |
| (17 | ad_h<34> | В    | Y18  | ad_h<0>    | В    |
| ¥19 | stop_l   | В    | Y20  | addr_h<28> | В    |
| 21  | cbe_l<2> | В    | Y22  | PWR5       | Р    |
| AA1 | PWR5     | Р    | AA2  | ad_h<29>   | В    |
| AA3 | ad_h<28> | В    | AA4  | ad_h<26>   | В    |
| AA5 | ad_h<55> | В    | AA6  | ad_h<53>   | В    |
| AA7 | ad_h<51> | В    | AA8  | ad_h<18>   | В    |
| A9  | ad_h<48> | В    | AA10 | ad_h<15>   | В    |
| A11 | ad_h<14> | В    | AA12 | ad_h<13>   | В    |
| A13 | ad_h<12> | В    | AA14 | ad_h<10>   | В    |
| A15 | ad_h<39> | В    | AA16 | ad_h<38>   | В    |
| A17 | ad_h<35> | В    | AA18 | ad_h<33>   | В    |
| A19 | cbe_l<0> | В    | AA20 | cbe_l<1>   | В    |
| A21 | perr_l   | В    | AA22 | GND        | Р    |
| B1  | PWR5     | Р    | AB2  | GND        | Р    |
| B3  | GND      | Р    | AB4  | PWR5       | Р    |
| B5  | GND      | Р    | AB6  | PWR5       | Р    |
| B7  | GND      | Р    | AB8  | PWR5       | Р    |
| AB9 | GND      | Р    | AB10 | PWR5       | Р    |
| B11 | PWR5     | Р    | AB12 | GND        | Р    |
| B13 | GND      | Р    | AB14 | PWR5       | Р    |
| B15 | GND      | Р    | AB16 | PWR5       | Р    |
| B17 | GND      | Р    | AB18 | GND        | Р    |
| B19 | GND      | Р    | AB20 | PWR5       | Р    |
| B21 | GND      | Р    | AB22 | PWR5       | Р    |

Table 2–9 (Cont.) DECchip 21171-CA Pin Assignment (Alphanumeric)

# 2.3 DECchip 21171-CA Mechanical Specifications

Figure 2–1 and Table 2–10 indicate the DECchip 21171-CA package dimensions.

DECchip 21171-CA Pin Descriptions 2.3 DECchip 21171-CA Mechanical Specifications



#### Figure 2–1 DECchip 21171-CA Package Dimensions

LJ-04217.AI

### Notes for Figure 2–1

The following notes apply to Figure 2–1:

Note 1. Chip capacitors envelope. Commercial grade chip caps; nominal capacitance 0.082  $\mu F$ .

- Note 2. Envelope for maximum lid (ceramic, epoxy seal).
- Note 3. Envelope for integral heat slug.

Note 4. The drawing/dimensions are for reference only. For board layout, request an engineering drawing from Digital Semiconductor.

# DECchip 21171-CA Pin Descriptions 2.3 DECchip 21171-CA Mechanical Specifications

| Indicator | Minimum             | Maximum             |
|-----------|---------------------|---------------------|
| A         | 1.78 mm (0.070 in)  | 3.30mm (0.130 in)   |
| A1        | $NA^1$              | 4.19 mm (0.165 in)  |
| A2        | NA                  | 1.27 mm (0.050 in)  |
| В         | 0.40 mm (0.016 in)  | 0.51 mm (0.020 in)  |
| B1        | 1.17 mm (0.046 in)  | 1.37 mm (0.054 in)  |
| D         | 57.30 mm (2.256 in) | 57.51 mm (2.264 in) |
| D1        | NA                  | 24.89 mm (0.980 in) |
| D2        | NA                  | 24.13 mm (0.950 in) |
| Е         | 57.30 mm (2.256 in) | 57.51 mm (2.264 in) |
| E1        | NA                  | 24.89 mm (0.980 in) |
| E2        | NA                  | 24.13 mm (0.950 in) |
| G         | 1.78 mm (0.070 in)  | 2.04 mm (0.080 in)  |
| Н         | NA                  | 3.56 mm (0.140 in)  |
| Ι         | NA                  | 4.06 mm (0.160 in)  |
| J         | NA                  | 1.65 mm (0.064 in)  |
| L         | 4.06 mm (0.160 in)  | 4.57 mm (0.180 in)  |
| L1        | 1.12 mm (0.044 in)  | 1.42 mm (0.056 in)  |
| Q1        | 0.23 mm (0.009 in)  | NA                  |
| Indicator | Basic               |                     |
| D3        | 2.100 in (53.34 mm) |                     |
| E3        | 2.100 in (53.34 mm) |                     |
| F         | 1.0 in (2.54 mm)    |                     |
| М         | 2.050 in (52.07 mm) |                     |
|           | 1.000 in (25.4 mm)  |                     |
| M1        |                     |                     |
| M1<br>N   | 2.000 in (50.8 mm)  |                     |

Table 2–10 DECchip 21171-CA Package Dimensions

# 3

# **DECchip 21171-CA Architecture Overview**

This chapter describes the DECchip 21171-CA (CIA) data paths with functional units, transactions, and architecture.

# 3.1 CIA Data Paths with Functional Units Description

This section shows the CIA data path functional units and describes operation of the functional units.

### 3.1.1 System Functional Units

The CIA operates as the host bridge on a PCI-based system along with the 21164, four DSWs, Bcache, memory arrays, and support logic. A simplified description of the system data paths and functional units is presented here to show where the CIA operates within the system.

The CIA performs control, I/O, and address tasks within the DECchip 21171 Core Logic Chipset as shown in Figure 3–1. The host bridge module is shown plugged into a 64-bit PCI.





# 3.1.2 CIA Functional Units

Figure 3–2 shows the CIA data paths and functional units.





LJ-04219.AI

The CIA functional units are listed here and are described in Section 3.1.2.1 through Section 3.1.2.5:

- 21164 instruction and address logic
- PCI data path logic
- Memory logic
- I/O address logic
- DMA address logic

### 3.1.2.1 21164 Instruction and Address Logic

The 21164 instruction and address logic accepts commands from the 21164 and directs the instruction to the memory port or the I/O port. The DMA read/write address (or the scatter-gather TLB miss servicing address) also has access to the memory port through a multiplexer.

The 21164 instruction queue is provided to capture 21164 commands should the memory or I/O port be busy. The 21164 can issue, at most, two read miss transactions—with one having a victim. This maximum condition would require holding three addresses and commands, so a 3-entry buffer is needed.

The flush address register is used during DMA read or write transactions to the Bcache for the latest data. The Bcache is implemented as a write invalidate cache and so might have the only valid copy of the required data.

### 3.1.2.2 PCI Data Path Logic

Because the CIA is the PCI host bridge it generates and decodes PCI addresses and also supplies and receives data. The data path to and from the PCI goes through the CIA and the DSW. The ECC generation and check logic is excluded from the DSW because of the bit slice nature of the DSW and so is performed by the CIA.

Separate buffers are provided in the CIA for DMA and I/O read/write transactions. These buffers are either 32 bytes or 64 bytes in size, and are shown partitioned into 16-byte units, which matches the width of the 21164 data bus.

Later, when the DSW is examined, it will be seen that the DSW also has buffers for the DMA and I/O paths. Control logic simplification is the reason for this duplication.

Table 3–1 lists the PCI commands that the CIA responds to and sends.

| PCI cbe_l<3:0> | Command                     | CIA Slave        | CIA Master |
|----------------|-----------------------------|------------------|------------|
| 0000           | Interrupt acknowledge       | No               | Yes        |
| 0001           | Special cycle               | No               | Yes        |
| 0010           | I/O read                    | No               | Yes        |
| 0011           | I/O write                   | No               | Yes        |
| 0100           | Reserved                    | _                | _          |
| 0101           | Reserved                    | _                | _          |
| 0110           | Memory read                 | Yes              | Yes        |
| 0111           | Memory write                | Yes              | Yes        |
| 1000           | Reserved                    | _                | _          |
| 1001           | Reserved                    | _                | _          |
| 1010           | Configuration read          | No               | Yes        |
| 1011           | Configuration write         | No               | Yes        |
| 1100           | Memory read multiple        | Yes              | No         |
| 1101           | Dual address cycle          | Yes              | No         |
| 1110           | Memory read line            | Yes              | No         |
| 1111           | Memory write and invalidate | Yes <sup>1</sup> | No         |

Table 3–1 PCI Commands Recognized by the CIA

<sup>1</sup>Accepted as memory write

The CIA has these PCI features:

- Supports 64-bit PCI bus width
- Supports 64-bit PCI addressing (DAC cycles)
- Accepts PCI fast back-to-back cycles
- Issues PCI fast back-to-back cycles in dense address space

### 3.1.2.3 Memory Logic

Memory logic provides the row and column address for the memory banks and all the control signals (**ras\_h**, **cas\_h**, **mem\_we\_l<1:0**>, and **mem\_en\_h**). The memory logic provides control signals to the DSW to inform it when to send/strobe the data to/from memory. The CIA also controls memory refresh.

### 3.1.2.4 I/O Address Logic

The I/O address logic handles the I/O read and write addresses. The address decode logic extracts the PCI address from the dense/sparse space 21164 address encodings (see Chapter 6 for more details).

This logic also increments the current address of each data cycle for two reasons:

- In case of a PCI retry, which will require the transaction to be resumed later, we need to start with the address of the aborted data.
- We need to provide a pointer to the next data item to be loaded/sent from the I/O read/write buffers.

The CIA can queue up to six I/O write transactions. Two of the I/O write transactions can be waiting in the 21164 queue and four I/O write transactions can be sitting in the I/O address queue (a 3-entry I/O address queue is provided together with a single-entry current address register). This allows six I/O write transactions to be outstanding (the DSW provides four corresponding I/O write data buffers). The bypass path is enabled/disabled by CIA\_CTRL[CSR\_IOA\_BYPASS] (CSR\_CTRL<15>) being equal to 0/1 respectively.

The CIA provides two more buffers that are needed to sustain maximum bandwidth for memory copy to I/O space. A bypass path is provided for certain dense-space I/O write transactions, that is, the valid bits for the first 16 bytes of data are either 1111, 1011, 1010, and 1001—these cases are optimized for a 64-bit PCI with at least two PCI data cycles.

#### 3.1.2.5 DMA Address Logic

The DMA address logic converts PCI addresses to CPU memory addresses. Two conversion methods are provided:

- · A direct path where a base offset is concatenated with the PCI address
- A scatter-gather map, which maps any 8KB PCI page to any 8KB memory space page

The scatter-gather TLB is eight entries deep with each entry holding four consecutive PTEs. A TLB miss is handled by hardware but software is required to invalidate stale entries by writing to the translation buffer invalidate register (TBIA). See Chapter 6 for more information on address mapping.

The output of the physical address register (PA) has a a counter that generates the prefetch address for certain DMA read miss transactions. An 8KB detector prevents prefetching across page boundaries.

# 3.2 CIA Transactions

The CIA performs the transactions listed here:

- 21164 memory read miss
- 21164 memory read miss with victim
- 21164 I/O read
- 21164 I/O write
- DMA read
- DMA read (prefetch)
- DMA write

These transactions are described in detail in Section 3.2.1 through Section 3.2.8.

# 3.2.1 21164 Read Miss Transaction

The 21164 read miss command and address are sent to the CIA. If the CIA is idle, the command will be stored directly in the memory port register; otherwise, the command enters the 3-deep CPU instruction queue and remains there until the memory port is free. The CIA can accept another subsequent read miss command from the 21164 and store it in the 21164 instruction queue.

The three data paths to the memory port have to arbitrate for use of the memory port: (1) the direct path and (2) the 21164 instruction queue previously mentioned and (3) the DMA read/write address path. The DMA read/write address path is also the path for scatter-gather TLB miss addresses. Upstream of the multiplexer all instruction ordering from the 21164 is preserved. Downstream of the multiplexer ordering between I/O write transactions and 21164 memory transactions is lost. This "post and run" I/O write coherency issue is discussed in Section 3.3.2.

When the 21164 read miss command enters the memory logic, the memory controller generates **ras\_h**, **cas\_h**, and other address signals for the memory array. The memory controller then waits for the memory access delay before instructing the DSW to accept the memory data. The MEMDATA bus width is 256 bits (32 bytes), and so two memory cycles are required to access the 64-byte block.

The DSW synchronizes the data to the 21164 clock. The fixed 64-byte block size read data is returned to the 21164 in wrapped-order.

# 3.2.2 21164 Read Miss with Victim Transaction

The read miss with victim transaction is similar to the read miss transaction described in Section 3.2.1, except the 21164 will also use a Bcache victim command to send out the victim block. The victim block is the modified (dirty) block that is to be replaced in the Bcache by the read miss transaction data.

The read miss command is followed by the Bcache victim command and address. The read miss command will get to the memory port first and so the Bcache victim command and address are always written into the 21164 instruction queue. The victim block data is saved in the victim buffer in the DSW.

The CIA arbiter ensures that a read miss transaction and a victim write transaction are an atomic operation. The victim data is written to memory after the read data has been fetched from memory. The row address portion of the victim address is compared to the row address of the current read miss transaction. If they match, then no memory **ras\_h** cycle is required; instead, only a **cas\_h** cycle is needed. The address bits for the memory have been carefully interspersed to maximize the chance of a victim row address "hitting" the read address—this performance feature is transparent to software. The memory controller in the CIA generates the memory write pulses and instructs the DSW to send the victim data to memory.

The DSW victim buffer is invalidated if a DMA write transaction (or DMA read with lock transaction) "hits" in the victim buffer. Until the 21164 has its read miss transaction data returned, the victim block is still in the Bcache and is still "owned" by the 21164. It is possible for the read miss with victim transaction from the 21164 to be stalled behind a DMA write transaction. The DMA write transaction could "hit" the victim block—in this case, the DMA write transaction will cause a flush command to be issued to the 21164, which will result in the 21164 providing the victim data to the DSW and then the 21164 will invalidate the victim block in Bcache. Thus, the victim data waiting in the victim buffer is no longer valid and is marked invalid by logic in the CIA.

# 3.2.3 21164 Read Transaction to Noncacheable Space

A read transaction by the 21164 to noncacheable space can be to one of four address spaces:

- PCI memory space
- PCI I/O dense or sparse space
- PCI configuration space
- CIA control and status register (CSR) space

The read command to noncacheable space is accepted by the CIA like the read miss command, except the instruction goes to the I/O port. All read commands to noncacheable space go to the I/O address queue. There is no bypass path for dense space I/O read transactions.

Decode logic is provided on the output of the I/O address queue to extract the byte address for the PCI from the 21164's sparse space encoding, and to decode the address for the correct region (PCI memory, I/O, configuration, or CSR).

A read command to noncacheable space destined for the PCI is described here because it is the more interesting case. Logic increments the current longword /quadword address stored in the current address register each data cycle. This is needed in case of a PCI retry and is also used to index the next data item in the I/O write/read data buffers. The value in the current address register corresponds to the address of the data item on the PCI bus (it has the same canonical time as the PCI data-out register).

The I/O read command address is sent to the PCI after any prior I/O write transactions have completed (strict ordering is maintained). The PCI returns the requested data and places it in the I/O read buffer. The contents of this I/O read buffer are next copied to the I/O read buffer in the DSW and then sent to the 21164.

Why have the DSW I/O read buffers been replicated in the CIA? The I/O read buffers in the CIA are provided for the following reasons:

- The path to the DSW might be busy with the end of a prior DMA write transaction (especially if the data has to be merged with memory data to build it up to the ECC width).
- At least 64 bits of storage are required for ECC because the PCI can return 32 bits of data at a time.
- It is convenient to handle transaction retries forced by the PCI protocol. The I/O read buffer in the DSW was provided to build the data up from 64 bits (IOD bus data lines between the CIA and DSW) to the 128 bits required by the 21164.

I/O read transactions from the 21164 have 8-byte resolution and the CIA always returns 32 bytes. If smaller resolution is required, sparse space addressing must be used. Sparse space addressing is described in Chapter 6.

Data is returned in the appropriate byte lanes.

# 3.2.4 21164 Write Transaction to Noncacheable Space

The 21164 issues write transactions to noncacheable space with longword resolution. For smaller granularity, sparse space addressing must be used (see Chapter 6).

Data for I/O write transactions is captured in the I/O write buffer in the DSW. Four 32-byte buffers are available in the DSW and a further two in the CIA. This number of entries allows the CIA to sustain maximum bandwidth on a large copy operation from memory through the 21164-to-I/O space.

The data from these I/O write buffers is sent to the two I/O write buffers in the CIA: two buffers are provided, allowing one to be emptied to the PCI bus while the other is being filled. Each 32-byte buffer in the CIA requires a separate PCI transaction (no merging of the write buffers occurs).

Another benefit of the CIA's I/O write buffers is simpler data-flow management when a target PCI device stalls the I/O write transactions.

The address for an I/O write transaction is sent to the CIA I/O port. For a 32-byte aligned dense space write transaction, the I/O write command is either sent directly to the PCI bus via the bypass path, or queued up in the I/O address queue. The direct (bypass) path is used if:

- There are no outstanding I/O commands.
- The command is an I/O write command to dense space and the first 16 bytes are mostly valid (like 1111, 1011, 1010, 1001).

This command also goes into the I/O address queue, but only as a convenient path in the I/O addressing logic section, to get the address into the current address register.

A total of six I/O write addresses can be queued: the first in the current address register, two in the 21164 queue, and three in the I/O address queue. The I/O address queue maintains strict ordering for I/O transactions but does not maintain strict ordering of I/O write transactions relative to any memory read or write transactions (see Section 3.3).

# 3.2.5 DMA Transactions

The PCI address and command are captured in the address/command register and the data/address register. The address is compared against four address windows to determine if this PCI command should be accepted or ignored by the CIA.

Address windows are a requirement of the PCI specification and are software programmable—they are described in detail in Chapter 6. All PCI commands destined for memory are accepted by the CIA.

\_ Note \_\_\_\_

Two registers capture incoming samples from the PCI bus.

- The address register captures the address and command, holding them for the duration of the transaction.
- The data-in register captures the data, but also captures the address.

The target window logic is attached to the data-in register. It is located there to capture a buffer of data (64 bytes) for use with a DMA write transaction scatter-gather TLB "miss." The target window logic retries the master PCI device in case it has more data.

The CIA has released the PCI for further transactions but is busy servicing the TLB "miss" so must hold the virtual address in the address register. Should another PCI transaction occur while the CIA is servicing the TLB "miss," the CIA will accept that address and compare it to the target window.

There are three registers associated with each of the four PCI windows:

- Window base register 0–3 (W*n*\_BASE)—defines the start of the target window. W*n*\_BASE[W*n*\_BASE\_SG] determines if the scatter-gather map is used for the translation.
- Window mask register 0–3 (W*n*\_MASK)—defines the size of the window.
- Translated base register (T*n*\_BASE)—holds the base address used to relocate the PCI address in the 21164's memory space (for direct mapping) and is also used to hold the scatter-gather map base address for scatter-gather mapping.

 $Wn_BASE[Wn_BASE_SG]$  determines how the PCI address is translated as follows:

- If W*n*\_BASE[W*n*\_BASE\_SG] is clear, the address is directly mapped by concatenating T*n*\_BASE[CSR\_WR\_DATA] with the address.
- If Wn\_BASE[Wn\_BASE\_SG] is set, the address is mapped through the scatter-gather table, allowing any 8KB PCI address to map to any 8KB memory address.

Figure 3–3 illustrates the mapping. This scatter-gather table is located in memory, but the CIA provides an 8-entry TLB that caches the most recent scatter-gather table entries. Each TLB entry holds four consecutive scatter-gather table entries, mapping a contiguous 32KB of virtual PCI addresses to any four 8KB memory pages.

### Figure 3–3 Address Space Overview

21164 CPU



LJ-04220.AI

# 3.2.6 DMA Read Transaction

The translated address stored in the PA register is sent to the 21164 through the flush/read address register and to memory through the memory port. If the 21164 data cache contains valid modified data, then a copy is sent to the Bcache-buffer part of one of the two DMA buffers in the DSW and the valid bit is set. Memory data is always fetched and put in the memory buffer of the DMA buffer. The PCI-buffer part of the DMA buffer is not used for DMA read transactions.

When the first valid QW is available in the DSW's DMA buffer, it is sent to the DMA read buffer in the CIA through the multiplexers. Any ECC correction is done in the CIA. From the DMA buffer in the CIA, the data goes from a register onto the PCI a cycle later. The DMA read data also takes the bypass path around the multiplexer for as long as the PCI can accept this stream of data. Once the PCI stalls, then the buffers are used.

# 3.2.7 DMA Read Transaction (Prefetch)

The PCI supports three types of memory read commands, which are used as specified in the *PCI Local Bus Specification*:

- Read—used for small transfers (up to 1/2 a cache line)
- Read line—used for medium transfers (1/2 to 3 cache lines)
- Read multiple—used for large transfers (more than 3 cache lines)

In the PCI environment, most devices assume a processor cache of 32 bytes (compared to the CIA cache line of 64 bytes). The CIA prefetch strategy is shown in Table 3–2.

| Table 3-2 CIA Prefetch Strategy |                                    |  |  |
|---------------------------------|------------------------------------|--|--|
| PCI Memory Read Command         | Prefetch Operation                 |  |  |
| Read                            | None.                              |  |  |
| Read line                       | Prefetch one block.                |  |  |
| Read multiple                   | Prefetch until end of transaction. |  |  |

Table 3–2 CIA Prefetch Strategy

A counter is used to increment the memory block address for prefetching. The output of this counter goes to the Bcache and memory like a normal DMA read command address. The returned data is sent to the next free DMA buffer in the DSW. So as one buffer is being copied down to the CIA, the other is free to accept DMA prefetched data.

At the end of a transaction all prefetched data in the DMA read buffers is ignored (that is, no prefetch caching is performed). Prefetching does not continue over 8KB page boundaries.

The 64-byte DMA read buffer in the CIA acts like two 32-byte halves during DMA commands—as one half is emptying to the PCI bus, the other half is being filled.

### 3.2.8 DMA Write Transaction

The translated address stored in the PA register is sent to the Bcache through the flush/read address register and also to memory via the memory port. If the Bcache contains valid (modified) data, the data is sent to the Bcache-buffer portion of the DMA buffer in the DSW and the Bcache data is invalidated. Memory data is always fetched and is put in the memory-buffer part of the DMA buffer.

The DMA write data is taken from the PCI bus and is placed in the DMA write buffer. If the data is a complete quadword, then ECC is generated and the data is sent to the PCI-write part of the DMA buffer in the DSW. If the data is an incomplete quadword, then a merge operation has to be performed. The valid Bcache or memory quadword is sent to the CIA from the DMA buffer in the DSW, and the valid bytes of the DMA write data are merged. This merged quadword then has ECC generated and is sent to the PCI-write buffer portion of the DMA buffer in the DSW.

The DMA buffer in the DSW builds the data up to 64 bytes (the block size) before sending the data to memory. The memory logic generates the memory write pulses. The memory address is read from the PA register by way of a multiplexer.

Note \_\_\_\_\_

Should the I/O port be busy with an I/O write/read transaction, the memory port will be available for DMA write commands.

One reason for providing a copy of the DMA write buffer in the CIA is that the data path to the DSW may not be available at the start of a DMA write transaction It could be busy transferring I/O write transaction data from the DSW to the I/O write buffers if a 21164 I/O write command had been received concurrently with a PCI DMA write command.

DMA write transaction data is always written to memory, and is never stored (cached) in the DMA write buffers across transactions.

# 3.3 System Data Coherency Issues

The 21164 is the processor in systems using the DECchip 21171 Core Logic Chipset and the data coherency requirements of the 21164 dominate CIA data coherency issues. The CIA supports the flush-based data coherency protocol with a Bcache but with no duplicate tag stores for either the Scache or Bcache. Therefore the CIA uses the read and flush transactions to probe the 21164 cache.

# 3.3.1 Basic Properties of the System

The system has these basic properties:

- 1. The memory arrays do only one thing at a time.
- 2. A read or write transaction to memory is atomic. No operation of the memory arrays can occur between the read and write parts of a read-modify-write sequence.
- 3. The memory array sequence for a 21164 cache "miss" with victim transaction is atomic in the memory array. A cache miss with victim transaction causes the 21164 to perform a read miss transaction for the block required for the cache miss transaction and then a Bcache victim transaction to write the victim data to memory. No other memory access can come between the read miss transaction and the Bcache victim transaction.
- 4. When "transaction A" gains access to memory it is said to "own" memory. Once "transaction A" "owns" memory there will be no access for any other transaction until "transaction A" has completed all of its memory activity.
- 5. When an I/O TLB "miss" occurs, the CIA issues a read command to the 21164 for the TLB entry and a memory access is also made for this data. The read command is not issued to the 21164 until memory is owned for this access.

### DECchip 21171-CA Architecture Overview 3.3 System Data Coherency Issues

- 6. The CIA processes a PCI device read transaction to memory by issuing a read command to the 21164 for the data and making a memory access for the required data. The read command is not issued until memory is "owned" for the memory cycle.
- 7. A device write transaction to memory causes the CIA to issue a flush transaction to the 21164 for the data and to start a memory access for the data. The memory access serves to write data obtained from the 21164 and also serves to write the data from the PCI device to memory. The CIA does not issue the flush command until memory is "owned" for the memory write transaction.
- 8. We can conclude that the 2-step sequences described in 5, 6, and 7 are all mutually atomic. In each case, the 2-step sequence is a probe of 21164 and a memory cycle. For any pair of sequences of the types describe in 5, 6, and 7, both steps of one of the sequences happened entirely before either of the two steps of the other sequences.

# 3.3.2 Post and Run I/O Write Data Coherency

The Alpha architecture allows "posted" or "buffered" write transactions to I/O devices, allowing the CIA to buffer write transactions from the 21164 to a PCI device. Several read transactions from a PCI device to main memory might be completed while write transactions to the same PCI device are buffered. The usual way for a software programmer to ensure that the write data has reached the device is to read a register on the same device.

The CIA performs the following operations to implement the Alpha architecture post and run feature.

- Before a read transaction to an I/O location is processed, all preceding 21164 write transactions to devices are flushed out of the buffers.
- Before a read transaction from a PCI device to main memory is processed all preceding write transactions by the PCI device to main memory are flushed out of the write buffers.

# DECchip 21171-CA Architecture Overview 3.4 CIA Memory ras\_h, cas\_h, and Address Operation

# 3.4 CIA Memory ras\_h, cas\_h, and Address Operation

The technique used by the CIA to eliminate **ras\_h** cycles for victim write transactions is described here. The method is transparent to software.

# 3.4.1 Traditional Mapping of 21164 Address to Memory Address

The traditional approach of mapping the 21164 address bit for bit to the memory address is shown in Figure 3-4.



### Figure 3–4 Traditional Mapping to a Memory Address

Because a cache is much smaller than available memory, multiple memory locations will correspond to the same cache location. This correspondence is shown in the left-hand side of Figure 3–5 where data A1, data B1, and data C1 all map to the same cache location (A1B1C1).







LJ-04222.AI

Suppose that data A1 currently resides in the Bcache, but the 21164 wants to access data C1. A cache miss will occur that will fetch data C1 and overwrite A1 in the cache. If A1 is the only valid copy of the data (for example, a 21164 write transaction had previously updated A1), then A1 has to be written to memory before data C1 can be written over data A1. The displaced data A1 is referred to as a victim.

Look again at Figure 3–5 and notice that in the traditional memory addressing scheme, data C1 and the potential victim (data A1) are well separated in memory. They are separated by a multiple of n times the cache size. This sparse distribution of potential victim locations means a read fill block and its victim may not reside in the same memory page.

#### 3.4.2 CIA Mapping of 21164 Address to Memory Address

The highest tag bits are used for memory bank selection in both the traditional and CIA address mapping schemes.

The CIA shuffles the memory address bits so that some of the high-order 21164 address bits (part of the Bcache tag) become the memory column address and the low-order CPU address bits (part of the cache index) become the memory row address as shown in Figure 3–6.



#### Figure 3–6 Modified Mapping to a Memory Address

LJ-04223.AI

Interchanging the memory row and column address bits, the write transaction target and the potential victim locations reside in the same SIMMs, even within the same row within the SIMMs, as shown in Figure 3–7. The chance of a cache block and its victim residing in the same memory page is greatly increased. This technique will remove all **ras\_h** cycles from victim write transactions. In fact, all victims will be able to share an **ras\_h** signal with the read miss transaction.





LJ-04224.AI

However, this approach hinders DMA transactions. Consecutive blocks (data A1, data A2, and data A3), as shown in Figure 3–7, are scattered a page apart by using this memory addressing scheme. This implies that consecutive DMA read/write transaction blocks will require a **ras\_h** cycle, reducing possible bandwidth. The traditional scheme does not suffer this problem.

A compromise between the two schemes, as shown in Figure 3–8, is used by the CIA. The four low-order bits of the index map straight to the low-order bits of the column address (just like in a traditional scheme). The remaining high-order index bits go to the memory row-address. The remainder of the column address uses the tag portion of the physical address.



Figure 3–8 CIA Mapping to a Memory Address

LJ-04225.AI

Using this compromise scheme, a DMA transaction will march through four 64-byte blocks (64 longwords), on average, before requiring a **ras\_h** cycle. This constitutes a large DMA transfer, minimizing the **ras\_h** penalty.

The logic that determines if a **ras\_h** cycle is required is located in the memory logic block of Figure 3–2.

Figures 3–9 and 3–10 show the relationship between CPU/DMA address bits <28:04> and column and row address bits to memory. The memory address maps for the 128-bit data path and the 256-bit data path are shown in Tables 3–9 and 3–10, respectively. The user specifies row type in MBA*n*[ROW\_TYPE] (MBA*n*<2:1>).

#### Figure 3–9 Memory Address Maps for 128-Bit Data Path

| _ | Row<br>Type | DRAM<br>Size | DRAM<br>Configuration  | 28 | 27      | 26      | 25       | 24      | 23      | 22      | 21      | 20       | 19      | 18      | 17      | 16      |
|---|-------------|--------------|------------------------|----|---------|---------|----------|---------|---------|---------|---------|----------|---------|---------|---------|---------|
| ſ | 00          | 4MB          | 10R x 10C              | -  | -       | -<br>-  | -        | -       | -<br>C8 | -<br>C7 | -<br>C6 | -<br>C5  | R9<br>- | R8<br>- | R7<br>- | R6<br>- |
|   | 01          | 16MB         | 11R x 11C<br>12R x 10C | -  | -       | -       | -<br>C4  | -<br>C9 | -<br>C8 | -<br>C7 | -<br>C6 | R10<br>- | R9<br>- | R8<br>- | R7<br>- | R6<br>- |
|   | 10          | 64MB         | 12R x 12C<br>13R x 11C | -  | -<br>C3 | -<br>C5 | -<br>C10 | -<br>C9 | -<br>C8 | -<br>C7 | -<br>C6 | R10<br>- | R9<br>- | R8<br>- | R7<br>- | R6<br>- |

For 128-Bit-Wide Memory:

| Row<br>Type | DRAM<br>Size | DRAM<br>Configuration  | 15      | 14      | 13      | 12      | 11      | 10      | 09       | 08         | 07      | 06      | 05*     | 04*     |
|-------------|--------------|------------------------|---------|---------|---------|---------|---------|---------|----------|------------|---------|---------|---------|---------|
| 00          | 4MB          | 10R x 10C              | R5      | R4      | R3      | R2      | R1      | R0      | -        | -          | -       | -       | -       | -       |
| 00          |              | 1010 × 100             | -       | -       | -       | -       | -       | -       | C4       | C3         | C2      | C1      | C0      | C9      |
| 01          | 16MB         | 11R x 11C              | R5      | R4      | R3      | R2      | R1      | R0      | R11      | -          | -       | -       | -       | -       |
| 01          | TOIVID       | 12R x 10C              | -       | -       | -       | -       | -       | -       | C10      | C3         | C2      | C1      | C0      | C5      |
| 10          | 64MB         | 12R x 12C<br>13R x 11C | R5<br>- | R4<br>- | R3<br>- | R2<br>- | R1<br>- | R0<br>- | R11<br>- | R12<br>C11 | -<br>C2 | -<br>C1 | -<br>C0 | -<br>C4 |

Note:

CPU tag index requires a minimum cache size of 2MB (CPU/DMA address bits <21:7> required).

LJ-04399.AI5

#### Figure 3–10 Memory Address Maps for 256-Bit Data Path

For 256-Bit-Wide Memory:

| Row<br>Type | DRAM<br>Size | DRAM<br>Configuration  | 28      | 27      | 26      | 25       | 24      | 23      | 22      | 21      | 20       | 19      | 18      | 17      | 16      |
|-------------|--------------|------------------------|---------|---------|---------|----------|---------|---------|---------|---------|----------|---------|---------|---------|---------|
| 00          | 4MB          | 10R x 10C              | -       | -       | -       | -        | -<br>C9 | -<br>C8 | -<br>C7 | -<br>C6 | -<br>C5  | R9<br>- | R8<br>- | R7<br>- | R6<br>- |
| 01          | 16MB         | 11R x 11C<br>12R x 10C | -       | -       | -<br>C5 | -<br>C4  | -<br>C9 | -<br>C8 | -<br>C7 | -<br>C6 | R10<br>- | R9<br>- | R8<br>- | R7<br>- | R6<br>- |
| 10          | 64MB         | 12R x 12C<br>13R x 11C | -<br>C4 | -<br>C3 | -<br>C5 | -<br>C10 | -<br>C9 | -<br>C8 | -<br>C7 | -<br>C6 | R10<br>- | R9<br>- | R8<br>- | R7<br>- | R6<br>- |

| Row   | DRAM  | DRAM |
|-------|-------|------|
| 1.0.0 | DIVIN |      |

| Туре | Size | Configuration | 15 | 14         | 13 | 12 | 11 | 10 | 09 | 08 | 07 | 06 | 05* | 04* |
|------|------|---------------|----|------------|----|----|----|----|----|----|----|----|-----|-----|
|      |      |               | 55 | <b>D</b> 4 | -  | 50 | 54 | 50 |    |    |    |    |     |     |

| 00 | 4MB    | 10R x 10C | R5 | R4 | R3 | R2 | R1 | R0 | -   | -   | -  | -  | -  | - |
|----|--------|-----------|----|----|----|----|----|----|-----|-----|----|----|----|---|
| 00 | 41010  |           | -  | -  | -  | -  | -  | -  | C4  | C3  | C2 | C1 | C0 | - |
| 01 | 16MB   | 11R x 11C | R5 | R4 | R3 | R2 | R1 | R0 | R11 | -   | -  | -  | -  | - |
| 01 | TOIVID | 12R x 10C | -  | -  | -  | -  | -  | -  | C10 | C3  | C2 | C1 | C0 | - |
| 10 | 64MB   | 12R x 12C | R5 | R4 | R3 | R2 | R1 | R0 | R11 | R12 | -  | -  | -  | - |
| 10 | 04IVID | 13R x 11C | -  | -  | -  | -  | -  | -  | -   | C11 | C2 | C1 | C0 | - |

Note:

CPU tag index requires a minimum cache size of 2MB (CPU/DMA address bits <21:7> required).

LJ-04400.AI5

#### DECchip 21171-CA Architecture Overview 3.5 MB and LOCK Instructions

# 3.5 MB and LOCK Instructions

The MB (memory barrier) and LOCK instructions are described in this section.

#### 3.5.1 MB Instruction

The MB instruction may or may not be disabled from leaving the 21164 by making the BC\_CONTROL [EI\_CMD\_GRP3] bit clear. If BC\_CONTROL [EI\_CMD\_GRP3] is clear, the CIA should never acknowledge receipt of an MB instruction.

CACK\_EN [MB\_ENABLE], in the CIA, enables or disables the CIA from acknowledging receipt of an MB instruction from the 21164. If CACK\_EN [MB\_ENABLE] is clear, the CIA will treat an MB instruction as a NOP. See Section 3.3.2.

#### 3.5.2 LOCK Instruction

The CIA has to contend with locks originating on either the 21164 or the PCI. There are two cases that require that the 21164 internal lock state on a block be cleared (from a system point of view). The first is during a DMA write transaction to the locked block and the second is when a PCI device has established a lock.

The things to consider for system lock behavior are:

- DMA write transaction case—The 21164 maintains its lock flag and lock address in its bus interface unit (BIU). This lock status is correctly maintained, even if the locked block is displaced from the Scache, as long as the system sends all DMA write FLUSH commands to the 21164 (no duplicate cache tag).
- PCI lock established—A PCI device can only establish a lock on a 16-byte block of data during a DMA read transaction. Once the lock is established by the successful DMA read transaction, the PCI device has exclusive access to that 16-byte block (the PCI target may lock a larger block). This PCI lock allows the device to do an atomic read-modify-write on a 16-byte data unit.

The Alpha and PCI architectures have different mechanisms for establishing a lock:

- For PCI architecture, it is a successful read transaction (with the PCI LOCK signal asserted) that establishes a lock.
- For Alpha architecture, it is a successful write transaction (ST $n_C$ ) that establishes a lock.

# DECchip 21171-CA Architecture Overview 3.5 MB and LOCK Instructions

So, a PCI read transaction with the PCI LOCK signal asserted must be treated by the 21164 as a write transaction (that is, for the Alpha architecture, it must have the same effect as a write transaction from some other processor). Example 3–1 shows an example of the 21164 and PCI competing for a memory flag.

#### Example 3–1 21164 and PCI Device Lock Contention

| 21164 Atomic Update                                                                            | PCI Device Atomic Update                                           |
|------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|
|                                                                                                |                                                                    |
| <pre>try_again:<br/>LDQ_L R1, mem_flag<br/>{ modify memory flag }<br/>STQ_C R1, mem_flag</pre> | READ/LOCK mem_flag<br>{ modify mem_flag }<br>WRITE/UNLOCK mem flag |
| BEQ R,no_store                                                                                 | ······································                             |
|                                                                                                |                                                                    |
| no_store:<br>{ check for excessive iterations}<br>BR try_again                                 |                                                                    |

Both the 21164 and the PCI device are attempting to perform an atomic readmodify-write operation on a memory flag (a semaphore). The 21164 begins with a LDQ\_L instruction but will not know if the update is successful until the companion STQ\_C instruction completes successfully.

Assume that the PCI device performs a PCI read transaction with the PCI LOCK signal asserted, and obtains the lock to the memory flag before the 21164 STQ\_C instruction is executed. The 21164's STQ\_C instruction must fail, otherwise, the 21164 and the PCI device will both believe they have successfully modified the flag.

Before a PCI device establishes the PCI lock, the 21164 must clear its lock flag. The CIA must perform a flush transaction to the locked block, causing the 21164 to clear its lock flag. Unfortunately, the system must not only perform a DMA read transaction, but must also write the flushed block to memory. Once the CIA successfully sends the data to the PCI device, the PCI lock is established.

#### DECchip 21171-CA Architecture Overview 3.5 MB and LOCK Instructions

While the PCI lock is in effect, the 21164 may attempt to refill the flushed block. This will happen if a loop, as shown in Example 3–1, is repeatedly executing an  $LDx_L$  instruction. The requested block cannot be provided until the PCI lock has completed because once the block is in the 21164 internal cache, the CIA loses control of the block.

Initially, the CIA could prevent the 21164 from setting its internal lock flag for the block by using the 21164 input signal line **system\_lock\_flag\_h**. The next time the  $LDx_L/STn_C$  loop, the 21164 will have a cache hit on the block and will be unaware of the system lock state, so the loop will succeed this second time.

The CIA lock rules are:

- The 21164 **system\_lock\_flag\_h** input signal line is not connected to the CIA and is always tied true.
- All DMA write transactions will result in the CIA performing a flush transaction to the 21164.
- All DMA read transactions with the PCI LOCK signal asserted will result in the CIA performing a flush transaction to the 21164. The CIA must write the flushed block to memory. The internal CIA lock address register will be set with the locking address.
- If the 21164 requests a fill that hits the CIA lock address register, then the fill is stalled until the PCI lock state is relinquished by the PCI device.
- The 21164 lock transaction will be treated as a NOP for systems with duplicate tag stores.
- The 21164 write transaction with lock will be treated as a write transaction.

#### 3.5.3 Locks to Uncached Space

The CIA does not support LD*x*\_L and ST*n*\_C to noncacheable space. They are converted to LD*x* and ST*n*.

# 4

# DECchip 21171-CA Control and Status Registers

This chapter describes the DECchip 21171-CA (CIA) control and status registers (CSRs). It also provides information about programming memory timing, configuring memory, and initializing the backup cache (Bcache).

Note

Programmers must write only zeros to register fields defined as reserved.

# 4.1 DECchip 21171-CA Registers

The DECchip 21171-CA CSRs are 32 bits wide and are located on NATURALLY ALIGNED 64-byte addresses. Write transactions to read-only registers could result in UNPREDICTABLE behavior while read transactions are nondestructive. Only zeros should be written to reserved bits. The register descriptions contain the initialized states.

The DECchip 21171-CA CSRs are presented here in seven groups:

- General registers
- Diagnostic registers
- Performance monitor registers
- Error registers
- System configuration registers
- PCI address and scatter-gather registers
- Address translation registers

The Alpha 21164 microprocessor CSRs, which are 64 bits wide, are described in the *Alpha 21164 Microprocessor Hardware Reference Manual*. The CSRs of most interest to uniprocessor system designers are:

- Scache control register (SC\_CTL)
- Bcache control register (BC\_CONTROL)
- Bcache configuration register (BC\_CONFIG)

#### 4.1.1 DECchip 21171-CA General Registers

Table 4–1 lists the DECchip 21171-CA (CIA) general registers and Section 4.2 shows and describes the individual registers.

| Address      | Mnemonic | Name                                       |
|--------------|----------|--------------------------------------------|
| 87.4000.0080 | CIA_REV  | CIA revision register                      |
| 87.4000.00C0 | PCI_LAT  | PCI latency register                       |
| 87.4000.0100 | CIA_CTRL | CIA control register                       |
| 87.4000.0400 | HAE_MEM  | Hardware address extension memory register |
| 87.4000.0440 | HAE_IO   | Hardware address extension I/O register    |
| 87.4000.0480 | CFG      | Configuration register                     |
| 87.4000.0600 | CACK_EN  | CIA acknowledgment enable register         |

Table 4–1 DECchip 21171-CA General Registers

#### 4.1.2 DECchip 21171-CA Diagnostic Registers

Table 4–2 lists the DECchip 21171-CA (CIA) diagnostic registers and Section 4.3 shows and describes the individual registers.

| Table 4–2 | DECchip | 21171-CA | Diagnostic | Registers |
|-----------|---------|----------|------------|-----------|
|           |         |          |            |           |

| Address      | Mnemonic   | Name                            |
|--------------|------------|---------------------------------|
| 87.4000.2000 | CIA_DIAG   | CIA diagnostic control register |
| 87.4000.3000 | DIAG_CHECK | Diagnostic check register       |

#### 4.1.3 DECchip 21171-CA Performance Monitor Registers

Table 4–3 lists the DECchip 21171-CA (CIA) performance monitor registers and Section 4.4 shows and describes the individual registers.

 Table 4–3
 DECchip 21171-CA Performance Monitor Registers

| Address      | Mnemonic     | Name                         |
|--------------|--------------|------------------------------|
| 87.4000.4000 | PERF_MONITOR | Performance monitor register |
| 87.4000.4040 | PERF_CONTROL | Performance control register |

# 4.1.4 DECchip 21171-CA Error Registers

Table 4–4 lists the DECchip 21171-CA (CIA) error registers and Section 4.5 shows and describes the individual registers.

| Address      | Mnemonic | Name                              |
|--------------|----------|-----------------------------------|
| 87.4000.8000 | CPU_ERR0 | CPU error information register 0  |
| 87.4000.8040 | CPU_ERR1 | CPU error information register 1  |
| 87.4000.8200 | CIA_ERR  | CIA error register                |
| 87.4000.8240 | CIA_STAT | CIA status register               |
| 87.4000.8280 | ERR_MASK | CIA error mask register           |
| 87.4000.8300 | CIA_SYN  | CIA syndrome register             |
| 87.4000.8400 | MEM_ERR0 | CIA memory port status register 0 |
| 87.4000.8440 | MEM_ERR1 | CIA memory port status register 1 |
| 87.4000.8800 | PCI_ERR0 | PCI error register 0              |
| 87.4000.8840 | PCI_ERR1 | PCI error register 1              |
| 87.4000.8880 | PCI_ERR2 | PCI error register 2              |

Table 4–4 DECchip 21171-CA Error Registers

# 4.1.5 DECchip 21171-CA System Configuration Registers

Table 4–5 lists the DECchip 21171-CA (CIA) system configuration registers and Section 4.6 shows and describes the individual registers.

| Address      | Mnemonic | Name                                 |
|--------------|----------|--------------------------------------|
| 87.5000.0000 | MCR      | Memory configuration register        |
| 87.5000.0600 | MBA0     | Memory base address register 0       |
| 87.5000.0680 | MBA2     | Memory base address register 2       |
| 87.5000.0700 | MBA4     | Memory base address register 4       |
| 87.5000.0780 | MBA6     | Memory base address register 6       |
| 87.5000.0800 | MBA8     | Memory base address register 8       |
| 87.5000.0880 | MBAA     | Memory base address register 10      |
| 87.5000.0900 | MBAC     | Memory base address register 12      |
| 87.5000.0980 | MBAE     | Memory base address register 14      |
| 87.5000.0B00 | TMG0     | Memory timing information register 0 |
| 87.5000.0B40 | TMG1     | Memory timing information register 1 |
| 87.5000.0B80 | TMG2     | Memory timing information register 2 |

Table 4–5 DECchip 21171-CA System Configuration Registers

#### 4.1.6 DECchip 21171-CA PCI Address and Scatter-Gather Registers

Table 4–6 lists the DECchip 21171-CA (CIA) PCI address and scatter-gather registers, and Section 4.7 describes the individual registers.

| Address      | Mnemonic | Name                                                  |
|--------------|----------|-------------------------------------------------------|
| 87.6000.0100 | TBIA     | Scatter-gather translation buffer invalidate register |
| 87.6000.0400 | W0_BASE  | Window base register 0                                |
| 87.6000.0440 | W0_MASK  | Window mask register 0                                |
| 87.6000.0480 | T0_BASE  | Translated base register 0                            |
| 87.6000.0500 | W1_BASE  | Window base register 1                                |
| 87.6000.0540 | W1_MASK  | Window mask register 1                                |
| 87.6000.0580 | T1_BASE  | Translated base register 1                            |
| 87.6000.0600 | W2_BASE  | Window base register 2                                |
| 87.6000.0640 | W2_MASK  | Window mask register 2                                |
| 87.6000.0680 | T2_BASE  | Translated base register 2                            |
| 87.6000.0700 | W3_BASE  | Window base register 3                                |
| 87.6000.0740 | W3_MASK  | Window mask register 3                                |
| 87.6000.0780 | T3_BASE  | Translated base register 3                            |
| 87.6000.07C0 | W_DAC    | Window Base DAC register                              |

Table 4–6 DECchip 21171-CA PCI Address and Scatter-Gather Registers

### 4.1.7 DECchip 21171-CA Address Translation Registers

Table 4–7 lists the DECchip 21171-CA (CIA) address translation registers and Section 4.8 describes the individual registers.

| Address      | Mnemonic  | Name                              |
|--------------|-----------|-----------------------------------|
| 87.6000.0800 | LTB_TAG0  | Lockable translation buffer Tag 0 |
| 87.6000.0840 | LTB_TAG1  | Lockable translation buffer Tag 1 |
| 87.6000.0880 | LTB_TAG2  | Lockable translation buffer Tag 2 |
| 87.6000.08C0 | LTB_TAG3  | Lockable translation buffer Tag 3 |
| 87.6000.0900 | TB_TAG0   | Translation buffer tag 0          |
| 87.6000.0940 | TB_TAG1   | Translation buffer tag 1          |
| 87.6000.0980 | TB_TAG2   | Translation buffer tag 2          |
| 87.6000.09C0 | TB_TAG3   | Translation buffer tag 3          |
| 87.6000.1000 | TB0_PAGE0 | Translation buffer 0 page 0       |
| 87.6000.1040 | TB0_PAGE1 | Translation buffer 0 page 1       |
| 87.6000.1080 | TB0_PAGE2 | Translation buffer 0 page 2       |
| 87.6000.10C0 | TB0_PAGE3 | Translation buffer 0 page 3       |
| 87.6000.1100 | TB1_PAGE0 | Translation buffer 1 page 0       |
| 87.6000.1140 | TB1_PAGE1 | Translation buffer 1 page 1       |
| 87.6000.1180 | TB1_PAGE2 | Translation buffer 1 page 2       |
| 87.6000.11C0 | TB1_PAGE3 | Translation buffer 1 page 3       |
| 87.6000.1200 | TB2_PAGE0 | Translation buffer 2 page 0       |
| 87.6000.1240 | TB2_PAGE1 | Translation buffer 2 page 1       |
| 87.6000.1280 | TB2_PAGE2 | Translation buffer 2 page 2       |
| 87.6000.12C0 | TB2_PAGE3 | Translation buffer 2 page 3       |

Table 4–7 DECchip 21171-CA Address Translation Registers

(continued on next page)

| Address      | Mnemonic  | Name                        |
|--------------|-----------|-----------------------------|
| 87.6000.1300 | TB3_PAGE0 | Translation buffer 3 page 0 |
| 87.6000.1340 | TB3_PAGE1 | Translation buffer 3 page 1 |
| 87.6000.1380 | TB3_PAGE2 | Translation buffer 3 page 2 |
| 87.6000.13C0 | TB3_PAGE3 | Translation buffer 3 page 3 |
| 87.6000.1400 | TB4_PAGE0 | Translation buffer 4 page 0 |
| 87.6000.1440 | TB4_PAGE1 | Translation buffer 4 page 1 |
| 87.6000.1480 | TB4_PAGE2 | Translation buffer 4 page 2 |
| 87.6000.14C0 | TB4_PAGE3 | Translation buffer 4 page 3 |
| 87.6000.1500 | TB5_PAGE0 | Translation buffer 5 page 0 |
| 87.6000.1540 | TB5_PAGE1 | Translation buffer 5 page 1 |
| 87.6000.1580 | TB5_PAGE2 | Translation buffer 5 page 2 |
| 87.6000.15C0 | TB5_PAGE3 | Translation buffer 5 page 3 |
| 87.6000.1600 | TB6_PAGE0 | Translation buffer 6 page 0 |
| 87.6000.1640 | TB6_PAGE1 | Translation buffer 6 page 1 |
| 87.6000.1680 | TB6_PAGE2 | Translation buffer 6 page 2 |
| 87.6000.16C0 | TB6_PAGE3 | Translation buffer 6 page 3 |
| 87.6000.1700 | TB7_PAGE0 | Translation buffer 7 page 0 |
| 87.6000.1740 | TB7_PAGE1 | Translation buffer 7 page 1 |
| 87.6000.1780 | TB7_PAGE2 | Translation buffer 7 page 2 |
| 87.6000.17C0 | TB7_PAGE3 | Translation buffer 7 page 3 |

Table 4–7 (Cont.) DECchip 21171-CA Address Translation Registers

# 4.2 DECchip 21171-CA General Registers

This section defines and describes the DECchip 21171-CA general registers.

# 4.2.1 CIA Revision Register (CIA\_REV)

#### Figure 4–1 CIA Revision Register (87.4000.0080)



LJ-04226.AI

#### Table 4–8 CIA Revision Register

| Field  | Name     | Туре       | Description                                                                     |
|--------|----------|------------|---------------------------------------------------------------------------------|
| <7:0>  | CIA_REV  | RO,CIA Rev | CIA revision field.<br>0—Pass 1 CIA chip present.<br>1—Pass 2 CIA chip present. |
| <31:8> | Reserved | RO,0       | _                                                                               |

08 07

00

# 4.2.2 PCI Latency Register (PCI\_LAT)





| Field   | Name     | Туре | Description                                   |
|---------|----------|------|-----------------------------------------------|
| <7:0>   | Reserved | RO,0 | _                                             |
| <15:8>  | LATENCY  | RW,0 | PCI master latency timer in PCI clock cycles. |
| <31:16> | Reserved | RO,0 | _                                             |

#### Table 4–9 PCI Latency Register

# 4.2.3 CIA Control Register (CIA\_CTRL)

#### Figure 4–3 CIA Control Register (87.4000.0100)

|                 | 31 | 30 | ) 29 | 9 2 | 8 2 | 7 : | 26 25 | 52 | 4 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 5 1 | 5 14 | 11 | 3 1 | 2 1 | 11 | 0 0 | 9 0 | 8 | 07 | 06 | 05 | 04 | 03 | 02 | 2 0 | 1 00 |
|-----------------|----|----|------|-----|-----|-----|-------|----|------|----|----|----|----|----|----|----|-----|------|----|-----|-----|----|-----|-----|---|----|----|----|----|----|----|-----|------|
|                 |    |    |      | 1   |     | 1   |       | 1  |      | 1  |    | 1  |    |    |    |    |     |      |    |     |     |    |     |     |   |    |    |    |    |    |    |     |      |
| EN_DMA_RD_PERF  | T  |    |      | T   |     |     |       | T  |      |    |    |    |    |    |    |    |     |      |    |     |     |    |     |     |   |    | T  |    | T  |    |    |     |      |
| Reserved        |    |    |      |     |     |     |       |    |      |    |    |    |    |    |    |    |     |      |    |     |     |    |     |     |   |    |    |    |    |    |    |     |      |
| RM_TYPE         |    |    |      |     |     |     |       |    |      |    |    |    |    |    |    |    |     |      |    |     |     |    |     |     |   |    |    |    |    |    |    |     |      |
| Reserved        |    |    |      |     |     |     |       |    |      |    |    |    |    |    |    |    |     |      |    |     |     |    |     |     |   |    |    |    |    |    |    |     |      |
| RL_TYPE         |    |    |      |     |     |     |       |    |      |    |    |    |    |    |    |    |     |      |    |     |     |    |     |     |   |    |    |    |    |    |    |     |      |
| Reserved        |    |    |      |     |     |     |       |    |      |    |    |    |    |    |    |    |     |      |    |     |     |    |     |     |   |    |    |    |    |    |    |     |      |
| RD_TYPE         |    |    |      |     |     |     |       |    |      |    |    |    |    |    |    |    |     |      |    |     |     |    |     |     |   |    |    |    |    |    |    |     |      |
| EN_ARB_LINK     |    |    |      |     |     |     |       |    |      |    |    |    |    |    |    |    |     |      |    |     |     |    |     |     |   |    |    |    |    |    |    |     |      |
| ARB_CPU_EN      |    |    |      |     |     |     |       |    |      |    |    |    |    |    |    |    |     |      |    |     |     |    |     |     |   |    |    |    |    |    |    |     |      |
| CPU_FLUSHREQ_EN |    |    |      |     |     |     |       |    |      |    |    |    |    |    |    |    |     |      |    |     |     |    |     |     |   |    |    |    |    |    |    |     |      |
| IO_FLUSHREQ_EN  |    |    |      |     |     |     |       |    |      |    |    |    |    |    |    |    |     |      |    |     |     |    |     |     |   |    |    |    |    |    |    |     |      |
| CSR_IOA_BYPASS  |    |    |      |     |     |     |       |    |      |    |    |    |    |    |    |    |     |      |    |     |     |    |     |     |   |    |    |    |    |    |    |     |      |
| CON_IDLE_BC     |    |    |      |     |     |     |       |    |      |    |    |    |    |    |    |    |     |      |    |     |     |    |     |     |   |    |    |    |    |    |    |     |      |
| ASSERT_IDLE_BC  |    |    |      |     |     |     |       |    |      |    |    |    |    |    |    |    |     |      |    |     |     |    |     |     |   |    |    |    |    |    |    |     |      |
| ECC_CHK_EN      |    |    |      |     |     |     |       |    |      |    |    |    |    |    |    |    |     |      |    |     |     |    |     |     |   |    |    |    |    |    |    |     |      |
| MCHK_ERR_EN     |    |    |      |     |     |     |       |    |      |    |    |    |    |    |    |    |     |      |    |     |     |    |     |     |   |    |    |    |    |    |    |     |      |
| FILL_ERR_EN     |    |    |      |     |     |     |       |    |      |    |    |    |    |    |    |    |     |      |    |     |     |    |     |     |   |    |    |    |    |    |    |     |      |
| PERR_EN         |    |    |      |     |     |     |       |    |      |    |    |    |    |    |    |    |     |      |    |     |     |    |     |     |   |    |    |    |    |    |    |     |      |
| ADDR_PE_EN      |    |    |      |     |     |     |       |    |      |    |    |    |    |    |    |    |     |      |    |     |     |    |     |     |   |    |    |    |    |    |    |     |      |
| PCI_ACK64_EN    |    |    |      |     |     |     |       |    |      |    |    |    |    |    |    |    |     |      |    |     |     |    |     |     |   |    |    |    |    |    |    |     |      |
| PCI_REQ64_EN    |    |    |      |     |     |     |       |    |      |    |    |    |    |    |    |    |     |      |    |     |     |    |     |     |   |    |    |    |    |    |    |     |      |
| PCI_MEM_EN      |    |    |      |     |     |     |       |    |      |    |    |    |    |    |    |    |     |      |    |     |     |    |     |     |   |    |    |    |    |    |    |     |      |
| PCI_MST_EN      |    |    |      |     |     |     |       |    |      |    |    |    |    |    |    |    |     |      |    |     |     |    |     |     |   |    |    |    |    |    |    |     |      |
| FST_BB_EN       |    |    |      |     |     |     |       |    |      |    |    |    |    |    |    |    |     |      |    |     |     |    |     |     |   |    |    |    |    |    |    |     |      |
| PCI_LOOP_EN     |    |    |      |     |     |     |       |    |      |    |    |    |    |    |    |    |     |      |    |     |     |    |     |     |   |    |    |    |    |    |    |     |      |
| PCI_LOCK_EN     |    |    |      |     |     |     |       |    |      |    |    |    |    |    |    |    |     |      |    |     |     |    |     |     |   |    |    |    |    |    |    |     |      |
| PCI_EN          |    |    |      |     |     |     |       |    |      |    |    |    |    |    |    |    |     |      |    |     |     |    |     |     |   |    |    |    |    |    |    |     |      |

LJ-04228.AI

| Field | Name           | Туре | Description                                                                                                                                                                |
|-------|----------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <0>   | PCI_EN         | RW,0 | 0—CIA asserts reset to the PCI.<br>1—CIA does not assert reset to the PCI.                                                                                                 |
| <1>   | PCI_LOCK_EN    | RW,0 | 0—CIA will not lock when the PCI tries to lock it.<br>1—CIA will lock when the PCI tries to lock it.                                                                       |
| <2>   | PCI_LOOP_EN    | RW,0 | 0—CIA will not respond as a target when it is the<br>master.<br>1—CIA will respond as a target when it is the<br>master.                                                   |
| <3>   | FST_BB_EN      | RW,0 | 0—CIA will not initiate fast back-to-back PCI<br>transactions.<br>1—CIA will initiate fast back-to-back PCI<br>transactions.                                               |
| <4>   | PCI_MST_EN     | RW,0 | 0—CIA will not initiate PCI transactions.<br>1—CIA will initiate PCI transactions.                                                                                         |
| <5>   | PCI_MEM_EN     | RW,0 | 0—CIA will not respond to PCI transactions.<br>1—CIA will respond to PCI transactions.                                                                                     |
| <6>   | PCI_REQ64_EN   | RW,0 | 0—CIA will not request 64-bit PCI data transactions.<br>1—CIA will request 64-bit PCI data transactions.                                                                   |
| <7>   | PCI_ACK64_EN   | RW,0 | 0—CIA will not accept 64-bit PCI data transactions.<br>1—CIA will accept 64-bit PCI data transactions.                                                                     |
| <8>   | ADDR_PE_EN     | RW,0 | 0—CIA will not check PCI address parity errors.<br>1—CIA will check PCI address parity errors.                                                                             |
| <9>   | PERR_EN        | RW,0 | 0—CIA will not check PCI data parity errors.<br>1—CIA will check PCI data parity errors.                                                                                   |
| <10>  | FILL_ERR_EN    | RW,0 | 0—CIA will not assert <b>fill_error_h</b> on sysBus.<br>1—CIA will assert <b>fill_error_h</b> if an error occurs<br>during a 21164 read miss transaction.                  |
| <11>  | MCHK_ERR_EN    | RW,0 | 0—CIA will not assert <b>error_h</b> on sysBus.<br>1—CIA will assert <b>error_h</b> to report system machine check conditions.                                             |
| <12>  | ECC_CHK_EN     | RW,0 | 0— CIA will not check IOD data for ECC errors.<br>1—CIA will check IOD data for ECC errors.                                                                                |
| <13>  | ASSERT_IDLE_BC | RW,0 | 0—CIA will not assert <b>idle_bc_h</b> on sysBus when<br>asserting <b>addr_bus_req_h</b> .<br>1—CIA will assert <b>idle_bc_h</b> when asserting<br><b>addr_bus_req_h</b> . |

# Table 4–10 CIA Control Register

(continued on next page)

| Field   | Name                | Туре | Description                                                                                                                                                                                    |
|---------|---------------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <14>    | CON_IDLE_BC         | RW,0 | 0—CIA may generate a noncontiguous <b>idle_bc_h</b><br>signal.<br>1—CIA will guarantee that the <b>idle_bc_h</b> signal is<br>contiguous.                                                      |
| <15>    | CSR_IOA_BYPASS      | RW,0 | 0—CIA will not bypass the I/O address queue.<br>1—CIA will bypass the I/O address queue. See<br>Table 4–11.                                                                                    |
| <16>    | IO_FLUSHREQ_<br>EN  | RW,0 | Used in combination with CPU_FLUSHREQ_EN.<br>The two bits control the CIA's response to a PCI<br>master, causing a flush request to the 21164.                                                 |
| <17>    | CPU_FLUSHREQ_<br>EN | RW,0 | See IO_FLUSHREQ_EN and Table 4–11.                                                                                                                                                             |
| <18>    | ARB_CPU_EN          | RW,0 | 0—Disable the bypass path from the 21164 into the<br>memory and IOA queue.<br>1—Enable the bypass path from the 21164 into the<br>memory and IOA queue.                                        |
| <19>    | EN_ARB_LINK         | RW,0 | 0—Disable CPU memory read transactions from<br>creating an arbitration link (sharing a common <b>ras</b><br>cycle).<br>1—Enable CPU memory read transactions to create<br>an arbitration link. |
| <21:20> | RD_TYPE             | RW,0 | This field controls the prefetch algorithm used for PCI memory read commands. See Table 4–12.                                                                                                  |
| <23:22> | Reserved            | RO,0 | _                                                                                                                                                                                              |
| <25:24> | RL_TYPE             | RW,0 | This field controls the prefetch algorithm used for PCI memory read line commands. See Table 4–12.                                                                                             |
| <27:26> | Reserved            | RO,0 | _                                                                                                                                                                                              |
| <29:28> | RM_TYPE             | RW,0 | This field controls the prefetch algorithm used for PCI memory read multiple commands. See Table 4–12.                                                                                         |
| <30>    | Reserved            | RO,0 | _                                                                                                                                                                                              |
| <31>    | EN_DMA_RD_<br>PERF  | RW,1 | 0—Disable the DMA read performance logic.<br>1—Enable the DMA read performance logic.                                                                                                          |

#### Table 4–10 (Cont.) CIA Control Register

| IO_FLUSH_REQ_EN | CPU_FLUSH_REQ_EN | Response                                                                                                  |
|-----------------|------------------|-----------------------------------------------------------------------------------------------------------|
| 0               | 0                | Assert <b>mem_ack_l</b> immediately.                                                                      |
| 0               | 1                | Assert <b>mem_ack_l</b> immediately and do not allow new CPU commands to proceed.                         |
| 1               | 0                | Illegal.                                                                                                  |
| 1               | 1                | Wait until IOA queue is empty, then assert <b>mem_ack_l</b> but do not allow new CPU commands to proceed. |

#### Table 4–11 CPU and I/O Flush Request

#### Table 4–12 PCI READ Prefetch Algorithm

| RL_TYPE | Туре     | Description                                                                |
|---------|----------|----------------------------------------------------------------------------|
| 0 0     | Short    | Fetch requested longword or quadword and the remainder of the cache block. |
| 0 1     | Medium   | Prefetch next block and no more. Will not cross 8KB page boundary.         |
| 1 0     | Long     | Keep prefetching until PCI transaction completes. Will not cross 8KB page. |
| 1 1     | Reserved | _                                                                          |

#### 4.2.4 Hardware Address Extension Memory Register (HAE\_MEM)

This hardware address extension register is used to extend a PCI sparse-space memory address up to the full 32-bit PCI address.

In sparse-addressing mode, the 21164 address provides the low-order PCI address bits. The high-order PCI address bits <31:26> are obtained from either the hardware address extension register or the 21164 address, depending on sparse regions, as shown in Table 4–13.

#### Figure 4–4 Hardware Address Extension Memory Register (87.4000.0400)



LJ-04229.AI

| Region <sup>1</sup> | PCI Address |         |         |         |         |         |  |  |  |  |  |  |  |
|---------------------|-------------|---------|---------|---------|---------|---------|--|--|--|--|--|--|--|
| -                   | <31>        | <30>    | <29>    | <28>    | <27>    | <26>    |  |  |  |  |  |  |  |
| 1                   | HAE_MEM     | HAE_MEM | HAE_MEM | 21164   | 21164   | 21164   |  |  |  |  |  |  |  |
|                     | <31>        | <30>    | <29>    | <33>    | <32>    | <31>    |  |  |  |  |  |  |  |
| 2                   | HAE_MEM     | HAE_MEM | HAE_MEM | HAE_MEM | HAE_MEM | 21164   |  |  |  |  |  |  |  |
|                     | <15>        | <14>    | <13>    | <12>    | <11>    | <31>    |  |  |  |  |  |  |  |
| 3                   | HAE_MEM     | HAE_MEM | HAE_MEM | HAE_MEM | HAE_MEM | HAE_MEM |  |  |  |  |  |  |  |
|                     | <7>         | <6>     | <5>     | <4>     | <3>     | <2>     |  |  |  |  |  |  |  |

Table 4–13 HAE\_MEM High-Order Sparse-Space Bits

Region 2 is 84.0000.0000 to 83.FFFF.FFFF. Region 3 is 85.0000.0000 to 85.7FFF.FFFF.

Table 4–14 lists the address range of each of the three regions.

| Name     | Туре                                         | 21164 Address Range                              |
|----------|----------------------------------------------|--------------------------------------------------|
|          | <b>7</b>   • •                               | 21104 Address Range                              |
| Region 1 | RW,0                                         | 80.0000.0000-83.FFFF.FFFF                        |
| Reserved | RW,0                                         | —                                                |
| Region 2 | RW,0                                         | 84.0000.0000-84.FFFF.FFFF                        |
| Reserved | RW,0                                         | —                                                |
| Region 3 | RW,0                                         | 85.0000.0000-85.7FFF.FFFF                        |
| Reserved | RW,0                                         | _                                                |
|          | Reserved<br>Region 2<br>Reserved<br>Region 3 | ReservedRW,0Region 2RW,0ReservedRW,0Region 3RW,0 |

 Table 4–14
 Hardware Address Extension Memory Register

Initializing this register to  $0000.2028_{16}$  will make all three regions contiguous starting at PCI address 0.

### 4.2.5 Hardware Address Extension I/O Register (HAE\_IO)





This hardware address extension register is used to extend a PCI sparse-space I/O address up to the full 32-bit PCI address. In sparse-addressing mode, the 21164 address provides the PCI address <24:0> and HAE\_IO provides <31:25>.

At power-up this register is set to zero. In this case, sparse I/O region A and region B both map to the lower 32MB of sparse I/O space. Setting HAE\_IO to 0200 0000 will make regions A and B consecutive in the lower 64MB of PCI I/O space.

Table 4–15 Hardware Address Extension I/O Register

| Field   | Name     | Туре | Description                                                          |
|---------|----------|------|----------------------------------------------------------------------|
| <24:0>  | Reserved | RO,0 | _                                                                    |
| <31:25> | HAE_IO   | RW,0 | In sparse-address mode, this field provides address bits $<31:25>$ . |

# 4.2.6 Configuration Register (CFG)

The CFG field bits are used as the low two address bits during an access to PCI configuration space.

#### Figure 4–6 Configuration Register (87.4000.0480)



LJ-04231.AI

#### Table 4–16 Configuration Register

|       | Name | Туре | Description |                            |  |
|-------|------|------|-------------|----------------------------|--|
| <1:0> | CFG  | RW,0 | PCI configu | ration space access type:  |  |
|       |      |      | CFG<1:0>    | Meaning                    |  |
|       |      |      | 0 0         | Type 0 configuration cycle |  |
|       |      |      | 0 1         | Type 1 configuration cycle |  |
|       |      |      | 1 x         | Reserved                   |  |

#### 4.2.7 CIA Acknowledgment Enable Register (CACK\_EN)

The CIA acknowledgment register (CACK\_EN) allows software to decide if the CIA will acknowledge receipt any of four particular commands from the 21164 or to ignore any of these commands (NOP response).





LJ-04232.AI

Table 4–17 CIA Acknowledgment Enable Register

| Field  | Name         | Туре | Description                                                                 |
|--------|--------------|------|-----------------------------------------------------------------------------|
| <0>    | LOCK_EN      | RW,1 | 1—Enables CIA to acknowledge receipt of a LOCK command from the 21164.      |
| <1>    | MB_EN        | RW,1 | 1—Enables CIA to acknowledge receipt of an MB command from 21164.           |
| <2>    | SET_DIRTY_EN | RW,1 | 1—Enables CIA to acknowledge receipt of a SET DIRTY command from the 21164. |
| <3>    | BC_VICTIM_EN | RW,1 | 1—Enables CIA to acknowledge receipt of a BC_VICTIM command from the 21164. |
| <31:4> | Reserved     | RO,0 | _                                                                           |

#### DECchip 21171-CA Control and Status Registers 4.3 DECchip 21171-CA Diagnostic Registers

# 4.3 DECchip 21171-CA Diagnostic Registers

This section defines and describes the DECchip 21171-CA diagnostic registers.

### 4.3.1 CIA Diagnostic Control Register (CIA\_DIAG)

The CIA\_DIAG is used as a diagnostic/debug tool, allowing various errors to be tested.

#### Figure 4-8 CIA Diagnostic Control Register (87.4000.2000)



LJ-04233.AI

| Table 4–18 | CIA Diagnostic Control Register |  |
|------------|---------------------------------|--|
|------------|---------------------------------|--|

| Field  | Name        | Туре | Description                                                                                                                                       |
|--------|-------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| <0>    | FROM_WRT_EN | RW,0 | 0-Flash ROM cannot be programmed. A write<br>transaction to flash ROM results in a system<br>machine check.<br>1—The flash ROM can be programmed. |
| <1>    | USE_CHECK   | RW,0 | 1—Use DIAG_CHECK<7:0> for DMA write cycle ECC sent on the IOD bus.                                                                                |
| <27:2> | Reserved    | RO,0 | _                                                                                                                                                 |
|        |             |      | (continued on next page)                                                                                                                          |

# DECchip 21171-CA Control and Status Registers 4.3 DECchip 21171-CA Diagnostic Registers

| Field   | Name       | Туре | Description                      |                                                                                                                  |
|---------|------------|------|----------------------------------|------------------------------------------------------------------------------------------------------------------|
| <29:28> | FPE_PCI    | RW,0 | This field all<br>for diagnostic | ows bad parity to be forced on the PCI<br>c purposes:                                                            |
|         |            |      | FPE_PCI<br><1:0>                 | Meaning                                                                                                          |
|         |            |      | 0 0                              | Normal parity asserted on PCI.                                                                                   |
|         |            |      | 0 1                              | Bad parity is forced onto<br><b>ad_h&lt;31:0</b> > during data cycles.                                           |
|         |            |      | 1 0                              | Bad parity is forced onto<br><b>ad_h&lt;63:32</b> > during data cycles.                                          |
|         |            |      | 1 1                              | Bad parity is forced onto<br><b>ad_h&lt;31:0</b> > and <b>ad_h&lt;63:32</b> ><br>during address and data cycles. |
| <30>    | Reserved   | RO,0 | _                                |                                                                                                                  |
| <31>    | FPE_TO_CPU | RW,0 | 1 5                              | error is forced on the 21164<br>nand bus when the CIA is the bus                                                 |

# Table 4–18 (Cont.) CIA Diagnostic Control Register

#### DECchip 21171-CA Control and Status Registers 4.3 DECchip 21171-CA Diagnostic Registers

### 4.3.2 Diagnostic Check Register (DIAG\_CHECK)

The DIAG\_CHECK is used to cause diagnostic DMA write transactions to force a known ECC pattern into memory. This register provides the ECC value that is written to memory if CIA\_DIAG[USE\_CHECK] is set.

#### Figure 4–9 Diagnostic Check Register (87.4000.3000)



Table 4–19 Diagnostic Check Register

| Field  | Name       | Туре         | Description                                                                   |
|--------|------------|--------------|-------------------------------------------------------------------------------|
| <7:0>  | DIAG_CHECK | RW,UNDEFINED | This register provides the quadword ECC for diagostic DMA write transactions. |
| <31:8> | Reserved   | RO,0         | _                                                                             |

# 4.4 DECchip 21171-CA Performance Monitor Registers

This section defines and describes the DECchip 21171-CA (CIA) performance monitor registers.

### 4.4.1 Performance Monitor Register (PERF\_MONITOR)

The performance monitor register is two 16-bit counters that can be programmed to count a variety of events. The performance control register is used to set up the counters. Each counter can be programmed to count events such as 21164 read miss transactions received by the CIA or DMA write transactions. This register can also be set up as a single 32-bit counter by directing the high counter to count the low counter overflow.

#### Figure 4–10 Performance Monitor Register (87.4000.4000)



 Table 4–20
 Performance Monitor Register

| Field   | Name       | Туре | Description                |
|---------|------------|------|----------------------------|
| <15:0>  | LOW_COUNT  | RO,0 | Value of the low counter.  |
| <31:16> | HIGH_COUNT | RO,0 | Value of the high counter. |

# 4.4.2 Performance Control Register (PERF\_CONTROL)





LJ-04236.AI

 Table 4–21
 Performance Control Register

| Field   | Name            | Туре | Description                                                                           |
|---------|-----------------|------|---------------------------------------------------------------------------------------|
| <7:0>   | LOW_SELECT      | RW,0 | See Table 4–22.                                                                       |
| <12:8>  | Reserved        | RO,0 | _                                                                                     |
| <13>    | LOW_COUNT_CLR   | WO,0 | Write a one to clear the low counter.                                                 |
| <14>    | LOW_ERR_STOP    | RW,0 | If the CIA encounters an error and this bit is set, then stop the low error counter.  |
| <15>    | LOW_COUNT_START | RW,0 | 0—Do not count. Keep current values.<br>1—Start counting.                             |
| <23:16> | HIGH_SELECT     | RW,0 | See Table 4–22.                                                                       |
| <28:24> | Reserved        | RO,0 | _                                                                                     |
| <29>    | HIGH_COUNT_CLR  | WO,0 | Write a one to clear the high counter.                                                |
| <30>    | HIGH_ERR_STOP   | RW,0 | If the CIA encounters an error and this bit is set, then stop the high error counter. |
|         |                 |      |                                                                                       |

(continued on next page)

| Table 4–21 (Cont.) Performance Control Register | Table 4–21 ( |
|-------------------------------------------------|--------------|
|-------------------------------------------------|--------------|

| Field | Name             | Туре | Description                                               |
|-------|------------------|------|-----------------------------------------------------------|
| <31>  | HIGH_COUNT_START | RW,0 | 0—Do not count. Keep current values.<br>1—Start counting. |

| Table 4–22 | PERF_ | CONTROL | Low/High | Select | Encodings |
|------------|-------|---------|----------|--------|-----------|
|------------|-------|---------|----------|--------|-----------|

| Select <sup>1</sup> | Description                                                                        |  |  |
|---------------------|------------------------------------------------------------------------------------|--|--|
| 0000 0000           | LOW_SELECT—The value is reserved.<br>HIGH_SELECT—Make 32-bit counter.              |  |  |
| 0000 0001           | Counting clock cycles—always increment.                                            |  |  |
| 0000 0010           | Counting refresh cycles.                                                           |  |  |
| 0001 0000           | Counting number of 21164 commands acknowledged                                     |  |  |
| 0001 0001           | Counting number of 21164 read commands (modify or not).                            |  |  |
| 0001 0010           | Counting number of 21164 read miss commands (not modify).                          |  |  |
| 0001 0011           | Counting number of 21164 read miss modify commands.                                |  |  |
| 0001 0100           | Counting number of 21164 Bcache victim commands that are acknowledged by the CIA.  |  |  |
| 0001 0101           | Counting number of 21164 lock commands that are acknowledged by the CIA.           |  |  |
| 0001 0110           | Counting number of 21164 memory barrier commands that are acknowledged by the CIA. |  |  |
| 0001 0111           | Counting number of 21164 FETCH or FETCH_M commands.                                |  |  |
| 0001 1000           | Counting number of 21164 write block commands (lock or not).                       |  |  |
| 0010 0000           | Counting number of 21164 memory commands.                                          |  |  |
| 0010 0001           | Counting number of 21164 I/O commands.                                             |  |  |
| 0010 0010           | Counting number of 21164 I/O read commands.                                        |  |  |
| 0010 0011           | Counting number of 21164 I/O write commands.                                       |  |  |
| 0010 0100           | Counting number of CIA system commands issued (read/flush).                        |  |  |
| 0010 0101           | Counting number of 21164 system read commands issued.                              |  |  |
| 0010 0110           | Counting number of 21164 system flush commands issued.                             |  |  |
| 0010 0111           | Counting number of times CIA received NOACK as a response.                         |  |  |

<sup>1</sup>Select = HIGH\_SELECT <23:16> and LOW\_SELECT <7:0>.

(continued on next page)

Table 4–22 (Cont.) PERF\_CONTROL Low/High Select Encodings

| Select <sup>1</sup> | Description                                                                             |  |  |  |
|---------------------|-----------------------------------------------------------------------------------------|--|--|--|
| 0010 1000           | Counting number of times CIA received Scache/ACK as a response.                         |  |  |  |
| 0010 1001           | Counting number of times CIA received Bcache/ACK as a response.                         |  |  |  |
| 0011 0000           | Counting number of DMA read commands (total).                                           |  |  |  |
| 0011 0001           | Counting number of DMA read commands.                                                   |  |  |  |
| 0011 0010           | Counting number of DMA read commands (read line).                                       |  |  |  |
| 0011 0011           | Counting number of DMA read commands (read multiple).                                   |  |  |  |
| 0011 0100           | Counting number of DMA write commands (total).                                          |  |  |  |
| 0011 0101           | Counting number of DMA write commands.                                                  |  |  |  |
| 0011 0110           | Counting number of DMA write commands (write and invalidate).                           |  |  |  |
| 0011 0111           | Counting number of DMA dual address cycles.                                             |  |  |  |
| 0011 1000           | Counting number of DMA cycles that CIA responded to by issuing a retry.                 |  |  |  |
| 0011 1001           | Counting number of I/O cycles on which CIA received a retry response.                   |  |  |  |
| 0100 0000           | Counting number of times PCI bus lock was established.                                  |  |  |  |
| 0100 0001           | Counting number of times 21164 tried to access block that was locked.                   |  |  |  |
| 0100 0010           | Counting number of times DMA commands (that caused a flux<br>hit on the victim address. |  |  |  |
| 0101 0000           | Counting number of times CIA had to refill the translation lookaside buffer (TLB).      |  |  |  |
| 0110 0000           | Counting number of single-bit ECC errors detected.                                      |  |  |  |
| All others          | Reserved, unused, not counting.                                                         |  |  |  |

# 4.5 DECchip 21171-CA Error Registers

This section defines and describes the DECchip 21171-CA (CIA) error registers.

# 4.5.1 CPU Error Information Register 0 (CPU\_ERR0)

The low-order address bits of the sysBus are locked into this register when the CIA detects an error event. Clearing all the error bits in CIA\_ERR unlocks this register. When CPU\_ERR0 is not locked, its contents are UNDEFINED.

The information in CPU\_ERR0 and CPU\_ERR1 is only related to sysBus parity errors detected by the CIA.

#### Figure 4–12 CPU Error Information Register 0 (87.4000.8000)



Table 4–23 CPU Error Information Register 0

| Field  | Name         | Туре         | Description                                                                                   |
|--------|--------------|--------------|-----------------------------------------------------------------------------------------------|
| <3:0>  | Reserved     | R0,0         | _                                                                                             |
| <31:4> | ADDR_H<31:4> | RO,UNDEFINED | Contains address bits <31:4> of the current address on the sysBus when a sysBus error occurs. |

## 4.5.2 CPU Error Information Register 1 (CPU\_ERR1)

The mask and command field and the remaining address field on the sysBus are locked into CPU\_ERR1 when the CIA detects a event error. Clearing all the error bits in CIA\_ERR unlocks CPU\_ERR1. When CPU\_ERR1 is not locked, its contents are UNDEFINED.

The information in CPU\_ERR0 and CPU\_ERR1 is only related to sysBus parity errors detected by the CIA (CPU\_ERR<2 > = 1).

## Figure 4–13 CPU Error Information Register 1 (87.4000.8040)



LJ-04238.AI

| Table 4–24 | CPU Error | Information | Register 1 |
|------------|-----------|-------------|------------|
|------------|-----------|-------------|------------|

| Field  | Name        | Туре             | Description                                        |
|--------|-------------|------------------|----------------------------------------------------|
| <2:0>  | ADDR<34:32> | RO,<br>UNDEFINED | Contains <b>addr_h&lt;34:32</b> > from the sysBus. |
| <6:3>  | Reserved    | RO,0             | _                                                  |
| <7>    | ADDR<39>    | RO,<br>UNDEFINED | Contains <b>addr_h&lt;39</b> > from the sysBus.    |
| <11:8> | CMD         | RO,<br>UNDEFINED | Contains the command from the sysBus.              |
|        |             |                  | (continued on next page)                           |

Preliminary Edition—Subject to Change—September 1995 4-27

| Field   | Name         | Туре             | Description                                                       |
|---------|--------------|------------------|-------------------------------------------------------------------|
| <15:12> | INT4_VALID   | RO,<br>UNDEFINED | Contains <b>int4_valid_h&lt;3:0</b> > from the sysBus.            |
| <20:16> | Reserved     | RO,0             | —                                                                 |
| <21>    | ADDR_CMD_PAR | RO,<br>UNDEFINED | Contains the parity bit from the sysBus.                          |
| <29:22> | Reserved     | RO,0             | _                                                                 |
| <30>    | FPE_2_CPU    | RO,<br>UNDEFINED | Contains a copy of the CSR bit to force bad parity on the sysBus. |
| <31>    | CPU_PE       | RO,<br>UNDEFINED | 1—Indicates that the CIA has logged a sysBus error.               |

Table 4–24 (Cont.) CPU Error Information Register 1

## 4.5.3 CIA Error Register (CIA\_ERR)

The CIA error register is used by the CIA to log information about an error condition detected in the CIA. All bits of CIA\_ERR, except the LOST bit, will be locked until the CIA\_ERR register is cleared by a write transaction. The LOST bit will be set whenever an error is detected and CIA\_ERR is already locked.

## Figure 4–14 CIA Error Register (87.4000.8200)



LJ-04239.AI

| Table 4–25 | CIA Error | Register |
|------------|-----------|----------|
|------------|-----------|----------|

| Field | Name         | Туре   | Description                                                                                                                                                                            |
|-------|--------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <0>   | COR_ERR      | RW1C,0 | Corrected single-bit ECC error detected.<br>This error cannot occur for a 21164 to memory<br>read/write:                                                                               |
|       |              |        | • 21164/memory read ECC errors are detected by the 21164.                                                                                                                              |
|       |              |        | • 21164/memory write transactions are not checked.                                                                                                                                     |
|       |              |        | This error is applicable to a DMA transaction, a scatter-gather TLB miss, or an I/O write transaction from the 21164.                                                                  |
| <1>   | UN_COR_ERR   | RW1C,0 | Uncorrectable ECC error detected (double-bit error<br>or single-bit error if correction disabled).<br>This error cannot occur for a 21164-to-memory<br>read/write transaction because: |
|       |              |        | • 21164/memory read transaction ECC errors are detected by the 21164.                                                                                                                  |
|       |              |        | • 21164/memory write transactions are not checked.                                                                                                                                     |
|       |              |        | This error is applicable to a DMA transaction, a scatter-gather TLB miss, or an I/O write transactior from the 21164.                                                                  |
| <2>   | CPU_PE       | RW1C,0 | sysBus parity error detected.                                                                                                                                                          |
| <3>   | MEM_NEM      | RW1C,0 | Access to nonexistent memory detected.                                                                                                                                                 |
| <4>   | PCI_SERR     | RW1C,0 | PCI bus system error (SERR) detected.                                                                                                                                                  |
| <5>   | PERR         | RW1C,0 | PCI bus data parity error (PERR) detected.                                                                                                                                             |
| <6>   | PCI_ADDR_PE  | RW1C,0 | PCI bus address parity error detected.                                                                                                                                                 |
| <7>   | RCVD_MAS_ABT | RW1C,0 | PCI master state machine generated master abort.                                                                                                                                       |
| <8>   | RCVD_TAR_ABT | RW1C,0 | PCI master state machine received target abort.                                                                                                                                        |
| <9>   | PA_PTE_INV   | RW1C,0 | Invalid page table entry (PTE) on scatter-gather access.                                                                                                                               |
| <10>  | FROM_WRT_ERR | RW1C,0 | Write to flash ROM attempted without setting CIA_DIAG[FROM_WRT_EN].                                                                                                                    |
|       |              |        | (continued on next page                                                                                                                                                                |

(continued on next page)

| Field   | Name                  | Туре   | Description                                                                                                          |
|---------|-----------------------|--------|----------------------------------------------------------------------------------------------------------------------|
| <11>    | IOA_TIMEOUT           | RW1C,0 | I/O timeout occurred. I/O read/write transaction failed to complete in 1 second.                                     |
| <15:12> | Reserved              | RO,0   | _                                                                                                                    |
| <16>    | LOST_COR_ERR          | RO,0   | A correctable error was detected while CIA_ERR wa locked.                                                            |
| <17>    | LOST_UN_COR_<br>ERR   | RO,0   | An uncorrectable error was detected while CIA_ERF was locked.                                                        |
| <18>    | LOST_CPU_PE           | RO,0   | A sysBus parity error was detected while CIA_ERR was locked.                                                         |
| <19>    | LOST_MEM_NEM          | RO,0   | An access to nonexistent memory was detected while CIA_ERR was locked.                                               |
| <20>    | Reserved              | RO,0   | _                                                                                                                    |
| <21>    | LOST_PERR             | RO,0   | A PCI data parity error was detected while CIA_ERI was locked.                                                       |
| <22>    | LOST_PCI_ADDR_<br>PE  | RO,0   | A PCI address parity error was detected while CIA_ERR was locked.                                                    |
| <23>    | LOST_RCVD_<br>MAS_ABT | RO,0   | The PCI master state machine generated a master abort while CIA_ERR was locked.                                      |
| <24>    | LOST_RCVD_TAR_<br>ABT | RO,0   | The PCI master state machine received a target abort while CIA_ERR was locked.                                       |
| <25>    | LOST_PA_PTE_<br>INV   | RO,0   | An invalid page table entry on scatter-gather access occurred while CIA_ERR was locked.                              |
| <26>    | LOST_FROM_<br>WRT_ERR | RO,0   | A write transaction to flash ROM was attempted,<br>with<br>CIA_DIAG[FROM_WRT_EN] clear, while CIA_ERR<br>was locked. |
| <27>    | LOST_IOA_<br>TIMEOUT  | RO,0   | An I/O timeout occurred while CIA_ERR was locked<br>An I/O read/write transaction failed to complete in<br>1 second. |
| <30:28> | Reserved              | RO,0   | _                                                                                                                    |
| <31>    | ERR_VALID             | RO,0   | An error has been detected and the CIA error registers are all locked.                                               |

## Table 4–25 (Cont.) CIA Error Register

## 4.5.4 CIA Status Register (CIA\_STAT)

This register contains status information about the error stored in CIA\_ERR. The register provides the state of the CIA when the error was detected.



## Figure 4–15 CIA Status Register (87.4000.8240)

LJ-04240.AI

#### Table 4–26 CIA Status Register

| Field  | Name           | Туре | Description                                                                            |
|--------|----------------|------|----------------------------------------------------------------------------------------|
| <0>    | PCI_STATUS<0>  | RO,0 | 1—The PCI target state machine is active.                                              |
| <1>    | PCI_STATUS<1>  | RO,0 | 1—The PCI master state machine is active.                                              |
| <2>    | Reserved       | RO,0 | _                                                                                      |
| <3>    | MEM_SOURCE     | RO,0 | 0—21164 is the source of the memory cycle.<br>1—PCI is the source of the memory cycle. |
| <7:4>  | IOA_VALID<3:0> | RO,0 | Valid bits for the I/O command/address queue.                                          |
| <10:8> | CPU_QUEUE<2:0> | RO,0 | Valid bits for the 21164 command/address queue.                                        |
| <11>   | TLB_MISS       | RO,0 | 1—A TLB miss refill was in progress when the error occurred.                           |
|        |                |      | (continued on next page)                                                               |

| Field   | Name            | Туре             | Description                                                                               |                                                      |  |
|---------|-----------------|------------------|-------------------------------------------------------------------------------------------|------------------------------------------------------|--|
| <15:12> | DM_ST<3:0>      | RO,<br>UNDEFINED | This field represents the state of the logic that moves data between the CIA and the DSW: |                                                      |  |
|         |                 |                  | DM_ST<3:0>                                                                                | Definition                                           |  |
|         |                 |                  | 0000                                                                                      | Idle                                                 |  |
|         |                 |                  | 0001                                                                                      | Restarting DSW IOW buffers                           |  |
|         |                 |                  | 0010                                                                                      | I/O write transaction to the 64-bit PCI bus          |  |
|         |                 |                  | 0110                                                                                      | DMA read transaction or TLB miss                     |  |
|         |                 |                  | 0111                                                                                      | DMA write transaction                                |  |
|         |                 |                  | 1010                                                                                      | I/O read transaction to an internal CIA CSR          |  |
|         |                 |                  | 1011                                                                                      | I/O read transaction to the PCI bus (32-bit/64-bit). |  |
|         |                 |                  | All others                                                                                | Reserved                                             |  |
| <17:16> | PA_CPU_RES<1:0> | RO,0             | 21164 respons<br>00 = No re<br>01 = NOA<br>10 = Scacl<br>11 = Bcacl                       | CK<br>he hit                                         |  |
| <31:18> | Reserved        | RO,0             | _                                                                                         |                                                      |  |

# Table 4–26 (Cont.) CIA Status Register

## 4.5.5 CIA Error Mask Register (ERR\_MASK)

ERR\_MASK is used to disable the logging and reporting of errors. A zero disables logging/reporting of errors while a one enables logging/reporting of errors.



### Figure 4–16 CIA Error Mask Register (87.4000.8280)

LJ-04241.AI

| Table 4–27 | CIA | Error | Mask | Register |
|------------|-----|-------|------|----------|
|------------|-----|-------|------|----------|

|       |            | •    |                                                                                   |
|-------|------------|------|-----------------------------------------------------------------------------------|
| Field | Name       | Туре | Description                                                                       |
| <0>   | CORR_ERR   | RW,0 | Disable/enable error logging/reporting for correctable ECC errors.                |
| <1>   | UN_COR_ERR | RW,0 | Disable/enable error logging/reporting for uncor-<br>rectable ECC errors.         |
| <2>   | CPU_PE     | RW,0 | Disable/enable error logging/reporting for 21164 parity errors.                   |
| <3>   | MEM_NEM    | RW,0 | Disable/enable error logging/reporting for nonexis-<br>tent memory access errors. |

(continued on next page)

| Field   | Name         | Туре | Description                                                           |
|---------|--------------|------|-----------------------------------------------------------------------|
| <4>     | PCI_SERR     | RW,0 | Disable/enable error logging/reporting for PCI system errors.         |
| <5>     | PERR         | RW,0 | Disable/enable error logging/reporting for PCI data parity errors.    |
| <6>     | PCI_ADDR_PE  | RW,0 | Disable/enable error logging/reporting for PCI address parity errors. |
| <7>     | RCVD_MAS_ABT | RW,0 | Disable/enable error logging/reporting for PCI master abort errors.   |
| <8>     | RCVD_TAR_ABT | RW,0 | Disable/enable error logging/reporting for PCI target abort errors.   |
| <9>     | PA_PTE_INV   | RW,0 | Disable/enable error logging/reporting for invalid<br>PTE errors.     |
| <10>    | FROM_WRT_ERR | RW,0 | Disable/enable error logging/reporting for flash ROM write errors.    |
| <11>    | IOA_TIMEOUT  | RW,0 | Disable/enable error logging/reporting for I/O timeout errors.        |
| <31:12> | Reserved     | RW,0 | _                                                                     |

Table 4–27 (Cont.) CIA Error Mask Register

# 4.5.6 CIA Syndrome Register (CIA\_SYN)

The CIA uses CIA\_SYN to log syndrome information about an error detected by the ECC checkers. The syndrome information is locked into CIA\_SYN when a CIA error occurs. Clearing all the error bits in CIA\_ERR unlocks this register. When CIA\_SYN is not locked its contents are UNDEFINED.

### Figure 4–17 CIA Syndrome Register (87.4000.8300)



LJ-04242.AI

| Field  | Name         | Туре             | Description                                                                        |
|--------|--------------|------------------|------------------------------------------------------------------------------------|
| <7:0>  | ECC_SYNDROME | RO,<br>UNDEFINED | The syndrome is locked in ECC_SYNDROME <7:0> when an error is detected by the CIA. |
| <31:8> | Reserved     | RO,0             | _                                                                                  |

Table 4–28 CIA Syndrome Register

Table 4–29 lists the ECC syndromes for single-bit errors.

Table 4–29 ECC Syndromes for Single-Bit Errors

| Bit <sub>10</sub> | Syndrome <sub>16</sub> |
|-------------------|------------------------|-------------------|------------------------|-------------------|------------------------|-------------------|------------------------|
|                   |                        |                   | Syndrome               | es for Da         | ata Bits               |                   |                        |
| 00                | CE                     | 01                | СВ                     | 02                | D3                     | 03                | D5                     |
| 04                | D6                     | 05                | D9                     | 06                | DA                     | 07                | DC                     |
| 08                | 23                     | 09                | 25                     | 10                | 26                     | 11                | 29                     |
| 12                | 2A                     | 13                | 2C                     | 14                | 31                     | 15                | 34                     |
| 16                | 0E                     | 17                | 0B                     | 18                | 13                     | 19                | 15                     |
| 20                | 16                     | 21                | 19                     | 22                | 1A                     | 23                | 1C                     |
| 24                | E3                     | 25                | E5                     | 26                | E6                     | 27                | E9                     |
| 28                | EA                     | 29                | EC                     | 30                | F1                     | 31                | F4                     |
| 32                | 4F                     | 33                | 4A                     | 34                | 52                     | 35                | 54                     |
| 36                | 57                     | 37                | 58                     | 38                | 5B                     | 39                | 5D                     |
| 40                | A2                     | 41                | A4                     | 42                | A7                     | 43                | A8                     |
| 44                | AB                     | 45                | AD                     | 46                | B0                     | 47                | B5                     |
| 48                | 8F                     | 49                | 8A                     | 50                | 92                     | 51                | 94                     |
| 52                | 97                     | 53                | 98                     | 54                | 9B                     | 55                | 9D                     |
| 56                | 62                     | 57                | 64                     | 58                | 67                     | 59                | 68                     |
| 60                | 6B                     | 61                | 6D                     | 62                | 70                     | 63                | 75                     |
|                   |                        |                   | Syndrome               | s for Ch          | eck Bits               |                   |                        |
| 00                | 01                     | 01                | 02                     | 02                | 04                     | 03                | 08                     |
| 04                | 10                     | 05                | 20                     | 06                | 40                     | 07                | 80                     |

## 4.5.7 CIA Memory Port Status Register 0 (MEM\_ERR0)

The low-order address bits of the memory port address bus are locked into MEM\_ERR0 upon a CIA-detected error. Clearing all the error bits in CIA\_ERR unlocks this register. If the register is not locked, the contents are UNDEFINED.

### Figure 4–18 CIA Memory Port Status Register 0 (87.4000.8400)



LJ-04243.AI

 Table 4–30
 CIA Memory Port Status Register 0

| Field  | Name                    | Туре             | Description                                                                                           |
|--------|-------------------------|------------------|-------------------------------------------------------------------------------------------------------|
| <3:0>  | Reserved                | RO,<br>UNDEFINED | _                                                                                                     |
| <31:4> | MEM_PORT_<br>ADDR<31:4> | RO,<br>UNDEFINED | Contains address bits <31:4> of the current address in the memory port when the CIA detects an error. |

## 4.5.8 CIA Memory Port Status Register 1 (MEM\_ERR1)

The command memory mask (**int4\_valid**<**3:0**> from the CPU), memory sequencer state, the source of the command, and encoded set select field, and the remaining address field are locked into MEM\_ERR1 upon a CIA error. Clearing all error bits in CIA\_ERR unlocks this register. If the register is not locked, the contents are UNDEFINED.



#### Figure 4–19 CIA Memory Port Status Register 1 (87.4000.8440)

LJ-04244.AI

| Table 4–31 CIA | Memory | Port Status | Register 1 |
|----------------|--------|-------------|------------|
|----------------|--------|-------------|------------|

| Field  | Name                     | Туре             | Description                                                                                      |
|--------|--------------------------|------------------|--------------------------------------------------------------------------------------------------|
| <1:0>  | MEM_PORT_<br>ADDR<33:32> | RO,<br>UNDEFINED | Captures memory port address bits <33:32> when the CIA detects an error.                         |
| <6:2>  | Reserved                 | RO,0             | _                                                                                                |
| <7>    | MEM_PORT_<br>ADDR<39>    | RW,<br>UNDEFINED | Captures memory port address bit <39> when the CIA detects an error.                             |
| <11:8> | MEM_PORT_CMD             | RO,<br>UNDEFINED | Contains command field of the memory port when a CIA error is detected, as listed in Table 4–32. |

(continued on next page)

| Field   | Name            | Туре             | Description                                                                                                     |
|---------|-----------------|------------------|-----------------------------------------------------------------------------------------------------------------|
| <15:12> | MEM_PORT_MASK   | RW,<br>UNDEFINED | The mask bits when the error occurred.                                                                          |
| <19:16> | SEQ_ST          | RW,<br>UNDEFINED | The memory sequencer state when the error occurred, as listed in Table 4–33.                                    |
| <20>    | MEM_PORT_SOURCE | RW,<br>UNDEFINED | Source of the memory command:<br>0—21164 is source of memory command.<br>1—DMA is source of memory command.     |
| <23:21> | Reserved        | RO,0             | _                                                                                                               |
| <28:24> | SET_SEL_ENC     | RW,<br>UNDEFINED | Encoded set select indicates which<br>memory set was active when the error<br>occurred as listed in Table 4–34. |
| <31:29> | Reserved        | RO,0             | _                                                                                                               |

Table 4–31 (Cont.) CIA Memory Port Status Register 1

## Table 4–32 Memory Port Command Field (MEM\_PORT\_CMD)

| MEM_PORT_ |              |                                       |
|-----------|--------------|---------------------------------------|
| SOURCE    | MEM_PORT_CMD | Description                           |
| 0         | 011X         | 21164 WRITE BLOCK or WRITE BLOCK LOCK |
| 0         | 10XX         | 21164 READ MISS, READ MISS MODIFY     |
| 0         | 1100         | 21164 BC_VICTIM                       |
| 0         | 111X         | 21164 READ MISS MODIFY                |
| 1         | 10XX         | DMA READ, DMA READ MODIFY             |
| 1         | 001X         | DMA WRITE                             |

| Table 4–33 | Memory | <sup>v</sup> Sequencer | State | Field | (SEQ_ | ST) |
|------------|--------|------------------------|-------|-------|-------|-----|
|------------|--------|------------------------|-------|-------|-------|-----|

| SEQ_ST            | Description                                          |
|-------------------|------------------------------------------------------|
| 0000              | Idle.                                                |
| 0001              | DMA read or write.                                   |
| 0010, 0011        | 21164 READ MISS (or READ MISS MDOIFY) with victim.   |
| 0100, 0101, 0110  | 21164 READ MISS (or READ MISS MODIFY) with no victim |
| 01F11, 1000, 1001 | Refresh.                                             |
| 1100              | Idle. Waiting for DMA pending read.                  |
| 1110, 1111        | Idle. <b>ras_h</b> precharge                         |

| SET_SEL_ENC | Description               |
|-------------|---------------------------|
| 00000       | Set 0 selected            |
| 00001       | Set 1 selected            |
| 00010       | Set 2 selected            |
| 00011       | Set 3 selected            |
| 00100       | Set 4 selected            |
| 00101       | Set 5 selected            |
| 00110       | Set 6 selected            |
| 00111       | Set 7 selected            |
| 01000       | Set 8 selected            |
| 01001       | Set 9 selected            |
| 01010       | Set 1 selected            |
| 01011       | Set B selected            |
| 01100       | Set C selected            |
| 01101       | Set D selected            |
| 01110       | Set E selected            |
| 01111       | Set F selected            |
| 10000       | No set selected           |
| 11111       | Refresh cyle.             |
| _           | All other codes reserved. |

Table 4–34 Encoded Set Select Field (SET\_SEL\_ENC)

# 4.5.9 PCI Error Register 0 (PCI\_ERR0)



Figure 4-20 PCI Error Register 0 (87.4000.8800)

LJ-04245.AI

PCI\_ERR0 is used by the CIA to log information about the state of the PCI interface when an error is detected by the CIA. PCI\_ERR0 is locked, as are all CIA error registers, when the CIA detects an error. PCI\_ERR0 is unlocked when CIA\_ERR is cleared. When the register is not locked, the contents are UNPREDICTABLE.

The data in the WINDOW, DMA\_DAC, and DMA\_CMD files is associated with the address stored in PCI\_ERR1. This group and PCI\_ERR1 hold information related to memory errors that occur while the CIA is handling a DMA transaction

- Correctable errors (CIA\_ERR<0>)
- Uncorrectable errors (CIA\_ERR<1>)
- Access to nonexistent memory (CIA\_ERR<3>)
- Invalid page table entry (CIA\_ERR<9>)

The data in the PCI\_DAC, PCI\_CMD, TARGET\_STATE, and MASTER\_STATE fields is associated with the address stored in PCI\_ERR2. This group and PCI\_ERR2 hold information about PCI bus errors

- PCI data parity error (CIA\_ERR<5>)
- PCI address parity error (CIA\_ERR<6>)
- PCI master abort (CIA\_ERR<7>)
- PCI target abort (CIA\_ERR<8>)
- IOA timeout (CIA\_ERR<11>)

The LOCK\_STATE field has general information about the current state of the CIA not specifically associated with either PCI\_ERR1 or PCI\_ERR2.

| Field   | Name       | Туре             | Description                                                      |                  |
|---------|------------|------------------|------------------------------------------------------------------|------------------|
| <3:0>   | DMA_CMD    | RO,<br>UNDEFINED | This field holds the current DMA command on the PCI.             |                  |
| <4>     | LOCK_STATE | RO,<br>UNDEFINED | 1—The CIA was locked when the errow was detected.                |                  |
| <5>     | DMA_DAC    | RO,<br>UNDEFINED | 1—The error occurred during a PCI de address cycle (DAC).        |                  |
| <7:6>   | Reserved   | RO,0             | _                                                                |                  |
| <11:8>  | WINDOW     | RO,<br>UNDEFINED | Indicates which window (if any) was selected by the PCI address. |                  |
|         |            |                  | WINDOW<3:0>                                                      | Window Selected  |
|         |            |                  | 0000                                                             | No window active |
|         |            |                  | 0001                                                             | Window 0 hit     |
|         |            |                  | 0010                                                             | Window 1 hit     |
|         |            |                  | 0100                                                             | Window 2 hit     |
|         |            |                  | 1000                                                             | Window 3 hit     |
| <15:12> | Reserved   | RO,0             | _                                                                |                  |

(continued on next page)

| Table 4–35 | PCI Error | <b>Register 0</b> |
|------------|-----------|-------------------|
|------------|-----------|-------------------|

| Field   | Name         | Туре             | Description                                                                                                                                                                                                                                                                                                                        |
|---------|--------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <19:16> | MASTER_STATE | RO,0             | Master state indicated here:                                                                                                                                                                                                                                                                                                       |
|         |              |                  | 0 = Idle<br>1 = Drive bus<br>2 = Address step cycle<br>3 = Address cycle<br>4 = Data cycle<br>5 = Last read data cycle<br>6 = Last write data cycle<br>7 = Read stop cycle<br>8 = Write stop cycle<br>9 = Read turnaround cycle<br>A = Write turnaround cycle<br>B = Reserved<br>C = Reserved<br>D = Reserved<br>F = Unknown state |
| <22:20> | TARGET_STATE | RO,0             | Target state indicated here:<br>0 = Idle<br>1 = Busy<br>2 = Read data cycle<br>3 = Write data cycle<br>4 = Read stop cycle<br>5 = Write stop cycle<br>6 = Read turnaround cycle<br>7 = Write turnaround cycle                                                                                                                      |
| <23>    | Reserved     | RO,0             | _                                                                                                                                                                                                                                                                                                                                  |
| <27:24> | PCI_CMD      | RO,<br>UNDEFINED | The current PCI command.                                                                                                                                                                                                                                                                                                           |
| <28>    | PCI_DAC      | RO,<br>UNDEFINED | 1—The current PCI command is a dual address cycle command.                                                                                                                                                                                                                                                                         |
| <31:29> | Reserved     | RO,0             | _                                                                                                                                                                                                                                                                                                                                  |

# Table 4–35 (Cont.) PCI Error Register 0

# 4.5.10 PCI Error Register 1 (PCI\_ERR1)

## Figure 4-21 PCI Error Register 1 (87.4000.8840)



The CIA uses PCI\_ERR1 to log DMA **ad\_h<31:0**> when an error condition is logged into PCI\_ERR0. This register is locked whenever the CIA detects an error. This register always captures **ad\_h<31:0**>—even for a DMA DAC cycle.

Signal **ad\_h<39:32**> can be obtained from W\_DAC; **ad\_h<63:40**> must be zero for the CIA to hit on the DAC cycle.

PCI\_ERR1 is unlocked when the error bits in CIA\_ERR have all been cleared. The contents of PCI\_ERR1 are UNPREDICTABLE when it is not locked

PCI\_ERR1 and some fields in PCI\_ERR0 (WINDOW, DMA\_DAC, DMA\_CMD) hold information related to the following errors, which are associated with the memory while the CIA is handling a DMA transaction:

- Correctable ECC error (CIA\_ERR<0>)
- Uncorrectable ECC error (CIA\_ERR<1>)
- Access to nonexistent memory (CIA\_ERR<3>)
- Invalid page table entry (CIA\_ERR<9>)

### Table 4–36 PCI Error Register 1

| Field  | Name              | Туре             | Description                         |
|--------|-------------------|------------------|-------------------------------------|
| <31:0> | DMA_ADDRESS<31:0> | RO,<br>UNDEFINED | Contains DMA <b>ad_h&lt;31:0</b> >. |

# 4.5.11 PCI Error Register 2 (PCI\_ERR2)

Figure 4–22 PCI Error Register 2 (87.4000.8880)



LJ-04247.AI

The CIA uses PCI\_ERR2 to log **ad\_h<31:0**> when an error condition is logged into PCI\_ERR0. This register is locked whenever the CIA detects an error. This register always captures **ad\_h<31:0**>—even for a DMA DAC cycle.

Signal **ad\_h<39:32**> can be obtained from W\_DAC; **ad\_h<63:40**> must be zero for the CIA to hit on the DAC cycle.

PCI\_ERR2 is unlocked when the error bits in CIA\_ERR have all been cleared. The contents of PCI\_ERR1 are UNPREDICTABLE when it is not locked.

PCI\_ERR2 and some fields in PCI\_ERR0 (PCI\_DAC, PCI\_CMDK, TARGET\_ STATE, MASTER\_STATE) hold information related to the following errors, which are associated with the PCI bus:

- PCI data parity error (CIA\_ERR<5>)
- PCI address parity error (CIA\_ERR<6>)
- PCI master abort (CIA\_ERR<7>)
- PCI target abort (CIA\_ERR<8>)
- IOA timeout (CIA\_ERR<11>)

### Table 4–37PCI Error Register 2

| Field  | Name              | Туре             | Description                         |
|--------|-------------------|------------------|-------------------------------------|
| <31:0> | PCI_ADDRESS<31:0> | RO,<br>UNDEFINED | Contains PCI <b>ad_h&lt;31:0</b> >. |

# 4.6 DECchip 21171-CA System Configuration Registers

This section defines and describes the DECchip 21171-CA system configuration registers.

# 4.6.1 Memory Configuration Register (MCR)

MCR defines the system Bcache and memory configuration. The register contents are used to configure the CIA memory controller.

## Figure 4–23 Memory Configuration Register (87.5000.0000)



LJ-04248.AI

| Field  | Name       | Туре | Description                                                                                                                                                                                                                                                                                  |                                            |  |
|--------|------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------|--|
| <0>    | MEM_SIZE   | RW,0 | This bit must be written by firmware.<br>0—The memory port is configured to a 128-bit data<br>path. See Figure 3–9.<br>1—The memory port is configured to a 256-bit data<br>path. See Figure 3–10. MMB0 and MMB1 must be<br>populated identically or an illegal configuration is<br>flagged. |                                            |  |
| <3:1>  | Reserved   | RO,0 | _                                                                                                                                                                                                                                                                                            |                                            |  |
| <6:4>  | CACHE_SIZE | RW,0 | SROM code determines the cache size and write these bits before any memory cycles are started.                                                                                                                                                                                               |                                            |  |
|        |            |      | CACHE_SIZE<br><2:0>                                                                                                                                                                                                                                                                          | Cache RAM Size                             |  |
|        |            |      | 0 0 0                                                                                                                                                                                                                                                                                        | No cache present                           |  |
|        |            |      | 0 0 1                                                                                                                                                                                                                                                                                        | Reserved                                   |  |
|        |            |      | 0 1 0                                                                                                                                                                                                                                                                                        | 128K * X, 2MB—complete cache               |  |
|        |            |      | 0 1 1                                                                                                                                                                                                                                                                                        | 256K * X, 4MB or larger—<br>complete cache |  |
|        |            |      | 100–111                                                                                                                                                                                                                                                                                      | Reserved                                   |  |
| <7>    | Reserved   | RO,0 | _                                                                                                                                                                                                                                                                                            |                                            |  |
| <17:8> | REF_RATE   | RW,0 | This field controls the memory refresh rate. A 10-<br>free-running counter, starting at zero, counts up<br>to the REF_RATE and resets to zero. Memory<br>is refreshed every time the REF_RATE value is<br>reached. Setting this field to zero will disable refra<br>cycles.                  |                                            |  |
|        |            |      |                                                                                                                                                                                                                                                                                              | (continued on next page)                   |  |

# Table 4–38 Memory Configuration Register

| Field   | Name              | Туре           | Description                                              |                                                                                                                                                                                                   |  |  |
|---------|-------------------|----------------|----------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| <19:18> | REF_BURST         | REF_BURST RW,0 |                                                          | The refresh state machine can be set up to perform<br>all or half the single inline memory modules (SIMM)<br>at once and also to do one or two refreshes when the<br>REF_RATE counter rolls over. |  |  |
|         |                   |                | REF_BURST<1:                                             | 0> Refresh Burst Size                                                                                                                                                                             |  |  |
|         |                   |                | 0 0                                                      | <b>ras_h</b> to all SIMMs at once, single refresh                                                                                                                                                 |  |  |
|         |                   |                | 0 1                                                      | <b>ras_h</b> to all SIMMs at once,<br>double refresh (burst)                                                                                                                                      |  |  |
|         |                   |                | 1 0                                                      | <b>ras_h</b> to half of SIMMs at once, single refresh                                                                                                                                             |  |  |
|         |                   |                | 1 1                                                      | <b>ras_h</b> to half of SIMMs at once, double refresh (burst)                                                                                                                                     |  |  |
| <21:20> | TMG_R0            | RW,0           | Controls the row                                         | v address nominal setup time.                                                                                                                                                                     |  |  |
|         |                   |                | TMG_R0<1:0>                                              | Row Address Setup (nominal)                                                                                                                                                                       |  |  |
|         |                   |                | 00                                                       | 15 ns                                                                                                                                                                                             |  |  |
|         |                   |                | 01                                                       | 30 ns                                                                                                                                                                                             |  |  |
|         |                   |                | 10                                                       | 45 ns                                                                                                                                                                                             |  |  |
|         |                   |                | 11                                                       | 60 ns                                                                                                                                                                                             |  |  |
| <22>    | LONG_CBR_<br>CAS  | RW,1           | Refresh ( <b>cas_h</b><br>0—Pulse width<br>1—Pulse width |                                                                                                                                                                                                   |  |  |
| <25:23> | Reserved          | RO,0           | _                                                        |                                                                                                                                                                                                   |  |  |
| <27:26> | DLY_IDLE_BC       | RW,00          |                                                          | <b>to this field</b> . Writing any other<br>UNPREDICTABLE behavior.                                                                                                                               |  |  |
| <28>    | Reserved          | RO,0           | —                                                        |                                                                                                                                                                                                   |  |  |
| <29>    | EARLY_IDLE_<br>BC | RW,1           | Write only 1 <sub>2</sub> t<br>UNPREDICTAB               | <b>o this bit</b> . Writing a 0 <sub>2</sub> may cause<br>BLE behavior.                                                                                                                           |  |  |
| <31:30> | Reserved          | RO,0           | _                                                        |                                                                                                                                                                                                   |  |  |

## Table 4–38 (Cont.) Memory Configuration Register

## 4.6.2 Memory Base Address Register n (MBAn)

The eight memory base address registers correspond to the 16 possible banks of memory that the CIA can support. The bits within the MBA register provide a pattern that is compared with the incoming address to determine which bank is being accessed. The minimum bank size for an MBA register is 16MB.

The addresses for the eight memory base address registers are listed here.

| MBA0-87.5000.0600 | MBA2-87.5000.0680 |
|-------------------|-------------------|
| MBA4-87.5000.0700 | MBA6-87.5000.0780 |
| MBA8-87.5000.0800 | MBAA—87.5000.0880 |
| MBAC-87.5000.0900 | MBAE-87.5000.0980 |

### Figure 4–24 Memory Base Address Register n



LJ-04249.AI

| Field   | Name     | Туре | Description                                                                                                                                                               |                                                                                                                                        |                                                                                                                                                                 |  |  |
|---------|----------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| <0>     | S0_VALID | RW,0 | 1—Indicates that                                                                                                                                                          | side 0 for                                                                                                                             | the bank is valid.                                                                                                                                              |  |  |
| <2:1>   | ROW_TYPE | RW,0 | Specifies the row and column configuration of the physical<br>bank being referenced. ROW_TYPE is used for generating<br>the memory address map. See Figures 3–9 and 3–10. |                                                                                                                                        |                                                                                                                                                                 |  |  |
|         |          |      | ROW_TYPE<1:0>                                                                                                                                                             | Rov                                                                                                                                    | v/Column                                                                                                                                                        |  |  |
|         |          |      | 0 0                                                                                                                                                                       | 10 1                                                                                                                                   | cow/10 column                                                                                                                                                   |  |  |
|         |          |      | 0 1                                                                                                                                                                       | 12 1                                                                                                                                   | row/10 column or 11 x 11                                                                                                                                        |  |  |
|         |          |      | 1 0                                                                                                                                                                       | 13 1                                                                                                                                   | row/11 column or 12 x 12                                                                                                                                        |  |  |
|         |          |      | 1 1                                                                                                                                                                       | Res                                                                                                                                    | erved                                                                                                                                                           |  |  |
| <3>     | Reserved | RO,0 | _                                                                                                                                                                         |                                                                                                                                        |                                                                                                                                                                 |  |  |
| <8:4>   | MASK     | RW,0 | with the physical indicates the size                                                                                                                                      | comparing MBA <i>n</i> [PATTERN]<br>The MASK field implicitly<br>mory SIMMs in the bank<br>register. For a 256-bit memory<br>elds are: |                                                                                                                                                                 |  |  |
|         |          |      | SIMM Size                                                                                                                                                                 | MASK                                                                                                                                   | Comparison Range                                                                                                                                                |  |  |
|         |          |      | 4MB or 8MB                                                                                                                                                                | 00001                                                                                                                                  | <b>addr&lt;24</b> > is not used in the address comparison.                                                                                                      |  |  |
|         |          |      | 16MB or 32MB                                                                                                                                                              | 00111                                                                                                                                  | <b>addr&lt;26:24</b> > are not used in the address comparison.                                                                                                  |  |  |
|         |          |      | 64MB or 128MB                                                                                                                                                             | 11111                                                                                                                                  | <b>addr&lt;28:24</b> > are not used in the address comparison.                                                                                                  |  |  |
| <14:9>  | Reserved | RO,0 | _                                                                                                                                                                         |                                                                                                                                        |                                                                                                                                                                 |  |  |
| <15>    | S1_VALID | RW,0 | 1—Indicates that<br>be valid unless sid                                                                                                                                   |                                                                                                                                        | the bank is valid. Side 1 cannot<br>valid.                                                                                                                      |  |  |
| <25:16> | PATTERN  | RW,0 | address <b>addr_h</b> <3<br>to determine if th<br>being accessed. PA                                                                                                      | <b>33:24</b> > and<br>e bank con<br>ATTERN i                                                                                           | red with the incoming sysBus<br>d then ORed with MASK<8:4><br>cresponding to this MBA is<br>ndicates the base address of the<br>c8:4> indicates the size of the |  |  |
|         |          |      |                                                                                                                                                                           |                                                                                                                                        |                                                                                                                                                                 |  |  |

## Table 4–39 Memory Base Address Register n

| Field   | Name     | Туре | Description  |                          |                                                 |
|---------|----------|------|--------------|--------------------------|-------------------------------------------------|
| <27:26> | Reserved | RO,0 | _            |                          |                                                 |
| <29:28> | TMG_SEL  | RW,0 | Timing regis | ster select:             |                                                 |
|         |          |      | TMG_SEL      | TMG <i>n</i><br>Selected | Description                                     |
|         |          |      | 0 0          | TMG0                     | Used to control timing of 50-ns and 60-ns SIMMs |
|         |          |      | 0 1          | TMG1                     | Used to control timing of<br>70-ns SIMMs        |
|         |          |      | 1 0          | TMG2                     | Used to control timing of<br>80-ns SIMMs        |
|         |          |      | 1 1          | Reserved                 | _                                               |
| <31:30> | Reserved | RO,0 | _            |                          |                                                 |

# Table 4–39 (Cont.) Memory Base Address Register n

## 4.6.3 Memory Timing Information Register n (TMGn)

The addresses for the three memory timing information registers are listed here.

TMG0-87.5000.0B00 TMG1-87.5000.0B40 TMG2-87.5000.0B80

The memory timing registers contain the system memory parameters that control operation of the CIA memory sequencer. See MBAn<29:28> in Section 4.6.2 for TMGn register selection.



## Figure 4–25 Memory Timing Information Register *n*

LJ-04250.AI

| Field   | Name       | Туре | Description                                  |
|---------|------------|------|----------------------------------------------|
| <1:0>   | TMG_R1     | RW,0 | Read starting data delay.                    |
| <3:2>   | TMG_R2     | RW,0 | Row address hold.                            |
| <5:4>   | TMG_R3     | RW,0 | Read cycle time.                             |
| <7:6>   | TMG_R4     | RW,0 | Read <b>cas_h</b> assertion delay.           |
| <9:8>   | TMG_R5     | RW,0 | Read <b>cas_h</b> pulse width.               |
| <11:10> | TMG_R6     | RW,0 | Read column address hold.                    |
| <13:12> | TMG_W1     | RW,0 | Write data delay.                            |
| <16:14> | TMG_W4     | RW,0 | Write <b>cas_h</b> assertion delay.          |
| <17>    | TMG_PRE    | RW,0 | <b>ras_h</b> precharge delay.                |
| <19:18> | TMG_V3     | RW,0 | Write cycle time.                            |
| <22:20> | TMG_V4     | RW,0 | Linked victim, <b>cas_h</b> assertion delay. |
| <23>    | Reserved   | RO,0 | _                                            |
| <25:24> | TMG_V5     | RW,0 | Victim/write, <b>cas_h</b> pulse width.      |
| <27:26> | TMG_V6     | RW,0 | Victim/write, column address hold.           |
| <29:28> | TMG_RV     | RW,0 | Read-to-victim start delay.                  |
| <31:30> | TMG_RD_DLY | RW,0 | Read data delay (affects DSW).               |
|         |            |      |                                              |

 Table 4–40
 Memory Timing Information Register n

Table 4-41 lists the possible values of the encoded memory parameters.

| Table 4–41 Memory Timing Parameters, Encoded V | Values |
|------------------------------------------------|--------|
|------------------------------------------------|--------|

|                     |     |     |     | Enco | Encoded Values |     |     |     |  |  |  |
|---------------------|-----|-----|-----|------|----------------|-----|-----|-----|--|--|--|
| Parameter           | 000 | 001 | 010 | 011  | 100            | 101 | 110 | 111 |  |  |  |
| TMG_R1              | 30  | _1  | 60  | _    | _              | _   | _   | _   |  |  |  |
| TMG_R2              | 30  | 45  | 60  | 75   | _              | _   | _   | _   |  |  |  |
| TMG_R3              | 60  | _   | 90  | _    | _              | _   | _   | _   |  |  |  |
| TMG_R4              | 30  | 45  | 60  | 75   | _              | _   | _   | _   |  |  |  |
| TMG_R5              | 30  | 45  | 60  | 75   | —              | —   | —   | _   |  |  |  |
| TMG_R6              | 30  | 45  | 60  | 75   | —              | —   | —   | _   |  |  |  |
| TMG_W1              | 30  | —   | 60  | _    | —              | —   | —   | —   |  |  |  |
| TMG_W4              | 60  | 75  | 90  | 105  | 120            | 135 | —   | _   |  |  |  |
| TMG_PRE             | 0   | 30  | —   | —    | —              | —   | —   | _   |  |  |  |
| TMG_V3              | 60  | —   | 90  | —    | —              | —   | —   | _   |  |  |  |
| TMG_V4              | 60  | 75  | 90  | 105  | 120            | 135 | —   | _   |  |  |  |
| TMG_V5              | 30  | 45  | 60  | 75   | —              | —   | —   | _   |  |  |  |
| TMG_V6              | 30  | 45  | 60  | 75   | —              | —   | —   | _   |  |  |  |
| TMG_RV <sup>2</sup> | 0   | 0   | 30  | 30   | —              | —   | —   | —   |  |  |  |
| TMG_RV <sup>3</sup> | 15  | 30  | 45  | 60   | —              | —   | —   | —   |  |  |  |
| TMG_RD_DLY          | 0   | 15  | 30  | 45   | _              | —   | —   | —   |  |  |  |

<sup>1</sup>Illegal parameters are indicated by —.

<sup>2</sup>Delay between a read and a linked victim.

<sup>3</sup>Delay after the read to assertion of **mem\_en\_h**.

Figures 4–26 and 4–27 demonstrate TMG*n* parameters applied to 21171 timing for read and write transactions. In these examples of 21171 timing, the 21171 accepts and uses a 33-MHz clock input. The 21171 doubles that frequency, generating a 66-MHz clock for its internal use.



## Figure 4–26 Memory Read Timing Sample



Figure 4–27 Memory Write Timing Sample

Tables 4–42 and 4–43 list the minimum and maximum timing limits for memory signals.

| Signal Name   | Minimum          | Maximum   |  |  |  |  |
|---------------|------------------|-----------|--|--|--|--|
| ras_h Timing  |                  |           |  |  |  |  |
| ras_h<0>      | 3.948 ns         | 7.030 ns  |  |  |  |  |
| ras_h<1>      | 3.948 ns         | 7.030 ns  |  |  |  |  |
| ras_h<2>      | 3.948 ns         | 6.996 ns  |  |  |  |  |
| ras_h<3>      | 3.948 ns         | 7.030 ns  |  |  |  |  |
|               | cas_h Timing     | 3         |  |  |  |  |
| cas_h<0>      | 3.696 ns         | 6.466 ns  |  |  |  |  |
| cas_h<1>      | 3.729 ns         | 6.466 ns  |  |  |  |  |
| cas_h<2>      | 3.718 ns         | 6.466 ns  |  |  |  |  |
| cas_h<3>      | 3.729 ns         | 6.466 ns  |  |  |  |  |
|               | set_sel<15:0> Ti | ming      |  |  |  |  |
| set_sel_l<0>  | 5.806 ns         | 13.812 ns |  |  |  |  |
| set_sel_l<1>  | 5.969 ns         | 14.185 ns |  |  |  |  |
| set_sel_l<2>  | 6.141 ns         | 14.572 ns |  |  |  |  |
| set_sel_l<3>  | 6.517 ns         | 14.728 ns |  |  |  |  |
| set_sel_l<4>  | 5.985 ns         | 14.219 ns |  |  |  |  |
| set_sel_l<5>  | 6.470 ns         | 14.618 ns |  |  |  |  |
| set_sel_l<6>  | 6.368 ns         | 14.391 ns |  |  |  |  |
| set_sel_l<7>  | 6.659 ns         | 15.047 ns |  |  |  |  |
| set_sel_l<8>  | 6.078 ns         | 14.500 ns |  |  |  |  |
| set_sel_l<9>  | 6.353 ns         | 14.925 ns |  |  |  |  |
| set_sel_l<10> | 6.170 ns         | 14.710 ns |  |  |  |  |
| set_sel_l<11> | 6.371 ns         | 14.965 ns |  |  |  |  |
| set_sel_l<12> | 5.938 ns         | 14.182 ns |  |  |  |  |
| set_sel_l<13> | 6.729 ns         | 15.208 ns |  |  |  |  |
| set_sel_l<14> | 5.971 ns         | 14.180 ns |  |  |  |  |
| set sel l<15> | 5.987 ns         | 14.227 ns |  |  |  |  |

 Table 4–42
 Memory Control Signals Timing Limits

(continued on next page)

| Signal Name | Minimum      | Maximum  |  |
|-------------|--------------|----------|--|
|             | we_I Timing  |          |  |
| mem_we_l<0> | 3.809 ns     | 6.646 ns |  |
| mem_we_l<1> | 3.783 ns     | 6.576 ns |  |
|             | mem_en_h Tim | ing      |  |
| mem_en_h    | 3.330 ns     | 8.206 ns |  |

# Table 4–42 (Cont.) Memory Control Signals Timing Limits

## Table 4–43 Memory Address Timing Limits

| Signal Name    | Minimum  | Column<br>Maximum | Row<br>Maximum <sup>1</sup> |
|----------------|----------|-------------------|-----------------------------|
| mem_addr_h<0>  | 3.839 ns | 8.850 ns          | 23.166 ns                   |
| mem_addr_h<1>  | 3.843 ns | 8.850 ns          | 22.946 ns                   |
| mem_addr_h<2>  | 3.842 ns | 8.870 ns          | 22.926 ns                   |
| mem_addr_h<3>  | 3.846 ns | 8.840 ns          | 23.086 ns                   |
| mem_addr_h<4>  | 3.861 ns | 8.840 ns          | 23.106 ns                   |
| mem_addr_h<5>  | 3.843 ns | 8.850 ns          | 23.186 ns                   |
| mem_addr_h<6>  | 3.846 ns | 8.860 ns          | 23.266 ns                   |
| mem_addr_h<7>  | 3.842 ns | 8.840 ns          | 23.186 ns                   |
| mem_addr_h<8>  | 3.846 ns | 8.880 ns          | 23.506 ns                   |
| mem_addr_h<9>  | 4.260 ns | 9.635 ns          | 23.616 ns                   |
| mem_addr_h<10> | 3.880 ns | 8.980 ns          | 23.356 ns                   |
| mem_addr_h<11> | 3.883 ns | 8.990 ns          | 23.196 ns                   |
| mem_addr_h<12> | 4.338 ns | 8.790 ns          | 23.586 ns                   |

Table 4–44 lists the data path timing limits for memory and CPU data.

| Signal Name     | Setup Time | Hold Time | Clock-to-Out Time<br>9.13 ns |  |
|-----------------|------------|-----------|------------------------------|--|
| cpu_dat_h<35:0> | 7.54 ns    | –0.11 ns  |                              |  |
|                 | 4.48 ns    | 0.30 ns   | 7.49 ns                      |  |

 Table 4–44
 Memory Data Timing Limits

The clock skew value for flip-flops triggered by the **clk\_h** signal line (**iod\_h**, **ioc\_h**, **cmc\_h**, and PCI signals) is 1500 ps. The clock skew value for flip-flops triggered by the **clk2x\_h** signal line (**ras\_h**, **cas\_h**, **mem\_we\_l<1:0>**, **mem\_ addr\_h<12:0>**, **mem\_en\_h**) is 2150 ps.

## DECchip 21171-CA Control and Status Registers 4.7 DECchip 21171-CA PCI Address and Scatter-Gather Registers

# 4.7 DECchip 21171-CA PCI Address and Scatter-Gather Registers

This section defines and describes the DECchip 21171-CA system configuration registers.

## 4.7.1 Scatter-Gather Translation Buffer Invalidate Register (TBIA)

Writing to the TBIA causes the specified group of scatter-gather TLB tags to be unlocked and marked invalid.

## Figure 4–28 Scatter-Gather TBIA Register (87.6000.0100)



# Table 4–45 Scatter-Gather Translation Buffer Invalidate Register

| Field  | Name<br>TBIA<1:0> | Type<br>WO,0 | Description                                                                                            |                                                               |
|--------|-------------------|--------------|--------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|
| <1:0>  |                   |              | A write transaction to this register will invalidate the specified scatter-gather translation buffers. |                                                               |
|        |                   |              | TBIA<1:0>                                                                                              | Operation                                                     |
|        |                   |              | 0 0                                                                                                    | No operation.                                                 |
|        |                   |              | 0 1                                                                                                    | Invalidate and unlock the TLB tags that are currently locked. |
|        |                   |              | 1 0                                                                                                    | Invalidate the TLB tags that currently unlocked.              |
|        |                   |              | 1 1                                                                                                    | Invalidate and unlock all TLB tags.                           |
| <31:2> | Reserved          | RO,0         | _                                                                                                      |                                                               |

## DECchip 21171-CA Control and Status Registers 4.7 DECchip 21171-CA PCI Address and Scatter-Gather Registers

## 4.7.2 Window Base Register (Wn\_BASE)

There are four window base registers, each providing the base address for a particular target window. The window base registers should not be modified unless software ensures that no PCI traffic is targeted for the window being modified.

The incoming PCI address bits <31:20> are compared with each of the four window base registers to determine if a hit occurs in the target window. The window mask register contents determine which bits are involved in the comparison (see Sections 6.3.4.1 and 6.3.4.2).

The target window is hit when the masked addresses match a valid window base register. If MEMCS\_ENABLE is set, the hit is further qualified by the MEMCS input signal—this is used if PC compatibility holes are required in the CIA.

When W3\_BASE[DAC\_ENABLE] is set, W\_DAC is used to compare PCI address bits <39:32> during a DAC cycle.

The addresses for the four window base address registers are listed here.

| W0_BASE-87.6000.0400 | W1_BASE-87.6000.0500 |
|----------------------|----------------------|
| W2_BASE-87.6000.0600 | W3_BASE-87.6000.0700 |

### Figure 4–29 Window Base Register n

|                         | 31 | 20 19 | 04 03 02 01 00 |
|-------------------------|----|-------|----------------|
|                         |    |       |                |
| W_BASE                  |    |       |                |
| Reserved                |    |       |                |
| DAC_ENABLE <sup>2</sup> |    |       |                |
| MEMCS_ENABLE 1          |    |       |                |
| Wn_BASE_SG              |    |       |                |
| W_EN                    |    |       |                |

<sup>1</sup>-W0\_BASE only.

<sup>2</sup>-W3\_BASE only.

LJ-04252.AI

# DECchip 21171-CA Control and Status Registers 4.7 DECchip 21171-CA PCI Address and Scatter-Gather Registers

| Field   | Name                      | Туре             | Description                                                                                                                                                                                                                                             |
|---------|---------------------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <0>     | W_EN                      | RW,<br>UNDEFINED | 0—The PCI target window is disabled and<br>will not be used to respond to PCI-initiated<br>transfers.<br>1—The PCI target window is enabled and is<br>used to respond to PCI-initiated transfers that<br>hit in the address range of the target window. |
| <1>     | Wn_BASE_SG                | RW,<br>UNDEFINED | 0—The PCI target window uses direct mapping<br>to translate a PCI address to a 21164 address.<br>See Table 4–50.<br>1—The PCI target window uses scatter-gather<br>mapping to translate a PCI address to a<br>physical memory address. See Table 4–49.  |
| <2>     | MEMCS_ENABLE <sup>1</sup> | RW,<br>UNDEFINED | 1—The MEMCS signal from the PCI-to-EISA bridge is ANDed with the normal window hit.                                                                                                                                                                     |
| <3>     | DAC_ENABLE <sup>2</sup>   | RW,<br>UNDEFINED | 1—W_DAC is compared with PCI address bits<br><39:32> for a PCI DAC cycle. If the compare is<br>a hit, and the 32-bit portion of the PCI address<br>is also hit, then a DAC cycle hit occurs.                                                            |
| <19:4>  | Reserved                  | RO,0             | _                                                                                                                                                                                                                                                       |
| <31:20> | W_BASE                    | RW,<br>UNDEFINED | Specifies the PCI base address of the PCI targe<br>window and is used to determine a hit in the<br>target window. See MEMCS_ENABLE and<br>DAC_ENABLE.                                                                                                   |

## Table 4–46 Window Base Register n

4-62 Preliminary Edition—Subject to Change—September 1995

# 4.7.3 Window Mask Register n (Wn\_MASK)

The window mask registers (W*n*\_MASK) provide a mask corresponding to **ad**<**31:20**> of an incoming PCI address. The size of each window can be programmed to be from 1MB to 4GB in powers of 2 by masking bits of an incoming PCI address with the window mask register bits <31:20> as shown in Table 4–47.

There are four window mask registers. The window mask registers should not be modified unless software ensures that no PCI traffic is targeted for the window being modified.

The incoming PCI address bits <31:20> are compared with each of the four window base registers to determine a hit in the target window. The window mask register contents determine which bits are involved in the comparison. The target window is hit when the masked addresses match a valid window base register.

The addresses of the window mask registers are listed here.

| W0_MASK-87.6000.0440 | W1_MASK-87.6000.0540 |
|----------------------|----------------------|
| W2_MASK-87.6000.0640 | W3_MASK-87.6000.0740 |

#### Figure 4–30 Window Mask Register n



LJ-04253.AI

| Field   | Name     | Туре             | Description        |                                                                                    |
|---------|----------|------------------|--------------------|------------------------------------------------------------------------------------|
| <19:0>  | Reserved | RO,0             | _                  |                                                                                    |
| <31:20> | W_MASK   | RW,<br>UNDEFINED |                    | size of the PCI target window.<br>out address bits not used when<br>et window hit. |
|         |          |                  | W_MASK<31:20>      | Size of Window                                                                     |
|         |          |                  | 0000 0000 0000     | 1MB                                                                                |
|         |          |                  | 0000 0000 0001     | 2MB                                                                                |
|         |          |                  | 0000 0000 0011     | 4MB                                                                                |
|         |          |                  | 0000 0000 0111     | 8MB                                                                                |
|         |          |                  | 0000 0000 1111     | 16MB                                                                               |
|         |          |                  | 0000 0001 1111     | 32MB                                                                               |
|         |          |                  | 0000 0011 1111     | 64MB                                                                               |
|         |          |                  | 0000 0111 1111     | 128MB                                                                              |
|         |          |                  | 0000 1111 1111     | 256MB                                                                              |
|         |          |                  | 0001 1111 1111     | 512MB                                                                              |
|         |          |                  | 0011 1111 1111     | 1GB                                                                                |
|         |          |                  | 0111 1111 1111     | 2GB                                                                                |
|         |          |                  | 1111 1111 1111     | 4GB                                                                                |
|         |          |                  | Other combinations | Not supported                                                                      |

# Table 4–47 Window Mask Register n

# 4.7.4 Translated Base Register *n* (T*n*\_BASE)

There are four translated base registers (Tn\_BASE), one for each window. They are used to map PCI addresses into memory addresses. The addresses of the four translated base registers are listed here.

| T0_BASE-87.6000.0480 | T1_BASE-87.6000.0580 |
|----------------------|----------------------|
| T2_BASE-87.6000.0680 | T3_BASE-87.6000.0780 |

If the scatter-gather bit of the window base register is set, the  $Tn_BASE$  provides the base address of the scatter-gather map for this window. If the scatter-gather bit is clear, the  $Tn_BASE$  provides the base physical address of this window.

The T*n*\_BASE register should not be modified unless software can ensure that no PCI traffic is targeted for the window being modified.

#### Figure 4–31 Translated Base Register n



LJ-04254.AI

| Table 4–48 | Translated | Base | Register | n |
|------------|------------|------|----------|---|
|------------|------------|------|----------|---|

| Field  | Name          | Туре             | Description                                                                                                                                                                                                                                                                                                                                    |
|--------|---------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <7:0>  | Reserved      | RO,0             | _                                                                                                                                                                                                                                                                                                                                              |
| <31:8> | T_BASE<33:10> | RW,<br>UNDEFINED | If scatter-gather mapping is enabled, this field<br>specifies the base 21164 address of the scatter-<br>gather map table for the PCI target window. See<br>Table 4–49.<br>If scatter-gather mapping is disabled, this field<br>specifies the base 21164 address of the translated<br>PCI address for the PCI target window. See<br>Table 4–50. |

W\_MASK<31:20> sets the size of the PCI target window and the number of 8KB pages that fall into the window. Every 8KB page requires one 8-byte scatter-gather map entry. Table 4–49 shows the relationship of the W\_MASK field to the size of the scatter-gather map in memory.

 $rac{Size \,\, of \,\, the \,\, Window \,\, in \,\, Bytes}{8KB} = Number \,\, of \,\, Entries \,\, Required$ 

Number of Entries \* 8 bytes = Size of the Scatter – Gather Table

| W_MASK<31:20>  | S-G Map<br>Table Size | Scatter-Gather Map Address addr_h<33:0><br>(Used to Index S-G Table in Memory) |
|----------------|-----------------------|--------------------------------------------------------------------------------|
| 0000 0000 0000 | 1KB                   | T_BASE<33:10> : ad_h<19:13> : 000                                              |
| 0000 0000 0001 | 2KB                   | T_BASE<33:11> : ad_h<20:13> : 000                                              |
| 0000 0000 0011 | 4KB                   | $T\_BASE{<}33{:}12{>}\ :\ ad\_h{<}21{:}13{>}\ :\ 000$                          |
| 0000 0000 0111 | 8KB                   | T_BASE<33:13> : ad_h<22:13> : 000                                              |
| 0000 0000 1111 | 16KB                  | T_BASE<33:14> : ad_h<23:13> : 000                                              |
| 0000 0001 1111 | 32KB                  | T_BASE<33:15> : ad_h<24:13> : 000                                              |
| 0000 0011 1111 | 64KB                  | T_BASE<33:16> : ad_h<25:13> : 000                                              |
| 0000 0111 1111 | 128KB                 | $T_BASE<33:17>$ : $ad_h<26:13>$ : 000                                          |
| 0000 1111 1111 | 256KB                 | $T\_BASE{<}33{:}18{>}\ :\ ad\_h{<}27{:}13{>}\ :\ 000$                          |
| 0001 1111 1111 | 512KB                 | T_BASE<33:19> : ad_h<28:13> : 000                                              |
| 0011 1111 1111 | 1MB                   | T_BASE<33:20> : ad_h<29:13> : 000                                              |
| 0111 1111 1111 | 2MB                   | $T_BASE<33:21>$ : $ad_h<30:13>$ : 000                                          |
| 1111 1111 1111 | 4MB                   | T_BASE<33:22> : ad_h<31:13> : 000                                              |

Table 4–49 PCI Address Translation—Scatter-Gather Mapping Enabled

\_ Note \_

Unused translated base must be zero for correct operation.

The quadword address used to index into the table is formed from concatenating the appropriate T\_BASE and PCI address bits based on the size of the scatter-gather map. The PCI address forms the index into the table, while T\_BASE forms the NATURALLY ALIGNED base of the table.

For example, there are 128 entries in the scatter-gather table, with a table size of 1KB, for a mask of 0000 0000 0000. Entries are quadwords, so the lower 3 bits, <2:0>, of the address are always zero. Now, mask off **ad\_h<31:20**> because of W\_MASK. Then use **ad\_h<19:13**> (7 bits,  $2^7 = 128$  entries in the table) as the table index. Use T\_BASE <31:8> to get the other bits of the 34-bit address.

| W_MASK<31:20>  | Translated Address addr_h<33:0> | Unused Translated<br>Base Register Bits |
|----------------|---------------------------------|-----------------------------------------|
| 0000 0000 0000 | T_BASE<33:20> : ad_h<19:0>      | T_BASE<19:10>                           |
| 0000 0000 0001 | T_BASE<33:21> : ad_h<20:0>      | T_BASE<20:10>                           |
| 0000 0000 0011 | T_BASE<33:22> : ad_h<21:0>      | T_BASE<21:10>                           |
| 0000 0000 0111 | T_BASE<33:23> : ad_h<22:0>      | T_BASE<22:10>                           |
| 0000 0000 1111 | T_BASE<33:24> : ad_h<23:0>      | T_BASE<23:10>                           |
| 0000 0001 1111 | T_BASE<33:25> : ad_h<24:0>      | T_BASE<24:10>                           |
| 0000 0011 1111 | T_BASE<33:26> : ad_h<25:0>      | T_BASE<25:10>                           |
| 0000 0111 1111 | T_BASE<33:27> : ad_h<26:0>      | T_BASE<26:10>                           |
| 0000 1111 1111 | T_BASE<33:28> : ad_h<27:0>      | T_BASE<27:10>                           |
| 0001 1111 1111 | T_BASE<33:29> : ad_h<28:0>      | T_BASE<28:10>                           |
| 0011 1111 1111 | T_BASE<33:30> : ad_h<29:0>      | T_BASE<29:10>                           |
| 0111 1111 1111 | T_BASE<33:31> : ad_h<30:0>      | T_BASE<30:10>                           |
| 1111 1111 1111 | T_BASE<33:32> : ad_h<31:0>      | T_BASE<31:10>                           |

Table 4–50 PCI Address Translation—Scatter-Gather Mapping Disabled

# 4.7.5 Window Base DAC Register (W\_DAC)

W\_DAC provides DAC\_BASE<7:0> for comparison against PCI address bits <39:32> during a DAC cycle. PCI address bits <63:40> must be zero for a PCI window hit. This register is used with W3\_BASE.

W\_DAC is only applicable to window 3 and only if enabled by W3\_BASE[DAC\_ENABLE].

# Determining a Hit in the Target Window

The target window is hit when the following is satisfied:

- The incoming PCI address bits <31:20> match one of the four window base registers. Wn\_MASK[W\_MASK]<31:20> determines which bits are involved in the comparison.
- PCI address bits <63:40> are zero.
- PCI address bits <39:32> match DAC\_BASE<7:0>.

# Figure 4–32 Window Base DAC Register (87.6000.07C0)



LJ-04255.AI

#### Table 4–51 Window Base DAC Register

| Field  | Name          | Туре             | Description                                                                                                        |
|--------|---------------|------------------|--------------------------------------------------------------------------------------------------------------------|
| <7:0>  | DAC_BASE<7:0> | RW,<br>UNDEFINED | Specifies bits <39:32> of the PCI base address<br>used to determine a hit in the target window<br>for a DAC cycle. |
| <31:8> | Reserved      | RO,0             | _                                                                                                                  |

# 4.8 DECchip 21171-CA Address Translation Registers

This section defines and describes the DECchip 21171-CA address translation registers.

# 4.8.1 Lockable Translation Buffer Tag *n* Registers (LTB\_TAG*n*)

Software can write to these four lockable translation buffer tag *n* registers. Hardware cannot evict the register contents when a scatter-gather TLB miss occurs if the LOCKED bit is set. The addresses of the LTB\_TAG*n* registers are listed here.

| LTB_TAG0-87.6000.0800 | LTB_TAG1-87.6000.0840 |
|-----------------------|-----------------------|
| LTB_TAG2-87.6000.0880 | LTB_TAG3-87.6000.08C0 |

#### **Determining a Hit in the Translation Buffer**

If W*n*\_BASE[W*n*\_BASE\_SG] true when a PCI address hits one of the W*n*\_BASE registers, the incoming PCI address bits <31:15> are compared with each of the eight translation buffer tag registers. If there is a match, the corresponding translation buffer page register group is indexed by PCI address bits <14:13> and if it is valid, there is a translation buffer hit.

#### **Operation on an Scatter-Gather TLB Miss**

Hardware uses a round-robin algorithm to handle a scatter-gather TLB miss. A scatter-gather TLB entry is overwritten if it is not locked, but will not be evicted if it is locked. The hardware will write all four PTEs on a miss.

#### Figure 4–33 Lockable Translation Buffer Tag n Registers



LJ-04256.AI

| Field   | Name     | Туре             | Description                                                                                                              |
|---------|----------|------------------|--------------------------------------------------------------------------------------------------------------------------|
| <0>     | VALID    | RW,0             | If both VALID and the corresponding Wn_BASE[Wn_<br>BASE_SG] are set, this entry will be used for address<br>translation. |
| <1>     | LOCKED   | RW,0             | 1—The hardware will not evict this entry.                                                                                |
| <2>     | DAC      | RW,0             | 0—This TAG entry belongs to a 32-bit PCI address.<br>1—This tag entry corresponds to a 64-bit PCI address.               |
| <14:3>  | Reserved | RO,0             | _                                                                                                                        |
| <31:15> | TB_TAG   | RW,<br>UNDEFINED | The TAG for each translation buffer entry.                                                                               |

 Table 4–52
 Lockable Translation Buffer Tag n Registers

# 4.8.2 Translation Buffer Tag *n* Register (TB\_TAG*n*)

The addresses for the four TB\_TAGn registers are listed here.

| TB_TAG0-87.6000.0900 | TB_TAG1-87.6000.0940 |
|----------------------|----------------------|
| TB_TAG2-87.6000.0980 | TB_TAG3-87.6000.09C0 |

Software can write to these TLB tag entries, but the entries cannot be locked and so may be evicted by the hardware on a scatter-gather TLB miss.

The incoming PCI address bits <31:15> are compared with each of the eight translation buffer tag registers. If there is a match, the corresponding translation buffer page register group is indexed by PCI address bits <14:13>, and if it is valid, then there is a translation buffer hit.

A scatter-gather TLB miss is handled by hardware using a round-robin algorithm. An entry is overwritten if it is not locked. The hardware will write all four PTEs in the event of a scatter-gather TLB miss.

# Figure 4–34 Translation Buffer Tag *n* Registers



LJ-04257.AI

| Field   | Name     | Туре             | Description                                                                                                    |
|---------|----------|------------------|----------------------------------------------------------------------------------------------------------------|
| <0>     | VALID    | RW,0             | If both VALID and the corresponding $Wn_BASE[Wn_BASE_SG]$ are set, this entry is used for address translation. |
| <1>     | Reserved | RO,0             | _                                                                                                              |
| <2>     | DAC      | RW,0             | 0—This TAG entry belongs to a 32-bit PCI address.<br>1—This TAG entry corresponds to a 64-bit PCI<br>address.  |
| <14:3>  | Reserved | RO,0             | _                                                                                                              |
| <31:15> | TB_TAG   | RW,<br>UNDEFINED | The TAG for each translation buffer entry.                                                                     |

### Table 4–53 Translation Buffer Tag n Registers

# 4.8.3 Translation Buffer *m* Page *n* Registers (TB*m*\_PAGE*n*)

There are 32 translation buffer data registers: a group of four for each of the eight translation buffer entries. The  $TBm_PAGEn$  registers are automatically updated on a TLB miss (a group of four at a time) by the CIA hardware.

The addresses for the 32 TB*m*\_PAGE*n* registers are listed here.

| TB0_PAGE0-87.6000.1000 | TB0_PAGE1-87.6000.1040 |
|------------------------|------------------------|
| TB0_PAGE2-87.6000.1080 | TB0_PAGE3-87.6000.10C0 |
| TB1_PAGE0-87.6000.1100 | TB1_PAGE1-87.6000.1140 |
| TB1_PAGE2-87.6000.1180 | TB1_PAGE3-87.6000.11C0 |
| TB2_PAGE0-87.6000.1200 | TB2_PAGE1-87.6000.1240 |
| TB2_PAGE2-87.6000.1280 | TB2_PAGE3-87.6000.12C0 |
| TB3_PAGE0-87.6000.1300 | TB3_PAGE1-87.6000.1340 |
| TB3_PAGE2-87.6000.1380 | TB3_PAGE3-87.6000.13C0 |
| TB4_PAGE0-87.6000.1400 | TB4_PAGE1-87.6000.1440 |
| TB4_PAGE2-87.6000.1480 | TB4_PAGE3-87.6000.14C0 |
| TB5_PAGE0-87.6000.1500 | TB5_PAGE1-87.6000.1540 |
| TB5_PAGE2-87.6000.1580 | TB5_PAGE3-87.6000.15C0 |
| TB6_PAGE0-87.6000.1600 | TB6_PAGE1-87.6000.1640 |
| TB6_PAGE2-87.6000.1680 | TB6_PAGE3-87.6000.16C0 |
| TB7_PAGE0-87.6000.1700 | TB7_PAGE1-87.6000.1740 |
| TB7_PAGE2-87.6000.1780 | TB7_PAGE3-87.6000.17C0 |

### Figure 4–35 Translation Buffer *m* Page *n* Registers



 Table 4–54
 Translation Buffer m Page n Registers

| Field   | Name         | Туре             | Description                                                                               |
|---------|--------------|------------------|-------------------------------------------------------------------------------------------|
| <0>     | VALID        | RW,<br>UNDEFINED | 1—This entry can be used for address translation.                                         |
| <21:1>  | PAGE_ADDRESS | RW,<br>UNDEFINED | This field forms physical address<33:13>. PCI<br>ad_h<12:0> forms physical address<12:0>. |
| <31:22> | Reserved     | RO,0             | -                                                                                         |

Incoming PCI address bits <31:15> are compared with each of the eight translation buffer tag registers. If there is a match, the corresponding translation buffer page register group is indexed using PCI address bits <14:13>, and if it is valid, there is a translation buffer hit.

If the address bits do not match the tag, or the page entry is invalid, a TLB miss occurs. If the PTE, fetched by the hardware TLB-miss handler, is still invalid, the CIA\_ERROR interrupt is asserted for a DMA write transaction.

# 5

# DECchip 21171-CA Power-Up and Initialization

This chapter describes the behavior of the DECchip 21171-CA (CIA) chip on power-up and assertion of **reset\_l**. It also describes the system level requirements and the various registers that must be initialized after **reset\_l** is deasserted.

# 5.1 Power-Up

On power-up, the **reset\_l** input of the CIA should be asserted. It should be kept asserted until the system clocks are up and running for eight cycles.

# 5.2 Internal Reset

The assertion and deassertion of the **reset\_l** pin on the module is asynchronous to the CIA. The CIA generates an internal reset signal from **reset\_l**. The internal reset signal is asserted asynchronously, as soon as **reset\_l** is asserted, but is deasserted synchronously. Because of the synchronous deassertion of the internal reset, the CIA requires that no external transaction start until eight system clock cycles after the deassertion of **reset\_l**.

# 5.3 State of Pins on Reset Assertion

The following are general rules and requirements for the behavior of the CIA pins during reset:

- All input control signals (except the clocks and reset\_l) must be in the deasserted state as long as reset\_l is asserted.
- All output and bidirectional signals are in the states listed in Table 5–1.

# DECchip 21171-CA Power-Up and Initialization 5.3 State of Pins on Reset Assertion

Table 5–1 lists the state of CIA pins while **reset\_l** is asserted.

| Signal         | Reset State | Signal             | Reset State |
|----------------|-------------|--------------------|-------------|
| addr_cmd_par_h | Z           | addr_h<39,34:4>    | Z           |
| cmd_h<3:0>     | Z           | addr_bus_req_h     | Z           |
| cack_h         | Z           | dack_h             | Z           |
| fill_h         | Z           | fill_id_h          | Z           |
| fill_error_h   | Z           | idle_bc_h          | Z           |
| tag_dirty_h    | Z           | tag_ctl_par_h      | Z           |
| mem_addr<12:0> | х           | set_sel_h<15:0>    | 0           |
| ras_h<3:0>     | 0           | cas_h<3:0>         | 0           |
| mem_we_l<1:0>  | 112         | mem_en_h           | 1           |
| ad_h<63:0>     | Z           | cbe_l<7:0>         | Z           |
| par_h          | Z           | par64_h            | Z           |
| req64_l        | Z           | ack64_l            | Z           |
| frame_l        | Z           | irdy_l             | Z           |
| devsel_l       | Z           | trdy_l             | Z           |
| stop_l         | Ζ           | perr_l             | Z           |
| serr_l         | Ζ           | req_l              | 1           |
| rst_l          | 0           | cmc_h<8:0>         | 0           |
| ioc_h<6:0>     | 52          | iod_h<63:0>        | Z           |
| iod_e_h<7:0>   | Ζ           | int_h              | 0           |
| error_h        | 0           | test_or_scan_out_h | 0           |

| Table 5–1 | CIA Pin | State | During | Reset |
|-----------|---------|-------|--------|-------|
|-----------|---------|-------|--------|-------|

# DECchip 21171-CA Power-Up and Initialization 5.4 Configuration after Reset Deassertion

# 5.4 Configuration after Reset Deassertion

Table 5–2 lists the state of CIA pins after **reset\_l** has been deasserted.

| Signal         | Reset State                           | Signal             | Reset State |
|----------------|---------------------------------------|--------------------|-------------|
| addr_cmd_par_h | Z                                     | addr_h<39,34:4>    | Z           |
| cmd_h<3:0>     | Z                                     | addr_bus_req_h     | 0           |
| cack_h         | 0                                     | dack_h             | 0           |
| fill_h         | 0                                     | fill_id_h          | 0           |
| fill_error_h   | 0                                     | idle_bc_h          | 0           |
| tag_dirty_h    | Z                                     | tag_ctl_par_h      | Z           |
| mem_addr<12:0> | х                                     | set_sel_h<15:0>    | 0           |
| ras_h<3:0>     | 0                                     | cas_h<3:0>         | 0           |
| mem_we_l<1:0>  | <b>11</b> <sub>2</sub>                | mem_en_h           | 1           |
| ad_h<63:32>    | Z                                     | cbe_l<7:4>         | Z           |
| ad_h<31:0>     | $\mathbf{x}$ or $\mathbf{Z}^1$        | cbe_l<3:0>         | x or Z      |
| par_h          | $\mathbf{x} \text{ or } \mathbf{Z}^1$ | par64_h            | >           |
| req64_l        | 0                                     | ack64_l            | Z           |
| frame_l        | Z                                     | irdy_l             | Z           |
| devsel_l       | Z                                     | trdy_l             | Z           |
| stop_l         | Z                                     | perr_l             | Z           |
| serr_l         | Z                                     | req_l              | 1           |
| rst_l          | 0                                     | cmc_h<8:0>         | 0           |
| ioc_h<6:0>     | 52                                    | iod_h<63:0>        | Z           |
| iod_e_h<7:0>   | Z                                     | int_h              | 0           |
| error_h        | 0                                     | test_or_scan_out_h | 0           |

<sup>1</sup>Dependent upon the state of PCI **gnt\_l**. If **gnt\_l** is low, (CIA granted use of the PCI) the state of these signal lines is x. If **gnt\_l** is high, (CIA not granted use of the PCI) the state of these signal lines is Z.

# DECchip 21171-CA Power-Up and Initialization 5.4 Configuration after Reset Deassertion

After **reset\_h** has been deasserted, the 21164 reads instructions from the serial ROM (SROM) into its internal Icache and then executes those instructions. The instructions from the SROM initialize the registers listed in Table 5–3 to the values shown.

| Register                                         | Acronym             | Initialized Value (Hex)            |  |
|--------------------------------------------------|---------------------|------------------------------------|--|
| Memory configuration register                    | MCR                 | Depends upon memory configuration. |  |
| Memory base address<br>registers 0,2,4,6,8,A,C,E | MBAN                | Depends upon memory configuration. |  |
| Memory timing<br>registers 0–2                   | TMG0, TMG1,<br>TMG2 | Depends upon memory configuration. |  |

Table 5–3 Registers Initialized by SROM Code

# 6

# **DECchip 21171-CA Address Mapping**

This chapter describes DECchip 21171-CA (CIA) mapping of 40-bit 21164 physical addresses to memory addresses and I/O space addresses. It also describes translation of a 21164-initiated address into a PCI address and translation of a PCI-initiated address into a physical memory address.

Topics include dense and sparse address space<sup>1</sup>, PCI addressing, scatter-gather address translation for DMA operations, and Extended Industry Standard Architecture (EISA) requirements.

# 6.1 Address Mapping Overview

The 21164 address space is divided into two regions, as shown in Figure 6–1, using physical address bit **addr\_h<39**>. If clear, the 21164 access is to the cacheable memory space (partly reserved), and if set, the 21164 access is to noncacheable address space.





The CIA does not support use of **addr\_h<38:35**>. Software must ensure that **addr\_h<38:35**> is zero (even parity); otherwise, the CIA will cause a parity error interrupt.

<sup>&</sup>lt;sup>1</sup> Dense and sparse address spaces are defined in Section 6.2.1 and Section 6.2.2, respectively.

# DECchip 21171-CA Address Mapping 6.1 Address Mapping Overview

# 6.1.1 21164 Address Space Configuration Supported by the CIA

As shown in Figure 6–2, the CIA supports only the first 8GB of cacheable memory space; the remainder is reserved. The cacheable memory space block size is fixed at 64 bytes. The CIA will send READ and FLUSH commands to the 21164 caches for DMA traffic to the 8GB memory address area.



#### Figure 6–2 21164 Address Space Configuration

LJ-04260.AI

The CIA supports 21164 access to memory-mapped I/O devices in noncacheable address space. The CIA defines four address spaces within the noncacheable space.

- 22GB PCI memory sparse space
- 2GB PCI I/O space
- 4GB PCI memory dense space
- 4GB that includes address space for:
  - PCI configuration

# DECchip 21171-CA Address Mapping 6.1 Address Mapping Overview

- Special/interrupt acknowledge cycles
- CIA control and status registers (CSR)
- Flash ROM and support logic registers

#### 6.1.1.1 21164 Access to Address Space

The 21164 has access to the complete address space: it can access cached memory and CSRs, as well as all the PCI memory, I/O, and configuration regions, as shown in Figure 6–3.

Figure 6–3 Address Space Overview



LJ-04261.AI

The CIA sends only 32-bit addresses to the PCI (SAC<sup>1</sup>). The CIA does not generate 64-bit addresses (DAC<sup>2</sup>).

<sup>&</sup>lt;sup>1</sup> Single address cycle (PCI 32-bit address transfer).

<sup>&</sup>lt;sup>2</sup> Dual access cycle (PCI 64-bit address transfer)–used only if address bits **ad\_h<63:32**> are non-zero.

# DECchip 21171-CA Address Mapping 6.1 Address Mapping Overview

## 6.1.1.2 PCI Access to Address Space

PCI devices have a restricted view of the address space. They can access any PCI device through the PCI memory or PCI I/O space, but they have no access to PCI configuration space.

Furthermore, the CIA restricts PCI access to the system memory (for DMA operations) to four programmable address windows in PCI memory space, as shown in Figure 6–3. Address windows are a PCI requirement. Each window location is defined by its base register and is implemented by all PCI devices.

DMA access to system memory is achieved through one of two access methods:

- The directly mapped method concatenates an offset to a portion of the PCI address.
- The virtually mapped method uses a scatter-gather translation map. The scatter-gather map allows any 8KB page of PCI memory address region to be redirected to an 8KB cached memory page, as shown in Figure 6–4.

# Figure 6–4 Address Mapping Overview



# DECchip 21171-CA Address Mapping 6.1 Address Mapping Overview

The CIA accepts both 64-bit address cycles (DAC) and 32-bit PCI address cycles (SAC). The following restrictions apply to PCI 64-bit address (DAC) support:

- The least significant 40 bits of the PCI address are used in the window comparison logic. PCI address bits **ad\_h<63:40**> must be zero.
- Only one of the four PCI windows (window 3) can be enabled to accept a 64-bit (DAC) PCI address; windows 0 through 2 accept only 32-bit (SAC) address cycles.
- With a 4GB DAC window and one of the 4GB SAC windows, a PCI device can access all 8GB of memory supported by the CIA.

# DECchip 21171-CA Address Mapping 6.1 Address Mapping Overview

21164

Figure 6–5 shows how the 21164 address map translates to the PCI address space. It also shows how PCI devices access 21164 memory space via DMAs. Notice that the PCI memory space is double mapped using dense and sparse space.



#### Figure 6–5 21164 and DMA Read and Write Transactions

LJ-04263.AI

# 6.2 21164 Address Space

This section lists and describes the 21164 address space regions. The requirements for using the address regions are also shown and described. Table 6–1 lists the 21164 address regions.

Table 6–1 21164 Address Space

| 21164 Address             | Size (GB) | Selection                                                |
|---------------------------|-----------|----------------------------------------------------------|
| 00.0000.0000-01.FFFF.FFFF | 8         | Main memory                                              |
| 80.0000.0000-83.FFFF.FFFF | 16        | PCI memory—512MB<br>Sparse Space—Region 0                |
| 84.0000.0000-84.FFFF.FFFF | 4         | PCI memory—128MB<br>Sparse Space—Region 1                |
| 85.0000.0000–85.7FFF.FFFF | 2         | PCI memory—64MB<br>Sparse Space—Region 2                 |
| 85.8000.0000-85.BFFF.FFFF | 1         | PCI I/O space—32MB<br>Sparse Space—Region A              |
| 85.C000.0000–85.FFFF.FFFF | 1         | PCI I/O space—32MB<br>Sparse Space—Region B              |
| 86.0000.0000-86.FFFF.FFFF | 4         | PCI memory, 4GB—Dense space                              |
| 87.0000.0000–87.1FFF.FFFF | 0.5       | PCI configuration<br>Sparse space                        |
| 87.2000.0000-87.3FFF.FFFF | 0.5       | PCI special/interrupt acknowledge<br>Sparse space        |
| 87.4000.0000-87.4FFF.FFFF | 0.25      | CIA main CSRs<br>Pseudosparse <sup>1</sup>               |
| 87.5000.0000-87.5FFF.FFF  | 0.25      | CIA PCI memory control CSRs<br>Pseudosparse <sup>1</sup> |
| 87.6000.0000-87.6FFF.FFFF | 0.25      | CIA PCI address translation<br>Pseudosparse <sup>1</sup> |
| 87.7000.0000–87.FFFF.FFF  | 2.25      | Reserved                                                 |

The reasons for using the 21164 I/O space address map are as follows:

- Limits the number of address pins sent to the CIA.
- Provides 4GB of dense space to completely map the 32-bit PCI memory space.
- Provides abundant PCI sparce memory space because sparse memory space has byte granularity and is the safest memory space to use (no prefetching). Furthermore, the larger the space, the less likely software will need to dynamically relocate the sparse space segments. The main problem with sparse space is that it is wasteful of 21164 address space. For instance, 16GB of 21164 address space maps to only 512MB of PCI sparse space.

The CIA supports three PCI sparse space memory regions, allowing 704MB of total sparse memory space. The three regions can be relocated using the HAE\_MEM CSR, and the simplest configuration allows for 704MB of contiguous memory space:

- 512MB region, which may be located in any NATURALLY ALIGNED 512MB segment of the PCI memory space. Software developers may find this region sufficient for their needs and can ignore the remaining two regions.
- 128MB region, which may be located on any NATURALLY ALIGNED 128MB segment of the PCI memory space.
- 64MB region, which may be located on any NATURALLY ALIGNED
   64MB segment of the PCI memory space.
- Limits the PCI I/O space to sparse space. Although the PCI I/O space can handle 4GB, some chips can access only 64KB. So most, if not all, PCI devices will not exceed 64KB for the foreseeable future. Therefore, the CIA supports 64MB of sparse I/O space.
- Supports two CIA PCI sparse space I/O regions. Region A contains 32MB and is fixed in PCI segment 0–32 MB. Region B also contains 32MB, but can be relocated using the HAE\_IO register.

# 6.2.1 PCI Dense Memory Space

PCI dense memory space is located in the range 86.0000.0000 to 86.FFFF.FFF. It is typically used for memory-like data buffers such as video frame buffers or nonvolatile RAM (NVRAM). Dense space does not allow byte or word access but has the following advantages over sparse space:

- Contiguous memory locations—Some software, like the default graphics routines of Windows NT, require memory-like access. These routines cannot use sparse space addresses, because sparse space addresses require PCI transactions to be at adjacent Alpha addresses, instead of being widely separated as in sparse space. As as result, if the user-mode driver uses sparse space for its frame-buffer manipulation, it cannot "hand over" the buffer to the common Windows NT graphics code.
- Higher bus bandwidth—PCI bus burst transfers are not usable in sparse space except for a two-longword burst for quadword write transactions. Dense space is defined to allow both burst read and write transactions.
- Efficient read/write buffering—In sparse space, separate accesses use separate read or write buffer entries. Dense space allows separate accesses to be collapsed in read and write buffers (this is exactly what the 21164 does).
- Few memory barriers-In general, sparse space accesses are separated by memory barriers to avoid read/write buffer collapsing. Dense space accesses only require barriers when explicit ordering is required by the software.

Dense space is provided for the 21164 to access PCI memory space, but not for accessing PCI I/O space. Dense space has the following characteristics:

- There is a one-to-one mapping between 21164 addresses and PCI addresses. A longword address from the 21164 will map to a longword on the PCI with no shifting of the address field.
- The concept of dense space (and sparse space) is applicable only to 21164-generated addresses. There is no such thing as dense space (or sparse space) for PCI-generated address.
- Byte or word accesses are *not* possible in this space. The minimum access granularity is a longword on write transactions and a quadword on read transactions. The maximum transfer length is 32 bytes (performed as a burst of 8 longwords on the PCI). Any combination of longwords may be valid on write transactions. Valid longwords surrounding invalid longwords (called a "hole") are required to be handled correctly by all PCI devices. The CIA will allow such "holes" to be issued.

- Read transactions will always be performed as a burst of two, or more, longwords on the PCI because the minimum granularity is a quadword. The processor can request a longword but the CIA will always fetch a quadword, thus prefetching a second longword. Therefore, this space cannot be used for devices that have read side effects. Although a longword may be prefetched, the prefetch buffer is not treated as a cache and thus coherency is not an issue. Note that a quadword read is not atomic on the PCI, that is, the target device is at liberty to force a retry after the first longword of data is sent, and then allow another device to take control of the PCI bus. The CIA does not drive the PCI LOCK signal and thus the PCI cannot ensure atomicity. This is true of all current Alpha systems using the PCI.
- The 21164 merges noncached read transactions up to a 32-byte maximum. The largest dense space read transaction is thus 32 bytes from the PCI bus.
- Write transactions to this space are buffered in the 21164. The CIA supports a burst length of 8 on the PCI, corresponding to 32 bytes of data. In addition, the CIA provides four 32-byte write buffers to maximize I/O write performance. These four buffers are strictly ordered.

Address generation in dense space is shown in Figure 6–6.

| 21164 Address<br>40 39                       |           | 33 32 31 |        | 05 04 03 02 01 00 |
|----------------------------------------------|-----------|----------|--------|-------------------|
| 1                                            | 1         | 1 0      |        | 0.0               |
|                                              | · · · · · |          | <31:5> | int4_valid        |
| 21164                                        |           |          |        |                   |
| PCI Dense <sup>31</sup><br>Memory<br>Address |           |          | V      | 05 04 ¥ 02 01 00  |

#### Figure 6–6 Dense Space Address Generation

Address generation in dense space is described in the following list:

- addr\_h<31:5> is directly sent out on the PCI as ad\_h<31:5>.
- addr\_h<4:2> is not sent from the 21164, but is inferred from int4\_valid\_h<3:0>.
- ad\_h<4:3> is a copy of addr\_h<4:3>.
- **ad\_h<2>** differs for read and write transactions as follows:
  - For a read transaction, ad\_h<2> is zero (minimum read resolution in noncached space is a quadword).
  - For a write transaction, **ad\_h<2>** equals **addr\_h<2>**.

#### 6.2.2 PCI Sparse Memory Space

The CIA supports three regions of contiguous 21164 address space that maps to PCI sparse memory space. The total 21164 range is from 80.0000.0000 to 85.7FFF.FFFF. Sparse address space maps a large piece of 21164 memory address space to a small PCI address space. For example, a 32-byte memory address might map to a single-byte PCI address.

A problem arises because the Alpha instruction set can express only aligned longword and quadword data references. The PCI bus requires the ability to express byte, word, tribyte, longword, and quadword references. The CIA must also be able to emulate PCI transactions for PCI devices designed for systems that are capable of generating the UNALIGNED references.

The CIA accomplishes UNALIGNED PCI references by encoding the size of the data transfer (byte, word, and so on) and the byte enable information in the 21164 address. Address bits **addr\_h<6:3**> are used for this purpose.

The PCI longword address **ad\_h<26:3**> is generated using remaining address bits **addr\_h<31:7**>.

Quadword address encoding is provided by **addr\_h<6:3**> with **addr\_h<7**> assumed to be zero by the CIA hardware. See Table 6–3.

The loss of address bits **addr\_h<6:3**> has resulted in a 22GB "sparse" address space that maps to only 704MB of address space on the PCI.

The rules for accessing sparse space follow:

- Sparse space supports all the byte encodings that are expected to be generated in a system to ensure compatibility with existing and expected PCI devices/drivers. The results of some references are not explicitly defined (these are the missing entries in Table 6–3, such as word size with address **addr\_h<6:5**> = 11). The hardware will complete the reference, but the reference is not required to produce any particular result nor will the CIA report an error.
- Software must use longword load or store instructions (LDL/STL) to perform a reference that is of longword length or less on the PCI bus.
  - The bytes to be transferred must be positioned within the longword in the correct byte lanes as indicated by the PCI byte enable.
  - The hardware will do no byte shifting within the longword.
- Quadword load and store instructions must be used only to perform a quadword transfer. Use of STQ/LDQ instructions for any other references will produce UNPREDICTABLE results.
- Read-ahead (prefetch) is not performed in sparse space by the CIA hardware because the read-ahead might have unwanted side effects.
- Programmers are required to insert memory barrier (MB) instructions between sparse space accesses to prevent collapsing in the 21164 write buffer. However, this is not always necessary. For instance, consecutive sparse space addresses will be separated by 32 bytes (and will not be collapsed by the 21164).
- Programmers are required to insert MB instructions if the sparse space address ordering/coherencey to a dense space address are to be maintained.
- On read transactions, the 21164 sends out **addr\_h<4:3**> indirectly on the **int4\_valid\_h<3:0**>.
- Accesses with addr\_h<2:0> non-zero will produce UNPREDICTABLE results.

• The relationship between **int4\_valid\_h<3:0**> and 21164 **addr\_h<4:3**> for a sparse space write transaction is shown in Table 6–2. The important point is that all other **int4\_valid\_h<3:0**> patterns will produce UNPREDICTABLE results such as the result of collapsing in the 21164 write buffer or issuing an STQ instruction when an STL instruction was required.

| 21164 Data Cycle | int4_valid_h<3:0> 1       | addr_h<4:3> |  |
|------------------|---------------------------|-------------|--|
| First            | 0001                      | 0 0         |  |
|                  | 0 0 1 0                   | 0 0         |  |
|                  | 0 1 0 0                   | 0 1         |  |
|                  | 1 0 0 0                   | 0 1         |  |
| Second           | 0001                      | 1 0         |  |
|                  | 0 0 1 0                   | 1 0         |  |
|                  | 0 1 0 0                   | 1 1         |  |
|                  | 1000                      | 1 1         |  |
|                  | $1 \ 1 \ 0 \ 0 \ (STQ)^2$ | 1 1         |  |

Table 6–2 int4\_valid\_h<3:0> and addr\_h<4:3> for Sparse Space Write Transactions

<sup>1</sup>All other **int4\_valid\_h<3:0**> patterns cause UNPREDICTABLE results. <sup>2</sup>Only one STQ case is allowed.

Table 6–3 defines the low-order PCI sparse memory address bits. Address bits **addr\_h<7:3**> are used to generate the length of the PCI transaction in bytes, the byte enables, and **ad\_h<2:0**>. Address bits **addr\_h<30:8**> correspond to the quadword PCI address and are sent out on the PCI as **ad\_h<25:3**>.

| Size        | Byte Offset              | 21164       | PCI                    | Data-In<br>Register          |                          |
|-------------|--------------------------|-------------|------------------------|------------------------------|--------------------------|
| addr_h<4:3> | addr_h<6:5> <sup>1</sup> | Instruction | ad_h<2:0> <sup>2</sup> | Byte <sup>3</sup><br>Enable  | Byte Lanes<br>[7:0]      |
| Byte        |                          |             |                        |                              |                          |
| 00          | 00<br>01<br>10<br>11     | LDL, STL    | addr_h<7>,00           | 1110<br>1101<br>1011<br>0111 | <0><br><1><br><2><br><3> |
| Word        |                          |             |                        |                              |                          |
| 01          | 00<br>01<br>10           | LDL, STL    | addr_h<7>,00           | 1100<br>1001<br>0011         | <1:0><br><2:1><br><3:2>  |
| Tribyte     |                          |             |                        |                              |                          |
| 10          | 00<br>01                 | LDL, STL    | addr_h<7>,00           | 1000<br>0001                 | <2:0><br><3:1>           |
| Longword    |                          |             |                        |                              |                          |
| 11          | 00                       | LDL, STL    | addr_h<7>,00           | 0000                         | <3:0>                    |
| Quadword    |                          |             |                        |                              |                          |
| 11          | 11                       | LDQ, STQ    | 000                    | 0000                         | <7:0>                    |

#### Table 6–3 PCI Memory Sparse Space Read/Write Encodings

<sup>1</sup>Missing entries (such as word size with **addr\_h<6:5>** =  $11_2$ ) cause UNPREDICTABLE results. <sup>2</sup>In PCI sparse memory space, **ad\_h<1:0>** is always equal to zero.

<sup>3</sup>Byte enable set to zero indicates that byte lane carries meaningful data.

The high-order PCI address bits **ad\_h<31:26>** are obtained from either the hardware address extension register (HAE\_MEM) or the 21164 address, depending on sparse space regions, as shown in Table 6–4.

| Region <sup>1</sup> | <31>   |         |         |         |         |         |
|---------------------|--------|---------|---------|---------|---------|---------|
|                     |        | <30>    | <29>    | <28>    | <27>    | <26>    |
|                     | AE_MEM | HAE_MEM | HAE_MEM | 21164   | 21164   | 21164   |
|                     | <31>   | <30>    | <29>    | <33>    | <32>    | <31>    |
|                     | AE_MEM | HAE_MEM | HAE_MEM | HAE_MEM | HAE_MEM | 21164   |
|                     | <15>   | <14>    | <13>    | <12>    | <11>    | <31>    |
| 3 H.                | AE_MEM | HAE_MEM | HAE_MEM | HAE_MEM | HAE_MEM | HAE_MEM |
|                     | <7>    | <6>     | <5>     | <4>     | <3>     | <2>     |

Table 6–4 HAE\_MEM High Order Sparse Space Bits

HAE\_MEM is located in the CIA and is described in Section 4.2.4. Figures 6–7 through 6–9 show mapping for the three regions.

Figure 6–7 PCI Memory Sparse Space Address Generation (Region 1)











Figure 6–9 PCI Memory Sparse Space Address Generation (Region 3)

The 21164 provides six physical address bits <39:34> that can be used to backfill the "lost" sparse space bits. However, other 21164 platforms use these high-order bits in different ways, encoding multiple PCI ports for instance, and so for easier software portability, these bits are not used.

# 6.2.3 PCI Sparse I/O Space

PCI sparse I/O space has characteristics similar to the PCI sparse memory space. PCI sparse I/O space is located in the address range 85.8000.0000 to 85.FFFF.FFFF. This 2GB 21164 address segment maps to two 32MB regions of PCI I/O address space. A read or write transaction to this space causes a PCI I/O read or write transaction.

The high-order PCI address bits for region A are handled as follows:

- This region has  $addr_h<34:30>$  equal to  $10110_2$  and addresses the lower 32MB of PCI sparse I/O space; thus,  $ad_h<31:25>$  are set to zero by the hardware. See Figure 6–10.
- ad\_h<24:3> are derived from addr\_h<29:8>.
- This region is used for (E)ISA addressing (the EISA 64KB I/O space cannot be relocated).
- **ad\_h<2:0>** are defined in Table 6–5.

#### Figure 6–10 PCI Sparse I/O Space Address Translation (Region A)



The high-order PCI address bits for region B are handled as follows:

- This region has **addr\_h<34:30**> equal to 10111<sub>2</sub> and addresses 32MB of PCI sparse I/O space that can be relocated.
- This 32MB segment is relocated by assigning **ad\_h<31:25**> equal to HAE\_IO<31:25>l as shown in Figure 6–11.

HAE\_IO is defined in Section 4.2.5. The power-on self-test (POST), running POST11 software, should initialize the contents of this register and the register should then remain unchanged.

- ad\_h<24:3> are derived from addr\_h<29:8>.
- **ad\_h<2:0>** are defined in Table 6–5.



## Figure 6–11 PCI Sparse I/O Space Address Translation (Region B)

| Size<br>addr_h<4:3> | Byte Offset | 21164<br>Instruction | PCI                    |                             | Data-In<br>Register |
|---------------------|-------------|----------------------|------------------------|-----------------------------|---------------------|
|                     |             |                      | ad_h<2:0> <sup>1</sup> | Byte <sup>2</sup><br>Enable | Byte Lanes<br>[7:0] |
| Byte                |             |                      |                        |                             |                     |
| 00                  | 00          | LDL, STL             | addr_h<7>,00           | 1110                        | <0>                 |
|                     | 01          |                      | addr_h<7>,01           | 1101                        | <1>                 |
|                     | 10          |                      | addr_h<7>,10           | 1011                        | <2>                 |
|                     | 11          |                      | addr_h<7>,11           | 0111                        | <3>                 |
| Word                |             |                      |                        |                             |                     |
| 01                  | 00          | LDL, STL             | addr_h<7>,00           | 1100                        | <1:0>               |
|                     | 01          |                      | addr_h<7>,01           | 1001                        | <2:1>               |
|                     | 10          |                      | addr_h<7>,10           | 0011                        | <3:2>               |
| Tribyte             |             |                      |                        |                             |                     |
| 10                  | 00          | LDL, STL             | addr_h<7>,00           | 1000                        | <2:0>               |
|                     | 01          |                      | addr_h<7>,01           | 0001                        | <3:1>               |
| Longword            |             |                      |                        |                             |                     |
| 11                  | 00          | LDL, STL             | addr_h<7>,00           | 0000                        | <3:0>               |
| Quadword            |             |                      |                        |                             |                     |
| 11                  | 11          | LDQ, STQ             | 000                    | 0000                        | <7:0>               |

#### Table 6–5 PCI I/O Sparse Space Read/Write Encodings

<sup>1</sup>Missing entries (such as word size with **addr\_h<6:5>** =  $11_2$ ) cause UNPREDICTABLE results. <sup>2</sup>Byte enable set to zero indicates that byte lane carries meaningful data.

The (E)ISA devices have reserved the lower 64KB of PCI I/O space (85.8000.0000 to 85.801F.FFFF). Hence, all PCI devices should be relocated above this region. Table 6–6 shows the PCI and (E)ISA I/O map for a 21164 system. Four (E)ISA slots are hardwired, allocating 4KB per slot (as per EISA standard). The first slot is reserved for the EISA system board (X-bus addressing, interrupt controller, and so forth).

| 21164 Address                 | PCI Address             | Range (KB)    | Selection                     |
|-------------------------------|-------------------------|---------------|-------------------------------|
| 85.8000.0000                  | 0000.0000               | 0-4           | EISA system board             |
| 85.8002.0000                  | 0000.1000               | 4-8           | EISA slot 1                   |
| 85.8004.0000                  | 0000.2000               | 8-12          | EISA slot 2                   |
| 85.8006.0000                  | 0000.3000               | 12-16         | EISA slot 3                   |
| 85.8008.0000                  | 0000.4000               | 16-20         | EISA slot 4                   |
| 85.800A.0000                  | 0000.5000               | 20-24         | Reserved                      |
| 85.800C.0000                  | 0000.6000               | 24-28         | Reserved                      |
| 85.800E.0000                  | 0000.7000               | 28-32         | Reserved                      |
| 85.8010.0000                  | 0000.8000               | 32-36         | Reserved                      |
| 85.8012.0000–<br>85.801F.FFFF | 0000.9000-<br>0000.FFFF | 36-64         | Reserved                      |
| 85.8020.0000–<br>85.BFFF.FFFF | 0001.0000–<br>01FF.FFFF | 64KB-<br>32MB | PCI I/O area—fixed            |
| 85.C000.0000–<br>85.FFFF.FFFF | 0200.0000–<br>03FF.FFFF | 32MB          | PCI I/O area—can be relocated |

#### Table 6–6 CIA PCI and (E)ISA I/O Map

\_\_\_\_\_ Note \_\_\_\_\_

A quadword access to the PCI sparse I/O space will result in a two-longword burst on the PCI. However, PCI devices might not support bursting in I/O space.

#### 6.2.4 PCI Configuration Space

PCI configuration space is located in the address range: 87.0000.0000 to 87.1FFF.FFFF. Software designers are advised to clear CIA\_CTRL [FILL\_ERR\_ EN] when probing for PCI devices using configuration space read transactions. This will prevent the CIA from generating an ECC error if no device responds to the configuration cycle and UNPREDICTABLE data is read from the PCI bus.

A 21164 read or write access to this address space causes a configuration read or write cycle on the PCI. The two types of targets selected, depending upon the value of the configuration register (CFG), are listed here and are shown in Figure 6-12.

- Type 0—These are targets on the primary 64-bit 21164 system PCI bus. These are selected by making CFG<1:0> equal to  $00_2$ .
- Type 1—These are targets on the secondary 32-bit 21164 system PCI bus (that is, behind a PCI–PCI bridge). These are selected by making CFG<1:0> equal to  $01_2$ .

\_\_\_\_\_ Note \_\_\_\_\_

CFG<1:0> equal to  $10_2$  and  $11_2$  are reserved by the PCI specification.



#### Figure 6–12 PCI Configuration Space Definition

LJ-04270.AI

Software must program CFG before running a configuration cycle. Sparse address decoding is used.

Note

The CIA uses CFG<1:0> instead of unused **addr\_h<38:35**> to be compatible with the DECchip 21071 core logic chipset. The DECchip 21071 core logic chipset is used with the Alpha 21064 microprocessor.

- The high-order PCI address bits **ad\_h<31:24**> are always zero.
- Address bits **addr\_h<28:7**> correspond to PCI **ad\_h<23:2**> and provide the configuration command information (which device to select).
- Address bits **addr\_h<6:3**> are used to generate both the length of the PCI transaction in bytes and the byte enables, as shown in Table 6–7.
- Address bits **ad\_h<1:0**> are obtained from CFG<1:0>.

| Size        | Byte Offset              | 21164<br>Instruction | PC                     |                             | Data-In<br>Register |  |
|-------------|--------------------------|----------------------|------------------------|-----------------------------|---------------------|--|
| addr_h<4:3> | addr_h<6:5> <sup>1</sup> |                      | ad_h<1:0> <sup>1</sup> | Byte <sup>2</sup><br>Enable | Byte Lanes<br>[7:0] |  |
| Byte        |                          |                      |                        |                             |                     |  |
| 00          | 00                       | LDL, STL             | CFG<1:0>               | 1110                        | <0>                 |  |
|             | 01                       |                      | CFG<1:0>               | 1101                        | <1>                 |  |
|             | 10                       |                      | CFG<1:0>               | 1011                        | <2>                 |  |
|             | 11                       |                      | CFG<1:0>               | 0111                        | <3>                 |  |
| Word        |                          |                      |                        |                             |                     |  |
| 01          | 00                       | LDL, STL             | CFG<1:0>               | 1100                        | <1:0>               |  |
|             | 01                       |                      | CFG<1:0>               | 1001                        | <2:1>               |  |
|             | 10                       |                      | CFG<1:0>               | 0011                        | <3:2>               |  |
| Tribyte     |                          |                      |                        |                             |                     |  |
| 10          | 00                       | LDL, STL             | CFG<1:0>               | 1000                        | <2:0>               |  |
|             | 01                       |                      | CFG<1:0>               | 0001                        | <3:1>               |  |
| Longword    |                          |                      |                        |                             |                     |  |
| 11          | 00                       | LDL, STL             | CFG<1:0>               | 0000                        | <3:0>               |  |
| Quadword    |                          |                      |                        |                             |                     |  |
| 11          | 11                       | LDQ, STQ             | CFG<1:0>               | 0000                        | <7:0>               |  |

#### Table 6–7 PCI Configuration Space Read/Write Encodings

<sup>1</sup>Missing entries (such as word size with **addr\_h<6:5>** =  $11_2$ ) cause UNPREDICTABLE results. <sup>2</sup>Byte enable set to zero indicates that byte lane carries meaningful data.

#### 6.2.4.1 Device Select (IDSEL)

Peripherals are selected during a PCI configuration cycle if these three statements are true:

- Their IDSEL pin is asserted.
- The PCI bus command indicates a configuration read or write transaction.
- Address bits <1:0> are 00.

Address bits <7:2> select a longword register in the peripheral's 256-byte configuration address space. Transactions can use byte masks.

Peripherals that integrate multiple functional units (like SCSI and Ethernet) can provide configuration space for each function. Address bits **ad\_h<10:8**> can be decoded by the peripheral to select one of eight functional units. Address bits **ad\_h<31:11**> are available to generate the IDSELs. (Note that IDSELs behind a PCI–PCI bridge are determined from the device field encoding of a type 1 access.)

The IDSEL pin of each device corresponds to a unique PCI address bit from **ad\_h<31:11**>. The binary value of **addr\_h<20:16**> is used to select an address that is asserted on **ad\_h<31:11**>, as listed in Table 6–8.

| addr_h<20:16> | ad_h<31:11>–IDSEL                 |  |
|---------------|-----------------------------------|--|
| 00000         | 0000 0000 0000 0000 0000 1        |  |
| 00001         | 0000 0000 0000 0000 0001 0        |  |
| 00010         | 0000 0000 0000 0000 0010 0        |  |
| 00011         | 0000 0000 0000 0000 0100 0        |  |
|               |                                   |  |
| 10011         | 0100 0000 0000 0000 0000 0        |  |
| 10100         | 1000 0000 0000 0000 0000 0        |  |
| 10101         | $0000 \ 0000 \ 0000 \ 0000 \ 0^1$ |  |
|               |                                   |  |
| 11111         | $0000 \ 0000 \ 0000 \ 0000 \ 0^1$ |  |

Table 6–8 Generating IDSEL Pin Signals

Note

If a quadword access is specified for the configuration cycle, then the least significant bit (LSB) of the register number field, **ad\_h<2**>, must be zero. A quadword read/write transaction must access quadword-aligned registers.

If the PCI cycle is a configuration read or write cycle but  $ad_h<1:0>$  equals  $01_2$  (like a type 1 transfer), then a device on a hierarchical bus is being selected using a PCI–PCI bridge. This cycle is accepted by the PCI–PCI bridge for propagation to its secondary PCI bus. During this cycle,  $ad_h<23:16>$  selects a unique bus number;  $ad_h<15:8>$  selects a device on that bus (typically decoded by the PCI–PCI bridge to generate the secondary PCI address pattern for IDSEL); and  $ad_h<7:2>$  selects a longword in the device's configuration space.

Each PCI–PCI bridge can be configured by PCI configuration cycles on its primary PCI interface. Configuration parameters in the PCI–PCI bridge will identify the bus number for its secondary PCI interface, and a range of bus numbers that can exist hierarchically behind it.

If the bus number of the configuration cycle matches the bus number of the PCI–PCI bridge secondary PCI interface, it will accept the configuration cycle, decode it, and generate a PCI configuration cycle with address bits <1:0> = 00 on its secondary PCI interface.

If the bus number is within the range of bus numbers that may exist hierarchically behind its secondary PCI interface, the PCI–PCI bridge passes the PCI configuration cycle on unmodified (address bits <1:0> = 01). It will be accepted by a bridge further downstream.

Figure 6–13 shows the PCI hierarchy for systems using the CIA. The IDSEL lines are significant in type 0 configuration cycles, and the PCI nodes are connected as tabulated in Table 6–9.





| Device Slot Assignment         | IDSEL Bit | Module<br>Reference | PCI Slot Number<br>(Firmware) |
|--------------------------------|-----------|---------------------|-------------------------------|
| 64-bit PCI slot 0 <sup>1</sup> | ad_h<18>  | J11                 | 7                             |
| 64-bit PCI slot 1              | ad_h<23>  | J10                 | 12                            |
| 64-bit PCI slot 2              | ad_h<22>  | J9                  | 11                            |
| 32-bit PCI slot 3              | ad_h<19>  | J8                  | 8                             |
| 32-bit PCI slot 4 <sup>2</sup> | ad_h<20>  | J7                  | 9                             |
| PCI-to-EISA bridge             | ad_h<21>  | _                   | 10                            |

Table 6–9 Primary 64-Bit PCI IDSEL Mapping

#### 6.2.4.2 PCI Special/Interrupt Acknowledge Cycles

PCI special/interrupt acknowledge cycle addresses are located in the range 87.2000.0000 to 87.3FFF.FFFF.

The special cycle command provides a simple message broadcasting mechanism on the PCI.

The special cycle contains no explicit destination address, but is broadcast to all devices. The CIA will drive all zeros as the special cycle address. Each receiving device must determine if the message contained in the data field is applicable to it.

A write transaction to address range 87.2000.0000 to 87.3FFF.FFFF causes a special cycle write transaction on the PCI. The 21164 write data will be passed unmodified to the PCI. Software must write the data in longword 0 of the hexword within the following fields:

- Bytes 0 and 1 contain the encoded message.
- Bytes 2 and 3 contain a message-dependent (optional) data field.

A read to address range 87.2000.0000 to 87.3FFF.FFFF will result in an interrupt acknowledge cycle on the PCI returning the vector data, which is provided by the PCI-to-EISA bridge, to the 21164.

#### 6.2.4.3 Hardware-Specific and Miscellaneous Register Space

Hardware-specific and miscellaneous register space is located in the range 87.4000.0000 to 87.FFFF.FFFF. Table 6–10 lists the regions, with hardware registers, within this space.

| addr_h<39:28>     | Selected Region                                           | addr_h<27:6> | addr_<br>h<5:0> |
|-------------------|-----------------------------------------------------------|--------------|-----------------|
| 87.4 <sup>1</sup> | CIA control, diagnostic, error registers                  | LW address   | 000000          |
| 87.5 <sup>1</sup> | CIA memory control registers                              | LW address   | 000000          |
| 87.6 <sup>1</sup> | CIA PCI adddress translation<br>(S/G, windows, and so on) | LW address   | 000000          |
| 87.7 to 87.F      | Reserved                                                  | —            | —               |

Table 6–10 Hardware-Specific Register Address Space

<sup>1</sup>This address space is a hardware-specific variant of sparse space encoding. For the CSRs, **addr\_h<27:6**> specify a longword address where **addr\_h<5:0**> must be zero. All CIA registers are accessed with LW granularity. For more specific details on the CIA CSRs, refer to Chapter 4.

# 6.3 PCI to Physical Memory Addressing

This section describes direct and scatter-gather mapping through the use of windows.

#### 6.3.1 Address Mapping Windows

PCI addresses coming into the CIA (32-bit or 64-bit) are mapped to the 21164 cached memory space (8GB). The CIA provides four programmable address windows that control access of PCI peripherals to system memory. Each window location is defined by its base register ( $Wn_BASE$ ) and its size is defined by its mask register ( $Wn_MASK$ ).

Mapping from the PCI address to a physical memory address can be direct (physical mapping with an address offset) or scatter-gather (virtual mapping).

The four PCI address windows are also referred to as the PCI target windows. Each window has three registers associated with it. They are:

- PCI base register (Wn\_BASE)
- PCI mask register (Wn\_MASK)
- Translation base register (Tn\_BASE)

In addition, there is an another register that is associated with window 3 only. It is the PCI window DAC base register (W\_DAC). It is used for PCI 64-bit addresses (DAC).

 $Wn_MASK$  provides a mask corresponding to bits <31:20> of an incoming PCI address. The size of each window can be programmed to be from 1MB to 4GB in powers of two, by masking bits of the incoming PCI address using  $Wn_MASK$  as shown in Table 6–11.

| W_MASK<31:20>  | Size of Window | Value of <i>n</i> <sup>1</sup> |  |
|----------------|----------------|--------------------------------|--|
| 0000 0000 0000 | 1MB            | 20                             |  |
| 0000 0000 0001 | 2MB            | 21                             |  |
| 0000 0000 0011 | 4MB            | 22                             |  |
| 0000 0000 0111 | 8MB            | 23                             |  |
| 0000 0000 1111 | 16MB           | 24                             |  |
| 0000 0001 1111 | 32MB           | 25                             |  |
| 0000 0011 1111 | 64MB           | 26                             |  |
| 0000 0111 1111 | 128MB          | 27                             |  |
| 0000 1111 1111 | 256MB          | 28                             |  |
| 0001 1111 1111 | 512MB          | 29                             |  |
| 0011 1111 1111 | 1GB            | 30                             |  |
| 0111 1111 1111 | 2GB            | 31                             |  |
| 1111 1111 1111 | 4GB            | 32                             |  |
| All others     | UNPREDICTABLE  | _                              |  |

Table 6–11 PCI Target Window MASK Register (Wn\_MASK)

<sup>1</sup>Only incoming **ad\_h<31**:*n*> are compared with PCI base register <31:*n*> as shown in Figure 6–15. If *n*=32, no comparison is performed. Windows are not allowed to overlap.

Based on the value of the window mask register, the unmasked bits of the incoming PCI address are compared with the corresponding bits of each window's  $Wn_BASE$ . If one of the four  $Wn_BASE$  addresses and the incoming PCI address match, then the PCI address has hit that PCI target window. Otherwise, it has missed the window.

A window enable bit, W*n*\_BASE [W\_EN], lets windows be independently enabled ([W\_EN]=1) or disabled ([W\_EN]=0). If a hit occurs in any of the four windows that are enabled, then the CIA will respond to the PCI cycle by asserting **devsel\_l**. The PCI target windows must be programmed so that their address ranges do not overlap. If they overlap, the compare results are UNDEFINED.

The window base address must be on a NATURALLY ALIGNED address boundary corresponding to the size of the window. For example, a 4MB window cannot start at address 1MB; it must start at address 4MB, or 8MB, or 12MB, and so on.

#### 6.3.1.1 PCI Device Address Space

A PCI device specifies the amount of memory space it requires by using base registers in its configuration space. The registers are implemented such that the address space consumed by the device is a power of two in size, and is NATURALLY ALIGNED on the size of the space consumed.

A PCI device need not use all of the address range it consumes, that is, the size of the PCI address window defined by the base address. Also, a PCI device need not respond to unused portions of the address space. The one exception to this is a PCI bridge that requires two additional registers (the base and limit address registers). These registers specify the address space that the PCI bridge will respond to in transactions.

A PCI bridge responds to all addresses in the range: base  $\leq$  address < limit.

These base and limit address registers are initialized by POST code at powerup. The CIA, as a PCI host-bridge device, does not have base and limit registers. Host bridges, because they are under system control, do not have to operate within the rules for other PCI devices. The CIA does respond to all the addresses within the four windows.

#### 6.3.1.2 Address Mapping Example

Figure 6–14 shows how the DMA address ranges of a number of PCI devices are within the PCI window ranges. PCI devices are allowed to have multiple DMA address ranges, like device 2.



Figure 6–14 PCI DMA Address Example

Figure 6–14 also shows that the CIA window can be larger than the corresponding device's DMA address range, as with device 0. Devices 1 and 2 have address ranges that are accepted by one CIA window.  $Wn_BASE$  [ $Wn_BASE_SG$ ] for each window determines whether direct mapping or scatter-gather mapping is used to access physical memory.

PCI single and dual address cycles have the following characteristics:

- Dual address cycle (DAC)—issued only if <63:32> are non-zero in 64-bit PCI address mode, and only if enabled by W3\_BASE[DAC\_ENABLE].
- Single address cycle (SAC)—all 32-bit addresses. A PCI device must use SAC if bits <63:32> of a 64-bit address equal zero.

Figure 6–15 shows the PCI window comparison logic.





The comparison logic associated with **ad\_h<63:32**> is used only for DAC with window 3. The other windows recognize only 32-bit PCI addresses (SAC).

For a hit to occur on a DAC address, address bits <63:40> must be zero and **ad\_h<39:32**> must match the W\_DAC[DAC\_BASE<7:0>]. The low-order address bits **ad\_h<31:20**> must also hit. This scheme allows a NATURALLY ALIGNED 1MB to 4GB PCI window to be placed anywhere in the first 1TB of a 64-bit PCI address space.

When an address match occurs with a PCI target window, the CIA translates the 32-bit PCI address **ad\_h<31:0**> to **memdata\_h<33:0**>. The translated address is generated in one of two ways as determined by  $Wn_BASE[Wn_BASE_SG]$ .

#### 6.3.2 Direct Mapped Addressing

If W*n*\_BASE [W*n*\_BASE\_SG] is clear, the DMA address is direct mapped. The translated address is generated by concatenating bits from the matching window's T*n*\_BASE with bits from the incoming PCI address (**ad\_h**<**31:0**>). This process is shown in Figure 6–16 with *n* being the LSB from the T*n*\_BASE column of Table 6–12.



#### Figure 6–16 Direct Mapped Translation

The bits involved in the concatenation are defined by the window's  $Wn_MASK$ , as shown in Table 6–12. Because memory is located in the lower 8GB of the 21164 address space, the CIA implicitly ensures that **addr\_h<39:33**> are always zero. Because  $Tn_BASE$  is simply concatenated to the PCI address, direct mapping is to a NATURALLY ALIGNED memory region. For example, a 4MB direct-mapped window will map to any 4MB region in main memory that falls on a 4MB boundary.

| W MASK         | Size of        | Translated Address Source |              |  |
|----------------|----------------|---------------------------|--------------|--|
|                | <31:20> Window |                           | PCI Address  |  |
| 0000 0000 0000 | 1MB            | addr_h<32:20>             | addr_h<19:2> |  |
| 0000 0000 0001 | 2MB            | addr_h<32:21>             | addr_h<20:2> |  |
| 0000 0000 0011 | 4MB            | addr_h<32:22>             | addr_h<21:2> |  |
| 0000 0000 0111 | 8MB            | addr_h<32:23>             | addr_h<22:2> |  |
| 0000 0000 1111 | 16MB           | addr_h<32:24>             | addr_h<23:2> |  |
| 0000 0001 1111 | 32MB           | addr_h<32:25>             | addr_h<24:2> |  |
| 0000 0011 1111 | 64MB           | addr_h<32:26>             | addr_h<25:2> |  |
| 0000 0111 1111 | 128MB          | addr_h<32:27>             | addr_h<26:2> |  |
| 0000 1111 1111 | 256MB          | addr_h<32:28>             | addr_h<27:2> |  |
| 001 1111 1111  | 512MB          | addr_h<32:29>             | addr_h<28:2> |  |
| 011 1111 1111  | 1GB            | addr_h<32:30>             | addr_h<29:2> |  |
| )111 1111 1111 | 2GB            | addr_h<32:31>             | addr_h<30:2> |  |
| 111 1111 1111  | 4GB            | addr_h<32>                | addr_h<31:2> |  |

Table 6–12 Direct-Mapped PCI Target Address Translation

 $^1 \rm Unused$  bits of T\_n\_BASE must be cleared because the hardware performs an OR operation for the concatenation.

#### 6.3.3 Scatter-Gather Addressing

When W*n*\_BASE[W*n*\_BASE\_SG] is set, the translated address is generated using a table lookup. The table is referred to as a scatter-gather map.

The incoming PCI address is compared to the PCI window addresses for a hit. The  $Tn_BASE$  of the window that was hit is used to specify the starting address of the scatter-gather map table in memory.

Part of the incoming PCI address is used as an offset from this starting address to access the scatter-gather page table entry (PTE). This PTE, together with the remaining least-significant PCI address bits, forms the 21164 memory address.

Each scatter-gather map entry maps an 8KB page of PCI address space into an 8KB page of 21164 address space. This offers a number of advantages to software:

• Performance—ISA devices map to the lower 16MB of memory. The Windows NT operating system currently copies data from here to user space. The scatter-gather map avoids this copy operation.

• Address management—User I/O buffers might not be physically contiguous or contained within a page. Without scatter-gather maps, software has to manage the scattered nature of the user buffer.

In peripheral components architecture, the term scatter-gather is not an address translation scheme but instead is used to signify a DMA transfer list. An element of this transfer list contains the DMA address and the number of data items to transfer. The DMA device fetches each item of the list until the list is empty. Many of the PCI devices, such as the PCI-to-EISA bridge, support this form of scatter-gather process.

Each scatter-gather PTE is a quadword and has a valid bit in PTE<0> as shown in Figure 6–17. Page address bit <13> is at PTE<1>.



#### Figure 6–17 Scatter-Gather PTE Format

LJ-04275.AI

Because the CIA implements only valid memory addresses up to 8GB, scattergather PTE bits <63:21> must be set to zero. PTE bits <20:1> are used to generate the physical page address. This address is appended to **ad\_h<12:5**> of the incoming PCI address to generate the memory address.

The size of the scatter-gather map table is determined by the size of the PCI target window defined by  $Wn_MASK$ , as shown in Table 6–13. The number of entries is the window size divided by the page size (8KB). The size of the table is simply the number of entries multiplied by 8 bytes.

The scatter-gather map table address is obtained from  $Tn_BASE$  and the PCI address, as shown in Table 6–13.

| W MASK         | Size of | S-G Map    | Scatter-Gather Map Address < |             |
|----------------|---------|------------|------------------------------|-------------|
| <31:20>        | Window  | Table Size | Tn_Base <sup>1</sup>         | PCI Address |
| 0000 0000 0000 | 1MB     | 1KB        | <32:10 >                     | <19:13>     |
| 0000 0000 0001 | 2MB     | 2KB        | <32:11>                      | <20:13>     |
| 0000 0000 0011 | 4MB     | 4KB        | <32:12>                      | <21:13>     |
| 0000 0000 0111 | 8MB     | 8KB        | <32:13>                      | <22:13>     |
| 0000 0000 1111 | 16MB    | 16KB       | <32:14>                      | <23:13>     |
| 0000 0001 1111 | 32MB    | 32KB       | <32:15>                      | <24:13>     |
| 0000 0011 1111 | 64MB    | 64KB       | <32:16>                      | <25:13>     |
| 0000 0111 1111 | 128MB   | 128KB      | <32:17>                      | <26:13>     |
| 0000 1111 1111 | 256MB   | 256KB      | <32:18>                      | <27:13>     |
| 0001 1111 1111 | 512MB   | 512KB      | <32:19>                      | <28:13>     |
| 0011 1111 1111 | 1GB     | 1MB        | <32:20>                      | <29:13>     |
| 0111 1111 1111 | 2GB     | 2MB        | <32:21>                      | <30:13>     |
| 1111 1111 1111 | 4GB     | 4MB        | <32:22>                      | <31:13>     |

 Table 6–13
 Scatter-Gather Mapped PCI Target Address Translation

<sup>1</sup>Unused bits of  $Tn_BASE$  must be zero for correct operation.

#### 6.3.3.1 Scatter-Gather Translation Lookaside Buffer (TLB)

An 8-entry translation lookaside buffer (TLB) is provided in the CIA for scatter-gather PTEs. The TLB is a fully associative cache and holds the eight most recent scatter-gather map lookups. Four of these entries can be "locked," preventing their displacement by the hardware TLB-miss handler. Each of the eight TLB entries holds a PCI address for the tag, and four consecutive 8KB page addresses as the TLB data, as shown in Figure 6–18.





Each time an incoming PCI address hits in a PCI target window that has scatter-gather enabled, **ad\_h<31:15**> are compared with the 32KB PCI page address in the TLB tag. If a match is found, the required 21164 page address is one of the four items provided by the data in the matching TLB entry. Address bits **ad\_h<14:13**> select the correct 8KB page address from the four addresses fetched.

With a TLB hit, the scatter-gather map table lookup in memory is avoided, resulting in enhanced performance. If no match is found in the TLB, the scatter-gather map lookup is performed and four PTE entries are fetched and written over an existing entry in the TLB. The TLB entry to be replaced is determined by a round-robin algorithm on the "unlocked" entries. Coherency of the TLB is maintained by software write transactions (invalidates) to the TBIA. See Section 4.7.1.

The TAG portion of the TLB entry contains a DAC flag to indicate that PCI tag address bits <31:15> correspond to a 64-bit DAC address. Only one bit is required instead of the high-order PCI address bits **ad\_h<39:32**> because only window 3 is assigned to a DAC cycle, and the window hit logic has already performed a comparison of the high-order address bits against W\_DAC.

Figure 6–19 shows the entire translation process, from PCI address to physical address, on a window that implements scatter-gather. The MSB from the PCI address column of Table 6–13 equals n–1. Both paths are indicated: the path for a TLB hit is to the right, and the path for a TLB miss is to the left. The scatter-gather TLB is shown in a slightly simplified but functionally equivalent form.

**6.3.3.1.1 Scatter-Gather TLB Hit Process** The process for a scatter-gather TLB hit is as follows:

- The window compare logic determines if the PCI address has hit in one of the four windows and Wn\_BASE[Wn\_BASE\_SG] determines if the scatter-gather path should be taken. If window 3 has DAC mode enabled, and the PCI cycle is a DAC cycle, then a further comparison is made between the high-order PCI bits and W\_DAC.
- Address bits **ad\_h<31:13**> are sent to the TLB associative tag together with the DAC hit indication. If the address and DAC bits match in the TLB, the corresponding 8KB page, 21164 memory address is read out of the TLB. If this entry is valid, then a TLB hit has occurred and this page address is concatenated with **ad\_h<12:2**> to form the physical memory address. If the data entry is invalid or if the TAG compare failed, a TLB miss occurs.

**6.3.3.1.2 Scatter-Gather TLB Miss Process** The process for a scatter-gather TLB miss is as follows:

- The relevant bits of the PCI address (as determined by W*n*\_MASK) are concatenated with the relevant T*n*\_BASE bits to form the address used to access the scatter-gather PTE from a table located in main memory.
- Scatter-gather PTE<20:1> are used to generate the page address that is appended to the page offset to generate the physical memory address.

At this point, the TLB is also updated (round-robin algorithm) with the four PTE entries that correspond to the 32KB PCI page 21164 memory address that first missed the TLB. The tag portion of the TLB is loaded with this PCI page address, and the DAC bit is set if this PCI cycle is a DAC cycle.

• If the requested PTE is marked invalid (bit 0 clear), then a TLB invalid entry exception is taken.

Preliminary Edition—Subject to Change—September 1995 6-39



#### Figure 6–19 Scatter-Gather Map Translation

#### 6.3.4 Suggested Use of a PCI Window

Figure 6–20 shows a power-up PCI window assignment (as configured by firmware) and Table 6–14 lists the details. PCI window 0 was chosen for the 8MB to 16MB EISA region because this window incorporates the **mem\_cs\_l** logic. PCI window 3 was not used as it incorporates the DAC cycle logic. PCI window 1 was chosen arbitrarily for the 1GB, direct-mapped region, and PCI window 2 is not assigned.



#### Figure 6–20 Default PCI Window Allocation

| PCI Window | Assignment     | Size | Comments                                           |
|------------|----------------|------|----------------------------------------------------|
| 0          | Scatter-Gather | 8MB  | Not used by firmware.<br><b>mem_cs_l</b> disabled. |
| 1          | Direct Mapped  | 1GB  | Mapped to 0GB to 1GB of main memory.               |
| 2          | Disabled       | _    | —                                                  |
| 3          | Disabled       | —    | —                                                  |

Table 6–14 PCI Window Power-Up Configuration

#### 6.3.4.1 Peripheral Component Architecture Compatibility Addressing and Holes

The peripheral component architecture allows certain (E)ISA devices to respond to hardwired memory addresses. An example is a VGA graphics device that has its frame buffer located in memory address region A0000–BFFFF. Such devices "pepper" memory space with holes that are collectively known as peripheral component architecture compatibility holes.

The PCI-to-EISA bridge decodes PCI addresses and generates a signal, **mem\_cs\_l**, that takes into account the various compatibility holes.

#### 6.3.4.2 Memory Chip Select Signal mem\_cs\_l

The PCI-to-EISA bridge set can be made using these two chips:

- Intel 82374EB EISA System Component (ESC)
- Intel 82375EB PCI-to-EISA Bridge (PCEB)

The PCI-to-EISA bridge provides address decode logic with attributes (such as read only, write only, VGA frame buffer, memory holes, and BIOS shadowing) to help manage the EISA memory map and peripheral component architecture compatibility holes.

This is known as main memory decoding in the PCEB chip, and results in the generation of the memory chip select (**mem\_cs\_l**) signal. One exception is the VGA memory hole region that never asserts **mem\_cs\_l**. If enabled, the CIA uses **mem\_cs\_l** with W0\_BASE.

In Figure 6–21, the two main holes are lightly shaded while the **mem\_cs\_l** range is darkly shaded.

The **mem\_cs\_l** range of Figure 6–21 is subdivided into several portions (such as the BIOS area) that are individually enabled/disabled using CSRs as listed here:

- The MCSTOM (top of memory) register has 2MB granularity and can be programmed to select the regions from 1MB up to 512MB.
- The MCSTOH (top of hole) and MCSBOH (bottom of hole) registers define a memory hole region where **mem\_cs\_l** is not selected. The granularity of the hole is 64KB.
- The MAR1, 2, and 3 registers enable various BIOS regions.
- The MCSCON (control) register enables the **mem\_cs\_l** decode logic, and in addition selects a number of regions (0KB to 512KB).

\_\_\_\_\_ Note \_\_\_\_\_

For more detail, please refer to the Intel 82375EB specification.





As shown in Figure 6–22, PCI window 0 in the CIA can be enabled to accept the **mem\_cs\_l** signal as the PCI memory decode signal. With this path enabled, the PCI window hit logic simply uses the **mem\_cs\_l** signal. For example, if **mem\_cs\_l** is asserted, then a PCI window 0 hit occurs and the **dev\_sel\_l** signal is asserted on the PCI.





Consequently, the window address area must be large enough to encompass the **mem\_cs\_l** region programmed into the PCI-to-EISA bridge. The remaining window attributes are still applicable and/or required.

- W0\_BASE [Wn\_BASE\_SG] determines if scatter-gather or direct mapping is applicable.
- W0\_MASK size information must match the **mem\_cs\_l** size in order for the scatter-gather and direct-mapping algorithms to correctly use the translated base register.
- The **mem\_cs\_l** enable bit, W0\_BASE [MEMCS\_ENABLE], takes precedence over W0\_BASE [W\_EN].

# DECchip 21171-BA (DSW) Information

Part II contains two chapters that provide information about the DECchip 21171-BA (DSW) chip. The following table lists the topics described in each chapter:

| Chapter | Description  |  |
|---------|--------------|--|
| 7       | Pin signals  |  |
| 8       | Architecture |  |

# **7** DECchip 21171-BA Pin Descriptions

This chapter provides a description of the DECchip 21171-BA pin signals.

# 7.1 DECchip 21171-BA Pin List

Table 7–1 lists the pin signals grouped by function. The information in the Type column identifies a signal as input (I), output (O), bidirectional (B), or power (P).

| Signal Name      | Quantity | Туре      | Signal Name          | Quantity | Туре |
|------------------|----------|-----------|----------------------|----------|------|
|                  | 5        | sysBus Si | gnals (36 Total)     |          |      |
| cpu_dat_h<35:0>  | 36       | В         | _                    | —        | —    |
|                  | IC       | OD Bus S  | ignals (34 Total)    |          |      |
| cmc_h<8:0>       | 9        | Ι         | ioc_h<6:0>           | 7        | 0    |
| iod_h<17:0>      | 18       | В         | —                    | _        | —    |
|                  | MEN      | IDATA Bu  | s Signals (73 Total) |          |      |
| mem_data_h<71:0> | 72       | В         | mem_en_h             | 1        | Ι    |
|                  |          | PLL Sig   | nals (6 Total)       |          |      |
| pll_agnd_h       | 1        | 0         | pll_clk_h            | 1        | Ι    |
| pll_lp1_h        | 1        | 0         | _<br>pll_lp2_h       | 1        | Ι    |
| pll_vdd_h        | 1        | Ι         | pll_vss_h            | 1        | Ι    |

(continued on next page)

#### DECchip 21171-BA Pin Descriptions 7.1 DECchip 21171-BA Pin List

| Signal Name    | Quantity | Туре       | Signal Name               | Quantity | Туре |
|----------------|----------|------------|---------------------------|----------|------|
|                | Mise     | cellaneous | s Signals (11 Total)      |          |      |
| config_h<1:0>  | 2        | Ι          | spare1_or_count_<br>out_h | 1        | 0    |
| spare<4:2>     | 3        | Ι          | reset_l                   | 1        | Ι    |
| scan_in_h      | 1        | Ι          | test_or_scan_out_h        | 1        | 0    |
| test_mode<1:0> | 2        | Ι          | _                         | _        | _    |

#### Table 7–1 (Cont.) DECchip 21171-BA Pin List

#### **Pin Totals**

| Total input pins:         | 14  |
|---------------------------|-----|
| Total output pins:        | 20  |
| Total bidirectional pins: | 126 |
|                           |     |
| Total signal pins:        | 160 |
| m · 1 · . 1 ·             | 100 |
| Total signal pins:        | 160 |
| Total power pins:         | 24  |
| Total ground pins:        | 24  |
|                           |     |
| Total pins:               | 208 |

# 7.2 DECchip 21171-BA Signal Descriptions

This section provides pin signal information, including a description of the signal; the clock edge on which the signal changes; and rules about signal usage during various sysBus transactions.

For simplicity, the rising edge of **sys\_clk\_out1\_h** will be indicated by the name clk1R and the falling edge of **sys\_clk\_out1\_h** will be indicated by the name clk1F. See Section 7.2.4 for more information about clock use on the DSW.

Signal descriptions are grouped by function and correspond to the pin list (see Table 7–1).

#### 7.2.1 sysBus Signals

This section describes the sysBus data signal lines.

#### cpu\_dat\_h<35:0>

The **cpu\_dat\_h**<**35:0**> signals carry data between the 21164, Bcache, and the DSW. Using four DSW chips in parallel results in 144 signal lines that carry 128 data bits and 16 ECC bits. There are no specific data and ECC bits. All bits are treated the same in the DSW. ECC generation and checking is performed in the 21164 and CIA.

By default, **cpu\_dat\_h<35:0>** are in the tristate condition as a DSW internal signal; Drive\_CPU\_L, is in the high state. This allows data to be read into the DSW from the 21164 or Bcache. The data source is controlled by the 21164. Data is clocked into the DSW every CLKX cycle.

When Drive\_CPU\_L is in the low state, the DSW drives data onto **cpu\_dat\_h<35:0**> during each CLKX cycle.

#### 7.2.2 IOD Bus Signals

This section describes the IOD bus signals.

#### iod<17:0>

The **iod**<**17:0**> signals carry data and ECC between the CIA and DSW on the IOD bus. Four DSW slices together drive and receive 72 data/ECC signal lines on the IOD bus between the DSW and the CIA.

The DSW slices treat all bits in the same manner and are unaware of the concept of ECC. No specific bits are dedicated to ECC nor data. All ECC generation and detection is performed in the 21164 and CIA.

The DSW puts these signal lines in tristate mode by default by deasserting an internal DSW signal, Drive\_IOD\_L. The DSW asserts Drive\_IOD\_L and so drives data to the CIA every CLKX cycle.

#### ioc\_h<6:0>

The **ioc**<**6:0**> signals allow the CIA to control data flow on the IOD bus. The data transfers are between memory and the PCI bus. CIA control is encoded as shown in Table 7–2.

|                | —                                    |                             |              |              |                                        |
|----------------|--------------------------------------|-----------------------------|--------------|--------------|----------------------------------------|
| ioc_h<br><6:4> | ioc_h<br><3>                         | ioc_h<br><2>                | ioc_h<br><1> | ioc_h<br><0> | Function                               |
| 000            | Buffer n                             | x                           | x            | x            | Clear valid bits in PCI buffer n.      |
| 001            | x                                    | х                           | х            | x            | Load the LW register (Reserved).       |
| 010            | Buffer n                             | Adr m2                      | Adr m1       | Adr m0       | Write PCI buffer <i>n</i> , adr m.     |
| 011            | Mask3                                | Mask2                       | Mask1        | Mask0        | Write IOR (QW mask).                   |
| 100            | Buffer n                             | Adr m2                      | Adr m1       | Adr m0       | Read DMA buffer <i>n</i> , adr m.      |
| 101            | Buffer n1                            | Buffer n0                   | Adr m1       | Adr m0       | Read IOW buffer <i>n</i> , adr m.      |
| 110            | Buffer <i>n</i> 1<br>Buffer <i>n</i> | Buffer <i>n</i> 0<br>Adr m2 | Adr m1       | Adr m0       | Read buffer (IOW or DMA) low longword. |
| 111            | Mask3                                | Mask2                       | Mask1        | Mask0        | Start IOW (buffer mask).               |
|                |                                      |                             |              |              |                                        |

Table 7–2 ioc\_h<6:0> Control Functions

#### cmc\_h<8:0>

The **cmc\_h<8:0**> signal lines control flow of data between the 21164 and the memory arrays. They also start and stop loading of the free-running buffers (victim, flush, IOW buffers) in the DSW. In Table 7–3, A5 and A4 are address bits. The Var field encodes the transaction being performed as shown in Table 7–4, Table 7–5, and Table 7–6.

Table 7–3 cmc\_h<8:0> Control Functions

| cmc_h<br><8:5> | cmc_h<br><4>       | cmc_h<br><3> | cmc_h<br><2> | cmc_h<br><1> | cmc_h<br><0> | Function                             |
|----------------|--------------------|--------------|--------------|--------------|--------------|--------------------------------------|
| 0000           | Var 4 <sup>1</sup> | Var 3        | Var 2        | Var 1        | Var 0        | Start/stop the buffer.               |
| 0010           | X                  | $A4^2$       | Delay        | Var 1        | Var 0        | Move fill data from memory to 21164. |
| 0011           | х                  | A4           | x            | Var 1        | Var 0        | Move IOR buffer data to 21164.       |
| 0100           | A5 <sup>2</sup>    | A4           | Delay        | Var 1        | Var 0        | Move memory data to memory buffer 0. |
| 0101           | A5                 | A4           | Delay        | Var 1        | Var 0        | Move memory data to memory buffer 1. |

 $^{1}$ The variable field encodes the transaction being performed. See Table 7–4, Table 2–5, and Table 2–6.  $^{2}$ A5 and A4 are address bits.

(continued on next page)

| cmc_h<br><8:5> | cmc_h<br><4> | cmc_h<br><3> | cmc_h<br><2> | cmc_h<br><1>           | cmc_h<br><0>           | Function                                                              |
|----------------|--------------|--------------|--------------|------------------------|------------------------|-----------------------------------------------------------------------|
| 0110           | A5           | A4           | Delay        | Stop<br>IOW <i>n</i> 1 | Stop<br>IOW <i>n</i> 0 | Move memory data to<br>memory buffer 0, stop<br>IOW buffer <i>n</i> . |
| 0111           | A5           | A4           | Delay        | Stop<br>IOW <i>n</i> 1 | Stop<br>IOW <i>n</i> 0 | Move memory data to<br>memory buffer 1, stop<br>IOW buffer <i>n</i> . |
| 1000           | A5           | A4           | Var 2        | Var 1                  | Var 0                  | Write victim buffer to<br>memory.                                     |
| 1010           | A5           | A4           | Var 2        | Var 1                  | Var 0                  | Write DMA0 buffer to<br>memory.                                       |
| 1011           | A5           | A4           | Var 2        | Var 1                  | Var 0                  | Write DMA1 buffer to memory.                                          |

Table 7–3 (Cont.) cmc\_h<8:0> Control Functions

| Table 7–4 | Var Encodings | for CMC | Command 0 |
|-----------|---------------|---------|-----------|
|-----------|---------------|---------|-----------|

| Var<4:3> | Function                                         |
|----------|--------------------------------------------------|
| 00       | None.                                            |
| 01       | Start victim.                                    |
| 10       | Start flush buffer 0 and clear PCI 0 valid bits. |
| 11       | Start flush buffer 1 and clear PCI 0 valid bits. |

| Table 7–5 | Var Encodings for CMC Commands 0, 8, A, and B |
|-----------|-----------------------------------------------|
|-----------|-----------------------------------------------|

| Var<2:0> | Function             |
|----------|----------------------|
| 000      | None.                |
| 001      | Stop victim.         |
| 010      | Stop flush buffer 0. |
| 011      | Stop flush buffer 1. |
| 100      | Stop IOW 0.          |
| 101      | Stop IOW 1.          |
| 110      | Stop IOW 2.          |
| 111      | Stop IOW 3.          |

.....

| Var<1:0> | Function             |
|----------|----------------------|
| 00       | None.                |
| 01       | Stop victim.         |
| 10       | Stop flush buffer 0. |
| 11       | Stop flush buffer 1. |

#### 7.2.3 MEMDATA Bus Signals

This section describes the MEMDATA bus signals.

#### mem\_data\_h<71:0>

The **mem\_data\_h<71:0>** signals carry data and ECC. Four DSW slices in parallel drive and receive 288 data/ECC signal lines on the MEMDATA bus between the DSW and memory arrays.

The DSW slices treat all bits in the same manner and are unaware of the concept of ECC. No specific bits are dedicated to ECC nor data. All ECC generation and detection is performed in the 21164 and CIA. By default, **mem\_dat\_h<35:0**> are in the active condition as a DSW internal signal; Drive\_MEM\_L is in the low state. This allows data to be driven onto the MEMDATA bus every CLKx cycle.

When Drive\_MEM\_L is in the high state, the DSW is in the tristate mode and data is read into the DSW from the memory arrays on the edge of each CLK2X cycle.

#### mem\_en\_h

When the CIA drives **mem\_en\_h** high, the DSW asserts Drive\_MEM\_L, enabling the DSW to drive the MEMDATA bus. When the CIA does not assert **mem\_en\_h**, the DSW deasserts Drive\_MEM\_L, enabling the memory arrays to drive the MEMDATA bus.

#### 7.2.4 Phase-Locked Loop Signals

This section describes the DSW phase-locked loop signals.

#### pll\_clk\_h

The **pll\_clk\_h** signal is the system clock (or reference signal) input to the phase-locked loop (PLL) circuit. It supplies a clock with the same frequency as that supplied to the PCI.

#### pll\_vdd\_h

Signal **pll\_vdd\_h** is an input to the PLL. It is connected to the system board power.

pll\_vss\_h

Signal **pll\_vss\_h** is an input to the PLL. It is connected to the system board ground.

pll\_lp2\_h

Signal **pll\_lp2\_h** is an input to the PLL, driving a VCO input.

pll\_lp1\_h

Signal **pll\_lp1\_h** is an output of the PLL (phase detector output).

#### pll\_a\_h

Signal **pll\_agnd\_h** is an input to the PLL, connected to the system board ground.

#### 7.2.5 Miscellaneous Signals

This section describes the miscellaneous DSW signals.

#### config\_h<1:0>

Signals **config\_h<1:0**> configure the data width of the IOD and MEMDATA buses as listed in Table 7–7.

| config<1:0>            | IOD Bus Data Width | MEMDATA Bus Data Width |
|------------------------|--------------------|------------------------|
| 00 <sup>1</sup>        | 32 bits            | 128 bits               |
| <b>01</b> <sup>1</sup> | 32 bits            | 256 bits               |
| 10                     | 64 bits            | 128 bits               |
| 11                     | 64 bits            | 256 bits               |

Table 7–7 IOD Bus and MEMDATA Bus Data Width Selection

<sup>1</sup>Not implemented.

#### reset\_l

Signal **reset\_l** is the system reset input signal to the DSW. When **reset\_l** is asserted, the DSW resets its internal state.

#### scan\_in\_h

Signal **scan\_in\_h** is the enable pin for the scan chain

spare1\_or\_count\_out\_h

Signal **spare1\_or\_count\_out\_h** is the **spare1** signal sharing a pin with the **count\_out** signal. This pin is used during PLL tests.

#### test\_mode\_h<1:0>

Signals **test\_mode\_h<1:0**> define the four operating modes of the DSW as listed in Table 7–8.

| test_mode_h<1:0> | DSW Operating Mode |
|------------------|--------------------|
| 00               | Tristate mode      |
| 01               | Normal mode        |
| 10               | Scan mode          |
| 11               | PLL test mode      |

#### test\_or\_scan\_out\_h

Signal **test\_or\_scan\_out\_h** is the TEST\_OUT output that is the end of the parametric NAND tree.

#### 7.2.6 DECchip 21171-BA Pin Name List (Alphabetic)

Table 7–9 lists the DECchip 21171-BA (DSW) pins in alphabetical order. The following abbreviations are used in the Type column of the table:

- B = Bidirectional
- I = Input
- P = Power
- O = Output

| Pin Name           | Pin | Туре | Pin Name           | Pin | Туре |
|--------------------|-----|------|--------------------|-----|------|
| cmc_h<0>           | 103 | Ι    | cmc_h<1>           | 102 | Ι    |
| cmc_h<2>           | 101 | Ι    | cmc_h<3>           | 100 | Ι    |
| cmc_h<4>           | 99  | Ι    | cmc_h<5>           | 116 | Ι    |
| cmc_h<6>           | 117 | Ι    | cmc_h<7>           | 118 | Ι    |
| cmc_h<8>           | 119 | Ι    | _                  | —   | —    |
| config_h<0>        | 49  | Ι    | config_h<1>        | 50  | Ι    |
| cpu_dat_h<0>       | 3   | В    | cpu_dat_h<1>       | 4   | В    |
| cpu_dat_h<2>       | 12  | В    | cpu_dat_h<3>       | 13  | В    |
| cpu_dat_h<4>       | 21  | В    | cpu_dat_h<5>       | 22  | В    |
| cpu_dat_h<6>       | 30  | В    | cpu_dat_h<7>       | 31  | В    |
| cpu_dat_h<8>       | 55  | В    | cpu_dat_h<9>       | 56  | В    |
| cpu_dat_h<10>      | 64  | В    | cpu_dat_h<11>      | 65  | В    |
| cpu_dat_h<12>      | 73  | В    | cpu_dat_h<13>      | 74  | В    |
| cpu_dat_h<14>      | 82  | В    | cpu_dat_h<15>      | 83  | В    |
| cpu_dat_h<16>      | 91  | В    | cpu_dat_h<17>      | 92  | В    |
| cpu_dat_h<18>      | 127 | В    | cpu_dat_h<19>      | 126 | В    |
| cpu_dat_h<20>      | 136 | В    | cpu_dat_h<21>      | 135 | В    |
| cpu_dat_h<22>      | 145 | В    | cpu_dat_h<23>      | 144 | В    |
| cpu_dat_h<24>      | 154 | В    | cpu_dat_h<25>      | 153 | В    |
| cpu_dat_h<26>      | 159 | В    | cpu_dat_h<27>      | 160 | В    |
| -<br>cpu_dat_h<28> | 168 | В    | cpu_dat_h<29>      | 169 | В    |
| -<br>cpu_dat_h<30> | 177 | В    | cpu_dat_h<31>      | 178 | В    |
| _<br>cpu_dat_h<32> | 186 | В    | _<br>cpu_dat_h<33> | 187 | В    |
| cpu_dat_h<34>      | 195 | В    | cpu_dat_h<35>      | 196 | В    |
| GND                | 5   | Р    | GND                | 14  | Р    |

Table 7–9 DECchip 21171-BA Pin Assignment List (Alphabetic)

| Pin Name      | Pin      | Туре | Pin Name      | Pin | Туре |
|---------------|----------|------|---------------|-----|------|
| GND           | 23       | P    | GND           | 32  | Р    |
| GND           | 20<br>44 | P    | GND           | 53  | P    |
| GND           | 62       | P    | GND           | 71  | P    |
| GND           | 80       | Р    | GND           | 89  | Р    |
| GND           | 98       | P    | GND           | 106 | P    |
| GND           | 111      | Р    | GND           | 120 | Р    |
| GND           | 129      | Р    | GND           | 138 | Р    |
| GND           | 147      | Р    | GND           | 152 | Р    |
| GND           | 161      | Р    | GND           | 170 | Р    |
| GND           | 179      | Р    | GND           | 188 | Р    |
| GND           | 197      | Р    | GND           | 208 | Р    |
| ioc_h<0>      | 45       | Ι    | ioc_h<1>      | 43  | Ι    |
| ioc_h<2>      | 42       | Ι    | ioc_h<3>      | 41  | Ι    |
| ioc_h<4>      | 40       | Ι    | ioc_h<5>      | 39  | Ι    |
| ioc_h<6>      | 38       | Ι    | _             | —   | —    |
| iod_h<0>      | 2        | В    | iod_h<1>      | 11  | В    |
| iod_h<2>      | 20       | В    | iod_h<3>      | 29  | В    |
| iod_h<4>      | 54       | В    | iod_h<5>      | 63  | В    |
| iod_h<6>      | 72       | В    | iod_h<7>      | 81  | В    |
| iod_h<8>      | 90       | В    | iod_h<9>      | 128 | В    |
| iod_h<10>     | 137      | В    | iod_h<11>     | 146 | В    |
| iod_h<12>     | 155      | В    | iod_h<13>     | 158 | В    |
| iod_h<14>     | 167      | В    | iod_h<15>     | 176 | В    |
| iod_h<16>     | 185      | В    | iod_h<17>     | 194 | В    |
| mem_dat_h<0>  | 6        | В    | mem_dat_h<1>  | 7   | В    |
| mem_dat_h<2>  | 8        | В    | mem_dat_h<3>  | 9   | В    |
| mem_dat_h<4>  | 15       | В    | mem_dat_h<5>  | 16  | В    |
| mem_dat_h<6>  | 17       | В    | mem_dat_h<7>  | 18  | В    |
| mem_dat_h<8>  | 24       | В    | mem_dat_h<9>  | 25  | В    |
| mem_dat_h<10> | 26       | В    | mem_dat_h<11> | 27  | В    |
| mem_dat_h<12> | 33       | В    | mem_dat_h<13> | 34  | В    |
| mem_dat_h<14> | 35       | В    | mem_dat_h<15> | 36  | В    |
| mem_dat_h<16> | 58       | В    | mem_dat_h<17> | 59  | В    |
| mem_dat_h<18> | 60       | В    | mem_dat_h<19> | 61  | В    |
| mem_dat_h<20> | 67       | В    | mem_dat_h<21> | 68  | В    |
| mem_dat_h<22> | 69       | В    | mem_dat_h<23> | 70  | В    |

## Table 7–9 (Cont.) DECchip 21171-BA Pin Assignment List (Alphabetic)

| Pin Name      | Pin | Туре | Pin Name      | Pin | Туре |
|---------------|-----|------|---------------|-----|------|
| mem_dat_h<24> | 76  | В    | mem_dat_h<25> | 77  | В    |
| mem_dat_h<26> | 78  | В    | mem_dat_h<27> | 79  | В    |
| mem_dat_h<28> | 85  | В    | mem_dat_h<29> | 86  | В    |
| mem_dat_h<30> | 87  | В    | mem_dat_h<31> | 88  | В    |
| mem_dat_h<32> | 94  | В    | mem_dat_h<33> | 95  | В    |
| mem_dat_h<34> | 96  | В    | mem_dat_h<35> | 97  | В    |
| mem_dat_h<36> | 124 | В    | mem_dat_h<37> | 123 | В    |
| mem_dat_h<38> | 122 | В    | mem_dat_h<39> | 121 | В    |
| mem_dat_h<40> | 133 | В    | mem_dat_h<41> | 132 | В    |
| mem_dat_h<42> | 131 | В    | mem_dat_h<43> | 130 | В    |
| mem_dat_h<44> | 142 | В    | mem_dat_h<45> | 141 | В    |
| mem_dat_h<46> | 140 | В    | mem_dat_h<47> | 139 | В    |
| mem_dat_h<48> | 151 | В    | mem_dat_h<49> | 150 | В    |
| mem_dat_h<50> | 149 | В    | mem_dat_h<51> | 148 | В    |
| mem_dat_h<52> | 162 | В    | mem_dat_h<53> | 163 | В    |
| mem_dat_h<54> | 164 | В    | mem_dat_h<55> | 165 | В    |
| mem_dat_h<56> | 171 | В    | mem_dat_h<57> | 172 | В    |
| mem_dat_h<58> | 173 | В    | mem_dat_h<59> | 174 | В    |
| mem_dat_h<60> | 180 | В    | mem_dat_h<61> | 181 | В    |
| mem_dat_h<62> | 182 | В    | mem_dat_h<63> | 183 | В    |
| mem_dat_h<64> | 189 | В    | mem_dat_h<65> | 190 | В    |
| mem_dat_h<66> | 191 | В    | mem_dat_h<67> | 192 | В    |
| mem_dat_h<68> | 198 | В    | mem_dat_h<69> | 199 | В    |
| mem_dat_h<70> | 200 | В    | mem_dat_h<71> | 201 | В    |
| mem_en_h      | 46  | Ι    | —             | —   | —    |
| pll_agnd_h    | 109 | Ι    | pll_clk_h     | 105 | Ι    |
| pll_lp1_h     | 113 | I    | pll_lp2_h     | 107 | Ι    |
| pll_vdd_h     | 112 | Ι    | pll_vss_h     | 110 | Ι    |
| PWR5          | 1   | Р    | PWR5          | 10  | Р    |
| PWR5          | 19  | Р    | PWR5          | 28  | Р    |
| PWR5          | 37  | Р    | PWR5          | 52  | Р    |
| PWR5          | 57  | Р    | PWR5          | 66  | Р    |
| PWR5          | 75  | Р    | PWR5          | 84  | Р    |
| PWR5          | 93  | Р    | PWR5          | 104 | Р    |
| PWR5          | 108 | Р    | PWR5          | 114 | Р    |
| PWR5          | 125 | Р    | PWR5          | 134 | Р    |

Table 7–9 (Cont.) DECchip 21171-BA Pin Assignment List (Alphabetic)

| Pin Name                  | Pin | Туре | Pin Name       | Pin | Туре |
|---------------------------|-----|------|----------------|-----|------|
| PWR5                      | 143 | Р    | PWR5           | 156 | Р    |
| PWR5                      | 157 | Р    | PWR5           | 166 | Р    |
| PWR5                      | 175 | Р    | PWR5           | 184 | Р    |
| PWR5                      | 193 | Р    | PWR5           | 202 | Р    |
| reset_l                   | 115 | Ι    | scan_in_h      | 203 | Ι    |
| spare1_or_count_<br>out_h | 204 | 0    | spare2         | 205 | Ι    |
| spare3                    | 206 | Ι    | spare4         | 207 | Ι    |
| test_or_scan_out_h        | 51  | 0    | —              | —   | —    |
| test_mode_h<0>            | 47  | Ι    | test_mode_h<1> | 48  | Ι    |

Table 7–9 (Cont.) DECchip 21171-BA Pin Assignment List (Alphabetic)

### 7.2.7 DECchip 21171-BA Pin Assignment List (Numeric)

Table 7–10 lists the DECchip 21171-BA (DSW) pins in numeric order. The following abbreviations are used in the Type column of the table:

- B = Bidirectional
- I = Input
- P = Power
- O = Output

| Pin<br>Number | Pin Name           | Туре | Pin<br>Number | Pin Name       | Туре |
|---------------|--------------------|------|---------------|----------------|------|
| 1             | PWR5               | Р    | 2             | iod_h<0>       | В    |
| 3             | cpu_dat_h<0>       | В    | 4             | cpu_dat_h<1>   | В    |
| 5             | GND                | Р    | 6             | mem_dat_h<0>   | В    |
| 7             | mem_dat_h<1>       | В    | 8             | mem_dat_h<2>   | В    |
| )             | mem_dat_h<3>       | В    | 10            | PWR5           | Р    |
| 1             | iod_h<1>           | В    | 12            | cpu_dat_h<2>   | В    |
| 3             | cpu_dat_h<3>       | В    | 14            | GND            | Р    |
| 5             | mem_dat_h<4>       | В    | 16            | mem_dat_h<5>   | В    |
| 7             | mem_dat_h<6>       | В    | 18            | mem_dat_h<7>   | В    |
| 9             | PWR5               | Р    | 20            | iod_h<2>       | В    |
| 1             | cpu_dat_h<4>       | В    | 22            | cpu_dat_h<5>   | В    |
| 3             | GND                | Р    | 24            | mem_dat_h<8>   | В    |
| 5             | mem_dat_h<9>       | В    | 26            | mem_dat_h<10>  | В    |
| 7             | mem_dat_h<11>      | В    | 28            | PWR5           | Р    |
| 9             | iod_h<3>           | В    | 30            | cpu_dat_h<6>   | В    |
| 1             | cpu_dat_h<7>       | В    | 32            | GND            | Р    |
| 3             | mem_dat_h<12>      | В    | 34            | mem_dat_h<13>  | В    |
| 5             | mem_dat_h<14>      | В    | 36            | mem_dat_h<15>  | В    |
| 7             | PWR5               | Р    | 38            | ioc_h<6>       | Ι    |
| 9             | ioc_h<5>           | Ι    | 40            | ioc_h<4>       | Ι    |
| 1             | ioc_h<3>           | Ι    | 42            | ioc_h<2>       | Ι    |
| 3             | ioc_h<1>           | Ι    | 44            | GND            | Р    |
| 5             | ioc_h<0>           | I    | 46            | mem_en_h       | Ι    |
| 7             | test_mode_h<0>     | Ι    | 48            | test_mode_h<1> | Ι    |
| 9             | config_h<0>        | Ι    | 50            | config_h<1>    | Ι    |
| 1             | test_or_scan_out_h | 0    | 52            | PWR5           | Р    |
| 3             | GND                | Р    | 54            | iod_h<4>       | В    |
| 5             | cpu_dat_h<8>       | В    | 56            | cpu_dat_h<9>   | В    |
| 7             | PWR5               | Р    | 58            |                | В    |
| 9             | mem_dat_h<17>      | В    | 60            | mem_dat_h<18>  | В    |
| 1             | mem_dat_h<19>      | В    | 62            | GND            | Р    |
| 3             | iod_h<5>           | В    | 64            | cpu_dat_h<10>  | В    |
| 5             | cpu_dat_h<11>      | В    | 66            | PWR5           | Р    |
| 7             |                    | В    | 68            | mem_dat_h<21>  | В    |
| 69            | mem_dat_h<22>      | В    | 70            | mem_dat_h<23>  | В    |
| 1             | GND                | Р    | 72            | iod_h<6>       | В    |
| 3             | cpu_dat_h<12>      | В    | 74            | cpu_dat_h<13>  | В    |
| 5             | PWR5               | Р    | 76            | mem_dat_h<24>  | В    |

Table 7–10 DECchip 21171-BA Pin Assignment (Numeric)

| Pin<br>Number | Pin Name           | Туре | Pin<br>Number | Pin Name      | Туре |
|---------------|--------------------|------|---------------|---------------|------|
| 77            | mem_dat_h<25>      | В    | 78            | mem_dat_h<26> | В    |
| 79            | mem_dat_h<27>      | В    | 80            | GND           | Р    |
| 81            | iod_h<7>           | В    | 82            | cpu_dat_h<14> | В    |
| 83            | cpu_dat_h<15>      | В    | 84            | PWR5          | Р    |
| 85            | _<br>mem_dat_h<28> | В    | 86            | mem_dat_h<29> | В    |
| 87            | mem_dat_h<30>      | В    | 88            | mem_dat_h<31> | В    |
| 89            | GND                | Р    | 90            | iod_h<8>      | В    |
| 91            | cpu_dat_h<16>      | В    | 92            | cpu_dat_h<17> | В    |
| 93            | PWR5               | Р    | 94            | mem_dat_h<32> | В    |
| 95            | mem_dat_h<33>      | В    | 96            | mem_dat_h<34> | В    |
| 97            | mem_dat_h<35>      | В    | 98            | GND           | Р    |
| 99            | cmc_h<4>           | Ι    | 100           | cmc_h<3>      | Ι    |
| 101           | cmc_h<2>           | Ι    | 102           | cmc_h<1>      | Ι    |
| 103           | cmc_h<0>           | Ι    | 104           | PWR5          | Р    |
| 105           | pll_clk_h          | Ι    | 106           | GND           | Р    |
| 107           | pll_lp2_h          | Ι    | 108           | PWR5          | Р    |
| 109           | pll_agnd_h         | Ι    | 110           | pll_vss_h     | Ι    |
| 111           | GND                | Р    | 112           | pll_vdd_h     | Ι    |
| 113           | pll_lp1_h          | Ι    | 114           | PWR5          | Р    |
| 115           | reset_l            | Ι    | 116           | cmc_h<5>      | Ι    |
| 117           | cmc_h<6>           | Ι    | 118           | cmc_h<7>      | Ι    |
| 119           | cmc_h<8>           | Ι    | 120           | GND           | Р    |
| 121           | mem_dat_h<39>      | В    | 122           | mem_dat_h<38> | В    |
| 123           | mem_dat_h<37>      | В    | 124           | mem_dat_h<36> | В    |
| 125           | PWR5               | Р    | 126           | cpu_dat_h<19> | В    |
| 127           | cpu_dat_h<18>      | В    | 128           | iod_h<9>      | В    |
| 129           | GND                | Р    | 130           | mem_dat_h<43> | В    |
| 131           | mem_dat_h<42>      | В    | 132           | mem_dat_h<41> | В    |
| 133           | mem_dat_h<40>      | В    | 134           | PWR5          | Р    |
| 135           | cpu_dat_h<21>      | В    | 136           | cpu_dat_h<20> | В    |
| 137           | iod_h<10>          | В    | 138           | GND           | Р    |
| 139           | mem_dat_h<47>      | В    | 140           | mem_dat_h<46> | В    |
| 141           | mem_dat_h<45>      | В    | 142           | mem_dat_h<44> | В    |
| 143           | PWR5               | Р    | 144           | cpu_dat_h<23> | В    |
| 145           | cpu_dat_h<22>      | В    | 146           | iod_h<11>     | В    |
| 147           | GND                | Р    | 148           | mem_dat_h<51> | В    |
| 149           | mem_dat_h<50>      | В    | 150           | mem_dat_h<49> | В    |
| 151           | mem_dat_h<48>      | В    | 152           | GND           | Р    |

Table 7–10 (Cont.) DECchip 21171-BA Pin Assignment (Numeric)

| Pin<br>Number | Pin Name      | Туре | Pin<br>Number | Pin Name                  | Туре |
|---------------|---------------|------|---------------|---------------------------|------|
| 153           | cpu_dat_h<25> | В    | 154           | cpu_dat_h<24>             | В    |
| 155           | iod_h<12>     | В    | 156           | PWR5                      | Р    |
| 157           | PWR5          | Р    | 158           | iod_h<13>                 | В    |
| 159           | cpu_dat_h<26> | В    | 160           | cpu_dat_h<27>             | В    |
| 161           | GND           | Р    | 162           | mem_dat_h<52>             | В    |
| 163           | mem_dat_h<53> | В    | 164           | mem_dat_h<54>             | В    |
| 165           | mem_dat_h<55> | В    | 166           | PWR5                      | Р    |
| 167           | iod_h<14>     | В    | 168           | cpu_dat_h<28>             | В    |
| 169           | cpu_dat_h<29> | В    | 170           | GND                       | Р    |
| 171           |               | В    | 172           | mem_dat_h<57>             | В    |
| 173           | mem_dat_h<58> | В    | 174           | mem_dat_h<59>             | В    |
| 75            | PWR5          | Р    | 176           | iod_h<15>                 | В    |
| 77            | cpu_dat_h<30> | В    | 178           | cpu_dat_h<31>             | В    |
| 179           | GND           | Р    | 180           |                           | В    |
| 81            | mem_dat_h<61> | В    | 182           | mem_dat_h<62>             | В    |
| 183           | mem_dat_h<63> | В    | 184           | PWR5                      | Р    |
| 85            | iod_h<16>     | В    | 186           | cpu_dat_h<32>             | В    |
| 187           | cpu_dat_h<33> | В    | 188           | GND                       | Р    |
| 89            |               | В    | 190           | mem_dat_h<65>             | В    |
| 91            | mem_dat_h<66> | В    | 192           | mem_dat_h<67>             | В    |
| 93            | PWR5          | Р    | 194           | iod_h<17>                 | В    |
| 95            | cpu_dat_h<34> | В    | 196           | cpu_dat_h<35>             | В    |
| 97            | GND           | Р    | 198           | mem_dat_h<68>             | В    |
| 199           | mem_dat_h<69> | В    | 200           | mem_dat_h<70>             | В    |
| 201           | mem_dat_h<71> | В    | 202           | PWR5                      | Р    |
| 203           | scan_in_h     | Ι    | 204           | spare1_or_count_<br>out_h | 0    |
| 205           | spare2        | Ι    | 206           | spare3                    | Ι    |
| 207           | spare4        | Ι    | 208           | GND                       | Р    |

Table 7–10 (Cont.) DECchip 21171-BA Pin Assignment (Numeric)

### DECchip 21171-BA Pin Descriptions 7.3 DECchip 21171-BA Mechanical Specifications

## 7.3 DECchip 21171-BA Mechanical Specifications

Figure 7–1 shows the DECchip 21171-BA (DSW) package dimensions.





LJ-04281.AI

DECchip 21171-BA Pin Descriptions 7.3 DECchip 21171-BA Mechanical Specifications





#### Notes for Figure 7–1

The following notes apply to Figure 7–1:

Note 1. Coplanarity is the difference between the highest lead and the seating plane -H-.

Note 2. Datums A-B and -D- to be determined at Datum plane -H-.

#### DECchip 21171-BA Pin Descriptions 7.3 DECchip 21171-BA Mechanical Specifications

Note 3. To be determined at seating plane -C-. Note 4. Dimensions D1 and E1 do not include mold protrusion. Allowable protrusion is 0.25 mm (0.010 in) per side. Dimensions D1 and E1 do not include mold mismatch and are determined at Datum plane -H-. Note 5. Details of pin 1 identifier are optional but must be located within the zone indicated. Note 6. Date plane -H- is located at the mold parting line and is coincident

with the bottom of the leads where the lead exits the plastic body.

\_\_\_\_ Note \_\_\_\_

The drawing/dimensions are for reference only. For board layout, request a detailed engineering drawing from Digital Semiconductor.

Table 7–11 provides the maximum and minimum dimensions for the 21171-AB (DSW).

| Indicator | Minimum             | Maximum             |
|-----------|---------------------|---------------------|
| A         | NA <sup>1</sup>     | 4.20 mm (0.165 in)  |
| A1        | 0.25 mm (0.010 in)  | NA                  |
| A2        | 3.17 mm (0.125 in)  | 3.67 mm (0.144 in)  |
| В         | 0.17 mm (0.007 in)  | 0.28 mm (0.011 in)  |
| )         | 30.35 mm (1.195 in) | 30.85 mm (1.215 in) |
| D1        | 27.90 mm (1.098 in) | 28.10 mm (1.106 in) |
| Ε         | 30.35 mm (1.195 in) | 30.85 mm (1.215 in) |
| E1        | 27.90 mm (1.098 in) | 28.10 mm (1.106 in) |
|           | 0.40 mm (0.016 in)  | 0.80 mm (0.031 in)  |
| aa        | NA                  | 0.08 mm (0.003 in)  |
| ccc       | NA                  | 0.08 mm (0.003 in)  |
| ndicator  | Basic               |                     |
| Ε         | 0.50 mm (0.020 in)  |                     |

Table 7–11 DECchip 21171-BA Package Dimensions

# 8

## **DECchip 21171-BA Architecture Overview**

This chapter describes the DECchip 21171-BA (DSW) architecture.

## 8.1 DSW Functional Units

The DSW connects the data paths between the memory, the 21164/Bcache, and the CIA (for PCI data).

- The memory data path, on the MEMDATA bus, has 128 bits or 256 bits of data and 16 bits or 32 bits of ECC. The width of the data path, 128 bits or 256 bits, is selected using input pins **config\_h**<1:0>.
- The 21164/Bcache data path, on the sysBus, has 128 bits of data and 16 bits of ECC.
- The CIA data path, on the IOD bus, has 64 bits of data and 8 bits of ECC.

The data paths supported by the DSW require four DSW slices to accommodate the data path widths. Each DSW slice is identical and there are no restrictions on how the bits of any bus are assigned.

The DSW is composed of mainly data buffers and multiplexers, as shown in Figure 8–1. All control for the DSW is supplied by the CIA (though some encoding and simple sequencing is performed by the DSW).

## DECchip 21171-BA Architecture Overview 8.1 DSW Functional Units





#### DECchip 21171-BA Architecture Overview 8.1 DSW Functional Units

The DSW functional units are:

- Victim buffer—64 bytes
- I/O read buffer—32 bytes
- Four I/O write buffers—4 \* 32 bytes
- Two DMA buffer sets are provided for read and write transactions. Each set contains:
  - Memory buffer
  - Flush buffer
  - PCI buffer

#### 8.1.1 Victim Buffer—64 Bytes

The victim buffer in each DSW slice has four 36-bit entries. Using four DSW slices results in a victim buffer with four 128-bit data entries and four 16-bit ECC entries.

The victim buffer is a free-loading first-in/first-out buffer (FIFO). The values in **cmc\_h<8:0**> "start" and "stop" loading of the victim buffer. When buffer loading is "started" data is shifted into the buffer during every CLKX cycle. When buffer loading is "stopped," the contents of the buffer are held and loading is inhibited. Normally buffer loading is "stopped" before data is read out to the MEMDATA bus.

The MEMDATA bus can be configured, using **config\_h**<1:0>, for 128-bit or 256-bit width. The buffer can be addressed in two ways:

- 128-bit—The victim buffer data has addresses 0, 1, 2, or 3. The data will be sent to memory by using the low-order memory bus bits.
- 256-bit—The victim buffer data has addresses 0 or 2 and two octawords of data plus ECC are sent to the memory in one cycle.

Data is sent to memory from a flip-flop loaded at CLKX.

#### 8.1.2 I/O Read Buffer (IOR)—32 Bytes

The IOR buffer in each DSW slice has two 36-bit entries. Using four DSW slices results in an IOR buffer with two 128-bit data entries and two associated 16-bit ECC entries.

The IOR buffer is loaded from the IOD bus by using a quadword mask. Any or all of the quadwords can be loaded in one cycle. Only one quadword of data comes from the IOD bus during one cycle so if more than a single quadword is selected, the same data will be written into each IOR buffer quadword.

## DECchip 21171-BA Architecture Overview 8.1 DSW Functional Units

One instruction to the DSW controls writing the entire IOR buffer. The instruction specifies which quadword to write first. Data is read from the IOR buffer and written into the IOR buffer on the edge of CLKX.

#### 8.1.3 I/O Write (IOW) Buffers—4 \* 32 Bytes

The IOW buffer in each DSW slice has four banks, with each bank containing two 36-bit registers. Using four DSW slices results in an IOW buffer with four banks, with each bank containing two 144-bit registers. The 144 bits contain 128 bits of data and 16 bits of ECC.

The IOW buffer is free-loading. Signals **ioc\_h<6:0**> and **cmc\_h<8:0**> "start" and "stop" loading of the IOW buffer.

When the IOW buffer is "started," new data is loaded every CLKX cycle from the sysBus data path (the same data is loaded into each bank). When the IOW buffer is "stopped," loading is inhibited and the current buffer contents are held.

Data is read from the IOW buffer to the IOD bus a quadword at each CLKX cycle by the CIA issuing an instruction on **ioc\_h<6:0**>. The instruction specifies the bank number and the bank address of the quadword.

Quadword valid bits are provided for the IOW buffer. These valid bits are used to merge the appropriate IOW buffer quadword with the memory/Bcache data. Finer granularity merging (such as bytes) is performed in the CIA (because of ECC) by looping the appropriate memory/Bcache quadword through the CIA and merging the valid write bytes.

No data is preserved in the IOW buffers across transactions (no I/O read prefetched data or posted I/O write data). Consequently, there are no coherency issues associated with I/O read/write data lingering in the buffers.

#### 8.1.4 DMA Buffer Sets

Two DMA buffer sets are provided for read and write transactions. Each buffer set consists of three buffers:

- Memory buffer for memory data
- Flush buffer for sysBus data
- PCI buffer for PCI DMA write data (not used during DMA read transactions)

The sysBus and memory data could have shared one buffer, because only one of these two will provide valid data, but two buffers simplified the control logic.

#### DECchip 21171-BA Architecture Overview 8.1 DSW Functional Units

The memory buffer (memory buffers 0 and 1) in each DSW slice has four 36-bit entries. Using four DSW slices results in a 4-entry memory buffer with 144 bits per entry (includes 128 data bits and 16 ECC bits).

The memory buffer is loaded from the MEMDATA bus on a CLKX cycle. Only the entry addressed by the instruction on **cmc\_h<8:0**> is loaded.

Data is read from the memory buffer by addressing an octaword or quadword location in the DMA buffer while the flush buffer and PCI buffer are *not* valid. Octawords are addressed for data to the memory arrays, and quadwords are addressed for data to the IOD bus.

#### 8.1.4.1 Flush Buffer

The flush buffer (both flush 0 and flush 1) in each DSW slice has four 36-bit entries. Using four DSW slices results in a flush buffer with four 144-bit entries (128 bits of data and 16 bits of ECC).

The flush buffer is a free-loading FIFO. Signal **cmc**<**8:0**> "starts" and "stops" loading of the flush buffer. While it is "started," it is loaded from the sysBus every CLKX cycle. When the flush buffer is "stopped," loading is inhibited and the current contents are held.

"Stopping" the flush buffer makes the buffer contents valid. When the flush buffer is valid, its contents will be selected over the contents of the memory buffer during a DMA read transaction.

Octawords are addressed for data sent to the memory arrays and quadwords are addressed for data sent to the IOD bus.

#### 8.1.4.2 PCI Buffer

The PCI buffer (both PCI 0 and PCI 1) in each DSW slice has eight 18-bit entries. Using four DSW slices results in a PCI buffer of eight 72-bit entries (64 bits data and 8 bits ECC).

The PCI buffer is loaded from the IOD bus with a quadword address under the control of **ioc\_h<6:0**>. Each quadword has a valid bit that is set when the quadword is written.

A DMA write transaction causes data to be read from the PCI buffer. When the write address points to valid data in the PCI buffer that data will be written to the memory arrays.

## A Technical Support and Ordering Information

## A.1 Technical Support

If you need technical support or help deciding which literature best meets your needs, call the Digital Semiconductor Information Line:

 United States and Canada
 1-800-332-2717

 Outside North America
 +1-508-628-4760

## A.2 Ordering Digital Semiconductor Products

To order the Alpha 21164 microprocessor and evaluation boards, contact your local distribtor.

You can order the following semiconductor products from Digital:

| Product                                                                                              | Order Number |
|------------------------------------------------------------------------------------------------------|--------------|
| Alpha 21164 300-MHz Microprocessor                                                                   | 21164-BA     |
| Alpha 21164 266-MHz Microprocessor                                                                   | 21164-AA     |
| DECchip 21171 Core Logic Chipset                                                                     | 21171–AA     |
| Alpha 21164 Microprocessor Evaluation Board Kit—<br>266 MHz (Supports Windows NT operating systems.) | 21A04-01     |

Note \_\_\_\_

Heat sink assemblies for the DECchip 21164 microprocessors are available from United Thermotechnology at (603)-642-3601.

### Technical Support and Ordering Information A.3 Ordering Associated Third-Party Literature

## A.3 Ordering Associated Third-Party Literature

You can order the following third-party literature directly from the vendor:

| Title                                                  | Vendor                                                                                                      |  |  |
|--------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|--|--|
| PCI Local Bus Specification<br>PCI System Design Guide | PCI Special Interest Group<br>1–800–433–5177 (US)<br>1–503–797–4207 (International)<br>1–503–234–6762 (FAX) |  |  |

## Index

#### 21171-BA *See* DSW 21171-CA *See* CIA 21164 *See* Alpha 21164 microprocessor, 3–4

## Α

Address mapping, 6–1 address space configuration, 6-2 overview, 6-1 Address space, 6-2, 6-7 21164 access, 6-3 PCI access, 6-4 PCI configuration space, 6–22 device select, 6-25 hardware-specific register space, 6 - 29miscellaneous register space, 6-29 special/interrupt acknowledge cycles, 6 - 28PCI dense memory space, 6-9 PCI sparse I/O space, 6-18 PCI sparse memory space, 6-11 Alpha 21164 microprocessor control and status registers, 4-2 instruction and address logic, 3-4

### С

Chipset overview, 1–1 See also System overview chipset characteristics, 1–8 CIA characteristics, 1–8 Chipset overview (cont'd) CIA microarchitecture, 1-4 DSW characteristics, 1-8 DSW microarchitecture, 1-6 features, 1-1 microarchitecture, 1-4 system clocks, 1-7 CIA, 1–1 definition, 1-1 CIA architecture basic properties of system, 3-16 data path functional units, 3-1 functional units, 3-3 DMA address logic, 3-7 I/O address logic, 3-6 memory logic, 3-6 PCI data path logic, 3-4 system data coherency, 3-16 transactions, 3-7 DMA, 3-12 DMA read, 3-14 DMA read (prefetch), 3-14 DMA write, 3-15 read miss, 3-8 read miss to noncacheable space, 3-9 read miss with victim, 3-8 write to noncacheable space, 3-11 CIA control and status registers, 4-1 address translation registers, 4-6, 4-69 diagnostic registers, 4-2, 4-19 error registers, 4-3, 4-26 general registers, 4-2, 4-8 PCI address and scatter-gather registers, 4-5, 4-60 performance monitor registers, 4-3, 4-22

CIA control and status registers (cont'd) system configuration registers, 4-4, 4-46 CIA memory operation, 3-18 address mapping, 3-20 traditional address mapping, 3-18 CIA package dimensions, 2-24 CIA pin descriptions, 2-1, 2-3 IOD bus signals, 2-7 memory control signals, 2-10 miscellaneous power signals, 2-11 miscellaneous signals, 2-12 PCI local bus signals, 2-4 pin groups, 2-1 pin totals, 2-3 PLL signals, 2–11 reserved signals, 2-12 sysBus signals, 2-3 CIA pin name list (alphabetic), 2-13 CIA pin name list (alphanumeric), 2-19 Control and status registers See CSRs Control, I/O interface, and address chip See CIA CSRs, 4-1 See also CIA control and status registers

## D

Data switch chip See DSW Data units, xvii DECchip 21171 definition, 1-1 DECchip 21171-BA architecture See DSW architecture DECchip 21171-CA architecture See CIA architecture Document conventions, xiv DSW, 1-1 definition, 1-1 DSW architecture. 8–1 functional units, 8-1 DMA buffer sets. 8-4 I/O read buffer. 8–3 I/O write buffer, 8-4

DSW architecture functional units (cont'd) victim buffer, 8–3 DSW package dimensions, 7–16 DSW pin descriptions, 7–1, 7–2 IOD bus signals, 7–3 MEMDATA bus signals, 7–6 miscellaneous signals, 7–7 pin groups, 7–1 pin totals, 7–2 PLL signals, 7–6 sysBus signals, 7–3 DSW pin name list (alphabetic), 7–9 DSW pin name list (numeric), 7–12

## Ε

ECC cache, 1–2 data paths, 1–1, 1–3 double-bit errors, 4–30, 4–34, 4–44 errors, 4–36 IOD bus, 4–11, 4–19 memory, 1–2, 4–21 single-bit errors, 4–25, 4–30, 4–34, 4–44 syndromes for single-bit errors, 4–35 EISA System Component *See* ESC Error correction code *See* ECC ESC, 6–42

## I

Initialization by SROM code, 5–4 pin state after **reset\_l** deassertion, 5–3 pin state with **reset\_l** asserted, 5–1 Input/output data bus *See* IOD bus IOD bus signal description, 2–7 signal group, 2–1

## L

LOCK instruction, 3–25 CIA lock rules, 3–27 locks to uncached space, 3–27

#### Μ

MB instruction, 3-25 Mechanical specifications CIA, 2-24 DSW, 7-16 Memory addressing PCI to physical, 6-29 Memory chip select signal (mem\_cs\_l), 6-42 Memory control signals signal description, 2-10 signal group, 2-2 Memory timing data paths limits, 4-59 maximum signal limits, 4-57 memory read timing figure, 4-55 memory timing parameters, 4-54 memory timing register n, 4–52 memory write timing figure, 4-56 minimum signal limits, 4-57

## 0

Ordering associated third-party literature, A-2 Ordering products, A-1 Organization of document, xiii

## Ρ

Parts ordering, A-1 PCEB, 6-42 PCI local bus signals signal description, 2-4 signal group, 2-2 PCI window suggested use, 6-41 PCI-to-EISA bridge, 6-42 See PCEB Phase-locked loop signals signal description, 2-11 signal group, 2-2 Pin descriptions DSW, 7-1 to 7-15, 7-1 Pins descriptions CIA, 2-1 TO 2-24, 2-1 Power CIA dissipation, 1-8 CIA supply, 1-8 DSW dissipation, 1-8 DSW supply, 1–8 Power-up, 5-1 internal reset, 5-1

## S

sysBus signal descriptions, 2–3 signal group, 2–1 System clocks, 1–7 System data coherency, 3–16 post and run I/O write data, 3–17 system basic properties, 3–16 System functional units, 3–1 System overview, 1–2 *See also* Chipset overview

## Т

Technical support, A-1

### W

W3\_BASE dual address cycle (DAC), 4–61 dual address cycle (DAC) enable, 6–32 illustration and description, 4–61