32-Bit Byte Queue ## ADVANCE INFORMATION # DISTINCTIVE CHARACTERISTICS #### Intelligent FIFO Array - Array of four intelligent FIFO buffers, each 9 bits wide, 32 bits deep (RAM-based) - Queuing/Dequeuing - Allows variable width queuing/dequeuing in one cycle - Byte Rotation - Four bytes can be rotated at the input as well as at the output of the Byte Queue. This allows interfacing between incompatible byte assignments. - Asynchronous and Synchronous Operation - Supports communication between systems with different clocks and different bus widths - Retransmit - Data can be read out repeatedly - Horizontal Cascading - Up to four devices allow simultaneous input or output up to 16 bytes - Parity Check - Protects data at the input and the output #### **GENERAL DESCRIPTION** The Am29338 is an intelligent FIFO that allows up to four bytes to be gueued and up to four bytes to be dequeued in a single cycle. When four devices are cascaded horizontally, up to sixteen bytes can be dequeued in a single cycle. The Am29338 queues variable-length data by disassembling the input data, which is aligned on the least-significant byte of the input bus (D), into individual bytes. These bytes are packed internally in FIFO (first-in, first-out) order. The data to be dequeued is unpacked and realigned to the least-significant byte of the output bus (Y). Queuing and dequeuing can be performed simultaneously. With the retransmit capability, the part can repeatedly send the block of data stored in the queue without having to requeue it. This is useful for retransmitting a block of data upon receipt of an error in I/O applications or for loop-locking in instruction-prefetch applications. The queue operates in synchronous or asynchronous mode, and is useful as an instruction-prefetch queue or as a general-purpose FIFO buffer. The device is manufactured in AMD's bipolar IMOX\* technology and comes in a 120-lead pin-grid-array package. #### **BLOCK DIAGRAM** This document contains information on a product under development at Advanced Micro Devices, inc. The information is intended to help you to evaluate this product. AMD reserves the right to change or discontinue work on this proposed product without notice. 3-11 Amendment Publication Issue Date: September 1987 3-115 ## RELATED AMD PRODUCTS | Part No. | Description | |----------------|-------------------------------------------| | | Description | | Am2900 Family | 4-Bit Microprocessor Slice Family | | Am29C00 Family | CMOS 4-Bit Microprocessor Slice Family | | Am29C101 | CMOS 16-Bit Microprocessor Slice | | Am29114 | Real-Time Interrupt Controller | | Am29116 | 16-Bit Bipolar Microprocessor | | Am29116A | High-Speed 16-Bit Bipolar Microprocessor | | Am29L116A | Low-Power 16-Bit Bipolar Microprocessor | | Am29C116 | CMOS 16-Bit Microprocessor | | Am29C116-1 | CMOS 16-Bit Microprocessor | | 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 | Four-Port, Dual-Access Register File | | Am29C334 | CMOS Four-Port, Dual-Access Register File | | Am29337 | 16-Bit Cascadable Bounds Checker | # CONNECTION DIAGRAM Bottom View | | A | 8 | C | D | E | F | G | н | J | K | Ļ | M | N | |----|------------|--------|-------|-----|------|------|------------|------|------|------|------|-------|-------| | 1 | ¥16 | Y17 | Œ | Y21 | GNDT | PY3 | ¥27 | Y28 | VCCT | CNT2 | GNDT | CNT6 | BDQ3 | | 2 | PY2 | Y15 | Y18 | Y20 | Y23 | Y24 | Y26 | Y29 | Y31 | CNT1 | CNT4 | CNT5 | BDQ2 | | 3 | GNDT | Y14 | Y13 | Y19 | Y22 | VCCE | Y25 | GNDE | Y30 | CNTO | CNT3 | BDQ0 | BDQ1 | | 4 | Y12 | Y11 | Y10 | | | | | | | | DOEN | RESET | RXMIT | | 5 | VCCT | Y9 | Y8 | | | | | | | | ŒN | BSW1 | DOCLK | | 6 | <b>Y</b> 7 | PY1 | GNIDT | | | | | | | | QCLK | BQ1 | BSW0 | | 7 | Y6 | Y5 | Y4 | | | | | | | | BQ0 | NC | D30 | | 8 | Y2 | Y3 | VCCT | | | | | | | | D31 | D28 | D29 | | 9 | GNDT | Y1 | Y0 | | | | | | | | D27 | D25 | D26 | | 10 | PYO | PYERR | PDERF | ì | | | | | | | D24 | PD3 | D23 | | 11 | vсст | A-FULL | PD0 | D2 | VCCE | D6 | <b>D</b> 7 | D12 | GNDE | D15 | D22 | D20 | D21 | | 12 | FULL | POS1 | POS0 | D1 | VCCE | D3 | D8 | D9 | GNDE | D14 | PD2 | D19 | D18 | | 13 | A-EMPTY | EMPTY | D5 | D0 | VCCE | D4 | PD1 | D11 | GNDE | D13 | D10 | D16 | 017 | CD011040 Legend: GNDE: GND, ECL GNDT: GND, TTL VCCE: V<sub>CC</sub>, ECL VCCT: V<sub>CC</sub>, TTL # PIN DESIGNATIONS (Sorted by Pin Number) | 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. | PIN<br>NO. | PIN NAME | |------------|------------|-----------------------|------------|------------|-----------------------|------------|------------|-----------------------|------------|------------|------------------| | 1 | A1 | Y <sub>16</sub> | 115 | C5 | Y <sub>8</sub> | 40 | G11 | D <sub>7</sub> | 27 | L10 | D <sub>24</sub> | | 120 | A2 | PY <sub>2</sub> | 113 | C6 | GND, TTL | 36 | G12 | D <sub>8</sub> | 88 | L11 | D <sub>22</sub> | | 59 | А3 | GND, TTL | 52 | C7 | Y <sub>4</sub> | 96 | G13 | PD <sub>1</sub> | 32 | L12 | PD <sub>2</sub> | | 58 | A4 | Y <sub>12</sub> | 53 | C8 | V <sub>CC</sub> , TTL | 69 | H1 | Y <sub>28</sub> | 35 | L13 | D <sub>10</sub> | | 56 | A5 | V <sub>CC</sub> , TTL | 109 | C9 | Yo | 10 | H2 | Y <sub>29</sub> | 75 | M 1 | CNT <sub>6</sub> | | 114 | A6 | Y <sub>7</sub> | 48 | C10 | PDERR | 68 | НЗ | GND, ECL | 15 | M2 | CNT <sub>5</sub> | | 54 | A7 | Y <sub>6</sub> | 44 | C11 | PD <sub>0</sub> | 34 | H11 | D <sub>12</sub> | 77 | МЗ | BDQ <sub>0</sub> | | 51 | A8 | Y <sub>2</sub> | 104 | C12 | POS <sub>0</sub> | 95 | H12 | Dg | 78 | M4 | RESET | | 50 | A9 | GND, TTL | 41 | C13 | D <sub>5</sub> | 94 | H13 | D <sub>11</sub> | 80 | M5 | BSW <sub>1</sub> | | 49 | A10 | PY <sub>0</sub> | 4 | D1 | Y <sub>21</sub> | 11 | J1 | V <sub>CC</sub> , TTL | 81 | M6 | BQ <sub>1</sub> | | 47 | A11 | V <sub>CC</sub> , TTL | 63 | D2 | Y <sub>20</sub> | 71 | J2 | Y <sub>31</sub> | 82 | M7 | NC | | 106 | A12 | FULL | 3 | D3 | Y <sub>19</sub> | 70 | J3 | Y <sub>30</sub> | 25 | М8 | D <sub>28</sub> | | 46 | A13 | A-EMPTY | 102 | D11 | D <sub>2</sub> | 38 | J11 | GND, ECL | 86 | М9 | D <sub>25</sub> | | 61 | B1 | Y <sub>17</sub> | 43 | D12 | D <sub>1</sub> | 38 | J12 | GND, ECL | 87 | M10 | PD <sub>3</sub> | | 60 | B2 | Y <sub>15</sub> | 103 | D13 | D <sub>0</sub> | 38 | J13 | GND, ECL | 89 | M11 | D <sub>20</sub> | | 119 | <b>B</b> 3 | Y <sub>14</sub> | 5 | E1 | GND, TTL | 13 | K1 | CNT <sub>2</sub> | 30 | M12 | D <sub>19</sub> | | 117 | B4 | Y <sub>11</sub> | 65 | E2 | Y <sub>23</sub> | 72 | K2 | CNT <sub>1</sub> | 91 | M13 | D <sub>16</sub> | | 116 | <b>B</b> 5 | Yg | 64 | E3 | Y <sub>22</sub> | 12 | КЗ | CNT <sub>0</sub> | 16 | N1 | BDQ <sub>3</sub> | | 55 | <b>B</b> 6 | PY <sub>1</sub> | 98 | E11 | V <sub>CC</sub> , ECL | 92 | K11 | D <sub>15</sub> | 76 | N2 | BDQ <sub>2</sub> | | 112 | B7 | Y <sub>5</sub> | 98 | E12 | V <sub>CC</sub> , ECL | 33 | K12 | D <sub>14</sub> | 17 | N3 | BDQ <sub>1</sub> | | 111 | B8 | Y3 | 98 | E13 | V <sub>CC</sub> , ECL | 93 | K13 | D <sub>13</sub> | 19 | N4 | RXMIT | | 110 | <b>B</b> 9 | Y <sub>1</sub> | 6 | F1 | PY <sub>3</sub> | 14 | L1 | GND, TTL | 20 | N5 | DQCLK | | 108 | B10 | PYERR | 66 | F2 | Y <sub>24</sub> | 74 | L2 | CNT <sub>4</sub> | 21 | N6 | BSW <sub>0</sub> | | 107 | B11 | A-FULL | В | F3 | V <sub>CC</sub> , ECL | 73 | L3 | CNT <sub>3</sub> | 24 | N7 | D <sub>30</sub> | | 45 | B12 | POS <sub>1</sub> | 100 | F11 | D <sub>6</sub> | 18 | L4 | DOEN | 84 | N8 | D <sub>29</sub> | | 105 | B13 | EMPTY | 42 | F12 | D <sub>3</sub> | 79 | L5 | QEN | 26 | N9 | D <sub>26</sub> | | 2 | C1 | ŌĒ | 101 | F13 | D <sub>4</sub> | 23 | L6 | QCLK | 28 | N10 | D <sub>23</sub> | | 62 | C2 | Y <sub>18</sub> | 9 | G1 | Y <sub>27</sub> | 22 | L7 | BQ <sub>0</sub> | 29 | N11 | D <sub>21</sub> | | 118 | C3 | Y <sub>13</sub> | 67 | G2 | Y <sub>26</sub> | 83 | L8 | D <sub>31</sub> | 90 | N12 | D <sub>18</sub> | | 57 | C4 | Y <sub>10</sub> | 7 | G3 | Y <sub>25</sub> | 85 | L9 | D <sub>27</sub> | 31 | N13 | D <sub>17</sub> | # PIN DESIGNATIONS (Sorted by 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. | PIN<br>NO. | PIN NAME | |------------|------------|------------------|------------|------------|-----------------|------------|------------|-----------------------|------------|------------|-----------------| | 82 | M7 | NC | 34 | H11 | D <sub>12</sub> | 59 | А3 | GND, TTL | 51 | A8 | Y <sub>2</sub> | | 46 | A13 | A-EMPTY | 93 | K13 | D <sub>13</sub> | 5 | E1 | GND, TTL | 111 | B8 | Y <sub>3</sub> | | 107 | B11 | A-FULL | 33 | K12 | D <sub>14</sub> | 50 | A9 | GND, TTL | 52 | C7 | Y4 | | 77 | МЗ | BDQ <sub>0</sub> | 92 | K11 | D <sub>15</sub> | 2 | C1 | ŌĒ | 112 | B7 | Y <sub>5</sub> | | 17 | N3 | BDQ <sub>1</sub> | 91 | M13 | D <sub>16</sub> | 44 | C11 | PD <sub>0</sub> | 54 | A7 | Y <sub>6</sub> | | 76 | N2 | BDQ <sub>2</sub> | 31 | N13 | D <sub>17</sub> | 96 | G13 | PD <sub>1</sub> | 114 | A6 | Y <sub>7</sub> | | 16 | N1 | BDQ <sub>3</sub> | 90 | N12 | D <sub>18</sub> | 32 | L12 | PD <sub>2</sub> | 115 | C5 | Yβ | | 22 | L7 | BQ <sub>0</sub> | 30 | M12 | D <sub>19</sub> | 87 | M10 | PD <sub>3</sub> | 116 | B5 | Y <sub>9</sub> | | 81 | М6 | BQ <sub>1</sub> | 89 | M11 | D <sub>20</sub> | 48 | C10 | PDERR | 57 | C4 | Y <sub>10</sub> | | 21 | N6 | BSW <sub>0</sub> | 29 | N11 | D <sub>21</sub> | 104 | C12 | POS <sub>0</sub> | 117 | B4 | Y <sub>11</sub> | | 80 | M5 | BSW <sub>1</sub> | 88 | L11 | D <sub>22</sub> | 45 | B12 | POS <sub>1</sub> | 58 | A4 | Y <sub>12</sub> | | 12 | КЗ | CNT <sub>0</sub> | 28 | N10 | D <sub>23</sub> | 49 | A10 | PY <sub>0</sub> | 118 | C3 | Y <sub>13</sub> | | 72 | K2 | CNT <sub>1</sub> | 27 | L10 | D <sub>24</sub> | 55 | B6 | PY <sub>1</sub> | 119 | В3 | Y <sub>14</sub> | | 13 | K1 | CNT <sub>2</sub> | 86 | М9 | D <sub>25</sub> | 120 | A2 | PY <sub>2</sub> | 60 | B2 | Y <sub>15</sub> | | 73 | L3 | CNT <sub>3</sub> | 26 | N9 | D <sub>26</sub> | 6 | F1 | PY <sub>3</sub> | 1 | A1 | Y <sub>16</sub> | | 74 | L2 | CNT <sub>4</sub> | 85 | L9 | D <sub>27</sub> | 108 | B10 | PYERR | 61 | B1 | Y <sub>17</sub> | | 15 | M2 | CNT <sub>5</sub> | 25 | М8 | D <sub>28</sub> | 23 | L6 | QCLK | 62 | C2 | Y <sub>18</sub> | | 75 | M1 | CNT <sub>6</sub> | 84 | N8 | D <sub>29</sub> | 79 | L5 | QEN | 3 | D3 | Y <sub>19</sub> | | 103 | D13 | D <sub>0</sub> | 24 | N7 | D <sub>30</sub> | 78 | M4 | RESET | 63 | D2 | Y <sub>20</sub> | | 43 | D12 | D <sub>1</sub> | 83 | L8 | D <sub>31</sub> | 19 | N4 | RXMIT | 4 | D1 | Y <sub>21</sub> | | 102 | D11 | D <sub>2</sub> | 20 | N5 | DQCLK | 98 | E11 | V <sub>CC</sub> , ECL | 64 | E3 | Y <sub>22</sub> | | 42 | F12 | D <sub>3</sub> | 18 | L4 | DQEN | 98 | E12 | V <sub>CC</sub> , ECL | 65 | E2 | Y <sub>23</sub> | | 101 | F13 | D <sub>4</sub> | 105 | B13 | EMPTY | 98 | E13 | V <sub>CC</sub> , ECL | 66 | F2 | Y <sub>24</sub> | | 41 | C13 | D <sub>5</sub> | 106 | A12 | FULL | 8 | F3 | V <sub>CC</sub> , ECL | 7 | G3 | Y <sub>25</sub> | | 100 | F11 | D <sub>6</sub> | 38 | J11 | GND, ECL | 56 | A5 | V <sub>CC</sub> , TTL | 67 | G2 | Y <sub>26</sub> | | 40 | G11 | D <sub>7</sub> | 38 | J12 | GND, ECL | 53 | C8 | V <sub>CC</sub> , TTL | 9 | G1 | Y <sub>27</sub> | | 36 | G12 | D <sub>8</sub> | 38 | J13 | GND, ECL | 47 | A11 | V <sub>CC</sub> , TTL | 69 | H1 | Y <sub>2B</sub> | | 95 | H12 | D <sub>9</sub> | 68 | НЗ | GND, ECL | 11 | J1 | V <sub>CC</sub> , TTL | 10 | H2 | Y <sub>29</sub> | | 35 | L13 | D <sub>10</sub> | 113 | C6 | GND, TTL | 109 | C9 | Υ0 | 70 | J3 | Y <sub>30</sub> | | 94 | H13 | D <sub>11</sub> | 14 | L1 | GND, TTL | 110 | B9 | Y <sub>1</sub> | 71 | J2 | Y <sub>31</sub> | ## 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 AM29338 e. OPTIONAL PROCESSING Blank = Standard processing B = Burn-in d. TEMPERATURE RANGE C = Commercial (0 to +85°C) c. PACKAGE TYPE G = 120-Lead Pin Grid Array with Heatsink (CG 120) b. SPEED OPTION Not Applicable a. DEVICE NUMBER/DESCRIPTION Am29338 Byte Queue **Valid Combinations** Valid Combinations list configurations planned to be **Valid Combinations** supported in volume for this device. Consult the local AMD AM29338 GC, GCB 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. #### PIN DESCRIPTION ## A-EMPTY Almost Empty (Output; Active HIGH) Indicates that there are less than four bytes of data in the queue. It is used in either synchronous or asynchronous operation ## A-FULL Almost Full (Output; Active HIGH) Indicates that there are less than four bytes of space remaining. It is used in either synchronous or asynchronous operation. #### BDQ<sub>0</sub> - BDQ<sub>3</sub> Bytes Dequeued (Input) Selects the number of bytes to be dequeued (see Table 2). The byte queue must operate synchronously to be able to dequeue more than four bytes in a single cycle. #### BQ0 - BQ1 Bytes Queued (input) Selects the number of bytes to be queued (see Table 1). #### BSW<sub>0</sub> - BSW<sub>1</sub> Byte Swap (input) Allows the bytes on the input to be reordered (see Table 3). ## CNT<sub>0</sub> - CNT<sub>6</sub> Byte Count (Output) Gives the current number of bytes in the queue. These are used only in synchronous operation. ## D<sub>0</sub> - D<sub>31</sub> Data Input (Input) Data inputs to be queued. #### DQCLK Dequeue Clock (Input) Dequeues the number of bytes set up on the Y bus. A LOW-to-HIGH transition on this input adjusts the internal dequeue pointers by the number set up on the BDQ lines. ## DOEN Dequeue Enable (Input; Active LOW) While DOEN is LOW, dequeuing is performed normally. When DOEN is HIGH, DQCLK is disabled. #### EMPTY Empty (Output; Active HIGH) Indicates that the queue is empty. It is used in either synchronous or asynchronous operation. #### FULL Full (Output; Active HIGH) Indicates that the queue is full. It is used in either synchronous or asynchronous operation. #### OE Output Enable (Input; Active LOW) When OE is LOW, the four bytes following the current dequeue pointer and the corresponding parity bits are on Y and PY outputs. When OE is HIGH, Y and PY outputs are three stated. ## PD<sub>0</sub> - PD<sub>3</sub> Data Input Parity (Input) The input parity bits for the corresponding byte on the D inputs. Only the bytes to be queued and the corresponding PD lines are checked for possible parity error. The byte queue has the even parity. ## PDERR Data Input Parity Error (Output; Active HIGH) If any of the bytes to be queued have a parity error, PDERR is asserted. #### POS<sub>0</sub> - POS<sub>1</sub> Position (Input) These inputs are used to program the location of each byte queue in horizontally cascaded system upon RESET (see Table 4). ## PY<sub>0</sub> - PY<sub>3</sub> Output Data Parity (Output; Three State) The output parity bits for Y outputs. When OE is HIGH, the parity bits of the four bytes following the dequeue pointer appear on these outputs. The byte queue has the even parity. ## PYERR Y Output Parity Error (Output; Active HIGH) If any of the bytes on the output has a parity error, PYERR is asserted. ## QCLK Queue Clock (Input) When QCLK is LOW, the number of bytes set up on the BQ lines are written into the next free space in the queue from the data set up on the D inputs. On a LOW-to-HIGH transition of this input, the internal queue pointers are updated. If QEN is HIGH, QCLK has no effect. ## QEN Queue Enable (Input; Active LOW) When QEN is LOW, queuing is performed normally. When QEN is HIGH, QCLK is disabled. ## RESET Reset (Input; Active LOW) when RESET is LOW, both the internal queue pointer and the internal dequeue pointer are reset to the first RAM location and both EMPTY and A\_EMPTY are asserted. ## RXMIT Retransmit (Input; Active LOW) When RXMIT is LOW, the internal dequeue pointers are reset to the first RAM location while the internal queue pointers remain unchanged. This allows the data contained between the current queue pointer and the first RAM location to become available for dequeuing again. The effect of asserting RXMIT is defined only if 128 bytes or less have been queued since the last assertion of RESET (see Figure 5). ## Y<sub>0</sub> - Y<sub>31</sub> Data Output (Output; Three State) The four bytes following the current dequeue pointer appear on these outputs when $\overline{OE}$ is LOW. When $\overline{OE}$ is HIGH, they are three stated. #### **FUNCTIONAL DESCRIPTION** #### **Architecture** The Am29338 is a 32-bit high-performance general-purpose intelligent FIFO that stores up to 128 bytes in the internal RAM slices and queues or dequeues up to four bytes in a single cycle. The byte queue is divided into five functional blocks: 1) four memory-slice logics, 2) byte rotators for input and output buses, 3) rotate-enable logic, 4) byte-count logic, and 5) full/empty-generate logic. The byte-oriented parity checking is provided on both the D-input bus and the Y-output bus. Figure 1 shows a detailed block diagram of the byte queue. #### Memory-Slice Logic Figure 2 shows a detail of the memory-slice logic. It consists of a 32 x 9 RAM, queue and dequeue pointers, adders for the pointers, and a full/empty detector. The RAM has independent 9-bit read and write ports. Both ports are accessible simultaneously if different RAM locations are operated on. A parity bit is stored along with its corresponding byte into the RAM. The queue and dequeue pointers point to the next location available for dequeuing. The next locations are produced by the internal adders with $\mathrm{BQ}_{0-1}$ or $\mathrm{BDQ}_{0-3}$ and the current pointer values. When $\overline{\mathrm{RESET}}$ is asserted, both pointers are set to zero and the RAM is flushed. These pointers are also used to indicate that the RAM is either empty or full for each memory slice. The slice-empty or slice-full signal is used to combinationally form FULL, A-FULL, EMPTY, and A-EMPTY signals. #### Byte Rotator There are two byte rotators in the byte queue. Each accepts 36-bit wide data and performs rotation of bytes according to the 2-bit rotate values fed from the rotate-enable logic. The input byte rotator realigns and stores the bytes to be queued into the next free slice location. The output byte rotator realigns the bytes to be dequeued to the least significant byte of the Y-output bus. #### Rotate-Enable Logic The queue and dequeue rotate-enable logic keeps track of which slice holds the first byte of the next queue/dequeue operation. A modulo-4 counter is used to rotate the data in operation and enables the correct slices by the number of bytes specified by either $BQ_{Q-1}$ or $BDQ_{Q-3}$ . The queue rotate-enable logic also performs byte and/or word swaps on the incoming data. The input bytes are swapped in one of four ways, according to Table 3, with BSW<sub>0-1</sub> and the current modulo-4 byte count through the input byte rotator. #### Byte-Count Logic This logic consists of a queue count register and a dequeue count register. The registers are incremented during a queue/dequeue operation by the number of bytes in the operation. The combinational subtract logic outside of these registers determines the number of bytes stored in the byte queue. Figure 4. An Example of Horizontal Cascading Figure 5. Retransmit Function with the Am29338 Figure 6. Queuing with the Am29338 Notes: 1. Each of the four segments stands for a memory size; MSB = Most-Significant Byte, and LSB = Least-Significant Byte. Figure 7. Dequeuing with the Am29338 Notes: 1. Each of the four segments stands for a memory size; MSB = Most-Significant Byte, and LSB = Least-Significant Byte. 2. First, one byte is dequeued ('A'), followed by a dequeue of two bytes ('CB'). TABLE 1. SELECTING THE NUMBER OF BYTES TO BE QUEUED | BQ <sub>1</sub> | BQ <sub>0</sub> | Bytes To Be<br>Queued | |-----------------|-----------------|-----------------------| | L | Н | 1 | | Н | L | 2 | | Н | Н | 3 | | L | L | 4 | Key: L = LOW H = HIGH TABLE 2. SELECTING THE NUMBER OF BYTES TO BE DEQUEUED | BDQ <sub>3</sub> | BDQ <sub>2</sub> | BDQ <sub>1</sub> | BDQ <sub>0</sub> | Bytes To Be<br>Dequeued | |------------------|------------------|------------------|------------------|-------------------------| | L | L | L | н | 1 | | L | L | Н | L | 2 | | L | L | н | н | 3 | | L | н | L | L | 4 | | L | Н | L | н | 5* | | L | Н | н | L | 6* | | L | Н | н | Н | 7* | | Н | L | L | L | 8* | | Н | L | L | Н | 9* | | н | L | Н | L | 10* | | Н | L | Н | Н | 11* | | Н | н | L | L | 12* | | Н | н | L | н | 13* | | Н | Н | Н | L | 14* | | Н | н | Н | н | 15* | | L | L | L | L | 16* | Key: L = LOW H= HIGH <sup>\*</sup> This is possible when four of the byte queues are cascaded together. The byte queue must be operated synchronously to select more than four bytes for dequeuing. TABLE 3. ENCODING OF BSW INPUTS | Inp | uts | | | | | |------------------|------------------|------------|-----|-----|---| | BSW <sub>1</sub> | BSW <sub>0</sub> | ] <b>'</b> | Out | put | S | | L | L | Α | В | С | D | | L | Н | В | Α | D | С | | Н | L | С | D | Α | В | | Н | Н | D | С | В | Α | Key: L = LOW H = HIGH Note: The assumption is made that the 32-bit data "A B C D" appears on the input bus. TABLE 4. LOCATION IDENTIFICATION FOR HORIZONTAL CASCADING | POS <sub>1</sub> | POS <sub>0</sub> | Location | |------------------|------------------|----------| | L | L | 0 | | L | Н | 1 | | Н | L | 2 | | Н | Н | 3 | Key: L = LOW H = HIGH Note: "0" stands for the least significant chip and "3" the most significant chip. #### Operational Modes #### General Operation To enter data into the Am29338, the number of bytes to be queued is set up on the Bytes Queued (BQ) pins; the corresponding data to be queued is set up on the Data Input (D) and Data Input Parity (PD) pins, aligned to the least-significant byte. If Queue Enable (QEN) is asserted, the data is entered into the Am29338 while the Queue Clock (QCLK) is LOW, and the internal queue pointers are updated on the LOW-to-HIGH transition of QCLK. Figure 6 shows an example of two bytes being queued, followed by three bytes being queued. Data is packed in the Am29338 so that no holes exist. If Output Enable $(\overline{OE})$ is asserted, the first four bytes available for dequeuing and their corresponding parity appear on the Data Output (Y) and Data Parity (PY) pins. The number of these bytes to be dequeued is set up on the Bytes Dequeued (BDQ) pins. If Dequeue Enable $(\overline{DQEN})$ is asserted, the LOW-to-HIGH transition of Dequeue Clock (DQCLK) updates the internal dequeue pointers, removing the dequeued bytes. Figure 7 shows an example of one byte dequeued, followed by a dequeue of two bytes. The data to be dequeued next is least-significant-byte aligned on the output bus. #### Synchronous Mode Both synchronous and asynchronous operations are available for the byte queue. During synchronous operation, both QCLK and DQCLK must be asserted on the edge of a common clock within certain skew limits. The following signals can be used as valid status outputs for this mode: FULL, A-FULL, EMPTY, A-EMPTY, and CNT $_{\rm 0-6}$ . Refer to the applications section for an example. #### Asynchronous Mode During asynchronous operation, QCLK and DQCLK clocks may be different. It is possible to execute queue and dequeue operations simultaneously if different locations are accessed. In this mode, CNT outputs are not guaranteed as valid and horizontal cascading is not possible. Refer to the applications section for an example. #### Horizontal Cascading In synchronous operation, four byte queues can be horizontally cascaded together. In this case, each of the four byte queues hold the same data and up to sixteen bytes may be dequeued in a single cycle, as shown in Table 2, and Figures 3 and 4. Each part has to be programmed with its position by the POS inputs, as shown in Table 4. In a normal operation, the internal dequeue pointer of each part is displaced according to the POS inputs. When RESET or RXMIT is asserted, the dequeue pointers are offset by the value programmed on the POS inputs. Horizontal cascading is useful in instruction buffers designed for systems with large, variable instructions that can span many bytes. ## **APPLICATIONS** ## Using Am29338 as an Instruction-Prefetch Queue Figure 8 shows the Am29338 used as an instruction-prefetch queue. Sequential 32-bit memory locations are fetched by the instruction Fetch Unit (IFU) and are queued up in the byte queue. When the central processor needs the next instruction, it looks at the next four bytes from the byte queue. The central processor then determines the instruction length from the opcode and updates the dequeue pointer in the byte queue by setting up the instruction length on the BDQ lines and asserting DQCLK. When a jump occurs, the IFU flushes the queue by asserting the RESET input and begins from the new address. For this application, the byte queue must be in synchronous mode. Using the RXMIT input, the byte queue can resend the block data through dequeuing rather than having to requeue it. This is useful for locking the loops into the byte queue and allows the processor to run faster than if it had to refetch instructions from memory or cache. Figure 9 illustrates how a loop can execute directly out of the byte queue. # Using Am29338 as a Hardware Mailbox in Multiprocessing System A mailbox is a communication device between loosely coupled processes in a multi-programming system. Messages from one process to another are queued in the mailbox on a first-in, first-out (FIFO) basis. In a multiprocessing system, hardware mailboxes are required. This can be implemented using the Am29338 as shown in Figure 10. When a process wishes to send a message to the mailbox, it calls a special operating-system routine. This routine first reads the status of the mailbox; if it is not FULL, the routine first writes the message to the mailbox and returns to the calling process. If the mailbox is FULL, the operating system blocks the calling process on a special queue and enables interrupts from the mailbox. When a slot becomes available in the mailbox, the sending processor is interrupted. The interrupt routine sends the message to the mailbox, disables interrupts from the mailbox, and unblocks the blocked process. On the receiving side, the EMPTY status of the mailbox must be available to the receiving processor in order to allow the receiving process to be blocked if the mailbox is empty. When a mailbox slot becomes filled, a blocked processor. The mailbox can be extended to operate in a heterogeneous multiprocessing system. In this type of system, processors with varying data-path widths and clock frequencies are interconnected. For example, a 32-bit main processor may control 8- to 16-bit coprocessors. The ability of the Am29338 to match data-path widths and to queue and dequeue asynchronously allows processors of different widths and clock rates to communicate. Figure 8. Instruction-Prefetch Queue Note: This describes a block of macro instructions. Figure 9. Loop Locking Using Am29338 Figure 10. Implementation of a Hardware Mailbox # Suggestions for Power and Ground Pin Connections The Am29338 operates in an environment of fast signal rise times and substantial switching currents. Therefore, care must be exercised during circuit board design and layout, as with any high-performance component. The following is a suggested layout, but since systems vary widely in electrical configuration, an empirical evaluation of the intended layout is recommended. The V<sub>CCT</sub> and GNDT pins, which carry output driver switching currents, tend to be electrically noisy. The V<sub>CCE</sub> and GNDE pins, which supply the ECL core of the device, tend to produce less noise, and the circuits they supply may be adversely affected by noise spikes on the V<sub>CCE</sub> plane. For this reason, it is best to provide isolation between the V<sub>CCE</sub> and V<sub>CCT</sub> pins, as well as independent decoupling for each. Isolating the GNDE and GNDT pins is not required. ## **Printed Circuit-Board Layout Suggestions** - 1. Use of a multi-layer PC board with separate power, ground, and signal planes is highly recommended. - 2. All V<sub>CCE</sub> and V<sub>CCT</sub> pins should be connected to the V<sub>CC</sub> plane. V<sub>CCT</sub> pins should be isolated from V<sub>CCE</sub> pins by means of a slot cut in the V<sub>CCE</sub> plane; see Figure 11. By physically separating the V<sub>CCE</sub> and V<sub>CCT</sub> pins, coupled noise will be reduced. - 3. All GNDE and GNDT pins should be connected directly to the ground plane. - 4. The $V_{CCT}$ pins should be decoupled to ground with a 0.1- $\mu$ F ceramic capacitor and a 10- $\mu$ F electrolytic capacitor, placed as closely to the Am29338 as is practical. $V_{CCE}$ pins should be decoupled to ground in a similar manner. - A suggested layout is shown in Figure 11. Figure 11. Suggested Printed Circuit-Board Layout #### **ABSOLUTE MAXIMUM RATINGS** | Storage Temperature65 to +150°C | |----------------------------------------------| | Case Temperature | | with Power Applied55 to +125°C | | Supply Voltage | | with Respect to Ground0.5 to +7.0 V | | DC Voltage Applied to Outputs | | for HIGH State0.5 V to +V <sub>CC</sub> Max. | | DC Input Voltage0.5 V to +5.5 V | 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** | Commercial (C) Devices | | | | | | |------------------------------------|----|-------|------|-----|---| | Case Temperature (T <sub>C</sub> ) | 0 | to + | +85 | 5°C | ) | | Supply Voltage (VCC)+ 4.75 | to | ) + 5 | 5.25 | 5 \ | 1 | | θ <sub>JA</sub> (un | de | r 20 | 0 1 | fm | ) | Operating ranges define those limits between which the functionality of the device is guaranteed. ## DC CHARACTERISTICS over operating ranges unless otherwise specified | Parameter<br>Symbol | Parameter<br>Description | Test Cond<br>(Note | liti <b>ons</b><br>1) | Min. | Typ.<br>(Note 2) | Max. | Unit | |---------------------|------------------------------------------|-----------------------------------------------------------------------------------------------------------|-------------------------------------------------|------|------------------|-------|-------| | Vон | 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> = -3 mA | | 2.4 | | | ٧ | | VOL | Output LOW Voltage | V <sub>CC</sub> = Min.<br>V <sub>IN</sub> = V <sub>IL</sub> or VIII<br>I <sub>OL</sub> = 16 mA | | | | 0.4 | ٧ | | VIH | Input HIGH Level | Guaranteed Input Logical<br>HIGH Voltage for All Inpu | | 2.0 | | | ٧ | | VIL | Input LOW Level | Guaranteed Input Logical | | | | 0.8 | ٧ | | VI | Input Clamp Voltage | <sup>//</sup> V <sub>CO</sub> <b>=</b> Min.<br>I <sub>I</sub> N = −18 mA | • | | | - 1.2 | ٧ | | կլ | Input LOW Current | V <sub>CC</sub> = Max. | QCLK, DQCLK | | | -1.0 | mA | | ЧL | 197 | V <sub>IN</sub> = 0.5 V | Others | | | -0.5 | | | lн | Input HIGH Current | V <sub>CC</sub> = Max.<br>V <sub>IN</sub> = 2.4 V | | | | 50 | μА | | l <sub>l</sub> | Input HIGH Current | $V_{CC} = Max.$ $V_{IN} = 5.5 \text{ V}$ | | | | 1.0 | mA | | lozh | Off State (High Impedance) | V <sub>CC</sub> = Max. | V <sub>O</sub> = 2.4 V | | | 50 | μΑ | | IOZL | Output Current | VCC - Max. | V <sub>O</sub> = 0.5 V | | | -50 | μΛ | | Isc | Output Short Circuit Current<br>(Note 3) | $V_{CC} = Max. \text{ to } +0.5 \text{ V}$<br>$V_{O} = 0.5 \text{ V}$ | | -20 | | - 80 | m/ | | 11 | David Company | V <sub>CC</sub> = Max. | $T_{\rm C} = 0 \text{ to } + 85^{\circ}{\rm C}$ | | 800 | 900 | m.A | | lcc | Power Supply Current | All Inputs HIGH | T <sub>C</sub> = +85°C | | | 800 | 11174 | Notes: 1. For conditions shown as Min. or Max., use the appropriate value specified under Operating Ranges for the applicable device type. 2. Typical values are for $V_{CC} = +25^{\circ}C$ ambient and maximum loading. 3. Not more than one output should be shorted at a time. Duration of the short-circuit test should not exceed one second. ## SWITCHING CHARACTERISTICS over operating range (Note 1) ## A. Combinational Propagation Delays | No. | From | То | Delay | Unit | |-----|---------|-------------------|-------|------| | 1 | D | PDERR | 50 | ns | | 2 | PD | PDERR | 50 | ns | | 3 | DQCLK | A-EMPTY or A-FULL | 44 | ns | | 4 | DQCLK T | CNT | 46 | ns | | 5 | DQCLK T | EMPTY or FULL | 44 | ns | | 6 | DQCLK | PYERR | 60 | ns | | 7 | DQCLK T | Y | 52 | ns | | 8 | ŌĒ | PYERR | 25 | ns | | 9 | ŌĒ | Y | 25 | ns | | 10 | QCLK T | A-EMPTY or EMPTY | . 44 | ns | | 11 | QCLK T | CNT | 46 | ns | | 12 | QCLK T | A-FULL or FULL | 44 | ns | | 13 | RESET | A-FULL or FULL | 44 | ns | | 14 | RESET ↓ | CNT J | 46 | ns | | 15 | RESET | EMPTY or | 44 | ns | | 16 | RESET | PYERR | 60 | ns | | 17 | RESET | Y | 52 | ns | | 18 | RXMIT ↓ | A-FULL or FULL | 44 | ns | | 19 | RXMIT ↓ | CNT | 46 | ns | | 20 | RXMIT ↓ | A-EMPTY or EMPTY | 44 | ns | | 21 | RXMIT ↓ | PYERR | 60 | ns | | 22 | RXMIT | Y | 52 | ns | ## B. Setup and Hold Times | No. | Parameter | ∜ For | With Respect To | Delay<br>20 | Unit | |-----|----------------------|-------------|-----------------|-------------|------| | 23 | Bytes Dequeued Setup | BOC | DQCLK T | | | | 24 | Bytes Dequeued Hold | <b>B</b> DQ | DQCLK T | 0 | ns | | 25 | Bytes Queued Setup | BQ | QCLK . | 12 | ns | | 26 | Bytes Queued Hold | BQ | QCLK T | | กร | | 27 | Byte Swap Setup | BSW | QCLK 1 | 20 | ns | | 28 | Byte Swap Hold | BSW | QCLK ↓ | | ns | | 29 | Data Setup | D | QCLK T | В | ns | | 30 | Data Hold | D | QCLK 1 | | ns | | 31 | Data Parity Setup | PD | QCLK T | В | ns | | 32 | Data Parity Hold | PD | QCLK T | | ns | | 33 | Dequeue Enable Setup | DOEN | DQCLK T | В | ns | | 34 | Dequeue Enable Hold | DQEN | DQCLK | 0 | ns | | 35 | Queue Enable Setup | QEN | QCLK ↓ | | ns | | 36 | Queue Enable Hold | OEN | QCLK T | | ns | #### C. Minimum Clock Requirements | No. | Input | Description | Delay | Unit | |-----|-------|-------------------------------|-------|------| | 37 | DOCLK | Dequeue Min. Pulse Width LOW | 10 | ns | | 38 | | Dequeue Min. Pulse Width HIGH | 10 | | | 39 | | Dequeue Min. Cycle Time | 80 | | | 40 | | Queue Min. Pulse Width LOW | 10 | | | 41 | QCLK | Queue Min. Pulse Width HIGH | 10 | ns | | 42 | 1 | Queue Min. Cycle Time | 80 | | Notes: 1. Case temperature (T<sub>C</sub>) = 0 to +85°C, supply voltage (V<sub>CC</sub>) = 5 V ±5%, It is the responsibility of the user to maintain a case temperature of +85°C or less. AMD recommends an air velocity of at least 200 linear feet per minute over the heatsink. ## SWITCHING TEST CIRCUITS $$R_{1} = \frac{5.0 - V_{BE} - V_{OL}}{I_{OL} + \frac{V_{OL}}{1K}}$$ $$R_2 = \frac{2.4 \text{ V}}{I_{OH}}$$ $$R_1 = \frac{5.0 - V_{BE} - V_{OL}}{I_{OL} + \frac{V_{OL}}{R_2}}$$ ## A. Three-State Outputs #### **B. Normal Outputs** Notes: 1. $C_L = 50$ pF includes scope probe, wiring and stray capacitances without device in test fixture. - 2. $S_1$ , $S_2$ , $S_3$ are closed during function 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. $C_L = 5.0$ pF for output disable tests. ## Test Philosophy and Methods The following points give the general philosophy that we apply to tests that must be properly engineered if they are to be implemented in an automatic environment. The specifics of what philosophies applied to which test are shown in the data sheet - 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. - 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 output 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. Current level may vary from product to product. - 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.0$ 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. Capacitive Loading for AC Testing result at the lower capacitance. Automatic testers and their associated hardware have stray capacitance that varies from one type of tester to another but is generally around 50 pF. This, of course, makes it impossible to make direct measurements of parameters that call for a smaller capacitive load than the associated stray capacitance. Typical examples of this are the so-called "float delays," which measure the propagation delays into the high-impedance state and are usually specified at a load capacitance of 5.0 pF. In these cases, the test is performed at the higher load capacitance (typically 50 pF) and engineering correlations based on data taken with a bench set up are used to predict the Similarly, a product may be specified at more than one capacitive load. Since the typical automatic tester is not capable of switching loads in mid-test, it is impossible to make measurements at <u>both</u> capacitances even though they may both be greater than the stray capacitance. In these cases, a measurement is made at one of the two capacitances. The result at the other capacitance is predicted from engineering correlations based on data taken with a bench setup and the knowledge that certain DC measurements (I<sub>OH</sub>, I<sub>OL</sub>, for example) have already been taken and are within spec. In some cases, special DC tests are performed in order to facilitate this correlation. #### 7. Threshold Testing The noise associated with automatic testing (due to the long, inductive cables), and the high gain of the tested device when in the vicinity of the actual device threshold, frequently give rise to oscillations when testing high-speed circuits. These oscillations are not indicative of a reject device, but instead, of an overtaxed test system. To minimize this problem, thresholds are tested at least once for $\underline{each}$ input pin. Thereafter, "hard" high and low levels are used for other tests. Generally this means that function and AC testing are performed at "hard" input levels rather than at $V_{\rm IL}$ Max. and $V_{\rm IH}$ Min. #### 8. AC Testing Occasionally parameters are specified that cannot be measured directly on automatic testers because of tester limitations. Data input hold times often fall into this category. In these cases, the parameter in question is guaranteed by correlating these tests with other AC tests that have been performed. These correlations are arrived at by the cognizant engineer using data from precise bench measurements in conjunction with the knowledge that certain DC parameters have already been measured and are within spec. In some cases, certain AC tests are redundant since they can be shown to be predicted by other tests that have already been performed. In these cases, the redundant tests are not performed. #### 9. Output Short-Circuit Current Testing When performing I<sub>OS</sub> tests on devices containing RAM or registers, great care must be taken that undershoot caused by grounding the high-state output does not trigger parasitic elements which in turn cause the device to change state. In order to avoid this effect, it is common to make the measurement at a voltage (V<sub>output</sub>) that is slightly above ground. The V<sub>CC</sub> is raised by the same amount so that the result (as confirmed by Ohm's law and precise bench testing) is identical to the V<sub>OUT</sub> = 0, V<sub>CC</sub> = Max. case.