Evolution of the ALU
Last Edit July 11, 2001
Am2901
The Am2901C is twice as fast as the original Am2901. (Each increment
is used to indicate faster, more reliable, pin compatible devices.)
[Yes, there was an Am2901B. Each rev was a die-shrink.]
The microinstruction control required by the Am2901 is a 9-bit
field divided into 3-bit subfields.
Source Control
The selection of the operand sources via a 3-bit subfield
allows the combinations shown in Table 5-5. The combinations
QQ, DD were considered to occur too seldom and 00 was considered
trivial.
Table 5-5 Am2901 Source Selection
Pairing
|
Microcontrol
Bits I2I1I0
(Octal)
|
Comment
|
AQ
|
0
|
equivalent to BQ, QB, or QA |
AB
|
1
|
|
0Q
|
2
|
|
0B
|
3
|
|
0A
|
4
|
|
DA
|
5
|
|
DQ
|
6
|
|
D0
|
7
|
equivalent to 0D |
Function Control
The functions allowed are the simple arithmetic and
logical operations. (AMD used R and S for A and B to avoid confusion
with the A and B ports of the scratchpad.) The functions selectable
with a 3-bit subfield are in Table 5-6.
Table 5-6 Am2901 Function Selection
Operation
|
Microcontrol
Bits I2I1I0
(Octal)
|
Comment |
A + S
|
0
|
ADD |
S - R
|
1
|
SUB |
R - S
|
2
|
SUB |
R V
S
|
3
|
OR |
R AND S
|
4
|
AND |
R' AND S
|
5
|
R compliment |
R ¥ S
|
6
|
Exclusive Or (EXOR) |
R = S
|
7
|
Identity |
Destination Control
The more complex control is the destination control
field. The 3-bit field must select among up, down, and no shift
for the RAM shift register, choose if the scratchpad memory is to
be loaded, select among up, down, and no shift of the Q shift register,
choose if Q is to be loaded, and select the output MUX for ALU or
scratchpad. SInce some operations imply others, Table 5-7 simplifies
the control selection.
Table 5-7 Am2901 Destination Control
Interconnection
The Am2901 is a 4-bit slice RALU intended to two's
complement arithmetic and active high data. Any number of slices
may be connected to construct a CPU of any multiple of 4 bits width.
Figure 5-10 shows a 12-bit CPU connected using
the Cin and Cout pins in a ripple-carry configuration. Figure
5-11 shows a 16-bit CPU connected using the G and P pins of
the Am2901s and an Am2902A, a carry-lookahead unit.
Figure 5-10 12-Bit CPU Interconnection (ripple
carry)
The execution time is considerably faster using carry-lookahead.
The technique of lookahead will not be discussed further in this
text at this time.
Figure 5-11 16-bit CPU Interconnection (carry-lookahead)
|