# Am29C117 16-Bit CMOS Microprocessor #### DISTINCTIVE CHARACTERISTICS - High-Speed Microprocessor - Am29C117-2 supports up to 65 ns microcycle times. - Very Low Power - Optimized for High-Performance Controllers - The architecture is optimized for controllers providing an excellent solution for applications requiring bitmanipulation power. - Flow-Through Architecture - Separate input and output ports avoid bus turnaround for higher throughput. - Instruction Set is identical to the Am29C116 - The Am29C117 has an identical architecture and instruction set with the exception of the two-port I/O structure and the additional Two-Address Immediate Instruction. - 16-Bit Barrel Shifter - 32 Working Registers - 68-Lead Pin Grid Array and Plastic Leaded Chip Carrier Packages. #### **GENERAL DESCRIPTION** The Am29C117 is a microprogrammable 16-bit CMOS microprocessor whose architecture and instruction set are identical to the Am29C116's except for the I/O bus structure. Since the device has separate input and output ports, designers can avoid quick bus turnaround requirements. The architecture and instruction set are not only optimized for high-performance peripheral controllers, but also suit- able for microprogrammed processor applications when combined with the Am29C517A 16 x 16 Multiplier. The instruction set contains unique functions besides ordinary logic and arithmetic functions: bit manipulation instructions (set, reset and test), rotate merge/compare instructions, prioritize instruction, and CRC instruction. Powered by ICminer.com Electronic-Library Service CopyRight 2003 #### **RELATED AMD PRODUCTS** | Part No. | Description | |----------------|------------------------------------------------| | Am29027 | Arithmetic Accelerator | | Am2910A | Microprogram Controller | | Am29C10A | CMOS 12-Bit Sequencer | | Am29C111 | CMOS 16-Bit Microsequencer | | Am29114 | 8-Level Real-Time Interrupt Controller | | Am29116 | 16-Bit Bipolar Microprocessor | | Am29C116/-1/-2 | 16-Bit CMOS Microprocessors | | Am29117 | 2-Port 16-Bit Microprocessor | | Am29118 | 8-Bit Am29C116 I/O Support | | Am29130 | 16-Bit Barrel Shifter | | Am2914 | Vectored Priority Interrupt Controller | | Am29PL141 | 64 x 32 Field-Programmable Controller | | Am29CPL141 | CMOS 64 Word Field-Programmable Controller | | Am29LPL141 | Low-Power Version of Am29PL141 | | Am29PL142 | 128 x 32 Field-Programmable Controller | | Am29C323 | CMOS 32-Bit Parallel Multiplier | | Am29325 | 32-Bit Floating-Point Processor | | Am29C325 | CMOS 32-Bit Floating-Point Processor | | Am29C327 | CMOS Double-Precision Floating-Point Processor | | Am29331 | 16-Bit Microprogram Sequencer | | Am29C331 | CMOS 16-Bit Microsequencer | | Am29334 | Four-Port Dual-Acccess Register File | | Am29C334 | CMOS Four-Port Dual-Access Register File | | Am29337 | 16-Bit Bounds Checker | | Am29C516A | CMOS 16 x 16 Multiplier | | Am29C517A | CMOS 2-Port 16 x 16 Multiplier | | Am29540 | Programmable FFT Address Sequencer | #### **CONNECTION DIAGRAMS** # PGA (Pins Facing Up) CD011680 # LCC\* Top View \*Also available in a 68-pin PLCC; pinout identical to LCC. V<sub>CC</sub> are power connections for the logic. V<sub>CC0</sub> are power connections for the output drivers. Note: Pin 1 is marked for orientation. #### **PGA PIN DESIGNATIONS** #### (Sorted by Pin Number) | PIN NO. | PIN NAME | PIN NO. | PIN NAME | PIN NO. | PIN NAME | PIN NO. | PIN NAME | |-------------|------------------|---------|-----------------|---------|-----------------|---------|-----------------| | A-2 | Y <sub>3</sub> | B-9 | GND | F-10 | D <sub>12</sub> | K-4 | 15 | | A-3 | Y <sub>4</sub> | B-10 | Y <sub>12</sub> | F-11 | D <sub>11</sub> | K-5 | 14 | | A-4 | Y <sub>6</sub> | B-11 | D <sub>8</sub> | G-1 | D <sub>0</sub> | K-6 | lg | | A-5 | OE <sub>Y</sub> | C-1 | NC | G-2 | l <sub>15</sub> | K-7 | l <sub>0</sub> | | A-6 | NC | C-2 | Yo | G-10 | T <sub>2</sub> | K-8 | ĪĒN | | A-7 | V <sub>CC0</sub> | C-10 | Y <sub>13</sub> | G-11 | Т1 | K-9 | СТ | | A-8 | Yg | C-11 | Y <sub>14</sub> | H-1 | 114 | K-10 | T <sub>4</sub> | | A-9 | DLE | D-1 | D <sub>5</sub> | H-2 | l <sub>13</sub> | K-11 | Т3 | | A-10 | Y <sub>11</sub> | D-2 | D <sub>6</sub> | H-10 | D <sub>13</sub> | L-2 | l <sub>8</sub> | | B-1 | Y <sub>1</sub> | D-10 | Y <sub>15</sub> | H-11 | GND | L-3 | 16 | | B-2 | Y2 | D-11 | NC | J-1 | 112 | L-4 | GND | | B-3 | D <sub>7</sub> | E-1 | D <sub>3</sub> | J-2 | 111 | L-5 | Vcc | | B-4 | Y <sub>5</sub> | E-2 | D <sub>4</sub> | J-10 | D <sub>15</sub> | L-6 | l <sub>2</sub> | | <b>B-</b> 5 | GND | E-10 | D <sub>9</sub> | J-11 | D <sub>14</sub> | L-7 | l <sub>1</sub> | | B-6 | Y <sub>7</sub> | E-11 | D <sub>10</sub> | K-1 | I <sub>10</sub> | L-8 | СР | | B-7 | Υg | F-1 | D <sub>1</sub> | K-2 | lg | L-9 | SRE | | B-8 | Y <sub>10</sub> | F-2 | D <sub>2</sub> | K-3 | 17 | L-10 | OE <sub>T</sub> | #### (Sorted by Pin Name) | PIN NO. | PIN NAME | PIN NO. | PIN NAME | PIN NO. | PIN NAME | PIN NO. | PIN NAME | |---------|-----------------|---------|-----------------|---------|-----------------|---------|------------------| | L-8 | СР | J-10 | D <sub>15</sub> | J-2 | l <sub>11</sub> | A-7 | V <sub>CC0</sub> | | K-9 | СТ | A-9 | DLE | J-1 | I <sub>12</sub> | C-2 | Y <sub>0</sub> | | G-1 | D <sub>0</sub> | B-5 | GND | H-2 | l <sub>13</sub> | B-1 | Υ1 | | F-1 | D <sub>1</sub> | L-4 | GND | H-1 | 114 | B-2 | Y <sub>2</sub> | | F-2 | D <sub>2</sub> | B-9 | GND | G-2 | 115 | A-2 | Y3 | | E-1 | D <sub>3</sub> | H-11 | GND | K-8 | ĪĒN | A-3 | Y4 | | E-2 | D <sub>4</sub> | K-7 | l <sub>0</sub> | C-1 | NC | B-4 | Y <sub>5</sub> | | D-1 | D <sub>5</sub> | L-7 | l <sub>1</sub> | D-11 | NC | A-4 | Υ <sub>6</sub> | | D-2 | D <sub>6</sub> | L-6 | l <sub>2</sub> | A-6 | NC | B-6 | Y <sub>7</sub> | | B-3 | D <sub>7</sub> | K-6 | lg | L-10 | OET | 8-7 | Y8 | | B-11 | D <sub>8</sub> | K-5 | 14 | A-5 | OEy | A-8 | Y <sub>9</sub> | | E-10 | D <sub>9</sub> | K-4 | l <sub>5</sub> | L-9 | SRE | B-8 | Y <sub>10</sub> | | E-11 | D <sub>10</sub> | L-3 | 16 | G-11 | T <sub>1</sub> | A-10 | Y <sub>11</sub> | | F-11 | D <sub>11</sub> | K-3 | 17 | G-10 | T <sub>2</sub> | B-10 | Y <sub>12</sub> | | F-10 | D <sub>12</sub> | L-2 | Ig | K-11 | Т3 | C-10 | Y <sub>13</sub> | | H-10 | D <sub>13</sub> | K-2 | lg | K-10 | T <sub>4</sub> | C-11 | Y14 | | J-11 | D <sub>14</sub> | K-1 | I <sub>10</sub> | L-5 | V <sub>CC</sub> | D-10 | Y <sub>15</sub> | $V_{CC}$ are power connections for the logic. $V_{CC0}$ are power connections for the output drivers. # 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 Co | mbinations | |------------|-------------| | AM29C117 | | | AM29C117-1 | GC, GCB, JC | | AM29C117-2 | | #### Valid Combinations Valid Combinations list configurations planned to be supported in volume for this device. Consult the local AMD sales office to confirm availability of specific valid combinations, to check on newly released combinations, and to obtain additional data on AMD's standard military grade products. #### MILITARY ORDERING INFORMATION #### **APL Products** AMD products for Aerospace and Defense applications are available in several packages and operating ranges. APL (Approved Products List) products are fully compliant with MIL-STD-883C requirements. The order number (Valid Combination) is formed by a combination of: **a. Device Number** - b. Speed Option (if applicable) - c. Device Class - d. Package Type - e. Lead Finish # Valid Combinations AM29C117-1 /BUA, /BZC #### Valid Combinations Valid Combinations list configurations planned to be supported in volume for this device. Consult the local AMD sales office to confirm availability of specific valid combinations or to check for newly released valid combinations. #### **Group A Tests** Group A tests consist of Subgroups 1, 2, 3, 7, 8, 9, 10, 11. #### PIN DESCRIPTION #### Do - D<sub>15</sub> Data Input Lines (Input) $D_0 - D_{15}$ are used as external data inputs which allow data to be directly loaded into the 16-Bit Data Latch. #### Yo - Y<sub>15</sub> Data Output Lines (Output) When $\overline{OE}_Y$ is HiGH, the 16-bit Y outputs are disabled (high impedance); having $\overline{OE}_Y$ LOW allows the ALU data to be output on $Y_0 - Y_{15}$ . #### DLE Data Latch Enable (Input) When DLE is HIGH, the 16-Bit Data Latch is transparent and is latched when DLE is LOW. #### OE<sub>Y</sub> Output Enable (Input) When $\overline{OE}_Y$ is HIGH, the 16-bit Y outputs are disabled (high impedance); when $\overline{OE}_Y$ is LOW, the 16-bit Y outputs are enabled. #### I<sub>0</sub>-I<sub>15</sub> Instruction Inputs (Input) Sixteen Instruction Inputs, used to select the operation to be performed in the Am29C117. Also used as data inputs white performing immediate instructions. #### IEN Instruction Enable (Input) When IEN is LOW, data can be written into RAM when the clock is LOW. The Accumulator can accept data during the LOW-to-HIGH transition of the clock. Having IEN LOW, the Status Register can be updated when SRE is LOW. With IEN HIGH, the conditional test output, CT, is disabled as a function of the instruction inputs. #### SRE Status Register Enable (Input) When SRE and IEN are both LOW, the Status Register is updated at the end of all instructions with the exception of NO-OP, Save Status, and Test Status. Having either SRE or IEN HIGH will inhibit the Status Register from changing. #### Clock Pulse (Input) The clock input to the Am29C117. The RAM latch is transparent when the clock is HIGH. When the clock goes LOW, the RAM output is latched. Data is written into the RAM during the LOW period of the clock, provided IEN is LOW, and if the instruction being executed designates the RAM as the destination of operation. The Accumulator and Status Register will accept data on the LOW-to-HIGH transition of the clock if IEN is also LOW. The Instruction Latch becomes transparent when it exits an immediate instruction mode during a LOW-to-HIGH transition of the clock. #### T<sub>1</sub>-T<sub>4</sub> Test I/O Pins (input/Output) Under the control of $OE_T$ , the four lower status bits, Z, C, N, and OVR become outputs on $T_1-T_4$ , respectively, when $OE_T$ goes HIGH. When $OE_T$ is LOW, $T_1-T_4$ are used as inputs to generate the CT output. #### OET Output Enable (Input) When OE<sub>T</sub> is LOW, 4-bit T outputs are disabled (high impedance); when OE<sub>T</sub> is HIGH, the 4-bit T outputs are enabled #### CT Conditional Test (Output) The condition code multiplexer selects one of the twelve condition code signals and places it on the CT output. A HIGH on the CT output indicates a passed condition and a LOW indicates a failed condition. # Suggestions for Power and Ground Pin Connections The Am29C117 operates in an environment of fast signal rise times and substantial switching currents. Therefore, care must be exercised during circuit board design and layout, as with any high-performance component. The following is a suggested layout, but since systems vary widely in electrical configuration, an empirical evaluation of the intended layout is recommended. The $V_{CC0}$ pin, which carries output driver switching currents, tends to be electrically noisy. The $V_{CC}$ pins, which supply the internal logic of the device, tend to produce less noise, and the circuits they supply may be adversely affected by noise spikes on the $V_{CC}$ plane. For this reason, it is best to provide isolation between the $V_{CC0}$ and $V_{CC}$ pins, as well as independent decoupling for each; isolating the GND pins is not required. #### Printed Circuit Board Layout Suggestions - Use of a multilayer PC board with separate V<sub>CC</sub>, GND, and signal planes is highly recommended. - 2. The V<sub>CCO</sub> and V<sub>CC</sub> pins should be connected to the V<sub>CC</sub> plane. The V<sub>CCO</sub> pin should be isolated from the V<sub>CC</sub> pins by means of a slot cut in the V<sub>CC</sub> plane (see suggested layout diagram that follows). By physically separating the V<sub>CCO</sub> and V<sub>CC</sub> pins, coupled noise will be reduced. - All GND pins should be connected directly to the ground plane. - 4. The V<sub>CCO</sub> pin should be decoupled to ground with a 0.1-μF ceramic capacitor and a 10-μF electrolytic capacitor, placed as closely to the Am29C117 as is practical. The V<sub>CC</sub> pins should be decoupled to ground in a similar manner. - A suggested layout is shown below: #### **Bottom View** ♣ = V<sub>CC</sub> Plane Connection■ = Through Hole C<sub>1</sub> = C<sub>3</sub> = 0.1 μF $C_2 = C_4 = 10 \mu F$ CD011690 Suggested PC Board Layout #### Architecture of the Am29C117 The Am29C117 is a high-performance, microprogrammable 16-bit CMOS microprocessor. As shown in the Detailed Block Diagram (Figure 1), the device consists of the following elements interconnected with 16-bit data paths. - 32-Word by 16-Bit RAM - Accumulator - Data Latch - Barrel Shifter - Arithmetic Logic Unit (ALU) - Priority Encoder - Status Register - Condition-Code Generator/Multiplexer - Three-State Output Buffers - Instruction Latch and Decoder #### 32-Word by 16-Bit RAM The 32-Word by 16-Bit RAM is a single-port RAM with a 16-bit latch at its output. The latches are transparent when the clock input (CP) is HIGH and latched when the clock input is LOW. Data is written into the RAM while the clock is LOW if the IEN input is also LOW and if the instruction being executed defines the RAM as the destination of the operation. For byte instructions, only the lower 8 RAM bits are written into; for word instructions, all 16 bits are written into. With the use of an external multiplexer on five of the instruction inputs, it is possible to select separate read and write addresses for the same instruction. #### **Accumulator** The 16-bit Accumulator is an edge-triggered register. The Accumulator accepts data on the LOW-to-HIGH transition of the clock input if the IEN input is LOW and if the instruction being executed defines the Accumulator as the destination of the operation. For byte instructions, only the lower 8 bits of the Accumulator are written into; for word instructions, all 16 bits are written into. #### Data Latch The 16-bit Data Latch holds the data input to the Am29C117 on the D bus. The latch is transparent when the DLE input is HIGH and latched when the DLE input is LOW. #### **Barrel Shifter** A 16-bit Barrel Shifter is used as one of the ALU inputs. This permits rotating data from either the RAM, the Accumulator, or the Data Latch up to 15 positions. In the word mode, the Barrel Shifter rotates a 16-bit word; in the byte mode, it rotates only the lower 8 bits. #### Arithmetic Logic Unit (ALU) The Am29C117 contains a 16-bit ALU with full carry lookahead across all 16 bits in the arithmetic mode. The ALU is capable of operating on either one, two, or three operands, depending upon the instruction being executed. It has the ability to execute all conventional one- and two-operand operations, such as pass, complement, two's complement, add, subtract, AND, NAND, OR, NOR, EXOR, and EX-NOR. In addition, the ALU can also execute three-operand instructions such as Rotate and Merge, and Rotate and Compare with Mask. All ALU operations can be performed on either a word or byte basis; byte operations being performed on the lower eight bits only. The ALU produces three status outputs, C (carry), N (negative), and OVR (overflow). The appropriate flags are generated at the byte or word level, depending upon whether the device is executing in the byte or word mode. The Z (zero) flag, although not generated by the ALU, detects zero at both the byte and word level. The carry input to the ALU is generated by the Carry Multiplexer, which can select an input of zero, one, or the stored carry bit from the Status Register, QC. Using QC as the carry input allows execution of multiprecision addition and subtractions. #### **Priority Encoder** The Priority Encoder produces a binary-weighted code to indicate the locations of the highest order ONE at its input. The input to the Priority Encoder is generated by the ALU which performs an AND operation on the operand to be prioritized and a mask. The mask determines which bit locations to eliminate from prioritization. In the word mode, if no bit is HIGH, the output is a binary zero. If bit 15 is HIGH, the output is a binary one. Bit 14 produces a binary two, etc. Finally, if only bit 0 is HIGH, a binary 16 is produced. In the byte mode, bits 8 through 15 do not participate. If none of bits 7 through 0 are HIGH, the output is a binary zero. If bit 7 is HIGH, a binary one is produced. Bit 6 produces a binary two, etc. Finally, if only bit 0 is HIGH, a binary 8 is produced. #### Status Register The Status Register holds the 8-bit status word. With the Status-Register Enable (SRE) input LOW and the IEN input LOW, the Status Register is updated at the end of all instructions except NO-OP, Save-Status, and Test-Status instructions. SRE going HIGH or IEN going HIGH inhibits the Status Register from changing. The lower four bits of the Status Register contain the ALU status bits of Zero (Z), Carry (C), Negative (N), and Overflow (OVR). The upper four bits contain a Link bit and three user-definable status bits (Flag1, Flag2, Flag3). With SRE LOW and IEN LOW, the lower four status bits are updated after each instruction except those mentioned above: NO-OP, Save Status, Status Test, and the Status Set/Reset instruction for the upper four bits. Under the same conditions, the upper four status bits are changed only during their respective Status Set/Reset instructions and during Status Load instructions in the word mode. The Link-Status bit is also updated after each shift instruction. The Status Register can be loaded from the internal Y-Bus, and can also be selected as a source for the internal Y-Bus. When the Status Register is loaded in the word mode, all 8 bits are updated; in the byte mode, only the lower 4 bits (Z, C, N, OVR) are updated. When the Status Register is selected as a source in the word mode, all eight bits are loaded into the lower byte of the destination; the upper byte of the destination is loaded with all zeros. In the byte mode, the Status Register again loads into the lower byte of the destination, but the upper byte remains unchanged. This Store and Load combination allows saving and restoring the Status Register for interrupt and subroutine processing. The four lower status bits (Z, C, N, OVR) can be read directly via the bidirectional T-Bus. These four bits are available as outputs on the $T_{1-4}$ outputs whenever $\text{OE}_{\text{T}}$ is HIGH. #### Condition-Code Generator/Multiplexer The Condition-Code Generator/Multiplexer contains the logic necessary to develop the 12 condition-code test signals. The multiplexer portion can select one of these test signals and place it on the CT output for use by the microprogram sequencer. The Multiplexer may be addressed in two different ways. One way is through the Test Instruction. This instruction specifies the test condition to be placed in the CT output, but does not allow an ALU operation at the same time. The second method uses the bidirectional T-Bus as an input. This requires extra bits in the microword, but provides the ability to simultaneously test and execute. The test instruction lines, $l_{0-4}$ , have priority over $T_{1-4}$ for testing status. #### Three-State Output Buffers There are two sets of Three-State Output Buffers in the Am29C117. One set controls the 16-bit Y-Bus. These outputs are enabled by placing a LOW on the $\overline{\text{OE}}_{Y}$ input. The second set of Three-State Output Buffers controls the bidirectional 4-bit T-Bus and is enabled by placing a HIGH on the OET input. This allows storing the four internal ALU status bits (Z, C, N, OVR) externally. A LOW OET input forces the T outputs into the high-impedance state. External devices can then drive the T-Bus to select a test condition for the CT output. #### Instruction Set The instruction set of the Am29C117 is very powerful. In addition to the single- and two-operand logical and arithmetic instructions, the Am29C117 instruction set contains functions particularly useful in controller applications: bit set, bit reset, bit test, rotate and merge, rotate and compare, and cyclic-redundancy-check (CRC) generation. Complex instructions like Rotate and Merge, Rotate and Compare, and Prioritize are executed in a single mircocycle. Three data types are supported by the Am29C117. - Bit - Byte - Word (16-bit) In the byte mode data is written into the lower half of the word and the upper half is unchanged. The special case is when the Status Register is specified as the destination. In the byte mode, the LSH (OVR, N, C, Z) of the Status Register is updated; and in the word mode, all eight bits of the Status Register are updated. The Status Register does not change for Save Status and Test Status instructions. In the Test #### Instruction Latch and Decoder The 16-bit Instruction Latch is normally transparent to allow decoding of the instruction inputs by the Instruction Decoder into the internal control signals for the Am29C117. All instructions except Immediate Instructions are executed in a single clock cycle. Immediate instructions require two clock cycles for execution. During the first clock cycle, the Instruction Decoder recognizes that an immediate instruction is being specified and captures the data on the instruction inputs in the Instruction Latch. During the second clock cycle, the data on the instruction inputs is used as one of the operands for the function specified during the first clock cycle. At the end of the second clock cycle, the Instruction Latch is returned to its transparent state. Status instructions the CT output has the result and the Y-Bus is undefined. The Am29C117 Instruction Set can be divided into eleven types of instructions. These are: - Single Operand - Two Operand - Single Bit Shift - Rotate and Merge - Rotate by n Bits - Bit Oriented - Rotate and Compare - Prioritize - Cyclic-Redundancy-Check - Status - No-Operation (NO-OP) Each instruction type is arbitrarily divided into quadrants. Two of the sixteen instruction lines decode to four quadrants labeled from 0 to 3. The quadrants were defined mainly for convenience in classification of the instruction set and addressing modes, and can be used together with the opcodes to distinguish the instructions. The following pages describe each of the instruction types in detail. Table 1 illustrates Operand Source-Destination Combinations for each instruction type. TABLE 1. OPERAND SOURCE-DESTINATION COMBINATIONS | Instruction Type | Operand | d Combinati | ons (Note 1) | | | |-----------------------|----------------------------------|----------------------------------|----------------------------------------------------|--|--| | | Source | (R/S) | Destination | | | | Single Operand | A(<br>[<br>D(( | Note 2)<br>CC<br>C<br>DE)<br>SE) | RAM<br>ACC<br>Y-Bus<br>Status<br>ACC and<br>Status | | | | | ( | ) | | | | | | Source (R) | Source (S) | Destination | | | | Two Operand | RAM<br>RAM<br>D<br>D<br>ACC<br>D | ACC<br>I<br>RAM<br>ACC<br>I | RAM ACC Y-Bus Status ACC and Status | | | | | Source | e (U) | Destination | | | | Single Bit Shift | RA<br>AC<br>E | AM<br>CC<br>CC<br>CC | RAM<br>ACC<br>Y-Bus<br>RAM<br>ACC<br>Y-Bus | | | | | Source | (R/S) | Destination | | | | Bit Oriented | RA<br>AC | | RAM<br>ACC<br>Y-Bus | | | | | Source | e (U) | Destination | | | | Rotate By n Bits | RA<br>AC | CC | RAM<br>ACC<br>Y-Bus | | | | | Rotated<br>Source (U) | Mask (S) | Non-Rotated<br>Source/<br>Destination (R) | | | | Rotate and Merge | D<br>D<br>D<br>D<br>ACC<br>RAM | RAM<br> <br>AGC<br> | ACC<br>ACC<br>RAM<br>RAM<br>RAM<br>ACC | | | | 2 | Rotated<br>Source (U) | Mask (S) | Non-Rotated<br>Source/<br>Destination (R) | | | | Rotate and<br>Compare | D<br>D<br>D<br>RAM | I<br>ACC<br>I | RAM<br>RAM<br>ACC | | | | Instruction Type | Operand | d Combination | ons (Note 1) | | | | | | | |---------------------------|-----------------|----------------------------------------------|-----------------------------|--|--|--|--|--|--| | | Source (R) | Mask (S) | Destination | | | | | | | | Prioritize (Note 3) | RAM<br>ACC<br>D | RAM<br>ACC<br>I<br>0 | RAM<br>ACC<br>Y-Bus | | | | | | | | Cyclic- | Data In | Destination | Polynomial | | | | | | | | Redundancy-Check<br>(CRC) | QLINK RAM ACC | | | | | | | | | | | | Bits Affect | ted | | | | | | | | Set Reset Status | | OVR, N, C<br>LINK<br>Flag1<br>Flag2<br>Flag3 | ;, Z | | | | | | | | | Sou | ırce | Destination | | | | | | | | Store Status | Sta | itus | RAM<br>ACC<br>Y-Bus | | | | | | | | <u> </u> | Source (R) | Source (S) | Destination | | | | | | | | Status Load | D<br>ACC | ACC<br>- | Status<br>Status and<br>ACC | | | | | | | | | D | 1 | | | | | | | | | | Te | est Condition | | | | | | | | | : | | (N⊕OVR)<br>N⊕OVR | | | | | | | | | | | z | | | | | | | | | | | OVR<br>Low | | | | | | | | | Test Status | | C | | | | | | | | | | | Z+ Ĉ<br>N | | | | | | | | | | | LINK | | | | | | | | | | Flag1 | | | | | | | | | | | Flag2<br>Flag3 | | | | | | | | | | No Operation<br>(NO-OP) | _ | | | | | | | | | Notes: 1. When there is no dividing line between the R & S Operand or Source and Destination, the two must be used as a given pair. But where there exists such a separation, any combination of them is possible. In the Single Operand Instruction, RAM cannot be used when both Accumulator (ACC) and Status are designated as a Destination. <sup>3.</sup> In the Prioritize Instruction, Operand and Mask must be different sources. #### Single Operand Instructions The Single Operand Instructions contain four indicators: Byte or Word mode, Opcode, Source, and Destination. They are further subdivided into two types. The first type uses RAM as a source or destination or both, and the second type does not use RAM as a source or destination. Both types have different instruction formats as shown below. Under the control of instruction inputs, the desired function is performed on the source and the result is either stored in the specified destination or placed on the Y-Bus, or both. For a special case where 8-bit to 16-bit conversion is needed, the Am29C117 is capable of extending sign bit (D(SE)) or binary zero (D(0E)) over 16 bits in the word mode. The least significant four bits of the Status Register (OVR, N, C, Z) are affected by the function performed in this category. The most significant bits of the Status Register (Flag1, Flag2, Flag3, LINK) are not affected. The only limitation in this type is that the RAM cannot be used as a source when both the Accumulator (ACC) and the Status Register are specified as a destination. #### SINGLE OPERAND FIELD DEFINITIONS: #### SINGLE OPERAND INSTRUCTION | Instruction 1 | B/W <sup>2</sup> | Quad <sup>3</sup> | | Орс | ode | | | R/S <sup>4</sup> | Dest <sup>4</sup> | | RAM A | ddress | |---------------|------------------|-------------------|------------------------------|----------------------------|----------------------------------------------------------|----------------------------------------------------------------------|--------------------------------------------------------------------------------|--------------------------------------|-------------------------------------------------------------------------|----------------------------------|---------------------------|-----------------------------------------------------------------| | SOR | 0 = B<br>1 = W | 10 | 1100<br>1101<br>1110<br>1111 | MOVE<br>COMP<br>INC<br>NEG | SRC Dest<br>SRC Dest<br>SRC + 1 Dest<br>SRC + 1 Dest | 0000<br>0010<br>0011<br>0100<br>0110<br>0111<br>1000<br>1001<br>1010 | SORA<br>SORY<br>SORS<br>SOAR<br>SODR<br>SOIR<br>SOZR<br>SOZER<br>SOSER<br>SORR | | ACC<br>Y-Bus<br>Status<br>RAM<br>RAM<br>RAM<br>RAM<br>RAM<br>RAM<br>RAM | 11111 | R00<br><br>R31 | RAM Reg 00<br><br>RAM Reg 31 | | Instruction | B/W | Quad | | Орс | ode | | | R/S <sup>4</sup> | | ļ | Desti | nation | | SONR | 0 = B<br>1 = W | 11 | 1100<br>1101<br>1110<br>1111 | MOVE<br>COMP<br>INC<br>NEG | SRC→Dest<br>SRC→Dest<br>SRC + 1 → Dest<br>SRC + 1 → Dest | 0100<br>0110<br>0111<br>1000<br>1001<br>1010 | SOA<br>SOD<br>SOI<br>SOZ<br>SOZE<br>SOSE | ACC<br>D<br>I<br>0<br>D(0E)<br>D(SE) | | 00000<br>00001<br>00100<br>00101 | NRY<br>NRA<br>NRS<br>NRAS | Y-Bus<br>ACC<br>Status <sup>5</sup><br>ACC, Status <sup>5</sup> | 1. The instruction mnemonic designates different instruction formats used in the Am29C117. They are useful in microcode assembly. Notes: B = Byte Mode, W = Word Mode. See Instruction Set description. R = Source; S = Source; Dest = Destination. When status is destination, Status i — Yi i = 0 to 3 (Byte mode) i = 0 to 7 (Word mode) #### Y-BUS AND STATUS - SINGLE OPERAND INSTRUCTIONS | Instruction | Opcode | Description | B/W | Y-Bus | Flag3 | Flag2 | Flag1 | LINK | OVR | N | C | z | |-------------|--------|---------------|-------|------------|-------|-------|-------|------|-----|---|---|---| | SOR | MOVE | SRC → Dest | 0 = B | Y ← SRC | NC | NC | NC | NC | 0 | U | 0 | U | | SONR | COMP | SRC → Dest | 1 = W | Y - SRC | NC | NC | NC | NC | 0 | υ | 0 | U | | | INC | SRC +1 → Dest | 1 | Y - SRC +1 | NC | NC | NC | NC | U | U | U | U | | | NEG | SRC +1 → Dest | 1 | Y - SRC +1 | NC | NC | NC | NC | U | U | U | U | SRC = Source U = Update NC = No Change 0 = Reset 1 = Set i = 0 to 15 when not specified #### Two Operand Instructions The Two Operand Instructions contain five indicators: Byte or Word mode, Opcode, R Source, S Source, and Destination. They are further subdivided into two types. The first type uses RAM as the source and/or destination and the second type does not use RAM as source or destination. The first type has two formats; the only difference is in the quadrant. Under the control of instruction inputs, the desired function is performed on the specified sources and the result is stored in the specified destination or placed on the Y-Bus, or both. The least significant four bits of the Status Register (OVR, N, C, Z) are affected by the arithmetic functions performed and only the N and Z bits are affected by the logical functions performed. The OVR and C bits of the Status Register are forced to ZERO for logical functions. Add with carry and Subtract with carry instructions are useful for Multiprecision Add or Subtract. #### TWO OPERAND FIELD DEFINITIONS: #### TWO OPERAND INSTRUCTIONS (Cont'd.) | instruction | B/W | Quad | | | R <sup>1</sup> | S <sup>1</sup> | Dest <sup>1</sup> | | Opcode | | RAM | Address | |-------------|----------------|------|----------------------------------------------------------------|-------------------------------------------------------------------------------|-------------------------------------------------------|-------------------------------------------------------|----------------------------------------------|--------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|----------------|------------| | TOR1 | 0 - B<br>1 - W | 00 | 0000<br>0010<br>0011<br>1000<br>1010<br>1011<br>11100<br>11110 | TORAA<br>TORIA<br>TORAY<br>TORAY<br>TORIY<br>TORAY<br>TORAR<br>TORIR<br>TODRA | RAM<br>RAM<br>D<br>RAM<br>RAM<br>D<br>RAM<br>RAM<br>D | ACC<br>I<br>RAM<br>ACC<br>I<br>RAM<br>ACC<br>I<br>RAM | ACC<br>Y-Bus<br>Y-Bus<br>Y-Bus<br>RAM<br>RAM | 0000<br>0001<br>0010<br>0011<br>0100<br>0101<br>0110<br>0111<br>1000<br>1001<br>1010 | SUBR S minus R SUBRC <sup>2</sup> S minus R with carry SUBS R minus S with carry ADD R plus S with carry AND R • S EXOR R + S SEXOR S | 00000 | R00<br><br>R31 | RAM Reg 31 | | Instruction | B/W | Quad | | | R <sup>1</sup> | S <sup>1</sup> | Dest <sup>1</sup> | | Opcode | | RAM | Address | | TOR2 | 0-B<br>1-W | 10 | 0001<br>0010<br>0101 | TODAR<br>TOAIR<br>TODIR | D<br>ACC<br>D | ACC<br>I | RAM<br>RAM<br>RAM | 0000<br>0001<br>0010<br>0011<br>0100<br>0101<br>0110<br>0111<br>1000<br>1001<br>1010 | SUBR S minus R SUBRC <sup>2</sup> S minus R with carry R minus S SUBSC <sup>2</sup> R minus S with carry R plus S ADDC R plus S with carry AND R • S EXOR R ⊕ S NOR R + S SEXOR R ⊕ S SEXOR R ⊕ S | 00000 | R00<br><br>R31 | RAM Reg 31 | Notes: 1. R = Source S = Source Dest = Destination 2. During subtraction the carry is interpreted as borrow. | | | | | | TW | /O OF | PERANI | INSTR | JCTIONS | | | |-------------|----------------|------|----------------------|----------------------|----------------|----------------|----------------------------------------------|-------------------------------------------------------------------------|---------------------------------------------------|----------------------------------|----------------------------------------------------------------------------------| | Instruction | B/W | Quad | | | R <sup>1</sup> | s <sup>1</sup> | | Or | ocode | | Destination | | TONR | 0 = B<br>1 = W | 11 | 0001<br>0010<br>0101 | TODA<br>TOAI<br>TODI | D<br>ACC<br>D | ACC<br>I | 0000<br>0001<br>0010<br>0011<br>0100<br>0101 | SUBR<br>SUBRC <sup>3</sup><br>SUBS<br>SUBSC <sup>3</sup><br>ADD<br>ADDC | carry<br>R minus S | 00000<br>00001<br>00100<br>00101 | NRY Y-Bus<br>NRA ACC<br>NRS Status <sup>2</sup><br>NRAS ACC, Status <sup>2</sup> | | | | | | | | | 0110<br>0111<br>1000<br>1001<br>1010 | AND<br>NAND<br>EXOR<br>NOR<br>OR<br>EXNOR | <u>R•Ś</u><br>R•S<br>R⊕S<br>R + S<br>R + S<br>R⊕S | | | Notes: 1. R = Source S = Source 2. When status is destination, Status i.— Y<sub>i</sub> i = 0 to 3 (Byte mode) i = 0 to 7 (Word mode) 3. During subtraction the carry is interpreted as borrow. #### Y-BUS AND STATUS CONTENTS — TWO OPERAND INSTRUCTIONS | Instruction | Opcode | Description | B/W | Y-Bus | Flag3 | Flag2 | Flag1 | LINK | OVR | N | С | Z | |--------------|--------|----------------------|-------|----------------------------------------------------|-------|-------|-------|------|-----|---|---|---| | | SUBR | S minus R | 0 = B | Y ← S + 🛱 + 1 | NC | NC | NC | NC | U | U | υ | υ | | | SUBRC | S minus R with carry | 1 = W | Y ← S + Ā + QC | NC | NC | NC | NC | U | U | υ | U | | | SUBS | R minus S | | Y ← R + S + 1 | NC | NC | NC | NC | U | U | U | U | | TOR1<br>TOR2 | SUBSC | R minus S with carry | | Y ← R + \$ + QC | NC | NC | NC | NC | U | U | U | U | | TONR | ADD | R plus S | | Y⊷R+S | NC | NC | NC | NC | U | U | U | U | | | ADDC | R plus S with carry | | Y - R + S + QC | NC | NC | NC | NC | U | U | U | U | | | AND | R·S | | Y -Ri AND Si | NC | NC | NC | NC | 0 | U | 0 | U | | | NAND | R·S | | Yi ← Ri NAND Si | NC | NC | NC | NC | 0 | U | 0 | U | | | EXOR | R⊕S | 1 | Y <sub>i</sub> ←R <sub>i</sub> EXOR S <sub>i</sub> | NC | NC | NC | NC | 0 | U | 0 | U | | | NOR | R+S | | Yi←Ri NOR Si | NC | NC | NC | NC | 0 | U | 0 | U | | | OR | R+S | 1 | Yi ← Ri OR Si | NC | NC | NC | NC | 0 | υ | 0 | U | | | EXNOR | R⊕S | 1 | Yi←Ri EXNOR Si | NC | NC | NC | NC | 0 | 0 | 0 | U | U = Update NC = No Change 0 = Reset 1 = Set i = 0 to 15 when not specified #### Single Bit Shift Instructions The Single Bit Shift Instructions contain four indicators: Byte or Word mode, Direction and Shift Linkage, Source, and Destination. They are further subdivided into two types. The first type uses RAM as the source and/or destination and the second type does not use RAM as source or destination. Under the control of the instruction inputs, the desired shift function is performed on the specified source and the result is stored in the specified destination or placed on the Y-Bus, or both. The direction and shift linkage indicator defines the direction of the shift (up or down) as well as what will be shifted into the with ZERO, ONE, or the Link-Status bit (QLINK). The MSB is loaded into the Link-Status bit as shown in Figure 2. On a shift-down instruction, the MSB may be loaded with ZERO, ONE, the contents of the Status Carry flip-flop, (QC), the Exclusive-OR of the Negative-Status bit, and the Overflow-Status bit (QN @ QOVR), or the Link-Status bit. The LSB is loaded into the Link-Status bit as shown in Figure 3. The N and Z bits of the Status Register are affected but the OVR and C bits are forced to ZERO. The Shift-Down with QN @ QOVR is useful for Two's Complement multiplication. | | SINGLE BIT SHIFT INSTRUCTIONS | | | | | | | | | | | | | | | | | | | |-------------|-------------------------------|------|-----------------------------------------|------------|----------------|--------------------------------------------------------------|-----------------------------------------------------------------------|-----------------------------------------------------------------------|--------------------------------------------------------|-----------------------------------------------------|----------------|------------------------------|--------------|--|-----------------------------------------|--|--|--|--| | Instruction | B/W | Quad | U <sup>1</sup> Dest <sup>1</sup> Opcode | | | | | | U <sup>1</sup> Dest <sup>1</sup> Opcode | | | | | | U <sup>1</sup> Dest <sup>1</sup> Opcode | | | | | | SHFTR | 0 = B<br>1 = W | 10 | 0110 SHRR<br>0111 SHDR | RAM<br>D | RAM<br>RAM | 0000<br>0001<br>0010<br>0100<br>0101<br>0110<br>0111<br>1000 | SHUPZ<br>SHUP1<br>SHUPL<br>SHDNZ<br>SHDN1<br>SHDNL<br>SHDNC<br>SHDNOV | Up<br>Up<br>Up<br>Down<br>Down<br>Down<br>Down | | 00000 | R00<br><br>R31 | RAM Reg 00<br><br>RAM Reg 31 | | | | | | | | | Instruction | B/W | Quad | | | U <sup>1</sup> | | | Оре | code | | | Des | tination | | | | | | | | SHFTNR | 0 = B<br>1 = W | 11 | 0110<br>0111 | SHA<br>SHD | ACC<br>D | - | 0000<br>0001<br>0010<br>0100<br>0101<br>0110<br>0111<br>1000 | SHUPZ<br>SHUP1<br>SHUPL<br>SHDNZ<br>SHDN1<br>SHDNL<br>SHDNC<br>SHDNOV | Up<br>Up<br>Up<br>Down<br>Down<br>Down<br>Down<br>Down | 0<br>1<br>QLINK<br>0<br>1<br>QLINK<br>QC<br>QN⊕QOVR | 00000<br>00001 | NRY<br>NRA | Y-Bus<br>ACC | | | | | | | Note 1. U = Source Dest = Destination #### Y-BUS AND STATUS - SINGLE BIT SHIFT INSTRUCTIONS | Instruction | Opcode | Description | B/W | Y-Bus | Flag3 | Flag2 | Flag1 | LINK | OVR | N | С | z | |-------------|--------------------------|---------------------------------------|---------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|-------|-------|--------------------|--------------------|------------------|-------------------|---|---| | | SHUPZ<br>SHUP1 | Up 0<br>Up 1 | 1 = W | $Y_i \leftarrow SRC_{i-1}$ , $i = 1$ to 15;<br>$Y_0 \leftarrow Shift Input$ | NC | NC | NC | SRC <sub>15*</sub> | 0 | SRC <sub>14</sub> | 0 | U | | SHR<br>SHNR | L Up QLINK | 0 = B | $Y_i - SRC_{i-1}$ , $i = 1$ to 7;<br>$Y_0 - Shift$ Input;<br>$Y_8 - SRC_7$ , $Y_i - SRC_{i-8}$<br>for $i = 9$ to 15 | NC | NC | NC | SRC <sub>7</sub> ∗ | 0 | SRC <sub>6</sub> | 0 | U | | | | SHDNZ<br>SHDN1 | Down 0<br>Down 1 | 1 = W | $Y_i \leftarrow SRC_{i+1}$ , $i = 0$ to 14;<br>$Y_{15} \leftarrow Shift$ Input | NC | NC | NC | SRC <sub>0*</sub> | 0 | Shift<br>Input | 0 | U | | | SHDNL<br>SHDNC<br>SHCNOV | Down QLINK<br>Down QC<br>Down QN⊕QOVE | 0 = B | $Y_i \leftarrow SRC_{i+1}$ , $i = 0$ to 6;<br>$Y_i \leftarrow SRC_{i-7}$ , $i = 8$ to 14;<br>$Y_{7.15} \leftarrow Shift Input$ | NC | NC | NC | SRC <sub>0</sub> ∗ | 0 | Shift<br>Input | 0 | U | \*Shifted Output is loaded into the QLINK. SRC = Source SRC = Source U = Update NC = No Change 0 = Reset 1 = Set i = 0 to 15 when not specified #### **Bit Oriented Instructions** The Bit Oriented Instructions contain four indicators: Byte or Word mode, Operation, Source/Destination, and the Bit Position of the bit to be operated on (Bit 0 is the least significant bit). They are further subdivided into two types. The first type uses the RAM as both source and destination and has two kinds of formats which differ only by quadrant. The second type does not use the RAM as a source or a destination. Under the control of the instruction inputs, the desired function is performed on the specified source and the result is stored in the specified destination or placed on the Y-Bus, or both. The operations which can be performed are: Set Bit n which forces the n<sup>th</sup> bit to a ONE leaving other bits unchanged; Reset Bit n which forces the n<sup>th</sup> bit to ZERO leaving the other bits unchanged; Test Bit n, which sets the ZERO Status Bit depending on the state of bit n leaving all the bits unchanged; Load 2<sup>n</sup>, which loads ONE in Bit position n and ZERO in all other bit positions; Load 2<sup>n</sup> which loads ZERO in bit position n and ONE in all other bit positions; increment by 2<sup>n</sup>, which adds 2<sup>n</sup> to the operand; and decrement by 2<sup>n</sup> which subtracts 2<sup>n</sup> from the operand. For all the Load, Set, Reset and Test instructions, the N and Z bits are affected and OVR and C bit of the Status Register are forced to ZERO. For all arithmetic instructions the LSH (OVR, C, N, Z bits) of the Status Register is affected. #### BIT ORIENTED FIELD DEFINITIONS: | | 15 | 14 13 | 12 9 | 8 5 | 4 0 | |------|-----|-------|------|--------|-------------| | BOR1 | B/W | Quad | n | Opcode | RAM Address | | , | | | | | | | BOR2 | B/W | Quad | n | Opcode | RAM Address | | | | _ | | | | | BONR | B/W | Quad | n | 1100 | Opcode | #### **BIT ORIENTED INSTRUCTIONS** | Instruction | B/W | Quad | n | Opcode | RAM Address | |-------------|----------------|------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | BOR1 | 0 = B<br>1 = W | 11 | 0 to 15 | 1101 SETNR Set RAM, Bit n<br>1110 RSTNR Reset RAM, Bit n<br>1111 TSTNR Test RAM, Bit n | 00000 R00 RAM Reg 00<br>11111 R31 RAM Reg 31 | | Instruction | B/W | Quad | n | Opcode | RAM Address | | BOR2 | 0 = B<br>1 = W | 10 | 0 to 15 | 1100 LD2NR 2 <sup>n</sup> -RAM<br>1101 LDC2NR 2 <sup>n</sup> -RAM<br>1110 A2NR RAM plus 2 <sup>n</sup> -RAM<br>1111 S2NR RAM minus 2 <sup>n</sup> -RAM | 00000 R00 RAM Reg 00<br>11111 R31 RAM Reg 31 | | Instruction | B/W | Quad | n | | Opcode | | BONR | 0 = B<br>1 = W | 11 | 0 to 15 | 1100 | 00000 TSTNA Test ACC, Bit n 00010 SETNA Reset ACC, Bit n 00100 SETNA Set ACC, Bit n 00100 A2NA ACC plus 2 <sup>n</sup> → ACC 00110 LD2NA 2 <sup>n</sup> → ACC 00111 LDC2NA 2 <sup>n</sup> → ACC 00111 LDC2NA 2 <sup>n</sup> → ACC 00111 LDC2NA 2 <sup>n</sup> → ACC 10000 TSTND Test D, Bit n 10010 RSTND Reset D, Bit n 10010 A2NDY D plus 2 <sup>n</sup> → Y-Bus 10110 LS2NY 2 <sup>n</sup> → Y-Bus 10110 LS2NY 2 <sup>n</sup> → Y-Bus 101111 LDC2NY 2 <sup>n</sup> → Y-Bus | #### Y-BUS AND STATUS — BIT ORIENTED INSTRUCTIONS Instruction Opcode Description B/W Y-Bus Flag3 LINK OVR Flag2 Flag1 N C Z SETNR Set RAM, Bit n Reset RAM, Bit n 0 = B $Y_i \leftarrow RAM_i$ for $i \neq n$ ; $Y_n \leftarrow 1$ 1 = W $Y_i \leftarrow RAM_i$ for $i \neq n$ ; $Y_n \leftarrow 0$ NC NC NC NC BOR1 **BSTNR** NC TSTNR Test RAM, Bit n $Y_i \leftarrow 0$ for $i \neq n$ ; $Y_n \leftarrow SRC_n$ NC NC NC NC 0 U 0 u LD2NR 2<sup>⊓</sup> ¬RAM $Y_i = 0$ for $i \neq n$ ; $Y_n = 1$ NC NC NC NC 0 U 0 0 LDC2NFI 2<sup>n</sup> → RAM Y<sub>i</sub>--1 for i≠n; Y<sub>n</sub>--0 NC NC NC NC 0 U 0 0 BOR2 A2NR RAM + 2<sup>n</sup> → RAM Y-RAM + 2<sup>n</sup> NC NC NC NC U υ U U S2NR RAM - 2<sup>n</sup> - RAM Y -- RAM - 2n NC NC NC NC U U U U TSTNA Test ACC, Bit n $Y_i \vdash 0$ for $i \neq n$ ; $Y_n \vdash ACC_n$ NC NC NC NC 0 U 0 U RSTNA Reset ACC, Bit n $Y_i - ACC_i$ for $i \neq n$ ; $Y_n - 0$ NC NC NC NC 0 U 0 U SETNA Set ACC, Bit n $Y_i - ACC_i$ for $i \neq n$ ; $Y_n - 1$ NC NC NC NC 0 U 0 0 A2NA ACC + 2<sup>n</sup> → ACC Y-ACC + 2n NC NC NC NC U U U U ACC - 2<sup>n</sup> → ACC S2NA Y-ACC-2n NC NC NC NC U U U U 2<sup>n</sup> → ACC LD2NA Y<sub>i</sub> ← 0 for i ≠ n; Y<sub>n</sub> ← 1 NC NC NC NC 0 U 0 0 2<sup>TI</sup> → ACC LDC2NA $Y_i-1$ for $i \neq n$ ; $Y_n-0$ NC NC NC NC 0 U 0 0 **BONR TSTND** Test D, Bit n $Y_i \leftarrow 0$ for $i \neq n$ ; $Y_n \leftarrow D_n$ NC NC NC NC 0 U 0 U RSTND Reset D, Bit n\* $Y_i \leftarrow D_i$ for $i \neq n$ ; $Y_n \leftarrow 0$ NC NC NC NC 0 U 0 U SETND Set D, Bit n\* $Y_i \leftarrow D_i$ for $i \neq n$ ; $Y_n \leftarrow 1$ NC NC NC NC 0 U 0 0 A2NDY D + 2<sup>n</sup> → Y-Bus Y ← D + 2<sup>n</sup> NC NC NC NC U U U U S2NDY D ~ 2<sup>n</sup> → Y-Bus Y - D - 2<sup>n</sup> NC NC NC NC U U U U LD2NY 2<sup>n</sup> → Y-Bus $Y_i = 0$ for $i \neq n$ ; $Y_n = 1$ NC NC NC NC 0 U 0 0 2⊓ → Y-Bus LDC2NY Y<sub>i</sub>-1 for i≠n; Y<sub>n</sub>-0 NC NC NC NC 0 υ 0 0 SRC = Source U = Update NC = No Change <sup>0 =</sup> Reset <sup>1 =</sup> Set i = 0 to 15 when not specified <sup>\*</sup>Destination is not D-Latch but Y-Bus. #### Rotate By n Bits Instructions The Rotate By n Bits Instructions contain four indicators: Byte or Word mode, Source, Destination, and the number of places the source is to be rotated. They are further subdivided into two types. The first type uses RAM as a source and/or a destination and the second type does not use RAM as a source or destination. The first type has two different formats and the only difference is in the quadrant. The second type has only one format as shown in the table. Under the control of instruction inputs, the n indicator specifies the number of bit positions the source is to be rotated up (0 to 15), and the result is either stored in the specified destination or placed on the Y-Bus, or both. An example of this instruction is given in Figure 4. In the Word mode, all 16 bits are rotated up while in the Byte mode, only the lower 8 bits (0-7) are rotated up. In the Word mode, a rotate up by n bits is equivalent to a rotate down by (16-n) bits. Similarly, in the Byte mode a rotate up by n bits is equivalent to a rotate down by (8-n) bits. The N and Z bits of the Status Register are affected and OVR and C bits are forced to ZERO. | n = 4, Word | Mode: | | | | |-------------|-------|------|------|------| | Source | 0001 | 0011 | 0111 | 1111 | | Destination | 0011 | 0111 | 1111 | 0001 | | n = 4, Byte | Mode: | | | | | Source | 0001 | 0011 | 0111 | 1111 | | Destination | 0001 | 0011 | 1111 | 0111 | ### Figure 4. Rotate By n Example #### **ROTATE BY n BITS FIELD DEFINITIONS:** | | _ 15 | 14 | 13 | 12 9 | 8 | 5 | 4 | 0 | į | |-------|------|-----|----|------|----|---------|-----|---------|---| | ROTR1 | B/W | Qua | ď | n | SF | RC-Dest | RAM | Address | | | ROTR2 | B/W | Quad | n | SRC-Dest | RAM Address | |-------|-----|------|---|----------|-------------| | | | | | | | | ROTNR | B/W | Quad | n | 1100 | SRC-Dest | | |-------|-----|------|---|------|----------|--| #### ROTATE BY n BITS INSTRUCTIONS | Instruction | B/W | Quad | n | | | U <sup>1</sup> | Dest <sup>1</sup> | | RAM | Address | 5 | |-------------|----------------|------|---------|----------------------|----------------------|-------------------|---------------------|----------------------------------|------------------------------|----------------------|------------------------------| | ROTR1 | 0 = B<br>1 = W | 00 | 0 to 15 | 1100<br>1110<br>1111 | RTRA<br>RTRY<br>RTRR | RAM<br>RAM<br>RAM | ACC<br>Y-Bus<br>RAM | 00000 | R00<br><br>R31 | RAM R | · · | | Instruction | B/W | Quad | n | | | υ¹ | Dest <sup>1</sup> | | RAM | Address | 3 | | ROTR2 | 0 = B<br>1 = W | 01 | 0 to 15 | 0000<br>0001 | RTAR<br>RTDR | ACC<br>D | RAM<br>RAM | 00000 | R00<br><br>R31 | RAM R | | | Instruction | B/W | Quad | n | | | | | | | U <sup>1</sup> | Dest <sup>1</sup> | | ROTNR | 0 = B<br>1 = W | 11 | 0 to 15 | 1100 | | | | 11000<br>11001<br>11100<br>11101 | RTDY<br>RTDA<br>RTAY<br>RTAA | D<br>D<br>ACC<br>ACC | Y-Bus<br>ACC<br>Y-Bus<br>ACC | Note: 1. U = Source Dest = Destination #### Y-BUS AND STATUS — ROTATE BY n BITS INSTRUCTIONS | Instruction | Op-<br>code | B/W | Y-Bus | Flag3 | Flag2 | Flag1 | LINK | OVR | N | С | z | |----------------|-------------|-------|--------------------------------------------------------------------|-------|-------|-------|------|-----|-----------------------|---|---| | ROTR1 | | 1 = W | Y <sub>i</sub> ← SRC <sub>(i-n)mod16</sub> | NC | NC | NC | NC | 0 | SRC <sub>15 - n</sub> | 0 | Ų | | ROTR2<br>ROTNR | | 0 = B | $Y_{i} \leftarrow SRC_{i+8} = SRC_{(i-n)mod8}$<br>for $i = 0$ to 7 | NC | NC | NC | NC | 0 | SRC <sub>8-n</sub> | 0 | U | SRC = Source U = Update NC = No Change 0 = Reset 1 = Set i = 0 to 15 when not specified #### Rotate and Merge Instructions The Rotate and Merge Instructions contain five indicators: Byte or Word mode, Rotated Source, Non-Rotated Source/ Destination, Mask, and the number of bit positions a source is to be rotated. The function performed by the Rotate and Merge Instruction is illustrated in Figure 5. The rotated source, U, is rotated up by the Barrel Shifter n places. The mask input then selects, on a bit-by-bit basis, the rotated U input or R input. A ZERO in bit i of the mask will select the ith bit of the R input as the ith output bit, while ONE in bit i will select the ith rotated U input as the output bit. The output word is stored in the non-rotated operand location. The N and Z bits are affected. The OVR and C bits of the Status Register are forced to ZERO. An example of this instruction is given in Figure 6. n = 4, Word Mode: 0011 0001 0101 0110 0011 0101 0110 Rotated U 0001 1010 1010 1010 1010 R 0000 1111 0000 1111 Mask (S) Figure 6. Rotate and Merge Example 1010 0101 0011 1010 #### ROTATE AND MERGE FIELD DEFINITIONS: Destination | | 15 | 14 13 | 129 | 85 | 4 0 | |------|-----|-------|-----|----------------------------------|-------------| | ROTM | B/W | Quad | n | ROT SRC-<br>Non ROT SRC-<br>Mask | RAM Address | #### ROTATE AND MERGE INSTRUCTION | Instruction | B/W | Quad | n | | | υ¹ | R/Des | t <sup>1</sup> S <sup>1</sup> | RAM Address | | | | | |-------------|----------------|------|---------|----------------------------------------------|----------------------------------------------|--------------------------------|----------------------------------------|-------------------------------|--------------------|----------------|--------------------------|--|--| | потм | 0 = B<br>1 = W | 01 | 0 to 15 | 0111<br>1000<br>1001<br>1010<br>1100<br>1110 | MDAI<br>MDAR<br>MDRI<br>MDRA<br>MARI<br>MRAI | D<br>D<br>D<br>D<br>ACC<br>RAM | ACC<br>ACC<br>RAM<br>RAM<br>RAM<br>ACC | I<br>RAM<br>I<br>AGC<br>I | 00000<br><br>11111 | R00<br><br>R31 | RAM Reg 00<br>RAM Reg 31 | | | U = Rotated Source #### Y-BUS AND STATUS - ROTATE AND MERGE INSTRUCTIONS | Instruction | Opcode | B/W | Y-Bus | Flag3 | Flag2 | Flag1 | LINK | OVR | N | С | z | |-------------|--------|-------|-------------------------------------------------------------------------------------------------------------------------------|-------|-------|-------|------|-----|---|---|---| | | | 1=W | Y <sub>i</sub> ← (Non Rot Op) <sub>i</sub> · (mask) <sub>i</sub> +<br>(Rot Op) <sub>(i = n)mod</sub> 16 · (mask) <sub>i</sub> | NC | NC | NC | NC | 0 | U | 0 | U | | ROTM | | 0 = B | Y <sub>i</sub> - (Non Rot Op) <sub>i</sub> · (mask) <sub>i</sub> + (Rot Op) <sub>(i - n)mod</sub> 8 · (mask) <sub>i</sub> | NC | NC | NC | NC | 0 | U | 0 | U | U = Update R/Dest = Non-Rotated Source and Destination S = Mask NC = No Change <sup>0 =</sup> Reset <sup>1 =</sup> Set i = 0 to 15 when not specified #### **Rotate and Compare Instructions** The Rotate and Compare Instructions contain five indicators: Byte or Word mode, Rotated Source, Non-Rotated Source, Mask, and the number of bit positions the rotated source is to be rotated up. Under the control of instruction inputs, the function performed by the Rotate and Compare Instruction is illustrated in Figure 7. The rotated operand is rotated by the Barrel Shifter n places. The mask is inverted and ANDed on a bit-by-bit basis with the output of the Barrel Shifter and R input. Thus, a ONE in the mask input eliminates that bit from the comparison. A ZERO allows the comparison. If the comparison passes, the Zero flag is set. If it fails, the Zero flag is reset. The N and Z bit are affected. The OVR and C bits of the Status Register are forced to ZERO. An example of this instruction is given in Figure 8. n = 4, Word Mode | U | 0011 | 0001 | 0101 | 0110 | |----------------|------|------|------|------| | - | | | | | | U Rotated | 0001 | 0101 | 0110 | 0011 | | R | 0001 | 0101 | 1111 | 0000 | | Mask (S) | 0000 | 0000 | 1111 | 1111 | | Z (status) = 1 | | | | | Figure 8. Rotate and Compare Example #### ROTATE AND COMPARE FIELD DEFINITIONS: | | 15 | 14 13 | 129 | 8 5 | 4 ( | |------|-----|-------|-----|----------------------------------|-------------| | ROTC | B/W | Quad | п | Rot Src-<br>Non Rot Src-<br>Mask | RAM Address | #### ROTATE AND COMPARE INSTRUCTIONS | Instruction | B/W | Quad | n | | | U <sup>1</sup> | R <sup>1</sup> | S <sup>1</sup> | | RAM A | ddress | |-------------|----------------|------|---------|------------------------------|------------------------------|--------------------|--------------------------|----------------|--------------------|------------|--------------------------| | ROTC | 0 = B<br>1 = W | 01 | 0 to 15 | 0010<br>0011<br>0100<br>0101 | CDAI<br>CDRI<br>CDRA<br>CRAI | D<br>D<br>D<br>RAM | ACC<br>RAM<br>RAM<br>ACC | I<br>ACC<br>I | 00000<br><br>11111 | R00<br>R31 | RAM Reg 00<br>RAM Reg 31 | U = Rotated Source #### Y-BUS AND STATUS — ROTATE AND COMPARE INSTRUCTIONS | Instruction | Opcode | B/W | Y-Bus | Flag3 | Flag2 | Flag1 | LINK | OVR | Z | С | Z | |-------------|--------|-------|--------------------------------------------------------------------------------------------------------------------------------------|-------|-------|-------|------|-----|---|---|---| | ROTC | | 1 = W | Y <sub>i</sub> ← (Non Rot Op) <sub>i</sub> · ( <u>mask)j</u> ⊕<br>(Rot Op) <sub>(i – n)mod 16 · (mask)<sub>i</sub></sub> | NC | NC | NC | NC | 0 | C | 0 | U | | HOTO | | 0 = B | Y <sub>i</sub> ← (Non Rot Op) <sub>i</sub> · ( <u>mask</u> ) <sub>i</sub> ⊕<br>(Rot Op) <sub>(i – n)mod 8 · (mask)<sub>i</sub></sub> | NC | NC | NC | NC | 0 | υ | 0 | υ | U = Update R = Non-Rotated Source S = Mask NC = No Change <sup>0 =</sup> Reset <sup>1 =</sup> Set i = 0 to 15 when not specified #### **Prioritize Instructions** The Prioritize Instructions contain four indicators: Byte or Word mode, Operand Source (R), Mask Source (S), and Destination. They are further subdivided into two types. The function performed by the Prioritize instruction is shown in Figure 9. The R operand is ANDed with the complement of the Mask operand. A ZERO in the Mask operand allows the corresponding bit in the R operand to participate in the priority encoding function. A ONE in the Mask operand forces the corresponding bit in the R operand to a ZERO, eliminating it from participation in the priority encoding function. The Priority Encoder accepts a 16-bit input and produces a 5-bit binary-weighted code indicating the bit position of the highest-priority active bit. If none of the inputs are active, the output is ZERO. In the Word mode, if input bit 15 is active, the output is 1, etc. Figure 10 lists the output as a function of the highest-priority active-bit position in both the Word and Byte mode. The N and Z bits are affected and the OVR and C bits of the Status Register are forced to ZERO. The only limitation in this instruction is that the operand and the mask must be different sources. Figure 9. Prioritize Function | WORD | MODE | BYTE MODE* | | | | | | |-----------------------------------|-------------------|-----------------------------------|-------------------|--|--|--|--| | Highest<br>Priority<br>Active Bit | Encoder<br>Output | Highest<br>Priority<br>Active Bit | Encoder<br>Output | | | | | | None | 0 | None | 0 | | | | | | 15 | 1 | 7 | 1 | | | | | | 14 | 2 | 6 | 2 | | | | | | • | • | | | | | | | | | | 1 . | | | | | | | 1 1 | 15 | 1 1 | 7 | | | | | | ó | 16 | 1 0 | 8 | | | | | <sup>\*</sup>Bits 8 through 15 do not participate Figure 10. Encoder Output #### PRIORITIZE FIELD DEFINITIONS: | 15 | 14 13 | 12 9 | 8 5 | 4 0 | |-----|-------|-------------|-------------|-----------------------------| | B/W | Quad | Destination | Source (R) | RAM Address/<br>Mask (S) | | B/W | Quad | Mask (S) | Destination | RAM Address/<br>Source (R) | | B/W | Quad | Mask (S) | Source (R) | RAM Address/<br>Destination | | B/W | Quad | Mask (S) | Source (R) | Destination | #### PRIORITIZE INSTRUCTION | Instruction | B/W | Quad | Ĭ | Destination | on | | Source (F | <b>3</b> ) | RAI | Addre | ss/Mask (S) | |-------------|----------------|------|----------------------|----------------------|---------------------|----------------------|----------------------|-----------------|--------------------|----------------|------------------------------| | PRT1 | 0 = B<br>1 = W | 10 | 1000<br>1010<br>1011 | PRIA<br>PR1Y<br>PR1R | ACC<br>Y-Bus<br>RAM | 0111<br>1001 | RPT1A<br>PR1D | ACC<br>D | 00000 | R00<br>R31 | RAM Reg 00<br><br>RAM Reg 31 | | Instruction | B/W | Quad | | Mask (S | 5) | | Destination | on | RAM | Addres | s/Source (R) | | PRT2 | 0 = B<br>1 = W | 10 | 1000<br>1010<br>1011 | PRA<br>PRZ<br>PRI | Acc<br>0 | 0000<br>0010 | PR2A<br>PR2Y | ACC<br>Y-Bus | 00000<br><br>11111 | R00<br>R31 | RAM Reg 00<br><br>RAM Reg 31 | | Instruction | B/W | Quad | | Mask (S | 5) | | Source ( | R) | H | AM Add | Iress/Dest | | PRT3 | 0 = B<br>1 = W | 10 | 1000<br>1010<br>1011 | PRA<br>PRZ<br>PRI | ACC<br>0<br>I | 0011<br>0100<br>0110 | PR3R<br>PR3A<br>PR3D | RAM<br>ACC<br>D | 00000 | R00<br><br>R31 | RAM Reg 00<br>RAM Reg 31 | | Instruction | B/W | Quad | | Mask (S | 5) | | Source ( | R) | | Desti | nation | | PRTNR | 0 = B<br>1 = W | 11 | 1000<br>1010<br>1011 | PRA<br>PRZ<br>PRI | ACC<br>0 | 0100<br>0110 | PRTA<br>PRTD | ACC<br>D | 00000<br>00001 | NRY<br>NRA | Y-Bus<br>ACC | #### Y-BUS AND STATUS - PRIORITIZE INSTRUCTIONS | Instruction | Opcode | B/W | Y-Bus | Flag3 | Flag2 | Flag1 | LINK | OVR | N | C | z | |---------------|--------|-------|-------------------------------------------------------------------------------------------------------------------------------------------|-------|-------|-------|------|-----|---|---|---| | PRT1<br>PRT2 | | 1 = W | $Y_i \leftarrow CODE (SCR_n \cdot mask_n);$<br>$Y_m \leftarrow 0; i = 0 \text{ to } 4 \text{ and } n = 0 \text{ to } 15$<br>m = 5 to 15 | NC | NC | NC | NC | 0 | U | 0 | U | | PRT3<br>PRTNR | | 0 = B | $Y_{i-}CODE (SCR_{n-}mask_{n});$<br>$Y_{m-}0; i = 0 \text{ to } 3 \text{ and } n = 0 \text{ to } 7$<br>m = 4 to 15 | NC | NC | NC | NC | 0 | U | 0 | U | SRC = Source U = Update NC = No Change 0 = Reset 1 = Set i = 0 to 15 when not specified #### Cyclic-Redundancy-Check Instructions The Cyclic-Redundancy-Check (CRC) Instructions contain one indicator: Address of a RAM register to use as the check sum register. The CRC Instruction provides a method for generation of the check bits in a CRC calculation. Two CRC Instructions are provided – CRC Forward and CRC Reverse. The reason for providing two instructions is that CRC standards do not specify which data bit is to be transmitted first, the LSB or the MSB, but they do specify which check bit must be transmitted first. Figure 11 illustrates the method used to generate these check bits for the CRC Forward function, and Figure 12 illustrates the method used for the CRC Reverse function. The ACC serves as a polynomial mask to define the generating polynomial while the RAM register holds the partial result and eventually the calculated check sum. The LINK-bit is used as the serial input. The serial input combines with the MSB of the check-sum register, according to the polynomial defined by the polynomial mask register. When the last input bit has been processed, the check-sum register contains the CRC check bits. The LINK, N, and Z bits are affected and the OVR and C bits of the Status Register are forced to ZERO. #### CYCLIC-REDUNDANCY-CHECK FIELD DEFINITIONS: Figure 11, CRC Forward Function #### CYCLIC-REDUNDANCY-CHECK INSTRUCTIONS | Instruction | B/W | Quad | | | | RAM | Address | |-------------|-----|------|------|------|--------------------|----------------|--------------------------| | CRCF | 1 | 10 | 0110 | 0011 | 00000<br><br>11111 | R00<br>R31 | RAM Reg 00<br>RAM Reg 31 | | Instruction | B/W | Quad | | | | RAI | M Address | | CRCR | 1 | 10 | 0110 | 1001 | 00000 | R00<br><br>R31 | RAM Reg 00<br>RAM Reg 31 | #### Y-BUS AND STATUS - CYCLIC-REDUNDANCY-CHECK INSTRUCTIONS | Instruction | Opcode | B/W | Y-Bus | Flag3 | Flag2 | Flag1 | LINK | OVR | N | С | Z | |-------------|--------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-------|-------|---------------------|-----|---|---|---| | CRCF | | 1 = W | Y <sub>i</sub> -[(QLINK ⊕ RAM <sub>15</sub> )·ACC <sub>i</sub> ]<br>⊕ RAM <sub>i-1</sub> for i= 15 to 1<br>Y <sub>0</sub> -[(QLINK ⊕ RAM <sub>15</sub> )·ACC <sub>0</sub> ] ⊕ 0 | NC | NC | NC | RAM <sub>15</sub> * | 0 | U | 0 | U | | CRCR | | 1 = W | Y <sub>i</sub> -[(QLINK ⊕ RAM <sub>0</sub> )·ACC <sub>i</sub> ]<br>⊕ RAM <sub>i+1</sub> for i = 14 to 0<br>Y <sub>15</sub> -[(QLINK ⊕ RAM <sub>0</sub> )· ACC <sub>15</sub> ] ⊕ 0 | NC | NC | NC | RAM <sub>0</sub> * | 0 | U | 0 | U | \*QLINK is loaded with the shifted out bit from the check-sum register. U = Update NC = No Change 0 = Reset 1 = Set i = 0 to 15 when not specified #### Status Instructions The Set Status Instruction contains a single indicator. This indicator specifies which bit or group of bits, contained in the Status Register (Figure 13), are to be set (forced to a ONE). | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-------|-------|------|-----|---|-----|-------| | Flag3 | Flag2 | Flag1 | LINK | OVR | N | С | z | | | | | | | | MPF | 3-775 | #### Figure 13. Status Byte The Reset Status Instruction contains a single indicator. This indicator specifies which bit or group of bits, contained in the Status Register, are to be reset (forced to ZERO). The Store Status Instruction contains two indicators; Byte/Word and a second indicator that specifies the destination of the Status Register. The Store Status Instruction allows the status of the processor to be saved and restored later, which is an especially useful function for interrupt handling. The Status Register is always stored in the lower byte of the RAM or the ACC register. Depending upon byte or word mode, the upper byte is unchanged or loaded with all ZEROs, respectively. The Load Status instructions are included in the single operand and two operand instruction types. The Test Status Instructions contain a single indicator which specifies which one of the 12 possible test conditions are to be placed on the Conditional-Test (CT) output. Besides the eight bits in the Status Register (QZ, QC, QN, QOVR, QLINK, QFlag1, QFlag2, and QFlag3), four logical functions (QN $\oplus$ QOVR, (QN $\oplus$ QOVR) + QZ, QZ + $\overline{\rm QC}$ , and LOW may also be selected. These functions are useful in testing results of Two's Complement and unsigned number arithmetic operations. The Status Register may also be tested via the bidirectional T-Bus. The code to test the Status Register via T-Bus is similar to the code used by instruction lines $\rm I_1$ to $\rm I_4$ as shown below. Instruction lines $\rm I_0$ to $\rm I_2$ as shown below. Status Register on CT output. See the discussion on the Status Register for a full description. | T <sub>4</sub> | T <sub>3</sub> | T <sub>2</sub> | T <sub>1</sub> | ст | |----------------|----------------|----------------|----------------|---------------| | 0 | 0 | 0 | 0 | (N ⊕ OVR) + Z | | 0 | 0 | 0 | 1 | N ⊕ OVR | | 0 | 0 | 1 | 0 | Z | | 0 | 0 | 1 | 1 | OVR | | 0 | 1 | 0 | 0 | LOW | | 0 | 1 | 0 | 1 | С | | 0 | 1 | 1 | 0 | Z + C | | 0 | 1 | 1 | 1 | N | | 1 | 0 | 0 | 0 | LINK | | 1 | 0 | 0 | 1 | Flag1 | | 1 | 0 | 1 | 0 | Flag2 | | 1 | 0 | 1 | 1 | Flag3 | #### STATUS FIELD DEFINITIONS: | | 15 | 14 13 | 12 9 | 8 5 | 4 0 | |--------|-----|-------|------|------|------------------| | SETST | 0 | Quad | 1011 | 1010 | Opcode | | | | | | | | | RSTST | 0 | Quad | 1010 | 1010 | Opcode | | | | | | | | | SVSTR | B/W | Quad | 0111 | 1010 | RAM Address/Dest | | | | | | | | | SVSTNR | B/W | Quad | 0111 | 1010 | Destination | #### STATUS INSTRUCTIONS | Instruction | B/W | Quad | | | | C | pcode | |-------------|----------------|------|------|------|-------------------------------------------|----------------------------------|-------------------------------------------------------------------------------| | SETST | 0 | 11 | 1011 | 1010 | 00011<br>00101<br>00110<br>01001<br>01010 | SONCZ<br>SL<br>SF1<br>SF2<br>SF3 | Set OVR, N, C, Z<br>Set LINK<br>Set Flag1<br>Set Flag2<br>Set Flag3 | | Instruction | B/W | Quad | | | | C | pcode | | RSTST | 0 | 11 | 1010 | 1010 | 00011<br>00101<br>00110<br>01001<br>01010 | RONCZ<br>RL<br>RF1<br>RF2<br>RF3 | Reset OVR, N, C, Z<br>Reset LINK<br>Reset Flag1<br>Reset Flag2<br>Reset Flag3 | | Instruction | B/W | Quad | | | | RAM A | ddress/Dest | | SVSTR | 0 = B<br>1 = W | 10 | 0111 | 1010 | 00000<br><br>11111 | R00<br><br>R31 | RAM Reg 00<br>RAM Reg 31 | | Instruction | B/W | Quad | | | | De | stination | | SVSTNR | 0 = B<br>1 = W | 11 | 0111 | 1010 | 00000<br>00001 | NRY<br>NRA | Y-Bus<br>ACC | #### STATUS INSTRUCTIONS (Cont'd.) | Instruction | B/W | Quad | | | Opcode (CT) | | | | | |-------------|-----|------|------|------|----------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|--|--| | Test | o | 11 | 1001 | 1010 | 00000<br>00010<br>00100<br>00110<br>01100<br>01010<br>01110<br>01110<br>10000<br>10010<br>10100<br>10110 | TNOZ<br>TNO<br>TZ<br>TOVR<br>TLOW<br>TC<br>TZC<br>TN<br>TL<br>TF1<br>TF2<br>TF3 | Test (N⊕OVR) + Z Test N⊕OVR Test Z Test OVR Test LOW Test C Test Z + Č Test N Test LINK Test Flag1 Test Flag2 Test Flag3 | | | #### Y-BUS AND STATUS — STATUS INSTRUCTIONS | Instruction | Opcode | Description | B/W | Y-Bus | Flag3 | Flag2 | Flag1 | LINK | OVR | N | С | Z | |-----------------|--------|--------------------|----------------|-------------------------------------------------------------|-------|-------|-------|------|-----|----|----|----| | | SONCZ | Set OVR, N, C, Z | 0 = B | Y <sub>i</sub> -1 for i = 0 to 15 | NC | NC | NC | NC | 1 | 1 | 1 | 1 | | | SL | Set LINK | 1 | | NC | NC | NC | 1 | NC | NC | NC | NC | | SETST | SF1 | Set Flag1 | ] | | NC | NC | 1 | NC | NC | NC | NC | NC | | | SF2 | Set Flag2 | | | NC | 1 | NC | NC | NC | NC | NC | NC | | | SF3 | Set Flag3 | 1 . | | 1 | NC | | RONCZ | Reset OVR, N, C, Z | 0 = B | Y <sub>i</sub> -0 for i = 0 to 15 | NC | NC | NC | NC | 0 | 0 | 0 | 0 | | | RL | Reset LINK | | | NC | NC | NC | 0 | NC | NC | NC | NC | | RSTST | RF1 | Reset Flag1 | | | NC | NC | 0 | NC | NC | NC | NC | NC | | | RF2 | Reset Flag2 | | | NC | 0 | NC | NC | NC | NC | NC | NC | | | RF3 | Reset Flag3 | 1 | | 0 | NC | SVSTR<br>SVSTNR | | Save Status* | 0 = B<br>1 = W | $Y_i$ - Status for i - 0 to 7;<br>$Y_i$ - 0 for i = 8 to 15 | NC | | TNOZ | Test (N⊕OVR) + Z | 0 = B | ** | NC | | TNO | Test N⊕OVR | 1 | | NC | | TZ | Test Z | ] | | NC | | TOVR | Test OVR | } | | NC | | TLOW | Test LOW | ] | | NC | Test | TC | Test C | ] | | NC | | TZC | Test Z + C | ] | | NC | | TN | Test N | ] | | NC | | TL | Test LINK | ] | | NC | | TF1 | Test Flag1 | ] | | NC | | TF2 | Test Flag2 | | | NC | | TF3 | Test Flag3 | | | NC U = Update NC = No Change 0 = Reset 1 = Set i = 0 to 15 when not specified <sup>\*</sup>In Byte mode only, the lower byte from the Y-Bus is loaded into the RAM or ACC, and in Word mode, all 16 bits from the Y-Bus are loaded into the RAM or ACC. <sup>\*\*</sup>Y-Bus is Undefined. #### No-Operation (NO-OP) Instruction The NO-OP Instruction has a fixed 16-bit code. This instruction does not change any internal registers in the Am29C117. It preserves the Status Register, RAM register, and the ACC register. #### NO-OP FIELD DEFINITION: | | 15 | 14 13 | 12 | 98 | 5 | 4 | 0 | |-------|----|-------|------|----|------|-------|---| | NO-OP | 0 | 11 | 1000 | | 1010 | 00000 | | #### **NO-OP INSTRUCTION** | Instruction | B/W | Quad | | | | |-------------|-----|------|------|------|-------| | NO-OP | 0 | 11 | 1000 | 1010 | 00000 | #### Y-BUS AND STATUS - NO-OP INSTRUCTION | Instruction | Opcode | B/W | Y-Bus | Flag3 | Flag2 | Flag1 | LINK | OVR | N | С | Z | |-------------|--------|-------|-------|-------|-------|-------|------|-----|----|----|----| | NO-OP | | 0 = B | * | NC SRC = Source U = Update NC = No Change 0 = Reset 1 = Set i = 0 to 15 when not specified \*Y-Bus is undefined. #### SUMMARY OF MNEMONICS #### INSTRUCTION TYPE SOR Single Operand RAM SONR Single Operand Non-RAM TOR1 Two Operand RAM (Quad 0) TOR2 Two Operand RAM (Quad 2) TONR Two Operand Non-RAM SHFTR Single Bit Shift RAM SHFTNR Single Bit Shift Non-RAM ROTR1 Rotate n Bits RAM (Quad 0) ROTR2 Rotate n Bits RAM (Quad 1) ROTNR Rotate n Bits Non-RAM BOR1 Bit Oriented RAM (Quad 3) BOR<sub>2</sub> Bit Oriented RAM (Quad 2) BONR Bit Oriented Non-RAM ROTM Rotate and Merge ROTO Rotate and Compare PRT1 Prioritize RAM; Type 1 PRT2 Prioritize RAM; Type 2 PRT3 Prioritize RAM; Type 3 PRTNR Prioritize Non-RAM CRCF Cyclic-Redundancy-Check Forward CRCR Cyclic-Redundancy-Check Reverse NOOP No Operation SETST Set Status **BSTST** Reset Status Save Status RAM SVSTR SVSTNR Save Status Non-RAM Test Status TEST #### SOURCE AND DESTINATION #### Single Operand: NRA NRS SORA Single Operand RAM to ACC SORY Single Operand RAM to Y-Bus SORS Single Operand RAM to Status Single Operand ACC to RAM SOAR SODR Single Operand D to RAM SOIR Single Operand I to RAM Single Operand 0 to RAM SOZR SOZER Single Operand D(0E) to RAM SOSER Single Operand D(SE) to RAM SORR Single Operand RAM to RAM SOA Single Operand ACC SOD Single Operand D SOL Single Operand I SOZ Single Operand 0 SOZE Single Operand D(0E) SOSE Single Operand D(SE) NRY Non-RAM Y-Bus Non-RAM Status NRAS Non-RAM ACC, Status Non-RAM ACC Mnemonics copyright @ 1980 Advanced Micro Devices, Inc. #### Two Operand: TORAA Two Operand RAM, ACC to ACC **TORIA** Two Operand RAM, I to ACC Two Operand D, RAM to ACC TODRA Two Operand RAM, ACC to Y-Bus TORAY TORIY Two Operand RAM, I to Y-Bus TODRY Two Operand D, RAM to Y-Bus TORAR Two Operand RAM, ACC to RAM TORIR Two Operand RAM, I to RAM Two Operand D, RAM to RAM TODRR **TODAR** Two Operand D, ACC to RAM TOAIR Two Operand ACC, I to RAM TODIR Two Operand D, I to RAM TODA Two Operand D, ACC TOAL Two Operand ACC, I TODI Two Operand D, I #### Single Bit Shift: SHRR Shift RAM, Store in RAM SHDR Shift D. Store in RAM SHA Shift ACC SHD Shift D #### Rotate By n Bits: RTRA Rotate RAM, Store in ACC Rotate RAM, Place on Y-Bus RTRY Rotate RAM, Store in RAM RTRR RTAR Rotate ACC, Store in RAM RTDR Rotate D, Store in RAM RTDY Rotate D. Place on Y-Bus Rotate D, Store in ACC RTDA Rotate ACC, Place on Y-Bus RTAY RTAA Rotate ACC, Store in ACC #### Rotate and Merge: MDAI Merge Disjoint Bits of D and ACC Using I as Mask and Store in ACC MDAR Merge Disjoint Bits of D and ACC Using RAM as Mask and Store in ACC MDRI Merge Disjoint Bits of D and RAM Using I as Mask and Store in RAM **MDRA** Merge Disjoint Bits of D and RAM Using ACC as Mask and Store in RAM MARI Merge Disjoint Bits of ACC and RAM Using I as Mask and Store in RAM Merge Disjoint Bits of RAM and ACC Using I as Mask and Store in ACC #### Rotate and Compare: MRAI CDAI Compare Unmasked Bits of D and ACC Using I as Mask | CDRI | Compare Unmasked Bits of D and RAM | SHDNZ | Shift Down Towards LSB with 0 Insert | |---------------|------------------------------------------------------|-------------|----------------------------------------------------------| | | Using I as Mask | SHDN1 | Shift Down Towards LSB with 1 Insert | | CDRA | Compare Unmasked Bits of D and RAM | SHDNL | Shift Down Towards LSB with LINK Insert | | | Using ACC as Mask | SHDNC | Shift Down Towards LSB with Carry Insert | | CRAI | Compare Unmasked Bits of RAM and ACC Using I as Mask | SHDNOV | Shift Down Towards LSB with Sign EXOR<br>Overflow Insert | | Prioritize: | | Loads: | | | PR1A | ACC as Destination for Prioritize Type 1 | LD2NR | Load 2 <sup>n</sup> into RAM | | PR1Y | Y-Bus as Destination for Prioritize Type 1 | LDC2NR | Load 2 <sup>™</sup> into RAM | | PR1R | RAM as Destination for Prioritize Type 1 | LD2NA | Load 2 <sup>n</sup> into ACC | | PRT1A | ACC as Source for Prioritize Type 1 | LDC2NA | Load 2 <sup>n</sup> into ACC | | PR1D | D as Source for Prioritize Type 1 | LD2NY | Place 2 <sup>n</sup> on Y-Bus | | PR2A | ACC as Destination for Prioritize Type 2 | LDC2NY | Place 2n on Y-Bus | | PR2Y | Y-Bus as Destination for Prioritize Type 2 | | | | PR3R | RAM as Source for Prioritize Type 3 | Bit Oriente | d: | | PR3A | ACC as Source for Prioritize Type 3 | SETNR | Set RAM, Bit n | | PR3D | D as Source for Prioritize Type 3 | SETNA | Set ACC, Bit n | | PRTA | ACC as source for Prioritize Type Non-RAM | SETND | Set D, Bit n | | PRTD | D as Source for Prioritize Type Non-RAM | SONCZ | Set OVR, N, C, Z, in Status Register | | PRA | ACC as Mask for Prioritize Type 2, 3, | SL | Set LINK Bit in Status Register | | 1112 | and Non-RAM | SF1 | Set Flag1 Bit in Status Register | | PRZ | Mask Equal to Zero for Prioritize Type | SF2 | Set Flag2 Bit in Status Register | | | 2, 3, and Non-RAM | SF3 | Set Flag3 Bit in Status Register | | PRI | I as Mask for Prioritize Type 2, 3, and | RSTNR | Reset RAM, Bit n | | | Non-RAM | RSTNA | Reset ACC, Bit n | | 00000 | | RSTND | Reset D, Bit n | | OPCODE | | RONCZ | Reset OVR, N, C, Z, in Status Register | | Addition: | | RL | Reset LINK Bit in Status Register | | ADD | Add without Carry | RF1 | Reset Flag1 Bit in Status Register | | ADDC | Add with Carry | RF2 | Reset Flag2 Bit in Status Register | | A2NA | Add 2 <sup>n</sup> to ACC | RF3 | Reset Flag3 Bit in Status Register | | A2NR | Add 2 <sup>n</sup> to RAM | TSTNR | Test RAM, Bit n | | A2NDY | Add 2 <sup>n</sup> to D, Place on Y-Bus | TSTNA | Test ACC, Bit n | | C. hamadia. | <u>.</u> . | TSTND | Test D, Bit n | | Subtraction | Subtract R from S without Carry | Arithmetic | Operations: | | SUBR<br>SUBRC | Subtract R from S with Carry | MOVE | Move and Update Status | | SUBS | Subtract S from R without Carry | COMP | Complement (1's Complement) | | SUBSC | Subtract S from R with Carry | INC | Increment | | S2NR | Subtract 2 <sup>n</sup> from RAM | NEG | Two's Complement | | S2NA | Subtract 2 <sup>n</sup> from ACC | | • • • • • • • • • • • • • • • • • • • • | | S2NDY | Subtract 2 <sup>n</sup> from D, Place on Y-Bus | Conditions | al Test: | | SZNDT | Subtract 2 from 5, race on 1-505 | TNOZ | Test (N ⊕ OVR) + Z | | Logical Op | perations: | TNO | Test N ⊕ OVR | | AND | Boolean AND | TZ | Test Zero Bit | | NAND | Boolean NAND | TOVR | Test Overflow Bit | | EXOR | Boolean EXOR | TLOW | Test for LOW | | NOR | Boolean NOR | TC | Test Carry Bit | | OR | Boolean OR | TZC | Test Z + C | | EXNOR | Boolean EXNOR | TN | Test Negative Bit | | _,((***)) | | TL | Test LINK Bit | | SHIFTS | | TF1 | Test Flag1 Bit | | SHUPZ | Shift Up Towards MSB with 0 Insert | TF2 | Test Flag2 Bit | | SHUFZ | | | | | SHUP1 | Shift Up Towards MSB with 1 Insert | TF3 | Test Flag3 Bit | # APPLICATIONS IR Sequencer IR Input Register D Am29C117 T V Data Register 076988-004A Figure 13. System Block Diagram | . Without any Exter | nal Logic | | | | |-----------------------------------|-----------------|--------|----------|----------| | • | | 29C117 | 29C117-1 | 29C117-2 | | Pipeline Register | CP-Q | 9 | 9 | 9 | | RALU (29C117) | 1-T | 105 | 60 | 49 | | Status Register | D-CP | 4 | 4 | 4 | | · | Total: | 118 | 73 | 62 | | Pipeline Register | CP-Q | 9 | 9 | 9 | | RALU (29C117) | I-Y | 98 | 60 | 49 | | Data Register | D-CP | 4 | 4 | 4 | | | Total: | 111 | 73 | 62 | | Input Register | CP-Q | 9 | 9 | 9 | | RALU (29C117) | D-Y | 78 | 49 | 40 | | Data Register | D-CP | 4 | 4 | 4 | | · · · · · · · · · · · · · · · · · | Total: | 91 | 62 | 53 | | | | | | | | II. With Multiplexers | for Two Address | | 202474 | 29C117-2 | | | | 29C117 | 29C117-1 | 290117-2 | | Pipeline Register | CP-Q | 9 | 9 | 9 | | Multiplexer | Sel-Y | 5 | 5 | 5 | | RALU (29C117) | I-T | 105 | 60 | 49 | | Status Register | D-CP | 4 | 4 | 4 | | | Total: | 123 | 78 | 67 | | Pipeline Register | CP-Q | 9 | 9 | 9 | | Multiplexer | Sel-Y | 5 | 5 | 5 | | RALU (29C117) | I-Y | 98 | 60 | 49 | | Data Register | D-CP | 4 | 4 | 4 | | | Total: | 116 | 78 | 67 | BD008220 #### **ABSOLUTE MAXIMUM RATINGS** | Storage Temperature65 to +150°C | |-------------------------------------------------| | (Case) Temperature Under Bias55 to +125°C | | Supply Voltage to | | Ground Potential Continuous0.3 to +7.0 V | | DC Voltage Applied to Outputs For | | High Output State0.3 to +V <sub>CC</sub> +0.3 V | | DC Input Voltage0.3 to +V <sub>CC</sub> +0.3 V | | DC Output Current, Into LOW 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. # \*Military Products 100% tested at T<sub>A</sub> = +25°C, +125°C, and -55°C Operating ranges define those limits between which the Ambient Temperature (TA) ...... 0 to +70°C Supply Voltage (V<sub>CC</sub>) .....+4.5 to +5.5 V Ambient Temperature (T<sub>A</sub>) ......55 to +125°C Supply Voltage (V<sub>CC</sub>) ......+4.5 to +5.5 V Uperating ranges define those limits between which the functionality of the device is guaranteed. #### Thermal Resistance and I/O Capacitance (Typical) | Symbol | PL 068 | CG 068 | CL 068 | Units | |---------------|--------|--------|--------|--------| | $\theta_{JA}$ | 35 | 25 | 37 | °C/W | | Ċ* | 5 | 5 | 10 | pF/Pin | <sup>\*</sup>Tested on a sample basis only. Military\* (M) Devices #### OPERATING RANGES Commercial (C) Devices **DC CHARACTERISTICS** over operating range unless otherwise specified (for APL Products, Group A, Subgroups 1, 2, 3, are tested unless otherwise noted) | Parameter<br>Symbol | Parameter<br>Description | Test Co | onditions | (Note 1) | Min. | Max. | Uni | |---------------------|---------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|------------------------------------------------------------------|------|-------------|-----| | Voн | Output HIGH Voltage | V <sub>CC</sub> = Min.,<br>V <sub>IN</sub> = V <sub>IH</sub> or V <sub>IL</sub> | | OOM'L I <sub>OH</sub> = -1.6 mA<br>MIL I <sub>OH</sub> = -1.2 mA | 2.4 | | > | | VOL | Output LOW Voltage | V <sub>CC</sub> = Min., V <sub>IN</sub> = V <sub>IH</sub> or V <sub>IL</sub> COM'L I <sub>OL</sub> = 16 mA MIL I <sub>OL</sub> = 12 mA | | | | 0.5 | ٧ | | V <sub>IH</sub> | Guaranteed Input Logical<br>HIGH Voltage (Note 2) | | | | 2.0 | <u> </u> | ٧ | | VIL | Guaranteed Input Logical<br>LOW Voltage (Note 2) | | | 0.8 | ٧ | | | | l <sub>IL</sub> | Input LOW Current | V <sub>CC</sub> = Max.,<br>V <sub>IN</sub> = 0.5 V | | -10 | μΑ | | | | I <sub>IH</sub> | Input HIGH Current | V <sub>CC</sub> = Max.,<br>V <sub>IN</sub> = V <sub>CC</sub> - 0.5 V | | 10 | μ. | | | | lozh | Off-State (High Impedance) Output Current | V <sub>CC</sub> = Max.,<br>V <sub>O</sub> = 2.4 V | | | | 10 | μΑ | | lozL | Off-State (High Impedance)<br>Output Current | V <sub>CC</sub> = Max.,<br>V <sub>O</sub> = 0.5 V | | | | -10 | μΑ | | | | | COM'L<br>T <sub>A</sub> = 0 | CMOS V <sub>IN</sub> = V <sub>CC</sub> or<br>GND | | 120 | | | lcc | Static Power Supply Current | V <sub>CC</sub> = Max. (Note 4) | to<br>+ 70°C | TTL V <sub>IN</sub> = 0.5 or 2.4 V | | 170 | m/ | | | (Note 3) | ΙΟ = 0 μΑ | MIL<br>T <sub>A</sub> = -5 | CMOS V <sub>IN</sub> = V <sub>CC</sub> or<br>GND | | 150 | me | | | | | TTL V <sub>IN</sub> = 0.5 or 2.4 V | | 200 | | | | C <sub>PD</sub> | Power Dissipation Capacitance (Note 4) | V <sub>CC</sub> = 5.0 V,<br>T <sub>A</sub> = 25°C,<br>No Load | | | 85 | iO pF Typic | al | Notes: 1. VCC conditions shown as Min. or Max. refer to the (±10%) VCC limits. 3. Worst-case ICC is measured at the lowest temperature in the specified operating range. CpD determines the no-load dynamic current consumption: Cc (Total) = |Cc (Static) (CpD + n CL) ½ where f is the clock frequency, CL is the output load capacitance, and n is the number of loads. These input levels provide zero-noise immunity and should only be statically tested in a noise-free environment (not functionally tested). <sup>4.</sup> Use CMOS ICC when the device is driven by CMOS circuits, and TTL ICC when the device is driven by TTL circuits. OP002750 Note: Values are calculated as typical $I_{CC}$ at $V_{CC}$ = 5.5 V. #### SWITCHING CHARACTERISTICS over COMMERCIAL operating range $(T_A = 0 \text{ to } +70^{\circ}\text{C}, \ V_{CC} = 4.50 \text{ to } 5.50 \text{ V}, \ C_L = 50 \text{ pF})$ #### Am29C117 #### A. Combinational Delays (nsec) | | | Outputs | | | |-------|-----------------------------|---------------------|------------------|----| | | | Y <sub>0 - 15</sub> | T <sub>1-4</sub> | СТ | | | I <sub>0-4</sub> (ADDR) | 98 | 105 | - | | | I <sub>0 - 15</sub> (DATA) | 98 | 105 | - | | | I <sub>0 - 15</sub> (INSTR) | 98 | 105 | 58 | | Input | DLE | 73 | 75 | - | | | T <sub>1-4</sub> | - | _ | 46 | | | CP | 76 | 83 | 48 | | | D <sub>0 - 15</sub> | 78 | 80 | - | | | ĪĒN | - | - | 53 | #### B. Enable/Disable Times (nsec) (C<sub>L</sub> = 5 pF for disable only) | | Enable Disable | | | able | | |------------|-------------------|------|------|------|------| | From Input | To Output | tpzH | tpzL | tpHZ | tpLZ | | ŌĒY | Y <sub>0-15</sub> | 25 | 25 | 25 | 25 | | OET | T <sub>1-4</sub> | 25 | 25 | 25 | 25 | #### C. Clock and Pulse Requirements (nsec) | Input | Min. LOW Time | Min. HIGH Time | |-------|---------------|----------------| | CP | 21 | 30 | | DLE | | 15 | | ĪĒN | 22 | _ | #### D. Setup and Hold Times (nsec) | | | HIGH-to-LOW<br>Transition | | LOW-t | | | | |-----------------------------|---------------------|---------------------------|------------------------|------------------------------------------------|--------------------------------------------|------------------------------|--| | Input | With Respect to | Setup | Hold | Setup | Hold | Comment | | | I <sub>0-4</sub> (RAM ADDR) | СР | (t <sub>s1</sub> ) 24 | (t <sub>h1</sub> ) 0 | (t <sub>h1</sub> ) 0 – | | Single ADDR<br>(Source) | | | I <sub>0-4</sub> (RAM ADDR) | CP and IEN both LOW | (t <sub>s2</sub> ) 10 | - | - | (t <sub>h7</sub> ) 2 | Two ADDR<br>(Destination) | | | I <sub>0 - 15</sub> (DATA) | СР | _ | _ | (t <sub>s8</sub> ) 78 | (t <sub>h8</sub> ) 0 | | | | I <sub>0-15</sub> (INSTR) | СР | (t <sub>s3</sub> ) 38 † | (th3) 17 † | (t <sub>s9</sub> ) 78 | (t <sub>h9</sub> ) 2 | | | | 1 <sub>0-15</sub> (INSTR) | ĪĒN | (t <sub>s16</sub> ) 6 | (t <sub>h16</sub> ) 18 | _ | _ | Two ADDR<br>(Immediate) | | | IEN HIGH | СР | (t <sub>s4</sub> ) 10 | _ | _ | (t <sub>h10</sub> ) 0 | Disable | | | IEN LOW | СР | | | (t <sub>\$11</sub> ) 22 (t <sub>\$5</sub> ) 20 | (t <sub>h11</sub> ) 0 (t <sub>h5</sub> ) 0 | Enable Immediate first cycle | | | SRE | CP | _ | - | (t <sub>s12</sub> ) 17 | (t <sub>h12</sub> ) 0 | | | | D | CP | _ | - | (t <sub>s13</sub> ) 53 | (t <sub>h13</sub> ) 0 | | | | D | DLE | (t <sub>s6</sub> ) 10 | (t <sub>h6</sub> ) 6 | - | - | **** | | | DLE | CP | | _ | (t <sub>s14</sub> ) 54 | (t <sub>h14</sub> ) 0 | | | #### SWITCHING CHARACTERISTICS over COMMERCIAL operating range (Cont'd.) #### Am29C117-1 #### A. Combinational Delays (nsec) | | | Outputs | | | | | | |-----------------------------|---------|------------------|----|--|--|--|--| | Input | Y0 - 15 | T <sub>1-4</sub> | СТ | | | | | | I <sub>0-4</sub> (ADDR) | 60 | 60 | _ | | | | | | I <sub>0 - 15</sub> (DATA) | 60 | 60 | - | | | | | | I <sub>0 - 15</sub> (INSTR) | 60 | 60 | 27 | | | | | | DLE | 48 | 47 | - | | | | | | T <sub>1-4</sub> | _ | - | 24 | | | | | | CP | 53 | 57 | 31 | | | | | | D <sub>0 - 15</sub> | 49 | 46 | - | | | | | | ĪĒN | _ | - | 24 | | | | | #### B. Enable/Disable Times (nsec) (C<sub>L</sub> = 5 pF for disable only) | | Enable Dis | | | | able | | | |-----------------|---------------------|-----------|----------------------------------|------|------|----|----| | From Input | To Output | tpzH tpzL | | tpHZ | tpLZ | | | | ŌĒγ | Y <sub>0 - 15</sub> | 21 | 21 | 21 | 21 | | | | OE <sub>T</sub> | | | OE <sub>T</sub> T <sub>1-4</sub> | | 21 | 21 | 21 | #### C. Clock and Pulse Requirements (nsec) | Input | Min. LOW Time | Min. HIGH Time | |-------|---------------|----------------| | CP | 21 | 15 | | DLE | - | 15 | | ĪĒN | 15 | - | #### D. Setup and Hold Times (nsec) | | | | HIGH-to-LOW<br>Transition | | | LOW-to-HIGH<br>Transition | | | | | | | | | | |-----------------------------|---------------------|--------------------|-------------------------------------------------|---------|-----------------------|---------------------------|----------------------|--------------------------|----------------------|-------------------------|--------------------------|-----|--|--|--| | Input | With Respect to | S | etup | He | old | Set | tup | Hol | ld | Comment | | | | | | | I <sub>0-4</sub> (RAM ADDR) | СР | (t <sub>s1</sub> | (t <sub>s1</sub> ) 11 (t <sub>h1</sub> ) 0 | | - | - | | - | | | Single AE<br>(Source) | DDR | | | | | I <sub>0-4</sub> (RAM ADDR) | CP and IEN both LOW | (t <sub>s</sub> | 2) 2 | - | | - | | - (t <sub>h7</sub> ) 0 | | Two ADD<br>(Destination | | | | | | | I <sub>0-15</sub> (DATA) | CP | | - | - | | (t <sub>s8</sub> ) 69 | | (the) 0 | | | | | | | | | I <sub>D-15</sub> (INSTR) | CP | (t <sub>s3</sub> ) | (t <sub>s3</sub> ) 19 † (t <sub>h3</sub> ) 12 † | | (t <sub>s9</sub> ) 69 | | (t <sub>h9</sub> ) 0 | | | | | | | | | | lo-15 (INSTR) | ĪĒN | (t <sub>s1</sub> | (t <sub>s16</sub> ) 6 (t <sub>h16</sub> ) 18 | | - | - | | | Two ADD | | | | | | | | IEN HIGH | CP | (t <sub>s</sub> | 4) 5 | | | | | (t <sub>h10</sub> ) | ) 0 | Disable | | | | | | | IEN LOW | СР | - | - | - | - | (t <sub>s11</sub> ) 12 | (t <sub>S5</sub> ) 6 | (t <sub>h11</sub> ) 0 | (t <sub>h5</sub> ) 0 | Enable | Immediate<br>first cycle | | | | | | SRE | CP | | _ | - | | (t <sub>s12</sub> ) | 11 | (t <sub>h12</sub> | 0 | | - | | | | | | D | CP | | - | - | | - | | (t <sub>s13</sub> ) | 39 | (t <sub>h13</sub> ) | ) 0 | | | | | | D | DLE | (t <sub>s</sub> | 6) 5 | (th6) 3 | | - | _ | | - | | - | | | | | | DLE | CP | | _ | | - | (ts14) 42 | | (t <sub>s14</sub> ) 42 ( | | (t <sub>h14</sub> ) | 0 | | | | | #### SWITCHING CHARACTERISTICS over COMMERCIAL operating range (Cont'd.) #### Am29C117-2 #### A. Combinational Delays (nsec) | | Outputs | | | | | | | | |-----------------------------|---------|------------------|-----|--|--|--|--|--| | Input | Yo - 15 | T <sub>1-4</sub> | СТ | | | | | | | I <sub>0-4</sub> (ADDR) | 49 | 49 | - | | | | | | | 10-15 (DATA) | 49 | 49 | | | | | | | | I <sub>0 - 15</sub> (INSTR) | 49 | 49 | 22 | | | | | | | DLE | 40 | 39 | - | | | | | | | T <sub>1-4</sub> | - | - | 22 | | | | | | | СР | 45 | 45 | 26 | | | | | | | D <sub>0 - 15</sub> | 40 | 38 | - " | | | | | | | IEN | | | 22 | | | | | | #### B. Enable/Disable Times (nsec) (C<sub>L</sub> = 5 pF for disable only) | | Enable | | | Dis | able | |------------|-------------------|------|------|------|------------------| | From Input | To Output | tpzH | tpZL | tpHZ | t <sub>PLZ</sub> | | ΘĒγ | Y <sub>0-15</sub> | 19 | 19 | 19 | 19 | | OET | T <sub>1-4</sub> | 19 | 19 | 19 | 19 | #### C. Clock and Pulse Requirements (nsec) | Input | Min. LOW Time | Min. HIGH Time | |-------|---------------|----------------| | CP | 20 | 15 | | DLE | - | 15 | | ĪĒN | 15 | | #### D. Setup and Hold Times (nsec) | | | | GH-to-LOW<br>Transition | | | | o-HIGH<br>sition | | | | | | |-----------------------------|---------------------|-----------------------|----------------------------------------------|-------------------------|--------------------------------------------|------------------------|-----------------------|----------------------|---------------------|--------------------------|--|--| | Input | With Respect to | Setup | H | old | Set | up | Hol | d | Co | mment | | | | I <sub>0-4</sub> (RAM ADDR) | СР | (t <sub>s1</sub> ) 10 | 10 (t <sub>h1</sub> ) 0 | | - | | | | | Single ADDR<br>(Source) | | | | I <sub>0-4</sub> (RAM ADDR) | CP and IEN both LOW | (t <sub>s2</sub> ) 2 | | | | | | Two ADD | | | | | | I <sub>0-15</sub> (DATA) | CP CP | - | | - (t <sub>s8</sub> ) 61 | | (t <sub>h8</sub> ) | 0 | | | | | | | I <sub>0-15</sub> (INSTR) | OP OP | (t <sub>s3</sub> ) 17 | † (th3) | 10 † | (t <sub>s9</sub> ) 61 (t <sub>h9</sub> ) 0 | | 0 | | | | | | | I <sub>0-15</sub> (INSTR) | IEN | (t <sub>s16</sub> ) 6 | (t <sub>s16</sub> ) 6 (t <sub>h16</sub> ) 18 | | - | | - | | Two ADI<br>(Immedia | | | | | IEN HIGH | СР | (t <sub>s4</sub> ) 5 | | - | _ | _ | | ) 0 | Disable | | | | | IEN LOW | CP | - | - - | T - | (t <sub>s11</sub> ) 11 | (t <sub>S5</sub> ) 6 | (t <sub>h11</sub> ) 0 | (t <sub>h5</sub> ) 0 | Enable | Immediate<br>first cycle | | | | SRE | СР | - | | - | (t <sub>s12</sub> ) | 10 | (t <sub>h12</sub> | ) 0 | | | | | | D | СР | | | - | | - | | 34 | (Կո13 | ) 0 | | | | D | DLE | (t <sub>s6</sub> ) 5 | (t <sub>h</sub> | (t <sub>h6</sub> ) 3 | | (t <sub>h6</sub> ) 3 - | | | | | | | | DLE | CP | _ | 1 | - | (t <sub>s14</sub> ) | 36 | (th14 | 0 | | | | | **SWITCHING CHARACTERISTICS** over **MILITARY** operating range (for APL Products, Group A, Subgroups 9, 10, 11 are tested unless otherwise noted) #### Am29C117-1 #### A. Combinational Delays (nsec) | | | Outputs | | | | | |----------------------------|---------------------|------------------|----|--|--|--| | input | Y <sub>0 - 15</sub> | T <sub>1-4</sub> | СТ | | | | | I <sub>0-4</sub> (ADDR) | 65 | 64 | _ | | | | | I <sub>0 - 15</sub> (DATA) | 65 | 64 | | | | | | I <sub>0-15</sub> (INSTR) | 65 | 64 | 27 | | | | | DLE | 53 | 52 | - | | | | | T <sub>1-4</sub> | - | - | 27 | | | | | CP | 58 | 61 | 34 | | | | | D <sub>0 - 15</sub> | 53 | 50 | - | | | | | IEN | _ | - | 26 | | | | #### B. Enable/Disable Times (nsec) (C<sub>L</sub> = 5 pF for disable only) | | | Enable | | Dis | able | |------------|---------------------|------------------|------|------|------| | From Input | To Output | t <sub>PZH</sub> | tpzL | tpHZ | tPLZ | | ŌĒY | Y <sub>0 - 15</sub> | 22 | 22 | 22 | 22 | | OET | T <sub>1-4</sub> | 22 | 22 | 22 | 22 | #### C. Clock and Pulse Requirements (nsec) | Input | Min. LOW Time | Min. HIGH Time | |-------|---------------|----------------| | CP | 22 | 15 | | DLE | - | 15 | | ĪĒN | 15 | - | #### D. Setup and Hold Times (nsec) | | | HIGH-to-LOW<br>Transition | | | LOW-to-HIGH<br>Transition | | | · | | | | |-----------------------------|---------------------|---------------------------|------|------------------|---------------------------|------------------------|----------------------|-----------------------|----------------------|-----------------------|--------------------------| | Input | With Respect to | Se | etup | H | old | Set | tup | Ho | ld | Co | mment | | I <sub>0-4</sub> (RAM ADDR) | СР | (t <sub>s1</sub> | ) 12 | (t <sub>h</sub> | 1) 1 | - | | _ | | Single AD<br>(Source) | DDFI | | I <sub>0-4</sub> (RAM ADDR) | CP and IEN both LOW | (t <sub>s.</sub> | 2) 2 | | _ | _ | | (t <sub>h7</sub> ) | 0 | Two ADD | | | lo - 15 (DATA) | CP | | _ | | _ | (t <sub>s8</sub> ) | 72 | (t <sub>h8</sub> ) | 0 | | | | I <sub>0 - 15</sub> (INSTR) | CP | (t <sub>s3</sub> ) | 21 † | (th3) | 12 † | (t <sub>s9</sub> ) | 72 | (t <sub>hg</sub> ) | 0 | | | | I <sub>0-15</sub> (INSTR) | IEN | (t <sub>s1</sub> | 6) 6 | (t <sub>h1</sub> | <sub>5</sub> ) 18 | - | | - | | Two ADD | | | IEN HIGH | CP | (t <sub>s</sub> | 4) 5 | | _ | - | | (t <sub>h10</sub> | ) 0 | Disable | | | IEN LOW | СР | _ | - | - | _ | (t <sub>s11</sub> ) 13 | (t <sub>S5</sub> ) 7 | (t <sub>h11</sub> ) 0 | (t <sub>h5</sub> ) 0 | Enable | Immediate<br>first cycle | | SRE | CP | | _ | | | (t <sub>s12</sub> ) | 11 | (t <sub>h12</sub> | ) 1 | | | | D | CP | | - | | | (t <sub>s13</sub> ) | 44 | (t <sub>h13</sub> | ) 0 | 1 | | | D | DLE | (t <sub>s</sub> | 6) 6 | (th | 6) 4 | _ | | - | | | | | DLE | CP | | - | | _ | (t <sub>s14</sub> ) | 47 | (t <sub>h14</sub> | ) 0 | | | # SWITCHING WAVEFORMS KEY TO SWITCHING WAVEFORMS INPUTS OUTPUTS WAVEFORM MUST BE STEADY WILL BE STEADY WILL BE CHANGING FROM H TO L MAY CHANGE FROM H TO L WILL BE CHANGING FROM L TO H MAY CHANGE FROM L TO H CHANGING; STATE UNKNOWN DON'T CARE; ANY CHANGE PERMITTED CENTER LINE IS HIGH IMPEDANCE "OFF" STATE DOES NOT KS000010 th10 DLE SRE WF025870 Single-Address Access Timing If the is satisfied, that need not be satisfied. #### Test Philosophy and Methods The following points give the general philosophy which we apply to tests that must be properly engineered if they are to be implemented in an automatic environment. The specifics of what philosophies applied to which test are shown in the data sheet. - Ensure the part is adequately decoupled at the test head. Large changes in V<sub>CC</sub> current when the device switches may cause function failures due to V<sub>CC</sub> changes. - Do not leave inputs floating during any tests, as they may start to oscillate at high frequency. - 3. Do not attempt to perform threshold tests at high speed. Following an input transition, ground current may change by as much as 400 mA in 5-8 ns. Inductance in the ground cable may allow the ground pin at the device to rise by hundreds of millivolts momentarily. - 4. Use extreme care in defining input levels for AC tests. Many inputs may be changed at once, so there will be significant noise at the device pins which may not actually reach $V_{IL}$ or $V_{IH}$ until the noise has settled. AMD recommends using $V_{IL} \leqslant 0$ V and $V_{IH} \geqslant 3.0$ V for AC tests. - To simplify failure analysis, programs should be designed to perform DC, Function, and AC tests as three distinct groups of tests. - 6. Capacitive Loading for AC Testing Automatic testers and their associated hardware have stray capacitance that varies from one type of tester to another, but is generally around 50 pF. This makes it impossible to make direct measurements of parameters that call for a smaller capacitive load than the associated stray capacitance. Typical examples of this are the so-called "float delays," which measure the propagation delays into the high-impedance state and are usually specified at a load capacitance of 5.0 pF. In these cases, the test is peformed at the higher load capacitance (typically 50 pF), and engineering correlations based on data taken with a bench setup are used to predict the result at the lower capacitance. Similarly, a product may be specified at more than one capacitive load. Since the typical automatic tester is not capable of switching loads in mid-test, it is impossible to make measurements at <u>both</u> capacitances even though they may both be greater than the stray capacitance. In these cases, a measurement is made at one of the two capacitances. The result at the other capacitance is predicted from engineering correlations based on data taken with a bench setup and the knowledge that certain DC measurements (I<sub>OH</sub>, I<sub>OL</sub>, for example) have already been taken and are within specification. In some cases, special DC tests are performed in order to facilitate this correlation. #### 7. Threshold Testing the noise associated with automatic testing (due to the long, inductive cables) and the high gain of the tested device when in the vicinity of the actual device threshold, frequently give rise to oscillations when testing high-speed circuits. These oscillations are not indicative of a reject device, but instead, of an overtaxed test system. To minimize this problem, thresholds are tested at least once for each input pin. Thereafter, ''hard'' HIGH and LOW levels are used for other tests. Generally this means that function and AC testing are performed at ''hard'' input levels rather than at $\rm V_{IL}$ Max. and $\rm V_{IH}$ Min. #### 8. AC Testing Occasionally parameters are specified that cannot be measured directly on automatic testers because of tester limitations. Data input hold times often fall into this category. In these cases, the parameter in question is guaranteed by correlating these tests with other AC tests that have been performed. These correlations are arrived at by the cognizant engineer using data from precise bench measurements in conjunction with the knowledge that certain DC parameters have already been measured and are within specification. In some cases, certain AC tests are redundant since they can be shown to be predicted by other tests that have already been performed. In these cases, the redundant tests are not performed. #### **SWITCHING TEST CIRCUITS** #### A. Three-State Outputs $R_1 = 300 \Omega$ #### **B. Normal Outputs** $R_1 = 300 \Omega$ $R_2 = 3.0 k\Omega$ Notes: 1. C<sub>L</sub> = 50 pF includes scope probe, wiring and stray capacitances without device in test fixture. 2. S<sub>1</sub>, S<sub>2</sub>, S<sub>3</sub> 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 tpzH test. - St and S2 are closed while S3 is open for tPZL test. - 4. CL = 5.0 pF for output disable tests. # DATA INPUT 1.5 V 1.5 V 0 V TIMING INPUT 1.5 V 0 V - Notes: 1. Diagram shown for HIGH data only. Output transition may be opposite sense. - Cross hatched area is don't care condition. #### A. Set-up, Hold, and Release Times #### C. Propagation Delay #### B. Pulse Width - Notes: 1. Diagram shown for Input Control Enable-LOW and Input Control Disable-HIGH. - 2. S<sub>1</sub>, S<sub>2</sub> and S<sub>3</sub> of Load Circuit are closed except where shown. #### D. Enable and Disable Times #### INPUT/OUTPUT CIRCUIT DIAGRAMS SWITCHING TEST WAVEFORMS WFR02970 $C_1 \approx 5.0$ pF, all inputs $C_{\text{O}} \approx 5.0$ pF, all outputs # PHYSICAL DIMENSIONS\* CG 068 Base Plane 1.140 1.180 1.000 BSC 1.140 1.180 1.000 BSC 1.140 1.140 1.180 1.000 BSC 1.140 1.140 1.180 1.000 BSC 1.140 1.140 1.140 1.180 1.000 BSC 1.140 1.140 1.140 1.140 1.140 1.180 1.000 BSC 1.140 1.140 1.140 1.140 1.140 1.180 1.000 BSC 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.180 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.180 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1.140 1. Note: 1. This dimension refers to a heatsink with only 3 fins. For heatsinks with more than 3 fins, the following dimensions apply: 4 fins = .450/.510 PL 068 6 fins = .540/.600 ### 7 fins = .690/.750 | orth Americal | | (005) 000 0100 | International (Continued | | |--------------------|-----------------------------------------|----------------------------------------------------------------------|--------------------------------------------------------------|------------------------------| | | | (205) 882-9122<br>(602) 242-4400 | TOKYO FEL | (03) 342-519 | | IZONA<br>LIFORNIA, | | (602) 242-4400 | TLX | (03) 342-519<br>J24064AMDTKO | | Culver City | | (213) 645-1524 | OsakaTEL | 06-243-32 | | Newcort Reach | | (213) 645-1524<br>(714) 752-6262<br>(619) 560-7030<br>(408) 452-0500 | FAX | 06-243-32 | | San Diego | | (619) 560-7030 | KOREA, SeoulTEL | 82-2-784-759 | | San Jose | | (408) 452-0500 | FAX | 82-2-784-80 | | Woodland Hills | | (818) 992-4155 | LATIN AMERICA, | | | NADA Optorio | | | Ft. LauderdaleTEL | (305) 484-86 | | NADA, Ontario, | | (613) 592-0060 | FAX | (305) 485-97 | | Nanata | | (613) 592-0060<br>(416) 224-5193 | TFI | 5109554261 AMDF | | VIIIOWGAIG | • • • • • • • • • • • • • • • • • • • • | (200) 744 2000 | NORWAY, HovikTEL<br>FAX | (02) 5378 | | LOHADO | | (303) 741-2900<br>(203) 264-7800 | FAX | (02) 5919 | | NNECTICUT | · · · · · · · · · · · · · · · · · · · | (203) 264-7800 | TLX | 790 | | ORIDA, | | (010) E20 0071 | SINGAPORETEL | 65-22575 | | Clearwater | | (813) 530-9971<br>(305) 776-2001<br>(407) 830-8100 | FAX | 65-22461 | | Ft. Lauderdale | | (407) 930 9100 | | RS55650 MMI F | | Orlando | | (407) 830-8100 | SWEDEN, | | | | | (404) 449-7920 | StockholmTEL | (08) /33 03 | | INOIS, | | (0.10) 770 1100 | FAX | (08) 733 22 | | Chicago | | (312) 773-4422<br>(312) 505-9517 | TLX | 116 | | Naperville | | (312) 505-9517 | TAIWAN TLX | 886-2-71220 | | DIANA | | (317) 244-7207 | FAX | 886-2-71220 | | NSAS | | (913) 451-3115 | UNITED KINGDOM, | | | RYLAND | | (317) 244-7207<br>(913) 451-3115<br>(301) 796-9310 | Manchester areaTEL | (0925) 8280 | | ASSACHUSETIS | | (617) 273-3970 | FAX | (0925) 8276 | | NNESOTA | | (612) 938-0001 | TLX<br>London areaTEL | 6285 | | SSOURI | | (913) 451-3115<br>(201) 299-0002 | London areaTEL | (04862) 221 | | W JERSEY | *************************************** | (201) 299-0002 | FAX | (0483) 7561 | | W YORK | | | TLX | 8591 | | Liverpool | | (315) 457-5400<br>(914) 471-8180<br>(516) 364-8020 | Manth American Den | | | Poughkeepsie | | (914) 471-8180 | North American Rep | resentatives | | Woodbury | | (516) 364-8020 | CANADA | | | DETH CAROLINA | | (919) 878-8111 | Burnahy B.C | | | HO. | | (373) 010 0111 | Burnaby, B.C. DAVETEK MARKETING | (604) 430-36 | | Columbus | | (614) 891-6455 | Calgary Alberta | | | Douton | | (614) 891-6455<br>(513) 439-0470 | Calgary, Alberta VITEL ELECTRONICS | (403) 278-58 | | Daylon | | (510) 405 0470 | Kanata, Ontario | | | | | (503) 245-0080 | VITEL ELECTRONICS | (613) 592-00 | | NNSYLVANIA, | | | | (010) 332-00 | | Allentown | | (215) 398-8006<br>(609) 662-2900 | Mississauga, Ontario VITEL ELECTRONICS | (416) 676-97 | | Willow Grove | | (609) 662-2900 | | (410) 070-57 | | OUTH CAROLINA | | (803) 772-6760 | Quebec VITEL ELECTRONICS | (514) 636-50 | | YAC PAY: | | | IDAHO | (314) 000-00 | | Austin | | (512) 346-7830<br>(214) 934-9099 | INTERMOUNTAIN TECH MKG | T (208) 888-60 | | Dallas | | (214) 934-9099 | INDIANA | 37(200) 000 00 | | Houston | | (/13) /85-9001 | ELECTRONIC MARKETING | | | ASHINGTON | | (206) 455-3600<br>(414) 792-0590 | CONSULTANTS, INC | (317) 921-34 | | SCONSIN | .,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | (414) 792-0590 | IOWA | (017, 021 0 | | | | | LORENZ SALES | (319) 377-46 | | nternational_ | | | KANSAS | (010) 017 4 | | CILIM Provelles | TEI | (02) 771-91-42 | Merriam | | | EGIOWI, BIUXEIIES | L L | (02) 771-31-42 | LORENZ SALES | (013) 384.6 | | | TIÝ | 61028 | | (515) 304-0. | | DANCE Porio | †E1 | (1) 49-75-10-10 | Wichita<br>LORENZ SALES | (216) 721 0 | | MINUE, FAIIS | I E L | /1\ 49-75-10-10 | KENTUCKY | (310) /21-0 | | | £00 | (1) 49-75-10-13<br>263282 | ELECTRONIC MARKETING | | | COT OFFILMNY | 1 L A | 203202 | CONSULTANTS, INC | (217) 021 2 | | EST GERMANY, | TEI | (0511) 736085 | MICHICAN | (517) 321-3 | | Hannover area | EL | (0511) 736085<br>(0511) 721254 | MICHIGAN MIKE RAICK ASSOCIATES | (212) 644 5 | | | TAX | 022050 | | (313) 644-3 | | Milaskaa | TEI | 922850<br>(089) 4114170<br>(089) 406490 | MISSOURI<br>LORENZ SALES | (214) 007 4 | | Munchen | | (003) 4114170 | LOHENZ SALES | (314) 997-4 | | | £∆≎ | E22002 | NEBRASKA<br>LORENZ SALES | /ADOL ATE 41 | | S4:-44=-a=4 | TE) | (0711) 62 33 77<br>(0711) 625187 | LUMENZ DALES | (402) 475-40 | | Siutigart | EL | (U/11) 02 33 // | NEW MEXICO | /EDE\ 202 91 | | | TAX | 721992 | THORSON DESERT STATES | ,(303) 293-0 | | ONG KONG | 1 L A | 721882<br>852-5-8654525 | NEW YORK NYCOM, INC | /21E\ /27 0 | | UNG KUNG | j k b | 002-0-0004020 | | (315) 437-8 | | | FAX | 852-5-8654335<br>67955AMDAPHX | оню | | | | ILX | 6/955AMDAPHX | Centerville | (640) 400 0 | | ALY, Milan | I EL | (02) 3390541 | DOLFUSS ROOT & CO | (513) 433-6 | | | | (02) 3533241 | Columbus | 10141 | | | FAX | (02) 3498000 | DOLFUSS ROOT & CO | (614) 885-4 | | | TLX | 315286 | Strongsville | | | | | | DOLFUSS ROOT & CO | (216) 238-03 | | ALY, Milan | | | DOLF033 NOOT & 00 | | | NAG | TEL | 462-47-2911 | PENNSYI VANIA | | | NAU | TEL | 462-47-2911<br>462-47-1729 | PENNSYLVANIA DOLFUSS ROOT & CO UTAH R <sup>2</sup> MARKETING | | 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, cohtact your local AMD sales representative. The company assumes no responsibility for the use of any circuits described herein. Advanced Micro Devices, Inc. 901 Thompson Place, P.O. Box 3453, Sunnyvale, CA 94088, USA Tel: (408) 732-2400 • TWX: 910-339-9280 • TELEX: 34-6306 • TOLL FREE: (800) 538-8450 APPLICATIONS HOTLINE TOLL FREE: (800) 222-9323 • (408) 749-5703 © 1988 Advanced Micro Devices, Inc. 026728