# **TMC3211** # Integer Divider 32-Bit, 20 MOPS The TMC3211 is a fast monolithic two's complement integer divider which can divide a 32-bit dividend by a 16-bit divisor to produce a 32-bit quotient, with a maximum pipelined throughput of 20 MOPS (Million Operations Per Second). Data is input on separate busses, and quotients are available on a 32-bit output bus with synchronous three-state enable. All data inputs and outputs are registered and TTL compatible. All input and output signal timing is referenced to the rising edge of Clock. The TMC3211 has a single system clock and separate load enable controls for the dividend and divisor registers. This allows the device to be used in applications requiring division by a constant. Underflow automatically produces the expected zero quotient, and dividing by zero sets a divide-by-zero output flag. The internal architecture of the TMC3211 allows all 32-bit two's complement integer dividends and nonzero 16-bit two's complement integer divisors, without prenormalization. The output quotient format is 32-bit integer. The TMC3211 makes a full-precision, full-speed divide function available to designers of Workstations, Image Processors, and Radar Systems who need to perform perspective extractions, matrix operations, range scaling, and other complex functions. ## **Features** - 32-Bit By 16-Bit Fixed-Point Integer Division With 32-Bit Quotient - 20MHz Clock Rate And Pipelined Throughput Rate - Three-Bus I/O Architecture Allows Unrestricted Throughput - Easy System Interfacing - Status Flags For Divide-By-Zero And Inexact Result - · All Inputs And Outputs TTL Compatible - Low Power CMOS Technology - Available In A 120 Pin Plastic Pin Grid Array Package # **Applications** - · Graphics And Image Processors - Matrix Operations And Geometric Transforms - Perspective Extraction - Radar Signal Processing - Range Scaling # **Functional Block Diagram** 95 # Pin Assignments ## 120-Pin Plastic Pin Grid Array - H5 Package | Pin | Name | Pin | Name | Pin | Name | Pin | Name | |------------|-----------------|-----|-----------------|-----|-----------------|------------|-----------------| | C3 | V <sub>DD</sub> | L3 | GND | L11 | V <sub>DD</sub> | C11 | GND | | B2 | Y <sub>15</sub> | M2 | X <sub>0</sub> | M12 | GND | B12 | Q <sub>7</sub> | | <b>B</b> 1 | YEN | N2 | x <sub>1</sub> | M13 | 0 <sub>25</sub> | A12 | a <sub>6</sub> | | D3 | GND | L4 | v <sub>DD</sub> | K11 | V <sub>DD</sub> | C10 | Q <sub>5</sub> | | C2 | v <sub>DD</sub> | M3 | X <sub>2</sub> | L12 | GND | B11 | 04 | | C1 | Y <sub>16</sub> | N3 | x <sub>3</sub> | L13 | 024 | A11 | 03 | | D2 | Y <sub>17</sub> | M4 | X <sub>4</sub> | K12 | 023 | B10 | 02 | | E3 | GND | L5 | GND | J11 | ν <sub>DD</sub> | C9 | Ω <sub>1</sub> | | D1 | Y <sub>18</sub> | N4 | X <sub>5</sub> | K13 | 022 | A10 | 0 <sub>0</sub> | | E2 | Y <sub>19</sub> | M5 | х <sub>6</sub> | J12 | Q <sub>21</sub> | 89 | DZ | | E1 | Y <sub>20</sub> | N5 | X <sub>7</sub> | J13 | 020 | A9 | REM | | F3 | v <sub>DD</sub> | L6 | X <sub>8</sub> | H11 | GND | C8 | YO | | F2 | Y <sub>21</sub> | M6 | Χg | H12 | a <sub>19</sub> | B8 | Υ1 | | F1 | Y <sub>22</sub> | N6 | x <sub>10</sub> | H13 | 018 | A8 | Y <sub>2</sub> | | G2 | GND | M7 | x <sub>11</sub> | G12 | V <sub>DD</sub> | B7 | Y3 | | G3 | v <sub>DD</sub> | L7 | ν <sub>DD</sub> | G11 | a <sub>17</sub> | C7 | Y4 | | G1 | Y <sub>23</sub> | N7 | x <sub>12</sub> | G13 | a <sub>16</sub> | <b>A</b> 7 | Y <sub>5</sub> | | H1 | Y <sub>24</sub> | N8 | X <sub>13</sub> | F13 | a <sub>15</sub> | A6 | Y <sub>6</sub> | | H2 | Y <sub>25</sub> | M8 | X <sub>14</sub> | F12 | 014 | B6 | Y <sub>7</sub> | | H3 | GND | LB | X <sub>15</sub> | F11 | v <sub>DD</sub> | C6 | Y <sub>8</sub> | | J1 | Y <sub>26</sub> | N9 | XEN | E13 | a <sub>13</sub> | <b>A</b> 5 | Yg | | J2 | Y <sub>27</sub> | M9 | CLK | E12 | a <sub>12</sub> | B5 | Y <sub>10</sub> | | K1 | Y <sub>28</sub> | N10 | ŌĒŪ | D13 | 011 | A4 | V <sub>DD</sub> | | J3 | V <sub>DO</sub> | L9 | 031 | E11 | GND | C5 | Y <sub>11</sub> | | K2 | Y <sub>29</sub> | M10 | a <sub>30</sub> | D12 | a <sub>10</sub> | B4 | Y <sub>12</sub> | | L1 | Y <sub>30</sub> | N11 | 029 | C13 | O <sub>g</sub> | <b>A</b> 3 | Y <sub>13</sub> | | M1 | Y <sub>31</sub> | N12 | 028 | B13 | Ω <sub>8</sub> | A2 | Y <sub>14</sub> | | K3 | GND | L10 | 027 | D11 | V <sub>DD</sub> | C4 | GND | | L2 | V <sub>DD</sub> | M11 | GND | C12 | GND | В3 | Voo | | N1 | GND | N13 | 0 <sub>26</sub> | A13 | V <sub>DD</sub> | Αì | GND | #### NMLKJHGFEDCBA 0 0 0 0 0 (O) 0 0 Top View O O 0 0 Cavity Up 0 0 ## **Functional Description** ### **General Information** The TMC3211 consists of input registers, a pipelined array divider, and output (quotient) registers. The 16-bit divisor and 32-bit dividend input registers can each be loaded independently using the two synchronous load enable controls. The divider is a 16-stage pipelined non-restoring array which produces a 32-bit quotient and condition flags which indicate an attempted division by zero, or operations which yield a non-zero remainder or inexact result. The 32-bit parallel quotient output register includes three-state output drivers with synchronous enable control, which permits multiple TMC3211s to be operated in parallel or connected directly to a system bus. The TMC3211 requires a total of 19 clock cycles to generate a full 32-bit quotient result. Once the internal pipeline is full, a new quotient is available at the output every clock cycle. # **Signal Definitions** #### Power V<sub>DD</sub>, GND The TMC3211 operates on a single +5V supply. All power and ground lines must be connected. ### Clock CLK The TMC3211 has a single Clock input. All input and output signal timing is referenced to the rising edge of Clock. ### Inputs $Y_{31-0}$ The 32-bit Dividend is presented through the registered Y input port. $Y_{31}$ is the sign bit. The LSB is $Y_0$ . $X_{15-0}$ The 16-bit Divisor is presented through the registered X input port. $X_{15}$ is the sign bit. The LSB is $X_0$ . ## Outputs $\Omega_{31-0}$ The current Quotient is available on the registered Q output bus, $\Omega_{31}$ is the sign bit. The LSB is $\Omega_0$ . # **TMC3211** | Controls | | Flags | | |------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------| | YEN | Data present at the Dividend input $Y_{31-0}$ is latched into the input registers on the rising edge of clock when the enable control $\overline{YEN}$ is LOW. | DZ | Whenever a zero divisor is input, the resulting invalid output quotient will be accompanied by a registered Divide-By-Zero Flag HIGH. | | XEN | Data present at the Divisor input $X_{15-0}$ is latched into the input registers on the rising edge of clock when the enable control $\overline{XEN}$ is LOW. | REM | Whenever a division operation leaves a nonzero remainder, the resulting quotient is accompanied by a registered nonzero Remainder Flag HIGH. | | <u>OEQ</u> | The quotient output bus $Q_{31-0}$ and flags DZ and REM are in the high-impedance state when the registered Output Enable $\overline{OEQ}$ is HIGH. When $\overline{OEQ}$ is LOW, they are enabled on the next clock cycle. | | | # Package Interconnections | Signal<br>Type | Signal<br>Name | Function | H5 Package | | | | | |----------------|-------------------|------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | Power | V <sub>DD</sub> | Supply Voltage | B3, A4, A13, D11, F11, G12, J11, K11,<br>L11, L7, L4, L2, J3, G3, F3, C2, C3 | | | | | | | GND | Ground | A1, C4, C11, C12, E11, H11, L12, M12,<br>M11, L5, L3, N1, K3, H3, G2, E3, D3 | | | | | | Clock | CLK | System Clock | M9 | | | | | | Inputs | Y <sub>31-0</sub> | Dividend Data | M1, L1, K2, K1, J2, J1, H2, H1,<br>G1, F1, F2, E1, E2, D1, D2, C1,<br>B2, A2, A3, B4, C5, B5, A5, C6,<br>B6, A6, A7, C7, B7, A8, B8, C8 | | | | | | | x <sub>15-0</sub> | Divisor Data | L8, M8, N8, N7, M7, N6, M6, L6,<br>N5, M5, N4, M4, N3, M3, N2, M2 | | | | | | Outputs | 0 <sub>31-0</sub> | Quotient Data | L9, M10, N11, N12, L10, N13, M13, L13<br>K12, K13, J12, J13, H12, H13, G11, G13<br>F13, F12, E13, E12, D13, D12, C13, B13,<br>B12, A12, C10, B11, A11, B10, C9, A10 | | | | | | Controls | YEN | Dividend Write Enable | B1 | | | | | | | XEÑ | Divisor Write Enable | N9 | | | | | | | ŌEŌ | Quotient Output Enable | N10 | | | | | | Flags | DZ | Divide - By Zero Flag | B9 | | | | | | Ī | REM | Inexact Remainder Flag | A9 | | | | | | No Connect | | Index Pin | | | | | | TRW LSI Products Inc. # **Applications Discussion** ## **Division Using A Constant** By utilizing the separate input data register load enable controls, the TMC3211 can perform division by a constant. The data currently held remain in the input registers until updated by the user. #### **Data Formats** The TMC3211 supports fixed-point two's complement data formats. By keeping track of the binary points of the input data, the user can then interpret the resulting quotient properly. Two possible binary weightings of the input and output bits are as follows: Figure 1. Integer Data Format | Pin | D31 | D30 | D29 | D28 | D27 | D26 | D25 | D24 | D23 | D22 | D21 | D20 | D19 | D18 | D17 | D16 | D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | DO | |-----|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|------|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----| | Y | -231 | 230 | 229 | 228 | 227 | 226 | 225 | 224 | 223 | 222 | 221 | 220 | 219 | 218 | 217 | 216 | 215 | 214 | 213 | 212 | 211 | 210 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | | Х | | | | | | | | | | | | | | | | | -215 | 214 | 213 | 212 | 211 | 210 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | | Q | -231 | 230 | 229 | 228 | 227 | 226 | 225 | 224 | 223 | 222 | 221 | 220 | 219 | 218 | 217 | 216 | 215 | 214 | 213 | 212 | 211 | 210 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | Figure 2. Fractional Data Format | Y | -20 | -2-1 | 2-2 | 2-3 | 2-4 | 2-5 | 2-6 | 2-7 | 2-8 | 2-9 | 2-10 | 2-11 | 2-12 | 2-13 | 2-14 | 2-15 | 2-16 | 2-17 | 2-18 | 2-19 | 2-20 | 2-21 | 2-22 | 2-23 | 2-24 | 2-25 | 2-26 | 2-27 | 2-28 | 2-29 | 2-30 | 2-31 | |---|------|------|-----|-----|-----|-----|-----|-----|-----|-----|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------| | X | | | | | | | | | | | | | | | | | -20 | .2-1 | 2-2 | 2-3 | 2-4 | 2-5 | 2-6 | 2-7 | 2-8 | 2-9 | 2-10 | 2-11 | 2-12 | 2-13 | 2-14 | 2-15 | | α | -215 | .214 | 213 | 212 | 211 | 210 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 2-1 | 2-2 | 2-3 | 2-4 | 2-5 | 2-6 | 2-7 | 2-8 | 2-9 | 2-10 | 2-11 | 2-12 | 2-13 | 2-14 | 2-15 | 2-16 | where a leading minus sign indicates a sign bit. Care must be taken when adopting fractional data formats. By observing the binary weighting applied to the input data in the dividend and divisor, the binary point of the quotient can then be correctly established. The difference lies only in constant scale factors, which must be considered in order to maintain a data format which is compatible with the bit weighting of the hardware system. The two most common choices are fractional and integer notation. If integer notation is used, the LSBs of the dividend, divisor, and quotient all have the same value. With fractional notation the MSBs are all of equal weight. ## Divide by Zero The flag DZ indicates that the divisor input for the current calculation was a zero, independent of the dividend. Dividing by zero is an undefined operation yielding a meaningless quotient. Thus, this flag must be monitored to guard against possible errors. ### **Inexact Results** The flag REM is provided to indicate that the current quotient left a nonzero remainder and was truncated toward zero. ## **Negative Full-Scale Overflow** Due to a finite data word width, a two's complement overflow error occurs under the following unique condition: Divisor Y = 80000000H (-Full-Scale) Dividend X = FFFFH (-1) Result: Quotient Q = 80000000H (-Full-Scale) As stated above, this is due to a limitation in the number of bits available to indicate a positive full-scale quotient, and data overflows into the MSB position to indicate an incorrect sign. Figure 3. Timing Diagram Notes: - 1. Demonstrates division by a constant, $Q_2 = Y_2/X_1$ . - 2. Assumes $\overline{0EQ}$ = LOW. Figure 4. Equivalent Input Circuit Figure 5. Equivalent Output Circuit TRW LSI Products Inc. ## Absolute maximum ratings (beyond which the device may be damaged) 1 | Supply Volta | oge | -0.5 to +7.0V | |--------------|----------------------------------------------------------------|----------------------------------| | Input Voltag | e | -0.5 to (V <sub>DD</sub> + 0.5)V | | Output | | | | | Applied voltage? | | | | Forced current 3,4 | -3.0 to 6.0mA | | | Short-circuit duration (single output in HIGH state to ground) | 1 sec | | Temperature | | | | | Operating, case | | | | junction | 175°C | | | Lead, soldering (10 seconds) | 300°C | | | Storage | | #### Notes - 1 Absolute maximum ratings are limiting values applied individually while all other parameters are within specified operating conditions. Functional operation under any of these conditions is NOT implied. - 2. Applied voltage must be current limited to specified range, and measured with respect to GND. - 3. Forcing voltage must be limited to specified range. - 4. Current is specified as conventional current flowing into the device. ## **Operating conditions** | | | | т | Temperature Range<br>Standard | | | | | | | |------------------------------------|-------------------------------------------------------|------------------------------------------------|----------|-------------------------------|-------------|----------|--|--|--|--| | Parame | eter | Test Conditions | Min | Nom | Max | Units | | | | | | V <sub>DD</sub> | Supply Voltage | | 4.75 | 5.0 | 5.25 | ٧ | | | | | | v <sub>IL</sub><br>v <sub>IH</sub> | Input Voltage, Logic LOW<br>Input Voltage, Logic HIGH | | 2.0 | | 0.8 | V<br>V | | | | | | l <sup>OH</sup> | Output Current, Logic LOW Output Current, Logic HIGH | | | | 4.0<br>-2.0 | mA<br>mA | | | | | | t <sub>CY</sub> | Cycle Time | V <sub>DD</sub> - Min | | | 50 | ns | | | | | | <sup>t</sup> PWL | Clock Pulse Width, LOW<br>Clock Pulse Width, HIGH | V <sub>DD</sub> - Min<br>V <sub>DD</sub> - Min | 15<br>15 | | | ns<br>ns | | | | | | t <sub>S</sub> | Input Setup Time<br>Input Hold Time | | 12<br>6 | | _ | ns<br>ns | | | | | | TA | Ambient Temperature, Still Air | | 0 | | 70 | °C | | | | | # DC characteristics within specified operating conditions <sup>1</sup> | | | | Temperat | ure Range | | | |------------------|------------------------------------------|---------------------------------------------------------------------------------|----------|-----------|-------|--| | | | | Stan | İ | | | | Param | eter | Test Conditions | Min | Max | Units | | | IDDQ | Supply Current, Quiescent | $V_{DD} = Max, V_{IN} = 0V$ | | 5 | mA | | | IDDU | Supply Current, Unloaded | $V_{DD} = Max, \overline{OEQ} = 5V, f = 20MHz$ | | 150 | mA | | | Ī <sub>IL</sub> | Input Current, Logic LOW | $V_{DD} = Max, V_{IN} = 0V$ | | -10 | μA | | | I <sub>IH</sub> | Input Current, Logic HIGH | $V_{DD} = Max, V_{IN} = V_{DD}$ | | 10 | μΑ | | | v <sub>OL</sub> | Output Voltage, Logic LOW | V <sub>DD</sub> = Min, I <sub>DL</sub> = Max | | 0.4 | V | | | VOH | Output Voltage, Logic HIGH | V <sub>DD</sub> = Min, l <sub>OH</sub> = Max | 2.4 | | ٧ | | | l <sub>OZL</sub> | Hi-Z Output Leakage Current, Output LOW | V <sub>DD</sub> = Max, V <sub>IN</sub> = 0V | | -40 | μA | | | I <sub>OZH</sub> | Hi-Z Output Leakage Current, Output HIGH | $V_{DD} = Max, V_{IN} = V_{DD}$ | | 40 | μΑ | | | l <sub>OS</sub> | Short-Circuit Output Current | V <sub>DD</sub> = Max, Output HIGH, one pin to ground, one second duration max. | | - 150 | mA | | | | | | | 10 | | | | Cl | Input Capacitance | T <sub>A</sub> = 25°C, f = 1MHz | <u> </u> | 10 | pF | | | c <sub>0</sub> | Output Capacitance | $T_A = 25$ °C, $f = 1$ MHz | | 10 | pF | | Note: 1. Actual test conditions may vary from those shown, but guarantee operation as specified. ## AC characteristics within specified operating conditions | | | Temperate | ure Range | | | | | | |------------------------------------------|-------------------------------------------------|-----------|-----------|-------|--|--|--|--| | | | Stan | Standard | | | | | | | Parameter | Test Conditions | Min | Max | Units | | | | | | t <sub>D</sub> Output Delay <sup>1</sup> | V <sub>DD</sub> = Min, C <sub>LOAD</sub> = 25pF | | 35 | ns | | | | | | t <sub>HO</sub> Output Hold Time | $V_{DD} = Max, C_{LOAD} = 25pF$ | 5 | | ns | | | | | Note: 1. Equivalent to t<sub>DIS</sub> and t<sub>ENA</sub> of the three-state outputs ## **Ordering Information** | Product<br>Number | Temperature Range | Screening | Package | Package<br>Marking | |-------------------|---------------------------------|------------|--------------------------------|--------------------| | TMC3211H5C | STD-T <sub>A</sub> =0°C to 70°C | Commercial | 120 Pin Plastic Pin Grid Array | 3211H5C | All parameters contained in this specification are guaranteed by design, characterization, sample testing or 100% testing as appropriate. TRW reserves the right to change products and specifications without notice. This information does not convey any license under patent rights of TRW Inc. or others. **Life Support Policy** — TRW LSI Products Inc. components are not designed for use in life support applications, wherein a failure or malfunction of the component can reasonably be expected to result in personal injury. The user of TRW LSI Products Inc. components in life support applications assumes all risk of such use and indemnifies TRW LSI Products Inc. against all damages # **Fixed-Point Arithmetic**