# 16-BIT CMOS MICROPROCESSOR SLICE # IDT 49C403 IDT 49C403A ### **FEATURES:** - Monolithic 16-bit CMOS µP Slice - Replaces four 2903As/29203s and a 2902A - Fas - 50% faster than four 2903As/29203s and a 2902 - Low power CMOS - Commercial: 250mA (max.) - Military: 275mA (max.) - · Performs binary and BCD Arithmetic - Expanded two-address architecture with independent, simultaneous access to two, expandable 64 x 16 register files - Word/Byte Control - · Expanded 4 x 16 Q Register - Performs Byte Swap and Word/Byte Operation - Fully cascadable without the need for additional carry lookahead - · Incorporates three 16-bit Bidirectional Busses - Includes Serial Protocol Channel (SPC™) - Flexible on-chip diagnostics - Serially monitors all pin states - Reads and Writes to Register File - · High Output Drive - Commercial: 16mA (max.) - Military: 12mA (max.) - Available in 108-pin PGA - Military product compliant to MIL-STD-883, Class B ## DESCRIPTION: The IDT49C403 is a high-speed, fully cascadable 16-bit CMOS microprocessor slice. It combines the standard function of four 2903s/29203s and one 2902 with additional control features aimed at enhancing the performance of all bit-slice microprocessor designs. Included in this extremely low power, yet fast IDT49C403 device are 3 bidirectional data buses, 64 word x 16-bit two-port expandable RAM, 4 word x 16-bit Q Register, parity generation, sign extension, multiplication/division and normalization logic. Additionally, the IDT49C403 offers the special feature of enhanced byte support through both word/byte control and byte swap control. The IDT49C403 easily supports fast 100ns microcycles and will enhance the speed of all existing quad 2903A/29203 systems by 50%. Being specified at an extremely low 250mA, the IDT device offers an immediate system power savings and improved reliability. Also featured on the IDT49C403 is an innovative diagnostics capability known as Serial Protocol Channel (SPC). This on-chip feature greatly simplifies the task of writing and debugging microcode, field maintenance debug and test, along with system testing during manufacturing. Military grade product is manufactured in compliance with the latest revision of MIL-STD-883, Class B, making it ideally suited to military temperature applications demanding the highest level of performance and reliability. # **FUNCTIONAL BLOCK DIAGRAM** CEMOS, SPC and MICROSLICE are trademarks of Integrated Device Technology, Inc. MILITARY AND COMMERCIAL TEMPERATURE RANGES **JANUARY 1989** © 1989 Integrated Device Technology, Inc. DSC-9012/-1 ## **DETAILED BLOCK DIAGRAM** S8-14 ## PIN CONFIGURATION | PIN<br>NO. | NAME |------------|--------------------|------------|------------------|------------|----------------|------------|-------------------|------------|-----------------|------------|-----------------|------------|----------------|------------|-----------------| | A1 | N/C | B4 | DB7 | C7 | DCMP | E10 | W/B | H1 | DA2 | K4 | DA8 | L7 | WE | M10 | ا م | | A2 | V <sub>CC</sub> | B5 | DB4 | C8 | l <sub>5</sub> | E11 | OEY | H2 | DA3 | K5 | DA12 | L8 | B <sub>2</sub> | M11 | V <sub>CC</sub> | | A3 | OĔB | В6 | DB1 | C9 | IEN | E12 | SIO | нз | DA5 | K6 | N/C | L9 | B <sub>5</sub> | M12 | N/C | | A4 | DB5 | B7 | MSS | C10 | Y <sub>2</sub> | F1 | GND | H10 | Y <sub>13</sub> | K7 | B <sub>0</sub> | L10 | Q₁ | | | | A5 | DB3 | B8 | 17 | C11 | Y <sub>5</sub> | F2 | DB15 | H11 | Y <sub>11</sub> | K8 | B4 : | L11 | SCLK | | | | A6 | DB0 | B9 | Cn + 16 | C12 | Y <sub>6</sub> | F3 | DB14 | H12 | Y <sub>10</sub> | K9 | WRITE | L12 | C/D | | | | A7 | GND | B10 | P/OVR | D1 | DB11 | F10 | QIO₀ | J1 | DA4 | K10 | GND | M1 | Vcc | | | | A8 | la la | B11 | Υ, | D2 | DB9 | F11 | SIO <sub>15</sub> | J2 | DA6 | K11 | SDO . | M2 | A <sub>5</sub> | | | | A9 | le le | B12 | Y <sub>3</sub> | D3 | l <sub>3</sub> | F12 | QIO <sub>15</sub> | J3 | . A 1 | K12 | Y <sub>15</sub> | M3 | DA10 | | | | A10 | G/N | C1 | DB8 | D10 | Y4 | G1 | OEA | J10 | SDI | L1 | A <sub>2</sub> | M4 | DA13 | | | | A11 | l γ <sub>0</sub> ∣ | C2 | 4 | D11 | Y <sub>7</sub> | G2 | DA0 | J11 | Y <sub>14</sub> | L2 | A4 | M5 | DA15 | | | | A12 | V <sub>cc</sub> | C3 | GND | D12 | z | G3 | DA1 | J12 | Y <sub>12</sub> | L3 | DA9 | М6 | GND | | | | B1 | 12 | C4 | l <sub>o</sub> i | E1 | DB13 | G10 | Yg | K1 | DA7 | L4 | DA11 | M7 | CP | | | | B2 | 1, | C5 | DB6 | E2 | DB12 | G11 | Y <sub>8</sub> | K2 | A <sub>o</sub> | L5 | DA14 | M8 | B <sub>1</sub> | | | | В3 | C <sub>n</sub> | C6 | DB2 | E3 | DB10 | G12 | GND | кз | A 3 | L6 | ESS | М9. | Вз | | | ## **PIN DESCRIPTION** | PIN NAME | I/O | DESCRIPTION | |---------------------------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | A <sub>0-5</sub> | 1 | Six address inputs to the RAM containing the address of the RAM word appearing at output port A. | | B <sub>0-5</sub> | ı | Six address inputs to the RAM which selects one of the words in the RAM, the contents of which is displayed through the B port. It also selects the location into which new data can be written when the WE input and CP input are low. | | DA <sub>0-15</sub> | 1/0 | Sixteen bi-directional data pins acting as operands R for entering external data into the ALU. DA 0 is the LS8. The DA lines also function as an external output for RAM port A. | | DB <sub>0-15</sub> | 1/0 | Sixteen bi-directional data pins for entering external data into the ALU. The DB lines act as either RAM port B output data, or as input operands S to the ALU. | | WE | 1 | The RAM write enable input, which when LOW causes the Y I/O port data to be written into the RAM when the CP input is low. When WE is HIGH writing data into the RAM is inhibited. | | ŌĒĀ | ı | Output enable, which, when HIGH selects $DA_{0-15}$ as the ALU R operand, and, when LOW, selects RAM output A as the ALU R operand and the $DA_{0-15}$ output data. | | OEB | - | Output enable, which, when HiGH selects $DB_{0-15}$ as the ALU S operand, and, when LOW, selects RAM output B as the ALU S operand and the $DB_{0-15}$ output data. | | SIO <sub>0</sub><br>SIO <sub>15</sub> | I/O | Bidirectional serial shift inputs/outputs for the ALU shifter. SIQ <sub>3</sub> is an input and SIO <sub>15</sub> is an output during a shift-up operation. Refer to Tables 4 (a, b, c, d) and 5 for an exact definition of these pins. | | QIO <sub>0</sub><br>QIO <sub>15</sub> | 1/0 | Bidirectional serial shift inputs/outputs for the Q registers shifter. They operate like $SIO_0$ and $SIO_{15}$ pins. Refer to Tables 4 (a, b, c, d) and 5 for an exact definition of these pins. | | Cn | ı | Carry-in input to the ALU. | | IEN | ı | Instruction enable input. When LOW, it enables writing into the Q register and the Sign Compare flip-flop. When HIGH, the Q register and the Sign Compare flip-flop are in hold mode. IEN does not affect WRITE, but internally disables the RAM write enable. | | LSS | 1 | Input pin, when held LOW, causes the chip to act as either stand alone slice (SA) or the least significant slice (LSS), When LSS is held HIGH, the chip acts as either an intermediate slice or most significant slice. | | MSS | 1 | Input pin, when held LOW, programs the chip to act as either stand alone slice (SA) or the most significant slice (MSS) and holding it HIGH programs the chip to act either as an intermediate slice (IS) or the least significant slice (LSS). | | WRITE | 0 | The WRITE signal is LOW when an instruction which causes data to be written into the RAM is being executed. This piles normally connected to the WE pin. | | C <sub>n + 16</sub> | 0 | This output indicates the carry out of the ALU. Refer to Tables 6a and 6b for an exact definition of this pin. | | Z | 1/0 | An open drain bidirectional pin. When HIGH it indicates that all outputs are LOW. Z is used as an input pin for some special functions. Refer to Tables 6a and 6b for an exact definition of this pin. | | G/N | 0 | G indicates the carry generate function at the least significant and intermediate slices, and indicates the sign, N, of the ALU result at the most significant slice. Refer to Tables 6a and 6b for an exact definition of this pin. | | ŌĒŸ | ı | A control input pin. When LOW the ALU shifter output data is enabled onto the $Y_{0-15}$ lines. When HIGH the $Y_{0-15}$ three-state output buffers are disabled. | | СР | 1 | Clock input. The Sign Compare flip-flop and the Q register are clocked on the LOW-to-HIGH transition of the CP signa When WE and CP are LOW, data is written into the RAM. | | P/OVR | 0 | F indicates the carry propagate function at the least significant and intermediate slices, and indicates the conventional two's complement overflow, OVR, signal at the most significant slice. Refer to Tables 6a and 6b for an exact definition of this pin. | | Y <sub>0-15</sub> | 1/0 | Sixteen bi-directional data pins. Controlled by OEY input, the ALU shifter output data can be enabled onto these lines, external data is written directly into the RAM using these lines as data inputs. | | l <sub>o-8</sub> | 1 | The nine instruction inputs used to select the IDT49C403 operation to be performed. | | Q <sub>0-1</sub> | 1 | Two address pins to select one of the four Q registers. | | W/B | 1 | Word/Byte control pin. Used only in the standard function mode, it selects Word mode when held HIGH and Byte mod when held LOW. Must be tied HIGH when the special functions are being used. | | SDI | 1 | Serial Data Input pin, used for receiving diagnostic data and commands from a host system or from the SDO pin of a cascaded processor. | | SDO | 0 | Serial Data Output pin, used for transmitting diagnostic data and commands to a host system or a cascaded processor via its SDI pin. | | C/D | ı | Input pin, when LOW defines the bit pattern being received at the SDI pin as Data, and when HIGH defines the incomir pattern as a Command for executing diagnostic functions. This pin should be tied HIGH when the diagnostics feature is not being used. | | SCLK | 1 | Input pin used for clocking in diagnostic data and command information at the SDI pin. This pin should be tied LOW when the diagnostics function is not being used. | | DCMP | 0 | Output pin, which, when HIGH indicates that the internal comparison between the Y or Q bus data and the data from the diagnostics data register resulted in a TRUE (they were equal). This feature is used for breakpoint detection. It is an open-drain pin and can be wire AND with other DCMP pins. | ### **DEVICE ARCHITECTURE** The IDT49C403 CMOS microprocessor slice is configured sixten bits wide and is cascadable to any number of bits (32, 48, 64, etc.). Key elements which make up this sixteen-bit microprocessor slice are: (1) the RAM file (a 64 x 16 dual-port RAM) with latches on both outputs. (2) a high-performance ALU with shifter, (3) a flexible Q register file (4 x 16 bits) with shifter input, (4) a nine-bit instruction decoder, and (5) Serial Protocol Channel. The IDT49C403 incorporates Serial Protocol Channel (SPC™). For system testing and debugging purposes SPC is a method by which data can be entered into and extracted from a device through a serial data input output, thus providing access to all internal registers. ## **REGISTER FILE** The Register File is composed of 64 x 16 bit RAM locations. The RAM data is read from the A-port as controlled by the 6-bit A address field input. Simultaneously, data can be read from the B port as defined by the 6-bit B address field input. If the same address is applied at both the A input field and the B input field, identical data will appear at the two respective output ports. Data is written into the RAM when WE, IEN and the clock CP are LOW. Both the RAM output data latches are transparent while CP is HIGH and latch the data when CP is LOW. The three-state output enable $\overline{\rm OEB}$ allows RAM B port data to be read at the DB I/O port, while $\overline{\rm OEA}$ performs the same function for the A port data at the DA I/O port. New data is written into the RAM word defined by the B address field. External data at the Y I/O port can be written directly into the RAM, or the ALU shifter output data can be enabled onto the Y I/O port and written into the RAM. #### ALU The ALU can perform seven arithmetic and nine logic operations on the two 16-bit input words S and R. Multiplexers at the ALU inputs allow selection of various pairs of ALU source operands. The $\overline{OEA}$ input selects either external DA data or RAM A port output data as the 16-bit R source operand. The $\overline{OEB}$ and $I_0$ inputs provide selection of either RAM B port output, external DB data or the Q register file output as the 16-bit S source operand. Also, during certain ALU operations, zeroes are forced at the ALU operand inputs. Thus, the ALU can operate on data from two external sources, from an external and an internal source, or from two internal sources. Table 1 shows all possible pairs of source operands as selected by $\overline{OEA}$ , $\overline{OEB}$ , and $I_0$ inputs. Table 1, ALU Operand Sources(1) | Table 1: ALO Operand Obdites : | | | | | | | | | | |--------------------------------|----------------|-----|--------------------|--------------------|--|--|--|--|--| | ŌĒĀ | I <sub>0</sub> | ŌEB | ALU OPERAND R | ALU OPERAND S | | | | | | | L | L | L | Ram Output A | Ram Output B | | | | | | | L | L | Н | Ram Output A | DB <sub>0-15</sub> | | | | | | | L | Н | х | Ram Output A | Q Register | | | | | | | н | L | L | DA <sub>0-15</sub> | Ram Output B | | | | | | | н | L | Н | DA <sub>0-15</sub> | DB <sub>0-15</sub> | | | | | | | Н | Н | Х | DA <sub>0-15</sub> | Q Register | | | | | | #### NOTE: L = LOW, H = HIGH, X = DON'T CARE The ALU performs special functions when instruction bits $I_3$ , $I_2$ , $I_1$ , and $I_0$ are LOW. Table 5 defines these special functions and the operation which the ALU performs for each instruction. When the ALU executes instructions other than the special functions, the operation is defined by instruction bits $I_4$ , $I_3$ , $I_2$ , and $I_1$ . Table 2 defines the operation as a function of these four instruction bits. Table 2, IDT49C403 ALU Functions(1) | 14 | l <sub>3</sub> | l <sub>2</sub> | l <sub>1</sub> | l <sub>o</sub> | ALU FUNCTIONS | |----|----------------|----------------|----------------|----------------|--------------------------------------------------------------| | L | L | L | L | L | Special Functions | | L | L | L | L | Н | F <sub>i</sub> = HIGH | | L | L | L | Ι | Х | F=S-R-1+C <sub>n</sub> | | L | ٦ | Н | د | Х | $F = R - S - 1 + C_n$ | | L | ٦ | Н | Н | Х | F=R+S+C <sub>n</sub> | | L | Ŧ | L | ٦ | х | F=S+C <sub>n</sub> | | L | Ι | L | Н | Х | F=S+Cn | | L | Н | Н | ٦ | L | Reserved Special Functions | | L | H | Η | ٦ | Ι | F=R+C <sub>n</sub> | | L | Н | н | Н | L | Reserved Special Functions | | L | н | Н | Н | Н | $F = \overline{R} + C_n$ | | Н | L | L | Ļ | L | Special Functions | | Н | L | ٦ | L | н | F <sub>i</sub> = LOW | | Н | L | L | н | х | $F_1 = \overline{R}$ AND S | | Н | L | Τ | ٦ | Х | F <sub>i</sub> = R <sub>i</sub> EXCLUSIVE NOR S <sub>i</sub> | | Н | L | Н | н | х | F <sub>i</sub> = R <sub>i</sub> EXCLUSIVE OR S <sub>i</sub> | | Н | Η | ٤ | L | Х | F <sub>i</sub> = R <sub>i</sub> AND S <sub>i</sub> | | Н | Н | L | н | х | F <sub>i</sub> = R <sub>i</sub> NOR S <sub>i</sub> | | Н | н | Н | L | × | F <sub>I</sub> = R <sub>i</sub> NAND S <sub>I</sub> | | Н | Н | Н | Н | × | F = R OR S | #### NOTE: 1. L=LOW, H=HIGH, i=0 to 15, X=Don't Care The IDT49C403 may be cascaded in either a ripple carry or carry lookahead fashion. When configured as cascaded ALUs, the IDT49C403s must be programmed to be a most significant slice (MSS), an intermediate slice (IS), or a least significant slice (LSS) of the array. The carry generate, G, and carry propagate, P, signals that are necessary in a cascaded system are available as outputs on the IDT49C403 least significant and intermediate slices. The IDT49C403 provides a carry-out signal $C_{n+18}$ which is available as an output of each slice. The carry-in, $C_n$ , and carry-out, $C_{n+18}$ , are both active HIGH. Two other status outputs are generated by the ALU. These are the negative, N, and the overflow, OVR. The N output indicates positive or negative results, while the OVR output indicates that the arithmetic operation performed exceeded the available two's complement range. Thus the pins $\overline{G}/N$ and $\overline{P}/OVR$ indicate carry generate or propagate on the least significant and intermediate slice, and sign and overflow on the most significant slice. Refer to Tables 6a and 6b for an exact definition of these four signals. ### **ALU DESTINATION CONTROL** The following tables show how the shifter at the output of the ALU should function for non-special instructions. The main addition with respect to the IDT39C203 is the built in byte capability. The 49C403 has two write enables internally. One for the upper byte and one for the lower byte. The enables are controlled by the instruction decode, external $\overline{WE}$ and the $W/\overline{B}$ input. For convenience to the user, the unused bits on the Y bus (MSB, ...., 8) are zero during byte operation. The $\overline{WE}$ input must be directly connected to the WRITE output, or indirectly through some amount of gating (i.e., expansion RAM decoding gates). The sign extend function is an exception to the rule with regard to the internal byte write enables. When executed, all of the write enables are active, irrespective of W/B . In the SA and LSS slices, the contents of bit 7 is replicated on bits 8 to 15 and SlO $_{15}$ in the byte mode. In the word mode bit 15 is placed on SlO $_{15}$ . In this way an 8-bit word (byte) or a 16-bit word can be extended to the entire width of the native data path. Extends of larger words than these, such as 24 and 32 bits, can be achieved by steering the MSS and LSS inputs of the IS slices to inform which device has the sign bit to extend. As Sign Extend requires internal gating of the write enables to the upper and lower portions of RAM, the instruction will not work with locations in memory expansion RAM. #### **ALU SHIFTER** The ALU shifter shifts the ALU output data under instruction control. It can shift up one bit position (2F), shift down one bit position (F/2), or pass the ALU output non-shifted (F). An arithmetic shift operation shifts the data around the most significant (Sign) bit of the most significant slice and a logical shift operation shifts the data through the most significant bit. Figure 1 shows these shift patterns. The SIOo and SIO<sub>15</sub> are bidirectional serial shift input/output pins. During a shift-up operation, SIOo is generally an input while SIO<sub>15</sub> is an output, whereas during a shift-down operation SIOo is generally an output while SIO<sub>15</sub> acts as an input. Refer to Tables 4 (a, b, c, d) and 5 for an exact definition of these pins. The ALU shifter also provides sign extension and parity generating/checking capabilities. Under instruction control, the SlO<sub>6</sub> (Sign) input can be extended through $Y_0, Y_1, Y_2, ...., Y_{15}$ and propagated to the SlO<sub>15</sub> output. A cascadable, five-bit parity generator/checking generates parity for the F<sub>0</sub>, F<sub>1</sub>, F<sub>2</sub>, .....F<sub>15</sub> ALU outputs and SlO<sub>15</sub> input and, under instruction control, is made available at the SlO<sub>9</sub> output. Figure 1. IDT49C403 Arithmetic and Logical Shift Operations Table 5 defines the special functions and the operation the ALU shifter performs for each instruction. For instructions other than the special function, s, the ALU shifter operation is determined by instruction bits $l_8$ , $l_7$ , $l_6$ , and $l_5$ . Table 4 (a, b, c, d) defines the ALU shifter operation as a function of these four bits. ### WORD/BYTE CONTROL AND BYTE SWAP In addition to the special ALU functions, the IDT49C403 also provides a Word and Byte control and Byte Swap features. The W/B pin at the Instruction Decoder input selects ALU operation on either a Word or a Byte. When W/B is HIGH, the ALU operates on a Word and, when W/B is LOW, the ALU operates on a Byte. Table 4 (a, b, c, d) shows the ALU Destination Controls for Word and Byte operations for each instruction mode. The Byte Swap special function allows the positions of the Upper and Lower bytes to be swapped before entering them as the ALU S operand. The ALU function then adds C<sub>n</sub> to this swapped word as its F output. Table 5 shows the instruction set that allows the ALU to operate the Byte Swap feature. ### **Q REGISTER FILE** The Q register is a separate 4-word by 16-bit file intended primarily for multiplication and division routines and can also be used as an accumulator or holding register for other types of applications. The ALU output, F, can be loaded into the Q register and/or the Q register output can be selected as one of the ALU S operands. The shifter at the input to the Q register performs only logical shifts. It can shift-up the data one bit position (2Q) or down one bit position (Q/2). For a shift-up operation, QIO $_{0}$ acts as an input while QIO $_{15}$ acts as an output; whereas, for a shift-down operation, QIO $_{0}$ is an output and QIO $_{15}$ is an input. By connecting QIO $_{15}$ of the most significant slice to SIO $_{0}$ of the least significant slice, double-length arithmetic and logical shifting is possible with cascaded IDT49C403s. The $Q_0$ and $Q_1$ inputs enable selection of any one of the four 16-bit Q register files. Once a specific Q register has been selected, access to the other three Q registers is disabled and can be gained only after changing $Q_0$ and $Q_1$ levels to enable a different Q register. Table 5 defines the special functions and the operations which the Q register and shifter perform for selected instruction inputs. While executing instructions other than the special functions, the Q register and shifter operation is controlled by instruction bits $I_8$ , $I_7$ , $I_6$ and $I_5$ . Table 4 (a, b, c, d) defines the Q register and shifter operation as a function of these four bits. #### INSTRUCTION DECODER The internal control signals necessary for the operation of the IDT49C403 are generated by the instruction decoder as a function of the nine instruction inputs, Io-8; the instruction enable input, IEN; the LSS input; the MSS input; the W/B input and the WRITE output. The WRITE output is LOW when an instruction which writes data into the RAM is executed. Refer to Tables 4 (a, b, c, d) and 5 for a definition of the $\overline{\text{WRITE}}$ output as a function of the instruction inputs. When IEN is HIGH, the Q register and Sign Compare Flip-Flop contents are preserved. When IEN is LOW, the WRITE output is enabled and the Q register and Sign Compare Flip-Flop can be written according to the IDT49C403 instruction. The Sign Compare Flip-Flop is an on-chip flip-flop which is used during a divide operation. See Figure 2. Figure 2. Sign Compare Flip-Flop #### SLICE POSITION PROGRAMMING The IDT49C403 can be programmed to operate in either a cascaded application or in the standalone mode. Table 3 shows its four programmed modes. **Table 3. SLICE Programming** | SLICE PROGR | AM INPUTS | MODE OF OPERATION | | | | | |-------------|-----------|-------------------------------|--|--|--|--| | Mss | LSS | MODE OF OPERATION | | | | | | LOW | LOW | Stand Alone Slice (SA) | | | | | | LOW | HIGH | Most Significant Slice (MSS) | | | | | | HIGH | HIGH | Intermediate Slice (IS) | | | | | | HIGH | LOW | Least Significant Slice (LSS) | | | | | #### SPECIAL FUNCTIONS Seventeen special functions are provided on the IDT49C403 which permit the implementation of the following operations: - Single and Double Length Normalization - Two's Complement Division - Unsigned and Two's Complement Multiplication - Conversion Between Two's Complement and Sign/Magnitude Representation - · Incrementation and Decrementation by One or Two - BCD Add, Subtract, and Divide by Two - Single and Double-precision BCD-to Binary and Binary-to-BCD Conversion - Byte Swap Adjusting a single-precision or double-precision floating-point number in order to bring its mantissa within a specified range can be performed using the single-length and double-length normalization operations. Three special functions can be used to perform a two's comple- ment, non-restoring divide operation. They provide single and double-precision divide operations and can be performed in "n" clock cycles (where "n" is the number of bits in the quotient). The unsigned multiply special function and the two two's complement multiply special functions can be used to multiply two n-bit, unsigned or two's complement numbers respectively, in 'n' clock cycles. During the last cycle of the two's complement multiplication, a conditional subtraction rather than addition is performed due to the fact that the sign bit of the multiplier carries negative weight. The sign/magnitude – two's complement special function can be used to convert number representation systems. A number expressed in sign/magnitude representation can be converted to the two's complement representation, and vice-versa, in one clock cycle Incrementing an unsigned or two's complement number by one or two is easily accomplished using the increment by one or two special function. In addition to BCD arithmetic special functions to add or subtract two BCD numbers, a BCD divide by two adjust instruction can be used to obtain a valid BCD representation after shifting a number down by one bit. The BCD/Binary conversion special function instructions permit single and double-precision algorithms to convert from BCD-to-Binary and from Binary-to-BCD. The Byte Swap feature allows the swapping of Lower and Upper bytes of a word before presenting them as the ALU S operand. The ALU then adds the carry C<sub>n</sub> to this swapped word to form its F output. This feature functions only for the ALU S operand. ## SERIAL DIAGNOSTICS The Serial Protocol Channel ™ (SPC) is a flexible on-chip feature of the IDT49C403 and is a set of pins by which data can be entered into and extracted from a device through a serial data input and output port. SPC can be used at many points in the life of a product for diagnostic purposes such as system level design debug and development; system test during manufacturing and field maintenance debug and test. It allows for observation of critical signals deep within the system. During system test, when an error is observed, these signals may be modified in order to zero in on the fault in the system. Serial diagnostics is primarily a scheme utilizing only four pins to examine and alter the internal state of a system for the purpose of monitoring and diagnosing system faults. # Detailed SPC Architecture of the IDT49C403 Bit-Slice Microprocessor The IDT49C403, a quad Am2903/29203 16-bit microprocessor slice, which includes an ALU and register file, is one of the devices on which IDT has incorporated the Serial Protocol Channel. The implementation of SPC on the IDT49C403 is shown in Figure 3. Only four SPC pins (SDI, SDO, SCLK and $C/\overline{D}$ ) are used to serially access the I/O pad cells, as well as the internal ALU registers and buses. To control or monitor a section (such as the ALU), the appropriate command is loaded into the SPC command register. The desired function is then executed and the status information captured in the data register. The status information can then be serially shifted out and observed to verify proper system functionality. Figure 3. Conceptual Diagram of IDT49C403 Die Incorporating SPC Scan Path The block diagram in Figure 4 shows the detailed SPC architecture for the IDT49C403. It primarily consists of serial registers for command, data, addresses and decode/control logic. The SPC command register consists of a four-bit field (signals 4-7) and four discrete control lines (signals 3, 2, 1, 0). The four-bit field coordinates the transfer of data between RAM and the SPC data register, as well as controls an on-chip break detect mechanism. The other discrete signals control the serial scan path through the I/O cells. The SPC data register is in series with a RAM address register and I/O pad scan. The SPC data register is connected to the internal bus to gain access to the RAM register file as well as a data break point feature. The point of connection is the Y bus from the ALU back into the RAM. Figure 4. Internal Organization of the SPC The multiplexer at the output transmits information via the SDO pin selecting data from either the SPC data register and the I/O pads or the command string from the SPC command register. ## IDT49C403 SPC Command Opcodes The SPC command register consists of an 8-bit field, as shown in Figure 5. Bit 1 enables the READ function of the I/O pad cells. Bit 3 enables the BYPASS function to bypass the I/O pad cells and scan out only the RAM address and data registers. Bits 0 and 2 are reserved. Bits 4 through 7 form the opcode field for reading and writing into the device. The 4-bit command opcode field gives 16 possible command opcodes. The first 8 are reserved for writing data from the SPC data register into the registers and RAM on the device. The second 8 opcodes are reserved for reading data from registers and RAM into the 16-bit SPC data register. Figure 5. SPC Command Register and Opcodes for the IDT49C403 The command with opcode 0 causes a write to the internal device RAM. Opcode 1 is used to write to the Q registers. Opcodes 2 and 3 are used to write data from SPC data register into the break data register and break control registers, respectively. Opcodes 4 through 7 are reserved opcodes. Opcode 8 is used for reading RAM data into the SPC data register. Opcode 9 is used to read a value out of the Q registers. (Here, also, the address register supplies the address of the Q register to be accessed). Opcodes 10 and 11 are used for reading the break control register and the break data register, respectively. Opcode 12 is used to strobe data from the Z bus into the 16-bit diagnostics data register. Opcodes 13 and 14 are reserved opcodes. The last opcode, 15, is a no-operation opcode. This opcode can be used to scan the data in and out of the I/O pad cells and use the device in a pass-through mode (in a cascaded application) without affecting normal device operation. All the reserved opcodes, if executed, perform a no-operation; however, they should not be relied upon to always perform NOPs as future upgrades may make use of reserved opcodes. # Accessing the Contents of the IDT49C403 Register File To read data from the device's internal RAM or other logic circuitry into the SPC data register, the address and don't care bits (for the SPC data register) are shifted in. The command is shifted into the SPC command register. The command register must be decoded to determine what data paths are to be steered in order to get data into the SPC data register. The read strobe, generated by the strobe logic, must then strobe this data (in parallel) into the SPC data register. The data can now be shifted out via the SDO pin and its contents disassembled and observed. To perform the write operation, address and data must first be shifted into the SPC data register. The command is then shifted into the SPC command register via the command mode. This register provides information as to what data paths are to be steered. The address is supplied by the address register in the data scan path. The write strobe is then generated between the time the $C/\overline{\mathbb{D}}$ line is | | | _ | |-------------------------------------------|-------------------------------------------------------------|---| | 0 | Y15 | ] | | 1 | Y14 | 1 | | 2 | Y13 | 1 | | 3 | Y12 | ] | | 4 | Y11 | 1 | | 0<br>1<br>2<br>3<br>4<br>5<br>6<br>7<br>8 | Y15<br>Y14<br>Y13<br>Y12<br>Y11<br>Y10<br>Y9 | | | 6 | | 1 | | 7 | Y8 | ] | | | QIO15 | | | 9 | SIO15 | | | 10 | Q100 | 1 | | 11 | SIOO | ] | | 10<br>11<br>12<br>13<br>14 | OEY | Ī | | 13 | Z | ] | | 14 | W/B | | | 15 | Y7 | ] | | 16 | Y6 | Ì | | 17<br>18 | SIO0<br>OEY<br>Z<br>W/B<br>Y7<br>Y6<br>Y5<br>Y4<br>Y3<br>Y2 | | | 18 | Y4 | 1 | | 19 | Y3 | i | | 20 | Y2 | | | 21 | Y1 | | | 22 | YO | | | 23 | IEN | | | 24 | P/N | | | 25 | G/N | |----|------| | 26 | CN16 | | 27 | 15 | | 28 | 16 | | 29 | 17 | | 30 | 18 | | 31 | DCMP | | 32 | MSS | | 33 | D80 | | 34 | DB1 | | 35 | DB2 | | 36 | DB3 | | 37 | DB4 | | 38 | DB5 | | 39 | DB6 | | 40 | DB7 | | 41 | OEB | | 42 | CN | | 43 | 10 | | 44 | 11 | | 45 | 12 | | 46 | 13 | | 47 | 14 | | 48 | DB8 | | 49 | DB9 | | - | | |-----|------| | 50 | DB10 | | 51 | DB11 | | 52 | DB12 | | 53 | DB13 | | 54 | DB14 | | 55 | DB15 | | 56 | OEA | | 57 | DA0 | | 58 | DA1 | | 59 | DA2 | | 60 | DA3 | | 61 | DA4 | | 62 | DA5 | | 63 | DA6 | | 64 | DA7 | | _65 | AO | | 66 | A1 | | 67 | A2 | | 68 | A3 | AΔ A5 DA8 DAG DA10 DA11 | | L DAIZ | |----|------------| | 76 | DA13 | | 77 | DA14 | | 78 | DA15 | | 79 | LSS | | 80 | CP | | 81 | WE | | 82 | B0 | | 83 | B1 | | 84 | B2 | | 85 | <b>B</b> 3 | | 86 | B4 | | 87 | B5 | | 88 | Q0 | | 89 | Q1 | | 90 | WRITE | | | | lowered and the SCLK line is raised. This is the strobe which actually clocks the data into the RAM or register in the device. # Pad Cell Scan Path Each I/O cell on the IDT49C403 contains a flip-flop which can be used to store the state of that cell and then be scanned out. Figure 6 shows the logic configuration. The READ line is enabled by a bit in the SPC command register and gated by the XFER signal, thus loading the scan flip-flops in parallel. The SCLK is then used to scan the data out of the SDO pin in series with the address and SPC data registers. Figure 6. Serial Scan in the I/O Cell The BYPASS bit in the SPC command register selects whether the shifting of the I/O cells will be bypassed such that only the RAM address and data registers are scanned out. When the READ bit is HIGH, data is transferred from the pins to the scan register when SCLK transitions HIGH after C/D has transitioned LOW. The BYPASS bit in the command register is active HIGH so that a HIGH level bypasses scanning the I/O cells. Figure 7 shows the order in which the I/O pad cells are scanned. The clocking will shift out the data on the $Y_{15}$ pin first and continue in series until the WRITE pin is shifted out last. DA12 75 69 70 71 72 73 74 Figure 8. Breakpoint Detect Circuitry # **Breakpoint Detection on the IDT49C403** Figure 8 shows the diagnostics breakpoint detection circuit on the IDT49C403. This circuit is designed to allow the user to monitor certain key data buses and detect the data patterns on the Y and Q buses. When a data pattern is detected, a breakpoint compare signal is generated on the DCMP pin and is used to halt the system operation. The DCMP is an open drain signal and should be wire-ORed with DCMP lines of other similar devices and monitored by the main sequencer in the system. The breakpoint detection mechanism thus allows for an easier debug of microcode with regard to the data path. At the heart of the breakpoint detection circuit is a comparator which compares data from the break data register with data from either the Y bus or the Q bus. The break control register determines which of the two buses is selected for a comparison. The break control register also steers a multiplexer at the output of the comparator. This multiplexer selects between the equal-to signal, latched equal-to, V<sub>CC</sub> or GND. The latched equal-to input into the multiplexer gives the user the ability to pipeline the match signal, thus shortening the system cycle time in the diagnostics mode. The V<sub>CC</sub> and GND inputs to the multiplexer allow the programmer to disable the break compare feature by forcing the DCMP pin either LOW or HIGH, respectively. When a match is made, the DCMP line goes HIGH. Thus, if any one slice in a cascade application does not match, the wire-ANDed DCMP will be low. Selecting Vcc via the multiplexer will disable matches altogether. To select GND, disable any one slice from the comparison. Figure 9 shows the format of the break data and break control register. The break data pattern is 16 bits wide, with bit 16 being the most significant bit and last to be shifted in. The Break Control register contains three fields. Bits 0 and 1 control the DCMP output and bit 2 selects between the Y and the Q bus to be compared with the break data register. Bits 3 to 15 are reserved for future expansion. ## BREAK POINT CONTROL ACCESS | BUS SEL | BUS | DCMP CON | TROL DCMP STATUS | |---------|-----|----------|------------------| | 0 | Υ | 0 ( | LOW | | 1 | Q | 0 | 1 PIPELINED | | | | 1 ( | NON-PIPELINED | | | | 1 . | 1 HIGH | Figure 9. Breakpoint Control Registers and Opcodes The SPC version allows data to be transferred into and out of a device and can also accommodate addresses and commands using the same number of pins. This is accomplished with a reconfiguration of the function of the diagnostic pins and internal logic. With this vastly expanded capability, SPC can conveniently be used in RAMs, peripherals an complex logic functions. These new capabilities allow the user to monitor and modify all of the storage elements and pins of a device. With a simple hardware interface and appropriate software, any type personal or mini computer can be turned into a development system for IDT parts with serial diagnostics. Figure 10 shows the Serial Protocol Channel being used with a writable control store in a microprogrammed design. The control store can be initialized through the SPC path. A register with SPC is used for the instruction register going into the IDT49C410 (16-bit microprogram sequencer) as well as data registers around the IDT49C403. In this way, the designer may use the Serial Protocol Channel to observe and modify the microcode coming out of the writable control store, as well as observing and being able to modify data and instructions in the overall machine. The block diagram of the diagnostics ring shows how the devices with diagnostics are hooked together in a serial ring via the SDI and SDO signals. The diagnostics signals may be generated through registers which are hooked up to a microprocessor. This microprocessor could conceivably be an IBM PC. Figure 10. Typical Microprogram Application with SPC Table 4a. ALU Destination Control (Word Mode) for $l_0$ , $l_1$ , $l_2$ or $l_3$ = HIGH, $\overline{\text{IEN}}$ = LOW | | ALU SHIFTER<br>FUNCTION | | SIO <sub>15</sub> | | | | SIO | WRITE | Q REGISTER<br>AND SHIFTER | QIO | QIO | |-------------------------------------------------|-------------------------|-----|-------------------|-----------------|------------------|-----------------|----------|-------|---------------------------|-------------------|----------------| | la 1 <sub>7</sub> 1 <sub>6</sub> 1 <sub>5</sub> | | HEX | SA | MSS | IS | LSS | SIO | WHITE | FUNCTION | G10 <sub>15</sub> | 4.00 | | LLLL | Arith. F/2 → Y | 0 | Input - | | | | Fo | L | Hold | z | z | | LLLH | Log. F/2 → Y | 1 | 1 | | | | | L | Hold | Z | Z | | LLHL | Arith. F/2 → Y | 2 | | | | | | L | Log. Q/2 → Q | Input | a | | LLHH | Log. F/2 → Y | 3 | | | | | . ♦ | L | Log. Q/2 → Q | Input | Q <sub>o</sub> | | LHLL | F→Y | 4 | | | | | Parity | L | Hold | Z | Z | | LHLH | F→Y | 5 | | | | | | Н | Log. Q/2 → Q | Input | a <sub>o</sub> | | LHHL | F→Y | 6 | | | | | | н | F→Q | Z | Z | | LHHH | F→Y | 7 | . ↓ | | | | ₩ . | L | F→Q | Z | Z | | HLLL | Arith. 2F → Y | 8 | F <sub>14</sub> | F <sub>14</sub> | F <sub>15</sub> | F <sub>15</sub> | Input | ٦ | Hold | Z | Z | | нььн | Log. 2F→ Y | 9 | F <sub>15</sub> | F <sub>15</sub> | 1 1 | | ' | L | Hold | Z | Z | | нгнг | Arith. 2F → Y | Α | F <sub>14</sub> | F,4 | ] ] | | | L | Log. 2Q →Q | Q <sub>15</sub> | Input | | ньнн | Log. 2F→ Y | В | F <sub>15</sub> | F <sub>15</sub> | ] | | | ٦ | Log. 2Q →Q | Q <sub>15</sub> | Input | | HHLL | F→ Y | С | | | | | | Н | Hold | Z | Z | | HHLH | F→ Y | D | | <u> </u> | ₩ | | | н | Log. 2Q →Q | Q <sub>15</sub> | Input | | HHL | Sign Extend | E | | SIO | SIO <sub>0</sub> | | | ب | Hold | Z | Ż | | нннн | F→Y | F | ₩ | F <sub>15</sub> | F <sub>15</sub> | ₩ | <b>.</b> | L | Hold | Z | Z | Table 4b. ALU Destination Control (Byte Mode) for $I_0$ , $I_1$ , $I_2$ or $I_3 = HIGH$ , $\overline{IEN} = LOW$ | | ALU | | | s | 1015 | | | s | 1O <sub>0</sub> | | WOITE | Q REGISTER<br>AND SHIFTER | | 1015 | C | HO <sup>0</sup> | |-------------------------------------------------|---------------------|-----|----------------|-----|----------|----------------|----------|-------------------|-----------------|----------|-------|---------------------------|------------------|----------------|-------------------|-----------------| | la 1 <sub>7</sub> 1 <sub>6</sub> 1 <sub>5</sub> | SHIFTER<br>FUNCTION | HEX | SA | MSS | IS | LSS | SA | MSS | IS | LSS | WHILE | | | SA/LSS | MSS/IS | SA/LSS | | LLLL | Arith. F/2→Y | 0 | Input | | | | Fo | SIO <sub>15</sub> | SIO15 | ьo | L | Hold | z — | | | | | LLLH | Log. F/2→Y | 1 | | | | | | | l 1 | | ٦ | Hold | z – | | | | | LLHL | Arith. F/2→Y | 2 | | | | | | | | | L | Log. Q/2→Q | Input - | | Q10 <sub>15</sub> | Q <sub>0</sub> | | LLHH | Log. F/2-→Y | 3 | | | | | + | | | <b>+</b> | L | Log. Q/2→Q | Input - | | QIO <sub>15</sub> | Q <sub>0</sub> | | LHLL | F→Y | 4 | | | | | Parity | | | Parity | L | Hold | z | | | - | | LHLH | F→Y | 5 | ] | | | | | | | | н | Log. Q/2→Q | Input - | | QIO <sub>15</sub> | O <sub>0</sub> | | LHHL | F-→Y | 6 | | | | | 1 | | | | Н | F→Q | z | | | | | LННН | F→Y | 7 | ↓ | | | | <b>+</b> | ₩ | <u> </u> | \ \ | L | F→Q | | | | | | HLLL | Arith. 2F-→Y | 8 | F <sub>6</sub> | SIO | SIO | F <sub>6</sub> | Input | | | | L | Hold | | | | | | HLLH | Log. 2F→Y | 9 | F7 | 1 | | F7 | l 1 | | | | L | Hold | 1 | | | | | HLHL | Arith. 2F→Y | Α | Fe | 1 | | F <sub>6</sub> | 1 | | | | L | Log. 2Q →Q | QIO <sub>0</sub> | Q <sub>7</sub> | Input - | | | HLHH | Log. 2F→Y | В | F <sub>7</sub> | | | F <sub>7</sub> | 1 | | | | L | Log. 2Q →Q | QIO <sub>0</sub> | Q <sub>7</sub> | Input - | | | ннгг | F-→Y | С | 1 | | | | | | | | Н | Hold | z — | | | | | HHLH | F→Y | D | | 1 | | | | | | | Н | Log. 2Q → Q | QIO <sub>0</sub> | Q <sub>7</sub> | Input - | | | HHHL | Sign Extend | Ε | | | | | | | | | L | Hold | z | · | | | | ннн | F→Y | F | 1 + | | <u> </u> | ↓ | ↓ | | | | L | Hold | z — | | | | Parity = $F_{15}$ $\heartsuit$ $F_{14}$ ..... $\heartsuit$ $F_{3}$ $\heartsuit$ $F_{2}$ $\heartsuit$ $F_{1}$ $\heartsuit$ $F_{0}$ $\heartsuit$ SIO $_{15}$ $\heartsuit$ = Exclusive OR L = LOW H = HIGH Z = High Impedance SA = Stand Alone MSS = Most Significant Slice IS = Intermediate Slice LSS = Least Significant Slice Table 4c. ALU Destination Control for $I_0$ , $I_1$ , $I_2$ or $I_3$ = HIGH, $\overline{IEN}$ = LOW | | | | | | | 810 | 215 | | | | | | | Y | 15 | | | | ļ | | | , | /14 | | | | |-------------|-------------------------|-----|----------------|-----------------|----------|-----------------|------------------|-----------------|----------------|-----------------|------|-------------------|------|-------------------|------|-------------------|------|-----------------|---------|-----------------|------|-----------------|------|-----------------|----------|-----------------| | 18 17 16 15 | ALU SHIFTER<br>FUNCTION | HEX | | 8A | M | 88 | | 18 | u | 88 | | 8A | | 188 | | 18 | - | L88 | | BA | м | 88 | | IS | L | 88 | | | | | Byte | Word | LLLL | Arith. F/2-→Y | 0 | Input | | | | | | | | 0 | F15 | 0 | F15 | 0 | SIO <sub>15</sub> | 0 | SIO 15 | 0 | SIO 15 | 0 | SIO 15 | 0 | F 15 | 0 | F <sub>15</sub> | | LLLH | Log. F/2-+Y | 1 | 1 | | | | | | | | | SIO <sub>15</sub> | 1 | SIO <sub>15</sub> | 11. | | 1 | 1 | $\prod$ | F <sub>15</sub> | 11 | F15 | 11 | ΙïΙ | П | ιĭΙ | | LLHL | Arith. F/2-→Y | 2 | | | | | | | | | | F15 | Ш | F <sub>15</sub> | | | | | Ш | SIO 15 | 1 | SIO 15 | | | П | | | LLHH | Log. F/2—→Y | 3 | | | | | | | | | | SIO 15 | | SIO <sub>15</sub> | | L۷I | | · | Ш | F 15 | 11 | F15 | 11 | | 11 | . ↓ | | LHLL | F→Y | 4 | | | | | | | | | | F15 | | F15 | | F15 | | F15 | 11 | F14 | 11 | F14 | 11: | F14 | | F14 | | LHLH | F→Y | 5 | | | | | | | | | | 11 | | ' | | | | | | | 11 | 1 | | | | | | LHHL | F → Y | 6 | | | | | | | | | | | | | | | | | | | П | 11 | | | | | | гннн | F→Y | 7 | * | | | | | | | | | 1 | | | | | Н | | | | П | L.\ | | <b>+</b> | Н | <b>V</b> | | HLLL | Arith, 2F → Y | 8 | FB | F <sub>14</sub> | SIOO | F <sub>14</sub> | sio <sub>o</sub> | F <sub>15</sub> | F <sub>6</sub> | F <sub>15</sub> | | ₩. | | \ \ | | F14 | | F <sub>14</sub> | | F <sub>13</sub> | 11 | F <sub>13</sub> | 1 | F <sub>13</sub> | | F <sub>13</sub> | | HLLH | Log. 2F → Y | 9 | F7 | F15 | | F15 | | | F7 | | | F14 | | F14 | | | | - C | | " | 11 | ١١ | | ١١١ | Ш | ۱۱ | | HLHL | Arith. 2F → Y | Α | F <sub>6</sub> | F14 | | F14 | | | F <sub>6</sub> | | | F <sub>15</sub> | | F <sub>15</sub> | | | | | | | i I | | | | П | 11 | | ньнн | Log. 2F → Y | В | F <sub>7</sub> | F <sub>15</sub> | | F <sub>15</sub> | | | F <sub>7</sub> | Ιi | | F14 | | F <sub>14</sub> | | ♦ | | ₩ : | H | ₩ | Н | ↓ | l | ₩ | Ш | . ↓ | | HHLL | F→Y | С | | | | | | | | | | F15 | | F15 | | F15 | | F15 | | F14 | 11 | F14 | | F14 | | F14 | | ннцн | F→Y | D | | | | <u> </u> | | ╚╋ | | | * | | | F15 | ₩ | F15 | + | 1 | ♦ | 1 | ₩ | F14 | ₩ | F14 | <b>#</b> | | | нннг | Sign Extend | E | | | | SIOO | | SIOO | | | F7 | ] [ | SIO0 | SIO0 | SIOO | SIOO | F7 | | F7 | | SIOO | SIOO | SIOD | SIOO | F7 | 11 | | нннн | F→Y | F | • | . ♦ | <b>+</b> | F <sub>15</sub> | <b>†</b> | F <sub>15</sub> | . ♦ | ¥ | 0 | [ ∳ ] | 0 | F15 | 0 | F15 | 0 | ₩. | 0 | | 0 | F14 | | | 0 | . ↓ | Table 4c. ALU Destination Control for $I_0$ , $I_1$ , $I_2$ or $I_3 = HIGH$ , $\overline{IEN} = LOW$ (cont'd.) | | | | | | | γ | 13-9 | | | | | | | • | 'a | | | | | | | | ٧, | | | | |-------------|-------------------------|-----|------|------------------|------------------|------------------|------------------|------------------|----------|------------------|----------|----------------|------------------|------------------|------------------|------------------|----------|----------------|-------------------|----------------|------------------|----------------|------|----------------|-------------------|----------------| | 18 17 16 15 | ALU SHIFTER<br>FUNCTION | HEX | | SA | R | ISS | | 18 | L | 88 | | SA | • | 188 | r – | 18 | L | 88 | S. | A | м | SS | _ | IB | L | ss | | | | | Byte | Word | LLŁL | Artth. F/2> Y | 0 | 0 | FI+ 1 | 0 | F <sub>1+1</sub> | 0 | F1+1 | 0 | FI+1 | 0 | Fa | 0 | Fg | ٥ | Fa | 0 | Fa | F7 | Fa | , | Fa | 0 | F8 | F <sub>7</sub> | Fa | | LLLH | Log. F/2→Y | 1 | | 11 | | 11 | 1 | | | | | Ĭ | 1 | ľ | | اآا | 11 | | SIO <sub>15</sub> | | Ιì | l i° | li | 1 1 1 | SIO <sub>15</sub> | 1 , 1 | | LLHL | Arith. F/2→Y | 2 | | | 11 | | Ш | | | | | | Ш | | | | | | F <sub>7</sub> | | | Ш | | | F <sub>7</sub> | ίll | | LLHH | Log. F/2 → Y | 3 | | <u> </u> | | | | . ₩ | | ₩ | | ₩ | 11 | ↓ | | ₩. | - 11 | . ↓ | SIO <sub>15</sub> | ↓ | | ↓ | | | SIO <sub>15</sub> | ↓ | | LHLL | F→Y | 4 | ! | Fį | ] [ | FĮ | ] ; | Fi | | Fį | | F8 | | F <sub>8</sub> | | F <sub>8</sub> | | Fa | F <sub>7</sub> | F <sub>7</sub> | 1 | F7 | | F <sub>7</sub> | F <sub>7</sub> | F7 | | LHLH | F→Y | 5 | | | | | | | | 1 | | 1 | | Ī | | ΙĭΙ | -11 | ĭ | i | Ĺ | | Ιú | | l i l | í | ΙίΙ | | LHHL | F→Y | 6 | | | Ш | | | | | | | | | | | | -11 | - 1 | - 1 4 | | Ш | | | | - | 111 | | LHHH | F→Y | 7 | | | ! , | . ▼ | | | | _ | 11 | . 🛊 | | ₩ . | | ∳ | | . ₩ | - | | H | ↓ | | ↓ | | ↓ | | HLLL | Arith. 2F → Y | 8 | | F <sub>j-1</sub> | | F <sub>j-1</sub> | | F <sub>I-1</sub> | - [ [ | F <sub>I-1</sub> | 11 | F7 | | F <sub>7</sub> | | F <sub>7</sub> | 11 | F <sub>7</sub> | ↓ | FR | | Fa | | FB | | Fe | | HLLH | Log. 2F→Y | 9 | | | | | | | - | | 11 | i i | | ٦ij | | | | i l | F <sub>6</sub> | ĭ | | اٽا | | ı | F <sub>6</sub> | ۱ľ۱ | | HLHL | Arith. 2F → Y | Α | | | | | | | | | 11 | | | | | | П | | F7 | - [ [ | | $ \ \ $ | | | F7 | | | нгнн | Log. 2F → Y | В | | * | | • | | ₩ | | <u> </u> | | | - | | | ₩ | | <b>↓</b> | F <sub>6</sub> | . ↓ . | | | | <b>↓</b> | F <sub>6</sub> | , J I | | HHLL | F→Y | c | | Fi | | Fį | - [ | F | ] [ | Fı | | F <sub>8</sub> | | F <sub>8</sub> | 11 | F <sub>8</sub> | 11 | F <sub>8</sub> | $\overline{}$ | F <sub>7</sub> | | F <sub>7</sub> | | F <sub>7</sub> | F7 | F <sub>7</sub> | | HHLH | F→Y | D | ٠ | | • | Fi | * | Fi | <u> </u> | 11 | <u> </u> | 11 | + | F <sub>8</sub> | ₩. | F <sub>8</sub> | <b>#</b> | Ĺ | ΙÌ | Ĥ | ¥ | F7 | ₩ | F7 | ı î | ı' l | | HHHL | Sign Extend | E | F7 | | SIO <sub>0</sub> | sic <sub>0</sub> | SIO <sub>0</sub> | SIO <sub>0</sub> | F7 | 1 [ | F 7 | | SIO <sub>0</sub> | SIO <sub>0</sub> | sio <sub>0</sub> | SIO <sub>0</sub> | F7 | | | 11 | SIO <sub>0</sub> | SIOO | SIOO | _ | | | | нннн | F→Y | F | 0 | • | 0 | F, | 0 | Fi | 0 | ₩[ | 0 | <b>V</b> | 0 | F <sub>8</sub> | 0 | F <sub>8</sub> | 0 | <b>↓</b> | . ↓ [ | . ↓ [ | 0 | F <sub>7</sub> | 0 | F <sub>7</sub> | ↓ | <b>↓</b> | Table 4c. ALU Destination Control (cont'd.) for $I_0$ , $I_1$ , $I_2$ or $I_3$ = HIGH, $\overline{IEN}$ = LOW | | Ī | | | | | Υ, | 3 | | | | | | | Y | 5-1 | | | | | | | ` | <b>'</b> 0 | | | | |--------|-------------------------|-----|----------------|----------------|------|----------------|------------------|----------------|----------------|----------------|------------------|------------------|------------|----------------------------------------------|------------------|------------------|------------------|------------------|------------------|------------------|----------|------------------|------------------|------------------|------------------|------| | 171815 | ALU SHIFTER<br>FUNCTION | HEX | 8 | iA . | M | 188 | | IS | L.S | 38 | - | SA. | N | ISS | 1 | s | Ľ | 88 | 8, | A. | М | 88 | | 18 | U | 88 | | | PONCTION | | Byte | Word | LLL | Arith. F/2→Y | 0 | SIO15 | F7 | 0 | F7 | 0 | F7 | SIO 15 | F7 | Fi + 1 | Fi+1 | 0 | FI+1 | 0 | F(+1 | Fi+1 | FI+1 | F1 | F1 | 0 | F1 | 0 | Fı | F1 | F1 | | LLH | Log. F/2→Y | 1 | F <sub>7</sub> | | П | | | | F7 | | | | | | | | | | | | | 11 | | l 1 I | | Ш | | LHL | Arith. F/2-Y | 2 | SIO15 | | 11 | | | | SIO 15 | 11 | П | П | | | | | | | 11 | | 1 | 11 | | | | П | | LHH | Log. F/2→Y | 3 | F7 | ₩ | ] ] | Lŧ | | <u> </u> | F7 | <u> </u> | * | <b>*</b> | | <u> </u> | | + | * | Ý | <u> </u> | | H | | 1 | * | * | * | | HLL | F→Y | 4 | F <sub>6</sub> | F <sub>6</sub> | 11 | Fe | | Fe | F <sub>6</sub> | F <sub>6</sub> | Fi | Fį | 1 | Fj | | F | Fi | Fj | Fo | Fo | ! ! | Fo | 11 | Fo | Fo | Fo | | HLH | F+Y | 5 | 11 | 1 | 11 | | | 11 | l I | 11 | | | 11 | 11 | | | | | 11 | | 11 | Н | 11 | | | П | | H H L | F-+Y | 6 | ] | Ш | | 11 | | | | 11 | | 11 | П | | $ \ \ $ | | Н | 11 | | 11 | Ш | H | | | | Н | | ннн | F→Y | 7 | ] ♦ | <b>.</b> | | L. | | | | 1 | . * | * | ! ! | * | 111 | 1 | * | | * | <b>*</b> | 11 | * | 11 | ┸ | . * | 1 | | LLL | Arith. 2F→Y | 8 | F <sub>5</sub> | F <sub>5</sub> | H | F <sub>5</sub> | | F <sub>5</sub> | F <sub>5</sub> | F <sub>5</sub> | F <sub>i-1</sub> | F <sub>[-1</sub> | 11 | F <sub>j-1</sub> | Ш | F <sub>j-1</sub> | F <sub>!-1</sub> | F <sub>I-1</sub> | SIO <sub>0</sub> | SIO <sub>0</sub> | H | SIO <sub>0</sub> | | SIO | SIC <sub>0</sub> | SIC | | LLH | Log. 2F→Y | 9 | ] | Ш | | | l I | | | 11 | Ш | 11 | Н | | | | Н | | П | | | 1 | | | Н | П | | L H L | Arith. 2F→Y | Α | 1 | | | | | 1 | 11 | 11 | H | | | | | Ш | | | 11 | | 11 | | | 111 | Ш | П | | LHH | Log. 2F→Y | В | 1 ₩ | ₩ | | ۱ 🛊 | П | ₩ | ₩. | <u> </u> | ₩ | <b>*</b> | | Lŧ. | | | | <b>*</b> | <u> * </u> | * | 11 | 1 | 11 | <u> </u> | <u> </u> | ļ٠ | | HLL | F→Y | С | F <sub>6</sub> | F <sub>6</sub> | 11 | F <sub>6</sub> | 11 | F <sub>6</sub> | Fe | F <sub>6</sub> | F, | F | 1 | FI | | Fi | Fı | Fi | Fo | Fo | Н | Fo | 1 | Fo | Fo | ١F. | | HLH | F→Y | В | 1 🗀 | 11 | ₩ | F <sub>6</sub> | ₩ | F <sub>6</sub> | ] [ | 11 | П | | <b>.</b> ★ | FI | * | Fi | ] | | 11 | 11 | <u> </u> | Fo | * | Fo | Н | 11 | | HHL | Sign Extend | E | 1 | 11 | SIO | SIOO | SIO <sub>0</sub> | SIO | | | | | SIO | SIO <sub>0</sub> | sio <sub>0</sub> | SIO | 1 | | П | | SIO | SIO | SKO <sub>0</sub> | SIO <sub>0</sub> | Н | H | | ннн | <del> </del> | F | 1 ↓ | ↓ | 0 | FB | 0 | FB | 7 I | ₩ | ₩ | ₩ | 0 | FL | 0 | Fi | ₩ | ₩ | I₩ | ₩ | ٥ | Fo | 0 | Fo | ₩ | 1 | $i = 1 \text{ to 6 (for F}_{5-1})$ SA = Stand Alone MSS = Most Significant Slice IS = Intermediate Slice LSS = Least Significant Slice Table 4c. ALU Destination Control (cont'd.) for I<sub>0</sub>, I<sub>1</sub>, I<sub>2</sub>or I<sub>3</sub> = HIGH, IEN = LOW | | | | | | | 9 | 100 | | | | |-------------------------------------------------|----------------------|-----|---------|----------|-------------------|----------|-------------------|--------|----------|-------------| | la 1 <sub>7</sub> 1 <sub>6</sub> 1 <sub>5</sub> | ALU SHIFTER FUNCTION | HEX | - | SA | M | ISS | 1 | s | L | SS | | | | | Byte | Word | Byte | Word | Byte | Word | Byte | Word | | LLLL | Arith. F/2→Y | 0 | Fo | Fo | SIO <sub>15</sub> | Fo | SIO <sub>15</sub> | Fo | Fo | Fo | | LLLH | Log. F/2→Y | 1 | | | | | | | | | | LLHL | Arith. F/2→Y | 2 | | | | | . | | | | | LLHH | Log. F/2→Y | 3 | | <b>.</b> | | _ ₩ | | | 1 | | | LHLL | F→Y | 4 | Parity | Parity | | Parity | 1 | Parity | Parity | Parity | | LHLH | F→Y | 5 | | | | l I | | | | | | LHHL | F→Y | 6 | | | | | | | | | | LHHH | F-→Y | 7 | | | ♦ _ | <b>.</b> | <b>.</b> | _ ₩ | <u> </u> | | | HLLL | Arith. 2F→Y | 8 | Input - | | | | | | | <del></del> | | HLLH | Log. 2F→Y | 9 | 1 | | | | | | | | | HLHL | Arith. 2F-→Y | Α | | | | | | | | | | HLHH | Log. 2F→Y | В | | | | | | | | | | HHLL | F→Y | С | | | | | | | | | | HHLH | F-→Y | D | | | | | | | | | | HHHL | Sign Extend | E | | | | | | | | | | нннн | F→Y | F | | | | | | | | | $i = 9 \text{ to } 14 \text{ (for } F_{13-9})$ Table 4d. ALU Destination Control for $l_0$ , $l_1$ , $l_2$ or $l_3 = HIGH$ , $\overline{IEN} = LOW$ | | Q REGISTER | | | Q | 1015 | | | ( | Q <sub>15</sub> | | | | 214-9 | | | *** | Q, | | |-------------------------------------------------------------|-------------|-----|------------------|-----------------|----------------|-----------------|------------|-------------------|-----------------|-------------------|----------|------------------|-------|------------------|--------------|----------------|------|----------------| | l <sub>8</sub> l <sub>7</sub> l <sub>6</sub> l <sub>5</sub> | AND SHIFTER | HEX | MS | S/IS | SA/ | LSS | мѕ | S/IS | SA/ | LSS | MS | S/IS | SA/ | LSS | MS | S/IS | SA/ | LSS | | | FUNCTION | | Byte | Word | LLLL | Hold | 0 | z - | | | | Hold | | | | Hold | | | | Hold | | | | | LLLH | Hold | 1 | z - | | | | <b> </b> - | | | - | | | | | <del> </del> | | | | | LLHL | Log. Q/2→Q | 2 | Input | | | | | QIO <sub>15</sub> | | QIO <sub>15</sub> | | Q <sub>1+1</sub> | | Q <sub>1+1</sub> | | Qg | | Q <sub>p</sub> | | LLHH | Log. Q/2→Q | 3 | Input | | | - | | Q1O <sub>15</sub> | | QIO <sub>15</sub> | | Q <sub>1+1</sub> | | Q <sub>1+1</sub> | | Q <sub>9</sub> | | Qg | | LHLL | Hold | 4 | z - | | | | | Hold | | Hold | | Hold | | Hold | | Hold | | Hold | | LHLH | Log. Q/2→Q | 5 | Input | | | | | QIO <sub>15</sub> | | QIO <sub>15</sub> | | Q (+1 | | Q <sub>1+1</sub> | | G <sub>9</sub> | | Q <sub>9</sub> | | LHHL | F-→Q | 6 | z – | | | | | F <sub>15</sub> | | F <sub>15</sub> | | Fi | | Fi | | F <sub>8</sub> | - 1 | F <sub>8</sub> | | LHHH | F→Q | 7 | | | | | | F <sub>15</sub> | | F <sub>15</sub> | | F | | Fi | | F <sub>8</sub> | | F <sub>8</sub> | | HLLL | Hold | 8 | | | | | | Hold | | Hold | | Hold | | Hold | | Hold | | Hold | | HLLH | Hold | 9 | + | | | | | Hold | | Hold | | Hold | | Hold | 1 | Hold | | Hold | | HLHL | Log. 2Q-→Q | Α | QIO <sub>0</sub> | Q <sub>15</sub> | Q <sub>7</sub> | Q <sub>15</sub> | | Q <sub>14</sub> | | Q <sub>14</sub> | | Q <sub>i-1</sub> | | Q <sub>1-1</sub> | | Q <sub>7</sub> | | Q <sub>7</sub> | | HLHH | Log. 2Q→Q | В | $QIO_0$ | Q <sub>15</sub> | Q <sub>7</sub> | Q <sub>15</sub> | | Q <sub>14</sub> | | Q <sub>14</sub> | | Q <sub>1-1</sub> | | Q -1 | | Q <sub>7</sub> | | Q <sub>7</sub> | | HHLL | Hold | С | z – | | | _ | | Hold | | Hold | | Hold | | Hold | | Hold | | Hold | | HHLH | Log. 2Q→Q | D | QIOo | Q <sub>15</sub> | Q <sub>7</sub> | Q <sub>15</sub> | | Q <sub>14</sub> | | Q <sub>14</sub> | | Q <sub>I-1</sub> | | Q -1 | | Q <sub>7</sub> | | Q <sub>7</sub> | | HHHL | Hold | E | z – | | | - | | Hold | | Hold | | Hold | | Hold | | Hold | | Hold | | нннн | Hold | _F | z | | | | | Hold | ¥ | Hold | <u> </u> | Hold | ¥ | Hold | ¥ | Hold | . ₩ | Hold | Table 4d. ALU Destination Control for In. In. In or In = HIGH. IEN = LOW (cont'd.) | | Q REGISTER | | | | Q | 7 | | | ( | 26-1 | | | 1 | Q <sub>0</sub> | | | | QIO <sub>0</sub> | | |---------|-------------|---|-----|------|------------------|-------------------|----------------|----------|--------------------|------|------|------|------------------|----------------|----------|-------------------|------------------|------------------|------| | | AND SHIFTER | | M | ISS/ | 'IS | SA/ | LSS | M: | SS/IS | SA/ | LSS | M | SS/IS | SA/ | LSS | MS | S/IS | SA/ | LSS | | | FUNCTION | | Ву | te \ | Word | Byte | LLLL | Hold | 0 | Hol | ld - | | | _ | Holo | ī —— | - | - | Hola | | | <u> </u> | z | | | | | LLLH | Hold | 1 | | | | | | $\vdash$ | | | | - | | | > | Z | | | | | LLHL | Log. Q/2→Q | 2 | | | Q <sub>8</sub> | QIO <sub>15</sub> | Q <sub>β</sub> | | Q <sub>1+1</sub> - | - | | 1 | Q <sub>1</sub> - | | - | QIO <sub>15</sub> | Q <sub>0</sub> - | | | | LLHH | Log. Q/2→Q | 3 | - 1 | | Q <sub>8</sub> | QIO <sub>15</sub> | Q <sub>8</sub> | | Q <sub>1+1</sub> - | | - | | Q1- | | - | QIO <sub>15</sub> | Q <sub>0</sub> - | | _ | | LHLL | Hold | 4 | | | Hold | | <b>*</b> | - [ | Hold - | | - | | Hold | | | Z | | | | | LHLH | Log. Q/2→Q | 5 | | | Q <sub>8</sub> | QIO <sub>15</sub> | Q <sub>8</sub> | - 1 | Q1+1- | | | | Q <sub>1</sub> - | | | QIO 15 | Q <sub>0</sub> - | | | | LHHL | F→Q | 6 | | | F7 - | | - | | F <sub>1</sub> — | | - | | F <sub>0</sub> - | | | z - | | | | | _ н н н | F→Q | 7 | | | F7 - | | | | F, | | - | | F <sub>0</sub> - | | | 1 1 | | | | | HLLL | Hold | 8 | | L | Hold - | | | | Hold - | | _ | | Hold | | | | | | | | HLLH | Hold | 9 | | Į. | Hold - | | | | Hold - | | _ | | Hold · | | _ | <b> </b> | | | | | HLHL | Log. 2Q→Q | Α | - | | Q <sub>6</sub> — | | - | | Q <sub>1-1</sub> - | | | | QIO <sub>0</sub> | | _ | Input | | | | | нгнн | Log. 2Q→Q | В | ı | | Q <sub>6</sub> - | | | | Q 1-1 - | | _ | | QIO <sub>0</sub> | | | Input | | | | | HHLL | Hold | С | ľ | | Hold - | | | | Hold - | | - | | Hold | | | Z | | | | | HHLH | Log. 2Q→Q | D | | | Q <sub>6</sub> | | | | Q -1 - | | _ | | QIO <sub>0</sub> | | _ | Input | | | | | HHL | Hold | Е | | | Hold - | | | | Hold - | | | | Hold | | - | z - | | - | | | нннь | Hold | F | ¥ | Ti | Hold - | | | ₩ | Hold - | | - | ŧ | Hold | | | z - | | | | $i = 1 \text{ to 6 (for } Q_{6-1})$ $i = 9 \text{ to } 14 \text{ (for } Q_{14-9})$ Z = High Impedance SA = Stand Alone MSS = Most Significant Slice IS = Intermediate Slice LSS = Least Significant Slice Table 5. Special Functions (7) | | | UEV | SPECIAL | ALU | ALU SHIFTER | s | 1015 | | Q REGISTER | | | | |-----------------------------------------------------------------|----|-----------------------------------------------------------------|--------------------------------------------------------|--------------------------------------------------------------|--------------------|--------------------------------------|-----------------|----------------|-----------------------|-------------------|------------------|-------| | HEX 1 <sub>8</sub> 1 <sub>7</sub> 1 <sub>6</sub> 1 <sub>5</sub> | 14 | HEX 1 <sub>3</sub> 1 <sub>2</sub> 1 <sub>1</sub> 1 <sub>0</sub> | FUNCTION | FUNCTION | FUNCTION | мѕѕ | OTHER<br>SLICES | SIO | & SHIFTER<br>FUNCTION | QIO <sub>15</sub> | GIO <sup>0</sup> | WRITE | | 0 | L | 0 | Unsigned Multiply | $F=S+C_n$ if $Z=L$<br>$F=R+S+C_n$ if $Z=H$ | Log F/2→Y<br>(1) | HZ | Input | F <sub>0</sub> | Log Q/2→Q | Input | Q <sub>0</sub> | L | | 1 | L | 0 | BCD-to-Binary<br>Conversion | (4) | Log F/2→Y | Input | Input | F <sub>0</sub> | Log Q/2→Q | Input | Qo | L | | 1 | н | 0 | Multiprecision<br>BCD-to-Binary | (4) | Log F/2-→Y | Input | Input | Fo | Hold | HZ | Q <sub>0</sub> | L | | 2 | L | 0 | Two's Complement<br>Multiply | $F=S+C_n$ if $Z=L$<br>$F=R+S+C_n$ if $Z=H$ | Log F/2 →Y<br>(2) | HZ | Input | Fo | Log Q/2→Q | Input | Q <sub>0</sub> | L | | 3 | L | 0 | Decrement by<br>One or Two | F=S-2+Cn | F→Y | Input | Input | Parity | Hold | HZ | HZ | L | | 4 | L | 0 | Increment by<br>One or Two | F = S + 1 + C <sub>n</sub> | F→Y | Input | Input | Parity | Hold | HZ | HZ | L | | 4 | Н | 0 | Byte Swap + C <sub>n</sub> | $F = (S_{LB}, S_{UB}) + C_n$ | F→Y | Input | Input | Parity | Hold | HZ | HZ | L | | 5 | ٦ | 0 | Sign/Magnitude<br>Two's Complement | | F/2 →Y<br>(3) | Input | Input | Parity | Hold | HZ | ΗŻ | L | | 6 | L | 0 | Two's Complement<br>Multiply, Last Cycle | $F=S+C_n$ if $Z=L$<br>$F=S-R-1+C_n$ if $Z=H$ | Log F/2 → Y<br>(2) | HZ | Input | Fo | Log Q/2→Q | Input | Q <sub>0</sub> | L | | 7 | L | 0 | BCD Divide by Two | (4) | F→Y | Input | Input | Parity | Hold | HZ | HZ | L | | 8 | L | 0 | Single Length<br>Normalize | F=S+C <sub>n</sub> | F→Y | F <sub>15</sub> | F <sub>15</sub> | HZ | Log 2Q →Q | Q <sub>15</sub> | Input | L | | 9 | L | 0 | Binary-to-BCD<br>Conversion | (5) | Log 2F→Y | F <sub>15</sub> | F <sub>15</sub> | Input | Log 2Q →Q | Q <sub>15</sub> | Input | L | | 9 | Н | 0 | Multiprecision<br>Binary-to-BCD | (5) | Log 2F→Y | F <sub>15</sub> | F <sub>15</sub> | Input | Hold | HZ | input | L | | А | L | 0 | Double Length<br>Normalize and<br>First Divide Op | F=S+Cn | Log 2F→Y | R <sub>15</sub> V<br>F <sub>15</sub> | F <sub>15</sub> | Input | Log 2Q →Q | Q <sub>15</sub> | Input | L | | В | L | 0 | BCD Add | F=R+S+C <sub>n</sub> BCD (6) | F→Y | 0 | 0 | HZ | Hold | HZ | HZ | L | | С | L | 0 | Two's Complement<br>Divide | $F=S+R+C_n$ if $Z=L$<br>$F=S-R-1+C_n$ if $Z=H$ | Log 2F→Y | R <sub>15</sub><br>V F | F <sub>15</sub> | Input | Log 2Q →Q | Q <sub>15</sub> | Input | L | | D | L | 0 | BCD Subtract | F = R-S-1 + C <sub>n</sub> BCD (6) | F→Y | 0 | 0 | HZ | Hold | HZ | HZ | L | | E | L | 0 | Two's Complement<br>Divide Correction<br>and Remainder | F=S+R+C <sub>n</sub> if Z=L<br>F=S-R-1+C <sub>n</sub> if Z=H | F→Y | F <sub>15</sub> | F <sub>15</sub> | HZ | Log 2Q →Q | Q <sub>15</sub> | Input | L | | F | L | 0 | BCD Subtract | F=S-R-1+C <sub>n</sub> BCD (6) | F→Y | 0 | 0 | HZ | Hold | HZ | HZ | L | ## NOTES: - 1. At the most significant slice only, the C<sub>0+16</sub> signal is internally gated to the Y output. - 2. At the most significant slice only, F<sub>15</sub> $\nabla$ OVR is internally gated to the Y output. - 3. At the most significant slice only, $S_{15}$ $\nabla$ $F_{15}$ is generated at the Y output. - 4. On each nibble, F = S if magnitude of S is less than 8, and F = S minus three if magnitude of S is 8 or greater. - 5. On each nibble, F = S if magnitude of S is less than 5, and F = S plus three if magnitude of S is 5 or greater. Addition is modulo 16. - 6. Additions and Subtractions are BCD adds and subtracts. Results are undefined if R or S are not in valid BCD format. - 7. The O register cannot be used explicitly as an operand for any Special Functions. It is defined implicitly within the functions. - 8. BCD Nibble propagate: $\overline{PN}_1 = (\overline{P}_{4l+0} + \overline{P}_{4l+3}) (\overline{P}_{4l+0} + \overline{G}_{4l+2}) (\overline{P}_{4l+0} + \overline{G}_{4l+1} + \overline{P}_{4l+2})$ BCD Slice propage: $\overline{P} = PN_3 PN_2 PN_1 PN_0$ - 9. BCD Nibble generate: $\overline{GN_1} = \overline{G_{4|+3}} \cdot (\overline{G_{4|+0}} + \overline{G_{4|+1}} + \overline{P_{4|+2}}) \cdot (\overline{G_{4|+0}} + \overline{G_{4|+1}}) \cdot (\overline{P_{4|+1}} + \overline{G_{4|+2}}) \cdot (\overline{P_{4|+3}} + \overline{P_{4|+1}} \cdot \overline{P_{4|+2}} \cdot \overline{G_{4|+3}}) \cdot \overline{G_{4|+3}} \cdot$ L = LOW LB = Lower Byte **▽** = Exclusive OR H = HIGH UB = Upper Byte Parity = SIO<sub>15</sub> \$\Phi F\_{15} \$\Phi F\_{14} \$\Phi F\_{13} \$\Phi \dots \dots \dots \frac{1}{5}\$ HZ = High Impedance Table 6a. IDT49C403 Status Outputs (Word Mode) | HEX | HEX | Ι. | G, | P <sub>1</sub> | | P/OVR | | G/ | N | I | Z (Ō | EŸ = I | L) | |-------------|-------------|----------------|----------------------------------------|------------------------------------|---------------------|----------------------------------------|-------|-----------------------------------------------------------------------|-------|---------------------------------|-------|----------------|---------------------------------| | 18 17 18 15 | 14 13 12 11 | ا <sub>0</sub> | | (i = 0 to 15) | C <sub>n+15</sub> | MSS/SA | OTHER | | OTHER | MSS | ISS | LSS | SA | | Х | 0 | Н | 0 | 1 | 0 | 0 | 0 | F <sub>15</sub> | Ğ | f (Y) | f (Y) | f (Y) | 1 (Y) | | Х | 1 | х | Ri∧Si | Ri V Si | G V PCn | Cn+15 T Cn+16 | Ē | F <sub>15</sub> | Ğ | f(Y) | f (Y) | f (Y) | f (Y) | | Х | 2 | Х | Ři∧Si | Ri V SI | G V PCn | Cn+15 T Cn+16 | P | F <sub>15</sub> | Ğ | f(Y) | f (Y) | f (Y) | f (Y) | | X | 3 | Х | Ri∧Si | Ri V Si | G V PCn | C <sub>n+15</sub> ♥ C <sub>n+16</sub> | P | F <sub>15</sub> | Ğ | f(Y) | f (Y) | f (Y) | f(Y) | | Х | 4 | х | 0 | Si | G V PC <sub>n</sub> | Cn+15 T Cn+16 | P | F <sub>15</sub> | G | f(Y) | f (Y) | f (Y) | f(Y) | | х | 5 | х | 0 | Si | G V PCn | Cn+15 T Cn+16 | P | F <sub>15</sub> | Ğ | f(Y) | f (Y) | f (Y) | f (Y) | | X | 6 | х | 0 | Ri | G V PC <sub>n</sub> | Cn+15 T Cn+16 | Ē | F <sub>15</sub> | Ğ | f(Y) | f (Y) | f (Y) | f (Y) | | X | 7 | Х | 0 | Ri | G V PCn | Cn+15 T Cn+16 | P | F <sub>15</sub> | Ğ | f(Y) | f (Y) | f (Y) | f (Y) | | Х | . 8 | Н | 0 | 1 | 0 | 0 | 0 | F <sub>15</sub> | Ğ | f(Y) | f (Y) | 1 (Y) | f (Y) | | X | 9 | х | Ri∧Si | 1 | 0 | 0 | 0 | F <sub>15</sub> | G | f(Y) | f (Y) | 1 (Y) | f(Y) | | X | Α | Х | Ri∧ Si | Ri V Si | 0 | 0 | 0 | F <sub>15</sub> | G | f(Y) | f (Y) | f(Y) | f(Y) | | X | В | Х | Ri∧ Si | Ri V Si | 0 | 0 | 0 | F <sub>15</sub> | Ğ | f(Y) | f (Y) | f(Y) | f(Y) | | X | С | Х | Ri A Si | 1 | 0 | 0 | 0 | F <sub>15</sub> | Ğ | f(Y) | f(Y) | f(Y) | f(Y) | | X | D | X | Ri∧Si | 1 | 0 | 0 | 0 | F <sub>15</sub> | Ğ | f(Y) | f (Y) | f(Y) | f (Y) | | X | E | Х | Ri A Si | 1 | 0 | 0 | 0 | F <sub>15</sub> | Ğ | f(Y) | f (Y) | f(Y) | f(Y) | | X | F | х | Ri∧Si | 1 | 0 | 0 | 0 | F <sub>15</sub> | G | f(Y) | f (Y) | f(Y) | f(Y) | | 0 | 0 | L | 0 if Z=L<br>Ri∧Si<br>if Z=H | SinfZ=L<br>RiVSi<br>ifZ=H | G V PCn | C <sub>n+15</sub> ♥ C <sub>n+16</sub> | Ē | F <sub>15</sub> | Ğ | Input | Input | a <sub>o</sub> | O <sub>0</sub> | | 1 | 0 | L | 0 | Si | G V PCn | Cn+15 7 Cn+16 | P | F <sub>15</sub> | G | f(Y) | f (Y) | f (Y) | f (Y) | | 1 | 8 | L | 0 | Si | 0 | 0 | 0 | F <sub>15</sub> | Ğ | f(Y) | f (Y) | f(Y) | 1(Y) | | 2 | 0 | L | 0 if Z=L<br>Ri∧ Si<br>if Z=H | Si if Z=L<br>RiVSi<br>if Z=H | G V PCn | C <sub>n+15</sub> 7 C <sub>n+16</sub> | ₽ | F <sub>15</sub> | G | Input | Input | Q <sub>0</sub> | Q <sub>0</sub> | | 3 | 0 | 니 | (6) | (7) | G V PCn | Cn+15 T Cn+16 | Ē | F <sub>15</sub> | Ğ | f(Y) | f (Y) | f (Y) | f (Y) | | 4 | 0 | 니 | (1) | (2) | G V PCn | Cn+15 T Cn+16 | Ē | F <sub>15</sub> | Ğ | f(Y) | f (Y) | f (Y) | f (Y) | | 4 | 8 | 니 | (1) | (2) | G V PC <sub>n</sub> | Cn+15 T Cn+16 | P | F <sub>15</sub> | Ğ | f(Y) | f(Y) | f(Y) | f(Y) | | 5 | o | L | o | SiifZ=L<br>SiifZ=H | G V PCn | C <sub>n+15</sub> ♥ C <sub>n+18</sub> | P | F <sub>15</sub> if Z=L<br>F <sub>15</sub> ♥ S <sub>15</sub><br>if Z=H | ß | S <sub>15</sub> | Input | Input | S <sub>15</sub> | | 6 | 0 | ١. | OifZ=L<br>Riasi<br>ifZ=H | SiffZ=L<br>RivSi<br>ifZ=H | G V PCn | Cn+15 & Cn+18 | P | F <sub>15</sub> | Ğ | Input | Input | Qo | Q <sub>0</sub> | | 7 | 0 | L | 0 | Si | G V PCn | Cn+15 T Cn+16 | ₱ | F <sub>15</sub> | G | f(Y) | f (Y) | f (Y) | f(Y) | | 8 | 0 | 니 | 0 | Si | (4) | Q <sub>2</sub> | P | O <sub>15</sub> | G | f (Q) | f (Q) | f (Q) | f (Q) | | 9 | 0 | 니 | 0 | | G V PC <sub>n</sub> | Cn+15 T Cn+16 | P | F <sub>15</sub> | G | f (Q) | f (Q) | f (Q) | f (Q) | | 9 | 8 | L | 0 | Si | 0 | 0 | 0 | F <sub>15</sub> | G | f (Q) | f (Q) | f (Q) | f (Q) | | A | 0 | 니 | 0 | Si | (3) | F <sub>2</sub> <b>♦</b> F <sub>1</sub> | ₽ | F <sub>15</sub> | G | (5) | (5) | (5) | (5) | | В | 0 | L | Ri A Si | | GVPCn | (8) | (8) | F <sub>15</sub> | (9) | f(Y) | f (Y) | f (Y) | f(Y) | | С | 0 | L | Ri A Si<br>if Z=L<br>Ri A Si<br>if Z=H | RiVSi<br>ifZ≂L<br>RiVSi<br>ifZ≕H | G V PC <sub>n</sub> | C <sub>n+15</sub> T C <sub>n+16</sub> | Ē | F <sub>15</sub> | Ğ | Sign<br>Compare<br>FF<br>Output | Input | Input | Sign<br>Compare<br>FF<br>Output | | D | 0 | L | Ri∧Ši | Ri V Si | G V PCn | Cn+15 T Cn+16 | (8) | F <sub>15</sub> | (9) | f(Y) | f (Y) | f (Y) | f (Y) | | E | o | L | Ri A Si<br>if Z=L<br>Ri A Si<br>if Z=H | RiVSi<br>if Z=L<br>RiVSi<br>if Z=H | G V PCn | Cn+15 T Cn+16 | Ē | F <sub>15</sub> | G | Sign<br>Compare<br>FF<br>Output | Input | Input | Sign<br>Compare<br>FF<br>Output | | F | 0 | <u>L</u> | Ri∧Si | Rivsi ( | G V PCn | Cn+15 7 Cn+16 | (8) | F <sub>15</sub> | (9) | f(Y) | f (Y) | f (Y) | f (Y) | Continued next page ``` NOTES: ``` ``` 1. If \overline{LSS} is LOW, G_0 = S_0 and G_{1,2,3,\dots}, 15 = 0. If \overline{LSS} is HIGH, G_{0,1,2,3,\dots,15} = 0 V = OR 2. If \overline{LSS} is LOW, P_0=1 and P_{1,\ 2,\ 3,\ \cdots}, 15 = S_{1,\ 2,\ 3,\ \cdots}, 15. If \overline{LSS} is HIGH, P_1=S_1 \Lambda = AND 3. At the most significant slice, C_{n+16} = Q_{15} \, \mathcal{D} \, Q_{14}. At other slices C_{n+16} = G \, V \, PC_n ∇ = Exclusive-OB P = P_{15}P_{14} \dots P_3P_2P_1P_0 4. At the most significant slice, C_{n+18} = F_{15} \nabla F_{14}. At other slices C_{n+18} = G \vee PC_n G = G_{15} V G_{14} P_{15} V G_{13} P_{14} P_{15} V G_{12} P_{13} P_{14} P_{15} 5. Z = \overline{Q}_0 \overline{Q}_1 \overline{Q}_2 \overline{Q}_3 \dots \overline{Q}_{15} \overline{F}_0 \overline{F}_1 \overline{F}_2 \overline{F}_3 \dots \overline{F}_{15} 6. If LSS is LOW, G_0 = 0 and G_{1, 2, 3}, \ldots, 15 = S_{1, 2, 3}, \ldots, 15. If LSS is HIGH, G_{0, 1, 2, 3}, \ldots, 15 = S_{0, 1, 2, 3}, \ldots, 15. 7. If LSS is LOW, P_0 = S_0 and P_{1, 2, 3}, \ldots, 15 = 1. If LSS is HIGH, P_{0, 1, 2, 3}, \ldots, 15 = 1. V G_{11}P_{12}P_{13}P_{14}P_{15}. V G_{11}P_{12}P_{13}P_{14}P_{15} V \dots V G_{1}P_{2}P_{3}P_{4} \dots P_{15} 8. BCD Nibble propagate: PN_1 = (P_{4|+0} + P_{4|+3})(P_{4|+0} + \overline{G}_{4|+2})(\overline{P}_{4|+0} + \overline{G}_{4|+1} + \overline{P}_{4|+2}) BCD Slice propagate: PN_1 = PN_3 PN_2 PN_1 PN_0 9. BCD Nibble generate: \overline{GN}_1 = \overline{G}_{4l+3} \cdot \overline{G}_{4l+0} + \overline{G}_{4l+1} + \overline{P}_{4l+2} \cdot \overline{G}_{4l+0} + \overline{G}_{4l+1} + \overline{G}_{4l+2} \cdot \overline{G}_{4l+2} \cdot \overline{G}_{4l+2} \cdot \overline{G}_{4l+3} + \overline{P}_{4l+2} \cdot \overline{G}_{4l+2} \cdot \overline{G}_{4l+3} + \overline{P}_{4l+2} \cdot \overline{G}_{4l+2} \cdot \overline{G}_{4l+3} + \overline{G}_{4l+3} \overline{G}_{4l f(Y) = \overline{Y}_0 \overline{Y}_1 \overline{Y}_2 \overline{Y}_3 \dots \overline{Y}_{15} ``` $f(Q) = \overline{Q}_0 \overline{Q}_1 \overline{Q}_2 \overline{Q}_3 \dots \overline{Q}_{15}$ L = LOW = 0H = HIGH = 1 Table 6b. IDT49C403 Status Outputs (Byte Mode) | HEX | HEX | | Q <sub>I</sub> | Pı | | P/OVR | | G/I | 4 | | Z (ŌE | Y = L) | | |-------------------------------------------------------------|-------------|---|----------------|---------|------------------|-------------------------------------|-----------------|----------------|-----------------|-------|-------|--------|-------| | 1 <sub>8</sub> 1 <sub>7</sub> 1 <sub>6</sub> 1 <sub>5</sub> | 14 13 12 11 | ı | (i = 0 to 7) | | C <sub>n+7</sub> | MSS/SA | OTHER<br>SLICES | MSS/SA | OTHER<br>SLICES | MS | ISS | LSS | SA | | х | 0 | Н | 0 | 1 | 0 | 0 | 0 | F <sub>7</sub> | G | f (Y) | f (Y) | f(Y) | f (Y) | | X | 1 | х | Ři∧ Si | Ri V Si | G V PCn | Cn+7 T Cn+8 | P | F <sub>7</sub> | Ğ | f(Y) | f (Y) | f (Y) | f (Y) | | × | 2 | х | Ri∧Si | Ri V SI | G V PCn | C <sub>n+7</sub> ♥ C <sub>n+8</sub> | P | F <sub>7</sub> | Ğ | f(Y) | f (Y) | f(Y) | f (Y) | | × | 3 | х | Ri∧ Si | RiVSi | G V PCn | Cn+7 7 Cn+8 | Ρ̈́ | F <sub>7</sub> | Ğ | 1(Y)_ | f (Y) | f (Y) | f (Y) | | X | 4 | х | 0 | Si | G V PCn | C <sub>n+7</sub> | P | F <sub>7</sub> | Ğ | f(Y) | f (Y) | f (Y) | f (Y) | | X | 5 | х | 0 | Si | G V PCn | C <sub>n+7</sub> ♥ C <sub>n+8</sub> | P | F <sub>7</sub> | Ğ | f(Y) | f (Y) | f (Y) | f (Y) | | X | 6 | Х | 0 | Ri | G V PCn | Cn+7 7 Cn+8 | P | F <sub>7</sub> | G | f(Y) | f (Y) | f (Y) | f (Y) | | х | 7 | х | 0 | Ri | G V PCn | Cn+7 7 Cn+8 | P | F <sub>7</sub> | Ğ | f(Y) | f (Y) | f(Y) | f (Y) | | х | 8 | Ξ | 0 | 1 | 0 | 0 | 0 | F | Ğ | f(Y) | f (Y) | f (Y) | f (Y) | | х | 9 | х | Ri∧ Si | 1 | 0 | 0 | 0 | F | Ğ | f(Y)_ | f (Y) | f (Y) | f (Y) | | х | Α | х | Ri A Si | Ri V Si | 0 | 0 | 0 | F | Ğ | f(Y) | f (Y) | f (Y) | f (Y) | | Х | В | х | Ri∧ Si | Ri V Si | 0 | 0 | 0 | F | Ğ | f(Y) | f (Y) | f (Y) | f (Y) | | × | С | х | Ri A Si | 1 | 0 | 0 | 0 | F | G | f(Y) | f (Y) | f (Y) | f (Y) | | X | D | х | Ri∧ Si | 1 | 0 | 0 | 0 | F | G | f(Y) | f (Y) | f (Y) | f (Y) | | X | E | x | Ri A Si | 1 | 0 | 0 | 0 | F | G | f(Y) | f (Y) | f (Y) | f (Y) | | Х | F | Х | Ri∧ Si | 1 | 0 | 0 | 0 | F | G | f(Y) | f (Y) | f (Y) | f (Y) | NOTES: $f(Y) = \overline{Y}_0 \overline{Y}_1 \overline{Y}_2 \overline{Y}_3 \dots \overline{Y}_7$ $\mathbf{1}(\mathbf{Q}) = \overline{\mathbf{Q}}_0 \overline{\mathbf{Q}}_1 \overline{\mathbf{Q}}_2 \overline{\mathbf{Q}}_3 \dots \overline{\mathbf{Q}}_7$ L = LOW = 0H = HIGH = 1 V = OR $\Lambda = AND$ ▼ = Exclusive OR $P = P_7 P_6 \dots P_3 P_2 P_1 P_0$ $G = G_7 \vee G_6 P_7 \vee G_5 P_6 P_7 \vee G_4 P_6 P_6 P_7$ $V G_3 P_4 P_5 P_6 P_7 V \dots V G_1 P_2 P_3 P_4 \dots P_7$ ### ABSOLUTE MAXIMUM RATINGS (1) | | OIL MAXIMON | INAIIIIGS | | | |-------------------|--------------------------------------------|--------------|--------------|------| | SYMBOL | RATING | COMMERCIAL | MILITARY | UNIT | | V <sub>TERM</sub> | Terminal Voltage<br>with Respect to<br>GND | -0.5 to +7.0 | -0.5 to +7.0 | ٧ | | T <sub>A</sub> | Operating<br>Temperature | 0 to +70 | -55 to + 125 | ô | | TBIAS | Temperature<br>Under Bias | -55 to + 125 | -65 to + 135 | ů | | T <sub>STG</sub> | Storage<br>Temperature | -55 to +125 | -65 to +150 | °C | | P <sub>T</sub> | Power Dissipation | 1.5 | 1.5 | w | | lout | DC Output Current | 50 | 50 | mA | #### NOTE: Stresses greater than those listed under ABSOLUTE MAXIMUM RAT-INGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect reliability. ## CAPACITANCE (To = +25°C, f = 10MHz) | SYMBOL | PARAMETER (1) | CONDITIONS | TYP. | UNIT | |--------|--------------------|-----------------------|------|------| | CIN | Input Capacitance | V <sub>IN</sub> = 0V | 10 | рF | | Cout | Output Capacitance | V <sub>OUT</sub> = 0V | 15 | pF | #### NOTE: 1. This parameter is sampled and not 100% tested. # DC ELECTRICAL CHARACTERISTICS $T_A = 0$ °C to +70°C $V_{CC} = 5.0V \pm 5\%$ (Commercial) $T_A = -55^{\circ}\text{C to } + 125^{\circ}\text{C}$ $V_{LC} = 0.2\text{V}$ $V_{CC} = 5.0V \pm 10\%$ (Military) $V_{HC} = V_{CC} - 0.2V$ | SYMBOL | PARAMETER | TEST CO | ONDITIONS (1) | MIN. | TYP.(2) | MAX. | UNI | |-----------------|------------------------------|-----------------------------------------------------------|---------------------------------------|-----------------|-----------------|-----------------|---------------| | ViH | Input HIGH Level (4) | | | 2.0 | | _ | $\overline{}$ | | V <sub>IL</sub> | Input LOW Level (4) | | | | | 0.8 | v | | l <sub>iH</sub> | Input HIGH Current | V <sub>CC</sub> = Max., V <sub>IN</sub> = V <sub>CC</sub> | | | 0.1 | 5 | μA | | l <sub>IL</sub> | Input LOW Current | V <sub>CC</sub> = Max., V <sub>IN</sub> = 0V | | | -0.1 | -5 | μΑ | | | | | I <sub>OH</sub> = -300µA | V <sub>HC</sub> | V <sub>CC</sub> | _ | | | V <sub>OH</sub> | Output HIGH Voltage | $V_{CC} = Min.$<br>$V_{IN} = V_{IH} \text{ or } V_{IL}$ | I <sub>OH</sub> = -6mA MIL. | 2.4 | 4.3 | | v | | | | AN - AN OLA | I <sub>OH</sub> = -8mA COM'L. | 2.4 | 4.3 | _ | | | | | | I <sub>OL</sub> = 300μA | _ | GND | V <sub>LC</sub> | | | V <sub>OL</sub> | Output LOW Voltage | $V_{CC} = Min.$<br>$V_{IN} = V_{IH} \text{ or } V_{II}$ | I <sub>OL</sub> = 12mA MIL. | | 0.3 | 0.5 | v | | | | -II4 -II4 | I <sub>OL</sub> = 16mA COM'L. | - | 0.3 | 0.5 | | | loz | Off State (High Impedance) | V <sub>CC</sub> = Max. | $V_O = 0V$ | - | - | -40 | | | | Output Current | VCC - Wax. | $V_0 = V_{CC}$ (max.) | | _ | 40 | μA | | los | Output Short Circuit Current | $V_{CC} = Min., V_{OUT} = 0V$ (3) | · · · · · · · · · · · · · · · · · · · | -15 | | | m/ | #### NOTES - 1. For conditions shown as max, or min, use appropriate value specified under Electrical Characteristics. - 2. Typical values are at $V_{CC} = 5.0V$ , $+25^{\circ}C$ ambient and maximum loading. - 3. Not more than one output should be shorted at one time. Duration of the short circuit test should not exceed one second. - 4. These input levels provide zero noise immunity and should only be static tested in a noise-free environment. Guaranteed by Design. # DC ELECTRICAL CHARACTERISTICS (Cont'd) $T_A = 0$ °C to +70°C $V_{CC} = 5.0V \pm 5\%$ (Commercial) $V_{CC} = 5.0V \pm 10\%$ (Military) $T_A = -55^{\circ}C \text{ to } + 125^{\circ}C$ $V_{LC} = 0.2V$ $V_{uc} = V_{cc} - 0.2V$ | SYMBOL | PARAMETER | TEST CONDITIONS (1) | | MIN. | TYP. <sup>(2)</sup> | MAX. | UNIT | |--------|--------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|--------|------|---------------------|------|--------------| | Іссан | Quiescent Power Supply Current<br>CP = H (CMOS Inputs) | $\begin{aligned} &V_{CC} = Max. \\ &V_{HC} \leq V_{IN} \ , \ V_{IN} \leq V_{LC} \\ &f_{CP} = 0, \ CP = H \end{aligned}$ | | - | 150 | 250 | mA | | Iccal | Quiescent Power Supply Current<br>CP = L (CMOS Inputs) | $V_{CC} = Max.$ $V_{HC} \le V_{IN}$ , $V_{IN} \le V_{LC}$ $f_{CP} = 0$ , $CP = L$ | | - | 50 | 100 | mA | | Ісст | Quiescent Input Power Supply (5)<br>Current (per Input @ TTL High) | $V_{CC} = Max. V_{IN} = 3.4V, f_{CP} = 0$ | | - | 0.3 | 0.5 | mA/Input | | | D : D : O : | V <sub>CC</sub> = Max. | MIL. | _ | 3.6 | 7.7 | mA/MHz | | ICCD | Dynamic Power Supply Current | $V_{HC} \le V_{IN} \cdot V_{IN} \le V_{LC}$<br>Outputs Open, $\overline{OE} = L$ | COM'L. | - | 3.6 | 5.2 | IIIA) WII 12 | | | | V <sub>CC</sub> = Max., f <sub>CP</sub> = 10MHz<br>Outputs Open, OE = L | MIL. | _ | 136 | 252 | | | | - · · - · · · · · · · · · · · · · · · · | $CP = 50\%$ Duty cycle $V_{HC} \le V_{IN}$ , $V_{IN} \le V_{LC}$ | COM'L. | - | 136 | 227 | mA | | lcc | Total Power Supply Current (6) | V <sub>CC</sub> = Max., f <sub>CP</sub> = 10MHz<br>Outputs Open, $\overline{OE}$ = L | MIL. | - | 150 | 275 | IIIA | | | | CP = 50% Duty cycle<br>$V_{IH} = 3.4V, V_{IL} = 0.4V$ | COM'L. | - | 150 | 250 | | ## NOTES: 5. I<sub>CCT</sub> is derived by measuring the total current with all the inputs tied together at 3.4V, subtracting out I<sub>CCQH</sub>, then dividing by the total number of inputs. 6. Total Supply Current is the sum of the Quiescent current and the Dynamic current (at either CMOS or TTL input levels). For all conditions, the Total Supply Current can be calculated by using the following equation: $$I_{CC} = I_{CCQH} (CD_H) + I_{CCQL} (1 - CD_H) + I_{CCT} (N_T \times D_H) + I_{CCD} (f_{CP})$$ $\begin{array}{l} CD_{H} = \mbox{Clock duty cycle high period.} \\ D_{H} = \mbox{Data duty cycle TTL high period ($V_{\!N}$ = 3.4V).} \\ N_{T} = \mbox{Number of dynamic inputs driven at TTL levels.} \end{array}$ f<sub>CP</sub> = Clock input frequency. ## IDT49C403A GUARANTEED COMMERCIAL AND MILITARY RANGE PERFORMANCE The tables below specify the guaranteed performance of the IDT49C403A over the commercial operating range of 0 to +70°C with V<sub>CC</sub> from 4.75 to 5.25V, and over the military operating range of -55 to +125°C with V<sub>CC</sub> from 4.5 to 5.5V. All data are in nanoseconds, with input switching between 0 and 3V at 1V/ns and measurements made at 1.5V. All outputs have maximum DC load. Table 7. Clock and Write Pulse Characteristics All Functions | | COM'L | MIL. | UNIT | |------------------------------------------|-------|------|------| | Minimum Clock Low Time | 10 | 11 | ns | | Minimum Clock High Time | 10 | 11 | ns | | Minimum Time CP and WE both Low to Write | 10 | 11 | ns | #### NOTE: Guaranteed by Design. Table 8. Enable/Disable Times All Functions | FROM | то | COM'L | BLE<br>MIL. | COM'L | ABLE<br>. MIL. | UNIT | |-----------------|-----|-------|-------------|-------|----------------|------| | ŌĒ <sub>Y</sub> | Υ | 12 | 20 | 10 | 12 | ns | | ŌĒ <sub>B</sub> | DB | 14 | 22 | 12 | 13 | ns | | ŌĒ <sub>A</sub> | DA | 15 | 22 | 13 | 14 | ns | | l <sub>8</sub> | SIO | 23 | 25 | 12 | 13 | ns | | l <sub>B</sub> | QIO | 16 | 24 | 21 | 22 | ns | | 18, 7, 6, 5 | QIO | 17 | 28 | 19 | 22 | ns | | 14, 3, 2, 1, 0 | QIO | 21 | 31 | 19 | 22 | ns | $C_1 = 5.0 pF$ for output disable tests. Measurement is made to a 0.5V change on the output. Table 9. Set-up and Hold Times All Functions #### NOTES: - 1. The internal Y-bus to RAM set-up condition will be met 5ns after valid Y output $(\overline{OE}_Y = 0)$ - 2. The set-up time with respect to CP falling edge is to prevent writing. The set-up time with respect to CP rising edge is to enable writing. - 3. The writing of data is controlled by CP, IEN, and WE; all must be LOW in order to write. The set-up time of B destination address is with respect to the last of these three inputs to go LOW, and the hold time is with respect to the first to go HIGH. - 4. A "-" implies this path does not exist. # IDT49C403A GUARANTEED COMMERCIAL AND MILITARY RANGE PERFORMANCE STANDARD AND INCREMENT (SF-4) /DECREMENT (SF-3) BY ONE OR TWO INSTRUCTIONS | | | | | | | | | | | | | | TO | | | | | | | | | | | | | į | |------------------|----------|--------------------------------------------------|------|----------------|------|--------|------|--------------|-----|--------|------|--------|------|--------------------------------------------------|-------|--------|------|--------|-------|--------|--------|--------|------|--------------|--------|------| | FROM | SLICE | ٧ | , | C <sub>n</sub> | = 18 | ō, i | F | z | | | 4 | ov | R | DA, | DB | WRI | TE | GIO | 0, 15 | 81 | 00 | SIO | 15 | SIO<br>PARIT | Ŷ | UNIT | | | | Com'i. | MII. | Com'l. | MII. | Com'l. | MII. | Com'l. | MH. | Com'i. | MII. | Com'l. | MII. | Com'l. | MII. | Com'l. | MII. | Com'i. | MII. | Com'l. | MR. | Com'l. | MII. | Com'L | MI. | | | A, B Addr | Any | 41 | 48 | 44 | 48 | 44 | 48 | 42 | 45 | 47 | 58 | 47 | 57 | 26 | 33 | - | 1 | | - | 41 | 48 | 40 | 48 | 52 | 56 | ns | | DA, DB | Any | 34 | 38 | 28 | 33 | 28 | 34 | 29 | 31 | 36 | 42 | 34 | 40 | - | - | _ | - | _ | - | 24 | 29 | 27 | 33 | 46 | 50 | ns | | c <sub>n</sub> | Апу | 27 | 35 | 15 | 19 | - | - | 22 | 24 | 26 | 29 | 23 | 28 | - | - | - | - | - | - | 24 | 29 | 26 | 30 | 26 | 30 | ns | | I <sub>8-0</sub> | Any | 38 | 43 | 32 | 34 | 23 | 35 | 48 | 51 | 36 | 38 | 42 | 45 | - | - | 18 | 25 | 24 | 27 | 28 | 38 | 37 | 40 | 41 | 50 | ns | | СР | Any | 43 | 46 | 44 | 48 | 39 | 42 | 39 | 42 | 51 | 55 | 54 | 58 | 20 | 25 | - | - | 26 | 30 | 36 | 39 | 37 | 40 | 41 | 45 | ns | | MSS | Any | 21 | 35 | - | - | 21 | 23 | 38 | 43 | 21 | 25 | 20 | 23 | - | | - | - | - | - | - | - | 20 | 23 | - | | ns | | | $\vdash$ | <del> </del> | | | | 1 | 3.00 | <del> </del> | | 1 | | | 100 | <del> </del> | 33,30 | | . 20 | | | | 100000 | | 100 | 1 | 100.00 | | **MULTIPLY INSTRUCTIONS (SF-0, 2 & 6)** 27 SIO 0, 15 Any | | | | | | | | | | | | TO | | | | | | | | | | | Ĺ | |----------------------|-------|--------|------|--------|------|--------|-----|-------|------|--------|------|--------|------|--------|-----|--------|-----|--------|-------|--------|-----|-----| | FROM | SLICE | Y | | cn | = 16 | ā, | F | Z | | N | | OV | R | DA, I | ЭВ | WRI | TE | QIO | 0, 15 | 811 | 00 | UNI | | | | Com'l. | MII. | Com'l. | | Com't. | MR. | Com1. | MII. | Com'l. | MII. | Com'l. | Mil. | Com'l. | MI. | Com'l. | MI. | Com'l. | MII. | Com'l. | MR. | _ | | A, B Addr | Any | 49 | 58 | 53 | 58 | 53 | 58 | - | - | 56 | 70 | 56 | 68 | 31 | 40 | _ | - | - | 1 | 49 | 58 | ns | | DA, DB | Any | 41 | 46 | 34 | 40 | 34 | 41 | - | - | 43 | 50 | 41 | 48 | - | - | - | - | - | 1 | 29 | 35 | ns | | Cn | Any | 32 | 42 | 18 | 23 | _ | - | _ | - | 31 | 35 | 28 | 34 | _ | - | - | _ | - | - | 29 | 35 | пѕ | | <sup>1</sup> 8-0 | Any | 46 | 52 | 38 | 41 | 28 | 42 | 58 | 61 | 43 | 46 | 50 | 54 | | - | 22 | 30 | 29 | 32 | 34 | 46 | ПŜ | | СР | Any | 52 | 55 | 53 | .58 | 47 | 50 | + | - | 61 | 66 | 65 | 70 | 24 | 30 | | - | 31 | 36 | 43 | 47 | пs | | Z<br>(ŌĒγ⇔<br>low) | Апу | 47 | 48 | | | | | - | _ | - | - | - | - | - | - | - | - | _ | - | - | - | ns | | SIO <sub>O, 15</sub> | Any | 25 | 32 | - | - | - | - | _ | - | _ | - | _ | _ | _ | _ | _ | - | _ | - | - | - | ns | Unsigned Multiply SFO: F=S+Cn If Z=L F=S+R+Cn If Z=H Y15=Cn+16 (MSS) Z=Q0 (LSS) Y=Log F/2 Q=Log Q/2 Two's Complement Multiply SF 2: F=S+Cn if Z=L F=S+R+Cn if Z=H Y15=F15 V OVR (MSS) Z=Q0 (LSS) Y=Log F/2 Q=Log Q/2 Two's Complement Multiply Last Cycle SF 6: F= S+Cn | | Z=L F=S-R-1+Cn | | Z=H Y15=OVR V F15 (MSS) Z=Q0 (LSS) Y=Log F/2 Q=Log Q/2 NOTES: A \* - \* means the delay path does not exist. A \* \* \* \* means the output may be enabled or disabled by the input; refer to function table. This specification is not tested. # IDT49C403A GUARANTEED COMMERCIAL AND MILITARY RANGE PERFORMANCE BCD INSTRUCTIONS (SF-1, 7, 9, B, D & F) | | | | | | | | | | | | | | то | | | | | | | _ | | | | | | | |----------------------|-------|--------|-----|----------------|------|--------|-----|--------|------|--------|------|--------|------|--------|-----|-------|----------|--------|-------|--------|-----|--------|------|-----------------|------|------| | FROM | SLICE | ١ | , | C <sub>n</sub> | = 16 | G, | F | Z | : | 1 | * | ov | R | DA, | DB | WRI | TE | QIC | 0, 15 | SI | 00 | SIO | 15 | 810 | 0, | UNIT | | | | Com'i. | MH. | Com'l. | MH. | Com'l. | MH. | Com'i. | MII. | Com'i. | Mil. | Com'i. | Mil. | Com'i. | MH. | Com'L | Mil. | Com'l. | MR. | Com'i. | MH. | Com'l. | Mil. | PARIT<br>Com'i. | MIL. | | | A, B Addr | Any | 49 | 58 | 53 | 58 | 53 | 58 | 50 | 54 | 56 | 70 | 56 | 68 | 31 | 40 | _ | <u>-</u> | _ | - | 49 | 58 | 48 | 58 | 62 | 67 | пs | | DA, DB | Any | 41 | 46 | 34 | 40 | 34 | 41 | 35 | 37 | 43 | 50 | 41 | 48 | - | - | | - | _ | 1 | 29 | 35 | 32 | 40 | 55 | 64 | ns | | c <sub>n</sub> | Any | 32 | 42 | 18 | 23 | - | - | 26 | 29 | 31 | 35 | 28 | 34 | - | - | - | - | - | - | 29 | 35 | 31 | 36 | 31 | 36 | ns | | <sup>1</sup> 8-0 | Any | 46 | 52 | 38 | 41 | 28 | 42 | 58 | 61 | 43 | 46 | 50 | 54 | - | - | 22 | 30 | 29 | 32 | 34 | 46 | 44 | 48 | 49 | 60 | ns | | CP | Any | 52 | 55 | 53 | 58 | 47 | 50 | 47 | 50 | 61 | 66 | 65 | 70 | 24 | 30 | - | - | 31 | 36 | 43 | 47 | 44 | 48 | 49 | 54 | ns | | SIO <sub>O, 15</sub> | Any | 25 | 32 | ~ | + | | _ | - | - | _ | _ | | - | - | - | - | + | - | | - | - | - | ÷ | - | _ | ns | #### NOTE: Blnary to BCD and multiprecision Binary to BCD instructions only BCD to Binary conversion (SF 1) BCD divide by two (SF 7) Binary to BCD conversion (SF 9) BCD add (SF B) BCD substract (SF F) # SIGN MAGNITUDE TO TWO'S COMPLEMENT CONVERSION (SF-5) | | | | | | | | | | | | TO | | | | | | | | | | | T | |---------------------------------|-------|------------|------|--------|------|--------|------|--------|------|--------|------|--------|------|--------|------|--------|------|--------|-------|--------|-----|------| | FROM | SLICE | ٧ | | | n=16 | ā, | | z | | N | | ov | | DA, | 08 | WRI | TE | QIO | 0, 15 | 810 | 00 | UNIT | | | - | Com'l. | MII. | Com'i. | Mä. | Com'l. | MII. | Com'l. | MII. | Cem'i, | Mil. | Com'l. | MII. | Com'i. | MII. | Com'l. | MII. | Com't. | | Com'i. | MI. | | | A, B Addr | Any | 49 | 58 | 53 | 58 | 53 | 58 | 50 | 54 | 56 | 70 | 56 | 68 | 31 | 40 | - | - | _ | - | 49 | 58 | ns | | DA, DB | Any | 41 | 46 | 34 | 40 | 34 | 41 | 35 | 37 | 43 | 50 | 41 | 48 | - | - | - | - | - | - | 29 | 35 | ns | | C <sub>n</sub> | Any | 32 | 42 | 18 | 23 | - | | - | - | 31 | 35 | 28 | 34 | - | - | - | T | - | - | 29 | 35 | ns | | 18-0 | Any | 46 | 52 | 38 | 41 | 28 | 42 | 58 | 61 | 43 | 46 | 50 | 54 | - | - | 22 | 30 | 29 | 32 | 34 | 46 | ns | | CP | Any | 52 | 55 | 53 . | 58 | 47 | 50 | 47 | 50 | 61 | 66 | 65 | 70 | 24 | 30 | - | _ | 31 | 36 | 43 | 47 | ns | | Z<br>(OE <sub>Y</sub> =<br>low) | Any | | | | | | | - | - | _ | - | _ | _ | - | - | - | - | - | - | - | _ | ns | | SIO <sub>0, 15</sub> | Any | <b>2</b> 5 | 32 | _ | - | _ | - | _ | - | - | - | - | - | _ | - | - | | - | - | - | - | ns | Y=F Q=Q N=F15; Z=L N=F15 17-S15; Z=H NOTES: 1. A "-" means the delay path does not exist. 2. An "s" means the output may be enabled or disabled by the input; refer to function table. 3. This specification is not tested. # IDT49C403A GUARANTEED COMMERCIAL AND MILITARY RANGE PERFORMANCE **DIVIDE INSTRUCTIONS (SF-A, C & E)** | | | | | | | | | | | | TO | | | | | | | | | | | 1 | |---------------------------------|-------|--------|-----|--------|------|--------|-----|--------|------|--------|------|--------|------|--------|-----|--------|------|--------|-------|--------|-----|------| | FROM | SLICE | Y | | Cn | = 16 | ā, i | 5 | z | | N | | ov | R | DA, E | В | WRI | ΪĒ | 010 | ), 15 | SIC | 15 | UNIT | | | | Com'l. | MR. | Com'l. | MI. | Com'i. | MI. | Com'l. | MII. | Com'l. | M#I. | Com'l. | MII. | Com'l. | MR. | Com'i. | MII. | Com'l. | MR. | Com'l. | MH. | - | | A, B Addr | Any | 49 | 58 | 53 | 58 | 53 | 58 | 50 | 54 | 56 | 70 | 56 | 68 | 31 | 40 | - | I | - | | 49 | 58 | ns | | DA, DB | Any | 41 | 46 | 34 | 40 | 34 | 41 | 35 | 37 | 43 | 50 | 41 | 48 | - | _ | - | - | - | - | 32 | 40 | ns | | c <sub>n</sub> | Any | 32 | 42 | 18 | 23 | _ | _ | 26 | 29 | 31 | 35 | 28 | 34 | - | - | - | - | - | 7 | 31 | 36 | ns | | 18-0 | Any | 46 | 52 | 38 | 41 | 28 | 42 | 58 | 61 | 43 | 46 | 50 | 54 | - | | 22 | 30 | 29 | 32 | 44 | 48 | ns | | СР | Any | 52 | 55 | 53 | 58 | 47 | 50 | 47 | 50 | 61 | 66 | 65 | 70 | 24 | 30 | - | - | 31 | 36 | 44 | 48 | ns | | Z<br>(OE <sub>V</sub> =<br>low) | Any | | | | | | | - | - | _ | - | _ | - | - | - | - | - | _ | | - | - | ns | | SIO (1, 15 | Any | 25 | 32 | - | - | - | - | - | - | - | - | - | - | _ | - | - | - | - | | - | - | ns | #### NOTES: - 1. Only 1st divide and normalization - 2. Only two's complement divide and two's complement divide correction Double Length Normalize and First Divide Op SFA: F=S+Cn N=F15 (MSS) SIO15=F15 TO R15 (MSS) Cn+18=F15 TO F14 (MSS) OVR=F2 TO F1 (MSS) Z=G0 G1 G2 G3 ... Q15 F0 F1 F2 F3 ... F15 Two's Complement Divide SFC: F=S+R+Cn II Z=L F=S-R-1+Cn II Z=H SI015=F15 \Pi R15 (MSS) Z=F15 \Pi R15 (MSS) from previous cycle Y=Log 2F Q=Log 2O Two's Complement DMde Correction and Remainde SFE: S=C<sub>0</sub> If Z=L S-R-1+C<sub>0</sub> If Z=H Z=F15 **?** R15 (MSS) from previous cycle Q=Log 2Q # SINGLE LENGTH NORMALIZATION (SF-8) | | | | | | | | | | | | TO | | | | | | | | | | | ] | |------------------|-------|--------|------|----|------|--------|------|--------|------|--------|------|--------|-----|--------|------|--------|-----|--------|------|-------|-----|-------| | FROM | SLICE | Y | | C, | = 16 | ā, i | P | z | | N | | ov: | R | DA, I | ЭВ | WRIT | ΤĒ | 0100 | , 15 | 810 | 15 | UNITS | | | | Com'i. | MIL. | | | Com'l. | MII. | Com'l. | MII. | Com'l. | MII. | Com'l. | MH. | Com'i. | Mtt. | Com'l. | MI. | Com'l. | MII. | Com1. | MI. | | | A, B Addr | Any | 49 | 58 | 53 | 58 | 53 | 58 | - | - | - | T | _ | - | 31 | 40 | - | 1 | _ | 1 | 48 | 58 | ns | | DA, DB | Any | 41 | 46 | 34 | 40 | 34 | 41 | - | - | _ | - | - | _ | - | - | | 1 | + | 1 | 32 | 40 | ns | | c <sub>n</sub> | Any | 32 | 42 | 18 | 23 | - | - | -+// | - | - | - | - | - | - | - | | - | - | 4 | 31 | 36 | ns | | 1 <sub>8-0</sub> | Any | 46 | 52 | 38 | 41 | 28 | 42 | 58 | 61 | 43 | 46 | 50 | 54 | _ | - | 22 | 30 | 29 | 32 | 44 | 48 | ns | | ÇP | Arty | 52 | 55 | 53 | 58 | 47 | 50 | 47 | 50 | 61 | 66 | 65 | 70 | 24 | 30 | - | - | 31 | 36 | 44 | 48 | ns | | SIO 6, 15 | Any | 25 | 32 | - | - | - | - | - | - | - | - | - | - | - | - | - | - | - | 1 | _ | _ | ns | NOTES: - TES: $^-$ means the delay path does not exist. A $^-$ means the output may be enabled or disabled by the input; refer to function table This specification is not tested. ## **IDT49C403 GUARANTEED COMMERCIAL AND** MILITARY RANGE PERFORMANCE The tables below specify the guaranteed performance of the IDT49C403 over the commercial operating range of 0 to 70 °C with $V_{\infty}$ from 4.75 to 5.25V, and over the military operating range of -55 to + 125 °C with $V_{\rm CC}$ from 4.5 to 5.5V. All data are in nanoseconds, with input switching between 0 and 3V at 1V/ns and measurements made at 1.5V. All outputs have maximum DC load. Table 10. Clock and Write Pulse Characteristics All Functions | | COM'L. | MIL. | UNIT | |------------------------------------------|--------|------|------| | Minimum Clock Low Time | 12 | 13 | ns | | Minimum Clock High Time | 12 | 13 | ns | | Minimum Time CP and WE both Low to Write | 12 | 13 | ns | NOTE: Guaranteed by design. Table 11. Enable/Disable Times All Functions | FROM | то | ENAI<br>COM'L. | BLE<br>MIL. | DIS. | ABLE<br>. MIL. | UNIT | |-----------------|-----|----------------|-------------|------|----------------|------| | ŌĒ <sub>Y</sub> | Y | 15 | 24 | 12 | 14 | ns | | ŌĒ <sub>B</sub> | DB | 17 | 26 | 15 | 16 | ns | | OE <sub>A</sub> | DA | 18 | 26 | 16 | 17 | ns | | lg | SIO | 28 | 30 | 15 | 16 | ns | | la | QIO | 20 | 29 | 25 | 27 | กร | | 18, 7, 6, 5 | QIO | 21 | 34 | 22 | 26 | ns | | l4. 3. 2. 1. 0 | QIO | 25 | 37 | 22 | 26 | ns | $C_{\perp} = 5.0 pF$ for output disable tests. Measurement is made to a 0.5V change on the output. Table 12. Set-up and Hold Times All Functions #### NOTES: - 1. The internal Y-bus to RAM set-up condition will be met 5ns after valid Y output ( $\overline{OE}_{Y}=0$ ) - The set-up time with respect to CP falling edge is to prevent writing. The set-up time with respect to CP rising edge is to enable writing. - The writing of data is controlled by CP, $\overline{\text{IEN}}$ , and $\overline{\text{WE}}$ ; all must be LOW in order to write. The set-up time of 8 destination address is with respect to the last of these three inputs to go LOW, and the hold time is with respect to the first to go HIGH. - 4. A "-" implies this path does not exist. # IDT49C403 GUARANTEED MILITARY AND COMMERCIAL RANGE PERFORMANCE STANDARD AND INCREMENT (SF-4) /DECREMENT (SF-3) BY ONE OR TWO INSTRUCTIONS | | | | | | | | | | | | | | то | | | | | | | | | | | | | 1 | |----------------------|-------|--------|------|----------------|-----|--------|------|--------|-----|--------|------|--------|-----|--------|------|--------|------|--------|-------|--------|------|--------|------|-------------|--------|----------| | FROM | SLICE | V | | C <sub>n</sub> | =16 | ā, i | 5 | Z | | • | | ov | R | DA, | DВ | WRI | TE | QIO | 0, 15 | 84 | 00 | 840 | 15 | SIO<br>PARI | r<br>P | UNIT | | | | Com'l. | MIL. | Com'l. | MH. | Com'l. | MII. | Com'l. | MB. | Com'l. | MII. | Com'l. | MN. | Com'i. | MHL. | Com'i. | MII. | Com'l. | MH. | Com'l. | MII. | Com'l. | MII. | Com'l. | MII. | <u> </u> | | A, B Addr | Any | 49 | 53 | 53 | 57 | 53 | 57 | 50 | 54 | 56 | 65 | 56 | 64 | 32 | 37 | - | - | - | + | 50 | 54 | 48 | 54 | 63 | 67 | ns | | DA, DB | Any | 40 | 43 | 34 | 36 | 34 | 38 | 35 | 37 | 43 | 47 | 40 | 45 | _ | | _ | - | _ | 1 | 29 | 33 | 33 | 37 | 55 | 59 | ns | | c <sub>n</sub> | Any | 33 | 39 | 18 | 21 | - | - | 27 | 29 | 32 | 34 | 28 | 30 | - | - | - | | - | | 29 | 33 | 32 | 34 | 32 | 34 | ns | | 1 <sub>8-0</sub> | Any | 46 | 49 | 39 | 41 | 39 | 41 | 56 | 59 | 43 | 46 | 51 | 54 | - | + | 21 | 28 | 29 | 32 | 34 | 43 | 45 | 47 | 49 | 56 | ns | | СР | Any | 51 | 55 | 53 | 56 | 47 | 51 | 47 | 51 | 62 | 66 | 65 | 70 | 24 | 28 | - | - | 32 | 34 | 43 | 46 | 45 | 47 | 49 | 53 | ns | | MSS | Any | 26 | 39 | - | | 26 | 28 | 46 | 50 | 26 | 28 | 24 | 26 | - | | - | | - | 1 | - | | 24 | 26 | - | _ | ns | | SIO <sub>0, 15</sub> | Any | 25 | 30 | - | - | - | - | 20 | 21 | - | - | - | - | - | 1 | - | - | - | 1 | - | | 23 | 26 | 19 | 23 | ns | **MULTIPLY INSTRUCTIONS (SF-0, 2 & 6)** | | | | | _ | | | | | | | TO | | | | | | | | | | | 1 | |----------------------|-------|-------|------|--------|------|--------|------|--------|-----|--------|------|--------|------|--------|------|--------|-----------------------|--------|-------|--------|------|------| | FROM | SLICE | , v | | cn | = 16 | ā, i | | Z | | N | 1 | ov | | DA, I | | WAI | | | 0, 15 | 810 | - | UNIT | | | | Com'L | MII. | Com'l. | Mil. | Com'l. | MII. | Com'l. | MI. | Com'l. | MII. | Com'l. | MII. | Com'i. | MII. | Com'l. | MII. | Com'i. | MR. | Com'l. | MIR. | ╁ | | A, B Addr | Any | 59 | 64 | 64 | 68 | 64 | 68 | _<br>: | - | 67 | 78 | 67 | 77 | 38 | 44 | _ | 9 | _ | - | 60 | 65 | пѕ | | DA, DB | Any | 48 | 52 | 41 | 43 | 41 | 46 | _ | _ | 52 | 56 | 48 | 54 | - | _ | - | 1 | - | - | 35 | 40 | ns | | c <sub>n</sub> | Any | 40 | 47 | 22 | 25 | _ | 7 | - | | 38 | 41 | 34 | 36 | - | _ | - | | - | - | 35 | 40 | 1 | | 18-0 | Any | 55 | 59 | 47 | 49 | 47 | 49 | 67 | 71 | 52 | 55 | 61 | 65 | - | - | 25 | 34 | 35 | 38 | 41 | 52 | ns | | СР | Any | 61 | 66 | 64 | 67 | 58 | 61 | - | _ | 74 | 79 | 78 | 84 | 29 | 34 | _ | | 38 | 41 | 52 | 55 | ns | | Z<br>(ŌĒγ⇔<br>low) | Any | 65 | 70 | | | | | _ | | _ | - | - | | _ | - | _ | 1 | - | - | - | - | ns | | SIO <sub>0, 15</sub> | Any | 30 | 36 | _ | - | _ | | _ | - | - | - | _ | - | _ | - | _ | ()<br>() <del>-</del> | - | - | - | - | ns | Unsigned Multiply Unsigned Multiply SF 0: F = S + Cn | I Z = L F = S + R + Cn | I Z = H Y15 = Cn + 16 (MSS) Z = Q0 (LSS) Y = Log F/2 Q = Log Q/2 Two's Complement Multiply SF 2: F=S+Cn if Z=L F=S+R+Cn if Z=H Y15=F15 V OVR (MSS) Z=Q0 (LSS) Y=Log F/2 Q=Log Q/2 Two's Complement Multiply Last Cycle SF 6: F = S + C<sub>1</sub> if Z = L F = S - R - 1 + C<sub>1</sub> if Z = H Y15 = OVR V F15 (MSS) Z=Q0 (LSS) Y=Log F/2 Q=Log Q/2 NOTES: 1. A " - " means the delay path does not exist. 2. An "\*" means the output may be enabled or disabled by the input; refer to function table. 3. This specification is not tested. # **IDT49C403 GUARANTEED MILITARY AND COMMERCIAL RANGE PERFORMANCE** BCD INSTRUCTIONS (SF-1, 7, 9, B, D & F) | | | | | | | | | | | | | | то | | | | | | | | | | | | | T | |----------------------|----------|--------|------|----------------|------|--------|------|--------|-----|--------|-----|--------|------|--------|------|--------|------|--------|-------|--------|-----|-------|------|----------------|------------|------| | FROM | SLICE | ١ ١ | • | c <sub>n</sub> | = 16 | Ğ, | P | Z | ! | Ī - | N | ov | R | DA, | DB | WR | ITE | QIO | 0, 15 | 81 | 00 | SIC | 15 | 810 | 20, | UNIT | | | <u> </u> | Com'l. | MII. | Com'l. | MII. | Com'l. | MII. | Com'i. | MH. | Com'l. | MH. | Com'l. | MII. | Com'l. | Mil. | Com'l. | MII. | Com'l. | MB. | Com'l. | MH. | Com1. | MII. | PARI<br>Com'l. | TY<br>Mil. | | | A, B Addr | Any | 59 | 64 | 64 | 68 | 64 | 68 | 60 | 65 | 67 | 78 | 67 | 77 | 38 | 44 | - | - | _ | - | 60 | 65 | 58 | 65 | 76 | 80 | ns | | DA, DB | Any | 48 | 52 | 41 | 43 | 41 | 46 | 42 | 44 | 52 | 56 | 48 | 54 | - | - | - | - | - | - | 35 | 40 | 40 | 44 | 66 | 71 | ns | | cn | Any | 40 | 47 | 22 | 25 | _ | - | 32 | 35 | 38 | 41 | 34 | 36 | - | - | - | - | - | i i | 35 | 40 | 38 | 41 | 38 | 41 | ns | | 1 <sub>8-0</sub> | Any . | 55 | 59 | 47 | 49 | 47 | 49 | 67 | 61 | 52 | 55 | 61 | 65 | - | _ | 25 | 34 | 35 | 38 | 41 | 52 | 54 | 56 | 59 | 67 | ns | | CP | Any | 61 | 66 | 64 | 67 | 56 | 61 | 56 | 61 | 74 | 79 | 78 | 84 | 29 | 34 | _ | T | 38 | 41 | 52 | 55 | 54 | 56 | 59 | 64 | ns | | SIO <sub>O, 15</sub> | Апу | 30 | 36 | _ | - | - | _ | - | _ | - | - | - | 1 | - | - | _ | | - | | - | Т | - | + | _ | | ns | Binary to BCD and multiprecision Binary to BCD instructions only BCD to Binary conversion (SF1) BCD divide by two (SF7) Binary to BCD conversion (SF9) BCD add (SFB) BCD substract (SFF) # SIGN MAGNITUDE TO TWO'S COMPLEMENT CONVERSION (SF-5) | i | L | | | | | | | | | | TO | | | | | | | | | | | $\top$ | |----------------------|-------|-------------|------|----|----------------|-------------|-----------|-------------|-----|--------|------|--------|-----------|-----|-----------|--------------|-----|--------|-------|-----|----|--------| | FROM | SLICE | Y<br>Com'l. | MII. | | n = 16<br>Mil. | Ğ,<br>Com'l | P<br>Mil. | Z<br>Com'l. | MI. | Com'i, | MII. | Com'l. | R<br>Mil. | DA, | DB<br>MIL | WRI<br>Com'L | | | 0, 15 | 810 | - | UNIT | | A, B Addr | Any | 59 | 64 | 64 | 68 | 64 | 68 | 60 | 65 | 67 | 78 | 67 | 77 | 38 | 44 | - | MK. | Com'i. | MR. | 60 | | ns | | DA, DB | Any | 48 | 52 | 41 | 43 | 41 | 46 | 42 | 44 | 52 | 56 | 48 | 54 | - | - | _ | - | - | | 35 | 40 | ns | | c <sub>n</sub> | Any | 40 | 47 | 22 | 25 | _ | - | _ | - | 38 | 41 | 34 | 36 | - | - | _ | - | - | | 35 | 40 | ns | | 18-0 | Any | 55 | 59 | 47 | 49 | 47 | 49 | 67 | 71 | 52 | 55 | 61 | 65 | - | - | 25 | 34 | 35 | 38 | 41 | 52 | пѕ | | СР | Any | 61 | 66 | 64 | 67 | 56 | 61 | 56 | 61 | 74 | 79 | 78 | 84 | 29 | 34 | - | | 38 | 41 | 52 | 55 | ns | | Z<br>(OEy=<br>low) | Any | | | | | | | - | 1 | _ | _ | _ | + | - | - | - | _ | _ | - | - | - | ns | | SIO <sub>0. 15</sub> | Any | 30 | 36 | - | - | - | - | - | | - | _ | - | | - | - | - | 7 | _ | | _ | | ns | SF 5: F=S+Cn | | | Z=L F=S+Cn | | | Z=H Y15=S15 | | | | F15 (MSS) Z=S15 (MSS) V=C Q=Q N=F15; Z=L N=F15 **7** S15; Z=H NOTES: 1. A \* --" means the delay path does not exist. 2. An \*\*\* means the output may be enabled or disabled by the input; refer to function table. 3. This specification is not tested. # IDT49C403 GUARANTEED MILITARY AND COMMERCIAL RANGE PERFORMANCE DIVIDE INSTRUCTIONS (SF-A, C & E) | | | | | | | | | | | | то | | | | | | | | | | | ] | |---------------------------------|-------|--------|------|--------|------|--------|----|--------|------|--------|----|--------------|-----------|-------|-----------|--------|----|----------------|----------------|---------------|----------|----------| | FROM | SLICE | Y | | | = 16 | Ğ, | | Z | | N | | OV<br>Com'i. | R<br>MII. | DA, I | DB<br>MIL | WRI | | QIO,<br>Com'l. | 0, 15<br>MH | Sid<br>Com'l. | 15<br>MI | UNIT | | | | Com'l. | MII. | Com'l. | MD. | Com'l. | 1 | Com'l. | MII. | Com'l. | | | - 888 | | 4.5 | Contri | - | COIII II | | | | $\vdash$ | | A, B Addr | Any | 59 | 64 | 64 | 68 | 64 | 68 | 60 | 65 | 67 | 78 | 67 | 77 | 38 | 44 | | | - | - | 58 | 65 | ns | | DA, DB | Any | 48 | 52 | 41 | 43 | 41 | 46 | 42 | 44 | 52 | 56 | 48 | 54 | - | 1 | - | ÷ | - | * <del>-</del> | 40 | 44 | ns | | c <sub>n</sub> | Any | 40 | 47 | 22 | 25 | _ | | 32 | 35 | 38 | 41 | 34 | 36 | - | = | - | - | - | - | 38 | 41 | ns | | <sup>†</sup> 8-0 | Any | 55 | 59 | 47 | 49 | 47 | 49 | 67 | 71 | 52 | 55 | 61 | 65 | - | - | 25 | 34 | 35 | 38 | 54 | 56 | ns | | СР | Any | 61 | 66 | 64 | 67 | 56 | 61 | 56 | 61 | 74 | 79 | 78 | 84 | 29 | 34 | - | - | 38 | 41 | 54 | 56 | ns | | Z<br>(OE <sub>Y</sub> =<br>low) | Any | | | | | | | _ | _ | _ | 4 | - | - | | - | _ | - | _ | | - | - | ns | | SIO <sub>0, 15</sub> | Any | 30 | 36 | - | - | _ | | - | - | _ | | _ | - | - | - | - | - | _ | - | - | _ | ns | # NOTES: - Only 1st divide and normalization - 2. Only two's complement divide and two's complement divide correction Double Length Normalize and First Divide Op SFA: F=S+C<sub>n</sub> N=F15 (MSS) SIO15=F15 \( \phi\) P15 (MSS) C<sub>n</sub>+16=F15 \( \phi\) F14 (MSS) OVR=F2 \( \phi\) F14 (MSS) Z=00 \( \text{ TO 2 } \text{ C3 } \dots \) OT5 F0 F1 F2 F3 \( \dots \) F15 Y=Log 2F Q=Log 2O Two's Complement Divide 1wo's Complement Divide SFC: F=S+R+C<sub>R</sub> If Z=L F=S-R-1+C<sub>R</sub> If Z=H SI015=F15 \$\frac{1}{2}\$ F15 (MSS) Z=F15 \$\frac{1}{2}\$ F15 (MSS) from previous cycle Y=Log 2F Q=Log 2O Two's Complement Divide Correction and Remainde SFE: S=C<sub>D</sub> if Z=L S-R-1+C<sub>D</sub> if Z=H Z=F15 \$\sqrt{6}\$ H15 (MSS) from previous cycle Y=F Q=Log 2Q SINGLE LENGTH NORMALIZATION (SF-8) | | | | | | | | | | | | то | | | | | | | | | | | | |----------------|-------|--------|------|----------------|------|--------|-----|--------|-----|--------|------|--------|------|--------|------|--------|------|------------------|------|--------|-----------------|------| | FROM | SLICE | γ | | C <sub>r</sub> | = 16 | ā, | P | Z | | N | | ov | R | DA, E | В | WRI | ΤĒ | QIO <sub>0</sub> | , 15 | SK | <sup>2</sup> 15 | UNIT | | | | Com'l. | MII. | Com'l. | MII. | Com'i. | MR. | Com'l. | MX. | Com'l. | MII. | Com'l. | Mil. | Com'l. | MII. | Com'l. | MII. | Com'l. | MII. | Com'l. | MI. | ↓ | | A, B Addir | Any | 59 | 64 | 64 | 68 | 64 | 68 | - | - | - | 1 | - | | 38 | 44 | - | - | - | + | .58 | 65 | ns | | DA, DB | Any | 48 | 52 | 41 | 43 | 41 | 46 | - | - | - | | - | - | - | 1 | - | - | - | - | 40 | 44 | ns | | c <sub>n</sub> | Any | 40 | 47 | 22 | 25 | _ | + | - | = | - | 1 | - | = | - | - | 1 | ÷. | | | 38 | 41 | ns | | 18-0 | Any | 55 | 59 | 47 | 49 | 47 | 49 | 67 | 71 | 52 | 55 | 61 | 65 | - | | 25 | 34 | 35 | 38 | 54 | 56 | ns | | СР | Any | 61 | 66 | 64 | 67 | 56 | 61 | -56 | 61 | 74 | 79 | 78 | 84 | 29 | 34 | - | - | 38 | 41 | 54 | 56 | ns. | | SIO 0, 15 | Any | 30 | 36 | - | - | - | - | - | + | _ | - | _ | - | - | - | _ | - | _ | - | - | _ | ns | NOTES: 1. A - - means the delay path does not exist. 2. An \*\* means the output may be enabled or disabled by the input; refer to function table. 3. This specification is not tested but is guaranteed by correlation to the Standard Function Table. Figure 11. IDT49C403 SPC Timing Waveforms ## IDT49C403/A SPC AC TIMING | PARAMETERS | TEST CONDITIONS | MIN. | MAX. | UNIT | |------------------------|-------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------|-------------------------------------------------------------| | SCLK TO SDO | | 3 | | ns | | C/D to SDO | | 3 | | ns | | C/D to SCLK | | 5 | | ns | | CLK to C/D | | <u> </u> | | ns | | SDI to SCLK | | | | | | C/D to SCLK | $R_L = 500\Omega$<br>$C_c = 50pF$ | | | ns | | CLK to SCLK | -L -sp. | | | ns | | SDI to SCLK | | <del></del> | | ns | | Pulse Width SCLK | | <del></del> | | nis | | SCLK Period | | | | ns | | Execution, C/D to SCLK | | | | ns | | | SCLK TO SDO C/D to SDO C/D to SCLK CLK to C/D SDI to SCLK C/D to SCLK CLK to SCLK CLK to SCLK Pulse Width SCLK SCLK Period | SCLK TO SDO C/D to SDO C/D to SCLK CLK to C/D SDI to SCLK C/D to SCLK C/D to SCLK CLK to SCLK SDI to SCLK Pulse Width SCLK SCLK Period | SCLK TO SDO 3 3 3 5 5 5 5 5 5 5 | SCLK TO SDO 3 15 3 50 50 50 50 50 50 50 | # **CMOS TESTING CONSIDERATIONS** There are certain testing considerations which must be taken into account when testing high-speed CMOS devices in an automatic environment. These are: - Proper decoupling at the test head is necessary. Placement of the capacitor set and the value of capacitors used is critical in reducing the potential erroneous failures resulting from large Vcc current changes. Capacitor lead length must be short and as close to the DUT power pins as possible. - All input pins should be connected to a voltage potential during testing. If left floating, the device may begin to oscillate causing improper device operation and possible latchup. - 3) Definition of input levels is very important. Since many inputs may change coincidentally, significant noise at the device pins may cause the V<sub>II</sub> and V<sub>IH</sub> levels not to be met until the noise has settled. To allow for this testing/board induced noise, IDT recommends using V<sub>II</sub> ≤ 0V and V<sub>IH</sub> ≥ 3V for AC tests. - 4) Device grounding is extremely important for proper device testing. The use of multi-layer performance boards with radial decoupling between power and ground planes is required. The ground plane must be sustained from the performance board to the DUT interface board. All unused interconnect pins must be properly connected to the ground pin. Heavy gauge stranded wire should be used for power wiring and twisted pairs are recommended to minimize inductance. ## IDT49C403 INPUT/OUTPUT INTERFACE CIRCUITRY Figure 12. Input Structure (All Inputs) Figure 13. Output Structure (All Outputs) # **AC TEST CONDITIONS** | GND to 3.0V | |---------------| | 1V/ns | | 1.5V | | 1.5V | | See Figure 15 | | | Figure 14. Open Drain Structure ## **SWITCHING WAVEFORMS** ## **TEST LOAD CIRCUIT** Figure 15. Test Load Circuit | TEST | SWITCH | |-----------------------------------------|--------| | Open Drain<br>Disable Low<br>Enable Low | Closed | | All Other Outputs | Open | ## DEFINITIONS $C_L$ = Load capacitance includes jig and probe capacitance $R_T$ = Termination resistance: should be equal to $Z_{OUT}$ of the pulse generator # **ORDERING INFORMATION**