## CMOS Four-Port Dual-Access Register File #### **PRELIMINARY** ## DISTINCTIVE CHARACTERISTICS #### • 64 x 18 Bit Wide Register File The Am29C334 is a 64 x 18-bit, dual-access RAM with two read ports and two write ports. #### Pipelined Data Path The Am29C334 can be configured to support either a non-pipelined data path (similar to the Am29334) or a pipelined data path. #### Cascadable The Am29C334 is cascadable to support either wider word widths, deeper register files, or both. #### Built in Forwarding Logic The Am29C334 provides simultaneous read/write access to the same address for double pipelined systems. #### Byte Parity Storage Width of 18 bits facilitates byte parity storage for each port and provides consistency with the Am29C332 32-bit ALU. #### • Byte Write Capability Individual byte-write enables allow byte or full word write. #### **BLOCK DIAGRAMS** #### Non-Pipelined Mode Pipelined Mode 2-76 Publication # Rev. Amendment 08786 B /0 (ssue Date: December 1987 #### **GENERAL DESCRIPTION** The Am29C334 is a 64-word by 18-bit dual-access RAM with two read ports and two write ports. Two independent, simultaneous accesses are possible and each access can be either a read or a write. It is designed to be used in a system that requires as many as two reads and two writes in a single cycle. The device can be configured to support either a non-pipelined data path or a pipelined data path. The Am29C334 is also fully compatible with the bipolar Am29334. When the device is connected to the pinout specified for the Am29334, it will appear as a 64-word by 18-bit array without support for pipelined operation. The pipelined operation of the Am29C334 is made possible because of the availability of unused power pins not required by the CMOS part. The pipelined operation is disabled by attaching the PIPE pin to VCC. #### RELATED AMD PRODUCTS | Part No. | Description | |----------|---------------------------------------------| | Am29C323 | CMOS 32-Bit Parallel Multiplier | | Am29325 | 32-Bit Floating Point Processor | | Am29C325 | CMOS 32-Bit Floating Point Processor | | Am29331 | 16-Bit Microprogram Sequencer | | Am29C331 | CMOS 16-Bit Microprogram Sequencer | | Am29332 | 32-Bit Extended Function ALU | | Am29C332 | CMOS 32-Bit Extended Function ALU | | Am29334 | 64 x 18 Four-Port Dual-Access Register File | | Am29337 | 16-Bit Bounds Checker | | Am29338 | 128 x 9 Byte Queue | ## **CONNECTION DIAGRAM** #### 120 Lead PGA\* CD010320 \*Pins facing up. # TABLE OF INTERCONNECTIONS (Sorted by Pin Name) | PIN NAME | PIN<br>NO. | PAD<br>NO. | PIN NAME | PIN<br>NO. | PAD<br>NO. | PIN NAME | PIN<br>NO. | PAD<br>NO. | PIN NAME | PIN<br>NO. | PAC<br>NO | |------------------|------------|------------|------------------|------------|------------|------------------|------------|------------|------------------|------------|-----------| | - | | | D <sub>A03</sub> | E02 | 65 | D <sub>B16</sub> | K13 | 93 | YA05 | N06 | 21 | | | | | DA04 | F01 | 6 | D <sub>B17</sub> | K12 | 33 | YA06 | M06 | 81 | | | | | DA05 | F02 | 66 | GND | F03 | 8 | YA07 | L07 | 22 | | | | | DA06 | G03 | 7 | GND | J11 | 37 | YA08 | M07 | 8: | | A <sub>RA0</sub> | D02 | 63 | DA07 | G02 | 67 | GND | J12 | 38 | YA09 | N07 | 2 | | ARA1 | C02 | 62 | DA08 | G01 | 9 | GND | J13 | 39 | YA10 | N08 | 8. | | ARA2 | B01 | 61 | DA09 | H01 | 69 | GNDA | N05 | 20 | YA11 | M08 | 2 | | ARA3 | A02 | 120 | DA10 | H02 | 10 | GNDA | N09 | 26 | YA12 | L09 | 8: | | ARA4 | B03 | 119 | DA11 | J03 | 70 | GNDA | A09 | 50 | YA13 | M09 | 8 | | ARA5 | L02 | 74 | DA12 | J01 | 11 | GNDA | A05 | 56 | YA14 | L10 | 2 | | A <sub>RB0</sub> | K11 | 92 | DA13 | J02 | 71 | LEA | L01 | 14 | YA15 | M10 | 8 | | ARB1 | M13 | 91 | DA14 | K03 | 12 | LEB | B12 | 45 | YA16 | N10 | 2 | | ARB2 | N12 | 90 | DA15 | K02 | 72 | ΘĒΔ | L06 | 23 | YA17 | L11 | 8 | | ARB3 | M11 | 89 | DA16 | K01 | 13 | ŌĒR | C08 | 53 | YB00 | C03 | 11 | | ARB4 | M03 | 77 | DA17 | L03 | 73 | PIPE | H03 | 68 | YB01 | A04 | 5 | | ARB5 | B13 | 105 | D <sub>B00</sub> | C12 | 104 | Vcc | E11 | 97 | YB02 | B04 | 11 | | AWAO | D03 | 3 | D <sub>B01</sub> | C11 | 44 | Vcc | E12 | 98 | Y <sub>B03</sub> | C04 | 5 | | AWA1 | C01 | 2 | DB02 | D13 | 103 | Vcc | E13 | 99 | YB04 | B05 | 11 | | AWA2 | A01 | 1 | DB03 | D12 | 43 | VCCA | L08 | 83 | Y <sub>B05</sub> | C05 | 11 | | AWA3 | B02 | 60 | DB04 | D11 | 102 | VCCA | C06 | 113 | YB06 | B06 | . 5 | | AWA4 | A03 | 59 | D <sub>B05</sub> | F12 | 42 | WEAC/CLKA | M01 | 75 | YB07 | A06 | 11 | | AWA5 | M02 | 15 | D <sub>B06</sub> | F13 | 101 | WEAH | N02 | 76 | YB08 | A07 | 5 | | AwBo | L12 | 32 | D <sub>B07</sub> | C13 | 41 | WEAL | N01 | 16 | YB09 | B07 | 11 | | Awb1 | N13 | 31 | D <sub>B08</sub> | F11 | 100 | WEBC/CLKB | A12 | 106 | YB10 | C07 | 5 | | AWB2 | M12 | 30 | D <sub>B09</sub> | G11 | 40 | WEBH | B11 | 107 | YB11 | B08 | 11 | | Awas | N11 | 29 | DB10 | G13 | 96 | WEBL | A11 | 47 | YB12 | A08 | 5 | | AWB4 | N03 | 17 | DB11 | G12 | 36 | YA00 | L04 | 18 | YB13 | B09 | 11 | | AWB5 | A13 | 46 | D <sub>B12</sub> | H12 | 95 | YA01 | M04 | 78 | YB14 | C09 | 10 | | DA00 | D01 | 4 | DB13 | L13 | 35 | YA02 | N04 | 19 | YB15 | A10 | 4 | | D <sub>A01</sub> | E03 | 64 | DB13 | H13 | 94 | YA03 | L05 | 79 | YB16 | B10 | 10 | | DAU1<br>DA02 | E01 | 5 | D <sub>B15</sub> | H11 | 34 | YA04 | M05 | 80 | Y <sub>B17</sub> | C10 | 4 | # TABLE OF INTERCONNECTIONS (Cont'd.) (Sorted by Pin No.) | PIN<br>NO. | PIN NAME | PAD<br>NO. | PIN<br>NO. | PIN NAME | PAD<br>NO. | PIN<br>NO. | PIN NAME | PAD<br>NO. | PIN<br>NO. | PIN NAME | PAD<br>NO. | |------------|------------------------------------|------------|------------|------------------|------------|------------|------------------|------------|------------|------------------|------------| | | | | C05 | Y <sub>B05</sub> | 115 | H02 | D <sub>A10</sub> | 10 | M05 | YA04 | 80 | | | | | C06 | VCCA | 113 | H03 | PIPE | 68 | M06 | YA06 | 81 | | | | İ | C07 | Y <sub>B10</sub> | 52 | H11 | D <sub>B15</sub> | 34 | M07 | YA08 | 82 | | | | | C08 | ŌĒ <sub>B</sub> | 53 | H12 | D <sub>B12</sub> | 95 | M08 | YA11 | 25 | | A01 | Awa2 | 1 | C09 | YB14 | 109 | H13 | D <sub>B14</sub> | 94 | M09 | YA13 | 86 | | A02 | ARA3 | 120 | C10 | Y <sub>B17</sub> | 48 | J01 | D <sub>A12</sub> | 11 | M10 | YA15 | 87 | | A03 | A <sub>WA4</sub> | 59 | C11 | D <sub>B01</sub> | 44 | J02 | D <sub>A13</sub> | 71 | M11 | A <sub>RB3</sub> | 89 | | A04 | Y <sub>B01</sub> | 58 | C12 | D <sub>B00</sub> | 104 | J03 | D <sub>A11</sub> | 70 | M12 | AWB2 | 30 | | A05 | GNDA | 56 | C13 | D <sub>B07</sub> | 41 | J11 | GND | 37 | M13 | A <sub>RB1</sub> | 91 | | A06 | Y <sub>B07</sub> | 114 | D01 | D <sub>A00</sub> | 4 | J12 | GND | 38 | N01 | WEAL | 16 | | A07 | Y <sub>B08</sub> | 54 | D02 | ARA0 | 63 | J13 | GND | 39 | N02 | WEAH | 76 | | A08 | Y <sub>B12</sub> | 51 | D03 | AWAD | 3 | K01 | D <sub>A16</sub> | 13 | N03 | AWB4 | 17 | | A09 | GNDA | . 50 | D11 | D <sub>B04</sub> | 102 | K02 | DA15 | 72 | N04 | YA02 | 19 | | A10 | YB15 | 49 | D12 | D <sub>B03</sub> | 43 | K03 | D <sub>A14</sub> | 12 | N05 | GNDA | 20 | | A11 | WE <sub>BL</sub> | 47 | D13 | D <sub>B02</sub> | 103 | K11 | A <sub>RB0</sub> | 92 | N06 | YA05 | 21 | | A12 | WE <sub>BC</sub> /CLK <sub>B</sub> | 106 | E01 | D <sub>A02</sub> | 5 | K12' | D <sub>B17</sub> | 33 | N07 | YA09 | 24 | | A13 | Aw <sub>B5</sub> | 46 | E02 | D <sub>A03</sub> | 65 | K13 | D <sub>B16</sub> | 93 | NO8 | YA10 | 84 | | B01 | A <sub>RA2</sub> | 61 | E03 | D <sub>A01</sub> | 64 | L01 | LEA | 14 | N09 | GNDA | 26 | | B02 | A <sub>WA3</sub> | 60 | E11 | Vcc | 97 | L02 | ARA5 | 74 | N10 | YA16 | 28 | | B03 | A <sub>RA4</sub> | 119 | E12 | Vcc | 98 | L03 | D <sub>A17</sub> | 73 | N11 | Aw <sub>B3</sub> | 29 | | B04 | YB02 | 117 | E13 | Vcc | 99 | L04 | YA00 | 18 | N12 | ARB2 | 90 | | B05 | Y <sub>B04</sub> | 116 | F01 | D <sub>A04</sub> | 6 | L05 | YA03 | 79 | N13 | AWB1 | 31 | | B06 | Y <sub>B06</sub> | 55 | F02 | D <sub>A05</sub> | 66 | L06 | ŌĒA | 23 | | | | | B07 | Y <sub>B09</sub> | 112 | F03 | GND | 8 | L07 | YA07 | 22 | | | | | B08 | Y <sub>B11</sub> | 111 | F11 | D <sub>B08</sub> | 100 | L08 | VCCA | 83 | | | | | B09 | Y <sub>B13</sub> | 110 | F12 | D <sub>B05</sub> | 42 | L09 | YA12 | 85 | | | | | B10 | YB16 | 108 | F13 | D <sub>B06</sub> | 101 | L10 | YA14 | 27 | | | | | B11 | WEBH | 107 | G01 | D <sub>A08</sub> | 9 | L11 | YA17 | 88 | | | | | B12 | LEB | 45 | G02 | D <sub>A07</sub> | 67 | L12 | Aw Bo | 32 | | | | | B13 | A <sub>RB5</sub> | 105 | G03 | D <sub>A06</sub> | 7 | L13 | D B13 | 35 | | | | | C01 | A <sub>WA1</sub> | 2 | G11 | D <sub>B09</sub> | 40 | M01 | WEAC/CLKA | 75 | | | | | C02 | A <sub>RA1</sub> | 62 | G12 | D <sub>B11</sub> | 36 | M02 | Aw A5 | 15 | | | | | C03 | Y <sub>B00</sub> | 118 | G13 | D <sub>B10</sub> | 96 | M03 | A <sub>RB4</sub> | 77 | | | | | C04 | Y <sub>803</sub> | 57 | H01 | D <sub>A09</sub> | 69 | M04 | YA01 | 78 | | | | METALLIZATION AND PAD LAYOUT #### ORDERING INFORMATION Standard Products AMD standard products are available in several packages and operating ranges. The order number (Valid Combination) is formed by a combination of: a. Device Number b. Speed Option (if applicable) c. Package Type d. Temperature Range e. Optional Processing | Valid C | ombinations | |------------|-------------| | AM29C334 | GC, GCB | | AM29C334-1 | | #### **Valid Combinations** Valid Combinations list configurations planned to be supported in volume for this device. Consult the local AMD sales office to confirm availability of specific valid combinations, to check on newly released valid combinations, and to obtain additional data on AMD's standard military grade products. ### ORDERING INFORMATION (Cont'd.) #### **APL Products** AMD products for Aerospace and Defense applications are available in several packages and operating ranges. APL (Approved Products List) products are fully compliant with MIL-STD-883C requirements. The order number (Valid Combination) for APL products is formed by a combination of: a. Device Number - b. Speed Option (if applicable) - c. Device Class - d. Package Type - e. Lead Finish | Valid ( | Combinations | | |----------|--------------|--| | AM29C334 | /BZC | | #### Valid Combinations Valid Combinations list configurations planned to be supported in volume for this device. Consult the local AMD sales office to confirm availability of specific valid combinations or to check for newly released valid combinations. ## Group A Tests Group A tests consist of Subgroups 1, 2, 3, 7, 8, 9, 10, 11. #### PIN DESCRIPTION #### ARA0 - ARA5 Read Address A-Side (Input) The 6-bit read address input selects one of the 64 memory locations for output to the YA Data Latch. #### ARB0 - ARB5 Read Address B-Side (Input) The 6-bit read address input selects one of the 64 memory locations for output to the ${\rm Y_B}$ Data Latch. #### AWA0 - AWA5 Write Address A-Side (Input) The 6-bit write address input selects one of the 64 memory locations for writing new data from the DA input. ## AWB0 - AWB5 Write Address B-Side (Input) The 6-bit write address input selects one of the 64 memory locations for writing new data from the D<sub>B</sub> input. #### DA0 - DA17 Data A-Side (Input) New data is written into memory from this input, as selected by the AWA address input. #### DB0 - DB17 Data B-Side (Input) New data is written into memory from this input, as selected by the AwB address input. #### GND, V<sub>CC</sub> Power Power supply for the internal logic (0, 5 V). #### GNDA, VCCA Power Power supply for the output drivers (0, 5 V). ## LEA YA Data Latch Enable (Input, Active HIGH) The LEA input controls the latch for the YA output port. When LEA is HIGH, the latch is open (transparent) and data from the RAM, as selected by the ARA address inputs, is passed to the YA output. When LEA is LOW, the latch is closed and it retains the last data read from the RAM. LEA is disabled in the pipelined mode. #### LE<sub>B</sub> Y<sub>B</sub> Data Latch Enable (Input, Active HIGH) The LEB input controls the latch for the YB output port. When LEB is HIGH, the latch is open (transparent), and data from the RAM, as selected by the ABB address inputs, is passed to the YB output. When LEB is LOW, the latch is closed and it retains the last data read from the RAM. LEA is disabled in the pipelined mode. #### OEA YA Output Enable (Input, Active LOW) When $\widehat{OE}_A$ is LOW, data in the Y<sub>A</sub> Data Latch is driven on the Y<sub>A</sub> output. When $\widehat{OE}_A$ is HIGH, Y<sub>A</sub> output is in the high-impedance (off) state. #### OEB YB Output Enable (Input, Active LOW) When $\widetilde{OE}_B$ is LOW, data in the $Y_B$ Data Latch is driven on the $Y_B$ outputs. When $\widetilde{OE}_B$ is HIGH, $Y_B$ output is in the high-impedance (off) state. #### PIPE Pipeline Enable (Input, Active LOW) When PIPE is LOW, the input and output registers are enabled, allowing for pipelined operation. When HIGH, these registers are made transparent. # WE<sub>AC</sub>/CLK<sub>A</sub> Write Enable A-Side Common (Input, Active LOW) When $\overline{WE}_{AC}$ is LOW together with $\overline{WE}_{AH}$ or $\overline{WE}_{AL}$ , new data is written into the location selected by the AWA address. When $\overline{WE}_{AC}$ is HIGH, no data is written into the RAM through the A port. $\overline{WE}_{AC}$ acts as a clock input in the pipeline mode for the A side. # WE<sub>BC</sub>/CLK<sub>B</sub> Write Enable B-Side Common (Input, Active LOW) When $\overline{WE}_{BC}$ is LOW together with $\overline{WE}_{BH}$ or $\overline{WE}_{BL}$ , new data is written into the location selected by the AWB address. When $\overline{WE}_{BC}$ is HIGH, no data is written into the RAM through the B port. $\overline{WE}_{BC}$ acts as a clock input in the pipeline mode for the B side. # WEAH High-Byte Write Enable A-Side (Input, Active LOW) When $\overline{WE}_{AH}$ is LOW together with $\overline{WE}_{AC}$ , new data is written into the high byte of the location selected by the AWA address input. When $\overline{WE}_{AH}$ is HIGH, no data is written into the high byte. # WEBH High-Byte Write Enable B-Side (Input, Active LOW) When $\overline{WE}_{BH}$ is LOW together with $\overline{WE}_{BC}$ , new data is written into the high byte of the location selected by the AW<sub>B</sub> address input. When $\overline{WE}_{BH}$ is HIGH, no data is written into the high byte. # WE<sub>AL</sub> Low-Byte Write Enable A-Side (Input, Active LOW) When $\overline{WE}_{AL}$ is LOW together with $\overline{WE}_{AC}$ , new data is written into the low byte of the location selected by the AWA address input. When $\overline{WE}_{AL}$ is HIGH, no data is written into the low byte. # WEBL Low-Byte Write Enable B-Side (Input, Active LOW) When WE<sub>BL</sub> is LOW together with WE<sub>BC</sub>, new data is written into the low byte of the location selected by the AW<sub>B</sub> address input. When WE<sub>BL</sub> is HIGH, no data is written into the low byte. # Y<sub>A0</sub> - Y<sub>A17</sub> Data Latch (Outputs, Three-State) The 18-bit Y<sub>A</sub> Data Latch outputs. #### Y<sub>B0</sub> - Y<sub>B17</sub> Data Latch (Outputs, Three-State) The 18-bit Y<sub>B</sub> Data Latch outputs. #### **FUNCTIONAL DESCRIPTION** The heart of the Am29C334 is a high-speed 64-word by 18-bit dual RAM cell array. Six write enables permit the RAM word to be written in one or both of its 9-bit bytes. Data to be written is presented to each side of the RAM array through the two data ports $(D_A$ and $D_B)$ . The remainder of the logic surrounding the RAM array supports pipelining the RAM access and providing a forwarding path for data around the RAM. This forwarding path is needed to eliminate the latency cycle associated with consecutive write/read accesses to the same memory location in a pipelined system. Pipelining of the RAM is controlled by the PIPE pin. When not asserted (i.e., in non-pipelined mode) the registers on the inputs (write ports $D_{A/B}$ , write addresses $A_{WA/B}$ , and write enables $\overline{WE}_{AC/BC}$ ) are made fully transparent, while the registers at the outputs (the read ports $Y_{A/B}$ ) are turned into latches, controlled by the latch enables LE<sub>A/B</sub>. In either mode of operation, each side of the RAM is controlled by its individual control signals. This means that the two sides of the RAM can operate at different clock rates to one another. In the pipelined mode, these clock rates must have a known relationship between each other. In the non-pipelined mode, there is no need for a relationship between the clock rates. Two special cases of operation arise because of this. The first is where the location written to by one side is being read from the other side. In this case, known as A-to-B transparency, the value read is the value being written. The second occurs when two writes to the same location occur at the same time. In this case the value written can not be defined, but the operation is not harmful to the device. The transparency mode (A-A or B-B) during a write $(\overline{WE}_A = LOW)$ allows the data in (D<sub>A</sub>) to not only be written into memory, but also to appear at the output (Y<sub>A</sub>) when the output latch (LE<sub>A</sub>) is HIGH and the output enable control $(\overline{OE}_A)$ is LOW. # Extensions to Four Read Ports and Two Write Ports A RAM with four read ports and two write ports can be made by using two dual-access RAMs and connecting each of the write ports, write addresses, and write enables in parallel for the two devices. Figure 2 details this in a non-pipelined mode. Figure 1. Am29C300 CMOS Family High-Performance System Block Diagram #### 32 Word x 36 Bit Single-Access RAM It is possible to convert the 64 word x 18 bit dual-access RAM into a 32 word x 36 bit single-access RAM. This is performed by storing the upper half of the 36 bits in the upper half of the 64 words and addressing these from the A side, and storing the lower half of the 36 bits in the lower half of the 64 words and addressing these from the B side. This arrangement does not change the capacity of the RAM, but the dual access is lost (see Figure 4). #### **Operational Modes** The Am29C334 may be configured in a non-pipelined mode or in a pipelined mode by controlling the PIPE pin. This mode is selected via hardwiring the pin to either LOW or HIGH. This option should not be changed during operation. #### Non-Pipelined Data Path In non-pipelined mode ( $\overline{\text{PIPE}}=1$ ), the Am29C334 is a flow-through device; data is read out, used, and written back all in the same cycle. In this mode all the registers are made transparent except the registers at the two read ports that are configured as latches. The read port latches are controlled individually by the LEA and LEB, so that they are transparent when the latch enables are HIGH and retain the data when the latch enables are LOW. The "forwarding logic" incorporated to support the pipelined mode of operation is also disabled in this mode of operation (specifically, the address comparators are disabled). In the non-pipelined mode of operation it is possible to simultaneously read two ports, read one port and write to the other, or write to two ports, concurrently. The read and write addresses are internally multiplexed on each side. The selection of the read and write addresses is controlled by the exclusive-OR of the $\overline{PIPE}$ pin and $\overline{WE_{AC/BC}}$ . Normally, the $\overline{WE_{AC/BC}}$ are connected to the system clock. With $\overline{PIPE}$ deaserted, the read address will be selected in the high part of the clock cycle ( $\overline{WE_{AC/BC}}=1$ ) and the write address selected only in the low part. Byte selection for writing on either ports is controlled by the $\overline{WE_{H/I}}$ pins. Two interesting cases arise as a result of the dual access capability. The first occurs if a location is written into by one side while it is being read out by the other side. In this case, known as A-to-B transparency, the data being written will appear on the read port after the TransparencyAB time (if other read access time parameters are met). The second case of interest occurs if both sides write to the same location at the same time. The value written as a result of this operation cannot be defined. #### Pipelined Data Path The Am29C334 can be configured in a pipelined system by asserting the PIPE signal (PIPE = 0) and adding an additional external register in the write address and the write control path on both A and B ports as shown in Figure 3. The registers on each side are controlled by separate clocks that are supplied over the $\overline{\text{WE}}_{AC}$ and $\overline{\text{WE}}_{BC}$ pins. Typically, in a pipelined system a read - modify - write would span three cycles. In the second half of the first cycle, a read of the operand(s) is performed and the data is clocked into the output registers at the end of the cycle. In the second cycle, the operation is performed on the operands and the result is clocked into the data register on the write port at the end of the second cycle. In the first half of the third cycle, the data is written to the register file. Therefore, in any cycle, a pipelined system is writing the result of instruction n (in the first half), executing instruction n+1, and reading the operands needed in instruction n+2. In any case, a write operation followed by a read operation is performed in the RAM in a cycle. A special case arises if the data to be written by the previous instruction is needed in the next instruction as an operand. Due to the pipeline register being at its write port, the location is not written into until the next cycle, and hence only the previous value is available in the current cycle. To overcome this problem, "forwarding logic" is included as shown in the block diagram. This logic consists of three elements: an address comparator, an AND gate, and a three-to-one multiplexer, as shown. If the read address of the current instruction is the same as the write address of the previous instruction, and if the result is to be written, then the data to be written is forwarded by the forwarding multiplexer to the output registers. Since there are two write ports, forwarding paths on both ports are provided. As each write port has byte write capability, the forwarding is further broken into the upper and lower bytes. Since each side has its own $\overline{WE}_C/CLK$ control, it is possible to clock each side of the chip differently. However, if the part is used at different frequencies, the forwarding cannot be guaranteed unless the addresses compared are held valid long enough to allow for a comparison to be made and the results of the forwarding setup on the output register. As mentioned earlier, it is necessary to use an external write address and write control registers in a pipelined system. These registers have not been included for two reasons. First, it is possible for the user to abort the writing before it fills the internal pipe. This situation may arise in cases such as in "traps." Second, by providing an external write address register it provides the flexibility of obtaining the write address from several sources by using an external multiplexer. Figure 2. RAM with Four Read Ports and Two Write Ports for Non-pipelined Mode Figure 3. System Diagram With the Am29C334 in a Double Pipelined Data Path Figure 4. 32 x 36 RAM (Single Access) Using 64 x 18 Dual-Access RAM # ABSOLUTE MAXIMUM RATINGS #### **OPERATING RANGES** Commercial (C) Devices | Temperature (T <sub>A</sub> )Supply Voltage | | |---------------------------------------------------------------------------------------|------------------------| | Military* (M) Devices Temperature (T <sub>A</sub> ) Supply Voltage (V <sub>CC</sub> ) | | | Operating ranges define those lim | nits between which the | Stresses above those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent device failure. Functionality at or above these limits is not implied. Exposure to absolute maximum ratings for extended periods may affect device reliability. \* Military product 100% tested at $T_A = +25$ °C, +125°C, and functionality of the device is guaranteed. DC CHARACTERISTICS over operating range unless otherwise specified (for APL Products, Group A, Subgroups 1, 2, 3 are tested unless otherwise noted) | Parameter<br>Symbol | Parameter<br>Description | Test Cor<br>(Note | | Min. | Max. | Unit | |---------------------|----------------------------------------|-----------------------------------------------------------------------------------------------------------|--------------------------------------------|------|----------|-------| | Voн | Output HIGH Voltage | V <sub>CC</sub> = Min.<br>V <sub>IN</sub> = V <sub>IL</sub> or V <sub>IH</sub><br>I <sub>OH</sub> = -4 mA | | 2.4 | | Volts | | V <sub>OL</sub> | Output LOW Voltage | V <sub>CC</sub> = Min.<br>V <sub>IN</sub> = V <sub>IL</sub> or V <sub>IH</sub><br>I <sub>OL</sub> = 8 mA | | | 0.5 | Volts | | VIH | Input HIGH Level | Guaranteed Input Logical<br>HIGH Voltage (Note 2) | | 2.0 | | Volts | | V <sub>IL</sub> | Input LOW Level | Guaranteed Input Logical<br>LOW Voltage (Note 2) | | | 0.8 | Volts | | I <sub>IL</sub> | Input LOW Current | V <sub>CC</sub> = Max.<br>V <sub>IN</sub> = 0.5 V | | | -10 | μΑ | | 1 <sub>IIH</sub> | Input HIGH Current | V <sub>CC</sub> = Max.<br>V <sub>IN</sub> = V <sub>CC</sub> - 0.5 V | | | 10 | μΑ | | lozн | Off State (High-Impedance) | V May | V <sub>O</sub> = 2.4 V | | 10 | | | lozL | Output Current | V <sub>CC</sub> = Max. | V <sub>O</sub> = 0.5 V | | -10 | μΑ | | | | V <sub>IN</sub> = V <sub>CC</sub> or GND | T <sub>A</sub> = -55 to 125°C | | 80 | mA | | Icc | Static Power Supply Current | V <sub>CC</sub> = Max<br>I <sub>O</sub> = 0 μA | $T_A = 0 \text{ to } + 70^{\circ}\text{C}$ | | 70 | mA | | C <sub>PD</sub> | Power Dissipation Capacitance (Note 3) | V <sub>CC</sub> = 5.0 V<br>T <sub>A</sub> = 25°C No Load | | 90 | 0 pF Typ | cal | 3. CPD determines the no-load dynamic current consumption: Notes: 1. $V_{CC}$ conditions shown as Min. or Max. refer to the commercial ( $\pm$ 5%) $V_{CC}$ limits. 2. These input levels provide zero-noise immunity and should only be statically tested in a noise-free environment (not functionally tested). $I_{CC}$ (Total) = $I_{CC}$ (Static) + $C_{PC}$ $V_{CC}$ f, where f is the switching frequency of the majority of the internal nodes, normally one-half of the clock frequency. This specification is not tested. # SWITCHING CHARACTERISTICS over COMMERCIAL operating range unless otherwise specified NON-PIPELINED MODE (Note 1) | - | | | | 29 | C334 | 290 | 334-1 | 290 | 334-2 | | |-----|-----------------------------------|---------------------------------------------------------------------------------|-----------------------------------|------|--------------|------|--------------------|------|----------------|------| | No. | Parameter | Description | Test Conditions | Min. | Max. | Min. | Max. | Min. | Max. | Unit | | 1 | Access Time | ARA or ARB to YA or<br>YB | LEA or LEB = H | | 32 | | 26 | | 21 | ns | | 2 | Access Time | WEAC or WEBC to<br>YA or YB | LEA or LEB = H | lan | 30 | | 25 | | 20 | ns | | 3 | Turn-On Time | OE <sub>A</sub> or OE <sub>B</sub> I to Y <sub>A</sub> or Y <sub>B</sub> Active | | 0 | 20 | 0 | 16 | O | 16 | ns | | 4 | Turn-Off Time<br>(Note 2) | OEA or OEB t to YA<br>or YB = High<br>Impedance | | 0 | 20 | 0 | 10 | 0 | 6 | ns | | 5 | Enable Time | LEA or LEB 1 to YA or YB | | 0 | 18 | 0 | | 0 | | ns | | 6 | Transparency | WEA or WEB I to YA<br>or YB | LEA or LEB = H | đ | 200 P | d | 1000000<br>1000000 | ısı. | 1007<br>1007 | ns | | 7 | Transparency | DA or DB to YA or<br>YB | LEA or LEB = H,<br>WEA or WEB = L | 3 | 3 | | 333 | | 234 | ns | | 8 | Write Recovery Time | ARA OF ARB to WEAC<br>or WEBC | | 4 | (2)-(1) | * | (2)-(1) | 187 | (2)-(1) | ns | | 9 | Data Setup Time | DA or DB to WEA or W | E <sub>B</sub> t | 15 | | 13 | E | 13 | | ns | | 10 | Data Hold Time | DA or DB to WEA or W | Æ <sub>B</sub> τ | 0 | 3 B | 0 | T <sub>m</sub> | 0 | - 15 T | ns | | 11 | Address Setup Time | AWA or AWB to WEA o | r WEB 1 | 2 | | 2 | | 2 | | ns | | 12 | Address Hold Time | AWA or AWB to WEA o | r WE <sub>B</sub> † | 1 4 | Physical Co. | 1 | Page 12 | 1 1 | No. | ns | | 13 | Address Setup Time | ARA or ARB to LEA or | LE <sub>B</sub> ↓ | 20 | | 17 | | 17 | _ سگ | ns | | 14 | Address Hold Time | ARA or ARB to LEA or | LE <sub>B</sub> ↓ | 1 | | 1 4 | | 14 | <b>1</b> | ns | | 15 | Latch Close Before<br>Write | LEA or LEB to WEA or | WE <sub>B</sub> : | 0 | and the same | 0. | A CONTRACTOR | 0 | and the second | ns | | 16 | Read Before Latch<br>Close | WEAC or WEBC to LEA | , or LE <sub>B</sub> ↓ | 20 | | 16 | | 16 | | ns | | 17 | Write Pulse Width | WEA or WEB (LOW) | | 20 | | 16 | ļ | 16 | ļ | ns | | 18 | Latch Data Capture<br>Pulse Width | LEA or LEB (HIGH) | | 14 | | 12 | | 12 | | ns | Notes: See notes following Military table. SWITCHING CHARACTERISTICS over MILITARY operating range unless otherwise specified (for APL Products, Group A, Subgroups 9, 10, 11 are tested unless otherwise noted) #### NON-PIPELINED MODE (Note 1) | | | | | 290 | 2334 | | |-----|-----------------------------------|--------------------------------------------------------------------------------------------|----------------------------------------|------|---------|------| | No. | Parameter | Description | Test Conditions | Min. | Max. | Unit | | 1 | Access Time | ARA or ARB to YA or YB | LEA or LEB = H | | 40 | ns | | 2 | Access Time | WEAC or WEBC to YA or YB | LE <sub>A</sub> or LE <sub>B</sub> ≠ H | 0 | 37 | ns | | 3 | Turn-On Time | OE <sub>A</sub> or OE <sub>B</sub> I to Y <sub>A</sub> or Y <sub>B</sub> Active | | 0 | 16 | ns | | 4 | Turn-Off Time<br>(Note 2) | OE <sub>A</sub> or OE <sub>B</sub> to Y <sub>A</sub> or<br>Y <sub>B</sub> = High Impedance | | 0 | 25 | ns | | 5 | Enable Time | LEA or LEB † to YA or<br>YB | | 0 | 21 | ns | | 6 | Transparency | WEA or WEB ↓ to YA or<br>YB | LEA or LEB = H | 0 | 47 | ns | | 7 | Transparency | DA or DB to YA or YB | LEA or LEB = H,<br>WEA or WEB = L | | 47 | ns | | 8 | Write Recovery Time | ARA or ARB to WEAC or WEBC | | | (2)-(1) | ns | | 9 | Data Setup Time | DA or DB to WEA or WEB | 1 | 19 | | ns | | 10 | Data Hold Time | DA or DB to WEA or WEB | 1 | 2 | | ns | | 11 | Address Setup Time | AWA or AWB to WEA or W | E <sub>B</sub> ↓ | 4 | | ns | | 12 | Address Hold Time | AWA or AWB to WEA or W | E <sub>B</sub> ↑ | 2 | | ns | | 13 | Address Setup Time | ARA or ARB to LEA or LEE | 3 ↓ | 23 | | ns | | 14 | Address Hold Time | ARA or ARB to LEA or LEE | 3 ↓ | 1 | | ns | | 15 | Latch Close Before<br>Write | LEA or LEB to WEA or WE | . В ↓ | 0 | | ns | | 16 | Read Before Latch<br>Close | WEAC or WEBC to LEA or | LE <sub>B</sub> ↓ | 24 | | ns | | 17 | Write Pulse Width | WEA or WEB (LOW) | | 23 | | | | 18 | Latch Data Capture<br>Pulse Width | LEA or LEB (HIGH) | | 17 | | ns | Notes: 1. WE<sub>A</sub> = WE<sub>AC</sub> + WE<sub>AL</sub>/H WE<sub>B</sub> = WE<sub>BC</sub> + WE<sub>BL</sub>/H 2. Y<sub>A</sub> and Y<sub>B</sub> are tested independently. 3. Minimum delays are not tested. ## SWITCHING CHARACTERISTICS over COMMERCIAL operating range (Cont'd.) #### PIPELINED MODE | | | | 290 | 334 | 29C | 334-1 | 29C | 334-2 | | |-----|-----------------------------|---------------------------------------------|------|-----------------|------|----------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------| | No. | Parameter | Description | Min. | Max. | Min. | Max. | Min. | Max. | Unit | | 19 | Write Data Setup Time | DA or DB to CLKA or CLKB t | 15 🍇 | | 13 | Molecus | 13 🍇 | Do | ns | | 20 | Write Data Hold Time | DA or DB to CLKA or CLKB t | 1 # | | 1 | author? | 1 # | a de la companya l | ns | | 21 | Write Address Setup<br>Time | AWA or AWB to CLKA or CLKB 1 | 23 | es ne | 20 | | 20 | | ns | | 22 | Write Address Hold<br>Time | AWA or AWB to CLKA or CLKB 1 | 0 | | 0 | ka<br>Ba | 0 | | ns | | 23 | Write Enable Setup<br>Time | WEH or WEL to CLKA or CLKB 1 | 20. | 65.00A | 16 | T | | ORDER! | ns | | 24 | Write Enable Hold Time | WEH or WEL to CLKA or CLKB 1 | 0 | 10 | 0 | | 0 | NO. | ns | | 25 | Read Address Setup<br>Time | ARA or ARB to CLKA or CLKB 1 | 24 | STEPAN<br>E | 20 | | 20 ** | erser 3 | ns | | 26 | Read Address Hold<br>Time | ARA or ARB to CLKA or CLKB 1 | 0 | | 0 | | 0 | | ns | | 27 | Minimum Clock Cycle | CLKA or CLKB (LOW) | 50 | The second | 40 | 2 tá d | 40 | n <sub>e</sub> godí | ns | | 28 | Minimum Clock Pulse | CLK <sub>A</sub> or CLK <sub>B</sub> (HIGH) | 17 | erioren<br>Majo | 14 | 1000 | 14 | 608/150<br>80 <sub>8</sub> | ns | | 29 | Minimum Clock Pulse | CLK <sub>A</sub> or CLK <sub>B</sub> (LOW) | 17 | esalva. | 14 | Rest : | 14 🖁 | adam. | ns | | 30 | Clock to Y | YA or YB to CLKA or CLKB | 14 | | 12 | | 10 | | ns | # SWITCHING CHARACTERISTICS over MILITARY operating range (Cont'd.) ## PIPELINED MODE | | | | 290 | C334 | | |-----|--------------------------|---------------------------------------------|------|------|------| | No. | Parameter | Description | Min. | Max. | Unit | | 19 | Write Data Setup Time | DA or DB to CLKA or CLKB 1 | 19 | | ns | | 20 | Write Data Hold Time | DA or DB to CLKA or CLKB t | 2 | | ns | | 21 | Write Address Setup Time | AWA or AWB to CLKA or CLKB ; | 27 | | ns | | 22 | Write Address Hold Time | AWA or AWB to CLKA or CLKB 1 | 2 | | ns | | 23 | Write Enable Setup Time | WEH or WEL to CLKA or CLKB 1 | 23 | | ns | | 24 | Write Enable Hold Time | WEH or WEL to CLKA or CLKB 1 | 2 | | ns | | 25 | Read Address Setup Time | ARA or ARB to CLKA or CLKB 1 | 28 | | ns | | 26 | Read Address Hold Time | ARA or ARB to CLKA or CLKB 1 | 0 | | ns | | 27 | Minimum Clock Cycle | CLK <sub>A</sub> or CLK <sub>B</sub> (LOW) | 55 | | ns | | 28 | Minimum Clock Pulse | CLK <sub>A</sub> or CLK <sub>B</sub> (HIGH) | 20 | | ns | | 29 | Minimum Clock Pulse | CLK <sub>A</sub> or CLK <sub>B</sub> (LOW) | 20 | | ns | | 30 | Clock to Y | YA or YB to CLKA or CLKB | 18 | | ns | ## SWITCHING TEST CIRCUIT Notes: 1. $C_L$ = 50pF includes scope probe, wiring and stray capacitances without device in test fixture. - 2. $S_1$ , $S_2$ , $S_3$ are closed during functions tests and all AC tests except output enable tests. - 3. $S_1$ and $S_3$ are closed while $S_2$ is open for $t_{PZH}$ test. $S_1$ and $S_2$ are closed while $S_3$ is open for $t_{PZL}$ test. 4. CL = TBD for output disable tests. KEY TO SWITCHING WAVEFORMS KS000010 ## INPUT/OUTPUT CIRCUIT DIAGRAMS $C_1 \approx 5.0$ pF, all inputs $C_{\mbox{O}} \approx 5.0$ pF, all outputs