## Am29C660 CMOS Cascadable 32-Bit Error Detection and Correction Circuit #### **PRELIMINARY** #### **DISTINCTIVE CHARACTERISTICS** - Improves memory reliability - Corrects all single-bit errors. Detects all double- and some triple-bit errors - Very high-speed error detection and correction - Down to 16 ns Data-In to error detection - Low-power CMOS process - Cascadable for data words up to 64 bits - Simplified byte operations - Separate byte enables on the Data Output Latch for fast byte writes - Built-in diagnostics - Proper EDC operation can be verified by the CPU via software control #### GENERAL DESCRIPTION The Am29C660 CMOS Cascadable 32-Bit Error Detection and Correction Circuit (EDC) contains the logic necessary to generate check bits on a 32-bit data field according to a modified Hamming Code, and to correct the data word when check bits are supplied. Operating on data read from memory, the Am29C660 detects and corrects all single-bit errors and detects all double- and some triple-bit errors. For 32-bit words, 7 check bits are used. The Am29C660 is expandable to operate on 64-bit data words (8 check bits). In both configurations, the device makes error syndromes available on separate outputs for error logging. The Am29C660 also features two diagnostic modes in which diagnostic data can be forced into portions of the chip to simplify device testing and to execute system diagnostic functions. When used with the Am2968A/Am29368/Am29C668 Dynamic Memory Controllers and the Am2969 Memory Timing Controller, the Am29C660 can perform AMD's invented memory "scrubbing" operation to provide highest data integrity. #### **BLOCK DIAGRAM** Publication # Rev. Amendment 10565 A /0 Issue Date: July 1988 #### **RELATED AMD PRODUCTS** | Part No. | Description | |----------|---------------------------------------------------| | Am29368 | 1M Dynamic Memory Controller/Driver | | Am29C60A | CMOS Cascadable 16-Bit EDC | | Am29C668 | 4M CMOS Advanced Dynamic Memory Controller/Driver | | Am2968A | 256K Dynamic Memory Controller/Driver | | Am2969 | Memory Timing Controller for EDC Systems | | Am2971A | 100-MHz Enhanced Programmable Event Generator | | Am2976 | 11-Bit Dynamic RAM Driver | | Am29C983 | 9-Bit x 4-Port Multiple Bus Exchange | ## CONNECTION DIAGRAMS Top View Note: Pin 1 is marked for orientation (PLCC only). \*Also available in LCC; pinout is identical to PLCC. PGA (Pins facing up) 10565A-003A CD011560 ## PGA PIN DESIGNATIONS (Sorted by Pin No.) | PIN<br>NO. | PIN NAME | PIN<br>NO. | PIN NAME | PIN<br>NO. | PIN NAME | PIN<br>NO. | PIN NAME | | |-------------|------------------------|------------|--------------------|------------|---------------------------------|------------|-----------------|--| | A-2 | DATA <sub>1</sub> | B-9 | DATA <sub>26</sub> | F-10 | Vcc | K-4 | CB <sub>3</sub> | | | A-3 | DATA <sub>0</sub> | B-10 | GND | F-11 | DATA <sub>17</sub> | K-5 | CB <sub>1</sub> | | | A-4 | LEIN | B-11 | DATA <sub>24</sub> | G-1 | DATA <sub>11</sub> | K-6 | SC <sub>0</sub> | | | A-5 | DIAG MODE <sub>0</sub> | C-1 | DATA <sub>4</sub> | G-2 | DATA <sub>10</sub> | K-7 | SC <sub>2</sub> | | | A-6 | CODE ID <sub>0</sub> | C-2 | DATA <sub>3</sub> | G-10 | OE BYTE2 | K-8 | SC <sub>4</sub> | | | A-7 | DATA <sub>31</sub> | C-10 | DATA <sub>22</sub> | G-11 | DATA <sub>16</sub> | K-9 | SC <sub>6</sub> | | | A-8 | DATA <sub>29</sub> | C-11 | DATA <sub>23</sub> | H-1 | DATA <sub>13</sub> | K-10 | GND | | | <b>A-</b> 9 | DATA <sub>27</sub> | D-1 | DATA <sub>6</sub> | H-2 | DATA <sub>12</sub> | K-11 | MULT ERROR | | | A-10 | DATA <sub>25</sub> | D-2 | DATA <sub>5</sub> | H-10 | CORRECT | L-2 | CB <sub>6</sub> | | | B-1 | DATA <sub>2</sub> | D-10 | DATA <sub>20</sub> | H-11 | LE <sub>OUT</sub> /<br>GENERATE | L-3 | CB <sub>4</sub> | | | B-2 | V <sub>CC</sub> | D-11 | DATA <sub>21</sub> | J-1 | DATA <sub>15</sub> | L-4 | CB <sub>2</sub> | | | B-3 | OE BYTE <sub>0</sub> | E-1 | DATA <sub>8</sub> | J-2 | DATA <sub>14</sub> | L-5 | CB <sub>0</sub> | | | B-4 | DIAG MODE <sub>1</sub> | E-2 | DATA <sub>7</sub> | J-10 | ERROR | L-6 | SC <sub>1</sub> | | | B-5 | CODE ID <sub>1</sub> | E-10 | DATA <sub>18</sub> | J-11 | LE <sub>DIAG</sub> | L-7 | SC <sub>3</sub> | | | B-6 | OE BYTE <sub>3</sub> | E-11 | DATA <sub>19</sub> | K-1 | OE BYTE <sub>1</sub> | L-8 | SC <sub>5</sub> | | | B-7 | DATA <sub>30</sub> | F-1 | DATA <sub>9</sub> | K-2 | CB <sub>7</sub> | L-9 | SC <sub>7</sub> | | | B-8 | DATA <sub>28</sub> | F-2 | GND | K-3 | CB <sub>5</sub> | L-10 | ŌĒSC | | #### (Sorted by Pin Name) | PIN<br>NO. | PIN NAME | PIN<br>NO. | PIN NAME | PIN<br>NO. | PIN NAME | PIN<br>NO. | PIN NAME | | |------------|----------------------|------------|--------------------|------------|-------------------------|------------|---------------------------------|--| | L-5 | CB <sub>0</sub> | D-1 | DATA <sub>6</sub> | C-11 | DATA <sub>23</sub> | H-11 | LE <sub>OUT</sub> /<br>GENERATE | | | K-5 | CB <sub>1</sub> | E-2 | DATA <sub>7</sub> | B-11 | DATA <sub>24</sub> | K-11 | MULT ERROP | | | L-4 | CB <sub>2</sub> | E-1 | DATA <sub>8</sub> | A-10 | DATA <sub>25</sub> | B-3 | OE BYTE <sub>0</sub> | | | K-4 | CB <sub>3</sub> | F-1 | DATA <sub>9</sub> | B-9 | DATA <sub>26</sub> | K-1 | OE BYTE <sub>1</sub> | | | L-3 | CB <sub>4</sub> | G-2 | DATA <sub>10</sub> | A-9 | DATA <sub>27</sub> | G-10 | OE BYTE2 | | | K-3 | CB <sub>5</sub> | G-1 | DATA <sub>11</sub> | B-8 | DATA <sub>28</sub> | B-6 | OE BYTE <sub>3</sub> | | | L-2 | CB <sub>6</sub> | H-2 | DATA <sub>12</sub> | A-8 | DATA <sub>29</sub> | L-10 | ŌĒSC | | | K-2 | CB <sub>7</sub> | H-1 | DATA <sub>13</sub> | B-7 | DATA <sub>30</sub> | K-6 | SC <sub>0</sub> | | | A-6 | CODE ID <sub>0</sub> | J-2 | DATA <sub>14</sub> | A-7 | DATA <sub>31</sub> | L-6 | SC <sub>1</sub> | | | B-5 | CODE ID <sub>1</sub> | J-1 | DATA <sub>15</sub> | A-5 | DIAG MODE <sub>0</sub> | K-7 | SC <sub>2</sub> | | | H-10 | CORRECT | G-11 | DATA <sub>16</sub> | B-4 | DIAG MODE <sub>1</sub> | L-7 | SC <sub>3</sub> | | | A-3 | DATA <sub>0</sub> | F-11 | DATA <sub>17</sub> | J-10 | ERROR | K-8 | SC <sub>4</sub> | | | A-2 | DATA <sub>1</sub> | E-10 | DATA <sub>18</sub> | B-10 | GND | L-8 | SC <sub>5</sub> | | | B-1 | DATA <sub>2</sub> | E-11 | DATA <sub>19</sub> | F-2 | GND | K-9 | SC <sub>6</sub> | | | C-2 | DATA <sub>3</sub> | D-10 | DATA <sub>20</sub> | K-10 | GND | L-9 | SC <sub>7</sub> | | | C-1 | DATA <sub>4</sub> | D-11 | DATA <sub>21</sub> | J-11 | J-11 LE <sub>DIAG</sub> | | Vcc | | | D-2 | DATA <sub>5</sub> | C-10 | DATA <sub>22</sub> | A-4 | LEIN | F-10 | V <sub>CC</sub> | | #### LOGIC SYMBOL LS003250 Die Size: 0.174" x 0.176" Gate Count: 1670 #### Package Information | Parameter | PGA | LCC | PLCC | Unit | |-------------------|-----|-----|------|------| | $\theta_{\sf JA}$ | 34 | 31 | 35 | °C/W | | $\theta_{\rm JC}$ | - | 6 | N/A | °C/W | #### 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 Am29C660 CMOS Cascadable 32-Bit Error Detection and Correction Circuit | Valid C | ombinations | |-----------|------------------------------| | AM29C660 | | | AM29C660A | GC, GCB, GE,<br>JC, JCB, LC, | | AM29C660B | LCB, LE, XC | | AM29C660C | | #### 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 combinations, and to obtain additional data on AMD's standard military grade products. #### MILITARY ORDERING INFORMATION #### **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) is formed by a combination of: a. Device Number - b. Speed Option (if applicable) - c. Device Class - d. Package Type - e. Lead Finish | Valid Com | binations | |-----------|------------| | AM29C660 | | | AM29C660A | /BUA, /BZC | | AM29C660B | 760A, 762C | | AM29C660C | | #### **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 #### CB<sub>0-7</sub> Check Bits (Inputs) These eight check bit lines are used to input bits for error detection. They are also used to input syndrome bits for error correction in the 64-bit configuration. #### CODE ID<sub>0. 1</sub> Code Identification (Inputs) These two code identification inputs identify the size of the total data word to be processed. The two allowable data word sizes are 32 and 64 bits and their respective modified Hamming Codes are designated 32/39 and 64/72. The CODE ID inputs are also used to instruct the EDC that the CODE ID<sub>0, 1</sub>, DIAG MODE<sub>0, 1</sub>, and CORRECT signals are to be taken from the Diagnostic Latch, rather than from the input control lines (Reference Table 1). #### CORRECT Correct (Input; Active HIGH) This signal allows the correction network to correct any single-bit error in the Data Input Latch before putting it into the Data Output Latch by complementing the bit-in-error. When the signal is LOW, the EDC routes data directly from the Data Input Latch to the Data Output Latch without correction. #### DATA<sub>0-31</sub> Data (Inputs/Outputs; Three-State) These bidirectional data lines provide input to the Data Input Latch and Diagnostic Latch, and receive output from the Data Output Latch. DATA $_0$ is the least significant bit and DATA $_3$ 1 is the most significant bit. ## DIAG MODE<sub>0, 1</sub> Diagnostic Mode Select (Inputs; Active HIGH) These two lines control the initialization and diagnostic operation of the EDC circuit (Reference Table 2). #### ERROR Error Detection Flag (Output; Active LOW) When the EDC is in the Detect or Detect/Correct Mode, this output goes LOW if one or more syndrome bits are nonzero, indicating one or more data and/or check bits are in error. If all syndrome bits are zero, there are no errors detected and the output will be HIGH. In the Generate Mode, ERROR is forced HIGH. #### GND (3) 0-V Power Supply These pins are the 0-V power supply to the EDC circuit. All grounds must be connected during device operation. #### LEDIAG Diagnostic Latch Enable (Input) This is the latch enable for the Diagnostic Latch. When HIGH, the Diagnostic Latch follows the 32-bit data on the input lines. When LOW, the outputs of the Diagnostic Latch are latched to their previous states. The Diagnostic Latch holds diagnostic check bits and internal control signals for CODE ID<sub>0, 1</sub>, DIAG MODE<sub>0, 1</sub>, and CORRECT. #### LEIN Latch Enable - Data Input Latch (Input) This input controls latching of the input data. When HIGH, the Data Input Latch and Check Bit Input Latch follow the input data and input check bits, respectively. When LOW, the Data Input Latch and Check Bit Input Latch are latched to their previous states. #### LEOUT/GENERATE Latch Enable — Data Output Latch (Input)/Generate Check Bits (Input; Active LOW) # This is a multifunction pin. When it is LOW, it operates in the Check Bit Generate Mode. In this mode, the device generates the check bits or partial check bits specific to the data in the Data Input Latch. The generated check bits are placed on the syndrome/check bit outputs. The Data Output Latch is latched to its previous state when this pin is LOW. When HIGH, the device is in the Detect or Detect/Correct Mode. In the Detect Mode, the device detects single and multiple errors, and generates syndrome bits specific to the data in the Data Input Latch and Check Bit Input Latch. In the Detect/Correct Mode, single-bit errors are automatically corrected, with the corrected data placed at the inputs of the Data Output Latch. The syndrome result is placed on the syndrome/check bit outputs and indicates, in a coded form, the number of errors and the specific bit in error. When HIGH, the Data Output Latch follows the output of the Data Input Latch as modified by the correction logic network. In the Detect/Correct Mode, single-bit errors are corrected by the network before being loaded into the Data Output Latch. In the Detect Mode, the contents of the Data Input Latch are passed through the correction network unchanged into the Data Output Latch. The Data Output Latch is disabled with its contents unchanged if the EDC is in the Generate Mode. ## MULT ERROR Multiple Error Detection Flag (Output; Active LOW) When LOW in the Detect or Detect/Correct Mode, this output indicates that two or more bit errors have been detected. If HIGH, either one or no errors have been detected. In the Generate Mode, MULT ERROR is forced HIGH. ## OE BYTE<sub>0-3</sub> Output Enable Bytes 0-3 (Inputs; Active LOW) These lines control the three-state output buffers for each of the four bytes of the Data Output Latch. When LOW, they enable the output buffer of the Data Output Latch. When HIGH, they force the Data Output Latch buffer into the high-impedance state. Any number of bytes of the Data Output Latch is easily activated by separately selecting any of the four enable lines. ## OE<sub>SC</sub> Output Enable, Syndrome/Check Bits (Input; Active LOW) When in the LOW state, the three-state output lines SC $_{0-7}$ are enabled. When this input is HIGH, the syndrome/check bit outputs are in the high-impedance state. ## SC0-7 Syndrome/Check Bits (Outputs; Three-State) These eight three-state outputs contain the check/partialcheck bits when the EDC is in the Generate Mode. They also contain the syndrome/partial-syndrome bits when the device is in the Detect or Detect/Correct Modes. V<sub>CC</sub> (2) + 5-V Positive Power Supply Voltage These pins are the positive + 5-V power supply to the EDC Circuit. All V<sub>CC</sub> pins must be connected during device operation. #### **FUNCTIONAL DESCRIPTION** #### **EDC Architecture** The Am29C660 EDC Circuit is a powerful 32-bit cascadable slice used for check bit generation, error detection, error correction, and diagnostics. As shown in the block diagram, the device consists of the following: - Data Input Latch - Check Bit Input Latch - · Check Bit Generation Logic - Syndrome Generation Logic - Error Detection Logic - Error Correction Logic - Data Output Latch and Output Buffers - Diagnostics Latch - Control Logic #### **Data Input Latch** The Latch Enable Input, $LE_{IN}$ , controls the loading of 32 bits of data into the Data Input Latch. Depending upon the control mode, the input data is either used for check bit generation or error detection/correction. #### Check Bit Input Latch Eight check bits are loaded under the control of LE<sub>IN</sub>. Check bits are used in the Error Detection and Error Detection/Correction Modes. #### Check Bit Generation Logic This block generates the appropriate check bits for the 32 bits of data in the Data Input Latch. The check bits are generated according to a modified Hamming Code. #### Syndrome Generation Logic In both the Error Detection and Error Detection/Correction Modes, this logic block compares the check bits read from the memory against a newly generated set of check bits produced for the data read in from the memory. If both sets of check bits match, then there are no errors. If there is a mismatch, then one or more of the data and/or check bits is in error. The syndrome bits are produced by an Exclusive-OR of the two sets of check bits. If the two sets of check bits are identical (meaning there are no errors), the syndrome bits will be all zeros. If there is a single-bit error, the syndrome bits can be decoded to determine the bit-in-error. #### **Error Detection Logic** This logic block decodes the syndrome bits generated by the Syndrome Generation Logic. If there are no errors in either the input data or check bits, the ERROR and MULT ERROR outputs remain HIGH. If one or more errors are detected, ERROR goes LOW. If two or more errors are detected, both ERROR and MULT ERROR go LOW. #### **Error Correction Logic** For single-bit errors, the Error Correction Logic corrects (by complementing) the single data bit in error. This corrected data is loaded into the Data Output Latch, which can then be read onto the bidirectional data lines. If the single-bit error is one of the check bits, the correction logic does not place corrected check bits on the syndrome/check bit outputs. If the corrected check bits are needed, the EDC must be switched to the Generate Mode. #### **Data Output Latch and Output Buffers** The Data Output Latch is used for storing the result of an error correction operation. The latch is loaded from the correction logic under control of the Data Output Latch Enable, LE<sub>OUT</sub>/GENERATE. The Data Output Latch may also be directly loaded from the Data Input Latch while in the Pass-Thru Mode. Four data bytes in the Data Output Latch may be enabled independently (by $\overline{\text{OE}}$ BYTE<sub>0-3</sub>) for reading onto the bidirectional data bus. This feature facilitates byte operations. #### **Diagnostics Latch** This is a 32-bit latch loadable from the bidirectional data lines under the control of the Diagnostic Latch Enable, LE<sub>DIAG</sub>. The Diagnostic Latch contains check bit information in one byte and control information in the other bytes. The Diagnostic Latch is used for driving the device when in the Internal Control Mode, or for supplying check bits when in one of the Diagnostic Modes. #### **Control Logic** The Control Logic specifies the mode in which the EDC is operating. Normally, the control logic is driven by the external control inputs. However, in the Internal Control Mode, the control signals are taken from the Diagnostic Latch. Since $LE_{OUT}$ and $\overline{\text{GENERATE}}$ are controlled by the same pin, the latching action (LE\_{OUT} from HIGH to LOW) of the Data Output Latch causes the EDC to go into the Generate Mode. #### **Detailed Operational Description** The Am29C660 contains the logic necessary to generate check bits on a 32-bit data field according to a modified Hamming Code. Operating on data read from memory, the EDC will correct any single-bit error, and will detect all double-and some triple-bit errors. The Am29C660 may be configured to operate on 32-bit data words (with 7 check bits) and 64-bit data words (with 8 check bits). In either configuration, the device makes the error syndrome bits available on separate outputs for error logging. #### Code and Byte Specification The EDC Circuit may be configured in several different ways, and operates differently in each configuration. It is necessary to indicate to the device what size data word is involved and which bytes of the data word it is processing. This is done with the input lines CODE ID<sub>0, 1</sub> as shown in Table 1. The two modified Hamming codes referred to in Table 1 are: - 1. 32/39 Code: 32 data bits, 7 check bits (39 bits in total) - 2. 64/72 Code: 64 data bits, 8 check bits (72 bits in total) TABLE 1. CODE ID DECODE | CODE ID <sub>1</sub> | CODE ID <sub>0</sub> | Hamming Code and Slice Selected | |----------------------|----------------------|----------------------------------------| | 0 | 0 | Code 32/39, 32-Bit Data Word | | 0 | 1 | Internal Control Mode | | 1 | 0 | Code 64/72, Lower 32-Bit Slice (0-31) | | 1 | 1 | Code 64/72, Upper 32-Bit Slice (32-63) | #### Control Mode Selection There are nine operating modes of the Am29C660. Eight of these modes are selected as shown in Tables 2 and 3. Table 2 is the Diagnostic Mode Control Decode Table, and Table 3 is the Mode Control Decode Table. The Diagnostic Mode pins, DIAG MODE<sub>0</sub>, 1, define the five basic areas of operation. GENERATE and CORRECT further divide the operations into eight functions. The ninth mode is the Internal Control Mode which is selected by the CODE ID inputs as shown in Table 1. TABLE 2. DIAGNOSTIC MODE CONTROL DECODE | DIAG MODE <sub>1</sub> | DIAG MODE <sub>0</sub> | CORRECT | Diagnostic Mode Selected | |------------------------|------------------------|---------|-----------------------------------------------------------| | 0 | 0 | × | Normal EDC Function Mode or Non-Diagnostic Mode | | 0 | 1 | × | Diagnostic Generate Mode | | 1 | 0 | х | Diagnostic Detect Mode and Diagnostic Detect/Correct Mode | | 1 | 1 | 1 | Initialize Mode | | 1 | 1 | 0 | Pass-Thru Mode | TABLE 3. MODE CONTROL DECODE | | | | | | | I | | |------------------------------|-----------|---------------------|-----------------------------|-----------|---------------------------------------------------------------|---------------------------------------------------|-----------------| | Operating<br>Mode | DIAG MODE | | LE <sub>OUT</sub> /GENERATE | CORRECT | Contents of Data Output Latch | $SC_{0-7}$ and $\overline{OE}_{SC} = LOW$ | ERROR and | | Mode | <u> </u> | | EE0017 GENERATE | COTTILECT | Data Output Laten | | 111021 21111011 | | Generate | 0 | 0<br>0 | 0 | × | * | Check bits generated from Data Input Latch | _ | | Detect | 0 | 0 | 1 | 0 | Data Input Latch Generated from Data Input/Check Bit Latches | | Valid | | Detect/Correct | 0 | 0<br>1 | 1 | 1 | Data Input Latch<br>with single bit error<br>detected | Generated From Data<br>Input/Check Bit<br>Latches | Valid | | Pass-Thru | 1 | 1 | 1 or ↓ | 0 | Data Input latch | Check Bit Latch | HIGH | | Diagnostic<br>Generate | 0 | 1 | 0 | × | _ | Check bits from<br>Diagnostic Latch | _ | | Diagnostic<br>Detect | 1 | 0 | 1 | 0 | Data Input latch | Data Input check bits from Diagnostic Latch | Valid | | Diagnostic<br>Detect/Correct | 1 | 0 | 1 | 1 | Data Input Latch<br>with single-bit error<br>detected | Data Input check bits from Diagnostic Latch | Valid | | Initialize | 1 | 1 | 1 or ↓ | 1 | Data Input Latch<br>set to all "0"s | Check bits generated from Data Input Latch | _ | | Internal Control | СО | DE ID <sub>0,</sub> | 1 = 10 Control Signa | | D <sub>0, 1</sub> DIAG MODE <sub>0, 1</sub> | and CORRECT are ta | ken from the | In the Generate Mode, data is read into the EDC circuit and the check bits are generated. The same data is written to the memory along with the check bits. Since the Data Output Latch is not used in the Generate Mode, LE<sub>OUT</sub> being LOW (since it is tied to Generate) does not affect the writing of check bits. The Generate Mode is used to display the check bits on the $SC_{0-7}$ outputs. The Error Detect Mode provides an indication of an error or multiple errors on the $\overline{ERROR}$ and $\overline{MULT}$ $\overline{ERROR}$ outputs. Single-bit errors are not corrected in this mode. The syndrome bits are provided on the $SC_{0-7}$ outputs. In the Diagnostic Detect Mode, the syndrome bits are generated by comparing the internally generated check bits from the Data Input Latch with check bits stored in the Diagnostic Latch (as opposed to those in the Check Bit Latch). The Detect/Correct Mode is similar to the Detect Mode except that single-bit errors will be corrected (by complementing) and made available as input to the Data Output Latch. In the Diagnostic Detect/Correct Mode, single-bit errors will be corrected as determined by the syndrome bits, which are in turn generated from the check bits corresponding to the data in the Data Input Latch and the check bits in the Diagnostic Latch. In the Initialize Mode check bits are generated for all zero data bits. The Data Input Latch is held to a logic zero and is made available as input to the Data Output Latch. In the Internal Control Mode, the control signals CODE $ID_{0,-1}$ , DIAG MODE<sub>0,-1</sub>, and CORRECT are taken from the Diagnostic Latch and their respective control inputs are disregarded. #### Check and Syndrome Bits The Am29C660 provides either check or syndrome bits on the three-state outputs $SC_{0-7}$ . Check bits are generated from the Data Input Bits. Syndrome bits are an Exclusive-OR of the check bits generated from the data read from the memory and the check bits read from the memory with the stored data. Syndrome bits can be decoded to determine the single bit-inerror or to indicate a double- or triple-bit error. The check bits generated by the Am29C660 are designated as follows: - 32-bit configuration: CX, C0, C1, C2, C4, C8, C16 - 64-bit configuration: CX, C0, C1, C2, C4, C8, C16, C32 - Pin Name: SC<sub>0</sub>, SC<sub>1</sub>, SC<sub>2</sub>, SC<sub>3</sub>, SC<sub>4</sub>, SC<sub>5</sub>, SC<sub>6</sub>, SC<sub>7</sub>. The syndrome bits generated by the Am29C660 are designated as follows: - 32-bit configuration: SX, S0, S1, S2, S4, S8, S16 - 64-bit configuration: SX, S0, S1, S2, S4, S8, S16, S32 - Pin Name: SC<sub>0</sub>, SC<sub>1</sub>, SC<sub>2</sub>, SC<sub>3</sub>, SC<sub>4</sub>, SC<sub>5</sub>, SC<sub>6</sub>, SC<sub>7</sub>. #### 32-Bit Word Configuration #### **Data Field Format** The 32-bit format consists of 32 data bits and 7 check bits and is referred to as the 32/39 code. The format is shown in Figure 1. 10565A-005A TB001210 Figure 1. 32-Bit Data Word Format #### **Chip Configuration** A single Am29C660 EDC Circuit connected as shown in Figure 2 is all that is necessary to perform single-bit error correction and double-bit error detection on a 32-bit data field. In this configuration, only seven check bits are required. Therefore, CB $_7$ is a "don't care" and CODE ID $_{0,\ 1}=00$ . Figure 2. 32-Bit Configuration #### Generate Mode In this mode, check bits will be generated that correspond to the contents of the Data Input Latch. The check bits generated are placed on the outputs $SC_{0-6}$ . $SC_7$ is a logic "1" or HIGH Check bits are generated according to a modified Hamming Code. Details of the code for check bit generation are shown in Tables 4-1 and 4-2. Check bits are generated as either an XOR or XNOR of 16 of the 32 bits as indicated in the table. The XOR function results in an even parity check bit, the XNOR in an odd parity check bit. Figure 3 shows the data flow in the Generate Mode. TABLE 4-1. 32-BIT CONFIGURATION CHECK BIT ENCODING (Data Bits 0 - 15) | Generated<br>Check | | | Participating Data Bits | | | | | | | | | | | | | | | |--------------------|------------|---|-------------------------|---|---|---|---|---|---|---|---|----|----|----|----|----|----| | Bits | Parity | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | | CX | Even (XOR) | Х | | | | Х | | Х | Х | Х | Х | | Х | | | Х | | | C0 | Even (XOR) | X | Х | Х | | Х | | Х | | Х | | Х | | X | | | | | C1 | Odd (XNOR) | × | | | Х | Х | | | X | | Х | Х | | | Х | | Х | | C2 | Odd (XNOR) | X | Х | | | | Х | Х | X | | | | Х | X | Х | | | | C4 | Even (XOR) | Π | | Х | Х | Х | Х | Х | Х | | | | | | | Х | Х | | C8 | Even (XOR) | | | | | | | | | Х | Х | Х | Х | X | Х | Х | Х | | C16 | Even (XOR) | Х | Х | Х | Х | X | Х | Х | Х | | | | | | | | | TABLE 4-2. 32-BIT CONFIGURATION CHECK BIT ENCODING (Data Bits 16 – 31) | Generated<br>Check | | Participating Data Bits | | | | | | | | | | | | | |--------------------|------------|------------------------------------------------|---|--|--|--|--|--|--|--|--|--|--|--| | Bits | Parity | 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 3 | 1 | | | | | | | | | | | | | CX | Even (XOR) | | < | | | | | | | | | | | | | C0 | Even (XOR) | x x x x x x x x | | | | | | | | | | | | | | C1 | Odd (XNOR) | X $X$ $X$ $X$ $X$ $X$ $X$ | < | | | | | | | | | | | | | C2 | Odd (XNOR) | x x x x x x x x x | | | | | | | | | | | | | | C4 | Even (XOR) | x x x x x x x x x x x x x x x x x x x | < | | | | | | | | | | | | | C8 | Even (XOR) | X X X X X X X X X X X X X X X X X X X | < | | | | | | | | | | | | | C16 | Even (XOR) | X X X X X X X X X X X X X X X X X X X | < | | | | | | | | | | | | The check bit is generated as either an XOR or XNOR of the sixteen data bits noted by an "X" in the table. #### **Detect Mode** In this mode the device will compare the check bits generated from the contents of the Data Input Latch with the contents of the Check Bit Latch, and will detect all single- and double-bit errors and some triple-bit errors. If one or more errors are detected, ERROR goes LOW. If two or more errors are detected, MULT ERROR and ERROR go LOW. Both error indicators are HIGH if there is no error. The syndrome bits which are generated during error detection are available on the outputs $SC_{0-6}$ . $SC_7$ remains HIGH. The syndrome bits may be decoded to determine if a bit error was detected and for a single-bit error, which of the data or check bits is in error. Table 5 shows the syndrome bit decoding for the 32-bit data word configuration. If no error is detected, the syndrome bits will all be zeros (except $SC_7$ which is tied to a logical "1"). TABLE 5. SYNDROME BIT DECODING MATRIX | s | Syndrome<br>Bits | | S16<br>S8<br>S4 | 0<br>0<br>0 | 1<br>0<br>0 | 0<br>1<br>0 | 1<br>1<br>0 | 0<br>0<br>1 | 1<br>0<br>1 | 0<br>1<br>1 | 1 1 1 | | |----|------------------|----|-----------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------|----| | sx | S0 | S1 | S2 | | | | | | | • | | | | 0 | 0 | 0 | 0 | | * | C16 | C8 | Т | C4 | T | Т | 30 | | 0 | 0 | 0 | 1 | | C2 | Т | Т | 27 | Т | 5 | М | Т | | 0 | 0 | 1 | 0 | | C1 | Т | Т | 25 | Т | 3 | 15 | Т | | 0 | 0 | 1 | 1 | | Т | М | 13 | Т | 23 | Т | Т | М | | 0 | 1 | 0 | 0 | | C0 | Т | Т | 24 | Т | 2 | М | Т | | 0 | 1 | 0 | 1 | | Т | 1 | 12 | Т | 22 | Т | Т | М | | 0 | 1 | 1 | 0 | | Т | М | 10 | Т | 20 | T | Т | М | | 0 | 1 | 1 | 1 | | 16 | Т | Т | М | Т | М | М | Т | | 1 | 0 | 0 | 0 | | СХ | Τ | Т | М | Т | М | 14 | Т | | 1 | 0 | 0 | 1 | | Т | М | 11 | Т | 21 | Т | Т | М | | 1 | 0 | 1 | 0 | | ۲ | М | 9 | Т | 19 | Т | Т | 31 | | 1 | 0 | 1 | 1 | | М | Т | Т | 29 | Т | 7 | М | Т | | 1 | 1 | 0 | 0 | | Т | М | 8 | Т | 18 | Т | Т | М | | 1 | 1 | 0 | 1 | | 17 | Т | Т | 28 | Т | 6 | М | Т | | 1 | 1 | 1 | 0 | | М | Т | Т | 26 | Т | 4 | М | Т | | 1 | 1 | 1 | 1 | | Т | 0 | М | Т | М | Т | Т | М | <sup>\* =</sup> No errors detected Number = The bit number of the single bit-in-error T = Two errors detected M = More than two errors detected #### Detect/Correct Mode In this mode, the EDC functions the same way as in the Detect Mode except that the correction network is enabled to correct, by complementing, any single-bit error of the Data Input Latch before placing it on the inputs of the Data Output Latch (see Figure 4). If a multiple error is detected, the output of the correction network is undefined. If a single-bit error occurs to a check bit there is no automatic correction. If a check bit correction is desired, it can be done by placing the device in the Generate Mode to produce the correct check bit sequence for the data in the Data Input Latch. #### Pass-Thru Mode In this mode, the unmodified contents of the Data Input Latch are placed on the inputs of the Data Output Latch, and the contents of the Check Bit Latch are placed on the outputs $SC_{0-6}$ (SC<sub>7</sub> is a logical ''1''). ERROR and MULT ERROR are forced HIGH in this mode (inactive). #### Diagnostic Generate Mode This is one of the three special Diagnostic Modes selected by the control inputs DIAG MODE0, $_{\rm 1}$ . This mode is similar to the normal Generate Mode except that the check bits are not generated from the contents of the Data Input Latch. They are instead taken directly from the contents of the Diagnostic Latch. Table 6 shows the Diagnostic Latch coding format. Figures 5 and 6 illustrate the flow of data during the two diagnostic modes. TABLE 6. 32-BIT DIAGNOSTIC LATCH CODING FORMAT | Data Bit | Internal Function | |----------|-------------------------| | 0 | Diagnostic Check Bit X | | 1 | Diagnostic Check Bit 0 | | 2 | Diagnostic Check Bit 1 | | 3 | Diagnostic Check Bit 2 | | 4 | Diagnostic Check Bit 4 | | 5 | Diagnostic Check Bit 8 | | 6 | Diagnostic Check Bit 16 | | 7 | Don't Care | | 8 | CODE ID <sub>0</sub> | | 9 | CODE ID <sub>1</sub> | | 10 | DIAG MODE <sub>0</sub> | | 11 | DIAG MODE <sub>1</sub> | | 12 | CORRECT | | 13-31 | Don't Care | ## Diagnostic Detect, Diagnostic Detect/Correct Modes These two special Diagnostic Modes are also selected by the control inputs DIAG MODE<sub>0, 1</sub>. They are similar to the normal Detect and Detect/Correct Modes except that the check bits are taken from the Diagnostic Latch rather than from the Check Bit Input Latch. #### Initialize Mode In this mode, the inputs of the Data Output Latch are forced to all zeros. The syndrome bit outputs $\mathrm{SC}_{0-6}$ are generated to correspond to the all-zero data on the Data Output Latch. $\mathrm{SC}_7$ is tied HIGH. The ERROR and MULT ERROR outputs are forced HIGH in this mode. The Initialize Mode is useful after power-up when RAM contents are random. The EDC may be placed in this mode and its outputs written into all memory addresses under processor control. Am29C660 takes the CODE $\rm ID_{0,\ 1}$ , DIAG MODE<sub>0,\ 1</sub>, and CORRECT control signals from the Diagnostic Latch rather than from the external input lines. #### **Internal Control Mode** This mode is selected by the external control inputs CODE ID<sub>0.1</sub>. When in the Internal Control Mode, the Figure 3. Check Bit Generation Data Path Figure 4. Error Detection and Correction Data Path Figure 5. Diagnostic Check Bit Generation Data Path Figure 6. Diagnostic Detect and Correct Data Path #### 64-Bit Data Word Configuration #### **Data Field Format** The 64-bit format consists of 64 data bits and 8 check bits and is referred to as the 64/72 code. The format is shown in Figure 7. TB001220 Figure 7. 64-Bit Data Word Format #### **Chip Configuration** Two Am29C660 EDC Circuits connected as shown in Figure 8, provide all the necessary logic for all single-bit error detection/ correction, all double-bit error detection, and some triple-bit error detection on a 64-bit data field. In this configuration, eight check bits are required. CODE ID<sub>0, 1</sub> control signal inputs distinguish the upper 32 bits from the lower 32 bits as shown in Table 1. Figure 8. 64-Bit Configuration The valid syndrome bits and the $\overline{\text{ERROR}}$ and $\overline{\text{MULT ERROR}}$ output signals are taken from the upper EDC slice. The lower EDC slice has its $\overline{\text{OE}}_{SC}$ input tied to ground (logic "0") and its $SC_{0-7}$ outputs connected to the respective $CB_{0-7}$ inputs of the upper EDC slice. The 32 most significant data bits, DATA $_{32-63}$ , are connected to the data lines of the upper EDC slice. All the latch enables and control signals must be input to both the upper and the lower EDC slices. In the Detect/Correct Mode, the valid syndrome bits from the upper EDC slice must be read into the lower EDC slice via the check bit inputs of the lower EDC slice. They are selected by an internal MUX as inputs to the bit-in-error decoder (see Block Diagram). External buffering and output enabling of the check bit lines is required as shown in Figure 8. The $\overline{\text{OE}}_{\text{SC}}$ signal to the upper EDC slice can be used to control the enabling of the check bits to the lower EDC slice. The external check bits to the lower EDC slice are disabled. #### **Generate Mode** In this mode, check bits will be generated that correspond to the contents of the Data Input Latch. The generated check bits are placed on the $SC_{0-7}$ outputs of the upper EDC slice. Check bits are generated according to a modified Hamming Code. Details of the code for check bit generation are shown in Tables 7-1 through 7-4. Check bits are generated as either an XOR or XNOR of 32 of the 64 bits. The XOR function results in an even parity check bit, the XNOR in an odd parity check bit. TABLE 7-1. 64-BIT CONFIGURATION CHECK BIT ENCODING (Data Bits 0 - 15) | Generated | | Participating Data Bits | | | | | | | | | | | | | | | | |------------|------------|-------------------------|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----| | Check Bits | Parity | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | | CX | Even (XOR) | | Х | Х | Х | | Х | | | Х | Х | | Х | | | Х | | | C0 | Even (XOR) | X | Х | Х | | Х | | Х | | Х | | Х | | Х | | | | | C1 | Odd (XNOR) | × | | | Х | X | | | Х | | Х | Х | | | Х | | Х | | C2 | Odd (XNOR) | × | Х | | | | Х | Х | Х | | | | Х | Х | X. | | | | C4 | Even (XOR) | | | Х | Х | Х | Х | Х | Х | | | | | | | Х | Х | | C8 | Even (XOR) | | | | | | | | | Х | Х | Х | Х | Х | Х | Х | Х | | C16 | Even (XOR) | Х | Х | Х | Х | х | Х | Х | Х | | | | | | | | | | C32 | Even (XOR) | Х | Х | Х | Х | Х | Х | Х | Х | | | | | | | | | TABLE 7-2. 64-BIT CONFIGURATION CHECK BIT ENCODING (Data Bits 16-31) | Generated | | Participating Data Bits | | | | | | | | | | | | | | | | |------------|------------|-------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----| | Check Bits | Parity | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | | CX | Even (XOR) | | Х | Х | Х | | Х | | | Х | Х | | Х | | | Х | | | C0 | Even (XOR) | Х | Х | Х | | Х | | Х | | Х | | Х | | Х | | | | | C1 | Odd (XNOR) | X | | | Х | х | | | Х | | Х | Х | | | Х | | Х | | C2 | Odd (XNOR) | X | Х | | | | Х | Х | Х | | | | Х | Х | Х | | | | C4 | Even (XOR) | | | Х | Х | Х | Х | Х | Х | | | | | | | Х | Х | | C8 | Even (XOR) | | | | | | | | | X | Х | Х | Х | Х | Х | Х | X | | C16 | Even (XOR) | | | | | | | | | Х | Х | Х | Х | Х | Х | Х | Х | | C32 | Even (XOR) | | | | | | | | | Х | Х | Х | Х | Х | Х | Х | Х | TABLE 7-3. 64-BIT CONFIGURATION CHECK BIT ENCODING (Data Bits 32 - 47) | Generated | | Participating Data Bits | | | | | | | | | | | | | | | | |------------|------------|-------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----| | Check Bits | Parity | 32 | 33 | 34 | 35 | 36 | 37 | 38 | 39 | 40 | 41 | 42 | 43 | 44 | 45 | 46 | 47 | | CX | Even (XOR) | Х | | | | Х | | Х | Х | | | Х | | Х | Х | | Х | | C0 | Even (XOR) | Х | Х | Х | | Х | | Х | | Х | | Х | | х | | | | | C1 | Odd (XNOR) | Х | | | Х | Х | | | Х | | Х | Х | | | Х | | Х | | C2 | Odd (XNOR) | Х | Х | | | | Х | Х | Х | | | | Х | Х | Х | | | | C4 | Even (XOR) | | | Х | Х | Х | Х | Х | Х | | | | | | | Х | Х | | C8 | Even (XOR) | | | | | | | | | Х | Х | Х | X | Х | Х | Х | Х | | C16 | Even (XOR) | Х | Х | Х | Х | Х | Х | Х | Х | | | | | | | | | | C32 | Even (XOR) | | | | | | | | | Х | Х | Х | Х | Х | Х | Х | Х | TABLE 7-4. 64-BIT CONFIGURATION CHECK BIT ENCODING (Data Bits 48-63) | Generated | 1 | Participating Data Bits | | | | | | | | | | | | | | | | |------------|------------|-------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----| | Check Bits | Parity | 48 | 49 | 50 | 51 | 52 | 53 | 54 | 55 | 56 | 57 | 58 | 59 | 60 | 61 | 62 | 63 | | CX | Even (XOR) | Х | | | | Х | | Х | Х | | | Х | | Х | Х | | Х | | C0 | Even (XOR) | Х | Х | Х | | Х | | Х | | Х | | Х | | Х | | | | | C1 | Odd (XNOR) | X | | | X | Х | | | Х | | Х | Х | | | Х | | X | | C2 | Odd (XNOR) | Х | Х | | | | Х | Х | Х | | | | X | Х | Х | | | | C4 | Even (XOR) | | | Х | Х | Х | Х | Х | Х | | | | | | | Х | Х | | C8 | Even (XOR) | | | | | | | | | Х | Х | Х | Х | Х | X | Х | Х | | C16 | Even (XOR) | | | | | | | | | Х | Х | Х | Х | Х | Х | Х | Х | | C32 | Even (XOR) | Х | Х | Х | Х | Х | Х | Х | Х | | | | | | | | | The check bit is generated as either an XOR or XNOR of the 32 data bits noted by an "X" in the table. #### **Detect Mode** In this mode, the device will compare the check bits generated from the contents of the Data Input Latch with the contents of the Check Bit Latch. All single- and double-bit errors and some triple-bit errors will be detected. If one or more errors are detected, ERROR goes LOW. If two or more errors are detected, both ERROR and MULT ERROR will go LOW. Both error indicators will be HIGH if no errors are detected. The valid ERROR and MULT ERROR signals are from the upper EDC slice. The syndrome bits which are generated during error detection are available on the outputs $SC_{0-7}$ of the upper EDC slice. The syndrome bits may be decoded to determine if a bit error was detected, and for a single-bit error, which of the data or check bits is in error. Table 8 shows the syndrome bit decoding for the 64-bit data word configuration. If no error is detected, the syndrome bits will all be zeros. In the Detect Mode, the contents of the Data Input Latch are driven directly into the inputs of the Data Output Latch without correction. TABLE 8. 64-BIT SYNDROME BIT DECODING MATRIX | | Synd<br>Bi | rome<br>ts | | S32<br>S16<br>S8<br>S4 | 0<br>0<br>0 | 1<br>0<br>0 | 0<br>1<br>0 | 1<br>1<br>0 | 0<br>0<br>1 | 1<br>0<br>1 | 0<br>1<br>1 | 1<br>1<br>1 | 0<br>0<br>0 | 1<br>0<br>0 | 0<br>1<br>0 | 1<br>1<br>0 | 0<br>0<br>1 | 1<br>0<br>1 | 0<br>1<br>1 | 1<br>1<br>1 | |----|------------|------------|----|------------------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------| | SX | S0 | S1 | S2 | ٠. | | | | | | | | | | · | , | · | | , | | | | 0 | 0 | 0 | 0 | | * | C32 | C16 | Т | C8 | Т | Т | М | C4 | Т | Т | М | Т | 46 | 62 | Т | | 0 | 0 | 0 | 1 | | C2 | Т | Т | М | Т | 43 | 59 | Т | Т | 53 | 37 | Т | М | Т | Т | М | | 0 | 0 | 1 | 0 | | C1 | Т | Т | М | Т | 41 | 57 | T | Т | 51 | 35 | Т | 15 | _ | Т | 31 | | 0 | 0 | 1 | 1 | | Т | М | М | Т | 13 | Т | T | 29 | 23 | Т | Т | 7 | Т | Δ | Δ | Т | | 0 | 1 | 0 | 0 | | CO | Т | Т | М | Т | 40 | 56 | Т | Т | 50 | 34 | Т | М | ۲ | Τ | М | | 0 | 1 | 0 | 1 | | Т | 49 | 33 | Т | 12 | Т | Т | 28 | 22 | ۲ | Τ | 6 | Т | М | М | Т | | 0 | 1 | 1 | 0 | | Т | М | М | Т | 10 | Т | Т | 26 | 20 | ۲ | Т | 4 | Т | М | М | Т | | 0 | . 1 | 1 | 1 | | 16 | Т | Т | 0 | Т | М | М | Т | Т | Μ | М | Т | М | Т | Т | М | | 1 | 0 | 0 | 0 | | СХ | Т | Т | М | Т | М | М | Т | Т | М | М | Т | 14 | Т | Т | 30 | | 1 | 0 | 0 | 1 | | Т | М | М | ۲ | 11 | Т | Т | 27 | 21 | Т | Т | 5 | Т | М | М | Т | | 1 | 0 | 1 | 0 | | Т | М | М | Т | 9 | Т | Т | 25 | 19 | Т | Т | 3 | Т | 47 | 63 | Т | | 1 | 0 | 1 | 1 | | М | Т | Т | М | Т | 45 | 61 | Т | Т | 55 | 39 | Т | М | Т | Т | М | | 1 | 1 | 0 | 0 | | Т | М | М | Т | 8 | Т | Т | 24 | 18 | Т | T | 2 | Т | М | М | Т | | 1 | 1 | 0 | 1 | | 17 | Т | Т | 1 | Т | 44 | 60 | Т | T | 54 | 38 | Т | М | Т | Т | М | | 1 | 1 | 1 | 0 | | М | Т | Т | М | Т | 42 | 58 | Т | Т | 52 | 36 | Т | М | Т | Т | М | | 1 | 1 | 1 | 1 | | Т | 48 | 32 | Т | М | Т | Т | М | М | Т | Т | М | Т | М | М | Т | <sup>\* =</sup> No errors detected Number = The bit number of the single bit-in-error M = More than two errors detected T = Two errors detected #### **Detect/Correct Mode** In this mode, the EDC functions the same way as in the Detect Mode except that the correction network is enabled to correct, by complementing, any single-bit error in the Data Input Latch before placing the data on the inputs of the Data Output Latch. If a multiple error is detected, the output of the correction network is undefined. If a single-bit error occurs to a check bit, there is no automatic correction. If a check bit correction is desired, it can be done by placing the device in the Generate Mode to produce the correct check bit sequence for the data in the Data Input Latch. For data correction, both the upper EDC slice and the lower EDC slice require access to the syndrome bits $SC_{0-7}$ of the upper EDC slice. The upper EDC slice has access to these syndrome bits through an internal data path. The syndrome bits must be read through the $CB_{0-7}$ inputs for the lower EDC slice as shown in Figure 8. In the Detect/Correct Mode, the valid SC<sub>0-7</sub> outputs of the upper EDC slice must be enabled so that they are available for reading in through the CB<sub>0-7</sub> inputs of the lower EDC slice. #### Pass-Thru Mode In this mode, the unmodified contents of the Data Input Latch are placed on the inputs of the Data Output Latch and the contents of the Check Bit Latch are placed on the outputs $SC_{0-7}$ of the upper EDC slice. $\overline{\text{ERROR}}$ and $\overline{\text{MULT ERROR}}$ are forced HIGH in this mode (inactive). #### Diagnostic Generate Mode This is one of the three special Diagnostic Modes selected by the control inputs DIAG MODE<sub>0</sub>, 1. This mode is similar to the normal Generate Mode except that the check bits are not generated from the contents of the Data Input Latch. They are instead taken directly from the contents of the Diagnostic Latch. Table 9 shows the Diagnostic Latch coding format. TABLE 9. 64-BIT DIAGNOSTIC LATCH CODING FORMAT | Data Bit | Internal Function | |----------|---------------------------------------------| | | | | 0 | Diagnostic Check Bit X | | 1 | Diagnostic Check Bit 0 | | 2 | Diagnostic Check Bit 1 | | 3 | Diagnostic Check Bit 2 | | 4 | Diagnostic Check Bit 4 | | 5 | Diagnostic Check Bit 8 | | 6 | Diagnostic Check Bit 16 | | 7 | Diagnostic Check Bit 32 | | 8 | CODE ID <sub>0</sub> , Lower 32-Bit Slice | | 9 | CODE ID <sub>1</sub> , Lower 32-Bit Slice | | 10 | DIAG MODE <sub>0</sub> , Lower 32-Bit Slice | | 11 | DIAG MODE <sub>1</sub> , Lower 32-Bit Slice | | 12 | CORRECT, Lower 32-Bit Slice | | 13-31 | Don't Care | | 32-39 | Don't Care | | 40 | CODE ID <sub>0</sub> , Upper 32-Bit Slice | | 41 | CODE ID <sub>1</sub> , Upper 32-Bit Slice | | 42 | DIAG MODE <sub>0</sub> , Upper 32-Bit Slice | | 43 | DIAG MODE <sub>1</sub> , Upper 32-Bit Slice | | 44 | CORRECT, Upper 32-Bit Slice | | 45-63 | Don't Care | ### Diagnostic Detect, Diagnostic Detect/Correct Modes These two special Diagnostic Modes are also selected by the control inputs DIAG MODE0, 1. These modes are similar to the normal Detect and Detect/Correct Modes except that the check bits are taken from the Diagnostic Latch, rather than from the Check Bit Input Latch. #### Initialize Mode In this mode the inputs of the Data Output Latch are forced to all zeros. The syndrome outputs $SC_{0-7}$ are generated to correspond to the all-zero data on the Data Output Latch. The ERROR and MULT ERROR outputs are forced HIGH in this mode. The Initialize Mode is useful after power-up when RAM contents are random. The EDC may be placed in this mode in order to write its outputs into all memory addresses under processor control. #### Internal Control Mode This mode is selected by the external control inputs CODE ${\rm ID_{0,\ 1}}$ . When in the Internal Control Mode, the Am29C660 takes the CODE ${\rm ID_{0,\ 1}}$ , DIAG MODE<sub>0,\ 1</sub>, and CORRECT control signals from the Diagnostic Latch rather than from the external input lines. TABLE 10. KEY AC CALCULATIONS FOR THE 64-BIT CONFIGURATION | | 64-Bit<br>Propagation Delay | Component Delays from Am29C660 | |----------------------|-----------------------------|--------------------------------------------------------------------------------------------| | From | То | AC Specifications | | DATA <sub>0-31</sub> | Check Bit Outputs | (Data to SC, CODE ID 10) + (Check Bit to SC, CODE ID 11) | | DATA <sub>0-31</sub> | Corrected Data Outputs | (Data to SC, CODE ID 10) + (Check Bit to SC, CODE ID 11) + (Check Bit to Data, CODE ID 10) | | DATA <sub>0-31</sub> | Syndrome Outputs | (Data to SC, CODE ID 10) + (Check Bit to SC, CODE ID 11) | | DATA <sub>0-31</sub> | ERROR for 64 Bits | (Data to SC, CODE ID 10) + (Check Bit to ERROR, CODE ID 11) | | DATA <sub>0-31</sub> | MULT ERROR for 64 Bits | (Data to SC, CODE ID 10) + (Check Bit to MULT ERROR, CODE ID 11) | #### **APPLICATIONS** #### System Design Considerations To obtain optimum performance and maximum design flexibility, AMD's Dynamic Memory Management System has been divided into functional building blocks. For 32-bit error detecting/correcting systems, these building blocks include the Am29660 EDC Circuit, the Am2969 Memory Timing Controller with EDC Timing Control (or PALs®), the Am29368 1-MBit DRAM Controller/Driver, and the Am2971A 100-MHz Enhanced Programmable Event Generator or delay lines as the timing reference. Together these chips can perform traditional EDC, Flow-Thru or Fly-By, or AMD's Scrubbing EDC cycle. #### **High-Performance Parallel Operation** For maximum memory system performance, the EDC should be used in the Check-Only (or Fly-By) configuration shown in Figure 9. With this configuration, the memory system operates as fast with EDC as it would without. On reads from memory, data is read out from the DRAMs directly to the data bus (same as in a non-EDC system). At the same time, the data is read into the EDC to check for errors. If an error exists, the EDC's error flags (ERROR, MULT ERROR) are used to interrupt the CPU and/or to stretch the memory cycle. If no error is detected, no slowdown is required. If an error is detected, the EDC generates corrected data for the processor. At the designer's option, the correct data may be written back into memory; error logging and diagnostic routines may also be run under processor control. The Check-Only configuration allows data reads to proceed as fast with EDC as without. Only if an error is detected is there any slowdown, but even if the memory system had an error every hour this would mean only one error every 3 – 4 billion memory cycles. Therefore, even with a very high error rate, EDC in a Check-Only configuration has essentially zero impact on memory system speed. On writes to memory, check bits must be generated before the full memory word can be written into memory. Using the Am29C983 Multiple Bus Exchange allows the data word to be buffered on the memory board while check bits are generated. This makes the check bit generate time transparent to the processor. #### EDC in the Data Path The simplest configuration for the Am29C660 is to have the EDC circuit directly in the data path, as shown in Figure 10 (Flow-Thru configuration). In this configuration, data read from memory is always corrected prior to putting the data on the data bus. The advantages are simpler operation and no need for mid-cycle interrupts. The disadvantage is that memory system speed is slowed by the amount of time it takes for error correction on every cycle. Usually the Flow-Thru configuration will be used with MOS microprocessors which have ample memory timing budgets. Most high-performance processors will use the high-performance parallel configuration shown in Figure 9 (Fly-By). #### **Memory Scrubbing During Refresh** Scrubbing is an error correction technique that examines the entire memory during system refresh cycles, thus causing little or no impact on performance yet providing high data reliability since errors cannot accumulate. Single-bit errors are by far the most common in a dynamic memory system, and are always correctable by the EDC. Double-bit errors occur far less frequently than single-bit errors (50-to-1 or 100-to-1) and are always detected by the EDC, but not corrected. In a memory system, soft errors occur only one at a time. A double-bit error in a data word occurs when a single soft error is left uncorrected and is followed by another error in the data word within hours, days, or weeks after the first occurence. Scrubbing the memory periodically avoids almost all double-bit errors. In the scrubbing operation, every data word in memory is periodically checked by the EDC for single-bit errors. If one is found, it is corrected and the correct data word is written back into memory. Errors are not allowed to accumulate, and thus most double-bit errors are avoided. The scrubbing operation is generally done as a background routine when the memory is not being used by the processor. If memory is scrubbed frequently, errors that are detected and corrected during processor accesses need not be immediately written back into memory. Instead, the error will be corrected in memory during scrubbing. This reduces the time delay involved in a processor access of an incorrect memory word. On each refresh-with-scrub cycle, one memory location is read, checked for errors, and if necessary, corrected before being written back into memory. For a sixteen-megaword memory (2<sup>24</sup> locations) with one refresh every 16 microseconds, the AMD Memory Management chip set will scrub the entire memory of single-bit errors every four minutes. If multiple-bit errors are encountered during a scrub cycle, WE is suppressed. With the occurance of an error, a read/modify/write (R/M/W) cycle is performed. The duration of a R/M/W cycle is typically longer than a normal read or write cycle. During refresh operations, a row in each bank is accessed by energizing the RAS line. This refreshes all the locations in that row. If an error is detected, a write operation is performed in that bank at the location of the error. This is accomplished by energizing the CAS line in that bank for that location. The entire checking operation is performed within the refresh cycle. A wait state may need to be issued to extend the cycle should an error be discovered. However, the system reliability will be increased because soft errors will not be able to accumulate in areas of memory that are not frequently accessed. When performing refresh without scrubbing, all four $\overline{\text{RAS}}$ lines go LOW but the $\overline{\text{CAS}}$ lines remain HIGH or inactive. A refresh with scrubbing will activate all four $\overline{\text{RAS}}$ lines as before and a single $\overline{\text{CAS}}$ line. Errors that are detected during scrubbing cycles do not cause interrupts or bus-error ( $\overline{\text{BERR}}$ ) signal assertions. Figure 11 shows a sixteen-megaword memory system with error detection and correction. Figure 9. Check-Only Configuration Figure 10. Correct-Always Configuration Figure 11. Sixteen-Megaword Memory System with EDC Figure 12. Device Decoupling — V<sub>CC</sub> and Ground Pin Connections Note: $C_1 = 1.0~\mu F$ , $C_2 = 0.1~\mu F$ , $C_3 = 0.01~\mu F$ The $C_1$ , $C_2$ , $C_3$ capacitors should be used to shunt low- and high-frequency noise from V<sub>CC</sub>. Do not replace with one capacitor. Place capacitors as close to the device as possible. #### ABSOLUTE MAXIMUM RATINGS | Storage Temperature65 to +150°C Temperature (Case) | |----------------------------------------------------| | | | Under Bias55 to +125°C | | Supply Voltage to Ground Potential | | Continous0.5 to +7.0 V | | DC Voltage Applied to Outputs For | | HIGH Output State0.5 V to V <sub>CC</sub> Max. | | DC Input Voltage0.5 to +5.5 V | | DC Input Current30 mA to +5.0 mA | 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. #### **OPERATING RANGES** | A) 0 to +70°C | |-----------------------| | +4.75 to +5.25 V | | ommercial (E) Devices | | 55 to +125°C | | +4.5 to +5.5 V | | | Operating ranges define those limits between which the 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 | Te | st Conditions | (Note 1) | Min. | Max. | Unit | |---------------------|----------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|---------------------------|----------------------|------|------------| | V <sub>IH</sub> | Input HIGH Voltage | Guaranteed Input I<br>Voltage for all Input | | | 2.0 | | V | | V <sub>IL</sub> | Input LOW Voltage | Guaranteed Input I<br>Voltage for all Inpu | | y and the second | | 0.8 | ٧ | | l <sub>IH</sub> | Input HIGH Current | V <sub>CC</sub> = Max.,<br>V <sub>IN</sub> = V <sub>CC</sub> | | | | 5.0 | μΑ | | I <sub>IL</sub> | Input LOW Current | V <sub>CC</sub> = Max.,<br>V <sub>IN</sub> = GND | | | | -5.0 | μΑ | | | | | $I_{OH} = -300 \ \mu$ A | | V <sub>CC</sub> -0.2 | | | | VOH | Output HIGH Voltage | V <sub>CC</sub> = Min. | MIL & E-COM | L I <sub>OH</sub> = -8 mA | 2.4 | | l v | | | | THE MEDICAL PROPERTY OF THE PARTY PAR | 2.4 | 0.2 | | | | | VoL | Output LOW Voltage | V <sub>CC</sub> = Min. | $I_{OL} = 300 \mu A$ MIL & E-COM | L loi = 8 mA | | 0.5 | l v | | . 02 | | COM'L I <sub>OL</sub> = 15 mA V <sub>C</sub> = Max. | | | | 0.5 | i . | | lo- | Off-State (High-Impedance) | | | | | -10 | | | loz | Output Current | VCC - Max. | | $V_O = V_{CC}$ (Max.) | | 10 | μΑ | | los | Output Short-Circuit Current | $V_{CC} = Min., V_O =$ | 0 V (Note 2) | | -30 | | m/ | | Icca | Quiescent Power<br>Supply Current<br>(CMOS Inputs) | $V_{CC} = Max.,$<br>$V_{CC} - 0.2 V \le V_{IN},$<br>$f_{OP} = 0$ | V <sub>IN</sub> ≤ 0.2 V | | | 5.0 | m/ | | ГССТ | Quiescent input Power Supply Current (per Input @ TTL HIGH) (Note 4) | V <sub>CC</sub> = Max.,<br>V <sub>IN</sub> = 3.4 V,<br>f <sub>OP</sub> = 0 | | | | 0.5 | mA<br>Inpi | | ICCD | Dynamic<br>Power Supply<br>Current | V <sub>CC</sub> = Max.,<br>V <sub>CC</sub> -0.2 V ≤ V <sub>IN</sub> ,<br>Outputs Open, | V <sub>IN</sub> ≤ 0.2 V | MIL &<br>E-COM'L | | 6.5 | mA<br>MH | | | Carron | OE = LOW | | COM'L | | 6 | 1 1 | | | | V <sub>CC</sub> = Max., f <sub>OP</sub> = Outputs open, OE | 10 MHz<br>= LOW | MIL &<br>E-COM'L | | 70 | | | lcc | Total Power | 50% Duty cycle<br>V <sub>CC</sub> -0.2 V ≤ V <sub>IN</sub> , V <sub>IN</sub> ≤ 0.2 V COM'L | | | | 65 | | | 'CC | Supply Current (Note 5) | V <sub>CC</sub> = Max., f <sub>OP</sub> = 10 MHz MIL &<br>Outputs open, OE = LOW E-COM'L | | | | 70 | m/ | | | | 50% Duty cycle<br>V <sub>IH</sub> = 3.4 V, V <sub>IL</sub> = | | 65 | | | | Notes: 1. For conditions shown as Min. or Max., use appropriate value specified under Operating Range for the applicable device type. 2. Not more than one output should be shorted at a time. Duration of the short-circuit test should not exceed one second. These input levels provide zero noise immunity and should only be static tested in a noise-free environment. Incr is derived by measuring the total current with all the inputs tied together at 3.4 V, subtracting out I<sub>CCQ</sub>, then dividing by the total number of inputs. = Operating frequency in Megahertz. #### SWITCHING CHARACTERISTICS over COMMERCIAL operating ranges (Notes 1 and 2) The following table specifies the guaranteed device performance over the Commercial operating range of $0^{\circ}$ C to $+70^{\circ}$ C (ambient), with $V_{CC}$ 4.75 to 5.25 V. All input switching is between 0 V and 3 V at 1 V/ns, and measurements are made at 1.5 V. All outputs have maximum DC load. All units are in nanoseconds (ns). | | Danamatan | Data Path Descript | ion | Am29 | C660 | Am29 | C660A | Am29 | C660B | Am29 | C660C | |-----|--------------------------------------------------------|-------------------------------------------------|------------------------------------|------|------|------|----------|------|-------|------|-------| | No. | Parameter<br>Symbol | From Input | To Output | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | | | | | SC <sub>0-7</sub> | | 37 | | 27 ( | 1 | 25 | | 18 | | 1 | t <sub>PD</sub> | DATA 0 - 31 (Note 3) | DATA <sub>0 - 31</sub><br>(Note 2) | | 49 | 35 | 36 | 1 | 30 | | 24 | | | | | ERROR | | 40 | 15 | 30 | 1 | 25 | | 16 | | | | | MULT ERROR | | 45 | 19 | ्रं ३३ ् | > | 27 | | 20 | | | | | SC <sub>0-7</sub> | | (22) | | 16 | | 14 | | 14 | | • | | CB <sub>0-7</sub> | DATA <sub>0-31</sub> | | 46 | | > 34 | | 30 | | 21 | | 2 | t <sub>PD</sub> | (CODE ID 00, 11) | ERROR | 1 | 26 | 7 | 19 | | 17 | | 13 | | | | | MULT ERROR | | 31, | 7 | 23 | | 20 | | 16 | | _ | | CB <sub>0-7</sub> | SC <sub>0</sub> - 7 | 1 | 22 | | 16 | | 16 | | 15 | | 3 | t <sub>PD</sub> | (CODE ID 10) | DATA <sub>0</sub> 2 <sub>31</sub> | Z | 30 | | 20 | | 18 | | 16 | | | | ۵ | SC <sub>0-7</sub> | ~ | 29 | | 21 | | 21 | | 18 | | 4 | t <sub>PD</sub> | GENERATE | ERROR | | 30 | | 25 | | 23 | | 9 | | | | | MULT ERROR | | 30 | | 25 | | 23 | | 11 | | 5 | t <sub>PD</sub> | CORRECT<br>(Not Internal Control Mode) | DATA <sub>0 - 31</sub> | | 31 | | 23 | | 23 | | 16 | | | | | SC <sub>0-7</sub> | | 23 | | 17 | | 17 | | 16 | | _ | | DIAG MODE <sub>0, 1</sub> | DATA <sub>0 - 31</sub> | | 35 | | 26 | | 26 | | 26 | | 6 | t <sub>PD</sub> | (Not Internal Control Mode) | ERROR | | 27 | | 20 | | 20 | | 11 | | | | | MULT ERROR | | 33 | | 24 | | 24 | | 20 | | | | | SC <sub>0 - 7</sub><br>(Note 6) | | 25 | | 18 | | 18 | | 18 | | 7 | t <sub>PD</sub> | CODE ID <sub>0, 1</sub> | DATA <sub>0-31</sub> | | 35 | | 26 | | 26 | | 23 | | | | ] | ERROR | | 29 | | 21 | | 21 | | 17 | | | | | MULT ERROR | | 35 | | 26 | | 26 | | 21 | | | | | SC <sub>0-7</sub> | | 37 | | 27 | | 27 | | 22 | | 8 | t <sub>PD</sub> | LEIN | DATA <sub>0 - 31</sub><br>(Note 2) | | 51 | | 38 | | 38 | | 28 | | | | (From Latched to Transparent) | ERROR | | 41 | | 30 | | 30 | | 19 | | | | | MULT ERROR | | 45 | | 33 | | 33 | | 22 | | 9 | t <sub>PD</sub> | LE <sub>OUT</sub> (From Latched to Transparent) | DATA <sub>0-31</sub> | | 17 | | 12 | | 12 | | 12 | | - | | I.E. | SC <sub>0 - 7</sub><br>(Note 6) | | 21 | | 15 | | 15 | | 15 | | 10 | LE <sub>DIAG</sub> 10 t <sub>PD</sub> (From Latched to | (From Latched to Transparent; | DATA <sub>0 - 31</sub> | | 38 | | 29 | | 29 | | 24 | | | | Not Internal Control Mode) | ERROR | | 26 | | 19 | | 19 | | 15 | | | | | MULT ERROR | | 30 | | 22 | | 22 | | 19 | #### SWITCHING CHARACTERISTICS over COMMERCIAL operating range (Cont'd.) | | Parameter | Data Path Description | | Am29C660 | | Am29C660A | | Am29C660B | | Am29C660C | | |-----|------------------------------------------------|------------------------------------------------|------------------------------------|----------|----------|-----------|------|-----------|------|-----------|------| | No. | Symbol | From Input | To Output | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | | | | | SC <sub>0 - 7</sub><br>(Note 6) | | 22 | | 16 | | 16 | | 16 | | 11 | t <sub>PD</sub> | Internal Control Mode:<br>LEDIAG | DATA <sub>0-31</sub> | | 42 | | 32 | | 32 | | 22 | | | | (From Latched to Transparent) | ERROR | | 26 | | 19 | | 19 | | 16 | | | | | MULT ERROR | | 33 | | 24 | 4 | 24 | | 18 | | | | | SC <sub>0-7</sub> | | 22 | | 16 | | 16 | | 16 | | 12 | t <sub>PD</sub> | Internal Control Mode:<br>DATA <sub>0-31</sub> | DATA <sub>0 – 31</sub><br>(Note 2) | | 42 | Á | 32 | | 32 | | 25 | | | | (Via Diagnostic Latch) | ERROR | | 27 | i i i | 20 | | 20 | | 13 | | | | | MULT ERROR | | 34 | Æ | 25 | | 25 | | 16 | | 13 | tSET | DATA <sub>0 – 31</sub> (Note 4) | | 6 🦪 | A. Y | 5 | | 4 | | 3 | | | 14 | tHOLD | DATA() = 31 (Note 4) | LE <sub>IN</sub> | 4 | <b>A</b> | 4 | | 4 | | 4 | | | 15 | t <sub>SET</sub> | CB <sub>0 - 7</sub> (Note 4) | LEIN | 5 | | 5 | | 4 | | .2 | | | 16 | <sup>t</sup> HOLD | OB0_7 (Note 4) | | 4 | À | 4 | | 4 | | 4 | | | 17 | tSET | DATA <sub>0-31</sub> (Notes 4 & 6) | | 30 | Ψ | 23 | | 19 | | 6 | | | 18 | <sup>t</sup> HOLD | DATA <sub>0</sub> _31 (Notes 4 & 6) | | ₩ò i | | 0 | | 0 | | 0 | | | 19 | tSET | CB <sub>0 - 7</sub> (Note 4) | | 20 | | 15 | | 15 | | 14 | | | 20 | <sup>t</sup> HOLD | (CODE ID 00, 11) | | 0 | | 0 | | 0 | | 0 | | | 21 | tSET | CB <sub>0-7</sub> | | 20 | | 15 | | 15 | | 8 | | | 22 | <sup>t</sup> HOLD | (CODE ID 10) (Note 4) | | 0 | | 0 | | 0 | | 0 | | | 23 | tSET | CORRECT (Note 4) | ľ | 16 | | 11 | | 11 | | 8 | | | 24 | <sup>t</sup> HOLD | CONTILOT (Note 4) | LE <sub>OUT</sub> | 0 | | 0 | | 0 | | 0 | | | 25 | tSET | DIAG MODE <sub>0, 1</sub> (Note 4) | | 23 | | 17 | | 17 | | 17 | | | 26 | tHOLD | DIAG MODE <sub>0, 1</sub> (Note 4) | | 0 | | 0 | | 0 | | 0 | | | 27 | tSET | CODE ID. (Note 1) | | 23 | | 17 | | 17 | | 10 | | | 28 | tHOLD | CODE ID <sub>0</sub> , t (Note 4) | | 0 | | 0 | | 0 | | 0 | | | 29 | tSET | LE <sub>IN</sub> (Notes 4 & 6) | | 31 | | 25 | | 20 | | 19 | | | 30 | <sup>t</sup> HOLD | LLIN (Notes 4 & 0) | | 0 | | 0 | | 0 | | 0 | | | 31 | tSET | DATA <sub>0-31</sub> (Notes 4 & 6) | LE <sub>DIAG</sub> | 6 | | 5 | | 4 | | 3 | | | 32 | <sup>t</sup> HOLD | DATA0_31 (Notes 4 & 6) | | 3 | | 3 | | 3 | | 3 | | | 33 | tEN | OF BYTEs a (Notes 5 % 6) | DATAs | | 27 | | 23 | | 23 | | 23 | | 34 | t <sub>DIS</sub> | OE BYTE <sub>0-3</sub> (Notes 5 & 6) | DATA <sub>0-31</sub> | | 23 | | 19 | | 19 | | 19 | | 35 | tEN | OF an (Notes 5 & 6) | 80 | | 28 | | 24 | | 24 | | 24 | | 36 | t <sub>DIS</sub> | OE <sub>SC</sub> (Notes 5 & 6) | SC <sub>0-7</sub> | | 24 | | 20 | | 20 | | 20 | | 37 | 7 tpw Minimum Pulse Width: LEIN, LEOUT, LEDIAG | | 12 | | 9 | | 9 | | 6 | | | Notes: 1. $C_L = 50$ pF. <sup>2.</sup> Certain parameters are combinational propagation delay calculations. <sup>3.</sup> Data In or LEIN to Correct Data Out measurement requires timing as shown in the Switching Waveforms. <sup>4.</sup> Setup and Hold times relative to Latch Enables (Latching up data). <sup>5.</sup> Output disable tests specified with $C_L = 5$ pF and measured to 0.5 V change of output voltage level. Testing is performed at $C_L = 50$ pF and correlated to $C_L = 5$ pF. <sup>6.</sup> Not production tested. Guaranteed by characterization. **SWITCHING CHARACTERISTICS** over **MILITARY** and **EXTENDED-COMMERCIAL** operating ranges (for APL Products, Group A, Subgroups 9, 10, 11 are tested unless otherwise noted) (Notes 1 and 2) The following table specifies the guaranteed device performance over the Military and Extended-Commercial operating ranges of $-55^{\circ}$ C to $+125^{\circ}$ C (case), with V<sub>CC</sub> 4.5 to 5.5 V and 4.75 to 5.25 V, respectively. All input switching is between 0 V and 3 V at 1 V/ns and measurements are made at 1.5 V. All outputs have maximum DC load. All units are in nanoseconds (ns). | | Parameter | Data Path Descript | Data Path Description Am29C | | 29C660 Am29 | | C660A | Am29C660B | | Am29C660 | | |-----|-------------------|-----------------------------------------------------------|----------------------------------|--------|-------------|-------------|-------|-----------|------|----------|------| | No. | Symbol | From Input | To Output | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | | | | | SC <sub>0-7</sub> | | 40 | | 30 | 1 | 28 | | 22 | | 1 | t <sub>PD</sub> | DATA 0 - 31 (Note 3) | DATA <sub>0-31</sub><br>(Note 2) | | 52 | £G. | 39 | 1/ | 33 | | 29 | | | | | ERROR | | 44 | K, | 33 | | 28 | | 21 | | | | | MULT ERROR | | 48 | A septiment | 36 | | 30 | | 24 | | | | | SC <sub>0-7</sub> | | 25 | | ે 19 | | 17 | | 17 | | 2 | | CB <sub>0-7</sub> | DATA <sub>0 - 31</sub> | 67 | 49 | Sh. A. | 37 | | 33 | | 23 | | 2 | t <sub>PD</sub> | (CODE ID 00, 11) | ERROR ( | Grand. | 29 | | 22 | | 20 | | 16 | | | | | MULT ERROR | 7 | -34 | | 26 | | 23 | | 18 | | 3 | • | CB <sub>0-7</sub> | sc <sub>0-7</sub> | | 25 | | 19 | | 19 | | 17 | | 3 | t <sub>PD</sub> | (CODE ID 10) | DATA <sub>0-31</sub> | JP* | 33 | | 23 | | 23 | | 18 | | | | | SC <sub>0-7</sub> | | 32 | | 24 | | 24 | | 20 | | 4 | t <sub>PD</sub> | GENERATE | ERROR | | 33 | | 28 | | 26 | | 10 | | | | | MULT ERROR | | 33 | | 28 | | 26 | | 12 | | 5 | t <sub>PD</sub> | CORRECT<br>(Not Internal Control Mode) | DATA <sub>0-31</sub> | | 34 | | 26 | | 26 | | 17 | | | | DIAG_MODE <sub>0</sub> , 1<br>(Not Internal Control Mode) | SC <sub>0-7</sub> | | 26 | | 20 | | 20 | | 18 | | | | | DATA <sub>0 - 31</sub> | | 38 | | 29 | | 29 | | 29 | | 6 | t <sub>PD</sub> | | ERROR | | 30 | | 23 | | 23 | | 12 | | | | | MULT ERROR | | 36 | | 27 | | 27 | | 23 | | | 7 t <sub>PD</sub> | SC <sub>0 - 7</sub> (Note 6) | | | 28 | | 21 | | 21 | | 21 | | 7 | | | DATA <sub>0-31</sub> | | 38 | | 29 | | 29 | | 26 | | | | | | 32 | | 24 | | 24 | | 20 | | | | | | MULT ERROR | | 38 | | 29 | | 29 | | 24 | | | | | SC <sub>0-7</sub> | | 40 | | 30 | | 30 | | 24 | | 8 | t <sub>PD</sub> | DATA <sub>0-3</sub> (Note 2) 54 | | 41 | | 41 | | 32 | | | | | | | (From Latched to Transparent) | ERROR | | 44 | | 33 | | 33 | | 21 | | | | | MULT ERROR | | 48 | | 36 | | 36 | | 25 | | 9 | t <sub>PD</sub> | LE <sub>OUT</sub> (From Latched to Transparent) | DATA <sub>0 - 31</sub> | | 20 | | 15 | | 15 | | 13 | | | | LE <sub>DIAG</sub> (From Latched to Transparent; | SC <sub>0 - 7</sub><br>(Note 6) | | 26 | | 18 | | 18 | | 18 | | 10 | t <sub>PD</sub> | | DATA <sub>0 - 31</sub> | | 42 | | 32 | | 32 | | 27 | | | | Not Internal Control Mode) | ERROR | | 29 | | 22 | | 22 | | 17 | | | | | MULT ERROR | | 33 | | 25 | | 25 | | 21 | ## SWITCHING CHARACTERISTICS over MILITARY and EXTENDED-COMMERCIAL operating ranges | | Parameter | Data Path Description | | Am29 | C660 | Am29 | C660A | A Am29C660B | | Am29C660C | | |-----|-------------------|------------------------------------------------|------------------------------------|------|----------|------|-------|-------------|------|-----------|------| | No. | Symbol | From Input | To Output | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | | | | | SC <sub>0 - 7</sub><br>(Note 6) | | 25 | | 19 | | 19 | | 19 | | 11 | t <sub>PD</sub> | Internal Control Mode: LEDIAG | DATA <sub>0 - 31</sub> | | 47 | | 35 | | 35 | | 25 | | | , <del>,</del> | (From Latched to Transparent) | ERROR | | 29 | | 22 | A | 22 | | 18 | | | | | MULT ERROR | | 36 | | 27 | Vill | 27 | | 21 | | | | | SC <sub>0-7</sub> | | 25 | | 19 | | 19 | | 18 | | 12 | t <sub>PD</sub> | Internal Control Mode:<br>DATA <sub>0-31</sub> | DATA <sub>0 - 31</sub><br>(Note 2) | | 47 | 4 | 35 | | 35 | | 29 | | | | (Via Diagnostic Latch) | ERROR | | 30 | pr- | 23 | (E) | 23 | | 14 | | | | | MULT ERROR | | 37 | | 28 | | 28 | | 18 | | 13 | t <sub>SET</sub> | DATA - (Note 4) | | 6 | D. Y | 5 | -GA | 4 | | 3 | | | 14† | <sup>t</sup> HOLD | DATA <sub>0-31</sub> (Note 4) | LE <sub>IN</sub> | 4 | Á | 4 | | 4 | | 4 | | | 15 | t <sub>SET</sub> | CB <sub>0 - 7</sub> (Note 4) | CEIN | 5 | | 5 | | 4 | | 2 | | | 16† | tHOLD | CB0_7 (Note 4) | | 4 | <b>A</b> | 4 | | 4 | | 4 | | | 17 | tSET | DATA - (Notes 4 8 6) | | 36 | | 27 | | 23 | | 7 | | | 18† | tHOLD | DATA <sub>0-31</sub> (Notes 4 & 6) | | 0 | | 0 | | 0 | | 0 | | | 19 | tSET | CB <sub>0-7</sub> (Note 4)<br>(CODE ID 00, 11) | <b>\$</b> | 24 | | 18 | | 18 | | 16 | | | 20† | tHOLD | | | 0 | | 0 | | 0 | | 0 | | | 21 | <sup>t</sup> SET | CB <sub>0-7</sub> | | 24 | | 18 | | 18 | | 10 | | | 22† | <sup>t</sup> HOLD | (CODE ID 10) (Note 4) | WP . | 0 | | 0 | | 0 | | 0 | | | 23 | <sup>t</sup> SET | CORRECT (Note 4) | | 20 | | 14 | | 14 | | 9 | | | 24† | <sup>t</sup> HOLD | CORNECT (INDIC 4) | LE <sub>OUT</sub> | 0 | | 0 | | 0 | | 0 | | | 25 | <sup>t</sup> SET | DIAG MODE <sub>0, 1</sub> (Note 4) | - | 28 | | 20 | | 20 | | 19 | | | 26† | tHOLD | DIAG MODEO, 1 (Note 4) | | 0 | | 0 | | 0 | | 0 | | | 27 | <sup>t</sup> SET | CODE ID <sub>0. 1</sub> (Note 4) | | 28 | | 20 | | 20 | | 12 | | | 28† | <sup>t</sup> HOLD | CODE IDO, 1 (Note 4) | | 0 | | 0 | | 0 | | 0 | | | 29 | <sup>t</sup> SET | LE <sub>IN</sub> (Notes 4 & 6) | | 37 | | 28 | | 23 | | 21 | | | 30† | <sup>t</sup> HOLD | בבווע (ויוטנפט יי מ ט) | | 0 | | 0 | | 0 | | 0 | | | 31 | <sup>t</sup> SET | DATA <sub>0-31</sub> (Notes 4 & 6) | LE <sub>DIAG</sub> | 6 | | 5 | | 4 | | 3 | | | 32† | <sup>t</sup> HOLD | D////U=31 (Notes 4 & 0) | | 3 | | 3 | | 3 | | 3 | | | 33 | <sup>t</sup> EN | OE BYTE <sub>0-3</sub> (Notes 5 & 6) | DATA <sub>0 - 31</sub> | | 29 | | 25 | | 25 | | 25 | | 34 | t <sub>DIS</sub> | SE DITE(123 (NOTES 5 & 6) | 20100-31 | | 25 | | 21 | | 21 | | 21 | | 35 | <sup>t</sup> EN | OE <sub>SC</sub> (Notes 5 & 6) | SC <sub>0-7</sub> | | 30 | | 27 | | 27 | | 27 | | 36 | tDIS | 0250 (110103 5 & 0) | 550 = 7 | | 26 | | 22 | | 22 | | 22 | | 37 | t <sub>PW</sub> | Minimum Pulse Width: LEIN, LEO | UT, LEDIAG | 15 | | 12 | | 12 | | 6 | | Notes: 1. $C_L = 50$ pF. - 2. Certain parameters are combinational propagation delay calculations. - 3. Data In or LEIN to Correct Data Out measurement requires timing as shown in the Switching Waveforms. - 4. Setup and Hold times relative to Latch Enables (Latching up data). - Soutp and hold lines relative to Calcining up data). Output tests specified with C<sub>L</sub> = 5 pF and measured to 0.5 V change of output voltage level. Testing is performed at C<sub>L</sub> = 50 pF and correlated to C<sub>L</sub> = 5 pF. Not production tested. Guaranteed by characterization. <sup>† =</sup> Not Included in Group A Tests. ## SWITCHING WAVEFORMS KEY TO SWITCHING WAVEFORMS KS000010 WF026320 DATA<sub>0-31</sub>/LE<sub>IN</sub> to Correct Data Out #### SWITCHING TEST CIRCUIT AF004810 - Notes: 1. C<sub>L</sub> = 50 pF for all tests except output enable/disable (includes scope probe, wiring, and stray capacitance without device in test fixture). - 2. $C_L = 5$ pF for output enable/disable tests. - 3. $V_T = 1.5 \text{ V}.$ #### SWITCHING TEST WAVEFORMS - Notes: 1. Diagram shown for HIGH data only. Output transition may be opposite sense. - 2. Cross-hatched area is don't care condition. #### Setup and Hold Times #### **Propagation Delay** #### SWITCHING TEST WAVEFORMS (Cont'd.) **Pulse Width** #### **Notes on Testing** Incoming test procedures on this device should be carefully planned, taking into account the complexity and power levels of the part. The following notes may be useful. - Ensure the part is adequately decoupled at the test head. Large changes in V<sub>CC</sub> current as the device switches may cause erroneous function failures due to V<sub>CC</sub> changes. - 2. Do not leave inputs floating during any tests, as they may start to oscillate at high frequency. - 3. Do not attempt to perform threshold tests at high speed. Following an input transition, ground current may change by as much as 400 mA in 5-8 ns. Inductance in the ground cable may allow the ground pin at the device to rise by hundreds of millivolts momentarily. - 4. Use extreme care in defining input levels for AC tests. Many inputs may be changed at once, so there will be significant noise at the device pins and they may not actually reach $V_{IL}$ or $V_{IH}$ until the noise has settled. AMD recommends using $V_{IL} \leqslant 0$ V and $V_{IH} \geqslant 3$ V for AC tests. - To simplify failure analysis, programs should be designed to perform DC, Function, and AC tests as three distinct groups of tests. - 6. Changing the CODE ID inputs can cause loss of data in some of the Am29C660 internal latches. Specifically, the entire checkbit latch and bits 6 and 7 of the diagnostic latch are indeterminate after a change in CODE ID inputs. Logic simulations should store "x" (i.e., "don't care") in these bits after CODE ID change. Test programs should reload these registers before they are used. - 7. Proper device grounding is critical when device testing. Multi-layer performance boards with radial decoupling between power and ground planes is recommended. Wiring unused interconnect pins to the ground plane is recommended. The ground plane must be sustained from the performance board to the device under test interface board. To minimize inductance, heavy-guage stranded wire with twisted pairs should be used for power wiring. #### **EQUIVALENT INPUT/OUTPUT CIRCUIT DIAGRAMS** ## PHYSICAL DIMENSIONS\* PID# 10968A <sup>\*</sup>For reference only. All dimensions are measured in inches. BSC is an ANSI standard for Basic Spacing Centering. #### ADVANCED MICRO DEVICES' NORTH AMERICAN SALES OFFICES | ALABAMA | (205) 882-9122 | MARYLAND | (301) 796-9310 | |------------------|----------------|-----------------------------------------|------------------| | | | | | | ARIZONA | (602) 242-4400 | MASSACHUSETTS | (617) 273-3970 | | CALIFORNIA, | | MINNESOTA | (612) 938-0001 | | Culver City | | MISSOURI | (913) 451-3115 | | Newport Beach | (714) 752-6262 | NEW JERSEY | (201) 299-0002 | | San Diego | (619) 560-7030 | NEW YORK, | | | San Jose | (408) 452-0500 | Liverpool | (315) 457-5400 | | Woodland Hills | | Poughkeepsie | (914) 471-8180 | | CANADA, Ontario. | (0.0, 00200 | Woodbury | (516) 364-8020 | | Kanata | (613) 592-0060 | NORTH CAROLINA | (919) 878-8111 | | Willowdale | | OHIO | (614) 891-6455 | | COLORADO | | Columbus | (614) 891-6455 | | CONNECTION | (303) 741-2900 | | (513) 439-0470 | | CONNECTICUT | (203) 264-7800 | Dayton | | | FLORIDA, | (0.0) =00 00=1 | OREGON | (503) 245-0080 | | Clearwater | | PENNSYLVANIA, | | | Ft Lauderdale | | Allentown | | | Melbourne | | Willow Grove | (609) 662-2900 | | Orlando | (305) 859-0831 | TEXAS, | | | GEORGIA | (404) 449-7920 | Austin | (512) 346-7830 | | ILLINOIS. | ( , | Dallas | (214) 934-9099 | | Chicago | (312) 773-4422 | Houston | (713) 785-9001 | | Naperville | | WASHINGTON | (206) 455-3600 | | INDIANA | | WISCONSIN | (414) 792-0590 | | | | *************************************** | (-11-1) 102-0000 | | KANSAS | (313) 431-3113 | | | | | | | | #### ADVANCED MICRO DEVICES' INTERNATIONAL SALES OFFICES | AD | TANGLE IMONO BETTOLO | INTERNATIONAL GALLO | 111020 | |-----------------------|------------------------------------------------------------------------------|---------------------|-------------------------------------------------------------------| | BELGIUM,<br>Bruxelles | TEL (02) 771 91 42<br>FAX (02) 762 37 12 | KOREA, Seoul | TEL 82-2-784-7598<br>FAX 82-2-784-8014 | | FRANCE,<br>Paris | TLX 61028 | Ft. Lauderdale | TEL (305) 484-8600<br>FAX (305) 485-9736<br>TLX 5109554261 AMDFTL | | WEST GERMANY. | FAX (1) 49-75-10-13<br>TLX 263282 | NORWAY,<br>Hovik | TEL (02) 537810<br>FAX (02) 591959 | | | TEL (0511) 736085<br>FAX (0511) 721254<br>TLX 922850 | SINGAPORE | TEL 65-2257544 | | | TEL (089) 41 14-0<br>FAX (089) 406490<br>TLX 523883 | CMEDEN. Charling | FAX 65-2246113<br>TLX RS55650 MMI RS<br>TEL (08) 733 03 50 | | Stuttgart | TEL (0711) 62 33 77<br>FAX (0711) 625187<br>TLX 721882 | SWEDEN, Slockholin | FAX (08) 733 22 85<br>TLX 11602 | | HONG KONG | TEL 852-5-8654525<br>FAX 852-5-8654335<br>TLX 67955AMDAPHX | TAIWAN | TLX 886-2-7122066<br>FAX 886-2-7122017 | | ITALY, Milano | TEL (02) 3390541 (02) 3533241 | | TEL (0925) 828008<br>FAX (0925) 827693<br>TLX 628524 | | JAPAN, | FAX (02) 3498000<br>TLX 315286 | London area | TEL (04862) 22121<br>FAX (0483) 756196<br>TLX 859103 | | 9 | TEL 462-47-2911 FAX 462-47-1729 TEL (03) 345-8241 FAX (03) 342-5196 | | | | Osaka | FAX (03) 342-5196<br>TLX J24064AMDTKOJ<br>TEL 06-243-3250<br>FAX 06-243-3253 | | | | | | | | #### **NORTH AMERICAN REPRESENTATIVES** | NOTHIN AMERICAN TEL NEGETIANTES | | | | | | | | | |------------------------------------|------------------|-------------------------------------|---------------|--|--|--|--|--| | CALIFORNIA 12 INC OEM | 1 (408) 988-3400 | KENTUCKY<br>ELECTRONIC MARKETING | | | | | | | | DISTI | (408) 498-6868 | CONSULTANTS, INC (3 | 317) 253-1668 | | | | | | | CANADA<br>Burnaby, B.C. | | MICHIGAN SAI MARKETING CORP(( | 313) 750-1922 | | | | | | | DAVÉTEK MARKETING | (604) 430-3680 | MISSOURI<br>LORENZ SALES(3 | 214) 007-4558 | | | | | | | Calgary, Alberta DAVETEK MARKETING | (604) 430-3680 | NEBRASKA | , | | | | | | | Kanata, Ontario VITEL ELECTRONICS | (613) 502-0000 | LORENZ SALES(4 NEW MEXICO | 402) 475-4660 | | | | | | | Mississauga, Ontario | | THORSON DESERT STATES (5 | 505) 293-8555 | | | | | | | VITAL ELECTRONICS | (416) 6/6-9/20 | NEW YORK NYCOM, INC( | 315) 437-8343 | | | | | | | VITEL ELECTRONICS | (514) 636-5951 | OHIO<br>Centerville | , | | | | | | | IDAHO INTERMOUNTAIN TECH MKGT | (208) 888-6071 | DOLFUSS ROOT & CO ( | 513) 433-6776 | | | | | | | INDIANA<br>ELECTRONIC MARKETING | | Columbus DOLFUSS ROOT & CO(6 | 614) 885-4844 | | | | | | | CONSULTANTS, INC | (317). 253-1668 | Strongsville | , | | | | | | | IOWA<br>LORENZ SALES | (319) 377-4666 | DOĽFUSS ROOT & CO(i<br>PENNSYLVANIA | 216) 238-0300 | | | | | | | KANSAS<br>LORENZ SALES | | DOLFUSS ROOT & CO(4 | 412) 221-4420 | | | | | | | LUHENZ SALES | (913) 384-6556 | R <sup>2</sup> MARKETING | 801) 595-0631 | | | | | | Advanced Micro Devices reserves the right to make changes in its product without notice in order to improve design or performance characteristics. The performance characteristics listed in this document are guaranteed by specific tests, guard banding, design and other practices common to the industry. For specific testing details, contact your local AMD sales representative. The company assumes no responsibility for the use of any circuits described herein.