# Am29C327 Double-Precisison Floating-Point Processor #### ADVANCE INFORMATION #### DISTINCTIVE CHARACTERISTICS - High-performance double-precision floating-point processor - Comprehensive floating-point and integer instruction sets - Single VLSI device performs single-, double-, and mixed-precision operations - Performs conversions between precisions and between data formats - Compatible with industry-standard floating-point formats - IEEE 754 format - DEC F, DEC D, and DEC G formats - IBM system/370 format - Exact IEEE compliance for denormalized numbers with no speed penalty - Eight-deep register file for intermediate results and onchip 64-bit data path facilitates compound operations; e.g., Newton-Raphson division, sum-of-products, and transcendentals - Supports pipelined or flow-through operation - Fabricated with Advanced Micro Devices' 1.2 micron CMOS process #### SIMPLIFIED SYSTEM DIAGRAM BD007470 Publication # Rev. Amendment 09418 A /0 Issue Date: August 1987 #### CONTENTS | DISTINCTIVE CHARACTERISTICS | 1 | |-------------------------------------------|----| | SIMPLIFIED BLOCK DIAGRAM | 1 | | GENERAL DESCRIPTION | 2 | | RELATED AMD PRODUCTS | 3 | | CONNECTION DIAGRAM | 3 | | PIN DESIGNATIONS | 4 | | LOGIC SYMBOL | 5 | | ORDERING INFORMATION | 5 | | PIN DESCRIPTION | 6 | | FUNCTIONAL DESCRIPTION | 6 | | Overview | 6 | | Block Diagram Description | 9 | | Mode Register Description | 10 | | Input Modes | 11 | | Pipelining of Operations | 20 | | Instruction Set | 24 | | Master/Slave Operation | 32 | | APPENDICES | | | Appendix A — Data Formats | 33 | | Appendix B — Rounding Modes | 37 | | Appendix C — Additional Operation Details | 40 | | ABSOLUTE MAXIMUM RATINGS | 41 | | OPERATING RANGES | 41 | | DC CHARACTERISTICS | 41 | | SWITCHING CHARACTERISTICS | 42 | | SWITCHING TEST CIRCUITS | 43 | | SWITCHING TEST WAVEFORMS | 44 | | SWITCHING WAVEFORMS | 45 | | PHYSICAL DIMENSIONS | 50 | #### **GENERAL DESCRIPTION** The Am29C327 double-precision floating-point processor is a single VLSI device that implements an extensive floating-point and integer instruction set, and can perform single-, double- or mixed-precision operations. The three most popular floating-point formats – IEEE, DEC, and IBM – are supported. IEEE operations comply with Standard 754, with direct implementation of special features such as gradual underflow and trap handling. The Am29C327 consists of a 64-bit ALU, a 64-bit datapath, and a control unit. The ALU has three data input ports, and can perform compound operations of the form (A \* B) + C. The data path comprises two 64-bit input operand registers, an 8-by-64-bit register file for storage of intermediate results, three operand-selection multiplexers that provide for orthogo- nal selection of input operands, a 64-bit output register, and an output multiplexer that allows access to the 32 MSBs or 32 LSBs of the result data. Control signals determine the operation to be performed, the source of operands, operand precision, rounding mode, and other aspects of device operation. Operations can be performed in either of two modes: flowthrough or pipelined. In the flow-through mode, the ALU is completely combinatorial; this mode is best suited for scalar operations. Pipelined mode divides the ALU into one or two pipelined stages, for use in vector operations, as often found in graphics or signal processing. Fabricated with AMD's 1.2 micron technology, the Am29C327 is housed in a 169-lead pin-grid-array (PGA) package. #### **RELATED AMD PRODUCTS** | Part No. | Description | | | | | | |-----------|---------------------------------------------|--|--|--|--|--| | Am29C10A | CMOS Microprogram Controller | | | | | | | Am29C116 | CMOS Minimum Power 16-Bit<br>Microprocessor | | | | | | | Am29C117 | CMOS Two-Port 16-Bit<br>Microprocessor | | | | | | | Am29PL141 | Field-Programmable Controller (FPC) | | | | | | | Am29C323 | CMOS 32-Bit Parallel Multiplier | | | | | | | Am29C325 | CMOS 32-Bit Floating-Point<br>Processor | | | | | | | Am29C331 | CMOS 16-Bit Microprogram<br>Sequencer | | | | | | | Am29C332 | CMOS 32-Bit Arithmetic Logic Unit | | | | | | | Am29C334 | CMOS Four-Port Dual-Access<br>Register File | | | | | | #### CONNECTION DIAGRAM 169-Lead PGA\* Bottom View \*Pinout observed from pin side of package. <sup>\*\*</sup>Alignment pin (not connected internally). ## PIN DESIGNATIONS (Sorted by Pin No.) | PIN NO. | PIN NAME | PIN NO. | PIN NAME | PIN NO. | PIN NAME | PIN NO. | PIN NAME | |--------------|------------|-------------|----------|---------|----------|---------|----------| | A-1 | | C-9 | | J-15 | | R-10 | | | A-2 | | C-10 | | J-16 | | R-11 | | | A-3 | | C-11 | | J-17 | | R-12 | | | A-4 | | C-12 | | K-1 | | R-13 | | | A-5 | | C-13 | | K-2 | | R-14 | | | A-6 | | C-14 | | K-3 | | R-15 | | | A-7 | | C-15 | | K-15 | | R-16 | | | A-8 | | C-16 | | K-16 | | R-17 | | | A-9 | | C-17 | | K-17 | | T-1 | | | A-10 | 3420145945 | <b>D</b> -1 | | L-1 | | T-2 | | | A-11 | | D-2 | | L-2 | | T-3 | | | A-12 | | D-3 | | L-3 | | T-4 | | | A-13 | | D-15 | <b>A</b> | L-15 | | T-5 | | | A-14 | | D-16 | ¥* | L-16 | | T-6 | | | A-15 | | D-17 | | L-17 | | T-7 | | | A-16 | | E-1 📲 | | M-1 | | T-8 | | | A-17 | | E-2 | | M-2 | | T-9 | | | B-1 | | E-3 | | M-3 | | T-10 | | | B-2 | | E-15 | | ₾ M-15 | | T-11 | | | B-3 | | E-16 | | M-16 | | T-12 | | | B-4 | | E-17 | | M-17 | | T-13 | | | B-5 | | F-1 | # | N-1 | | T-14 | | | B-6 | | F-2 | | N-2 | 4 | T-15 | | | B-7 | | F-3 | | N-3 | | T-16 | | | B-8 | | F-15 | | N-15 | | T-17 | | | B-9 | | F-16 | | N-16 | | U-1 | | | B-10 | | F-17 | | N-17 | | U-2 | | | B-11 | | G-1 | | P-1 | | U-3 | | | B-12 | | G-2 | | P-2 | | U-4 | | | B-13 | | G-3 | | P-3 | | U-5 | | | B-14 | | G-15 | | P-15 | - | U-6 | | | <b>B</b> -15 | | G-16 | | P-16 | # | U-7 | | | B-16 | | G-17 | | P-17 | | U-8 | | | B-17 | | H-1 | | R-1 | | U-9 | | | C-1 | | H-2 | | R-2 | | U-10 | | | C-2 | | H-3 | | R-3 | | U-11 | | | C-3 | | H-15 | | R-4 | | U-12 | | | C-4 | | H-16 | | R-5 | | U-13 | | | C-5 | | H-17 | | R-6 | | U-14 | | | C-6 | | J-1 | | R-7 | | U-15 | | | C-7 | | J-2 | | R-8 | | U-16 | | | C-8 | | J-3 | | R-9 | | U-17 | | #### LOGIC SYMBOL R<sub>0</sub>-R<sub>31</sub> S/DR Sn-S31 FLAG1 - FLAG6 S/DS MSERR S/DF CLK FNR ENS **ENF** ENRE ĒNI OFF **OES** RFSEL0-RFSEL2 PSEL<sub>0</sub>-PSEL<sub>3</sub> QSEL0-QSEL3 TSELO-TSEL 3 FSEL 10-113 RM<sub>0</sub>-RM<sub>2</sub> SLAVE LS003080 #### **ORDERING INFORMATION** #### Standard Products AMD standard products are available in several packages and operating ranges. The order number (Valid Combination) is formed by a combination of: a. Device Number - b. Speed Option (if applicable) - c. Package Type - d. Temperature Range - e. Optional Processing # Valid Combinations AM29C327 GC, GCB #### 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. #### PIN DESCRIPTION #### CLK Clock (Input) Clock input to all registers. #### ENF F Register Enable (Input: Active LOW) When ENF is HIGH, the contents of the F register are static. When ENF is LOW, the ALU output data is clocked into the F register on the next LOW-to-HIGH transition of CLK. Note that the F register can be made transparent by setting the mode register bit M17 HIGH (as described in the Mode Register Description section); when the F register is transparent, ENF has no effect. #### ENI Instruction Register Enable (Input; Active LOW) When ENI is LOW, an instruction word is clocked into the instruction register on the next LOW-to-HIGH transition of CLK. The instruction word comprises the following fields: P, Q, and T-multiplexer control inputs, rounding modes, ALU instruction inputs, and the precision of the output operand. #### ENR R Register Enable (Input; Active LOW) When ENR is HIGH, the contents of the R register are static. When ENR is LOW, new data is loaded into the R register on the next LOW-to-HIGH transition of CLK. #### ENRF Register File Enable (Input; Active LOW) When ENRF is HIGH, the contents of the register file are static. When ENRF is LOW, the ALU output operand is clocked into the register file on the next LOW-to-HIGH transition of CLK. #### ENS S Register Enable (Input; Active LOW) When ENS is HIGH, the contents of the S register are static. When ENS is LOW, new data is loaded into the S register on the next LOW-to-HIGH transition of CLK. #### F<sub>0</sub>-F<sub>31</sub> F Output Bus (Output) #### FLAG<sub>1</sub> - FLAG<sub>6</sub> Flag Outputs (Output) The six flag outputs report the status of the last operation executed. #### FSEL Output Multiplexer Control (Input) When FSEL is HIGH, the most significant 32 bits of the output register are connected to the output driver. When FSEL is LOW, the least significant 32 bits of the output register are connected to the output driver. #### I<sub>0</sub>-I<sub>13</sub> ALU Instruction Inputs (Input) I<sub>0</sub>-I<sub>13</sub> select the operation to be performed by the ALU. #### MSERR Master/Slave Error Flag (Output) A HIGH level indicates a master/slave error on the current output. #### F Output Bus Enable (Input; Active LOW) When $\overline{\text{OEF}}$ is HIGH, signals $F_0 - F_{31}$ assume a high-impedance state. When $\overline{\text{OEF}}$ is LOW (and $\overline{\text{SLAVE}}$ is HIGH), the output of the F multiplexer is placed on $F_0 - F_{31}$ . #### OES Flag Output Enable (Input) When $\overline{\text{OES}}$ is HIGH, outputs SIGN and FLAG<sub>1</sub> through FLAG<sub>6</sub> assume a high-impedance state. When $\overline{\text{OES}}$ is LOW (and $\overline{\text{SLAVE}}$ is HIGH), these signals are enabled. ## PSEL<sub>0</sub> - PSEL<sub>3</sub> P-Multiplexer Control Inputs (Input) PSEL<sub>0</sub> - PSEL<sub>3</sub> select the data input to the ALU P-port. QSEL<sub>0</sub> - QSEL<sub>3</sub> Q-Multiplexer Control Inputs (Input) QSEL<sub>0</sub> - QSEL<sub>3</sub> select the data input to the ALU Q-port. #### R<sub>0</sub>-R<sub>31</sub> R Input Bus (Input) #### RFSEL<sub>0</sub> - RFSEL<sub>2</sub> Register File Select (Input) $RFSEL_0 - RFSEL_2$ select the register file location (RF<sub>0</sub> - RF<sub>7</sub>) to which the ALU result is to be written. Data is written to the register file if $\overline{ENRF}$ is LOW. #### RM<sub>0</sub>-RM<sub>2</sub> Round Mode Control Inputs (Input) The Am29C327 supports six rounding modes. $RM_0 - RM_2$ select the rounding mode to be applied to the current operation. #### S<sub>0</sub>-S<sub>31</sub> S Input Bus (Input) #### S/DF F Output Single/Double Control (Input) When S/\overline{\overline{DF}} is HIGH, the ALU generates a single-precision result. When S/\overline{DF} is LOW, the ALU generates a double-precision result. #### S/DR R Input Single/Double Control (Input) When $S/\overline{DR}$ is HIGH, the data loaded into the R-port is treated as single precision. When $S/\overline{DR}$ is LOW, the data loaded into the R register is treated as double precision. #### S/DS S Input Single/Double Control (Input) When $S/\overline{DS}$ is HIGH, the data loaded into the S-port is treated as single precision. When $S/\overline{DS}$ is LOW, the data loaded into the S register is treated as double precision. #### SIGN Sign Flag (Output) If the final result of the last operation was negative, SIGN is HIGH. If the final result of the last operation was not negative, SIGN is LOW. #### SLAVE Master/Slave Mode Select (Input) When SLAVE is LOW, SLAVE mode is selected. In this mode, all outputs except MSERR are disabled. When SLAVE is HIGH, MASTER mode is selected. TSEL<sub>0</sub> – TSEL<sub>3</sub> T-Multiplexer Control Inputs (Input) TSEL<sub>0</sub> – TSEL<sub>3</sub> select the data input to the ALU T-port. #### **FUNCTIONAL DESCRIPTION** #### Overview The Am29C327 is a high-performance, single-chip, double-precision floating-point processor. #### **Architecture** The Am29C327 comprises a high-speed ALU, a 64-bit data path, and control circuitry. The core of the Am29C327 is a 64-bit floating-point/integer ALU. This ALU takes operands from three 64-bit input ports and performs the selected operation, placing the result on a 64-bit output port. Thirteen ALU flags report operation status via the 7-bit Flag port. The ALU is completely combinatorial for reduced latency; optional pipelining is available to boost throughput for array operations. The data path consists of the 32-bit input buses R and S; two 64-bit input operand registers; an 8-by-64-bit register file for storage of intermediate results; three operand-selection multiplexers that provide for orthogonal selection of input operands; a 64-bit output register; and an output multiplexer that permits the selection of 32 MSBs, or 32 LSBs of data. Input operands enter the processor through the R and S buses, and are then demultiplexed and buffered for subsequent storage in registers R and S. The operand selection multiplexers route the operands to the ALU. Operation results are stored in register F, and leave the device on the 32-bit output bus F. The results can also be stored in the register file for use in subsequent operations. #### Instruction Set The Am29C327 implements 58 arithmetic and logical instructions. Thirty-five instructions operate on floating-point numbers; these instructions fall into the following categories: - Addition/subtraction - Multiplication - Multiplication-accumulation - Comparison - Selecting the larger or smaller of two numbers - Rounding to integral value - Absolute value, negation - Reciprocal seed generation - Conversion between any of the supported floating-point formats - Conversion of a floating-point number to an integer format, with or without a scale factor - Pass operand By concatenating these operations, the user can also perform division, square-root extraction, polynomial evaluation, and other functions not implemented directly. Twenty-two instructions operate on integers, and belong to the following general categories: - Addition/subtraction - Multiplication - Comparison - Selecting the smaller or larger of two numbers - o Absolute value, negation, pass operand - Logical operations; e.g., AND, OR, XOR, NOT - · Arithmetic, logical, and funnel shifts - Conversion between single- and double-precision integer formats - Conversion of an integer number to a floating-point format, with or without a scale factor One special instruction is provided to move data. #### Mixed-Precision Operations All Am29C327 instructions, floating-point or integer, can be performed with either single- or double-precision operands. In addition, the user can elect to mix precisions within an operation. All operations are performed in double-precision internally; the user specifies the precisions of the input operands and the required precision for the output operand. The necessary precision conversions are made in concert with the selected operation, with no additional cycle-time overhead. #### I/O Modes The Am29C327 supports eight I/O modes that afford flexible interface to a variety of 32- and 64-bit systems. #### **Fault Detection Features** The Am29C327 contains special comparison hardware to allow the operation of two processors in parallel, with one processor (the slave) checking the results produced by the other (the master). This feature is of particular importance in the design of high-reliability systems. Figure 1. Am29C327 Double-Precision Floating-Point Processor #### **Block Diagram Description** A block diagram of the Am29C327 is shown in Figure 1. The Am29C327 comprises input registers, operand selection multiplexers, instruction register, ALU, output register/register file, status register, output selection multiplexer, mode register, and the master/slave comparator. #### Input Registers/Input Modes Operands enter the processor through the R and S buses, and are then demultiplexed and buffered for subsequent storage in the 65-bit registers R and S. Input operands may be either single-precision (32-bit) or double-precision (64-bit) as specified by S/DR and S/DS. Accompanying the input registers are two 32-bit temporary registers, R-Temp and S-Temp, that allow for the overlapping of operand transfers and ALU operations. This arrangement of temporary registers and demultiplexers permits data and corresponding precision bit S/DR or S/DS to be loaded into the 65-bit R register and 65-bit S register via one of the eight input modes: - 1. 32-bit-bus, double-cycle, LSWs first - 2. 32-bit-bus, double-cycle, MSWs first - 3. 32-bit-bus, single-cycle, LSWs first - 4. 32-bit-bus, single-cycle, MSWs first - 5. 64-bit-bus, double-cycle, R first - 6. 64-bit-bus, double-cycle, S first - 7. 64-bit-bus, single-cycle, R first 8. 64-bit-bus, single-cycle, S first These modes are described in detail in the Input Modes Description section. #### **Operand Selection Multiplexers** modes are described in Appendix B. The operand selection multiplexers route operands to the ALU. These multiplexers, as well as selecting operands from input registers R and S and register file locations RF0 – RF7, also have access to a set of constants (0, 0.5, 1, 2, 3, Pi). These constants are double-precision preprogrammed numbers for use in ALU operations, and are automatically provided in the appropriate floating-point or integer format. #### Instruction Register The instruction register stores a 32-bit word specifying the current processor operation. Included in the instruction word are fields that specify the P, Q, and T multiplexer selects, the rounding modes; the core operation to be performed by the ALU; sign-change controls for ALU input and result operands; and the single/double-precision control for the output operand. The multiplexer selects and the instruction word are described in detail in the Instruction Set section; Rounding #### ALU The ALU is a combinatorial arithmetic/logic unit that performs a large repertoire of floating-point and integer operations. The ALU has three operand inputs, and performs operations of the form (P\*Q) + T. Most ALU operations require only one or two input operands; for example, addition requires only operands P and T, multiplication only operands P and Q, and precision conversion only operand P. Many ALU arithmetic operations allow for the independent control of operand signs, thus greatly increasing the number of arithmetic expressions that can be evaluated in a single ALU pass. The ALU can be configured in either a flow-through mode, for which the ALU is completely combinatorial, or a pipelined mode, for which ALU operations incur one or two pipeline delays, but which results in a higher throughput than flow-through mode. A detailed description of ALU operations appears in the Instruction Set section. #### Output Register/Register File The results of the operations performed by the ALU are stored in the 64-bit output register F. Results can also be stored in the 8-by-64-bit register file for use in subsequent operations. Each register file location contains a 65th bit indicating the precision of the operand stored in that location, thus permitting the ALU to correctly process the operand in subsequent operations. #### Status Register The status register is a 7-bit register that stores flags pertaining to the most recently performed operation. A detailed description is provided in the Instruction Set section. #### **Output Multiplexer** The output multiplexer routes operation results to the F bus. This multiplexer selects the 32 MSBs of the output register or the 32 LSBs. #### Mode Register The mode register contains processor parameters that are changed infrequently. The 32-bit mode word is loaded into the register via the R bus. A detailed description of the mode register is provided in the Mode Register Description section. #### Master/Slave Comparator Each Am29C327 output signal has associated logic that compares that signal with the signal that the processor is providing internally to the output driver; any discrepancies are indicated by assertion of signal MSERR. For a single processor, this output comparison detects short circuits in output signals or defective output drivers, but does not detect open circuits. It is possible to connect a second processor in parallel with the first, with the second processor's outputs disabled by assertion of signal SLAVE. The second processor detects open-circuit signals, as well as providing a check of the outputs of the first. #### Mode Register Description The "Load Mode Register" instruction loads a 32-bit word appearing on the R port into the mode register. Data is clocked into the register on the LOW-to-HIGH transition of CLK. The register is organized as described below: M0 - M3 - Floating-Point Format Select: | M1 | MO | Primary Format | |-----------|----------------|---------------------------------------------------------------| | 0 | 0 | IEEE | | 1 | ó | DEC F (SINGLE), DEC D (DOUBLE) DEC F (SINGLE), DEC G (DOUBLE) | | 1 | 1 | IBM . | | | | | | МЗ | M2 | Alternate Format | | <b>M3</b> | <b>M2</b><br>0 | Alternate Format | | | | IEEE<br>DEC F (SINGLE), DEC D (DOUBLE) | | 0 | | IEEE | Floating-point formats are discussed in further detail in Appendix $\, A. \,$ M4 — Saturate Enable: If M4 is HIGH, overflowed results are replaced by the largest representable value in the selected format of the same sign as the overflowed result. If M4 is LOW, the result is not changed. If M6 is HIGH, saturation is disabled. M5 — IEEE Affine/Projective Select: If M5 is HIGH, affine mode is selected. If M5 is LOW, projective mode is selected. The interpretation of infinities is determined by M5. The only differences between the modes occur during the addition and subtraction of infinities. | Operation | Affine Mode | Projective Mode | |-------------|-------------|----------------------------------------------------------| | (+∞) + (+∞) | Output +∞ | Output Quiet NAN, set invalid and reserved operand flags | | (-∞) + (-∞) | Output -∞ | Output Quiet NAN, set invalid and reserved operand flags | | (+∞) - (-∞) | Output +∞ | Output Quiet NAN, set invalid and reserved operand flags | | (-∞) - (+∞) | Output -∞ | Output Quiet NAN, set invalid and reserved operand flags | If the current floating-point format is not IEEE, this bit has no effect. **M6** — **IEEE Trap Enable:** If M6 is HIGH, IEEE trapped operation is enabled; the saturate (M4) and sudden underflow (M7) bits are ignored. For an underflowed result, the exponent is replaced by e = e + 192 (SP), or e = e + 1536 (DP), with the significand unchanged. For an overflowed result, the exponent is replaced by e = e - 192 (SP), or e = e - 1536 (DP), with the significand unchanged. If M6 is LOW, IEEE trapped operation is disabled. M7 — IEEE Sudden Underflow Enable: If M7 is HIGH and IEEE traps are disabled (M6 LOW), all IEEE denormalized results are replaced by a zero of the same sign. If M7 is LOW, a valid denormalized number will be produced. This bit has no effect for formats other than IEEE. M8 — IBM Significance Mask Enable: If M8 is HIGH, certain IBM operations having intermediate results of 0 will produce a final result of 0 with the biased exponent unchanged. If M8 is LOW, these operations will produce a final result of true-zero. This bit has no effect for formats other than IBM. M9 — IBM Underflow Mask Enable: If M9 is HIGH, certain underflowed IBM operations will produce a normalized result with the exponent replaced by e + 128. If M9 is LOW, these operations will produce a final result of true-zero. This bit has no effect for formats other than IBM. M10: Reserved for future use (must be set to Logic 0) M11 — Integer Multiplication Signed/Unsigned Select: If M11 is HIGH, the input operands are treated as two's-complement numbers. If M11 is LOW, the input operands are treated as unsigned numbers. This bit has no effect for operations other than integer multiplication. M12, M13 — Integer Multiplication Format Adjust: Selects the output format for integer multiplications. The user may select either the MSBs or the LSBs of the result of an integer multiplication: | M13 | M12 | Output Format | |-----|-----|-----------------------| | 0 | 0 | LSBs | | 0 | 1 | LSBs, format-adjusted | | 1 | 0 | MSBs | | 1 | 1 | MSBs, format adjusted | "Format-adjusted" indicates that the product is shifted left one place before the MSBs or LSBs are selected. M14 - M16 - Input Mode: Selects the input bus mode: | M16 | M15 M14 Input Mode | | | | | | |-----|--------------------|---|-------------------------------------|--|--|--| | 0 | 0 | 0 | 32-bit-bus, single-cycle, LSW first | | | | | 0 | 0 | 1 | 32-bit-bus, single-cycle, MSW first | | | | | 0 | 1 | 0 | 32-bit-bus, double-cycle, LSW first | | | | | 0 | 1 | 1 | 32-bit-bus, double-cycle, MSW first | | | | | 1 | 0 | 0 | 64-bit-bus, single-cycle, R first | | | | | 1 | 0 | 1 | 64-bit-bus, single-cycle, S first | | | | | 1 | 1 | 0 | 64-bit-bus, double-cylce, R first | | | | | 1 | 1 | 1 | 64-bit-bus, double-cycle, S first | | | | Additional information on input modes can be found in the Input Modes section. M17 - F Register Feedthrough Enable: When M17 is HIGH, register F is made transparent. When M17 is LOW, the ALU output data is clocked into the F register on the next LOW-to-HIGH transition of CLK. M18 - Status Register Feedthrough Enable: When M18 is HIGH, the status register is made transparent. When M18 is LOW, the output flags are clocked into the status register on the next LOW-to-HIGH transition on CLK. M19, M20 - Pipeline Mode Select: | | M20 | M19 | Pipeline Mode | |---|-----|-----|---------------------------------------------------------------------------------------------------| | ĺ | 0 | Х | Flow-through mode | | | 1 | 0 | Single-pipeline mode for all operations | | | 1 | 1 | Double-pipeline mode for mul-<br>tiply/accumulate<br>Single-pipeline mode for other<br>operations | M21 - M31 - Reserved for factory test (must be set to Logic 0) #### Input Modes The Am29C327 supports a total of eight input modes for loading data into the R and S registers. The 32-bit bus modes allow the user to connect each input port ( $R_0-R_{31}$ and $S_0-S_{31}$ ) to separate 32-bit buses. 64-bit operands can then be loaded by placing the MSBs and LSBs alternately on the appropriate ports. In the 64-bit bus modes, the two input ports are configured internally as a single 64-bit port. The Am29C327 may then be connected directly to a 64-bit bus, and 64-bit operands may be loaded in single operation. Either the 32-bit bus modes or the 64-bit bus modes may be used regardless of the precision of the operands being transferred — the choice of input modes will in practice be determined by the system into which the Am29C327 is to be integrated. Single-cycle input modes allow two 64-bit operands to be loaded in a single clock cycle. This necessitates driving the input buses at twice the speed of the Am29C327. For systems when this is not practical, the double-cycle modes allow the loading of one 64-bit operand (or two 32-bit operands) per clock cycle. Data may be loaded from the input buses to the R register and S register using one of the eight input modes: - 1. 32-Bit Bus, Single-Cycle, LSWs First - 2. 32-Bit Bus, Single-Cycle, MSWs First - 3. 32-Bit Bus, Double-Cycle, LSWs First - 4. 32-Bit Bus, Double-Cycle, MSWs First - 5. 64-Bit Bus, Single-Cycle, R First - 6. 64-Bit Bus, Single-Cycle, S First - 7. 64-Bit Bus, Double-Cycle, R First - 8. 64-Bit Bus, Double-Cycle, S First The choice of the input modes is determined by mode register bits M14 – M16. In order to permit the loading of new operands to be overlapped with the execution of a current operation, temporary registers are provided within the "operand router" block (shown in Figure 1). The operation of these temporary registers is transparent to the user. The conditions under which they are loaded depends on the input mode selected. The eight input modes are described on the following pages. ## 32-Bit Bus, Single-Cycle, LSW First (M16 = 0, M15 = 0, M14 = 0) In this mode, the two halves of the 64-bit R operand are placed on the R-input bus in successive half-cycles, with the S operand similarly placed on the S-input port. After one complete cycle, the R and S registers contain the R and S operands, respectively. Timing of Operations with Input Mode 1 (32-Bit Bus, Single-Cycle, LSW First)\* In this mode, the temporary registers are clocked on every HIGH-to-LOW clock transition. At 1, the least-significant 32 bits of the R operand are loaded from the R-input port into the R-temp register, and the least-significant 32 bits of the S operand are loaded from the S-input port into the S-temp register. Both words are loaded on the HIGH-to-LOW transition of the clock. At 2, the most-significant 32 bits of the R operand are loaded from the R-input port into the most-significant half of the R register, and the most-significant 32 bits of the S operand are loaded from the S-input port into the most-significant half of the S register. At the same time, at 2, the output of the R-temp register is loaded into the least-significant half of the R register, and the output of the S-temp register is loaded into the least-significant half of the S register. If an input operand is single-precision, the 32-bit data is kept on the input bus for the full cycle. <sup>\*</sup>Assumes flow-through operation, F register, and S register clocked. 32-Bit Bus, Single-Cycle, MSW First (M16 = 0, M15 = 0, M14 = 1) In this mode, the two halves of the 64-bit R operand are placed on the R-input bus in successive half-cycles, with the S operand similarly placed on the S-input port. After one complete cycle, the R and S registers contain the R and S operands, respectively. Timing of Operations with Input Mode 2 (32-Bit Bus, Single-Cycle, MSW First)\* \*Assumes flow-through operation, F register, and S register clocked. In this mode, the temporary registers are clocked on every HIGH-to-LOW clock transition. At 1, the most-significant 32 bits of the R operand are loaded from the R-input port into the R-temp register, and the most-significant 32 bits of the S operand are loaded from the S-input port into the S-temp register. Both words are loaded on the HIGH-to-LOW transition of the clock. At 2, the least-significant 32 bits of the R operand are loaded from the R-input port into the least-significant half of the R register, and the least-significant 32 bits of the S operand are loaded from the S-input port into the least-significant half of the S register. At the same time, at 2, the output of the R-temp register is loaded into the most-significant half of the R register, and the output of the S-temp register is loaded into the most-significant half of the S register. If an input operand is single-precision, the 32-bit data is kept on the input bus for the full cycle. 32-Bit Bus, Double-Cycle, LSW First (M16 = 0, M15 = 1, M14 = 0) In this mode, the two halves of the 64-bit R operand are placed on the R-input bus in successive cycles, with the S operand similarly placed on the S-input port. After two cycles, the R and S registers contain the R and S operands, respectively. Timing of Operations with Input Mode 3 (32-Bit Bus, Double-Cycle, LSW First)\* \*Assumes flow-through operation, F register, and S register clocked. In this mode, the temporary registers are clocked on every LOW-to-HIGH clock transition. At 1, the least-significant 32 bits of the R operand are loaded from the R-input port into the R-temp register, and the least-significant 32 bits of the S operand are loaded from the S-input port into the S-temp register. At 2, the most-significant 32 bits of the R operand are loaded from the R-input port into the most-significant half of the R register, and the most-significant 32 bits of the S operand are loaded from the S-input port into the most-significant half of the S register. At the same time, at 2, the output of the R-temp register is loaded into the least-significant half of the R register, and the output of the S-temp register is loaded into the least-significant half of the S register. ## 32-Bit Bus, Double-Cycle, MSW First (M16 = 0, M15 = 1, M14 = 1) In this mode, the two halves of the 64-bit R operand are placed on the R-input bus in successive cycles, with the S $\,$ operand similarly placed on the S-input port. After two cycles, the R and S registers contain the R and S operands, respectively. Timing of Operations with Input Mode 4 (32-Bit Bus, Double-Cycle, MSW First)\* \*Assumes flow-through operation, F register, and S register clocked. In this mode, the temporary registers are clocked on every LOW-to-HIGH clock transition. At 1, the most-significant 32 bits of the R operand are loaded from the R-input port into the R-temp register, and the most-significant 32 bits of the S operand are loaded from the S-input port into the S-temp register. At 2, the least-significant 32 bits of the R operand are loaded from the R-input port into the least-significant half of the R register, and the least-significant 32 bits of the S operand are loaded from the S-input port into the least-significant half of the S register. At the same time, at 2, the output of the R-temp register is loaded into the most-significant half of the R register, and the output of the S-temp register is loaded into the most-significant half of the S register. ## 64-Bit Bus, Single-Cycle, R First (M16 = 1, M15 = 0, M14 = 0) In this mode, the MSW of the 64-bit R operand is placed on the R-input bus and the LSW of the S-input bus. Both halfwords are loaded in the first half cycle. Similarly, the two halves of the S operand are loaded in the second half cycle. After one full cycle, the R and S registers contain the R and S operands, respectively. Timing of Operations with Input Mode 5 (64-Bit Bus, Single-Cycle, R First)\* In this mode, the temporary registers are clocked on every HIGH-to-LOW clock transition. At 1, the most-significant 32 bits of the R operand are loaded from the R-input port into the R-temp register, and the least-significant 32 bits of the R operand are loaded from the S-input port into the S-temp register. At 2, the most-significant 32 bits of the S operand are loaded from the R-input port into the most-significant half of the S $\,$ register, and the least-significant 32 bits of the S operand are loaded from the S-input port into the least-significant half of the S register. At the same time, at 2, the output of the R-temp register is loaded into the most-significant half of the R register, and the output of the S-temp register is loaded into the least-significant half of the R register. <sup>\*</sup>Assumes flow-through operation, F register, and S register clocked. ## 64-Bit Bus, Double-Cycle, S First (M16 = 1, M15 = 0, M14 = 1) In this mode, the MSW of the 64-bit S operand is placed on the R-input bus and the LSW on the S-input bus. Both halfwords are loaded in the first half cycle. Similarly, the two halves of the R operand are loaded in the second half cycle. After one full cycle, the R and S registers contain the R and S operands, respectively. Timing of Operations with Input Mode 6 (64-Bit Bus, Single-Cycle, S First)\* \*Assumes flow-through operation, F register, and S register clocked. In this mode, the temporary registers are clocked on every HIGH-to-LOW clock transition. At 1, the most-significant 32 bits of the S operand are loaded from the R-input port into the R-temp register, and the least-significant 32 bits of the S operand are loaded from the S-input port into the S-temp register. At 2, the most-significant 32 bits of the R operand are loaded from the R-input port into the most-significant half of the R register, and the least-significant 32 bits of the R operand are loaded from the S-input port into the least-significant half of the R register. At the same time, at 2, the output of the R-temp register is loaded into the most-significant half of the S register, and the output of the S-temp register is loaded into the least-significant half of the S register. ## 64-Bit Bus, Double-Cycle, R First (M16 = 1, M15 = 1, M14 = 0) In this mode, the MSW of the 64-bit R operand is placed on the R-input bus and the LSW of the S-input bus. Both halfwords are loaded in the first cycle. Similarly, the two halves of the S operand are loaded in the second cycle. After the two cycles, the R and S registers contain the R and S operands, respectively. Timing of Operations with Input Mode 7 (64-Bit Bus, Double-Cycle, R First)\* In this mode, the temporary registers are clocked on every LOW-to-HIGH clock transition. At 1, the most-significant 32 bits of the R operand are loaded from the R-input port into the R-temp register, and the least-significant 32 bits of the R operand are loaded from the S-input port into the S-temp register. At 2, the most-significant 32 bits of the S operand are loaded from the R-input port into the most-significant half of the S register, and the least-significant 32 bits of the S operand are loaded from the S-input port into the least-significant half of the S register. At the same time, at 2, the output of the R-temp register is loaded into the most-significant half of the R register, and the output of the S-temp register is loaded into the least-significant half of the R register. <sup>\*</sup>Assumes flow-through operation, F register, and S register clocked. ## 64-Bit Bus, Double-Cycle, S First (M16 = 1, M15 = 1, M14 = 1) In this mode, the MSW of the 64-bit S operand is placed on the R-input bus and the LSW of the S-input bus. Both halfwords are loaded in the first cycle. Similarly, the two halves of the R operand are loaded in the second cycle. After the two cycles, the R and S registers contain the R and S operands, respectively. Timing of Operations with Input Mode 8 (64-Bit Bus, Double-Cycle, S First)\* \*Assumes flow-through operation, F register, and S register clocked. In this mode, the temporary registers are clocked on every LOW-to-HIGH clock transition. At 1, the most-significant 32 bits of the S operand are loaded from the R-input port inot the R-temp register, and the least-significant 32 bits of the S operand are loaded from the S-input port into the S-temp register. At 2, the most-significant 32 bits of the R operand are loaded from the R-input port into the most-significant half of the R register, and the least-significant 32 bits of the R operand are loaded from the S-input port into the least-significant half of the R register. At the same time, at 2, the output of the R-temp register is loaded into the most-significant half of the S register, and the output of the S-temp register is loaded into the least-significant half of the S register. #### Pipelining of Operations The floating-point ALU of the Am29C327 may be operated in one of three pipeline modes: - 1. Flow-Through Mode - 2. Single-Pipelined Mode - 3. Double-Pipelined Mode #### Flow-Through Mode In this mode the floating-point ALU acts as a purely combinatorial device. #### Single-Pipelined Mode In this mode the floating-point ALU contains a single pipeline delay for all operations; throughput is roughly double that for unpipelined mode. Simplified diagrams for the ALU configuration for single-pipelined mode are shown in Figure 2. #### **Double-Pipelined Mode** In this mode, which applies only to the multiplication-accumulation operation, the ALU contains two pipeline delays; throughput is roughly triple that for the unpipelined multiplication-accumulation operation. Simplified block diagrams are shown in Figure 3. Figures 4 to 8 provide timing diagrams for all operations except multiply-accumulate illustrating flow-through mode, single-pipelined mode, and double-pipelined mode, respectively. The choice of pipelining mode affects only the floating-point ALU. Operations of other parts of the Am29C327, such as the input registers, the output register, the mode register, and the instruction register are not affected by the choice of pipelining mode. However, the instruction bits are pipelined as they pass through the ALU. This permits instructions to be interleaved in pipelined mode. The desired pipeline mode or modes can be invoked by setting mode register bits M19 and M20 to the appropriate values. When using the Am29C327 in either single-pipelined or double-pipelined mode, two conditions must be observed: - The "load mode register" instruction is not pipelined, nor are any of the mode register bits. When the mode register is loaded, any differences between the current mode and the previous mode take effect immediately. In single-pipelined mode, the user should separate the last valid ALU instruction and the "load mode register" instruction with one "NO-OP" instruction. In double-pipelined mode, the user should separate them with two "NO-OP" instructions. A NO-OP instruction is any instruction whose result is not stored in register F, or the register file. - 2. A multiplication-accumulation instruction cannot be immediately followed by any other type of instruction. This problem can be avoided by inserting a "dummy" multiplication-accumulation instruction at the end of a multiplication-accumulation instruction. This "dummy" is any instruction whose results are not stored in register F or the register file. Figure 2. ALU Configuration for Single-Pipelined Mode Figure 3. ALU Configuration for Double-Pipelined Mode Figure 4. Timing for All Operations EXCEPT Multiply-Accumulate, Flow-Through Mode Figure 5. Timing for All Operations EXCEPT Multiply-Accumulate, Pipelined Mode Figure 6. Timing for Multiply-Accumulate, Flow-Through Mode Figure 7. Timing for Multiply-Accumulate, Single-Pipelined Mode Figure 8. Timing for Multiply-Accumulate, Double-Pipelined Mode #### Instruction Set #### Instruction Register Format The 14-bit instruction word $I_0 - I_{13}$ comprises sign-change controls, integer/floating-point select bit, and the opcode. | l <sub>13</sub> | l <sub>12</sub> l <sub>11</sub> | l <sub>10</sub> l <sub>9</sub> | l <sub>8</sub> l <sub>7</sub> | l <sub>6</sub> l <sub>5</sub> | l4 l3 l2 l1 l0 | | |-----------------|---------------------------------|--------------------------------|-------------------------------|-------------------------------|----------------|--| | SIGN (P) | SIGN (Q) | SIGN (T) | SIGN (F) | INT/FP | OPCODE | | The opcode field, $I_4-I_0$ , specifies the core operation to be performed by the ALU; instruction bit $I_5$ selects between floating-point and integer formats. The core operations and their corresponding opcodes are listed in Table 1. TABLE 1. CORE OPERATIONS/OPCODES | | | | | | - | | |---------------------------|-------------------------------------------|---------------------|------------------------------------------------|------------------------------------------------|-------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------| | 15 | 14 | lз | l <sub>2</sub> | l <sub>1</sub> | I <sub>0</sub> | Operation (Floating-Point) | | 0 | 0 | 0 | 0 | 0 | 0 | P | | 0 | 0 | 0 | 0 | 0 | 1 | P+T | | 0 | 0 | 0 | 0 | 1 | 0 | P * Q | | 0 | 0 | 0 | 0 | 1 | 1 | COMPARE P, T | | 0 | 0 | 0 | 1 | 0 | 0 | MAX P, T | | 0 | 0 | 0 | 1 | 0 | 1 | MIN P, T | | 0 | 0 | 0 | 1 | 1 | 0 | CONVERT T TO INTEGER | | 0 | 0 | 0 | 1 | 1 | 1 | SCALE T TO INTEGER BY Q | | 0 | 0 | 1 | 0 | 0 | 0 | (P * Q) + T | | 0 | 0 | 1 | 0 | 0 | 1 | ROUND T TO INTEGRAL VALUE | | 0 | 0 | 1 | 0 | 1 | 0 | RECIPROCAL SEED OF P | | 0 | 0 | 1 | 0 | 1 | 1 | CONVERT T TO ALTERNATE F.P. FORMAT | | 0 | 0 | 1 | 1 | 0 | 0 | CONVERT T FROM ALTERNATE F.P. FORMAT | | | | | | | | | | 15 | 14 | lз | l <sub>2</sub> | 11 | I <sub>0</sub> | Operation (Integer) | | 1 <sub>5</sub> | 0 | <b>l</b> 3 | <b>l</b> <sub>2</sub> | 0 | <b>l</b> o<br>0 | Operation (Integer) | | - | <u> </u> | | - | <u> </u> | | | | 1 | 0 | 0 | 0 | 0 | 0 | P | | 1 1 | 0 | 0 | 0 | 0 | 0 | P<br>P+T | | 1 1 1 | 0 0 | 0 0 | 0<br>0<br>0 | 0 0 1 | 0<br>1<br>0 | P<br>P+T<br>P*Q | | 1 1 1 1 | 0<br>0<br>0<br>0 | 0 0 0 | 0<br>0<br>0<br>0 | 0<br>0<br>1<br>1 | 0<br>1<br>0<br>1 | P<br>P+T<br>P*Q<br>COMPARE P, T | | 1 1 1 1 1 | 0<br>0<br>0<br>0 | 0 0 0 0 | 0<br>0<br>0<br>0 | 0<br>0<br>1<br>1 | 0<br>1<br>0<br>1<br>0 | P P+T P*Q COMPARE P, T MAX P, T MIN P, T CONVERT T TO FLOATING-POINT | | 1 1 1 1 1 1 | 0<br>0<br>0<br>0<br>0 | 0 0 0 0 0 | 0<br>0<br>0<br>0<br>1<br>1 | 0<br>0<br>1<br>1<br>0 | 0<br>1<br>0<br>1<br>0 | P P+T P*Q COMPARE P, T MAX P, T MIN P, T CONVERT T TO FLOATING-POINT SCALE T TO FLOATING-POINT BY Q | | 1 1 1 1 1 1 1 | 0<br>0<br>0<br>0<br>0 | 0 0 0 0 0 0 | 0<br>0<br>0<br>0<br>1<br>1 | 0<br>0<br>1<br>1<br>0<br>0 | 0<br>1<br>0<br>1<br>0<br>1 | P P+T P*Q COMPARE P, T MAX P, T MIN P, T CONVERT T TO FLOATING-POINT SCALE T TO FLOATING-POINT BY Q P OR T | | 1 1 1 1 1 1 1 1 1 1 1 | 0<br>0<br>0<br>0<br>0<br>0<br>0<br>0 | 0 0 0 0 0 0 0 0 0 | 0<br>0<br>0<br>0<br>1<br>1<br>1<br>1<br>0 | 0<br>0<br>1<br>1<br>0<br>0<br>1<br>1<br>0 | 0<br>1<br>0<br>1<br>0<br>1<br>0<br>1 | P P+T P*Q COMPARE P, T MAX P, T MIN P, T CONVERT T TO FLOATING-POINT SCALE T TO FLOATING-POINT BY Q P OR T P AND T | | 1 1 1 1 1 1 1 1 1 | 0<br>0<br>0<br>0<br>0<br>0<br>0 | 0 0 0 0 0 0 0 0 0 0 | 0<br>0<br>0<br>0<br>1<br>1<br>1<br>1<br>0<br>0 | 0<br>0<br>1<br>1<br>0<br>0<br>1<br>1 | 0<br>1<br>0<br>1<br>0<br>1<br>0<br>1<br>0 | P P+T P*Q COMPARE P, T MAX P, T MIN P, T CONVERT T TO FLOATING-POINT SCALE T TO FLOATING-POINT BY Q P OR T P AND T P XOR T | | 1 1 1 1 1 1 1 1 1 1 1 1 1 | 0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0 | 0 0 0 0 0 0 0 0 0 0 | 0<br>0<br>0<br>0<br>1<br>1<br>1<br>1<br>0<br>0 | 0<br>0<br>1<br>1<br>0<br>0<br>1<br>1<br>0<br>0 | 0<br>1<br>0<br>1<br>0<br>1<br>0<br>1<br>0 | P P+T P*Q COMPARE P, T MAX P, T MIN P, T CONVERT T TO FLOATING-POINT SCALE T TO FLOATING-POINT BY Q P OR T P AND T P XOR T SHIFT P LOGICAL Q PLACES | | 1 1 1 1 1 1 1 1 1 1 1 | 0<br>0<br>0<br>0<br>0<br>0<br>0<br>0 | 0 0 0 0 0 0 0 0 0 0 | 0<br>0<br>0<br>0<br>1<br>1<br>1<br>1<br>0<br>0 | 0<br>0<br>1<br>1<br>0<br>0<br>1<br>1<br>0<br>0 | 0<br>1<br>0<br>1<br>0<br>1<br>0<br>1<br>0 | P P+T P*Q COMPARE P, T MAX P, T MIN P, T CONVERT T TO FLOATING-POINT SCALE T TO FLOATING-POINT BY Q P OR T P AND T P XOR T | Core operations MOVE P and LOAD MODE REGISTER can both be performed in either floating-point or integer format: | | l <sub>5</sub> | 14 | lз | l <sub>2</sub> | l <sub>1</sub> | I <sub>0</sub> | Operation | |---|----------------|----|----|----------------|----------------|----------------|--------------------| | Γ | Х | 1 | 1 | 0 | 0 | 0 | MOVE P | | | Χ | 1 | 1 | 1 | 1 | 1 | LOAD MODE REGISTER | #### Sign-Change Selects Each ALU input and output operand has associated hardware that can be used to modify operand signs (see Figure 9). These sign-change blocks, when applied to core operations, greatly increase the number of available operations. A core operation of P+T, for example, can be used to perform operations such as P-T, ABS(P+T), ABS(P)+ABS(T), and others, simply by modifying the signs of the input and output operands. Using the sign-change blocks, the sign of an input operand may be left unchanged, inverted, set to zero, or set to one; the sign of the output operand may be left unchanged, set to zero, set to one, set to the sign of the P input operand, or set to the sign of the T input operand. Select decodes for the P, Q, T, and F operand sign-change blocks are shown in Table 2-1, 2-2, 2-3, and 2-4, respectively. Figure 9. ALU Sign-Change Blocks TABLE 2-1. SELECT DECODE FOR P OPERAND SIGN-CHANGE BLOCK | l <sub>13</sub> | 112 | Sign (P') | |-----------------|-----|-----------| | 0 | 0 | SIGN (P) | | 0 | 1 | SIGN (P) | | 1 | 0 | 0 | | 1 | 1 | 1 | TABLE 2-3. SELECT DECODE FOR T OPERAND SIGN-CHANGE BLOCK | lg | l <sub>8</sub> | Sign (T') | |-----|----------------|-----------| | 0 | 0 | SIGN T | | 0 | 1 | SIGN T | | ] 1 | 0 | 0 | | 1 | 1 | 1 | TABLE 2-2. SELECT DECODE FOR Q OPERAND SIGN-CHANGE BLOCK | 111 | I <sub>10</sub> | Sign (Q') | |-----|-----------------|-----------| | 0 | 0 | SIGN (Q) | | 0 | 1 | SIGN (Q) | | 1 | 0 | 0 | | 1 | 1 | 1 | TABLE 2-4. SELECT DECODE FOR F OPERAND SIGN-CHANGE BLOCK | Core Operation | 111 | I <sub>10</sub> | 17 | I <sub>6</sub> | Sign (F) | |----------------|-----|-----------------|----|----------------|-----------| | P, | 0 | х | 0 | 0 | SIGN (F') | | Max P, T | 0 | × | 0 | 1 | SIGN (F') | | or | 0 | × | 1 | 0 | 0 | | Min P, T | 0 | × | 1 | 1 | 1 | | | 1 | 0 | х | x | SIGN (P) | | | 1 | 1 | × | х | SIGN (T) | | | х | х | 0 | 0 | SIGN (F') | | Other | × | x | 0 | 1 | SIGN (F') | | | × | × | 1 | 0 | 0 | | | х | x | 1 | 1 | 1 | #### **Operand Multiplexer Selects** Instruction fields PSEL<sub>0</sub> - PSEL<sub>3</sub>, QSEL<sub>0</sub> - QSEL<sub>3</sub>, and TSEL<sub>0</sub> - TSEL<sub>3</sub> specify the select codes for the P, Q, and T operand multiplexers, respectively; the codes are summarized in Table 3. TABLE 3. OPERAND MULTIPLEXER SELECT CODES | PSEL <sub>3</sub><br>QSEL <sub>3</sub><br>TSEL <sub>3</sub> | PSEL <sub>2</sub><br>QSEL <sub>2</sub><br>TSEL <sub>2</sub> | PSEL <sub>1</sub><br>QSEL <sub>1</sub><br>TSEL <sub>1</sub> | PSEL <sub>0</sub><br>QSEL <sub>0</sub><br>TSEL <sub>0</sub> | P<br>Q<br>T | |-------------------------------------------------------------|-------------------------------------------------------------|-------------------------------------------------------------|-------------------------------------------------------------|--------------------------------------| | 0 | 0 | 0 | 0 | R | | 0 | 0 | 0 | 1 | S | | 0 | 0 | 1 | 0 | 0 | | 0 | 0 | 1 | 1 | 0.5 (Floating Point) | | | | | | -1 (Integer) | | 0 | 1 | 0 | 0 | 1 | | 0 | 1 | 0 | 1 | 2 | | 0 | - 1 | 1 | 0 | 3 | | 0 | 1 | 1 | 1 | Pi (Floating Point) | | | | | | Max Neg. Two's-Comp. Value (Integer) | | 1 1 | 0 | 0 | 0 | Register File Location 0 (RF0) | | 1 | 0 | 0 | 1 | Register File Location 1 (RF1) | | 1 1 | 0 | 1 | 0 | Register File Location 2 (RF2) | | 1 | 0 | 1 | 1 | Register File Location 3 (RF3) | | 1 1 | 1 | 0 | 0 | Register File Location 4 (RF4) | | 1 1 | 1 | 0 | 1 | Register File Location 5 (RF5) | | 1 | 1 | 1 | 0 | Register File Location 6 (RF6) | | 1 | 1 | 1 | 1 | Register File Location 7 (RF7) | #### **Operand Precisions** The Am29C327 supports mixed-precision operations, so that it is possible, for example, for an operation to have single-precision inputs and a double-precision output, or one single-and one double-precision input, or any other combination. Precision of the operands in registers R and S is specified by signals S/ $\overline{DR}$ and S/ $\overline{DS}$ . A logic HIGH indicates a single-precision operand or operands; a LOW, double precision. Precision of an operation result is specified by signal S/DF. A logic HIGH indicates a single-precision operand; a logic LOW, double-precision. Operands stored in the register file are each accompanied by a bit indicating that operand's precision; this precision informa- tion is automatically supplied to the ALU when a register file location is used as an input operand to an operation. #### **Processor Operations** Table 4 illustrates a number of possible ALU instructions comprising the opcode, integer/floating-point select, and sign-change fields. Note that the remaining instruction bits — P, Q, and T operand multiplexer selects; the rounding modes; and the output operand precision — can be specified independently. The user may create instructions using instruction words other than those listed in Table 4. For some core operations, sign-change control settings are completely arbitrary; for others, only the sign-change field values shown in Table 4 are valid. Table 5 summarizes permissible sign-change field values for each core operation. TABLE 4. INSTRUCTION WORDS | | | Si | | | | | |----------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|----------------------------------------------|----------------------------------------|----------------------------------------|----------------------------|----------------------------------------------------------------------| | Operation | Р | Q | Т | F | I/F | Opcode | | FP P FP -P FP ABS (P) FP Sign (T)*ABS (P) | 00<br>00<br>00<br>00 | 00<br>00<br>00<br>11 | xx<br>xx<br>xx<br>xx | 00<br>01<br>10<br>xx | 0<br>0<br>0<br>0 | 00000<br>00000<br>00000<br>00000 | | FP P+T FP P-T FP T-P FP -P-T FP ABS (P+T) FP ABS (P) + ABS (T) FP ABS (P) - ABS (T) | 00<br>00<br>01<br>01<br>00<br>00<br>10 | xx<br>xx<br>xx<br>xx<br>xx<br>xx<br>xx<br>xx | 00<br>01<br>00<br>01<br>00<br>01<br>10 | 00<br>00<br>00<br>00<br>10<br>10<br>00 | 0 0 0 0 0 0 0 0 | 00001<br>00001<br>00001<br>00001<br>00001<br>00001 | | FP ABS (ABS (P) - ABS (T)) FP P * Q FP (-P) * Q FP ABS (P * Q) | 10<br>00<br>01<br>00 | 00<br>00<br>00 | 11<br>xx<br>xx<br>xx<br>xx | 10<br>00<br>00<br>10 | 0<br>0<br>0<br>0 | 00001<br>00010<br>00010<br>00010 | | FP Compare P, T FP Max P, T FP Max ABS (P), ABS (T) | 00<br>00<br>10 | 00<br>00 | 01<br>01<br>11 | 00<br>00<br>00 | 0 0 | 00011<br>00100<br>00100 | | FP Min P, T<br>FP Min ABS (P), ABS (T) | 01<br>11 | 00<br>00 | 00<br>10 | 00<br>00 | 0<br>0 | 00101<br>00101 | | FP Limit P to Magnitude T FP Convert T to Integer FP Scale T to Integer by O | 11<br>xx | 10<br>xx | 00 | 00<br>00 | 0 | 00101 | | FP Scale T to Integer by Q FP T+P*Q FP T-P*Q FP -T+P*Q FP -T-P*Q FP ABS (T) + ABS (P*Q) FP ABS (T) - ABS (P*Q) FP ABS (P*Q) - ABS (T) | 00<br>01<br>00<br>01<br>10<br>11 | 00<br>00<br>00<br>00<br>00<br>10<br>10 | 00<br>00<br>00<br>01<br>01<br>10<br>10 | 00<br>00<br>00<br>00<br>00<br>00<br>00 | 0<br>0<br>0<br>0<br>0<br>0 | 00111<br>01000<br>01000<br>01000<br>01000<br>01000<br>01000<br>01000 | | FP Round T to Integral Value | xx | xx | 00 | 00 | 0 | 01001 | | FP Reciprocal Seed (P) FP Convert T to Alternate Floating-point Format | 00<br>xx | xx<br>xx | 00 | 00 | 0 | 01010<br>01011 | | FP Convert T from Alternate<br>Floating-point Format | xx | xx | 00 | 00 | 0 | 01100 | TABLE 4. INSTRUCTION WORDS (Cont'd.) | | | Si | gn | | | | |-----------------------------------------------------|----------------------------|----------------------------|----------------------------|----------------------------|------------------|-------------------------------------------| | Operation | Р | Q | Т | F | I/Ē | Opcode | | Int P Int -P Int ABS (P) Int sign (T)*ABS (P) | 00<br>00<br>00<br>00 | 00<br>00<br>00<br>11 | 00<br>00<br>00<br>00 | 00<br>01<br>10<br>xx | 1<br>1<br>1 | 00000<br>00000<br>00000<br>00000 | | Int P+T Int P-T Int T-P Int ABS (P+T) Int ABS (P-T) | 00<br>00<br>01<br>00<br>00 | xx<br>xx<br>xx<br>xx<br>xx | 00<br>01<br>00<br>00<br>01 | 00<br>00<br>00<br>10<br>10 | 1<br>1<br>1<br>1 | 00001<br>00001<br>00001<br>00001<br>00001 | | Int P * Q Int Compare P, T | 00<br>00 | 00<br>xx | xx<br>01 | 00<br>00 | 1 | 00010<br>00011 | | Int Max P, T | 00 | 00 | 01 | 00 | 1 | 00100 | | Int Min P, T Int Convert T to Float | 01<br>xx | 00<br>xx | 00<br>00 | 00<br>00 | 1 | 00101<br>00110 | | Int Scale T to Float by Q | xx | 00 | 00 | 00 | 1 | 00111<br>10000 | | Int PORT | xx<br>xx | xx<br>xx | xx<br>xx | xx<br>xx | 1 | 10000 | | Int P XOR T Int NOT T (see Note 1) | xx<br>xx | xx<br>xx | xx<br>xx | xx<br>xx | 1 | 10010<br>10010 | | Int Shift P Logical Q Places | 00 | 00 | xx | 00 | 1 | 10011 | | Int Shift P Arithmetic Q Places | 00 | 00 | xx | 00 | 1 | 10100 | | Int Funnel Shift PT Q Places | 00 | 00 | 00 | 00 | 1 | 10101 | | Move P | xx | xx | xx | xx | × | 11000 | | Load Mode Register | xx | xx | xx | xx | × | 11111 | Notes: 1. NOT T is performed by XORing T with a word containing all 1's (integer -1). When invoking NOT T the user must set PSEL<sub>3</sub> - PSEL<sub>0</sub> to 0011<sub>2</sub>, thus selecting integer constant -1. TABLE 5. ALLOWABLE SIGN-CHANGE/CORE-OPERATION COMBINATIONS | 1 11111 | | Sign-Change Fields | | | | | | | |---------|---------------------|--------------------|------------|----------|----------|--|--|--| | 5 43210 | Core Operation | Sign (P) | Sign (Q) | Sign (T) | Sign (F) | | | | | 0 00000 | FP P | ٧ | ٧ | × | V | | | | | 0 00001 | FP P + T | V | × | V | V | | | | | 0 00010 | FP P*Q | V | V | × | V | | | | | 0 00011 | FP Compare P, T | F | × | F | F | | | | | 0 00100 | FP Max P, T | F | F | F | F | | | | | 0 00101 | FP Min P, T | F | F | F | F | | | | | 0 00110 | FP Cvt T to Int | × | × | F | F | | | | | 0 00111 | FP Scale T to Int | × | F | F | F | | | | | 0 01000 | FP P*Q+T | V | V | V | V | | | | | 0 01001 | FP Round T | × | × | F | F | | | | | 0 01010 | FP Recip Seed P | F | × | × | F | | | | | 0 01011 | FP Cvt T to Alt Fmt | × | × | F | F | | | | | 0 01100 | FP Cvt T fm Alt Fmt | × | × | F | F | | | | | 1 00000 | Int P | F | F | F | F | | | | | 1 00001 | Int P+T | F | × | F | F | | | | | 1 00010 | Int P*Q | F | F | x | F | | | | | 1 00011 | Int Compare P, T | F | × | F | F | | | | | 1 00100 | Int Max P, T | F | F | F | F | | | | | 1 00101 | Int Min P, T | F | F | F | F | | | | | 1 00110 | Int Cvt T to f.p. | × | × | F | F | | | | | 1 00111 | Int Scale T to f.p. | × | F | F | F | | | | | 1 10000 | Int P OR T | × | <b>x</b> . | × | x | | | | | 1 10001 | Int P AND T | × | × | × | x | | | | | 1 10010 | Int P XOR T | x | × | x | x | | | | | 1 10011 | Int Shift P Logical | F | F | x | F | | | | | 1 10100 | Int Shift P Arith | F | F | × | F | | | | | 1 10101 | Int Funnel Shift PT | F | F | F | F | | | | | x 11000 | Move P | × | х | х | Х | | | | | x 11111 | Load Mode Reg | x | x | x | x | | | | Key: V = Variable; user can specify arbitrary sign change. F = Fixed; user is restricted to sign change combinations shown in Table 4. x = Don't care; this field does not affect the operation or its result. #### **Descriptions of Operations** P (Floating-Point or Integer): The operand on port P is passed through the ALU to port F. This operation may be used to change the precision of an operand, negate an operand, extract the absolute value of an operand, or transfer the sign of operand T to operand P. P+T (Floating-Point or Integer): The addition operation (P+T) adds the operands on ports P and T, and places the result on port F. $P^*Q$ (Floating-Point or Integer): The multiplication operation ( $P^*Q$ ) multiplies the operands on ports P and Q, and places the result on port F. **COMPARE P, T (Floating-Point or Integer):** This operation compares the operands on ports P and T, and places (P-T) on port F. One of four comparison flags (=, >, <, #) is set according to the result of the comparison. Note that the unordered flag (#) can be set only when the format selected is IEEE or DEC. **MAX P, T (Floating-Point or Integer):** This operation selects the most positive of the two operands on ports P and T, and places the result on port F. **MIN P, T (Floating-Point or Integer):** This operation selects the most negative of the two operands on ports P and T, and places the result on port F. LIMIT P TO MAGNITUDE T (Floating-Point): This operation imposes a clipping or saturation level on operand P by comparing the magnitudes of the operands on ports P and T. If operand P has the smaller magnitude, it is placed on port F; if operand T has the smaller magnitude, it is placed on port F, but with its sign modified to agree with that of operand P. This operation is equivalent to operation SIGN(P) \* MIN( ABS(P), ABS(T) ). **CONVERT T TO INTEGER (Floating-Point):** The floating-point-to-integer conversion operation takes a floating-point operand on port T and places the equivalent two's-complement integer value on port F. **CONVERT T TO FLOATING-POINT (Integer):** The integerto-floating-point conversion operation takes a two's-complement integer operand on port T and places the equivalent floating-point value on port F. SCALE T TO INTEGER BY Q (Floating-Point): This operation converts the floating-point operand T to integer format using the floating-point operand Q as a scale factor. The true exponent of Q is added to the true exponent of T before the new value T is converted to integer format. The operation therefore permits T to be scaled by any multiple of two when the source format is IEEE or DEC, and by any multiple of 16 when the source format is IBM. SCALE T TO FLOATING-POINT BY Q (Integer): This operation converts the integer operand T to floating-point format using the operand Q as a scale factor, where Q is a floating-point operand in the destination format. The true exponent of Q is added to the true exponent of T after T has been converted from integer to floating-point. The operation therefore permits T to be scaled by any multiple of two when the destination format is IEEE or DEC, and by any multiple of 16 when the destination format is IBM. (P\*Q) + T (Floating-Point): This operation multiplies the operands on port P and Q, adds the product to the operand on port T, and places the result on port F. ROUND T TO INTEGRAL VALUE (Floating-Point): This operation rounds a floating-point operand to an integer-valued floating-point operand of the same format. A value of 3.5, for example, would be rounded to either 3.0 or 4.0, the choice depending on the rounding mode. RECIPROCAL SEED OF P (Floating-Point): The reciprocal seed of the floating-point operand on port P is placed on port F; the result obtained is a crude estimate of the input operand's reciprocal. This operation can be used as the initial step in performing Newton-Raphson division. A single-precision result is obtained after five iterations, and a double-precision result after six iterations. Alternately, an external seed look-up table can be used for faster convergence. CONVERT T TO ALTERNATE FLOATING-POINT FORMAT (Floating-Point): This operation converts operand T from the primary floating-point format to the alternate floating-point format, thus allowing conversions among the IEEE, DEC, and IBM floating-point formats. The result obtained through iteration is approximate. CONVERT T FROM ALTERNATE FLOATING-POINT FOR-MAT (Floating-Point): This operation converts operand T from the alternate floating-point format to the primary floatingpoint format, in a manner similar to that of CONVERT T TO ALTERNATE FLOATING-POINT FORMAT above. P OR T, P AND T, P XOR T, NOT T (Integer): The logical operations (OR, AND, EXCLUSIVE OR) are performed on the operands on ports P and T, and the result is placed on port F. NOT T is performed by XORing T with a word containing all ones (integer –1). When invoking NOT T, instruction bits PSEL<sub>3</sub> – PSEL<sub>0</sub> must be set to 0011, thus selecting integer constant –1. SHIFT P LOGICAL Q PLACES (Integer): This operation logically shifts operand P by Q places. If the shift is Q places to the right, Q zeros are filled from the left. If the shift is Q places to the left, Q zeros are filled from the right. SHIFT P ARITHMETIC Q PLACES (Integer): This operation arithmetically shifts operand P by Q places. With a right shift, the result is sign extended Q places. With a left shift, Q zeros are filled from the right. **FUNNEL SHIFT PT LOGICAL Q PLACES (Integer):** The operands on ports P and T are concatenated to form a double-width operand PT, which is then shifted to the right or left by Q places; the 32- or 64-bit result is placed on port F. **MOVE P** (Floating-Point or Integer): The operand on port P is moved to port F. The operand is left unchanged, and only the sign flag is set. #### **Primary and Alternate Floating-Point Formats** All floating-point operations except format conversions are performed in the primary format selected by mode register bits M0 and M1. Conversions to the alternate format convert floating-point numbers from the primary format to the alternate format selected by mode register bits M2 and M3. Conversions from the alternate format convert floating-point data from the alternate format to the primary format. Conversions and scale operations to and from integer format operate on floating-point numbers in the primary format. #### **Operation Flags** For each operation, the ALU produces thirteen flags that indicate operation status. Of the flags produced, a maximum of seven are relevant to any given operation. The relevant flags are placed in the status register, and the other flags are discarded. The ALU flags are: **C — CARRY:** Carry-out bit produced by integer addition, subtraction, or comparison. **I — INVALID OPERATION:** Input operands are unsuitable for the operation specified (e.g., $\infty$ \* 0). **R — RESERVED OPERAND:** Reserved operand detected/ generated. S - SIGN: Result sign. U — UNDERFLOW: Result underflowed the destination format V - OVERFLOW: Result overflowed the destination format. **W — WINNER:** Indicates which of the two operands selected when performing Max/Min operations. $\mathbf{X} - \mathbf{INEXACT}$ RESULT: Result had to be rounded to fit the destination format. Z - ZERO: Zero result. >, =, <, # — GREATER THAN, EQUAL, LESS THAN, UNORDERED: Used to report the result of a comparison operation. Table 6 lists the flags reported for each operation. TABLE 6. ORGANIZATION OF FLAGS | | | | Flag Register | | | | | | V-17 | |-------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|---------------|---------------------|-----------------------------------------|-------------|-----------------------|----------------------------------------------------------|-----------------------------------------| | | | Opcode | LSB | | ı ıaç | , 1105 | ,,,,,,,,,, | | MSB | | | Operations | 14-10 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | | IEEE IEEE IEEE IEEE IEEE IEEE IEEE IEE | Non-arithmetic single-operand Operations using add Operations using multiply Compare Maximum, minimum, limit Convert/scale to integer Multiply/accumulate Round to integral value Reciprocal seed Convert to alt. f.p. format Convert from alt. f.p. format | 00000<br>00001<br>00010<br>00011<br>0010x<br>0011x<br>01000<br>01001<br>01010<br>01011 | | | V V V W V V V V V V V V V V V V V V V V | 000 8 0000 | X | Z<br>Z<br>Z<br>Z<br>Z<br>Z<br>Z<br>Z<br>Z<br>Z<br>Z<br>Z | 0000000000000 | | DEC D | Non-arithmetic single-operand Operations using add Operations using multiply Compare Maximum, minimum, limit Convert/scale to integer Multiply/accumulate Round to integral value Reciprocal seed Convert to alt. f.p. format Convert from alt. f.p. format | 00000<br>00001<br>00010<br>00011<br>0010x<br>0011x<br>01000<br>01001<br>01010<br>01011<br>01100 | 1 | R R R R R R R R R R | V V V V V V | טטט ט איטט | x<br>x<br>x<br>x<br>x | Z<br>Z<br>Z<br>Z<br>Z<br>Z<br>Z<br>Z<br>Z<br>Z | 00000000000000 | | DEC G | Non-arithmetic single-operand Operations using add Operations using multiply Compare Maximum, minimum, limit Convert/scale to integer Multiply/accumulate Round to integral value Reciprocal seed Convert to alt. f.p. format Convert from alt. f.p. format | 00000<br>00001<br>00010<br>00011<br>0010x<br>0011x<br>01000<br>01001<br>01010<br>01011<br>01100 | | R R R R R R R R R | >>># >>>>> | טככ כ איטככ | x x x x x | Z<br>Z<br>Z<br>Z<br>Z<br>Z<br>Z<br>Z<br>Z<br>Z<br>Z | 0000000000000 | | IBM | Non-arithmetic single-operand Operations using add Operations using multiply Compare Maximum, minimum, limit Convert/scale to integer Multiply/accumulate Round to integral value Reciprocal seed Convert to alt. f.p. format Convert from alt. f.p. format | 00000<br>00001<br>00010<br>00011<br>0010x<br>0011x<br>01000<br>01001<br>01010<br>01011<br>011100 | I<br>I | RR | >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> | CC C & ACC | X<br>X<br>X<br>X<br>X | Z Z Z Z Z Z Z Z Z Z Z Z Z Z Z Z Z Z Z | 000000000000000000000000000000000000000 | | Integer<br>Integer<br>Integer<br>Integer<br>Integer<br>Integer<br>Integer<br>Integer<br>Integer | Non-arithmetic single-operand Sign transfer Operations using add Operations using multiply Compare operations Maximum, minimum, limit Convert to float Scale to float Logical operations Arithmetic shift Funnel shift | 00000<br>00000<br>00001<br>00010<br>00011<br>0010x<br>00110<br>00111<br>100xx<br>10100<br>10101 | C<br>C | R | V V V V V | < W U | ><br>X<br>X | Z Z Z Z Z Z Z Z Z Z Z Z Z | 8 8 8 8 8 8 8 8 8 8 8 | | | perand ode register | 11000<br>11111 | | | | | | ı | S | Note: Unused flags assume the LOW state. # Master/Slave Operation Two Am29C327 processors can be tied together in master/slave configuration, with the slave checking the results produced by the master. All input and output signals of the slave, with the exception of SLAVE and MSERR, are tied to the corresponding signals of the master. The master is selected by asserting signal SLAVE LOW; the slave, by asserting signal SLAVE HIGH. The slave processor, by comparing its outputs to the outputs of the master processor, performs a comprehensive check of the operation of the master processor. In addition, the slave processor may detect open circuits and other faults in the electrical path between the master processor and the system. Note that the master processor still performs the comparison between its outputs and its own internally generated results, and is therefore able to detect faults in its output drivers. #### **APPENDICES** #### APPENDIX A - DATA FORMATS The following data formats are supported: 32-bit integer, 64-bit integer, IEEE single-precision, IEEE double-precision, DEC F, DEC D, DEC G, IBM single-precision, and IBM double-precision. The primary and alternate floating-point formats are selected by mode register bits M0 to M3. The user may select between floating-point operations and integer operations by means of instruction bit I5. The nine supported formats are described below: #### Integer Formats #### 32-Bit Integer The 32-bit integer word is arranged as follows: $$2^{31} 2^{30} 2^{29} 2^{28} 2^{27} 2^{26} 2^{25} \dots 2^{7} 2^{6} 2^{5} 2^{4} 2^{3} 2^{2} 2^{1} 2^{0}$$ TB001030 The 32-bit word is interpreted as a two's-complement integer. For integer multiplications, the user has the option of interpreting integers as unsigned. An unsigned single-precision integer has a format similar to that of the two's-complement integer, but with an MSB weight of 2<sup>31</sup>. #### 64-Bit Integer The 64-bit integer word is arranged as follows: $$_{-2}^{63}$$ $_{2}^{62}$ $_{2}^{61}$ $_{2}^{60}$ $_{2}^{59}$ $_{2}^{58}$ $_{2}^{57}$ . . . . . $_{2}^{7}$ $_{2}^{6}$ $_{2}^{5}$ $_{2}^{4}$ $_{2}^{3}$ $_{2}^{2}$ $_{2}^{1}$ $_{2}^{0}$ TB001040 The 64-bit word is interpreted as a two's-complement integer. For integer multiplications, the user has the option of interpreting integers as unsigned. An unsigned double-precision inte- ger has a format similar to that of the two's-complement integer, but with an MSB weight of $2^{63}$ . #### **IEEE Formats** #### **IEEE Single-Precision** The IEEE single-precision word is 32 bits wide and is arranged in the format as follows: TB001050 The floating-point word is divided into three fields: a single-bit sign, an 8-bit biased exponent, and a 23-bit fraction. The sign bit is 0 for positive numbers and 1 for negative numbers. Zero may have either sign. The biased exponent is an 8-bit unsigned integer representing a multiplicative factor of some power of two. The bias value is 127. If, for example, the multiplicative value for a floating-point number is to be $2^a$ , the value of the biased exponent is a + 127, where "a" is the true exponent. The fraction is a 23-bit unsigned fractional field containing the 23 least-significant bits of the floating-point number's 24-bit mantissa. The weight of the fraction's most-significant bit is $2^{-1}$ . The weight of the least-significant bit is $2^{-23}$ . An IEEE floating-point number is evaluated or interpreted as follows: Not-a-Number Infinity Normalized number Denormalized number Zero **Infinity:** Infinity can have either a positive or negative sign. The interpretation of infinities is determined by the Affine/Projective select input AFF/PROJ. **NaN:** A NaN is interpreted as a signal or symbol. NaNs are used to indicate invalid operations, and as a means of passing process status through a series of calculations. They arise in two ways: either generated by the Am29C327 to indicate an invalid operation, or provided by the user as an input. A signaling NaN has the MSB of its fraction set to 0 and at least one of the remaining fraction bits set to 1. A quiet NaN has the MSB of its fraction set to 1. The IEEE format is fully described in IEEE Standard 754. #### IEEE Double-Precision The IEEE double-precision word is 64 bits wide and is arranged in the format shown below: TB001060 The floating-point word is divided into three fields: a single-bit sign, an 11-bit biased exponent, and a 52-bit fraction. The sign bit is 0 for positive numbers and 1 for negative numbers; zero may have either sign. The biased exponent is an 11-bit unsigned integer representing a multiplicative factor of some power of two. The bias value is 1023. If, for example, the multiplicative value for a floating-point number is to be $2^a$ , the value of the biased exponent is a + 1023, where "a" is the true exponent. The fraction is a 52-bit unsigned fractional field containing the 52 least-significant bits of the floating-point number's 53-bit mantissa. The weight of the fraction's most-significant bit is $2^{-1}$ . The weight of the least-significant bit is $2^{-52}$ . An IEEE floating-point number is evaluated or interpreted as follows: If $$e=2047$$ and $f\neq 0$ ...... value = Reserved operand Not-a-Number If $e=2047$ and $f=0$ ..... value = $(-1)^{S_{\infty}}$ Infinity If $0 < e < 2047$ ..... value = $(-1)^{S_{2}e-1023}(1.f)$ Normalized number If $e=0$ and $f\neq 0$ .... value = $(-1)^{S_{2}-1022}(0.f)$ Denormalized number If $e=0$ and $f=0$ .... value = $(-1)^{S_{0}}$ **Infinity:** Infinity can have either a positive or negative sign. The interpretation of infinities is determined by the Affine/Projective select input AFF/ $\overline{PROJ}$ . NaN: A NaN is interpreted as a signal or symbol. NaNs are used to indicate invalid operations, and as a means of passing process status through a series of calculations. They arise in two ways: either generated by the Am29C327 to indicate an invalid operation, or provided by the user as an input. A signaling NaN has the MSB of its fraction set to 0 and at least one of the remaining fraction bits set to 1. A quiet NaN has the MSB of its fraction set to 1. The IEEE format is fully described in IEEE Standard 754. #### **DEC Formats** #### DEC F The DEC F word is 32 bits wide and is arranged in the format shown below: TB001070 The floating-point word is divided into three fields: a single-bit sign, an 8-bit biased exponent, and a 23-bit fraction. The sign bit is 0 for positive numbers and 1 for negative numbers; zero has a positive sign. The biased exponent is an 8-bit unsigned integer representing a multiplicative factor of some power of two. The bias value is 128. If, for example, the multiplicative value for a floating-point number is to be $2^a$ , the value of the biased exponent is a + 128, where "a" is the true exponent. The fraction is a 23-bit unsigned fractional field containing the 23 least-significant bits of the floating-point number's 24-bit mantissa. The weight of the fraction's most-significant bit is $2^{-2}$ . The weight of the least-significant bit is $2^{-24}$ . A DEC F floating-point number is evaluated or interpreted as follows: If $$e \neq 0$$ ....... value $\neq (-1)^s 2^{e-128} (0.1f)$ If $s = 0$ and $e = 0$ ...... value = 0 If $s = 1$ and $e = 0$ ...... value = DEC-Reserved Operand **DEC-Reserved Operand:** A DEC-Reserved Operand is interpreted as a signal or symbol. DEC-Reserved Operands are used to indicate invalid operations and operations whose results have overflowed the destination format. They may also be used to pass symbolic information from one calculation to another. The DEC formats are fully described in the VAX Architecture Manual. #### DEC D The DEC D word is 64 bits wide and is arranged in the format shown below: TB001080 The floating-point word is divided into three fields: a single-bit sign, an 8-bit biased exponent, and a 55-bit fraction. The sign bit is 0 for positive numbers and 1 for negative numbers; zero has a positive sign. The biased exponent is an 8-bit unsigned integer representing a multiplicative factor of some power of two. The bias value is 128. If, for example, the multiplicative value for a floating-point number is to be $2^a$ , the value of the biased exponent is a + 128, where "a" is the true exponent. The fraction is a 55-bit unsigned fractional field containing the 55 least-significant bits of the floating-point number's 56-bit mantissa. The weight of the fraction's most-significant bit is $2^{-2}$ . The weight of the least-significant bit is $2^{-56}$ . A DEC D floating-point number is evaluated or interpreted as follows: If s = 1 and e = 0...... value = DEC-Reserved Operand **DEC-Reserved Operand:** A DEC-Reserved Operand is interpreted as a signal or symbol. DEC-Reserved Operands are used to indicate invalid operations and operations whose results have overflowed the destination format. They may also be used to pass symbolic information from one calculation to another. The DEC formats are fully described in the VAX Architecture Manual. #### DEC G The DEC G word is 64 bits wide and is arranged in the format shown below: TB001090 The floating-point word is divided into three fields: a single-bit sign, an 11-bit biased exponent, and a 52-bit fraction. The sign bit is 0 for positive numbers and 1 for negative numbers; zero has a positive sign. The biased exponent is an 11-bit unsigned integer representing a multiplicative factor of some power of two. The bias value is 1024. If, for example, the multiplicative value for a floating-point number is to be $2^a$ , the value of the biased exponent is a + 1024, where "a" is the true exponent. The fraction is a 52-bit unsigned fractional field containing the 52 least-significant bits of the floating-point number's 53-bit mantissa. The weight of the fraction's most-significant bit is $2^{-2}$ . The weight of the least-significant bit is $2^{-53}$ . A DEC G floating-point number is evaluated or interpreted as follows: **DEC-Reserved Operand:** A DEC-Reserved Operand is interpreted as a signal or symbol. DEC-Reserved Operands are used to indicate invalid operations and operations whose results have overflowed the destination format. They may also be used to pass symbolic information from one calculation to another The DEC formats are fully described in the VAX Architecture Manual. #### **IBM Formats** #### IBM Single-Precision The IBM single-precision word is 32 bits wide and is arranged in the format shown below: TB001100 The floating-point word is divided into three fields: a single-bit sign, a 7-bit biased exponent, and a 24-bit fraction. The sign bit is 0 for positive numbers and 1 for negative numbers; a True-zero has a positive sign. The biased exponent is a 7-bit unsigned integer representing a multiplicative factor of some power of 16. The bias value is 64. If, for example, the multiplicative value for a floating-point number is to be $16^a$ , the value of the biased exponent is a + 64, where "a" is the true exponent. The fraction is a 24-bit unsigned fractional field containing the 24 least-significant bits of the floating-point number's 25-bit mantissa. The weight of the fraction's most-significant bit is $2^{-1}$ . The weight of the least-significant bit is $2^{-24}$ . An IBM floating-point number is evaluated or interpreted as follows: value = $$(-1)^{S}16^{e-64}(0.f)$$ **Zero:** There are two possible classes of representations for zero. Since there is no leading bit in the IBM format, the range of the IBM fraction is equal to or greater than zero and less than one. If an operation causes the fraction of the result to cancel exactly, then the result is a floating-point zero. A Truezero has a positive sign, a biased exponent of zero, and a fraction of zero. The IBM format is fully described in the IBM System/370 Principles of Operation Manual. #### **IBM Double-Precision** The IBM double-precision word is 64 bits wide and is arranged in the format shown below: TB001110 The floating-point word is divided into three fields: a single-bit sign, a 7-bit biased exponent, and a 56-bit fraction. The sign bit is 0 for positive numbers and 1 for negative numbers; a True-zero has a positive sign. The biased exponent is a 7-bit unsigned integer representing a multiplicative factor of some power of 16. The bias value is 64. If, for example, the multiplicative value for a floating-point number is to be $16^a$ , the value of the biased exponent is a + 64, where "a" is the true exponent. The fraction is a 56-bit unsigned fractional field containing the 56 least-significant bits of the floating-point number's 57-bit mantissa. The weight of the fraction's most-significant bit is $2^{-1}$ . The weight of the least-significant bit is $2^{-56}$ . An IBM floating-point number is evaluated or interpreted as follows: value = $$(-1)^{8}16^{e-64}(0.f)$$ **Zero:** There are two possible classes of representations for zero. Since there is no leading bit in the IBM format, the range of the IBM fraction is equal to or greater than zero and less than one. If an operation causes the fraction of the result to cancel exactly, then the result is a floating-point zero. A Truezero has a positive sign, a biased exponent of zero, and a fraction of zero. The IBM format is fully described in the IBM System/370 Principles of Operation Manual. #### APPENDIX B — ROUNDING MODES The Am29C327 provides six rounding modes for floating-point operations, and for integer multiplication: #### Round to Nearest (Unbiased) The infinitely precise result of an operation is rounded to the closest representable value in the destination format. If the infinitely precise result is exactly halfway between two representations, it is rounded to the representation having a least-significant bit of zero. This rounding mode conforms to the "round to nearest" mode described in the IEEE Floating-Point Standard. #### Round to Minus Infinity The infinitely precise result of an operation is rounded to the closest representable value in the destination format that is less than or equal to the infinitely precise result. This rounding mode conforms to the "round to minus infinity" mode described in the IEEE Floating-Point Standard. # Round to Plus Infinity The infinitely precise result of an operation is rounded to the closest representable value in the destination format that is greater than or equal to the infinitely precise result. This round mode conforms to the ''round to plus infinity'' mode described in the IEEE Floating-Point Standard. #### Round to Zero The infinitely precise result of an operation is rounded to the closest representable value in the destination format whose magnitude is less than or equal to the infinitely precise result. This rounding mode conforms to the "round to zero" mode described in the IEEE Floating-Point Standard. #### Round to Nearest (Biased) The infinitely precise result of an operation is rounded to the closest representable value in the destination format. If the infinitely precise result is exactly halfway between two representations, it is rounded to the representation having the greater magnitude. This rounding mode is used by DEC VAX computers. #### Round Away from Zero The infinitely precise result of an operation is rounded to the closest representable value in the destination format whose magnitude is greater than or equal to the infinitely precise result. A graphical representation of these rounding modes is shown in Figures B1-1 and B1-2. # APPENDIX C — ADDITIONAL OPERATION DETAILS # Differences Between IEEE Floating-Point Standard and Am29C327 IEEE Operation The IEEE floating-point standard recommends that a trapped overflow on conversion from a binary format return a result in that or a wider format, rounded to the destination format. The Am29C327 returns an operand in the destination format. rounded to that format. Note that trapped operation is an optional aspect of the IEEE floating-point standard, and as such, is not necessary for compliance. # Differences Between IBM 370 Floating-Point Arithmetic and Am29C327 IBM Operation For all arithmetic operations, the Am29C327 in general will produce a more precise result than the IBM 370. # Differences Between DEC Floating-Point Arithmetic and Am29C327 DEC Operation The Am29C327 and DEC VAX floating-point formats contain identical information, but the sub-fields of the floating-point words are arranged differently: The Am29C327 DEC F format is: sign - bit 31 exponent - bits 30 - 23 mantissa - bits 22 - 0 The Am29C327 DEC D format is: sign – bit 63 exponent – bits 62 – 55 mantissa – bits 54 – 0 The VAX format is: sign – bit 15 exponent – bits 14 – 7 mantissa – bits 6 – 0, bits 31 – 16 The VAX format is: sign – bit 15 mantissa – bits 6 – 0, bits 31 – 16, bits 47 – 32, bits 63 – 48 bit 6 = MSB, bit 48 = LSB exponent - bits 14 - 7 #### ABSOLUTE MAXIMUM RATINGS | Storage Temperature65 to +150°C Ambient Temperature (T <sub>A</sub> ) | |-----------------------------------------------------------------------| | Under Bias | | Supply Voltage to | | Ground Potential Continuous0.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 to +5.5 V | | DC Output Current, Into Outputs30 mA | | DC Input Current10 to +10 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** | Military (M) Devices Temperature (T <sub>A</sub> ) | | |-----------------------------------------------------|--| Operating ranges define those limits between which the functionality of the device is guaranteed. ## DC CHARACTERISTICS over operating range unless otherwise specified | Parameter<br>Symbol | Parameter<br>Description | Test Conditions<br>(Note 1) | Min. | Max. | Unit | |-----------------------------|-------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|------------|------| | V <sub>ОН</sub> | Output HIGH Voltage | $ \begin{array}{c} V_{CC} = \text{Min.} \\ V_{IN} = V_{IL} \text{ or } V_{IH} \\ V_{IL} = 0.8 \text{ V} \\ V_{IH} = 2.0 \text{ V} \\ I_{OH} = -0.4 \text{ mA} \\ \end{array} $ | 2.4 | | V | | V <sub>OL</sub> | Output LOW Voltage | V <sub>CC</sub> = Min.<br>V <sub>IN</sub> = V <sub>IL</sub> or V <sub>IH</sub><br>V <sub>IL</sub> = 0.8 V<br>V <sub>IH</sub> = 2.0 V<br>I <sub>OL</sub> = 4.0 mA | | 0.5 | V | | VIH | Input HIGH Level | Guaranteed Input Logical-<br>HIGH Voltage for All Inputs | 2.0 | | V | | V <sub>IL</sub> | Input LOW Level | Guaranteed Input Logical-LOW<br>Voltage for All Inputs | <i>*</i> | 0.8 | V | | VI | Input Clamp Voltage | V <sub>CC</sub> = Min.<br>I <sub>IN</sub> = -18 mA | V propin | -1.5 | ٧ | | liL | Input LOW Current | V <sub>CC</sub> = Max.<br>V <sub>IN</sub> = 0.4 V | | -0.4 | mA | | liн | Input HIGH Current | V <sub>CC</sub> = Max.<br>V <sub>IN</sub> = 2,4 V | | 75 | μΑ | | II | Input HIGH Current | V <sub>CC</sub> = Max.<br>V <sub>IN</sub> = 5.5 V | | 1 | mA | | lozh<br>lozh | Off-State (High-Impedance) Output Current | $V_{CC} = Max.$ $V_O = 2.4 V$ $V_O = 0.4 V$ | The second | 25<br>-25 | μΑ | | I <sub>SC</sub><br>(Note 2) | Output Short-Circuit Current | V <sub>CC</sub> = Max.<br>V <sub>O</sub> = 0 V<br>All Outputs | -3 | -30 | mA | | I <sub>CC</sub> (Note 3) | Power Supply Current | COM'L<br>MIL | | 300<br>350 | mA | | ICCQ1<br>(Note 4) | Quiescent Power Supply Current | COM'L<br>MIL | 1 | 7 | mA. | | ICCQ2<br>(Note 5) | Quiescent Power Supply Current | COM'L | | | mA | Notes: 1. For conditions shown as Min. or Max., use the appropriate value specified under Electrical Characteristics 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. <sup>2.</sup> Icc is measured with clock frequency = 8 MHz and with outputs disabled. Inputs should be presented with random logic-HIGHs and LOWs to assure the toggling of internal nodes. 4. VI<sub>IN</sub> ≥ VI<sub>IH</sub>, VI<sub>IN</sub> ≤ VI<sub>IL</sub> 5. VI<sub>IN</sub> ≥ V<sub>CC</sub> − 0.2 V, VI<sub>IN</sub> ≤ 0.2 V ### SWITCHING CHARACTERISTICS over operating range unless otherwise specified | No. | Parameter Description | Test Conditions | Min. | Max. | Unit | |------|---------------------------------------------------------------------------|-----------------|-------------|------------|----------| | 1 | CLK Period | (Note 1) | | | Ф. | | | Flow-Through Mode<br>Multiply-Accumulate<br>All Other Operations | | 360<br>240 | DC DC | ns<br>ns | | | Single-Pipelined Mode<br>Multiply-Accumulate<br>All Other Operations | | 240<br>120 | DC<br>DC | ns<br>ns | | | Double-Pipelined Mode<br>Multiply-Accumulate | | 120 | DC | ns | | 2 | CLK LOW Time | | O'HE | W | ns | | 3 | CLK HIGH Time | 4 | The William | P | ns | | 4 | CLK Rise Time | (Note 2) | | | ns | | 5 | CLK Fall Time | (Note 2) | Veril. | | ns | | 6 | Data/Instruction Setup Time | (Note 3) | 15 | | ns | | 7 | Data/Instruction Hold Time | (Note 3) | 0 | | ns | | 8 | Control Lines Setup Time | (Note 4) | 15 | | ns | | 9 | Control Lines Hold Time | (Note 4) | 0 | | ns | | 10 | F <sub>0-31</sub> CLK-to-Output-Valid<br>F Register Clocked | | | 20 | ns | | 11 | FLAG <sub>1 – 6</sub> SIGN CLK-to-Output-Valid<br>Register Clocked | | | 20 | ns | | 12 | F <sub>0-31</sub> CLK-to-Output-Valid<br>F Register Transparent | | | | | | | Flow-Through Mode Multiply-Accumulate All Other Operations | | | 380<br>260 | ns<br>ns | | | Single-Pipelined Mode Multiply-Accumulate All Other Operations | | | 260<br>140 | ns<br>ns | | | Double-Pipelined Mode Multiply-Accumulate | | | 140 | ns | | 13 | FLAG <sub>1-6</sub> SIGN<br>CLK-to-Output-Valid<br>S Register Transparent | | | | | | | Flow-Through Mode<br>Multiply-Accumulate<br>All Other Operations | | | 380<br>260 | ns<br>ns | | | Single-Pipelined Mode Multiply-Accumulate All Other Operations | | | 260<br>140 | ns<br>ns | | | Double-Pipelined Mode Multiply-Accumulate | | | 140 | ns | | 14 | OEF, OES, Disable Time<br>HIGH to Z | | | 15 | ns | | 15 | OEF, OES, Disable Time<br>LOW to Z | | | 15 | ns | | 16 🤻 | OEF, OES, Enable Time<br>Z to HIGH | | | 20 | ns | | 17 | OEF, OES, Disable Time<br>Z to LOW | | | 20 | ns | | 18 | FSEL to F <sub>0-31</sub> | | | 20 | ns | | 19 | MSERR Data-to-Valid Delay | | | 20 | ns | Notes: 1. CLK switching characteristics are made relative to 2.5 V. 2. CLK rise time and fall time measured between 0.8 V and (V<sub>CC</sub>-1.0 V). 3. Data/Instruction signals include R<sub>0-31</sub>, S<sub>0-31</sub>, S/DR, S/DS, S/DF, RM<sub>0-2</sub>, PSEL<sub>0-3</sub>, QSEL<sub>0-3</sub>, TSEL<sub>0-3</sub> and I0-13. 4. Control signals include ENR, ENS, ENF, ENRF, RFSEL<sub>0-2</sub>, FSEL, ENI, OEF, and OES. Conditions: A. All inputs/outputs except CLK are TTL-compatible for V<sub>IH</sub>, V<sub>IL</sub>, and V<sub>OL</sub>. B. All outputs are driving 80 pF unless otherwise noted. C. All setup, hold, and delay times are measured relative to CLK at V<sub>CC</sub>/2 volts unless otherwise noted. #### **SWITCHING TEST CIRCUITS** # 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. - 4. $C_L = 5.0$ pF for output disable tests. #### 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, Hold, and Release Times Pulse Width Notes: 1. Diagram shown for Input Control Enable-LOW and Input Control Disable-HIGH. S<sub>1</sub>, S<sub>2</sub> and S<sub>3</sub> of Load Circuit are closed except where shown. ## **Propagation Delay** #### **Enable and Disable Times** # SWITCHING WAVEFORMS KEY TO SWITCHING WAVEFORMS Timing of Operations with F Register and Status Clocked. Assumes 32-Bit Bus, Single-Cycle, LSW-First Input Mode and Flow-Through Operation # SWITCHING WAVEFORMS (Cont'd.) Timing of Operations with F-Register and Status Register in Feedthrough Mode. Assumes 32-Bit Bus, Single-Cycle, LSW-First Input Mode and Flow-Through Operation. # PHYSICAL DIMENSIONS\* CGX169 <sup>\*</sup>For reference only. #### ADVANCED MICRO DEVICES' U.S. SALES OFFICES | ALABAMA | (205) | 882-9122 | KANSAS | (913) | 451-3115 | |----------------|-------|----------|----------------|-------|----------| | ARIZONA, | • | | MARYLAND | (301) | 796-9310 | | Tempe | (602) | 242-4400 | MASSACHUSETTS | | 273-3970 | | CALIFORNIA, | ` ' | | MINNESOTA | | 938-0001 | | Culver City | (213) | 645-1524 | MISSOURI | | 275-4415 | | Newport Beach | | 752-6262 | NEW JERSEY | | 299-0002 | | San Diego | (619) | 560-7030 | NEW YORK. | (201) | 200 0002 | | Santa Clara | | 727-3270 | Liverpool | (315) | 457-5400 | | Woodland Hills | | 992-4155 | Poughkeepsie | | 471-8180 | | COLORADO | | 741-2900 | Woodbury | | 364-8020 | | CONNECTICUT | (203) | 264-7800 | NORTH CAROLINA | | 847-8471 | | FLORIDA, | () | | OREGON | | 245-0080 | | Clearwater | (813) | 530-9971 | OHIO | | 891-6455 | | Ft Lauderdale | | 484-8600 | PENNSYLVANIA, | (0) | 001 0100 | | Melbourne | | 729-0496 | Allentown | (215) | 398-8006 | | Orlando | | 859-0831 | Willow Grove | (215) | 657-3101 | | GEORGIA | | 449-7920 | TEXAS. | (2.0) | 007 0101 | | ILLINOIS. | (, | | Austin | (512) | 346-7830 | | Chicago | (312) | 773-4422 | Dallas | | 934-9099 | | Naperville | (312) | 505-9517 | Houston | | 785-9001 | | INDIÁNA | (317) | | WASHINGTON | | 455-3600 | | | ( ) | | WISCONSIN | | 792-0590 | | | | | | | | # ADVANCED MICRO DEVICES' INTERNATIONAL SALES OFFICES | BELGIUM. | IA DANI | |---------------------------------|------------------------------------------------------------| | Bruxelles TEL (02) 771 91 42 | JAPAN, | | FAX (02) 771 91 42 | Tokyo | | TLX 61028 | FAX | | CANADA, Ontario, | Osaka TEL 06-243-3250 | | Kanata TEL . (613) 592-0060 | FAX 06-243-3253 | | Willowdale TEL . (416) 224-5193 | 17.00 11.11.11.11.11.100 240 0200 | | FAX (416) 224-5193 | KOREA, Seoul TEL 82-2-784-7598 | | FRANCE, | FAX 82-2-784-8014 | | Paris TEL (01) 49-75-10-10 | LATIN AMERICA. | | FAX (01) 49-75-10-13 | Ft. Lauderdale TEL (305) 484-8600 | | TLX 263282F | FAX (305) 485-9736 | | GERMANY, | TLX 5109554261 AMDFTL | | Hannover area TEL (05143) 50 55 | 014/50 514 01 14 14 15 15 15 15 15 15 15 15 15 15 15 15 15 | | FAX (05143) 55 53 | SWEDEN, Stockholm TEL (08) 733 03 50 | | TLX 925287<br>München | FAX (08) 733 22 85 | | FAX (089) 406490 | TLX 11602 | | TLX 523883 | TAIWAN TLX 886-2-7122066 | | Stuttgart | FAX 886-2-7122007 | | FAX (0711) 625187 | UNITED KINGDOM. | | TLX 721882 | Manchester area TEL (0925) 828008 | | HONG KONG, | FAX (0925) 827693 | | Kowloon TEL 3-695377 | TLX | | FAX 1234276 | London area TEL (04862) 22121 | | TLX 504260AMDAPHX | FAX (04862) 22179 | | | TLX 859103 | | ITALY, Milano TEL (02) 3390541 | TLX 886-2-7122066 | | FAX (02) 3498000 | FAX 886-2-7122017 | | TLX 315286 | | #### **NORTH AMERICAN REPRESENTATIVES** | CALIFORNIA | | |----------------------------------------|--------------------------------------------------| | CALIFORNIA | MICHIGAN | | I <sup>2</sup> INC OEM (408) 988-3400 | SAI MARKETING CORP (313) 750-1922 | | DISTI (408) 498-6868 | MISSOURI | | CANADA | LORENZ SALES (314) 997-4558 | | Calgary, Alberta | NEBRASKA | | VITEL ELECTRONICS (403) 278-5833 | LORENZ SALES (402) 475-4660 | | Kanata, Ontario | NEW MEXICO | | VITEL ELECTRONICS (613) 592-0090 | | | Mississauga, Ontario | THORSON DESERT STATES (505) 293-8555<br>NEW YORK | | VITAL ELECTRONICS (416) 676-9720 | | | | NYCOM, INC (315) 437-8343 | | Quebec | OHIO | | VITEL ELECTRONICS (514) 636-5951 | Columbus | | IDAHO | DOLFUSS ROOT & CO (614) 885-4844 | | INTERMOUNTAIN TECH MKGT (208) 888-6071 | Dayton | | INDIANA | DOLFUSS ROOT & CO (513) 433-6776 | | SAI MARKETING CORP (317) 253-1668 | Strongsville | | IOWA | DOLFUSS ROOT & CO (216) 238-0300 | | LORENZ SALES (319) 377-4666 | PENNSYLVANIA | | KANSAS | DOLFUSS ROOT & CO (412) 221-4420 | | LORENZ SALES (913) 384-6556 | UTAH | | 20112142 0/1220 (913) 304-0000 | | | | 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. **ADVANCED MICRO DEVICES** 901 Thompson Pl., PO. Box 3453, Sunnyvale, CA 94088, USA TEL: (408) 732-2400 ● TWX: 910-339-9280 ● TELEX: 34-6306 ● TOLL FREE: (800) 538-8450