## Am29C331 CMOS 16-Bit Microprogram Sequencer #### **PRELIMINARY** #### DISTINCTIVE CHARACTERISTICS #### • 16-Bits Address up to 64K Words Supports 110-ns microcycle time for a 32-bit highperformance system when used with the other members of the Am29C300 Family. - Speed Select - Supports 80-ns system cycle time. - Real-Time Interrupt Support Micro-trap and interrupts are handled transparently at any microinstruction boundary. Built-In Conditional Test Logic Has twelve external test inputs, four of which are used to internally generate an additional four test conditions. Test multiplexer selects one out of 16 test inputs. #### Break-Point Logic Built-in address comparator allows break-points in the microcode for debugging and statistics collection. Master/Slave Error Checking Two sequencers can operate in parallel as a master and a slave. The slave generates a fault flag for unequal results. 33-Level Stack Provides support for interrupts, loops, and subroutine nesting. It can be accessed through the D-bus to support diagnostics. ## **GENERAL DESCRIPTION** The Am29C331 is a 16-bit wide, high-speed single-chip sequencer designed to control the execution sequence of microinstructions stored in the microprogram memory. The instruction set is designed to resemble high-level language constructs, thereby bringing high-level language programming to the micro level. The Am29C331 is interruptible at any microinstruction boundary to support real-time interrupts. Interrupts are handled transparently to the microprogrammer as an unexpected procedure call. Traps are also handled transparently at any microinstruction boundary. This feature allows reexecution of the prior microinstruction. Two separate buses are provided to bring a branch address directly into the chip from two sources to avoid slow turn-on and turn-off times for different sources connected to the data-input bus. Four sets of multiway inputs are also provided to avoid slow turnon and turn-off times for different branch-address sources. This feature allows implementation of table look-up or use of external conditions as part of a branch address. The 33-deep stack provides the ability to support interrupts, loops, and subroutine nesting. The stack can be read through the D-bus to support diagnostics or to implement multitasking at the micro-architecture level. The master/ slave mode provides a complete function check capability for the device. Fabricated using Advanced Micro Devices' 1.6 micron CMOS process, the Am29C331 is powered by a single 5-volt supply. The device is housed in a 120-terminal pin-grid array package. #### SIMPLIFIED BLOCK DIAGRAM Publication # Rev. Amendment 08823 C /0 Issue Date: December 1987 ## RELATED AMD PRODUCTS | Part No. | Description | |-----------|--------------------------------------------------| | Am29114 | Vectored Priority Interrupt Controller | | Am29116 | High-Performance Bipolar 16-Bit Microprocessor | | Am29C116 | High-Performance CMOS 16-Bit Microprocessor | | Am29PL141 | Field-Programmable Controller | | Am29C323 | CMOS 32-Bit Parallel Multiplier | | Am29325 | 32-Bit Floating-Point Processor | | Am29C325 | CMOS 32-Bit Floating-Point Processor | | Am29332 | 32-Bit Extended Function ALU | | Am29C332 | CMOS 32-Bit Extended Function ALU | | Am29334 | 64 x 18 Four-Port, Dual-Access Register File | | Am29C334 | CMOS 64 x 18 Four-Port Dual-Access Register File | | Am29337 | 16-Bit Bounds Checker | | Am29338 | Byte Queue | Figure 1. Am29C331 Detailed Block Diagram # CONNECTION DIAGRAM 120-Lead PGA\* | | A | В | С | D | E | F | G | Н | J | K | L | M | N | |----|------|------------|------|------------|------|------|------|------|--------|-------|-------|-------------|-----| | 1 | M0,0 | M1,0 | M2,0 | M2,1 | CIN | M1,2 | M1,3 | M2,3 | GND | RST | INTR | SLAVE | D15 | | 2 | Do | A0 | M3,0 | M1,1 | M0,2 | M2,2 | M0,3 | M3,3 | EQUAL | OED | INTEN | HOLD | A15 | | 3 | vec | YO | D1 | M0,1 | M3,1 | GND | M3,2 | vcc | A-FULL | ERROR | INTA | Y15 | vac | | 4 | A1 | <b>Y</b> 1 | D2 | | | | | | | | D14 | A14 | Y14 | | 5 | GND | A2 | ¥2 | | | | | | | | D13 | A13 | GND | | 6 | A3 | D3 | GND | | | | | | | | GND | D12 | Y13 | | 7 | Y3 | D4 | A 4 | | | | | | | | A12 | Y12 | D11 | | 8 | D5 | Y4 | vcc | | | | | | | | vcc | <b>Y</b> 11 | A11 | | 9 | GND | <b>A</b> 5 | Y5 | | | | | | | | D10 | A10 | GND | | 10 | D6 | A6 | Y6 | | | | | | | | Y10 | D9 | A9 | | 11 | vcc | <b>D</b> 7 | Т3 | Т6 | GND | T10 | T11 | 10 | vcc | 13 | Y9 | D8 | vcc | | 12 | A7 | T1 | T2 | <b>T</b> 5 | GND | 17 | S0 | S1 | VCC | 12 | 14 | A8 | Y8 | | 13 | ¥7 | TO | Т9 | T4 | GND | T8 | СР | \$3 | VCC | н | \$2 | 15 | FC | CD010380 <sup>\*</sup>Pins facing up. ## PIN DESIGNATIONS (Sorted by Pin No.) | PIN NO. | PIN NAME | PAD<br>NO. | PIN<br>NO. | PIN NAME | PAD<br>NO. | PIN<br>NO. | PIN NAME | PAD<br>NO. | PIN<br>NO. | PIN NAME | PAI | |------------|-------------------|------------|------------|-------------------|------------|------------|------------------------------------|------------|------------|------------------------|-----| | í | | | C-5 | Y <sub>2</sub> | 115 | H-2 | M <sub>3, 3</sub> | 10 | M-5 | A <sub>13</sub> | 80 | | ł | | | C-6 | GND | 113 | H-3 | vcc | 68 | M-6 | D <sub>12</sub> | 81 | | | | | C-7 | A <sub>4</sub> | 52 | H-11 | l <sub>o</sub> | 34 | M-7 | Y <sub>12</sub> | 82 | | A-1 | | | C-8 | Vcc | 53 | H-12 | S <sub>1</sub> | 95 | M-8 | Y <sub>11</sub> | 25 | | A-1<br>A-2 | M <sub>0, 0</sub> | 1 | C-9 | Y <sub>5</sub> | 109 | H-13 | S <sub>3</sub> | 94 | M-9 | A <sub>10</sub> | 86 | | A-2<br>A-3 | D <sub>0</sub> | 120 | C-10 | Y <sub>6</sub> | 48 | J-1 | GND | 11 | M-10 | D <sub>9</sub> | 87 | | A-3<br>A-4 | Vcc | 59 | C-11 | Тз | 44 | J-2 | EQUAL | 71 | M-11 | D <sub>8</sub> | 89 | | A-4<br>A-5 | A <sub>1</sub> | 58 | C-12 | T <sub>2</sub> | 104 | J-3 | A-FULL | 70 | M-12 | A <sub>8</sub> | 30 | | | GND | 56 | C-13 | T <sub>9</sub> | 41 | J-11 | Vcc | 37 | M-13 | 15 | | | A-6 | Аз | 114 | D-1 | M <sub>2, 1</sub> | 4 | J-12 | Vcc | 38 | N-1 | D <sub>15</sub> | 91 | | A-7 | Y <sub>3</sub> | 54 | D-2 | M <sub>1, 1</sub> | 63 | J-13 | VCC | 39 | N-2 | | 16 | | A-8 | D <sub>5</sub> | 51 | D-3 | M <sub>0, 1</sub> | 3 | K-1 | RŠŤ | 13 | N-3 | A <sub>15</sub> | 76 | | A-9 | GND | 50 | D-11 | T <sub>6</sub> | 102 | K-2 | OED | 72 | N-4 | Vcc | 17 | | A-10 | D <sub>6</sub> | 49 | D-12 | T <sub>5</sub> | 43 | K-3 | ERROR | 12 | N-5 | Y <sub>14</sub><br>GND | 19 | | A-11 | Vcc | 47 | D-13 | T <sub>4</sub> | 103 | K-11 | 13 | 92 | N-6 | | 20 | | A-12 | A <sub>7</sub> | 106 | E-1 | C <sub>in</sub> | 5 | K-12 | l <sub>2</sub> | 33 | N-7 | Y <sub>13</sub> | 21 | | A-13 | Y <sub>7</sub> | 46 | E-2 | M <sub>0, 2</sub> | 65 | K-13 | 1 <sub>2</sub> | 93 | N-7<br>N-8 | D <sub>11</sub> | 24 | | B-1 | M <sub>1, 0</sub> | 61 | E-3 | M <sub>3.1</sub> | 64 | L-1 | INTR | 14 | N-9 | A <sub>11</sub> | 84 | | B-2 | A <sub>0</sub> | 60 | E-11 | GND | 97 | L-2 | INTEN | 74 | _ | GND | 26 | | B-3 | Y <sub>0</sub> | 119 | E-12 | GND | 98 | L-3 | INTA | 73 | N-10 | A9 | 28 | | B-4 | Y <sub>1</sub> | 117 | E-13 | GND | 99 | L-4 | D <sub>14</sub> | 18 | N-11 | Vcc | 29 | | B-5 | A <sub>2</sub> | 116 | F-1 | M <sub>1, 2</sub> | 6 | L-5 | D <sub>14</sub> | 79 | N-12 | Y <sub>8</sub> | 90 | | B-6 | D <sub>3</sub> | 55 | F-2 | M <sub>2, 2</sub> | 66 | L-6 | GND | 23 | N-13 | FC | 31 | | B-7 | D <sub>4</sub> | 112 | F-3 | GND | 8 | L-7 | A <sub>12</sub> | 23 | | _ | | | 3-8 | Y <sub>4</sub> | 111 | F-11 | T <sub>10</sub> | 100 | L-8 | VCC | 83 | | | | | 3-9 | A <sub>5</sub> | 110 | F-12 | T <sub>7</sub> | 42 | L-9 | D <sub>10</sub> | 85 | | | | | 3-10 | A <sub>6</sub> | 108 | F-13 | T <sub>8</sub> | 101 | L-10 | | | | | | | 3-11 | D <sub>7</sub> | 107 | G-1 | M <sub>1, 3</sub> | 9 | L-11 | Y <sub>10</sub> | 27 | | | | | 3-12 | T <sub>1</sub> | 45 | G-2 | M <sub>0, 3</sub> | 67 | L-12 | Y <sub>9</sub> | 88 | | | | | 3-13 | T <sub>0</sub> | 105 | G-3 | M <sub>3, 2</sub> | 7 | L-13 | I <sub>4</sub><br>S <sub>2</sub> | 32 | | | | | C-1 | M <sub>2, 0</sub> | 2 | G-11 | T <sub>11</sub> | 40 | M-1 | SLAVE | 35 | | | | | -2 | M3. 0 | 62 | G-12 | s <sub>0</sub> | 36 | M-2 | HOLD | 75 | | | | | :-3 | D <sub>1</sub> | 118 | G-13 | CP | 96 | M-2 | | 15 | | | | | -4 | D <sub>2</sub> | 57 | H-1 | M <sub>2, 3</sub> | 69 | M-4 | Y <sub>15</sub><br>A <sub>14</sub> | 77<br>78 | | | | ## PIN DESIGNATIONS (Sorted by Pin Name) | PIN NAME | PIN<br>NO. | PAD<br>NO. | PIN NAME | PIN<br>NO. | PAD<br>NO. | PIN NAME | PIN<br>NO. | PAD<br>NO. | PIN NAME | PIN<br>NO. | PAD<br>NO. | |-----------------|------------|------------|-----------------|------------|------------|--------------------|------------|------------|-----------------|------------|------------| | | _ | 37 | D <sub>8</sub> | M-11 | 89 | INTEN | L-2 | 74 | Т <sub>6</sub> | D-11 | 102 | | _ | _ | 39 | Do | M-10 | 87 | INTR | L-1 | 14 | T <sub>7</sub> | F-12 | 42 | | _ | _ | 97 | D <sub>10</sub> | L-9 | 85 | M <sub>0, 0</sub> | A-1 | 1 | T <sub>8</sub> | F-13 | 101 | | _ | _ ' | 99 | D <sub>11</sub> | N-7 | 24 | M <sub>0. 1</sub> | D-3 | 3 | T <sub>9</sub> | C-13 | 41 | | A-FULL | J-3 | 70 | D <sub>12</sub> | M-6 | 81 | M <sub>0, 2</sub> | E-2 | 65 | T <sub>10</sub> | F-11 | 100 | | Ao | B-2 | 60 | D <sub>13</sub> | L-5 | 79 | M <sub>0</sub> , 3 | G-2 | 67 | T <sub>11</sub> | G-11 | 40 | | A <sub>1</sub> | A-4 | 58 | D <sub>14</sub> | L-4 | 18 | M <sub>1</sub> , 0 | B-1 | 61 | GND | J-1 | 11 | | A <sub>2</sub> | B-5 | 116 | D <sub>15</sub> | N-1 | 16 | M <sub>1, 1</sub> | D-2 | 63 | GND | N-5 | 20 | | A <sub>3</sub> | A-6 | 114 | GND | E-12 | 97 | M <sub>1, 2</sub> | F-1 | 6 | GND | A-9 | 50 | | A <sub>4</sub> | C-7 | 52 | GND | E-13 | 98 | M <sub>1, 3</sub> | G-1 | 9 | GND | N-9 | 26 | | A <sub>5</sub> | B-9 | 110 | GND | E-11 | 99 | M <sub>2</sub> , 0 | C-1 | 2 | GND | A-5 | 56 | | A <sub>6</sub> | B-10 | 108 | GND | F-3 | 8 | M <sub>2, 1</sub> | D-1 | 4 | Vcc | N-3 | 17 | | A <sub>7</sub> | A-12 | 106 | GND | L-6 | 23 | M <sub>2, 2</sub> | F-2 | 66 | Vcc | N-11 | 29 | | A <sub>8</sub> | M-12 | 30 | GND | C-6 | 113 | M <sub>2, 3</sub> | H-1 | 69 | Vcc | A-3 | 59 | | A <sub>9</sub> | N-10 | 28 | Vcc | J-13 | 38 | M <sub>3, 0</sub> | C-2 | 62 | Vcc | A-11 | 47 | | A <sub>10</sub> | M-9 | 86 | Vcc | H-3 | 68 | M <sub>3, 1</sub> | E-3 | 64 | Yo | B-3 | 119 | | A <sub>11</sub> | N-8 | 84 | Vcc | C-8 | 53 | M <sub>3, 2</sub> | G-3 | 7 | Y <sub>1</sub> | B-4 | 117 | | A <sub>12</sub> | L-7 | 22 | Vcc | L-8 | 83 | M <sub>3, 3</sub> | H-2 | 10 | Y <sub>2</sub> | C-5 | 115 | | A <sub>13</sub> | M-5 | 80 | Vcc | J-12 | 37 | OED | K-2 | 72 | Y <sub>3</sub> | A-7 | 54 | | A14 | M-4 | 78 | Vcc | J-11 | 39 | RST | K-1 | 13 | Y4 | B-8 | 111 | | A <sub>15</sub> | N-2 | 76 | EQUAL | J-2 | 71 | S <sub>0</sub> | G-12 | 36 | Y <sub>5</sub> | C-9 | 109 | | Cin | E-1 | 5 | ERROR | K-3 | 12 | S <sub>1</sub> | H-12 | 95 | Y <sub>6</sub> | C-10 | 48 | | CP | G-13 | 96 | FC | N-13 | 31 | S <sub>2</sub> | L-13 | 35 | Y <sub>7</sub> | A-13 | 46 | | D <sub>0</sub> | A-2 | 120 | HOLD | M-2 | 15 | S <sub>3</sub> | H-13 | 94 | Y <sub>8</sub> | N-12 | 90 | | D <sub>1</sub> | C-3 | 118 | 10 | H-11 | 34 | SLAVE | M-1 | 75 | Y <sub>9</sub> | L-11 | 88 | | D <sub>2</sub> | C-4 | 57 | 1 11 | K-13 | 93 | T <sub>0</sub> | B-13 | 105 | Y <sub>10</sub> | L-10 | 27 | | $D_3$ | B-6 | 55 | l <sub>2</sub> | K-12 | 33 | T <sub>1</sub> | B-12 | 45 | Y <sub>11</sub> | M-8 | 25 | | D <sub>4</sub> | B-7 | 112 | l <sub>3</sub> | K-11 | 92 | T <sub>2</sub> | C-12 | 104 | Y <sub>12</sub> | M-7 | 82 | | D <sub>5</sub> | A-8 | 51 | 14 | L-12 | 32 | T <sub>3</sub> | C-11 | 44 | Y <sub>13</sub> | N-6 | 21 | | D <sub>6</sub> | A-10 | 49 | l <sub>5</sub> | M-13 | 91 | T4 | D-13 | 103 | Y <sub>14</sub> | N-4 | 19 | | D <sub>7</sub> | B-11 | 107 | INTA | L-3 | 73 | T <sub>5</sub> | D-12 | 43 | Y <sub>15</sub> | M-3 | 77 | ## LOGIC SYMBOL ## ORDERING INFORMATION #### Standard Products AMD standard products are available in several packages and operating ranges. The order number (Valid Combination) is formed by a combination of: a. Device Number b. Speed Option (if applicable) c. Package Type d. Temperature Range e. Optional Processing ## Valid Combinations 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 valid combinations, and to obtain additional data on AMD's standard military grade products. | Valid Combinations | | | | | | | | |--------------------|--|--|--|--|--|--|--| | 00.000 | | | | | | | | | AM29C331-1 GC, GCB | | | | | | | | | | | | | | | | | ## 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) for APL products is formed by a combination of: a. Device Number - b. Speed Option (if applicable) - c. Device Class - d. Package Type - e. Lead Finish | Valid C | ombinations | |----------|-------------| | AM29C331 | /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 #### A<sub>0</sub> - A<sub>15</sub> Alternate Data (Input) Input to address multiplexer and counter. ## A-FULL Almost Full (Bidirectional; Three-State) Indicates that $28 \leqslant SP \leqslant 63$ (meaning there are five or less empty locations left on stack). Also active during stack underflow. ## Cin Carry In (Input, Active LOW) Carry in to the incrementer. ## CP Clock Pulse (Input) Clocks sequencer at the LOW-to-HIGH transition. ## D<sub>0</sub> - D<sub>15</sub> Data (Bidirectional, Three-State) Input to address multiplexer, counter, stack, and comparator register. Output for stack and stack pointer. ## EQUAL Equal (Bidirectional, Three-State) Indicates that the address comparator is enabled and has found a match. ## ERROR Error (Output) Indicates a master/slave error in the slave mode. Indicates a malfunctioning driver or contention of any output in the master mode. ## FC Force Continue (Input) Overrides instruction with CONTINUE. #### HOLD Hold (Input) Stops the sequencer and three-states the outputs. ## I<sub>0</sub>-I<sub>5</sub> Instruction (input) Selects one of 64 instructions. #### INTA Interrupt Acknowledge (Bidirectional; Three-State, Active LOW) indicates that an interrupt is accepted. ## INTEN Interrupt Enable (Input) Enables interrupts. ## INTR Interrupt Request (Input) Requests the sequencer to interrupt execution. ## M<sub>0-3, 0-3</sub> Multiway (Input) Four sets of multiway inputs providing 16-way branches. The first index refers to the set number. ## OED Output Enable — D-Bus (Input) Enables the D-bus driver, provided that the sequencer is not in the hold or slave mode. ## RST Reset (Input; Active LOW) Resets the sequencer. ## S<sub>0</sub> - S<sub>3</sub> Select (Input) Selects one of 16 test conditions. #### SLAVE Slave (Input) Makes the sequencer a slave. ## To-T11 Test (Input) Provides external test inputs. ## Y<sub>0</sub> - Y<sub>15</sub> Address (Bidirectional; Three-State) Output of microcode address. Input for interrupt address. #### **FUNCTIONAL DESCRIPTION** #### **Architecture** The major blocks of the sequencer are the address multiplexer, the address register (AR), the stack (with the top of stack denoted TOS), the counter (C), the test multiplexer with logic, and the address comparison register (R) (Figure 1). The bidirectional D-bus provides branch addresses and iteration counts; it also allows access to the stack from the outside. The A-bus may be used for map addresses. There are four sets of four-bit multiway branch inputs (M). The bidirectional Y-bus either outputs microprogram addresses or inputs interrupt addresses. The buses are all 16 bits wide. Figure 1 shows a detailed block diagram of the sequencer. #### Address Multiplexer The address multiplexer can select an address from any of five sources: - 1) A branch address supplied by the D-bus - 2) A branch address supplied by the A-bus - 3) A multiway-branch address - 4) A return or loop address from the top of stack - 5) The next sequential address from the incrementer #### Multiway-Branch Address A multiway-branch address is formed by substituting the lower four bits of the address on the D-bus $(D_3,\,D_2,\,D_1,\,D_0)$ with one of the four sets $(M_{0X},\,M_{1X},\,M_{2X},\,$ or $M_{3X})$ of four-bit multiway-branch addresses. The multiway-branch set is selected by the number $D_1D_0$ , while the bits $D_3$ and $D_2$ are ''don't cares'' (see Figure 2). | D <sub>1</sub> | D <sub>0</sub> | Multiway Set Selected | |----------------|----------------|-----------------------| | 0 | 0 | Mox | | 0 | 1 | M <sub>1X</sub> | | 1 | 0 | M <sub>2</sub> X | | 1 | 1 | M <sub>3X</sub> | Notes: 1. $D_1$ and $D_0$ select one out of four multiway sets. $D_3$ and $D_2$ are "don't cares." - Each set of M<sub>3X</sub> M<sub>0X</sub> can select one of sixteen locations. The multiway-branch address is the concatenation of D<sub>15</sub> - D<sub>4</sub> (base address) and M<sub>X3</sub> - M<sub>X0</sub>. - 3. For a given base address, there can be four look-up tables, each sixteen deep. Figure 2. Multiway Branch ## Address Register and Incrementer The address register contains the current address. It is loaded from the interrupt multiplexer and feeds the incrementer. The incrementer is inhibited if $\overline{\text{CiN}}$ is taken HIGH. #### Stack A 33-word-deep and 16 bit-wide stack provides first-in last-out storage for return addresses, loop addresses, and counter values. Items to be pushed come from the incrementer, the interrupt-return-address register, the counter, or the D-bus. Items popped go to the address multiplexer, the counter, or the D-bus. The access to the stack via the D-bus may be used for context switching, stack extension, or diagnostics. As the stack is only accessible from the top, stack extension is done by temporarily storing the whole or some lower part of the stack outside the sequencer. The save and the later restore are done with pop and push operations, respectively, at balanced points in the microprogram; for example, points with the same stack depth. The internal D-bus driver must be turned on when popping an item to the D-bus; if the driver is off, the item will be unstacked instead. The driver is normally turned on when the Output Enable signal is asserted and the sequencer is not being reset $(OED = 1, \overline{RST} = 1)$ . The stack pointer is a modulo 64 counter, which is incremented on each push and decremented on each pop. The stack pointer is reset to zero when the sequencer is reset, but the pointer may also be reset by instruction. Thus, the stack pointer indicates the number of items on the stack as long as stack overflow or underflow has not occurred. Overflow happens when an item is pushed onto a full stack, whereby the item at the bottom of the stack is overwritten. Underflow happens when an item is popped from an empty stack; in this case the item is undefined. In the case of stack overflow, the SP is incremented for every push after overflow. Thus, immediately after the first occurence of stack overflow, the SP will be equal to 34. Subsequent pushes will increment the SP to 35, 36 ... 61, 62, 63, 0, 1, etc. In the case of stack underflow, the SP is decremented for every pop after underflow. Thus, immediately after the first occurrence of stack underflow, the SP will be equal to 63. Subsequent pops will decrement the SP to 62, 61, ... 2, 1, 0, 63, etc. The contents of the stack pointer are present on the D-bus for all instructions except POP D, provided the driver is turned on. The output signal, A–FULL, is active under the following condition: $28 \le SP \le 63$ . #### Counter The counter may be used as a loop counter. It may be loaded from the D-bus, the A-bus, or via a pop from the stack. Its contents may also be pushed onto the stack. A normal for-loop is set up by a FOR instruction, which loads the counter from the D- or A-bus with the desired number of iterations; the instruction also pushes onto the stack a loop address that points to the next sequential instruction. The end of the loop is given by an unconditional END FOR instruction, which tests the counter value against the value one and then decrements the counter. If the values differ, the loop is repeated by selecting the address at the stack as the next address. If the values are equal, the loop is terminated by popping the stack, thereby removing the loop address, and selecting the address from the incrementer as the next address. The number of iterations is a 16-bit unsigned number, except that the number zero corresponds to 65,536 iterations. By pushing and popping counter values it is possible to handle nested loops. #### Address Comparison The sequencer is able to compare the address from the interrupt multiplexer with the contents of the comparator register. The instruction SET loads the comparator register with the address on the D-bus and enables the comparison, while CLEAR disables it. The comparison is disabled at reset. A HIGH is present at the output EQUAL if the comparison is enabled and the two addresses are equal. The comparison is useful for detection of a break point or counting the number of times a microinstruction at a specific address is executed. ## Instruction Set The sequencer has 64 instructions that are divided into four classes of 16 instructions each. The instruction lines $I_0-I_5$ use $I_5$ and $I_4$ to select a class, and $I_0-I_3$ to select an instruction within a class. The classes are: - l<sub>5</sub> l<sub>4</sub> Classes - Conditional sequence control, - Conditional sequence control with inverted polarity, - 1 0 Unconditional sequence control, and - 1 1 Special function with implicit continue. Note that for the first three classes $I_5$ forces the condition to be true and $I_4$ inverts the condition. The basic instructions of the first three classes are shown in Table 1 and the instructions of the fourth class in Table 2. Structured microprogramming is supported by sequencer instructions that singly or in pairs correspond to high-level language control constructs. Examples are FOR I: = D DOWN TO 1 DO ... END FOR and CASE N OF ... END CASE. The instructions have been given high-level language names where appropriate. Figure 2 shows how to microprogram important control constructs; the high-level language is on the left and the microcode on the right. ## **Test Conditions** The condition for a conditional instruction is supplied by a test multiplexer, which selects one out of sixteen tests with the select lines $S_0 - S_3$ . Twelve of these are supplied directly by the inputs $T_0 - T_{11}$ , while the remaining four tests are generated by the test logic from the inputs $T_8 - T_{11}$ . The following table shows the assignments. | (S <sub>0</sub> - S <sub>3</sub> | ) <sub>H</sub> Test | Intended Use | |----------------------------------|-------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------| | 0 – 7 | $T_0 - T_7$ | General | | 8 | Т8 | C (Carry) | | 9 | Т9 | N (Negative) | | A | T <sub>10</sub> | V (Overflow) | | В | T <sub>11</sub> | Z (Zero or equal) | | С | $T_8 + T_{11}$ | C + Z (Unsigned less | | D | T <sub>8</sub> + T <sub>11</sub> | than or equal, borrow mode) $\overline{C} + Z$ (Unsigned less | | E<br>F | T <sub>9</sub> ⊕ T <sub>10</sub><br>(T <sub>9</sub> ⊕ T <sub>10</sub> ) + T <sub>11</sub> | than or equal) N⊕V (Signed less than) (N⊕V) + Z (Signed less than or equal) | #### **Force Continue** The sequencer has a force continue (FC) input, which overrides the instruction inputs $l_0-l_5$ with a CONTINUE instruction. This makes it possible to share the microinstruction field for the sequencer instruction with some other control or to initialize a writable control store. #### Reset In order to start a microprogram properly, the sequencer must be reset. The reset works like an instruction overriding both the instruction input and the force continue input. The reset selects the address 0 at the address multiplexer, forces the EQUAL output to LOW, and disregards a potential interrupt request. It synchronously disables the address comparison and initializes the stack pointer to 0. The contents of the stack are invalid after a reset. TABLE 1. INSTRUCTION SET for IsI4 = 00, 01, 10 | I <sub>5</sub> – I <sub>0</sub> | Instruction | Con<br>Y | d.: Fail<br>Stack | Coi<br>Y | nd.: Pass<br>Stack | Counter | Comp. | D-Mux | |---------------------------------|------------------|----------|-------------------|----------|--------------------|---------|--------------|-------| | 00, 10, 20 | Goto D | INC | _ | D | - | - | - | SP | | 01, 11, 21 | Call D | INC | _ | D | Push INC | - | _ | SP | | 02, 12, 22 | Exit D | INC | _ | D | Pop | - | - | SP | | 03, 13, 23 | End for D, C≠1 | INC | _ | D | l - ' | C←C – 1 | - | SP | | 00, 10, 20 | End for D, C = 1 | INC | _ | INC | _ | C←C - 1 | _ | SP | | 04, 14, 24 | Goto A | INC | _ | Α | l – | - | - | SP | | 05, 15, 25 | Call A | INC | _ | Α | Push INC | 1 - | <del>-</del> | SP | | 06, 16, 26 | Exit A | INC | _ | A | Pop | - | - | SP | | 07, 17, 27 | End for A, C≠1 | INC | _ | Α | - ' | C←C - 1 | _ | SP | | 07, 17, 27 | End for A, C = 1 | INC | _ | INC | - | C←C – 1 | - | SP | | 08, 18, 28 | Goto M | INC | - | D:M | _ | - | _ | SP | | 09, 19, 29 | Call M | INC | _ | D:M | Push INC | - | - | SP | | 0A, 1A, 2A | Exit M | INC | - | D:M | Pop | - | - | SP | | 0B, 1B, 2B | End for M, C≠1 | INC | _ | D:M | - | C←C – 1 | - | SP | | 05, 15, 25 | End for M. C = 1 | INC | - | INC | - | C←C – 1 | _ | SP | | 0C, 1C, 2C | End Loop | INC | Pop | TOS | - | - | _ | SP | | 0D, 1D, 2D | Call Coroutine | INC | | TOS | Pop & | _ | - | SP | | 05, .5, 25 | | | | 1 | Push INC | 1 | | | | 0E, 1E, 2E | Return | INC | _ | TOS | Pop | - | _ | SP | | 0F, 1F, 2F | End for, C≠1 | INC | Pop | TOS | - | C←C - 1 | _ | SP | | ,, <u></u> , | End for, C = 1 | INC | Pop | INC | Pop | C←C – 1 | - | SP | $\begin{array}{ll} \text{Cond.} &= (\text{Test } \left[\, \text{S} \,\right] \, \text{OR} \, \, I_5) \, \, \text{XOR} \, \, I_4 \\ : &= \text{Concatination} \end{array}$ = Counter INC = Output of Incrementer = AR + 1 (if $\overline{C_{in}}$ = LOW) Note: For unconditional instructions, the action marked under "Cond: Pass" is taken. TABLE 2. INSTRUCTION SET for 1514 = 11 | I <sub>5</sub> - I <sub>0</sub> | Instruction | γ | Stack | Counter | Comp. | D-Mux | |---------------------------------|---------------|-----|----------|---------|-------------|-------| | 30 | Continue | INC | _ | _ | _ | SP | | 31 | For D | INC | Push INC | C←D | _ | SP | | 32 | Decrement | INC | _ | C←C – 1 | - | SP | | 33 | Loop | INC | Push INC | _ | | SP | | 34 | Pop D | INC | Pop | _ | - | TOS | | 35 | Push D | INC | Push D | _ | - | SP | | 36 | Reset SP | INC | SP←0 | _ | - | SP | | 37 | For A | INC | Push INC | C←A | - | SP | | 38 | Pop C | INC | Pop | C←TOS | _ | SP | | 39 | Push C | INC | Push C | _ | _ | SP | | 3A | Swap | INC | TOS←C | C←TOS | - | SP | | 3B | Push C Load D | INC | Push C | C←D | - | SP | | 3C | Load D | INC | | C←D | _ | SP | | 3D | Load A | INC | 1 - | C←A | - | SP | | 3E | Set | INC | _ | - | R←D, Enable | SP | | 3F | Clear | INC | _ | | Disable | SP | R = Comp. Register #### Interrupts The sequencer may be interrupted at the completion of the current microcycle by asserting the interrupt request input INTR. The return address of the interrupted routine is saved on the stack so that nested interrupts can be easily implemented. An interrupt is accepted if interrupts are enabled and the sequencer is not being reset or held (INTEN = HIGH, RST = HIGH, and HOLD = LOW). The interrupt-acknowledge output (INTA) goes LOW when an interrupt is accepted. When there is no interrupt, addresses go from the address multiplexer to the Y-bus via the driver, and to the address register and the comparator via the interrupt multiplexer. When there is an interrupt, the driver of the sequencer is turned off, an external driver is turned on, and the interrupt multiplexer is switched. The interrupt address is supplied via the external driver to the Y-bus, the address register, and the comparator (Figure 4). In order to save the address from the address multiplexer, the address is stored in the interrupt return address register, which for simplicity is clocked every cycle. The next microinstruction is the first microinstruction of the interrupt routine (Figure 5). In this cycle the address in the interrupt return address register is automatically pushed onto the stack. Therefore the microinstruction in this cycle must not use the stack; if a stack operation is programmed, the result is undefined. The instructions that do not use the stack are GOTO D, GOTO A, GOTO M, CONTINUE, DECREMENT, LOAD D, LOAD A, SET and CLEAR. A RETURN instruction terminates the interrupt routine and the interrupted routine is resumed. Interrupts only work with a single-level control path. #### **Traps** A trap is an unexpected situation linked to current microinstruction that must be handled before the microinstruction completes and changes the state of the system. An example of such a situation is an attempt to read a word from memory across a word boundary in a single cycle. When a trap occurs, the current microinstruction must be aborted and re-executed after the execution of a trap routine, which in the meantime will take corrective measures. An interrrupt, on the other hand, is not linked directly to the current microinstruction that can complete safely before an interrupt routine is executed. Execution of a trap requires that the sequencer ignore the current microinstruction, select the trap return address at the address multiplexer, and initiate an interrupt. This will save the trap return address on the stack and issue the trap address from an external source (Figure 6). The address register contains the address of the microinstruction in the pipeline register, thus the address register already contains the trap return address when a trap occurs. This address can be selected by the address multiplexer by disabling the incrementer ( $\overline{C}_{IN}=1$ ), and using the force continue mode (FC=1). In this mode the sequencer ignores the current microinstruction. The remaining part of the trap handling is done by the interrupt (Figure 7), thus the section on interrupts also applies to traps. There is one exception, however. The interrupt enable cannot be used as a trap enable as it does not control the force continue mode and the carry-in to the incrementer. #### Hold Mode The sequencer has a hold mode in which the operation is suspended. The outputs (Y, INTA, A-FULL & EQUAL) are disabled and the sequencer enters the hold mode immediately after the HOLD signal goes active. While the sequencer is in this mode, the internal state is left unchanged and the D-bus is disabled. The outputs (Y, INTA, A-FULL & EQUAL) are enabled again and the sequencer leaves the hold mode after the cycle immediately after the HOLD signal goes inactive. In a time-multiplexed multi-microprocess system there may be one sequencer for all processes with microprogrammed context save and restore, or there may be one sequencer per microprocess permitting fast process switch. In the latter case the Y-buses of the sequencers are tied together and connected to a single microprogram store. A control unit decides on a cycle-by-cycle basis what sequencer should be running, and activates the HOLD signal to the remaining sequencers. The hold mode has higher priority than interrupts, and works independently of the reset. The hold mode can only be used with a single-level control path. ## Master/Slave Configuration In some systems reliability is very important. The master/slave configuration that consists of two sequencers operated in parallel is able to detect faults in both the interconnect and the internal function of the sequencers. One sequencer is the master and operates normally. The other is the slave, i.e., all outputs except the signal ERROR are turned into inputs and connected to the outputs of the master. Since the slave is operated in parallel with the master, it can compare its result with the result of the master and signal an error if they differ. The error signal from the master indicates a malfunctioning driver or contention. Because a TTL output goes HIGH when power is missing, the ERROR signal also indicates power failure. ## High-Level Language Constructs An example of high-level language constructs using Am29C331 instructions is given in Figure 3 (3-1, 3-2, 3-3, and 3-4). REPEAT LOOP UNTIL CC END LOOP NOT CC WHILE CC DO LOOP IF NOT CC THEN EXIT L END WHILE END LOOP LOOP LOOP END CASE B: IF CC THEN EXIT IF CC THEN EXIT L END LOOP END LOOP Figure 3-1. Loops with Unknown Number of Iterations Figure 3-2. Loop with Known Number of Iterations Figure 3-3. Case Statement (with $D=A_{15}\ldots A_4XX00$ and $M_{0,\ 0-3}=A_3|_{1}|_{0}$ during the GOTO M instruction. $A_1A_0$ must be 00, and X signifies a don't care.) PUSH D C IF X THEN IF NOT X THEN GOTO A IF NOT Y THEN GOTO B IF Y THEN -, RETURN (TO C) ELSE B: -, RETURN (TO C) END IF ELSE IF Z THEN IF NOT Z THEN GOTO D -, RETURN (TO D) D: ELSE -, RETURN (TO C) END IF END IF C: Figure 3-4. Double-Nested If Statement ## **Instruction Set Definition** Legend: ● = Other instruction ⊙ = Instruction being described P = Test pass F = Test fail = Register in part $CC = (Test [S_3 - S_0])$ | Opcode<br>(I <sub>5</sub> - I <sub>0</sub> ) | Mnemonics | Description | Execution Example | |----------------------------------------------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------| | 20 <sub>H</sub> | BRA_D | GOTO D<br>Unconditional branch to the address specified<br>by the D inputs. The D port must be disabled to<br>avoid bus contention. | 50 | | 24 <sub>H</sub> | BRA_A | GOTO A Unconditional branch to the address specified by the A inputs. | 51 | | 28 <sub>H</sub> | BRA_M | GOTO Multiway $(D_{15}-D_4\ M_{X3}-M_{X0})$ Unconditional branch to the address specified by the M inputs concatenated with the D input. The lower four bits on the D bus $(D_3-D_0)$ are replaced by one of the four sets of the four-bit multiway branch addresses. The multiway branch set is selected by bits $D_1$ and $D_0$ while bits $D_3$ and $D_2$ are "don't cares." | 90<br>91<br>92 | | 2C <sub>H</sub> | BRA_S | GOTO TOS<br>Unconditional branch to the addiess on the top<br>of the stack. | PF001730 | | 00Н | BRCC_D | IF CC THEN GOTO D ELSE CONTINUE If CC is HIGH (pass), branch to the address specified by D. If CC is LOW (fail), continue. The D port must be disabled to avoid bus contention. | 50 | | 04 <sub>H</sub> | BRCC_A | IF CC THEN GOTO A ELSE CONTINUE If CC is HIGH (pass), branch to the address specified by A. If CC is LOW (fail), continue. | 51 <b>6</b> F | | 08 <sub>H</sub> | BRCC_M | IF CC THEN GOTO Multiway ( $D_{15} - D_4 \ Mx_3 - Mx_0$ ) ELSE CONTINUE If CC is HIGH (pass), branch to the address specified by D inputs concatenated with the M inputs. If CC is LOW (fail) continue. The lower four bits on the D bus ( $D_3 - D_0$ ) are replaced by one of the four sets of the 4-bit multiway branch addresses. The multiway branch set is selected by bits $D_1$ and $D_0$ while bits $D_3$ and $D_2$ are "don't cares." | 53 P 90 91 92 | | осн | BRCC_S | IF CC THEN GOTO TOS ELSE POP STACK CONTINUE If CC is HIGH (pass), branch to the address on the top of the stack. If CC is LOW (fail), pop the stack and continue. | PF001740 | | Opcode<br>(I <sub>5</sub> - I <sub>0</sub> ) | Mnemonics | Description | Execution Example | |----------------------------------------------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------| | 10 <sub>H</sub> | BRNC_D | IF NOT CC THEN GOTO D ELSE CONTINUE If CC is LOW (pass), branch to the address specified by D. If CC is HIGH (fail), continue. The D Port must be disabled to avoid Bus contention. | | | 14 <sub>H</sub> | BRNC_A | IF NOT CC THEN GOTO A ELSE CONTINUE If CC is LOW (pass), branch to the address specified by A. If CC is HIGH (fail), continue. | 50 | | 18 <sub>H</sub> | BRNC_M | IF NOT CC THEN GOTO Multiway (D <sub>15</sub> - D <sub>4</sub> M <sub>X3</sub> - M <sub>X0</sub> ) ELSE CONTINUE If CC is LOW (pass), branch to the address specified by D inputs concatenated with the M inputs. If CC is HIGH (fail), continue. The lower four bits on the D bus (D <sub>3</sub> - D <sub>0</sub> ) are replaced by one of the four sets of the 4-bit multiway branch addresses. The multiway branch set is selected by bits D <sub>1</sub> and D <sub>0</sub> while bits D <sub>3</sub> and D <sub>2</sub> are "don't cares." | 52 F<br>53 P 90<br>91 | | 1C <sub>H</sub> | BRNC_S | IF NOT CC THEN GOTO TOS ELSE POP STACK CONTINUE If CC is LOW (pass), branch to the address on the top of the stack. If CC is HIGH (fail), pop the stack and continue. | PF001750 | | 21 <sub>H</sub> | CALL_D | CALL D Unconditional branch to the subroutine specified by the D inputs. Push the return address (address Reg. + 1) on the stack. The D port must be disabled to avoid bus contention. | 1 | | 25 <sub>H</sub> | CALL_A | CALL A Unconditional branch to the subroutine specified by the A inputs. Push the return address (Address Reg. + 1) on the stack. | 50 STACK 51 PC + 1 | | 29 <sub>Н</sub> | CALL_M | CALL Multiway (D <sub>15</sub> - D <sub>4</sub> M <sub>X3</sub> - M <sub>X0</sub> ) Unconditional branch to the subroutine specified by the D inputs concatenated with the multiway inputs. Push the return address (Address Reg. + 1) on the stack. The lower four bits on the D bus (D <sub>3</sub> - D <sub>0</sub> ) are replaced by one of the four sets of the 4-bit multiway branch addresses. The multiway branch set is selected by bits D <sub>1</sub> and D <sub>0</sub> while bits D <sub>3</sub> and D <sub>2</sub> are "don't cares." | 52 90<br>53<br>91<br>92 | | 2D <sub>H</sub> | CALL_S | CALL TOS Unconditional branch to the subroutine specified by the address on the top of the stack. The stack is popped and the return address (Address Reg. + 1) is then pushed onto the stack. | PF001760 | | Opcode<br>(1 <sub>5</sub> - 1 <sub>0)</sub> | Mnemonics | Description | Execution Example | |---------------------------------------------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------| | 01 <sub>H</sub> CCC_D | | IF CC, THEN CALL D ELSE CONTINUE If CC is HIGH (pass), call the subroutine specified by the D inputs. Push the return address (Address Reg. + 1) on the stack. If CC is LOW (fail), continue. The D port must be disabled to avoid bus contention. | | | 05 <sub>H</sub> | CCC_A | IF CC, THEN CALL A ELSE CONTINUE If CC is HIGH (pass), call the subroutine specified by the A inputs. Push the return address Reg. + 1) on the stack. If CC is LOW (fail), continue. | 50 STACK | | 09н | CCC_M | IF CC, THEN CALL Multiway ( $D_{15} - D_4 \text{ M}_{X3} - M_{X0}$ ) ELSE CONTINUE If CC is HIGH (pass), call the subroutine specified by the D inputs concatenated with the M inputs. Push the return address (Address Reg. + 1) on the stack. The lower four bits on the D bus ( $D_3 - D_0$ ) are replaced by one of the four sets of the 4-bit multiway branch addresses. The multiway branch set is selected by bits $D_1$ and $D_0$ while bits $D_3$ and $D_2$ are "don't cares." | 52 OF PC + 1 53 OP 90 54 91 55 92 | | 0D <sub>H</sub> | ccc_s | IF CC, THEN CALL TOS ELSE CONTINUE If CC is HIGH (pass), call the subroutine specified by the address on the top of the stack. The stack is popped and the return address (Address Reg. + 1) is pushed onto the stack. If CC is LOW (fail), continue. | PF001770 | | 11 <sub>H</sub> | CNC_D | IF NOT CC, THEN CALL D ELSE CONTINUE If CC is LOW (pass), call the subroutine specified by the D inputs. Push the return address (Address Reg. + 1) on the stack. If CC is HIGH (fail), continue. The D port must be disabled to avoid bus contention. | | | 15 <sub>H</sub> | CNC_A | IF NOT CC, THEN CALL A ELSE CONTINUE If CC is LOW (pass), call the subroutine specified by the A inputs. Push the return address (Address Reg. + 1) on the stack. If CC is HIGH (fail), continue. | 50 51 51 STACK | | 19н | CNC_M | IF NOT CC, THEN CALL Multiway $(D_{15}-D_4\ M_{X3}-M_{X0})$ ELSE CONTINUE If CC is LOW (pass), call the subroutine specified by the D inputs concatenated with the M inputs. Push the return address (Address Reg. + 1) on the stack. The lower four bits on the D bus $(D_3-D_0)$ are replaced by one of the four sets of the 4-bit multiway branch addresses. The multiway branch set is selected by bits $D_1$ and $D_0$ while bits $D_3$ and $D_2$ are "don't cares." | 52 F PC + 1 54 53 P 90 54 91 55 92 | | 1D <sub>H</sub> | CNC_S | IF NOT CC, THEN CALL TOS ELSE CONTINUE If CC is LOW (pass), call the subroutine specified by the address on the top of the stack. The stack is popped and the return address (Address Reg. + 1) is pushed onto the stack. | PF001780 | | Opcode<br>(I <sub>5</sub> - I <sub>0</sub> ) | Mnemonics | Description | Execution Example | |----------------------------------------------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------| | 22 <sub>H</sub> | EXIT_D | EXIT TO D Unconditional branch to the address specified by the D inputs and pop the stack. The D port must be disabled to avoid bus contention. | | | 26 <sub>H</sub> | EXIT_A | EXIT TO A Unconditional branch to the address specified by the A inputs and pop the stack. | 50 | | 2Ан | EXIT_M | EXIT TO Multiway $(D_{15}-D_4\ M_{X3}-M_{X0})$ Unconditional branch to the address specified by the D inputs concatenated with the M inputs and pop the stack. The lower four bits on the D bus $(D_3-D_0)$ are replaced by one of the four sets of the 4-bit multiway branch addresses. The multiway branch set is selected by bits $D_1$ and $D_0$ while $D_3$ and $D_2$ are "don't cares." | 51 90<br>91<br>STACK 92 | | 2E <sub>H</sub> | EXIT_S | EXIT TO TOS Unconditional branch to the address on the top of the stack and pop the stack. Also used for unconditional returns. | PF001790 | | 02 <sub>H</sub> | XTCC_D | IF CC, THEN EXIT TO D ELSE CONTINUE If CC is HIGH (pass), exit to the address specified by the D inputs and pop the stack. If CC is LOW (fail), continue with no pop. The D port must be disabled to avoid bus contention. | STACK PC + 1 | | 06 <sub>H</sub> | XTCC_A | IF CC, THEN EXIT TO A ELSE CONTINUE If CC is HIGH (pass), exit to the address specified by the A inputs and pop the stack. If CC is LOW (fail), continue with no pop. | STACK 51 F 52 | | 0A <sub>H</sub> | XTCC_M | IF CC, THEN EXIT TO Muttiway (D <sub>15</sub> – D <sub>4</sub> M <sub>X3</sub> – M <sub>X0</sub> ) ELSE CONTINUE If CC is HIGH (pass), exit to the address specified by the D inputs concatenated with the M inputs and pop the stack. The lower four bits on the D bus (D <sub>3</sub> – D <sub>0</sub> ) are replaced by one of the four sets of the 4-bit muttiway branch addresses. The multiway branch set is selected by bits D <sub>1</sub> and D <sub>0</sub> while bits D <sub>3</sub> and D <sub>2</sub> are "don't cares." | 53<br>54<br>55<br>56 | | 0E <sub>H</sub> | xtcc_s | IF CC, THEN EXIT TO TOS ELSE CONTINUE If CC is HIGH (pass), exit to the address on the top of the stack and pop the stack. If CC is LOW (fail), continue with no pop. Also used for conditional returns. | PF001800 | | Opcode<br>(I <sub>5</sub> – I <sub>0</sub> ) | Mnemonics | Description | Execution Example | |----------------------------------------------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------| | 12 <sub>H</sub> | XTNC_D | IF NOT CC, THEN EXIT TO D ELSE CONTINUE If CC is LOW (pass), exit to the address specified by the D inputs and pop the stack. If CC is HIGH (fail), continue with no pop. The D port must be disabled to avoid bus contention. | STACK PC + 1 | | 16 <sub>H</sub> | XTNG_A | IF NOT CC, THEN EXIT TO A ELSE CONTINUE If CC is LOW (pass), exit to the address specified by the A inputs and pop the stack. If CC is HIGH (fail), continue with no pop. | STACK 51 F | | 1A <sub>H</sub> | XTNC_M | IF NOT CC, THEN EXIT TO Multiway $(D_{15} - D_4 - M_{X3} - M_{X0})$ ELSE CONTINUE If CC is LOW (pass), exit to the address specified by the D inputs concatenated with the M inputs and pop the stack. The lower four bits on the D bus $(D_3 - D_0)$ are replaced by one of the four sets of the 4-bit multiply branch addresses. The multiway branch set is selected by bits $D_1$ and $D_0$ while bits $D_3$ and $D_2$ are "don't cares." | 52<br>53<br>54<br>55 | | 1E <sub>H</sub> | XTNC_S | IF NOT CC, THEN EXIT TO TOS ELSE CONTINUE If CC is LOW (pass), exit to the address on the top of the stack and pop the stack. If CC is HIGH (fail), continue with no pop. Also used for conditional returns. | PF001810 | | 23 <sub>H</sub> | DJMP_D | IF CNT ≠ 1 THEN CNT: = CNT − 1 GOTO D ELSE CNT: = CNT − 1 CONTINUE If the counter is not equal to one, decrement the counter and branch to the address specified by the D inputs. If the counter is equal to one, then decrement the counter and continue. The D port must be disabled to avoid bus contention. | 50 | | 27н | DJMP_A | IF CNT ≠ 1 THEN CNT: = CNT - 1 GOTO A ELSE CNT: = CNT - 1 CONTINUE If the counter is not equal to one, decrement the counter and branch to the address specified by the A inputs. If the counter is equal to one, then decrement the counter and continue. | 51 52 COUNTER = 1 COUNTER COUNTER = 1 | | 2Вн | DJMP_M | IF CNT $\neq$ 1 THEN CNT:= CNT - 1 GOTO Multiway (D <sub>15</sub> - D <sub>4</sub> M <sub>X3</sub> - M <sub>X0</sub> ) ELSE CNT:= CNT - 1 CONTINUE If the counter is not equal to one, decrement the counter and branch to the address specified by the D inputs concatenated with the M inputs. The lower four bits on the D bus (D <sub>3</sub> - D <sub>0</sub> ) are replaced by one of the four sets of the 4-bit multiway branch addresses. The multiway branch set is selected by bits D <sub>1</sub> and D <sub>0</sub> while bits D <sub>3</sub> and D <sub>2</sub> are "don't cares." | PF001820 | | 2F <sub>H</sub> | DJMP_S | IF CNT ≠ 1 THEN CNT: = CNT − 1 GOTO TOS ELSE CNT: = CNT − 1 POP STACK CONTINUE If the counter is not equal to one, decrement the counter and branch to the address on the top of the stack. If the counter is equal to one, then decrement the counter, pop the stack and continue. | | | | | | | | Opcode<br>(I <sub>5</sub> – I <sub>0</sub> ) | Mnemonics | Description | Execution Example | |----------------------------------------------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------| | 03 <sub>H</sub> | DJCC_D | IF CC AND CNT ≠1 THEN CNT: = CNT-1 GOTO D ELSE CNT: = CNT-1 CONTINUE If CC is HIGH (pass) and the counter is not equal to one, decrement the counter and branch to the address specified by the D inputs. If CC is LOW (fail) or the counter is equal to one, then decrement the counter and continue. The D port must be disabled to avoid bus contention. | 50 | | 07 <sub>H</sub> | DJCC_A | IF CC AND CNT ≠ 1 THEN CNT: = CNT − 1 GOTO A ELSE CNT: = CNT − 1 CONTINUE If CC is HIGH (pass) and the counter is not equal to one, decrement the counter and branch to the address specified by the A inputs. If CC is LOW (fail) or the counter is equal to one, then decrement the counter and continue. | P AND COUNTER # 1 COUNTER F OR COUNTER = 1 | | 0B <sub>H</sub> | DJCC_M | IF CC AND CNT $\neq$ 1 THEN CNT:= CNT - 1 GOTO Multiway (D <sub>15</sub> - D <sub>4</sub> M <sub>X3</sub> - M <sub>X0</sub> ) ELSE CNT:= CNT - 1 CONTINUE If CC is HIGH (pass) and the counter is not equal to one, decrement the counter and branch to the address specified by the D inputs concatenated with the M inputs. The lower four bits on the D bus (D <sub>3</sub> - D <sub>0</sub> ) are replaced by one of the four sets of the 4-bit multiway branch addresses. The multiway branch set is selected by bits D <sub>1</sub> and D <sub>0</sub> while bits D <sub>3</sub> and D <sub>2</sub> are "don't cares." | PF001830 | | 0F <sub>H</sub> | DJCC_S | IF CC AND CNT ≠ 1 THEN CNT: = CNT − 1 GOTO TOS ELSE CNT: = CNT − 1 POP STACK CONTINUE If CC is HIGH (pass) and the counter is not equal to one, decrement the counter and branch to the address on the top of the stack. If CC is LOW (fail) or the counter is equal to one, then decrement the counter, pop the stack and continue. | | | (ls - l <sub>0</sub> ) | Mnemonics | Description | Execution Example | |------------------------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------| | 13 <sub>H</sub> | DJNCC_D | IF NOT CC AND CNT ≠ 1 THEN CNT: = CNT - 1 GOTO D ELSE CNT: = CNT - 1 CONTINUE If CC is LOW (pass) and the counter is not equal to one, decrement the counter and branch to the address specified by the D inputs. If CC is HIGH (fail) or the counter is equal to one, then decrement the counter and continue. The D port must be disabled to avoid bus contention. | 50 | | 17 <sub>H</sub> | DJNCC_A | IF NOT CC AND CNT ≠ 1 THEN CNT:= CNT - 1 GOTO A ELSE CNT:= CNT - 1 CONTINUE If CC is LOW (pass) and the counter is not equal to one, decrement the counter and branch to the address specified by the A inputs. The content of the interrupt return address register and the address register is replaced by the A address in this case. If CC is HIGH (fail) or the counter is equal to one, the current address is incremented, appears on the bus for continue, and is stored into the above two registers. | 52 53 PAND COUNTER ≠ 1 54 FOR COUNTER = 1 56 | | 1B <sub>H</sub> | DJNCC_M | IF NOT CC AND CNT $\neq$ 1 THEN CNT: = CNT - 1 GOTO Multiway (D <sub>15</sub> - D <sub>4</sub> M <sub>3</sub> - M <sub>0</sub> ) ELSE CONTINUE If CC is LOW (pass) and the counter is not equal to one, decrement the counter and branch to the address specified by the D inputs concatenated with the M inputs. The lower four bits on the D bus (D <sub>3</sub> - D <sub>0</sub> ) are replaced by one of the four sets of the 4-bit multiway branch addresses. The multiway branch set is selected by bits D <sub>1</sub> and D <sub>0</sub> while bits D <sub>3</sub> and D <sub>2</sub> are "don't cares." | PF001840 | | 1F <sub>H</sub> | DJNCC_S | IF NOT CC AND CNT ≠ 1 THEN CNT: = CNT − 1 GOTO TOS ELSE CNT: = CNT − 1 POP STACK CONTINUE If CC is LOW (pass) and the counter is not equal to one, decrement the counter and branch to the address on the top of the stack. If CC is HIGH (fail) or the counter is equal to one, then decrement the counter, pop the stack and continue. | | | 2E <sub>H</sub> | RET | RETURN Unconditional return from subroutine. The return address is popped from the stack. | STACK PC+1 | | 0E <sub>H</sub> | RETCC | IF CC THEN RETURN ELSE CONTINUE If CC is HIGH (pass), return from subroutine. The return address is popped from the stack. If CC is LOW (fail), continue. | 50 90 | | 1E <sub>H</sub> | RETNC | IF NOT CC THEN RETURN ELSE CONTINUE If CC is LOW (pass), return from subroutine. The return address is popped from the stack. If | 52 92<br>53 93 | | Opcode<br>(i <sub>5</sub> ~ i <sub>0</sub> ) | Mnemonics | Description | Execution Example | |----------------------------------------------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------| | 31 <sub>H</sub> | FOR_D | INITIALIZE LOOP Push the Address Reg. + 1 on the stack, load the counter from the D inputs and continue. Use with DJUMP_S for FOR NEXT loops. The D port must be disabled to avoid bus contention. | STACK 50 PC + 1 | | 37 <sub>H</sub> | FOR_A | INITIALIZE LOOP Push the Address Reg. +1 on the stack, load the counter from the A inputs and continue. Use with DJUMP_S for FORNEXT loops. | 51 COUNTER N | | 33 <sub>H</sub> | LOOP | INITIALIZE LOOP Push the Address Reg. + 1 on the stack and continue. Use with BRCC_S for REPEATUNTIL loops, or with XTCC_D and BRA_S for WHILEEND WHILE loops. | STACK 50 PC + 1 | | | | | 51 🗑 | | | | | PF001860 | | 34 <sub>H</sub> | POP_D | Pop the stack and output the value on the D | | | 34 <sub>H</sub> | POP_D | Pop the stack and output the value on the D outputs and continue. The D port must be enabled. | |-----------------|--------|---------------------------------------------------------------------------------------------------| | 38 <sub>H</sub> | POP_C | Pop the stack and store the value in the counter and continue. | | 35 <sub>H</sub> | PUSH_D | Push the D inputs on the stack and continue. The D port must be disabled to avoid bus contention. | | 39 <sub>H</sub> | PUSH_C | Push the counter on the stack and continue. | | 3A <sub>H</sub> | SWAP | Exchange the counter and the top of stack and continue. | | | | | PF001870 | Opcode<br>(I <sub>5</sub> – I <sub>0</sub> ) | Mnemonics | Description | Execution Example | |-------------------------------------------------------|---------------------------|--------------------------------------------------------------------------------------------------------------------|-----------------------| | 3B <sub>H</sub> | STACK_C | Push the counter on the stack and load the counter with the value of the D inputs and continue. | 1 | | 3C <sub>H</sub> | LOAD_D | Load the counter with the value of the D inputs and continue. The D port must be disabled to avoid bus contention. | STACK | | 3D <sub>H</sub> | LOAD_A | Load the counter with the value of the A inputs and continue. | COUNTER | | | | | 50 COUNTER D 51 © 52 | | | | | PF001880 | | 30 <sub>Н</sub><br>32 <sub>Н</sub><br>36 <sub>Н</sub> | CONT DECR RESET_SP | Continue. Decrement the counter and continue. Reset the stack pointer and continue. | 50 51 COUNTER COUNT-1 | | 3E <sub>Н</sub> | SET | Load the comparison register with the value of the D inputs, enable the comparator and | PF001890 | | <b>Э</b> Г <sub>Н</sub> | CLEAR | continue. Disable the comparator and continue. | 50 D S1 D S2 | | | | | PF001900 | | | | | | | | | | | | Nana Carada | imbers are in hexadecimal | potetion | | Figure 8. Typical Control-Path Architecture For Am29C300 Family Figure 9. Cycle Timing Waveform\* \*This waveform shows the timing relationship for the configuration shown in Figure 8. ## **ABSOLUTE MAXIMUM RATINGS** | Storage Temperature65 to +150°C | |---------------------------------------------------| | (Case) Temperature Under Bias55 to +125°C | | Supply Voltage to | | Ground Potential Continuous0.3 V to +7.0 V | | DC Voltage Applied to Outputs For | | High Output State0.3 V to +V <sub>CC</sub> +0.3 V | | DC Input Voltage $-0.3$ V to $+V_{CC}$ $+0.3$ V | | DC Output Current, Into LOW Outputs30 mA | | DC Input Current10 mA to +10 mA | Stresses above those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent device failure. Functionality at or above these limits is not implied. Exposure to absolute maximum ratings for extended periods may affect device reliability. #### **OPERATING RANGES** | Commercial (C) Devices | | |-----------------------------------|--------------------| | Temperature (TA) | 0 to +70°C | | Supply Voltage (V <sub>CC</sub> ) | +4.75 V to +5.25 V | | Military* (M) Devices | | | Temperature (TA) | 55 to +125°C | | Supply Voltage (VCC) | +4.5 V to +5.5 V | Operating ranges define those limits between which the functionality of the device is guaranteed. \*Military Product 100% tested at TA = +25°C, +125°C, and -55°C. 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 Conditions (Note 1) | | Min. | Max. | Unit | | |---------------------|---------------------------------------------------|--------------------------------------------------------------------------------|------------------------|--------------------------------------------|------|------------|-------| | V <sub>OH</sub> | Output HIGH Voltage | V <sub>CC</sub> = Min.<br>V <sub>IN</sub> = V <sub>IH</sub> or V <sub>IL</sub> | I <sub>OH</sub> = | 0.4 mA | 2.4 | | Volts | | VoL | Output LOW Voltage | V <sub>CC</sub> = Min.<br>V <sub>IN</sub> = V <sub>IH</sub> or V <sub>IL</sub> | | 8 mA for Y-BUS<br>4 mA for All Other Plins | | 0.5 | Volts | | VIH | Guaranteed Input Logical<br>HIGH Voltage (Note 2) | | 14 | | 2.0 | | Volts | | V <sub>IL</sub> | Guaranteed Input Logical<br>LOW Voltage (Note 2) | 9. | | *** | | 0.8 | Volts | | ارل | Input LOW Current | V <sub>CC</sub> = Max.<br>V <sub>IN</sub> = 0.5 Voits | V <sub>CC</sub> = Max. | | | -10 | μΑ | | lін | 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) | V <sub>CC</sub> = Max.<br>V <sub>O</sub> ≠ 2.4 Volts | | | | 10 | μΑ | | lozL | Off-State (HIGH Impedance) Output Current | V <sub>CC</sub> = Max.<br>V <sub>O</sub> = 0.5 Volts | | | | -10 | μΑ | | | 10, | V <sub>GC</sub> = Max., | COM'L | 29C331 | | 40 | | | lcc | Static Power Supply Current<br>(Note 3) | VIN = VCC or GND, | COMIL | 29C331-1/-2 | | 50 | mA | | | (1565 5) | $I_O = 0 \mu A$ | MIL | 29C331 only | | 50 | | | 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 | | | | pF Typical | | 3. Worst-case ICC is measured at the lowest temperature in the specified operating range. Cpp determines the no-load dynamic current consumption: Icc (Total) = Icc (Static) + Cpp Vcc I, where f is the switching frequency of the majority of the internal nodes, normally one-half of the clock frequency. This specification is not tested. Notes: 1. V<sub>CC</sub> conditions shown as Min. or Max. refer to the commercial and military V<sub>CC</sub> limits. 2. These input levels provide zero-noise immunity and should only be statically tested in a noise-free environment (not functionally tested). ## SWITCHING CHARACTERISTICS over COMMERCIAL operating range ## A. COMBINATIONAL PROPAGATION DELAYS | | | | 29C331 | 29C331-1 | 29C331-2 | | |-----|----------------------------------------------|------------------------------|---------------------|--------------------------|--------------------------------------------|----------| | No. | From | То | Max. Delay | Max. Delay | Max. Delay | Unit | | 1 | D <sub>15</sub> – 0 | Y15-0 | 22* | 20* | 18 | ns | | | D <sub>15</sub> - 0 | EQUAL | 32 | 28 | 23 | ns | | | D <sub>15</sub> - 0 | ERROR | 36 | 32 | 26 | ns | | 2 | A <sub>15</sub> – 0 | Y <sub>15</sub> - 0 | 20 | 18 | 16 | ns | | ŀ | A <sub>15</sub> - 0 | EQUAL | 31 | 27<br>29. | 22 | ns | | 3 | A <sub>15</sub> – 0 | ERROR | 33 | 29. | 24 | ns | | 3 | M <sub>X3</sub> - X0<br>M <sub>X3</sub> - X0 | Y15 - 0 | 19 | 18 (45) | 1 <b>6</b> arising | ns | | ľ | M <sub>X3</sub> - x0 | EQUAL<br>ERROR | 29 | 26 | 21/7/// | ns | | | Y15 - 0 | EQUAL | 33<br>31 | 29 | 24 | ns | | 1 | Y15-0 | ERROR | 26 | 28 | 23 | ns | | 4 | 15-0 | Y31 - 0 | 24 | 23<br>22 | - A Contractor | ns | | 5 | 15 - 0 | D <sub>15</sub> - 0 | 29 | 26 | 18<br><b>21</b> | ns | | | 15 - 0 | EQUAL | 36 | 33 | 27 | ns<br>ns | | İ | l <sub>5</sub> – 0 | ERROR | 40 | 35 | 28 | ns | | 6 | T <sub>11</sub> - 0 | Y <sub>15</sub> - 0 | .24 | 35<br>22 | 18 | ns | | | T <sub>11</sub> - 0 | EQUAL | 35<br>37 | 32 | | ns | | | T <sub>11</sub> - 0 | ERROR | 37 | 33<br>22 | 27 | ns | | | S <sub>3-0</sub> | Y <sub>15</sub> – 0<br>EQUAL | 24 | 22 | 27. 18. 18. 18. 18. 18. 18. 18. 18. 18. 18 | ns | | İ | S <sub>3-0</sub><br>S <sub>3-0</sub> | ERROR | 35<br>37 | 32 | 26 | ns | | 7 | CP CP | Y15-0 | | <b>33</b> | 27 | ns | | 8 | CP | D <sub>15</sub> = 0 | 28<br>2 <b>7</b> /Z | 25/ <b>2</b> | 20<br>20/2 | ns | | 9 | CP | A-FULL | 27 | 24 Tille | 20 | ns | | | CP | EQUAL | 36: app | no II | 26 | ns<br>ns | | | CP | ERROR | 50 i <sup>(F)</sup> | 45 | 36 | ns | | 10 | RST | Y15-0 | 26/Z | 24/Z | 20/Z | ns | | 11 | RST | D <sub>15</sub> – 0 | <b>Z</b> 1647 | \ <b>z</b> \lambda_tem | <b>Z</b> | ns | | '' | RST | EQUAL | 22 | 19<br>3 1 | 17<br>25 | ns | | | RST | ERROR | 35**/<br>38 | 31 jili 18" | 25 | пѕ | | 12 | FC | Y <sub>15</sub> = 0 | 24 | | <b>26</b> | ns | | 13 | FC | D <sub>15</sub> - 0 | 28 | <b>22</b><br>25 | 1 <b>8</b> | ns | | 1 | FC | EQUAL | 33 | 30 | 1 24 | ns<br>ns | | | FC | ERROR | 95 mill | 31 | 25 | ns | | i | INTR | Y <sub>15</sub> - 0<br>INTA | Z<br>17<br>(Note 1) | <b>2</b> kad | <b>2</b> 5 | ns l | | 14 | INTR | INTA | 17 | 16<br>(Note 1) | (N) 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | ns | | | INTR | EQUAL<br>ERROR | (Note 1)<br>46 | (Note 1) | (INDICE I) | ns | | | INTEN | | 46 | <b>21</b> /1/3 | 18 | ns | | 15 | INTEN | Y <sub>15</sub> - 0<br>INTA | Z<br>16 | 15 | <b>Z</b><br>9, <sub>0</sub> , 1 | ns | | İ | INTEN | EQUAL | (Note 1) | (Note 1) | (8) 444 (4) | ns | | | INTEN | ERROR | 46 | 21 | (Note 1) | ns | | | HOLD | Y <sub>15</sub> - 0 | Z | Z | 18 | ns<br>ns | | | HOLD | INTA | Z | <b>Z</b> 2 | Z<br>Z | ns | | | HOLD | A-FULL | Z | <b>Z</b><br>31/ <b>Z</b> | 7.7.7.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1 | ns | | | HOLD<br>HOLD | EQUAL | 34/Z | 31/Z | 17/ <b>Z</b> | ns | | | OED | ERROR | 46 | 1 18 | | ns | | | OED | D <sub>15</sub> – 0<br>ERROR | Z<br>19 | 17 | <b>Z</b> (100) | ns | | | INTA | ERROR | 19** | Z<br>17** | 17.01 | ns | | | A-FULL | ERROR | 21** | 20** | 17<br>1 <b>7</b> | ns | | | EQUAL | ERROR | 19** | | 17 | ns | | 16 | Cin | Y <sub>15</sub> - 0 | 24 | 17**<br>21 | 18 | ns<br>ns | | | Cin | EQUAL | 36 | 33 | 20 | ns | | | Cin | ERROR | 37 | 33 | 21 | ns | | | SLAVE<br>SLAVE | Y <sub>15</sub> - 0 | Z | Z | Z | ns | | | SLAVE | D <sub>15</sub> - 0<br>INTA | Z | Z | Z | ns | | | SLAVE | A-FULL | Z<br>Z | Z | Z | ns | | | SLAVE | EQUAL | Z | Z<br>Z | Z<br>Z | ns | | | | | | | | ns | Notes: See notes following Table D. <sup>\*</sup>This includes using D as select lines for multiway sets. <sup>\*\*</sup>In the slave mode. ## SWITCHING CHARACTERISTICS over COMMERCIAL operating range (Cont'd.) ## B. OUTPUT DISABLE TIME | | | | | 29C331 | 29C331-1 | 29C331-2 | | |-----|-------|---------------------|--------------------------|------------|-----------------|--------------------|------| | No. | From | То | Description | Max. Value | Max. Value | Max. Value | Unit | | | RST | Y <sub>15-0</sub> | Reset-to-Address Enable | 29 | <b>25</b><br>25 | 25. | ns | | | RST | Y <sub>15</sub> – 0 | Reset-to-Address Disable | 29 | 25 | 25 | ns | | 43 | INTR | Y <sub>15</sub> - 0 | INTR-to-Address Enable | 24 | 21 | 21 | ns | | 44 | INTR | Y15-0 | INTR-to-Address Disable | 24 | 21 | 21<br>21 | ns | | | INTEN | Y <sub>15</sub> - 0 | INTEN-to-Address Enable | 24 | 21 | | ns | | | INTEN | Y <sub>15</sub> -0 | INTEN-to-Address Disable | 24 | 21// | 21 | ns | | | HOLD | Y <sub>15</sub> - 0 | HOLD-to-Address Enable | 23 | 20 | 20 | ns | | | HOLD | Y <sub>15</sub> - 0 | HOLD-to-Address Disable | 23 | 20 | 20 | ns | | | SLAVE | Y <sub>15</sub> - 0 | SLAVE-to-Address Enable | 24 | 21 | 7. <b>/21</b> ./// | ns | | | SLAVE | Y <sub>15</sub> - 0 | SLAVE-to-Address Disable | 24 | 21 | 21 | ns | | | OED | Y <sub>15-0</sub> | OED-to-Data Enable | 26 | 22<br>22 | 22 | ns | | | OED | D <sub>15</sub> - 0 | OED-to-Data Disable | - 26 | 22 | 22<br>22<br>23 | ns | | | RST | D <sub>15</sub> - 0 | Reset-to-Data Enable | <b>27</b> | 23 | 23 | ns | | | RST | D <sub>15</sub> – 0 | Reset-to-Data Disable | 27 | 23 | 23 | ns | | | SLAVE | D <sub>15</sub> - 0 | SLAVE-to-Data Enable | 26 | 22 | * 22 | ns | | | SLAVE | D <sub>15</sub> – 0 | SLAVE-to-Data Disable | 26 | 22 | 22 | ns | | | CP | D <sub>15</sub> - 0 | Clock-to-Data Enable | 35 | 24 | 24 | ns | | | CP | D <sub>15</sub> - 0 | Clock-to-Data Disable | 35 | 24 | 24 | ns | | | HOLD | INTA | HOLD-to-INTA Enable | 22 | 19 | 19 | ns | | | HOLD | INTA | HOLD-to-INTA Disable | 22 | 19 | 19 | ns | | | HOLD | A-FULL | HOLD-to-A-FULL Enable | 21 | 18 | 18 | ns | | | HOLD | A-FULL | HOLD-to-A-FULL Disable | 21 | 18 | 18 | ns | | | HOLD | EQUAL | HOLD-to-EQUAL Enable | 21 | 18 | 18 | ns | | | HOLD | EQUAL | HOLD-to-EQUAL Disable | 21 | 18 | 18 | ns | | Ì | SLAVE | INTA | SLAVE-to-INTA Enable | 22 | 19 | 19 | ns | | | SLAVE | INTA | SLAVE-to-INTA Disable | 22 | 19 | 718 | ns | | | SLAVE | A-FULL | SLAVE-to-A-FULL Enable | <b>2</b> 2 | 19 | 19 | ns | | | SLAVE | A-FULL | SLAVE-to-A-FULL Disable | 22 | 19 | 19 | ns | | | SLAVE | EQUAL | SLAVE-to-EQUAL Enable | 22 | 19 | 19 | ns | | | SLAVE | EQUAL | SLAVE-to-EQUAL Disable | 22 | 19 | 19 | ns | Notes: See notes following Table D. ## SWITCHING CHARACTERISTICS over COMMERCIAL over operating range (Cont'd.) ## C. SETUP AND HOLD TIMES | | | | With Respect | 29C331 | 29C331-1 | 29C331-2 | | |-----|-------------------------|---------------------------------|--------------|-------------|----------------------------------------|-----------------------|------| | No. | Parameter | For | То | Max. Value | Max. Value | Max. Value | Unit | | 17 | Data Setup | D <sub>15</sub> - 0 | CP 1 | 21 | 19 | 19 | ns | | 18 | Data Hold | D <sub>15</sub> - 0 | CP ↑ | 0 | l o | A Proceedings | ns | | 19 | Alternate Data Setup | A <sub>15</sub> – 0 | CP ↑ | 23 | <b>5</b> | 21 | ns | | 20 | Alternate Data Hold | A <sub>15</sub> – 0 | CP ↑ | O. | #O# | | ns | | 21 | Multiway Setup | M <sub>X3</sub> - <sub>X0</sub> | CP ↑ | 28 | 21 | 0<br>21 | ns | | 22 | Multiway Hold | Mx3 - x0 | CP ↑ | <b>o</b> 1 | 7 <b>0</b> 00000 | <b>C</b> aratera | ns | | 23 | Address Setup | Y <sub>15</sub> -0 | CP T | 18 | 17 | 47.4F | ns | | 24 | Address Hold | Y <sub>15</sub> - 0 | CP ↑ | 0 | 16 | Onen ape | ns | | 25 | Instruction Setup | 15 - 0 | CP ↑ | 24 | 21 | 21 | ns | | 26 | Instruction Hold | 15-0 | CP ↑ | 0. | #O # # | - : | ns | | 27 | Forced Continue Setup | FC | CP ↑ | 2 | <b>t</b> 9 | 19 | ns | | 28 | Forced Continue Hold | FC | CP ↑ | O STATEMENT | D | [] | ns | | 29 | Test Setup | T <sub>11-0</sub> | CP ↑ | 21 | 20 | 20 | ns | | 30 | Test Hold | T <sub>11-0</sub> | CP ↑ | 9 | Outsill | <b>O</b> CALLED | ns | | 31 | Select Setup | S <sub>3-0</sub> | CP ↑ | 22 | 20 | 20 | ns | | 32 | Select Hold | <u>S<sub>3-0</sub></u> | CP ↑ | <b>0</b> 31 | 4 <b>9</b> wyw | Or Aller | ns | | 33 | Reset Setup | RST | CP ↑ | 22 | 20 | 20 | ns | | 34 | Reset Hold | RST | CP ↑ | O 40 00 | <b>(C</b> ) | 0 | ns | | 35 | Interrupt Request Setup | INTR | CP ↑ | 210 | 18 | 18 | ns | | 36 | Interrupt Request Hold | INTR | CP ↑ | Garana | <b>**</b> | O the later of | ns | | 37 | Interrupt Enable Setup | INTEN | CP ↑ | 18 | 16 | 16 | ns | | 38 | Interrupt Enable Hold | INTEN | CP ↑ | O deepe | (O************************************ | OF THE REAL PROPERTY. | ns | | 39 | Hold Mode Setup | HOLD | CP ↑ | 21 | 19 | 19 | ns | | 40 | Hold Mode Hold | HOLD | CP ↑ | <b>0</b> | O | O management | ns | | 41 | Carry-In Setup | Cin | CP ↑ | 22 | 20 | 20 | ns | | 42 | Carry-In Hold | C <sub>in</sub> | CP ↑ | 0 | 0 | 0 | ns | ## D. MINIMUM CLOCK REQUIREMENT | | | 29C33.1 | 29C331-1 | 29C331-2 | | |----------|---------------------------------------------------|------------|-----------------|------------|----------| | No. | Description | Max. Value | Max. Value | Max. Value | Unit | | 53<br>54 | Minimum Clock LOW Time<br>Minimum Clock HIGH Time | 23<br>19 | <b>22</b><br>16 | 22<br>16 | ns<br>ns | Notes: 1. (INTR, INTEN)-to-EQUAL is the sum of (INTR, INTEN)-to-Y disable time and Y-to-EQUAL delay time. <sup>2.</sup> $C_L = 50$ pF; $C_L = 5$ pF for Disable Time only. **SWITCHING CHARACTERISTICS** over **MILITARY** operating range (for APL Products, Group A, Subgroups 9, 10, 11 are tested unless otherwise noted) ## A. COMBINATIONAL PROPAGATION DELAYS | | | | 29C331 | | |------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|------------|----------| | No. | From | То | Max. Delay | Unit | | 1 | D <sub>15-0</sub> | Y <sub>15</sub> -0 | 30* | ns | | | D <sub>15</sub> - 0 | EQUAL | 48 | ns | | | D <sub>15</sub> - 0 | ERROR | 29** | ns | | 2 | A <sub>15</sub> – 0 | Y15-0 | 27 | ns | | | A <sub>15</sub> – 0 | EQUAL | 44 | ns | | | A <sub>15</sub> – 0 | ERROR | 50 | ns | | 3 | M <sub>X3</sub> - <sub>X0</sub> | Y <sub>15</sub> – 0 | 30 | ns | | | Mx3 - x0 | EQUAL | 48 | ns | | | M <sub>X3</sub> – X0 | ERROR | 55 | ns | | | Y15 - 0 | EQUAL | 41 | ns | | | Y15-0 | ERROR | 29** | ns | | 4 | 5-0 | Y31 - 0 | 32 | ns | | 5 | 5-0 | D <sub>15</sub> _ 0 | 37 | ns | | | 5-0 | EQUAL | 48 | ns | | 6 | 15 - 0 | ERROR | 55<br>32 | ns | | 6 | T <sub>11</sub> = 0 | Y <sub>15-0</sub><br>EQUAL | | ns | | | T <sub>11</sub> = 0<br>T <sub>11</sub> = 0 | ERROR | 540 | ns<br>ns | | | S <sub>3-0</sub> | Y <sub>15-0</sub> | 55<br>32 | | | | S <sub>3-0</sub> | EQUAL | 46 | ns<br>ns | | | S <sub>3</sub> - 0 | ERROR | <b>55</b> | ns | | 7 | CP | Y <sub>15-0</sub> | 37 | ns | | 8 | CP | D <sub>15</sub> - 0 | 37/Z | ns | | 9 | CP | A-FULL | 92 | ns | | | CP | EQUAL | 54 | ns | | | CP | FRROR | 60 | ns | | 10 | RST | Y+E 0 | 32/Z | ns | | | RST | Y15 - 0<br>D15 - 0<br>INTA<br>EQUAL | Z | ns | | 11 | RST | | 22 | ns | | | RST | EQUAL<br>ERROR | 48 | ns | | | RST | ERROR<br>Y15-0 | 55 | ns | | 12 | FC | | 32 | ns | | 13 | FC 🦚 | D <sub>15</sub> – 0 | 37 | ns | | | FC 2 | EQUAL | 48 | ns | | | FC / | ERROR | 55 | ns | | | INTR | ¥15 - 0<br>INTA | Z | ns | | 14 | INTE | | 21 | ns | | | INTR | EQUAL | (Note 1) | ns | | .H | AND THE STATE OF T | ERROR | 49 | ns | | 15 | INTEN | Y <sub>15</sub> = 0<br>INTA | Z<br>21 | ns<br>ns | | 15 % | INTEN | EQUAL | (Note 1) | | | | INTEN | ERROR | 49 | ns<br>ns | | | HOLD | Y <sub>15</sub> - 0 | Z 2 | ns | | | HOLD | INTA | Z | ns | | | HOLD | A-FULL | 21/Z | ns | | | HOLD | EQUAL | 43/Z | ns | | | HOLD | ERROR | 49 | ns | | | OED | D <sub>15</sub> – 0 | 26 | ns | | | OED | ERROR | Z | ns | | | INTA | ERROR | 29** | ns | | | A-FULL | ERROR | 29** | ns | | | EQUAL | ERROR | 29** | ns | | 16 | Cin | Y <sub>15</sub> - 0 | 32 | ns | | | Cin | EQUAL | 48 | ns | | | C <sub>in</sub> | ERROR | 55 | ns | | | SLAVE | Y15-0 | Z | ns | | | SLAVE | D <sub>15</sub> - 0<br>INTA | Z | ns | | | SLAVE | | Z | ns | | 1 | SLAVE | A-FULL | Z | ns | | | SLAVE | EQUAL | Z | ns | Notes: See notes following Table D. <sup>\*</sup>This includes using D as select lines for multiway sets. <sup>\*\*</sup>In the slave mode. ## SWITCHING CHARACTERISTICS over MILITARY operating range (Cont'd.) ## B. OUTPUT DISABLE TIME | | | | | 29C331 | | |-----|-------|---------------------|--------------------------|------------|------| | No. | From | То | Description | Max. Value | Unit | | | RST | Y <sub>15</sub> - 0 | Reset-to-Address Enable | 26 | ns | | | RST | Y <sub>15-0</sub> | Reset-to-Address Disable | 26 | ns | | 43 | INTR | Y <sub>15</sub> - 0 | INTR-to-Address Enable | 26 | ns | | 44 | INTR | Y <sub>15</sub> - 0 | INTR-to-Address Disable | 26 | ns | | | INTEN | Y <sub>15-0</sub> | INTEN-to-Address Enable | 26 | ns | | | INTEN | Y <sub>15</sub> – 0 | INTEN-to-Address Disable | 26 | ns | | | HOLD | Y <sub>15</sub> - 0 | HOLD-to-Address Enable | 26 | ns | | | HOLD | Y <sub>15</sub> – 0 | HOLD-to-Address Disable | 26 | ns | | | SLAVE | Y <sub>15</sub> - 0 | SLAVE-to-Address Enable | 26 | ns | | 1 | SLAVE | Y <sub>15</sub> – 0 | SLAVE-to-Address Disable | 26 | ns | | | OED | Y <sub>15</sub> ~ 0 | OED-to-Data Enable | 26 | ns | | | OED | D <sub>15-0</sub> | OED-to-Data Disable | 26 | ns | | | RST | D <sub>15</sub> – 0 | Reset-to-Data Enable | 26 | ns | | | RST | D <sub>15</sub> – 0 | Reset-to-Data Disable | 26 | ns | | | SLAVE | D <sub>15 - 0</sub> | SLAVE-to-Data Enable | 26 | ns | | | SLAVE | D <sub>15-0</sub> | SLAVE-to-Data Disable | 26 | ns | | | CP | D <sub>15</sub> _ 0 | Clock-to-Data Enable | 23 | ns | | 1 | CP | D <sub>15</sub> _0 | Clock-to-Data Disable | 23 | ns | | | HOLD | INTA<br>INTA | HOLD-to-INTA Enable | 21 | ns | | 1 | HOLD | INTA | HOLD-to-INTA Disable | 21 | ns | | | HOLD | A-FULL | HOLD-to-A-FULL Enable | 21 | ns | | } | HOLD | A-FULL | HOLD-to-A-FULL Disable | 21 | ns | | | HOLD | EQUAL | HOLD-to-EQUAL Enable | 21 | ns l | | 1 | HOLD | EQUAL | HOLD-to-EQUAL Disable | 21 | ns | | | SLAVE | INTA | SLAVE-to-INTA Enable | 21 | ns | | | SLAVE | ĪNTĀ | SLAVE-to-INTA Disable | 21 | ns | | | SLAVE | A-FULL | SLAVE-to-A-FULL Enable | 21 | ns | | 1 1 | SLAVE | A-FULL | SLAVE-to-A-FULL Disable | 21 | ns | | | SLAVE | EQUAL | SLAVE-to-EQUAL Enable | 21 | ns | | | SLAVE | EQUAL | SLAVE-to-EQUAL Disable | 21 | ns | Notes: See notes following Table D. ## SWITCHING CHARACTERISTICS over MILITARY operating range (Cont'd.) ## C. SETUP AND HOLD TIMES | | | | | 29C331 | | |-----|-------------------------|------------------------------------|-----------------|------------|------| | No. | Parameter | For | With Respect To | Max. Value | Unit | | 17 | Data Setup | D <sub>15-0</sub> | CP ↑ | 32 | ns | | 18 | Data Hold | D <sub>15</sub> - 0 | CP ↑ | 1 | ns | | 19 | Alternate Data Setup | A <sub>15</sub> – 0 | CP ↑ | 32 | ns | | 20 | Alternate Data Hold | A <sub>15</sub> - 0 | CP ↑ "á | 1 | ns | | 21 | Multiway Setup | M <sub>X3</sub> <sub>– X0</sub> | CP ↑ 🦼 | 32 | ns | | 22 | Multiway Hold | M <sub>X3 – X0</sub> | CP ↑ | 1 | ns | | 23 | Address Setup | Y <sub>15</sub> -0 | CP 1 | 27 | ns | | 24 | Address Hold | Y <sub>15</sub> – 0 | CP ↑ | 2 | ns | | 25 | Instruction Setup | 15 – 0 | OP 1 | 32 | ns | | 26 | Instruction Hold | 15 - 0 | ,CP ↑ | 0 | ns | | 27 | Forced Continue Setup | FC | CP <br>CP ↑ | 32 | ns | | 28 | Forced Continue Hold | FG. | CP ↑ | 1 | ns | | 29 | Test Setup | T <sub>11</sub> +0 | CP ↑ | 32 | ns | | 30 | Test Hold | T <sub>11</sub> -0 | CP <b>↑</b> | 0 | ns | | 31 | Select Setup | <b>S</b> 3 - 0 | CP ↑ | 32 | ns | | 32 | Select Hold | S <sub>3-0</sub> | CP ↑ | 0 | ns | | 33 | Reset Setup | RST | CP 1 | 32 | ns | | 34 | Reset Hold | RST | CP ↑ | 1 | ns | | 35 | Interrupt Request Setup | INTR | CP ↑ | 27 | ns | | 36 | Interrupt Request Hold | INTR | CP 1 | 1 | ns | | 37 | Interrupt Enable Setup | INTEN | CP ↑ | 27 | ns | | 38 | Interrupt Enable Hold | INTEN | CP 1 | 1 | ns | | 39 | Hold Mode Setup | HOLD | CP ↑ | 27 | ns | | 40 | Hold Mode Hold | HOLD | CP 1 | 1 | ns | | 41 | Carry-In Setup | C <sub>in</sub><br>C <sub>in</sub> | CP 1 | 30 | ns | | 42 | Carry-In Hold | C <sub>in</sub> | CP 1 | 1 | ns | ## D. MINIMUM CLOCK REQUIREMENTS | | | 29C331 | | |-----|-------------------------|------------|------| | No. | | Max. Value | Unit | | 53 | Minimum Clock LOW Time | 33 | ns | | 54 | Minimum Clock HIGH Time | 28 | ns | Notes: 1. (INTR, INTEN)-to-EQUAL is the sum of (INTR, INTEN)-to-Y disable time and Y-to-EQUAL delay - 2. $C_L$ = 50 pF; $C_L$ = 5 pF for Disable Time only. 3. The status of $I_5-I_0$ and FC must not be changed during the clock LOW time. ## SWITCHING TEST CIRCUIT TC003420 ## A. Three-State Outputs Notes: 1. $C_L = 50$ pF includes scope probe, wiring, and stray capacitances without device in test fixture. - 2. $S_1$ , $S_2$ , $S_3$ are closed during function tests and all AC tests except output enable tests. 3. $S_1$ and $S_3$ are closed while $S_2$ is open for $t_{PZH}$ test. - - S<sub>1</sub> and S<sub>2</sub> are closed while S<sub>3</sub> is open for t<sub>PZL</sub> test. - 4. $C_L = 5.0$ pF for output disable tests. ## SWITCHING TEST WAVEFORMS **Pulse Width** - Notes: 1. Diagram shown for HIGH data only. Output transition may be opposite sense. - 2. Cross hatched area is don't care condition. ## Setup, Hold, and Release Times ## **Propagation Delay** - Notes: 1. Diagram shown for Input Control Enable-LOW and Input Control Disable-HIGH. - S<sub>1</sub>, S<sub>2</sub>, and S<sub>3</sub> of Load Circuit are closed except where shown. #### **Enable and Disable Times** #### Test Philosophy and Methods The following points give the general philosophy that we apply to tests that must be properly engineered if they are to be implemented in an automatic environment. The specifics of what philosophies applied to which test are shown. - Ensure the part is adequately decoupled at the test head. Large changes in supply 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 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. Current level may vary from product to product. - 4. Use extreme care in defining input levels for AC tests. Many inputs may be changed at once, so there will be significant noise at the device pins 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$ 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 which varies from one type of tester to another, but is generally around 50 pF. This makes it impossible to make direct measurements of parameters which 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 and out of the high-impedance state, and are usually specified at a load capacitance of 5.0 pF. In these cases, the test is performed at the higher load capacitance (typically 50 pF), and engineering correlations based on data taken with a bench 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, the long inductive cables, and the high gain of bipolar devices 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. #### 9. Output Short-Circuit Current Testing When performing $l_{OS}$ tests on devices containing RAM or registers, great care must be taken that undershoot caused by grounding the high-state output does not trigger parasitic elements which in turn cause the device to change state. In order to avoid this effect, it is common to make the measurement at a voltage ( $V_{OUTDU}$ ) that is slightly above ground. The $V_{OC}$ is raised by the same amount so that the result (as confirmed by Ohm's law and precise bench testing) is identical to the $V_{OUT}=0$ , $V_{CC}=Max$ . case. # SWITCHING WAVEFORMS KEY TO SWITCHING WAVEFORMS ## SWITCHING WAVEFORMS (Cont'd.) WF025100 ## Interrupt Timing - Notes: 1. Interrupt Request comes from an interrupt-controller register. If reflects the CP ↑ to INTR time of the interrupt controller. - 2. During Cycle 2, there may be contention on the Y-bus if the Y-bus is turned ON before the INT-VECT buffer is turned OFF. - 3. Refer to Figures 4 and 5 for definition of A and B. ## INPUT/OUTPUT CIRCUIT DIAGRAM (All Devices) ICR00480