#### DISTINCTIVE CHARACTERISTICS - Two-address architecture Independent simultaneous access to two working registers saves machine cycles. - Eight-function ALU — Performs addition, two subtraction operations, and five logic functions on two source operands. - Flexible data source selection - ALU data is selected from five source ports for a total of 203 source operand pairs for every ALU function. - Left/right shift independent of ALU - Add and shift operations take only one cycle. - Four status flags — Carry, overflow, zero, and negative. Expandable – Connect any number of Am2901's together for longer word lengths. Microprogrammable – Three groups of three bits each for source operand, ALU function, and destination control. # GENERAL DESCRIPTION The four-bit bipolar microprocessor slice is designed as a high-speed cascadable element intended for use in CPU's, peripheral controllers, programmable microprocessors and numerous other applications. The microinstruction flexibility of the Am2901 will allow efficient emulation of almost any digital computing machine. The device, as shown in the block diagram below, consists of a 16-word by 4-bit two-port RAM, a high-speed ALU, and the associated shifting, decoding and multiplexing circuitry. The nine-bit microinstruction word is organized into three groups of three bits each and selects the ALU source operands, the ALU function, and the ALU destination register. The microprocessor is cascadable with full look-ahead or with ripple carry, has three-state outputs, and provides various status flag outputs from the ALU. Advanced low-power Schottky processing is used to fabricate this 40-lead LSI chip. ### TABLE OF CONTENTS | Block Diagram | ٠ | • | • | | | | ٠ | ٠ | ě | ٠ | ٠ | ٠ | • | ٠ | ٠ | ٠ | • | • | 4 | |----------------------|---|----|---|---|---|---|---|---|---|----|----|---|---|---|---|---|---|---|----| | Function Tables | | ٠, | | | • | | | | | , | ē | ě | ě | · | ٠ | ě | ٠ | | 5 | | Package Outline | | | | | | | | | | | | | | ě | • | | | | 7 | | Connection Diagram | | | | | ٠ | | | | | | | | | | | | | | 8 | | Pin Definitions | | | | | | | · | | • | | | | | | | | | • | 8 | | Screening | | | | | | ٠ | | | | | ÷ | | | | | | • | • | 9 | | Order Codes | | | | | • | | | | | | | | | | ě | | | | 9 | | DC Characteristics . | | | ٠ | | | | | | | į. | | × | | | | | | | 10 | | AC Characteristics . | | ž | | ě | į | | | | • | | | | | | | | | | 11 | | Switching Waveform | s | ž. | | ÷ | į | | | | | | į. | | | | | | | | 12 | | Applications | | | | | | | | | | | | | | | | | | | 13 | | 350 S | | | | | | | | | | | | | | | | | | | | # MICROPROCESSOR SLICE BLOCK DIAGRAM #### **ARCHITECTURE** A detailed block diagram of the bipolar microprogrammable microprocessor structure is shown in Figure 1. The circuit is a four-bit slice cascadable to any number of bits. Therefore, all data paths within the circuit are four bits wide. The two key elements in the Figure 1 block diagram are the 16-word by 4-bit 2-port RAM and the high-speed ALU. Data in any of the 16 words of the Random Access Memory (RAM) can be read from the A-port of the RAM as controlled by the 4-bit A address field input. Likewise, data in any of the 16 words of the RAM as defined by the B address field input can be simultaneously read from the B-port of the RAM. The same code can be applied to the A select field and B select field in which case the identical file data will appear at both the RAM A-port and B-port outputs simultaneously. When enabled by the RAM write enable (RAM EN), new data is always written into the file (word) defined by the B address field of the RAM. The RAM data input field is driven by a 3-input multiplexer. This configuration is used to shift the ALU output data (F) if desired. This three-input multiplexer scheme allows the data to be shifted up (right) one bit position, shifted down (left) one bit position, or not shifted in either direction. The RAM A-port data outputs and RAM B-port data outputs drive separate 4-bit latches. These latches hold the RAM data while the clock input is LOW. This eliminates any possible race conditions that could occur while new data is being written into the RAM. The high-speed Arithmetic Logic Unit (ALU) can perform three binary arithmetic and five logic operations on the two 4-bit input words R and S. The R input field is driven from a 2-input multiplexer, while the S input field is driven from a 3-input multiplexer. Both multiplexers also have an inhibit capability; that is, no data is passed. This is equivalent to a "zero" source operand. Referring to Figure 1, the ALU R-input multiplexer has the RAM A-port and the direct data inputs (D) connected as inputs. Likewise, the ALU S-input multiplexer has the RAM A-port, the RAM B-port and the Q register connected as inputs. This multiplexer scheme gives the capability of selecting various pairs of the A, B, D, Q and "0" inputs as source operands to the ALU. These five inputs, when taken two at a time, result in ten possible combinations of source operand pairs. These combinations include AB, AD, AQ, AO, BD, BQ, BO, DQ, DO and QO. It is apparent that AD, AQ and AO are somewhat redundant with BD, BQ and BO in that if the A address and B address are the same, the identical function results. Thus, there are only seven completely non-redundant source operand pairs for the ALU. The Am2901 microprocessor implements eight of these pairs. The microinstruction inputs used to select the ALU source operands are the I<sub>0</sub>, I<sub>1</sub>, and I<sub>2</sub> inputs. The definition of I<sub>0</sub>, I<sub>1</sub>, and I<sub>2</sub> for the eight source operand combinations are as shown in Figure 2. Also shown is the octal code for each selection. The two source operands not fully described as yet are the D input and $\Omega$ input. The D input is the four-bit wide direct data field input. This port is used to insert all data into the working registers inside the device. Likewise, this input can be used in the ALU to modify any of the internal data files. The $\Omega$ register is a separate 4-bit file intended primarily for multiplication and division routines but it can also be used as an accumulator or holding register for some applications. The ALU itself is a high-speed arithmetic/logic operator capable of performing three binary arithmetic and five logic functions. The $I_3$ , $I_4$ , and $I_5$ microinstruction inputs are used to select the ALU function. The definition of these inputs is shown in Figure 3. The octal code is also shown for reference. The normal technique for cascading the ALU of several devices is in a look-ahead carry mode. Carry generate, $\overline{G}_{\rm s}$ and carry propagate, $\overline{P}_{\rm s}$ are outputs of the device for use with a carry-look-ahead-generator such as the Am2902 ('182). A carry-out, $C_{n+4}$ , is also generated and is available as an output for use as the carry flag in a status register. Both carry-in $\{C_n\}$ and carry-out $(C_{n+4})$ are active HIGH. The ALU has three other status-oriented outputs. These are $F_3$ , F=0, and overflow (OVR). The $F_3$ output is the most significant (sign) bit of the ALU and can be used to determine positive or negative results without enabling the three-state data outputs. $F_3$ is non-inverted with respect to the sign bit output $Y_3$ . The F=0 output is used for zero detect. It is an open-collector output and can be wire OR'ed between microprocessor slices. F=0 is HIGH when all F outputs are LOW. The overflow output (OVR) is used to flag arithmetic operations that exceed the available two's complement number range. The overflow output (OVR) is HIGH when overflow exists. That is, when $C_{n+3}$ and $C_{n+4}$ are not the same polarity. The ALU data output is routed to several destinations. It can be a data output of the device and it can also be stored in the RAM or the Q register. Eight possible combinations of ALU destination functions are available as defined by the $I_6$ , $I_7$ , and $I_8$ microinstruction inputs. These combinations are shown in Figure 4. The four-bit data output field (Y) features three-state outputs and can be directly bus organized. An output control $(\overline{OE})$ is used to enable the three-state outputs. When $\overline{OE}$ is HIGH, the Y outputs are in the high-impedance state. A two-input multiplexer is also used at the data output such that either the A-port of the RAM or the ALU outputs (F) are selected at the device Y outputs. This selection is controlled by the $I_6$ , $I_7$ , and $I_8$ microinstruction inputs. Refer to Figure 4 for the selected output for each microinstruction code combination. As was discussed previously, the RAM inputs are driven from a three-input multiplexer. This allows the ALU outputs to be entered non-shifted, shifted up one position (X2) or shifted down one position (÷2). The shifter has two ports; one is labeled RAM<sub>0</sub>—LO/RI and the other is labeled RAM<sub>3</sub>—RO/LI. Both of these ports consist of a buffer-driver with a three-state output and an input to the multiplexer. Thus, in the shift up mode, the RO buffer is enabled and the RI multiplexer input is enabled. Likewise, in the shift down mode, the LO buffer and LI input are enabled. In the no-shift mode, both the LO and RO buffers are in the high-impedance state and the multiplexer inputs are not selected. This shifter is controlled from the I<sub>6</sub>, I<sub>7</sub>, and I<sub>8</sub> microinstruction inputs as defined in Figure 4. Similarly, the Q register is driven from a 3-input multiplexer. In the no-shift mode, the multiplexer enters the ALU data into the Q register. In either the shift-up or shift-down mode, the multiplexer selects the Q register data appropriately shifted up or down. The Q shifter also has two ports; one is labeled $\rm Q_0-LO/Rl$ and the other is $\rm Q_3-RO/Ll$ . The operation of these two ports is similar to the RAM shifter and is also controlled from I $_{6}$ , I $_{7}$ , and I $_{8}$ as shown in Figure 4. The clock input to the Am2901 controls the RAM, the Q register, and the A and B data latches. When enabled, data is clocked into the Q register on the LOW-to-HIGH transition of the clock. When the clock input is HIGH, the A and B latches are open and will pass whatever data is present at the RAM outputs. When the clock input is LOW, the latches are closed and will retain the last data entered. If the RAM-EN is enabled, new data will be written into the RAM file (word) defined by the B address field when the clock input is LOW. | | MICR | O COD | E | OPERAND | | | |----|------|-------|---------------|---------|---|--| | 12 | 11 | 10 | Octal<br>Code | R | s | | | L | L | L, | 0 | А | a | | | L | L | н | 1 | Α | В | | | L | н | L | 2 | 0 | a | | | L | H | н | 3 | 0 | В | | | н | L | L | 4 | 0 | Α | | | н | L | н | 5 | D | A | | | н | н | L | 6 | D | Q | | | н | H | н | 7 | D | 0 | | | Figure | 2. | ALU | Source | Operand | Control. | |---------|----|-----|---------|---------|----------| | 1 Iguic | | 750 | OUG: CC | Operana | Control. | | | MICE | RO COD | E | ALU | | | |----------|------|---------------|----------|------------|-------|--| | 15 14 13 | | Octal<br>Code | Function | Symbol | | | | L | L | L. | o | R Plus S | R+S | | | L | L | н | 1 | S Minus R | S - R | | | L | н | L | 2 | R Minus S | R-S | | | L | н | H | 3 | RORS | RVS | | | н | L | L | 4 | RANDS | RAS | | | н | L | н | 5 | RANDS | R ^ S | | | H | н | L | 6 | R EX-OR S | RYS | | | н | н | H | 7 | R EX-NOR S | R ¥ S | | Figure 3. ALU Function Control. | MICRO CODE | | RA<br>FUNC | | | EG.<br>CTION | Υ | RAM<br>SHIFTER | | Q<br>SHIFTER | | | | |----------------|----|------------|---------------|-----------------|----------------------------|-----------------|------------------------------|--------|------------------|---------------------------|-------------------------|-----------------| | 1 <sub>B</sub> | 17 | 16 | Octal<br>Code | Shift | Load | Shift | Load | ООТРИТ | RAM <sub>0</sub> | RAM <sub>3</sub><br>LI/RO | Q <sub>0</sub><br>LO/RI | Q <sub>3</sub> | | L | L | L | 0 | | | NONE | ALU<br>(F <sub>i</sub> ) | F | х | х | х | х | | L | L | н | 1 | - | - | _ | _ | F | х | х | х | х | | L | н | L | 2 | NONE | ALU<br>(F <sub>i</sub> ) | - | _ | А | × | х | × | × | | L | н | н | 3 | NONE | ALU<br>(F <sub>i</sub> ) | - | _ | F | × | × | × | × | | н | L | L | 4 | RIGHT<br>(DOWN) | ALU<br>(F <sub>i+1</sub> ) | RIGHT<br>(DOWN) | Q-REG<br>(Q <sub>i+1</sub> ) | F | F <sub>0</sub> | IN <sub>3</sub> | <b>a</b> <sub>0</sub> | IN <sub>3</sub> | | н | L | н | 5 | RIGHT<br>(DOWN) | ALU<br>(F <sub>i+1</sub> ) | - | = | F | F <sub>0</sub> | IN <sub>3</sub> | a <sub>o</sub> | × | | н | н | L | 6 | LEFT<br>(UP) | ALU<br>(F <sub>i-1</sub> ) | LEFT<br>(UP) | Q-REG<br>(Q <sub>i-1</sub> ) | F | IN <sub>O</sub> | F <sub>3</sub> | IN <sub>O</sub> | σ <sub>3</sub> | | н | н | н | 7 | LEFT<br>(UP) | ALU<br>(F <sub>i1</sub> ) | _ | _ | F | IN <sub>O</sub> | F <sub>3</sub> | × | Ο3 | X = Don't care. Electrically, the shift pin is a TTL input internally connected to a three-state output which is in the high-impedance state. Figure 4. ALU Destination Control. | / | 210 OCTAL | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | |---------------------|----------------------------------|-------|-------|--------------|------|------|-------|-------|------| | O I 5<br>A 4<br>L 3 | ALU<br>Source<br>ALU<br>Function | Α, Ω | A, B | ο, α | О, В | O, A | D, A | D, Q | D, 0 | | 0 | C <sub>n</sub> = L<br>R Plus S | A+Q | A+B | a | В | А | D+A | D+Q | D | | | Cn = H | A+Q+1 | A+B+1 | Q+1 | B+1 | A+1 | D+A+1 | D+Q+1 | D+1 | | 1 | C <sub>n</sub> = L<br>S Minus R | Q-A-1 | BA-1 | Q-1 | 8-1 | A-1 | A-D-1 | Q-D-1 | -D-1 | | | C <sub>n</sub> =H | Q-A | B-A | a | В | Α | A-D | Q-D | -D | | 2 | Cn = L<br>R Minus S | A-Q-1 | A-8-1 | <b>-</b> Q−1 | -B−1 | -A-1 | D-A-1 | D-Q-1 | D-1 | | | Cn = H | A-Q | A-B | -α | ~В | -A | D-A | D-Q | D | | 3 | RORS | ΔVQ | A∨B | Q | В | А | D∀A | DVQ | D | | 4 | R AND S | ΑΛQ | AAB | 0 | 0 | 0 | DAA | D/A | 0 | | 5 | Ř AND S | Ā∧Q | Ā∧B | a | В | А | Ō∧A | ō∧α | 0 | | 6 | R EX-OR S | A∀Q | A∀B | o | В | Α | D∀A | D∀Q | , D | | 7 | R EX-NORS | A VQ | A V B | ā | В | Ā | DVA | ĎΨQ | ö | + = Plus; - = Minus; V = OR; ∧ = AND; ¥ = EX-OR Figure 5. Source Operand and ALU Function Matrix. # **SOURCE OPERANDS AND ALU FUNCTIONS** There are eight source operand pairs available to the ALU as selected by the $I_0$ , $I_1$ , and $I_2$ instruction inputs. The ALU can perform eight functions; five logic and three arithmetic. The $I_3$ , $I_4$ , and $I_5$ instruction inputs control this function selection. The carry input, $C_n$ , also affects the ALU results when in the arithmetic mode. The $C_n$ input has no effect in the logic mode. When $I_0$ through $I_5$ and $C_n$ are viewed together, the matrix of Figure 5 results. This matrix fully defines the ALU/source operand function for each state. The ALU functions can also be examined on a "task" basis, i.e., add, subtract, AND, OR, etc. In the arithmetic mode, the carry will affect the function performed while in the logic mode, the carry will have no bearing on the ALU output. Figure 6 defines the various logic operations that the Am2901 can perform and Figure 7 shows the arithmetic functions of the device. Both carry-in LOW $\{C_n=0\}$ and carry-in HIGH $\{C_n=1\}$ are defined in these operations. | Octal<br> 543, 210 | Group | Function | |--------------------------|--------|--------------------------| | 4 0<br>4 1<br>4 5<br>4 6 | AND | A∧Q<br>A∧B<br>D∧A<br>D∧Q | | 3 0<br>3 1<br>3 5<br>3 6 | OR | AVQ<br>AVB<br>DVA<br>DVQ | | 6 0<br>6 1<br>6 5<br>6 6 | EX-OR | A∀Q<br>A∀B<br>D∀A<br>D∀Q | | 7 0<br>7 1<br>7 5<br>7 6 | EX-NOR | Ā∀Q<br>Ā∀B<br>□∀Ā<br>□∀Q | | 7 2<br>7 3<br>7 4<br>7 7 | INVERT | I CI BIAID | | 6 2<br>6 3<br>6 4<br>6 7 | PASS | Q<br>B<br>A<br>D | | 3 2<br>3 3<br>3 4<br>3 7 | PASS | Q<br>Bs<br>A<br>D | | 4 2<br>4 3<br>4 4<br>4 7 | "ZERO" | 0<br>0<br>0 | | 5 0<br>5 1<br>5 5<br>5 6 | MASK | Ā∧Q<br>Ā∧B<br>Ō∧A<br>Ō∧Q | Figure 6. ALU Logic Mode Functions. (Cn Irrelevant) | Octal | C <sub>n</sub> = 0 | (Low) | C <sub>n</sub> = 1 | (High) | |-------------------------------------|--------------------|--------------|--------------------|----------| | l <sub>543</sub> , l <sub>210</sub> | Group | Function | Group | Function | | 0 0 | | A+Q | | A+Q+1 | | 0 1 | ADD | A+B | ADD plus | A+B+1 | | 0.5 | | D+A | one | D+A+1 | | 0 6 | | D+Q | | D+Q+1 | | 0 2 | | α | | Q+1 | | 03 | PASS | В | Increment | B+1 | | 0 4 | | A | | A+1 | | 0 7 | | D | | D+1 | | 1 2 | | Q-1 | | Q | | 1 3 | Decrement | B-1 | PASS | В | | 1 4 | | A-1 | | Α | | 2 7 | | D-1 | | D | | 2 2 | | <b>–</b> Q−1 | | -a | | 2 3 | 1's Comp. | _B_1 | 2's Comp. | -В | | 2 4 | | -A-1 | (Negate) | -A | | 1 7 | | -D-1 | | -D | | 1 0 | | Q-A-1 | | Q-A | | 1 1 | Subtract | B-A-1 | Subtract | B-A | | 15 | (1's Comp) | AD-1 | (2's Comp) | A-D | | 1 6 | | Q-D-1 | | Q-D | | 2 0 | | A-Q-1 | 1 | A-Q | | 2 1 | l | A-B-1 | | A—B | | 2 5 | | D-A-1 | | D-A | | 2 6 | | D-Q-1 | L | D-Q | Figure 7. ALU Arithmetic Mode Functions. # LOGIC FUNCTIONS FOR G, P, $C_{n+4}$ , AND OVR The four signals G, P, $C_{n+4}$ , and OVR are designed to indicate carry and overflow conditions when the Am2901 is in the add or subtract mode. The table below indicates the logic equations for these four signals for each of the eight ALU functions. The R and S inputs are the two inputs selected according to Figure 2. # Definitions (+ = OR) | 1543 | Function | P | Ğ | C <sub>n+4</sub> | OVR | | | | | | | |------|----------|---------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|--|--|--|--|--|--| | 0 | R + S | P <sub>3</sub> P <sub>2</sub> P <sub>1</sub> P <sub>0</sub> | $\overline{G_3} + P_3G_2 + P_3P_2G_1 + P_3P_2P_1G_0$ | C <sub>4</sub> | C <sub>3</sub> <del>∀</del> C <sub>4</sub> | | | | | | | | 1 | S – R | | Same as R + S equations, but substitute $\overline{R_i}$ for $R_i$ in definitions | | | | | | | | | | 2 | R S | | Same as R + S equations, but substitute $\overline{S_i}$ for $S_i$ in definitions | | | | | | | | | | 3 | R∨S | LOW | $P_{3}P_{2}P_{1}P_{0}$ | $\overline{P_3P_2P_1P_0} + C_n$ | P <sub>3</sub> P <sub>2</sub> P <sub>1</sub> P <sub>0</sub> + C <sub>n</sub> | | | | | | | | 4 | R∧S | LOW | $\overline{G_3 + G_2 + G_1 + G_0}$ | G <sub>3</sub> + G <sub>2</sub> + G <sub>1</sub> + G <sub>0</sub> + C <sub>n</sub> | $\overline{G_3 + G_2 + G_1 + G_0} + \overline{C_n}$ | | | | | | | | 5 | R∧S | LOW | Same as R ∧ S equation | ns, but substitute $\overline{R_i}$ for $R_i$ in defi | nitions — | | | | | | | | 6 | R∀S | Same as $\overline{R \forall S}$ , but substitute $\overline{R_i}$ for $R_i$ in definitions | | | | | | | | | | | 7 | R∀S | $G_3 + G_2 + G_1 + G_0$ | P <sub>3</sub> G <sub>3</sub> + P <sub>3</sub> P <sub>2</sub> G <sub>2</sub> + P <sub>3</sub> P <sub>2</sub> P <sub>1</sub> G <sub>1</sub> + P <sub>3</sub> P <sub>2</sub> P <sub>1</sub> P <sub>0</sub> | $\begin{array}{c} P_3G_3 + P_3P_2G_2 + P_3P_2P_1G_1 \\ + P_3P_2P_1P_0 \ (G_0 + \overline{C_n}) \end{array}$ | Complement of<br>C <sub>n+4</sub> at left | | | | | | | + = OR Figure 8. Figure 9. Figure 10. #### PIN DEFINITIONS - A<sub>0-3</sub> The four address inputs to the register stack used to select one register whose contents are displayed through the A-port. - B<sub>0-3</sub> The four address inputs to the register stack used to select one register whose contents are displayed through the B-port and into which new data can be written when the clock goes LOW. - I<sub>0-8</sub> The nine instruction control lines to the Am2901, used to determine what data sources will be applied to the ALU (I<sub>012</sub>), what function the ALU will perform (I<sub>345</sub>), and what data is to be deposited in the Q-register or the register stack (I<sub>678</sub>). - RO/LI A shift line at the MSB of the Q register (Q<sub>3</sub>RO/LI) and the register stack (RAM<sub>3</sub>RO/LI). Electrically these lines are three-state outputs connected to TTL inputs internal to the Am2901. When the destination code on I<sub>678</sub> indicates a right shift (octal 6 or 7) the three-state outputs are enabled and the MSB of the Q register is available on the Q<sub>3</sub>RO/LI pin and the MSB of the ALU output is available on the RAM<sub>3</sub>RO/LI pin. Otherwise, the three-state outputs are OFF (high-impedance) and the pins are electrically LS-TTL inputs. When the destination code calls for a down (left) shift, the pins are used as the data inputs to the MSB of the Q register (octal 4) and RAM (octal 4 or 5). - LO/RI Shift lines like RO/LI, but at the LSB of the Q-register and RAM. These pins are tied to the RO/LI pin of the adjacent device to transfer data between devices for left and right shifts of the Q register and ALU data - D<sub>0-3</sub> Direct data inputs. A four-bit data field which may be selected as one of the ALU data sources for entering data into the Am2901. D<sub>0</sub> is the LSB. - Y<sub>0-3</sub> The four data outputs of the Am2901. These are three-state output lines. When enabled, they display either the four outputs of the ALU or the data on the A-port of the register stack, as determined by the destination code I<sub>678</sub>. - OE Output Enable. When OE is HIGH, the Y outputs are OFF; when OE is LOW, the Y outputs are active (HIGH or LOW). - P, G The carry generate and propagate outputs of the Am2901's ALU. These signals are used with the Am2902 for carry-lookahead. See Figure 8 for the logic equations. - OVR Overflow. This pin is logically the Exclusive-OR of the carry-in and carry-out of the MSB of the ALU. At the most significant end of the word, this pin indicates that the result of an arithmetic two's complement operation has overflowed into the sign-bit. See Figure 8 for logic equation. - ${\sf F}={\sf 0}$ This is an open collector output which goes HIGH (OFF) if the data on the four ALU outputs ${\sf F}_{{\sf 0}-{\sf 3}}$ are all LOW. In positive logic, it indicates the result of an ALU operation is zero. - C<sub>n</sub> The carry-in to the Am2901's ALU. - C<sub>n+4</sub> The carry-out of the Am2901's ALU. See Figure 8 for equations. - CP The clock to the Am2901. The Q register and register stack outputs change on the clock LOW-to-HIGH transition. The clock LOW time is internally the write enable to the 16 x 4 RAM which comprises the "master" latches of the register stack. While the clock is LOW, the "slave" latches on the RAM outputs are closed, storing the data previously on the RAM outputs. This allows synchronous master-slave operation of the register stack. # MAXIMUM RATINGS (Above which the useful life may be impaired) | Storage Temperature | -65°C to +150°C | |-----------------------------------------------------|---------------------------------| | Temperature (Ambient) Under Bias | –55°C to +125°C | | Supply Voltage to Ground Potential | -0.5 V to +6.3 V | | DC Voltage Applied to Outputs for HIGH Output State | -0.5 V to +V <sub>CC</sub> max. | | DC Input Voltage | -0.5 V to +5.5 V | | DC Output Current, Into Outputs | 30 mA | | DC Input Current | -30 mA to +5.0 mA | # **OPERATING RANGE** | P/N | Ambient Temperature | V <sub>CC</sub> | |--------------|---------------------|------------------| | Am2901PC, DC | 0°C to +70°C | 4.75 V to 5.25 V | | Am2901DM, FM | -55°C to +125°C | 4.50 V to 5.50 V | STANDARD SCREENING (Conforms to MIL-STD-883 for Class C Parts) | | MIL-STD-883 | | Level | | | | |-----------------------------------|-----------------------|----------------------------------------|--------------|--------------|--|--| | Step | Method | Conditions | Am2901PC, DC | Am2901DM, FM | | | | Pre-Seal Visual Inspection | 2010 | В | 100% | 100% | | | | Stabilization Bake | 1008 | C 24-hour<br>150°C | 100% | 100% | | | | Temperature Cycle | 1010 | C -65°C to +150°C<br>10 cycles | 100% | 100% | | | | Centrifuge | 2001 | B 10,000 G | 100% * | 100% | | | | Fine Leak | 1014 | A 5 x 10 -8 atm-cc/cm <sup>3</sup> | 100% * | 100% | | | | Gross Leak | 1014 | C2 Fluorocarbon | 100% * | 100% | | | | Electrical Test Subgroups 1 and 7 | 5004 | See below for definitions of subgroups | 100% | 100% | | | | Insert Additional Screening h | ere for Class B Parts | 3 | | | | | | Group A Sample Tests | | | | | | | | Subgroup 1 | | | LTPD = 5 | LTPD = 5 | | | | Subgroup 2 | | | LTPD = 7 | LTPD = 7 | | | | Subgroup 3 | | See below for | LTPD = 7 | LTPD = 7 | | | | Subgroup 7 | 5005 | definitions of subgroups | LTPD = 7 | LTPD = 7 | | | | Subgroup 8 | | | LTPD = 7 | LTPD = 7 | | | | Subgroup 9 | | | LTPD = 7 | LTPD = 7 | | | # \*Not applicable for Am2901PC # ADDITIONAL SCREENING FOR CLASS B PARTS | _ | MIL-STD-883 | | Level | |---------------------------------------------------------------------------------------|-------------|---------------------------|--------------------------------------| | Step | Method | Conditions | Am2901DMB, FMB | | Burn-In | 1015 | D 125°C<br>160 hours min. | 100% | | Electrical Test<br>Subgroup 1<br>Subgroup 2<br>Subgroup 3<br>Subgroup 7<br>Subgroup 9 | 5004 | | 100%<br>100%<br>100%<br>100%<br>100% | # **ORDERING INFORMATION** | Package | Temperature | Order | |--------------------|-----------------|----------| | Type | Range | Number | | Molded DIP | 0°C to +70°C | AM2901PC | | Hermetic DIP | 0°C to +70°C | AM2901DC | | Hermetic DIP | -55°C to +125°C | AM2901DM | | Hermetic Flat Pack | -55°C to +125°C | AM2901FM | | Dice | 0°C to +70°C | AM2901XC | GROUP A SUBGROUPS (as defined in MIL-STD-883, method 5005) | Subgroup | Parameter | Temperature | |----------|-----------|---------------------------------------| | 1 | DC | 25°C | | 2 | DC | Maximum rated temperature | | 3 | DC | Minimum rated temperature | | 7 | Function | 25°C | | 8 | Function | Maximum and minimum rated temperature | | 9 | Switching | 25°C | | 10 | Switching | Maximum Rated Temeperature | | 11 | Switching | Minimum Rated Temperature | # ELECTRICAL CHARACTERISTICS OVER OPERATING RANGE (Unless Otherwise Noted) (Group A, Subgroups 1, 2 and 3) | rameters | Description | Test Conditions (Note 1) | | | | Min. | Typ.<br>(Note 2) | Max. | Units | |-------------------|--------------------------------------------|------------------------------------------------------------------------------------------------|-------------------------------------------------------------------|----------------------|-----------------------------------|------|------------------|----------|--------| | | | | Iон = − | | | 2.4 | Ì | ļ | | | | | | Y0, Y1, | Y2, Y3 | | | | | | | | 1 | | Іон = − | | | 2.4 | | | | | | | VCC = MIN. | I <sub>OH</sub> = -800μA, OVR, P | | | 2.4 | | | Volts | | VOH | Output HIGH Voltage | VIN = VIH or VIL | I <sub>OH</sub> = -600μA, F <sub>3</sub> | | | 2.4 | | | | | | | | I <sub>OH</sub> = -600μA<br>All RO/LI, LO/RI | | | 2.4 | | | | | | | | I <sub>OH</sub> = -1.6mA, G | | | 24 | | | | | | | | | 1.6mA | , G | 2.4 | | | | | CEX | Output Leakage Current<br>for F = 0 Output | V <sub>CC</sub> = MIN., V <sub>OH</sub> = V <sub>IN</sub> = V <sub>IH</sub> or V <sub>IL</sub> | 5.50 | | | | | 250 | μA<br> | | | | | IOL = 11 | | | | | 0.5 | | | | | | | | | | | 0.5 | | | VOL | Output LOW Voltage | V <sub>CC</sub> = MIN., | IOF = 8 | | Cn+4, F=0 | | | 0.5 | Volts | | ·OL | | AIN * AIH ot AIF | | | | | | 0.5 | | | | | | 1 <sub>OL</sub> = 6.0mA, F <sub>3</sub><br>All RO/LI, LO/RI | | | | | 0.5 | | | V <sub>IE</sub> ; | Input HIGH Level | Guaranteed input log | | | | 2.0 | | | Volts | | · (F) | | voltage for all inputs | nteed input logical LOW Military | | | | | 0.7 | Volts | | VIL | Input LOW Level | voltage for all inputs | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | | | | | 0.8 | Voits | | V <sub>I</sub> | Input Clamp Voltage | VCC = MIN., IIN = - | 18mA | | | | | -1.5 | Volts | | | input outrip voids | | Clock, OE | | | - | -0.36 | | | | | | V <sub>CC</sub> = MAX.<br>V <sub>IN</sub> = 0.5V | A <sub>0</sub> , A <sub>1</sub> , A <sub>2</sub> , A <sub>3</sub> | | | | | -0.36 | mA | | | | | B <sub>0</sub> , B <sub>1</sub> , B <sub>2</sub> , B <sub>3</sub> | | | | -0.36 | | | | I <sub>1</sub> L | | | D <sub>0</sub> , D <sub>1</sub> , D <sub>2</sub> , D <sub>3</sub> | | | | | -0.72 | | | (Note 3) | Input LOW Current | | 10, 11, 12, 16, 18 | | | | | -0.36 | | | | | | 13, 14, 15, 17 | | | | , , | -0.72 | | | | | | All LO/RI, RO/LI(Note 4) | | | | | -0.8 | | | | | | Cn | | | | | -3.6 | | | | <u> </u> | | Clock, OE | | | | | 20 | | | | | | A <sub>0</sub> , A <sub>1</sub> | , A <sub>2</sub> , A | ۸3 | | | 20 | | | | | | B <sub>0</sub> , B <sub>1</sub> , B <sub>2</sub> , B <sub>3</sub> | | | | | 20 | μА | | чн | | | D <sub>0</sub> , D <sub>1</sub> , D <sub>2</sub> , D <sub>3</sub> | | | . , | | 40 | | | (Note 3) | Input HIGH Current | V <sub>CC</sub> = MAX. | 10, 11, 12, 16, 18 | | | | | 20 | | | | | V <sub>IN</sub> = 2.7V | 13, 14, 15, 17 | | | | | 40 | | | | | | All LO/RI, RO/LI (Note 4) | | | | 100 | | | | | | | Cn | | | | | 200 | | | <del></del> | Input HIGH Current | VCC = MAX., VIN | 5.5V | | | | | 1.0 | mA | | Off State | | | Y <sub>0</sub> , Y <sub>1</sub> | , | V <sub>O</sub> = 2.4V | | | 50 | 1 | | | | | Y2, Y3 | | V <sub>O</sub> = 0.5V | | | -50 | | | | Off State (High Impedance) | V <sub>CC</sub> = MAX. | | | V <sub>O</sub> = 2.4V | | | 100 | μА | | | Output Current | | All LO<br>RO/LI | | | | | <u> </u> | 1 | | | | | 1.5/ 1.5 | | V <sub>O</sub> = 0.5V<br>(Note 5) | | | -800 | | | | | | Y <sub>0</sub> , Y | , Y <sub>2</sub> , | Y3, Ğ | -6.0 | | -40 | | | | 0 Ch Ci | | Cn+4 | | | -6.0 | | -40 | · | | Isc | Output Short Circuit Current<br>(Note 4) | | OVR, P | | | -6.0 | <del> </del> | -40 | mA | | (10018 | | | F <sub>3</sub> | | | -6.0 | ļ | -40 | - | | | 1 | 1 | All RO/LI, LO/RI | | | 6.0 | 1 | -40 | I | | | | <u></u> | Milita | - | 0/ <u>F</u> 1 | -0.0 | 185 | 280 | 1 | Notes: 1. For conditions shown as MIN or MAX, use the appropriate value specified under Electrical Characteristics for the applicable device type. 2. Typical limits are at V<sub>CC</sub> = 5.0V, 25°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. 4. LO/RI and RO/LI are three-state outputs internally connected to TTL inputs. Input characteristics are measured with I<sub>678</sub> in a state such that the three-state output is OFF. ### **GUARANTEED OPERATING CONDITIONS** Tables I, II, and III below define the timing requirements of the Am2901 in a system. The Am2901 is guaranteed to function correctly over the operating range when used within the delay and set-up time constraints of these tables for the appropriate device type. The tables are divided into three types of parameters; clock characteristics, combinational delays from inputs to outputs, and set-up and hold time requirements. The latter table defines the time prior to the end of the cycle (i.e., clock LOW-to-HIGH transition) that each input must be stable to guarantee that the correct data is written into one of the internal registers. The performance of the Am2901 within the limits of these tables is guaranteed by the testing defined as "Group A, Subgroup 9" Electrical Testing. For a copy of the tests and limits used for subgroup 9, contact Advanced Micro Devices' Product Marketing. TABLE I # CYCLE TIME AND CLOCK CHARACTERISTICS | TIME | Am2901DC | Am2901DM | |--------------------------------------------------------------------------------------------------|----------|----------| | Minimum Read-Modify-Write<br>Cycle (time from selection<br>of A, B registers to end of<br>cycle) | 105 ns | 120 ns | | Maximum Clock Frequency to<br>Shift Q Register (50% duty<br>cycle) | 9,5 MHz | 8.3 MHz | | Minimum Clock LOW Time | 30 ns | 30 ns | | Minimum Clock HIGH Time | 30 ns | 30 ns | | Minimum Clock Period | 105 ns | 120 ns | TABLE II MAXIMUM COMBINATIONAL PROPAGATION DELAYS (all in ns, C<sub>L</sub> ≤ 15pF) | | Am2901DC | | | | | | | | Am2901DM | | | | | | | | |------------------------------|----------|----|------------------|------|------------|------|-----|----|----------|------|------------------|------|------------|-----|-----|----| | To Output | v | F- | | G, P | F=0 | OVR | RO, | LO | γ | E. | | G, ₽ | F=0 | OVR | RO, | LO | | From Input | Y | F3 | C <sub>n+4</sub> | G, F | RL=<br>470 | OVK | RAM | Q | • | / F3 | C <sub>n+4</sub> | G, F | RL=<br>470 | OVK | RAM | Q | | Clock _ | 115 | 85 | 100 | 100 | 110 | 95 | 105 | 60 | 125 | 95 | 110 | 110 | 120 | 105 | 115 | 65 | | A, B | 110 | 85 | 80 | 80 | 110 | - 75 | 110 | _ | 120 | 95 | 90 | 90 | 120 | 85 | 120 | | | D | 100 | 70 | 70 | 70 | 100 | 60 | 60 | _ | 110 | 80 | 75 | 75 | 110 | 65 | 65 | | | Cn | 55 | 35 | 30 | - | 50 | 40 | 55 | _ | 60 | 40 | 30 | | 55 | 45 | 60 | | | l <sub>012</sub> | 85 | 65 | 65 | 65 | 80 | 65 | 80 | | 90 | 70 | 70 | 70 | 85 | 70 | 85 | | | 1345 | 70 | 55 | 60 | 60 | 70 | 60 | 65 | _ | 75 | 60 | 65 | 65 | 75 | 65 | 70 | - | | 1678 | 55 | _ | | _ | _ | | 45 | 45 | 60 | - | _ | _ | _ | | 50 | 50 | | OE Enable/Disable | 40/25 | - | | _ | | | - | _ | 40/25 | _ | _ | - | _ | | _ | | | A bypassing<br>ALU (I = 2xx) | 60 | _ | _ | _ | _ | _ | _ | _ | 65 | - | _ | - | _ | _ | _ | | ## SET-UP AND HOLD TIMES (minimum cycles from each input) Set-up and hold times are defined relative to the clock LOW-to-HIGH edge. Inputs must be steady at all times from the set-up time prior to the clock until the hold time after the clock. The set-up times allow sufficient time to perform the correct operation on the correct data so that the correct ALU data can be written into one of the registers. Set Up and Hold Times (all in ns) (Note 1) | F 1 | Notes | Am29 | 01DC | Am2901DM | | | | |-------------------|---------|------------------------|-----------|-------------------------------|-----------|--|--| | From Input | Notes | Set-Up Time | Hold Time | Set-Up Time | Hold Time | | | | A, B<br>Source | 2, 3, 4 | 105<br>tpwL + 30 | 0 | 120<br>t <sub>pw</sub> L + 30 | 0 | | | | B Dest. | 2,4 | t <sub>pw</sub> L + 15 | 0 | t <sub>pw</sub> L + 15 | 0 | | | | D | | 100 | 0 | 110 | 0 | | | | C <sub>n</sub> | | 55 | 0 | 60 | 0 | | | | <sup>1</sup> 012 | | 85 | 0 | 90 | 0 | | | | 1345 | | 70 | 0 | 75 | 0 | | | | 1678 | 4 | t <sub>pw</sub> L + 15 | 0 | t <sub>pw</sub> L + 15 | 0 | | | | RI, LI (RAM or Q) | | 30 | 0 | 30 | 0 | | | TABLE III Notes: 1. See Figure 11 and 12. <sup>2.</sup> If the B address is used as a source operand, allow for the "A, B source" set-up time; if it is used only for the destination address, use the "B dest," set-up time. <sup>3.</sup> Where two numbers are shown, both must be met, 4. "tpwL" is the clock LOW time, Figure 11. Minimum Cycle Times from Inputs. Numbers Shown are Minimum Data Stable Times for Am2901 DC, in ns. Figure 12. Switching Waveforms for 16-Bit System Assuming A, B, D and I are all Driven from Registers with the same Propagation Delay, Clocked by the Am2901 Clock.