## 1983

## HARRIS SEMICONDUCTOR DSP PRODUCTS

This Digital Signal Processing databook represents the full line of Harris Semiconductor DSP products for commercial and military applications and supersedes previously published DSP material under the Harris, GE, RCA or Intersil names. For a complete listing of all Harris Semiconductor products, please refer to the Product Selection Guide (PSG-201S; ordering information below.)

For complete, current and detailed technical specifications on any Harris devices please contact the nearest Harris sales, representative or distributor office; or direct literature requests to:

Harris Semiconductor Literature Department
P.O. Box 883, MS CB1-25

Melbourne, FL 32901
FAX 407-724-3937

## U.S. HEADQUARTERS

Harris Semiconductor 1301 Woody Burke Road
Melbourne, Florida 32902
TEL: (407) 724-3000

## SOUTH ASIA

Harris Semiconductor H.K. Ltd
13/F Fourseas Building
208-212 Nathan Road
Tsimshatsui, Kowloon
Hong Kong
TEL: (852) 723-6339

## EUROPEAN HEADQUARTERS

Harris Semiconductor
Mercure Centrer
100, Rue de la Fusee
1130 Brussels, Belgium
TEL: (32) 2-246-21.11
NORTH ASIA
Harris K.K.
Shinjuku NS Bldg. Box 6153
2-4-1 Nishi-Shinjuku
Shinjuku-ku, Tokyo 163 Japan
TEL: 81-3-3345-8911

Harris Semiconductor products are sold by description only. All specifications in this product guide are applicable only to packaged products; specifications for die are available upon request. Harris reserves the right to make changes in circuit design, specifications and other information at any time without prior notice. Accordingly, the reader is cautioned to verify that information in this publication is current before placing orders. Reference to products of other manufacturers are solely for convenience of comparison and do not imply total equivalency of design, performance, or otherwise.

## OX HEMCONDUCTO

## DIIITAL SIGNAL PROCESSINE

# FOR COMMERCIAL AND MILITARY APPLICATIONS 

General InformationMultipliers2
One Dimensional Filters ..... 3
Two Dimensional Filters ..... 4
Signal Synthesizers ..... 5
Special Function6
Development Tools ..... 7
Application Notes ..... 8
Quality and Reliability ..... 9
Packaging and Ordering Information ..... 10
Sales Offices ..... 11

## DIGITAL SIGNAL PROCESSING PRODUCT TECHNICAL ASSISTANCE

For technical assistance on the Harris products listed in this databook, please contact Field Applications Engineering staff available at one of the following Harris Sales Offices:

| UNITED STATES |  |
| :---: | :---: |
| CALIFORNIA | Woodland Hills . . . . . . . . . . . . . . . . . . 818-992-0686 |
|  | San Jose . . . . . . . . . . . . . . . . . . . . . . 408-922-0977 |
| FLORIDA | Melbourne . . . . . . . . . . . . . . . . . . . . . 407-724-3576 |
| GEORGIA | Duluth. . . . . . . . . . . . . . . . . . . . . . . . 404-476-2034 |
| ILLINOIS | Schaumburg. . . . . . . . . . . . . . . . . . . . 708-240-3499 |
| NEW JERSEY | Mt. Laurel. . . . . . . . . . . . . . . . . . . . . . 609-727-1909 |
| NEW YORK | Great Neck. . . . . . . . . . . . . . . . . . . . . 516-824-9441 |
| INTERNATIONAL |  |
| FRANCE | Paris. . . . . . . . . . . . . . . . . . . . . . . . . 33-1-346-54090 |
| GERMANY | Munich . . . . . . . . . . . . . . . . . . . . . . . . 49-8-963-813-117 |
| HONG KONG | Kowloon . . . . . . . . . . . . . . . . . . . . . . . 852-723-6339 |
| ITALY | Milano . . . . . . . . . . . . . . . . . . . . . . . 39-2-262-0761 |
| JAPAN | Tokyo . . . . . . . . . . . . . . . . . . . . . . . . . 81-3-345-8911 |
| KOREA | Seoul . . . . . . . . . . . . . . . . . . . . . . . . 82-2-551-0931 |
| U.K. | Camberley . . . . . . . . . . . . . . . . . . . . . 44-2-766-86886 |

## GENERAL INFORMATION

## ALPHA NUMERIC PRODUCT INDEX

PAGE
$\mathrm{DECl} \cdot \mathrm{MATE}^{\text {TM }}$ Harris HSP43220 Decimating Digital Filter Development Software ..... 7-3
HMA510 $16 \times 16$-Bit CMOS Parallel Multiplier Accumulator ..... 2-3
HMA510/883 $16 \times 16$-Bit CMOS Parallel Multiplier Accumulator ..... 2-10
HMU16/HMU17 $16 \times 16$-Bit CMOS Parallel Multipliers ..... 2-15
HMU16/883 $16 \times 16$-Bit CMOS Parallel Multiplier ..... 2-25
HMU17/883 $16 \times 16$-Bit CMOS Parallel Multiplier ..... 2-31
HSP-EVAL DSP Evaluation Platform NEW PRODUCT ..... 7-7
HSP43168 Dual FIR Filter NEW PRODUCT ..... 3-3
HSP43168/883 Dual FIR Filter NEW PRODUCT ..... 3-19
HSP43216 Halfband Filter NEW PRODUCT ..... 3-116
HSP43220 Decimating Digital Filter ..... 3-27
HSP43220/883 Decimating Digital Filter ..... 3-47
HSP43481 Digital Filter ..... 3-54
HSP43481/883 Digital Filter ..... 3-69
HSP43881 Digital Filter ..... 3-74
HSP43881/883 Digital Filter ..... 3-89
HSP43891 Digital Filter ..... 3-95
HSP43891/883 Digital Filter ..... 3-110
HSP45102 12 Bit Numerically Controlled Oscillator ..... 5-3
HSP45106 16 Bit Numerically Controlled Oscillator ..... 5-10
HSP45106/883 16 Bit Numerically Controlled Oscillator ..... 5-20
HSP45116 Numerically Controlled Oscillator/Modulator ..... 5-26
HSP45116/883 Numerically Controlled Oscillator/Modulator ..... 5-41
HSP45116-DB HSP45116 Daughter Board NEW PRODUCT ..... 7-8
HSP45240 Address Sequencer ..... 6-3
HSP45240/883 Address Sequencer ..... 6-15
HSP45256 Binary Correlator NEW PRODUCT ..... 6-21
HSP45256/883 Binary Correlator NEW PRODUCT ..... 6-34
HSP48410 Histogrammer/Accumulating Buffer NEW PRODUCT ..... 6-42
HSP48901 $3 \times 3$ Image Filter ..... 4-3
HSP48908 Two Dimensional Convolver ..... 4-12
HSP48908/833 Two Dimensional Convolver ..... 4-28
HSP50016 Digital Down Converter NEW PRODUCT. ..... 5-48
HSP9501 Programmable Data Buffer ..... 6-53
HSP9520/952 Multilevel Pipeline Register ..... 6-60
ISP9520/9521
DECI • MATE ${ }^{\text {T }}$ is a Trademark of Harris Corporation

## PRODUCT INDEX BY FAMILY

MULTIPLIERS PAGE
HMA510 $16 \times 16$-Bit CMOS Parallel Multiplier Accumulator ..... 2-3
HMA510/883 $16 \times 16$-Bit CMOS Parallel Multiplier Accumulator ..... 2-10
HMU16/HMU17 $16 \times 16$-Bit CMOS Parallel Multipliers ..... 2-15
HMU16/883 $16 \times 16$-Bit CMOS Parallel Multiplier ..... 2-25
HMU17/883 $16 \times 16-$ Bit CMOS Parallel Multiplier ..... 2-31
ONE DIMENSIONAL FILTERS
HSP43168 Dual FIR Filter NEW PRODUCT ..... 3-3
HSP43168/883 Dual FIR Filter NEW PRODUCT ..... 3-19
HSP43216 Halfband Filter NEW PRODUCT ..... 3-116
HSP43220 Decimating Digital Filter ..... 3-27
HSP43220/883 Decimating Digital Filter ..... 3-47
HSP43481 Digital Filter ..... 3-54
HSP43481/883 Digital Filter ..... 3-69
HSP43881 Digital Filter ..... 3-74
HSP43881/883 Digital Filter ..... 3-89
HSP43891 Digital Filter ..... 3-95
HSP43891/883 Digital Filter ..... 3-110
TWO DIMENSIONAL FILTERS
HSP48901 $3 \times 3$ Image Filter ..... 4-3
HSP48908 Two Dimensional Convolver ..... 4-12
HSP48908/833 Two Dimensional Convolver ..... 4-28
SIGNAL SYNTHESIZERS
HSP45102 12 Bit Numerically Controlled Oscillator ..... 5-3
HSP45106 16 Bit Numerically Controlled Oscillator ..... 5-10
HSP45106/883 16 Bit Numerically Controlled Oscillator ..... 5-20
HSP45116 Numerically Controlled Oscillator/Modulator ..... 5-26
HSP45116/883 Numerically Controlled Oscillator/Modulator ..... 5-41
HSP50016 Digital Down Converter NEW PRODUCT ..... 5-48
SPECIAL FUNCTION
HSP45240 Address Sequencer ..... 6-3
HSP45240/883 Address Sequencer ..... 6-15
HSP45256 Binary Correlator NEW PRODUCT ..... 6-21
HSP45256/883 Binary Correlator NEW PRODUCT ..... 6-34
HSP48410 Histogrammer/Accumulating Buffer NEW PRODUCT ..... 6-42
HSP9501 Programmable Data Buffer ..... 6-53
HSP9520/9521 Multilevel Pipeline Register ..... 6-60
ISP9520/9521
DEVELOPMENT TOOLS
DECI • MATE Harris HSP43220 Decimating Digital Filter Development Software ..... 7-3
HSP-EVAL DSP Evaluation Platform NEW PRODUCT ..... 7-7
HSP45116-DB HSP45116 Daughter Board NEW PRODUCT ..... 7-8


## MULTIPLIERS

PAGE

## DATA SHEETS

| HMA510 | -Bit CMOS Parallel Multiplier Accumulator | 2-3 |
| :---: | :---: | :---: |
| HMA510/883 | $16 \times 16$-Bit CMOS Parallel Multiplier Accumulator | 2-10 |
| HMU16/HMU17 | $16 \times 16$-Bit CMOS Parallel Multipliers | 2-15 |
| HMU16/883 | $16 \times 16-$ Bit CMOS Parallel Multiplier | 2-25 |
| HMU17/883 | $16 \times 16$-Bit CMOS Parallel Multiplier . . . | 2-31 |

# $16 \times 16$-Bit CMOS ParalleI Multiplier Accumulator 

## Features

- $16 \times 16$-bit Parallel Multiplication with Accummulation to a 35-Bit Result
- High-Speed (45ns) Multiply Accumulate Time
- Low Power CMOS Operation:
- ICCSB $=500 \mu \mathrm{~A}$ Maximum
- ICCOP $=7.0 \mathrm{~mA}$ Maximum @ 1.0 MHz
- HMA510 is Compatible with the CY7C510 and the IDT7210
- Supports Two's Complement or Unsigned Magnitude Operations
- TTL Compatible Inputs/Outputs
- Three-State Outputs
- Available in 68 Pin Plastic Leaded Chip Carrier (PLCC) and 68 Lead Pin Grid Array (PGA)


## Description

The HMA510 is a high speed, low power CMOS $16 \times 16$-bit parallel multiplier accumulator capable of operating at 45ns clocked multiply-accumulate cycles. The 16-bit X and Y operands may be specified as either two's complement or unsigned magnitude format. Additional inputs are provided for the accumulator functions which include: loading the accumulator with the current product, adding or subtracting the accumulator contents and the current product, and preloading the accumulator registers from the external inputs.

All inputs and outputs are registered. The registers are all positive edge triggered, and are latched on the rising edge of the associated clock signal. The 35 -bit accumulator output register is broken into three parts. The 16-bit least significant product (LSP), the 16-bit most significant product (MSP), and the 3-bit extended product (XTP) registers. The XTP and MSP registers have dedicated output ports, while the LSP register shares the Y-inputs in a multiplexed fashion. The entire 35-bit accumulator output register may be preloaded at any time through the use of the bidirectional output ports and the preloaded control.

## Block Diagram



Pinouts
HMA510 PLCC


HMA510 CERAMIC PGA


## Pin Descriptions

| NAME | $\begin{gathered} \text { PLCC } \\ \text { PIN NUMBER } \end{gathered}$ | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ | 17-20 |  | The +5 V power supply pins. $0.1 \mu \mathrm{~F}$ capacitors between the $\mathrm{V}_{\mathrm{CC}}$ and GND pins are recommended. |
| GND | 53,54 |  | The device ground. |
| X0-X15 | 1-10,63-68 | 1 | X-Input Data. These 16 data inputs provide the multiplicand which may be in two's complement or unsigned magnitude format. |
| $\begin{aligned} & \text { YO-Y15/ } \\ & \text { PO-P15 } \end{aligned}$ | 45-52, 55-62 | 1/0 | Y-Input/LSP Output Data. This 16-bit port is used to provide the multiplier which may be in two's complement or unsigned magnitude format. It may also be used for output of the Least Significant Product (PO-P15) or for preloading the LSP register. |
| P16-P3 | 29-44 | 1/O | MSP Output Data. This 16-Bit port is used to provide the Most Significant Product Output (P16-P31). It may also be used to preload the MSP register. |
| P32-P34 | 26-28 | 1/0 | XTP Output Data. This 3-Bit port is used to provide the Extended Product Output (P32-P34). It may also be used to preload the XTP register. |
| TC | 21 | 1 | Two's Complement Control. Input data is interpreted as two's complement when this control is HIGH. A LOW indicates the data is to be interpreted as unsigned magnitude format. This control is latched on the rising edge of CLKX or CLKY. |
| ACC | 14 | 1 | Accumulate Control. When this control is HIGH, the accumulator output register contents are added to or subtracted from the current product, and the result is stored back into the accumulator output register. <br> When LOW, the product is loaded into the accumulator output register overwriting the current contents. This control is also latched on the rising edge of CLKX or CLKY. |
| SUB | 13 | 1 | Subtract Control. When both SUB and ACC are HIGH, the accumulator register contents are subtracted from the current product. When ACC is HIGH and SUB is LOW, the accumulator register contents and the current product are summed. The SUB control input is latched on the rising edge of CLKX or CLKY. |
| RND | 12 | 1 | Round Control. When this control is HIGH, a one is added to the most significant bit of the LSP. When LOW, the product is unchanged. |
| PREL | 23 | 1 | Preload Control. When this control is HIGH, the three bidirectional ports may be used to preload the accumulator registers. The three-state controls ( $\overline{O E X}, \overline{O E M}$, $\overline{O E L}$ ) must be HIGH, and the data will be preloaded on the rising edge of CLKP. When this control is LOW, the accumulator registers function in a normal manner. |
| $\overline{O E L}$ | 11 | 1 | Y-Input/LSP Output Port Three-state Control. When $\overline{O E L}$ is HIGH, the output drivers are in the high impedance state. This state is required for Y -data input or preloading the LSP register. When $\overline{O E L}$ is LOW, the port is enabled for LSP output. |
| $\overline{O E M}$ | 24 | 1 | MSP Output Port Three-state Control. A LOW on this control line enables the port for output. When $\overline{\text { OEM }}$ is HIGH, the output drivers are in the high impedance state. This control must be HIGH for preloading the MSP register. |
| $\overline{\mathrm{OEX}}$ | 22 | 1 | XTP Output Port Three-state Control. A LOW on this control line enables the port for output. When $\overline{O E X}$ is HIGH, the output drivers are in the high impedance state. This control must be HIGH for preloading the XTP register. |
| CLKX | 15 | 1 | X-Register Clock. The rising edge of this clock latches the X-data input register along with the TC, ACC, SUB and RND inputs. |
| CLKY | 16 | 1 | Y-Register Clock. The rising edge of this clock latches the Y -data input register along with the TC, ACC, SUB and RND inputs. |
| CLKP | 25 | 1 | Product Register Clock. The rising edge of CLKP latches the LSP, MSP and XTP registers. If the preload control is active, the data on the I/O ports is loaded into these registers. If preload is not active, the accumulated product is loaded into the the registers. |

## Functional Description

The HMA510 is a high speed $16 \times 16$-bit multiplier accumulator (MAC). It consists of a 16-bit parallel multiplier follower by a 35-bit accumulator. All inputs and outputs are registered and are latched on the rising edge of the associated clock signal. The HMA510 is divided into four sections: the input section, the multiplier array, the accumulator and the output/preload section.

The input section has two 16-bit operand input registers for the $X$ and $Y$ operands which are latched on the rising edge of CLKX and CLKY respectively. A four bit control register (TC, RND, ACC, SUB) is also included and is latched from either of the input clock signals.

The $16 \times 16$ multiplier array produces the 32-bit product of the input operands. Two's complement or unsigned magnitude operation can be selected by the use of the TC control. The 32-bit result may also be rounded through the use of the RND control. In this case, a ' 1 ' is added to the MSB of the LSP (bit P15). The 32-bit product is zero-filled or sign-extened as appropriate and passed as a 35-bit number to the accumulator section.

The accumulator functions are controlled by the ACC, SUB and PREL control inputs. Four functions may be selected: the accumulator may be loaded with the current product; the product may be added to the accumulator contents; the accumulator contents may be subtracted from the current product; or the accumulator may be loaded from the bidirectional ports. The accumulator registers are updated at the rising edge of the CLKP signal.

The output/preload section contains the accumulator/ output register and the bidirectional ports. This section is controlled by the signals PREL, $\overline{O E X}, \overline{O E M}$ and $\overline{O E L}$. When PREL is high, the output buffers are in a high impedance state. When one of the controls $\overline{\mathrm{OEX}}, \overline{\mathrm{OEM}}$ or $\overline{\mathrm{OEL}}$ are also high, data present at the outputs will be preloaded into the associated register on the rising edge of CLKP. When PREL is low, the signals $\overline{O E X}, \overline{O E M}$ and $\overline{O E L}$ are enable controls for their respective three-state output ports.

PRELOAD FUNCTION TABLE

|  |  |  |  |  | OUTPUTREGISTERS |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |
|  | $\overline{O E X}$ | $\overline{O E M}$ |  | XTP | MSP | LSP |
| 0 | 0 | 0 | 0 | $Q$ | $Q$ | $Q$ |
| 0 | 0 | 0 | 1 | $Q$ | $Q$ | $Z$ |
| 0 | 0 | 1 | 0 | $Q$ | $Z$ | $Q$ |
| 0 | 0 | 1 | 1 | $Q$ | $Z$ | $Z$ |
| 0 | 1 | 0 | 0 | $Z$ | $Q$ | $Q$ |
| 0 | 1 | 0 | 1 | $Z$ | $Q$ | $Z$ |
| 0 | 1 | 1 | 0 | $Z$ | $Z$ | $Q$ |
| 0 | 1 | 1 | 1 | $Z$ | $Z$ | $Z$ |
| 1 | 0 | 0 | 0 | $Z$ | $Z$ | $Z$ |
| 1 | 0 | 0 | 1 | $Z$ | $Z$ | $P L$ |
| 1 | 0 | 1 | 0 | $Z$ | $P L$ | $Z$ |
| 1 | 0 | 1 | 1 | $Z$ | $P L$ | $P L$ |
| 1 | 1 | 0 | 0 | $P L$ | $Z$ | $Z$ |
| 1 | 1 | 0 | 1 | $P L$ | $Z$ | $P L$ |
| 1 | 1 | 1 | 0 | $P L$ | $P L$ | $Z$ |
| 1 | 1 | 1 | 1 | $P L$ | $P L$ | $P L$ |

$Z=$ Output Buffers at High Impedance (Disabled).
Q = Output Buffers at LOW Impedance. Contents of Output Register Available Through Output Ports.
PL = Output disabled. Preload data supplied to the output pins will be loaded into the register at the rising edge of CLKP.

## ACCUMULATOR FUNCTION TABLE

| PREL | ACC | SUB | P | OPERATION |
| :---: | :---: | :---: | :---: | :--- |
| L | L | X | Q | Load |
| L | H | L | Q | Add |
| L | H | H | Q | Subtract |
| H | X | X | PL | Preload |

## INPUT FORMATS

Fractional Two's Complement Input

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| -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$ | (Sign)


| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $2^{0}$ | $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}$ | (Sign)

Integer Two's Complement Input


Unsigned Fractional Input


## Unsigned Integer Input

| X |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | Y |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 2 |  | $2^{13}$ | $2^{12}$ | $22^{11}$ | 210 | $2^{9}$ | $2^{8}$ | $2^{7}$ | $2^{6}$ | 25 | $2^{4}$ | 23 | 22 | $2^{1}$ | 20 | 215 | 214 | $2^{13}$ |  |  | 210 | $2^{9}$ | $2^{8}$ | $2^{7}$ | 26 | 25 | 24 | $2^{3}$ | $2^{2}$ | 21 | 20 |

## OUTPUT FORMATS

Two's Complement Fractional Output


## Two's Complement Integer Output

MSP


Unsigned Fractional Output


Unsigned Integer Output



## Operating Conditions

Operating Voltage Range
+4.75 V to +5.25 V
Operating Temperature Range $. \ldots \ldots \ldots \ldots \ldots . . .0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$

## Reliability Information


$\theta_{\text {jc }} \ldots \ldots \ldots \ldots \ldots \ldots \ldots . . .15 .1^{\circ} \mathrm{C} / \mathrm{W}$ (PLCC), $10.0^{\circ} \mathrm{C} / \mathrm{W}$ (PGA)
Maximum Package Power Dissipation at $70^{\circ} \mathrm{C}$......1.7W (PLCC)
2.46/W (PGA)
D.C. Electrical Specifications ( $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| PARAMETER | SYMBOL | MIN | MAX | UNITS | TEST CONDITIONS |
| :--- | :---: | :---: | :---: | :--- | :--- |
| Logical One Input Voltage | $\mathrm{V}_{\mathrm{IH}}$ | 2.0 | - | V | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| Logical Zero Input Voltage | $\mathrm{V}_{\mathrm{IL}}$ | - | 0.8 | V | $\mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Output HIGH Voltage | $\mathrm{V}_{\mathrm{OH}}$ | 2.6 | - | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Output LOW Voltage | $\mathrm{V}_{\mathrm{OL}}$ | - | 0.4 | V | $\mathrm{I}_{\mathrm{OL}}=+4.0 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Input Leakage Current | I | -10 | 10 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}$ or $\mathrm{GND}, \mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| Output or I/O Leakage Current | IO | -10 | 10 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{OUT}}=\mathrm{V}_{\mathrm{CC}}$ or $\mathrm{GND}, \mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| Standby Power Supply Current | $\mathrm{I}_{\mathrm{CCSB}}$ | - | 500 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}$ or $\mathrm{GND}, \mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$, Outputs Open |
| Operating Power Supply Current | $\mathrm{I}_{\mathrm{CCOP}}$ | - | 7.0 | mA | $\mathrm{f}=1.0 \mathrm{MHz}, \mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}$ or GND <br> $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}(\mathrm{Note} 1)$ |

Capacitance ( $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$, Note 2)

| PARAMETER | SYMBOL | MIN | MAX | UNITS | TEST CONDITIONS |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| Input Capacitance | $\mathrm{C}_{\mathrm{IN}}$ | - | 10 | pF | FREQ $=1 \mathrm{MHz}, \mathrm{V}_{\mathrm{CC}}=$ Open all Measurements <br> are Referenced to Device Ground. |  |
| Output Capacitance | $\mathrm{C}_{\mathrm{OUT}}$ | - | 10 | pF |  |  |
| I/O Capacitance | $\mathrm{C}_{\mathrm{I} / \mathrm{O}}$ | - | 15 | pF |  |  |

## NOTES:

1. Operating Supply Current is proportional to frequency, typical rating is 2. Not tested, but characterized at initial design and at major process/design $5.0 \mathrm{~mA} / \mathrm{MHz}$. changes.
A.C. Electrical Specifications $\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $\left.+70^{\circ} \mathrm{C}\right)$

| PARAMETER | SYMBOL | HMA510-45 |  | HMA510-55 |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |  |  |
| Multiply Accumulate Time | TMA | - | 45 | - | 55 | ns |  |
| Output Delay | TD | - | 25 | - | 30 | ns |  |
| 3-State Enable Time | TENA | - | 25 | - | 30 | ns | Note 1 |
| 3-State Disable Time | TDIS | - | 25 | - | 30 | ns | Note 1 |
| Input Setup Time | Ts | 18 | - | 20 | - | ns |  |
| Input Hold Time | $\mathrm{T}_{\mathrm{H}}$ | 2 | - | 2 | - | ns |  |
| Clock High Pulse Width | TPWH | 15 | - | 20 | - | ns |  |
| Clock Low Pulse Width | TPWL | 15 | - | 20 | - | ns |  |
| Output Rise Time | $T_{R}$ | - | 8 | - | 8 | ns | From 0.8V to 2.0V |
| Output Fall Time | $\mathrm{T}_{\mathrm{F}}$ | - | 8 | - | 8 | ns | From 2.0 V to 0.8 V |

## NOTES:

1. Transition is measured at $\pm 200 \mathrm{mV}$ from steady state voltage with loading specified in A.C. Test Circuit; $\mathrm{V}_{1}=1.5 \mathrm{~V}, \mathrm{R}_{1}=500 \Omega$ and $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$.
2. For A.C. Test load, refer to A.C. Test Circuit with $\mathrm{V}_{1}=2.4 \mathrm{~V}, \mathrm{R}_{1}=500 \Omega$ and $C_{L}=40 \mathrm{pF}$.
A.C. Test Circuit

*Includes Stray and Jig Capacitance
A.C. Testing Input, Output Waveforms

A.C. Testing: All Parameters tested as per test circuit. Input rise and fall times are driven at $1 \mathrm{~ns} / \mathrm{V}$.

## Timing Diagram

SET-UP AND HOLD TIME


HMA510 TIMING DIAGRAM


THREE STATE CONTROL


PRELOAD TIMING DIAGRAM


## August 1992

## $16 \times 16$-Bit CMOS Parallel Multiplier Accumulator

## Features

- This Circuit is Processed in Accordance to Mil-Std883 and is Fully Conformant Under the Provisions of Paragraph 1.2.1.
- $16 \times 16$-bit Parallel Multiplication with Accummulation to a 35-Bit Result
- High-Speed (55ns) Multiply Accumulate Time
- Low Power CMOS Operation:
- ICCSB $=500 \mu \mathrm{~A}$ Maximum
- ICCOP $=7.0 \mathrm{~mA}$ Maximum @ 1.0MHz
- HMA510/883 is Compatible with the CY7C510 and the IDT7210
- Supports Two's Complement or Unsigned Magnitude Operations
- TTL Compatible Inputs/Outputs
- Three-State Outputs
- Available in 68 Lead Pin Grid Array (PGA) Package


## Description

The HMA510/883 is a high speed, low power CMOS $16 \times 16$-bit parallel multiplier accumulator capable of operating at 55 ns clocked multiply-accumulate cycles. The 16-bit $X$ and $Y$ operands may be specified as either two's complement or unsigned magnitude format. Additional inputs are provided for the accumulator functions which include: loading the accumulator with the current product, adding or subtracting the accumulator contents and the current product, and preloading the accumulator registers from the external inputs.

All inputs and outputs are registered. The registers are all positive edge triggered, and are latched on the rising edge of the associated clock signal. The 35-bit accumulator output register is broken into three parts. The 16-bit least significant product (LSP), the 16-bit most significant product (MSP), and the 3-bit extended product (XTP) registers. The XTP and MSP registers have dedicated output ports, while the LSP register shares the Y -inputs in a multiplexed fashion. The entire 35-bit accumulator output register may be preloaded at any time through the use of the bidirectional output ports and the preloaded control.

## Block Diagram



## Absolute Maximum Ratings

Supply Voltage $\qquad$
input or Output Voltage Applied $\qquad$ GND-0.5V to $\mathrm{V}_{\mathrm{CC}}+0.5 \mathrm{~V}$
Storage Temperature Range
$\qquad$ GND-0 $-65^{\circ} \mathrm{C}$ to $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ Junction Temperature . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $+175^{\circ} \mathrm{C}$ Lead Temperature (Soldering 10 sec ) . . . . . . . . . . . . . . . . . . . $300^{\circ} \mathrm{C}$ ESD Classification
CAUTION: Stresses above those listed in "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.

## Operating Conditions

Operating Voltage Range . . . . . . . . . . . . . . . . . . . . . . . . +4.5 V to +5.5 V
Operating Temperature Range . . . . . . . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

Device Guaranteed and 100\% Tested

| PARAMETER | SYMBOL | CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| Logical One Input Voltage | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 2.2 | - | v |
| Logical Zero Input Voltage | VIL | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 0.8 | V |
| Output HIGH Voltage | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & \mathrm{IOH}_{\mathrm{OH}}=-400 \mu \mathrm{~A} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}(\text { Note } 1) \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 2.6 | - | v |
| Output LOW Voltage | VOL | $\begin{aligned} & \mathrm{I}_{\mathrm{OL}}=+4.0 \mathrm{~mA} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}(\text { Note } 1) \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 0.4 | V |
| Input Leakage Current | 1 | $\begin{aligned} & V_{I N}=V_{C C} \text { or } G N D \\ & V_{C C}=5.5 V \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}^{\prime} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Output or I/O Leakage Current | 10 | $\begin{aligned} & \mathrm{V}_{\text {OUT }}=\mathrm{V}_{\mathrm{CC}} \text { or GND } \\ & \mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq T \mathrm{~A} \leq+125^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Standby Power Supply Current | ${ }^{\text {I CCsB }}$ | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\mathrm{CC}}$ or GND , <br> $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, Outputs Open | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 500 | $\mu \mathrm{A}$ |
| Operating Power Supply Current | I'COP | $\begin{aligned} & f=1.0 \mathrm{MHz}, \\ & \mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}} \text { or GND } \\ & \mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V} \text { (Note 2) } \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 7.0 | mA |
| Functional Test | FT | ( Note 3) | 7,8 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | - |  |

NOTES:

1. Interchanging of force and sense conditions is permitted.
2. Tested as follows: $f=1 \mathrm{MHz}, \mathrm{V}_{\mathrm{IH}}$ (clock inputs) $=3.2 \mathrm{~V}, \mathrm{~V}_{\mathrm{IH}}$ (all other inputs) $=2.6 \mathrm{~V}, \mathrm{~V}_{\mathrm{IL}}=0.4 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}} \geq 1.5 \mathrm{~V}$, and $\mathrm{V}_{\mathrm{OL}} \leq 1.5 \mathrm{~V}$.

## Reliability Information

| Thermal Resistance | $\theta_{\mathrm{ja}}$ | $\theta_{\mathrm{jc}}$ |
| :---: | :---: | :---: |
| Ceramic PGA Package | $43^{\circ} \mathrm{C}$ | $10^{\circ} \mathrm{C} / \mathrm{W}$ |
| Maximum Package Power Dissipation at $+125^{\circ} \mathrm{C}$ |  |  |
| Ceramic PGA Package . . . . . . . . . . . . . . . . . . . . . . . . . . . 1.17 Watt |  |  |
| Gate Count |  | 00 Gates |

$\theta_{\mathrm{ja}} \quad \theta_{\mathrm{jc}}$ $10^{\circ} \mathrm{C} / \mathrm{W}$ Maximum Package Power Dissipation at $+125^{\circ} \mathrm{C}$ Ceramic PGA Package 1.17 Watt 4800 Gates

## TABLE 1. HMA510/883 D.C. ELECTRICAL PERFORMANCE CHARACTERISTICS

2. Operating Supply Current is proportional to frequency, typical rating is $5 \mathrm{~mA} / \mathrm{MHz}$.

TABLE 2. HMA510/883 A.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and 100\% Tested

| PARAMETER | SYMBOL | (NOTE 1) CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | -55 |  | -65 |  | -75 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |
| Multiply <br> Accumulate Time | TMA |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 55 | - | 65 | - | 75 | ns |
| Input Setup Time | Ts |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}^{\prime} \leq+125^{\circ} \mathrm{C}$ | 20 | - | 25 | - | 25 | - | ns |
| Clock HIGH Pulse Width | TPWH |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 20 | - | 25 | - | 25 | - | ns |
| Clock LOW Pulse Width | TPWL |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 20 | - | 25 | - | 25 | - | ns |
| Output Delay | TD |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 30 | - | 35 | - | 35 | ns |
| 3-State Enable Time | TENA | (Note 2) | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 30 | - | 30 | - | 35 | ns |

NOTES:

1. AC Testing as follows: $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and 5.5 V . Input levels OV and 3.0 V ( OV and 3.2 V for clock inputs). Timing reference levels $=1.5 \mathrm{~V}$, Output load per test load circuit, with $\mathrm{V}_{1}=2.4 \mathrm{~V}, \mathrm{R}_{1}=500 \Omega$ and $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$.
2. Transition is measured at $\pm 200 \mathrm{mV}$ from steady state voltage, Output loading per test load circuit, with $\mathrm{V}_{1}=1.5 \mathrm{~V}, \mathrm{R}_{1}=500 \Omega$ and $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$.

TABLE 3. HMA510/883 ELECTRICAL PERFORMANCE CHARACTERISTICS

| PARAMETER | SYMBOL | CONDITIONS | NOTE | TEMPERATURE | -55 |  | -65 |  | -75 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |
| Input Capacitance | $\mathrm{C}_{1 \mathrm{~N}}$ | $\begin{aligned} & v_{C C}=O \text { Open, } \\ & f=1 \mathrm{MHz} \mathrm{All} \end{aligned}$ <br> measurements are referenced to device GND. | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 10 | - | 10 | - | 10 | pF |
| Output Capacitance | COUT |  | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 10 | - | 10 | - | 10 | pF |
| 1/O Capacitance | $\mathrm{C}_{1 / \mathrm{O}}$ |  | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 15 | - | 15 | - | 15 | pF |
| Input Hold Time | $\mathrm{T}_{\mathrm{H}}$ |  | 1 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 3 | - | 3 | - | 3 | - | ns |
| 3-State Disable Time | TDIS |  | 1 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 30 | - | 30 | - | 30 | ns |
| Output Rise Time | $\mathrm{T}_{\mathrm{R}}$ | From 0.8 V to 2.0 V | 1 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 10 | - | 10 | - | 10 | ns |
| Output Fall Time | $\mathrm{T}_{\mathrm{F}}$ | From 2.0 V to 0.8 V | 1 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 10 | - | 10 | - | 10 | ns |

NOTE:

1. The parameters listed in Table 3 are controlled via design or process parameters and are not directly tested. These parameters are characterized upon initial design and after major process and/or design changes.

TABLE 4. APPLICABLE SUBGROUPS

| CONFORMANCE GROUPS | METHOD | SUBGROUPS |
| :--- | :---: | :---: |
| Initial Test | $100 \% / 5004$ | - |
| Interim Test | $100 \% / 5004$ | - |
| PDA | $100 \%$ | 1 |
| Final Test | $100 \%$ | $2,3,8 \mathrm{~A}, 8 \mathrm{~B}, 10,11$ |
| Group A | - | $1,2,3,7,8 \mathrm{~A}, 8 \mathrm{~B}, 9,10,11$ |
| Groups C \& D | Samples/5005 | $1,7,9$ |

## Burn-In Circuit



| $\begin{aligned} & \text { PGA } \\ & \text { PIN } \end{aligned}$ | PIN NAME | BURN-IN SIGNAL | $\begin{aligned} & \text { PGA } \\ & \text { PIN } \end{aligned}$ | PIN NAME | BURN-IN SIGNAL | PGA <br> PIN | PIN NAME | BURN-IN SIGNAL | PGA <br> PIN | PIN NAME | BURN-IN SIGNAL |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| B6 | X6 | F1 | F1 | Y9/P9 | F2 | K7 | P26 | $\mathrm{V}_{\mathrm{CC}} / 2$ | E11 | ACC | F1 |
| A6 | X5 | F2 | G2 | Y10/P10 | F3 | L7 | P27 | $\mathrm{V}_{\mathrm{CC}} / 2$ | D10 | SUB | F2 |
| B5 | X4 | F3 | G1 | Y11/P11 | F5 | K8 | P28 | $\mathrm{V}_{\mathrm{CC}} / 2$ | D11 | RND | F3 |
| A5 | X3 | F4 | H2 | Y12/P12 | F4 | L8 | P29 | $\mathrm{V}_{\mathrm{CC} / 2}$ | C10 | $\overline{\text { OEL }}$ | $\mathrm{V}_{\mathrm{CC}}$ |
| B4 | X2 | F5 | H1 | Y13/P13 | F4 | K9 | P30 | $\mathrm{V}_{\mathrm{CC}} / 2$ | C11 | X15 | F8 |
| A4 | X1 | F6 | J2 | Y14/P14 | F8 | L9 | P31 | $\mathrm{V}_{\mathrm{CC}} / 2$ | B10 | X14 | F9 |
| B3 | X0 | F7 | J1 | Y15/P15 | F9 | K10 | P32 | $\mathrm{V}_{\mathrm{CC}} / 2$ | A10 | X13 | F10 |
| A3 | YO/PO | F8 | K2 | P16 | $\mathrm{VCC} / 2$ | K11 | P33 | $\mathrm{V}_{\mathrm{CC}} / 2$ | B9 | X12 | F11 |
| B2 | Y1/P1 | F9 | L2 | P17 | $\mathrm{V}_{\mathrm{CC}} / 2$ | J10 | P34 | $\mathrm{V}_{\mathrm{CC} / 2}$ | A9 | X11 | F12 |
| B1 | Y2/P2 | F10 | K3 | P18 | $\mathrm{V}_{\mathrm{CC}} / 2$ | 511 | CLKP | FO | B8 | X10 | F13 |
| C 2 | Y3/P3 | F11 | L3 | P19 | $\mathrm{V}_{\mathrm{Cc}} / 2$ | H10 | $\overline{\text { OEM }}$ | GND | A8 | X9 | F14 |
| C1 | Y4/P4 | F12 | K4 | P20 | $\mathrm{V}_{\mathrm{CC}} / 2$ | H11 | PREL | F6 | B7 | X8 | F15 |
| D2 | Y5/P5 | F13 | L4 | P21 | $\mathrm{V}_{\mathrm{CC}} / 2$ | G10 | $\overline{\text { OEX }}$ | GND | A7 | X7 | F7 |
| D1 | Y6/P6 | F14 | K5 | P22 | $\mathrm{VCC} / 2$ | G11 | TC | F5 | A2 | N.C. | N.C. |
| E2 | Y7/P7 | F15 | L5 | P23 | $\mathrm{V}_{\mathrm{CC}} / 2$ | F10 | $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ | K1 | N.C. | N.C. |
| E1 | GND | GND | K6 | P24 | $\mathrm{V}_{\mathrm{CC}} / 2$ | F11 | CLKY | FO | 110 | N.C. | N.C. |
| F2 | Y8/P8 | F1 | L6 | P25 | $\mathrm{V}_{\mathrm{CC}} / 2$ | E10 | CLKX | FO | B11 | N.C. | N.C. |

NOTES:

1. $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}+0.5 \mathrm{~V} /-0.0 \mathrm{~V}$ with $0.1 \mu \mathrm{~F}$ decoupling capacitor to GND
2. $F O=100 \mathrm{kHz}, F 1=F 0 / 2, F 2=F 1 / 2$, ., 10\%
3. $V_{I H}=V_{C C}-1 V \pm 0.5 V(\mathrm{Min}), V_{I L}=0.8 V$ (Max)
4. $47 \mathrm{k} \Omega$ load resistors used on all pins except $\mathrm{V}_{\mathrm{CC}}$ and GND (Pin-Grid identifiers F10, G10, G11 and H11)

## Die Characteristics

DIE DIMENSIONS:
$184 \times 176 \times 19 \pm 1$ mils
METALLIZATION:
Type: $\mathrm{Si}-\mathrm{Al}$ or $\mathrm{Si}-\mathrm{Al}-\mathrm{Cu}$
Thickness: $8 \mathrm{k} \AA$
GLASSIVATION:
Type: Nitrox
Thickness: 10kÅ
Metallization Mask Layout

DIE ATTACH:
Material: $\mathrm{Si}-\mathrm{Au}$ Eutectic Alloy or Silver-Glass
WORST CASE CURRENT DENSITY: $0.9 \times 10^{5} \mathrm{~A} / \mathrm{cm}^{2}$


## Features

- $16 \times 16$-Bit Parallel Multiplier with Full 32-Bit Product
- High-Speed (35ns) Clocked Multiply Time
- Low Power Operation:
- ICCSB $=500 \mu \mathrm{~A}$ Maximum
- ICCOP $=7.0 \mathrm{~mA}$ Maximum $@ 1 \mathrm{MHz}$
- Supports Two's Complement, Unsigned Magnitude and Mixed Mode Multiplication
- HMU16 is Compatible with the AM29516, LMU16, IDT7216 and the CY7C516
- HMU17 is Compatible with the AM29517, LMU17, IDT7217 and the CY7C517
- TTL Compatible Inputs/Outputs
- Three-State Outputs
- Available in a Ceramic 68 Pin Grid Array (PGA) and 68 Pin Plastic Leaded Chip Carrier (PLCC)


## Applications

- Fast Fourier Transform Analysis
- Digital Filtering
- Graphic Display Systems
- Image Processing
- Radar and Sonar
- Speech Synthesis and Recognition


## Description

The HMU16/HMU17 are high speed, low power CMOS $16 \times 16$-bit multipliers ideal for fast, real time digital signal processing applications.
The $X$ and $Y$ operands along with their mode controls (TCX and TCY) have 17-bit input registers. The mode controls independently specify the operands as either two's complement or unsigned magnitude format, thereby allowing mixed mode multiplication operations.

Two 16-bit output registers are provided to hold the most and least significant halves of the result (MSP and LSP). For asynchronous output these registers may be made transparent through the use of the feedthrough control (FT).

Additional inputs are provided for format adjustment and rounding. The format adjust control (FA) allows the user to select either a left shifted 31-bit product or a full 32-bit product, whereas the round control (RND) provides the capability of rounding the most significant portion of the result.

The HMU16 has independent clocks (CLKX, CLKY, CLKL, CLKM) associated with each of these registers to maximize throughput and simplify bus interfacing. The HMU17 has only a single clock input (CLK), but makes use of three register enables (ENX, $\overline{E N Y}$ and $\overline{E N P}$ ). The $\overline{E N X}$ and $\overline{E N Y}$ inputs control the $X$ and $Y$ input registers, while ENP controls both the MSP and LSP output registers. This configuration facilitates the use of the HMU17 for microprogrammed systems.

The two halves of the product may be routed to a single 16-bit three-state output port via a multiplexer, and in addition, the LSP is connected to the Y -input port through a separate three-state buffer.

All outputs of the HMU16/HMU17 multipliers also offer threestate control for multiplexing results onto multi-use busses.


68 PIN PLASTIC LEADED CHIP CARRIER (PLCC)
TOP VIEW


## Functional Block Diagram



HMU17


P16-31/P0-15

## Pin Description

| SYMBOL | PLCC PIN NUMBER | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ | 1,68 |  | $\mathrm{V}_{\mathrm{CC}}$. The +5 V power supply pins. $\mathrm{A} 0.1 \mu \mathrm{~F}$ capacitor between the $\mathrm{V}_{\mathrm{CC}}$ and GND pins is recommended. |
| GND | 2,3 |  | GND. The device ground. |
| X0-X15 | 47-59, 61-63 | 1 | X-Input Data. These 16 data inputs provide the multiplicand which may be in two's complement or unsigned magnitude format. |
| $\begin{aligned} & \mathrm{YO}-\mathrm{Y} 15 / \\ & \mathrm{PO} \mathrm{P} 15 \end{aligned}$ | 27-42 | 1/0 | Y-Input/LSP Output Data. This 16-Bit port is used to provide the multiplier which may be in two's complement or unsigned magnitude format. It may also be used for output of the Least Significant Product (LSP). |
| $\begin{aligned} & \text { P16-P31/ } \\ & \text { P0-P15 } \end{aligned}$ | 10-25 | 0 | Output Data. This 16-Bit port may provide either the MSP (P16-31) or the LSP (PO-15). |
| TCY, TCX | 66,67 | 1 | Two's Complement Control. Input data is interpreted as two's complement when this control is HIGH. A LOW indicates the data is to be interpreted as unsigned magnitude format. |
| FT | 5 | 1 | Feedthrough Control. When this control is HIGH, both the MSP and LSP registers are transparent. When LOW, the registers are latched by their associated clock signals. |
| FA | 6 | 1 | Format Adjust Control. A full 32-bit product is selected when this control line is HIGH. A LOW on this control line selects a left shifted 31-bit product with the sign bit replicated in the LSP. This control is normally HIGH except for certain two's complement integer and fractional applications. |
| RND | 65 | 1 | Round Control. When this control is HIGH, a one is added to the Most Significant Bit (MSB) of the LSP. This position is dependent on the FA control; FA $=$ HIGH indicates RND adds to the 2-15 bit (P15), and FA = LOW indicates RND adds to the $2^{-16}$ bit (P14). |
| $\overline{\text { MSPSEL }}$ | 4 | 1 | Output Multiplexer Control. When this control is LOW, the MSP is available for output at the dedicated output port, and the LSP is available at the Y -input/LSP output port. When MSPSEL is HIGH, the LSP is available at both ports and the MSP is not available for output. |
| $\overline{O E L}$ | 46 | 1 | $\mathrm{Y}-\ln / \mathrm{PO}-15$ Output Port Three-state Control. When $\overline{\mathrm{OEL}}$ is HIGH, the output drivers are in the high impedance state. This state is required for $Y$-data input. When $\overline{O E L}$ is LOW, the port is enabled for LSP output. |
| $\overline{\mathrm{OEP}}$ | 7 | 1 | P16-31/P0-15 Output Port Three-state Control. A LOW on this control line enables the output port. When $\overline{\mathrm{OEP}}$ is HIGH, the output drivers are in the high impedance state. |
| The following Pin Descriptions apply to the HMU16 only. |  |  |  |
| CLKX | 64 | 1 | X-Register Clock. The rising edge of this clock loads the X-data input register along with the TCX and RND registers. |
| CLKY | 44 | 1 | Y-Register Clock. The rising edge of this clock loads the Y -data input register along with the TCY and RND registers. |
| CLKM | 8 | 1 | MSP Register Clock. The rising edge of CLKM loads the most significant product (MSP) register. |
| CLKL | 45 | 1 | LSP Register Clock. The rising edge of CLKL loads the least significant product (LSP) register. |
| The following Pin Descriptions apply to the HMU17 only. |  |  |  |
| CLK | 45 | 1 | Clock. The rising edge of this clock will load all enabled registers. |
| $\overline{\mathrm{ENX}}$ | 64 | I | X-Register Enable. When ENX is LOW, the X-register is enabled; X-input data and TCX will be latched at the rising edge of CLK. When $\overline{\mathrm{ENX}}$ is high, the $X$-register is in a hold mode. |
| ENY | 44 | 1 | Y-Register Enable. $\overline{\mathrm{ENY}}$ enables the Y -register. (See $\overline{\mathrm{ENX}}$ ). |
| $\overline{\text { ENP }}$ | 8 | 1 | Product Register Enable. $\overline{\text { ENP }}$ enables the product register. Both the MSP and LSP sections are enabled by $\overline{\mathrm{ENP}}$. (See $\overline{\mathrm{ENX}}$ ). |

## Functional Description

The HMU16/HMU17 are high speed $16 \times 16$-bit multipliers designed to perform very fast multiplication of two 16-bit binary numbers. The two 16-bit operands ( $X$ and $Y$ ) may be independently specified as either two's complement or unsigned magnitude format by the two's complement controls (TCX and TCY). When either of these control lines is LOW, the respective operand is treated as an unsigned 16-bit value; and when it is HIGH, the operand is treated as a signed value represented in two's complement format. The operands along with their respective controls are latched at the rising edge of the associated clock signal. The HMU16 accomplishes this through the use of independent clock inputs for each of the input registers (CLKX and CLKY), while the HMU17 utilizes a single clock signal (CLK) along with the $X$ and $Y$ register enable inputs (ENX and ENY).

Input controls are also provided for rounding and format adjustment of the 32-bit product. The Round input (RND) is provided to accomodate rounding of the most significant portion of the product by adding one to the Most Significant Bit (MSB) of the LSP register. The position of the MSB is dependent on the state of the Format Adjust Control (See Pin Descriptions and Multiplier Input/Output Format Tables). The Round input is latched into the RND register whenever either of the input registers is clocked. The Format Adjust control ( $\overline{\mathrm{FA}})$ allows the product output to be formatted. When the $\overline{F A}$ control is HIGH, a full 32-bit product is output; and when $\overline{F A}$ is LOW, a left-shifted 31-bit product is output with the sign bit replicated in bit position 15 of the LSP. The $\overline{F A}$ control must be HIGH for unsigned magnitude, and mixed mode multiplication
operations. It may be LOW for certain two's complement integer and fractional operations only (See Multiplier Input/ Output Formats Table).

The HMU16/HMU17 multipliers are equipped with two 16-bit output registers (MSP and LSP) which are provided to hold the most and least significant portions of the resultant product respectively. The HMU16 uses independent clocks (CLKM and CLKL) for latching the two output registers, while the HMU17 uses a single clock input (CLK) along with the Product Latch Enable (ENP). The MSP and LSP registers may also be made transparent for asynchronous output through the use of the Feedthrough control (FT).

There are two output configurations which may be selected when using the HMU16/HMU17 multipliers. The first configuration allows the simultaneous access of the most and least significant halves of the product. When the MSPSEL input is LOW, the Most Significant Product will be available at the dedicated output port (P16-31/PO-15). The Least Significant Product is simultaneously available at the bi-directional port shared with the Y -inputs (YO-15/PO-15) through the use of the LSP output enable ( $\overline{\mathrm{OEL}})$. The other output configuration involves multiplexing the MSP and LSP registers onto the dedicated output port through the use of the MSPSEL control. When the MSPSEL control is LOW, the Most Significant Product will be available at the dedicated output port; and when MSPSEL is HIGH, the Least Significant Product will be available at this port. This configuration allows access of the entire 32-bit product by a 16 -bit wide system bus.

## Multiplier Input/Output Formats Table

FRACTIONAL TWO'S COMPLEMENT NOTATION


* In this format an overflow occurs in the attempted multiplication of the two's complement number $1,000 \ldots 0$ with $1,000 \ldots 0$ yielding an erroneous product of -1 in the fraction case and $-2^{30}$ in the integer case.

FRACTIONAL UNSIGNED MAGNITUDE NOTATION


FRACTIONAL MIXED MODE NOTATION


## Multiplier Input/Output Formats Table (Continued)

INTEGER TWO'S COMPLEMENT NOTATION


* In this format an overflow occurs in the attempted multiplication of the two's complement number 1,000 $\qquad$ with $1,000 \ldots 0$ yielding an erroneous product of -1 in the fraction case and -230 in the integer case.

INTEGER UNSIGNED MAGNITUDE NOTATION


INTEGER MIXED MODE NOTATION


## Absolute Maximum Ratings

| Supply Voltage | +8.0 Volts |
| :---: | :---: |
| Input, Output or I/O Voltage Applied | GND-0.5V to $\mathrm{V}_{\mathrm{CC}}+0.5 \mathrm{~V}$ |
| Storage Temperature Range | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Gate Count | 4500 Gates |
| $\theta_{\text {ja }}$ | $43.2{ }^{\circ} \mathrm{C} / \mathrm{W}$ (PLCC), $42.69^{\circ} \mathrm{C} / \mathrm{W}$ (PGA) |
|  | $15.1{ }^{\circ} \mathrm{C} / \mathrm{W}$ (PLCC), $10.0^{\circ} \mathrm{C} / \mathrm{W}$ (PGA) |
| Maximum Package Power Dissipation at $70^{\circ} \mathrm{C}$ | .. 1.7W (PLCC), 2.46 (PGA) |
| Junction Temperature | $+150^{\circ} \mathrm{C}$ (PLCC), $+175^{\circ} \mathrm{C}$ (PGA) |
| Lead Temperature (Soldering, Ten Seconds) | $\ldots+300^{\circ} \mathrm{C}$ |
| CAUTION: Stresses above those listed in the "Absol and operation at these or any other conditions abov | age to the device. This is a stress only rating, specification is not implied. |

## Operating Conditions

$$
\begin{aligned}
& \text { Operating Voltage Range } \\
& +4.75 \mathrm{~V} \text { to }+5.25 \mathrm{~V} \\
& \text { Operating Temperature Range } \\
& 0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C}
\end{aligned}
$$

D.C. Electrical Specifications ( $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}+5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{IH}}$ | Logical One Input Voltage | 2.0 | - | V | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{IL}}$ | Logical Zero Input Voltage | - | 0.8 | $v$ | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.6 | - | v | $\mathrm{I}^{\circ} \mathrm{OH}=-400 \mu \mathrm{~A}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| VOL | Output Low Voltage | - | 0.4 | V | $\mathrm{I}_{\mathrm{OL}}=+4.0 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| 1 | Input Leakage Current | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{I}}=\mathrm{V}_{\mathrm{CC}}$ or $\mathrm{GND}, \mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| 10 | Output or I/O Leakage Current | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{O}}=\mathrm{V}_{\mathrm{CC}}$ or GND, $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| ${ }^{\text {I CCsB }}$ | Standby Power Supply Current | - | 500 | $\mu \mathrm{A}$ | $V_{1}=V_{C C} \text { or } G N D, V_{C C}=5.25 V$ Outputs Open |
| ICCOP | Operating Power Supply Current | - | 7.0 | mA | $\begin{aligned} & V_{1}=V_{C C} \text { or } G N D, V_{C C}=5.25 \mathrm{~V} \\ & f=1 \mathrm{MHz}(\text { Note } 1) \end{aligned}$ |

Capacitance ( $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$, Note 2)

| SYMBOL | PARAMETER | TYPICAL | UNITS | TEST CONDITIONS |
| :---: | :--- | :---: | :---: | :--- |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance | 15 | pF | Frequency $=1 \mathrm{MHz}$. <br> All measurements referenced <br> to device Ground. |
| COUT $^{C_{I / O}}$ | Output Capacitance | I/O Capacitance | 10 | pF |

## notes:

1. Operating Supply Current is proportional to frequency, Typical rating is $5 \mathrm{~mA} / \mathrm{MHz}$.
2. Not tested, but characterized at initial design and at major process/ design changes.
A.C. Electrical Specifications $\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}+5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $+70^{\circ} \mathrm{C}$, Note 3)

| SYMBOL | PARAMETER | HMU16/HMU17-35 |  | HMU16/HMU17-45 |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |  |  |
| TMUC | Unclocked Multiply Time | - | 55 | - | 70 | ns |  |
| TMC | Clocked Multiply Time | - | 35 | - | 45 | ns |  |
| TS | X, Y, RND Setup Time | 15 | - | 18 | - | ns |  |
| $\mathrm{T}_{\mathrm{H}}$ | X, Y, RND Hold Time | 2 | - | 2 | - | ns |  |
| TPWH | Clock Pulse Width High | 10 | - | 15 | - | ns |  |
| TPWL | Clock Pulse Width Low | 10 | - | 15 | - | ns |  |
| TPDSEL | $\overline{\text { MSPSEL }}$ to Product Out | - | 22 | - | 25 | ns |  |
| TPDP | Output Clock to P | - | 22 | - | 25 | ns |  |
| TPDY | Output Clock to Y | - | 22 | - | 25 | ns |  |
| TENA | 3-State Enable Time | - | 22 | - | 25 | ns | Note 1 |
| TDIS | 3-State Disable Time | - | 22 | - | 25 | ns |  |
| TSE | Clock Enable Setup Time (HMU17 only) | 15 | - | 15 | - | ns |  |
| THE | Clock Enable Hold Time (HMU17 only) | 2 | - | 2 | - | ns |  |
| THCL | Clock Low Hold Time CLKXY Relative to CLKML (HMU16 only) | 0 | - | 0 | - | ns | Note 2 |
| $\mathrm{T}_{\mathrm{R}}$ | Output Rise Time | - | 8 | - | 8 | ns | From 0.8 V to 2.0 V |
| $\mathrm{T}_{\mathrm{F}}$ | Output Fall Time | - | 8 | - | 8 | ns | From 2.0 V to 0.8 V |

NOTES:

1. Transition is measured at $\pm 200 \mathrm{mV}$ from steady state voltage with loading $\quad$ 3. Refer to A.C. Test Circuit, with $V_{1}=2.4 \mathrm{~V}, \mathrm{R}_{1}=500 \Omega$ and $\mathrm{C}_{1}=40 \mathrm{pF}$ specified in A.C. Test Circuit, $\mathrm{V}_{1}=1.5 \mathrm{~V}, \mathrm{R}_{1}=500 \Omega$ and $\mathrm{C}_{1}=40 \mathrm{pF}$
2. To ensure the correct product is entered in the output registers, new data may not be entered into the input registers before the output registers have been clocked.

## A.C. Test Circuit



* Includes Stray and Jig Capacitance
A.C. Testing Input, Output Waveforms

A.C. Testing: All parameters tested as per test circuit. Input rise and fall times are driven at $1 \mathrm{~ns} / \mathrm{V}$.


## Timing Diagram



THREE STATE CONTROL


HMU17 TIMING DIAGRAM


## Features

- This Circuit is Processed in Accordance to Mil-Std883 and is Fully Conformant Under the Provisions of Paragraph 1.2.1.
- $16 \times 16$-Bit Parallel Multiplier with Full 32-Bit Product
- High-Speed (45ns) Clocked Multiply Time
- Low Power CMOS Operation:
- $\operatorname{ICCSB}=500 \mu \mathrm{~A}$ Maximum
- ICCOP $=7.0 \mathrm{~mA}$ Maximum @ 1 MHz
- HMU16 is compatible with the AM29516, LMU16, IDT7216, and the CY7C516
- Supports Two's Complement, Unsigned Magnitude and Mixed Mode Multiplication
- TTL Compatible Inputs/Outputs
- Three-State Outputs
- Available in a 68 Lead Pin Grid Array Package


## Description

The HMU16 is a high speed, low power CMOS $16 \times 16$-bit parallel multiplier ideal for fast, real time digital signal processing applications. The 16 -bit X and Y operands may be independently specified as either two's complement or unsigned magnitude format, thereby allowing mixed mode multiplication operations.

Additional inputs are provided to accommodate format adjustment and rounding of the 32-bit product. The Format Adjust control allows the user to select a 31-bit product with the sign bit replicated in the LSP. The Round control provides for rounding the most significant portion of the result by adding one to the most significant bit of the LSP.

Two 16-bit output registers (MSP and LSP) are provided to hold the most and least significant portions of the result, respectively. These registers may be made transparent for asynchronous operation through the use of the feedthrough control (FT). The two halves of the product may be routed to a single 16-bit three-state output port via the output multiplexer control, and in addition, the LSP is connected to the Y -input port through a separate three-state buffer.
The HMU16 utilizes independent clock signals (CLKX, CLKY, CLKL, CLKM) to latch the input operands and output product registers. This configuration maximizes throughput and simplifies bus interfacing. All outputs of the HMU16 also offer three-state control for multiplexing onto multi-use system busses.

## Functional Diagram



## Absolute Maximum Ratings

Supply Voltage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8.0 ov
Input or Output Voltage Applied GND-0.5V to $\mathrm{V}_{\mathrm{CC}}+0.5 \mathrm{~V}$
Storage Temperature Range . . . . . . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Junction Temperature . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $+175^{\circ} \mathrm{C}$
Lead Temperature (Soldering 10 sec ) . . . . . . . . . . . . . . . . . . . . $300^{\circ} \mathrm{C}$
ESD Classification . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Class 1
CAUTION: Stresses above those listed in "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.

## Operating Conditions

Operating Voltage Range . . . . . . . . . . . . . . . . . . . . . . . +4.5 V to +5.5 V
Operating Temperature Range $\ldots \ldots \ldots \ldots \ldots . . .55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
TABLE 1. HMU16/883 D.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and $100 \%$ Tested

| PARAMETER | SYMBOL | CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| Logical One Input Voltage | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 2.2 | - | V |
| Logical Zero Input Voltage | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 0.8 | V |
| Output HIGH Voltage | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & \mathrm{IOH}=-400 \mu \mathrm{~A} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}(\text { Note } 1) \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 2.6 | - | V |
| Output LOW Voltage | $\mathrm{V}_{\mathrm{OL}}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OL}}=+4.0 \mathrm{~mA} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}(\text { Note } 1) \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}^{\prime} \leq+125^{\circ} \mathrm{C}$ | - | 0.4 | V |
| Input Leakage Current | I | $\begin{aligned} & V_{I N}=V_{C C} \text { or } G N D \\ & V_{C C}=5.5 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Output or I/O Leakage Current | 10 | $\begin{aligned} & \mathrm{V}_{\mathrm{OUT}}=\mathrm{V}_{\mathrm{CC}} \text { or } \mathrm{GND} \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Standby Power Supply Current | ${ }^{\prime} \mathrm{CCSB}$ | $\mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}$ or GND , <br> $V_{C C}=5.5 \mathrm{~V}$, Outputs <br> Open | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 500 | $\mu \mathrm{A}$ |
| Operating Power Supply Current | ICCOP | $\begin{aligned} & f=1.0 \mathrm{MHz}, \\ & \mathrm{~V}_{\text {IN }}=\mathrm{V}_{\mathrm{CC}} \text { or GND } \\ & \mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V} \text { (Note 2) } \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125{ }^{\circ} \mathrm{C}$ | - | 7.0 | mA |
| Functional Test | FT | (Note 3) | 7, 8 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | - |  |

NOTES:

1. Interchanging of force and sense conditions is permitted.
2. Operating Supply Current is proportional to frequency, typical rating is $5 \mathrm{~mA} / \mathrm{MHz}$.

## Reliability Information

Thermal Resistance $\theta_{\mathrm{ja}} \quad \theta_{\mathrm{jc}}$

TABLE 2. HMU16/883 A.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and 100\% Tested

| PARAMETER | SYMBOL | (NOTE 1) CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | -45 |  | -60 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| Unclocked Multiply Time | TMUC |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 70 | - | 90 | ns |
| Clocked Multiply Time | $\mathrm{T}_{\mathrm{MC}}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 45 | - | 60 | ns |
| X, Y, RND Setup Time | $\mathrm{T}_{\mathrm{S}}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | 18 | - | 20 | - | ns |
| Clock HIGH Pulse Width | TPWH |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 15 | - | 20 | - | ns |
| Clock LOW Pulse Width | TPWL |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 15 | - | 20 | - | ns |
| MSPSEL to Product Out | TPDSEL |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 25 | - | 30 | ns |
| Output Clock to P | TPDP |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 25 | - | 30 | ns |
| Output Clock to $Y$ | TPDY |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | - | 25 | - | 30 | ns |
| 3-State Enable Time | TENA | (Note 2) | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 25 | - | 30 | ns |
| Clock Low Hold Time CLKXY Relative to CLKML | THCL | (Note 3) | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \top \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns |

NOTES:

1. AC Testing as follows: $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and 5.5 V . Input levels OV and 3.0 V , Timing reference levels $=1.5 \mathrm{~V}$, Output load per test load circuit, with $\mathrm{V}_{1}=$ $2.4 \mathrm{~V}, \mathrm{R}_{1}=500 \Omega$ and $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$.
2. Transition is measured at $\pm 200 \mathrm{mV}$ from steady state voltage, Output loading per test load circuit, with $\mathrm{V}_{1}=1.5 \mathrm{~V}, \mathrm{R}_{1}=500 \Omega$ and $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$.
3. To ensure the correct product is entered in the output registers, new data may not be entered into the input registers before the output registers have been clocked.

TABLE 3. HMU16/883 ELECTRICAL PERFORMANCE CHARACTERISTICS

| PARAMETER | SYMBOL | CONDITIONS | NOTES | TEMPERATURE | -45 |  | -60 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| Input Capacitance | $\mathrm{CIN}^{\text {N }}$ | $V_{C C}=\text { Open, } f=1 \mathrm{MHz}$ <br> All Measurements are referenced to device GND. | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 15 | - | 15 | pF |
| Output Capacitance | COUT |  | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 10 | - | 10 | pF |
| I/O Capacitance | $\mathrm{Cl}_{1 / \mathrm{O}}$ |  | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 10 | - | 10 | pF |
| X, Y, RND Hold Time | $\mathrm{TH}_{\mathrm{H}}$ |  | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 3 | - | 3 | - | ns |
| 3-State Disable Time | TDIS |  | 1,2,3 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 25 | - | 30 | ns |
| Output Rise Time | $T_{R}$ | From 0.8 V to 2.0 V | 1,2,4 | $-55^{\circ} \mathrm{C} \leq \top \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 10 | - | 10 | ns |
| Output Fall Time | $\mathrm{T}_{\mathrm{F}}$ | From 2.0 V to 0.8 V | 1,2,4 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 10 | - | 10 | ns |

NOTES: 1. The parameters listed in table 3 are controlled via design or process parameters and are not directly tested. These parameters are characterized upon initial design and after major process and/or design changes.
2. Guaranteed, but not $100 \%$ tested.
3. Transition is measured at $\pm 200 \mathrm{mV}$ from steady state voltage, Output loading per test load circuit, with $\mathrm{V}_{1}=1.5 \mathrm{~V}, \mathrm{R}_{1}=500 \Omega$ and $C_{L}=40 \mathrm{pF}$.
4. Loading is as specified in the test load circuit, with $\mathrm{V}_{1}=2.4 \mathrm{~V}$, $R_{1}=500 \Omega$ and $C_{L}=40 \mathrm{pF}$.

TABLE 4. APPLICABLE SUBGROUPS

| CONFORMANCE GROUPS | METHOD | SUBGROUPS |
| :--- | :---: | :---: |
| Initial Test | $100 \% / 5004$ | - |
| Interim Test | $100 \% / 5004$ | - |
| PDA | $100 \%$ | 1 |
| Final Test | $100 \%$ | $2,3,8 \mathrm{~A}, 8 \mathrm{~B}, 10,11$ |
| Group A | - | $1,2,3,7,8 \mathrm{~A}, 8 \mathrm{~B}, 9,10,11$ |
| Groups C \& D | Samples $/ 5005$ | $1,7,9$ |

Burn-In Circuit


| $\begin{aligned} & \text { PGA } \\ & \text { PIN } \end{aligned}$ | $\begin{gathered} \text { PIN } \\ \text { NAME } \end{gathered}$ | BURN-IN SIGNAL | $\begin{aligned} & \text { PGA } \\ & \text { PIN } \end{aligned}$ | $\begin{gathered} \text { PIN } \\ \text { NAME } \end{gathered}$ | BURN-IN SIGNAL | $\begin{aligned} & \text { PGA } \\ & \text { PIN } \end{aligned}$ | PIN NAME | BURN-IN SIGNAL | $\begin{aligned} & \text { PGA } \\ & \text { PIN } \end{aligned}$ | $\begin{aligned} & \text { PIN } \\ & \text { NAME } \end{aligned}$ | BURN-IN SIGNAL |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| B6 | X4 | F6 | F1 | Y9/P9 | F11 | K7 | P10/P26 | $\mathrm{V}_{\mathrm{CC} / 2}$ | E11 | RND | F1 |
| A6 | X3 | F5 | G2 | Y10/P10 | F12 | L7 | P11/P27 | $\mathrm{V}_{\mathrm{CC}} / 2$ | D10 | CLKX | FO |
| B5 | X2 | F4 | G1 | Y11/P11 | F13 | K8 | P12/P28 | $\mathrm{V}_{\mathrm{CC} / 2}$ | D11 | X15 | F3 |
| A5 | X1 | F3 | H2 | Y12/P12 | F14 | L8 | P13/P29 | $\mathrm{V}_{\mathrm{CC} / 2}$ | C10 | X14 | F2 |
| B4 | xo | F2 | H1 | Y13/P13 | F15 | K9 | P14/P30 | $\mathrm{v}_{\mathrm{CC} / 2}$ | C11 | X13 | F15 |
| A4 | OEL | $\mathrm{V}_{\mathrm{CC}}$ | J2 | Y14/P14 | F4 | L9 | P15/P31 | $\mathrm{v}_{\mathrm{CC}} / 2$ | B10 | X12 | F14 |
| B3 | CLKL | FO | J1 | Y15/P15 | F5 | K10 | CLKM | FO | A10 | X11 | F13 |
| A3 | CLKY | FO | K2 | P0/P16 | $\mathrm{v}_{\mathrm{CC} / 2}$ | K11 | $\overline{\text { OEP }}$ | F1 | B9 | X10 | F12 |
| B2 | YO/PO | F2 | L2 | P1/P17 | $\mathrm{v}_{\mathrm{CC} / 2}$ | J10 | $\stackrel{F}{F A}$ | F14 | A9 | X9 | F11 |
| B1 | Y1/P1 | F3 | K3 | P2/P18 | $\mathrm{V}_{\mathrm{CC}} / 2$ | J11 | FT | F15 | B8 | X8 | F10 |
| C2 | Y2/P2 | F4 | L3 | P3/P19 | $\mathrm{v}_{\mathrm{CC} / 2}$ | H10 | MSPSEL | F14 | A8 | X7 | F9 |
| C1 | Y3/P3 | F5 | K4 | P4/P20 | $\mathrm{v}_{\mathrm{CC}} / 2$ | H11 | GND | GND | B7 | X6 | F8 |
| D2 | Y4/P4 | F6 | L4 | P5/P21 | $\mathrm{v}_{\mathrm{CC} / 2}$ | G10 | GND | GND | A7 | X5 | F7 |
| D1 | Y5/P5 | F7 | K5 | P6/P22 | $\mathrm{v}_{\mathrm{CC}} / 2$ | G11 | $V_{C C}$ | $V_{C C}$ | A2 | N.C. | NONE |
| E2 | Y6/P6 | F8 | L5 | P7/P23 | $\mathrm{v}_{\mathrm{CC}} / 2$ | F10 | $\mathrm{V}_{\mathrm{CC}}$ | $V_{C C}$ | K1 | N.C. | NONE |
| E1 | Y7/P7 | F9 | K6 | P8/P24 | $\mathrm{v}_{\mathrm{CC} / 2}$ | F11 | TCY | F15 | L10 | N.C. | NONE |
| F2 | Y8/P8 | F10 | L6 | P9/P25 | $\mathrm{v}_{\mathrm{CC} / 2}$ | E10 | TCX | F15 | B11 | N.C. | NONE |

NOTES:

1. $V_{C C}=5.0 \mathrm{~V}+0.5 \mathrm{~V} /-0.0 \mathrm{~V}$ with $0.1 \mu \mathrm{~F}$ decoupling capacitor to GND.
2. $F O=100 \mathrm{kHz}, F 1=F O / 2, F 2=F 1 / 2$,
3. $V_{I H}=V_{C C}-1 V \pm 0.5 \mathrm{~V}(\mathrm{Min}), \mathrm{V}_{\mathrm{IL}}=0.8 \mathrm{~V}(\mathrm{Max})$
4. $47 \mathrm{k} \Omega$ load resistors used on all pins except $\mathrm{V}_{\mathrm{CC}}$ and GND (Pin-Grid identifiers F10, G10, G11 and H11).

## Die Characteristics

DIE DIMENSIONS:
$179 \times 169 \times 19 \pm 1 \mathrm{mils}$
METALLIZATION:
Type: $\mathrm{Si}-\mathrm{Al}$ or $\mathrm{Si}-\mathrm{Al}-\mathrm{Cu}$
Thickness: $8 \mathrm{k} \AA$
GLASSIVATION:
Type: Nitrox
Thickness: 10k $\AA$
Metallization Mask Layout

## DIE ATTACH:

Material: Si-Au Eutectic Alloy or Silver-Glass
WORST CASE CURRENT DENSITY: $1.2 \times 10^{5} \mathrm{~A} / \mathrm{cm}^{2}$


## Features

- This Circuit is Processed in Accordance to Mil-Std-883 and is Fully Conformant Under the Provisions of Paragraph 1.2.1.
- $16 \times 16$-Bit Parallel Multiplier with Full 32-Bit Product
- High-Speed (45ns) Clocked Multiply Time
- Low Power CMOS Operation:
- $\operatorname{ICCSB}=500 \mu \mathrm{~A}$ Maximum
- ICCOP $=7.0 \mathrm{~mA}$ Maximum @ 1 MHz
- HMU17 is compatible with the AM29517, LMU17, IDT7217, and the CY7C517
- Supports Two's Complement, Unsigned Magnitude and Mixed Mode Multiplication
- TTL Compatible Inputs/Outputs
- Three-State Outputs
- Available in a 68 Lead Pin Grid Array Package


## Description

The HMU17 is a high speed, low power CMOS $16 \times 16$-bit parallel multiplier ideal for fast, real time digital signal processing applications. The 16 -bit $X$ and $Y$ operands may be independently specified as either two's complement or unsigned magnitude format, thereby allowing mixed mode multiplication operations.

Additional inputs are provided to accommodate format adjustment and rounding of the 32-bit product. The Format Adjust control allows the user the option of selecting a 31-bit product with the sign bit replicated LSP. The Round control is provided to accommodate rounding of the most significant portion of the result. This is accomplished by adding one to the most significant bit of the LSP.
Two 16-bit output registers (MSP and LSP) are provided to hold the most and least significant portions of the result, respectively. These registers may be made transparent for asynchronous operation through the use of the feedthrough control (FT). The two halves of the product may be routed to a single 16-bit three-state output port via the output multiplexer control, and in addition, the LSP is connected to the Y -input port through a separate three-state buffer.

The HMU17 utilizes a single clock signal (CLK) along with three register enables (ENX, ENY, and ENP) to latch the input operands and the output product registers. The ENX and ENY inputs enable the $X$ and $Y$ input registers, while ENP enables both the LSP and MSP output registers. This configuration facilitates the use of the HMU17 for micro-programmed systems.
All outputs of the HMU17 also offer three-state control for multiplexing onto multi-use system busses.

Functional Diagram


## Absolute Maximum Ratings

| Supply Voltage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . +8.8 OV |  |
| :---: | :---: |
| Input or Output Voltage Applied ........ GND-0.5V to V $\mathrm{CC}+0.5 \mathrm{~V}$ |  |
| Storage Temperature Range | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Junction Temperature | $+175^{\circ} \mathrm{C}$ |
| Lead Temperature (Soldering 10 sec ) | $300^{\circ} \mathrm{C}$ |
| ESD Classification | Class 1 |

Input or Output Voltage Applied ........ GND-0.5V to $\mathrm{V}_{\mathrm{CC}}+0.5 \mathrm{~V}$
Storage Temperature Range .................... $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Lead Temperature (Soldering 10 sec ) ...................... $300^{\circ} \mathrm{C}$
ESD Classification . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . Class 1
CAUTION: Stresses above those listed in "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.

Operating Conditions
Operating Voltage Range . . . . . . . . . . . . . . . . . . . . . . . . +4.5 V to +5.5 V
Operating Temperature Range . . . . . . . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

TABLE 1. HMU16/883 D.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and 100\% Tested

| PARAMETER | SYMBOL | CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| Logical One Input Voltage | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 2.2 | - | V |
| Logical Zero Input Voltage | VIL | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 0.8 | V |
| Output HIGH Voltage | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & \mathrm{IOH}_{\mathrm{OH}}=-400 \mu \mathrm{~A} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}(\text { Note } 1) \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \top \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 2.6 | - | v |
| Output LOW Voltage | $\mathrm{V}_{\mathrm{OL}}$ | $\begin{aligned} & \mathrm{IOL}_{\mathrm{OL}}=+4.0 \mathrm{~mA} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}(\text { Note } 1) \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 0.4 | V |
| Input Leakage Current | 1 | $\begin{aligned} & V_{I N}=V_{C C} \text { or } G N D \\ & V_{C C}=5.5 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}^{\prime} \leq+125^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Output or I/O Leakage Current | 10 | $\begin{aligned} & V_{\text {OUT }}=V_{C C} \text { or GND } \\ & V_{C C}=5.5 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}^{\prime} \mathrm{S} \leq+125^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Standby Power Supply Current | ICCsB | $\mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}$ or GND , $V_{C C}=5.5 \mathrm{~V}$, Outputs Open | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}^{\prime} \leq+125^{\circ} \mathrm{C}$ | - | 500 | $\mu \mathrm{A}$ |
| Operating Power Supply Current | I'coop | $\begin{aligned} & f=1.0 \mathrm{MHz}, \\ & V_{\text {IN }}=V_{C C} \text { or GND } \\ & V_{C C}=5.5 \mathrm{~V} \text { (Note 2) } \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{S} \leq+125^{\circ} \mathrm{C}$ | - | 7.0 | mA |
| Functional Test | FT | (Note 3) | 7,8 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}^{\prime} \mathrm{S} \leq+125^{\circ} \mathrm{C}$ | - | - |  |

## NOTES:

1. Interchanging of force and sense conditions is permitted.
2. Operating Supply Current is proportional to frequency, typical rating is $5 \mathrm{~mA} / \mathrm{MHz}$.

## Reliabllity Information



TABLE 2. HMU17/883 A.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and 100\% Tested

| PARAMETER | SYMBOL | (NOTE 1) CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | -45 |  | -60 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| Unclocked Multiply Time | TMUC |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 70 | - | 90 | ns |
| Clocked Multiply Time | $\mathrm{T}_{\mathrm{MC}}$ |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 45 | - | 60 | ns |
| X, Y, RND Setup Time | Ts |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 18 | - | 20 | - | ns |
| Clock HIGH Pulse Width | TPWH |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq T \mathrm{~A} \leq+125^{\circ} \mathrm{C}$ | 15 | - | 20 | - | ns |
| Clock LOW Pulse Width | ${ }^{\text {T PWWL }}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 15 | - | 20 | - | ns |
| MSPSEL to Product Out | TPDSEL |  | 9, 10, 11 | ${ }^{-55}{ }^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 25 | - | 30 | ns |
| Output Clock to P | TPDP |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 25 | - | 30 | ns |
| Output Clock to Y | TPDY |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 25 | - | 30 | ns. |
| 3-State Enable Time | TENA | (Note 2) | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 25 | - | 30 | ns |
| Clock Enable Setup | TSE |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 15 | - | 15 | - | ns |

NOTES:

1. AC Testing as follows: $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and 5.5 V . Input levels OV and 3.0 V , Timing reference levels $=1.5 \mathrm{~V}$, Output load per test load circuit, with $\mathrm{V}_{1}=$ $2.4 \mathrm{~V}, \mathrm{R}_{1}=500 \Omega$ and $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$.
[^0]TABLE 3. HMU17/883 ELECTRICAL PERFORMANCE CHARACTERISTICS

| PARAMETER | SYMBOL | CONDITIONS | NOTES | TEMPERATURE | -45 |  | -60 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| Input Capacitance | $\mathrm{C}_{\text {IN }}$ | $V_{C C}=$ Open, $f=1 \mathrm{MHz}$ All Measurements are referenced to device GND. | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 15 | - | 15 | pF |
| Output Capacitance | $\mathrm{C}_{\text {OUT }}$ |  | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 10 | - | 10 | pF |
| I/O Capacitance | $\mathrm{Cl}_{1 / \mathrm{O}}$ |  | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 10 | - | 10 | pF |
| X, Y, RND Hold Time | TH |  | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 3 | - | 3 | - | ns |
| 3-State Disable Time | T DIS |  | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 25 | - | 30 | ns |
| Clock Enable Hold Time | THE |  | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 3 | - | 3 | - | ns |
| Output Rise Time | $T_{R}$ | From 0.8 V to 2.0 V | 1,2,4 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | - | 10 | - | 10 | ns |
| Output Fall Time | $\mathrm{T}_{\text {F }}$ | From 2.0 V to 0.8 V | 1,2,4 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 10 | - | 10 | ns |

NOTES:

1. The parameters listed in Table 3 are controlled via design or process parameters and are not directly tested. These parameters are characterized upon initial design and after major process and/or design changes.
2. Guaranteed, but not $100 \%$ tested.
3. Transition is measured at $\pm 200 \mathrm{mV}$ from steady state voltage, Output loading per test load circuit, with $V_{1}=1.5 \mathrm{~V}, R_{1}=500 \Omega$ and $C_{L}=40 \mathrm{pF}$.
4. Loading is as specified in the test load circuit, with $\mathrm{V}_{1}=2.4 \mathrm{~V}, \mathrm{R}_{1}=500 \Omega$ and $C_{L}=40 \mathrm{pF}$.

TABLE 4. APPLICABLE SUBGROUPS

| CONFORMANCE GROUPS | METHOD | SUBGROUPS |
| :--- | :---: | :---: |
| Initial Test | $100 \% / 5004$ | - |
| Interim Test | $100 \% / 5004$ | - |
| PDA | $100 \%$ | 1 |
| Final Test | $100 \%$ | $2,3,8 \mathrm{~A}, 8 \mathrm{~B}, 10,11$ |
| Group A | - | $1,2,3,7,8 \mathrm{~A}, 8 \mathrm{~B}, 9,10,11$ |
| Groups C \&D | Samples $/ 5005$ | $1,7,9$ |

## Burn-In Circuit



| $\begin{aligned} & \text { PGA } \\ & \text { PIN } \end{aligned}$ | PIN NAME | BURN-IN SIGNAL | $\begin{aligned} & \text { PGA } \\ & \text { PIN } \end{aligned}$ | PIN NAME | BURN-IN SIGNAL | PGA PIN | PIN NAME | BURN-IN SIGNAL | $\begin{aligned} & \text { PGA } \\ & \text { PIN } \end{aligned}$ | PIN NAME | BURN-IN SIGNAL |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| B6 | X4 | F6 | F1 | Y9/P9 | F11 | K7 | P10/P26 | $\mathrm{V}_{\mathrm{CC} / 2}$ | E11 | RND | F1 |
| A6 | X3 | F5 | G2 | Y10/P10 | F12 | L7 | P11/P27 | $\mathrm{V}_{\mathrm{CC}} / 2$ | D10 | ENX | FO |
| B5 | X2 | F4 | G1 | Y11/P11 | F13 | K8 | P12/P28 | $\mathrm{V}_{\mathrm{CC} / 2}$ | D11 | X15 | F3 |
| A5 | X1 | F3 | H2 | Y12/P12 | F14 | L8 | P13/P29 | $\mathrm{V}_{\mathrm{CC} / 2}$ | C10 | X14 | F2 |
| B4 | X0 | F2 | H1 | Y13/P13 | F15 | K9 | P14/P30 | $\mathrm{V}_{\mathrm{CC}} / 2$ | C11 | X13 | F15 |
| A4 | $\overline{\mathrm{OEL}}$ | $\mathrm{V}_{\mathrm{CC}}$ | J2 | Y14/P14 | F4 | L9 | P15/P31 | $\mathrm{V}_{\mathrm{CC}} / 2$ | B10 | X12 | F14 |
| B3 | CLK | FO | J1 | Y15/P15 | F5 | K10 | ENP | FO | A10 | X11 | F13 |
| A3 | ENY | FO | K2 | PO/P16 | $\mathrm{V}_{\mathrm{CC} / 2}$ | K11 | $\overline{\mathrm{OEP}}$ | F1 | B9 | X10 | F12 |
| B2 | YO/PO | F2 | L2 | P1/P17 | $\mathrm{V}_{\mathrm{CC}} / 2$ | J10 | $\overline{F A}$ | F14 | A9 | X9 | F11 |
| B1 | Y1/P1 | F3 | K3 | P2/P18 | $\mathrm{V}_{\mathrm{CC} / 2}$ | J11 | FT | F15 | B8 | X8 | F10 |
| C2 | Y2/P2 | F4 | L3 | P3/P19 | $\mathrm{V}_{C C} / 2$ | H1O | $\overline{\text { MSPSEL }}$ | F14 | A8 | X7 | F9 |
| C1 | Y3/P3 | F5 | K4 | P4/P20 | $\mathrm{V}_{\mathrm{CC}} / 2$ | H11 | GND | GND | B7 | X6 | F8 |
| D2 | Y4/P4 | F6 | L4 | P5/P21 | $V_{C C / 2}$ | G10 | GND | GND | A7 | X5 | F7 |
| D1 | Y5/P5 | F7 | K5 | P6/P22 | $\mathrm{V}_{\mathrm{CC}} / 2$ | G11 | $V_{C C}$ | $V_{C C}$ | A2 | N.C. | NONE |
| E2 | Y6/P6 | F8 | L5 | P7/P23 | $\mathrm{V}_{\mathrm{CC} / 2}$ | F10 | $V_{C C}$ | $V_{C C}$ | K1 | N.C. | NONE |
| E1 | Y7/P7 | F9 | K6 | P8/P24 | $\mathrm{V}_{\mathrm{CC} / 2}$ | F11 | TCY | F15 | L10 | N.C. | NONE |
| F2 | Y8/P8 | F10 | L6 | P9/P25 | $\mathrm{V}_{\mathrm{CC}} / 2$ | E10 | TCX | F15 | B11 | N.C. | NONE |

## NOTES:

1. $V_{C C}=5.0 \mathrm{~V}+0.5 \mathrm{~V} /-0.0 \mathrm{~V}$ with $0.1 \mu \mathrm{~F}$ decoupling capacitor to GND.
2. $F O=100 \mathrm{kHz}, F 1=F 0 / 2, F 2=F 1 / 2, \ldots \ldots \ldots$
3. $\mathrm{V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{CC}}-1 \mathrm{~V} \pm 0.5 \mathrm{~V}$ (Min), $\mathrm{V}_{\mathrm{IL}}=0.8 \mathrm{~V}$ (Max).

## Die Characteristics

DIE DIMENSIONS:
$179 \times 169 \times 19 \pm 1$ mils
METALLIZATION:
Type: $\mathrm{Si}-\mathrm{Al}$ or $\mathrm{Si}-\mathrm{Al}-\mathrm{Cu}$ Thickness: 8kA
GLASSIVATION:
Type: Nitrox
Thickness: 10k $\AA$
Metallization Mask Layout

## DIE ATTACH:

Material: Si-Au Eutectic Alloy or Silver-Glass
WORST CASE CURRENT DENSITY: $1.2 \times 10^{5} \mathrm{~A} / \mathrm{cm}^{2}$

## HMU17/883




## ONE DIMENSIONAL FILTERS

PAGE

## DATA SHEETS

HSP43168 Dual FIR Filter ..... 3-3
HSP43168/883 Dual FIR Filter ..... 3-19
HSP43220 Decimating Digital Filter ..... 3-27
HSP43220/883 Decimating Digital Filter ..... 3-47
HSP43481 Digital Filter ..... 3-54
HSP43481/883 Digital Filter ..... 3-69
HSP43881 Digital Filter ..... 3-74
HSP43881/883 Digital Filter ..... 3-89
HSP43891 Digital Filter ..... 3-95
HSP43891/883 Digital Filter ..... 3-110
HSP43216 Halfband Filter ..... 3-116

## Features

- Two Independent 8-Tap FIR Filters Configurable as a Single 16-Tap FIR
- 10 Bit Data \& Coefficients
- On-Board Storage for 32 Programmable Coefficient Sets
- Up To: 256 FIR Taps, $16 \times 16$ 2-D Kernels, or $10 \times 19$ Bit Data and Coefficients
- Programmable Decimation to 16
- Programmable Rounding on Output
- Mixed Mode Arithmetic
- Standard Microprocessor Interface
- 33MHz, 45MHz Versions
- 84-Pin PGA And PLCC Packages


## Applications

- Quadrature Filtering
- Correlation
- Image Processing
- Complex Filtering
- PolyPhase Filtering
- Adaptive Filtering


## Description

The HSP43168 Dual FIR Filter consists of two independent 8-tap FIR filters. Each filter supports decimation from 1 to 16 and provides on-board storage for 32 sets of coefficients. The Block Diagram shows two FIR cells each fed by a separate coefficient bank and one of two separate inputs. The outputs of the FIR cells are either summed or multiplexed by the MUX/Adder. The compute power in the FIR Cells can be configured to provide quadrature filtering, complex filtering, 2-D convolution, 1-D/2-D correlations, and interpolating/decimating filters.
The FIR cells take advantage of symmetry in FIR coefficints by pre-adding data samples prior to multiplication. This allows an 8-tap FIR to be implemented using only 4 multipliers per filter cell. These cells can be configured as either a single 16-tap FIR filter or dual 8-tap FIR filters. Asymmetric filtering is also supported.

Decimation of up to 16 is provided to boost the effective number of filter taps from 2 to 16 times. Further, the decimtion registers provide the delay necessary for fractional data conversion and 2-D filtering with kernels to $16 \times 16$.

The flexibility of the Dual is further enhanced by 32 sets of user programmable coefficients. Coefficient selection may be changed asynchronously from clock to clock. The ability to toggle between coefficient sets further simplifies applications such as polyphase or adaptive filtering.
The HSP43168 is a low power fully static design implemented in an advanced CMOS process. The configuration of the device is controlled through a standard microprocessor interface. The Dual FIR Filter is available in 84 pin PGA and 84 pin PLCC packages.

Block Diagram



## Pin Description

| SYMBOL | PIN <br> NUMBER | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| vcc | $\begin{gathered} \text { B5, D11, K10 } \\ \text { K7, F1 } \end{gathered}$ |  | VCC: +5 V power supply pin. |
| GND | $\begin{gathered} \text { A9, E10, L11 } \\ \text { K4, D2 } \end{gathered}$ |  | Ground. |
| CINO-9 | $\begin{gathered} \text { E1-3, D1, } \\ \text { C1-2, B1-3, } \\ \text { A1 } \end{gathered}$ | 1 | Control/Coefficient Data Bus. Processor interface for loading control data and coefficients. CINO is the LSB. |
| AO-8 | $\begin{gathered} \text { A5-8, B6-8, } \\ \text { C6-7 } \end{gathered}$ | 1 | Control/Coefficient Address Bus. Processor interface for addressing control and coefficient registers. AO is the LSB. |
| WR\# | A10 | 1 | Control/Coefficient Write Clock. Data is latched into the control and coefficient registers on the rising edge of WR\#. |
| CSELO-4 | A2-4, B4, C5 | 1 | Coefficient Select. This input determines which of the 32 coefficient sets are to be used by FIR $A$ and $B$. This input is registered and CSELO is the LSB. |
| INAO-9 | $\begin{gathered} \text { K1, J1-2, } \\ \text { H1-2, G1-3, } \\ \text { F2-3 } \end{gathered}$ | 1 | Input to FIR A. INAO is the LSB |
| INBO-9 | $\begin{gathered} \text { L1-5, K2-3 } \\ \text { K5-6, J5 } \end{gathered}$ | 1/0 | Bidirectional Input for FIR B. INBO is the LSB and is input only. When used as output, INB1-9 are the LSB's of the output bus, and INB9 is the MSB of these bits. |
| OUT9-27 | $\begin{gathered} \text { F9-11, G9-11, } \\ \text { H10-11, J10-11 } \\ \text { J7,K11, } \\ \text { K8-9, L6-10 } \end{gathered}$ | 0 | 19 MSB's of Output Bus. Data format is either unsigned or two's complement depending on configuration. OUT27 is the MSB. |
| SHFTEN\# | B11 | 1 | Shift Enable. This active low input enables clocking of data into the part and shifting of data through the decimation registers. |
| FWRD\# | C10 | I | Forward ALU Input Enable. When active low, data from the forward decimation path is input to the ALU's through the "a" input. When high, the " $a$ " inputs to the ALUs are zeroed. |
| RVRS\# | A11 | 1 | Reverse ALU Input Enable. When active low, data from the reverse decimation path is input to the ALU's through the " $b$ " input. When high, the " $b$ " inputs to the ALUs are zeroed. |
| TXFR\# | C11 | 1 | Data Transfer Control. This active low input switches the LIFO being read into the reverse decimation path with the LIFO being written from the forward decimation path (see Figure 1). |
| MUXO-1 | B9-10 | 1 | Adder/Mux Control. This input controls data flow through the output Adder/Mux. Table 3.0 lists the various configurations. |
| CLK | E9 | 1 | Clock. All inputs except those associated with the processor interface (CINO-9, AO-8, WR\#) and the output enables (OEL\#, OEH\#) are registered by the rising edge of CLK. |
| OEL\# | J6 | 1 | Output Enable Low. This tristate control enables the LSB's of the output bus to INB1-9 when OEL\# is low. |
| OEH\# | E11 | 1 | Output Enable High. This tristate control enables OUT9-27 when OEH\# is low. |
| ACCEN | D10 | 1 | Accumulate Enable. This active high input allows accumulation in the FIR Cell Accumulator. A low on this input latches the FIR Accumulator contents into the Output Holding Registers while zeroing the feedback path in the Accumulator. |



## Functional Description

As shown in Figure 1.0, the HSP43168 consists of two 4multiplier FIR filter cells which process 10 bit data and coefficients. The FIR cells can operate as two independent 8-tap FIR filters or two 4-tap asymmetric filters at maximum I/O rates. A single filter mode is provided which allows the FIR cells to operate as one 16-tap FIR filter or one 8-tap asymmetric filter. On board coefficient storage for up to 32 sets of 8 coefficients is provided. The coefficient sets are user selectable and are programmed through a microprocessor interface. Programmable decimation to 16 is also provided. By utilizing decimation registers together with the coefficient sets, polyphase filters are realizable which allow the user to trade data rate for filter taps. The MUX/ Adder can be configured to either add or multiplex the outputs of the filter cells depending upon whether the cells are operating in single or dual filter mode. In addition, a shifter in the MUX/Adder is provided for implementation of filters with 10 bit data and 20 bit coefficients or vice versa.

## Microprocessor Interface

The Dual has a 20 pin write only microprocessor interface for loading data into the Control Block and Coefficient Bank. The interface consists of a 10-bit data bus (CINO-9), a 9 bit address bus (AO-8), and a write input (WR\#) to latch the data into the on-board registers. The control and coefficient data can be loaded asynchronously to CLK.

## Control Block

The Dual FIR is configured by writing to the registers within the Control Block. These registers are memory mapped to address $000 \mathrm{H}(\mathrm{H}=$ Hexadecimal $)$ and 001 H on $\mathrm{AO}-8$. The format of these registers is shown in Table 1 and Table 2. Writing the Control/Configuration registers causes a reset which lasts for 6 CLK cycles following the assertion of WR\#. The reset caused by writing registers in the Control Block will not clear the contents of the Coefficient Bank.

TABLE 1

| CONTROL ADDRESS OOOH |  |  |
| :---: | :--- | :--- |
| BITS | FUNCTION | DESCRIPTION |
| $3-0$ | Decimation Factor | $0000=$ No Decimation <br> $1111=$ Decimation by 16 |
| 4 | Mode Select | $0=$ Single Fllter Mode <br> $1=$ Dual Fllter Mode |
| 5 | Odd/Even Symmetry | $0=$ Even symmetric coefficients <br> $1=$ Odd symmetric coefficients |
| 6 | FIR A odd/even taps | $0=$ Odd number of taps in filter <br> $1=$ Even number of taps in filter |
| 7 | FIR B odd/even taps | (Defined same as FIR A above) |
| 8 | FIR B Input Source | $0=$ Input from INAO-9 <br> $1=$ Input from INBO-9 |
| 9 | Not Used | Set to O for proper operation |

The 4 LSBs of the control word loaded at address 000 H are used to select the decimation factor. For example, if the 4

LSBs are programmed with a value of 0010, the forward and reverse shifting decimation registers are each configured with a delay of 3 . Bit 4 is used to select whether the FIR cells operate as two independent filters or one extended length filter. Coefficient symmetry is selected by bit 5 . Bits 6 and 7 are programmed to configure the FIR cells for odd or even filter lengths. Bit 8 selects the FIR B input source when the FIR cells are configured for independent operation. Bit 9 must be programmed to 0 .

The 4 LSB's of the control word loaded at address 001 H are used to configure the format of the FIR cell's data and coefficients. Bit 4 is programmed to enable or disable the reversal of data sample order prior to entering the backward shifting decimation registers. Bits 5-9 are used to support programmable rounding on the output.

TABLE 2

| CONTROL ADDRESS 001H |  |  |
| :---: | :--- | :--- |
| BITS | FUNCTION | DESCRIPTION |
| 0 | FIR A Input Format | $0=$ Unsigned <br> $1=$ Two's Complement |
| 1 | FIR A Coefficient <br> Format | (Defined same as FIR A input) |
| 2 | FIR B Input Format | (Defined same as FIR A input) |
| 3 | FIR B Coefficient | (Defined same as FIR A input) |
| 4 | Data Reversal <br> Enable | $0=$ Enabled <br> $1=$ Disabled |
| $8-5$ | Round Position | $0000=2^{-10}$ <br> $1011=2^{1}$ |
| 9 | Round Enable | $0=$ Enabled <br> $1=$ Disabled |

NOTE: Address locations 002 H to 1 ffH are reserved, and writing to these locations will have unpredictable effects on part configuration.

## FIR Filter Cells

Each FIR filter cell is based on an array of four $11 \times 10$ bit two's complement multipliers. The multipliers get one input from the ALUs which combine data shifting through the forward and backward decimation registers. The second input comes from the user programmable coefficient bank. The multiplier outputs feed an accumulator whose result is passed to the output section where it is multiplexed or added.

## Decimation Registers

The forward and backward shifting registers are configurable for decimation by 1 to 16 (see Table 1). The backward shifting registers are used to take advantage of symmetry in linear phase filters by aligning data at the ALU's for pre-addition prior to multiplication by the common coefficient. When the FIR cells are configured in single filter mode, the decimation registers in each cell are cascaded. This lengthened delay path allows computation of a filter which is twice the size of that capable in a single cell. The decimation registers also provide data storage for poly-phase or 2-D filtering applications (See Applications Examples section).

The Data Feedback Circuitry in each FIR cell is responsible for transferring data from the forward to the backward shifting decimation registers. This circuitry feeds blocks of samples into the backward shifting decimation path in either reversed or non-reversed sample order. The MUX/DEMUX structure at the input to the Feedback Circuitry routes data to the LIFO's or the delay stage depending on configuration. The MUX on the Feedback Circuitry Output selects the storage element which feeds the backward shifting decimation registers.
In applications requiring reversal of sample order, such as FIR filtering with decimation, the FIR cells are configured with data reversal enabled (see Table 2). In this mode, data is transferred from the forward to the backward shifting registers through a ping-ponged LIFO structure. While one LIFO is being read into the backward shifting path, the other is written with data samples. The MUX/DEMUX controls which LIFO is being written, and the MUX on the Feedback Circuitry output controls which LIFO is being read. A low on TXFR\# and SHIFTEN\#, switches the LIFO's being read and written, which causes the block of data read from the structure to be reversed in sample order (See Example 4 in the Application Examples section).
The frequency with which TXFR\# is asserted determines size of the data blocks in which sample order is reversed. For example, if TXFR\# is asserted once every three CLK's, blocks of 3 data samples with order reversed, would be fed into the backward decimation registers. Note: altering the frequency or phase of TXFR\# assertion once a filtering operation has been started will cause unknown results.
In applications which do not require sample order reversal, the FIR cells must be configured with data reversal disabled (see Table 2). In addition, TXFR\# must be asserted to ensure proper data flow. In this configuration, data to the backward shifting decimation path is routed though a delay stage instead of the ping-pong LIFO's. The number of registers in the delay stage is based on the programmed decimation factor. Note: data reversal must be disabled and TXFR\# must be asserted for filtering applications which do not use decimation.

The shifting of data through the forward and reverse decimation registers is enabled by asserting the SHFTEN\# input. When SHFTEN\# transitions high, data shifting is disabled, and the data sample latched into the part on the previous clock is the last input to the forward decimation path. When SHFTEN\# is asserted, shifting of data through the decimation paths is enabled. The data sample at the part input when SHFTEN\# is asserted will be the next data sample into the forward decimation path.
When operating the FIR cells as two independent filters, FIR A receives input data via INAO-9 and FIR B receives data from either INAO-9 or INBO-9 depending on the configuration (Table 1). When the FIR cells are configured as a single extended length filter, the forward and backward decimation paths are cascaded. In this mode, data is transferred from the forward decimation path to the backward decimation path by the Data Feedback Circuitry in FIR B. Thus, the manner in which data is read into the backward shifting decimation path is determined by FIR B's configuration.

When the decimation paths are cascaded, data is routed through the delay stage in FIR A's Data Feedback Circuitry.
The configuration of the FIR cells as even or odd length filters determines the point in the forward decimation path from which data is multiplexed to the Data Feedback Circuitry. For example, if the FIR cell is configured as an odd length filter, data prior to the last register in the third forward decimation stage is routed to the Feedback Circuitry. If the FIR cell is configured as an even length filter, data output from the third forward decimation stage is multiplexed to the Feedback Circuitry. This is required to insure proper data alignment with symmetric filter coefficients (See Application Examples).

## ALUs

Data shifting through the forward and reverse decimation path feeds the "a" and " $b$ " inputs of the ALUs respectively. The ALU's perform an " $b+a$ " operation if the FIR cell is configured for even symmetric coefficients or an "b-a" operation if configured for odd symmetric coefficients.
For applications in which a pre-add or subtract is not required, the " $a$ " or " $b$ " input can be zeroed by disabling FWRD\# or RVRS\# respectively. This has the effect of producing an ALU output which is either " $a$ ","- $a$ ", or " $b$ " depending on the filter symmetry chosen. For example, if the FIR cell is configured for an even symmetric filter with FWRD\# low and RVRS\# high, the data shifting through the forward decimation registers would appear on the ALU output.

## Coefficient Bank

The output of the ALU is multiplied by a coefficient from one of 32 user programmable coefficient sets. Each set consists of 8 coefficients ( 4 coefficients for FIR A and 4 for FIR B). The active coefficient set is selected using CSELO-4. The coefficient set may be switched every clock to support polyphase filtering operations.
The coefficients are loaded into on-board registers using the microprocessor interface, CINO-9, AO-8, and WR\#. Each multiplier within the FIR Cells is driven by a coefficient bank with one of 32 coefficients. These coefficients are addressed as shown in Table 3. The inputs AO-1 specify the Coefficient Bank for one of the four multipliers in each FIR Cell; A2 specifies FIR Cell A or B; Bits A7-3 specify one of 32 sets in which the coefficient is to be stored. For example, an address of 10 dH would access the coefficient for the second multiplier in FIR B in the second coefficient set.

TABLE 3

| A8 | A7-3 | A2 | A1-0 | FIR | BANK |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | $x x x x x$ | 0 | 00 | A | 0 |
| 1 | $x x x x x$ | 0 | 01 | $A$ | 1 |
| 1 | $x x x x x$ | 0 | 10 | A | 2 |
| 1 | $x x x x x$ | 0 | 11 | A | 3 |
| 1 | $x x x x x$ | 1 | 00 | B | 0 |
| 1 | $x x x x x$ | 1 | 01 | B | 1 |
| 1 | $x x x x x$ | 1 | 10 | $B$ | 2 |
| 1 | $x x x x x$ | 1 | 11 | B | 3 |

## FIR Cell Accumulator

The registered outputs from the multipliers in each FIR cell feed the FIR cell's accumulator. The ACCEN input controls each accumulator's running sum and the latching of data from the accumulator into the Output Holding Registers. When ACCEN is low, feedback from the accumulator adder is zeroed which disables accumulation. Also, output from the accumulator is latched into the Output Holding Registers. When ACCEN is asserted, accumulation is enabled and the contents of the Output Holding Registers remain unchanged.

## Output MUX/Adder

The contents of each FIR Cell's Output Holding Register is summed or multiplexed in the Mux/Adder. The operation of the Mux/Adder is controlled by the MUXO-1 inputs as shown in Table 4. Applications requiring 10 bit data and 20 bit coefficients or 20 bit data and 10 bit coefficients are made possible by configuring the MUX/Adder to scale FIR B's output by $2^{-10}$ prior to summing with FIR A. When the Dual FIR is configured as two independent filters, the MUXO-1 inputs would be used to multiplex the filter outputs of each cell. For applications in which FIR A and B are configured as a single filter, the MUX/Adder is configured to sum the output of each FIR cell.

TABLE 4

| MUXO-1 DECODING |  |
| :---: | :--- |
| MUX1-0 | OUT0-27 |
| 00 | FIRA + FIRB (FIR B Scaled by 2-10) |
| 01 | FIRA + FIRB |
| 10 | FIRA |
| 11 | FIRB |

## Input/Output Formats

The Dual FIR supports mixed mode arithmetic with both unsigned and two's complement data and coefficients. The input and output formats for both data types is shown below. If the Dual FIR is configured as an even symmetric filter with unsigned data and coefficients, the output will be unsigned. Otherwise, the output will be two's complement.

## INPUT DATA FORMAT INAO-9, INBO-9 FRACTIONAL TWO'S COMPLEMENT

| 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $-2^{0}$ | $2^{-1}$ | $2^{-2}$ | $2^{-3}$ | $2^{-4}$ | $2^{-5}$ | $2^{-6}$ | $2^{-7}$ | $2^{-8}$ | $2^{-9}$ |

OUTPUT DATA FORMAT OUT9-27 FRACTIONAL TWO'S COMPLEMENT


OUTPUT DATA FORMAT OUTO-8 FRACTIONAL TWO'S COMPLEMENT

| 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $2^{-10}$ | $2^{-11}$ | $2^{-12}$ | $2^{-13}$ | $2^{-14}$ | $2^{-15}$ | $2^{-16}$ | $2^{-17}$ | $2^{-18}$ |

INPUT DATA FORMAT INAO-9, INBO-9 FRACTIONAL UNSIGNED


OUTPUT DATA FORMAT OUT9-27 FRACTIONAL UNSIGNED

$2^{9} 2^{8} 2^{7} 2^{6} 2^{4} 2^{5} 2^{3} 2^{2} 2^{1} 2^{0} .2^{-1} 2^{-2} 2^{-3} 2^{-4} 2^{-5} 2^{-6} 2^{-7} 2^{-8} 2^{-9}$

## OUTPUT DATA FORMAT OUTO-8

FRACTIONAL UNSIGNED

| 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $2^{-10}$ | $2^{-11}$ | $2^{-12}$ | $2^{-13}$ | $2^{-14}$ | $2^{-15}$ | $2^{-16}$ | $2^{-17}$ | $2^{-18}$ |

The MUX/Adder can be configured to implement programmable rounding at bit locations $2^{-10}$ through $2^{1}$. The round is implemented by adding a 1 to the specified location (see Table 2.0). For example, to configure the part such that the output is rounded to the 10 MSBs , OUT18-27, the round position would be chosen to be $2^{-1}$.

## Application Examples

In this section a number of examples which show even, odd, symmetric, asymmetric and decimating filters are presented. These examples are intended to show different operational modes of the HSP43168. The examples are all based on a dual filter configuration. However, the same principles apply when the part is configured with both FIR cells operating as a single filter.

## Example 1. Even-Tap Symmetric Filter Example

The HSP43168 may be configured as two independent 8tap symmetric filters as shown by the block diagram in Figure 2. Each of the FIR cells takes advantage of symmetric filter coefficients by pre-adding data samples common to a given coefficient. As a result, each FIR cell can implement an 8-tap symmetric filter using only four multipliers. Similarly, when the HSP43168 is configured in single filter mode a 16-tap symmetric filter is possible by using the multipliers in both cells.

The operation of the FIR cell is better understood by comparing the data and coefficient alignment for a given filter output, Figure 3, with the data flow through the FIR cell, as shown in Figure 4. The block diagrams in Figure 4 are a simplification of the FIR cell shown in Figure 1. For simplicity, the ALU's and FIR Cell Accumulators were replaced by adders, and the pipeline delay registers were omitted.


FIGURE 2. USING HSP43168 AS TWO INDEPENDENT FILTERS

In Figure 4, the order of the data samples within the filter cell is shown by the numbers in the forward and backward shifting decimation paths. The output of the filter cell is given by the equation at the bottom of each block diagram. Figure 4a shows the data sample alignment at the pre-adders for the data/coefficient alignment shown in Figure 3.


FIGURE 3. DATA/COEFFICIENT ALIGNMENT FOR 8-TAP EVEN SYMMETRIC FILTER

The dual filter application is configured by writing 1 dOH to address 000 H via the microprocessor interface, CINO-9, AO-8, and WR\#. Since this application does not use decimation, the 4th bit of the control register at address 001 H must be set to disable data reversal (see Table 2). Failure to disable data reversal will produce erroneous results.
A. DATA FLOW AS DATA SAMPLE 7 IS CLOCKED INTO THE FEED FORWARD STAGE.

$(X 7+X 0) \mathrm{C} 0+(X 6+X 1) \mathrm{C} 1+(X 5+X 2) \mathrm{C} 2+(X 4+X 3) \mathrm{C} 3$
B. DATA FLOW AS DATA SAMPLE 8 IS CLOCKED INTO THE FEED FORWARD STAGE.

$(X 8+X 1) C 0+(X 7+X 2) C 1+(X 6+X 3) C 2+(X 5+X 4) C 3$
C. DATA FLOW AS DATA SAMPLE 9 IS CLOCKED INTO THE FEED FORWARD STAGE.

(X9+X2)C0+(X8+X3)C1+(X7+X4)C2+(X6+X5)C3

FIGURE 4. DATA FLOW DIAGRAMS FOR 8-TAP SYMMETRIC FILTER

Using this architecture, only the unique coefficients need to be stored in the Coefficient Bank. For example, the above filter would be stored in the first coefficient set for FIR A by writing C0, C1, C2, and C3 to address $100 \mathrm{H}, 101 \mathrm{H}, 102 \mathrm{H}$, and 103 H respectively. To write the same filter to the first coefficient set for FIR B, the address sequence would change to $104 \mathrm{H}, 105 \mathrm{H}, 106 \mathrm{H}$, and 107 H .

To operate the HSP43168 in this mode, TXFR\# is tied low to ensure proper data flow; both FWRD\# and RVRS\# are tied low to enable data samples from the forward and reverse data paths to the ALU's for pre-adding; ACCEN is tied low to prevent accumulation over multiple CLK's; SHFTEN\# is tied low to allow shifting of data through the decimation registers; MUXO-1 is programmed to multiplex the output the of either FIR A or FIR B; CSELO-4 is programmable to access the stored coefficient set, in this example CSEL $=0000$.

## Example 2. Odd-Tap Symmetric Filter Example

The HSP43168 may be configured as two independent 7-tap symmetric filters with a functional block diagram resembling Figure 2. As in the 8 -tap filter example, the HSP43168 implements the filtering operation by summing data samples sharing a common coefficient prior to multiplication by that coefficient. However, for odd length filters the pre-addition requires that the center coefficient be scaled by $1 / 2$.

The operation of the FIR cell for odd length filters is better understood by comparing the data/coefficient alignment in Figure 5 with the data flow diagrams in Figure 6. The block diagrams in Figure 6 are a simplification of the FIR cell shown in Figure 1.



FIGURE 5. DATA/COEFFICIENT ALIGNMENT FOR 7-TAP SYMMETRIC FILTER

For odd length filters, proper data/coefficient alignment is ensured by routing data entering the last register in the third forward decimation stage to the backward shifting registers. In this configuration, the center coefficient must be scaled by $1 / 2$ to compensate for the summation of the same data sample from both the forward and backward shifting registers.
A. DATA FLOW AS DATA SAMPLE 6 IS CLOCKED INTO THE FEED FORWARD STAGE.

$(X 6+X 0) C 0+(X 5+X 1) C 1+(X 4+X 2) C 2+(X 3+X 3) C 3 / 2$
B. DATA FLOW AS DATA SAMPLE 7 IS CLOCKED INTO THE FEED FORWARD STAGE.

$(X 7+X 1) C 0+(X 6+X 2) C 1+(X 5+X 3) C 2+(X 4+X 4) C 3 / 2$
C. DATA FLOW AS DATA SAMPLE 8 IS CLOCKED INTO THE FEED FORWARD STAGE.

$(X 8+X 2) C 0+(X 7+X 3) C 1+(X 6+X 4) C 2+(X 5+X 5) C 3 / 2$
FIGURE 6. DATA FLOW DIAGRAMS FOR 7-TAP SYMMETRIC FILTER.

In the data flow diagrams of Figure 6, the order of the data samples input in to the filter cell is shown by the numbers in the forward and backward shifting decimation paths. The output of the filter cell is given by the equation at the bottom of the block. The diagram in Figure 6a shows data sample alignment at the pre-adders for the data/coefficient alignment shown in Figure 5.

This dual filter application is configured by writing 110 H to address 000 H via the microprocessor interface, $\mathrm{CINO}-9$, AO-8, and WR\#. Also, data reversal must be disabled by setting bit 4 of the control register at address 0001 H . As in the 8-tap example, only the unique coefficients need to be stored in the Coefficient Bank. These coefficients are stored in the first coefficient set for FIR A by writing CO, C1, C2, and C3 to address $100 \mathrm{H}, 101 \mathrm{H}, 102 \mathrm{H}$, and 103 H respectively. To write the same filter to the first coefficient set for FIR B, the address sequence would change to $104 \mathrm{H}, 105 \mathrm{H}$, 106 H , and 107 H . The control signals TXFR\#, FWRD\#, RVRS\#, ACCEN, SHFTEN\#, and CSELO-4 are controlled as described in Example 1.

## Example 3. Asymmetric Filter Example

The FIR cells within the HSP43168 can each calculate 4 asymmetric taps on each clock. Thus, a single FIR cell can implement an 8-tap asymmetric filter if the HSP43168 is clocked at twice the input data rate. Similarly, if the Dual is configured as a single filter, a 16- tap asymmetric filter is realizable.

For this example, the FIR cells are configured as two 8-tap asymmetric filters which are clocked at twice the input data rate. New data is shifted into the forward and backward decimation paths every other CLK by the assertion of SHFTEN\#. The filter output is computed by passing data from each decimation path to the multipliers on alternating clocks. Two sets of coefficients are required, one for data on the forward decimation path, and one for data on the reverse path. The filter output is generated by accumulating the multiplier outputs for two CLKs.

The operation of this configuration is better understood by comparing the data/coefficient alignment in Figure 7 with the data flow diagrams in Figure 8. The ALU's have been omitted from the FIR cell diagrams because data is fed to the multipliers directly from the forward and reverse decimation paths. The data samples within the FIR cell are shown by the numbers in the decimation paths.
$h(n)$

$x(n)$


FIGURE 7. DATA/COEFFICIENT ALIGNMENT FOR 8-TAP ASYMMETRIC FILTER
A. DATA SHIFTING DISABLED, BACKWARD SHIFTING DECIMATION REGISTERS FEEDING MULTIPLIERS.

B. SHIFTING OF DATA SAMPLE 7 INTO FIR CELL ENABLED, FORWARD SHIFTING REGISTERS FEEDING MULTIPLIERS.

C. DATA SHIFTING DISABLED, BACKWARD SHIFTING DECIMATION REGISTERS FEEDING MULTIPLIERS.

$(\mathrm{X} 1) \mathrm{C} 0+(\mathrm{X} 2) \mathrm{C} 1+(\mathrm{X} 3) \mathrm{C} 2+(\mathrm{X} 4) \mathrm{C} 3$

FIGURE 8. DATA FLOW DIAGRAMS FOR 8-TAP ASYMMETRIC FILTER
D. SHIFTING OF DATA SAMPLE 8 INTO FIR CELL ENABLED, FORWARD SHIFTING REGISTERS FEEDING MULTIPLIERS


FIGURE 8. DATA FLOW DIAGRAMS FOR 8-TAP ASYMMETRIC FILTER CONTINUED

For this application, each filter cell is configured as an odd length filter by writing 110 H to the control register at address 000 H . Even though an even tap filter is being implemented, the filter cells must be configured as odd length to ensure proper data flow. Also, the 4th bit at control address 001 H must be set to disable data reversal, and TXFR\# must be tied low. Since an 8 -tap asymmetric filter is being implemented, two sets of coefficients must be stored. These eight coefficients could be loaded into the first two coefficient sets for FIR A by writing $\mathrm{C0}, \mathrm{C} 1, \mathrm{C} 2, \mathrm{C} 3, \mathrm{C} 7, \mathrm{C} 6, \mathrm{C} 5$, and C 4 to address $100 \mathrm{H}, 101 \mathrm{H}, 102 \mathrm{H}, 103 \mathrm{H}, 108 \mathrm{H}, 109 \mathrm{H}, 10 \mathrm{aH}$, and 10 bH respectively.

The sum of products required for this 8-tap filter require dynamic control over FWRD\#, RVRS\#, ACCEN, and CSELO4. The relative timing of these signals is shown in Figure 9.


FIGURE 9. CONTROL TIMING FOR 8-TAP ASYMMETRIC FILTER

## Example 4. Even-Tap Decimating Filter Example

The HSP43168 supports filtering applications requiring decimation to 16. In these applications the output data rate is reduced by a factor of N . As a result, N clock cycles can be used for the computation of the filter output. For example, each FIR cell can calculate 8 symmetric or 4 asymmetric taps in one clock. If the application requires decimation by two, the filter output can be calculated over two clocks thus boosting the number of taps per FIR cell to 16 symmetric or 8 asymmetric. For this example, each FIR cell is configured as an independent 24-tap decimate $\times 3$ filter.

The alignment of data relative to the 24 filter coefficients for a particular output is depicted graphically in Figure 10. As in previous examples, the HSP43168 implements the filtering operation by summing data samples prior to multiplication by the common coefficient. In this example an output is required every third CLK which allows 3 CLK's for computation. On each CLK, one of three sets of coefficients are used to calculate 8 of the filter taps. The block diagrams in Figure 12 show the data flow and accumulator output for the data/ coefficient alignment in Figure 10.


FIGURE 10. DATA/COEFFICIENT ALIGNMENT FOR 24-TAP DECIMATE BY 3 FIR FILTER

Proper data and coefficient alignment is achieved by asserting TXFR\# once every three CLK's to switch the LIFO's which are being read and written. This has the effect of feeding blocks of three samples into the backward shifting decimation path which are reversed in sample order. In addition, ACCEN is de-asserted once every three clocks to allow accumulation over three CLK's. The three sets of coefficients required in the calculation of a 24-tap symmetric filter are cycled through using CSELO-4. The timing relationship between the CSELO-4, ACCEN, and TXFR\# are shown in Figure 12.

$(X 2+X 21) C 2+(X 5+X 18) C 5+(X 8+X 15) C 8+(X 11+X 12) C 11$
B. COMPUTATIONAL FLOW AS DATA SAMPLE 22 IS CLOCKED INTO THE FEED FORWARD STAGE

C. COMPUTATIONAL FLOW AS DATA SAMPLE 23 IS CLOCKED INTO THE FEED FORWARD STAGE


To operate in this mode the Dual is configured by writing 1 d 2 to address 000 H via the microprocessor interface, CINO-9, AO-8, and WR\#. Data reversal must be enabled see (Table 2.0). The 12 unique coefficients for this example are stored as three sets of coefficients for either FIR cell. For FIR A, the coefficients are loaded into the Coefficient Bank by writing $\mathrm{C} 2, \mathrm{C} 5, \mathrm{C} 8, \mathrm{C} 11, \mathrm{C} 1, \mathrm{C} 4, \mathrm{C} 7, \mathrm{C} 10, \mathrm{C} 0, \mathrm{C} 3, \mathrm{C} 6$, and C9 to address $100 \mathrm{H}, 101 \mathrm{H}, 102 \mathrm{H}, 103 \mathrm{H}, 108 \mathrm{H}, 109 \mathrm{H}$, $10 \mathrm{aH}, 10 \mathrm{bH}, 110 \mathrm{H}, 111 \mathrm{H}, 112 \mathrm{H}$, and 113 H respectively.
D. COMPUTATIONAL FLOW AS DATA SAMPLE 24 IS CLOCKED INTO THE FEED FORWARD STAGE


FIGURE 11. DATA FLOW DIAGRAMS FOR 24-TAP DECIMATE BY 3 FIR FILTER


FIGURE 12. CONTROL SIGNAL TIMING FOR 24-TAP DECIMATE X3 FILTER

## Example 5. Odd-Tap Decimating Symmetric Filter

This example highlights the use of the HSP43168 as two independent, 23-tap, symmetric, decimate by 3 filters. In this example, the operational differences in the control signals and data reversal structure may be compared to the previously discussed even-tap decimating filter.

As in tr e 24-tap example, an output is required every third CLK which allows 3 CLK's for computation. On each CLK, one of three sets of coefficients are used to calculate the filter taps. Since this is an odd length filter, the center coefficient must be scaled by $1 / 2$ to compensate for the summation of the same data sample from the forward and backward shifting decimation paths. The block diagrams in Figure 14 show the data flow and accumulator output for the data coefficient alignment in Figure 13.
Proper data and coefficient alignment is achieved by asserting TXFR\# once every three CLK's to switch the LIFO's which are being read and written. For odd length filters, data prior to the last register in the forward decimation path is routed to the Feedback Circuitry. As a result, TXFR\# should be asserted one cycle prior to the input data samples which align with the center tap. The timing relationship between the CSELO-5, ACCEN, and TXFR\# are shown in Figure 15.


FIGURE 13. DATA/COEFFICIENT ALIGNMENT FOR 23-TAP DECIMATE BY 3 SYMMETRIC FILTER

A. COMPUTATIONAL FLOW AS DATA SAMPLE 20 IS CLOCKED INTO THE FEED FORWARD STAGE
 $+(\mathrm{X} 2+\mathrm{X} 20) \mathrm{C} 2+(\mathrm{X} 5+\mathrm{X} 17) \mathrm{C} 5+(\mathrm{X} 8+\mathrm{X} 14) \mathrm{C} 8+(\mathrm{X} 11+\mathrm{X} 11) \mathrm{C} 11 / 2$
B. COMPUTATIONAL FLOW AS DATA SAMPLE 21 IS CLOCKED INTO THE FEED FORWARD STAGE
C. COMPUTATIONAL FLOW AS DATA SAMPLE 22 IS CLOCKED INTO THE FEED FORWARD STAGE


## Absolute Maximum Ratings

Supply Voltage ..... $+8.0 \mathrm{~V}$
Input, Output Voltage GND -0.5 V to $\mathrm{V}_{\mathrm{CC}}+0.5 \mathrm{~V}$
Storage Temperature. . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ESDClass 1
Maximum Package Power Dissipation at $+70^{\circ} \mathrm{C}$ 2.4W (PLCC), 3.1W (PGA)
$\theta_{\mathrm{jc}}$ $11.0^{\circ} \mathrm{C} / \mathrm{W}$ (PLCC), $7.5^{\circ} \mathrm{C} / \mathrm{W}$ (PGA)$\theta_{\text {ja }}$$33.6^{\circ} \mathrm{C} / \mathrm{W}$ (PLCC), $33.5^{\circ} \mathrm{C} / \mathrm{W}$ (PGA)Gate Count32529
Junction Temperature $+175^{\circ} \mathrm{C}$ (PGA) $+150^{\circ} \mathrm{C}$ (PLCC)Lead Temperature (Soldering 10s) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $+300^{\circ} \mathrm{C}$CAUTION: Stresses above those listed in the "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating andoperation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.

## Operating Conditions

## D.C. Electrical Specifications

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| I'COP | Power Supply Current | - | 363 | mA | $V_{C C}=M a x$ <br> CLK Frequency 33 MHz <br> Note 2, Note 3, Note 4 |
| ICCsB | Standby Power Supply Current | - | 500 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=$ Max, Outputs Not Loaded |
| 1 | Input Leakage Current | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {CC }}=$ Max, Input $=0 \mathrm{~V}$ or $\mathrm{V}_{\text {CC }}$ |
| 10 | Output Leakage Current | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}$, Input $=0 \mathrm{~V}$ or $\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{V}_{\mathrm{IH}}$ | Logical One Input Voltage | 2.0 | - | V | $\mathrm{V}_{\text {CC }}=$ Max |
| $\mathrm{V}_{\mathrm{IL}}$ | Logical Zero Input Voltage | - | 0.8 | V | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}$ |
| VOH | Logical One Output Voltage | 2.6 | - | V | $1 \mathrm{OH}=-4000 \mathrm{~A}, \mathrm{~V}_{\mathrm{CC}}=\mathrm{Min}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Logical Zero Output Voltage | - | 0.4 | V | $\mathrm{I}_{\mathrm{OL}}=2 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=\mathrm{Min}$ |
| $\mathrm{V}_{\mathrm{IHC}}$ | Clock Input High | 3.0 | - | V | $\mathrm{V}_{\mathrm{CC}}=$ Max |
| $\mathrm{V}_{\text {ILC }}$ | Clock input Low | - | 0.8 | V | $\mathrm{V}_{C C}=\mathrm{Min}$ |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance | - | 12 | pF | CLK Frequency 1 MHz All measurements referenced |
| COUT | Output Capacitance | - | 12 | pF | to GND. $T_{A}=+25^{\circ} \mathrm{C} \text {, Note } 1$ |

## NOTES:

1. Controlled via design or process parameters and not directly tested. Characterized upon initial design and after major process and/or changes.
2. Power Supply current is proportional to operating frequency. Typical rating for ${ }^{1} \mathrm{CCOP}$ is $11 \mathrm{~mA} / \mathrm{MHz}$.
3. Output load per test load circuit and $C_{L}=40 \mathrm{pF}$.
4. Maximum junction temperature must be considered when operating part at high clock frequencies.
A.C. Electrical Specifications $\mathrm{V}_{\mathrm{CC}}=+4.75 \mathrm{~V}$ to $+5.25 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ (Note 1)

| SYMBOL | PARAMETER | 33 MHz |  | 45 MHz |  | COMMENTS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |  |
| $\mathrm{T}_{\mathrm{CP}}$ | CLK Period | 30 | - | 22 | - | ns |
| $\mathrm{T}_{\mathrm{CH}}$ | CLK High | 12 | - | 8 | - | ns |
| TCL | CLK Low | 12 | - | 8 | - | ns |
| TWP | WR\# Period | 30 | - | 22 | - | ns |
| TWH | WR\# High | 12 | - | 10 | - | ns |
| TWL | WR\# Low | 12 | - | 10 | - | ns |
| TAWS | Set-up Time AO-8 to WR\# Going Low | 10 | - | 8 | - | ns |
| TAWH | Hold Time AO-8 from WR\# Going High | 0 | - | 0 | - | ns |
| TCWS | Set-up Time CINO-9 to WR\# Going High | 12 | - | 10 | - | ns |
| TCWH | Hold Time CINO-9 from WR\# Going High | 1 | - | 1 | - | ns |
| TWLCL | Set-up Time WR\# Low to CLK Low | 5 | - | 3 | - | ns, Note 2 |
| TCVCL | Set-up Time CINO-9 to CLK Low | 7 | - | 7 | - | ns, Note 2 |
| TECS | Set-up Time CSELO-5, SHFTEN\#, FWRD\#, RVRS\#, TXFR\#, MUXO-1 to CLK Going High | 15 | - | 12 | - | ns |
| TECH | Hold Time CSELO-5, SHFTEN\#, FWRD\#, RVRS\#, TXFR\#, MUXO-1 to CLK Going High | 0 | - | 0 | - | ns |
| TDO | CLK to Output Delay OUTO-27 | - | 14 | - | 12 | ns |
| TOE | Output Enable Time | - | 12 | - | 12 | ns |
| TOD | Output Disable Time | - | 12 | - | 12 | ns, Note 3 |
| TRF | Output Rise, Fall Time | - | 6 | - | 6 | ns, Note 3 |

NOTES:

1. AC tests performed with $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}, \mathrm{I}_{\mathrm{OL}}=2 \mathrm{~mA}$, and $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$. Input reference level CLK $=2.0 \mathrm{~V}$. Input reference level for all other inputs is 1.5 V . Test $\mathrm{V}_{\mathrm{IH}}=3.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{IHC}}=4.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{IL}}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{ILC}}=0 \mathrm{~V}$.
2. Set-up time requirement for loading of data on CINO-9 to guarantee recognition on the following clock.
3. Controlled via design or process parameters and not directly tested. Characterized upon initial design and after major process and/or changes.
A.C. Test Load Circuit


## Waveforms



OEL \#, OEH \#

OUTO-27


OUTPUT ENABLE, DISABLE TIMING


OUTPUT RISE AND FALL TIMES

Dual FIR Filter

## Features

- Two Independent 8-Tap FIR Filters Configurable as a Single 16-Tap FIR
- 10 Bit Data \& Coefficients
- On-Board Storage for 32 Programmable Coefficient Sets
- Up To: 256 FIR Taps, $16 \times 16$ 2-D Kernels, or $10 \times 20$ Bit Data and Coefficients
- Programmable Decimation to 16
- Programmable Rounding on Output
- Mixed Mode Arithmetic
- Standard Microprocessor Interface
- 33MHz, 25.6MHz Versions
- 84-Pin PGA


## Applications

- Quadrature Filtering
- Correlation
- Image Processing
- Complex Filtering
- PolyPhase Filtering
- Adaptive Filtering


## Description

The HSP43168 Dual FIR Filter consists of two independent 8-tap FIR filters. Each filter supports decimation from 1 to 16 and provides on-board storage for 32 sets of coefficients. The Block Diagram shows two FIR cells each fed by a separate coefficient bank and one of two separate inputs. The outputs of the FIR cells are either summed or multiplexed by the MUX/Adder. The compute power in the FIR Cells can be configured to provide quadrature filtering, complex filtering, 2-D convolution, 1-D/2-D correlations, and interpolating/decimating filters.

The FIR cells take advantage of symmetry in FIR coefficients by pre-adding data samples prior to multiplication. This allows an 8 -tap FIR to be implemented using only 4 multipliers per filter cell. These cells can be configured as either a single 16-tap FIR filter or dual 8 -tap FIR filters. Asymmetric filtering is also supported.

Decimation of up to 16 is provided to boost the effective number of filter taps from 2 to 16 times. Further, the decimation registers provide the delay necessary for fractional data conversion and 2-D filtering with kernels to $16 \times 16$.

The flexibility of the Dual is further enhanced by 32 sets of user programmable coefficients. Coefficient selection may be changed asynchronously from clock to clock. The ability to toggle between coefficient sets further simplifies applications such as polyphase or adaptive filtering.
The HSP43168 is a low power fully static design implemented in an advanced CMOS process. The configuration of the device is controlled through a standard microprocessor interface. The Dual FIR Filter is available in 84 pin PGA.

## Block Diagram



## Pinouts



84 PIN PGA BOTTOM VIEW


| Absolute Maximum Ratings |  |
| :---: | :---: |
| Supply Voltage | +8.0V |
| Input, Output or I/O Voltage | .GND-0.5V to $\mathrm{V}_{\mathrm{CC}}+0.5 \mathrm{~V}$ |
| Storage Temperature Range | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Junction Temperature. | $+175^{\circ} \mathrm{C}$ |
| Lead Temperature (Soldering 10s). | $+300^{\circ} \mathrm{C}$ |
| ESD Classification | Class 1 |

Reliability Information

| Thermal Resistance Ceramic PGA Package |  | $\begin{gathered} \theta_{j c} \\ 7.5^{\circ} \mathrm{C} / \mathrm{W} \end{gathered}$ |
| :---: | :---: | :---: |
| Maximum Package Power Dissipation at $+125^{\circ} \mathrm{C}$ |  |  |
| Ceramic PGA Package | 1.49 W |  |
| Gate Count |  | 2529 Gates |

CAUTION: Stresses above those listed in "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.

## Operating Conditions

Operating Voltage Range. +4.5 V to +5.5 V Operating Temperature Range
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
TABLE 1. DC ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and 100\% Tested

| PARAMETER | SYMBOL | CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| Logical One Input Voltage | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 2.2 | - | V |
| Logical Zero Input Voltage | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{\mathrm{cc}}=4.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 0.8 | V |
| Logical One Input Voltage Clock | $\mathrm{V}_{\text {IHC }}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 3.0 | - | V |
| Logical Zero Input Voltage Clock | $\mathrm{V}_{\text {ILC }}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 0.8 | V |
| Output HIGH Voltage | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}(\text { Note } 1) \end{aligned}$ | 1,2,3 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 2.6 | - | V |
| Output LOW <br> Voltage | $V_{\text {OL }}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OL}}=+2.0 \mathrm{~mA} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}(\text { Note } 1) \end{aligned}$ | 1,2,3 | $-55^{\circ} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 0.4 | V |
| Input Leakage Current | 1 | $\begin{aligned} & V_{I N}=V_{C C} \text { or } G N D \\ & V_{C C}=5.5 V \end{aligned}$ | 1,2,3 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Output Leakage Current | 10 | $\begin{aligned} & V_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}} \text { or } \mathrm{GND} \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V} \end{aligned}$ | 1,2,3 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Standby Power Supply Current | Iccss | $\begin{aligned} & \mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}} \text { or } \mathrm{GND} \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \\ & \text { Outputs Open } \end{aligned}$ | 1,2,3 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 500 | $\mu \mathrm{A}$ |
| Operating Power Supply Current | I'cop | $\begin{aligned} & f=25.6 \mathrm{MHz}, \mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}} \\ & \text { or GND, } \mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V} \\ & \text { (Note 2) } \end{aligned}$ | 1,2,3 | $-55^{\circ} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 281.6 | mA |
| Functional Test | FT | (Note 3) | 7,8 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | - | - |

NOTES:

1. Interchanging of force and sense conditions is permitted.
2. Operating Supply Current is proportional to frequency, typical rating is $11 \mathrm{~mA} / \mathrm{MHz}$.
3. Tested as follows: $f=1 \mathrm{MHz}, \mathrm{V}_{\mathrm{IH}}$ (clock inputs) $=3.4 \mathrm{~V}, \mathrm{~V}_{\mathrm{H}}$ (all other inputs) $=2.6 \mathrm{~V}, \mathrm{~V}_{\mathrm{IL}}=0.4 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}} \geq 1.5 \mathrm{~V}$, and $\mathrm{V}_{\mathrm{OL}} \leq 1.5 \mathrm{~V}$.

TABLE 2. AC ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and 100\% Tested

| PARAMETER | SYMBOL | (NOTE 1) CONDITIONS | $\begin{aligned} & \text { GROUP A } \\ & \text { SUB- } \\ & \text { GROUPS } \end{aligned}$ | TEMPERATURE | (-33MHz) |  | (-25MHz) |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| CLK Period | $\mathrm{T}_{\text {CP }}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 30 | - | 39 | - | ns |
| CLK High | $\mathrm{T}_{\mathrm{CH}}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 12 | - | 15 | - | ns |
| CLK Low | TCL |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 12 | - | 15 | - | ns |
| WR\# Period | $\mathrm{T}_{\text {WP }}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 30 | - | 39 | - | ns |
| WR\# High | $\mathrm{T}_{\text {WH }}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 12 | - | 15 | - | ns |
| WR\# Low | $\mathrm{T}_{\mathrm{WL}}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 12 | - | 15 | - | ns |
| Set-up Time; A0-8 to WR\# Low | $\mathrm{T}_{\text {AWs }}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 10 | - | 10 | - | ns |
| Hold Time; A0-8 to WR\# High | $\mathrm{T}_{\text {AWH }}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 1 | $\bullet$ | 1 | - | ns |
| Set-up Time; CINO-9 to WR\# High | $\mathrm{T}_{\text {cws }}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 12 | - | 15 | - | ns |
| Hold Time; CINO-9 to WR\# High | $\mathrm{T}_{\text {CWH }}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 1.5 | - | 1.5 | - | ns |
| Set-up Time; WR\# Low to CLK Low | $\mathrm{T}_{\text {WLCL }}$ | Note 3 | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 5 | - | 8 | - | ns |
| Set-up Time; CINO-9 to CLK Low | T CVCL | Note 3 | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 8 | - | 8 | - | ns |
| Set-up Time; CSELO-5, SHFTEN\#, FWRD\#, RVRS\#, TXFR\#, MUX0-1 to CLK High | $\mathrm{T}_{\text {ECS }}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 15 | - | 17 | $\bullet$ | ns |
| Hold Time; CSELO-5, SHFTEN\#, FWRD\#, RVRS\#, TXFR\#, MUXO-1 to CLK High | $\mathrm{T}_{\mathrm{ECH}}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns |
| CLK to Output Delay OUTO-27 | $\mathrm{T}_{\mathrm{DO}}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 15 | - | 17 | - | ns |
| Output Enable Time | ToE | Note 2 | 9, 10, 11 | $-55^{\circ} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 12 | - | 12 | - | ns |

## NOTES:

1. AC testing is performed as follows: Input levels (CLK Input) 4.0 V and 0 V ; Input levels (all other inputs) 3.0 V and 0 V ; Timing reference levels (CLK) 2.0V; All others 1.5 V . $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and 5.5 V . Output load per test load circuit with $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$. Output transition is measured at $\mathrm{V}_{\mathrm{OH}}>1.5 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{L}}<1.5 \mathrm{~V}$.
2. Transition is measured at $\pm 200 \mathrm{mV}$ from steady state voltage, Output loading per test load circuit, $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$.
3. Set-up time requirements for loading of data on CINO-9 to guarantee recognition on the following clock.

TABLE 3. ELECTRICAL PERFORMANCE CHARACTERISTICS

| PARAMETER | SYMBOL | CONDITIONS | NOTES | TEMPERATURE | (-33MHz) |  | (-25MHz) |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| Input Capacitance | $\mathrm{C}_{\text {IN }}$ | $\mathrm{V}_{\mathrm{cc}}=\text { Open, } \mathrm{f}=1 \mathrm{MHz}$ <br> All measurements are referenced to device GND. | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 12 | - | 12 | pF |
| Output Capacitance | $\mathrm{C}_{\text {OUT }}$ |  | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 12 | - | 12 | pF |
| Output Disable Time | $\mathrm{T}_{\text {OD }}$ |  | 1,2 | $-55^{\circ} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 12 | - | 12 | ns |
| Output Rise Time | $\mathrm{T}_{\mathrm{R}}$ | From 0.8 V to 2.0 V | 1,2 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 8 | - | 8 | ns |
| Output Fall Time | $\mathrm{T}_{\mathrm{F}}$ | From 2.0 V to 0.8 V | 1,2 | $-55^{\circ} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 8 | - | 8 | ns |

NOTE:

1. The parameters in Table 3 are controlled via design or process parameters and not directly tested. Characterized upon initial design and after major process and/or design changes.
2. Loading is as specified in the test load circuit with $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$.

TABLE 4. APPLICABLE SUBGROUPS

| CONFORMANCE GROUPS | METHOD | SUBGROUPS |
| :--- | :---: | :---: |
| Initial Test | $100 \% / 5004$ | - |
| Interim Test | $100 \% / 5004$ | - |
| PDA | $100 \%$ | 1 |
| Final Test | $100 \%$ | $2,3,8 \mathrm{~A}, 8 \mathrm{~B}, 10,11$ |
| Group A | - | $1,2,3,7,8 \mathrm{~A}, 8 \mathrm{~B}, 9,10,11$ |
| Groups C and D | Samples/5005 | $1,7,9$ |

## AC Test Load Circuit



SWITCH S1 OPEN FOR I $I_{\text {cCSB }}$ AND ICCOP TEST

## Waveforms



OUTPUT ENABLE, DISABLE TIMING


OUTPUT RISE AND FALL TIMES

## Burn-In Circuit

84 PIN PGA
BOTTOM VIEW


NOTES:

1. $\mathrm{V}_{\mathrm{C}} \mathrm{d}^{2}(2.7 \mathrm{~V} \pm 10 \%)$ used for outputs only.
2. $47 \mathrm{~K} \Omega( \pm 20 \%)$ resistor connected to all pins except $\mathrm{V}_{\mathrm{CC}}$ and $G N D$
3. $V_{C C}=5.5 \pm 0.5 \mathrm{~V}$.
4. $0.1 \mu \mathrm{f}$ (Min) capacitor between $\mathrm{V}_{\mathrm{CC}}$ and GND per position.

| PGA <br> PIN | PIN <br> NAME | BURN-IN <br> SIGNAL |
| :--- | :--- | :--- |
| A1 | CIN8 | F9 |
| A2 | CSEL4 | F12 |
| A3 | CSEL3 | F11 |
| A4 | CSEL1 | F9 |
| A5 | A8 | F12 |
| A6 | A7 | F10 |
| A7 | A4 | F11 |
| A8 | A1 | F12 |
| A9 | GND | GND |
| A10 | WRB | F6 |
| A11 | RVRS | F12 |
| B1 | CIN5 | F8 |
| B2 | CIN7 | F10 |
| B3 | CIN9 | F10 |
| B4 | CSEL2 | F10 |
| B5 | $V_{\text {CC }}$ | $V_{\text {CC }}$ |
| B6 | A2 | F11 |
| B7 | A3 | F10 |
| B8 | A0 | F13 |
| B9 | MUX1 | F13 |
| B10 | MUX0 | F12 |


| PGA <br> PIN | PIN <br> NAME | BURN-IN <br> SIGNAL |
| :--- | :--- | :--- |
| B11 | SHFTEN | F14 |
| C1 | CIN4 | F7 |
| C2 | CIN6 | F9 |
| C5 | CSEL0 | F8 |
| C6 | A6 | F11 |
| C7 | A5 | F12 |
| C10 | FWRD | F13 |
| C11 | TXFR | F11 |
| D1 | CIN3 | F10 |
| D2 | GND | GND |
| D10 | ACCEN | F13 |
| D11 | $V_{\text {CC }}$ | $V_{C C}$ |
| E1 | CIN0 | F7 |
| E2 | CIN1 | F8 |
| E3 | CIN2 | F9 |
| E9 | CLK | F0 |
| E10 | GND | GND |
| E11 | OEHB | F14 |
| F1 | $V_{\text {CC }}$ | $V_{C C}$ |
| F2 | INA9 | F10 |
| F3 | INA8 | F9 |


| $\begin{aligned} & \hline \text { PGA } \\ & \text { PIN } \end{aligned}$ | PIN NAME | BURN-IN SIGNAL |
| :---: | :---: | :---: |
| F9 | SUM26 | $\mathrm{V}_{\mathrm{c}}{ }^{\text {2 }}$ |
| F10 | SUM22 | $\mathrm{V}_{\mathrm{cc}}$ 2 |
| F11 | SUM27 | $\mathrm{V}_{\mathrm{cd}}$ 2 |
| G1 | INA6 | F7 |
| G2 | INA5 | F6 |
| G3 | INA7 | F8 |
| G9 | SUM25 | $\mathrm{V}_{\mathrm{cd}} / 2$ |
| G10 | SUM23 | $\mathrm{V}_{\mathrm{c}}{ }^{2} 2$ |
| G11 | SUM24 | $\mathrm{V}_{\mathrm{c}}{ }^{2} 2$ |
| H1 | INA4 | F5 |
| H2 | INA3 | F4 |
| H10 | SUM20 | $\mathrm{V}_{\mathrm{Cd}}$ 2 |
| H11 | SUM21 | $\mathrm{V}_{\mathrm{c} / 2} 2$ |
| J1 | INA2 | F3 |
| J2 | INAO | F1 |
| J5 | INB3 | F4 |
| J6 | OELB | F13 |
| J7 | SUM9 | $\mathrm{V}_{\mathrm{Cd}}{ }^{2}$ |
| 110 | SUM17 | $\mathrm{V}_{\mathrm{c}}{ }^{2} 2$ |
| J11 | SUM19 | $\mathrm{V}_{\mathrm{c}}{ }^{2}$ 2 |
| K1 | INA1 | F2 |


| $\begin{array}{\|l} \hline \text { PGA } \\ \text { PIN } \end{array}$ | PIN NAME | BURN-IN SIGNAL |
| :---: | :---: | :---: |
| K2 | INB8 | F9 |
| K3 | INB7 | F8 |
| K4 | GND | GND |
| K5 | INB2 | F3 |
| K6 | INBO | F1 |
| K7 | $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ |
| K8 | SUM13 | $\mathrm{V}_{\mathrm{cd}}$ 2 |
| K9 | SUM16 | $\mathrm{V}_{\mathrm{cd}}$ 2 |
| K10 | $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{C C}$ |
| K11 | SUM18 | $\mathrm{V}_{\mathrm{Cd}}$ 2 |
| L1 | INB9 | F10 |
| L2 | INB6 | F7 |
| L3 | INB5 | F6 |
| L4 | INB4 | F5 |
| L5 | INB1 | F2 |
| L6 | SUM11 | $\mathrm{V}_{\mathrm{C}}{ }^{2} 2$ |
| L7 | SUM10 | $\mathrm{V}_{\mathrm{cd}}$ 2 |
| L8 | SUM12 | $\mathrm{V}_{\mathrm{cd}} / 2$ |
| L9 | SUM14 | $\mathrm{V}_{\mathrm{c} \text { d }}$ 2 |
| L10 | SUM15 | $\mathrm{V}_{\mathrm{cd}}$ 2 |
| L11 | GND | GND |

## Metallization Topology

DIE DIMENSIONS:
$314 \times 348 \times 19 \pm 1$ mils
METALLIZATION:
Type: Si-Al or Si-Al-Cu
Thickness: 8kA
GLASSIVATION:
Type: Nitrox
Thickness: $10 \mathrm{k} \AA$

DIE ATTACH:
Material: Silver Glass
WORST CASE CURRENT DENSITY:
$1.93 \times 10^{5} \mathrm{~A}^{\mathrm{cm}}{ }^{2}$

Metallization Mask Layout
HSP43168/883


## Features

- Single Chip Narrow Band Filter with up to 96 dB Attenuation
- DC to 33 MHz Clock Rate
- 16 Bit 2's Complement Input
- 20 Bit Coefficients in FIR
- 24 Bit Extended Precision Output
- Programmable Decimation up to a Maximum of 16,384
- Standard 16 Bit Microprocessor Interface
- Filter Design Software Available DECI•MATE ${ }^{\text {m }}$
- Available in 84 Pin PGA and PLCC


## Applications

- Very Narrow Band Filters
- Zoom Spectral Analysis
- Channelized Receivers
- Large Sample Rate Converter
- Instrumentation
- 512 Tap Symmetric FIR filtering


## Description

The HSP43220 Decimating Digital Filter is a linear phase low pass decimation filter which is optimized for filtering narrow band signals in a broad spectrum of a signal processing applications. The HSP43220 offers a single chip solution to signal processing application which have historically required several boards of IC's. This reduction in component count results in faster development times as well as reduction of hardware costs.

The HSP43220 is implemented as a two stage filter structure. As seen in the block diagram, the first stage is a high order decimation filter (HDF) which utilizes an efficient decimation (sample rate reduction) technique to obtain decimation up to 1024 through a coarse low-pass filtering process. The HDF provides up to 96 dB aliasing rejection in the signal pass band. The second stage consists of a finite impulse response (FIR) decimation filter structured as a transversal FIR filter with up to 512 symmetric taps which can implement filters with sharp transition regions. The FIR can perform further decimation by up to 16 if required while preserving the 96 dB aliasing attenuation obtained by the HDF. The combined total decimation capability is 16,384 .

The HSP43220 accepts 16 bit parallel data in 2's complement format at sampling rates up to 33 MSPS . It provides a 16 bit microprocessor compatible interface to simplify the task of programming and three-state outputs to allow the connection of several IC's to a common bus. The HSP43220 also provides the capability to bypass either the HDF or the FIR for additional flexibility.

## Block Diagram



DECI • MATE ${ }^{\text {m }}$ is a registered trademark of Harris Corporation. IBM PC ${ }^{\mathrm{mw}}, \mathrm{XT}^{{ }^{\mathrm{m}}}, \mathrm{AT}^{\mathrm{mw}}, \mathrm{PS} / 2^{\text {w }}$ are registered trademarks of International Business Machines, Inc.


84 PLASTIC LEADED CHIP CARRIER (PLCC)


## Pin Description

| NAME | PLCC PIN | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ | $\begin{gathered} 13,28,42,45, \\ 60,75,78 \end{gathered}$ |  | The +5 V power supply pins. |
| GND | $\begin{gathered} \hline 11,29,43,46, \\ 61,74,77 \\ \hline \end{gathered}$ |  | The device ground. |
| CK_IN | 76 | 1 | Input sample clock. Operations in the HDF are synchronous with the rising edge of this clock signal. The maximum clock frequency is 33 MHz . CK_IN is synchronous with FIR_CK and thus the two clocks may be tied together if required, or CK__IN can be divided down from FIR__CK. CK_IN is a CMOS level signal. |
| FIR_CK | 44 | 1 | Input clock for the FIR filter. This clock must be synchronous with CK__IN. Operations in the FIR are synchronous with the rising edge of this clock signal. The maximum clock frequency is 33 MHz . FIR__CK is a CMOS level signal. |
| DATA__INO-15 | 1-10,79-84 | 1 | Input Data bus. This bus is used to provide the 16-bit input data to the HSP43220. The data must be provided in a synchronous fashion, and is latched on the rising edge of the CK_IN signal. The data bus is in 2's complement fractional format. |
| C_BUSO-15 | 21-27, $30-38$ | 1 | Control Input bus. This input bus is used to load all the filter parameters. The pins WR\#, CS\# and AO, A1 are used to select the destination of the data on the Control bus and write the Control bus data into the appropriate register as selected by AO and A1. |
| $\begin{gathered} \text { DATA_OUT } \\ 0-23 \end{gathered}$ | 48-59, 62-73 | 0 | Output Data bus. This 24-Bit output port is used to provide the filtered result in 2's complement format. The upper 8 bits of the output, DATA__OUT16-23 will provide extension or growth bits depending on the state of OUT__SELH and whether the FIR has been put in bypass mode. Output bits DATA_OUTO-15 will provide bits $2^{0}$ through $2^{-15}$ when the FIR is not bypassed and will provide the bits $2^{-16}$ through $2^{-31}$ when the FIR is in bypass mode. |
| DATA_RDY | 47 | 0 | An active high output strobe that is synchronous with FIR_CK that indicates that the result of the just completed FIR cycle is available on the data bus. |
| RESET\# | 16 | 1 | RESET\# is an asynchronous signal which requires that the input clocks CK_IN and FIR_CK are active when RESET\# is asserted. RESET\# disables the clock divider and clears all of the internal data registers in the HDF. The FIR filter data path is not initialized. The control register bits that are cleared are F_BYP, H_STAGES, and H__DRATE. The F__DIS bit is set. In order to guarantee consistent operation of the part, the user must reset the DDF after power up. |
| WR\# | 19 | 1 | Write strobe. WR\# is used for loading the internal registers of the HSP43220. When CS\# and WR\# are asserted, the rising edge of WR\# will latch the C_BUSO-15 data into the register specified by AO and A1. |
| CS\# | 20 | 1 | Chip Select. The Chip Select input enables loading of the internal registers. When CS\# and WR\# are low, the AO and A1 address lines are decoded to determine the destination of the data on C__BUSO-15. The rising edge of WR\# then loads the appropriate register as specified by AO and A1. |
| AO, A1 | 18,17 | 1 | Control Register Address. These lines are decoded to determine which control register is the destination for the data on C__BUSO-15. Register loading is controlled by the AO and A1, WR \# and CS\# inputs. |
| ASTARTIN\# | 15 | 1 | ASTARTIN\# is an asynchronous signal which is sampled on the rising edge of CK_IN. It is used to put the DDF in operational mode. ASTARTIN\# is internally synchronized to CK_IN and is used to generate STARTOUT\#. |
| STARTOUT\# | 12 | 0 | STARTOUT\# is a pulse generated from the internally synchronized version of ASTARTIN\#. It is provided as an output for use in multi-chip configurations to synchronously start multipie HSP43220's. The width of STARTOUT\# is equal to the period of CK_iN. |
| STARTIN\# | 14 | 1 | STARTIN\# is a synchronous input. A high to low transition of this signal is required to start the part. STARTIN\# is sampled on the rising edge of CK_IN. This synchronous signal can be used to start single or multiple HSP43220's. |
| OUT__SELH | 39 | 1 | Output Select. The OUT__SELH input controls which bits are provided at output pins DATA_OUT16-23. A HIGH on this control line selects bits $2^{8}$ through $2^{1}$ from the accumulator output. A LOW on this control line selects bits $2^{-16}$ through $2^{-23}$ from the accumulator output. Processing is not interrupted by this pin. |
| OUT_ENP\# | 40 | 1 | Output Enable. The OUT__ENP\# input controls the state of the lower 16 bits of the output data bus, DATA__OUTO-15. A LOW on this control line enables the lower 16 bits of the output bus. When OUT_ENP\# is HIGH, the output drivers are in the high impedance state. Processing is not interrupted by this pin. |
| OUT_ENX\# | 41 | 1 | Output Enable. The OUT__ENX\# input controls the state of the upper 8 bits of the output data bus, DATA__OUT16-23. A LOW on this control line enables the upper 8 bits of the output bus. When OUT_ENX\# is HIGH, the output drivers are in the high impedance state. Processing is not interrupted by this pin. |

## The HDF

The first filter section is called the High Order Decimation Filter (HDF) and is optimized to perform decimation by large factors. It implements a low pass filter using only adders and delay elements instead of a large number of multiplier/ accumulators that would be required using a standard FIR filter.

The HDF is divided into 4 sections: the HDF filter section, the clock divider, the control register logic and the start logic (Figure 1).

## Data Shifter

After being latched into the Input Register the data enters the Data Shifter. The data is positioned at the output of the shifter to prevent errors due to overflow occurring at the output of the HDF. The number of bits to shift is controlled by H__GROWTH.

## Integrator Section

The data from the shifter goes to the Integrator section. This is a cascade of 5 integrator (or accumulator) stages, which implement a low pass filter. Each accumulator is
implemented as an adder followed by a register in the feed forward path. The integrator is clocked by the sample clock, CK_IN as shown in Figure 2. The bit width of each integrator stage goes from 66 bits at the first integrator down to 26 bits at the output of the fifth integrator. Bit truncation is performed at each integrator stage because the data in the integrator stages is being accumulated and thus is growing, therefore the lower bits become insignificant, and can be truncated without losing significant data.

There are three signals that control the integrator section; they are H_STAGES, H_BYP and RESET\#. In Figure 2 these control signals have been decoded and are labelled INT__EN1 - INT__EN5. The order of the filter is loaded via the control bus and is called H__STAGES. H__STAGES is decoded to provide the enables for each integrator stage. When a given integrator stage is selected, the feedback path is enabled and the integrator accumulates the current data sample with the previous sum. The integrator section can be put in bypass mode by the H__BYP bit. When H__BYP or RESET\# is asserted, the feedback paths in all integrator stages are cleared.


HDF FILTER SECTION


FIGURE 1. HIGH ORDER DECIMATION FILTER


FIGURE 2. INTEGRATOR

## Decimation Register

The output of the Integrator section is latched into the Decimation Register by CK_DEC. The output of the Decimation register is cleared when RESET\# is asserted. The HDF decimation rate $=\mathrm{H}$ _ DRATE +1 , which is defined as Hdec for convenience.

## Comb Filter Section

The output of the Decimation Register is passed to the Comb Filter Section. The Comb section consists of 5 cascaded Comb filters or differentiators. Each Comb filter section calculates the difference between the current and previous integrator output. Each Comb filter consists of a register which is clocked by CK__DEC, followed by an subtractor, where the subtractor calculates the difference between the input and output of the register. Bit truncations are done at each stage as shown in Figure 3. The first stage bit width is 26 bits and the output of the fifth stage is 19 bits.
There are three signals that control the Comb Filter; $\mathrm{H}_{-}$ STAGES, H_BYP and RESET\#. In Figure 3 these control signals are decoded as COMB__EN1 - COMB__EN5. The order of the Comb filter is controlled by H__STAGES, which is programmed over the control bus. H__BYP is used to put the comb section in bypass mode. RESET\# causes the register output in each Comb stage to be cleared. The $\mathrm{H}_{-}$ BYP and RESET\# control pins, when asserted force the output of all registers to zero so data is passed through the subtractor unaltered. When the H_STAGES control bits enable a given stage the output of the register is subtracted from the input.
It is important to note that the Comb filter section has a speed limitation. The Input sampling rate divided by the decimation factor in the HDF (CK_IN/Hdec) should not exceed 4 MHz . Violating this condition causes the output of the filter to be incorrect. When the HDF is put in bypass mode this limitation does not apply. Equation 1.0 describes the relationship between F__TAPS, F__DRATE, H__DRATE, CK_IN and FIR_CK.

## Rounder

The filter accuracy is limited by the 16 bit data input. To maintain the maximum accuracy, the output of the comb is rounded to 16 bits.

The Rounder performs a symmetric round of the 19 bit output of the last Comb stage. Symmetric rounding is done to prevent the synthesis of a OHz spectral component by the rounding process and thus causing a reduction in spurious free dynamic range. Saturation logic is also provided to prevent roll over from the largest positive value to the most negative value after rounding. The output of the last comb filter stage in the HDF section has a 16 bit integer portion with a 3 bit fractional part in 2's complement format.

The rounding algorithm is as follows:

| POSITIVE NUMBERS |  |
| :--- | :---: |
| Fractional Portion Greater Than or <br> Equal to 0.5 | Round Up |
| Fractional Portion Less Than 0.5 | Truncate |


| NEGATIVE NUMBERS |  |
| :--- | :---: |
| Fractional Portion Less Than or <br> Equal to 0.5 | Round Up |
| Fractional Portion Greater Than 0.5 | Truncate |

The output of the rounder is latched into the HDF output register with CK_DEC. CK_DEC is generated by the Clock Divider section. The output of the register is cleared when RESET\# is asserted.

## Clock Divider and Control Logic

The clock divider divides CK_IN by the decimation factor Hdec to produce CK__DEC. CK__DEC clocks the Decimation Register, Comb Filter section, HDF output register. In the FIR filter CK_DEC is used to indicate that a new data sample is available for processing. The clock generator is cleared by RESET\# and is not enabled until the DDF is started by an internal start signal (see Start Logic).
The Control Register Logic enables the updating of the Control registers which contain all of the filter parameter data. When WR\# and CS\# are asserted, the control register addressed by bits AO and A1 is loaded with the data on the C_BUS.


FIGURE 3. COMB FILTER

## DDF Control Registers

F__Register ( $\mathrm{A} 1=0, A 0=0$ )


Bits TO-T8 are used to specify the number of FIR filter taps. The number entered is one less than the number of taps required. For example, to specify a 511 tap filter F_TAPS would be programmed to 510 .

## F DRATE

Bits DO-D3 are used to specify the amount of FIR decimation. The number entered is one less than the decimation required. For example, to specify decimation of 16, F__DRATE would be programmed to 15. For no FIR decimation, F__DRATE would be set equal to O. FDRATE +1 is defined as Fdec.

## F_ESYM

Bit ESO is used to select the FIR symmetry. F__ESYM is set equal to one to select even symmetry and set equal to zero to select odd symmetry. When F__ESYM is one, data is added in the pre-adder; when it is zero, data is subtracted. Normally set to one.

F__BYP
Bit FBO is used to select FIR bypass mode. FIR bypass mode is selected by setting F__BYP=1. When FIR bypass mode is selected, the FIR is internally set up for a 3 tap even symmetric filter, no decimation ( F _DRATE $=0$ ) and F __OAD is set equal to one to zero one side of the preadder. In FIR bypass mode all FIR filter parameters, except F__CLA, are ignored, including the contents of the FIR coefficient RAM. In FIR bypass mode the output data is brought output on the lower 16 bits of the output bus DATA__OUT 0-15. To disable FIR bypass mode, F__BYP is set equal to zero. When F_BYP is returned to zero, the coefficients must be reloaded.

## F_OAD

Bit FAO is used to select the zero the preadder mode. This mode zeros one of the inputs to the pre-adder. Zero preadder mode is selected by setting F__OAD equal to one. This feature is useful when implementing arbitrary phase filters or can be used to verify the filter coefficients. To disable the Zero Preadder mode F__OAD is set equal to zero.

FIGURE 4.

## DDF Control Registers (Continued)

FC__Register ( $\mathrm{A} 1=0, \mathrm{AO}=1$ )

| F_CF |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| C19 | C18 | C17 | C16 | C15 | C14 | C13 | C12 | C11 | C10 | C9 | C8 | C7 | C6 | C5 | C4 |
| X | X | X | X | X | x | X | X | X | x | X | X | С3 | C 2 | C1 | co |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |

Bits C0-C19 represent the coefficient data, where C19 is the MSB. Two writes are required to write each coefficient which is 2's complement fractional format. The first write loads C19 through C4; C3 through CO are loaded on the second write cycle. As the coefficients are written into this register they are formatted into a 20 bit coefficient and written into the Coefficient RAM sequentially starting with address location zero. The coefficients must be loaded sequentially, with the center tap being the last coefficient to be loaded. See coefficient RAM, below.

FIGURE 5.
$H^{\prime}$ _Register $1(A 1=1, A O=0)$

| RESERVED |  |  | F_DIS | F_CLA | H__BYP | H_DRATE |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | FDO | FCO | HBO | R9 | R8 | R7 | R6 | R5 | R4 | R3 | R2 | R1 | RO |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |

Bits RO-R9 are used to select the amount of decimation in the HDF. The amount of decimation selected is programmed as the required decimation minus one; for instance to select decimation of 1024 H__DRATE is set equal to 1023 . HDRATE +1 is defined as Hdec.
H_BYP
Bit HBO is used to select HDF bypass mode. This mode is selected by setting $H$ __BYP $=1$. When this mode is selected the input data passes through the HDF unfiltered. Internally H_STAGES and H__DRATE are both set to zero and H__GROWTH is set to 50. H_REGISTER 2 must be reloaded when H__BYP is returned to 0 . To disable HDF bypass mode $\mathrm{H} \_$BYP $=0$. The relationship between CK_IN and FIR__CK in this and all other modes is defined by equation 1.0.
F__CLA
Bit FCO is used to select the clear accumulator mode in the FIR. This mode is enabled by setting F_CLA=1 and is disabled by setting $F$ __CLA $=0$. In normal operation this bit should be set equal to zero. This mode zeros the feedback path in the accumulator of the multiplier/accumualator (MAC). It also allows the multiplier output to be clocked off the chip by FIR_CK, thus DATA__RDY has no meaning in this mode. This mode can be used in conjunction with the F__OAD bit to read out the FIR coefficients from the coefficient RAM.
F__DIS
Bit FDO is used to select the FIR disabie mode. This feature enables the FIR parameters to be changed. This feature is selected by setting F__DIS $=1$. This mode terminates the current FIR cycle. While this feature is selected, the HDF contines to process data and write it into the FIR data RAM. When the FIR re-programming is completed, the FIR can be re-enabled either by clearing F__DIS, or by asserting one of the start inputs, which automatically clears F__DIS.

FIGURE 6

## DDF Control Registers (Continued)

H__Register $2(A 1=1, A 0=1)$


Bits NO-N2 are used to select the number of stages or order of the HDF filter. The number that is programmed in is equal to the required number of stages. For a 5th order filter, H_STAGES would be set equal to 5 .

## H_GROWTH

Bits G0-G5 are used to select the proper amount of growth bits. H__GROWTH is calculated using the following equation:

H__GROWTH $=50-$ CEILING $\{\mathrm{H}$ _STAGES $\times \log (\mathrm{Hdec}) /$ $\log (2)\}$
where the CEILING \{ \} means use the next largest integer of the result of the value in brackets and log is the log to the base 10.
The value of $H_{\text {_ GROWTH represents the position of the }}$ LSB on the output of the data shifter.

FIGURE 7

## Start Logic

The Start Logic generates a start signal that is used internally to synchronously start the DDF. If ASTARTIN\# is asserted (STARTIN\# must be tied high) the Start Logic synchronizes it to CK_IN by double latching the signal and generating the signal STARTOUT\#, which is shown in Figure 8. The STARTOUT\# signal is then used to synchronously start other DDFs in a multi-chip configuration (the STARTOUT\# signal of the first DDF would be tied to the STARTIN\# of the second DDF). The NAND gate shown in Figure 8 then passes this synchronized signal to be used on chip to provide a synchronous start. Once started, the chip requires a RESET\# to halt operation.

When STARTIN\# is asserted (ASTARTIN\# must be tied high) the NAND gate passes STARTIN\# which is used to provide the internal start, ISTART, for the DDF. When RESET\# is asserted the internal start signal is held inactive, thus it is necessary to assert either ASTARTIN\# or STARTIN\# in order to start the DDF. The timing of the first valid DATA_IN with respect to START__IN\# is shown in the Timing Waveforms below.

In using ASTARTIN\# or STARTIN\# a high to low transition must be detected by the rising edge of CK__IN, therefore these signals must have been high for more than one CK__IN cycle and then taken low.

RESET\#


## The FIR Section

The second filter in the top level block diagram is a Finite Impulse Response (FIR) filter which performs the final shaping of the signal spectrum and suppresses the aliasing components in the transition band of the HDF. This enables the DDF to implement filters with narrow pass bands and sharp transition bands.

The FIR is implemented in a transversal structure using a single multiplier/accumulator (MAC) and RAM for storage of the data and filter coefficients as shown in Figure 9. The FIR can implement up to 512 symmetric taps and decimation up to 16 .

The FIR is divided into 2 sections: the FIR filter section and the FIR control logic.

## Coefficient RAM

The Coefficient RAM stores the coefficients for the current FIR filter being implemented. The coefficients are loaded into the Coefficient RAM over the control bus (C_BUS). The coefficients are written into the Coefficient RAM sequentially, starting at location zero. It is only necessary to write one half of the coefficients when symmetric filters are being implemented, where the last coefficient to be written in is the center tap.

The coefficients are loaded into address 01 in two writes. The first write loads the upper 16 bits of the 20 bit coefficient, C4 through C19. The second write loads the lower 4 bits of the coefficient, CO through C3, where C19 is the MSB. The two 16 bit writes are then formatted into the 20 bit coefficient that is then loaded into the Coefficient RAM starting at RAM address location zero, where the coefficient at this location is the outer tap (or the first coefficient value).

To reload coefficients, the Coefficient RAM Address pointer must be reset to location zero so that the coefficients will be loaded in the order the FIR filter expects. There are two methods that can be used to reset the Coefficient RAM address pointer. The first is to assert RESET\#, which automatically resets the pointer, but also clears the HDF and alters some of the control register bits. (RESET\# does not change any of the coefficient values.) The second method is to set the F_DIS bit in control register H_ REGISTER1. This control bit allows any of the FIR control register bits to be re-programmed, but does not automatically modify any control registers. When the programming is completed, the FIR is re-started by clearing the F__DIS bit or by asserting one of the start inputs (ASTARTIN\# or STARTIN\#). The F__DIS bit allows the filter parameters to be changed more quickly and is thus the recommended reprogramming method.

## Data RAM

The Data RAM stores the data needed for the filter calculation. The format of the data is:
$2^{0} . \mathbf{2}^{-1} \mathbf{1}_{2}-\mathbf{2}_{2}-3_{2}-\mathbf{4}_{2}-\mathbf{5}_{2}-\mathbf{6}_{2}-\mathbf{7}_{2}-8_{2}-9_{2}-10_{2}-11_{2}-12_{2}-13_{2}-14_{2}-15$ where the sign bit is in the $2^{0}$ location.

The 16 bit output of the HDF Output Register is written into the Data Ram on the rising edge of CK_DEC.

RESET\# initializes the write pointer to the data RAM. After a RESET\# occurs, the output of the FIR will not be valid until the number of new data samples written to the Data RAM equals TAPS.
The filter always operates on the most current sample and the taps -1 previous samples. Thus if the F__DIS bit is set, data continues to be written into the data RAM coming from the HDF section. When the FIR is enabled again the filter will be operating on the most current data samples and thus another transient response will not occur.
The maximum throughput of the FIR filter is limited by the use of a single Multiplier/Accumulator (MAC). The data output from the HDF being clocked into the FIR filter by CK__DEC must not be at a rate that causes an erroneous result being calculated because data is being overwritten.

The equation shown below describes the relationship between, FIR_CK, CK_DEC, the number of taps that can be implemented in the FIR, the decimation rate in the HDF and the decimation rate in the FIR. (In the Design Considerations section of the OPERATIONAL SECTION there is a chart that shows the tradeoffs between these parameters.)


This equation expresses the minimum FIR_CK. The minimum FIR_CK is the smallest integer multiple of CK__IN that satisfies equation 1.0. In addition, the TSK specification must be met (see A.C. Electrical Specifications). Fdec is the decimation rate in the FIR ( $\mathrm{Fdec}=\mathrm{F}$ _DRATE +1), where TAPS $=$ the number of taps in the FIR for even length filters and equals the number of taps +1 for odd length filters.
Solving the above equation for the maximum number of taps:
TAPS $=2\left(\frac{\text { FIR_CK Hdec Fdec }}{\text { CK_IN }}-\right.$ Fdec -4$)$
In using this equation, it must be kept in mind that CK__IN/ Hdec must be less than or equal to 4 MHz (unless the HDF is in bypass mode in which case this limitation in the HDF does not apply). In the OPERATIONAL SECTION under the Design Considerations, there is a table that shows the trade-offs of these parameters. In addition, Harris provides a software package called DECI • MATE ${ }^{\text {w }}$ which designs the DDF filter from System specifications.
The registered outputs of the data RAM are added or subtracted in the 17 bit pre-adder. The F__OAD control bit allows zeros to be input into one side of the pre-adder. This provides the capability to implement non-symmetric filters.

The selection of adding the register outputs for an even symmetric filter or for subtracting the register outputs for odd symmetric filter is provided by the control bit F__ESYM, which is programmed over the control bus. When subtraction is selected, the new data is subtracted from the old data. The 17 bit output of the adder forms one input of the multiplier/accumulator.

A control bit F__CLA provides the capability to clear the feedback path in the accumulator such that multiplier output will not be accumulated, but will instead flow directly to the output register. The bit weightings of the data and coefficients as they are processed in the FIR is shown below.

Input Data (from HDF) $2^{0} .2^{-1} \ldots 2^{-15}$
Pre-adder Output $2^{1} 2^{0} .2^{-1} \ldots 2^{-15}$
Coefficient $2^{0} .2^{-1} \ldots 2^{-19}$
Accumulator $2^{8} \ldots 2^{0} .2^{1} \ldots 2^{-34}$

## FIR Output

The 40 most significant bits of the accumulator are latched into the output register. The lower 3 bits are not brought to the output. The 40 bits out of the output register are selected to be output by a pair of multiplexers. This register is clocked by FIR_CK (see Figure 9).

There are two multiplexers that route 24 of the 40 output bits from the output register to the output pins. The first multiplexer selects the output register bits that will be routed to output pins DATA__OUT16-23 and the second multiplexer selects the output register bits that will be routed to output pins DATA_OUTO-15.

The multiplexers are controlled by the control signal $\mathrm{F}_{-}$ BYP and the OUT__SELH pin. F__BYP and OUT__SELH both control the first multiplexer that selects the upper 8 bits of the output bus, DATA__OUT16-23. F__BYP controls the second multiplexer that selects the lower 16 bits of the output bus, DATA__OUTO-15. The output formatter is shown in detail in Figure 10.

## FIR Control Logic

The DATA __RDY strobe indicates that new data is available on the output of the FIR. The rising edge of DATA __RDY can be used to load the output data into an external register or RAM.

## Data Format

The DDF maintains 16 bits of accuracy in both the HDF and FIR filter stages. The data formats and bit weightings are shown in Figure 11.

## Operational Section

## Start Configurations

The scenario to put the DDF into operational mode is: reset the DDF by asserting the RESET\# input, configure the DDF over the control bus, and apply a start signal, either by ASTARTIN\# or STARTIN\#. Until the DDF is put in operational mode with a start pulse, the DDF ignores all data inputs.

To use the asynchronous start, an asynchronous active low pulse is applied to the ASTARTIN\# input. ASTARTIN\# is internally synchronized to the sample clock, CK_IN, and generates STARTOUT\#. This signal is also used internally when the asynchronous mode is selected. It puts the DDF in operational mode and allows the DDF to begin accepting data. When the ASTARTIN\# input is being used, the STARTIN\# input must be tied high to ensure proper operation.

To start the DDF synchronously, the STARTIN\# is asserted with a active low pulse that has been externally synchronized to CK__IN. Internally the DDF then uses this start pulse to put the DDF in operate mode and start accepting data inputs. When STARTIN\# is used to start the DDF the ASTARTIN\# input must be tied high to prevent false starts.


## INPUT DATA FORMAT

Fractional Two's Complement Input

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |

FIR COEFFICIENT FORMAT
Fractional Two's Complement Input


## OUTPUT DATA FORMAT

Fractional Two's Complement Output
FOR: OUT_SELH $=1$

$$
F_{\_} B Y P=0
$$

| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| $-2^{8}$ | $2^{7}$ | $2^{6}$ | $2^{5}$ | $2^{4}$ | $2^{3}$ | $2^{2}$ | $2^{1}$ |


| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| $2^{0}$ | $.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}$ |  |  |  |  |  |

FOR: OUT_SELH $=0$ $F$ _BYP $=0$

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| $-2^{0}$ | $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}$ |  |  |  |  |

$$
\begin{array}{|l|l|l|l|l|l|l|l|}
\hline 23 & 22 & 21 & 20 & 19 & 18 & 17 & 16 \\
\hline 2^{-16} 2^{-17} 2^{-18} 2^{-19} 2^{-20} & 2^{-21} 2^{-22} 2^{-23}
\end{array}
$$

FOR: OUT_SELH $=X$

$$
F \_B Y P=1
$$

| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |


| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

FIGURE 11.

## Multi-Chip Start Configurations

Since there are two methods to start up the DDF, there are also two configurations that can be used to start up multiple chips.
The first method is shown in Figure 12. The timing of the STARTOUT\# circuitry starts the second DDF on the same clock as the first. If more DDF's are also to be started synchronously, STARTOUT\# is connected to their STARTIN\#'s.

The second method to start up DDF's in a multiple chip configuration is to use the synchronous start scenario.

The STARTIN\# input is wired to all the chips in the chain, and is asserted by a active low synchronous pulse that has been externally synchronized to CK_IN. In this way all DDF's are synchronously started. The ASTARTIN\# input on all the chips is tied high to prevent false starts. The STARTOUT\# outputs are all left unconnected. This configuration is illustrated in Figure 13.


FIGURE 12. ASYNCHRONOUS START UP


FIGURE 13. SYNCHRONOUS START UP

## Chip Set Application

The HSP43220 is ideally suited for narrow band filtering in Communications, Instrumentation and Signal Processing applications. The HSP43220 provides a fully integrated solution to high order decimation filtering.

The combination of the HSP43220 and the HSP45116 (which is a NCOM Numerically Controlled Oscillator/ Modulator) provides a complete solution to digital receivers. The diagram in Figure 14 illustrates this concept.

The HSP45116 down converts the signal of interest to baseband, generating a real component and an imaginary
component. A HSP43220 then performs low pass filtering and reduces the sampling rate of each of the signals.
The system scenario for the use of the DDF involves a narrow band signal that has been over-sampled. The signal is over-sampled in order to capture a wide frequency band containing many narrow band signals. The NCOM is "tuned" to the frequency of the signal of interest and performs a complex down conversion to baseband of this signal, which results in a complex signal centered at baseband. A pair of DDF's then low pass filters the NCOM output, extracting the signal of interest.


FIGURE 14. DIGITAL CHANNELIZER

## Design Trade-Off Considerations

Equation 2.0 in the Functional Description section expresses the relationship between the number of TAPS which can be implemented in the FIR as a function of CK_IN, FIR_CK, Hdec, Fdec. Figure 15 provides a
tradeoff of these parameters. For a given speed grade and the ratio of the clocks, and assuming minimum decimation in the HDF, the number of FIR taps that can be implemented is given in equation 2.0.

| $\begin{gathered} \text { SPEED } \\ \text { GRADE }(\mathrm{MHz}) \end{gathered}$ | $\frac{\mathrm{FIR} \_\mathrm{CK}}{\mathrm{CK} \_\mathrm{IN}}$ | MIN <br> Hdec | TAPS |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Fdec $=1$ | Fdec $=2$ | Fdec $=4$ | Fdec $=8$ | Fdec $=16$ |
| 33 | 1 | 9 | 8 | 24 | 56 | 120 | 248 |
| 25.6 | 1 | 7 | 4 | 16 | 40 | 88 | 184 |
| 15 | 1 | 4 | * | 4 | 16 | 40 | 88 |
| 33 | 2 | 5 | 10 | 28 | 64 | 136 | 280 |
| 25.6 | 2 | 4 | 6 | 20 | 48 | 104 | 216 |
| 15 | 2 | 2 | * | 4 | 16 | 40 | 88 |
| 33 | 4 | 3 | 14 | 36 | 80 | 168 | 344 |
| 25.6 | 4 | 2 | 6 | 20 | 48 | 104 | 216 |
| 15 | 4 | 1 | * | 4 | 16 | 40 | 88 |
| 33 | 8 | 2 | 22 | 52 | 112 | 232 | 472 |
| 25.6 | 8 | 1 | 6 | 20 | 48 | 104 | 216 |
| 15 | 8 | 1 | 6 | 20 | 48 | 104 | 216 |

* Filter Not Realizable

FIGURE 15. DESIGN TRADE OFF FOR MINIMUM Hdec

## DECI•MATE

Harris provides a development system which assists the design engineer to utilizing this filter. The DECI • MATE software package provides the user with both filter design and simulation environments for filter evaluation and design. These tools are integrated within one standard DSP CAD environment, The Athena Group's Monarch Professional DSP Software package.
The software package is designed specifically for the DDF. It provides all the filter design software for this proprietary architecture. It provides a user-friendly menu driven interface to allow the user to input system level filter requirements. It provides the frequency response curves and a data flow simulation of the specified filter design (Figure 16). It also creates all the information necessary to program the DDF, including a PROM file for programming the control registers.

This software package runs on an $I \mathrm{BM}^{m} \mathrm{PC}^{m}, \mathrm{XT}^{m}, A T^{m}$, $\mathrm{PS} / 2^{\text {m }}$ computer or $100 \%$ compatible with the following configuration:

## 640K RAM

$5.25^{\prime \prime}$ or $3.5^{\prime \prime}$ Floppy drive hard disk
math co-processor
MS/PC-DOS 2.0 or higher CGA, MCGA, EGA, VGA and
Hercules graphics adapters

For more information, see the description of DECI-MATE in the Development Tools Section of this databook.

## HSP43220 DDF FILTER SPECIFICATION




FIGURE 16. DECI॰MATE DESIGN MODULE SCREENS

## Absolute Maximum Ratings

```
Supply Voltage
+8.0V
Input, Output or I/O Voltage Applied . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . GND -0.5V to VCC +0.5V
```



```
Maximum Package Power Dissipation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2.4W (PLCC) , 3.2W (PGA)
0jc . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10.9.90
```



```
Device Count
Junction Temperature
150}\mp@subsup{}{}{\circ}\textrm{C}\mathrm{ (PLCC) , +175}\mp@subsup{}{}{\circ}\textrm{C}\mathrm{ (PGA)
```



```
ESD Classification
Class }
```

CAUTION: Stresses above those listed in the "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.

## Operating Conditions


D.C. Electrical Specifications $\mathrm{V}_{\mathrm{CC}}=+4.75 \mathrm{~V}$ to $+5.25 \mathrm{~V}\left(\mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%\right), \mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$

| PARAMETER | SYMBOL | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Logical One Input Voltage | $V_{\text {IH }}$ | 2.0 | - | V | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| Logical Zero Input Voltage | $\mathrm{V}_{\text {IL }}$ | - | 0.8 | V | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| High Level Clock Input | $\mathrm{V}_{\text {IHC }}$ | 3.0 | - | V | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| Low Level Clock Input | VILC | - | 0.8 | V | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Output HIGH Voltage | $\mathrm{V}_{\mathrm{OH}}$ | 2.6 | - | V | $\begin{aligned} & \mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A} \\ & \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & \hline \end{aligned}$ |
| Output LOW Voltage | VOL | - | 0.4 | V | $\begin{aligned} & \mathrm{IOL}=+2.0 \mathrm{~mA} \\ & \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V} \end{aligned}$ |
| Input Leakage Current | 1 | -10 | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{I N}=V_{C C} \text { or } G N D \\ & V_{C C}=5.25 V \end{aligned}$ |
| 1/O Leakage Current | 10 | -10 | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{\text {OUT }}=V_{C C} \text { or GND } \\ & V_{C C}=5.25 \mathrm{~V} \end{aligned}$ |
| Standby Power Supply Current | ${ }^{\prime} \mathrm{CCSB}$ | - | 500 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{I N}=V_{C C} \text { or } G N D, \\ & V_{C C}=5.25 \mathrm{~V}, \text { Note } 3 \end{aligned}$ |
| Operating Power Supply Current | I'COP | - | 120 | mA | $\mathrm{f}=15 \mathrm{MHz}, \mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}$ or GND $V_{C C}=5.25 \mathrm{~V}$, Note 1, Note 3 |

## Capacitance ( $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$, Note 2)

| PARAMETER | SYMBOL | MIN | MAX | UNITS | TEST CONDITIONS |
| :--- | :---: | :---: | :---: | :---: | :--- |
| Input Capacitance | CIN $^{\text {IN }}$ |  | 12 | pF | FREQ $=1 \mathrm{MHz}, \mathrm{V}_{\text {CC }}=$ Open, <br> all measurements are referenced <br> to device ground. |
| Output Capacitance | CO $_{\mathrm{O}}$ |  | 10 | pF |  |

## NOTES:

1. Power supply current is proportional to operating frequency. Typical rat- $\quad 3$. Output load per test load circuit and $C_{L}=40 p F$. ing for $\mathrm{I} C \mathrm{COP}$ is $8 \mathrm{~mA} / \mathrm{MHz}$.
2. Not tested, but characterized at initial design and at major process/design changes.

Specifications HSP43220
A.C. Electrical Specifications $V_{C C}=+4.75 \mathrm{~V}$ to $+5.25 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$

| PARAMETER | SYMBOL | -15 |  | -25 |  | -33 |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |  |
| Input Clock Frequency | FCK | 0 | 15 | 0 | 25.6 | 0 | 33 | MHz |  |
| FIR Clock Frequency | FFIR | 0 | 15 | 0 | 25.6 | 0 | 33 | MHz |  |
| Input Clock Period | TCK | 66 | - | 39 | - | 30 | - | ns |  |
| FIR Clock Period | TFIR | 66 | - | 39 | - | 30 | - | ns |  |
| Clock Pulse Width Low | TSPWL | 26 | - | 16 | - | 13 | - | ns |  |
| Clock Pulse Width High | TSPWH | 26 | - | 16 | - | 13 | - | ns |  |
| Clock Skew Between FIR_CK and CK_IN | TSK | 0 | $\mathrm{T}_{\text {FIR }}-25$ | 0 | ${ }^{\text {F }} \mathrm{FIR}^{-15}$ | 0 | $\mathrm{T}_{\text {FIR }}{ }^{-15}$ | ns |  |
| CK__IN Pulse Width Low | $\mathrm{T}_{\mathrm{CH} 1 \mathrm{~L}}$ | 29 | - | 19 | - | 19 | - | ns | Note 1, Note 4 |
| CK_IN Pulse Width High | $\mathrm{T}^{\text {CH1H }}$ | 29 | - | 19 | - | 19 | - | ns | Note 1, Note 4 |
| CK_IN Setup to FIR_CK | TCIS | 27 | - | 17 | - | 17 | - | ns | Note 1, Note 4 |
| CK_IN Hold from FIR_CK | ${ }^{\text {T }}$ CIH | 2 | - | 2 | - | 2 | - | ns | Note 1, Note 4 |
| RESET\# Pulse Width Low | TRSPW | 4 T CK | - | ${ }^{4 T} \mathrm{CK}$ | - | ${ }^{4} \mathrm{CK}$ | - | ns |  |
| Recovery Time on RESET\# | TRTRS | $8 \mathrm{~T}^{\text {ck }}$ | - | $8^{8 T}$ CK | - | $8 \mathrm{~T}^{\text {CK }}$ | - | ns |  |
| ASTARTIN\# Pulse Width Low | TAST | $\mathrm{T}^{\text {CK }}+10$ | - | ${ }^{\text {T }}$ CK +10 | - | ${ }^{\text {T }}$ CK+10 | - | ns |  |
| STARTOUT\# Delay from CK_IN | TSTOD | - | 35 | - | 20 | - | 18 | ns |  |
| STARTIN\# Setup to CK_IN | TSTIC | 25 | - | 15 | - | 10 | - | ns |  |
| Setup Time on DATA_IN | $T_{\text {SET }}$ | 20 | - | 15 | - | 14 | - | ns |  |
| Hold Time on All inputs | THOLD | 0 | - | 0 | - | 0 | - | ns |  |
| Write Pulse Width Low | TWL | 26 | - | 15 | - | 12 | - | ns |  |
| Write Pulse Width High | TWH | 26 | - | 20 | - | 18 | - | ns |  |
| Setup Time on Address Bus Before the Rising Edge of Write | TSTADD | 26 | - | 20 | - | 20 | - | ns |  |
| Setup Time on Chip Select Before the Rising Edge of Write | Tstcs | 26 | - | 20 | - | 20 | - | ns |  |
| Setup Time on Control Bus Before the Rising Edge of Write | Tstcb | 26 | - | 20 | - | 20 | - | ns |  |
| DATA_RDY Pulse Width Low | TDRPWL | $2 \mathrm{TFIR}^{-20}$ | - | ${ }^{2} \mathrm{~F}_{\text {FIR }}{ }^{-10}$ | - | $2 \mathrm{~F}_{\text {FIR }}-10$ | - | ns |  |
| DATA_OUT Delay Relative to FIR_CK | TFIRDV | - | 50 | - | 35 | - | 28 | ns |  |
| DATA RDY Valid Delay Relative to FIR__CK | $\mathrm{T}_{\text {FIRDR }}$ | - | 35 | - | 25 | - | 20 | ns |  |
| DATA__OUT Delay Relative to OUT__SELH | TOUT | - | 25 | - | 20 | - | 20 | ns |  |
| Output Enable to Data Out Valid | ToEV | - | 15 | - | 15 | - | 15 | ns | Note 2 |
| Output Disable to Data Out Three State | ToEZ | - | 15 | - | 15 | - | 15 | ns | Note 1 |
| Output Rise, Output Fall Times | $T_{R}, T_{F}$ | - | 8 | - | 8 | - | 6 | ns | $\begin{aligned} & \text { from } .8 \mathrm{~V} \text { to } 2 \mathrm{~V} \text {, } \\ & \text { Note } 1 \end{aligned}$ |

NOTES:

[^1]Test Load Circuit


Switch S1 Open for ICCSE and ICCOP Tests

## Timing Waveforms

input timing


START TIMING


Timing Waveforms (Continued)

## OUTPUT TIMING



## Features

- This Circuit is Processed in Accordance to Mil-Std883 and is Fully Conformant Under the Provisions of Paragraph 1.2.1.
- Single Chip Narrow Band Filter with up to 96 dB Attenuation
- DC to 25.6MHz Clock Rate
- 16 Bit 2's Complement Input
- 20 Bit Coefficients in FIR
- 24 Bit Extended Precision Output
- Programmable Decimation up to a Maximum of 16,384
- Standard 16 Bit Microprocessor Interface
- Filter Design Software Available DECl•MATE ${ }^{\text {TM }}$
- Available in 84 Pin PGA


## Applications

- Very Narrow Band Filters
- Zoom Spectral Analysis
- Channelized Receivers
- Sample Rate Converter
- Instrumentation
- 512 Tap Symmetric FIR Filtering


## Description

The HSP43220/883 Decimating Digital Filter is a linear phase low pass decimation filter which is optimized for filtering narrow band signals in a broad spectrum of a signal processing applications. The HSP43220/883 offers a single chip solution to signal processing application which have historically required several boards of IC's. This reduction in component count results in faster development times as well as reduction of hardware costs.

The HSP43220/883 is implemented as a two stage filter structure. As seen in the block diagram, the first stage is a high order decimation filter (HDF) which utilizes an efficient decimation (sample rate reduction) technique to obtain decimation up to 1024 through a coarse low-pass filtering process. The HDF provides up to 96 dB aliasing rejection in the signal pass band. The second stage consists of a finite impulse response (FIR) decimation filter structured as a transversal FIR filter with up to 512 symmetric taps which can implement filters with sharp transition regions. The FIR can perform further decimation by up to 16 if required while preserving the 96 dB aliasing attenuation obtained by the HDF. The combined total decimation capability is 16,384 .

The HSP43220/883 accepts 16 bit parallel data in 2's complement format at sampling rates up to 30MSPS. It provides a 16 bit microprocessor compatible interface to simplify the task of programming and three-state outputs to allow the connection of several IC's to a common bus. The HSP43220/883 also provides the capability to bypass either the HDF or the FIR for additional flexibility.

## Block Diagram



DECI • MATE ${ }^{\text {m }}$ is a registered trademark of Harris Corporation.
IBM PC ${ }^{\text {w }}$, XT $^{\text {w }}, ~ A T{ }^{\text {ww }}, ~ P S / 2^{\text {w }}$ are registered trademarks of International Business Machines, Inc.

Reliability Information

| Thermal Resistance | $\theta_{\mathrm{ja}}$ | $\theta_{\text {jc }}$ |
| :---: | :---: | :---: |
| Ceramic PGA Package | $32.9{ }^{\circ} \mathrm{C} / \mathrm{W}$ | $7.2^{\circ} \mathrm{C} / \mathrm{W}$ |
| Maximum Package Power Dissipation at $+125{ }^{\circ} \mathrm{C}$Ceramic PGA Package ....................... 1.52 Watt |  |  |
|  |  |  |
| Gate Count |  | 8,250 Gates |

AUTION: Stresses above those listed in "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.

## Operating Conditions

Operating Voltage Range .+4.5 V to +5.5 V
Operating Temperature Range $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

TABLE 1. D.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Devices Guaranteed and 100\% Tested

| PARAMETER | SYMBOL | CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| Logical One Input Voltage | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq T \mathrm{~A} \leq+125^{\circ} \mathrm{C}$ | 2.2 | - | v |
| Logical Zero Input Voltage | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq T \leq+125^{\circ} \mathrm{C}$ | - | 0.8 | V |
| Output HIGH Voltage | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}(\text { Note } 1) \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq T \leq+125^{\circ} \mathrm{C}$ | 2.6 | - | V |
| Output LOW Voltage | VOL | $\begin{aligned} & \mathrm{IOL}=+2.0 \mathrm{~mA} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}(\text { Note } 1) \\ & \hline \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq T \mathrm{~A} \leq+125^{\circ} \mathrm{C}$ | - | 0.4 | v |
| Input Leakage Current | I | $\begin{aligned} & V_{I N}=V_{C C} \text { or } G N D \\ & V_{C C}=5.5 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Output Leakage Current | 10 | $\begin{aligned} & V_{\text {OUT }}=V_{C C} \text { or GND } \\ & V_{C C}=5.5 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \top^{\top} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Clock Input High | $\mathrm{V}_{1} \mathrm{HC}$ | $v_{C C}=5.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 3.0 | - | v |
| Clock Input Low | $\mathrm{V}_{\text {ILC }}$ | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 0.8 | V |
| Standby Power Supply Current | I'ccsb | $\begin{aligned} & V_{I N}=V_{C C} \text { or } G N D \\ & V_{C C}=5.5 \mathrm{~V}, \\ & \text { Outputs Open } \\ & \hline \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \top^{\prime} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 500 | $\mu \mathrm{A}$ |
| Operating Power Supply Current | ICCOP | $\begin{aligned} & \mathrm{f}=15.0 \mathrm{MHz} \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V} \text { (Note 2) } \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \top \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 120.0 | mA |
| Functional Test | FT | (Note 3) | 7,8 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | - |  |

NOTES:

1. Interchanging of force and sense conditions is permitted.
2. Operating Supply Current is proportional to frequency, typical rating is $8 \mathrm{~mA} / \mathrm{MHz}$.
3. Tested as follows: $f=1 \mathrm{MHz}, \mathrm{V}_{\mathrm{IH}}=2.6, \mathrm{~V}_{\mathrm{IL}}=0.4, \mathrm{VOH} \geq 1.5 \mathrm{~V}$, $V_{\mathrm{OL}} \leq 1.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{IHC}}=3.4 \mathrm{~V}$, and $\mathrm{V}_{\mathrm{ILC}}=0.4 \mathrm{~V}$.

TABLE 2. A.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and 100\% Tested

| PARAMETER | SYMBOL | (NOTE 1) CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | -15 (15MHz) |  | $-25(25.6 \mathrm{MHz})$ |  |  |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| Input Clock Period | $\mathrm{T}_{\mathrm{CK}}$ |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 66 | - | 39 | - | ns |
| FIR Clock Period | $\mathrm{T}_{\text {FIR }}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 66 | - | 39 | - | ns |
| Clock Pulse Width Low | TSPWL |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 26 | - | 16 | - | ns |
| Clock Pulse Width High | ${ }^{\text {T SPWH }}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \top^{\prime} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 26 | - | 16 | - | ns |
| Clock Skew Between FIR_CK and CK__IN | TSK |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 0 | $\begin{aligned} & T_{\text {FIR }} \\ & -25 \end{aligned}$ | 0 | $\begin{aligned} & \text { TFIR } \\ & -19 \end{aligned}$ | ns |
| RESET\# Pulse <br> Width Low | TRSPW |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | ${ }^{4 T} \mathrm{CK}$ | - | ${ }^{4 T} \mathrm{CK}$ | - | ns |
| Recovery Time On RESET\# | TrTRS |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}^{\prime} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | ${ }^{8 T} \mathrm{CK}$ | - | ${ }^{87} \mathrm{CK}$ | - | ns |
| ASTARTIN\# Puise Width Low | ${ }^{\text {A AST }}$ |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}^{\prime} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | $\begin{aligned} & \mathrm{T} C K \\ & +10 \end{aligned}$ | - | $\begin{aligned} & \mathrm{T}_{\mathrm{CK}} \\ & +10 \end{aligned}$ | - | ns |
| STARTOUT\# Delay From CK_IN | TSTOD |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 35 | - | 20 | ns |
| STARTIN\# Setup To CK_IN | TSTIC |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 25 | - | 15 | - | ns |
| Setup Time on DATA_IN | TSET |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 20 | - | 16 | - | ns |
| Hold Time on All Inputs | THOLD |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns |
| Write Pulse Width Low | TWL |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 26 | - | 15 | - | ns |
| Write Pulse Width High | TWH |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq T^{\prime} \leq+125^{\circ} \mathrm{C}$ | 26 | - | 20 | - | ns |
| Setup Time on Address Bus Before the Rising Edge of Write | TSTADD |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 28 | - | 24 | - | ns |
| Setup Time on Chip Select Before the Rising Edge of Write | TSTCS |  | 9, 10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 28 | - | 24 | - | ns |
| Setup Time on Control Bus Before the Rising Edge of Write | Tstcb |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 28 | - | 24 | - | ns |
| DATA__RDY Pulse Width Low | TDRPWL |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | $\begin{array}{\|l} 2 T_{\text {FIR }} \\ -20 \\ \hline \end{array}$ | - | $\begin{array}{\|l} 2 T_{\text {FIR }} \\ -10 \\ \hline \end{array}$ | - | ns |
| DATA_OUT Delay Relative to FIR_CK | TFIRDV |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 50 | - | 35 | ns |
| DATA_RDY Valid Delay Relative to FIR_CK | $T_{\text {FIRDR }}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125{ }^{\circ} \mathrm{C}$ | - | 35 | - | 25 | ns |
| DATA_OUT Delay Relative to OUT__SELH | TOUT |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 30 | - | 25 | ns |
| Output Enable to Data Out Valid | ToEV | Note 2 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 20 | - | 20 | ns |

NOTES:

1. A.C. Testing: $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V . Inputs are driven at 3.0 V for a Logic " 1 " and 0.0 V for a Logic " 0 ". Input and output timing measurements are made at 1.5 V for both a Logic " 1 " and " 0 ". CLK is driven at 4.0 V and 0 V and measured at 2.0 V .
2. Transition is measured at $\pm 200 \mathrm{mV}$ from steady state voltage with loading as specified by test load circuit and $C_{L}=40 \mathrm{pF}$.

TABLE 3. ELECTRICAL PERFORMANCE CHARACTERISTICS

| PARAMETERS | SYMBOL | CONDITIONS | NOTES | TEMPERATURE | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | $-15(15 \mathrm{MHz})$ |  | -25 (25.6MHz) |  |  |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| CK_IN Pulse Width Low | TCH1L |  | 1,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 29 | - | 19 | - | ns |
| CK_IN Pulse Width High | ${ }^{\text {T }} \mathrm{CH} 1 \mathrm{H}$ |  | 1,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 29 | - | 19 | - | ns |
| CK_IN Setup to FIR__CK | TCIS |  | 1,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 27 | - | 17 | - | ns |
| CK__IN Hold from FIR_CK | ${ }^{\text {T }} \mathrm{CIH}$ |  | 1,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 2 | - | 2 | - | ns |
| Input Capacitance | $\mathrm{CIN}^{\text {N }}$ | $\begin{aligned} & V_{C C}=\text { Open, } \\ & f=1 \mathrm{MHz}, \mathrm{All} \end{aligned}$ <br> measurements are referenced to device GND. | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 12 | - | 12 | pF |
| Output Capacitance | COUT | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\text { Open, } \\ & \mathrm{f}=1 \mathrm{MHz}, \text { All } \end{aligned}$ <br> measurements are referenced to device GND. | 1 | $T_{A}=+25^{\circ} \mathrm{C}$ | - | 10 | - | 10 | pF |
| Output Disable Delay | TOEZ |  | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 20 | - | 20 | ns |
| Output Rise Time | TOR |  | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 8 | - | 8 | ns |
| Output Fall Time | TOF |  | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 8 | - | 8 | ns |

## NOTES:

1. Parameters listed in Table 3 are controlled via design or process parameters and are not directly tested. These parameters are characterized upon initial design and after major process and/or design changes.
2. Loading is as specified in the test load circuit with $C_{L}=40 p F$.
3. Applies only when H _BYP $=1$ or H _DRATE $=0$.

TABLE 4. APPLICABLE SUBGROUPS

| CONFORMANCE GROUPS | METHOD | SUBGROUPS |
| :--- | :---: | :---: |
| Initial Test | $100 \% / 5004$ | - |
| Interim Test | $100 \% / 5004$ | - |
| PDA | $100 \%$ | 1 |
| Final Test | $100 \%$ | $2,3,8 \mathrm{~A}, 8 \mathrm{~B}, 10,11$ |
| Group A | - | $1,2,3,7,8 \mathrm{~A}, 8 \mathrm{~B}, 9,10,11$ |
| Groups C \& D | Samples/5005 | $1,7,9$ |

Burn-In Circuit


| PIN <br> LEAD | PIN <br> NAME | BURN_IN <br> SIGNAL |
| :--- | :--- | :--- |
| A1 | GND | GND |
| A2 | DATA_IN 1 | F2 |
| A3 | DATA_IN 2 | F3 |
| A4 | DATA_IN 4 | F5 |
| A5 | DATA_IN 7 | F8 |
| A6 | DATA_IN 8 | F1 |
| A7 | DATA_IN 11 | F4 |
| A8 | DATA_IN 14 | F7 |
| A9 | V $C C$ | $V_{C C}$ |
| A10 | GND | GND |
| A11 | GND | GND |
| B1 | STARTIN\# | F15 |
| B2 | STARTOUT\# | $V_{C C} / 2$ |
| B3 | DATA_IN 0 | F1 |
| B4 | DATA_IN 3 | F4 |
| B5 | DATA_IN 6 | F7 |
| B6 | DATA_IN 13 | F6 |
| B7 | DATA_IN 12 | F5 |
| B8 | DATA_IN 16 | F8 |
| B9 | CK_IN | F0 |
| B10 | VCC | $V_{C C}$ |
| B11 | DATA_OUT1 | $V_{C C} / 2$ |
|  |  |  |


| $\begin{aligned} & \text { PIN } \\ & \text { LEAD } \end{aligned}$ | PIN NAME | BURN-IN SIGNAL |
| :---: | :---: | :---: |
| C1 | ASTARTIN\# | F15 |
| C2 | $V_{C C}$ | $V_{C C}$ |
| C5 | DATA_IN 5 | F6 |
| C6 | DATA_IN 9 | F2 |
| C7 | DATA_IN 10 | F3 |
| C10 | DATA_OUT 0 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| C11 | DATA_OUT 2 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| D1 | A1 | F14 |
| D2 | RESET\# | F16 |
| D10 | DATA_OUT 3 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| D11 | DATA_OUT 4 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| E1 | CS\# | F11 |
| E2 | WR\# | F11 |
| E3 | AO | F13 |
| E9 | DATA_OUT 5 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| E10 | DATA_OUT 6 | $\mathrm{V}_{\mathrm{CC}} / 2$ |
| E11 | DATA_OUT 7 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| F1 | C__bUS 10 | F3 |
| F2 | C__BUS 15 | F8 |
| F3 | C_BUS 14 | F7 |
| F9 | DATA_OUT 9 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| F10 | $\mathrm{V}_{\text {CC }}$ | $\mathrm{V}_{\text {CC }}$ |


| $\begin{aligned} & \text { PIN } \\ & \text { LEAD } \end{aligned}$ | PIN NAME | BURN-IN SIGNAL |
| :---: | :---: | :---: |
| F11 | DATA _OUT 3 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| G1 | C__bUS 12 | F5 |
| G2 | C_bus 11 | F4 |
| G3 | C._BUS 13 | F6 |
| G9 | DATA_OUT 10 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| G10 | GND | GND |
| G11 | DATA_OUT 11 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| H1 | C_BUS 9 | F2 |
| H2 | $V_{C C}$ | $V_{C C}$ |
| H10 | DATA_OUT 13 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| H11 | DATA_OUT 12 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| J1 | GND | GND |
| J2 | C__BUS 7 | F5 |
| J5 | OUT_SELH | F10 |
| J6 | GND | GND |
| J8 | FIR_CK | FO |
| J10 | DATA_OUT 16 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| J11 | DATA_OUT 14 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| K1 | C__bus 8 | F1 |
| K2 | C_BUS 5 | F6 |
| K3 | C__BUS 4 | F5 |
| K4 | C__BUS 1 | F2 |

NOTES:

1. $\mathrm{V}_{\mathrm{CC}} / 2(2.7 \mathrm{~V} \pm 10 \%)$ used for outputs only.
2. $47 \mathrm{~K} \Omega( \pm 20 \%)$ resistor connected to all pins except $V_{\mathrm{CC}}$ and GND.
3. $V_{C C}=5.5 \pm 0.5 \mathrm{~V}$.
4. $0.1 \mu \mathrm{~F}(\mathrm{~min})$ capacitor between $\mathrm{V}_{\mathrm{CC}}$ and $G N D$ per position.

## Burn-In Circuit (Continued)

| PIN <br> LEAD | PIN <br> NAME | BURN-IN <br> SIGNAL |
| :--- | :--- | :--- |
| K5 | OUT_ENP\# | F9 |
| K6 | $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ |
| K7 | GND | GND |
| K8 | DATA_OUT 22 | $\mathrm{~V}_{\mathrm{CC}} / 2$ |
| K9 | DATA__OUT 19 | $\mathrm{~V}_{\mathrm{CC}} / 2$ |
| K10 | DATA_OUT 17 | $\mathrm{~V}_{\mathrm{CC}} / 2$ |


| PIN <br> LEAD | PIN <br> NAME | BURN-IN <br> SIGNAL |
| :--- | :--- | :--- |
| K11 | DATA_OUT 15 | $V_{\text {CC }}$ /2 |
| L1 | C__BUS 6 | F7 |
| L2 | C__BUS 3 | F4 |
| L3 | C__BUS 2 | F3 |
| L4 | C__BUS 0 | F1 |
| L5 | OUT_ENP\# | F9 |


| PIN <br> LEAD | PIN <br> NAME | BURN-IN <br> SIGNAL |
| :--- | :--- | :--- |
| L6 | DATA_RDY\# | $\mathrm{V}_{\mathrm{CC}} / 2$ |
| L7 | V $_{\text {CC }}$ | $\mathrm{V}_{\mathrm{CC}}$ |
| L8 | DATA_OUT 23 | $\mathrm{~V}_{\mathrm{CC}} / 2$ |
| L9 | DATA_OUT 21 | $\mathrm{~V}_{\mathrm{CC}} / 2$ |
| L10 | DATA_OUT 20 | $\mathrm{~V}_{\mathrm{CC}} / 2$ |
| L11 | DATA_OUT 18 | $\mathrm{~V}_{\mathrm{CC}} / 2$ |

NOTES:

1. $\mathrm{V}_{\mathrm{CC}} / 2(2.7 \mathrm{~V} \pm 10 \%)$ used for outputs only.
2. $47 \mathrm{~K} \Omega( \pm 20 \%)$ resistor connected to all pins except $\mathrm{V}_{\mathrm{CC}}$ and GND .
3. $\mathrm{V}_{\mathrm{CC}}=5.5 \pm 0.5 \mathrm{~V}$.
4. $F 0=100 \mathrm{kHz} \pm 10 \%, F 1=F 0 / 2, F 2=F 1 / 2 \ldots . F 16=F 15 / 2,40 \%-60 \%$ Duty Cycle.
5. $0.1 \mu \mathrm{~F}(\mathrm{~min})$ capacitor between $\mathrm{V}_{\mathrm{CC}}$ and GND per position.

## Metal Topology

DIE DIMENSIONS:
$348 \times 349.2 \times 19 \pm 1$ mils
METALLIZATION:
Type: $\mathrm{Si}-\mathrm{Al}$ or $\mathrm{Si}-\mathrm{Al}-\mathrm{Cu}$
Thickness: $8 \mathrm{k} \AA$
DIE ATTACH:
Material: Silver-Glass

WORST CASE CURRENT DENSITY:
$1.18 \times 10^{5} \mathrm{~A} / \mathrm{cm}^{2}$
GLASSIVATION:
Type: Nitrox
Thickness: $10 \mathrm{k} \AA$

## Metallization Mask Layout

HSP43220/883
(11) GND
(10) DATA_INO
(9) DATA_IN1
(8) DATA_IN2
(7) DATA_IN3
(6) DATA_IN4
(5) DATA_IN5
(4) DATA_IN6
(3) DATA_IN7
(2) DATA_IN8
(1) DATA_IN9
(84) DATA_IN10
(83) DATA_IN11
(82) DATA_IN12
(81) DATA_IN13
(80) DATA_IN14
(79) DATA_IN15
(78) VCC
(77) GND
(76) CK_IN
(75) VCC


## Features

- Four Filter Cells
- 0 to 30 MHz Sample Rate
- 8 Bit Coefficients and Signal Data
- 26 Bit Accumulator per Stage
- Filter Lengths Up to 1032 Tap
- Shift-And-Add Output Stage for Combining Filter Outputs
- Expandable Coefficient Size, Data Size and Filter Length
- Decimation by 2, 3 or 4
- CMOS Power Dissipation Characteristics


## Applications

- 1-D and 2-D FIR Filters
- Radar/Sonar
- Digital Video and Audio
- Adaptive Filters
- Echo Cancellation
- Correlation/Convolution
- Complex Multiply-Add
- Butterfly Computation
- Matrix Multiplication
- Sample Rate Converters


## Description

The HSP43481 is a video-speed Digital Filter (DF) designed to efficiently implement vector operations such as FIR digital filters. It is comprised of four filter cells cascaded internally and a shift-and-add output stage, all in a single integrated circuit. Each filter cell contains an $8 \times 8$ multiplier, three decimation registers and a 26 bit accumulator which can add the contents of any filter cell accumulator to the output stage accumulator shifted right by eight bits. The HSP43481 has a maximum sample rate of 30 MHz . The effective multiply-accumulate (MAC) rate is 120 MHz .

The HSP43481 can be configured to process expanded coefficient and word sizes. Multiple devices can be cascaded for larger filter lengths without degrading the sample rate or a single device can process larger filter lengths at less than 30 MHz with multiple passes. The architecture permits processing filter lengths of over 1000 taps with the guarantee of no overflows. In practice, most filter coefficients are less than 1.0, making even larger filter lengths possible. The HSP43481 provides for unsigned or two's complement arithmetic, independently selectable for coefficients and signal data.
Each DF filter cell contains three resampling or decimation registers which permit output sample rate reduction at rates of $1 / 2,1 / 3$ or $1 / 4$ the input sample rate. These registers also provide the capability to perform 2-D operations such as $\mathrm{N} \times \mathrm{N}$ spatial correlations/convolutions for image processing applications.

## Block Diagram



## Pinouts



68 PIN PLASTIC LEADED CHIP CARRIER (PLCC) TOP VIEW


## Pin Description

| SYMBOL | PIN NUMBER | TYPE | NAME AND FUNCTION |
| :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ | 61 |  | +5V Power Supply Input |
| $V_{S S}$ | 27 |  | Power Supply Ground Input |
| CLK | 19 | 1 | The CLK input provides the DF system sample clock. The maximum clock frequency is is 30 MHz . |
| DINO-7 | $\begin{gathered} 64-68 \\ 1-3 \end{gathered}$ | 1 | These eight inputs are the data sample input bus. Eight bit data samples are synchronously loaded through these pins to the $X$ register of each filter cell simultaneously. The DIENB signal enables loading, which is synchronous on the rising edge of the clock signal. |
| TCS | 4 | 1 | The TCS input determines the number system interpretation of the data input samples on pins DINO-7 as follows: <br> TCS $=$ Low $\rightarrow$ Unsigned Arithmetic <br> TCS $=$ High $\rightarrow$ Two's Complement Arithmetic <br> The TCS signal is synchronously loaded into the $X$ register in the same way as the DINO-7 inputs. |
| $\overline{\text { DIENB }}$ | 5 | 1 | A low on this enables the data sample input bus (DINO-7) to all the filter cells. A rising edge of the CLK signal occurring while $\overline{\text { DIENB }}$ is low will load the $X$ register of every filter cell with the 8 bit value present on DINO-7. A high on this input forces all the bits of the data sample input bus to zero; a rising CLK edge when DIENB is high will load the X register of every filter cell with all zeros. This signal is latched inside the $D F$, delaying its effect by one clock internal to the $D F$. Therefore, it must be low during the clock cycle immediately preceding presentation of the desired data on the DINO-7 inputs. Detailed operation is shown in later timing diagrams. |
| CINO-7 | 53-60 | 1 | These eight inputs are used to input the 8 bit coefficients. The coefficients are synchronously synchronously loaded into the C register of filter Cell 0 if a rising edge of CLK occurs while CIENB is low. The CIENB signal is delayed by one clock as discussed below. |
| TCCI | 62 | 1 | The TCCI input determines the number system interpretation of the coefficient inputs on pins CINO-7 as follows: <br> TCCI $=$ LOW $\rightarrow$ Unsigned Arithmetic <br> TCCI $=$ HIGH $\rightarrow$ Two's Complement Arithmetic <br> The TCCI signal is synchronously loaded into the C register in the same way as the CINO-7 inputs. |
| $\overline{\text { CIENB }}$ | 63 | I | A low on this input enable the $C$ register of every filter cell and the $D$ registers (decimation) of every filter cell according to the state of the DCMO-1 inputs. A rising edge of the CLK signal occurring while CIENB is low will load the C register and appropriate D registers with the coefficient data present at their inputs. This privides the mechanism for shifting the coefficients from cell to cell through the device. A high on this input freezes the contents of the C register and the D registers, ignoring the CLK signal. This signal is latched and delayed by one clock internal to the DF. Therefore, it must be low during the clock cycle immediately preceding presentation of the desired coefficient on the CINO-7 inputs. Detailed operation is shown in the Timing Diagrams section. |
| COUTO-7 | 10-17 | 0 | These eight three-state outputs are used to output the 8 bit coefficients from filter cell 7. These outputs are enabled by the COENB signal low. These outputs may be tied to the CINO-7 inputs of the same DF to recirculate the coefficients, or they may be tied to the CINO-7 inputs of another DF to cascade DFs for longer filter lengths. |
| TCCO | 9 | 0 | The TCCO three-state output determines the number system representation of the coefficients output on COUTO-7. It tracks the TCCI signal to this same DF. It should be tied to the TCCI input of the next DF in a cascade of DFs for increased filter lengths. This signal is enabled by COENB low. |

## Pin Descriptions

| SYMBOL | PIN NUMBER | TYPE | NAME FUNCTION |
| :---: | :---: | :---: | :---: |
| COENB | 8 | 1 | A low on the $\overline{\text { COENB }}$ input enables the COUTO-7 and the TCCO output. A high on this input places all these outputs in their high impedance state. |
| DCMO-1 | 20-21 | 1 | These two inputs determine the use of the internal decimation registers as follows: <br> The coefficients pass from cell to cell at a rate determined by the number of decimation registers used. When no decimation registers are used, coefficients move from cell to cell on each clock. When one decimation register is used, coefficients move from cell to cell on every other clock, etc. These signals are latched and delayed by one clock internal to the DF. |
| SUMO-25 | $\begin{aligned} & 25,26, \\ & 28-51 \end{aligned}$ | 0 | These 26 three-state outputs are used to output the results of the internal filter cell computations. Individual filter cell results or the result of the shift-and-add output stage can be output. If an individual filter cell result is to be output, the ADRO-1 signals select the filter cell result. The SHADD signal determines whether the selected filter cell result or the output stage adder result is output. The signals $\overline{\text { SENBH }}$ and $\overline{\text { SENBL }}$ enable the most significant and least significant bits of the SUMO-25 result, respectively. Both $\overline{\text { SENBH }}$ and SENBL may be enabled simultaneously if the system has a 26 bit or larger bus. However, individual enables are provided to facilitate use with a 16 bit bus. |
| $\overline{\text { SENBH }}$ | 24 | 1 | A low on this input enables result bits SUM16-25. A high on this input places these bits in their high impedance state. |
| $\overline{\text { SENBL }}$ | 52 | 1 | A low on this input enables result bits SUMO-15. A high on this input places these bits on their high impedance state. |
| ADRO-1 | 22, 23 | 1 | These two inputs select the one cell whose accumulator will be read through the output bus (SUMO-25) or added to the output stage accumulator. They also determine which accumulator will be cleared when ERASE is low. For selection of which accumulator to read through the output bus (SUMO-25) or which to add of the output stage accumulator, these inputs are latched in the DF and delayted by one clock internal to the device. If the ADRO-1 lines remain at the same address for more than one clock, the output at SUMO-25 will not change to reflect any subsequent accumulator updates in the addressed cell. Only the result available during the first clock, when ADRO-1 selects the cell, will be output. This does not hinder normal operation since the ADRO-1 lines are changed sequentially. This feature facilitates the interface with slow memories where the output is required to be fixed for more than one clock. |
| SHADD | 18 | 1 | The SHADD input controls the activation of the shift-and-add operation in the output stage. This signal is latched in the DF and delayed by one clock internal to the device. A detailed explanation is given in the DF Output Stage section. |
| $\overline{\text { RESET }}$ | 6 | 1 | A low on this input synchronously clears all the internal registers, except the cell accumulators. It can be used with ERASE to also clear all the accumulators simultaneously. This signal is latched in the DF and delayed by one clock internal to the DF. |
| $\overline{\text { ERASE }}$ | 7 | 1 | A low on this input synchronously clears the cell accumulator selected by the ADRO-1 signals. If RESET is also low simultaneously, all cell accumulators are cleared. |

## Functional Description

The Digital Filter (DF) is composed of four filter cells cascaded together and an output stage for combining or selecting filter cell outputs (see Block Diagram). Each filter cell contains a multiplier-accumulator and several registers (Figure 1). Each 8 bit coefficient is multiplied by a 8 bit data sample, with the result added to the 26 bit accumulator contents. The coefficient output of each cell is cascaded to the coefficient input of the next cell to its right.

## DF Filter Cell

An 8 bit coefficient (CINO-7, TCCI) enters each cell through the $C$ register on the left and exits the cell on the right as signals COUTO-7 and TCCO. With no decimation, the coefficient moves directly from the $C$ register to the output, and is valid on the clock following its entrance. When decimation is selected the coefficient exit is delayed by 1,2 or 3 clocks by passing through one or more decimation registers (D1, D2 or D3).

The combination of $D$ registers through which the coefficient passes is determined by the state of DCMO and DCM1. The output signals (COUTO-7, TCCO) are connected to the CINO-7 and TCCI of the next cell to its right. The COENB input signal enables the COUTO-7 and TCCO outputs of the right-most cell to the COUTO-7 and TCCO pins of the DF.
The $C$ and $D$ registers are enabled for loading by $\overline{C I E N B}$. Loading is synchronous with CLK when CIENB is low. Note that $\overline{C I E N B}$ is latched internally. It enables the register for loading after the next CLK following the onset of CIENB low. Actual loading occurs on the second CLK following the onset of $\overline{\text { CIENB }}$ low. Therefore, $\overline{\text { CIENB }}$ must be low during the clock cycle immediately preceding presentation of the coefficient on the CINO-7 inputs. In most basic FIR operations, $\overline{C I E N B}$ will be low throughout the process, so this latching and delay sequence is only important during the initialization phase. When CIENB is high, the coefficients are frozen.

These registers are cleared synchronously under control of $\overline{\text { RESET, }}$, which is latched and delayed exactly like $\overline{\mathrm{CIENB}}$.

The output of the $C$ register is one input of the multiplier.
The other input of the multiplier comes from the output of the $X$ register. This register is loaded with a data sample from the DF input signals. DINO-7 and TCS discussed above. The $X$ register is enabled for loading by DIENB. Loading is synchronous with CLK when DIENB is low. Note that $\overline{\text { DIENB }}$ is latched internally. It enables the register for loading after the next CLK following the onset of DIENB low. Therefore, $\overline{\mathrm{DIENB}}$ must be low during the clock cycle immediately preceding presentation of the sample on the DINO-7 inputs. In most basic FIR operations, DIENB will be low throughout the process, so this latching and delay sequence is only important during the initialization phase. When DIENB is high, the X register is loaded with all zeros.
The multiplier is pipelined and is modeled as a multiplier core followed by two pipeline registers, MREGO and MREG1. The multiplier output is sign extended and input as one operand of the 26 bit adder. The other adder operand is the output of the 26 bit accumulator. The adder output
is loaded synchronously into both the accumulator and the TREG.

The TREG loading is disabled by the cell select signal, Celln, where $n$ is the cell number. The cell select is decoded from the ADRO-1 signals to generate the TREG load enable. The cell select is inverted and applied as the load enable to the TREG. Operation is such that the TREG is loaded whenever the cell is not selected. Therefore, TREG is loaded every other clock except the clock following cell selection. The purpose of the TREG is to hold the result of a sum-ofproducts calculation during the clock when the accumulator is cleared to prepare for the next sum-of-products calculation. This allows continuous accumulation without wasting clocks.

The accumulator is loaded with the adder output every clock unless it is cleared. It is cleared synchronously in two ways. When $\overline{\operatorname{RESET}}$ and $\overline{\text { ERASE }}$ are both low, the accumulator is cleared along with all other registers in the DF. Since both $\overline{E R A S E}$ and $\overline{\operatorname{RESET}}$ are latched and delayed one clock internally, clearing occurs on the second CLK following the onset of both ERASE and $\overline{\text { RESET }}$ low.

The second accumulator clearing mechanism clears a single accumulator in a selected cell. The cell select signal, Celln, decoded from ADRO-1 and ERASE signal, Celln enable clearing of the accumulator on the next CLK.
The ERASE and $\overline{\operatorname{RESET}}$ signals clear the DF internal registers and states as follows:

| $\overline{\text { ERASE }}$ | $\overline{\text { RESET }}$ | CLEARING EFFECT |
| :---: | :---: | :--- |
| 1 | 1 | No clearing occurs, internal state <br> remains same. |
| 1 | 0 | $\overline{\text { RESET only active, all registers except }}$ <br> accumulators are cleared, including <br> the internal pipeline registers. |
| 0 | 1 | ERASE only active, the accumulator <br> whose address is given by the ADRO-1 <br> inputs is cleared. |
| 0 | 0 | Both $\overline{\text { RESET and } \overline{\text { ERASE }} \text { active, all }}$accumulators as well as all other reg- <br> isters are cleared. |

## The DF Output Stage

The output stage consists of a 26 bit adder, 26 bit register, feedback multiplexer from the register to the adder, an output multiplexer and a 26 bit three-state driver stage (Figure 2).

The 26 bit output adder can add any filter cell accumulator result to the 18 most significant bits of the outupt buffer. This operation takes place in one clock period. The eight LSBs are lost. The filter cell accumulator is selected by the ADRO-1 inputs.
The 18 MSBs of the output buffer actually pass through the zero mux on their way to the output adder input. The zero mux is controlled by the SHADD input signal and selects either the 18 MSBs of the output buffer or all zeros for the adder input. A low on the SHADD input selects zero. A high on the SHADD input selects the output buffer MSBs, thus activating the shift-and-add operation. SHADD signal is latched and delayed by one clock internally.


FIGURE 1. HSP43481 FILTER CELL


FIGURE 2. HSP43481 OUTPUT STAGE

The 26 Least Significant Bits (LSBs) from either a cell accumulator or the output buffer are output on the SUMO-25 bus. The output mux determines whether the cell accumulator selected by ADRO-1 or the output buffer is output to the bus. The mux is controlled by the SHADD input signal. Control is based on the state of the SHADD during two successive clocks; in other words, the output mux selection contains memory. If SHADD is low during a clock cycle and was low during the previous clock, the output mux selects the contents of the filter cell accumulator addressed by ADRO-1. Otherwise the output mux selects the contents of the output buffer.

If the ADRO-1 lines remain at the same address for more than one clock, the output at SUMO-25 will not change to reflect any subsequent accumulator updates in the addressed cell. Only the result available during the first clock when ADRO-1 selects the cell will be output. This does not hinder normal FIR operations since the ADRO-1
lines are changed sequentially. This feature facilitates the interface wtith slow memories where the output is required to be fixed for more than one clock.

The SUMO-25 output bus is controlled by the SENBH and $\overline{\text { SENBL }}$ signals. A low on SENBL enables bits SUMO-15. A low on SENBH enables bits SUM16-25. Thus all 26 bits can be output simultaneously if the external system has a 26 bit or larger bus. If the external system bus is only 16 bits, the bits can be enabled in two groups of 16 and 9 bits (sign extended).

## DF Arithmetic

Both data samples and coefficients can be represented as either unsigned or two's complement numbers. The TCS and TCCl input signals determine the type of arithmetic representation. Internally all values are represented by a 9 bit two's complement number. The value of the additional ninth bit depends on arithmentic representation selected. For two's complement arithmetic, the sign is extended into the ninth bit. For unsigned arithmetic, bit 9 is 0 .

The multiplier output is 18 bits and the accumulator is 26 bits. The accumulator width determines the maximum possible number of terms in the sum-of-products without overflow. The maximum number of terms depends also on the number system and the distribution of the coefficient and data values. As a worst case assume the coefficients and data samples are always at their absolute maximum values.

Then the maximum numbers of terms in the sum products are:

| $\|c\|$ <br> NUMBER SYSTEM | MAX \# <br> OF TERMS |
| :--- | :---: |
| Two unsigned vectors | 1032 |
| Two two's complement vectors: |  |
| - Two positive vectors | 2080 |
| - Two negative vectors | 2047 |
| - One positive and one negative vector | 2064 |
| One unsigned and one two's complement |  |
| vector: |  |
| - Positive two's complement vector | 1036 |
| - Negative two's complement vector | 1028 |

For practical FIR filters, the coefficients are never all near maximum value, so even larger vectors are possible in practice.

## Basic FIR Operation

A simple 30 MHz 4 tap filter example serves to illustrate more clearly the operation of the DF. Table 1 shows the results of the multiply accumulate in each cell after each clock. The coefficient sequence, Cn , enters the DF on the left and moves from left to right through the cells. The data sample sequence, Xn , enters the DF from the top, with each cell receiving the same sample simultaneously. Each cell
accumulates the sum-of-products for one output point. Four sums-of-products are calculated simultaneously, but staggered in time so that a new output is available every system clock.
Detailed operation of the DF to perform a basic 4 tap, 8 bit coefficient, 8 bit data, 30 MHz FIR filter is best understood by observing the schematic (Figure 3) and timing diagram

TABLE 1. $25 \mathrm{MHz}, 4$ TAP FIR FILTER SEQUENCE


| CLK | CELLO | CELL 1 | CELL 2 | CELL 3 | SUM/CLR |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | $C_{3} \times X_{0}$ | 0 | 0 | 0 | - |
| 1 | $+C_{2} \times X_{1}$ | $C_{3} \times X_{1}$ | 0 | 0 | - |
| 2 | $+C_{1} \times X_{2}$ | $+C_{2} \times X_{2}$ | $C_{3} \times X_{2}$ | 0 | - |
| 3 | $+C_{0} \times X_{3}$ | $+C_{1} \times X_{3}$ | $+C_{2} \times X_{3}$ | $C_{3} \times X_{3}$ | Cell $0\left(Y_{3}\right)$ |
| 4 | $C_{3} \times X_{4}$ | $+C_{0} \times X_{4}$ | $+C_{1} \times X_{4}$ | $+C_{2} \times X_{4}$ | Cell $1\left(Y_{4}\right)$ |
| 5 | $+C_{2} \times X_{5}$ | $C_{3} \times X_{5}$ | $+C_{0} \times X_{5}$ | $+C_{1} \times X_{5}$ | Cell $2\left(Y_{5}\right)$ |
| 6 | $+C_{1} \times X_{6}$ | $+C_{2} \times X_{6}$ | $C_{3} \times X_{6}$ | $+C_{0} \times X_{6}$ | Cell 3 $\left(Y_{6}\right)$ |
| 7 | $+C_{0} \times X_{7}$ | $+C_{1} \times X_{7}$ | $+C_{2} \times X_{7}$ | $C_{3} \times X_{7}$ | Cell $0\left(Y_{7}\right)$ |



FIGURE 3. $30 \mathrm{MHz}, 4$ TAP FIR FILTER APPLICATION SCHEMATIC
(Figure 4). The internal pipeline length of the DF is four (4) clock cycles, corresponding to the register levels CREG (or XREG), MREGO, MREG1, and TREG (Figures 1 and 2). Therefore, the delay from presentation of data and coefficients at the DINO-7 and CINO-7 inputs to a sum appearing at the SUMO-25 output is:
$k+T d$ where
$\mathbf{k}=$ filter length
$T d=4$, the internal pipeline delay of $D F$


FIGURE 4. 30 MHz 4 TAP FILTER TIMING


FIGURE 5. 30 MHz 8 TAP FILTER USING TWO CASCADED HSP43481s

## Extended FIR Filter Length

Filter lengths greater than four taps can be created by either cascading together multiple DFs or "reusing" a single DF. Using multiple devices, an FIR filter of over 1024 taps can be constructed to operate at a 30 MHz sample rate. Using a single DF clocked at 30 MHz , an FIR filter of over 1024 taps can be constructed to operate at less than a 30 MHz sample rate. Combinations of these two techniques are also possible.

## Cascade Configuration

To design a filter length $L>4, L / 4$ DFs are cascaded by connecting the COUTO-7 outputs of the (i)th DF to the CINO-7 inputs of the $(i+1)$ th DF. The DINO-7 inputs and SUMO-25 outputs of all the DFs are slso tied together. A specific example of two cascaded DFs illustrates the technique (Figure 5). Timing (Figure 6) is similar to the simple 4 tap FIR, except the ERASE and $\overline{\text { SENBL }} / \overline{\text { SENBH }}$ signals must be enabled independently of the two DFs in order to clear the correct accumulators and enable the SUMO-25 output signals at the proper times.

## Single DF Configuration

Using a DF, a filter of length $L>4$ can be constructed by processing in L/4 passes as illustrated in Table 2 for an 8 tap FIR. Each pass is composed of $T p=7+L$ cycles and computes four output samples. In pass $i$, the samples with indices ix 4 to ix $4+(L+2)$ enter the DINO-7 inputs. The coefficients $\mathrm{C}_{0}-\mathrm{C}_{\mathrm{L}-1}$ enter the CINO-7 inputs, followed by three zeros. As these zeros are entered, the result samples are output and the accumulators reset. Initial filling of the pipeline is not shown in this sequence table. Filter outputs can be put through a FIFO to even out the sample rate.

## Extended Coefficient And Data Sample Word Size

The sample and coefficient word size can be extended by utilizing several DFs in parallel to get the maximum sample rate or a single DF with resulting lower sample rates. The technique is to compute partial products of $8 \times 8$ and combine these partial products by shifting and adding to obtain the final result. The shifting and adding can be accomplished with external adders (for full speed) or with the DFs shift-and-add mechanism contained in its output stage (at reduced speed).


FIGURE 6. 30 MHz 8 TAP FIR FILTER TIMING

## Decimation/Resampling

The HSP43481 provides a mechanism for decimating by factors of 2,3 or 4 . From the DF filter cell block diagram (Figure 1), note the three D registers and two multiplexers in the coefficient pass through the cell. These allow the coefficients to be delayed by 1, 2 or 3 clocks through the cell. The
sequence table (Table 3) for a decimate-by-two filter illustrates the technique.
Detailed timing for a 30 MHz input sample rate, 15 MHz output sample rate (i.e., decimate-by-two), 8 tap FIR filter, including pipelining, is shown in Figure 7.

TABLE 3. 8 TAP DECIMATE-BY-TWO FIR FILTER SEQUENCE, $30 \mathrm{MHz} \operatorname{IN}, 15 \mathrm{MHz}$ OUT


| CLK | CELLO | CELL 1 | CELL 2 | CELL 3 | SUM/CLR |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | $\mathrm{C}_{7} \times \mathrm{X}_{0}$ | 0 |  |  | - |
| 1 | $+\mathrm{C}_{6} \times \mathrm{X}_{1}$ | 0 |  |  | - |
| 2 | $+\mathrm{C}_{5} \times \mathrm{X}_{2}$ | $\mathrm{C}_{7} \times \mathrm{X}_{2}$ |  |  | - |
| 3 | $+\mathrm{C}_{4} \times \mathrm{X}_{3}$ | $+\mathrm{C}_{6} \times \mathrm{X}_{3}$ |  |  | - |
| 4 | $+C_{3} \times \mathrm{X}_{4}$ | $+\mathrm{C}_{5} \times \mathrm{X}_{4}$ | $\mathrm{C}_{7} \times \mathrm{X}_{4}$ |  | - |
| 5 | $+\mathrm{C}_{2} \times \mathrm{X}_{5}$ | $+\mathrm{C}_{4} \times \mathrm{X}_{5}$ | $+\mathrm{C}_{6} \times \mathrm{X}_{5}$ |  | - |
| 6 | $+\mathrm{C}_{1} \times \mathrm{X}_{6}$ | $+\mathrm{C}_{3} \times \mathrm{X}_{6}$ | $+\mathrm{C}_{5} \times \mathrm{X}_{6}$ | $+C_{7} \times \mathrm{X}_{6}$ | - |
| 7 | $+C_{0} \times X_{7}$ | $+C_{2} \times{ }^{4}$ | $+\mathrm{C}_{4} \times \mathrm{X}_{7}$ | $+\mathrm{C}_{6} \times \mathrm{X}_{7}$ | Cell $0\left(Y_{7}\right)$ |
| 8 | $\mathrm{C}_{7} \times \mathrm{X}_{8}$ | $+\mathrm{C}_{1} \times \mathrm{X}_{8}$ | $+C_{3} \times{ }_{8}$ | $+\mathrm{C}_{5} \times \mathrm{X}_{8}$ | Cell $0\left(Y_{7}\right)$ |
| 9 | $+\mathrm{C}_{6} \times \mathrm{X}_{9}$ | $+C_{0} \times X_{9}$ | $+\mathrm{C}_{2} \times \mathrm{X}_{9}$ | $+\mathrm{C}_{4} \times \mathrm{X}_{9}$ | Cell 1 (Yg) |
| 10 | $+\mathrm{C}_{5} \times \mathrm{X}_{10}$ | $\mathrm{C}_{7} \times \mathrm{X}_{10}$ | $+\mathrm{C}_{1} \times \mathrm{X}_{10}$ | $+\mathrm{C}_{3} \times \mathrm{X}_{10}$ | Cell $1\left(\mathrm{Y}_{\mathrm{g}}\right)$ |
| 11 | $+\mathrm{C}_{4} \times \mathrm{X}_{11}$ | $+\mathrm{C}_{6} \times \mathrm{X}_{11}$ | $+\mathrm{C}_{0} \times \mathrm{X}_{11}$ | $+\mathrm{C}_{2} \times \mathrm{X}_{11}$ | Cell $2\left(Y_{11}\right)$ |
| 12 | $+\mathrm{C}_{3} \times \mathrm{X}_{12}$ | $+\mathrm{C}_{5} \times \mathrm{X}_{12}$ | $\mathrm{C}_{7} \times \mathrm{X}_{12}$ | $+\mathrm{C}_{1} \times \mathrm{X}_{12}$ | Cell $2\left(Y_{11}\right)$ |
| 13 | $+\mathrm{C}_{2} \times \mathrm{X}_{13}$ | $+\mathrm{C}_{4} \times \mathrm{X}_{13}$ | $+\mathrm{C}_{6} \times \mathrm{X}_{13}$ | $+\mathrm{C}_{0} \times \mathrm{X}_{13}$ | Cell $3\left(Y_{13}\right)$ |
| 14 | $+\mathrm{C}_{1} \times \mathrm{X}_{14}$ | $+\mathrm{C}_{3} \times \mathrm{X}_{14}$ | $+\mathrm{C}_{5} \times \mathrm{X}_{14}$ | $\mathrm{C}_{7} \times \mathrm{X}_{14}$ | Cell $3\left(Y_{13}\right)$ |
| 15 | $+\mathrm{C}_{0} \times \mathrm{X}_{15}$ | $+\mathrm{C}_{2} \times \mathrm{X}_{15}$ | $+\mathrm{C}_{4} \times \mathrm{X}_{15}$ | $+C_{6} \times{ }_{15}$ | Cell $\mathrm{O}\left(\mathrm{Y}_{15}\right)$ |



DINO-7 $\quad\left|x_{0}\right| x_{1}\left|x_{2}\right| x_{3}\left|x_{4}\right| x_{5}\left|x_{6}\right| x_{7} \mid \cdots$
DIENB $77 / \square$
$\left.\begin{gathered}\text { CINO-7 }\end{gathered} \quad\left|c_{7}\right| c_{6}\left|c_{5}\right| c_{4}\left|c_{3}\right| c_{2}\left|c_{1}\right| c_{0} \right\rvert\, \ldots$
टाहNB TIITA


FIGURE 7. 8 TAP DECIMATE-BY-TWO FIR FILTER TIMING, $30 \mathrm{MHz} \operatorname{IN}, 15 \mathrm{MHz}$ OUT

## Absolute Maximum Ratings

| Supply Voltage | +8.0V |
| :---: | :---: |
| Input, Output Voltage | $\ldots . .$. . GND -0.5V to $\mathrm{V}_{\mathrm{CC}}+0.5 \mathrm{~V}$ |
| Storage Temperature. | . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| ESD | . Class 1 |
| Maximum Package Power Dissipation at $70^{\circ} \mathrm{C}$ | . . 1.9W (PLCC), 2.6W (PGA) |
| $\theta_{\text {jc }}$ | . $15.0 \mathrm{~W} /{ }^{\circ} \mathrm{C}$ (PLCC), $9.92 \mathrm{~W} /{ }^{\circ} \mathrm{C}$ (PGA) |
| $\theta_{\text {ja }}$ | $43.0 \mathrm{~W} /{ }^{\circ} \mathrm{C}$ (PLCC), 38.44W/ ${ }^{\circ} \mathrm{C}$ (PGA) |
| Gate Count | . 9371 |
| Junction Temperature | . $150^{\circ} \mathrm{C}$ (PLCC), $175{ }^{\circ} \mathrm{C}$ (PGA) |
| Lead Temperature (Soldering 10s) | . . . . . . . . . . 300 ${ }^{\circ} \mathrm{C}$ |
| CAUTION: Stresses above those listed in the "Absolut and operation of the device at these or any other co | age to the device. This is a stress only rating ections of this specification is not implied. |

## Operating Conditions

```
Operating Voltage Range
                                    5V }\pm5
Operating Temperature Ranges
00}\textrm{C}\mathrm{ to +70
```


## D.C. Electrical Specifications

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ICCOP | Power Supply Current | - | 110 | mA | $V_{C C}=$ Max CLK Frequency 20 MHz Note 1, Note 3 |
| ${ }^{\text {I CCSB }}$ | Standby Power Supply Current | - | 500 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {CC }}=$ Max, Note 3 |
| 1 | Input Leakage Current | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=$ Max, Input $=0 \mathrm{~V}$ or $\mathrm{V}_{\text {CC }}$ |
| 10 | Output Leakage Current | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {CC }}=$ Max, Input $=0 \mathrm{~V}$ or $\mathrm{V}_{\text {CC }}$ |
| $\mathrm{V}_{\mathrm{IH}}$ | Logical One Input Voltage | 2.0 | - | V | $\mathrm{V}_{\text {CC }}=$ Max |
| $\mathrm{V}_{\text {IL }}$ | Logical Zero Input Voltage |  | 0.8 | V | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Logical One | 2.6 | - | V | $\mathrm{I}^{\mathrm{OH}}=-400 \mu \mathrm{~A}, \mathrm{~V}_{\mathrm{CC}}=\mathrm{Min}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Logical Zero Output Voltage | - | 0.4 | V | ${ }^{1} \mathrm{OL}=2 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=\mathrm{Min}$ |
| $\mathrm{V}_{\text {IHC }}$ | Clock Input High | 3.0 | - | V | $V_{\text {CC }}=$ Max |
| $\mathrm{V}_{\text {ILC }}$ | Clock Input Low | - | 0.8 | V | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}$ |
| $\mathrm{CIN}^{\text {I }}$ | Input Capacitance $\begin{array}{r}\text { PLCC } \\ \\ \hline\end{array}$ | - | $\begin{aligned} & 10 \\ & 15 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{pF} \\ & \mathrm{pF} \end{aligned}$ | CLK Frequency 1 MHz All Measurements |
| Cout | $\begin{array}{lr}\text { Output Capacitance } & \text { PLCC } \\ & \text { PGA }\end{array}$ |  | $\begin{aligned} & 10 \\ & 15 \end{aligned}$ | $\begin{aligned} & \mathrm{pF} \\ & \mathrm{pF} \end{aligned}$ | Referenced to GND $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C} \text { Note } 2$ |

NOTES: 1. Operating supply current is proportional to frequency. Typical rating is $5.5 \mathrm{~mA} / \mathrm{MHz}$.
2. Controlled via design or process parameters and not directly tested. Characterized upon initial design and after major process and/or design changes.
3. Output load per test circuit and $C_{L}=40 \mathrm{pF}$.
A.C. Electrical Specifications $V_{C C}=+4.75 \mathrm{~V}$ to $+5.25 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | -20 (20MHz) |  | -25 (25.6MHz) |  | -30 (30MHz) |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |  |
| $\mathrm{T}_{\mathrm{CP}}$ | Clock Period | 50 | - | 39 | - | 33 | - | ns |  |
| ${ }^{\text {T }} \mathrm{CL}$ | Clock Low | 20 | - | 16 | - | 13 | - | ns |  |
| ${ }^{\text {T }} \mathrm{CH}$ | Clock High | 20 | - | 16 | - | 13 | - | ns |  |
| TIS | Input Setup | 16 | - | 14 | - | 13 | - | ns |  |
| $\mathrm{TIH}^{\text {H }}$ | Input Hold | 0 | - | 0 | - | 0 | - | ns |  |
| TODC | CLK to Coefficient Output Delay | - | 26 | - | 22 | - | 19 | ns |  |
| TOED | Output Enable Delay | - | 20 | - | 15 | - | 15 | ns |  |
| TODD | Output Disable Delay | - | 20 | - | 15 | - | 15 | ns | Note 1 |
| TODS | CLK to SUM <br> Output Delay | - | 30 | - | 26 | - | 21 | ns |  |
| TOR | Output Rise | - | 6 | - | 6 | - | 6 | ns | Note 1 |
| TOF | Output Fall | - | 6 | - | 6 | - | 6 | ns | Note 1 |

NOTE: 1. Controlled by design or process parameters and not directly tested. Characterized upon initial design and after major process and/or design changes.

Test Load Circuit


Switch S1 Open for ICCSB and ICCOP Tests

## Waveforms



CLOCK AC PARAMETERS


SUMO-25, COUTO-7, TCCO OUTPUT DELAYS


* Input includes: DINO-7, CINO-7, DIENB, CIENB, ERASE, RESET, DCMO-1, ADR0-1, TCS, TCCI, SHADD

INPUT SETUP AND HOLD


RISE AND FALL TIMES

A.C. Testing: Inputs are driven at 3.0V for a Logic " 1 " and OV for a Logic " 0 ". Input and output timing measurements are made at 1.5 V for both a Logic " 1 " and " 0 ". CLK is driven at 4.0 V and 0.0 V and measured at 2.0 V .
A.C. TESTING INPUT, OUTPUT WAVEFORM

## Features

- This Circuit is Processed in accordance to Mil-Std-883C and is Fully Conformant Under the Provisions of Paragraph 1.2.1
- 0 to 25.6 MHz Sample Rate
- Four Filter Cells
- 8 Bit Coefficients and Signal Data
- Low Power CMOS Operation
- $\operatorname{lccsB}=500 \mu \mathrm{~A}$ Maximum
- ICCOP $=110 \mu \mathrm{~A}$ Maximum @ 20 MHz
- 26 Bit Accumulator Per Stage
- Filter Lengths Up To 1032 Taps
- Shift-And-Add Output Stage for Combining Filter Outputs
- Expandable Coefficient Size, Data Size and Filter Length
- Decimation by 2, 3 or 4


## Applications

- 1-D and 2-D FIR Filters
- Radar/Sonar
- Digital Video and Audio
- Adaptive Filters
- Echo Cancellation
- Correlation/Convolution
- Complex Multiply-Add
- Butterfly Computation
- Matrix Multiplication
- Sample Rate Converters


## Description

The HSP43481/883 is a video-speed Digital Filter (DF) designed to efficiently implement vector operations such as FIR digital filters. It is comprised of four filter cells cascaded internally and a shift-andadd output stage, all in a single integrated circuit. Each filter cell contains an $8 \times 8$ multiplier, three decimation registers and a 26 bit accumulator which can add the contents of any filter cell accumulator to the output stage accumulator shifted right by eight bits. The HSP43481/883 has a maximum sample rate of 25.6 MHz . The effective multiply-accumulate (MAC) rate is 102 MHz .

The HSP43481/883 can be configured to process expanded coefficient and word sizes. Multiple devices can be cascaded for larger filter lengths without degrading the sample rate or a single device can process larger filter lengths at less than 25.6 MHz with multiple passes. The architecture permits processing filter lengths of over 1000 taps with the guarantee of no overflows. In practice, most filter coefficients are less than 1.0, making even larger filter lengths possible. The HSP43481/883 provides for unsigned or two's complement arithmetic, independently selectable for coefficients and signal data.

Each DF filter cell contains three resampling or decimation registers which permit output sample rate reduction at rates of $1 / 2,1 / 3$ or $1 / 4$ the input sample rate. These registers also provide the capability to perform 2-D operations such as NxN spatial correlations/convolutions for image processing applications.

## Block Diagram



Reliability Information


CAUTION: Stresses above those listed in "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.

## Operating Conditions


Operating Temperature Range $\ldots \ldots \ldots \ldots \ldots . .-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
TABLE 1. HSP43481/883 D.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Devices Guaranteed and $100 \%$ Tested

| PARAMETER | SYMBOL | CONDITIONS | GROUPA SUBGROUPS | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| Logical One Input Voltage | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{v}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 2.2 | - | v |
| Logical Zero Input Voltage | $V_{\text {IL }}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 0.8 | V |
| Output HIGH Voltage | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}(\text { Note } 1) \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 2.6 | - | V |
| Output LOW Voltage | VoL | $\begin{aligned} & \mathrm{IOL}_{\mathrm{OL}}=+2.0 \mathrm{~mA} \\ & \left.\mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V} \text { (Note } 1\right) \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 0.4 | V |
| Input Leakage Current | 1 | $\begin{aligned} & V_{I N}=V_{C C} \text { or } G N D \\ & V_{C C}=5.5 \mathrm{~V} \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}^{\prime} \leq+125^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Output Leakage Current | 10 | $\begin{aligned} & V_{\text {OUT }}=V_{C C} \text { or GND } \\ & V_{C C}=5.5 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Clock Input High | $\mathrm{V}_{\mathrm{IHC}}$ | $V_{C C}=5.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 3.0 | - | V |
| Clock Input Low | VILC | $V_{C C}=4.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 0.8 | V |
| Standby Power Supply Current | I'ccsb | $\begin{aligned} & V_{I N}=V_{C C} \text { or } G N D \\ & V_{C C}=5.5 \mathrm{~V}, \\ & \text { Outputs Open } \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 500 | $\mu \mathrm{A}$ |
| Operating Power Supply Current | I'COP | $\begin{aligned} & f=20.0 \mathrm{MHz} \\ & v_{C C}=5.5 \mathrm{~V}(\text { Note } 2) \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 110.0 | mA |
| Functional Test | FT | (Note 3) | 7,8 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | - |  |

NOTES: 1. Interchanging of force and sense conditions is permitted.
2. Operating Supply Current is proportional to frequency, typical rating is $5.5 \mathrm{~mA} / \mathrm{MHz}$.
3. Tested as follows: $f=1 \mathrm{MHz}, \mathrm{V}_{\mathrm{IH}}=2.6, \mathrm{~V}_{\mathrm{IL}}=0.4, \mathrm{~V}_{\mathrm{OH}} \geq 1.5 \mathrm{~V}$, $\mathrm{V}_{\mathrm{OL}} \leq 1.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{IHC}}=3.4 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{ILC}}=0.4 \mathrm{~V}$.

TABLE 2. HSP43481/883 A.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and $100 \%$ Tested

| PARAMETER | SYMBOL | CONDITIONS | GROUPA SUBGROUPS | TEMPERATURE | -20 (20MHz) |  | -25 (25.6MHz) |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| Clock Period | $\mathrm{T}_{\mathrm{CP}}$ | Note 1 | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 50 | - | 39 | - | ns |
| Clock Low | ${ }^{\text {T }} \mathrm{CL}$ | Note 1 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 20 | - | 16 | - | ns |
| Clock High | $\mathrm{T}_{\mathrm{CH}}$ | Note 1 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 20 | - | 16 | - | ns |
| Input Setup | TIS | Note 1 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 20 | - | 17 | - | ns |
| Input Hold | $\mathrm{T}_{\mathrm{IH}}$ | Note 1 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns |
| CLK to Coefficient Output Delay | TODC | Note 1 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 24 | - | 20 | ns |
| Output Enable Delay | TOED | Note 1 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 20 | - | 15 | ns |
| CLK to SUM Output Delay | TODS | Note 1 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 31 | - | 25 | ns |

NOTE: 1. A.C. Testing: $V_{C C}=4.5 \mathrm{~V}$ and 5.5 V . Inputs are driven at 3.0 V for a Logic " 1 " and 0.0 V for a Logic " 0 ". Input and output timing measurements are made at 1.5 V for both a Logic " 1 " and " 0 ". CLK is driven at 4.0 V and OV and measured at 2.0 V .

TABLE 3. HSP43481/883 A.C. ELECTRICAL PERFORMANCE CHARACTERISTICS

| PARAMETER | SYMBOL | CONDITIONS | NOTES | TEMPERATURE | -20 (20MHz) |  | -25 (25.6MHz) |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| Input Capacitance | $\mathrm{ClN}^{\text {N }}$ | $V_{C C}=\text { Open, } f=1 \mathrm{MHz}$ <br> All measurements are referenced to device GND. | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 15 | - | 15 | pF |
| Output Capacitance | COUT |  | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 15 | - | 15 | pF |
| Output Disable Delay | TODD |  | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 20 | - | 15 | ns |
| Output Rise Time | TOR |  | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 7 | - | 6 | ns |
| Output Fall Time | TOF |  | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 7 | - | 6 | ns |

NOTES: 1. The parameters listed in Table 3 are controlled via design or process parameters and are not directly tested. These parameters are characterized upon initial design and after major process and/or design changes.
2. Loading is as specified in the test load circuit, $C_{L}=40 p F$.

TABLE 4. APPLICABLE SUBGROUPS

| CONFORMANCE GROUPS | METHOD | SUBGROUPS |
| :--- | :---: | :---: |
| Initial Test | $100 \% / 5004$ | - |
| Interim Test | $100 \% / 5004$ | - |
| PDA | $100 \%$ | 1 |
| Final Test | $100 \%$ | $2,3,8 \mathrm{~A}, 8 \mathrm{~B}, 10,11$ |
| Group A | - | $1,2,3,7,8 \mathrm{~A}, 8 \mathrm{~B}, 9,10,11$ |
| Groups C \&D | Samples $/ 5005$ | $1,7,9$ |

HSP43481/883

Burn-In Circuit


| $\begin{aligned} & \text { PGA } \\ & \text { PIN } \end{aligned}$ | PIN NAME | BURN-IN SIGNAL | $\begin{aligned} & \text { PGA } \\ & \text { PIN } \end{aligned}$ | PIN NAME | BURN-IN SIGNAL | $\begin{aligned} & \text { PGA } \\ & \text { PIN } \end{aligned}$ | PIN NAME | BURN-IN SIGNAL | PGA PIN | PIN NAME | BURN-IN SIGNAL |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| K1 | tCCO | $\mathrm{v}_{\mathrm{CC} / 2}$ | C2 | $\overline{\text { CIENB }}$ | F10 | B6 | Sumo | $\mathrm{v}_{\mathrm{CC} / 2}$ | H10 | SUM19 | $\mathrm{v}_{\mathrm{CC} / 2}$ |
| J1 | ERASE | F10 | B2 | CIN6 | F6 | A6 | SENBL | F10 | G10 | SUM17 | $\mathrm{v}_{\mathrm{CC} / 2}$ |
| H1 | RESET | F11 | A2 | CIN7 | F7 | L7 | CLK | FO | F10 | SUM15 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| G1 | TCS | F7 | L3 | COUT5 | $\mathrm{v}_{\mathrm{CC} / 2}$ | K7 | DCM1 | F6 | E10 | $V_{S S}$ | GND |
| F1 | DIN5 | F5 | K3 | COUT6 | $\mathrm{v}_{\mathrm{CC} / 2}$ | B7 | SUM2 | $\mathrm{V}_{\mathrm{CC} / 2}$ | D10 | SUM12 | $\mathrm{v}_{\mathrm{CC} / 2}$ |
| E1 | DIN3 | F3 | B3 | CIN4 | F4 | A7 | SUM1 | $\mathrm{V}_{\mathrm{CC} / 2}$ | C10 | SUM10 | $\mathrm{v}_{\mathrm{CC} / 2}$ |
| D1 | DIN1 | F1 | A3 | CIN5 | F5 | 18 | ADDR1 | F1 | B10 | SUM8 | $\mathrm{v}_{\mathrm{CC} / 2}$ |
| C1 | DINO | FO | L4 | COUT3 | $\mathrm{V}_{\mathrm{CC} / 2}$ | K8 | DCMO | F5 | A10 | SUM7 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| B1 | TCCI | F8 | K4 | COUT4 | $\mathrm{v}_{\mathrm{CC} / 2}$ | B8 | SUM4 | $\mathrm{v}_{\mathrm{CC} / 2}$ | K11 | SUM23 | $\mathrm{v}_{\mathrm{CC} / 2}$ |
| L2 | COUT7 | $\mathrm{V}_{\mathrm{CC}} / 2$ | B4 | CIN2 | F2 | A8 | SUM3 | $\mathrm{v}_{\mathrm{CC} / 2}$ | J11 | SUM22 | $\mathrm{v}_{\mathrm{CC} / 2}$ |
| K2 | $\overline{\text { COENB }}$ | F10 | A4 | CIN3 | F3 | L9 | ADDRO | FO | H11 | SUM20 | $\mathrm{v}_{\mathrm{cc} / 2}$ |
| J2 | $V_{\text {cc }}$ | $\mathrm{V}_{\mathrm{CC}}$ | L5 | COUT1 | $\mathrm{V}_{\mathrm{CC} / 2}$ | K9 | SENBH | F10 | G11 | SUM18 | $\mathrm{V}_{\mathrm{CC}} / 2$ |
| H2 | $\overline{\text { DIENB }}$ | F10 | K5 | COUT2 | $\mathrm{V}_{\mathrm{CC} / 2}$ | B9 | SUM6 | $\mathrm{V}_{\mathrm{CC} / 2}$ | F11 | SUM16 | $\mathrm{v}_{\mathrm{CC} / 2}$ |
| G2 | DIN7 | F8 | B5 | CINO | FO | A9 | SUM5 | $\mathrm{V}_{\mathrm{CC} / 2}$ | E11 | SUM14 | $\mathrm{v}_{\mathrm{cc} / 2}$ |
| F2 | DIN6 | F6 | A5 | CIN1 | F1 | L10 | SuM25 | $\mathrm{v}_{\mathrm{CC} / 2}$ | D11 | SUM13 | $\mathrm{v}_{\mathrm{CC} / 2}$ |
| E2 | DIN4 | F4 | L6 | COUTO | $\mathrm{V}_{\mathrm{CC} / 2}$ | K10 | SUM24 | $\mathrm{v}_{\mathrm{CC} / 2}$ | C11 | SUM11 | $\mathrm{V}_{\mathrm{cc} / 2}$ |
| D2 | DIN2 | F2 | K6 | SHADD | F9 | J10 | SUM21 | $\mathrm{V}_{\mathrm{CC} / 2}$ | B11 | SUM9 | $\mathrm{v}_{\mathrm{CC} / 2}$ |

NOTES: 1. $\mathrm{V}_{\mathrm{CC}} / 2(2.7 \mathrm{~V} \pm 10 \%)$ used for outputs only.
2. $47 \mathrm{~K} \Omega( \pm 20 \%)$ resistor connected to all pins except $V_{C C}$ and GND.
3. $\mathrm{V}_{\mathrm{CC}}=5.5 \pm 0.5 \mathrm{~V}$.
4. $0.1 \mu \mathrm{~F}(\mathrm{~min})$ capacitor between $\mathrm{V}_{\mathrm{CC}}$ and GND per position.
5. $\mathrm{FO}=100 \mathrm{KHz} \pm 10 \%, \mathrm{~F}_{1}=\mathrm{FO} / 2, F 2=F 1 / 2 \ldots, \ldots, F_{1}=F 10 / 2$, 40\% - 60\% Duty Cycle.
6. Input voltage limits: $\mathrm{V}_{\mathrm{IL}}=0.8 \mathrm{~V}$ max., $\mathrm{V}_{\mathrm{IH}}=4.5 \mathrm{~V} \pm 10 \%$.

## Metallization Topology

## DIE DIMENSIONS:

$253 \times 230 \times 19 \pm 1$ mils
METALLIZATION:
Type: Si - Al or Si - Al - Cu
Thickness: 8kA
GLASSIVATION:
Type: Nitrox
Thickness: $10 \mathrm{k} \AA$
DIE ATTACH:
Material: Gold/Silicon Eutectic Alloy or Silver-Glass
WORST CASE CURRENT DENSITY:
$1.2 \times 10^{5} \mathrm{~A} / \mathrm{cm}^{2}$
Metallization Mask Layout
HSP43481/883


## Features

- Eight Filter Cells
- 0 to 30 MHz Sample Rate
- 8-Bit Coefficients and Signal Data
- 26-Bit Accumulator Per Stage
- Filter Lengths Over 1000 Taps
- Shift and Add Output Stage for Combining Filter Outputs
- Expandable Coefficient Size, Data Size and Filter Length
- Decimation by 2, 3 or 4
- CMOS Power Dissipation Characteristics


## Applications

- 1-D and 2-D FIR Filters
- Radar/Sonar
- Digital Video and Audio
- Adaptive Filters
- Echo Cancellation
- Correlation/Convolution
- Complex Multiply-Add
- Butterfly Computation
- Matrix Multiplication
- Sample Rate Converters


## Description

The HSP43881 is a video speed Digital Filter (DF) designed to efficiently implement vector operations such as FIR digital filters. It is comprised of eight filter cells cascaded internally and a shift and add output stage, all in a single integrated circuit. Each filter cell contains a $8 \times 8$ bit multiplier, three decimation registers and a 26-bit accumulator. The output stage contains an additional 26-bit accumulator which can add the contents of any filter cell accumulator to the output stage accumulator shifted right by 8 bits. The HSP43881 has a maximum sample rate of 30 MHz . The effective multiply accumulate (mac) rate is 240 MHz . The HSP43881 DF can be configured to process expanded coefficient and word sizes. Multiple DFs can be cascaded for larger filter lengths without degrading the sample rate or a single DF can process larger filter lengths at less than 30 MHz with multiple passes. The architecture permits processing filter lengths of over 1000 taps with the guarantee of no overflows. In practice, most filter coefficients are less than 1.0, making even larger filter lengths possible. The DF provides for 8-bit unsigned or two's complement arithmetic, independently selectable for coefficients and signal data.
Each DF filter cell contains three resampling or decimation registers which permit output sample rate reduction at rates of $1 / 2,1 / 3$ or $1 / 4$ the input sample rate. These registers also provide the capability to perform 2-D operations such as matrix multiplication and $\mathrm{N} \times \mathrm{N}$ spatial correlations/convolutions for image processing applications.

Block Diagram




NOTE: An overbar on a signal name represents an active LOW signal.

## Pin Description

| SYMBOL | PIN <br> NUMBER | TYPE | NAME AND FUNCTION |
| :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ | $\begin{gathered} \text { A3, A10, B1, } \\ \text { D11, F10, J1, } \\ \text { K4,L7 } \end{gathered}$ |  | +5V Power Supply Input |
| VSS | $\begin{gathered} \mathrm{A} 1, \mathrm{~A} 11, \mathrm{E} 2, \mathrm{~F} 1, \\ \mathrm{E} 11, \mathrm{H} 11, \mathrm{~K} 3, \\ \mathrm{~K} 6, \mathrm{~L} 9 \end{gathered}$ |  | Power Supply Ground Input |
| CLK | G3 | 1 | The CLK input provides the DF system sample clock. The maximum clock frequency is is 30 MHz . |
| DINO-7 | $\begin{gathered} \text { A5-8, B6-7, } \\ \text { C6-7 } \end{gathered}$ | 1 | These eight inputs are the data sample input bus. Eight bit data samples are synchronously loaded through these pins to the $X$ register of each filter cell simultaneously. The DIENB signal enables loading, which is synchronous on the rising edge of the clock signal. |
| TCS | B5 | 1 | The TCS input determines the number system interpretation of the data input samples on pins DINO-7 as follows: <br> TCS $=$ Low $\rightarrow$ Unsigned Arithmetic <br> TCS $=$ High $\rightarrow$ Two's Complement Arithmetic <br> The TCS signal is synchronously loaded into the X register in the same way as the DINO-7 inputs. |
| $\overline{\text { DIENB }}$ | C5 | 1 | A low on this enables the data sample input bus (DINO-7) to all the filter cells. A rising edge of the CLK signal occurring while DIENB is low will load the $X$ register of every filter cell with the 8 bit value present on DINO-7. A high on this input forces all the bits of the data sample input bus to zero; a rising CLK edge when DIENB is high will load the X register of every filter cell with all zeros. This signal is latched inside the DF, delaying its effect by one clock internal to the DF. Therefore, it must be low during the clock cycle immediately preceding presentation of the desired data on the DINO-7 inputs. Detailed operation is shown in later timing diagrams. |
| CINO-7 | $\begin{gathered} \text { B9-11, C10-11, } \\ \text { D10, E9-10 } \end{gathered}$ | 1 | These eight inputs are used to input the 8 bit coefficients. The coefficients are synchronously synchronously loaded into the C register of filter CELL 0 if a rising edge of CLK occurs while $\overline{C I E N B}$ is low. The CIENB signal is delayed by one clock as discussed below. |
| TCCI | A9 | 1 | The TCCI input determines the number system interpretation of the coefficient inputs on pins CINO-7 as follows: <br> TCCI $=$ LOW $\rightarrow$ Unsigned Arithmetic <br> TCCI $=\mathrm{HIGH} \rightarrow$ Two's Complement Arithmetic <br> The TCCI signal is synchronously loaded into the Cregister in the same way as the CINO-7 inputs. |
| $\overline{\text { CIENB }}$ | B8 | 1 | A low on this input enable the $C$ register of every filter cell and the $D$ registers (decimation) of every filter cell according to the state of the DCMO-1 inputs. A rising edge of the CLK signal occurring while CIENB is low will load the C register and appropriate D registers with the coefficient data present at their inputs. This privides the mechanism for shifting the coefficients from cell o cell through the device. A high on this input freezes the contents of the C registel and the D registers, ignoring the CLK signal. This signal is latched and delayed by one clock internal to the DF. Therefore, it must be low during the clock cycle immediately preceding presentation of the desired coefficient on the CINO-7 inputs. Detailed operation is shown in the Timing Diagrams section. |
| COUTO-7 | $\begin{gathered} \text { B2, C1-2,D1-2 } \\ \text { E1, E3, F2 } \end{gathered}$ | 0 | These eight three-state outputs are used to output the 8 bit coefficients from filter cell 7. These outputs are enabled by the COENB signal low. These outputs may be tied to the CINO-7 inputs of the same DF to recirculate the coefficients, or they may be tied to the CINO-7 inputs of another DF to cascade DFs for longer filter lengths. |
| TCCO | B3 | 0 | The TCCO three-state output determines the number system representation of the coefficients output on COUTO-7. It tracks the TCCI signal to this same DF. It should be tied to the TCCI input of the next DF in a cascade of DFs for increased filter lengths. This signal is enabled by COENB low. |
| $\overline{\text { COENB }}$ | A2 | 1 | A low on the $\overline{\text { COENB }}$ input enables the COUTO-7 and the TCCO output. A high on this input places all these outputs in their high impedance state. |

## Pin Description (Continued)

| SYMBOL | PIN NUMBER | TYPE | NAME FUNCTION |
| :---: | :---: | :---: | :---: |
| DCMO-1 | G2, L1 | 1 | These two inputs determine the use of the internal decimation registers as follows: <br> The coefficients pass from cell to cell at a rate determined by the number of decimation registers used. When no decimation registers are used, coefficients move from cell to cell on each clock. When one decimation register is used, coefficients move from cell to cell on every other clock, etc. These signals are latched and delayed by one clock internal to the DF. |
| SUMO-25 | $\begin{aligned} & \mathrm{J} 2, \mathrm{~J} 5-8, \\ & \mathrm{~J} 10, \mathrm{~K} 2, \\ & \mathrm{~K} 5-11, \\ & \mathrm{~L} 2-6, \mathrm{LB}, \\ & \mathrm{~L} 10-11 \end{aligned}$ | 0 | These 26 three-state outputs are used to output the results of the internal filter cell computations. Individual filter cell results or the result of the shift-and-add output stage can be output. If an individual filter cell result is to be output, the ADRO-2 signals select the filter cell result. The SHADD signal determines whether the selected filter cell result or the output stage adder result is output. The signals $\overline{\text { SENBH }}$ and $\overline{\text { SENBL }}$ enable the most significant and least significant bits of the SUMO-25 result, respectively. Both SENBH and SENBL may be enabled simultaneously if the system has a 26 bit or larger bus. However, individual enables are provided to facilitate use with a 16 bit bus. |
| $\overline{\text { SENBH }}$ | K1 | 1 | A low on this input enables result bits SUM16-25. A high on this input places these bits in their high impedance state. |
| $\overline{\text { SENBL }}$ | E11 | 1 | A low on this input enables result bits SUMO-15. A high on this input places these |
| ADRO-2 | G1, H1-2 | 1 | These inputs select the one cell whose accumulator will be read through the output bus (SUMO-25) or added to the output stage accumulator. They also determine which accumulator will be cleared when ERASE is low. For selection of which accumulator to read through the output bus (SUMO-25) or which to add of the output stage accumulator, these inputs are latched in the DF and delayed by one clock internal to the device. If the ADRO-2 lines remain at the same address for more than one clock, the output at SUMO-25 will not change to reflect any subsequent accumulator updates in the addressed cell. Only the result available during the first clock, when ADRO-1 selects the cell, will be output. This does not hinder normal operation since the ADRO-1 lines are changed sequentially. This feature facilitates the interface with slow memories where the output is required to be fixed for more than one clock. |
| SHADD | F3 | 1 | The SHADD input controls the activation of the shift-and-add operation in the output stage. This signal is latched in the DF and delayed by one clock internal to the device. A detailed explanation is given in the DF Output Stage section. |
| $\overline{\text { RESET }}$ | A4 | 1 | A low on this input synchronously clears all the intemal registers, except the cell accumulators. It can be used with ERASE to also clear all the accumulators simultaneously. This signal is latched in the DF and delayed by one clock internal to the DF. |
| ERASE | B4 | 1 | A low on this input synchronously clears the cell accumulator selected by the ADRO-1 signals. If $\overline{\text { RESET }}$ is also low simultaneously, all cell accumulators are cleared. |
| ALIGN PIN | C3 |  | Used for aligning chip in socket or printed circuit board. Must be left as a no connect in circuit. |

## Functional Description

The Digital Filter Processor (DF) is composed of eight filter cells cascaded together and an output stage for combining or selecting filter cell outputs (See Block Diagram). Each filter cell contains a multiplier-accumulator and several registers (Figure 1). Each 8-bit coefficient is multiplied by a 8- bit data sample, with the result added to the 26-bit accumulator contents. The coefficient output of each cell is cascaded to the coefficient input of the next cell to its right.

## DF Filter Cell

A 8-bit coefficient (CINO-7) enters each cell through the C register on the left and exits the cell on the right as signals COUTO-7. With no decimation, the coefficient moves directly from the C register to the output, and is valid on the clock following its entrance. When decimation is selected the coefficient exit is delayed by 1,2 or 3 clocks by passing through one or more decimation registers (D1, D2 or D3).
The combination of $D$ registers through which the coefficient passes is determined by the state of DCMO and DCM1. The output signals (COUTO-7) are connected to the CINO-7 inputs of the next cell to its right. The $\overline{\text { COENB }}$ input signal enables the COUTO-7 outputs of the right most cell to the COUTO-7 pins of the device.
The $C$ and $D$ registers are enabled for loading by CIENB. Loading is synchronous with CLK when CIENB is low. Note that $\overline{C I E N B}$ is latched internally. It enables the register for loading after the next CLK following the onset of CIENB low. Actual loading occurs on the second CLK following the onset of $\overline{C I E N B}$ low. Therefore $\overline{C I E N B}$ must be low during the clock cycle immediately preceding presentation of the coefficient on the CINO-7 inputs. In most basic FIR operations, CIENB will be low throughout the process, so this latching and delay sequence is only important during the initialization phase. When $\overline{\text { CIENB }}$ is high, the coefficients are frozen.
These registers are cleared synchronously under control of $\overline{\text { RESET, }}$, which is latched and delayed exactly like $\overline{\text { CIENB. }}$
The output of the C register ( $\mathrm{CO}-8$ ) is one input to $8 \times 8 \mathrm{mul}$ tiplier.
The other input to the $8 \times 8$ multiplier comes from the output of the X register. This register is loaded with a data sample from the device input signals DINO-7 discussed above. The $X$ register is enabled for loading by DIENB. Loading is synchronous with CLK when DIENB is low. Note that $\overline{D I E N B}$ is latched internally. It enables the register for loading after the next CLK following the onset of DIENB low. Actual loading occurs on the second CLK following the onset of DIENB low; therefore, $\overline{\text { DIENB }}$ must be low during the clock cycle immediately preceding presentation of the data sample on the DINO-7 inputs. In most basic FIR operations, $\overline{\text { DIENB }}$ will be low throughout the process, so this latching and delay sequence is only important during the initialization phase. When DIENB is high, the X register is loaded with all zeros.
The multiplier is pipelined and is modeled as a multiplier core followed by two pipeline registers, MREGO and MREG1 (Figure 1). The multiplier output is sign extended and input as one operand of the 26-bit adder. The other
adder operand is the output of the 26-bit accumulator. The adder output is loaded synchronously into both the accumulator and the TREG.
The TREG loading is disabled by the cell select signal, CELLn, where $n$ is the cell number. The cell select is decoded from the ADRO-2 signals to generate the TREG load enable. The cell select is inverted and applied as the load enable to the TREG. Operation is such that the TREG is loaded whenever the cell is not selected. Therefore, TREG is loaded every clock except the clock following cell selection. The purpose of the TREG is to hold the result of a sum-ofproducts calculation during the clock when the accumulator is cleared to prepare for the next sum-of-products calculation. This allows continuous accumulation without wasting clocks.
The accumulator is loaded with the adder output every clock unless it is cleared. It is cleared synchronously in two ways. When RESET and ERASE are both low, the accumulator is cleared along with all other registers on the device. Since ERASE and RESET are latched and delayed one clock internally, clearing occurs on the second CLK following the onset of both ERASE and RESET low.
The second accumulator clearing mechanism clears a single accumulator in a selected cell. The cell select signal, CELLn, decoded from ADRO-2 and the ERASE signal enable clearing of the accumulator on the next CLK.
The ERASE and $\overline{R E S E T}$ signals clear the DF internal registers and states as follows:

| $\overline{\text { ERASE }}$ | $\overline{\text { RESET }}$ | CLEARING EFFECT |
| :---: | :---: | :--- |
| 1 | 1 | No clearing occurs, internal state <br> remains same |
| 1 | 0 | $\overline{\text { RESET only active, all registers except }}$ <br> accumulators are cleared, including <br> the internal pipeline registers. |
| 0 | 1 | $\overline{\text { ERASE only active, the accumulator }}$ <br> whose address is given by the ADRO-2 <br> inputs is cleared. |
| 0 | 0 | Both $\overline{\text { RESET and } \overline{\text { ERASE active, all }}}$accumulators as well as all other <br> registers are cleared. |

## The DF Output Stage

The output stage consists of a 26-bit adder, 26-bit register, feedback multiplexer from the register to the adder, an output multiplexer and a 26-bit three-state driver stage (Figure 2).
The 26-bit output adder can add any filter cell accumulator result to the 18 most significant bits of the output buffer. This result is stored back in the output buffer. This operation takes place in one clock period. The eight LSBs of the output buffer are lost. The filter cell accumulator is selected by the ADRO-2 inputs.
The 18 MSBs of the output buffer actually pass through the zero mux on their way to the output adder input. The zero mux is controlled by the SHADD input signal and selects either the output buffer 18 MSBs or all zeros for the adder input. A low on the SHADD input selects zero. A high on the SHADD input selects the output buffer MSBs, thus activating the shift-and-add operation. The SHADD signal is latched and delayed by one clock internally.


FIGURE 1. HSP43881 FILTER CELL


FIGURE 2. HSP43881 DF OUTPUT STAGE

The 26 least significant bits (LSBs) from either a cell accumulator or the output buffer are output on the SUMO-25 bus. The output mux determines whether the cell accumulator selected by ADRO-2 or the output buffer is output to the bus. This mux is controlled by the SHADD input signal. Control is based on the state of the SHADD during two successive clocks; in other words, the output mux selection contains memory. If SHADD is low during a clock cycle and was low during the previous clock, the output mux selects the contents of the filter cell accumulator addressed by ADRO-2. Otherwise the output mux selects the contents of the output buffer.
If the ADRO-2 lines remain at the same address for more than one clock, the output at SUMO-25 will not change to reflect any subsequent accumulator updates in the addressed cell. Only the result available during the first clock when ADRO-2 selects the cell will be output. This does not hinder normal FIR operation since the ADRO-2 lines are changed sequentially. This feature facilitates the interface with slow memories where the output is required to be fixed for more than one clock.

The SUMO-25 output bus is controlled by the SENBH and SENBL signals. A low on SENBL enables bits SUMO-15. A low on SENBH enables bits SUM16-25. Thus all 26 bits can be output simultaneously if the external system has a 26-bit or larger bus. If the external system bus is only 16 bits, the bits can be enabled in two groups of 16 and 10 bits (sign extended).

## DF Arithmetic

Both data samples and coefficients can be represented as either unsigned or two's complement numbers. The TCS and TCCI inputs determine the type of arithmetic representation. Internally all values are represented by a 9 -bit two's complement number. The value of the additional ninth bit depends on the arithmetic representation selected. For two's complement arithmetic, the sign is extended into the ninth bit. For unsigned arithmetic, bit 9 is 0 .

The multiplier output is 18 bits and the accumulator is 26 bits. The accumulator width determines the maximum possible number of terms in the sum of products without overflow. The maximum number of terms depends also on the number system and the distribution of the coefficient and data values. Then maximum numbers of terms in the sum products are:

| NUMBER SYSTEM | MAX \# <br> OF TERMS |
| :--- | :---: |
| Two unsigned vectors | 1032 |
| Two two's complement: |  |
| - Two positive vectors | 2080 |
| - Negative vectors |  |
| - One positive and one negative vector | 2047 |
| One unsigned and one two's complement <br> vector: <br> - Positive two's complement vector <br> - Negative two's complement vector |  |

For practical FIR filters, the coefficients are never all near maximum value, so even larger vectors are possible in practice.

## Basic FIR Operation

A simple, 30 MHz 8 -tap filter example serves to illustrate more clearly the operation of the DF. The sequence table (Table 1) shows the results of the multiply accumulate in each cell after each clock. The coefficient sequence, Cn , enters the DF on the left and moves from left to right through the cells. The data sample sequence, Xn , enters the DF from the top, with each cell receiving the same sample simultaneously. Each cell accumulates the sum of products for one output point. Eight sums of products are calculated simultaneously, but staggered in time so that a new output is available every system clock.

TABLE 1. HSP43881 30MHz, 8 TAP FIR FILTER SEQUENCE

| CLK | CELLO | CELL 1 | CELL 2 | CELL 3 | CELL 4 | CELL 5 | CELL 6 | CELL 7 | SUM/CLR |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | $\mathrm{C}_{7} \times \mathrm{X}_{0}$ | 0 | 0 | 0 |  |  |  |  | - |
| 1 | $+\mathrm{C}_{6} \times \mathrm{x}_{1}$ | $\mathrm{C}_{7} \times \mathrm{X}_{1}$ | 0 | 0 |  |  |  |  | - |
| 2 | $+\mathrm{C}_{5} \times \mathrm{x}_{2}$ | $+\mathrm{C}_{6} \times \mathrm{x}_{2}$ | $\mathrm{C}_{7} \times \mathrm{X}_{2}$ | 0 |  |  |  |  | - |
| 3 | $+C_{4} \times x_{3}$ | $+C_{5} \times x_{3}$ | $+C_{6} \times x_{3}$ | $\mathrm{C}_{7} \times \mathrm{X}_{3}$ |  |  |  |  | - |
| 4 | $+\mathrm{C}_{3} \times \mathrm{x}_{4}$ | $+C_{4} \times{ }^{4}$ | $+C_{5} \times{ }^{1}$ | $+C_{6} \times{ }^{4}$ | $\mathrm{C}_{7} \times \mathrm{X}_{4}$ |  |  |  | - |
| 5 | $+\mathrm{C}_{2} \times \mathrm{X}_{5}$ | $\mathrm{C}_{3} \times \mathrm{X}_{5}$ | $+C_{4} \times{ }^{\prime}$ | $+C_{5} \times{ }^{2}$ | $+C_{6} \times{ }^{2}$ | $\mathrm{C}_{7} \times \mathrm{X}_{5}$ |  |  | - |
| 6 | $+\mathrm{C}_{1} \times \mathrm{x}_{6}$ | $+C_{2} \times \mathrm{X}_{6}$ | $+C_{3} \times x_{6}$ | $+C_{4} \times \mathrm{X}_{6}$ | $+\mathrm{C}_{5} \times \mathrm{X}_{6}$ | $+\mathrm{C}_{6} \times \mathrm{x}_{6}$ | $\mathrm{C}_{7} \times \mathrm{X}_{6}$ |  | - |
| 7 | $+\mathrm{C}_{0} \times \mathrm{X}_{7}$ | $+c_{1} \times x_{7}$ | $+\mathrm{C}_{2} \times \mathrm{X}_{7}$ | $+C_{3} \times{ }^{4}$ | $+\mathrm{C}_{4} \times \mathrm{X}_{7}$ | $+C_{5} \times x_{7}$ | $+C_{6} \times x_{7}$ | $\mathrm{C}_{7} \times \mathrm{X}_{7}$ | Cell 0 (Y7) |
| 8 | $\mathrm{C}_{7} \times \mathrm{X}_{8}$ | $+\mathrm{C}_{0} \times \mathrm{X}_{8}$ | $+\mathrm{C}_{1} \times \mathrm{x}_{8}$ | $+\mathrm{C}_{2} \times \mathrm{X}_{8}$ | $+\mathrm{C}_{3} \times \mathrm{x}_{8}$ | $+\mathrm{C}_{4} \times \mathrm{X}_{8}$ | $+\mathrm{C}_{5} \times \mathrm{X}_{8}$ | $+C_{6} \times x_{8}$ | Cell 1 (Y8) |
| 9 | $+\mathrm{C}_{6} \times \mathrm{X}_{9}$ | $\mathrm{C}_{7} \times \mathrm{X}_{9}$ | $+C_{0} \times{ }^{1}$ | $+C_{1} \times{ }^{\prime}$ | $+\mathrm{C}_{2} \times \mathrm{x}_{9}$ | $+C_{3} \times x_{9}$ | $+C_{4} \times \mathrm{X}_{9}$ | $+C_{5} \times{ }^{\prime}$ | Cell 2 (Y9) |
| 10 | $+C_{5} \times{ }_{10}$ | $+C_{6} \times{ }_{10}$ | $C_{7} \times{ }_{10}$ | $+C_{0} \times x_{10}$ | $+c_{1} \times x_{10}$ | $+C_{2} \times x_{10}$ | $+C_{3} \times x_{10}$ | $+C_{4} \times x_{10}$ | Cell 3 (Y10) |
| 11 | $+C_{4} \times \mathrm{X}_{11}$ | $+C_{5} \times{ }_{11}$ | $+C_{6} \times{ }_{11}$ | $\mathrm{C}_{7} \times{ }_{11}$ | $+C_{0} \times{ }_{11}$ | $+c_{1} \times x_{11}$ | $+\mathrm{C}_{2} \times \mathrm{X}_{11}$ | $+c_{3} \times x_{11}$ | Cell 4 (Y11) |
| 12 | $+C_{3} \times x_{12}$ | $+C_{4} \times x_{12}$ | $+C_{5} \times{ }^{12}$ | $+\mathrm{C}_{6} \times \mathrm{X}_{12}$ | $C_{7} \times{ }_{12}$ | $+C_{0} \times x_{12}$ | $+C_{1} \times \mathrm{X}_{12}$ | $+\mathrm{C}_{2} \times \mathrm{X}_{12}$ | Cell 5 (Y12) |
| 13 | $+\mathrm{C}_{2} \times \mathrm{X}_{13}$ | $+C_{3} \times x_{13}$ | $+C_{4} \times{ }_{13}$ | $+C_{5} \times{ }_{13}$ | $+c_{6} \times x_{13}$ | $\mathrm{C}_{7} \times{ }_{13}$ | $+c_{0} \times{ }_{13}$ | $+c_{1} \times x_{13}$ | Cell 6 (Y13) |
| 14 | $+\mathrm{C}_{1} \times \mathrm{x}_{14}$ | $+\mathrm{C}_{2} \times \mathrm{X}_{14}$ | $+c_{3} \times x_{14}$ | $+C_{4} \times{ }_{14}$ | $+C_{5} \times{ }_{14}$ | $+C_{6} \times x_{14}$ | $+C_{7} \times{ }_{14}$ | $+c_{0} \times x_{14}$ | Cell 7 (Y14) |
| 15 | $+\mathrm{C}_{0} \times \mathrm{X}_{15}$ | $+C_{1} \times \mathrm{X}_{15}$ | $+\mathrm{C}_{2} \times \mathrm{X}_{15}$ | $+\mathrm{C}_{3} \times \mathrm{X}_{15}$ | $+\mathrm{C}_{4} \times \mathrm{X}_{15}$ | $+C_{5} \times{ }_{15}$ | $+C_{6} \times{ }_{15}$ | $\mathrm{C}_{7} \times{ }^{15}$ | Cell O (Y15) |

SAMPLE


FIGURE 3. HSP43881 30MHz, 8 TAP FIR FILTER APPLICATION SCHEMATIC

Detailed operation of the DF to perform a basic 8-tap, 8-bit coefficient, 8-bit data, 30 MHz FIR filter is best understood by observing the schematic (Figure 3) and timing diagram (Figure 4). The internal pipeline length of the DF is four (4) clock cycles, corresponding to the register levels CREG (or XREG), MREGO, MREG1, and TREG (Figures 1 and 2). Therefore the delay from presentation of data and coefficients at the DINO-7 and CINO-7 inputs to a sum appearing at the SUMO-25 output is:
k + Td
where
$k=$ filter length
$T d=4$, the internal pipeline delay of DF
After the pipeline has filled, a new output sample is available every clock. The delay to last sample output from last sample input is Td .

The output sums, Yn , shown in the timing diagram are derived from the sum-of-products equation:
$\mathrm{Y}(\mathrm{n})=\mathrm{C}(0) \times \mathrm{X}(\mathrm{n})+\mathrm{C}(1) \times \mathrm{X}(\mathrm{n}-1)+\mathrm{C}(2) \times \mathrm{X}(\mathrm{n}-2)+\mathrm{C}(3)$ $x X(n-3)+C(4) \times X(n-4)+C(5) \times X(n-5)+C(6) \times X(n-6)$ $+C(7) \times X(n-7)$

## Extended FIR Filter Length

Filter lengths greater that eight taps can be created by either cascading together multiple DF devices or "reusing" a single device. Using multiple devices, an FIR filter of over 1000 taps can be constructed to operate at a 30 MHz sample rate. Using a single device clocked at 30 MHz , an FIR filter of over 1000 taps can be constructed to operate at less than a 30 MHz sample rate. Combinations of these two techniques are also possible.


FIGURE 4. HSP43881 30MHz, 8 TAP FIR FILTER TIMING


FIGURE 5. HSP $4388130 \mathrm{MHz}, 16$ TAP FIR FILTER CASCADE APPLICATION SCHEMATIC.

## Cascade Configuration

To design a filter length L>8, L/8 DFs are cascaded by connecting the COUTO-7 outputs of the (i)th DF to the CINO-7 inputs of the ( $i+1$ )th DF. The DINO-7 inputs and SUMO-25 outputs of all the DFs are also tied together. A specific example of two cascaded DFs illustrates the technique (Figure 5). Timing (Figure 6) is similar to the simple 8-tap FIR, except the ERASE and $\overline{\text { SENBL/SENBH }}$
signals must be enabled independently for the two DFs in order to clear the correct accumulators and enable the SUMO-25 output signals at the proper times.

## Single DF Configuration

Using a single DF, a filter of length $L>8$ can be constructed by processing in L/8 passes as illustrated in the following table (Table 2) for a 16-tap FIR. Each pass is composed of

TABLE 2. HSP43881 16-TAP FIR FILTER SEQUENCE USING A SINGLE DF
 Input

| CLK | CELL 0 | CELL 1 | CELL 2 | CELL 3 | CELL 4 | CELL 5 | CELL 6 | CELL 7 | SUM/CLR |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 6 | $\mathrm{C}_{15} \times \mathrm{X}_{0}$ | 0 | 0 | 0 |  |  |  |  | - |
| 7 | $+\mathrm{C}_{14} \times \mathrm{X}_{1}$ | $\mathrm{c}_{15} \times \mathrm{X}_{1}$ | 0 | 0 |  |  |  |  | - |
| 8 | $+\mathrm{C}_{13} \times \mathrm{X}_{2}$ |  | $\mathrm{C}_{15} \times \mathrm{X}_{2}$ | 0 |  |  |  |  | - |
| 9 | $+\mathrm{C}_{12} \times \mathrm{x}_{3}$ |  |  | $\mathrm{C}_{15} \times \mathrm{X}_{3}$ |  |  |  |  | - |
| 10 | $+\mathrm{C}_{11} \times \mathrm{X}_{4}$ |  |  | $+C_{14} \times X_{4}$ | $\mathrm{C}_{15} \times \mathrm{X}_{4}$ |  |  |  | - |
| 11 | $+\mathrm{C}_{10} \times \mathrm{X}_{5}$ |  |  | $+\mathrm{C}_{13} \times \mathrm{X}_{5}$ |  | $\mathrm{C}_{15} \times \mathrm{X}_{5}$ |  |  | - |
| 12 | $+C_{9} \times x_{6}$ |  |  | $+\mathrm{C}_{12} \times \mathrm{X}_{6}$ |  |  | $c_{15} \times x_{6}$ |  | - |
| 13 | $+C_{8} \times x_{7}$ |  |  | $+C_{11} \times x_{7}$ |  |  |  | $\mathrm{C}_{15} \times \mathrm{x}_{7}$ | - |
| 14 | $+C_{7} \times \mathrm{X}_{8}$ |  |  | $+\mathrm{C}_{10} \times \mathrm{X}_{8}$ |  |  |  | $+\mathrm{C}_{14} \times \mathrm{X}_{8}$ | - |
| 15 | $+\mathrm{C}_{6} \times \mathrm{X}_{9}$ |  |  | $+\mathrm{C}_{9} \times \mathrm{X}_{9}$ |  |  |  | $+\mathrm{C}_{13} \times \mathrm{X}_{9}$ | - |
| 16 | $+\mathrm{C}_{5} \times \mathrm{X}_{10}$ |  |  | $+\mathrm{C}_{8} \times \mathrm{X}_{10}$ |  |  |  | $+\mathrm{C}_{12} \times \mathrm{X}_{10}$ | - |
| 17 | $+C_{4} \times x_{11}$ |  |  | $+C_{7} \times{ }^{11}$ |  |  |  | $+C_{11} \times \mathrm{X}_{11}$ | - |
| 18 | $+C_{3} \times \mathrm{X}_{12}$ |  |  | $+C_{6} \times x_{12}$ |  |  |  | $+\mathrm{C}_{10} \times \mathrm{X}_{12}$ | - |
| 19 | $+\mathrm{C}_{2} \times \mathrm{X}_{13}$ |  |  | $+\mathrm{C}_{5} \times \mathrm{X}_{13}$ |  |  |  | $+C_{9} \times{ }^{13}$ | - |
| 20 | $+\mathrm{C}_{1} \times \mathrm{X}_{14}$ |  |  | $+\mathrm{C}_{4} \times \mathrm{X}_{14}$ |  |  |  | $+\mathrm{C}_{8} \times \mathrm{X}_{14}$ | - |
| 21 | $+\mathrm{C}_{0 \times 15}$ | $\downarrow$ |  | $+C_{3} \times \mathrm{X}_{15}$ |  |  |  | $+C_{7} \times{ }^{15}$ | CELL O(Y15) |
| 22 | 0 | $\mathrm{C}_{0} \times \mathrm{X}_{16}$ | $\downarrow$ | $+\mathrm{C}_{2} \times \mathrm{X}_{16}$ |  |  |  | $+\mathrm{C}_{6} \times \mathrm{X}_{16}$ | CELL 1 (Y16) |
| 23 | 0 | 0 | $\mathrm{C}_{0} \times \mathrm{X}_{17}$ | $+\mathrm{C}_{1} \times \mathrm{X}_{17}$ |  |  |  | $+\mathrm{C}_{5} \times \mathrm{X}_{17}$ | CELL 2 (Y17) |
| 24 | 0 | 0 | 0 | $+\mathrm{C}_{0} \times \mathrm{X}_{18}$ | $\downarrow$ |  |  | $+C_{4} \times{ }^{18}$ | CELL 3(Y18) |
| 25 | 0 | 0 | 0 | 0 | $\mathrm{c}_{0} \times \mathrm{X}_{19}$ | $\downarrow$ |  | $+C_{3} \times 19$ | CELL 4 (Y19) |
| 26 | 0 | 0 | 0 | 0 | 0 | $\mathrm{C}_{0} \times \mathrm{X}_{20}$ | $\downarrow$ | $+\mathrm{C}_{2} \times \mathrm{X}_{20}$ | CELL 5 (Y20) |
| 27 | 0 | 0 | 0 | 0 | 0 | 0 | $c_{0} \times{ }_{21}$ | $+c_{1} \times \times_{21}$ | CELL 6 (Y21) |
| 28 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | $+C_{0} \times{ }_{22}$ | CELL 7 (Y22) |
| 29 | $\mathrm{C}_{15} \times \mathrm{X}_{8}$ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | - |
| 30 | $+\mathrm{C}_{14} \times \mathrm{X}_{9}$ | $\mathrm{C}_{15} \times \mathrm{X}_{9}$ | 0 | 0 | 0 | 0 | 0 | 0 | - |
| 31 | $+\mathrm{C}_{13} \times \mathrm{X}_{10}$ |  | $c_{15} \times{ }^{10}$ | 0 | 0 | 0 | 0 | 0 | - |
| 32 | $+\mathrm{C}_{12} \times \mathrm{X}_{11}$ |  |  | $c_{15} \times x_{11}$ | 0 | 0 | 0 | 0 | - |
| 33 | $+C_{11} \times \mathrm{X}_{12}$ |  |  |  | $c_{15} \times \mathrm{X}_{12}$ | 0 | 0 | 0 | - |
| 34 | $+\mathrm{C}_{10} \times \mathrm{X}_{13}$ |  |  |  |  | $c_{15} \times{ }_{13}$ | 0 | 0 | - |
| 35 | $+\mathrm{C}_{9} \times \mathrm{X}_{14}$ |  |  |  |  |  | $\mathrm{C}_{15} \times \mathrm{X}_{14}$ | 0 | - |
| 36 | $+\mathrm{C}_{8} \times \mathrm{x}_{15}$ |  |  |  |  |  |  | $\mathrm{C}_{15} \times \mathrm{X}_{15}$ | - |
| 37 | $+\mathrm{C}_{7} \times \mathrm{X}_{16}$ |  |  |  |  |  |  | $+C_{14} \times{ }_{16}$ | - |
| 38 | $+\mathrm{C}_{6} \times \mathrm{X}_{17}$ |  |  |  |  |  |  | $+C_{13} \times{ }^{17}$ | - |
| 39 | $+\mathrm{C}_{5} \times \mathrm{X}_{18}$ |  |  |  |  |  |  | $+\mathrm{C}_{12} \times \mathrm{X}_{18}$ | - |
| 40 | $+\mathrm{C}_{4} \times \mathrm{X}_{19}$ |  |  |  |  |  |  | $+C_{11} \times{ }^{19}$ | - |
| 41 | $+\mathrm{C}_{3} \times \mathrm{X}_{20}$ |  |  |  |  |  |  | $+C_{10} \times{ }^{20}$ | - |
| 42 | $+\mathrm{C}_{2} \times \mathrm{X}_{21}$ |  |  |  |  |  |  | $+\mathrm{C}_{9} \times \mathrm{X}_{21}$ | - |
| 43 | $+\mathrm{C}_{1} \times \mathrm{X}_{22}$ |  |  |  |  |  |  | $+\mathrm{C}_{8} \times \mathrm{X}_{22}$ | - |
| 44 | $+\mathrm{C}_{0} \times \mathrm{X}_{23}$ | $\downarrow$ |  |  |  |  |  | $+C_{7} \times{ }^{23}$ | CELL O(Y23) |
| 45 | 0 | $\mathrm{C}_{0} \times \mathrm{X}_{24}$ | $\downarrow$ |  |  |  |  | $+\mathrm{C}_{6} \times \mathrm{X}_{24}$ | CELL 1 (Y24) |
| 46 | 0 | 0 | $\mathrm{C}_{0} \times \mathrm{X}_{25}$ | 1 |  |  |  | $+C_{5} \times{ }^{25}$ | CELL 2 (Y25) |
| 47 | 0 | 0 | 0 | $\mathrm{C}_{0} \times \mathrm{X}_{26}$ | 1 |  |  | $+C_{4} \times{ }_{26}$ | CELL 3(Y26) |
| 48 | 0 | 0 | 0 | 0 | $\mathrm{C}_{0} \times \mathrm{X}_{27}$ | $\downarrow$ | $\downarrow$ | $+c_{3} \times x_{27}$ | CELL 4 (Y27) |

$\mathrm{Tp}=7+\mathrm{L}$ cycles and computes eight output samples. In pass i , the sample with indices $\mathrm{i}^{*} 8$ to $\mathrm{i}^{*} 8+(\mathrm{L}-1)$ enter the DINO-7 inputs. The coefficients $C_{0}-C_{L}-1$ enter the CINO-7 inputs, followed by seven zeros. As these zeros are entered, the result samples are output and the accumulators reset. Initial filing of the pipeline is not shown in this sequence table. Filter outputs can be put through a FIFO to even out the sample rate.

## Extended Coefficient and Data Sample Word Size

The sample and coefficient word size can be extended by utilizing several DFs in parallel to get the maximum sample rate or a single DF with resulting lower sample rates. The technique is to compute partial products of $8 \times 8$ and combine these partial products by shifting and adding to obtain the final result. The shifting and adding can be
accomplished with external adders (at full speed) or with the DF's shift-and-add mechanism contained in its output stage (at reduced speed).

## Decimation/Resampling

The HSP43881 DF provides a mechanism for decimating by factors of 2,3 , or 4 . From the DF filter cell block diagram (Figure 1), note the three D registers and two multiplexers in the coefficient path through the cell. These allow the coefficients to be delayed by 1,2 , or 3 clocks through the cell. The sequence table (Table 3) for a decimate-by-two- filter illustrates the technique (internal cell pipelining ignored for simplicity).

Detailed timing for a 30 MHz input sample rate, 15 MHz output sample rate (i.e., decimate-by-two), 16 -tap FIR filter, including pipelining, is shown in Figure 7. This filter requires only a single HSP43881 DF.


FIGURE 6. HSP43881 16-TAP 3OMHz FIR FILTER TIMING USING TWO CASCADED HSP43881s

TABLE 3. HSP43881 16-TAP DECIMATE-BY-TWO FIR FILTER SEQUENCE; $30 \mathrm{MHz} \operatorname{IN}, \mathbf{1 5 M H z}$ OUT


| CLK | CELL 0 | CELL 1 | CELL 2 | CELL 3 | CELL 4 | CELL 5 | CELL 6 | CELL 7 | SUM/CLR |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 6 | $\mathrm{C}_{15} \times \mathrm{X}_{0}$ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | - |
| 7 | $+\mathrm{C}_{14} \times \mathrm{X}_{1}$ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | - |
| 8 | $+\mathrm{C}_{13} \times \mathrm{X}_{2}$ | $\mathrm{C}_{15} \times \mathrm{X}_{2}$ | 0 | 0 | 0 | 0 | 0 | 0 | - |
| 9 | $+\mathrm{C}_{12} \times \mathrm{X}_{3}$ |  | 0 | 0 | 0 | 0 | 0 | 0 | - |
| 10 | $+\mathrm{C}_{11} \times \mathrm{X}_{4}$ |  | $\mathrm{C}_{15} \times \mathrm{X}_{4}$ | 0 | 0 | 0 | 0 | 0 | - |
| 11 | $+\mathrm{C}_{10} \times{ }^{\text {x }}$ |  |  | 0 | 0 | 0 | 0 | 0 | - |
| 12 | $+\mathrm{C}_{9} \times \mathrm{X}_{6}$ |  |  | $\mathrm{c}_{15} \times \mathrm{X}_{6}$ | 0 | 0 | 0 | 0 | - |
| 13 | $+C_{8} \times x_{7}$ |  |  |  | 0 | 0 | 0 | 0 | - |
| 14 | $+\mathrm{C}_{7} \times \mathrm{X}_{8}$ |  |  |  | $\mathrm{c}_{15} \times \mathrm{X}_{8}$ | 0 | 0 | 0 | - |
| 15 | $+\mathrm{C}_{6} \times \mathrm{X}_{9}$ |  |  |  |  | 0 | 0 | 0 | - |
| 16 | $+\mathrm{C}_{5} \times \mathrm{X}_{10}$ |  |  |  |  | $\mathrm{c}_{15} \times \mathrm{X}_{10}$ | 0 | 0 | - |
| 17 | $+\mathrm{C}_{4} \times \mathrm{X}_{11}$ |  |  |  |  |  | 0 | 0 | - |
| 18 | $+\mathrm{C}_{3} \times \mathrm{X}_{12}$ |  |  |  |  |  | $\mathrm{C}_{15} \times \mathrm{X}_{12}$ | 0 | - |
| 19 | $+\mathrm{C}_{2} \times \mathrm{X}_{13}$ |  |  |  |  |  |  | 0 | - |
| 20 | $+\mathrm{C}_{1} \times \mathrm{X}_{14}$ |  |  |  |  |  |  | $\mathrm{C}_{15} \times \mathrm{X}_{14}$ | - |
| 21 | $+\mathrm{C}_{0} \times \mathrm{X}_{15}$ |  |  |  |  |  |  | $+C_{14} \times{ }_{15}$ | CELLO(Y15) |
| 22 | $\mathrm{C}_{15} \times \mathrm{X}_{16}$ |  |  |  |  |  |  | $+\mathrm{C}_{13} \times \mathrm{X}_{16}$ | ( |
| 23 | $+\mathrm{C}_{14} \times \mathrm{X}_{17}$ |  |  |  |  |  |  | $+\mathrm{C}_{12} \times \mathrm{X}_{17}$ | CELL 1 (Y17) |
| 24 | $+\mathrm{C}_{13} \times \mathrm{X}_{18}$ |  |  |  |  |  |  | $+\mathrm{C}_{11} \times \mathrm{X}_{18}$ | - |
| 25 | $+\mathrm{C}_{12} \times \mathrm{X}_{19}$ |  |  |  |  |  |  | $+\mathrm{C}_{10} \times \mathrm{X}_{19}$ | CELL 2 (Y19) |
| 26 | $+\mathrm{C}_{11} \times \mathrm{X}_{20}$ |  |  |  |  |  |  | $+\mathrm{C}_{9} \times \mathrm{X}_{20}$ | - |
| 27 | $+\mathrm{C}_{10} \times \mathrm{X}_{21}$ |  |  |  |  |  |  | $+\mathrm{C}_{8} \times \mathrm{X}_{21}$ | CELL 3(Y21) |
| 28 | $+\mathrm{C}_{9} \times \mathrm{X}_{22}$ |  |  |  |  |  |  | $+C_{7} \times \mathrm{X}_{22}$ | - |
| 29 | $+\mathrm{C}_{8} \times \mathrm{X}_{23}$ |  |  |  |  |  |  | $+\mathrm{C}_{6} \times \mathrm{x}_{23}$ | CELL 4 (Y23) |
| 30 | $+\mathrm{C}_{7} \times \mathrm{X}_{24}$ |  |  |  |  |  |  | $+\mathrm{C}_{5} \times \mathrm{X}_{24}$ | - |
| 31 | $+\mathrm{C}_{6} \times \mathrm{X}_{25}$ |  |  |  |  |  |  | $+\mathrm{C}_{4} \times \mathrm{X}_{25}$ | CELL 5 (Y25) |
| 32 | $+\mathrm{C}_{5} \times \mathrm{X}_{26}$ |  |  |  |  |  |  | $+\mathrm{C}_{3} \times \mathrm{X}_{26}$ |  |
| 33 | $+\mathrm{C}_{4} \times \mathrm{X}_{27}$ |  |  |  |  |  |  | $+\mathrm{C}_{2} \times \mathrm{X}_{27}$ | CELL 6 (Y27) |
| 34 | $+c_{3} \times \mathrm{X}_{28}$ |  |  |  |  |  |  | $+\mathrm{C}_{1} \times \mathrm{x}_{28}$ | - |
| 35 | $+\mathrm{C}_{2} \times \mathrm{X}_{29}$ |  |  |  |  |  |  | $+C_{0} \times 2 \times 2$ | CELL 7 (Y29) |
| 36 | $+\mathrm{C}_{1} \times \mathrm{X}_{30}$ | $\downarrow$ | $\downarrow$ | $\downarrow$ | $\downarrow$ | $\downarrow$ | $\downarrow$ | $\mathrm{c}_{15} \times \mathrm{X}_{30}$ | - |
| 37 | $+c_{0} \times x_{31}$ | $+C_{14} \times{ }^{3}$ | $+\mathrm{C}_{14} \times \mathrm{X}_{31}$ | $+\mathrm{C}_{14} \times \mathrm{X}_{31}$ | $+C_{14} \times \mathrm{X}_{31}$ | $+\mathrm{C}_{14} \times \mathrm{X}_{31}$ | $+\mathrm{C}_{14} \times \mathrm{X}_{31}$ | $+\mathrm{C}_{14} \times \mathrm{X}_{31}$ | CELL 8 (Y31) |
| $\downarrow$ | $\downarrow$ |  |  |  |  |  |  |  | $\downarrow$ |



FIGURE 7. HSP43881 16-TAP DECIMATE-BY-TWO FIR FILTER TIMING; 30 MHz IN, $\mathbf{1 5 M H z}$ OUT

## Absolute Maximum Ratings




```
Storage Temperature. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . - -650
```




```
\mp@subsup{0}{jc}{c}.......................................................................................... 11.10
0ja
33.7}\mp@subsup{}{}{\circ}\textrm{C}/\textrm{W}(PLCC),34.660%/W (PGA
```



```
Junction Temperature . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 150年年 (PLCC), 1750
Lead Temperature (Soldering 10s)
300}\mp@subsup{}{}{\circ}\textrm{C
CAUTION: Stresses above those listed in the "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating
and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.
```


## Operating Conditions



```
Operating Temperature Range
00}\textrm{C}\mathrm{ to +70
```


## D.C. Electrical Specifications

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| I'COP | Power Supply Current | - | 160 | mA | $v_{C C}=\operatorname{Max}$ <br> CLK Frequency 20 MHz <br> Note 1, Note 3 |
| ${ }^{\prime} \mathrm{ccss}$ | Standby Power Supply Current | - | 500 | $\mu \mathrm{A}$ | $V_{\text {CC }}=$ Max, Note 3 |
| $!$ | Input Leakage Current | -10 | 10 | $\mu \mathrm{A}$ | $V_{C C}=$ Max, Input $=0 V$ or $V_{C C}$ |
| 10 | Output Leakage Current | -10 | 10 | $\mu \mathrm{A}$ | $V_{C C}=$ Max, Input $=0 V$ or $V_{C C}$ |
| $\mathrm{V}_{1 \mathrm{H}}$ | Logical One Input Voltage | 2.0 | - | V | $V_{C C}=$ Max |
| $V_{\text {IL }}$ | Logical Zero Input Voltage |  | 0.8 | V | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Logical One Output Voltage | 2.6 | - | V | $\mathrm{I}^{\mathrm{OH}}=-400 \mu \mathrm{~A}, \mathrm{~V}_{\mathrm{CC}}=\mathrm{Min}$ |
| $\mathrm{V}_{\text {OL }}$ | Logical Zero Output Voltage | - | 0.4 | V | $\mathrm{l}^{\mathrm{OL}}=2 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=\mathrm{Min}$ |
| $\mathrm{V}_{\text {IHC }}$ | Clock Input High | 3.0 | - | V | $\mathrm{V}_{\text {CC }}=\mathrm{Max}$ |
| $V_{\text {ILC }}$ | Clock Input Low | - | 0.8 | V | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}$ |
| $\mathrm{C}_{\text {IN }}$ | $\begin{array}{ll}\text { Input Capacitance } & \text { PLCC } \\ & \text { PGA }\end{array}$ | - | $\begin{aligned} & 10 \\ & 15 \end{aligned}$ | $\begin{aligned} & \mathrm{pF} \\ & \mathrm{pF} \end{aligned}$ | CLK Frequency 1 MHz <br> All measurements referenced |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance PLCC <br> PGA |  | $\begin{aligned} & 10 \\ & 15 \end{aligned}$ | $\begin{aligned} & \mathrm{pF} \\ & \mathrm{pF} \end{aligned}$ | $T_{A}=+25^{\circ} \mathrm{C}, \text { Note } 2$ |

NOTES:

1. Operating supply current is proportional to frequency. Typical rating is $8 \mathrm{~mA} / \mathrm{MHz}$.
2. Controlled via design or process parameters and not directly tested. Characterized upon initial design and after major process and/or design changes.
3. Output load per test load circuit and $C_{L}=40 \mathrm{pF}$.
A.C. Electrical Specifications $\quad V_{C C}=5 \mathrm{~V} \pm 5 \%, T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | -20 (20MHz) |  | -25 (25.6MHz) |  | -30 (30MHz) |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |  |
| $\mathrm{T}_{\mathrm{CP}}$ | Clock Period | 50 | - | 39 | - | 33 | - | ns |  |
| TCL | Clock Low | 20 | - | 16 | - | 13 | - | ns |  |
| ${ }^{\text {T }} \mathrm{CH}$ | Clock High | 20 | - | 16 | - | 13 | - | ns |  |
| TIS | Input Setup | 16 | - | 14 | - | 13 | - | ns |  |
| TIH | Input Hold | 0 | - | 0 | - | 0 | - | ns |  |
| TODC | CLK to Coefficient Output Delay | - | 24 | - | 20 | - | 18 | ns |  |
| ToEd | Output Enable Delay | - | 20 | - | 15 | - | 15 | ns |  |
| TODD | Output Disable Delay | - | 20 | - | 15 | - | 15 | ns | Note 1 |
| TODS | CLK to SUM <br> Output Delay | - | 27 | - | 25 | - | 21 | ns |  |
| TOR | Output Rise | - | 6 | - | 6 | - | 6 | ns | Note 1 |
| TOF | Output Fall | - | 6 | - | 6 | - | 6 | ns | Note 1 |

NOTE:

1. Controlled by design or process parameters and not directly tested. Characterized upon initial design and after major process and/or design changes.

Test Load Circuit


Switch S1 Open for ICCSE and $\mathrm{I}_{\mathrm{CCOP}}$ Tests

## Waveforms



CLOCK AC PARAMETERS


* SUMO-25, COUTO-7, TCCO are assumed not to be in high-impedance state

SUMO-25, COUTO-7, TCCO OUTPUT DELAYS


OUTPUT ENABLE, DISABLE TIMING


INPUT SETUP AND HOLD


OUTPUT RISE AND FALL TIMES

A.C. Testing: Inputs are driven at 3.0 V for Logic " 1 " and 0.0 V for Logic " 0 ". Input and output timing measurements are made at 1.5 V for both a Logic "1" and " 0 ". CLK is driven at 4.0 V and OV and measured at 2.0 V .
A.C. TESTING INPUT, OUTPUT WAVEFORM

## Features

- This Circuit is Processed in Accordance to Mil-Std883C and is Fully Conformant Under the Provisions of Paragraph 1.2.1.
- O to 25.6MHz Sample Rate
- Eight Filter Cells
- 8-Bit Coefficients and Signal Data
- Low Power CMOS Operation
- ICCSB $500 \mu$ A Maximum
- ICCOP $160 \mu \mathrm{~A}$ Maximum @ 20 MHz
- 26-Bit Accumulator Per Stage
- Filter Lengths Up to 1032 Taps
- Shift and Add Output Stage for Combining Filter Outputs
- Expandable Coefficient Size, Data Size and Filter Length
- Decimation by 2, 3 or 4


## Applications

- 1-D and 2-D FIR Filters
- Radar/Sonar
- Digital Video and Audio
- Adaptive Filters
- Echo Cancellation
- Correlation/Convolution
- Complex Multiply-Add
- Butterfly Computation
- Matrix Multiplication
- Sample Rate Converters


## Description

The HSP43881/883 is a video speed Digital Filter (DF) designed to efficiently implement vector operations such as FIR digital filters. It is comprised of eight filter cells cascaded internally and a shift and add output stage, all in a single integrated circuit. Each filter cell contains a $8 \times 8$ bit multiplier, three decimation registers and a 26-bit accumulator. The output stage contains an additional 26-bit accumulator which can add the contents of any filter cell accumulator to the output stage accumulator shifted right by 8 bits. The HSP43881/883 has a maximum sample rate of 25.6 MHz . The effective multiply accumulate (mac) rate is 204 MHz . The HSP43881/883 DF can be configured to process expanded coefficient and word sizes. Multiple DFs can be cascaded for larger filter lengths without degrading the sample rate or a single DF can process larger filter lengths at less than 25.6 MHz with multiple passes. The architecture permits processing filter lengths of over 1000 taps with the guarantee of no overflows. In practice, most filter coefficients are less than 1.0, making even larger filter lengths possible. The DF provides for 8-bit unsigned or two's complement arithmetic, independently selectable for coefficients and signal data.
Each DF filter cell contains three resampling or decimation registers which permit output sample rate reduction at rates of $1 / 2,1 / 3$ or $1 / 4$ the input sample rate. These registers also provide the capability to perform 2-D operations such as matrix multiplication and NxN spatial correlations/convolutions for image processing applications.

## Block Diagram



85 PIN GRID ARRAY (PGA)

|  | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A | $\mathrm{v}_{\text {SS }}$ | $\overline{\text { COENB }}$ | $\mathrm{v}_{\mathrm{cc}}$ | $\overline{\text { RESET }}$ | DIN7 | DIN6 | Din3 | dino | TCCI | $\mathrm{v}_{\mathrm{cc}}$ | $\mathrm{v}_{\mathrm{ss}}$ |
| B | $\mathrm{v}_{\mathrm{Cc}}$ | cout7 | tcco | ERASE | tcs | DIN1 | DIN2 | CIENB | CIN7 | CIN6 | CIN4 |
| $c$ | cout5 | cout6 | Align |  | $\overline{\text { DIENB }}$ | DIN5 | DIN4 |  |  | CIN5 | CIN3 |
| D | cout3 | cout 4 |  | HSP43881/883 tor view PINS DOWH |  |  |  |  |  | CIN2 | $\mathrm{v}_{\mathrm{cc}}$ |
| E | cour1 | $\mathrm{v}_{\text {SS }}$ | cout2 |  |  |  |  |  | CIN1 | cino | $\overline{\text { SENBL }}$ |
| F | $v_{s s}$ | couto | SHADD |  |  |  |  |  | sumo | $\mathrm{v}_{\mathrm{GC}}$ | $\mathrm{v}_{\mathrm{ss}}$ |
| G | ADR2 | дсмо | cle |  |  |  |  |  | sum1 | Sum3 | sum2 |
| H | ADR1 | ADRO |  |  |  |  |  |  |  | sum5 | Sum4 |
| J | $\mathrm{v}_{\mathrm{cc}}$ | SUM25 |  |  | SUM20 | SUM17 | SUM16 |  |  | Sum7 | $\mathrm{v}_{\text {Ss }}$ |
| K | $\overline{\text { SENBH }}$ | SUM24 | $\mathrm{v}_{\text {Ss }}$ | $\mathrm{v}_{\mathrm{cc}}$ | SUM19 | $\mathrm{v}_{\mathrm{ss}}$ | SUM15 | SUM12 | SUM10 | Sum8 | SUM6 |
| L | DCM1 | SUM23 | SUM22 | SUM21 | SUM18 | SUM14 | $\mathrm{v}_{\mathrm{Cc}}$ | SUM13 | $\mathrm{v}_{\mathrm{SS}}$ | SUM11 | Sum9 |



Note: An overbar on a signal name represents an active LOW signal.

## Absolute Maximum Ratings



## Reliability Information

| Thermal Resistance | $\theta_{\text {ja }}$ |
| :--- | :--- |$\theta_{j_{j c}}$

CAUTION: Stresses above those listed in "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.

## Operating Conditions

Operating Voltage Range . . . . . . . . . . . . . . . . . . . . . . . . +4.5 V to +5.5 V
Operating Temperature Range . . . . . . . . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

TABLE 1. HSP43881/883 D.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Devices Guaranteed and 100\% Tested

| PARAMETER | SYMBOL | CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| Logical One Input Voltage | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 2.2 | - | V |
| Logical Zero Input Voltage | $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 0.8 | V |
| Output HIGH Voltage | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}(\text { Note } 1) \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 2.6 | - | v |
| Output LOW Voltage | VoL | $\begin{aligned} & \mathrm{I}_{\mathrm{OL}}=+2.0 \mathrm{~mA} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}(\text { Note } 1) \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 0.4 | V |
| Input Leakage Current | 1 | $\begin{aligned} & V_{I N}=V_{C C} \text { or } G N D \\ & V_{C C}=5.5 V \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Output Leakage Current | 10 | $\begin{aligned} & V_{\text {OUT }}=V_{C C} \text { or GND } \\ & V_{C C}=5.5 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Clock Input High | $\mathrm{V}_{\mathrm{IHC}}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 3.0 | - | V |
| Clock Input Low | $\mathrm{V}_{\text {ILC }}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \top$ S $\leq+125^{\circ} \mathrm{C}$ | - | 0.8 | V |
| Standby Power Supply Current | ICCsB | $\begin{aligned} & \mathrm{V}_{I N}=\mathrm{V}_{\mathrm{CC}} \text { or } \mathrm{GND} \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \\ & \text { Outputs Open } \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 500 | $\mu \mathrm{A}$ |
| Operating Power Supply Current | ICCOP | $\begin{aligned} & f=20.0 \mathrm{MHz} \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V} \text { (Note 2) } \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 160.0 | mA |
| Functional Test | FT | (Note 3) | 7,8 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | - |  |

NOTES:

1. Interchanging of force and sense conditions is permitted.
2. Operating Supply Current is proportional to frequency, typical rating is $8.0 \mathrm{~mA} / \mathrm{MHz}$.
3. Tested as follows: $f=1 \mathrm{MHz}, \mathrm{V}_{\mathrm{IH}}=2.6, \mathrm{~V}_{\mathrm{IL}}=0.4, \mathrm{VOH} \geq 1.5 \mathrm{~V}$, $\mathrm{V}_{\mathrm{OL}} \leq 1.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{IHC}}=3.4 \mathrm{~V}$, and $\mathrm{V}_{\mathrm{ILC}}=0.4 \mathrm{~V}$.

## Specifications HSP43881/883

TABLE 2. HSP43881/883 A.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and 100\% Tested

| PARAMETER | SYMBOL | CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | -20 (20MHz) |  | -25 (25.6MHz) |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| Clock Period | $\mathrm{T}_{\mathrm{CP}}$ | Note 1 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125{ }^{\circ} \mathrm{C}$ | 50 | - | 39 | - | ns |
| Clock Low | $\mathrm{T}_{\mathrm{CL}}$ | Note 1 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 20 | - | 16 | - | ns |
| Clock High | TCH | Note 1 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 20 | - | 16 | - | ns |
| Input Setup | TIS | Note 1 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 20 | - | 17 | - | ns |
| Input Hold | $\mathrm{T}_{\mathrm{IH}}$ | Note 1 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns |
| CLK to Coefficient Output Delay | TODC | Note 1 | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 24 | - | 20 | ns |
| Output Enable Delay | ToED | Note 1 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 20 | - | 15 | ns |
| CLK to SUM Output Delay | TODS | Note 1 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 31 | - | 25 | ns |

NOTE: 1. A.C. Testing: $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and 5.5 V . Inputs are driven at 3.0 V for a Logic " 1 " and 0.0 V for a Logic " 0 ". Input and output timing measurements are made at 1.5 V for both a Logic " 1 " and " 0 ". CLK is driven at 4.0 V and OV and measured at 2.0 V .

TABLE 3. HSP43881/883 A.C. ELECTRICAL PERFORMANCE CHARACTERISTICS

| PARAMETER | SYMBOL | CONDITIONS | NOTES | TEMPERATURE | -20 |  | -25 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| Input Capacitance | $\mathrm{Clin}^{1}$ | $V_{C C}=\text { Open, } f=1 \mathrm{MHz}$ <br> All measurements are referenced to device GND. | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 15 | - | 15 | pF |
| Output Capacitance | COUT |  | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 15 | - | 15 | pF |
| Output Disable Delay | TODD |  | 1,2 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 20 | - | 15 | ns |
| Output Rise Time | TOR |  | 1,2 | $-55^{\circ} \mathrm{C} \leq T \mathrm{~A} \leq+125^{\circ} \mathrm{C}$ | - | 7 | - | 6 | ns |
| Output Fall Time | TOF |  | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 7 | - | 6 | ns |

NOTES:

1. The parameters listed in Table 3 are controlled via design or process parameters and are not directly tested. These parameters are characterized upon initial design and after major process and/or design changes.
2. Loading is as specified in the test load circuit, $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$.

TABLE 4. APPLICABLE SUBGROUPS

| CONFORMANCE GROUPS | METHOD | SUBGROUPS |
| :--- | :---: | :---: |
| Initial Test | $100 \% / 5004$ | - |
| Interim Test | $100 \% / 5004$ | - |
| PDA | $100 \%$ | 1 |
| Final Test | $100 \%$ | $2,3,8 \mathrm{~A}, 8 \mathrm{~B}, 10,11$ |
| Group A | - | $1,2,3,7,8 \mathrm{~A}, 8 \mathrm{~B}, 9,10,11$ |
| Groups C \&D | Samples $/ 5005$ | $1,7,9$ |

Burn-In Circuit

## HSP43881/883 PIN GRID ARRAY (PGA)



| $\begin{array}{\|c\|} \hline \text { PGA } \\ \text { PIN } \end{array}$ | PIN NAME | BURN-IN SIGNAL | $\begin{aligned} & \text { PGA } \\ & \text { PIN } \end{aligned}$ | PIN NAME | BURN-IN SIGNAL | $\left\lvert\, \begin{aligned} & \text { PGA } \\ & \text { PIN } \end{aligned}\right.$ | PIN NAME | BURN-IN SIGNAL | $\left\lvert\, \begin{aligned} & \text { PGA } \\ & \text { PIN } \end{aligned}\right.$ | $\begin{aligned} & \text { PIN } \\ & \text { NAME } \end{aligned}$ | BURN-IN SIGNAL |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A1 | $V_{S S}$ | GND | C1 | COUT5 | $\mathrm{V}_{\mathrm{CC} / 2}$ | F10 | $V_{C C}$ | $V_{C C}$ | K4 | $\mathrm{V}_{\mathrm{CC}}$ | $V_{\text {CC }}$ |
| A2 | COENB | F10 | C2 | COUT6 | $\mathrm{V}_{\mathrm{CC} / 2}$ | F11 | $V_{S S}$ | GND | K5 | SUM19 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| A3 | $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ | C3 | ALIGN | NC | G1 | ADR2 | F2 | K6 | $V_{S S}$ | GND |
| A4 | RESET | F11 | C5 | DIENB | F10 | G2 | DCMO | F5 | K7 | SUM15 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| A5 | DIN7 | F8 | C6 | DIN5 | F5 | G3 | CLK | FO | K8 | SUM12 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| A6 | DIN6 | F6 | C7 | DIN4 | F4 | G9 | SUM1 | $\mathrm{V}_{\mathrm{CC}} / 2$ | K9 | SUM10 | $\mathrm{V}_{\mathrm{CC}} / 2$ |
| A7 | DIN3 | F3 | C10 | CIN5 | F5 | G10 | SUM3 | $\mathrm{v}_{\mathrm{CC} / 2}$ | K10 | Sum8 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| A8 | DINO | FO | C11 | CIN3 | F3 | G11 | SUM2 | $\mathrm{V}_{\mathrm{CC} / 2}$ | K11 | SUM6 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| A9 | CIN8/TCCI | F8 | D1 | COUT3 | $\mathrm{V}_{\mathrm{CC} / 2}$ | H1 | ADR1 | F1 | L1 | DCM1 | F6 |
| A10 | $V_{C C}$ | $V_{C C}$ | D2 | COUT4 | $\mathrm{V}_{\mathrm{CC} / 2}$ | H2 | ADRO | FO | L2 | SUM23 | $\mathrm{v}_{\mathrm{CC} / 2}$ |
| A11 | $V_{S S}$ | GND | D10 | CIN2 | F2 | H10 | SUM5 | $\mathrm{V}_{\mathrm{CC} / 2}$ | L3 | SUM22 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| B1 | $\mathrm{V}_{\mathrm{CC}}$ | $V_{C C}$ | D11 | $\mathrm{V}_{\mathrm{CC}}$ | $V_{C C}$ | H11 | SUM4 | $\mathrm{V}_{\mathrm{CC}} / 2$ | L4 | SUM21 | $\mathrm{V}_{\mathrm{CC}} / 2$ |
| B2 | COUT7 | $\mathrm{V}_{\mathrm{CC}} / 2$ | E1 | COUT1 | $\mathrm{V}_{\mathrm{CC} / 2}$ | J1 | $\mathrm{V}_{\text {CC }}$ | $\mathrm{V}_{\mathrm{CC}}$ | L5 | SUM18 | $\mathrm{V}_{\mathrm{CC}} / 2$ |
| B3 | COUT8/TCCO | $\mathrm{V}_{\mathrm{CC} / 2}$ | E2 | $\mathrm{V}_{S S}$ | GND | J2 | SUM25 | $\mathrm{V}_{\mathrm{CC} / 2}$ | L6 | SUM14 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| B4 | ERASE | F10 | E3 | COUT2 | $\mathrm{V}_{\mathrm{CC} / 2}$ | J5 | SUM20 | $\mathrm{V}_{\mathrm{CC} / 2}$ | L7 | $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ |
| B5 | DIN8/TCS | F7 | E9 | CIN1 | F1 | J6 | SUM17 | $\mathrm{V}_{\mathrm{CC}} / 2$ | L8 | SUM13 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| B6 | DIN1 | F1 | E10 | CINO | FO | J7 | SUM16 | $\mathrm{V}_{\mathrm{CC}} / 2$ | L9 | VSS | GND |
| B7 | DIN2 | F2 | E11 | SENBL | F10 | J10 | SUM7 | $\mathrm{V}_{\mathrm{CC}} / 2$ | L10 | SUM11 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| B8 | $\overline{\text { CIENB }}$ | F10 | F1 | $\mathrm{V}_{S S}$ | GND | J11 | $V_{S S}$ | GND | L11 | Sum9 | $\mathrm{v}_{\mathrm{CC} / 2}$ |
| B9 | CIN7 | F7 | F2 | COUTO | $\mathrm{V}_{\mathrm{CC} / 2}$ | K1 | SENBH | F10 |  |  |  |
| B10 | CIN6 | F6 | F3 | SHADD | F9 | K2 | SUM24 | $\mathrm{V}_{\mathrm{CC} / 2}$ |  |  |  |
| B11 | CIN4 | F4 | F9 | SUMO | VCC/2 | K3 | $V_{S S}$ | GND |  |  |  |

NOTES:

1. $\mathrm{V}_{\mathrm{CC}} / 2(2.7 \mathrm{~V} \pm 10 \%)$ used for outputs only.
2. $0.1 \mu \mathrm{~F}(\mathrm{~min})$ capacitor between $\mathrm{V}_{\mathrm{CC}}$ and GND per device.
3. $\mathbf{4 7} \mathrm{K} \Omega( \pm 20 \%)$ resistor connected to all pins except $\mathrm{V}_{\mathrm{CC}}$ and GND .
4. $\mathrm{FO}=100 \mathrm{kHz} \pm 10 \%, \mathrm{~F} 1=\mathrm{F} 0 / 2, \mathrm{~F} 2=\mathrm{F} 1 / 2 \ldots, \mathrm{~F} 11=\mathrm{F} 10 / 2,40 \%-60 \%$ Duty Cycle.
5. Input voltage Limits: $\mathrm{V}_{\mathrm{IL}}=0.8 \mathrm{~V}$ Max, $\mathrm{V}_{\mathrm{IH}}=4.5 \mathrm{~V} \pm 10 \%$

## Die Characteristics

DIE DIMENSIONS:
$328 \times 283 \times 19 \pm 1$ mils
METALLIZATION:
Type: $\mathrm{Si}-\mathrm{Al}$ or $\mathrm{Si}-\mathrm{Al}-\mathrm{Cu}$ Thickness: 8k $\AA$

GLASSIVATION:
Type: Nitrox
Thickness: $10 \mathrm{k} \AA$

DIE ATTACH:
Material: Si-Au Eutectic Alloy or Silver-Glass
WORST CASE CURRENT DENSITY: $1.2 \times 10^{5} \mathrm{~A} / \mathrm{cm}^{2}$

Metallization Mask Layout
HSP43881/883


## Features

- Eight Filter Cells
- 0 to 30 MHz Sample Rate
- 9-Bit Coefficients and Signal Data
- 26-Bit Accumulator per Stage
- Filter Lengths Over 1000 Taps
- Shift-and-Add Output Stage for Combining Filter Outputs
- Expandable Coefficient Size, Data Size and Filter Length
- Decimation by 2, 3 or 4
- CMOS Power Dissipation Characteristics


## Applications

- 1-D and 2-D FIR Filters
- Radar/Sonar
- Digital Video and Audio
- Adaptive Filters
- Echo Cancellation
- Correlation/Convolution
- Complex Multiply-Add
- Butterfly Computation
- Matrix Multiplication
- Sample Rate Converters


## Description

The HSP43891 is a video-speed Digital Filter (DF) designed to efficiently implement vector operations such as FIR digital filters. It is comprised of eight filter cells cascaded internally and a shift and add output stage, all in a single integrated circuit. Each filter cell contains a $9 \times 9$ two's complement multiplier, three decimation registers and a 26-bit accumulator. The output stage contains an additional 26-bit accumulator which can add the contents of any filter cell accumulator to the output stage accumulator shifted right by 8 bits. The HSP 43891 has a maximum sample rate of 30 MHz . The effective multiply-accumulate (mac) rate is 240 MHz . The HSP43891 DF can be configured to process expanded coefficient and word sizes. Multiple DFs can be cascaded for larger filter lengths without degrading the sample rate or a single DF can process larger filter lengths at less than 30 MHz with multiple passes. The architecture permits processing filter lengths of over 1000 taps with the guarantee of no overflows. In practice, most filter coefficients are less than 1.0, making even larger filter lengths possible. The DF provides for 8-bit unsigned or 9 -bit two's complement arithmetic, independently selectable for coefficients and signal data.

Each DF filter cell contains three re-sampling or decimation registers which permit output sample rate reduction at rates of $1 / 2,1 / 3$ or $1 / 4$ the input sample rate. These registers also provide the capability to perform 2-D operations such as matrix multiplication and NxN spatial correlations/ convolutions for image processing applications.

## Block Diagram



## Pinouts



84 PIN PLASTIC LEADED CHIP CARRIER (PLCC)


## Pin Description

| SYMBOL | PIN NUMBER | TYPE | NAME AND FUNCTION |
| :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ | $\begin{gathered} \mathrm{B} 1, \mathrm{~J} 1, \mathrm{~A} 3 \\ \mathrm{~K} 4, \mathrm{~L} 7, \mathrm{~A} 10 \\ \mathrm{~F} 10, \mathrm{D} 11 \end{gathered}$ |  | +5 power supply input |
| $\mathrm{V}_{\text {SS }}$ | A1, F1, E2, K3, K6, L9, A11, E11, H11 |  | Power supply ground input. |
| CLK | G3 | 1 | The CLK input provides the DF system sample clock. The maximum clock frequency is 30 MHz . |
| DINO-8 | $\begin{aligned} & A 5-8, \\ & B 5-7 \\ & \text { C6, C7 } \end{aligned}$ | I | These nine inputs are the data sample input bus. Nine-bit data samples are synchronously loaded through these pins to the $X$ register of each filter cell of the DF simultaneously. The $\overline{\text { DIENB }}$ signal enables loading, which is synchronous on the rising edge of the clock signal. <br> The data samples can be either 9-bit two's complement or 8-bit unsigned values. For 9-bit two's complement values, DIN8 is the sign bit. For 8-bit unsigned values, DIN8 must be held at logical zero. |
| $\overline{\text { DIENB }}$ | C5 | 1 | A low on this input enables the data sample input bus (DINO-8) to all the filter cells. A rising edge of the CLK signal occurring while DIENB is low will load the $X$ register of every filter cell with the 9-bit value present on DINO-8. A high on this input forces all the bits of the data sample input bus to zero; a rising CLK edge when DIENB is high will load the $X$ register of every filter cell with all zeros. This signal is latched inside the device, delaying its effect by one clock internal to the device. Therefore it must be low during the clock cycle immediately preceding presentation of the desired data on the DINO-8 inputs. Detailed operation is shown in later timing diagrams. |
| CINO-8 | $\begin{gathered} \text { A9, B9-11, } \\ \text { C10, C11, } \\ \text { D10, E9, } \\ \text { E10 } \end{gathered}$ | 1 | These nine inputs are used to input the 9-bit coefficients. The coefficients are synchronously loaded into the C register of filter CELLO if a rising edge of CLK occurs while CIENB is low. The CIENB signal is delayed by one clock as discussed below. <br> The coefficients can be either 9-bit two's complement or 8-bit unsigned values. For 9-bit two's complement values, CIN8 is the sign bit. For 8-bit unsigned values, CIN8 must be held at logical zero. |
| ALIGN PIN | C3 |  | Used for aligning chip on socket or printed circuit board. This pin must be left as a no connect in circuit. |
| $\overline{\text { CIENB }}$ | B8 | I | A low on this input enables the $C$ register of every filter cell and the $D$ (decimation) registers of every filter cell according to the state of the DCMO-1 inputs. A rising edge of the CLK signal occurring while $\overline{C I E N B}$ is low will load the $C$ register and appropriate $D$ registers with the coefficient data present at their inputs. This provides the mechanism for shifting coefficients from cell to cell through the device. A high on this input freezes the contents of the $C$ register and the $D$ registers, ignoring the CLK signal. This signal is latched and delayed by one clock internal to the DF. Therefore it must be low during the clock cycle immediately preceding presentation of the desired coefficient on the CINO-8 inputs. Detailed operation is shown in later timing diagrams. |
| COUTO-8 | $\begin{aligned} & \mathrm{B} 2, \mathrm{~B} 3, \mathrm{C} 1 \text {, } \\ & \mathrm{D} 1, \mathrm{E} 1, \mathrm{C} 2, \\ & \mathrm{D} 2, \mathrm{~F} 2, \mathrm{E} 3 \end{aligned}$ | 0 | These nine three-state outputs are used to output the 9-bit coefficients from filter CELL7. These outputs are enabled by the COENB signal low. These outputs may be tied to the CINO-8 inputs of the same DF to recirculate to coefficients, or they may be tied to the CINO-8 inputs of another DF to cascade DFs for longer filter lengths. |
| $\overline{\text { COENB }}$ | A2 | 1 | A low on the COENB input enables the COUTO-8 outputs. A high on this input places all these outputs in their high impedance state. |
| DCMO-1 | L1, G2 | I | These two inputs determine the use of the internal decimation registers as follows: |
|  |  |  | DCM1 DCMO DECIMATION FUNCTION |
|  |  |  | 0 0 Decimation registers not used |
|  |  |  | 0 1 One decimation register is used |
|  |  |  | 1 0 O |
|  |  |  | 1 1 Three decimation registers are used |

## Pin Description (Continued)

$\left.\begin{array}{|l|c|c|l|}\hline \text { SYMBOL } & \begin{array}{c}\text { PIN } \\ \text { NUMBER }\end{array} & \text { TYPE } & \\ \hline \begin{array}{l}\text { DCMO-1 } \\ \text { (Cont.) }\end{array} & \text { L1, G2 } & \text { I } & \begin{array}{l}\text { NAME AND FUNCTION }\end{array} \\ \hline \text { The coefficients pass from cell to cell at a rate determined by the number of decimation } \\ \text { registers used. When no decimation registers are used, coefficients move from cell to cell } \\ \text { on each clock. When one decimation register is used, coefficients move from cell to cell on } \\ \text { every other clock, etc. These signals are latched and delayed by one clock internal to the } \\ \text { device. }\end{array}\right]$

## Functional Description

The Digital Filter Processor (DF) is composed of eight filter cells cascaded together and an output stage for combining or selecting filter cell outputs (See Block Diagram). Each filter cell contains a multiplier-accumulator and several registers (Figure 1). Each 9-bit coefficient is multiplied by a 9 -bit data sample, with the result added to the 26 -bit accumulator contents. The coefficient output of each cell is cascaded to the coefficient input of the next cell to its right.

## DF Filter Cell

A 9-bit coefficient (CINO-8) enters each cell through the C register on the left and exits the cell on the right as signals COUTO-8. With no decimation, the coefficient moves directly from the $C$ register to the output, and is valid on the clock following its entrance. When decimation is selected the coefficient exit is delayed by 1,2 or 3 clocks by passing through one or more decimation registers (D1, D2 or D3).
The combination of $D$ registers through which the coefficient passes is determined by the state of DCMO and DCM1. The output signals (COUTO-8) are connected to the CINO-8 inputs of the next cell to its right. The $\overline{\mathrm{COENB}}$ input signal enables the COUTO-8 outputs of the right most cell to the COUTO-8 pins of the device.
The $C$ and $D$ registers are enabled for loading by $\overline{C I E N B}$. Loading is synchronous with CLK when CIENB is low. Note that CIENB is latched internally. It enables the register for loading after the next CLK following the onset of CIENB low. Actual loading occurs on the second CLK following the onset of $\overline{\text { CIENB }}$ low. Therefore $\overline{\text { CIENB }}$ must be low during the clock cycle immediately preceding presentation of the coefficient on the CINO-8 inputs. In most basic FIR operations, $\overline{\mathrm{CI} E N B}$ will be low throughout the process, so this latching and delay sequence is only important during the initialization phase. When $\overline{\mathrm{CIENB}}$ is high, the coefficients are frozen.
These registers are cleared synchronously under control of $\overline{R E S E T}$, which is latched and delayed exactly like CIENB.
The output of the $C$ register ( $\mathrm{CO}-8$ ) is one input to $9 \times 9$ multiplier.
The other input to the $9 \times 9$ multiplier comes from the output of the X register. This register is loaded with a data sample from the device input signals DINO-8 discussed above. The $X$ register is enabled for loading by DIENB. Loading is synchronous with CLK when $\overline{\text { DIENB }}$ is low. Note that $\overline{\text { DIENB }}$ is latched internally. It enables the register for loading after the next CLK following the onset of DIENB low. Actual loading occurs on the second CLK following the onset of DIENB low; therefore, $\overline{\text { DIENB }}$ must be low during the clock cycle immediately preceding presentation of the data sample on the DINO-8 inputs. In most basic FIR operations, $\overline{\text { DIENB }}$ will be low throughout the process, so this latching and delay sequence is only important during the initialization phase. When DIENB is high, the $X$ register is loaded with all zeros.
The multiplier is pipelined and is modeled as a multiplier core followed by two pipeline registers, MREGO and MREG1 (Figure 1). The multiplier output is sign extended and input as one operand of the 26-bit adder. The other adder operand is the output of the 26-bit accumulator. The
adder output is loaded synchronously into both the accumulator and the TREG.
The TREG loading is disabled by the cell select signal, CELLn, where $n$ is the cell number. The cell select is decoded from the ADRO-2 signals to generate the TREG load enable. The cell select is inverted and applied as the load enable to the TREG. Operation is such that the TREG is loaded whenever the cell is not selected. Therefore, TREG is loaded every clock except the clock following cell selection. The purpose of the TREG is to hold the result of a sum-ofproducts calculation during the clock when the accumulator is cleared to prepare for the next sum-of-products calculation. This allows continuous accumulation without wasting clocks.
The accumulator is loaded with the adder output every clock unless it is cleared. It is cleared synchronously in two ways. When RESET and ERASE are both low, the accumulator is cleared along with all other registers on the device. Since ERASE and RESET are latched and delayed one clock internally, clearing occurs on the second CLK following the onset of both ERASE and RESET low.
The second accumulator clearing mechanism clears a single accumulator in a selected cell. The cell select signal, CELLn, decoded from ADRO-2 and the ERASE signal enable clearing of the accumulator on the next CLK.
The ERASE and $\overline{R E S E T}$ signals clear the DF internal registers and states as follows:

| ERASE | $\overline{\text { RESET }}$ | CLEARING EFFECT |
| :---: | :---: | :--- |
| 1 | 1 | No clearing occurs, internal state <br> remains same. |
| 1 | 0 | $\overline{\text { RESET only active, all registers except }}$ <br> accumulators are cleared, including <br> the internal pipeline registers. |
| 0 | 1 | $\overline{\text { ERASE }}$ only active, the accumulator <br> whose address is given by the ADRO-2 <br> inputs is cleared. |
| 0 | 0 | Both $\overline{\text { RESET }}$ and $\overline{\text { ERASE }}$ active, all <br> accumulators as well as all other <br> registers are cleared. |

## The DF Output Stage

The output stage consists of a 26 -bit adder, 26-bit register, feedback multiplexer from the register to the adder, an output multiplexer and a 26-bit three-state driver stage (Figure 2).
The 26-bit output adder can add any filter cell accumulator result to the 18 most significant bits of the output buffer. This result is stored back in the output buffer. This operation takes place in one clock period. The eight LSBs of the output buffer are lost. The filter cell accumulator is selected by the ADRO-2 inputs.
The 18 MSBs of the output buffer actually pass through the zero mux on their way to the output adder input. The zero mux is controlled by the SHADD input signal and selects either the output buffer 18 MSBs or all zeros for the adder input. A low on the SHADD input selects zero. A high on the SHADD input selects the output buffer MSBs, thus activating the shift-and-add operation. The SHADD signal is latched and delayed by one clock internally.


FIGURE 1. HSP43891 DF FILTER CELL


FIGURE 2. HSP43891 DFP OUTPUT STAGE

The 26 least significant bits (LSBs) from either a cell accumulator or the output buffer are output on the SUMO-25 bus. The output mux determines whether the cell accumulator selected by ADRO-2 or the output buffer is output to the bus. This mux is controlled by the SHADD input signal. Control is based on the state of the SHADD during two successive clocks; in other words, the output mux selection contains memory. If SHADD is low during a clock cycle and was low during the previous clock, the output mux selects the contents of the filter cell accumulator addressed by ADRO-2. Otherwise the output mux selects the contents of the output buffer.

If the ADRO-2 lines remain at the same address for more than one clock, the output at SUMO-25 will not change to reflect any subsequent accumulator updates in the addressed cell. Only the result available during the first clock when ADRO-2 selects the cell will be output.

This does not hinder normal. FIR operation since the ADRO-2 lines are changed sequentially. This feature facilitates the interface with slow memories where the output is required to be fixed for more than one clock.

The SUMO-25 output bus is controlled by the SENBH and $\overline{\text { SENBL }}$ signals. A low on SENBL enables bits SUMO-15. A low on SENBH enables bits SUM16-25. Thus all 26 bits can be output simultaneously if the external system has a 26-bit or larger bus. If the external system bus is only 16 bits, the bits can be enabled in two groups of 16 and 10 bits (sign extended).

## DF Arithmetic

Both data samples and coefficients can be represented as either 8-bit unsigned or 9-bit two's complement numbers. The 9x9 bit multiplier in each cell expects 9 -bit two's complement operands. The binary format of 8-bit two's complement is shown below. Note that if the most significant or sign bit is held at logical zero, the 9-bit two's complement multiplier can multiply 8-bit unsigned operands. Only the upper (positive) half of the two's complement binary range is used.

The multiplier output is 18 bits and the accumulator is 26 bits. The accumulator width determines the maximum possible number of terms in the sum of products without overflow. The maximum number of terms depends also on the number system and the distribution of the coefficient and data values. Then maximum numbers of terms in the sum products are:

| NUMBER SYSTEM | MAX \# OF TERMS |  |
| :--- | :---: | :---: |
|  | 8-BIT | 9-BIT |
| Two unsigned vectors | 1032 | N/A |
| Two two's complement vectors: |  |  |
| - Two positive vectors | 2080 | 1032 |
| - Negative vectors | 2047 | 1024 |
| - One positive and one negative vector | 2064 | 1028 |
| One unsigned 8 bit vector and one two's |  |  |
| complement vector: |  |  |
| - Postive two's complement vector | 1036 | 1032 |
| - Negative two's complement vector | 1028 | 1028 |

For practical FIR filters, the coefficients are never all near maximum value, so even larger vectors are possible in practice.

## Basic FIR Operation

A simple, 30 MHz 8 -tap filter example serves to illustrate more clearly the operation of the DF. The sequence table (Table 1) shows the results of the multiply accumulate in each cell after each clock. The coefficient sequence, Cn , enters the DF on the left and moves from left to right through the cells. The data sample sequence, Xn , enters the DF from
the top, with each cell receiving the same sample simultaneously. Each cell accumulates the sum of products for one output point. Eight sums of products are calculated simultaneously, but staggered in time so that a new output is available every system clock.

TABLE 1. HSP43891 $30 \mathrm{MHz}, 8$-TAP FIR FILTER SEQUENCE


| CLK | CELL 0 | CELL 1 | CELL 2 | CELL 3 | CELL 4 | CELL 5 | CELL 6 | CELL 7 | SUM/CLR |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | $\mathrm{C}_{7} \times \mathrm{X}_{0}$ | 0 | 0 | 0 | - | - | - | - | - |
| 1 | $+\mathrm{C}_{6} \times \mathrm{X}_{1}$ | $\mathrm{C}_{7} \times \mathrm{X}_{1}$ | 0 | 0 | - | - | - | - | - |
| 2 | $+C_{5} \times \mathrm{X}_{2}$ | $+C_{6} \times{ }_{2}$ | $\mathrm{C}_{7} \times \mathrm{X}_{2}$ | 0 | - | - | - | - | - |
| 3 | $+\mathrm{C}_{4} \times \mathrm{X}_{3}$ | $+\mathrm{C}_{5} \times \mathrm{X}_{3}$ | $+C_{6} \times{ }^{3}$ | $\mathrm{C}_{7} \times \mathrm{X}_{3}$ | - | - | - | - | - |
| 4 | $+\mathrm{C}_{3} \times \mathrm{X}_{4}$ | $+\mathrm{C}_{4} \times \mathrm{X}_{4}$ | $+\mathrm{C}_{5} \times \mathrm{X}_{4}$ | $+C_{6} \times \mathrm{X}_{4}$ | $\mathrm{C}_{7} \times \mathrm{X}_{4}$ | - | - | - | - |
| 5 | $+C_{2} \times X_{5}$ | $+C_{3} \times{ }_{5}$ | $+C_{4} \times{ }^{4}$ | $+C_{5} \times X_{5}$ | $+C_{6} \times \times_{5}$ | $\mathrm{C}_{7} \times \mathrm{X}_{5}$ | - | - | - |
| 6 | $+C_{1} \times x_{6}$ | $+\mathrm{C}_{2} \times \mathrm{X}_{6}$ | $+c_{3} \times x_{6}$ | $+\mathrm{C}_{4} \times \mathrm{X}_{6}$ | $+\mathrm{C}_{5} \times \mathrm{X}_{6}$ | $+\mathrm{C}_{6} \times \mathrm{X}_{6}$. | $\mathrm{C}_{7} \times \mathrm{X}_{6}$ | - | - |
| 7 | $+C_{0} \times x_{7}$ | $+C_{1} \times{ }^{1}$ | $+C_{2} \times{ }^{1}$ | $+c_{3} \times{ }^{1}$ | $+C_{4} \times{ }^{1}$ | $+C_{5} \times \mathrm{X}_{7}$ | $+\mathrm{C}_{6} \times \mathrm{X}_{7}$ | $\mathrm{C}_{7} \times \mathrm{X}_{7}$ | Cell O (Y7) |
| 8 | $\mathrm{C}_{7} \times \mathrm{X}_{8}$ | $+C_{0} \times{ }_{8}$ | $+C_{1} \times{ }^{1}$ | $+\mathrm{C}_{2} \times \mathrm{X}_{8}$ | $+c_{3} \times{ }_{8}$ | $+C_{4} \times{ }^{1}$ | $+C_{5} \times \mathrm{X}_{8}$ | $+C_{6} \times x_{8}$ | Cell 1 (Y8) |
| 9 | $+\mathrm{C}_{6} \times \mathrm{X}_{9}$ | $\mathrm{C}_{7} \times \mathrm{X}_{9}$ | $+\mathrm{C}_{0} \times \mathrm{X}_{9}$ | $+\mathrm{C}_{1} \times \mathrm{X}_{9}$ | $+\mathrm{C}_{2} \times \mathrm{X}_{9}$ | $+C_{3} \times{ }^{\prime}{ }_{9}$ | $+C_{4} \times{ }^{\prime}$ | $+C_{5} \times{ }_{9}$ | Cell 2 (Y9) |
| 10 | $+C_{5} \times{ }_{10}$ | $+C_{6} \times{ }_{10}$ | $\mathrm{C}_{7} \times \mathrm{X}_{10}$ | $+C_{0} \times{ }_{10}$ | $+C_{1} \times{ }_{10}$ | $+\mathrm{C}_{2} \times \mathrm{X}_{10}$ | $+C_{3} \times{ }_{10}$ | $+C_{4} \times{ }_{10}$ | Cell 3 (Y10) |
| 11 | $+C_{4} \times{ }_{11}$ | $+C_{5} \times{ }_{11}$ | $+C_{6} \times \mathrm{X}_{11}$ | $\mathrm{C}_{7} \times \mathrm{X}_{11}$ | $+C_{0} \times{ }_{11}$ | $+c_{1} \times x_{11}$ | $+C_{2} \times{ }_{11}$ | $+C_{3} \times \mathrm{X}_{11}$ | Cell 4 (Y11) |
| 12 | $+C_{3} \times X_{12}$ | $+\mathrm{C}_{4} \times \mathrm{X}_{12}$ | $+\mathrm{C}_{5} \times \mathrm{X}_{12}$ | $+C_{6} \times{ }_{12}$ | $\mathrm{C}_{7} \times \mathrm{X}_{12}$ | $+C_{0} \times{ }_{12}$ | $+C_{1} \times{ }_{12}$ | $+\mathrm{C}_{2} \times \mathrm{X}_{12}$ | Cell 5 (Y12) |
| 13 | $+\mathrm{C}_{2} \times \mathrm{X}_{13}$ | $+\mathrm{C}_{3} \times \mathrm{X}_{13}$ | $+\mathrm{C}_{4} \times \mathrm{X}_{13}$ | $+\mathrm{C}_{5} \times \mathrm{X}_{13}$ | $+C_{6} \times{ }_{13}$ | $\mathrm{C}_{7} \times \mathrm{X}_{13}$ | $+\mathrm{C}_{0} \times \mathrm{X}_{13}$ | $+C_{1} \times{ }_{13}$ | Cell 6 (Y13) |
| 14 | $+\mathrm{C}_{1} \times \mathrm{X}_{14}$ | $+\mathrm{C}_{2} \times \mathrm{X}_{14}$ | $+C_{3} \times{ }_{14}$ | $+\mathrm{C}_{4} \times \mathrm{X}_{14}$ | $+\mathrm{C}_{5} \times \mathrm{X}_{14}$ | $+C_{6} \times{ }_{14}$ | $+C_{7} \times{ }_{14}$ | $+C_{0} \times{ }_{14}$ | Cell 7 (Y14) |
| 15 | $+\mathrm{C}_{0} \times \mathrm{X}_{15}$ | $+\mathrm{C}_{1} \times \mathrm{X}_{15}$ | $+\mathrm{C}_{2} \times \mathrm{X}_{15}$ | $+\mathrm{C}_{3} \times \mathrm{X}_{15}$ | $+\mathrm{C}_{4} \times \mathrm{X}_{15}$ | $+\mathrm{C}_{5} \times \mathrm{X}_{15}$ | $+\mathrm{C}_{6} \times \mathrm{X}_{15}$ | $\mathrm{C}_{7} \times \mathrm{X}_{15}$ | Cell O (Y15) |



FIGURE 3. HSP43891 30 MHz , 8-TAP FIR FILTER APPLICATION SCHEMATIC

Detailed operation of the DF to perform a basic 8-tap, 9-bit coefficient, 9-bit data, 30 MHz FIR filter is best understood by observing the schematic (Figure 3) and timing diagram (Figure 4). The internal pipeline length of the DF is four (4) clock cycles, corresponding to the register levels CREG (or XREG), MREGO, MREG1, and TREG (Figures 1 and 2). Therefore the delay from presentation of data and coefficients at the DINO-8 and CINO-8 inputs to a sum appearing at the SUMO-25 output is: $k+T d$, where $k=$ filter length and $T d=4$, the internal pipeline delay of the DF.

After the pipeline has filled, a new output sample is available every clock. The delay to last sample output from last sample input is Td.
The output sums, Yn , shown in the timing diagram are derived from the sum-of-products equation:
$Y(n)=C(0) \times X(n)+C(1) \times X(n-1)+C(2) \times X(n-2)+C(3)$ $x X(n-3)+C(4) \times X(n-4)+C(5) \times X(n-5)+C(6) \times X(n-6)$
$+C(7) \times X(n-7)$


DIENB
CINO-8 $\quad\left|c_{7}\right| c_{6}\left|c_{5}\right| c_{4}\left|c_{3}\right| c_{2}\left|c_{1}\right| c_{0}\left|c_{7}\right| c_{6}\left|c_{5}\right| c_{4}\left|c_{3}\right| c_{2}\left|c_{1}\right| c_{0}\left|c_{7}\right| c_{6}\left|c_{5}\right|$


$$
Y_{N}=\sum_{K=0}^{7} C_{K} \times X_{N-K}
$$

FIGURE 4. HSP43891 $30 \mathrm{MHz}, 8$-TAP FIR FILTER TIMING


FIGURE 5. HSP43891 30 MHz , 16-TAP FIR FILTER CASCADE APPLICATION SCHEMATIC

## Extended FIR Filter Length

Filter lengths greater that eight taps can be created by either cascading together multiple DF devices or "reusing" a single device. Using multiple devices, an FIR filter of over 1000 taps can be constructed to operate at a 30 MHz sample rate. Using a single device clocked at 30 MHz , an FIR filter of over 500 taps can be constructed to operate at less than a 30 MHz sample rate. Combinations of these two techniques are also possible.

## Cascade Configuration

To design a filter length L>8, L/8 DFs are cascaded by connecting the COUTO-8 outputs of the (i)th DF to the CINO-8 inputs of the (i+1)th DF. The DINO-8 inputs and SUMO-25 outputs of all the DFs are also tied together. A specific example of two cascaded DFs illustrates the technique (Figure 5). Timing (Figure 6) is similar to the simple 8-tap FIR, except the ERASE and SENBL/ $\overline{\text { SENBH }}$ signals must be enabled independently for the two DFs in order to clear the correct accumulators and enable the SUMO-25 output signals at the proper times.

DATA SEQUENCE
INPUT $x_{30} \ldots x_{9}, x_{8}, x_{22} \ldots x_{1}, x_{0}$
COEFFICIENT SEQUENCE
INPUT
$\mathrm{C}_{0} \ldots \mathrm{C}_{14}, \mathrm{C}_{15}, 0 \ldots 0, \mathrm{C}_{0} \ldots \mathrm{C}_{14}, \mathrm{C}_{15}$


TABLE 2.

| CLK | CELL 0 | CELL 1 | CELL 2 | CELL 3 | CELL 4 | CELL 5 | CELL 6 | CELL 7 | SUM/CLR |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 6 | $\mathrm{C}_{15} \times \mathrm{X}_{0}$ | 0 | 0 | 0 | - | - | - | - | - |
| 7 | $+\mathrm{C}_{14} \times \mathrm{X}_{1}$ | $\mathrm{C}_{15} \times \mathrm{X}_{1}$ | 0 | 0 | - | - | - | - | - |
| 8 | $+C_{13} \times x_{2}$ |  | $\mathrm{c}_{15} \times \mathrm{X}_{2}$ | 0 | - | - | - | - | - |
| 9 | $+\mathrm{c}_{12} \times \mathrm{X}_{3}$ |  |  | $\mathrm{C}_{15} \times \mathrm{X}_{3}$ | - | - | - | - | - |
| 10 | $+c_{11} \times x_{4}$ |  |  | $+\mathrm{C}_{14} \times \mathrm{X}_{4}$ | $\mathrm{C}_{15} \times \mathrm{X}_{4}$ | - | - | - | - |
| 11 | $+\mathrm{C}_{10} \times \mathrm{X}_{5}$ |  |  | $+C_{13} \times x_{5}$ |  | $c_{15} \times{ }_{5}$ | - | - | - |
| 12 | $+\mathrm{C}_{9} \times \mathrm{X}_{6}$ |  |  | $+\mathrm{C}_{12} \times \mathrm{x}_{6}$ |  |  | $c_{15} \times \mathrm{X}_{6}$ | - | - |
| 13 | $+c_{8} \times x_{7}$ |  |  | $+\mathrm{C}_{11} \times \mathrm{x}_{7}$ |  |  |  | $\mathrm{C}_{15} \times \mathrm{X}_{7}$ | - |
| 14 | $+C_{7} \times x_{8}$ |  |  | $+\mathrm{C}_{10} \times \mathrm{X}_{8}$ |  |  |  | $+C_{14} \times \mathrm{X}_{8}$ | - |
| 15 | $+C_{6} \times{ }_{9}$ |  |  | $+\mathrm{C}_{9} \times \mathrm{X}_{9}$ |  |  |  | $+C_{13} \times \mathrm{X}_{9}$ | - |
| 16 | $+\mathrm{C}_{5} \times \mathrm{X}_{10}$ |  |  | $+c_{8} \times \mathrm{X}_{10}$ |  |  |  | $+\mathrm{C}_{12} \times \mathrm{X}_{10}$ | - |
| 17 | $+C_{4} \times \mathrm{X}_{11}$ |  |  | $+C_{7} \times x_{11}$ |  |  |  | $+\mathrm{C}_{11} \times \mathrm{X}_{11}$ | - |
| 18 | $+c_{3} \times \mathrm{X}_{12}$ |  |  | $+\mathrm{C}_{6} \times \mathrm{X}_{12}$ |  |  |  | $+\mathrm{C}_{10} \times \mathrm{X}_{12}$ | - |
| 19 | $+C_{2} \times{ }_{13}$ |  |  | $+C_{5} \times{ }_{13}$ |  |  |  | $+\mathrm{C}_{9} \times \mathrm{X}_{13}$ | - |
| 20 | $+C_{1} \times{ }^{14}$ |  |  | $+C_{4} \times{ }^{14}$ |  |  |  | $+\mathrm{C}_{8} \times \mathrm{X}_{14}$ | - |
| 21 | $+\mathrm{C}_{0} \times \mathrm{X}_{15}$ | $\downarrow$ |  | $+c_{3} \times X_{15}$ |  |  |  | $+C_{7} \times{ }^{15}$ | Cell O(Y15) |
| 22 | 0 | $\mathrm{C}_{0} \times \mathrm{X}_{16}$ | $\downarrow$ | $+\mathrm{C}_{2} \times \mathrm{X}_{16}$ |  |  |  | $+C_{6} \times X_{16}$ | Cell 1(Y16) |
| 23 | 0 | 0 | $\mathrm{C}_{0} \times \mathrm{X}_{17}$ | $+c_{1} \times{ }_{17}$ |  |  |  | $+\mathrm{C}_{5} \times \mathrm{X}_{17}$ | Cell 2(Y17) |
| 24 | 0 | 0 | 0 | $+\mathrm{C}_{0} \times \mathrm{X}_{18}$ | $\downarrow$ |  |  | $+\mathrm{C}_{4} \times \mathrm{X}_{18}$ | Cell 3(Y18) |
| 25 | 0 | 0 | 0 | 0 | $\mathrm{C}_{0} \times \mathrm{X}_{19}$ | $\downarrow$ |  | $+C_{3} \times \mathrm{X}_{19}$ | Cell 4(Y19) |
| 26 | 0 | 0 | 0 | 0 | 0 | $c_{0} \times X_{20}$ | $\downarrow$ | $+C_{2} \times \mathrm{X}_{20}$ | Cell 5(Y20) |
| 27 | 0 | 0 | 0 | 0 | 0 | 0 | $\mathrm{c}_{0} \times \mathrm{X}_{21}$ | $+C_{1} \times{ }^{21}$ | Cell 6(Y21) |
| 28 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | $+c_{0} \times{ }_{22}$ | Cell 7(Y22) |
| 29 | $\mathrm{C}_{15} \times{ }^{\text {8 }}$ | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |
| 30 31 | $+C_{14} \times X_{9}$ $+c_{13} \times x_{10}$ | $+\mathrm{C}_{15} \times \mathrm{X}_{9}$ |  |  | 0 |  |  | 0 | - |
| 31 32 | $+C_{13} \times \times_{10}$ $+C_{12} \times \times_{11}$ | $1$ | $+\mathrm{C}_{15} \times \mathrm{X}_{10}$ | 0 $+c_{15} \times \mathrm{X}_{11}$ | 0 | 0 0 | 0 | 0 | - |
| 32 33 | $+C_{12} \times{ }^{1} \times 11$ $+C_{11} \times \times_{12}$ |  |  | $+\mathrm{C}_{15} \times \mathrm{X}_{11}$ | ${ }_{+}{ }^{0}{ }_{15} \times \mathrm{X}_{12}$ | 0 0 | 0 0 | 0 | - |
| 34 | $+C_{10} \times{ }^{13}$ |  |  |  |  | $+c_{15} \times \mathrm{X}_{12}$ | 0 | 0 | - |
| 35 | $+\mathrm{C}_{9} \times \mathrm{X}_{14}$ |  |  |  |  | 1 | $+C_{15} \times \mathrm{X}_{14}$ | 0 | - |
| 36 | $+C_{8} \times{ }^{15}$ |  |  |  |  |  |  | $\mathrm{C}_{15} \times \mathrm{X}_{15}$ | - |
| 37 38 | $+C_{7} \times \times_{16}$ $+C_{6} \times \times_{17}$ |  |  |  |  |  |  | + $C_{14} \times{ }^{1}{ }^{16}$ | - |
| 38 39 | $+\mathrm{C}_{6} \times \mathrm{X}_{17}$ $+\mathrm{C}_{5} \times \mathrm{X}_{18}$ |  |  |  |  |  |  | + $\mathrm{C}_{13} \times \mathrm{X}_{17}$ | - |
| 40 | + ${ }^{+} \times{ }_{4} \times \times_{19}$ |  |  |  |  |  |  | + ${ }_{+}^{+} \mathrm{C}_{12} \times \times \times 18$ | - |
| 41 | $+C_{3} \times x_{20}$ |  |  |  |  |  |  | $+C_{10} \times{ }^{20}$ | - |
| 42 | $+\mathrm{C}_{2} \times \mathrm{X}_{21}$ |  |  |  |  |  |  | $+\mathrm{C}_{9} \times \mathrm{X}_{21}$ | - |
| 43 | $+\mathrm{C}_{1} \times \mathrm{x}_{22}$ |  |  |  |  |  |  | $+C_{8} \times{ }_{22}$ |  |
| 44 45 | $\xrightarrow{+} \mathrm{C}_{0} \times \mathrm{X}_{23}$ |  | $\downarrow$ |  |  |  |  | $\begin{aligned} & +C_{7} \times x_{23} \\ & +C_{5} \times x_{0} \end{aligned}$ | Cell O(Y23) <br> Cell 1 (Y24) |
| 45 | 0 | $\underset{0}{\mathrm{C}_{0} \times \mathrm{X}_{23}}$ | $\mathrm{C}_{0} \stackrel{\downarrow}{\text { ¢ }}$ ( ${ }_{25}$ | $\downarrow$ |  |  |  | $+C_{6} \times \times_{24}$ $+C_{5} \times \times_{25}$ | $\begin{aligned} & \text { Cell 1(Y24) } \\ & \text { Cell 2(Y25) } \end{aligned}$ |
| 47 | 0 | 0 | ${ }_{0}$ | $\mathrm{C}_{0} \times \mathrm{X}_{26}$ | $\downarrow$ |  |  | + $\mathrm{C}_{4} \times \mathrm{X}_{26}$ | Cell 3(Y26) |
| 48 | 0 | 0 | 0 |  | $c_{0} \times{ }_{27}$ | $\downarrow$ | $\downarrow$ | $+c_{3} \times{ }^{27}$ | Cell 4(Y27) |



FIGURE 6. HSP43891 16-TAP 30MHz FILTER TIMING USING TWO CASCADED HSP43891s

## Single DF Configuration

Using a single DF, a filter of length $L>8$ can be constructed by processing in $L / 8$ passes, as illustrated in Table 2, for a 16-tap FIR. Each pass is composed of $T p=7+L$ cycles and computes eight output samples. In pass $i$, the sample with indices $i^{*} 8$ to $i^{*} 8+(L-1)$ enter the DINO-8 inputs. The coefficients $\mathrm{C}_{0}-\mathrm{C}_{\mathrm{L}}-1$ enter the CINO-8 inputs, followed by seven zeros. As these zeros are entered, the result samples are output and the accumulators reset. Initial filing of the pipeline is not shown in this sequence table. Filter outputs can be put through a FIFO to even out the sample rate.

## Extended Coefficient and Data Sample Word Size

The sample and coefficient word size can be extended by utilizing several DFs in parallel to get the maximum sample rate or a single DF with resulting lower sample rates. The technique is to compute partial products of $9 \times 9$ and com-
bine these partial products by shifting and adding to obtain the final result. The shifting and adding can be accomplished with external adders (at full speed) or with the DF's shift-and-add mechanism contained in its output stage (at reduced speed).

## Decimation/Resampling

The HSP43891 DF provides a mechanism for decimating by factors of 2,3 , or 4 . From the DF filter cell block diagram (Figure 1), note the three D registers and two multiplexers in the coefficient path through the cell. These allow the coefficients to be delayed by 1,2 , or 3 clocks through the cell. The sequence table (Table 3) for a decimate-by-twofilter illustrates the technique (internal cell pipelining ignored for simplicity).
Detailed timing for a 30 MHz input sample rate, 15 MHz output sample rate (i.e., decimate-by-two), 16-tap FIR filter, including pipelining, is shown in Figure 7. This filter requires only a single HSP43891 DF.

TABLE 3. HSP43891 16-TAP DECIMATE-BY-TWO FIR FILTER SEQUENCE; 30MHz IN, 15MHz OUT
DATA


| CLK | CELL 0 | CELL 1 | CELL 2 | CELL 3 | CELL 4 | CELL 5 | CELL 6 | CELL 7 | SUM/CLR |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 6 | $\mathrm{C}_{15} \times \mathrm{X}_{0}$ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | - |
| 7 | $+C_{14} \times X_{1}$ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | - |
| 8 | $+C_{13} \times X_{2}$ | $\mathrm{C}_{15} \times \mathrm{X}_{2}$ | 0 | 0 | 0 | 0 | 0 | 0 | - |
| 9 | $+C_{12} \times x_{3}$ | $+C_{14} \times \mathrm{X}_{3}$ | 0 | 0 | 0 | 0 | 0 | 0 | - |
| 10 | $+C_{11} \times \mathrm{X}_{4}$ | $+C_{13} \times \mathrm{X}_{4}$ | $\mathrm{C}_{15} \times \mathrm{X}_{4}$ | 0 | 0 | 0 | 0 | 0 | - |
| 11 | $+C_{10} \times X_{5}$ | $+C_{12} \times \mathrm{X}_{5}$ | $+C_{14} \times \mathrm{X}_{5}$ | 0 | 0 | 0 | 0 | 0 | - |
| 12 | $+C_{9} \times x_{6}$ | $+C_{11} \times X_{6}$ | $+C_{13} \times X_{6}$ | $\mathrm{C}_{15} \times \mathrm{X}_{6}$ | 0 | 0 | 0 | 0 | - |
| 13 | $+\mathrm{C}_{8} \times \mathrm{X}_{7}$ | $+\mathrm{C}_{10} \times \mathrm{X}_{7}$ | $+C_{12} \times X_{7}$ | $+C_{14} \times X_{7}$ | 0 | 0 | 0 | 0 | - |
| 14 | $+C_{7} \times X_{8}$ | $+C_{9} \times X_{8}$ | $+C_{11} \times X_{8}$ | $+C_{13} \times X_{8}$ | $\mathrm{C}_{15} \times \mathrm{X}_{8}$ | 0 | 0 | 0 | - |
| 15 | $+C_{6} \times{ }^{\prime}{ }_{9}$ | $+C_{8} \times X_{9}$ | $+\mathrm{C}_{10} \times \mathrm{X}_{9}$ | $+C_{12} \times \mathrm{X}_{9}$ | $+C_{14} \times X_{9}$ | 0 | 0 | 0 | - |
| 16 | $+C_{5} \times \mathrm{X}_{10}$ | $+C_{7} \times{ }_{10}$ | $+C_{9} \times{ }_{10}$ | $+C_{11} \times X_{10}$ | $+C_{13} \times{ }_{10}$ | $\mathrm{C}_{15} \times \mathrm{X}_{10}$ | 0 | 0 | - |
| 17 | $+C_{4} \times X_{11}$ | $+C_{6} \times \mathrm{X}_{11}$ | $+C_{8} \times{ }_{11}$ | $+C_{10} \times X_{11}$ | $+C_{12} \times x_{11}$ | $+C_{14} \times X_{11}$ | 0 | 0 | - |
| 18 | $+C_{3} \times X_{12}$ | $+C_{5} \times{ }^{12}$ | $+C_{7} \times X_{12}$ | $+C_{9} \times{ }_{12}$ | $+C_{11} \times X_{12}$ | $+C_{13} \times X_{12}$ | $\mathrm{C}_{15} \times \mathrm{X}_{12}$ | 0 | - |
| 19 | $+C_{2} \times \mathrm{X}_{13}$ | $+\mathrm{C}_{4} \times \mathrm{X}_{13}$ | $+C_{6} \times \times_{13}$ | $+\mathrm{C}_{8} \times \mathrm{X}_{13}$ | $+C_{10} \times X_{13}$ | $+C_{12} \times X_{13}$ | $+C_{14} \times X_{13}$ | 0 | - |
| 20 | $+C_{1} \times \mathrm{X}_{14}$ | $+C_{3} \times \times_{14}$ | $+C_{5} \times \mathrm{X}_{14}$ | $+C_{7} \times{ }_{14}$ | $+C_{9} \times \mathrm{X}_{14}$ | $+C_{11} \times \mathrm{X}_{14}$ | $+C_{13} \times X_{14}$ | $C_{15} \times{ }_{14}$ | - |
| 21 | $+c_{0} \times X_{15}$ | $+C_{2} \times{ }_{15}$ | $+C_{4} \times{ }^{15}$ | $+C_{6} \times \times_{15}$ | $+C_{8} \times{ }_{15}$ | $+C_{10} \times X_{15}$ | $+C_{12} \times X_{15}$ | $+C_{14} \times X_{15}$ | Cell O(Y15) |
| 22 | $\mathrm{C}_{15} \times \mathrm{X}_{16}$ | $+C_{1} \times \mathrm{X}_{16}$ | $+C_{3} \times{ }_{16}$ | $+C_{5} \times{ }_{16}$ | $+C_{7} \times{ }_{16}$ | $+\mathrm{C}_{9} \times \mathrm{X}_{16}$ | $+C_{11} \times X_{16}$ | $+C_{13} \times X_{16}$ | - |
| 23 | $+C_{14} \times \mathrm{X}_{17}$ | $+C_{0} \times X_{17}$ | $+C_{2} \times{ }^{17}$ | $+C_{4} \times \mathrm{X}_{17}$ | $+C_{6} \times X_{17}$ | $+\mathrm{C}_{8} \times \mathrm{X}_{17}$ | $+C_{10} \times X_{17}$ | $+C_{12} \times X_{17}$ | Cell 1(Y17) |
| 24 | $+C_{13} \times \mathrm{X}_{18}$ | $\mathrm{C}_{15} \times \mathrm{X}_{18}$ | $+C_{1} \times{ }_{18}$ | $+C_{3} \times{ }^{18}$ | $+C_{5} \times{ }_{18}$ | $+C_{7} \times{ }^{18}$ | $+\mathrm{Cg}_{9} \times \mathrm{X}_{18}$ | $+C_{11} \times X_{18}$ | - |
| 25 | $+C_{12} \times \mathrm{X}_{19}$ | $+C_{14} \times X_{19}$ | $+C_{0} \times X_{19}$ | $+C_{2} \times{ }_{19}$ | $+C_{4} \times{ }_{19}$ | $+C_{6} \times \times_{19}$ | $+C_{8} \times \mathrm{X}_{19}$ | $+C_{10} \times X_{19}$ | Cell 2(Y19) |
| 26 | $+C_{11} \times X_{20}$ | $+C_{13} \times X_{20}$ | $\mathrm{C}_{15} \times \mathrm{X}_{20}$ | $+C_{1} \times X_{20}$ | $+C_{3} \times{ }_{20}$ | $+C_{5} \times{ }_{20}$ | $+C_{7} \times{ }_{20}$ | $+C_{9} \times{ }_{20}$ | - |
| 27 | $+C_{10} \times{ }_{21}$ | $+C_{12} \times X_{21}$ | $+C_{14} \times \mathrm{X}_{21}$ | $+C_{0} \times{ }_{21}$ | $+C_{2} \times X_{21}$ | $+C_{4} \times X_{21}$ | $+C_{6} \times \times_{21}$ | $+C_{8} \times{ }_{21}$ | Cell 3(Y21) |
| 28 | $+\mathrm{C}_{9} \times \mathrm{X}_{22}$ | $+C_{11} \times X_{22}$ | $+C_{13} \times X_{22}$ | $\mathrm{C}_{15} \times \mathrm{X}_{22}$ | $+C_{1} \times X_{22}$ | $+C_{3} \times X_{22}$ | $+C_{5} \times{ }_{22}$ | $+C_{7} \times{ }_{22}$ | - |
| 29 | $+C_{8} \times{ }_{23}$ | $+C_{10} \times X_{23}$ | $+C_{12} \times X_{23}$ | $+C_{14} \times X_{23}$ | $+c_{0} \times{ }_{23}$ | $+C_{2} \times{ }_{23}$ | $+C_{4} \times{ }_{23}$ | $+C_{6} \times{ }_{23}$ | Cell 4(Y23) |
| 30 | $+C_{7} \times X_{24}$ | $+C_{9} \times{ }_{24}$ | $+C_{11} \times X_{24}$ | $+C_{13} \times X_{24}$ | $+C_{15} \times X_{24}$ | $+C_{1} \times X_{24}$ | $+c_{3} \times X_{24}$ | $+C_{5} \times X_{24}$ | - |
| 31 | $+C_{6} \times{ }_{25}$ | $+C_{8} \times{ }_{25}$ | $+C_{10} \times X_{25}$ | $+C_{12} \times \mathrm{X}_{25}$ | $+C_{14} \times X_{25}$ | $+C_{0} \times{ }_{25}$ | $+C_{2} \times{ }_{25}$ | $+C_{4} \times X_{25}$ | Cell 5(Y25) |
| 32 | $+\mathrm{C}_{5} \times \mathrm{X}_{26}$ | $+C_{7} \times X_{26}$ | $+C_{9} \times{ }_{26}$ | $+C_{11} \times \mathrm{X}_{26}$ | $+C_{13} \times X_{26}$ | $+C_{15} \times X_{26}$ | $+C_{1} \times{ }_{26}$ | $+C_{3} \times X_{26}$ | - |
| 33 | $+C_{4} \times \mathrm{X}_{27}$ | $+C_{6} \times X_{27}$ | $+C_{8} \times \mathrm{X}_{27}$ | $+C_{10} \times X_{27}$ | $+C_{12} \times X_{27}$ | $+C_{14} \times X_{27}$ | $+C_{0} \times X_{27}$ | $+C_{2} \times x_{27}$ | Cell 6(Y27) |
| 34 | $+c_{3} \times{ }_{28}$ | $+C_{5} \times X_{28}$ | $+C_{7} \times{ }_{28}$ | $+\mathrm{C}_{9} \times \mathrm{X}_{28}$ | $+C_{11} \times X_{28}$ | $+C_{13} \times X_{28}$ | $+C_{15} \times X_{28}$ | $+C_{1} \times X_{28}$ |  |
| 35 | $+C_{2} \times X_{29}$ | $+C_{4} \times X_{29}$ | $+C_{6} \times X_{29}$ | $+C_{8} \times X_{29}$ | $+C_{10} \times X_{29}$ | $+C_{12} \times X_{29}$ | $+C_{14} \times X_{29}$ | $+C_{0} \times X_{29}$ | Cell 7(Y29) |
| 36 | $+C_{1} \times \mathrm{X}_{30}$ | $+C_{3} \times x_{30}$ | $+C_{5} \times{ }_{30}$ | $+C_{7} \times{ }_{30}$ | $+\mathrm{C}_{9} \times \mathrm{X}_{30}$ | $+C_{11} \times X_{30}$ | $+C_{13} \times X_{30}$ | $\mathrm{C}_{15} \times \mathrm{X}_{30}$ |  |
| 37 | $+c_{0} \times x_{31}$ | $+C_{2} \times x_{31}$ | $+c_{4} \times X_{31}$ | $+C_{6} \times \times_{31}$ | $+C_{8} \times X_{31}$ | $+C_{10} \times X_{31}$ | $+C_{12} \times X_{31}$ | $+C_{14} \times \mathrm{X}_{31}$ | Cell 8(Y31) |

世 RESET


FIGURE 7. HSP43891 16-TAP DECIMATE-BY-TWO FIR FILTER TIMING; 30MHz IN, 15MHz OUT

## Absolute Maximum Ratings

| Supply Voltage | +8.0V |
| :---: | :---: |
| Input, Output Voltage | .GND -0.5V to $\mathrm{V}_{\mathrm{CC}}+0.5 \mathrm{~V}$ |
| Storage Temperature. | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| ESD | . Class 1 |
| Maximum Package Po | .... 2.4W (PLCC), 2.88W (PGA) |
| $\theta_{\text {jc }}$ | $11.1^{\circ} \mathrm{C} / \mathrm{W}$ (PLCC), $7.78^{\circ} \mathrm{C} / \mathrm{W}$ (PGA) |
|  | $33.7^{\circ} \mathrm{C} / \mathrm{W}$ (PLCC), $34.66^{\circ} \mathrm{C} / \mathrm{W}$ (PGA) |
| Gate Count | ........ 17763 |
| Junction Temperature | $150^{\circ} \mathrm{C}$ (PLCC), $175^{\circ} \mathrm{C}$ (PGA) |
|  | $300^{\circ} \mathrm{C}$ |

CAUTION: Stresses above those listed in the "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.

## Operating Conditions


D.C. Electrical Specifications

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ICCOP | Power Supply Current | - | 160 | mA | $v_{C C}=M a x$ <br> CLK Frequency 20 MHz <br> Note 1, Note 3 |
| ICCsB | Standby Power Supply Current | - | 500 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {CC }}=$ Max, Note 3 |
| 1 | Input Leakage Current | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {CC }}=$ Max, Input $=0 \mathrm{~V}$ or $\mathrm{V}_{\text {CC }}$ |
| 10 | Output Leakage Current | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {CC }}=$ Max, Input $=0 \mathrm{~V}$ or $\mathrm{V}_{\text {CC }}$ |
| $\mathrm{V}_{\mathrm{IH}}$ | Logical One Input Voltage | 2.0 | - | V | $V_{C C}=$ Max |
| $\mathrm{V}_{\text {IL }}$ | Logical Zero Input Voltage |  | 0.8 | V | $\mathrm{V}_{\mathrm{CC}}=$ Min |
| $\mathrm{V}_{\mathrm{OH}}$ | Logical One Output Voltage | 2.6 | - | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}, \mathrm{~V}_{\mathrm{CC}}=\mathrm{Min}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Logical Zero Output Voltage | - | 0.4 | V | $\mathrm{I}_{\mathrm{OL}}=2 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=\mathrm{Min}$ |
| $\mathrm{V}_{\mathrm{IHC}}$ | Clock Input High | 3.0 | - | V | $\mathrm{V}_{\text {CC }}=$ Max |
| VILC | Clock Input Low | - | 0.8 | V | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}$ |
| $\mathrm{CIN}^{\text {I }}$ | Input Capacitance $\begin{array}{rr}\text { PLCC } \\ & \text { PGA }\end{array}$ | - | $\begin{aligned} & 10 \\ & 15 \end{aligned}$ | $\begin{aligned} & \mathrm{pF} \\ & \mathrm{pF} \end{aligned}$ | CLK Frequency 1 MHz All measurements referenced |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance $\begin{array}{rr}\text { PLCC } \\ & \text { PGA }\end{array}$ |  | $\begin{aligned} & 10 \\ & 15 \end{aligned}$ | $\begin{aligned} & \mathrm{pF} \\ & \mathrm{pF} \end{aligned}$ | $T_{A}=25^{\circ} \mathrm{C} . \quad \text { Note } 2$ |

NOTES: 1. Operating supply current is proportional to frequency. Typical rating is $8 \mathrm{~mA} / \mathrm{MHz}$.
2. Controlled via design or process parameters and not directly tested. Characterized upon initial design and after major process and/or design changes.
3. Output load per test load circuit and $C_{L}=40 \mathrm{pF}$.

Specifications HSP43891
A.C. Electrical Specifications $\quad V_{C C}=5 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | -20 (20MHz) |  | -25 (25.6MHz) |  | -30 (30MHz) |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |  |
| TCP | Clock Period | 50 | - | 39 | - | 33 | - | ns |  |
| TCL | Clock Low | 20 | - | 16 | - | 13 | - | ns |  |
| $\mathrm{T}_{\mathrm{CH}}$ | Clock High | 20 | - | 16 | - | 13 | - | ns |  |
| TIS | Input Setup | 16 | - | 14 | - | 13 | - | ns |  |
| $\mathrm{T}_{\mathrm{IH}}$ | Input Hold | 0 | - | 0 | - | 0 | - | ns |  |
| TODC | CLK to Coefficient Output Delay | - | 24 | - | 20 | - | 18 | ns |  |
| ToEd | Output Enable Delay | - | 20 | - | 15 | - | 15 | ns |  |
| TODD | Output Disable Delay | - | 20 | - | 15 | - | 15 | ns | Note 1 |
| TODS | CLK to SUM Output Delay | - | 27 | - | 25 | - | 21 | ns |  |
| TOR | Output Rise | - | 6 | - | 6 | - | 6 | ns | Note 1 |
| TOF | Output Fall | - | 6 | - | 6 | - | 6 | ns | Note 1 |

NOTE: 1. Controlled by design or process parameters and not directly tested. Characterized upon initial design and after major process and/or design changes.

Test Load Circuit


Switch S1 Open for ICCSB and ICCOP Tests

## Waveforms



CLOCK AC PARAMETERS


SUM0-25, COUTO-8, OUTPUT DELAYS


OUTPUT ENABLE, DISABLE TIMING


RISE AND FALL TIMES
A.C. Testing: Inputs are driven at 3.0V for a Logic " 1 " and 0.0 V for a Logic " $O$ ". Input and output timing measurements are made at 1.5 V for both a Logic " 1 " and " 0 ". CLK is driven at 4.0 V and OV and measured at 2.5 V .
A.C. TESTING INPUT, OUTPUT WAVEFORM

## Features

- This Circuit is Processed in Accordance to Mil-Std-883C and is Fully Conformant Under the Provisions of Paragraph 1.2.1
- 0 to 25.6 MHz Sample Rate
- Eight Filter Cells
- 9-Bit Coefficients and Signal Data
- Low Power CMOS Operation
$-\mathrm{ICCSB}=500 \mu \mathrm{~A}$ Maximum
- ICCOP $=160 \mu \mathrm{~A}$ Maximum @ 20 MHz
- 26-Bit Accumulator per Stage
- Filter Lengths Up to 1032 Taps
- Shift-and-Add Output Stage for Combining Filter Outputs
- Expandable Coefficient Size, Data Size and Filter Length
- Decimation by 2, 3 or 4


## Applications

- 1-D and 2-D FIR Filters
- Radar/Sonar
- Digital Video and Audio
- Adaptive Filters
- Echo Cancellation
- Correlation/Convolution
- Complex Multiply-Add
- Butterfly Computation
- Matrix Multiplication
- Sample Rate Converters


## Description

The HSP43891/883 is a video-speed Digital Filter (DF) designed to efficiently implement vector operations such as FIR digital filters. It is comprised of eight filter cells cascaded internally and a shift and add output stage, all in a single integrated circuit. Each filter cell contains a $9 \times 9$ two's complement multiplier, three decimation registers and a 26-bit accumulator. The output stage contains an additional 26-bit accumulator which can add the contents of any filter cell accumulator to the output stage accumulator shifted right by 8 bits. The HSP43891/883 has a maximum sample rate of 25.6 MHz . The effective multiply-accumulate (mac) rate is 204 MHz . The HSP43891/883 DF can be configured to process expanded coefficient and word sizes. Multiple DFs can be cascaded for larger filter lengths without degrading the sample rate or a single DF can process larger filter lengths at less than 25.6 MHz with multiple passes. The architecture permits processing filter lengths of over 1000 taps with the guarantee of no overflows. In practice, most filter coefficients are less than 1.0, making even larger filter lengths possible. The DF provides for 8-bit unsigned or 9-bit two's complement arithmetic, independently selectable for coefficients and signal data.

Each DF filter cell contains three re-sampling or decimation registers which permit output sample rate reduction at rates of $1 / 2,1 / 3$ or $1 / 4$ the input sample rate. These registers also provide the capability to perform 2-D operations such as matrix multiplication and NxN spatial correlations/convolutions for image processing applications.

## Block Diagram



## Pinouts

85 PIN GRID ARRAY (PGA)



| Absolute Maximum Ratings |  |
| :---: | :---: |
| Supply Voltage | +8.0V |
| Input, Output Voltage Applied | GND-0.5V to $\mathrm{V}_{\mathrm{CC}}+0.5 \mathrm{~V}$ |
| Storage Temperature Range | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Junction Temperature | $\ldots+175^{\circ} \mathrm{C}$ |
| Lead Temperature (Soldering, | $+300^{\circ} \mathrm{C}$ |
| ESD Classification | Class 1 |

Input, Output Voltage Applied ........... GND-0.5V to $\mathrm{V}_{\mathrm{CC}}+0.5 \mathrm{~V}$
Storage Temperature Range . . ................ -650 C to $+150{ }^{\circ}$
Lead Temperature (Soldering, Ten Seconds) .............. $+300^{\circ} \mathrm{C}$
ESD Classification . Class 1

## Reliability Information

Thermal Resistance $\quad \theta_{\mathrm{ja}} \quad \theta_{\mathrm{jc}}$

Ceramic PGA Package ............... $34.66^{\circ} \mathrm{C} / \mathrm{W} \quad 7.78^{\circ} \mathrm{C} / \mathrm{W}$
Maximum Package Power Dissipation at $+125^{\circ} \mathrm{C}$
Ceramic PGA Package
. 1.44 Watt

CAUTION: Stresses above those listed in "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.

## Operating Conditions

Operating Voltage Range $\ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots+4.5 \mathrm{~V}$ to +5.5 V
Operating Temperature Range $. \ldots \ldots \ldots . . . . . . .5^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
TABLE 1. HSP43891/883 D.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Devices Guaranteed and $100 \%$ Tested

| PARAMETER | SYMBOL | CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| Logical One Input Voltage | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 2.2 | - | V |
| Logical Zero Input Voltage | $V_{\text {IL }}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 0.8 | V |
| Output HIGH Voltage | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & \mathrm{IOH}^{\mathrm{OH}}=-400 \mu \mathrm{~A} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}(\text { Note } 1) \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 2.6 | - | V |
| Output LOW Voltage | VoL | $\begin{aligned} & I_{\mathrm{OL}}=+2.0 \mathrm{~mA} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}(\text { Note } 1) \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 0.4 | V |
| Input Leakage Current | 1 | $\begin{aligned} & V_{I N}=V_{C C} \text { or } G N D \\ & V_{C C}=5.5 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Output Leakage Current | 10 | $\begin{aligned} & V_{\text {OUT }}=V_{C C} \text { or GND } \\ & V_{\text {CC }}=5.5 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Clock Input High | $\mathrm{V}_{1 \mathrm{HC}}$ | $V_{C C}=5.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 3.0 | - | V |
| Clock Input Low | $\mathrm{V}_{\text {ILC }}$ | $V_{C C}=4.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 0.8 | V |
| Standby Power Supply Current | ICCsB | $\begin{aligned} & V_{I N}=V_{C C} \text { or GND } \\ & V_{C C}=5.5 \mathrm{~V}, \\ & \text { Outputs Open } \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 500 | $\mu \mathrm{A}$ |
| Operating Power Supply Current | ICCOP | $\begin{aligned} & f=20.0 \mathrm{MHz} \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V} \text { (Note 2) } \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 160.0 | mA |
| Functional Test | FT | (Note 3) | 7,8 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | - |  |

NOTES: 1. Interchanging of force and sense conditions is permitted.
2. Operating Supply Current is proportional to frequency, typical rating is $8 \mathrm{~mA} / \mathrm{MHz}$.
3. Tested as follows: $f=1 \mathrm{MHz}, \mathrm{V}_{\mathrm{IH}}=2.6, \mathrm{~V}_{\mathrm{IL}}=0.4, \mathrm{~V}_{\mathrm{OH}} \geq 1.5 \mathrm{~V}$, $V_{\mathrm{OL}} \leq 1.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{IHC}}=3.4 \mathrm{~V}$, and $\mathrm{V}_{\mathrm{ILC}}=0.4 \mathrm{~V}$.

TABLE 2. HSP43891/883 A.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and 100\% Tested

| PARAMETER | SYMBOL | CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | -20 (20MHz) |  | -25 (25.6MHz) |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| Clock Period | $\mathrm{T}_{\mathrm{CP}}$ | Note 1 | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 50 | - | 39 | - | ns |
| Clock Low | $T^{\text {ch }}$ | Note 1 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 20 | - | 16 | - | ns |
| Clock High | ${ }^{\text {T }} \mathrm{CH}$ | Note 1 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 20 | - | 16 | - | ns |
| Input Setup | $\mathrm{T}_{\text {IS }}$ | Note 1 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 20 | - | 17 | - | ns |
| Input Hold | $\mathrm{T}_{\mathrm{IH}}$ | Note 1 | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns |
| CLK to Coefficient Output Delay | TODC | Note 1 | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 24 | - | 20 | ns |
| Output Enable Delay | ToED | Note 1 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq T^{\prime} \leq+125^{\circ} \mathrm{C}$ | - | 20 | - | 15 | ns |
| CLK to SUM Output Delay | TODS | Note 1 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 31 | - | 25 | ns |

NOTE: 1. A.C. Testing: $\mathrm{VCC}=4.5 \mathrm{~V}$ and 5.5 V . Inputs are driven at 3.0 V for a Logic " 1 " and 0.0 V for a Logic " 0 ". Input and output timing measurements are made at 1.5 V for both a Logic " 1 " and " 0 ". CLK is driven at 4.0 V and OV and measured at 2.0 V .

TABLE 3. HSP43891/883 A.C. ELECTRICAL PERFORMANCE CHARACTERISTICS

| PARAMETER | SYMBOL | CONDITIONS | NOTES | TEMPERATURE | -20 (20MHz) |  | -25 (25.6MHz) |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| Input Capacitance | $\mathrm{Cin}_{\text {IN }}$ | $\mathrm{V}_{\mathrm{CC}}=$ Open, $\mathrm{f}=1 \mathrm{MHz}$ All measurements are referenced to device GND. | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 15 | - | 15 | pF |
| Output Capacitance | COUT |  | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 15 | - | 15 | pF |
| Output Disable Delay | TODD |  | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 20 | - | 15 | ns |
| Output Rise Time | TOR |  | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 7 | - | 6 | ns |
| Output Fall Time | TOF |  | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 7 | - | 6 | ns |

NOTES: 1. The parameters listed in Table 3 are controlled via design or process parameters and are not directly tested. These parameters are characterized upon initial design and after major process and/or design changes.
2. Loading is as specified in the test load circuit, $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$.

TABLE 4. APPLICABLE SUBGROUPS

| CONFORMANCE GROUPS | METHOD | SUBGROUPS |
| :--- | :---: | :---: |
| Initial Test | $100 \% / 5004$ | - |
| Interim Test | $100 \% / 5004$ | - |
| PDA | $100 \%$ | 1 |
| Final Test | $100 \%$ | $2,3,8 \mathrm{~A}, 8 \mathrm{~B}, 10,11$ |
| Group A | - | $1,2,3,7,8 \mathrm{~A}, 8 \mathrm{~B}, 9,10,11$ |
| Groups C \&D | Samples $/ 5005$ | $1,7,9$ |

HSP43891/883
Burn-In Circuit


| $\begin{aligned} & \text { PGA } \\ & \text { PIN } \end{aligned}$ | $\begin{aligned} & \text { PIN } \\ & \text { NAME } \end{aligned}$ | BURN-IN SIGNAL | $\begin{aligned} & \text { PGA } \\ & \text { PIN } \end{aligned}$ | PIN NAME | BURN-IN SIGNAL | $\begin{aligned} & \text { PGA } \\ & \text { PIN } \end{aligned}$ | PIN NAME | BURN-IN SIGNAL | $\begin{aligned} & \text { PGA } \\ & \text { PIN } \end{aligned}$ | PIN NAME | BURN-IN SIGNAL |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A1 | $V_{S S}$ | GND | C1 | COUT5 | $\mathrm{V}_{\mathrm{CC} / 2}$ | F10 | $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ | K4 | $\mathrm{V}_{\mathrm{CC}}$ | $V_{\text {cc }}$ |
| A2 | $\overline{\text { COENB }}$ | F10 | C2 | COUT6 | $\mathrm{V}_{\mathrm{CC} / 2}$ | F11 | $V_{S S}$ | GND | K5 | SUM19 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| A3 | $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{Cc}}$ | C3 | ALIGN | NC | G1 | ADR2 | F2 | K6 | $V_{S S}$ | GND |
| A4 | RESET | F11 | C5 | $\overline{\text { DIENB }}$ | F10 | G2 | DCMO | F5 | K7 | SUM15 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| A5 | DIN7 | F8 | C6 | DIN5 | F5 | G3 | CLK | FO | K8 | SUM12 | $\mathrm{v}_{\mathrm{CC} / 2}$ |
| A6 | DIN6 | F6 | C7 | DIN4 | F4 | G9 | SUM1 | $\mathrm{V}_{\mathrm{CC} / 2}$ | K9 | SUM10 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| A7 | DIN3 | F3 | C10 | CIN5 | F5 | G10 | SUM3 | $\mathrm{V}_{\mathrm{CC} / 2}$ | K10 | SUM8 | $\mathrm{v}_{\mathrm{CC} / 2}$ |
| A8 | DINO | FO | C11 | CIN3 | F3 | G11 | SUM2 | $\mathrm{V}_{\mathrm{CC} / 2}$ | K11 | SUM6 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| A9 | CIN8/TCCI | F8 | D1 | COUT3 | $\mathrm{V}_{\mathrm{CC} / 2}$ | H1 | ADR1 | F1 | L1 | DCM1 | F6 |
| A10 | $V_{\text {cc }}$ | $\mathrm{V}_{\mathrm{CC}}$ | D2 | COUT4 | $\mathrm{V}_{\mathrm{CC} / 2}$ | H2 | ADRO | FO | L2 | SUM23 | $\mathrm{V}_{\mathrm{cc} / 2}$ |
| A11 | $\mathrm{V}_{\text {SS }}$ | GND | D10 | CIN2 | F2 | H10 | SUM5 | $\mathrm{v}_{\mathrm{CC} / 2}$ | L3 | SUM22 | $\mathrm{V}_{\mathrm{cc} / 2}$ |
| B1 | $V_{C C}$ | $\mathrm{V}_{\text {CC }}$ | D11 | $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ | H11 | SUM4 | $\mathrm{v}_{\mathrm{CC} / 2}$ | L4 | SUM21 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| B2 | COUT7 | $\mathrm{v}_{\mathrm{cc} / 2}$ | E1 | COUT1 | $\mathrm{V}_{\mathrm{CC} / 2}$ | J1 | $\mathrm{V}_{\mathrm{CC}}$ | $V_{\text {cc }}$ | L5 | SUM18 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| B3 | $\begin{aligned} & \text { COUT8/ } \\ & \text { TCCO } \end{aligned}$ | $\mathrm{V}_{\mathrm{cc} / 2}$ | E2 | VSS | GND | J2 | SUM25 | $\mathrm{V}_{\mathrm{CC} / 2}$ | L6 | SUM14 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
|  |  |  | E3 | COUT2 | $\mathrm{V}_{\mathrm{CC} / 2}$ | J5 | SUM20 | $\mathrm{V}_{\mathrm{CC} / 2}$ | L7 | $\mathrm{V}_{\text {cc }}$ | $\mathrm{V}_{\mathrm{CC}}$ |
| B4 | ERASE | F10 | E9 | CIN1 | F1 | J6 | SUM17 | $\mathrm{V}_{\mathrm{CC} / 2}$ | L8 | SUM13 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| B5 | DIN8/TCS | F7 | E10 | CINO | FO | J7 | SUM16 | $\mathrm{V}_{\mathrm{CC} / 2}$ | L9 | $V_{S S}$ | GND |
| B6 | DIN1 | F1 | E11 | SENBL | F10 | J10 | SUM7 | $\mathrm{V}_{\mathrm{CC} / 2}$ | L10 | SUM11 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| B7 | DIN2 | F2 | F1 | $V_{\text {SS }}$ | GND | J11 | VSS | GND | L11 | SuM9 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| B8 | CIENB | F10 | F2 | CUTO | $\mathrm{V}_{\mathrm{CC}} / 2$ | K1 | SENBH | F10 |  |  |  |
| B9 | CIN7 | F7 | F3 | SHADD | F9 | K2 | SUM24 | $\mathrm{VCC}_{\mathrm{Cl}}$ |  |  |  |
| B10 | CIN6 | F6 | F9 | SUMO | $\mathrm{v}_{\mathrm{CC}} / 2$ | K3 | $\mathrm{V}_{\text {SS }}$ | GND |  |  |  |
| B11 | CIN4 | F4 |  |  |  |  |  |  |  |  |  |

NOTES: 1. $\mathrm{V}_{\mathrm{CC}} / 2(2.7 \mathrm{~V} \pm 10 \%)$ used for outputs only.
2. $47 \mathrm{~K} \Omega( \pm 20 \%)$ resistor connected to all pins except $V_{C C}$ and GND.
3. $\mathrm{V}_{\mathrm{CC}}=5.5 \pm 0.5 \mathrm{~V}$.
4. $0.1 \mu \mathrm{~F}(\mathrm{~min})$ capacitor between $\mathrm{V}_{\mathrm{CC}}$ and GND per position.
5. $\mathrm{FO}=100 \mathrm{KHz} \pm 10 \%, F 1=F 0 / 2, F 2=F 1 / 2 \ldots, \ldots 11=F 10 / 2$, 40\% - 60\% Duty Cycle.
6. Input voltage limits: $\mathrm{V}_{\mathrm{IL}}=0.8 \mathrm{~V}$ max., $\mathrm{V}_{\mathrm{IH}}=4.5 \mathrm{~V} \pm 10 \%$

## Metallization Topology

DIE DIMENSIONS:
$328 \times 283 \times 19 \pm 1$ mils
METALLIZATION:
Type: Si - Al or $\mathrm{Si}-\mathrm{Al}-\mathrm{Cu}$
Thickness: $8 \mathrm{k} \AA$
GLASSIVATION:
Type: Nitrox
Thickness: 10k $\AA$
DIE ATTACH:
Material: Gold/Silicon Eutectic Alloy or Silver-Glass
WORST CASE CURRENT DENSITY:
$1.2 \times 10^{5} \mathrm{~A} / \mathrm{cm}^{2}$

## Metallization Mask Layout

HSP43891/883


## ADVANCE INFORMATION

## Features

- Sample Rates to 75 MHz
- External Multiplexing Supported for Processing of Sample Rates to 150 MHz
- 67 Tap FIR Filter with 20 Bit Coefficients
- 1.24:1 Filter Shape Factor, > 90dB Stopband Attenuation, $<0.0005 \mathrm{~dB}$ Stopband Ripple
- Four Modes of Operation:
- Interpolation by 2
- Decimation by 2
- $\mathrm{F}_{\mathrm{S}} / 4$ Quadrature Up Conversion of a Complex Signal with Real Output
- $F_{\mathbb{S}} / 4$ Quadrature Down Conversion of a Real Input Signal with Complex Output
- Upper/Lower Sideband Selection in both Down Convert and Up Convert Modes
- Dual 16-Bit Inputs and Outputs with Programmable Rounding on the Outputs
- Two's Complement or Offset Binary Output
- 85-Pin PGA, 84-Pin PLCC Package


## Applications

- Digital Down Conversion
- D/A and A/D Pre/Post Filtering
- Processing Bandwidth Expansion for HSP45116 and HSP43220 Digital Down Converter Chip Set
- Tuning Bandwidth Expansion for HSP45116 and HSP45106


## Description

The HSP43216 Halfband Filter addresses a wide variety of applications by combining quadrature up/down conversion circuitry with a fixed coefficient halfband filter processor. The filter processor implements a 67 tap FIR filter with either interpolation or decimation by 2. As shown in the block diagram, the filter processor may be configured to receive output from the $\mathrm{F}_{\mathrm{S}} / 4$ quadrature down converter or provide complex input to the $F_{S} / 4$ quadrature up converter. In either of these two configurations the halfband processor functions as a quadrature filter. Two data inputs and outputs are provided so that an external multiplexer may be used to effectively double the processing speed of the part.

The HSP43216 can be configured in one of the four following modes: decimate by 2 filtering of a real input signal; interpolate by 2 filtering of a real input signal; quadrature down conversion of a real input signal followed by decimate-by-2 filtering of the resulting complex analytic signal; interpolate-by-2 filtering of a complex analytic signal followed by quadrature up conversion producing a real valued output.

Typical applications include the simplification of AD and D/A subsystem design and extension of the operational envelope of certain parts within the HSPXXXXX family. The first two modes simplify the analog anti-aliasing and reconstruction filter requirements of an A/D or D/A subsystem by providing a mechanism to increase the converter sample rate relative to the frequency content of the digitized signal. The quadrature down convert mode doubles the signal bandwidth processed by the HSP45116/HSP43220 digital down convert chipset by providing quadrature samples at the maximum clock rate of the chip set. Similarly, the quadrature up convert mode doubles the tuning bandwidth of either the HSP45116 or HSP45106 by converting the quadrature outputs of these parts to a real signal at twice the sample rate.

The frequency response of the HSP43216's halfband filter has a shape factor, (passband+transition band)/passband, of $1.24: 1$ with 90 dB of stopband attenuation. The passband has less than .0005 dB of ripple from 0 to $0.2 \mathrm{~F}_{\mathrm{S}}$ with stopband attenuation of greater than 90 dB from $0.3 \mathrm{~F}_{\mathrm{S}}$ to Nyquist. At $.25 \mathrm{~F}_{\mathrm{S}}$ the filter provides 6 dB of attenuation.

## Block Diagram




## TWO DIMENSIONAL FILTERS

PAGE
DATA SHEETS
HSP48901
$3 \times 3$ Image Filter.
4-3
HSP48908
Two Dimensional Convolver
4-12
HSP48908/833 Two Dimensional Convolver . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-28

## Features

- DC to 30 MHz Clock Rate
- Configurable for 1-D and 2-D Correlation/ Convolution.
- Dual Coefficient Mask Registers, Switchable in a Single Clock Cycle
- Two's Complement or Unsigned 8-Bit Input Data and Coefficients
- 20 Bit Extended Precision Output
- Standard $\mu \mathbf{P}$ Interface
- TTL Compatible Inputs/Outputs
- Low Power CMOS
- Available in 68 Pin PGA and PLCC Packages


## Applications

- Image Filtering
- Edge Detection/Enhancement
- Pattern Matching
- Real Time Video Filters


## Description

The Harris HSP48901 is a high speed 9-Tap FIR Filter which utilizes 8 -bit wide data and coefficients. It can be configured as a one dimensional (1-D) 9-Tap filter for a variety of signal processing applications, or as a two dimensional (2-D) filter for image processing. In the 2-D configuration, the device is ideally suited for implementing $3 \times 3$ kernel convolution. The 30 MHz clock rate allows a large number of image sizes to be processed within the required frame time for real-time video.

Data is provided to the HSP48901 through the use of programmable data buffers such as the HSP9500 or any other programmable shift register. Coefficient and pixel input data are 8-bit signed or unsigned integers, and the 20 bit extended output guarantees no overflow will occur during the filtering operation.

There are two internal register banks for storing independent $3 \times 3$ filter kernels, thus facilitating the implementation of adaptive filters and multiple filter operations on the same data.

The configuration of the HSP48901 Image Filter is controlled through a standard microprocessor interface and all inputs and outputs are TTL compatible. The HSP48901 is available in 68 pin PGA and PLCC packages.

## Block Diagram




HSP48901

## Pin Descriptions

| NAME | PLCC PIN | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| VCC | 9, 27, 45, 61 |  | The +5 V power supply pins. $0.1 \mu \mathrm{~F}$ capacitors between the VCC and GND pins are recommended. |
| GND | 18,29,38, 56 |  | The device ground. |
| CLK | 28 | 1 | Input and System clock. Operations are synchronous with the rising edge of this clock signal. |
| DIN1 (7-0) | 1-8 | 1 | Pixel Data Input bus \#1. These inputs are used to provide 8-bit pixel data to the HSP48901. The data must be provided in a synchronous fashion, and is latched on the rising edge of the CLK signal. The DIN1(0-7) inputs are also used to input data when operating in the 9 Tap FIR mode. |
| DIN2(7-0) | 10-17 | 1 | Pixel Data Input bus \#2. Same as above. These inputs should be grounded when operating in the 1D mode. |
| DIN3(7-0) | 19-26 | 1 | Pixel Data Input bus \#3. Same as above. These inputs should be grounded when operating in the 1D mode. |
| CIN7-0 | 30-37 | I | Coefficient Data Input bus. This input bus is used to load the Coefficient Mask register(s) and the Initialization register. The register to be loaded is defined by the register address bits A0-2. The CINO-7 data is loaded to the addressed register through the use of the LD\# input. |
| DOUT19-0 | $\begin{gathered} 46-55,57-60 \\ 62-67 \end{gathered}$ | 0 | Output Data bus. This 20-Bit output port is used to provide the convolution result. The result is the sum of products of the input data samples and their corresponding coefficients. |
| FRAME\# | 44 | 1 | Frame\# is an asynchronous new frame or vertical sync input. A low on this input resets all internal circuitry except for the Coefficient and INT registers. Thus, after a Frame\# reset has occurred, a new frame of pixels may be convolved without reloading these registers. |
| HOLD | 40 | 1 | The Hold Input is used to gate the clock from all of the internal circuitry of the HSP48901. This signal is synchronous, is sampled on the rising edge of CLK and takes effect on the following cycle. While this signal is active (high), the clock will have no effect on the HSP48901 and internal data will remain undisturbed. |
| A2-0 | 41-43 | 1 | Control Register Address. These lines are decoded to determine which register in the control logic is the destination for the data on the CINO-7 inputs. Register loading is controlled by the AO-2 and LD\# inputs. |
| LD\# | 39 | I | Load Strobe. LD\# is used for loading the internal registers of the HSP48901. The rising edge of LD\# will latch the CINO-7 data into the register specified by AO-2. The Address on AO-2 must be set up with respect to the falling edge of LD\# and must be held with respect to the rising edge of LD\#. |

## Functional Description

The HSP48901 can perform convolution of a $3 \times 3$ filter kernel with 8-bit image data. It accepts the image data in a raster scan, non-interlaced format, convolves it with the filter kernel and outputs the filtered image. The input and filter kernel data are both 8-bits, while the output data is 20-bits to prevent overflow during the convolution operation. Image data is input via the DIN1, DIN2, and DIN3 busses. This data would normally be provided by programmable data buffer such as the HSP9501 as illustrated in the operations section of this specification. The data is then convolved with the $3 \times 3$ array of filter coefficients. The resultant output data is then stored in the output register. The HSP48901 may also be used in a one-dimensional mode. In this configuration, it functions as a 1-D 9-tap FIR filter. Data would be input via the DIN1(0-7) bus for operation in this mode.

Initialization of the convolver is done using the CINO-7 bus to load configuration data and the filter kernel(s). The address lines AO-2 are used to address the internal registers for initialization. The configuration data is loaded using the AO-2, CINO-7 and LD\# controls as address, data and write enable, respectively. This interface is compatible with standard microprocessors without the use of any additional glue logic.

Filtered image data is output from the convolver over the DOUTO-19 bus. This output bus is 20-bits wide to provide room for growth during the convolution operation.

## 8-Bit Multiplier Array

The multiplier array consists of nine $8 \times 8$ multipliers. Each multiplier forms the product of a filter coefficient with a corresponding pixel in the input image. Input and coefficient data may be in either two's complement or unsigned integer format. The nine coefficients form a $3 \times 3$ filter kernel which is multiplied by the input pixel data and summed to form a sum of products for implementation of the convolution operation as shown below:

| FILTER KERNEL |  |  | INPUT DATA |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| A | B | C | P1 | P2 | P3 |
| D | E | F | P4 | P5 | P6 |
| G | H | I | P7 | P8 | P9 |

$$
\begin{aligned}
\text { OUTPUT } & =(A \times P 1)+(B \times P 2)+(C \times P 3) \\
& +(D \times P 4)+(E \times P 5)+(F \times P 6) \\
& +(G \times P 7)+(H \times P 8)+(I \times P 9)
\end{aligned}
$$

## Control Logic

The control logic (Figure 1) contains the Initialization Register and the Coefficient Registers. The control logic is updated by placing data on the CINO-7 bus and using the AO-2 and LD\# control lines to write to the addressed register (see Address Decoder). All of the control logic registers are unaffected by FRAME\#.


FIGURE 1. CONTROL LOGIC BLOCK DIAGRAM

## Initialization Register

The initialization register is used to appropriately configure the convolver for a particular application. It is loaded through the use of the CINO-7 bus along with the LD\# input. Bit 0 defines the input data and coefficients format (unsigned or two's complement); Bit 1 defines the mode of operation (1-D or 2-D); and Bits 2 and 3 determine the type of rounding to occur on the DOUTO-19 bus; The complete definition of the initialization register bits is given in Table 1.
table 1. INITIALIZATION REGISTER DEFINITION

| INITIALIZATION REGISTER |  |  |
| :---: | :--- | :---: |
| BIT 0 |  |  |$\quad$| FUNCTION = Input \& Coefficient |
| :---: |
| Data Format |

## Coefficient Registers (CREGO, CREG1)

The control logic contains two coefficient register banks, CREGO and CREG1. Each of these register banks is capable of storing nine 8-bit filter coefficient values ( $3 \times 3$ Kernel). The output of the registers are connected to the coefficient input of the corresponding multiplier in the $3 \times 3$ multiplier array (designated $A$ through I). The register bank to be used for the convolution is selectable by writing to the approprite address (See address decoder). All registers in a given bank are enabled simultaneously, and one of the banks is always active.
For most applications, only one of the register banks is necessary. The user can simply load CREGO after power up, and use it for the entire convolution operation. (CREGO is the default register). The alternate register bank allows the user to maintain two sets of filter coefficients and switch between them in real time. The coefficient masks are loaded via the CINO-7 bus by using AO-2 and LD\#. The selection of the particular register bank to be used in processing is also done by writing to the appropriate address (See address decoder). For example, if CREGO is being used to provide coefficients to the multipliers, CREG1 can be updated at a low rate by an external processor; then, at the proper time, CREG1 can be selected, so that the new coeffi-
cient mask is used to process the data. Thus, no clock cycles have been lost when changing between alternate $3 \times 3$ filter kernels.

The nine coefficients must be loaded sequentially over the CINO-7 bus from $A$ to $I$. The address of CREGO or CREG1 is placed on $\mathrm{AO}-2$, and then the coefficients are written to the corresponding coefficient register one at a time by using the LD\# input.

## Address Decoder

The address decoder (See Figure 1) is used for writing to the control logic of the HSP48901. Loading an internal register is done by selecting the destination register with the AO-2 address lines, placing the data on CINO-7, and asserting LD\# control line. When LD\# goes high, the data on CINO-7 is latched into the addressed register. The address map for the AO-2 bus is shown in Table 2.
While loading of the control logic registers is asynchronous to CLK, the target register in the control logic is being read synchronous to the internal clock. Therefore, care must be taken when modifying the convolver setup parameters during processing to avoid changing the contents of the registers near a rising edge of CLK. The required setup time relative to CLK is given by the specification TLCS. For example, in order to change the active coefficient register from CREGO to CREG1 during an active convolution operation, a write will be performed to the address for selecting CREG1 for internal processing ( $\mathrm{AO}-2=110$ ). In order to provide proper uninterrupted operation, LD\# should be deasserted at least TLCS prior to the next rising edge of CLK. Failure to meet this setup time may result in unpredictable results on the output of the convolver. Keep in mind that this requirement applies only to the case where changes are being made in the control logic during an active convolution operation. In a typical convolver configuration routine, where the configuration data is loaded prior to the actual convolution operation, this specification would not apply.

TABLE 2. ADDRESS MAP

| CONTROL LOGIC ADDRESS MAP |  |  |  |
| :---: | :---: | :---: | :---: |
| A2-0 |  |  | FUNCTION |
| 0 | 0 | 0 | Reserved for future use |
| 0 | 0 | 1 | Reserved for future use |
| 0 | 1 | 0 | Load Coefficient Register 0 (CREGO) |
| 0 | 1 | 1 | Load Coefficient Register 1 (CREG1) |
| 1 | 0 | 0 | Load Initialization Register (INT) |
| 1 | 0 | 1 | Select CREGO for Internal Processing |
| 1 | 1 | 0 | Select CREG1 for Internal Processing |
| 1 | 1 | 1 | No Operation |

## Control Signals

## Hold

The HOLD control input provides the ability to disable internal clock and stop all operations temporarily. HOLD is sampled on the rising edge of CLK and takes effect during the following clock cycle (Refer to Figure 2). This signal can be used to momentarily ignore data at the input of the convolver while maintaining its current output data and operational state.


FIGURE 2. HOLD OPERATION

## FRAME\#

The FRAME\# input initializes all internal flip flops and registers except for the coefficient and initialization registers. It is used as a reset between video frames and eliminates the need to re-initialize the entire HSP48901 or reload the coefficients. The registers and flip flops will remain in a reset state as long as FRAME\# is active. FRAME\# is an asynchronous input and may occur at any time. However, it must be deasserted at least tFS ns prior to the rising clock edge that is to begin operation for the next frame in order to ensure the new pixel data is properly loaded.

## Operation

A single HSP48901 can be used to perform $3 \times 3$ convolution on 8-bit image data. A block diagram of this configuration is shown in Figure 3. The inputs of an external data buffer (such as the HSP9501) are connected to the input data in parallel with the $\operatorname{DIN1}(0-7)$ lines; the outputs of the data buffer are connected to the DIN2(0-7) bus. A second external data buffer is connected between the outputs of the first buffer and the DIN3(0-7) inputs. To perform the convolution operation, a group of nine image pixels is multiplied by the $3 \times 3$ array of filter coefficients and their products are summed and sent to the output. For the example in figure 3, the pixel value in the output image at location $\mathrm{m}, \mathrm{n}$ is given by:

$$
\begin{aligned}
\operatorname{DOUT}(\mathrm{m}, \mathrm{n})= & A \times P \mathrm{Pm}-1, \mathrm{n}-1+B \times P m-1, \mathrm{n}+\mathrm{C} \times P \mathrm{Pm}-1, \mathrm{n}+1 \\
& +\mathrm{D} \times P \mathrm{Pm}, \mathrm{n}-1+E \times P m, n+F \times P m, n+1 \\
& +G \times P m+1, \mathrm{n}-1+H \times P m+1, \mathrm{n}+1 \times P m+1, \mathrm{n}+1
\end{aligned}
$$

This process is continually repeated until the last pixel of the last row of the image has been input. It can then start again with the first row of the next frame. The FRAME\# pin is used to clear the internal multiplier registers and DOUTO-19 registers between frames. The row length of the image to be convolved is limited only by the maximum length of the external data buffers.

The setup is straightforward. The user must first setup the HSP48901 by loading a new value into the initialization register. The coefficients can now be loaded one at a time from A to I via the CINO-7 coefficient bus, and the AO-2 and LD\# control lines.


## FILTER KERNEL

## IMAGE DATA

## FIGURE 3. $3 \times 3$ KERNEL ON AN 8-BIT IMAGE

Multiple filter kernels can also be used on the same image data using the dual coefficient registers CREGO and CREG1. This type of filtering is used when the characteristics of the input pixel data change over the image in such a way that no one filter produces satisfactory results for the entire image. In order to filter such an image, the characteristics of the filter itself must change while the image is being processed. The HSP48901 can perform this function with the use of an external processor. The processor is used to calculate the required new filter coefficients, loads them into the coefficient register not in use, and selects the newly loaded coefficient register at the proper time. The first coefficient register can then be loaded with new coefficients in preparation for the next change. This can be carried out with no interruption in processing, provided that the new register is selected synchronous to the convolver CLK signal.

The HSP48901 can also operate as a one dimensional 9 tap FIR filter by programming the initialization register to 1-D mode (i.e. INT bit $1=$ ' 0 '). This configuration will provide for nine sequential input values to be multiplied by the coefficient values in the selected coefficient register and provide the proper filtered output. The input bus to be used when operating in this mode is the $\operatorname{DIN1}(0-7)$ inputs.

The equation for the output in the 1-D 9-tap FIR case becomes:

$$
\begin{aligned}
\text { DOUTn }= & A \times D n-8+B \times D n-7+C \times D n-6+D \times D n-5 \\
& +E \times D n-4+F \times D n-3+G \times D n-2+H \times D n-1 \\
& +I \times D n
\end{aligned}
$$

## Frame Rate

The total time to process an image is given by the formula:

$$
T=R \times C / F
$$

where: $\quad T=$ Time to process a frame
$R=$ number of rows in the image
$C=$ number of pixels in a row
$F=$ clock rate of the HSP48901

## Absolute Maximum Ratings

| Supply Voltage | +8.0V |
| :---: | :---: |
| Input, Output or I/O Voltage Applied | GND -0.5V to $\mathrm{V}_{\mathrm{CC}}+0.5 \mathrm{~V}$ |
| Storage Temperature Range | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Maximum Package Power Dissipation at $+70^{\circ} \mathrm{C}$ | PGA Package $=2.56 \mathrm{~W}$, PLCC Package $=1.9 \mathrm{~W}$ |
| Thermal Impedance Junction To Ambient ( $\theta_{\text {ja }}$ ) | PGA Package $=41^{\circ} \mathrm{C} / \mathrm{W}$, PLCC Package $=42.8{ }^{\circ} \mathrm{C} / \mathrm{W}$ |
| Thermal Impedance Junction To Case ( $\theta_{\mathrm{jc}}$ ) | PGA Package $=16^{\circ} \mathrm{C} / \mathrm{W}$, PLCC Package $=14.9{ }^{\circ} \mathrm{C} / \mathrm{W}$ |
| Gate Count | ... 13,594 Gates |
| Junction Temperature ( $\mathrm{T}_{\mathrm{J}}$ ) | PGA Package $=+175^{\circ} \mathrm{C}$, PLCC Package $=+150^{\circ} \mathrm{C}$ |
| Lead Temperature (Soldering, Ten Seconds) | $\ldots . .300^{\circ} \mathrm{C}$ |
| ESD Classification | .. Class 1 |
| CAUTION: Stresses above those listed in the "Absolu and operation of the device at these or any other cond | se permanent damage to the device. This is a stress only rating in the operational sections of this specification is not implied. |

## Operating Conditions

$\qquad$
$\qquad$
D.C. Electrical Specifications $\quad \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| PARAMETER | SYMBOL | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Logical One Input Voltage | VIH | 2.0 | - | V | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| Logical Zero Input Voltage | VIL | - | 0.8 | V | $\mathrm{V}_{C C}=4.75 \mathrm{~V}$ |
| High Level Clock Input | VIHC | 3.0 | - | V | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| Low Level Clock Input | VILC | - | 0.8 | V | $\mathrm{V}_{C C}=4.75 \mathrm{~V}$ |
| Output HIGH Voltage | VOH | 2.6 | - | V | $\mathrm{I}^{\circ} \mathrm{OH}=-400 \mu \mathrm{~A}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Output LOW Voltage | VOL | - | 0.4 | V | $1 \mathrm{OL}=+2.0 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Input Leakage Current | 1 | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{1 N}=\mathrm{V}_{\text {CC }}$ or GND, $\mathrm{V}_{\text {CC }}=5.25 \mathrm{~V}$ |
| Standby Power Supply Current | ICCSB | - | 500 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{I N}=\mathrm{V}_{C C} \text { or } G N D, \mathrm{~V}_{C C}=5.25 \mathrm{~V} \text {, } \\ & \text { Outputs Open } \end{aligned}$ |
| Operating Power Supply Current | ICCOP | - | 120 | mA | $\begin{aligned} & f=20 \mathrm{MHz}, \mathrm{~V}_{I N}=V_{C C} \text { or } G N D \\ & V_{C C}=5.25 \mathrm{~V}(\text { Note } 1) \end{aligned}$ |

Capacitance ( $T_{A}=+25^{\circ} \mathrm{C}$, Note 2)

| PARAMETER | SYMBOL | MIN | MAX | UNITS | TEST CONDITIONS |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Input Capacitance | CIN | - | 10 | pF | FREQ $=1 \mathrm{MHz}, \mathrm{V}_{\mathrm{CC}}=$ Open, all measurements <br> are referenced to device ground. |
| Output Capacitance | CO | - | 15 | pF |  |

NOTES: 1. Power supply current is proportional to operating frequency. Typical rating for ICCOP is $6 \mathrm{~mA} / \mathrm{MHz}$.
2. Not tested, but characterized at initial design and at major process/design changes.
A.C. Electrical Specifications $\quad\left(V_{C C}=5.0 \mathrm{~V} \pm 5 \%, T_{A}=0^{\circ} \mathrm{C}\right.$ to $\left.+70^{\circ} \mathrm{C}\right)$

| PARAMETER | SYMBOL | -30 |  | -20 |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |  |  |
| Clock Period | TCYCLE | 33 | - | 50 | - | ns |  |
| Clock Pulse Width High | TPWH | 13 | - | 20 | - | ns |  |
| Clock Pulse Width Low | TPWL | 13 | - | 20 | - | ns |  |
| Data Input Setup Time | TDS | 14 | - | 16 | - | ns |  |
| Data Input Hold Time | TDH | 0 | - | 0 | - | ns |  |
| Clock to Data Out | TOUT | - | 21 | - | 30 | ns |  |
| Address Setup Time | TAS | 5 | - | 5 | - | ns |  |
| Address Hold Time | $\mathrm{T}_{\text {AH }}$ | 2 | - | 2 | - | ns |  |
| Configuration Data Setup Time | TCS | 10 | - | 12 | - | ns |  |
| Configuration Data Hold Time | $\mathrm{T}_{\mathrm{CH}}$ | 0 | - | 0 | - | ns |  |
| LD\# Pulse Width | TLPW | 13 | - | 20 | - | ns |  |
| LD\# Setup Time | TLCS | 31 | TCYCLE +2 | 40 | TCYCLE +2 | ns | Note 1 |
| HOLD Setup Time | THS | 10 | - | 12 | - | ns |  |
| HOLD Hold Time | $\mathrm{T}_{\mathrm{HH}}$ | 0 | - | 0 | - | ns |  |
| FRAME\# Pulse Width | TFPW | TCycle | - | TCYCLE | - | ns |  |
| FRAME\# Setup Time | TFS | 28 | - | 40 | - | ns | Note 2 |
| Output Rise Time | $\mathrm{T}_{\mathrm{R}}$ | - | 8 | - | 8 | ns | From 0.8 V to 2.0 V |
| Output Fall Time | $\mathrm{T}_{\mathrm{F}}$ | - | 8 | - | 8 | ns | From 2.0 V to 0.8 V |

NOTES: 1. This specification applies only to the case where a change in the active coefficient register is being selected during a convolution operation. It must be met in order to achieve predictable results at the next rising clock edge. In most applications, this selection will be made asynchronously, and the TLCS specification may be disregarded.
2. While FRAME\# is asynchronous with respect to CLK, it must be deasserted a minimum of $T_{F S} n s$ prior to the rising clock edge which is to begin loading new pixel data for the next frame.
3. A.C. Testing is performed as follows: Input levels (CLK Input) $=4.0 \mathrm{~V}$ and OV ; Input levels (All other inputs) $=0 \mathrm{~V}$ to 3.0 V ; Input timing reference levels: $(C L K)=2.0 \mathrm{~V}$, (Others) $=1.5 \mathrm{~V}$; Other timing references: $\mathrm{V}_{\mathrm{OH}} \geq 1.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}} \leq 1.5 \mathrm{~V}$; Output load per test load circuit with $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$.

Test Load Circuit


## Timing Waveforms




FRAME\# TIMING

## Features

- Single Chip $3 \times 3$ Kernel Convolution
- Programmable On-Chip Row Buffers
- DC to 32 MHz Clock Rate
- Cascadable for Larger Kernels and Images
- On-Chip 8-Bit ALU
- Dual Coefficient Mask Registers, Switchable in a Single Clock Cycle
- 8-Bit Signed or Unsigned Input and Coefficient Data
- 20-Bit Extended Precision Output
- Standard $\mu \mathrm{P}$ Interface
- TTL Compatible Inputs/Outputs
- Low Power CMOS
- Available in 84 Pin PGA and PLCC Packages


## Applications

- Image Filtering
- Edge Detection
- Adaptive Filtering
- Real Time Video Filters


## Description

The Harris HSP48908 is a high speed Two Dimensional Convolver which provides a single chip implementation of a video data rate $3 \times 3$ kernel convolution on two dimensional data. It eliminates the need for external data storage through the use of the on-chip row buffers which are programmable for row lengths up to 1024 pixels.
There are internal register banks for storing two independent $3 \times 3$ filter kernels, thus facilitating the implementation of adaptive filters and multiple filter operations on the same data. The pixel data path also includes an on-chip ALU for performing real-time arithmetic and logical pixel point operations.

Data is provided to the HSP48908 in a raster scan noninterlaced fashion, and is internally buffered on images up to 1024 pixels wide for the $3 \times 3$ convolution operation Images with larger rows and convolution with larger kerne sizes can be accommodated by using external row buffers and/or multiple HSP48908s. Coefficient and pixel input data are 8-bit signed or unsigned integers, and the 20 bit convolver output guarantees no overflow for kernel sizes up to $4 \times 4$. Larger kernel sizes can be implemented however, since the filter coefficients will normally be less than their maximum 8-bit values.

The HSP48908 is manufactured using an advanced CMOS process, and is a low power fully static design. The configuration of the device is controlled through a standard microprocessor interface and all inputs/outputs are TTL compatible. The 2-D convolver is available in 84 pin PGA and PLCC packages.

Package Pinouts



## Block Diagram


$\xrightarrow[\text { HOLD } \rightarrow \text { CLOCK }]{\substack{\text { GEN } \\ \text { GEN }}} \rightarrow$ INTERNAL CLOCK

Pin Descriptions

| NAME | PLCC PIN | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ | 21,42,63,84 |  | The +5 V power supply pins. $0.1 \mu \mathrm{~F}$ capacitors between the $\mathrm{V}_{\mathrm{CC}}$ and GND pins are recommended. |
| GND | $\begin{gathered} 19,48,54,61 \\ 69,76,82 \end{gathered}$ |  | The device ground. |
| CLK | 20 | 1 | Input and System clock. Operations are synchronous with the rising edge of this clock signal. |
| DINO-7 | 1-8 | I | Pixel Data input bus. This bus is used to provide the 8 -bit pixel input data to the HSP48908. The data must be provided in a synchronous fashion, and is latched on the rising edge of the CLK signal. |
| CINO-9 | 9-18 | 1 | Coefficient Input bus. This input bus is used to load the Coefficient Mask register(s), the Initialization register, the Row Buffer length register and the ALU microcode. It may also be used to provide a second operand input to the ALU. The definition of the CINO-9 bits is defined by the register address bits AO-2. The CINO-9 data is loaded to the addressed register through the use of the CS\# and LD\# inputs. |
| DOUTO-19 | $\begin{gathered} 49-53,55-60, \\ 62,64-68 \\ 70-72 \end{gathered}$ | 0 | Output Data bus. This 20-Bit output port is used to provide the convolution result. The result is the sum of products of the input data samples and their corresponding coefficients. The Cascade inputs CASIO-15 may also be added to the result by selecting the appropriate cascade mode in the Initialization register. |
| CASIO-15 | 29-41, 43-45 | 1 | Cascade Input bus. This bus is used for cascading multiple HSP48908s to allow convolution with larger kernels or row sizes. It may also be used to interface to external row buffers. The function of this bus is determined by the Cascade Mode bit (Bit 0 ) of the Initialization register. When this bit is set to a ' 0 ', the value on CASIO-15 is left shifted and added to DOUTO-19. The amount of the shift is determined by bits 7-8 of the Initialization register. While this mode is intended primarily for cascading, it may also be used to add an offset value, such as to increase the brightness of the convolved image. <br> When the Cascade mode bit is set to a ' 1 ', this bus is used for interfacing to external row buffers. In this mode the bus is divided into two 8-bit busses (CASIO-7 and CASI8-15), thus allowing two additional pixel data inputs. The cascade data is sent directly to the internal multiplier array which allows for larger row sizes without using multiple HSP48908s. |
| CASOO-7 | 73-75, 77-81 | 0 | Cascade Output bus. This bus is used primarily during cascading to handle larger frames and/or kernel sizes. This output data is the data on DINO-7 delayed by twice the programmed internal row buffer length. |
| FRAME\# | 46 | 1 | Frame\# is an asynchronous new frame or vertical sync input. A low on this input resets all internal circuitry except for the Coefficient, ALU, AMC, EOR and INT registers. Thus, after a Frame\# reset has occurred, a new frame of pixels may be convolved without reloading these registers. |
| EALU | 28 | 1 | Enable ALU Input. This control line gates the clock to the ALU Register. When it is high, the data on CINO-7 is loaded on the next rising clock edge. When EALU is low, the last value loaded remains in the ALU register. |
| HOLD | 22 | I | The Hold Input is used to gate the clock from all of the internal circuitry of the HSP48908. This signal is synchronous, is sampled on the rising edge of CLK and takes effect on the following cycle. While this signal is active (high), the clock will have no effect on the HSP48908 and internal data will remain undisturbed. |
| RESET\# | 47 | 1 | Reset is an asynchronous signal which resets all internal circuitry of the HSP48908. All outputs are forced low in the reset state. |
| OE\# | 83 | 1 | Output Enable. The OE\# input controls the state of the Output Data bus (DOUTO-19). A LOW on this control line enables the port for output. When OE\# is HIGH, the output drivers are in the high impedance state. Processing is not interupted by this pin. |

## Pin Descriptions (Continued)

| NAME | PLCC PIN | TYPE |  |
| :---: | :---: | :---: | :--- |
| AO-2 | $25-27$ | I | Control Register Address. These lines are decoded to determine which register <br> in the control logic is the destination for the data on the CINO-9 inputs. <br> Register loading is controlled by the AO-2, LD\# and CS\# inputs. |
| LD\# | 23 | 1 | Load Strobe. LD\# is used for loading the internal registers of the HSP48908. <br> When CS\# and LD\# are active, the rising edge of LD\# will latch the CINO-7 data <br> into the register specified by AO-2. |
| CS\# | 24 | I | Chip Select. The Chip Select input enables loading of the internal registers. <br> When CS\# is low, the AO-2 address lines are decoded to determine the meaning <br> of the data on the CINO-7 bus. The rising edge of LD\# will then load the <br> addressed register. |

## Functional Description

The HSP48908 two-dimensional convolver performs convolution of $3 \times 3$ filter kernels. It accepts the image data in raster scan, non-interlaced format, convolves it with the filter kernel and outputs the filtered image. The input and filter kernel data are both 8-bits, while the output data is 20bits to prevent overflow during the convolution operation. The HSP48908 has internal storage for two $3 \times 3$ filter kernels and is capable of buffering two $1024 \times 8$-bit rows for true single chip operation at video frame rates. An 8-bit ALU in the input pixel data path allows the user to perform arithmetic and logical operations on the input data in real time during the convolution. Multiple devices can also be cascaded together for larger kernel convolution, larger frame sizes and increased precision.
Image data is input to the convolver via the DINO-7 bus. The data is then operated on by the ALU, stored in the row buffers and convolved with the $3 \times 3$ array of filter coefficients. The resultant output data is then latched into the output register. The row buffers are preprogrammed to the length of one row of the input image to enable the user to input the image data one pixel at a time in raster scan format without having to provide external storage.

Initialization of the convolver is done using the CINO-7 bus to load configuration data, such as the filter kernel(s) and the length of the row buffers. The address lines AO-2 are used to address the internal registers for initialization. The configuration data is loaded using the AO-2, CINO-9, CS\# and LD\# controls as address, data, chip select and write enable, respectively. This interface is compatible with standard microprocessors without the use of any additional glue logic.

Filtered image data comes out of the convolver over the DOUTO-19 bus. This output bus is 20-bits wide to provide room for growth during the convolution operation. The 20-bit bus will allow the use of up to $4 \times 4$ kernels (using multiple 48908's) without overflow. However, in practical applications, much larger kernel sizes can be implemented without overfiow since the filter coefficients are typically much smaller than 8-bit full scale values. DOUT0-19 is also a registered, three state bus to facilitate cascading multiple chips and to allow the HSP48908 to reside on a standard microprocessor system bus.

Multiple convolvers can also be cascaded together for kernel sizes larger than $3 \times 3$ and for convolution on images with row lengths longer than 1024 pixels. The maximum kernel size is dependent upon the magnitude of the image data and the coefficients in a given application; care must always be taken with very large kernel sizes to prevent overflow of the 20-bit output.

## Data Input

Image data coming into the 2D Convolver passes through a programmable pipeline delay before being sent to the ALU. The amount of delay ( 1 to 4 clock cycles) is set in the initialization register during configuration setup (See Control Logic). Delays greater than one are used primarily in cascading multiple HSP48908s to align data sequences for proper output (See Operation).

## Arithmetic Logic Unit

The on-chip ALU provides the user with the capability of performing pixel point operations on incoming image data. Depending on the instruction in the ALU microcode register, the ALU can perform any one of 19 arithmetic and logical functions, and shift the resulting number left or right by up to 3 bits. Tables 1 and 2 show the available ALU functions and the 10-bit associated microcode to be loaded into the ALU microcode register. Note that the shifts take place on the output of the ALU and are completely independent of the logical or arithmetic operation being performed. The first input (A) of the ALU is taken from the pixel input bus (DINO-7). The second input (B) is taken from the ALU Register. The ALU Register is loaded via the CINO-7 bus while the EALU control line is valid (see EALU).

TABLE 1. ALU SHIFT OPERATIONS

| ALU MICROCODE REGISTER |  |  |  |
| :--- | :--- | :--- | :--- |
| REGISTER BIT |  |  | OPERATION |
| 9 | $\mathbf{8}$ | $\mathbf{7}$ |  |
| 0 | 0 | 0 | No Shift (Default) |
| 0 | 0 | 1 | Shift Right 1 |
| 0 | 1 | 0 | Shift Right 2 |
| 0 | 1 | 1 | Shift Right 3 |
| 1 | 0 | 0 | Shift Left 1 |
| 1 | 0 | 1 | Shift Left 2 |
| 1 | 1 | 0 | Shift Left 3 |
| 1 | 1 | 1 | Not Valid |

table 2. ALU PIXEL OPERATIONS

| REGISTER BIT |  |  |  |  | OPERATION |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 6 | 5 | 4 | 3 | 2 | 1 | 0 | OPPE |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | Logical (OOOO0000) |
| 1 | 1 | 1 | 1 | 0 | 0 | 0 | Logical (111111111) |
| 0 | 0 | 1 | 1 | 0 | 0 | 0 | Logical (A) (Default) |
| 0 | 1 | 0 | 1 | 0 | 0 | 0 | Logical (B) |
| 1 | 1 | 0 | 0 | 0 | 0 | 0 | Logical (A\#) |
| 1 | 0 | 1 | 0 | 0 | 0 | 0 | Logical (B\#) |
| 0 | 1 | 1 | 0 | 0 | 0 | 1 | Arithmetic (A + B) |
| 1 | 0 | 0 | 1 | 0 | 1 | 0 | Arithmetic (A - B) |
| 1 | 0 | 0 | 1 | 1 | 0 | 0 | Arithmetic (B - A) |
| 0 | 0 | 0 | 1 | 0 | 0 | 0 | Logical (A AND B) |
| 0 | 0 | 1 | 0 | 0 | 0 | 0 | Logical (A AND B\#) |
| 0 | 1 | 0 | 0 | 0 | 0 | 0 | Logical (A\# AND B) |
| 0 | 1 | 1 | 1 | 0 | 0 | 0 | Logical (A OR B) |
| 1 | 0 | 1 | 1 | 0 | 0 | 0 | Logical (A OR B\#) |
| 1 | 1 | 0 | 1 | 0 | 0 | 0 | Logical (A\# OR B) |
| 1 | 1 | 1 | 0 | 0 | 0 | 0 | Logical (A NAND B) |
| 1 | 0 | 0 | 0 | 0 | 0 | 0 | Logical (A NOR B) |
| 0 | 1 | 1 | 0 | 0 | 0 | 0 | Logical (A XOR B) |
| 1 | 0 | 0 | 1 | 0 | 0 | 0 | Logical (A XNOR B) |

## EALU

The EALU control pin enables loading of the ALU Register. While the EALU line is high, the data on CINO-7 is latched into the ALU Register on the rising edge of CLK. When EALU goes low, the current value in the ALU register is held until EALU is again asserted. Note that the ALU loading operation makes use of the CINO-7 inputs, but is completely independent of CS\# and LD\#. Therefore, in order to prevent overwriting an internal register, care must be taken to ensure that CS\# and LD\# are not active during an EALU cycle.

## Programmable Row Buffers

The programmable row buffers are used for buffering raster input data for the convolution operation. They can be thought of as programmable shift registers which can each store up to 10248 -bit values, thus delaying each pixel by up to 1024 clock cycles. Functionally, each row buffer can be represented as a set of registers connected as a $1024 \times$ 8 -bit serial shift register. The output of each buffer can be
represented by the equation $Q=D(n-r)$, where $Q$ is the row buffer output, $D$ is the buffer input, $n$ is the current clock cycle and $r$ is the preprogrammed row length of the input image. Since the two buffers are connected in series, the data at the cascade outputs (CASOO-7) is delayed by two row delays and may be used for cascading multiple convolvers for larger kernel sizes and/or row lengths. The programmable row buffers can also be bypassed by selecting the appropriate cascade mode in the initialization register. This mode allows the use of external row buffers for convolving with row lengths longer than 1024 pixels.

## 8-Bit Multiplier Array

The multiplier array consists of nine $8 \times 8$ multipliers. Each multiplier forms the product of a filter coefficient with a corresponding pixel in the input image. Input and coefficient data may be in either two's complement or unsigned integer format. The nine coefficients form a $3 \times 3$ filter kernel which is multiplied by the input pixel data and summed to form a sum of products for implementation of the convolution operation as shown below:

| INPUT DATA |  | FILTER KERNEL |  |
| :---: | :---: | :---: | :---: |
| $P 1$ | $P 2$ | $P 3$ | $A B C$ |
| $P 4$ | $P 5$ | $P 6$ | DEF |
| $P 7$ | $P 8$ | $P 9$ | $G H I$ |
| OUTPUT $=$ | $(A \times P 1)+(B \times P 2)+(C \times P 3)$ |  |  |
|  | $+(D \times P 4)+(E \times P 5)+(F \times P 6)$ |  |  |
|  | $+(G \times P 7)+(H \times P 8)+(I \times P 9)$ |  |  |

## Control Logic

The control logic (Figure 1) contains the ALU Microcode Register, the Initialization Register, the Row Length Register, and the Coefficient Registers. The control logic is updated by placing data on the CINO-9 bus and using the AO-2, CS\# and LD\# control lines to write to the addressed register (see Address Decoder). All of the control logic registers are loaded with their default values on RESET\#, and are unaffected by FRAME\#.

## ALU Microcode Register

The ALU microcode register is used to store the command word for the ALU. The ALU command word is a 10-bit instruction divided into two fields: the lower 7 bits determine the ALU operation and the upper 3 bits specify the number of shifts which occur. The ALU command words are defined in Tables 1 and 2 (See ALU section).


FIGURE 1. CONTROL LOGIC BLOCK DIAGRAM

## Initialization Register

The initialization register is used to appropriately configure the convolver for a particular application. It is loaded through the use of the CINO-7 bus along with the CS\# and LD\# inputs. Bit 0 defines the type of cascade mode to be used; Bits 1 and 2 select the number of delays to be included in the input pixel data path; Bits 3 and 4 define the input and coefficient data format; Bits 5 and 6 determine the type of rounding to occur on the DOUTO-19 bus; Bits 7 and 8 define the shift applied to the cascade input data. The complete definition of the initialization register bits is given in Table 3.

TABLE 3. INITIALIZATION REGISTER DEFINITION

| INITIALIZATION REGISTER |  |  |
| :---: | :---: | :---: |
| BIT 0 |  | FUNCTION = CASCADE MODE |
| 0 |  | Multiplier input from internal row buffers <br> Multiplier input from external buffers |
| 2 BIT 1 |  | FUNCTION = INPUT DATA DELAY |
| 0 0 1 1 | $\begin{aligned} & 0 \\ & 1 \\ & 0 \\ & 1 \end{aligned}$ | No data delay registers used <br> One data delay register used <br> Two data delay registers used <br> Three data delay registers used |
| BIT 3 |  | FUNCTION = INPUT DATA FORMAT |
| 0 |  | Unsigned integer format <br> Two's complement format |
| BIT 4 |  | FUNCTION = COEFFICIENT DATA FORMAT |
| 0 |  | Unsigned integer format <br> Two's complement format |
| 6 BIT 5 |  | FUNCTION = OUTPUT ROUNDING |
| 0 0 1 1 | $\begin{aligned} & 0 \\ & 1 \\ & 0 \\ & 1 \end{aligned}$ | No Rounding <br> Round to 16 bits (i.e. DOUT19-4) <br> Round to 8 bits (i.e. DOUT19-12) <br> Not Valid |
| 8 BIT 7 |  | FUNCTION = CASIO-15 INPUT SHIFT |
| 0 | 0 1 0 | No Shift <br> Shift CASIO-15 left two <br> Shift CASIO- 15 left four <br> Shift CASIO-15 left eight |

## Row Length Register

The row length register is used to store the programmed number of delays for the internal row buffers. The programmed delay is set equal to the row length $(r)$ of the input image. The input pixel data is stored in the row buffers to allow corresponding pixels of adjacent rows to be synchronously sent to the mutiplier array for the convolution operation. The row length register is programmable with values from 0 to 1023, with 0 defined as a row length of 1024. Row lengths of 1 or 2 lead to meaningless results for a $3 \times 3$ kernel convolution, while a row length of 3 defines a $1 \times 9$ filter (See Operation section). The Row Length register is written through the use of AO-2, CS\# and LD\#. Once the row length register has been loaded, the convolver must be reset before a new row length can be entered; failure to toggle RESET\# before reloading the Row Length Register will result in the new value being ignored. After RESET\# returns high, the user has 1024 cycles of CLK to load the Row Length Register. After 1024 CLK cycles, the Row Length Register is automatically set to 0 (row length $=1024$ ) and further writes to this register are ignored.

## Coefficient Registers (CREGO, CREG1)

The control logic contains two coefficient register banks, CREGO and CREG1. Each of these register banks is capable of storing nine 8-bit filter coefficient values ( $3 \times 3$ Kernel). The output of the registers are connected to the coefficient input of the corresponding multiplier in the $3 \times 3$ multiplier array (designated $A$ through I). The register bank to be used for the convolution is selectable by writing to the appropriate address (See address decoder). All registers in a given bank are enabled simultaneously, and one of the banks is always active.

For most applications, only one of the register banks is necessary. The user can simply load CREGO after power up, and use it for the entire convolution operation. (CREGO is the default register). The alternate register bank allows the user to maintain two sets of filter coefficients and switch between them in real time. The coefficient masks are loaded via the CIN bus by using AO-2, CS\# and LD\#. The selection of the particular register bank to be used in processing is also done by writing to the appropriate address (See address decoder). For example, if CREGO is being used to provide coefficients to the multipliers, CREG1 can be updated at a low rate by an external processor; then, at the proper time, CREG1 can be selected, so that the new coefficient mask is used to process the data. Thus, no clock cycles have been lost when changing between alternate $3 x$ 3 filter kernels.

The nine coefficients must be loaded sequentially over the CINO-7 bus from A to $I$. The address of CREGO or CREG1 is placed on AO-2, and then the nine coefficients are written to the corresponding coefficient register one at a time by using the CS\# and LD\# inputs.

## Address Decoder

The address decoder (See Figure 1) is used for writing to the control logic of the HSP48908. Loading an internal register is done by selecting the destination register with the AO-2 address lines, placing the data on $\mathrm{CINO}-9$, and asserting the CS\# and LD\# control lines. When either CS\# or LD\# goes high, the data on the CINO-9 lines is latched into the addressed register. The address map for the AO-2 bus is shown in Table 4.

While loading of the control logic registers is asynchronous to CLK, the target register in the control logic is being read synchronous to the internal clock. Therefore, care must be taken when modifying the convolver setup parameters during processing to avoid changing the contents of the registers near a rising edge of CLK. The required setup time relative to CLK is given by the specification TLCS. For example, in order to change the active coefficient register from CREGO to CREG1 during an active convolution operation, a write will be performed to the address for selecting CREG1 for internal processing ( $\mathrm{A} 2-0=110$ ). In order to provide proper uninterrupted operation, LD\# should be deasserted at least TLCS prior to the next rising edge of CLK. Failure to meet this setup time may result in unpredictable results on the output of the convolver for one clock cycle. Keep in mind that this requirement applies only to the case where changes are being made in the control logic during an active convolution operation. In a typical convolver configuration routine, this specification would not be applicable.

TABLE 4. ADDRESS MAP

| CONTROL LOGIC ADDRESS MAP |  |
| :--- | :--- |
| A2-0 | Function |
| 000 | Load Row Length Register (RLR) |
| 001 | Load ALU MIcrocode Register (AMC) |
| 010 | Load Coefficient Register 0 (CREGO) |
| 011 | Load Coefficient Register 1 (CREG1) |
| 100 | Load Initialization Register (INT) |
| 101 | Select CREGO for Internal Processing |
| 110 | Select CREG1 for Internal Processing |
| 111 | No Operation |

## Cascade I/O

## Cascade Input

The cascade input lines (CASIO-15) have two primary functions. The first is used to allow convolutions with kernel sizes larger than $3 \times 3$. This can be implemented by connecting the DOUT bus of one convolver to the cascade inputs of another. The second function is for convolution on images wider than 1024 pixels. This type of operation can be implemented by using external row buffers to supply the pixel input data to the CASIO-15 inputs. The cascade input functions are determined by Initialization Register bit 0. When this bit is set to a ' 0 ', the cascade input data is added
to the convolver output. In this manner, multiple convolvers can be used to implement larger kernel convolution. When Initialization Register bit 0 is a ' 1 ', the data on CASIO-15 is divided into two 8 -bit portions and is sent to the $3 \times 3$ multiplier array (Refer to Block Diagram). This mode of operation allows the use of external row buffers for convolution of images with row sizes larger than 1024. Examples of these configurations are given in the Operations section of this specification.

The data on the cascade inputs (CASIO-15) can also be left shifted by $0,2,4$, or 8 bits. The amount of shift is determined by bits 7 and 8 of the Initialization Register (See Table 3). CASIO-15 is shifted by the specified number of bits and is added to the 20-bit output DOUT 0-19. The shifting function provides a method for cascading multiple HSP48908s and allowing a selectable amount of output growth while maximizing the resolution of the convolver result.

The cascade inputs can also be used as a simple way to add an offset to the convolved image. Bit 0 of the configuration register would be set to ' 0 ', and the desired offset placed on the CASIO-15 inputs. While multiple offets can be used and changed during the convolution operation, note that the required data setup and hold times with respect to CLK (TDS and TDH) must be met.

## Cascade Output

The cascade output lines (CASOO-7) are outputs from the second row buffer. Data at these outputs is the input pixel data delayed by two times the preprogrammed value in the row length register. The cascade outputs are used to cascade multiple convolvers by connecting the cascade outputs of one device to the data inputs of another (See Operation section).

## Control Signals

## HOLD

The HOLD control input provides the ability to disable internal clock and stop all operations temporarily. HOLD is sampled on the rising edge of CLK and takes effect during the fo'lowing clock cycle (Refer to Figure 2). This signal can be used to momentarily ignore data at the input of the convolver while maintaining its current output data and operational state.


FIGURE 2. HOLD OPERATION

## RESET\#

The RESET\# signal initializes all internal flip flops and registers in the HSP48908. It is an asynchronous signal, and the convolver will remain in the reset state as long as RESET\# is asserted. On reset, all internal registers are set to zero or their default values, and all outputs are forced low. Following a reset, the default values in the internal registers will define the following mode of operation: internal row buffers used, line length $=1024$, no input data delay, logical A operation: output of ALU $=A$ input (DINO-7) output rounding and unsigned input data format.
The convolver can be reset at any time, but must be reset before updating the Row Length register in order to provide proper operation. After RESET\# returns high, the user has 1024 cycles of CLK to load the Row Length Register. After 1024 CLK cycles, the Row Length Register is automatically set to 0 (row length $=1024$ ) and further writes to this register are ignored.

## FRAME\#

This FRAME\# input initializes all internal flip flops and registers except for the coefficient, ALU, ALU microcode, row length, and initialization registers. It is used to reset the convolver between video frames and eliminates the need to re-initialize the entire convolver or reload the coefficients. FRAME\# is an asynchronous input and may occur at any time. However, it must be deasserted at least TFS ns prior to the rising clock edge that is to begin operation for the next frame. While FRAME\# is asserted, the registers and flipflops will remain in the reset state.

## Operation

The HSP48908 has three basic modes of operation: single chip mode, operation with external row buffers and multiple devices cascaded together for larger convolution kernels and/or longer row lengths. The mode of operation is defined by the contents of the initialization register, and can be modified at any time by a microprocessor or other external means.

## Single Chip Mode

A single HSP48908 can be used to perform $3 \times 3$ convolution on 8-bit image data with row lengths up to 1024. A block diagram of this configuration is shown in Figure 3. In this mode of operation, the image data is input into the DINO-7 bus in a raster scan order starting with the upper left pixel. To perform the convolution operation, a group of nine image pixels is multiplied by the $3 \times 3$ array of filter coefficients and their products are summed and sent to the output. For the example in Figure 3, the pixel value in the output image at location $(\mathrm{m}, \mathrm{n})$ is given by:

$$
\begin{array}{rlrl}
\operatorname{POUT}(m, n) & \left(A \times P_{m-1, n-1}\right) & +\left(B \times P_{m-1, n}\right) & +\left(C \times P_{m-1, n+1}\right) \\
+ & \left(D \times P_{m, n-1)}+\left(E \times P_{m, n}\right)\right. & +\left(F \times P_{m, n+1}\right) \\
+ & \left(G \times P_{m+1, n-1)}+\left(H \times P_{m+1, n}\right)\right. & +\left(\left(1 \times P_{m+1, n+1}\right)\right.
\end{array}
$$

This process is continually repeated until the last pixel of the last row of the image has been input. It can then start again with the first row of the next frame. The FRAME\# pin is used output image at location $(m, n)$ is given by:
to clear the row buffers, multiplier input latches and DOUTO-19 registers between frames.
The setup for single chip operation is straightforward. After reset, the convolver is configured for row lengths of 1024 pixels, no input data delay, no ALU pixel point operations, no output rounding, and an unsigned input format. The user can change this default setup by loading new values into the ALU microcode, initialization and row length registers. RESET\# also clears the coefficient registers and CREGO is selected for internal processing. The user can now load the coefficients one at a time from $A$ to $I$ via the $\mathrm{CINO}-7$ inputs and the LD\# and CS\# control lines.

Multiple filter kernels can also be used on the same image data using the dual coefficient registers CREGO and CREG1. This type of filtering is used when the characteristics of the input pixel data change over the image in such a way that no single filter produces satisfactory results for the entire image. In order to filter such an image, the characteristics of the filter itself must change while the image is being processed. The HSP48908 can perform this function with the use of an external processor. The processor is used to calculate the required new filter coefficients, loads them into the coefficient register not in use, and selects the newly loaded coefficient register at the proper time. The first coefficient register can then be loaded with new coefficients in preparation for the next change. This can be carried out with no interruption in processing, provided that the new register is selected synchronous to the convolver CLK signal.
The HSP48908 can also operate as a one dimensional 9 tap FIR filter by programming the row buffer length register with a value of 3 and setting the initialization register bit 0 to a ' 0 '. This configuration will provide for nine sequential input values in the input to be multiplied by the coefficient values in the selected coefficient register and provide the proper filtered output. The equation for the output then becomes:

$$
\begin{aligned}
D_{\text {OUTn }}= & A \times D_{n-8}+B \times D_{n-7}+C \times D_{n-6}+D \times D_{n-5} \\
& +E \times D_{n-4}+F \times D_{n-3}+G \times D_{n-2}+H \times D_{n-1} \\
& +1 \times D_{n}
\end{aligned}
$$

| FILTER KERNEL | IMAGE DATA |  |  |
| :---: | :--- | :--- | :--- |
| ABC | $P_{m-1, n-1}$ | $P_{m-1, n}$ | $P_{m-1, n+1}$ |
| DEF | $P_{m, n-1}$ | $P_{m, n}$ | $P_{m, n+1}$ |
| GHI | $P_{m+1, n-1}$ | $P_{m+1, n}$ | $P_{m+1, n+1}$ |

FIGURE 3. $3 \times 3$ KERNEL ON AN 8-BIT, $1024 \times$ N IMAGE


## Use Of External Row Buffers

External row buffers may be used when frames with row sizes larger than 1024 pixels are desired. To use the HSP48908 in this mode, the cascade mode control bit (bit 0 ) of the initialization register is set to ' 1 ' to allow the data on the cascade inputs CASIO-15 to go to the multiplier array. The inputs of one external row buffer (such as the HSP9500) are connected to the input data in parallel with the DINO-7 lines of the convolver; and its outputs are connected to the CASIO-7 inputs (See Figure 4). A second external row buffer is connected between the outputs of the first row buffer and the CASI8-15 inputs of the convolver. The convolution operation can then be performed by the HSP48908 in the same manner as the single chip mode. The row length in this configuration is limited only by the maximum length of the external row buffers. Note that when using the convolver in this configuration, the programmable input data delays and ALU will only operate on the data entering the DINO-7 inputs (i.e. the bottom row of the $3 \times 3$ sum of products). If higher order filters or pixel point operations are required when using external row buffers, these functions must be implemented externally by the user.


FIGURE 4. USING EXTERNAL ROW BUFFERS WITH THE HSP48908

## Cascading Multiple HSP48908's

Multiple HSP48908s are capable of being cascaded to perform convolution on images with row lengths longer than 1024 pixels and with kernel sizes larger than $3 \times 3$. Figure 5 illustrates the use of two HSP48908s to perform a $3 \times 3$ kernel convolution on a $2 \mathrm{~K} \times \mathrm{N}$ frame. In this case, the cascade mode control bit (Bit 0 ) of both initialization registers are set to a ' 0 '. The loading of the coefficients is

| $3 \times 3$ FILTER <br> KERNEL | COEFFICIENT MASKS |  |
| :---: | :---: | :---: |
|  | CONVOLVER \#1 | CONVOLVER \#2 |
| ABC | DEF | ABC |
| DEF | 000 | 000 |
| GHI | GHI | 000 |



FIGURE 5. $3 \times 3$ KERNEL CONVOLUTION ON A $2 \mathrm{~K} \times \mathrm{N}$ IMAGE
accomplished just as before. However, the $3 \times 3$ mask is divided into two portions for proper convolution output as follows: Convolver \#1 = DEF000GHI and Convolver \#2 = ABC000000.

The same configuration can be used to perform $3 \times 5$ convolution on a $1 \mathrm{~K} \times \mathrm{N}$ frame simply by setting up the coefficients of the convolvers to implement the $3 \times 5$ mask as indicated below:

| $3 \times 5$ FILTER <br> KERNEL | COEFFICIENT MASKS |  |
| :---: | :---: | :---: |
|  | CONVOLVER \#1 | CONVOLVER \#2 |
| ABC | GHI | ABC |
| DEF | JKL | DEF |
| GHI | MNO | 000 |
| JKL |  |  |
| MNO |  |  |

In addition to larger frames, larger kernels can also be addressed through cascadability. An example of the configuration for a $5 \times 5$ kernel convolution on a $1 \mathrm{~K} \times \mathrm{N}$ frame is shown in Figure 6. Note that in this configuration, convolver \#2 incorporates a 3 clock cycle delay $(z-3)$ and convolvers 3 and 4 incorporate 2 clock cycle delays ( $z-2$ ) at their pixel inputs. These delays are required to ensure proper data alignment in the final sum of products output of the cascaded convolvers. The number of delays required at the pixel input is programmable through the use of bits 1 and 2 of the initialization register (Refer to Table 3).


| 5X5 | CONVOLVER <br> FILTERKERNEL |  |
| :---: | :---: | :---: |
| COEFFICIENT MASKS |  |  |
| FGCDE | OKL | OAB |
| KLMNO | OPQ | OFG |
| PQRST | OUV | 000 |
| UVWXY |  |  |
|  | MNO | CDE |
|  | RST | HIJ |
|  | WXY | 000 |

FIGURE 6. $5 \times 5$ KERNEL CONVOLUTION ON A $1 \mathrm{~K} \times$ N IMAGE

In any of the cascade configurations, only 16 bits of the 20bit output (DOUTO-19) can be connected to the 16 cascade inputs (CASIO-15) of another convolver. Which 16 bits are chosen depends upon the amount of growth expected at the convolver output. The amount of growth is dependent on the input pixel data and the coefficients selected for the convolution operation. The maximum possible growth is calculated in advance by the user, and the convolvers are set up to appropriately shift the cascade input data through the use of bits 7 and 8 of the initialization register (See Cascade I/O). Refering to Figure 6, if the maximum growth out of convolver \#1 extends into bit 16 or 17, then DOUT2-17 are connected to the cascade inputs of convolver \#3, which is programmed to shift the input data left by two bits. Likewise, if the data out of convolver \#3 grows into bit 18 or 19, then DOUT4-19 are connected to the CASIO-15 inputs of convolver \#2, which is programmed to shift the input left by 4 bits.

## Cascading For Row Sizes Larger Than 1024

Combining large images with large kernels is accomplished by implementing external row buffers, external data delay registers and external adders. Figure 7 illustrates a circuit
for implementation of a $5 \times 5$ convolution on a $2 \mathrm{~K} \times \mathrm{N}$ image. The $5 \times 5$ coefficient mask is again distributed among the four HSP48908's. The width of the DOUT path to be used in this case is dependent on the amount of resolution required and the amount of growth expected at the output.

## Frame Rate

The total time to process an image is given by the formula:
$\mathrm{T}=\mathrm{R} \times \mathrm{C} / \mathrm{F}$
where:
$T=$ time to process a frame
$R=$ number of rows in the image
C = number of pixels in a row
F = clock rate of the HSP48908
Note that the size of the kernel does not enter into the equation. Convolvers cascaded for larger kernels or larger frame sizes, as in the examples shown, process the image in the same amount of time as a single HSP48908 convolving the image with a $3 \times 3$ kernel. Therfore, there is no performance degradation when cascading multiple HSP48908s.

Absolute Maximum Ratings

| Supply Voltage | +8.0V |
| :---: | :---: |
| Input, Output or I/O Voltage Applied | . GND -0.5V to $\mathrm{V}_{\mathrm{CC}}+0.5 \mathrm{~V}$ |
| Storage Temperature Range | . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Maximum Package Power Dissipation @ $70^{\circ} \mathrm{C}$ | 2.46 W (PLCC), 3.04W (PGA) |
| Thermal Impedance Junction To Case ( $\theta_{\mathrm{jc}}$ ) | $10.26^{\circ} \mathrm{C} / \mathrm{W}$ (PLCC), $7.73{ }^{\circ} \mathrm{C} / \mathrm{W}$ (PGA) |
| Thermal Impedance Junction To Ambient ( $\mathrm{\theta}_{\mathrm{ja}}$ ) . | $32.47{ }^{\circ} \mathrm{C} / \mathrm{W}$ (PLCC), $34.56^{\circ} \mathrm{C} / \mathrm{W}$ (PGA) |
| Gate Count | .. 190,000 Transistors |
| Maximum Junction Temperature ( $\mathrm{T}_{\mathrm{J}}$ ) | $150{ }^{\circ} \mathrm{C}$ (PLCC), $175{ }^{\circ} \mathrm{C}$ (PGA) |
| Lead Temperature (Soldering, Ten Seconds) | .$+300^{\circ} \mathrm{C}$ |
| ESD Classification | . Class 1 |

CAUTION: Stresses above those listed in the "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.

## Operating Conditions

Operating Voltage Range +4.75 V to +5.25 V
Operating Temperature Range $.0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
D.C. Electrical Specifications $\quad\left(V_{C C}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $\left.+70^{\circ} \mathrm{C}\right)$

| PARAMETER | SYMBOL | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Logical One Input Voltage | $\mathrm{V}_{\mathrm{IH}}$ | 2.0 | - | V | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| Logical Zero Input Voltage | $\mathrm{V}_{\text {IL }}$ | - | 0.8 | v | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| High Level Clock Input | $\mathrm{V}_{\text {IHC }}$ | 3.0 | - | V | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| Low Level Clock Input | $V_{\text {ILC }}$ | - | 0.8 | V | $\mathrm{V}_{C C}=4.75 \mathrm{~V}$ |
| Output HIGH Voltage | $\mathrm{V}_{\mathrm{OH}}$ | 2.6 | - | V | $\mathrm{IOH}^{\mathrm{H}}=-400 \mu \mathrm{~A}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Output LOW Voltage | $\mathrm{V}_{\mathrm{OL}}$ | - | 0.4 | V | $\mathrm{I}^{\mathrm{OL}}=+2.0 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Input Leakage Current | 1 | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{1}=\mathrm{V}_{\text {CC }}$ or $\mathrm{GND}, \mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| 1/O Leakage Current | 10 | -10 | 10 | $\mu \mathrm{A}$ | $V_{\text {OUT }}=V_{\text {CC }}$ or GND |
| Standby Power Supply Current | ${ }^{\prime} \mathrm{CCSB}$ | - | 500 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{I N}=V_{C C} \text { or } G N D, V_{C C}=5.25 \mathrm{~V}, \\ & \text { Outputs Open } \end{aligned}$ |
| Operating Power Supply Current | I'cop | - | 160 | mA | $\begin{aligned} & f=20 \mathrm{MHz}, \mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}} \text { or } \mathrm{GND} \\ & \text { Note } 1 \end{aligned}$ |

Capacitance $\left(T_{A}=+25^{\circ} \mathrm{C}\right.$, Note 2)

| PARAMETER | SYMBOL | MIN | MAX | UNITS | TEST CONDITIONS |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Input Capacitance | $\mathrm{C}_{\mathrm{IN}}$ | - | 10 | pF | FREQ $=1 \mathrm{MHz}, \mathrm{V}_{\mathrm{CC}}=$ Open, all measurements <br> are referenced to device ground. |
| Output Capacitance | $\mathrm{C}_{\mathrm{O}}$ | - | 12 | pF |  |

NOTES: 1. Power supply current is proportional to operating frequency.
Typical rating for $I_{\text {CCOP }}$ is $8.0 \mathrm{~mA} / \mathrm{MHz}$.
2. Not tested, but characterized at initial design and at major process/design changes.
A.C. Electrical Specifications ( $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| PARAMETER | SYMBOL | -32 (32MHz) |  | -20 (20MHz) |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |  |  |
| Clock Period | TCyCLE | 31 | - | 50 | - | ns |  |
| Clock Pulse Width High | TPWH | 12 | - | 20 | - | ns |  |
| Clock Pulse Width Low | TPWL | 13 | - | 20 | - | ns |  |
| Data Input Setup Time | TDS | 13 | - | 14 | - | ns |  |
| Data Input Hold Time | TDH | 0 | - | 0 | - | ns |  |
| Clock to Data Out | TOUT | - | 16 | - | 22 | ns |  |
| Address Setup Time | TAS | 13 | - | 13 | - | ns |  |
| Address Hold Time | $\mathrm{T}_{\text {AH }}$ | 0 | - | 0 | - | ns |  |
| Configuration Data Setup Time | $\mathrm{T}_{\text {CDS }}$ | 14 | - | 16 | - | ns |  |
| Configuration Data Hold Time | ${ }^{T}$ CDH | 0 | - | 0 | - | ns |  |
| LD\# Pulse Width | TLPW | 12 | - | 20 | - | ns |  |
| LD\# Setup Time | TLCS | 25 | - | 30 | - | ns | Note 1 |
| CINO-7 Setup to CLK | TCS | 14 | - | 16 | - | ns |  |
| CS\# Setup To LD\# | $\mathrm{T}_{\text {CSS }}$ | 0 | - | 0 | - | ns |  |
| CINO-7 Hold Time From CLK | $\mathrm{T}_{\mathrm{CH}}$ | 0 | - | 0 | - | ns |  |
| CS\# Hold From LD\# | ${ }^{\text {T }}$ CSH | 0 | - | 0 | - | ns |  |
| RESET\# Pulse Width | TRPW | 31 | - | 50 | - | ns |  |
| FRAME\# Setup To Clock | TFS | 21 | - | 25 | - | ns | Note 2 |
| FRAME\# Pulse Width | TFPW | 31 | - | 50 | - | ns |  |
| EALU Setup Time | TES | 12 | - | 14 | - | ns |  |
| EALU Hold Time | TEH | 0 | - | 0 | - | ns |  |
| HOLD Setup Time | THS | 11 | - | 12 | - | ns |  |
| HOLD Hold Time | THH | 1 | - | 1 | - | ns |  |
| Output Enable Time | TEN | - | 16 | - | 22 | ns | Note 3 |
| Output Disable Time | Toz | - | 28 | - | 32 | ns | Note 5 |
| Output Rise Time | $\mathrm{T}_{\mathrm{R}}$ | - | 6 | - | 6 | ns | From 0.8 to 2.0 V Note 5 |
| Output Fall Time | $\mathrm{T}_{\mathrm{F}}$ | - | 6 | - | 6 | ns | From 2.0 to 0.8 V Note 5 |

NOTES: 1. This specification applies only to the case where the HSP48908 is being written to during an active convolution cycle. It must be met in order to acheive predictable results at the next rising clock edge. In most applications, the configuration data and coefficients are loaded asynchronously and the TLCS specification may be disregarded.
2. While FRAME\# is an asynchronous signal, it must be deasserted a minimum of $T_{F S}$ ns prior to the rising clock edge which is to begin loading pixel data for a new frame.
3. Transition is measured at $\pm 200 \mathrm{mV}$ from steady state voltage with loading as specified in test load circuit with $C_{L}=40 \mathrm{pF}$.
4. A.C. Testing is performed as follows: Input levels (CLK Input) 4.0 and $O V$, Input levels (All other inputs) OV and 3.0V, Timing reference levels $(C L K)=2.0 \mathrm{~V}$, (Others) $=1.5 \mathrm{~V}$, Output load per test load circuit with $C_{\mathrm{L}}=40 \mathrm{pF}$. Output transition is measured at $\mathrm{V}_{\mathrm{OH}} \geq 1.5 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{OL}} \leq 1.5 \mathrm{~V}$.
5. Controlled via design or process parameters and not directly tested. Characterized upon initial design and after major process and/or design changes.

Test Load Circuit


Switch S1 Open for ICCSB and ICCOP Tests
Timing Waveforms


Timing Waveforms (Continued)



INTERNAL CLOCK

FRAME\#/RESET\# TIMING


## Features

- This Circuit is Processed in accordance to Mil-Std883C and is Fully Conformant Under the Provisions of Paragraph 1.2.1
- Single Chip $3 \times 3$ Kernel Convolution
- Programmable On-Chip Row Buffers
- DC to 27 MHz Clock Rate
- Cascadable for Larger Kernels and Images
- On-Chip 8-Bit ALU
- Dual Coefficient Mask Registers, Switchable in a Single Clock Cycle
- 8-Bit Signed or Unsigned Input and Coefficient Data
- 20-Bit Extended Precision Output
- Standard $\mu \mathrm{P}$ Interface
- TTL Compatible Inputs/Outputs
- Low Power CMOS
- Available in 84 Pin PGA Package


## Applications

- Image Filtering
- Edge Detection
- Adaptive Filtering
- Real Time Video Filters


## Description

The Harris HSP48908/883 is a high speed Two Dimensional Convolver which provides a single chip implementation of a video data rate $3 \times 3$ kernel convolution on two dimensional data. It eliminates the need for external data storage through the use of the on-chip row buffers which are programmable for row lengths up to 1024 pixels.
There are internal register banks for storing two independent $3 \times 3$ filter kernels, thus facilitating the implementation of adaptive filters and multiple filter operations on the same data. The pixel data path also includes an on-chip ALU for performing real-time arithmetic and logical pixel point operations.
Data is provided to the HSP48908/883 in a raster scan noninterlaced fashion, and is internally buffered on images up to 1024 pixels wide for the $3 \times 3$ convolution operation. Images with larger rows and convolution with larger kernel sizes can be accommodated by using external row buffers and/or multiple HSP48908/883's. Coefficient and pixel input data are 8 -bit signed or unsigned integers, and the 20 bit convolver output guarantees no overflow for kernel sizes up to $4 \times 4$. Larger kernel sizes can be implemented however, since the filter coefficients will normally be less than their maximum 8-bit values.
The HSP48908/883 is manufactured using an advanced CMOS process, and is a low power fully static design. The configuration of the device is controlled through a standard microprocessor interface and all inputs/outputs are TTL compatible. The 2-D convolver is available in 84 pin PGA package.

Pinout
HSP48908/883 (PGA) TOP VIEW


CAUTION: These devices are sensitive to electrostatic discharge. Proper I.C. handling procedures should be followed.

## Absolute Maximum Ratings

Supply Voltage $\qquad$
Input, Output or I/O Voltage Applied .... GND-0.5V to $\mathrm{V}_{\mathrm{CC}}+0.5 \mathrm{~V}$
Storage Temperature Range . . . . . . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Junction Temperature . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $+175^{\circ} \mathrm{C}$
Lead Temperature (Soldering 10 sec ) ..................... $+300^{\circ} \mathrm{C}$
ESD Classification ............................................ . Class 1
CAUTION: Absolute maximum ratings are limiting values, applied individually beyond which the serviceability of the circuit may be impaired. Functional operability under any of these conditions is not necessarily implied.

## Recommended Operating Conditions

Operating Temperature Range
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Operating Voltage Range
+4.5 V to +5.5 V

TABLE 1. D.C. ELECTRICAL PERFORMANCE CHARACTERISTICS

| D.C. PARAMETERS | SYMBOL | CONDITIONS | GROUP A SUBGROUP | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| Logical 1 Input Voltage | $V_{1 H}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 2.2 | - | V |
| Logical 0 Input Voltage | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 0.8 | v |
| Clock Input High | $\mathrm{V}_{\mathrm{IHC}}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 3.0 | - | V |
| Clock Input Low | VILC | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 0.8 | V |
| Output HIGH Voltage | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & \mathrm{IOH}=-400 \mathrm{~mA} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V} \\ & \text { (Note 1) } \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 2.6 | - | v |
| Output LOW Voltage | $\mathrm{V}_{\mathrm{OL}}$ | $\begin{aligned} & \mathrm{IOL}=+2.0 \mathrm{~mA} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V} \\ & \text { (Note } 1) \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 0.4 | V |
| Input Leakage Current | 1 | $\begin{aligned} & \mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}} \text { or } \mathrm{GND} \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Output or I/O Leakage Current | 10 | $\begin{aligned} & V_{\text {OUT }}=V_{C C} \text { or GND } \\ & V_{C C}=5.5 \mathrm{~V} \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Standby Power Supply Current | ICCsB | $\begin{aligned} & V_{I N}=V_{C C} \text { or GND } \\ & V_{C C}=5.5 \mathrm{~V} \\ & \text { Outputs Open (Note 4) } \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 500 | $\mu \mathrm{A}$ |
| Operating Power Supply Current | ${ }^{\text {I CCOP }}$ | $\begin{aligned} & \mathrm{f}=20.0 \mathrm{MHz} \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V} \\ & \text { Outputs Open, } \\ & \text { (Notes 2, 4) } \\ & \hline \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 160.0 | mA |
| Functional Test | FT | (Notes 3, 4) | 7,8 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | - | - |

NOTES: 1. Interchanging of force and sense conditions is permitted.
2. Operating Supply Current is proportional to frequency, typical rating is $8.0 \mathrm{~mA} / \mathrm{MHz}$.
3. Tested as follows: $\mathrm{f}=1 \mathrm{MHz}, \mathrm{V}_{\mathrm{IH}}=2.6, \mathrm{~V}_{\mathrm{IL}}=0.4, \mathrm{~V}_{\mathrm{OH}} \geq 1.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}} \leq 1.5 \mathrm{~V}$, $V_{I H C}=3.4 \mathrm{~V}$, and $\mathrm{V}_{\text {ILC }}=0.4 \mathrm{~V}$.
4. Loading is a specified in the test load circuit with $C_{L}=40 \mathrm{pF}$.

TABLE 2. A.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Tested at: $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (Note 4)

| PARAMETERS | SYMBOL | CONDITIONS | GROUP A SUBGROUP | TEMPERATURE | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | -27 (27MHz) |  | -20 (20MHz) |  |  |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| Clock Period | TCYCLE |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 37 | - | 50 | - | ns |
| Clock Pulse Width High | TPWH |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 15 | - | 20 | - | ns |
| Clock Pulse Width Low | TPWL |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \leq+125^{\circ} \mathrm{C}$ | 15 | - | 20 | - | ns |
| Data Input Setup Time | TDS |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 16 | - | 17 | - | ns |
| Data Input Hold Time | TDH |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns |
| Clock to Data Out | TOUT |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq T \mathrm{~A} \leq+125^{\circ} \mathrm{C}$ | - | 19 | - | 28 | ns |
| Address Setup Time | $\mathrm{T}_{\text {AS }}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 15 | - | 15 | - | ns |
| Address Hold Time | $\mathrm{T}_{\text {AH }}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns |
| Configuration Data Setup Time | ${ }^{\text {T CDS }}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 17 | - | 20 | - | ns |
| Configuration Data Hold Time | $\mathrm{T}_{\mathrm{CDH}}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns |
| LD\# Pulse Width | TLPW |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 15 | - | 20 | - | ns |
| LD\# Setup Time | TLCS | Note 1 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 30 | - | 37 | - | ns |
| CIN7-0 Setup to CLK | TCS |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 17 | - | 20 | - | ns |
| CIN7-0 Hold from CLK | ${ }^{\text {T }} \mathrm{CH}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns |
| CS\# Setup to LD\# | TCss |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns |
| CS\# Hold from LD\# | $\mathrm{T}^{\text {CSH }}$ |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns |
| RESET\# Pulse Width | $\mathrm{T}_{\text {RPW }}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 37 | - | 50 | - | ns |
| FRAME\# Setup to CLK | TFS | Note 2 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 25 | - | 30 | - | ns |
| FRAME\# Pulse Width | TFPW |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 37 | - | 50 | - | ns |
| EALU Setup Time | TES |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 15 | - | 17 | - | ns |
| EALU Hold Time | TEH |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns |
| HOLD Setup Time | THS |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq T \mathrm{~A} \leq+125^{\circ} \mathrm{C}$ | 13 | - | 14 | - | ns |
| HOLD Hold Time | THH |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 2 | - | 2 | - | ns |
| Output Enable Time | TEN | Note 3 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 19 | - | 28 | ns |

NOTES: 1. This specification applies only to the case where the HSP48908/ 883 is being written to during an active convolution cycle. It must be met in order to achieve predictable results at the next rising clock edge. In most applications, the configuration data and coefficients are loaded asynchronously and the TLCS specification may be disregarded.
2. While FRAME\# is an asynchronous signal, it must be deasserted a minimum of $\mathrm{T}_{\mathrm{FS}}$ ns prior to the rising clock edge which is to begin loading pixel data for a new frame.
3. Transition is measured at $\pm 200 \mathrm{mV}$ from steady state voltage with loading as specified in test load circuit with $C_{L}=40 \mathrm{pF}$.
4. A.C. Testing is performed as follows: Input levels (CL.K input) 4.0 V and OV , Input levels (All other Inputs) OV and 3.0V, Timing Reference Levels $(C L K)=2.0 \mathrm{~V}$, (Others) $=1.5 \mathrm{~V}$. Output load per test load circuit with $C_{L}=40 \mathrm{pF}$. Output transition is measured at $\mathrm{V}_{\mathrm{OH}} \geq 1.5 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{OL}} \leq 1.5 \mathrm{~V}$.

TABLE 3. ELECTRICAL PERFORMANCE CHARACTERISTICS

| PARAMETERS | SYMBOL | CONDITIONS | NOTES | TEMPERATURE | LIMITS |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | -27 |  | -20 |  |  |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| Input Capacitance | $C_{I N}$ | $\begin{aligned} & v_{C C}=\text { Open, } \\ & f=1 \mathrm{MHz}, \text { All } \end{aligned}$ measurements are referenced to device GND. | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 10 | - | 10 | pF |
| Output Capacitance | $\mathrm{Co}_{0}$ | $\begin{aligned} & v_{\mathrm{CC}}=\text { Open, } \\ & \mathrm{f}=1 \mathrm{MHz}, \mathrm{All} \end{aligned}$ measurements are referenced to device GND. | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 12 | - | 12 | pF |
| Output Disable Time | Toz |  | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 35 | - | 40 | ns |
| Output Rise Time | $T_{R}$ | From 0.8 V to 2.0 V | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 6 | - | 6 | ns |
| Output Fall Time | $\mathrm{T}_{\mathrm{F}}$ | From 2.0 V to 0.8 V | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 6 | - | 6 | ns |

NOTES: 1. Parameters listed in Table 3 are controled via design or process
2. Loading is as specified in the test load circuit with $C_{L}=40 \mathrm{pF}$. parameters and are not directly tested. These parameters are characterized upon initial design and after major process and/or design changes.

TABLE 4. ELECTRICAL TEST REQUIREMENTS

| CONFORMANCE GROUPS | METHOD | SUBGROUPS |
| :--- | :---: | :---: |
| Initial Test | $100 \% / 5004$ | - |
| Interim Test | $100 \% / 5004$ | - |
| PDA | $100 \%$ | 1 |
| Final Test | $100 \%$ | $2,3,8 \mathrm{~A}, 8 \mathrm{~B}, 10,11$ |
| Group A | - | $1,2,3,7,8 \mathrm{~A}, 8 \mathrm{~B}, 9,10,11$ |
| Groups C \& D | Samples/5005 | $1,7,9$ |

Test Load Circuit


Switch S1 Open for ICCSB and ICCOP Tests

## Burn-In Circuit



| PIN NAME | PGA PIN | BURN-IN SIGNAL |
| :---: | :---: | :---: |
| CIN2 | A1 | F13 |
| CINO | A2 | F12 |
| DIN7 | A3 | F7 |
| DIN5 | A4 | F5 |
| DIN2 | A5 | F2 |
| DIN1 | A6 | F1 |
| OE | A7 | F10 |
| CASO. 1 | A8 | $V_{C C / 2}$ |
| CASO. 3 | A9 | $\mathrm{v}_{\mathrm{CC}} / 2$ |
| CASO. 4 | A10 | $\mathrm{V}_{\mathrm{CC}} / 2$ |
| CASO. 6 | A11 | $\mathrm{V}_{\mathrm{CC}} / 2$ |
| CIN5 | B1 | F12 |
| CIN3 | B2 | F13 |
| CIN1 | B3 | F12 |
| DIN6 | B4 | F6 |
| DIN3 | B5 | F3 |
| CASO. 0 | B6 | $\mathrm{V}_{\mathrm{CC}} / 2$ |
| GND | B7 | GND |
| CASO. 2 | B8 | $\mathrm{V}_{\text {CC/2 }}$ |
| GND | B9 | GND |
| CASO. 5 | B10 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| POUTO | B11 | $\mathrm{V}_{\mathrm{CC}} / 2$ |
| CIN6 | C1 | F13 |
| CIN4 | C 2 | F13 |
| DIN4 | C5 | F4 |
| DINO | C6 | FO |
| $V_{C C}$ | C7 | $\mathrm{V}_{\text {CC }}$ |
| CASO. 7 | C10 | $\mathrm{V}_{\mathrm{CC}} / 2$ |


| PIN |
| :--- | :--- | :--- |
| NAME |\(\left.\quad \begin{array}{ll}PGA <br>

PIN\end{array} \quad $$
\begin{array}{l}\text { BURN-IN } \\
\text { SIGNAL }\end{array}
$$\right]\)

| PIN NAME | PGA PIN | BURN-IN SIGNAL |
| :---: | :---: | :---: |
| CASI. 13 | J2 | F5 |
| CASI. 5 | J5 | F5 |
| CASI. 2 | J6 | F2 |
| CASI. 1 | J7 | F1 |
| POUT14 | J10 | $V_{C C / 2}$ |
| POUT12 | J11 | $V_{C C / 2}$ |
| CASI. 14 | K1 | F6 |
| CASI. 11 | K2 | F3 |
| CASI. 10 | K3 | F2 |
| CASI. 7 | K4 | F7 |
| CASI. 4 | K5 | F4 |
| $V_{\text {CC }}$ | K6 | $\mathrm{V}_{\text {CC }}$ |
| FRAME | K7 | F15 |
| POUT19 | K8 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| POUT16 | K9 | $\mathrm{V}_{\mathrm{CC}} / 2$ |
| GND | K10 | GND |
| POUT13 | K11 | $\mathrm{V}_{\mathrm{CC}} / 2$ |
| CASI. 12 | L1 | F4 |
| CASI. 9 | L2 | F1 |
| CASI. 8 | L3 | FO |
| CASI. 6 | L4 | F6 |
| CASI. 3 | L5 | F3 |
| RESET | L6 | F16 |
| CASI. 0 | L7 | FO |
| GND | L8 | GND |
| POUT18 | L.9 | $\mathrm{V}_{\mathrm{CC}} / 2$ |
| POUT17 | L10 | $\mathrm{V}_{\mathrm{CC}} / 2$ |
| POUT15 | L11 | $\mathrm{VCC}^{12}$ |

NOTES: 1. $V_{C C} / 2(2.7 \mathrm{~V} \pm 10 \%)$ used for outputs only.
2. $47 \mathrm{~K} \Omega( \pm 20 \%)$ resistor connected to all pins except $V_{C C}$ and GND.
3. $\mathrm{V}_{\mathrm{CC}}=5.5 \pm 0.5 \mathrm{~V}$.
4. $0.1 \mu \mathrm{~F}(\mathrm{~min})$ capacitor between $\mathrm{V}_{\mathrm{CC}}$ and GND per position.
5. $\mathrm{FO}=100 \mathrm{kHz} \pm 10 \%, F 1=F 0 / 2, F 2=F 1 / 2 \ldots \mathrm{~F} 11=\mathrm{F} 10 / 2$, 40-60\% Duty Cycle.
6. Input Voltage Limits: $\mathrm{V}_{\mathrm{IL}}=0.8 \mathrm{~V}$ max., $\mathrm{V}_{\mathrm{IH}}=4.5 \mathrm{~V} \pm 10 \%$.

## Die Characteristics

DIE DIMENSIONS:
$341 \times 322 \times 19 \pm 1$ mils
METALLIZATION:
Type: Si - Al or $\mathrm{Si}-\mathrm{Al}-\mathrm{Cu}$
Thickness: $8 \mathrm{k} \AA$
WORST CASE CURRENT DENSITY
$2 \times 10^{5} \mathrm{~A} / \mathrm{cm}^{2}$

GLASSIVATION:
Type: Nitrox
Thickness: 10k $\AA$
DIE ATTACH:
Material: Silver Glass

Metallization Mask Layout


## SIGNAL SYNTHESIZERS

PAGEDATA SHEETS
HSP45102 12 Bit Numerically Controlled Oscillator ..... 5-3
HSP45106 16 Bit Numerically Controlled Oscillator ..... 5-10
HSP45106/883 16 Bit Numerically Controlled Oscillator ..... 5-20
HSP45116 Numerically Controlled Oscillator/Modulator ..... 5-26
HSP45116/883 Numerically Controlled Oscillator/Modulator ..... 5-41
HSP50016 Digital Down Converter ..... 5-48

HSP45102

August 1992

## Features

- $33 \mathrm{MHz}, 40 \mathrm{MHz}$ Versions
- 32-Bit Frequency Control
- BFSK, QPSK Modulation
- Serial Frequency Load
- 12-Bit Sine Output
- Offset Binary Output Format
- 0.009 Hz Tuning Resolution at 40 MHz
- Spurious Frequency Components <-69dBc
- Fully Static CMOS
- Available in 28 Pin DIP and SOIC
- Low Cost


## Applications

- Direct Digital Synthesis
- Modulation


## 12-Bit Numerically Controlled Oscillator

## Description

The Harris HSP45102 is Numerically Controlled Oscillator with 32 bit frequency resolution and 12 bit output. With over 69 dB of spurious free dynamic range and worst case frequency resolution of 0.009 Hz , the NCO 12 provides dramatic improvements in accuracy over other frequeny synthesis solutions at a competitive price.

The frequency to be generated is selected from two frequency control words. A single control pin selects which word is used to determine the output frequency. Switching from one frequency to another occurs in one clock cycle, with a 6 clock pipeline delay from the time that the new control word is loaded until the new frequency appears on the output.

Two pins, PO-1, are provided for phase modulation. They are encoded and added to the top two bits of the phase accumulator to offset the phase in $90^{\circ}$ increments.

The 13 bit output of the Phase Offset Adder is mapped to the sine wave amplitude via the Sine ROM. The output data format is offset binary to simplify interfacing to D/A converters. Spurious frequency components in the output sinusoid are less than -69 dBc .

The NCO12 has applications as a Direct Digital Synthesizer and modulator in low cost digital radios, satellite terminals, and function generators.


## Pinout



Pin Description

| NAME | PIN <br> NUMBER | TYPE |  |
| :---: | :---: | :---: | :--- |
| VCC | 8,22 |  | +5V power supply pin. |
| GND | $7,15,21$ |  | Ground |
| PO-1 | 19,20 | I | Phase modulation inputs (become active after a pipeline delay of four clocks). A phase shift <br> of $0,90,180$, or 270 degrees can be selected (Table 1). |
| CLK | 16 | I | NCO clock. (CMOS level) |
| SCLK | 14 | I | This pin clocks the frequency control shift register. |
| SEL_L/M\# | 9 | I | A high on this input selects the least significant 32 bits of the 64 bit frequency register as <br> the input to the phase accumulator; a low selects the most significant 32 bits. |
| SFTEN\# | 10 | 1 | The active low input enables the shifting of the frequency register. |
| MSB/LSB\# | 11 | I | This input selects the shift direction of the frequency register. A low on this input shifts in the <br> data LSB first; a high shifts in the data MSB first. |
| ENPHAC\# | 12 | I | This pin, when low, enables the clocking of the Phase Accumulator. This input has a pipe- <br> line delay of four clocks. |
| SD | 13 | I | Data on this pin is shifted into the frequency register by the rising edge of SCLK when <br> SFTEN\# is low. |
| TXFR\# | 17 | I | This active low input is clocked onto the chip by CLK and becomes active after a pipeline <br> delay of four clocks. When low, the frequency control word selected by SEL_L/M\# is <br> transferred from the frequency register to the phase accumulator's input register. |
| LOAD\# | 18 | I | This input becomes active after a pipeline delay of five clocks. When low, the feedback in <br> the phase accumulator is zeroed. |
| OUTO-11 | $1-6,23-28$ | O | Output data. OUTO is LSB. Unsigned. |

All inputs are TTL level, with the exception of CLK.
\# sign designates active low signals.

## Functional Description

The NCO12 produces a 12 bit sinusoid whose frequency and phase are digitally controlled. The frequency of the sine wave is determined by one of two 32 bit words. Selection of the active word is made by SEL__L/M\#. The phase of the output is controlled by the two bit input PO-1, which is used to select a phase offset of $0^{\circ}, 90^{\circ}, 180^{\circ}$, or $270^{\circ}$.

As shown in the Block Diagram, the NCO12 consists of a Frequency Control Section, a Phase Accumulator, a Phase Offset Adder and a Sine ROM. The Frequency Control section serially loads the frequency control word into the frequency register. The Phase Accumulator and Phase Offset Adder compute the phase angle using the frequency control word and the two phase modulation inputs. The Sine ROM generates the sine of the computed phase angle. The format of the 12 bit output is offset binary.

## Frequency Control Section

The Frequency Control Section (Figure 1), serially loads the frequency data into a 64 bit, bidirectional shift register. The shift direction is selected with the MSB/LSB\# input. When this input is high, the frequency control word on the SD input is shifted into the register MSB first. When MSB/LSB\# is low the data is shifted in LSB first. The register shifts on the rising edge of SCLK when SFTEN\# is low. The timing of these signals is shown in Figure 2.
The 64 bits of the frequency register are sent to the Phase Accumulator Section where 32 bits are selected to control the frequency of the sinusoidal output.

## Phase Accumulator Section

The phase accumulator and phase offset adder compute the phase of the sine wave from the frequency control word and the phase modulation bits PO-1. The architecture is shown in Figure 1. The most significant 13 bits of the 32 bit phase accumulator are summed with the two bit phase offset to generate the 13 bit phase input to the Sine Rom. A value of 0 corresponds to $0^{\circ}$, a value of 1000 hexadecimal corresponds to a value of $180^{\circ}$.

The phase accumulator advances the phase by the amount programmed into the frequency control register. The output frequency is equal to $N^{*}$ Fclk/232, where $N$ is the selected 32 bits of the frequency control word. For example, if the control word is 20000000 hexadecimal and the clock frequency is 30 Mhz , then the output frequency would be Fclk/8 or 3.75 Mhz .

The frequency control multiplexer selects the least significant 32 bits from the 64 bit frequency control register when SEL_L/M\# is high, and the most significant 32 bits when SEL__L/M\# is low. When only one frequency word is desired, SEL_L/M\# and MSB/LSB\# must be either both high or both low. This is due to the fact that when a frequency control word is loaded into the shift register LSB first, it enters through the most significant bit of the register. After 32 bits have been shifted in, they will reside in the 32 most significant bits of the 64 bit register.

When TXFR\# is asserted, the 32 bits selected by the frequency control multiplexer are clocked into the phase accumulator input register. At each clock, the contents of this register are summed with the current contents of the accumulator to step to the new phase. The phase accumulator stepping may be inhibited by holding ENPHAC\# high. The phase accumulator may be loaded with the value in the input register by asserting LOAD\#, which zeroes the feedback to the phase accumulator.
The phase adder sums the encoded phase modulation bits PO-1 and the output of the phase accumulator to offset the phase by $0,90,180$ or 270 degrees. The two bits are encoded to produce the phase mapping shown in Table 1. This phase mapping is provided for direct connection to the in-phase and quadrature data bits for QPSK modulation.

TABLE 1

| PO-1 CODING |  |  |
| :---: | :---: | :---: |
| P1 | PO | PHASE SHIFT (DEGREES) |
| 0 | 0 | 0 |
| 0 | 1 | 90 |
| 1 | 0 | 270 |
| 1 | 1 | 180 |

## ROM Section

The ROM section generates the 12 bit sine value from the 13 bit output of the phase adder. The output format is offset binary and ranges from 001 to FFF hexadecimal, centered around 800 hexadecimal.


FIGURE 1. NCO-12 FUNCTIONAL BLOCK DIAGRAM


FIGURE 2. I/O TIMING

## Absolute Maximum Ratings

| Supply Volt | 8.0 V |
| :---: | :---: |
| Input, Output or I/O Voltage Applied | GND -0.5V to $\mathrm{V}_{\mathrm{CC}}+0.5 \mathrm{~V}$ |
| Storage Temperature Range | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Junction Temperature | $+150^{\circ} \mathrm{C}$ |
| Maximum Package Power Dissipation (Commercial) | 1.5W (DIP), 1.1W (SOIC) |
| Maximum Package Power Dissipation (Industrial). | $1.3{ }^{\circ} \mathrm{C} / \mathrm{W}$ (DIP), $0.9^{\circ} \mathrm{C} / \mathrm{W}$ (SOIC) |
| 8jc | $20.3^{\circ} \mathrm{C} / \mathrm{W}$ (DIP), $21.6^{\circ} \mathrm{C} / \mathrm{W}$ (SOIC) |
| 0ja | $50.1^{\circ} \mathrm{C} / \mathrm{W}$ (DIP), $71.4{ }^{\circ} \mathrm{C} / \mathrm{W}$ (SOIC) |
| Device Count | . 32,528 Transistors |
| Lead Temperature (Soldering, Ten Seconds) | $\ldots+300{ }^{\circ} \mathrm{C}$ |
| ESD Classification | ... Class 1 |
| CAUTION: Stresses above those listed in the "Absolute Maximu operation of the device at these or any other conditions ab | e device. This is a stress only rating and this specification is not implied. |

## Operating Conditions


D.C. Electrical Specifications

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{IH}}$ | Logical One Input Voltage | 2.0 | - | V | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| $\mathrm{V}_{\text {IL }}$ | Logical Zero Input Voltage | - | 0.8 | V | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| $\mathrm{V}_{\text {IHC }}$ | High Level Clock Input | 3.0 | - | V | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| $\mathrm{V}_{\text {ILC }}$ | Low Level Clock Input | - | 0.8 | V | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output HIGH Voltage | 2.6 | - | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Output LOW Voltage | - | 0.4 | V | ${ }^{1} \mathrm{OL}=+2.0 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| 1 | Input Leakage Current | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {CC }}$ or GND, $\mathrm{V}_{\text {CC }}=5.25 \mathrm{~V}$ |
| ${ }^{\prime} \mathrm{CCSB}$ | Standby Power Supply Current | - | 500 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{\text {IN }}=V_{C C} \text { or GND } \\ & V_{C C}=5.25 \mathrm{~V}, \text { Note } 3 \end{aligned}$ |
| ICCOP | Operating Power Supply Current | - | 99 | mA | $\begin{aligned} & f=33 \mathrm{MHz}, V_{I N}=V_{C C} \text { or GND } \\ & V_{C C}=5.25 \mathrm{~V} \text {, Notes } 1 \text { and } 3 \end{aligned}$ |

## Capacitance ( $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$, Note 2)

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :--- | :---: | :---: | :---: | :--- |
| $C_{\mathbb{I}}$ | Input Capacitance | - | 10 | pF | FREQ $=1 \mathrm{MHz}, \mathrm{V}_{\mathrm{CC}}=$ Open, <br> All measurements are referenced <br> to device ground |
| $\mathrm{C}_{\mathrm{O}}$ | Output Capacitance | - | 10 | pF |  |

## NOTES:

[^2]A.C. Electrical Specifications $V_{C C}=5.0 \mathrm{~V} \pm 5 \%, T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ (Note 1)

| SYMBOL | PARAMETER | -33 (33MHz) |  | -40 (40MHz) |  | COMMENTS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |  |
| $\mathrm{T}_{\mathrm{CP}}$ | Clock Period | 30 | - | 25 | - | ns |
| $\mathrm{T}_{\mathrm{CH}}$ | Clock High | 12 | - | 10 | - | ns |
| TCL | Clock Low | 12 | - | 10 | - | ns |
| TSW | SCLK High/Low | 12 | - | 10 | - | ns |
| TDS | Set-up Time SD to SCLK Going High | 12 | - | 12 | - | ns |
| TDH | Hold Time SD from SCLK Going High | 0 | - | 0 | - | ns |
| $\mathrm{T}_{\text {MS }}$ | Set-up Time SFTEN\#, MSB/LSB\# to SCLK Going HGgh | 15 | - | 12 | - | ns |
| $\mathrm{T}_{\text {M }}$ | Hold Time SFTEN\#, MSB/LSB\# from SCLK Going High | 0 | - | 0 | - | ns |
| TSS | Set-up Time SCLK High to CLK Going High | 16 | - | 15 | - | ns, Note 2 |
| TPS | Set-up Time PO-1 to CLK Going High | 15 | - | 12 | - | ns |
| TPH | Hold Time PO-1 from CLK Going High | 1 | - | 1 | - | ns |
| TES | Set-up Time LOAD\#, TXFR\#, ENPHAC\#, SEL_L/M\# to CLK Going High | 15 | - | 13 | - | ns |
| TEH | Hold Time LOAD\#, TXFR\#, ENPHAC\#, SEL_L/M\# from CLK Going High | 1 | - | 1 | - | ns |
| $\mathrm{TOH}^{\text {O }}$ | CLK to Output Delay | 2 | 15 | 2 | 13 | ns |
| TRF | Output Rise, Fall Time | 8 | - | 8 | - | ns, Note 3 |

notes

1. A.C. testing is performed as follows: Input levels (CLK Input) 4.0 V and OV ; Input levels (all other inputs) OV and 3.0V; Timing reference levels (CLK) 2.0 V ; All others 1.5 V . Output load per test load circuit with switch closed and $C_{L}=40 \mathrm{pF}$. Output transition is measured at $\mathrm{V}_{\mathrm{OH}} \geq 1.5 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{OL}} \leq 1.5 \mathrm{~V}$.
2. If TXFR\# is active, care must be taken to not violate set-up and hoid times as data from the shift registers may not have settled before CLK occurs.
3. Controlled via design or process parameters and not directly tested. Characterized upon initial design and after major process and/or design changes.

## A.C. Test Load Circuit



Switch S1 open for ICCSB and ICCOP

## Waveforms



16 Bit Numerically Controlled Oscillator

## Features

- 25.6MHz, 33MHz Versions
- 32-Bit Center and Offset Frequency Control
- 16-Bit Phase Control
- 8 Level PSK Supported Through Three Pin Interface
- Simultaneous 16 Bit Sine and Cosine Outputs
- Output in Two's Complement or Offset Binary
- $<0.008 \mathrm{~Hz}$ Tuning Resolution at $\mathbf{3 3 M H z}$
- Serial or Parallel Outputs
- Spurious Frequency Components <-90dBc
- 16 Bit Microprocessor Compatible Control Interface
- 85 Pin PGA, 84 Pin PLCC


## Applications

- Direct Digital Synthesis
- Quadrature Signal Generation
- Modulation - FM, FSK, PSK (BPSK, QPSK, 8PSK)
- Precision Signal Generation


## Description

The Harris HSP45106 is a high performance 16-bit quadrature numerically controlled oscillator (NCO16). The NCO16 simplifies applications requiring frequency and phase agility such as frequency-hopped modems, PSK modems, spread spectrum communications, and precision signal generators. As shown in the block diagram, the HSP45106 is divided into a Phase/Frequency Control Section (PFCS) and a Sine/Cosine Section.

The inputs to the Phase/Frequency Control Section consist of a microprocessor interface and individual control lines. The frequency resolution is 32 bits, which provides for resolution of better than 0.008 Hz at 33 MHz . User programmable center frequency and offset frequency registers give the user the capability to perform phase coherent switching between two sinusoids of different frequencies. Further, a programmable phase control register allows for phase control of better than 0.0060 . In applications requiring up to 8 -level PSK, three discrete inputs are provided to simplify implementation.

The output of the PFCS is a 32-bit phase which is input to the Sine/Cosine Section for conversion into sinusoidal amplitude. The outputs of the sine/cosine section are two 16 -bit quadrature signals. The spurious free dynamic range of this complex vector is greater than 90 dBc .
For added flexibility when using the NCO16 in conjunction with DAC's, a choice of either parallel of serial outputs with either two's complement or offset binary encoding is provided. In addition, a synchronization signal is avallable which signals serial word boundaries.

## Block Diagram



## Pinouts



HSP45106

## Pin Description

| NAME | PGA PIN NUMBER | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {cc }}$ | $\begin{gathered} \text { B5, D11, F1, } \\ \text { K7, K10 } \end{gathered}$ |  | +5 power supply pin. |
| GND | $\begin{gathered} \text { A9, D2, E10, } \\ \text { K4, L11 } \end{gathered}$ |  | Ground |
| C0-15 | $\begin{aligned} & A 1-8, B 3-4 \\ & B 6-8, C 5-7 \end{aligned}$ | 1 | Control input bus for loading phase, frequency, and timer data into the PFCS. CO is LSB. |
| A0-2 | A10, B9-10 | 1 | Address pins for selecting destination of $\mathrm{CO} \mathbf{- 1 5}$ data (Table 2). |
| CS\# | E11 | 1 | Chip select (Active low). Enables data to be written into control registers by WR\#. |
| WR\# | E9 | 1 | Write enable (Active low). Data is clocked into the register selected by AO-2 on the rising edge of WR \# when CS\# is low. |
| CLK | K9 | 1 | Clock. All registers, except the control registers clocked with WR\#, are clocked (when enabled) by the rising edge of CLK. |
| ENPOREG\# | F10 | 1 | Phase Offset Register Enable (Active low). Registered on chip by CLK. When active, after being clocked onto chip, ENPOREG\# enables the clocking of data into the Phase Offset Register. Allows ROM address to be updated regardless of ENPHAC\#. |
| ENOFREG\# | F9 | 1 | Offset Frequency Register Enable (Active low). Registered on chip by CLK. When active, after being clocked onto chip, ENOFREG\# enables the clocking of data into the Offset Frequency Register. |
| ENCFREG\# | F11 | I | Center Frequency Register Enable (Active low). Registered on chip by CLK. When active, after being clocked onto chip, ENCFREG\# enables the clocking of data into the Center Frequency Register. |
| ENPHAC\# | H11 | 1 | Phase Accumulator Register Enable (Active low). Registered on chip by CLK. When active, after being clocked onto chip, ENPHAC\#enables the clocking of data into the Phase Accumulator Register. |
| ENTIREG\# | G11 | 1 | Timer Increment Register Enable (Active low). Registered on chip by CLK. When active, after being clocked onto chip, ENTIREG\# enables the clocking of data into the Timer Increment Register. |
| INHOFR\# | G9 | 1 | Inhibit Offset Frequency Register Output (active low). Registered on chip by CLK. When active, after being clocked onto chip, INHOFR\# zeroes the data path from the Offset Frequency Register to the Frequency Adder. New data can be still clocked into the Offset Frequency Register. INHOFR\# does not affect the contents of the register. |
| INITPAC\# | J11 | 1 | Initialize Phase Accumulator (Active low). Registered on chip by CLK. Zeroes the feedback path in the Phase Accumulator. Does not clear the Phase Accumulator Register. |
| MODO-2 | $\begin{gathered} \mathrm{B} 11, \\ \mathrm{C} 10-11 \end{gathered}$ | 1 | Modulation Control Inputs. When selected with the PMSEL line, these bits add an offset of $0,45,90$, $135,180,225,270$, or 315 degrees to the current phase (i.e., modulate the output). The lower 13 bits of the phase control are set to zero. These bits are registered when the Phase Offset Register is enabled. |
| PMSEL | A11 | 1 | Phase Modulation Select input. Registered on chip by CLK. This input determines the source of the data clocked into the Phase Offset Register. When high, the Phase Input Register is selected. When low, the external modulation pins (MODO-2) control the three most significant bits of the Phase Offset Register and the 13 least significant bits are set to zero. |
| PACI\# | H10 | 1 | Phase Accumulator Carry Input (Active low). Registered on chip by CLK. |
| INITTAC\# | G10 | 1 | Initialize Timer Accumulator (Active low). This input is registered on chip by CLK. When active, after being clocked onto chip, INITTAC\# enables the clocking of data into the Timer increment Register, and also zeroes the feedback path in the Timer Accumulator. |
| TEST | D10 | 1 | Test select input. Registered on chip by CLK. This input is active high. When active, this input enables test busses to the outputs instead of the sine and cosine data. |
| PAR/SER\# | J10 | 1 | Parallel/Serial Output Select. This input is registered on chip by CLK. When low, the sine and cosine outputs are in serial mode. The output shift registers will load in new data after ENPHAC\# goes low and will start shifting the data out after ENPHAC\# goes high. When this input is high, the output registers are loaded every clock and no shifting takes place. |
| BINFMT\# | K11 | 1 | Format. This input is registered on chip by CLK. When low, the MSB of the SIN and COS are inverted to form an offiset binary (unsigned) number. |
| OES\# | K2 | 1 | Three-state control for bits SINO-15. Outputs are enabled when OES\# is low. |
| OEC\# | J2 | 1 | Three-state control for bits COSO-15. Outputs are enabled when OEC\# is low. |
| TICO\# | B2 | 0 | Timer Accumulator Carry Output. Active low, registered. This output goes low when a carry is generated by the Timer Accumulator. |

## Pin Description (Continued)

| NAME | PGA PIN <br> NUMBER | TYPE |  |
| :---: | :---: | :---: | :--- |
| DACSTRB\# | L1 | O | DAC Strobe (Active low). In serial mode, this output will go low when the first bit of a new output <br> word is valid at the shift register output. This pin is active only in serial mode. |
| SINO-15 | J5-7, K3, <br> K5-6, K8, <br> L2-10 | O | Sine output data. When parallel mode is enabled, data is output on SINO-15. When serial mode is <br> enabled, output data bits are shifted out of SIN15 and SINO. The bit stream on SIN 15 is provided <br> MSB first while the bit stream on SINO is provided LSB first. |
| COSO-15 | B1, C1-2, <br> D1, E1-3, <br> F2-3, G1-3, <br> H1-2, J1, K1 | O | Cosine output data. When parallel mode is enabled, data is output on COSO-15. When serial <br> mode is enabled, output data bits are shifted out of COS15 and COSO. The bit stream on COS15 <br> is provided LSB tirst. |
| Index Pin | C3 |  | Used to align chip in socket or on circuit board. Must be left as a no connect in circuit. |

## Functional Description

The 16 -bit Numerically Controlled Oscillator (NCO16) produces a digital complex sinusoid waveform whose frequency and phase are controlled through a standard microprocessor interface and discrete inputs. The NCO16 generates 16 -bit sine and cosine vectors at a maximum sample rate of 40 MHz . The NCO16 can be preprogrammed to produce a constant (CW) sine and cosine output for Direct Digital Synthesis (DDS) applications. Alternatively, the phase and frequency inputs can be updated in real time to produce a FM, PSK, FSK, or MSK modulated waveform. To simplify PSK generation, a 3 pin interface is provided to support modulation of up to 8 levels.

As shown in the Block Diagram, the NCO16 is comprised of a Phase and Frequency Control Section (PFCS) and Sine/ Cosine Section. The PFCS stores the phase and frequency control inputs and uses them to calculate the phase angle of a rotating complex vector. The Sine/Cosine Section performs a lookup on this phase and generates the appropriate amplitude values for the sine and cosine. These quadrature outputs may be configured as serial or parallel with either two's complement or offset binary format.

## Phase/Frequency Control Section

The phase and frequency of the quadrature outputs are controlled by the PFCS (Figure 1). The PFCS generates a 32 bit word which represents the instantaneous phase ( $\mathrm{Sin} / \mathrm{Cos}$ argument) of the sine and cosine waves being generated. This phase is incremented on the rising edge of each CLK by the preprogrammed amounts in the phase and frequency control registers. As the instantaneous phase steps from 0 through full scale $(232-1)$, the phase of the quadrature outputs proceeds from $0^{\circ}$ around the unit circle counter clockwise.

The PFCS is comprised of a Phase Accumulator Section, Phase Offset adder, Input Section, and a Timer Accumulator Section. The Phase Accumulator computes the instantaneous phase angle from user programmed values in the Center and Offset Frequency Registers. This angle is then fed into the Phase Offset adder where it is offset by the preprogrammed value in the Phase Offset Register. The Input Section routes data from a microprocessor compatible control bus and discrete input signals into the appropriate configuration registers. The Timer Accumulator
supplies a pulse to mark the passage of a user programmed period of time.

## Input Section

The Input Section loads the data on C0-15 into one of the seven input registers, the LSB and MSB Center Frequency Input Registers, the LSB and MSB Offset Frequency Registers, the LSB and MSB Timer Input Registers, and the Phase Input Register. The destination depends on the state of AO-2 when CS\# and WR\# are low (Table 1).

TABLE 1

| A2-0 DECODING |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :--- | :---: |
| A2 | A1 | AO | CS\# | WR\# | FUNCTION |  |
| 0 | 0 | 0 | 0 | $\uparrow$ | Load least significant bits of <br> Center Frequency input. |  |
| 0 | 0 | 1 | 0 | $\uparrow$ | Load most significant bits of <br> Center Frequency input. |  |
| 0 | 1 | 0 | 0 | $\uparrow$ | Load least significant bits of <br> Offset Frequency input. |  |
| 0 | 1 | 1 | 0 | $\uparrow$ | Load most significant bits of <br> Offset Frequency input. |  |
| 1 | 0 | 0 | 0 | $\uparrow$ | Load least significant bits of <br> Timing Interval input. |  |
| 1 | 0 | 1 | 0 | $\uparrow$ | Load most significant bits of <br> Timing Interval input. |  |
| 1 | 1 | 0 | 0 | $\uparrow$ | Load Phase Register |  |
| 1 | 1 | 1 | 0 | $\uparrow$ | Reserved |  |
| x | x | x | 1 | x | Input Disabled |  |

Once the input registers have been loaded, the control inputs ENCFREG\#, ENOFREG\#, ENTIREG\#, ENCTIREG\#, and ENPOREG\# will allow the input registers to be downloaded to the PFCS control registers with the input CLK. The control inputs are latched on the rising edge of CLK and the control registers are updated on the rising edge of the following CLK. For example, to load the Center Frequency Register, the data is loaded into the LSB and MSB Center Frequency Input Register, and ENCFREG\# is set to zero; the next rising edge of CLK will pass the registered version of ENCFREG\#, R.ENCFREG\#, to the

clock enable of the Center Frequency Register; this register then gets loaded on the following rising edge of CLK. The contents of the input registers are downloaded to the control registers every clock if the control inputs are enabled.

## Phase Accumulator Section

The Phase Accumulator adds the 32 bit output of the Frequency Adder with the contents of a 32 bit Phase Accumulator Register on every clock cycle. When the sum causes the adder to overflow, the accumulation continues with the least significant 32 bits of the result.
Initializing the Phase Accumulator Register is done by putting a low on the INITPAC\# and ENPHAC\# lines. This zeroes the feedback path to the accumulator, so that the register is loaded with the current value of the Frequency Adder on the next clock.

The frequency of the quadrature outputs is based on the number of clock cycles required to step from 0 to full scale. The number of steps required for this transition depends on the phase increment calculated by the frequency adder. For example, if the Center and Offset Frequency registers are programmed such that the output of the Frequency Adder is 40000000 hex, the Phase Accumulator will step the phase from 0 to 360 degrees every 4 clock cycles. Thus, for a 30 MHz CLK, the quadrature outputs will have a frequency of $30 / 4 \mathrm{MHz}$ or 7.5 MHz . In general, the frequency of the quadrature output is determined by $\mathrm{N} \times \mathrm{FCLK} / 232$, where N is the output of the Frequency Adder and FCLK is the frequency of CLK.

The Frequency Adder sums the contents of both the Center and Offset Frequency Registers to produce a phase increment. By enabling INHOFR\#, the output of the Offset Frequency Register is disabled so that the output frequency is determined from the Center Frequency Register alone. For BFSK modems, INHOFR\# can be asserted/ de-asserted to toggle the quadrature outputs between two programmed frequencies. Note: enabling/disabling INHOFR\# preserves the contents of the Offset Frequency Register.

## Phase Offset Adder

The output of the Phase Accumulator goes to the Phase Offset Adder, which adds the 16 bit contents of the Phase Offset Register to the 16 MSB's of the phase. The resulting 32-bit number forms the instantaneous phase which is fed to the Sine/Cosine Section.

The user has the option of loading the Phase Offset Registers with the contents of the Phase Input Register or the MODO-2 inputs depending on the state of PMSEL. When PMSEL is high, the contents of the Phase Input Register are loaded. If PMSEL is low, MODO-2 encode the upper 3 bits of the Phase Offset Register while the lower 13 bits are cleared. The MODO-2 inputs simplify PSK modulation by providing a 3 input interface to phase modulate the carrier as shown in Table 2. The control input ENPOREG\# acts as a clock enable and must be low to enable clocking of data into the Phase Offset Register.

TABLE 2

| MOD2-0 DECODING |  |  |  |
| :---: | :---: | :---: | :---: |
| MOD2 | MOD1 | MODO | PHASE SHIFT <br> (DEGREES) |
| 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 45 |
| 0 | 1 | 0 | 90 |
| 0 | 1 | 1 | 135 |
| 1 | 0 | 0 | 270 |
| 1 | 0 | 1 | 315 |
| 1 | 1 | 0 | 180 |
| 1 | 1 | 1 | 225 |

## Timer Accumulator Section

The Timer Accumulator consists of a register which is incremented on every clock. The amount by which it increments is loaded into the Timer Increment Input Registers and is latched into the Timer Increment Register on rising edges of CLK while ENTIREG\# is low. The output of the Timer Accumulator is the accumulator carry out, TICO\#. TICO\# can be used as a timer to enable the periodic sampling of the output of the NCO-16. The number programmed into this register equals ( $2^{32} \times$ CLK period)/ (desired time interval).

## Sine/Cosine Section

The Sine/Cosine Section (Figure 2) converts the instantaneous phase from the PFCS Section into the appropriate amplitude values for the sine and cosine outputs. It takes the most significant 20 bits of the PFCS output and passes them through a Sine/Cosine look up to form the 16 bit quadrature outputs. The sine and cosine values are computed to reduce the amount of ROM needed. The magnitude of the error in the computed value of the complex vector is less than -90.2 dB . The error in the sine or cosine alone is approximately 2 dB better. The 20 bit phase word maps into $2 \pi$ radians so that the angular resolution is $(2 \pi) / 2^{20}$. An address of zero corresponds to 0 radians and an address of hex FFFFF corresponds to $2 \pi-((2 \pi) / 220)$ radians. The outputs of the Sine/Cosine Section are two's complement sine and cosine values. The ROM contents have been scaled by $\left(2^{16-1}\right) /\left(2^{16+1}\right)$ for symmetry about zero.
To simplify interfacing with D/A converters, the format of the sine/cosine outputs may be changed to offset binary by enabling BINFMT\#. When BINFMT\# is enabled, The MSB of the Sine and Cosine outputs (SIN15 and COS15 when the outputs are in parallel mode) are inverted. Depending upon the state of BINFMT\#, the output is centered around midscale and ranges from 8001 H to 7FFFH (two's complement mode) or 0001 H to FFFFH (offset binary mode).
Serial output mode may is chosen by enabling PAR/SER\#. In this mode the user loads the output shift registers with Sine/Cosine ROM output by enabling ENPHAC\#. After ENPHAC\# goes inactive the data is shifted out serially. For
example, to clock out one 16 bit sine/cosine output, ENPHAC\# would be active for one cycle to load the output shift register, and would then go inactive for the following 15 cycles to clock the remaining bits out. Output bit streams are provided in formats with either MSB first or LSB first. The MSB first format is available on the SIN15 and COS15 output pins. The LSB first format is available on the SINO and COSO output pins. In MSB first format, zero's follow the LSB if a new output word is not loaded into the shift register. In LSB first format, the sine extension bit follows the MSB if
a new data word is not loaded. The output signal DACSTRB\# is provided to signal the first bit of a new output word is valid (Figure 3). Note: all unused pins of SINO-15 and COSO-15 should be left floating.
A test mode is supplied which enables the user to access the phase input to the Sine/Cosine ROM. If TEST and PAR/ SER\# are both high, the 28 MSB's of the phase input to the Sine/Cosine Section are made available on SINO-15 and COS4-15. The SINO-15 outputs represent the MSW of the address.


FIGURE 2. SINE/COSINE BLOCK DIAGRAM


FIGURE 3. SERIAL OUTPUT I/O TIMING DIAGRAM

## Absolute Maximum Ratings

| Supply Voltage | +8.0V |
| :---: | :---: |
| Input, Output or I/O Voltage Applied | GND -0.5V to $\mathrm{V}_{\mathrm{CC}}+0.5 \mathrm{~V}$ |
| Storage Temperature Range | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Maximum Package Power Dissipation | 2.3W (PLCC), 2.9W (PGA) |
| $\theta_{\text {jc }}$ | $11.3{ }^{\circ} \mathrm{C} / \mathrm{W}$ (PLCC), $10.0^{\circ} \mathrm{C} / \mathrm{W}$ (PGA) |
|  | $34.0{ }^{\circ} \mathrm{C} / \mathrm{W}$ (PLCC), $36^{\circ} \mathrm{C} / \mathrm{W}$ (PGA) |
| Component Count | . 75,000 Transistors |
| Junction Temperature | $+150^{\circ} \mathrm{C}$ (PLCC),$+175^{\circ} \mathrm{C}$ (PGA) |
| Lead Temperature (Soldering, Ten Secore | .$+300^{\circ} \mathrm{C}$ |
| ESD Classification | . . Class 1 |

## Operating Conditions

| Operating Voltage Range | 75 V to +5.25 V |
| :---: | :---: |
| Operating Temperature Range | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |

D.C. Electrical Specifications

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{IH}}$ | Logical One Input Voltage | 2.0 | - | V | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{IL}}$ | Logical Zero Input Voltage | - | 0.8 | V | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{IHC}}$ | High Level Clock Input | 3.0 | - | V | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| VILC | Low Level Clock Input | - | 0.8 | V | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output HIGH Voltage | 2.6 | - | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Output LOW Voltage | - | 0.4 | V | $\mathrm{I}^{\mathrm{OL}}=+2.0 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| 1 | Input Leakage Current | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {CC }}$ or $\mathrm{GND}, \mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| 10 | 1/O Leakage Current | -10 | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{O U T}=V_{C C} \text { or } G N D, \\ & V_{C C}=5.25 V \end{aligned}$ |
| ${ }^{\prime} \mathrm{CCSB}$ | Standby Power Supply Current | - | 500 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{I N}=V_{C C} \text { or GND } \\ & V_{C C}=5.25 \mathrm{~V}, \text { Note } 3 \end{aligned}$ |
| I'COP | Operating Power Supply Current | - | 205 | mA | $\begin{aligned} & f=25.6 \mathrm{MHz}, V_{I N}=V_{C C} \text { or GND } \\ & V_{C C}=5.25 \mathrm{~V}, \text { Notes } 1 \text { and } 3 \end{aligned}$ |

Capacitance ( $T_{A}=+25^{\circ} \mathrm{C}$, Note 2)

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :--- | :---: | :---: | :---: | :--- |
| $C_{I N}$ | Input Capacitance | - | 10 | pF | FREQ $=1 \mathrm{MHz}, \mathrm{V}_{\mathrm{CC}}=$ Open, <br> All measurements are referenced <br> to device ground |
| $\mathrm{C}_{\mathrm{O}}$ | Output Capacitance | - | 10 | pF |  |

## NOTES:

1. Power supply current is proportional to operating frequency. Typical 3. Output load per test load circuit with switch open and $C_{L}=40 p F$. rating for ${ }^{1} \mathrm{CCOP}$ is $8 \mathrm{~mA} / \mathrm{MHz}$.
2. Not tested, but characterized at initial design and at major process/design changes.
A.C. Electrical Specifications $V_{C C}=5.0 \mathrm{~V} \pm 5 \%, T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ (Note 1)

| SYMBOL | PARAMETER | 25.6 MHz |  | 33MHz |  | COMMENTS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |  |
| TCP | CLK Period | 39 | - | 30 | - | ns |
| TCH | CLK High | 15 | - | 12 | - | ns |
| TCL | CLK Low | 15 | - | 12 | - | ns |
| TWP | WR\# Period | 39 | - | 30 | - | ns |
| TWH | WR\# High | 15 | - | 12 | - | ns |
| TWL | WR\# Low | 15 | - | 12 | - | ns |
| TAWS | Set-up Time A0-2, CS\# to WR\# Going High | 13 | - | 13 | - | ns |
| TAWH | Hold Time AO-2, CS\# from WR\# Going High | 1 | - | 1 | - | ns |
| TCWS | Set-up Time C0-15 to WR\# Going High | 15 | - | 15 | - | ns |
| TCWH | Hold Time C0-15 from WR\# Going High | 0 | - | 0 | - | ns |
| TWC | Set-up Time WR\# High to CLK High | 16 | - | 12 | - | ns, Note 2 |
| TMCS | Set-up Time MODO-2 to CLK Going High | 15 | - | 15 | - | ns |
| TMCH | Hold Time MODO-2 from CLK Going High | 0 | - | 0 | - | ns |
| TECS | Set-up Time ENPOREG\#,ENOFREG\#,ENCFREG\#, ENPHAC\#, ENTIREG\#, INHOFR \#, PMSEL\#, INITPAC\#, BINFMT\#, TEST, PAR/SER\#, PACI\#, INITTAC\# to CLK Going High | 12 | - | 12 | - | ns |
| TECH | Hold Time ENPOREG\#, ENOFREG\#, ENCFREG\#, ENPHAC\#, ENTIREG\#, INHOFR\#, PMSEL\#, INITPAC\#, BINFMT\#, TEST,PAR/SER\# , PACI\#, INITTAC\# from CLK Going High | 0 | - | 0 | - | ns |
| $T_{\text {DO }}$ | CLK to Output Delay SINO-15, COSO-15, TICO\# | - | 18 | - | 15 | ns |
| TDSO | CLK to Output Delay DACSTRB\# | 2 | 18 | 2 | 15 | ns |
| TOE | Output Enable Time | - | 12 | - | 12 | ns |
| TOD | Output Disable Time | - | 15 | - | 15 | ns, Note 3 |
| TRF | Output Rise, Fall Time | - | 8 | - | 8 | ns, Note 3 |

NOTES:

1. A.C. testing is performed as follows: Input levels (CLK Input) 4.0 V and OV ; Input levels (all other inputs) OV and 3.0 V ; Timing reference levels (CLK) 2.0V; All others 1.5 V . Output load per test load circuit with switch closed and $C_{L}=40 \mathrm{pF}$. Output transition is measured at $V_{O H} \geq 1.5 \mathrm{~V}$ and $V_{O L} \leq$ 1.5 V .
2. If ENOFREG\#, ENCFREG\#, ENTIREG\#, OR ENPOREG\# are active, care must be taken to not violate set-up and hold times to these registers when writing data into the chip via the $\mathbf{C 0}-15$ port.
3. Controlled via design or process parameters and not directly tested. Characterized upon initial design and after major process and/or changes.

## A.C. Test Load Circuit




OUTPUT ENABLE, DISABLE TIMING


OUTPUT RISE AND FALL TIMES


## Features

- This Circuit is Processed in Accordance to Mil-Std883 and is Fully Conformant Under the Provisions of Paragraph 1.2.1
- 25.6MHz Clock Rate
- 32-Bit Center and Offset Frequency Control
- 16-Bit Phase Control
- 8 Level PSK Supported Through Three Pin Interface
- Simultaneous 16 Bit Sine and Cosine Outputs
- Output in Two's Complement or Offset Binary
- $<\mathbf{0} .006 \mathrm{~Hz}$ Tuning Resolution at $\mathbf{2 5 . 6 M H z}$
- Serial or Parallel Outputs
- Spurious Frequency Components <-90dBc
- 16 Bit Microprocessor Compatible Control Interface
- 85 Pin PGA


## Applications

- Direct Digital Synthesis
- Quadrature Signal Generation
- Modulation - FM, FSK, PSK (BPSK, QPSK, 8PSK)
- Precision Signal Generation


## Description

The Harris HSP45106/883 is a high performance 16-bit quadrature numerically controlled oscillator (NCO16). The NCO16 simplifies applications requiring frequency and phase agility such as frequency-hopped modems, PSK modems, spread spectrum communications, and precision signal generators. As shown in the block diagram, the HSP45106/883 is divided into a Phase/Frequency Control Section (PFCS) and a Sine/Cosine Section.

The inputs to the Phase/Frequency Control Section consist of a microprocessor interface and individual control lines. The frequency resolution is 32 bits, which provides for resolution of better than 0.006 Hz at 25.6 MHz . User programmable center frequency and offset frequency registers give the user the capability to perform phase coherent switching between two sinusoids of different frequencies. Further, a programmable phase control register allows for phase control of better than 0.0060 . In applications requiring up to 8 level PSK, three discrete inputs are provided to simplify implementation.

The output of the PFCS is a 32-bit phase argument which is input to the sine/cosine section for conversion into sinusoidal amplitude. The outputs of the sine/cosine section are two 16-bit quadrature signals. The spurious free dynamic range of this complex vector is greater than 90 dBc .

For added flexibility when using the NCO16 in conjunction with DAC's, a choice of either parallel of serial outputs with either two's complement or offset binary encoding is provided. In addition, a synchronization signal is available which signals serial word boundaries.

## Block Diagram




## Reliability Information

Thermal Resistance $\quad \theta_{\mathrm{ja}} \quad \theta_{\mathrm{jc}}$ Ceramic PGA Package . . . . . . . . . . . . $36.0^{\circ} \mathrm{C} / \mathrm{W} \quad 11.6^{\circ} \mathrm{C} / \mathrm{W}$ Maximum Package Power Dissipation at $+125^{\circ} \mathrm{C}$

Ceramic PGA Package
1.39 Watt Gate Count ........................................... 18,750 Gates

CAUTION: Stresses above those listed in "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.

## Operating Conditions

Operating Voltage Range . . . . . . . . . . . . . . . . . . . . . . . . +4.5 V to +5.5 V
Operating Temperature Range $. \ldots \ldots . . . . . . . . .-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
TABLE 1. HSP45106/883 D.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Devices Guaranteed and $100 \%$ Tested

| PARAMETER | SYMBOL | CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| Logical One Input Voltage | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{v}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 2.2 | - | V |
| Logical Zero Input Voltage | VIL | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 0.8 | V |
| Output HIGH Voltage | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}(\text { Note } 1) \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 2.6 | - | V |
| Output LOW Voltage | $\mathrm{V}_{\mathrm{OL}}$ | $\begin{aligned} & \mathrm{IOL}_{\mathrm{O}}=+2.0 \mathrm{~mA} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}(\text { Note } 1) \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 0.4 | V |
| Input Leakage Current | 1 | $\begin{aligned} & V_{I N}=V_{C C} \text { or GND } \\ & V_{C C}=5.5 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Output Leakage Current | 10 | $\begin{aligned} & V_{O U T}=V_{C C} \text { or GND } \\ & V_{C C}=5.5 \mathrm{~V} \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Clock Input High | $\mathrm{V}_{\text {IHC }}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 3.0 | - | V |
| Clock Input Low | VILC | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 0.8 | V |
| Standby Power Supply Current | ${ }^{\text {I CcsB }}$ | $\begin{aligned} & V_{I N}=V_{C C} \text { or } G N D \\ & V_{C C}=5.5 \mathrm{~V}, \\ & \text { (Note 4) } \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 500 | $\mu \mathrm{A}$ |
| Operating Power Supply Current | ICCOP | $\begin{aligned} & \mathrm{f}=25.6 \mathrm{MHz} \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V}(\text { Notes } 2,4) \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 205 | mA |
| Functional Test | FT | (Note 3) | 7,8 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | - | - |

NOTES:

1. Interchanging of force and sense conditions is permitted.
2. Operating Supply Current is proportional to frequency, typical rating is $8 \mathrm{~mA} / \mathrm{MHz}$.
3. Tested as foliows: $f=1 \mathrm{MHz}, \mathrm{V}_{\mathrm{IH}}=2.6, \mathrm{~V}_{\mathrm{IL}}=0.4, \mathrm{~V}_{\mathrm{OH}} \geq 1.5 \mathrm{~V}$, $\mathrm{V}_{\mathrm{OL}} \leq 1.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{IHC}}=3.4 \mathrm{~V}$, and $\mathrm{V}_{\mathrm{ILC}}=0.4 \mathrm{~V}$.
4. Loading is as specified in the test load circuit with $C_{L}=40 \mathrm{pF}$.

TABLE 2. A.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and $100 \%$ Tested.

| PARAMETERS | SYMBOL | (NOTE 1) CONDITIONS | GROUP A SUBGROUP | TEMPERATURE | LIMITS$(25.6 \mathrm{MHz})$ |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |
|  |  |  |  |  | MIN | MAX |  |
| CLK Period | ${ }^{T} \mathrm{CP}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 39 | - | ns |
| CLK High | ${ }^{\text {T }} \mathrm{CH}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 15 | - | ns |
| CLK Low | ${ }^{T} \mathrm{CL}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 15 | - | ns |
| WR\# Period | TWP |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 39 | - | ns |
| WR\# High | TWH |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 15 | - | ns |
| WR\# Low | TWL |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 15 | - | ns |
| Set-up Time AO-2, CS\# to WR\# Going High | TAWS |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 13 | - | ns |
| Hold Time AO-2, CS\# from WR\# Going High | $\mathrm{T}_{\text {AWH }}$ |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 2 | - | ns |
| Set-up Time CO-15 to WR\# Going High | TCws |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \leq+125^{\circ} \mathrm{C}$ | 15 | - | ns |
| Hold Time C0-15 from WR\# Going High | TCWh |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 1 | - | ns |
| Set-up Time WR\# High to CLK High | TWC | Note 3 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 16 | - | ns |
| Set-up Time MODO-2 to CLK Going High | TMCS |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 15 | - | ns |
| Hold Time MODO-2 from CLK Going High | $\mathrm{T}_{\mathrm{MCH}}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 1 | - | ns |
| Set-up Time ENPOREG\#, ENOFREG\#, ENCFREG\#, ENPHAC\#, ENTIREG\#, INHOFR\#, PMSEL\#, INITPAC\#, BINFMT\#, TEST, PAR/SER\#, PACI\#, INITTAC\# to CLK Going High | TECS |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 12 | - | ns |
| Hold Time ENPOREG\#, ENOFREG\#, ENCFREG\#, ENPHAC\#, ENTIREG\#, INHOFR\#, PMSEL\#, INITPAC\#, BINFMT\#, TEST, PAR/SER\#,PACI\#, INITTAC\# from CLK Going High | TECH |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 1 | - | ns |
| CLK to Output Delay SINO-15, COSO-15, TICO\# | $\mathrm{T}_{\text {DO }}$ |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 18 | ns |
| CLK to Output Delay DACSTRB\# | TDSO |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | 2 | 18 | ns |
| Output Enable Time | TOE | Note 2 | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 12 | ns |

NOTES:

1. A.C. Testing: $V_{C C}=4.5 \mathrm{~V}$ and 5.5 V . Inputs are driven to 3.0 V for a Logic " 1 " and 0.0 V for a Logic " 0 ". Input and output timing measurements are made at 1.5 V for both a Logic " 1 " and " 0 ". CLK is driven at 4.0 V and OV and measured at 2.0 V . Output load per test load circuit with switch closed and $C_{L}=40 \mathrm{pF}$.
2. Transition is measured at $\pm 200 \mathrm{mV}$ from steady state voltage with loading as specified by test load circuit and $C_{L}=40 \mathrm{pF}$.
3. If ENOFRCTL\#, ENCFRCTL\#, ENTICTL\# or ENPHREG\# are active, care must be taken to not violate set-up and hold times to these registers when writing data into the chip via the CO-15 port.

Specifications HSP45106/883

TABLE 3. ELECTRICAL PERFORMANCE CHARACTERISTICS

| PARAMETERS | SYMBOL | CONDITIONS | NOTES | TEMPERATURE | Limits |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | -25 (25.6MHz) |  |  |
|  |  |  |  |  | MIN | MAX |  |
| Input Capacitance | $\mathrm{Cl}_{\mathrm{IN}}$ | $\begin{aligned} & V_{C C}=\text { Open, } \\ & f=1 \mathrm{MHz}, \text { All } \end{aligned}$ measurements are referenced to device GND. | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 10 | pF |
| Output Capacitance | COUT | $\begin{aligned} & v_{C C}=\text { Open, } \\ & f=1 \mathrm{MHz}, A l l \end{aligned}$ <br> measurements are referenced to device GND. | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 10 | pF |
| Output Disable Delay | ToEz |  | 1,2 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 15 | ns |
| Output Rise Time | TOR | From 0.8 V to 2.0 V | 1,2 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 8 | ns |
| Output Fall Time | ToF | From 2.0 V to 0.8 V | 1,2 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 8 | ns |

NOTES:

1. Parameters listed in Table 3 are controlled via design or process parameters and are not directly tested. These parameters are characterized upon initial design and after major process and/or design changes.
2. Loading is as specified in the test load circuit with switch closed and $C_{L}=40 p F$.

TABLE 4. ELECTRICAL TEST REQUIREMENTS

| CONFORMANCE GROUPS | METHOD | SUBGROUPS |
| :--- | :---: | :---: |
| Initial Test | $100 \% / 5004$ | - |
| Interim Test | $100 \% / 5004$ | - |
| PDA | $100 \%$ | 1 |
| Final Test | $100 \%$ | $2,3,8 A, 8 B, 10,11$ |
| Group A | - | $1,2,3,7,8 A, 8 B, 9,10,11$ |
| Groups C \&D | Samples/5005 | $1,7,9$ |

HSP45106/883

## Burn-In Circuit

## HSP45106/883 PIN GRID ARRAY (PGA)



## NOTES:

1. $V_{\mathrm{CC}} / 2(2.7 \mathrm{~V} \pm 10 \%)$ used for outputs only.
2. $47 \mathrm{~K} \Omega( \pm 20 \%)$ resistor connected to all pins except $\mathrm{V}_{\mathrm{CC}}$ and GND .
3. $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V} \pm 0.5 \mathrm{~V}$.
4. $0.1 \mu \mathrm{~F}(\mathrm{~min})$ capacitor between $V_{C C}$ and GND per position.
5. $F 0=100 \mathrm{kHz} \pm 10 \%, F 1=F 0 / 2, F 2=F 1 / 2 \ldots, F 11=F 10 / 2,40 \%-60 \%$ Duty Cycle.
6. Input voltage limits: $\mathrm{V}_{\mathrm{IL}}=0.8 \mathrm{~V} \operatorname{Max} \quad \mathrm{~V}_{\mathrm{IH}}=4.5 \mathrm{~V} \pm 10 \%$

## Die Characteristics

DIE DIMENSIONS:
$251 \times 240 \times 19 \pm 1$ mils
METALLIZATION:
Type: $\mathrm{Si}-\mathrm{Al}$ or $\mathrm{Si}-\mathrm{Al}-\mathrm{Cu}$
Thickness: $8 \mathrm{k} \AA$
GLASSIVATION:
Type: Nitrox
Thickness: $10 k \AA$

## Metallization Mask Layout

## DIE ATTACH:

Material: Silicon Au (Gold) Eutectic Alloy or Silver-Glass
WORST CASE CURRENT DENSITY: $0.8 \times 10^{5} \mathrm{~A} / \mathrm{cm}^{2}$


# Numerically Controlled Oscillator/Modulator 

## Features

- NCO and CMAC on One Chip
- 15MHz, 25.6MHz, 33MHz Versions
- 32-bit Frequency Control
- 16-bit Phase Modulation
- 16-bit CMAC
- 0.008 Hz Tuning Resolution at 33 MHz
- Spurious Frequency Components $<-90 \mathrm{dBc}$
- Fully Static CMOS
- 145 Pin PGA


## Applications

- Frequency Synthesis
- Modulation - AM, FM, PSK, FSK, QAM
- Demodulation, PLL
- Phase Shifter
- Fast Fourier Transforms (FFT)
- Polar to Cartesian Conversions


## Description

The Harris HSP45116 combines a high performance quadrature numerically controlled oscillator (NCO) and a high speed 16-bit Complex Multiplier/Accumulator (CMAC) on a single IC. This combination of functions allows a complex vector to be multiplied by the internally generated (cos, sin ) vector for quadrature modulation and demodulation. As shown in the block diagram, the HSP45116 is divided into three main sections. The Phase/Frequency Control Section (PFCS) and the Sine/Cosine Section together form a complex NCO. The CMAC multiplies the output of the Sine/ Cosine Section with an external complex vector.
The inputs to the Phase/Frequency Control Section consist of a microprocessor interface and individual control lines. The phase resolution of the PFCS is 32 bits, which results in frequency resolution better than 0.008 Hz at 33 MHz . The output of the PFCS is the argument of the sine and cosine. The spurious free dynamic range of the complex sinusoid is greater than 90 dBc .
The output vector from the Sine/Cosine Section is one of the inputs to the Complex Multiplier/Accumulator. The CMAC multiplies this (cos, $\sin$ ) vector by an external complex vector and can accumulate the result. The resulting complex vectors are available through two 20-bit output ports which maintain the 90 dB spectral purity. This result can be accumulated internally to implement an accumulate and dump filter.
A quadrature down converter can be implemented by loading a center frequency into the Phase/Frequency Control Section. The signal to be downconverted is the Vector Input of the CMAC, which multiplies the data by the rotating vector from the Sine/Cosine Section. The resulting complex output is the down converted signal.

## Block Diagram



## Pinouts

145 PIN PGA
TOP VIEW

|  | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A | $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{IMIN}_{4}$ | $\begin{gathered} \hline \text { IMIN } \\ 8 \end{gathered}$ | $\underset{9}{\text { IMIN }}$ | $\underset{11}{\text { IMIN }}$ | $\begin{array}{\|c} \text { IMIN } \\ \hline 15 \end{array}$ | $\begin{aligned} & \text { IMIN } \\ & 16 \end{aligned}$ | GND | $v_{\text {cc }}$ | $\begin{aligned} & 10 \\ & 18 \end{aligned}$ | $\begin{aligned} & 10 \\ & 15 \end{aligned}$ | $\begin{aligned} & 10 \\ & 12 \end{aligned}$ | $\begin{aligned} & 10 \\ & 10 \end{aligned}$ | GND | $\mathrm{v}_{\mathrm{CC}}$ |
| B | GND | $\begin{gathered} \text { IMIN } \\ 1 \end{gathered}$ | $\begin{gathered} \text { IMIN } \\ 5 \end{gathered}$ | ${ }_{7}^{\text {IMIN }}$ | $\begin{gathered} \text { IMIN } \\ 10 \end{gathered}$ | $\underset{13}{\operatorname{IMIN}}$ | $\begin{gathered} \text { IMIN } \\ 14 \end{gathered}$ | $\begin{aligned} & 10 \\ & 19 \end{aligned}$ | $\begin{aligned} & 10 \\ & 16 \end{aligned}$ | $\begin{aligned} & 10 \\ & 14 \end{aligned}$ | $10$ | $\begin{gathered} 10 \\ 8 \end{gathered}$ | $\begin{gathered} 10 \\ 7 \end{gathered}$ | $\begin{gathered} 10 \\ 5 \end{gathered}$ | $\begin{gathered} 10 \\ 2 \end{gathered}$ |
| c | $\begin{gathered} \text { RIN } \\ 15 \end{gathered}$ | $\begin{gathered} \text { RIN } \\ 18 \end{gathered}$ | $\begin{gathered} \hline \text { IMIN } \\ 2 \end{gathered}$ | $\begin{gathered} \text { IMIN } \\ 3 \end{gathered}$ | $\underset{6}{\text { IMIN }}$ | $\begin{array}{\|c} \hline \text { IMIN } \\ 12 \end{array}$ | $\underset{17}{\operatorname{IM} \operatorname{IN}}$ | $\begin{array}{\|c\|c\|} \hline \text { IMIN } \\ \hline \end{array}$ | $\begin{aligned} & 10 \\ & 17 \end{aligned}$ | $\begin{aligned} & 10 \\ & 13 \end{aligned}$ | $\begin{gathered} 10 \\ 9 \end{gathered}$ | $\begin{gathered} 10 \\ 6 \end{gathered}$ | $\begin{array}{r} 10 \\ 4 \end{array}$ | $10$ | $\begin{aligned} & \text { RO } \\ & 18 \end{aligned}$ |
| D | $\begin{gathered} \text { RIN } \\ 13 \end{gathered}$ | $\begin{gathered} \text { RIN } \\ 17 \end{gathered}$ | $\begin{gathered} \text { IMIN } \\ 0 \end{gathered}$ | INDEX |  |  |  |  |  |  |  |  | 10 3 | $\begin{aligned} & \text { RO } \\ & 19 \end{aligned}$ | $\begin{aligned} & \text { RO } \\ & 17 \end{aligned}$ |
| E | $\begin{gathered} \text { RIN } \\ 10 \end{gathered}$ | $\begin{gathered} \text { RIN } \\ 14 \end{gathered}$ | $\begin{gathered} \text { RIN } \\ 16 \end{gathered}$ |  |  |  |  |  |  |  |  |  | 10 0 | $\begin{aligned} & \text { RO } \\ & 16 \end{aligned}$ | $\begin{gathered} \text { RO } \\ 15 \end{gathered}$ |
| F | $\begin{gathered} \text { RIN } \\ 7 \end{gathered}$ | $\begin{aligned} & \text { RIN } \\ & 11 \end{aligned}$ | $\begin{gathered} \text { RIN } \\ 12 \end{gathered}$ |  |  |  |  |  |  |  |  |  | $\begin{aligned} & \text { RO } \\ & 14 \end{aligned}$ | $\begin{aligned} & \text { RO } \\ & 13 \end{aligned}$ | $\begin{aligned} & \text { RO } \\ & 11 \end{aligned}$ |
| G | $\mathrm{V}_{\mathrm{cc}}$ | $\underset{9}{\text { RIN }}$ | $\underset{8}{\text { RIN }}$ |  |  |  |  |  |  |  |  |  | $\begin{gathered} \mathrm{RO} \\ 9 \end{gathered}$ | $\begin{aligned} & \text { RO } \\ & 12 \end{aligned}$ | $\begin{aligned} & \text { RO } \\ & 10 \end{aligned}$ |
| H | GND | $\mathrm{RIN}_{6}^{\mathrm{R}}$ | $\begin{gathered} \text { RIN } \\ 5 \end{gathered}$ |  |  |  |  |  |  |  |  |  | $\begin{gathered} \text { RO } \\ 8 \end{gathered}$ | $\begin{gathered} \text { RO } \\ 7 \end{gathered}$ | GND |
| J | $\begin{gathered} \text { RIN } \\ 3 \end{gathered}$ | $\mathrm{RIN}_{1}$ | $\mathrm{RIN}_{4}$ |  |  |  |  |  |  |  |  |  | $\begin{gathered} \text { RO } \\ 5 \end{gathered}$ | $\begin{gathered} \text { RO } \\ 4 \end{gathered}$ | $\mathrm{V}_{\mathrm{Cc}}$ |
| K | $\begin{gathered} \text { RIN } \\ 2 \end{gathered}$ | $\underset{0}{\text { RIN }}$ | $\begin{gathered} \mathrm{SH} \\ 1 \end{gathered}$ |  |  |  |  |  |  |  |  |  | $\begin{gathered} \text { RO } \\ 1 \end{gathered}$ | $\begin{gathered} \text { RO } \\ 2 \end{gathered}$ | $\begin{gathered} \text { RO } \\ 8 \end{gathered}$ |
| L | $\begin{gathered} \mathrm{SH} \\ \mathrm{O} \end{gathered}$ | ACC | $\begin{gathered} \text { RBythio } \\ \# \end{gathered}$ |  |  |  |  |  |  |  |  |  | ${\underset{\text { PACO }}{ }}^{\text {P }}$ | $\begin{gathered} \text { DET } \\ 1 \end{gathered}$ | $\begin{gathered} \text { RO } \\ 3 \end{gathered}$ |
| M | $\begin{array}{r} \text { ENPH } \\ \text { REG } \\ \neq 7 \end{array}$ | $\begin{gathered} \text { PEAK } \\ \not \# \end{gathered}$ | $\begin{gathered} \text { MOD } \\ 1 \end{gathered}$ |  |  |  |  |  |  |  |  |  | ofrext <br> \# | OEI <br> \# | $\begin{gathered} \text { RO } \\ 0 \end{gathered}$ |
| N | $\begin{array}{r} \text { ENOF } \\ \text { REG } \\ \nexists 7 \end{array}$ | Binfmt \# | $\begin{array}{\|c\|} \hline \text { MOD } \\ 0 \end{array}$ | $\begin{gathered} \text { LOAD } \\ \# \end{gathered}$ | $\begin{aligned} & \text { ENCF } \\ & \text { REG } \\ & \nexists F \end{aligned}$ | $\begin{gathered} \text { MODP } \\ \begin{array}{c} 12 P 1 \\ \not Z 7 \end{array} \\ \hline \end{gathered}$ | $\begin{gathered} \text { AD } \\ 0 \end{gathered}$ | $\begin{gathered} C \\ 14 \end{gathered}$ | $\begin{gathered} \hline \mathrm{C} \\ 13 \end{gathered}$ | $\begin{aligned} & \mathrm{C} \\ & 8 \end{aligned}$ | $\begin{aligned} & \mathrm{C} \\ & 2 \end{aligned}$ | $\begin{gathered} \text { our- } \\ 1 \end{gathered}$ | OuT- Mux 0 | $\begin{gathered} \text { OEIEXT } \\ \# \# \end{gathered}$ | $\begin{gathered} \mathrm{DET} \\ \mathrm{D} \end{gathered}$ |
| $P$ | $\left\lvert\, \begin{gathered} \text { TICO } \\ \hline \end{gathered}\right.$ | $\begin{gathered} \text { PACI } \\ \# \end{gathered}$ | PMSEL | CLROFA <br> \# | ENTIREC <br> \# | $\begin{aligned} & \text { CS } \\ & \# \end{aligned}$ | $\begin{gathered} \text { AD } \\ 1 \end{gathered}$ | $\begin{gathered} C \\ 15 \end{gathered}$ | $\begin{gathered} C \\ 10 \end{gathered}$ | $\begin{aligned} & \mathbf{C} \\ & \mathbf{g} \end{aligned}$ | $\begin{aligned} & \text { C } \\ & 6 \end{aligned}$ | $\begin{aligned} & \mathbf{C} \\ & 3 \end{aligned}$ | $\begin{aligned} & \mathbf{C} \\ & \mathbf{1} \end{aligned}$ | $\begin{aligned} & \text { OER } \\ & \nRightarrow \end{aligned}$ | GNO |
| Q | $\mathrm{V}_{\mathrm{CC}}$ | GND | ENPHAC <br> \# | ENI | GLK | WR $\#$ | $\mathrm{V}_{\mathrm{Cc}}$ | GND | $\begin{aligned} & \hline \mathrm{C} \\ & 12 \end{aligned}$ | $\begin{gathered} c \\ c \\ 11 \end{gathered}$ | $\begin{aligned} & \hline \mathbf{C} \\ & 7 \end{aligned}$ | $\begin{aligned} & \hline \mathbf{C} \\ & 5 \end{aligned}$ | $\begin{aligned} & C \\ & 4 \end{aligned}$ | $\begin{aligned} & \mathrm{C} \\ & \mathrm{O} \end{aligned}$ | Vcc |


|  | BOTTOM VIEW |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 |  |
| A | $v_{\text {cc }}$ | GND | $\begin{aligned} & 10 \\ & 10 \end{aligned}$ | $\begin{aligned} & 10 \\ & 12 \end{aligned}$ | $\begin{aligned} & 10 \\ & 15 \end{aligned}$ | $\begin{aligned} & 10 \\ & 18 \end{aligned}$ | vcc | GND | $\begin{array}{\|l\|l\|l\|} \hline \text { IMIN } \\ \hline \end{array}$ | $\begin{gathered} \text { IMIN } \\ 15 \end{gathered}$ | $\underset{11}{\text { IMIN }}$ | $\underset{9}{\text { IMIN }}$ | $\underset{8}{\text { IMIN }}$ | $\begin{gathered} \text { IMIN } \\ 4 \end{gathered}$ | $\mathrm{v}_{\mathrm{cc}}$ | A |
| B | 10 2 | 10 5 | $\begin{gathered} 10 \\ 7 \end{gathered}$ | $\begin{gathered} 10 \\ 8 \end{gathered}$ | $\begin{aligned} & 10 \\ & 11 \end{aligned}$ | $\begin{aligned} & 10 \\ & 14 \end{aligned}$ | $\begin{aligned} & 10 \\ & 16 \end{aligned}$ | $\begin{aligned} & 10 \\ & 19 \end{aligned}$ | $\begin{gathered} \text { IMIN } \\ 14 \end{gathered}$ | $\underset{13}{\operatorname{IMIN}}$ | $\underset{10}{\text { IMIN }}$ | $\underset{7}{\operatorname{IMIN}}$ | ${ }_{5}^{\text {IMIN }}$ | $\begin{gathered} \text { IMIN } \\ 1 \end{gathered}$ | GND | B |
| C | $\begin{aligned} & \mathrm{RO} \\ & 18 \end{aligned}$ | 10 | $\begin{gathered} 10 \\ 4 \end{gathered}$ | $\begin{gathered} 10 \\ 6 \end{gathered}$ | $\begin{gathered} 10 \\ 9 \end{gathered}$ | $\begin{aligned} & 10 \\ & 13 \end{aligned}$ | $\begin{aligned} & 10 \\ & 17 \end{aligned}$ | $\begin{gathered} \mathrm{IMIN} \\ 18 \end{gathered}$ | $\underset{17}{1 \mathrm{MIN}}$ | $\begin{gathered} \text { IMIN } \\ 12 \end{gathered}$ | $\underset{6}{\mathrm{IMIN}}$ | $\begin{array}{\|c} \text { IMIN } \\ 3 \end{array}$ | $\underset{2}{\text { IMIN }}$ | $\begin{gathered} \text { RIN } \\ 18 \end{gathered}$ | $\begin{gathered} \text { RIN } \\ 15 \end{gathered}$ | C |
| D | $\begin{aligned} & \text { RO } \\ & 17 \end{aligned}$ | $\begin{aligned} & \text { RO } \\ & 19 \end{aligned}$ | $\begin{gathered} 10 \\ 3 \end{gathered}$ |  |  |  |  |  |  |  |  | INDEX | $\underset{0}{\text { IMIN }}$ | $\begin{gathered} \text { RIN } \\ 17 \end{gathered}$ | $\begin{gathered} \text { RIN } \\ 13 \end{gathered}$ | D |
| E | $\begin{aligned} & \text { RO } \\ & 15 \end{aligned}$ | $\begin{aligned} & \text { RO } \\ & 16 \end{aligned}$ | $\begin{gathered} 10 \\ 0 \end{gathered}$ |  |  |  |  |  |  |  |  |  | $\begin{gathered} \text { RIN } \\ 16 \end{gathered}$ | $\begin{gathered} \text { RIN } \\ 14 \end{gathered}$ | $\begin{gathered} \text { RIN } \\ 10 \end{gathered}$ | E |
| F | $\begin{aligned} & \text { RO } \\ & 11 \end{aligned}$ | $\begin{aligned} & \text { RO } \\ & 13 \end{aligned}$ | $\begin{aligned} & \text { RO } \\ & 14 \end{aligned}$ |  |  |  |  |  |  |  |  |  | RIN | $\begin{array}{r} \text { RIN } \\ 11 \end{array}$ | ${ }_{7}^{\text {RIN }}$ | F |
| G | $\begin{aligned} & \text { RO } \\ & 10 \end{aligned}$ | $\begin{aligned} & \mathrm{RO} \\ & 12 \end{aligned}$ | $\begin{gathered} \text { RO } \\ 9 \end{gathered}$ |  |  |  |  |  |  |  |  |  | RIN | $\underset{9}{\text { RIN }}$ | $\mathrm{v}_{\mathrm{Cc}}$ | G |
| H | GND | RO 7 | $\begin{gathered} \text { RO } \\ 8 \end{gathered}$ |  |  |  |  |  |  |  |  |  | RIN | $\underset{6}{\text { RIN }}$ | GND | H |
| J | $V_{\text {cc }}$ | RO | $\begin{gathered} \text { RO } \\ 5 \end{gathered}$ |  |  |  |  |  |  |  |  |  | RIN 4 | $\underset{1}{\operatorname{RIN}}$ | $\begin{gathered} \text { RIN } \\ 3 \end{gathered}$ | J |
| K | $\begin{gathered} \text { RO } \\ 6 \end{gathered}$ | $\begin{gathered} \text { RO } \\ 2 \end{gathered}$ | $\begin{gathered} \text { RO } \\ 1 \end{gathered}$ |  |  |  |  |  |  |  |  |  | $\mathrm{SH}_{1}$ | RIN | $\begin{gathered} \mathrm{RIN} \\ 2 \end{gathered}$ | K |
| L. | $\begin{gathered} \text { RO } \\ 3 \end{gathered}$ | $\begin{gathered} \text { DET } \\ 1 \end{gathered}$ | $\begin{gathered} \text { PACO } \\ \mathrm{H} \end{gathered}$ |  |  |  |  |  |  |  |  |  | RBytild办 | ACC | $\underset{0}{\mathrm{SH}}$ | $L$ |
| M | $\begin{gathered} \text { RO } \\ 0 \end{gathered}$ | $\begin{aligned} & \mathrm{OEI} \\ & \nexists \mathrm{I} \end{aligned}$ | $\begin{gathered} \text { OEREXT } \\ \not \# \\ \hline \end{gathered}$ |  |  |  |  |  |  |  |  |  | $\begin{gathered} \text { MOD } \\ 1 \end{gathered}$ | PEAK \# | $\begin{gathered} \text { ENPH } \\ \text { REG } \\ \not Z+ \\ \hline \end{gathered}$ | M |
| N | $\begin{gathered} \text { DET } \\ 0 \end{gathered}$ | $\begin{gathered} \text { OEIEXT } \\ \nexists \end{gathered}$ | $\begin{gathered} \hline \text { outmux } \\ 0 \end{gathered}$ | $\begin{gathered} \text { outmux } \\ 1 \end{gathered}$ | $\begin{aligned} & \hline \mathbf{C} \\ & 2 \end{aligned}$ | $\begin{aligned} & \hline \mathbf{C} \\ & \mathbf{B} \end{aligned}$ | $\begin{gathered} c \\ 13 \end{gathered}$ | $\begin{gathered} C \\ 14 \end{gathered}$ | $\begin{gathered} A D \\ 0 \end{gathered}$ | $\begin{gathered} \text { MODPT } \\ 12 \mathrm{PI} \\ \nexists \neq \end{gathered}$ | $\begin{gathered} \text { ENCF } \\ \text { REG } \\ \neq \end{gathered}$ | $\begin{gathered} \text { LOAD } \\ \# \end{gathered}$ | $\begin{gathered} \mathrm{MOD} \\ 0 \end{gathered}$ | BINFMT \# | $\begin{aligned} & \text { ENOF } \\ & \text { REG } \\ & \not \not H \end{aligned}$ | N |
| P | GND | $\begin{aligned} & \text { OER } \\ & \# \end{aligned}$ | $\begin{aligned} & C \\ & 1 \end{aligned}$ | $\begin{aligned} & C \\ & 3 \end{aligned}$ | $\begin{aligned} & C \\ & 6 \end{aligned}$ | $\begin{aligned} & \mathbf{C} \\ & 9 \end{aligned}$ | $\begin{gathered} C \\ 10 \end{gathered}$ | $\begin{gathered} C \\ 15 \end{gathered}$ | $\begin{gathered} \text { AD } \\ 1 \end{gathered}$ | $\begin{aligned} & \text { CS } \\ & \not \# \end{aligned}$ | $\left\|\begin{array}{c} \text { ENTIREG } \\ H \end{array}\right\|$ | CL.ROFR <br> \# | PMSEL | $\begin{gathered} \text { PACI } \\ \not \# \end{gathered}$ | $\begin{gathered} \text { TICO } \\ \# \end{gathered}$ | P |
| 0 | $\mathrm{V}_{\text {cc }}$ | $\begin{aligned} & \mathrm{C} \\ & 0 \end{aligned}$ | $\begin{aligned} & C \\ & 4 \end{aligned}$ | $\begin{aligned} & C \\ & 5 \end{aligned}$ | $\begin{aligned} & \mathbf{C} \\ & 7 \end{aligned}$ | $\begin{gathered} C \\ 11 \end{gathered}$ | C | GND | $\mathrm{V}_{\text {cc }}$ | $\begin{aligned} & \text { WR } \\ & \not \# \end{aligned}$ | CLK | $\begin{aligned} & \text { ENI } \\ & \#+ \end{aligned}$ | $\begin{gathered} \text { ENPHAC } \\ \nRightarrow \end{gathered}$ | GND | $V_{\text {cc }}$ | Q |
|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 |  |

## Pin Description

| NAME | NUMBER | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ | A1, A9, A15, G1, J15, Q1, Q7, Q15 |  | +5 Power supply input |
| GND | A8, A14, B1, H1, H15, P15, Q2, Q8 |  | Power supply ground input |
| C0-15 | $\begin{gathered} \mathrm{N} 8-11, \mathrm{P} 8-13, \\ \text { Q9-14 } \end{gathered}$ | 1 | Control input bus for loading phase and frequency data into the PFCS. C15 is the MSB. |
| ADO-1 | N7, P7 | 1 | Address pins for selecting destination of $\mathrm{CO-15}$ data |
| CS\# | P6 | 1 | Chip select (Active Low) |
| WR\# | Q6 | 1 | Write enable. Data is clocked into the register selected by ADO-1 on the rising edge of WR\# when the CS\# line is low. |
| CLK | Q5 | 1 | Clock. All registers, except the control registers clocked with WR\#,are clocked (when enabled) by the rising edge of CLK. |
| ENPHREG\# | M1 | 1 | Phase register enable. (Active low) Registered on chip by CLK. When active, after being clocked onto chip, ENPHREG\# enables the clocking of data into the phase register. |
| ENOFREG\# | N1 | 1 | Frequency offset register enable. (Active Low) Registered on chip by CLK. When active, after being clocked onto chip, ENOFREG\# enables clocking of data into the frequency offset register. |
| ENCFREG\# | N5 | 1 | Center frequency register enable. (Active low) Registered on chip by CLK. When active, after being clocked onto chip, ENCFREG\# enables clocking of data into the center frequency register. |
| ENPHAC\# | Q3 | 1 | Phase accumulator register enable. (Active low) Registered on chip by CLK. When active, after being clocked onto chip, ENPHAC\# enables clocking of the phase accumulator register. |
| ENTIREG\# | P5 | 1 | Time interval control register enable. (Active low) Registered on chip by CLK. When active, after being clocked onto chip, ENTIREG\# enables clocking of data into the time accumulator register. |
| ENI\# | Q4 | I | Real and imaginary data input register (RIR, IIR) enable. (Active low) Registered on chip by CLK. When active, after being clocked onto chip, ENI\# enables clocking of data into the real and imaginary input data register. |
| MODPI/ 2PI\# | N6 | 1 | Modulo $\pi / 2 \pi$ select. When low, the Sine and Cosine ROMs are addressed modulo $2 \pi$ ( 360 degrees). When high, the most significant address bit is held low so that the ROMs are addressed modulo $\pi$ ( 180 degrees). This input is registered on chip by clock. |
| CLROFR\# | P4 | 1 | Frequency offset register output zero. (Active low) Registered on chip by CLK. When active, after being clocked onto chip, CLROFR\# zeros the data path from the frequency offset register to the frequency adder. New data can still be clocked into the frequency offset register; CLROFR\# does not affect the contents of the register. |
| LOAD\# | N4 | 1 | Phase accumulator load control. (Active low) Registered on chip by CLK. Zeroes feedback path in the phase accumulator without clearing the phase accumulator register. |
| MODO-1 | M3, N3 | 1 | External modulation control bits. When selected with the PMSEL line, these bits add a 0,90 , 180, or 270 degree offset to the current phase in the phase accumulator. The lower 14 bits of the phase control path are set to zero. <br> These bits are loaded into the phase register when ENPHREG\# is low. |
| PMSEL | P3 | 1 | Phase modulation select line. This line determines the source of the data clocked into the phase register. When high, the phase control register is selected. When low, the external modulation pins (MODO-1) are selected for the most significant two bits and the least significant two bits and the least significant 14 bits are set to zero. This control is registered by CLK. |
| RBYTILD\# | L3 | 1 | ROM bypass, timer load. Active low, Registered by CLK. This input bypasses the sine/ cosine ROM so that the 16 bit phase adder output and lower 16 bits of the phase accumulator go directly to the CMAC's sine and cosine inputs, respectively. It also enables loading of the timer accumulator register by zeroing the feedback in the accumulator. |

## Pin Description (Continued)

| NAME | NUMBER | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| PACI\# | P2 | 1 | Phase accumulator carry input. (Active low) A low on this pin causes the phase accumulator to increment by one in addition to the values in the phase accumulator register and frequency adder. |
| PACO\# | L13 | 0 | Phase accumulator carry output. Active low and registered by CLK. A low on this output indicates that the phase accumulator has overflowed, i.e., the end of one sine/cosine cycle has been reached. |
| TICO\# | P1 | 0 | Time interval accumulator carry output. Active low, registered by CLK. This output goes low when a carry is generated by the time interval accumulator. This function is provided to time out control events such as synchronizing register clocking to data timing. |
| RINO-18 | $\begin{gathered} \text { C1, C2, D1, D2, } \\ \text { E1-3, F1-3, } \\ \text { G2, G3, H2, } \\ H 3, J 1-3, K 1, K 2 \end{gathered}$ | 1 | Real input data bus. This is the external real component into the complex multiplier. The bus is clocked into the real input data register by CLK when ENI\# is asserted. |
| IMINO-18 | $\begin{gathered} \text { A2-7, B2-7, } \\ \text { C3-8, D3 } \end{gathered}$ | 1 | Imaginary input data bus. This is the external imaginary component into the complex multiplier. The bus is clocked into the real input data register by CLK when ENI\# is asserted. |
| SHO-1 | K3, L1 | 1 | Shift control inputs. These lines control the input shifters of the RIN and IIN inputs of the complex multiplier. The shift controls are common to the shifters on both of the busses. |
| ACC | L2 | 1 | Accumulate/dump control. This input controls the complex accumulators and their holding registers. When high, the accumulators accumulate and the holding registers are disabled. When low, the feedback in the accumulators is zeroed to cause the accumulators to load. <br> The holding registers are enabled to clock in the results of the accumulation. This input is registered by CLK. |
| BINFMT\# | N2 | 1 | This input is used to convert the two's complement output to offset binary (unsigned) for applications using D/A converters. When low, bits RO19 and IO19 are inverted from the internal two's complement representation. This input is registered by CLK. |
| PEAK\# | M2 | I | This input enables the peak detect feature of the block floating point detector. When high, the maximum bit growth in the output holding registers is encoded and output on the DETO-1 pins. When the PEAK\# input is asserted, the block floating point detector output will track the maximum growth in the holding registers, including the data in the holding registers at the time that PEAK\# is activated. |
| OUTMUXO-1 | N12, N13 | 1 | These inputs select the data to be output on ROO-19 and 100-19. |
| ROO-19 | C15, D14, D15 E14, E15, F13-15, G13-15, H13, H14, J13, J14, K13-15, L15, M15 | 0 | Real output data bus. These three state outputs are controlled by OER\# and OEREXT\#. OUTMUXO-1 select the data output on the bus. |
| 100-19 | $\begin{aligned} & \text { A10-13, B8-15, } \\ & \text { C9-14, D13, E13 } \end{aligned}$ | 0 | Imaginary output data bus. These three state outputs are controlled by OEI\# and OEIEXT\#. OUTMUXO-1 select the data output on the bus. |
| DETO-1 | N15, L14 | 0 | These output pins indicate the number of bits of growth in the accumulators. While PEAK\# is low, these pins indicate the peak growth. The detector examines bits 15-18, real and imaginary accumulator holding registers and bits 30-33 of the real and imaginary CMAC holding registers. The bits indicate the largest growth of the four registers. |
| OER\# | P14 | 1 | Three state control for bits ROO-15. Outputs are enabled when the line is low. |
| OEREXT\# | M13 | 1 | Three state control for bits RO16-19. Outputs are enabled when the line is low. |
| OEI\# | M14 | 1 | Three state control for bits 100-15. Outputs are enabled when the line is low. |
| OEIEXT\# | N14 | I | Three state control for bits 1016-19. Outputs are enabled when the line is low. |

## Functional Description

The Numerically Controlled Oscillator/Modulator (NCOM) produces a digital complex sinusoid waveform whose amplitude, phase and frequency are controlled by a set of input command words. When used as a Numerically Controlled Oscillator (NCO), it generates 16 bit sine and cosine vectors at a maximum sample rate of 33 MHz . The NCOM can be preprogrammed to produce a constant (CW) sine and cosine output for Direct Digital Synthesis (DDS) applications. Alternatively, the phase and frequency inputs can be updated in real time to produce a FM, PSK, FSK, or MSK modulated waveform. The Complex Multiplier/ Accumulator (CMAC) can be used to multiply this waveform by an input signal for AM and QAM signals. By stepping the phase input, the output of the ROM becomes an FFT twiddle factor; when data is input to the Vector Inputs (see Block Diagram), the NCOM calculates an FFT butterfly.

As shown in the Block Diagram, the NCOM consists of three parts: Phase and Frequency Control Section (PFCS), Sine/Cosine Generator, and CMAC. The PFCS stores the phase and frequency inputs and uses them to calculate the phase angle of a rotating complex vector. The Sine/Cosine Generator performs a lookup on this phase and outputs the appropriate values for the sine and cosine. The sine and cosine form one set of inputs to the CMAC, which multiplies them by the input vector to form the modulated output.

## Phase and Frequency Control Section

The phase and frequency of the internally generated sine and cosine are controlled by the PFCS (Figure 1). The PFCS generates a 32 bit word that represents the current phase of the sine and cosine waves being generated: the Sine/ Cosine Argument. Stepping this phase angle from 0 through full scale (232-1) corresponds to the phase angle of a sinusoid starting at 00 and advancing around the unit circle counterclockwise. The PFCS automatically increments the phase by a preprogrammed amount on every rising edge of the external clock. The value of the phase step (which is the sum of the Center and Offset Frequency Registers) is:

$$
\text { Phase Step }=\frac{\text { Signal Frequency }}{\text { Clock Frequency }} \times 2^{32}
$$

The PFCS is divided into 2 sections: the Phase Accumulator uses the data on $\mathrm{CO}-15$ to compute the phase angle that is the input to the Sine/Cosine Section (Sine/Cosine Argument); the Time Accumulator supplies a pulse to mark the passage of a preprogrammed period of time.

The Phase Accumulator and Time Accumulator work on the same principle: a 32 bit word is added to the contents of a 32 bit accumulator register every clock cycle; when the sum


FIGURE 1. PHASE/FREQUENCY CONTROL SECTION BLOCK DIAGRAM
causes the adder to overflow, the accumulation continues with the 32 bits of the adder going into the accumulator register. The overflow bit is used as an output to indicate the timing of the accumulation overflows. In the Time Accumulator, the overflow bit generates TICO\#, the Time Accumulator carry out (which is the only output of the Time Accumulator). In the Phase Accumulator, the overflow is inverted to generate the Phase Accumulator Carry Out, PACO\#.

The output of the Phase Accumulator goes to the Phase Adder, which adds an offset to the top 16 bits of the phase. This 32 bit number forms the argument of the sine and cosine, which is passed to the Sine/Cosine Generator.

Both accumulators are loaded 16 bits at a time over the C0-15 bus. Data on C0-15 is loaded into one of the three input registers when CS\# and WR\# are low. The data in the Most Significant Input Register and Least Significant Input Register forms a 32 bit word that is the input to the Center Frequency Register, Offset Frequency Register and Time Accumulator. These registers are loaded by enabling the proper register enable signal; for example, to load the Center Frequency Register, the data is loaded into the LS and MS Input Registers, and ENCFREG\# is set to zero; the next rising edge of CLK will pass the registered version of ENCFREG\#, R.ENCFREG\#, to the clock enable of the Center Frequency Register; this register then gets loaded on the following rising edge of CLK. The contents of the input Registers will be continuously loaded into the Center Frequency Register as long as R.ENCFREG\# is low.

The Phase Register is loaded in a similar manner. Assuming PMSEL is high, the contents of the Phase Input Register is loaded into the Phase Register on every rising clock edge that R.ENPHREG is low. If PMSEL is low, MODO-1 supply the two most significant bits into the Phase Register (MOD1 is the MSB) and the least significant 14 bits are loaded with 0. MODO-1 are used to generate a Quad Phase Shift Keying (QPSK) signal (Table 2).

TABLE 1. ADO-1 DECODING

| AD1 | ADO | CS\# | WR\# | FUNCTION |
| :---: | :---: | :---: | :---: | :--- |
| 0 | 0 | 0 | $\uparrow$ | Load least significant bits of <br> frequency input |
| 0 | 1 | 0 | $\uparrow$ | Load most significant bits of <br> frequency input |
| 1 | 0 | 0 | $\uparrow$ | Load phase register |
| 1 | 1 | X | X | Reserved |
| X | X | 1 | X | Reserved |

The Phase Accumulator consists of registers and adders that compute the value of the current phase at every clock. It has three inputs: Center Frequency, which corresponds to the carrier frequency of a signal; Offset Frequency, which is the deviation from the Center Frequency; and Phase, which is a 16 bit number that is added to the current phase for

PSK modulation schemes. These three values are used by the Phase Accumulator and Phase Adder to form the phase of the internally generated sine and cosine.

The sum of the values in Center and Offset Frequency Registers corresponds to the desired phase increment (modulo $2^{32}$ ) from one clock to the next. For example, loading both registers with zero will cause the Phase Accumulator to add zero to its current output; the output of the PFCS will remain at its current value; i.e., the output of the NCOM will be a DC signal. If a hexadecimal 00000001 is loaded into the Center Frequency Control Register, the output of the PFCS will increment by one after every clock. This will step through every location in the Sine/Cosine Generator, so that the output will be the lowest frequency above DC that can be generated by the NCOM, i.e., the clock frequency divided by 232. If the input to the Center Frequency Control Register is hex 80000000 , the PFCS will step through the Generator with half of the maximum step size, so that frequency of the output waveform will be half of the sample rate.

The operation of the Offset Frequency Control Register is identical to that of the Center Frequency Control Register; having two separate registers allows the user to generate an FM signal by loading the carrier frequency in the Center Frequency Control Register and updating the Offset Frequency Control Register with the value of the frequency offset - the difference between the carrier frequency and the frequency of the output signal. A logic low on CLROFR\# disables the output of the Offset Frequency Register without clearing the contents of the register.

TABLE 2. MODO-1 DECODE

| MOD1 | MODO | PHASE SHIFT (DEGREES) |
| :---: | :---: | :---: |
| 0 | 0 | 0 |
| 0 | 1 | 90 |
| 1 | 0 | 270 |
| 1 | 1 | 180 |

Initializing the Phase Accumulator Register is done by putting a low on the LOAD\# line. This zeroes the feedback path to the accumulator, so that the register is loaded with the current value of the phase increment summer on the next clock.

The final phase value going to the Generator can be adjusted using MODPI/2PI\# to force the range of the phase to be 00 to $180^{\circ}$ (modulo $\pi$ ) or 00 to 3600 (modulo $2 \pi$ ). Modulo $2 \pi$ is the mode used for modulation, demodulation, direct digital synthesis, etc. Modulo $\pi$ is used to calculate FFTs. This is explained in greater detail in the Applications section.

The Phase Register adds an offset to the output of the Phase Accumulator. Since the Phase Register is only 16 bits, it is added to the top 16 bits of the Phase Accumulator.

The Time Accumulator consists of a register which is incremented on every clock. The amount by which it increments is loaded into the Input Registers and is latched into the Time Accumulator Register on rising edges of CLK while ENTIREG\# is low. The output of the Time Accumulator is the accumulator carry out, TICO\#. TICO\# can be used as a timer to enable the periodic sampling of the output of the NCOM. The number programmed into this register equals $2^{32} \times$ CLK period/desired time interval. TICO\# is disabled and its phase is initialized by zeroing the feedback path of the accumulator with RBYTILD\#.

## Sine/Cosine Section

The Sine/Cosine Section (Figure 2) converts the output of the PFCS into the appropriate values for the sine and cosine. It takes the most significant 20 bits of the PFCS output and passes them through a look up table to form the 16 bit sine and cosine inputs to the CMAC.


## Figure 2. SINE/COSINE SECTION

The 20 bit word maps into $2 \pi$ radians so that the angular resolution is $2 \pi / 2^{20}$. An address of zero corresponds to 0 radians and an address of hex FFFFF corresponds to $2 \pi-$ $\left(2 \pi / 2^{20}\right)$ radians. The outputs of the Generator section are 2 's complement sine and cosine values. The sine and cosine outputs range from hexadecimal 8001, which represents negative full scale, to 7FFF, which represents positive full scale. Note that the normal range for two's complement numbers is 8000 to 7 FFF ; the output range of the SIN/COS generator is scaled by one so that it is symmetric about 0 .

The sine and cosine values are computed to reduce the amount of ROM needed. The magnitude of the error in the computed value of the complex vector is less than -90.2 dB . The error in the sine or cosine alone is approximately 2 dB better.

If RBYTILD\# is low, the output of the PFCS goes directly to the inputs of the CMAC. If the real and imaginary inputs of the CMAC are programmed to hex 7FFF and 0 respectively, then the output of the PFCS will appear on output bits 0 through 15 of the NCOM with the output multiplexers set to bring out the most significant bits of the CMAC output (OUTMUX $=00$ ). The most significant 16 bits out of the PFCS appears on IOUTO-15 and the least significant bits come out on ROUTO-15.

## Complex Multiplier/Accumulator

The CMAC (Figure 3) performs two types of functions: complex multiplication/accumulation for modulation and demodulation of digital signals, and the operations necessary to implement an FFT butterfly. Modulation and demodulation are implemented using the complex multiplier and its associated accumulator; the rest of the circuitry in this section, i.e., the complex accumulator, input shifters and growth detect logic are used along with the complex multiplier/accumulator for FFTs. The complex multiplier performs the complex vector multiplication on the output of the Sine/Cosine Section and the vector represented by the real and imaginary inputs RIN and IIN. The two vectors are combined in the following manner:
ROUT $=\operatorname{COS} \times$ RIN $-\operatorname{SIN} \times I I N$
IOUT $=\operatorname{COS} \times \operatorname{IIN}+\operatorname{SIN} \times \operatorname{RIN}$
RIN and IIN are latched into the input registers and passed through the shift stages. Clocking of the input registers is enabled with a low on ENI\#. The amount of shift on the latched data is programmed with $\mathrm{SHO}-1$ (Table 3). The output of the shifters is sent to the CMAC and the auxiliary accumulators.

TABLE 3. INPUT SHIFT SELECTION

| SH1 | SHO | SELECTED BITS |
| :---: | :---: | :---: |
| 0 | 0 | RINO-15, IMINO-15 |
| 0 | 1 | RIN1-16, IMIN1-16 |
| 1 | 0 | RIN2-17, IMIN2-17 |
| 1 | 1 | RIN3-18, IMIN3-18 |

The 33 bit real and imaginary outputs of the Complex Multiplier are latched in the Multiplier Registers and then go through the accumulator section of the CMAC. If the ACC line is high, the feedback to the accumulators is enabled; a low on ACC zeroes the feedback path, so that the next set of real and imaginary data out of the complex multiplier is stored in the CMAC Output Registers.

The data in the CMAC Output Registers goes to the Multiplexer, the output of which is determined by the OUTMUXO- 1 lines (Table 4). BINFMT\# controls whether the output of the Multiplexer is presented in two's complement or unsigned format; BINFMT\# $=0$ inverts ROUT19 and IOUT19 for unsigned output, while BINFMT\# $=1$ selects two's complement.

TABLE 4. OUTPUT MULTIPLEXER SELECTION

| OUT <br> MUX <br> 1 | OUT <br> MUX <br> 0 | RO16-19 | ROO-15 | 1016-19 | 100-15 |
| :---: | :---: | :--- | :--- | :--- | :--- |
| 0 | 0 | Real <br> CMAC <br> $31-34$ | Real CMAC <br> $15-30$ | Imag <br> CMAC <br> $31-34$ | Imag CMAC <br> $15-30$ |
| 0 | 1 | Real <br> CMAC <br> $31-34$ | 0, Real <br> CMAC <br> $0-14$ | Imag <br> CMAC <br> $31-34$ | 0, Imag <br> CMAC <br> $0-14$ |
| 1 | 0 | Real Acc <br> $16-19$ | Real Acc <br> $0-15$ | Imag Acc <br> $16-19$ | Imag Acc <br> $0-15$ |
| 1 | 1 | Reserved | Reserved | Reserved | Reserved |



FIGURE 3. COMPLEX MULTIPLIER/ACCUMULATOR; ALL REGISTERS CLOCKED BY CLK

The Complex Accumulator duplicates the accumulator in the CMAC. The input comes from the data shifters, and its 20 bit complex output goes to the Multiplexer. ACC controls whether the accumulator is enabled or not. OUTMUXO-1 determines whether the accumulator output appears on ROUT and IOUT.

The Growth Detect circuitry outputs a two bit value that signifies the amount of growth on the data in the CMAC and Complex Accumulator. Its output, DETO-1, is encoded as shown in Table 5. If PEAK\# is low, the highest value of DETO-1 is latched in the Growth Detect Output Register.

The relative weighting of the bits at the inputs and outputs of the CMAC is shown in figure 4. Note that the binary point of the sine, cosine, RIN and IIN is to the right of the most signif-
icant bit, while the binary point of RO and IO is to the right of the fifth most significant bit. These CMAC external input and output busses are aligned with each other to facilitate cascading NCOM's for FFT applications.

TABLE 5. GROWTH ENCODING

| DET 1 | DET O | NUMBER OF BITS OF GROWTH ABOVE 20 |
| :---: | :---: | :---: |
| 0 | 0 | 0 |
| 0 | 1 | 1 |
| 1 | 0 | 2 |
| 1 | 1 | 3 |

## SIN/COS INPUT

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

COMPLEX MULTIPLIER/ACCUMULATOR INPUT (RIN, IIN)


COMPLEX MULTIPLIER/ACCUMULATOR OUTPUT (RO, IO)
OUTMUX $=00$

| 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $-24$ | $2^{3}$ | $2^{2}$ | 21 | $2^{0}$ <br> Radix | $2^{-1}$ <br> Point | $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 |

COMPLEX MULTIPLIER/ACCUMULATOR OUTPUT (RO, IO)
OUTMUX = 01

| 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $-2^{4}$ | $2^{3}$ | $2^{2}$ | $2^{1}$ | $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}$ | 0 |

COMPLEX ACCUMULATOR OUTPUT (RO, IO)
OUTMUX $=10$

| 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| $\mathbf{- 2}^{-24}$ | $2^{3}$ | $2^{2}$ | $2^{1}$ | $2^{2} .^{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}$ |  |
| Radix Point |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

Figure 4. bit weighting

## Applications

The NCOM can be used for Amplitude, Phase and Frequency modulation, as well as in variations and combinations of these techniques, such as QAM. It is most effective in applications requiring multiplication of a rotating complex sinusoid by an external vector. These include AM and QAM modulators and digital receivers. The NCOM implements AM and QAM modulation on a single chip, and is a element in demodulation, where it performs complex down conversion. It can be combined with the Harris HSP43220 Decimating Digital Filter to form the front end of a digital receiver.

## Modulation/Demodulation

Figure 5 shows a block diagram of an AM modulator. In this example, the phase increment for the carrier frequency is loaded into the center frequency register, and the modulating input is clocked into the real input of the CMAC, with the imaginary input set to 0 . The modulated output is obtained at the real output of the CMAC. With a sixteen bit, two's complement signal input, the output will be a 16 bit real number, on ROUTO-15 ( with OUTMUX $=00$ ).


FIGURE 5. AMPLITUDE MODULATION
By replacing the real input with a complex vector, a similar setup can generate QAM signals (Figure 6). In this case, the carrier frequency is loaded into the center frequency register as before, but the modulating vector now carries both amplitude and phase information. Since the input vector and the internally generated sine and cosine waves are both 16 bits, the number of states is only limited by the characteristics of the transmission medium and by the analog electronics in the transmitter and receiver.

The phase and amplitude resolution for the Sine/Cosine section (16 bit output), delivers a spectral purity of greater than 90 dBc . This means that the unwanted spectral components due to phase uncertainty (phase noise) will be greater than 90 dB below the desired output ( dBc , decibels below the carrier). With a 32 bit phase accumulator in the Phase/


FIGURE 6. QUADRATURE AMPLITUDE MODULATION (QAM)
Frequency Control Section, the frequency tuning resolution equals the clock frequency divided by $2^{32}$. For example, a 25 MHz clock gives a tuning resolution of 0.006 Hz .

The NCOM also works with the HSP43220 Decimating Digital Filter to implement down conversion and low pass filtering in a digital receiver (Figure 7). The NCOM performs complex down conversion on the wideband input signal by multiplying the input vector and the internally generated complex sinusoid. The resulting signal has components at twice the center frequency and at DC. Two HSP43220's, one each on the real and imaginary outputs of the HSP45116, perform low pass filtering and decimation on the down converted data, resulting in a complex baseband signal.

figure 7. Channelized receiver chip set

## FFT Butterfly

Figure 8 shows a Fast Fourier Transform (FFT) implementation. The FFT is a highly efficient way of calculating the Discrete Fourier Transform [1]. The basic building block in FFTs is called the butterfly. The butterfly calculation involves adding complex numbers and multiplying by complex sinusoids. The Phase/Frequency Control Section and Sine/Cosine Generator provide the complex sinusoids and the CMAC performs the complex multiplies and adds.


FIGURE 8. RADIX-2 FFT BUTTERFLY
The NCOM circuit shown implements the butterfly shown in Figure 9. The two complex inputs $A$ and $B$ produce two complex outputs $A^{\prime}$ and $B^{\prime}$ using the equations $A^{\prime}=A+B$, $B^{\prime}=(A-B) W^{k}$ where $W^{k}=e^{-j w k}=\cos (w k)+j \sin (w k)$. Two clock cycles are required to calculate the butterfly. A is clocked into the chip first and then $B$ is clocked in. The complex accumulator in the CMAC section adds $A$ and $B$. The

CMAC calculates $(A-B) W^{k}$ as $A W^{k}+B\left(-W^{k}\right) .-W^{k}$ is generated by phase shifting the ROM address 180 degrees using the phase modulation inputs. For radix-2 decimation in frequency FFTs, the phase of the complex sinusoid starts at 0 degrees and increments by a fixed step size (for each pass) after each butterfly. The phase/frequency section is initialized to 0 degrees and the frequency control loaded with the appropriate phase step size for the pass. The resulting words, A' and B', are held in output registers and multiplexed through the output pins for writing to memory. Using a single NCOM clocked at 25 MHz , a 1024 point radix-2 FFT can be computed in (CLK period) $x\left(\mathrm{Nlog}_{2} \mathrm{~N}\right)$, or 410 microseconds.


FIGURE 9. DECIMATION BY FREQUENCY BUTTERFLY

Circuitry is included to implement block floating point FFTs. In block floating point, an exponent is generated for an entire block of data. To implement block floating point, the maximum bit growth during a set of calculations is detected. The number of bits of growth is used to adjust the block's exponent and to scale the block on the next set of calculations to maintain a desired number of bits of precision. This technique requires less memory than true floating point and yields better performance than fixed point implementations, though its resolution does not meet that of true floating point implementations.

## References

[1] Oppenheim, A. V. and Schafer, R. W., Discrete Time Signal Processing, Prentice Hall

## Absolute Maximum Ratings



## Operating Conditions

```
Operating Voltage Range +4.75 V to +5.25 V
Operating Temperature Range
\(.0^{\circ} \mathrm{C}\) to \(+70^{\circ} \mathrm{C}\)
```


## D.C. Electrical Specifications

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{1 \mathrm{H}}$ | Logical One Input Voltage | 2.0 | - | v | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| $\mathrm{V}_{\text {IL }}$ | Logical Zero Input Voltage | - | 0.8 | V | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| $\mathrm{V}_{1 \mathrm{HC}}$ | High Level Clock Input | 3.0 | - | V | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| $\mathrm{V}_{\text {ILC }}$ | Low Level Clock Input | - | 0.8 | v | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output HIGH Voltage | 2.6 | - | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Output LOW Voltage | - | 0.4 | V | $\mathrm{I}^{\mathrm{OL}}=+2.0 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| 1 | Input Leakage Current | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}$ or $\mathrm{GND}, \mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| 10 | I/O Leakage Current | -10 | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{OUT}}=\mathrm{V}_{\mathrm{CC}} \text { or } \mathrm{GND}, \\ & \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V} \end{aligned}$ |
| ICcsB | Standby Power Supply Current | - | 500 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{I N}=V_{C C} \text { or } G N D \\ & V_{C C}=5.25 \mathrm{~V}, \text { Note } 3 \end{aligned}$ |
| ${ }^{\text {I CCOP }}$ | Operating Power Supply Current | - | 150 | mA | $f=15 \mathrm{MHz}, \mathrm{~V}_{I N}=V_{C C} \text { or } G N D$ $V_{C C}=5.25 \mathrm{~V} \text {, Notes } 1 \text { and } 3$ |

Capacitance ( $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$, Note 2)

| SYMBOL | PARAMETER | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{\mathbb{I N}}$ | Input Capacitance | - | 15 | pF | FREQ $=1 \mathrm{MHz}, \mathrm{V}_{\text {CC }}=$ Open, <br> All measurements are referenced |
| to device ground |  |  |  |  |  |

## NOTES:

1. Power supply current is proportional to operating frequency. Typical 3. Output load per test load circuit with switch open and $C_{L}=40 \mathrm{pF}$. rating for ${ }^{1} \mathrm{CCOP}$ is $10 \mathrm{~mA} / \mathrm{MHz}$.
2. Not tested, but characterized at initial design and at major process/design changes.
A.C. Electrical Specifications $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ (Note 1)

| SYMBOL | PARAMETER | -15 (15MHz) |  | -25 (25.6MHz) |  | $-33(33 \mathrm{MHz})$ |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |  |
| $\mathrm{T}_{\mathrm{CP}}$ | CLK Period | 66 |  | 39 |  | 30 |  | ns |  |
| $\mathrm{T}_{\mathrm{CH}}$ | CLK High | 26 |  | 15 |  | 12 |  | ns |  |
| $\mathrm{T}_{\mathrm{CL}}$ | CLK Low | 26 |  | 15 |  | 12 |  | ns |  |
| $\mathrm{T}_{\text {WL }}$ | WR\# Low | 26 |  | 15 |  | 12 |  | ns |  |
| TWH | WR\# High | 26 |  | 15 |  | 12 |  | ns |  |
| TAWS | Set-up Time; ADO-1, CS\# to WR\# Going High | 18 |  | 13 |  | 13 |  | ns |  |
| ${ }^{\text {T }}$ AWH | Hold Time; ADO, AD1, CS\# from WR\# Going High | 0 |  | 0 |  | 0 |  | ns |  |
| T ${ }^{\text {cWs }}$ | Set-up Time CO-15 from WR\# Going High | 20 |  | 15 |  | 15 |  | ns |  |
| ${ }^{\text {T }}$ WWH | Hold Time CO-15 from WR\# Going High | 0 |  | 0 |  | 0 |  | ns |  |
| TWC | Set-up time WR\# High to CLK High | 20 |  | 16 |  | 12 |  | ns | Note 3 |
| $\mathrm{T}_{\text {MCS }}$ | Set-up Time MODO-1 to CLK Going High | 20 |  | 15 |  | 15 |  | ns |  |
| TMCH | Hold Time MODO-1 from CLK Going High | 0 |  | 0 |  | 0 |  | ns |  |
| TPCS | Set-up Time PACI\# to CLK Going High | 25 |  | 15 |  | 11 |  | ns |  |
| ${ }^{\text {TPCH }}$ | Hold Time PACI\# from CLK Going High | 0 |  | 0 |  | 0 |  | ns |  |
| TECS | Set-up ENPHREG\#, ENCFREG\#, ENOFREG\#, ENPHAC\#, ENTIREG\#,CLROFR\#, PMSEL, LOAD\#,ENI\#, ACC, BINFMT\#, PEAK\#, MODPI/2PI\#, SHO-1, RBYTILD\# from CLK Going High | 18 |  | 12 |  | 12 |  | ns |  |
| TECH | Hold Time ENPHREG\#, ENCFREG\# ENOFREG\#,ENPHAC\#, ENTIREG\#, CLROFR\#,PMSEL, LOAD\#, ENI\#, ACC, BINFMT\#, PEAK\#, MODPI/2PI\#, SHO-1, RBYTILD\# from CLK Going High | 0 |  | 0 |  | 0 |  | ns |  |
| TDS | Set-up Time RINO-18, IMINO-18 to CLK Going High | 18 |  | 12 |  | 12 |  | ns |  |
| TDH | Hold Time RINO-18, IMINO-18 from CLK Going High | 0 |  | 0 |  | 0 |  | ns |  |
| TDO | CLK to Output Delay ROO-19, 100-19 |  | 40 |  | 24 |  | 19 | ns |  |
| TDEO | CLK to Output Delay DETO-1 |  | 40 |  | 27 |  | 20 | ns |  |
| TPO | CLK to Output Delay PACO\# |  | 30 |  | 20 |  | 12 | ns |  |
| TTO | CLK to Output Delay TICO\# |  | 30 |  | 20 |  | 12 | ns |  |
| ToE | Output Enable Time OER\#, OEI\#, OEREXT\#, OEIEXT\# |  | 25 |  | 20 |  | 20 | ns |  |
| $\mathrm{T}_{\text {MD }}$ | OUTMUXO-1 to Output Delay |  | 40 |  | 28 |  | 26 | ns |  |
| Ton | Output Disable Time |  | 20 |  | 15 |  | 15 | ns | Note 2 |
| TRF | Output Rise, Fall Time |  | 8 |  | 8 |  | 6 | ns | Note 2 |

## NOTES:

1. A.C. testing is performed as follows: Input levels (CLK Input) 4.0 V and OV ; Input levels (all other inputs) OV and 3.0 V ; Timing reference levels (CLK) 2.0 V ; All others 1.5 V . Output load per test load circuit with switch closed and $\mathrm{C}_{\mathrm{L}}=$ 40 pF . Output transition is measured at $\mathrm{V}_{\mathrm{OH}} \geq 1.5 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{OL}} \leq 1.5 \mathrm{~V}$.
2. Controlled via design or process parameters and not directly tested. Characterized upon initial design and after major process and/or design changes.
3. Applicable only when outputs are being monitered and ENCFREG\#, ENPHREG\#, or ENTIREG\# is active.

## Waveforms



CONTROL BUS TIMING


INPUT AND OUTPUT TIMING

## Waveforms (Continued)



OUTPUT RISE AND FALL TIMES

Test Load Circuit


Switch S1 open for ${ }^{\text {I CCSB }}$ and ${ }^{\text {I CCOP tests }}$
EQUIVALENT CIRCUIT

## Features

- This Circuit is Processed in Accordance to Mil-Std-883 and is Fully Conformant Under the Provisions of Paragraph 1.2.1
- NCO and CMAC on One Chip
- 15 MHz and 25.6MHz Versions
- 32-bit Frequency Control
- 16-bit Phase Modulation
- 16-bit CMAC
- 0.006 Hz Tuning Resolution at 25.6 MHz
- Spurious Frequency Components <-90dBc
- Fully Static CMOS
- 145 Pin PGA


## Applications

- Frequency Synthesis
- Modulation - AM, FM, PSK, FSK, QAM
- Demodulation, PLL
- Phase Shifter
- Fast Fourier Transforms (FFT)
- Polar to Cartesian Conversions


## Description

The Harris HSP45116/883 combines a high performance quadrature numerically controlled oscillator (NCO) and a high speed 16-bit Complex Multiplier/Accumulator (CMAC) on a single IC. This combination of functions allows a complex vector to be multiplied by the internally generated (cos, $\sin$ ) vector for quadrature modulation and demodulation. As shown in the block diagram, the HSP45116/883 is divided into three main sections. The Phase/Frequency Control Section (PFCS) and the Sine/Cosine Section together form a complex NCO. The CMAC multiplies the output of the Sine/Cosine Section with an external complex vector.

The inputs to the Phase/Frequency Control Section consist of a microprocessor interface and individual control lines. The phase resolution of the PFCS is 32 bits, which results in frequency resolution better than 0.006 Hz at 25.6 MHz . The output of the PFCS is the argument of the sine and cosine. The spurious free dynamic range of the complex sinusoid is greater than 90 dBc .

The output vector from the Sine/Cosine Section is one of the inputs to the Complex Multiplier/Accumulator. The CMAC multiplies this (cos, sin) vector by an external complex vector and can accumulate the result. The resulting complex vectors are available through two 20-bit output ports which maintain the 90 dB spectral purity. This result can be accumulated internally to implement an accumulate and dump filter.

A quadrature down converter can be implemented by loading a center frequency into the Phase/Frequency Control Section. The signal to be downconverted is the Vector Input of the CMAC, which multiplies the data by the rotating vector from the Sine/Cosine Section. The resulting complex output is the down converted signal.

## Block Diagram



## Absolute Maximum Ratings


$\qquad$

Reliability Information

| Thermal Resistance | $\theta_{\text {ja }}$ | $\theta_{\text {jc }}$ |
| :---: | :---: | :---: |
| Ceramic PGA Package | $23.1{ }^{\circ} \mathrm{C} / \mathrm{W}$ | $8.3^{\circ} \mathrm{C} / \mathrm{W}$ |
| Maximum Package Power Dissipation at $+125^{\circ} \mathrm{C}$ |  |  |
| Ceramic PGA Package |  | 16 Watt |
| Device Count | 103,00 | ransistors |

CAUTION: Stresses above those listed in "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.

## Operating Conditions

Operating Voltage Range +4.5 V to +5.5 V
Operating Temperature Range $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

TABLE 1. HSP45116/883 D.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and 100\% Tested

| PARAMETER | SYMBOL | CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| Logical One Input Voltage | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \leq+125^{\circ} \mathrm{C}$ | 2.2 | - | V |
| Logical Zero Input Voltage | VIL | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 0.8 | V |
| Logical One Input Voltage Clock | VIHC | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 3.0 | - | V |
| Logical Zero Input Voltage Clock | VILC | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 0.8 | V |
| Output HIGH Voltage | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & \mathrm{lOH}=-400 \mu \mathrm{~A} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}(\text { Note } 1) \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq T_{\text {A }} \leq+125^{\circ} \mathrm{C}$ | 2.6 | - | V |
| Output LOW Voltage | Vol | $\begin{aligned} & \mathrm{IOL}^{2}=+2.0 \mathrm{~mA} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}(\text { Note } 1) \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \top \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 0.4 | V |
| Input Leakage Current | 1 | $\begin{aligned} & V_{I N}=V_{C C} \text { or } G N D \\ & V_{C C}=5.5 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Output or I/O Leakage Current | 10 | $\begin{aligned} & V_{\text {OUT }}=V_{C C} \text { or GND } \\ & V_{C C}=5.5 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Standby Power Supply Current | I'cesb | $\begin{aligned} & V_{I N}=V_{C C} \text { or GND, } \\ & V_{C C}=5.5 \mathrm{~V}, \\ & \text { (Note 4) } \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 500 | $\mu \mathrm{A}$ |
| Operating Power Supply Current | ICCOP | $\begin{aligned} & f=15 \mathrm{MHz}, \\ & V_{I N}=V_{C C} \text { or GND } \\ & V_{C C}=5.5 \mathrm{~V}(\text { Notes } 2,4) \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 150 | mA |
| Functional Test | FT | (Note 3) | 7,8 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | - |  |

## NOTES:

1. Interchanging of force and sense conditions is permitted.
2. Operating Supply Current is proportional to frequency, typical rating is $10 \mathrm{~mA} / \mathrm{MHz}$.
3. Tested as follows: $f=1 \mathrm{MHz}, \mathrm{V}_{\mathrm{IH}}$ (clock inputs) $=3.4 \mathrm{~V}, \mathrm{~V}_{\mathrm{IH}}$ (all other inputs) $=2.6 \mathrm{~V}, \mathrm{~V}_{\mathrm{IL}}=0.4 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}} \geq 1.5 \mathrm{~V}$, and $\mathrm{V}_{\mathrm{OL}} \leq 1.5 \mathrm{~V}$.
4. Output per test load circuit with switch open and $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$.

TABLE 2. HSP45116/883 ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and 100\% Tested

| PARAMETER | SYMBOL | (NOTE 1) CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | -15 (15MHz) |  | -25 (25.6MHz) |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | max | MIN | MAX |  |
| CLK Period | $\mathrm{T}_{\mathrm{CP}}$ |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 66 | - | 39 | - | ns |
| CLK High | ${ }^{\text {T }} \mathrm{CH}$ |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 26 | - | 15 | - | ns |
| CLKLow | $\mathrm{T}_{\mathrm{CL}}$ |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 26 | - | 15 | - | ns |
| WR\# Low | TWL |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | 26 | - | 15 | - | ns |
| WR\# High | TWH |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 26 | - | 15 | - | ns |
| Set-up Time; ADO-1, CS\# to WR\# Going High | ${ }^{\text {TAWS }}$ |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 20 | - | 18 | - | ns |
| Hold Time; ADO, AD1, CS\# from WR\# Going High | TAWH |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns |
| Set-up Time CO-15 from WR\# Going High | TCWs |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 20 | - | 18 | - | ns |
| Hold Time CO-15 from WR\# Going High | ${ }^{\text {T }}$ CWh |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns |
| Set-up Time WR\# to CLK High | TwC | (Note 2) | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 20 | - | 16 | - | ns |
| Set-up Time MODO-1 to CLK Going High | TMCS |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 20 | - | 18 | - | ns |
| Hold Time MODO-1 from CLK Going High | TMCH |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns |
| Set-up Time PACI\# to CLK Going High | TPCS |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 25 | - | 18 | - | ns |
| Hold Time PACI\# from CLK Going High | TPCH |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns |
| Set-up Time ENPHREG\# ENCFRCTL\#, <br> ENPHAC\#, ENTICTL\# CLROFR\#,PMSEL\#, LOAD\#, ENI\#, ACC, BINFMT\#,PEAK\#, MODPI/2PI\#,SHO-1, RBYTILD\# from CLK Going High | TECS |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 20 | - | 15 | - | ns |
| Hold Time ENPHREG\#, ENCFRCTL\#, <br> ENPHAC\#, ENTICTL\# CLROFR\#,PMSEL\#, LOAD\#, ENI\#, ACC, BINFMT\#, PEAK\#, MODPI/2PI\#, SHO-1, RBYTILD\# from CLK Going High | TECH |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns |
| Set-up Time RINO-18, IMINO-18 to CLK Going High | TDS |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 20 | - | 15 | - | ns |
| Hold Time RINO-18, IMINO-18, to CLK Going High | ${ }^{\text {T }}$ DH |  | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | ns |

TABLE 2. HSP45116/883 ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and 100\% Tested

| PARAMETER | SYMBOL | (NOTE 1) CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | -15 |  | -25 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| CLK to Output Delay ROO-19, 100-19 | TDO |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 40 | - | 25 | ns |
| CLK to Output Delay DETO-1 | TDEO |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}^{\prime} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 40 | - | 27 | ns |
| CLK to Output Delay PACO\# | Tpo |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 30 | - | 20 | ns |
| CLK to Output Delay TICO\# | TTO |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 30 | - | 20 | ns |
| Output Enable Time OER\#, OEI\#, OEREXT\#, OEIEXT\# | ToE | ( Note 3) | 9,10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 25 | - | 20 | ns |
| OUTMUXO-1 to Output Delay | $\mathrm{T}_{\text {MD }}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}^{\prime} \leq+125^{\circ} \mathrm{C}$ | - | 40 | - | 28 | ns |

## NOTES:

1. A.C. testing is performed as follows: $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ and 5.5 V . Input levels (CLK Input) 4.0 V and OV ; Input levels (all other inputs) 3.0 V and OV ; Timing reference levels (CLK) 2.0V; All others 1.5 V . Output load per test load circuit with switch closed and $C_{L}=40 \mathrm{pF}$. Output transition is measured at $\mathrm{V}_{\mathrm{OH}} \geq 1.5 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{OL}} \leq 1.5 \mathrm{~V}$.
2. Applicable only when outputs are being monitored and ENCFREG\#, ENPHREG\#, or ENTIREG\# is active.
3. Transition is measured at $\pm 200 \mathrm{mV}$ from steady state voltage, Output loading per test load circuit, with switch closed and $C_{L}=40 p F$.

TABLE 3. HSP45116/883 ELECTRICAL PERFORMANCE CHARACTERISTICS

| PARAMETER | SYMBOL | CONDITIONS | NOTES | TEMPERATURE | -15 |  | -25 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| Input Capacitance | CIN <br> COUT | $\mathrm{VCC}=$ Open, $\mathrm{f}=1 \mathrm{MHz}$ <br> All measurements are referenced to device GND. | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 15 | - | 15 | pF |
| Output Capacitance |  |  | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 15 | - | 15 | pF |
| Output Disable Time | TOD |  | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 20 | - | 15 | ns |
| Output Rise Time | $T_{R}$ | From 0.8 V to 2.0 V | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 8 | - | 8 | ns |
| Output Fall Time | $\mathrm{T}_{\mathrm{F}}$ | From 2.0 V to 0.8 V | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 8 | - | 8 | ns |

NOTES:

1. The parameters in Table 3 are controlled via design or process parameters $\quad$ 2. Loading is as specified in the test load circuit with $C_{L}=40 p F$. and not directly tested. Characterized upon initial design and after major process and/or design changes.

TABLE 4. APPLICABLE SUBGROUPS

| CONFORMANCE GROUPS | METHOD | SUBGROUPS |
| :--- | :---: | :---: |
| Initial Test | $100 \% / 5004$ | - |
| Interim Test | $100 \% / 5004$ | - |
| PDA | $100 \%$ | 1 |
| Final Test | $100 \%$ | $2,3,8 A, 8 B, 10,11$ |
| Group A | - | $1,2,3,7,8 A, 8 B, 9,10,11$ |
| Groups C \& D | Samples/5005 | $1,7,9$ |

## Burn-In Circuit

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A | vcc | $\underset{4}{\operatorname{IMIN}}$ | $\underset{8}{\operatorname{IMIN}}$ | $\underset{9}{\text { IMIN }}$ | $\underset{11}{\operatorname{IMIN}}$ | $\underset{15}{\text { IMIN }}$ | $\underset{16}{\operatorname{IM}}$ | GND | $\mathrm{v}_{\mathrm{cc}}$ | $\begin{aligned} & 10 \\ & 18 \end{aligned}$ | $\begin{aligned} & 10 \\ & 15 \end{aligned}$ | $\begin{aligned} & 10 \\ & 12 \end{aligned}$ | $\begin{aligned} & 10 \\ & 10 \end{aligned}$ | GND | $\mathrm{v}_{\mathrm{cc}}$ |
| B | GND | $\underset{1}{\operatorname{IMIN}}$ | $\underset{5}{\text { IMIN }}$ | $\begin{array}{\|c} \text { IMIN } \\ 7 \end{array}$ | $\begin{gathered} \text { IMIN } \\ 10 \end{gathered}$ | $\underset{13}{\operatorname{Im} / \mathrm{N}}$ | $\begin{gathered} \text { IMIN } \\ 14 \end{gathered}$ | $\begin{aligned} & 10 \\ & 19 \end{aligned}$ | $\begin{aligned} & 10 \\ & 16 \end{aligned}$ | $\begin{aligned} & 10 \\ & 14 \end{aligned}$ | $\begin{aligned} & 10 \\ & 11 \end{aligned}$ | $\begin{gathered} 10 \\ 8 \end{gathered}$ | 10 7 | $\begin{gathered} 10 \\ 5 \end{gathered}$ | 10 2 |
| c | $\begin{aligned} & \text { RIN } \\ & 15 \end{aligned}$ | $\underset{18}{\text { RiN }}$ | $\begin{gathered} \text { IMIN } \\ 2 \end{gathered}$ | $\begin{gathered} \text { IMIN } \\ 3 \end{gathered}$ | $\underset{6}{\operatorname{lm} \mathrm{IN}}$ | $\begin{array}{\|c} \text { IMIN } \\ 12 \end{array}$ | $\begin{gathered} \text { IMIN } \\ 17 \end{gathered}$ | $\begin{gathered} \mathrm{IM} \operatorname{N} \\ 18 \end{gathered}$ | $\begin{aligned} & 10 \\ & 17 \end{aligned}$ | $\begin{aligned} & 10 \\ & 13 \end{aligned}$ | $\begin{gathered} 10 \\ 9 \end{gathered}$ | $\begin{gathered} 10 \\ 6 \end{gathered}$ | 10 4 | $\begin{gathered} 10 \\ 1 \end{gathered}$ | $\begin{aligned} & \text { RO } \\ & 18 \end{aligned}$ |
| D | $\begin{array}{\|c} \hline \text { RIN } \\ 13 \end{array}$ | $\begin{gathered} \text { RIN } \\ 17 \end{gathered}$ | $\begin{array}{\|c\|} \hline \text { IMIN } \\ 0 \end{array}$ |  | 145 LEAD PIN GRID ARRAY TOP VIEW |  |  |  |  |  |  |  | 10 | $\begin{aligned} & \text { RO } \\ & 19 \end{aligned}$ | $\begin{aligned} & \text { RO } \\ & 17 \end{aligned}$ |
| E | $\begin{gathered} \text { RIN } \\ 10 \end{gathered}$ | $\begin{gathered} \text { RIN } \\ 14 \end{gathered}$ | $\begin{gathered} \text { RIN } \\ 16 \end{gathered}$ |  |  |  |  |  |  |  |  |  | 10 | $\begin{aligned} & \text { RO } \\ & 16 \end{aligned}$ | RO 15 |
| F | $\begin{gathered} \text { RIN } \\ 7 \end{gathered}$ | $\begin{aligned} & \text { RIN } \\ & 11 \end{aligned}$ | $\begin{gathered} \text { RIN } \\ 12 \end{gathered}$ |  |  |  |  |  |  |  |  |  | $\begin{aligned} & \text { RO } \\ & 14 \end{aligned}$ | $\begin{aligned} & \text { RO } \\ & 13 \end{aligned}$ | $\begin{aligned} & \text { RO } \\ & 11 \end{aligned}$ |
| G | $\mathrm{v}_{\mathrm{cc}}$ | RIN 9 | RIN |  |  |  |  |  |  |  |  |  | RO | $\begin{aligned} & \hline \text { RO } \\ & 12 \end{aligned}$ | $\begin{aligned} & \text { RO } \\ & 10 \end{aligned}$ |
| H | GND | $\begin{array}{r} \text { RIN } \\ \hline \end{array}$ | $\begin{gathered} \text { RIN } \\ 5 \end{gathered}$ |  |  |  |  |  |  |  |  |  | $\begin{gathered} \text { RO } \\ 8 \end{gathered}$ | $\begin{gathered} \text { RO } \\ 7 \end{gathered}$ | GND |
| J | $\mathrm{RIN}_{3}$ | $\underset{1}{\text { RIN }}$ | $\begin{gathered} \text { RIN } \\ 4 \end{gathered}$ |  |  |  |  |  |  |  |  |  | $\begin{gathered} \mathrm{RO} \\ 5 \end{gathered}$ | $\begin{gathered} \text { RO } \\ \hline \end{gathered}$ | Vcc |
| K | $\underset{\mathbf{2 I N}}{\mathrm{RIN}}$ | RIN | $\underset{1}{S H}$ |  |  |  |  |  |  |  |  |  | $\begin{gathered} \text { RO } \\ 1 \end{gathered}$ | $\begin{gathered} \text { RO } \\ 2 \end{gathered}$ | $\begin{gathered} \text { RO } \\ 6 \end{gathered}$ |
| $L$ | $\underset{\mathrm{O}}{\mathrm{SH}}$ | ACC | RByIMD \# |  |  |  |  |  |  |  |  |  | $\begin{gathered} \text { PACO } \\ \# \end{gathered}$ | $\begin{gathered} \text { DET } \\ 1 \end{gathered}$ | $\begin{gathered} \text { RO } \\ 3 \end{gathered}$ |
| M | $\begin{array}{\|c} \hline \text { ENPH } \\ R C G \\ \text { RE } \end{array}$ | $\begin{aligned} & \text { PEAK } \\ & \# \end{aligned}$ | MOD |  |  |  |  |  |  |  |  |  | $\begin{gathered} \text { oerext } \\ \# \end{gathered}$ | $\begin{aligned} & \text { OEI } \\ & \# \# \end{aligned}$ | $\begin{gathered} \text { RO } \\ 0 \end{gathered}$ |
| N | $\begin{gathered} \text { ENOF } \\ \text { RNGG } \\ \neq \# \end{gathered}$ | $\begin{gathered} \hline \text { вілгмт } \\ \# \end{gathered}$ | $\begin{gathered} \text { MOD } \\ 0 \end{gathered}$ | $\begin{gathered} \text { LOAD } \\ \# \end{gathered}$ | $\begin{aligned} & \text { ENGF } \\ & \text { REGO } \\ & \# \end{aligned}$ | $\begin{array}{\|c} \text { MOOP } \\ \text { 12P1 } \\ \ddagger \end{array}$ | $\begin{gathered} \mathrm{AD} \\ 0 \end{gathered}$ | $\begin{gathered} c \\ \hline 14 \end{gathered}$ | $\begin{gathered} c \\ 13 \end{gathered}$ | $\begin{aligned} & \hline \mathbf{C} \\ & 8 \end{aligned}$ | $\begin{aligned} & \bar{c} \\ & 2 \end{aligned}$ | $\begin{gathered} \text { our- } \\ \text { mux } \\ 1 \end{gathered}$ | $\begin{array}{\|c} \text { MuI } \\ \operatorname{mux} \\ 0 \end{array}$ | $\begin{array}{\|c\|} \hline \text { OEIEXI } \\ \# \end{array}$ | $\mathrm{DET}$ |
| P | $\underset{\#}{\text { Tico }}$ | $\begin{gathered} \text { PACI } \\ \# \end{gathered}$ | pmsel | $\begin{gathered} \text { cinorr } \\ \# \\ \hline \end{gathered}$ | $\left.\right\|_{\text {entraci }}$ | $\begin{aligned} & \text { cs } \\ & \not \# \end{aligned}$ | $\begin{gathered} \text { AD } \\ 1 \end{gathered}$ | $\begin{gathered} C \\ 15 \end{gathered}$ | $\begin{gathered} c \\ 10 \end{gathered}$ | $\begin{aligned} & \mathrm{C} \\ & 9 \end{aligned}$ | $\begin{aligned} & C \\ & 6 \end{aligned}$ | $\begin{aligned} & c \\ & 3 \end{aligned}$ | $\begin{aligned} & c \\ & 1 \end{aligned}$ | $\begin{gathered} \text { OER } \\ \# \end{gathered}$ | GND |
| 0 | $\mathrm{v}_{\mathrm{cc}}$ | GND | enphac <br> \# | $\begin{aligned} & \text { ENI } \\ & \text { \# } \end{aligned}$ | CLK | $\begin{aligned} & \text { WR } \\ & \not \# \end{aligned}$ | $v_{\text {cc }}$ | GND | $\begin{gathered} c \\ \hline 12 \end{gathered}$ | $\begin{gathered} \hline \mathrm{C} \\ 11 \end{gathered}$ | $\begin{aligned} & C \\ & 7 \end{aligned}$ | $\begin{aligned} & \hline c \\ & 5 \end{aligned}$ | $\begin{aligned} & c \\ & 4 \end{aligned}$ | $\begin{aligned} & \mathrm{C} \\ & \mathrm{O} \end{aligned}$ | $v_{\text {cc }}$ |
|  | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |

Burn-In Circuit (Continued)

| $\begin{aligned} & \text { PGA } \\ & \text { PIN } \end{aligned}$ | PIN NAME | BURN-IN SIGNAL | $\begin{aligned} & \text { PGA } \\ & \text { PIN } \end{aligned}$ | PIN NAME | BURN-IN SIGNAL | $\begin{aligned} & \text { PGA } \\ & \text { PIN } \end{aligned}$ | PIN NAME | BURN-IN SIGNAL | $\begin{aligned} & \text { PGA } \\ & \text { PIN } \end{aligned}$ | PIN NAME | BURN-IN SIGNAL |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| D3 | $\operatorname{IMIN}(0)$ | F4 | Q3 | ENPHAC\# | F1 | K14 | RO(2) | $\mathrm{V}_{\mathrm{CC} / 2}$ | A10 | 10(18) | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| C2 | RIN(18) | F9 | P5 | ENTIREG\# | F4 | L15 | RO(3) | $\mathrm{v}_{\mathrm{CC} / 2}$ | B8 | 10(19) | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| D2 | RIN(17) | F8 | Q4 | ENI\# | F1 | J14 | RO(4) | $\mathrm{v}_{\mathrm{CC} / 2}$ | C8 | IMIN(18) | F9 |
| E3 | RIN(16) | F7 | N6 | MODPI/2PI\# | F16 | J13 | $\mathrm{RO}(5)$ | $\mathrm{V}_{\mathrm{CC}} / 2$ | C7 | IMIN(17) | F8 |
| C1 | RIN(15) | F6 | P6 | CS\# | F2 | K15 | RO(6) | $\mathrm{V}_{\mathrm{CC}} / 2$ | A7 | $\operatorname{IMIN}(16)$ | F7 |
| E2 | RIN(14) | F5 | Q5 | CLK | FO | H14 | $\mathrm{RO}(7)$ | $\mathrm{V}_{\mathrm{CC} / 2}$ | A6 | $\operatorname{IMIN}(15)$ | F6 |
| D1 | RIN(13) | F4 | P7 | AD(1) | F4 | H13 | RO(8) | $\mathrm{V}_{\mathrm{CC}} / 2$ | B7 | IMIN(14) | F5 |
| F3 | RIN(12) | F16 | N7 | AD(0) | F3 | G13 | RO(9) | $\mathrm{V}_{\mathrm{CC}} / 2$ | B6 | $\operatorname{IMIN}(13)$ | F4 |
| F2 | RIN(11) | F15 | Q6 | WR\# | F1 | G15 | RO(10) | $\mathrm{V}_{\mathrm{CC} / 2}$ | C6 | IMIN(12 | F16 |
| E1 | $\operatorname{RIN}(10)$ | F14 | P8 | C(15) | GND | F15 | RO(11) | $\mathrm{V}_{\mathrm{CC} / 2}$ | A5 | IMIN(11) | F15 |
| G2 | RIN(9) | F13 | N8 | C(14) | GND | G14 | RO(12) | $\mathrm{v}_{\mathrm{CC} / 2}$ | B5 | $\operatorname{IMIN}(10)$ | F14 |
| G3 | RIN(8) | F12 | N9 | C(13) | GND | F14 | RO(13) | $\mathrm{V}_{\mathrm{CC}} / 2$ | A4 | $\operatorname{IMIN}(9)$ | F13 |
| F1 | RIN(7) | F11 | Q9 | C(12) | GND | F13 | RO(14) | $\mathrm{v}_{\mathrm{CC} / 2}$ | A3 | $\operatorname{IMIN}(8)$ | F12 |
| H2 | RIN(6) | F10 | Q10 | C(11) | GND | E15 | RO(15) | $\mathrm{V}_{\mathrm{CC} / 2}$ | B4 | $\operatorname{IMIN}(7)$ | F11 |
| H3 | RIN(5) | F9 | P9 | C(10) | GND | E14 | RO(16) | $\mathrm{V}_{\mathrm{CC}} / 2$ | C5 | $\operatorname{IMIN}(6)$ | F10 |
| J3 | RIN(4) | F8 | P10 | C(9) | GND | D15 | RO(17) | $\mathrm{V}_{\mathrm{CC}} / 2$ | B3 | $\operatorname{IMIN}(5)$ | F9 |
| J1 | RIN(3) | F7 | N10 | C(8) | GND | C15 | RO(18) | $\mathrm{V}_{\mathrm{CC}} / 2$ | A2 | $\operatorname{IMIN}(4)$ | F8 |
| K1 | RIN(2) | F6 | Q11 | C(7) | GND | D14 | RO(19) | $\mathrm{V}_{\mathrm{CC}} / 2$ | C4 | $\operatorname{MIN}(3)$ | F7 |
| J2 | RIN(1) | F5 | P11 | C(6) | GND | E13 | 10(0) | $\mathrm{V}_{\mathrm{CC} / 2}$ | C3 | $\operatorname{IMIN}(2)$ | F6 |
| K2 | RIN(0) | F4 | Q12 | C(5) | GND | C14 | 10(1) | $\mathrm{V}_{\mathrm{CC} / 2}$ | B2 | $\operatorname{IMIN}(1)$ | F5 |
| K3 | SH(1) | F3 | Q13 | C(4) | GND | B15 | 10(2) | $\mathrm{V}_{\mathrm{CC} / 2}$ | A1 | $\mathrm{V}_{\mathrm{CC}}$ | None |
| L1 | $\mathrm{SH}(0)$ | F2 | P12 | C(3) | GND | D13 | 10(3) | $\mathrm{V}_{\mathrm{CC}} / 2$ | A9 | $V_{C C}$ | $\mathrm{V}_{\mathrm{CC}}$ |
| L2 | ACC | F4 | N11 | C(2) | GND | C13 | 10(4) | $\mathrm{V}_{\mathrm{CC}} / 2$ | A15 | $V_{C C}$ | None |
| M1 | ENPHREG\# | F16 | P13 | C(1) | GND | B14 | 10(5) | $\mathrm{V}_{\mathrm{CC} / 2}$ | G1 | $V_{\text {CC }}$ | $\mathrm{V}_{\text {CC }}$ |
| N1 | ENOFREG\# | F4 | Q14 | C(0) | $V_{\text {CC }}$ | C12 | 10(6) | $\mathrm{v}_{\mathrm{CC}} / 2$ | J15 | $V_{\text {c }}$ | $\mathrm{V}_{\text {CC }}$ |
| M2 | PEAK\# | F8 | N12 | OUTMUX(1) | F11 | B13 | 10(7) | $\mathrm{V}_{\mathrm{CC} / 2}$ | Q1 | $V_{C C}$ | None |
| L3 | RBYTILD\# | F16 | N13 | OUTMUX(0) | F10 | B12 | 10(8) | $V_{\mathrm{CC} / 2}$ | Q7 | $V_{C C}$ | $\mathrm{V}_{\text {CC }}$ |
| N2 | BINFMT\# | F4 | P14 | OER\# | FO | C11 | 10(9) | $\mathrm{V}_{\mathrm{CC} / 2}$ | Q15 | $V_{C C}$ | None |
| P1 | TICO\# | $\mathrm{V}_{\mathrm{CC} / 2}$ | M13 | OEREXT\# | FO | A13 | 10(10) | $V_{C C / 2}$ | A8 | GND | GND |
| M3 | MOD(1) | GND | N14 | OEIEXT\# | FO | B11 | 10(11) | $\mathrm{V}_{\mathrm{CC} / 2}$ | A14 | GND | None |
| N3 | MOD(0) | GND | M14 | OEI\# | Fo | A12 | 10(12) | $\mathrm{V}_{\mathrm{CC} / 2}$ | B1 | GND | None |
| P2 | PACI\# | F4 | L13 | PACO\# | $\mathrm{V}_{\mathrm{CC}} / 2$ | C10 | 10(13) | $\mathrm{V}_{\mathrm{CC} / 2}$ | H1 | GND | GND |
| N4 | LOAD\# | F15 | N15 | DETO | $\mathrm{V}_{\mathrm{CC} / 2}$ | B10 | $10(14)$ | $\mathrm{V}_{\mathrm{CC} / 2}$ | H15 | GND | GND |
| P3 | PMSEL | F1 | L14 | DET1 | $\mathrm{V}_{\mathrm{cC} / 2}$ | A11 | 10(15) | $\mathrm{V}_{\mathrm{CC} / 2}$ | P15 | GND | None |
| P4 | CLROFR\# | F4 | M15 | RO(0) | $\mathrm{V}_{\mathrm{CC} / 2}$ | B9 | $10(16)$ | $\mathrm{V}_{\mathrm{CC} / 2}$ | Q2 | GND | None |
| N5 | ENCFREG\# | F4 | K13 | RO(1) | $\mathrm{V}_{\mathrm{CC}} / 2$ | C9 | 10(17) | $\mathrm{v}_{\mathrm{CC} / 2}$ | Q8 | GND | GND |

NOTES:

1. $47 \mathrm{~K} \Omega( \pm 20 \%)$ resistor connected to all pins except $V_{C C}$ and GND
2. $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V} \pm 0.5 \mathrm{~V}$ with $0.1 \mu \mathrm{~F}(\mathrm{~min})$ capacitor between $\mathrm{V}_{C C}$ and $G N D$ per position
3. $F O=100 \mathrm{kHz} \pm 10 \%, F 1=F 0 / 2, F 2=F 1 / 2 \ldots \ldots, F 11=F 10 / 2,40 \%$ to $60 \%$ duty cycle
4. Input Voltage limits: $\mathrm{V}_{\mathrm{IL}}=0.8 \mathrm{~V} \max , \mathrm{~V}_{\mathrm{IH}}=4.5 \mathrm{~V} \pm 10 \%$

## Die Characteristics

DIE DIMENSIONS:
$350 \times 353 \times 19 \pm 1$ mils
METALLIZATION:
Type: $\mathrm{Si}-\mathrm{Al}$ or $\mathrm{Si}-\mathrm{Al}-\mathrm{Cu}$
Thickness: 8k $\AA$
GLASSIVATION:
Type: Nitrox
Thickness: $10 \mathrm{k} \AA$
Metallization Mask Layout

DIE ATTACH:
Material: Silver Glass
WORST CASE CURRENT DENSITY: $1.6 \times 10^{5} \mathrm{~A} / \mathrm{cm}^{2}$

HSP45116/883





1XnWI 0 (02)
$00(69)$


SEMICONDUCTOR

## ADVANCE INFORMATION

## Features

- 75MSPS Input Data Rate
- 16 Bit Data Input
- Spurious Free Dynamic Range: > 102dB
- Frequency Selectivity: $\mathbf{~ 0 . 0 0 9 H z}$
- Identical Lowpass Filters for I and Q
- Passband Ripple: $<0.04 \mathrm{~dB}$
- Stopband Attenuation: > 106dB
- Filter -3dB to -102dB Shape Factor: < 1.5
- Decimation from 64 to 131,072
- IEEE 1149.1 Test Access Port
- 40 Pin DIP, 44 Pin PLCC


## Applications

- Digital Radio Receivers
- Channelized Receivers
- Spectrum Analysis


## Description

The Digital Down Converter (DDC) is a single chip synthesizer, quadrature mixer and low pass filter. It takes a 16 bit input data stream at a 75MSPS data rate, downconverts it, performs narrowband low pass filtering and decimation to produce a baseband signal.
The internal synthesizer can tune in on a variety of signal, including CW , frequency hopped and swept sine waves. The complex result is lowpass filtered and decimated with identical real filters in the in-phase (I) and quadrature ( $Q$ ) processing chains. The lowpass filtering is accomplished by a high decimation filter (HDF) followed by a fixed finite impulse response filter (FIR). The combined response of the two stage filter results in a shape factor of 1.5 from -3 dB to -102 dB . The stopband attenuation is greater than 106 dB . The composite passband ripple is less than 0.04 dB .

The chip receives forty bit serial commands as a control input. This interface is compatible with the serial I/O port available on most microprocessors.

The output data can be configured in several formats, including 16 to 38 bit fixed point, which is available as two's complement, unsigned and sign magnitude. There is also an option for single precision IEEE floating point format.

The phase generator can also be bypassed to provide a direct input to the high decimation filter section. This allows the DDC to be used as a high decimation filter.

In circuit test is provided by an IEEE 1149.1 Test Access Port.

## Block Diagram




## SPECIAL FUNCTION

PAGE
DATA SHEETS

HSP45240
HSP45240/883
HSP45256
HSP45256/883
HSP48410
HSP9501
HSP9520/9521
ISP9520/9521

Address Sequencer
6-3
Address Sequencer
6-15
Binary Correlator. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6-21
Binary Correlator
6-34
Histogrammer/Accumulating Buffer
6-42
Programmable Data Buffer . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6-53
Multilevel Pipeline Register
6-60

## Features

- Block Oriented 24-Bit Sequencer
- Configurable as Two Independent 12-Bit Sequencers
- $24 \times 24$ Crosspoint Switch
- Programmable Delay on 12 Outputs
- Multi-Chip Synchronization Signals
- Standard $\mu P$ Interface
- TTL Compatible Inputs/Outputs
- 100pF Drive on Outputs
- DC to 50 MHz Clock Rate
- Available in 68 Pin PGA and PLCC Packages


## Applications

- 1-D, 2-D Filtering
- Pan/Zoom Addressing
- FFT Processing
- Matrix Math Operations


## Description

The Harris HSP45240 is a high speed Address Sequencer which provides specialized addressing for functions like FFT's,1-D and 2-D filtering, matrix operations, and image manipulation. The sequencer supports block oriented addressing of large data sets up to 24 bits at clock speeds up to 50 MHz .

Specialized addressing requirements are met by using the onboard $24 \times 24$ crosspoint switch. This feature allows the mapping of the 24 address bits at the output of the address generator to the 24 address outputs of the chip. As a result, bit reverse addressing, such as that used in FFT's, is made possible.

A single chip solution to read/write addressing is also made possible by configuring the HSP45240 as two 12-bit sequencers. To compensate for system pipeline delay, a programmable delay is provided on 12 of the address outputs.

The HSP45240 is manufactured using an advanced CMOS process, and is a low power fully static design. The configuration of the device is controlled through a standard microprocessor interface and all inputs/outputs, with the exception of clock, are TTL compatible. The Sequencer is available in 68 pin PGA and PLCC packages.

ADDRESS SEQUENCER HSP45240 68 PIN PLASTIC LEADED CHIP CARRIER (PLCC)


68 PIN GRID ARRAY (PGA)
(BOTTOM VIEW)


## Pin Descriptions

| NAME | TYPE | PLCC PIN NUMBER | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ | 1 | $\begin{gathered} 6,24,34,41 \\ 49,55,68 \end{gathered}$ | +5 V power supply pin. |
| GND | 1 | $\begin{gathered} 3,9,18,22 \\ 38,46,52 \\ 58,65 \end{gathered}$ | GROUND |
| RST\# | 1 | 25 | RESET: This active low input causes a chip reset which lasts for 26 clocks after RST\# has been de-asserted. The reset initializes the Crosspoint Switch and some of the configuration registers as described in the Processor Interface section. The chip must be clocked for reset to complete. |
| CLK | 1 | 23 | CLOCK: The "CLK" signal is a CMOS input which provides the basic timing for address generation. |
| WR\# | 1 | 19 | WRITE: The rising edge of this input latches the data/address on DO-6 to be latched into the Processor Interface. |
| CS\# | 1 | 21 | CHIP SELECT: This active "low" input enables the configuration data/address on DO-6 to be latched into the Processor Interface. |
| AO | 1 | 20 | ADDRESS 0 : This input defines DO-6 as a configuration register address if "high", and configuration data if "low", (see Processor Interface text). |
| D0-6 | 1 | 11-17 | DATA BUS: Data bus for Processor Interface. |
| OEH\# | 1 | 28 | OUTPUT ENABLE HIGH: This asynchronous input is used to enable the output buffers for OUT12-23. |
| OEL\# | 1 | 29 | OUTPUT ENABLE LOW: This asynchronous input is used to enable the output buffers for OUTO-11. |
| STARTIN\# | 1 | 31 | START-IN: This active low input initiates an addressing sequence. May be tied to STARTOUT\# of another HSP45240 for multi-chip synchronization. STARTIN\# should only be asserted for one CLK because address sequencing begins after STARTIN\# is de-asserted. |
| DLYBLK | I | 30 | DELAY BLOCK: This active "high" input may be used to halt address generation on address block boundaries (see Sequence Generator text). The required timing relationship of this signal to the end of an address block is shown in Application Note 9205. |
| OUTO-23 | 0 | $\begin{gathered} 39,40,42,45, \\ 47,48,50,51, \\ 53,54,56,57, \\ 59,62-64,66, \\ 67,1,2,4,5, \\ 7,8 \end{gathered}$ | OUTPUT BUS: TTL compatible 24-bit Address Sequencer output. |
| BLOCKDONE\# | 0 | 36 | BLOCK DONE: This active low output signals when the last address in an address block is on OUTO-23. |
| DONE\# | 0 | 37 | DONE: This active low output signals when the last address of an address sequence is on OUTO-23. |
| ADDVAL\# | 0 | 33 | ADDRESS VALID: This active low output signals when the first address of an address sequence is on OUTO-23. |
| STARTOUT\# | 0 | 32 | START-OUT: This active low output is generated when an address sequence is initiated by a mechanism other than STARTIN\#. May be tied to the STARTIN\# of other HSP45240's for multichip synchronization. |
| BUSY\# | 0 | 35 | BUSY: This active low output is asserted one CLK after RST\# is de-asserted and will remain asserted for 25 CLK's. While BUSY\# is asserted all writes to the Processor Interface are disabled. |

Denotes active low.

## Functional Description

The Address Sequencer is a 24-bit programmable address generator. As shown in the Block Diagram, the sequencer consists of 4 functional blocks: the start circuitry, the sequence generator, the crosspoint switch, and the processor interface. The addresses produced by the sequence generator are input into the crosspoint switch. The crosspoint switch maps 24 bits of address input to a 24 bit output. This allows for addressing schemes like "bitreverse" addressing for FFT's. A programmable delay block is provided to allow the MSW of the output to be skewed from the LSW. This feature may be used to compensate for processor pipeline delay when the sequence generator is configured as two independent 12 bit sequencers. Address Sequencer operation is controlled by values loaded into configuration registers associated with the sequence generator, crosspoint switch, and start circuitry. The configuration registers are loaded through the processor interface.

## Start Circuitry

The Start Circuitry generates the internal START signal which causes the Sequence Generator to initiate an addressing sequence. The START signal is produced by writing the Processor Interface's "Sequencer Start" address (see Processor Interface text), by asserting the STARTIN\# input, or by the terminal address of a sequence generated under "One-Shot Mode with Restart" (see Sequence Generator section). Care should be taken to assert STARTIN\# for only one clock cycle to insure proper operation. A programmable delay from 1 to 31 clocks is provided to delay the initiation of an addressing sequence by delaying the internal START signal (see Processor Interface text).

The Start Circuitry generates the output signal ADDVAL\# which is asserted when the first valid output address is at the pads. In addition, the Start Circuitry generates the "STARTOUT\#" signal for multichip syncronization. Note: STARTOUT\# is only generated when an addressing sequence is started by writing the "Sequencer Start" address of the Processor Interface, or an internal START is generated by reaching the end of an addressing sequence produced by "One-Shot Mode with Restart".

## Sequence Generator

The Sequence Generator is a block oriented address generator. This means that the desired address sequence is subdivided into one or more address blocks each containing a user defined number of addresses. User supplied configuration data determines the number of address blocks and the characteristics of the address sequence to be generated.
As shown in Figure 1, the Sequence Generator is subdivided into the an address generation and control section. The address generation section performs an accumlation based on the output of MUX1 and MUX2. The control section governs the operation of the multiplexers, enables loading of the Block Start Address register, and signals completion of an address sequence.

An address sequence is started when the control section of the Sequence Generator receives the internal START signal from the Start Circuitry. When the START signal is received, the control section multiplexes the contents of the Start

Address Register and a " 0 " to the adder. The result of this summation is the first address in the first block of the address sequence. This value is stored in the Block Start Address register by an enable generated from the control section, and the multiplexers are switched to feed the output of the Holding and Address Increment registers to the adder. Address generation will continue with the Address Increment added to the contents of the Holding Register until the first address block has been completed.

An address block is completed when the number of addresses generated since the beginning of the address block equals the value stored in the Block Size register. When the last address of the block is generated, BLOCKDONE\# is asserted to signal the end of the address block (see Application Note 9205). On the following CLK, the multiplexers are configured to pass the contents of the Block Start Address and Block Increment registers to the adder which generates the first address of the next address block. An enable from the control section allows this value to update the Block Start Address register, and the multiplexers are switched to feed the Holding and Address Increment registers to the adder for generation of the remaining addresses in the block.
The address sequence is completed when the number of address blocks generated equals the value loaded into the Number of Blocks register. When the final address in the last address block has been generated, DONE\# and BLOCKDONE\# are asserted to signal the completion of the address sequence.

The parameters governing address generation are loaded into five 24-bit configuration registers via the Processor Interface. These parameters include the Start Address, the beginning address of the sequence; the Block Size, the number of addresses in the address block; the Address Increment, the increment between addresses in a block; the Number of Blocks, the number of address blocks in a sequence (minimum 1); the Block Increment, the increment between starting addresses of each block. The loading and structure of these registers is detailed in the Processor Interface text.


FIGURE 1. SEQUENCE GENERATOR BLOCK

Three modes of operation may be selected by loading the 6-bit Mode Control register (see Processor Interface). The three modes of operation are:

1. One-Shot Mode without Restart Address generation halts after completion of the user specified address sequence. Address generation will not resume until the internal START signal is generated by the Start Circuitry. When the final address in the final block of the address sequence is generated, both DONE\# and BLOCKDONE\# are asserted and the last address is held on OUTO-23 (See Application Note 9205).
2. One-Shot Mode with Restart: This mode is identical to One-Shot Mode without Restart with the exception that the Start Circuitry automatically generates an internal START at the end of the user specified sequence to restart address generation. The end of the address sequence is signaled by the assertion of DONE\#, BLOCKDONE\#, and STARTOUT\# as shown in Application Note 9205. In this mode, the first address of the next sequence immediately follows the last address of the current sequence if start delay is disabled.
3. Continuous Mode: Address generation never terminates. Address generation proceeds based on the Start Address, Address Increment, Block Size, and Block Increment Parameters. The Number of Blocks parameter is ignored, and the DONE\# signal is never asserted.

The Mode Control register is also used to configure the Sequence Generator for operation as two independent 12-bit address sequencers. In dual sequencer mode, the adder in the sequence generator suppresses the carry from the 12 LSB's to the 12 MSB's. With the carry suppressed, two independent sequences may be produced. These 12-bit address sequences may be delayed relative to each other by programming the Mode Control register for a delay up to 7 clocks. This feature is useful to compensate for pipeline delay when using dual sequencer mode to generate read/write addressing.

The DLYBLK input can be used to halt address generation at the end of any address block within a sequence. In addition, DLYBLK can be used to delay an address sequence from restarting if asserted at the end of the final address block generated under "One-Shot Mode with Restart". See Application Note 9205 for the timing relationship of DLYBLK to the end of the address block required to halt address sequencing.

## Crosspoint Switch

The crosspoint switch is responsible for reordering the address bits output by the sequence generator. The switch allows any of its 24 inputs to be independently connected to any of its 24 outputs. The crosspoint switch outputs can be driven by only one input, however, one input can drive any number of switch outputs. If none of the inputs are mapped to a particular output bit, that output will be "low".
The input to output map is configured through the processor interface. The I/O map is stored in a bank of 24 configuration registers. Each register corresponds to one output bit. The output bit is mapped to the input via a value, 0 to 23, stored in the register. After power-up, the user has the option of configuring the switch in 1:1 mode by using the
reset input, "RST\#". In 1:1 mode the cross-point switch outputs are in the same order as the input. More details on configuring the switch registers are contained in the Processor Interface text.

## Processor Interface

The Processor Interface consists of a 10 pin microprocessor interface and a register bank which holds configuration data. The data is loaded into the register bank by first writing the register address to the processor Interface and then writing the data. An auto address increment mode is provided so that a base address may be written followed by a number of data writes.
The microprocessor interface consists of a 7 bit data bus (DO-6), a one bit address select (AO) to specify DO-6 as either address or data, a write input (WR\#) to latch data into the Processor Interface, and a chip select input (CS\#) to enable writing to the interface. The Processor Interface input is decoded as either data or address as shown by the bit map in Table 1.

TABLE 1.

| REGISTER ADDRESSES |  |  |  |  |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | AO | D6 | D5 | D4 | D3 | D2 | D1 | DO |
| Switch Output Registers | 1 | $x$ | 0 | $n$ | $n$ | $n$ | $n$ | $n$ |
| Sequencer Starting <br> Address | 1 | $x$ | 1 | 0 | 0 | 0 | $n$ | $n$ |
| Sequencer Block Size | 1 | $x$ | 1 | 0 | 0 | 1 | $n$ | $n$ |
| Sequencer Number of <br> Blocks | 1 | $x$ | 1 | 0 | 1 | 0 | $n$ | $n$ |
| Sequencer Block <br> Address Increment | 1 | $x$ | 1 | 0 | 1 | 1 | $n$ | $n$ |
| Sequencer Address <br> Increment | 1 | $x$ | 1 | 1 | 0 | 0 | $n$ | $n$ |
| Mode Control | 1 | $x$ | 1 | 1 | 0 | 1 | 0 | 0 |
| Test Control | 1 | $x$ | 1 | 1 | 0 | 1 | 0 | 1 |
| Start Delay Control | 1 | $x$ | 1 | 1 | 0 | 1 | 1 | 0 |
| Address Sequencer <br> "START" | 1 | $x$ | 1 | 1 | 1 | 1 | 1 | 1 |
|  |  | DATA WORDS |  |  |  |  |  |  |
|  | AO | D5 | D4 | D3 | D2 | $D 1$ | D0 |  |
| Current Address Data <br> (no address increment) | 0 | 0 | $n$ | $n$ | $n$ | $n$ | $n$ | $n$ |
| Current Address Data <br> (address increment) | 0 | 1 | $n$ | $n$ | $n$ | $n$ | $n$ | $n$ |

Table 1 " $x$ " means "don't care", and " $n$ " denotes bits which are decoded as an address in address registers and data in data registers.
The register bank consists of a series of 6 bit registers which may be addressed individually as shown in Table 1. The data in these registers is down loaded into configuration registers in the Start Circuitry, Sequence Generator, and Crosspoint Swith when an address sequence is initiated by the internal START signal (see Start Circuitry). This double buffered architecture allows new configuration data to be down loaded to the Processor Interface while an address sequence is being completed using previous configuration data.

The register bank has five sets of four registers which contain address generation parameters. These parameters include: Address Start, Block Size, Number of Blocks, Block Increment, and Address Increment. Each register set maps to one of five 24-bit configuration registers in the Sequence Generator block (see Sequence Generator). The mapping of the 6-bit registers in the register bank to the 24-bit configuration registers is determined by the 2 LSB's of the register address. The higher the value of the 2 LSB's the higher the relative mapping of the 6-bit register to the 24-bit register. For example, if the 2 LSB's of the register address are both 0 , the register contents will map to the 6 LSB's of the configuration register.
The register bank has 24 registers which contain the data for Crosspoint Switch I/O mapping. These registers are accessed via the 5 LSB's of the address for the Crosspoint Mapping registers in Table 1. A value from 0 to 23 accesses the mapping registers for OUTO-23 repectively. A value greater than 23 is ignored. The output bit represented by a particular register is mapped to the input by the 6-bit value loaded into the register. If the value loaded into the register exceeds 23 , the correponding output bit will be "0". For example, if the 5 LSB's of the Crosspoint Mapping address are equal to 3 , and the valued loaded into the register accessed by this address is equal to 23 , OUT3 would be mapped to the MSB of the sequence generator output.

After a reset, the Mode Control, Test Control, and Start Delay registers are reset as described in the section describing each register's bit map; the Crosspoint Mapping registers are reset to a $1: 1$ crosspoint switch mapping; the registers which hold the five address generation parameters are not affected.

To save the user the expense of alternating between address and data writes, an auto address increment mode is provided. The address increment mode is invoked by performing data writes with a " 1 " in the D6 location of the data word as shown in Table 1. For example, the crosspoint switch could be configured by 25 writes to the Processor Interface (one write for the starting address of the crosspoint mapping registers followed by 24 data writes to those registers).

## Mode Control Register

The Mode Control Register is used to control the operation of the sequence generator. In addition, it also controls the output delay between the MSW and the LSW of OUTO-23. The following tables illustrate the structure of the mode control register.

TABLE 2. MODE CONTROL REGISTER FORMAT

| ADDRESS LOCATION: $1 \times 110100$ |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| D5 | D4 | D3 | D2 | D1 | D0 |
| OD2 | OD1 | ODO | DS | M1 | M0 |

ODx - Output Delay: Delays OUTO-11 from OUT12-23 by the following number of clocks.

| OD2 | OD1 | ODO |  |
| :---: | :---: | :---: | :--- |
| 0 | 0 | 0 | Output Delay of 0 |
| 0 | 0 | 1 | Output Delay of 1 |
| 0 | 1 | 0 | Output Delay of 2 |
| 0 | 1 | 1 | Output Delay of 3 |
| 1 | 0 | 0 | Output Delay of 4 |
| 1 | 0 | 1 | Output Delay of 5 |
| 1 | 1 | 0 | Output Delay of 6 |
| 1 | 1 | 1 | Output Delay of 7 |

DS - Dual Sequencer Enable: Allows two independent 12- bit sequences to be generated.

| 0 | A 24-bit sequence is generated. |
| :--- | :--- |
| 1 | Two 12-bit sequences are generated. |

Mx - Mode: Sequencer Mode.

| M1 | M0 |  |
| :---: | :---: | :--- |
| 0 | 0 | One-Shot Mode without Restart |
| 0 | 1 | One-Shot Mode with Restart |
| 1 | $x$ | Continuous Mode ( $x=$ don't care) |

During reset, this register will be reset to all zeroes. This will configure the chip as a 24-bit sequencer with zero delays on the outputs. The chip will also be in one-shot mode without restart.

## Start Delay Control Register

The Start Delay Control Register is used to configure the start circuitry for delayed starts from 1 to 31 clock cycles. Internal "START", external "START", and restarts will be delay by the programmed amount. The structure of the Start Delay Control Register is shown in Table 3.

TABLE 3. START DELAY CONTROL REGISTER FORMAT

| ADDRESS LOCATION: $1 \times 110110$ |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| D5 | D4 | D3 | D2 | D1 | D0 |
| SDE | SD4 | SD3 | SD2 | SD1 | SD0 |

SDE - Start Delay Enable: Enables "START" to be delayed by the programmed amount. When Start Delay is enabled, a minimum of " 1 " is required for the programmed delay.

| 0 | Start Delay is Disabled. |
| :---: | :--- |
| 1 | Start Delay is Enabled. |

SDx - Start Delay: Delays the "START" by the decoded number of clocks.

| SD4 | SD3 | SD2 | SD1 | SD0 |  |
| :---: | :---: | :---: | :---: | :---: | :--- |
| 0 | 0 | 0 | 0 | 1 | Start Delay of 1 |
| 0 | 0 | 0 | 1 | 0 | Start Delay of 2 |
| 0 | 0 | 0 | 1 | 1 | Start Delay of 3 |
| 1 | 1 | 1 | 1 | 1 | Start Delay of 31 |

During reset, this register will be reset to all zeros. This will bring the chip up in a mode with Start Delay disabled.

## Test Control Register

A Test Control Register is provided to configure the sequence generator to produce test sequences. In this mode, the sequence generator can be configured to multiplex out the contents of the down counters in the sequence generator control circuitry, Figure 2. These counters are used to determine when a block or sequence is complete. As shown in Figures 1 and 2, the MSW or LSW in the down counters is multiplexed to the MSW of the address generator output. In addition, a test mode is provided in which the sequence generator performs a shifting operation on the contents of the start address register. The structure of the Test Control Register is shown in Table 4.


FIGURE 2. SEQUENCE GENERATOR CONTROL

TABLE 4. TEST CONTROL REGISTER FORMAT

| ADDRESS LOCATION: $1 \times 110101$ |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| D 5 | D4 | D3 | D2 | D1 | D0 |
| xx | xx | SE | COE | CS1 | CSO |

Bits "D5" and "D6" are currently not used.

SE - Shifter Enable: Input to crosspoint switch is generated by shifting Start Address Register one bit per clock.

| 0 | Sequence Generator Functions Normally |
| :--- | :--- |
| 1 | Sequence Generator Functions as Shift Register |

COE - Counter Output Enable: Enable contents of down counters in the sequence generator control circuitry to be muxed to the 12 MSB 's of the address generator output.

| 0 | Disable Muxing of down counters |
| :---: | :--- |
| 1 | Enable Muxing of down counters |

CS - Counter Select: Selects which 12-bit word of the down counters is muxed to the MSW of the address generator output.

| CS1 | CSO |  |
| :---: | :---: | :--- |
| 0 | 0 | Select Counter \#1, bits 0-11 |
| 0 | 1 | Select Counter \#1, bits 12-23 |
| 1 | 0 | Select Counter \#2, bits 0-11 |
| 1 | 1 | Select Counter \#2, bits 12-23 |

During reset, this register will be reset to all zeroes. This will bring the chip up in the mode with all of the test features disabled.

## Applications

## Image Processing

The application shown in Figure 3 uses the HSP45240 Address Sequencer to satisfy the addressing requirements for a simple image processing system. In this example the controller configures the sequencers to generate specialized addressing sequences for reading and writing the frame buffers. A typical mode of operation for this system might be to perform edge detection on a sub-section of an image stored in the frame buffer. In this application, data is fed to the 2-D Convolver by the address sequence driving the input frame buffer.
A graphical interpretation of sub-image addressing is shown in Figure 4. Each dot in the figure corresponds to an image pixel stored in memory. It is assumed that the pixel values are stored by row. For example, the first 16 memory locations would contain the first row of pixel values. The 17 th memory location would contain the first pixel of the second row.


FIGURE 3. IMAGE PROCESSING SYSTEM


The sub-image address sequence shown in Figure 3 is generated by configuring the sequence generator with the following:

| 1. Start Address | $=35$ | 4. Step Size | $=1$ |
| :--- | :--- | :--- | :--- |
| 2. Block Size | $=8$ | 5. Block Step Size | $=16$ |
| 3. Number of Blocks $=8$ |  |  |  |

In this example the start address corresponds to the address of the first pixel of the first row. The row length corresponds to the Block Size which is programmed to 8. Within the block, consecutive addresses are generated by programming the Step Size to 1 . At the completion of first block of addresses, the Block Step Size of 16 is added to the Start Address to generate the address of the first pixel of the second row. Finally, 8 rows of addressing are generated by setting the Number of Blocks to 8.

In this application, the sub-image is processed one time and then a new sub-image area is chosen. As a result, the Mode Control Register would be configured for One-Shot mode without Restart. Also, the Start Delay Control register of the Sequencer driving the output frame buffer would be configured with a start delay to compensate for the pipeline delay introduced by the 2-D Convolver. Finally, the crosspoint switch would be configured in $1: 1$ mode so that the sequence generator output has a 1 to 1 mapping to the chip output.

For applications requiring decimation of the original image, the Step Size could be increased to provide addressing which skips over pixels along a row. Similary, the Block Step Size could be increased such that pixel rows are skipped.

## FFT Processing

The application shown in Figure 5 depicts the architecture of a simplified radix 2 FFT processor. In this application the Address Sequencer drives a memory bank which feeds the arithmetic processor with data. In a radix 2 implementation, the arithmetic processor takes two complex data inputs and produces two results. These results are then stored in the registers from which the data came. This type of implementation is referred to as an "in place" FFT algorithm.

The arithmetic processing unit performs an operation know as the radix 2 butterfly which is shown graphically in Figure 6. In this diagram the node in the center of the butterfly represents summing point while the arrow represents a multiplication point. The flow of an FFT computation is described by diagrams comprised of many butterflies as shown in Figure 7.

The FFT processing shown in Figure 7 consists of three stages of radix 2 butterfly computation. The read/write addressing, expressed in binary, for each stage is shown in Table 5. The specialized addressing required here is produced by using the crosspoint switch to map the address bits from the sequence generator to the chip output.

The mapping for the sequencer's crosspoint switch is determined, by inspecting the addressing for each stage. For example, the first stage of addressing is generated by configuring the crosspoint switch so that bit 0 of the switch input is mapped to bit 2 of the switch output, bit 1 of the
switch input is mapped to bit 0 of the output, and bit 2 of the switch input is mapped to bit 1 of the switch output. The remainder of the switch I/O map is configured 1:1, i.e. bit 3 of the switch input is mapped to bit 3 of the switch output. Under this configuration, a sequence generator output of $0,1,2,3,4,5,6,7$ will produce a crosspoint switch output of $0,4,1,5,2,6,3,7$. The switch maps for the other stages as well as a map for the bit-reverse addressing of the FFT result is given in Table 5.
The serial count required as input for the crosspoint switch is generated by configuring the sequence generator with the following:

1. Start Address
$=0$ 4. Step Size
$=1$
2. Block Size $=8$
3. Block Step Size
$=0$
4. Number of Blocks $=1$

Under this configuration the sequence generator will produce a count from 0 to 7 in increments of 1 . The FFT length corresponds to the Block Size, in this case 8.
The serial count from the sequence generator is converted into the desired addressing sequence by applying the appropriate map to the crosspoint switch. In this application, the switch mapping changes for each stage of the FFT computation. Thus, while one address sequence is being completed, the crosspoint switch is being configured for the next stage of FFT addressing. When one stage of addressing is complete, the new switch configuration is loaded into the current state registers by an internal or externally generated start or restart.
The crosspoint switch is configured for the first stage of addressing by writing a 0 to switch output register 2 , a 2 to switch output register 1, and a 0 to switch output register 2. These values are loaded by first writing the address of switch output register 0 and then loading data using auto-address increment mode (see Table 1). The remaining registers are assumed to be configured in 1:1 mode as a result of a prior "RESET". The second and third stages of addressing are generated by reconfiguring the above three registers.
The Address Sequencer can be configured in dual sequencer mode to provide both read and write addressing for each butterfly. Since 2 independent 12 bit sequences can be generated by the Address Sequencer, it can be used to provide read/write addressing for FFT's up to 4096 points. The programmable delay between the MSW and LSW of the Sequencer output is used to compensate for the pipeline delay associated with the arithmetic processor.
table 5. FFT ADDRESSING BY COMPUTATIONAL STAGE

| STAGE 1 R/W ADDR. | STAGE 2 R/W ADDR. | STAGE 3 R/W ADDR. | OUTPUT ADDRESSING |
| :---: | :---: | :---: | :---: |
| 000 | 000 | 000 | 000 |
| 100 | 010 | 001 | 100 |
| 001 | 001 | 010 | 010 |
| 101 | 011 | 011 | 110 |
| 010 | 100 | 100 | 001 |
| 110 | 110 | 101 | 101 |
| 011 | 101 | 110 | 011 |
| 111 | 111 | 111 | 111 |
| SWITCH MAPPING |  |  |  |
| 021 | 201 | 210 | 012 |



FIGURE 5. FFT PROCESSOR


FIGURE 6. BUTTERFLY FOR DECIMATION-IN-FREQUENCY


FIGURE 7. COMPLETE EIGHT-POINT IN-PLACE DECIMATION-IN-FREQUENCY FFT

## Absolute Maximum Ratings



CAUTION: Stresses above those listed in the "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.

## Operating Conditions


D.C. Electrical Specifications ( $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}+5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| PARAMETER | SYMBOL | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Logical One Input Voltage | $\mathrm{V}_{\mathrm{IH}}$ | 2.0 | - | V | $V_{C C}=5.25 \mathrm{~V}$ |
| Logical Zero Input Voltage | $\mathrm{V}_{\text {IL }}$ | - | 0.8 | V | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| High Level Clock Input | $\mathrm{V}_{\mathrm{IHC}}$ | 3.0 | - | V | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| Low Level Clock Input | $\mathrm{V}_{\text {ILC }}$ | - | 0.8 | V | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Output HIGH Voltage | VOH | 2.6 | - | v | $\mathrm{I}^{\mathrm{OH}}=-400 \mu \mathrm{~A}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Output LOW Voltage | VOL | - | 0.4 | V | $\mathrm{IOL}=+2.0 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Input Leakage Current | 1 | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {CC }}$ or $\mathrm{GND}, \mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| I/O Leakage Current | 10 | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {OUT }}=\mathrm{V}_{\text {CC }}$ or GND, $\mathrm{V}_{\text {CC }}=5.25 \mathrm{~V}$ |
| Standby Power Supply Current | I'ccsb | - | 500 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{I N}=V_{C C} \text { or } G N D, \\ & V_{C C}=5.25 \mathrm{~V}, \text { Outputs open } \end{aligned}$ |
| Operating Power Supply Current | ICCOP | - | 99 | mA | $\begin{aligned} & f=33 \mathrm{MHz}, \\ & V_{I N}=V_{C C} \text { or GND, } V_{C C}=5.25 \mathrm{~V}, \\ & \text { Outputs Open, (Note 1) } \end{aligned}$ |
| Input Capacitance | $\mathrm{CIN}_{1}$ | - | 10 | pF | $f=1 \mathrm{MHz}, \mathrm{V}_{\mathrm{CC}}=$ Open, |
| Output Capacitance | $\mathrm{C}_{0}$ | - | 10 | pF |  |

## NOTES:

1. Power supply current is proportional to operating frequency. Typical 2 . Not tested, but characterized at initial design and at major rating for ${ }^{1} \mathrm{CCOP}$ is $3 \mathrm{~mA} / \mathrm{MHz}$.
process/design changes.

## A．C．Electrical Specifications $\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}+5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $\left.+70^{\circ} \mathrm{C}\right)$（Note 2）

| PARAMETER | SYMBOL | －33（33MHz） |  | －40（ 40 MHz ） |  | -50 （ 50 MHz ） |  | UNIT | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |  |
| Clock Period | TCP | 30 | － | 25 | － | 20 | － | ns |  |
| Clock Pulse Width High | $\mathrm{T}_{\mathrm{CH}}$ | 12 | － | 10 | － | 9 | － | ns |  |
| Clock Pulse Width Low | TCL | 12 | － | 10 | － | 9 | － | ns |  |
| Setup Time D0－6 to WR\＃High | $\mathrm{T}_{\mathrm{DS}}$ | 14 | － | 13 | － | 12 | － | ns |  |
| Hold Time DO－6 from WR\＃High | ${ }^{\text {T }}$ D | 0 | － | 0 | － | 0 | － | ns |  |
| Set－up Time AO，CS\＃，to WR\＃Low | TAS | 5 | － | 5 | － | 5 | － | ns |  |
| Hold Time AO，CS\＃，from WR\＃High | $\mathrm{T}_{\text {AH }}$ | 0 | － | 0 | － | 0 | － | ns |  |
| Pulse Width for WR\＃Low | TWRL | 13 | － | 12 | － | 10 | － | ns |  |
| Pulse Width for WR\＃High | TWRH | 13 | － | 12 | － | 10 | － | ns |  |
| WR\＃Cycle Time | TWP | 30 | － | 25 | － | 20 | － | ns |  |
| Set－up Time STARTIN\＃， DLYBLK，to Clock High | TIS | 12 | － | 10 | － | 8 | － | ns |  |
| Hold Time STARTIN\＃， DLYBLK，to Clock High | TIH | 0 | － | 0 | － | 0 | － | ns |  |
| Clock to Output Prop． <br> Delay on OUTO－23 | TPDO | － | 15 | － | 13 | － | 12 | ns |  |
| Clock to Output Prop． <br> Delay on STARTOUT\＃， BLKDONE\＃，DONE\＃， ADDVAL\＃，and BUSY\＃ | TPDS | － | 15 | － | 13 | － | 12 | ns |  |
| Output Enable Time | TEN | － | 20 | － | 15 | － | 13 | ns |  |
| Output Disable Time | TOD | － | 20 | － | 15 | － | 13 | ns | Note 1 |
| Output Rise／Fall Time | TORF | － | 5 | － | 3 | － | 3 | ns | Note 1 |
| RST\＃Low Time | TRST | 2 Clock Cycles |  |  |  |  |  | ns |  |

## NOTES：

1．Controlled by design or process parameters and not directly tested． Characterized upon initial design and after major process and／or design changes．

2．A．C．Testing is performed as follows：Input levels（CLK Input）$=4.0 \mathrm{~V}$ and OV；Input levels（All other inputs）$=\mathrm{OV}$ and 3.0 V ；Input timing reference levels：$(C L K)=2.0 \mathrm{~V}$ ，（Others）$=1.5 \mathrm{~V}$ ；Output timing references： $\mathrm{V}_{\mathrm{OH}} \geq 1.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}} \leq 1.5 \mathrm{~V}$ ．

## A．C．Test Load Circuit

| OUTPUT PIN | $\mathrm{C}_{\mathrm{L}}$ |
| :--- | :---: |
| BLOCKDONE\＃ <br> DONE\＃ <br> ADDVAL\＃ <br> STARTOUT\＃ <br> BUSY\＃ | 40 pF |
| OUTO－23 | 100 pF |


＊Test Head Capacitance
Switch S1 Open for ICCSB and ICCOP Tests．

Timing Diagrams


ADDRESS/CHIP SELECT SETUP AND HOLD


OUTPUT ENABLE, DISABLE TIMING


WR\# AC PARAMETERS


OUTPUT PROPOGATION DELAY


OUTPUT RISE AND FALL TIMING

## Features

- This Circuit is Processed in Accordance to Mil-Std883 and is Fully Conformant Under the Provisions of Paragraph 1.2.1.
- Block Oriented 24-Bit Sequencer
- Configurable as Two Independent 12-Bit Sequencers
- $24 \times 24$ Crosspoint Switch
- Programmable Delay on 12 Outputs
- Multi-Chip Synchronization Signals
- Standard $\mu \mathrm{P}$ Interface
- TTL Compatible Inputs/Outputs
- 100pF Drive on Outputs
- DC to 40 MHz Clock Rate
- Available in 68 Pin PGA Package


## Applications

- 1-D, 2-D Filtering
- Pan/Zoom Addressing
- FFT Processing
- Matrix Math Operations


## Description

The Harris HSP45240 is a high speed Address Sequencer which provides specialized addressing for functions like FFT's, 1-D and 2-D filtering, matrix operations, and image manipulation. The sequencer supports block oriented addressing of large data sets up to 24 bits at clock speeds up to 40 MHz .

Specialized addressing requirements are met by using the onboard $24 \times 24$ crosspoint switch. This feature allows the mapping of the 24 address bits at the output of the address generator to the 24 address outputs of the chip. As a result, bit reverse addressing, such as that used in FFT's, is made possible.

A single chip solution to read/write addressing is also made possible by configuring the HSP45240 as two 12-bit sequencers. To compensate for system pipeline delay, a programmable delay is provided on 12 of the address outputs.

The HSP45240 is manufactured using an advanced CMOS process, and is a low power fully static design. The configuration of the device is controlled through a standard microprocessor interface and all inputs/outputs, with the exception of clock, are TTL compatible. The Sequencer is available in a 68 pin PGA package.

## Absolute Maximum Ratings



Reliability Information

| Thermal Resistance | $\theta_{\text {ja }}$ | $\theta_{\text {jc }}$ |
| :---: | :---: | :---: |
| Ceramic PGA Package | $37.1{ }^{\circ} \mathrm{C} / \mathrm{W}$ | $10.1{ }^{\circ} \mathrm{C} / \mathrm{W}$ |
| Maximum Package Powe Ceramic PGA Package | $+125^{\circ} \mathrm{C}$ | . 1.35 Watt |
| Gate Count |  | , 388 Gat |

CAUTION: Stresses above those listed in "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.

## Operating Conditions

Operating Voltage Range
+4.5 V to +5.5 V
Operating Temperature Range $\ldots \ldots \ldots \ldots \ldots . . .5^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

TABLE 1. D.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Devices Guaranteed and 100\% Tested

| PARAMETER | SYMBOL | CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| Logical One Input Voltage | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{v}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 2.2 | - | V |
| Logical Zero Input Voltage | $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 0.8 | V |
| Output HIGH Voltage | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & \mathrm{IOH}^{\mathrm{O}}=-400 \mu \mathrm{~A} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}(\text { Note } 1) \end{aligned}$ | 1,2,3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 2.6 | - | V |
| Output LOW Voltage | $\mathrm{V}_{\mathrm{OL}}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OL}}=+2.0 \mathrm{~mA} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}(\text { Note } 1) \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 0.4 | v |
| Input Leakage Current | 1 | $\begin{aligned} & V_{I N}=V_{C C} \text { or } G N D \\ & V_{C C}=5.5 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Output Leakage Current | 10 | $\begin{aligned} & V_{\text {OUT }}=V_{C C} \text { or GND } \\ & V_{C C}=5.5 \mathrm{~V} \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Clock Input High | $\mathrm{V}_{\text {IHC }}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 3.0 | - | V |
| Clock Input Low | VILC | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{A} \leq+125^{\circ} \mathrm{C}$ | - | 0.8 | V |
| Standby Power Supply Cúrrent | ${ }^{\prime} \mathrm{Ccss}$ | $\begin{aligned} & V_{I N}=V_{C C} \text { or } G N D \\ & V_{C C}=5.5 \mathrm{~V}, \\ & \text { Outputs Open } \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 500 | $\mu \mathrm{A}$ |
| Operating Power Supply Current | ICCOP | $\begin{aligned} & \mathrm{f}=33 \mathrm{MHz} \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V} \text { (Note 2) } \end{aligned}$ | 1, 2, 3 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 99 | mA |
| Functional Test | FT | (Note 3) | 7,8 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | - |  |

NOTES:

1. Interchanging of force and sense conditions is permitted.
2. Operating Supply Current is proportional to frequency, typical rating is $3 \mathrm{~mA} / \mathrm{MHz}$.
3. Tested as follows: $f=1 \mathrm{MHz}, \mathrm{V}_{\mathrm{IH}}=2.6, \mathrm{~V}_{\mathrm{IL}}=0.4, \mathrm{~V}_{\mathrm{OH}} \geq 1.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}} \leq$ $1.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{IHC}}=3.4 \mathrm{~V}$, and $\mathrm{V}_{\mathrm{ILC}}=0.4 \mathrm{~V}$.

TABLE 2. A.C. ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and 100\% Tested (Note 1)

| PARAMETERS | SYMBOL | CONDITIONS | $\begin{array}{\|c\|} \text { GROUPA } \\ \text { SUB- } \\ \text { GROUP } \end{array}$ | TEMPERATURE | LIMITS |  |  |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | -25 (25MHz) |  | -33 (33MHz) |  | -40 (40MHz) |  |  |
|  |  |  |  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |
| Clock Period | $\mathrm{T}_{\mathrm{CP}}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 39 | - | 30 | - | 25 | - | ns |
| Clock Pulse Width High | ${ }^{\text {T }} \mathrm{CH}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 15 | - | 12 | - | 10 | - | ns |
| Clock Pulse Width Low | TCL |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 15 | - | 12 | - | 10 | - | ns |
| Setup Time D0-6 to WR\# High | ${ }^{T}$ DS |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 17 | - | 16 | - | 14 | - | ns |
| Hold Time DO-6 from WR\# Low | ${ }^{\text {T }}$ DH |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | 0 | - | ns |
| Set-up Time A, CS\#, to WR\# Low | TAS |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 5 | - | 5 | - | 5 | - | ns |
| Hold Time A,CS\#, from WR\# High | $\mathrm{T}_{\text {AH }}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | 0 | - | ns |
| Pulse Width for WR\# Low | TWRL |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 18 | - | 14 | - | 12 | - | ns |
| Pulse Width for WR\# High | TWRH |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | 18 | - | 14 | - | 12 | - | ns |
| WR\# Cycle Time | TWP |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 39 | - | 30 | - | 25 | - | ns |
| Set-up Time STARTIN\#, DLYBLK, to to Clock High | TIS |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 15 | - | 12 | - | 10 | - | ns |
| Hold Time STARTIN\#, DLYBLK, to Clock High | $\mathrm{TIH}^{\text {H }}$ |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 0 | - | 0 | - | 0 | - | ns |
| Clock to Output Prop. Delay on OUTO-23 | TPDO |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 18 | - | 16 | - | 14 | ns |
| Clock to <br> Prop. Delay, on STARTOUT\#, BLKDONE\#, DONE\#, ADVAL\# and BUSY\# | TPDS |  | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 18 | - | 16 | - | 14 | ns |
| Output Enable Time | TEN | Note 2 | 9, 10, 11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ | - | 22 | - | 20 | - | 15 | ns |
| RST\# Low Time | TRST |  | 9, 10,11 | $-55^{\circ} \mathrm{C} \leq \mathrm{T} \mathrm{A} \leq+125^{\circ} \mathrm{C}$ |  |  | 2 Cloc | Cycles |  |  | ns |

## NOTES:

1. A.C. Testing: $V_{C C}=4.5 \mathrm{~V}$ and 5.5 V , Inputs are driven at 3.0 V for Logic " 1 " and 0.0 V for a Logic " 0 ". Input and output timing measurements are made at 1.5 V for both a logic " 1 " and " 0 ". CLK is driven at 4.0 V and OV and measured at 2.0 V .
2. Transition is measured at $\pm 200 \mathrm{mV}$ from steady state voltage with loading as specified by test load circuit and $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$.

TABLE 3. ELECTRICAL PERFORMANCE CHARACTERISTICS

| PARAMETERS | SYMBOL | CONDITIONS | NOTES | TEMPERATURE | LIMITS |  |  |  |  |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | -25 (25MHz) |  | -33 (33MHz) |  | -40 (40MHz) |  |  |
|  |  |  |  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |
| Input Capacitance | $\mathrm{Cl}_{\text {IN }}$ | $\begin{aligned} & v_{C C}=O \text { Open, } \\ & f=1 \mathrm{MHz}, \end{aligned}$ <br> All measurements are referenced to device GND. | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 10 | - | 10 | - | 10 | pF |
| Output Capacitance | COUT | $v_{C C}=\text { Open }$ $f=1 \mathrm{MHz},$ <br> All measurements are referenced to device GND. | 1 | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ | - | 10 | - | 10 | - | 10 | pF |
| Output Disable Delay | ToEz |  | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 22 | - | 20 | - | 15 | ns |
| Output Rise Time | TOR |  | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}^{\prime} \leq+125^{\circ} \mathrm{C}$ | - | 5 | - | 5 | - | 3 | ns |
| Output Fall Time | TOF |  | 1,2 | $-55^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 5 | - | 5 | - | 3 | ns |

NOTES: 1. Parameters listed in Table 3 are controlled via design or process
2. Loading is as specified in the test load circuit with $C_{L}=40 \mathrm{pF}$. parameters and are not directly tested. These parameters are characterized upon initial design and after major process and/or design changes.

TABLE 4. ELECTRICAL TEST REQUIREMENTS

| CONFORMANCE GROUPS | METHOD | SUBGROUPS |
| :--- | :---: | :---: |
| Initial Test | $100 \% / 5004$ | - |
| Interim Test | $100 \% / 5004$ | - |
| PDA | $100 \%$ | 1 |
| Final Test | $100 \%$ | $2,3,8 \mathrm{~A}, 8 \mathrm{~B}, 10,11$ |
| Group A | - | $1,2,3,7,8 \mathrm{~A}, 8 \mathrm{~B}, 9,10,11$ |
| Groups C \& D | Samples $/ 5005$ | $1,7,9$ |

Burn-In Circuit


| PGA PIN | PIN NAME | BURN-IN SIGNAL | PGA PIN | PIN NAME | BURN-IN SIGNAL | $\begin{aligned} & \text { PGA } \\ & \text { PIN } \end{aligned}$ | PIN NAME | BURN-IN SIGNAL | $\left\lvert\, \begin{aligned} & \mathrm{PGA} \\ & \mathrm{PIN} \end{aligned}\right.$ | $\begin{aligned} & \text { PIN } \\ & \text { NAME } \end{aligned}$ | BURN-IN SIGNAL |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A2 | GND | GND | B9 | OUT14 | $\mathrm{V}_{\mathrm{CC} / 2}$ | F11 | OUT8 | $\mathrm{v}_{\mathrm{CC} / 2}$ | K6 | BUSYB | $\mathrm{v}_{\mathrm{CC} / 2}$ |
| A3 | OUT23 | $\mathrm{v}_{\mathrm{CC} / 2}$ | C1 | D2 | F10 | G1 | CSB | F5 | K7 | DONEB | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| A4 | $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ | C2 | D1 | F9 | G2 | AO | F6 | K8 | OUTO | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| A5 | OUT20 | $\mathrm{v}_{\mathrm{CC} / 2}$ | C10 | GND | GND | G10 | OUT6 | $\mathrm{V}_{\mathrm{C} / 2}$ | K9 | $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\text {CC }}$ |
| A6 | OUT19 | $\mathrm{V}_{\mathrm{CC} / 2}$ | C11 | OUT12 | $\mathrm{v}_{\mathrm{CC} / 2}$ | G11 | OUT7 | $\mathrm{V}_{\mathrm{CC} / 2}$ | K11 | OUT3 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| A7 | $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ | D1 | D4 | F12 | H1 | CLK | FO | L2 | OEHB | F13 |
| A8 | OUT16 | $\mathrm{V}_{\mathrm{CC} / 2}$ | D2 | D3 | F11 | H2 | GND | GND | L3 | DLYBLK | F11 |
| A9 | OUT15 | $\mathrm{V}_{\mathrm{CC}} / 2$ | D10 | OUT10 | $\mathrm{v}_{\mathrm{CC} / 2}$ | H10 | OUT5 | $\mathrm{V}_{\mathrm{CC} / 2}$ | L4 | STARTOUTB | $\mathrm{v}_{\mathrm{CC} / 2}$ |
| A10 | OUT13 | $\mathrm{V}_{\mathrm{CC} / 2}$ | D11 | OUT11 | $\mathrm{v}_{\mathrm{CC} / 2}$ | H11 | $\mathrm{V}_{\mathrm{CC}}$ | $V_{C C}$ | L5 | $V_{C C}$ | $\mathrm{V}_{\text {cc }}$ |
| B1 | DO | F8 | E1 | D6 | F7 | J1 | RSTB | F14 | L6 | BLOCKDONEB | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| B3 | OUT22 | $\mathrm{V}_{\mathrm{CC} / 2}$ | E2 | D5 | F13 | J2 | $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ | L7 | GND | GND |
| B4 | OUT21 | $\mathrm{V}_{\mathrm{CC}} / 2$ | E10 | OUT9 | $\mathrm{v}_{\mathrm{CC} / 2}$ | J10 | GND | GND | L8 | OUT1 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| B5 | GND | GND | E11 | $\mathrm{V}_{\mathrm{CC}}$ | $V_{C C}$ | $J 11$ | OUT4 | $\mathrm{V}_{\mathrm{CC}} / 2$ | L9 | OUT2 | $\mathrm{V}_{\mathrm{CC} / 2}$ |
| B6 | OUT18 | $\mathrm{V}_{\mathrm{CC} / 2}$ | F1 | WRB | F4 | K3 | Oelb | F12 |  |  |  |
| B7 | OUT17 | $\mathrm{V}_{\mathrm{CC} / 2}$ | F2 | GND | GND | K4 | STARTINB | F6 |  |  |  |
| B8 | GND | GND | F10 | GND | GND | K5 | ADVALB | $\mathrm{v}_{\mathrm{CC} / 2}$ |  |  |  |

NOTES:

1. $\mathrm{V}_{\mathrm{CC}} / 2(2.7 \mathrm{~V} \pm 10 \%)$ used for outputs only.
2. $0.1 \mu \mathrm{~F}(\mathrm{~min})$ capacitor between $\mathrm{V}_{\mathrm{CC}}$ and GND per position.
3. $47 \mathrm{~K} \Omega( \pm 20 \%)$ resistor connected to all pins except $V_{C C}$ and GND.
4. $V_{C C}=5.5 \pm 0.5 \mathrm{~V}$.
5. $F 0=100 \mathrm{KHz} \pm 10 \%, F 1=F 0 / 2, F 2=F 1 / 2 \ldots, F 11=F 10 / 2,40 \%-$ 60\% Duty Cycle.
6. Input voltage limits: $V_{I L}=0.8 \mathrm{~V} \max ., V_{I H}=4.5 \mathrm{~V} \pm 10 \%$.

## Metallization Topology

DIE DIMENSIONS:
$186 \times 222 \times 19 \pm 1 \mathrm{mils}$

## METALLIZATION:

Type: Si - Al or $\mathrm{Si}-\mathrm{Al}-\mathrm{Cu}$
Thickness: $8 \mathrm{k} \AA$

## GLASSIVATION:

Type: Nitrox
Thickness: $10 \mathrm{k} \AA$
DIE ATTACH:
Material: Si-Au Eutectic Alloy or Silver/Glass
WORST CASE CURRENT DENSITY:
$1.8 \times 10^{5} \mathrm{~A} / \mathrm{cm}^{2}$
Metallization Mask Layout


HARRIS
SEMICONDUCTOR

August 1992

## Features

- Reconfigurable 256 Stage Binary Correlator
- 1-Bit Reference $x$ 1, 2, 4, or 8-Bit Data
- Separate Control and Reference Interfaces
- 25.6, 33MHz Versions
- Configurable for 1-D and 2-D Operation
- Double Buffered Mask and Reference
- Programmable Output Delay
- Cascadable
- Standard Microprocessor Interface
- 85-pin PGA, 84-pin PLCC


## Applications

- Radar/Sonar
- Spread Spectrum Communications
- Pattern/Character Recognition
- Error Correction Coding


## Description

The Harris HSP45256 is a high-speed, 256 tap binary correlator. It can be configured to perform one- or twodimensional correlations of selectable data precision and length. Multiple HSP45256's can be cascaded for increased correlation length. Unused taps can be masked out for reduced correlation length.
The correlation array consists of eight 32-tap stages. These may be cascaded internally to compare 1, 2, 4 or 8 -bit input data with a 1-bit reference. Depending on the number of bits in the input data, the length of the correlation can be up to 256, 128, 64, or 32 taps. The HSP45256 can also be configured as two separate correlators with window sizes from 4 by 32 to 1 by 128 each. The mask register can be used to prevent any subset of the 256 bits from contributing to the correlation score.

The output of the correlation array (correlation score) feeds the weight and sum logic, which gives added flexibility to the data format. In addition, an offset register is provided so that a preprogrammed value can be added to the correlation score. This result is then passed through a user programmable delay stage to the cascade summer. The delay stage simplifies the cascading of multiple correlators by compensating for the latency of previous correlators.

The Binary Correlator is configured by writing a set of control registers via a standard microprocessor interface. To simplify operation, both the control and reference registers are double buffered. This allows the user to load new mask and reference data while the current correlation is in progress.

## Block Diagram



## Pinouts




## Pin Description

| SYMBOL | PLCC PIN NUMBER | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ | 16, 33, 63 |  | The +5V power supply pin. |
| GND | 14, 35, 55, 70, 77 |  | Ground. |
| DINO-7 | 17-24 | 1 | The DINO-7 bus consists of eight single data input pins. The assignment of the active pins is determined by the configuration. Data is loaded synchronous to the rising edge of CLK. DINO is the LSB. |
| DOUTO-7 | 60-62, 64-68 | 0 | The DOUTO-7 bus is the data output of the correlation array. The format of the output is dependent on the window configuration and bit weighting. DOUTO is the LSB. |
| CLK | 15 | 1 | System clock. Positive edge triggered. |
| CASINO-12 | 1-13 | 1 | CASINO-12 allows multiple correlators to be cascaded by connecting CASOUTO-12 of one correlator to CASINO-12 of another. The CASIN bus is added internally to the correlation score to form CASOUT. CASINO is the LSB. |
| CASOUT0-12 | 69, 71-76, 78-83 | 0 | CASOUTO-12 is the output correlation score. This value is the delayed sum of all the 256 taps of one chip and CASINO-12. When the part is configured to act as two independent correlators, CASOUT0-8 represents the correlation score for the first correlator while the second correlation score is available on the AUXOUT0-8 bus. In this configuration, the cascading feature is no longer an option. CASOUTO is the LSB. |
| OEC\# | 84 | 1 | OEC\# is the output enable for CASOUTO-12. When OEC\# is high, the output is threestated. Processing is not interrupted by this pin. (Active low.) |
| TXFR\# | 36 | 1 | TXFR\# is a synchronous clock enable signal that allows the loading of the reference and mask inputs from the preload register to the correlation array. Data is transferred on the rising edge of CLK while TXFR\# is low. (Active low.) |
| DREF0-7 | 25-32 | 1 | DREF0-7 is an 8-bit wide data reference input. This is the input data bus used to load the reference data. RLOAD\# going active initiates the loading of the reference registers. This input bus is used to load the reference registers of the correlation array. The manner in which the reference data is loaded is determined by the window configuration. If the window configuration is $1 \times 256$, the reference bits are loaded one at a time over DREF7. When the HSP45256 is configured as an $8 \times 32$ array, the data is loaded into all stages in parallel. In this case, DREF7 is the reference data for the first stage and DREFO is the reference data for the eighth stage. The contents of the reference data registers are not affected by changing the window configuration. DREFO is the LSB. |
| RLOAD\# | 34 | 1 | RLOAD\# enables loading of the reference registers. Data on DREF0-7 is loaded into the preload registers on the rising edge of RLOAD\#. This data is transferred into the correlation array by TXFR\#. (Active low.) |
| DCONT0-7 | 41-48 | 1 | DCONT0-7 is the control data input, which is used to load the mask bit for each tap as well as the configuration registers. The mask data is sequentially loaded into the eight stages in the same manner as the reference data. DCONTO is the LSB. |
| CLOAD\# | 37 | 1 | CLOAD\# enables the loading of the data on DCONTO-7. The destination of this data is controlled by AO-2. (Active low.) |
| A0-2 | 38-40 | 1 | A0-2 is a 3-bit address that determines what function will be performed when CLOAD\# is active. This address bus is set up with respect to the rising edge of the load signal, CLOAD\#. A0 is the LSB. |
| AUXOUTO-8 | 50-54, 56-59 | 0 | AUXOUT0-8 is a 9-bit bus that provides either the data reference output or the 9-bit correlation score of the second correlator, depending on the configuration. When the user programs the chip to be two separate correlators, the score of the second correlator is output on this bus. When the user has programmed the chip to be one correlator, AUXOUT0-7 represents the reference data out, with the state of AUXOUT0-8 undefined. AUXOUTO is the LSB. |
| OEA\# | 49 | 1 | The OEA\# signal is the output enable for the AUXOUTO-8 output. When OEA\# is high, the output is disabled. Processing is not interrupted by this pin. (Active low.) |

## Functional Description

The correlation array consists of eight 32-bit stages. The first stage receives data directly from input pin DIN7. The other seven stages receive input data from either an external data pin, DINO-6, or from the shift register output of the previous stage, as determined by the Configuration Register. When the part is configured as a single correlator the sum of correlation score, offset register and cascade input appears on CASOUTO-12. Delayed versions of the data and reference inputs appear on DOUTO-7 and AUXOUTO-7, respectively. The input and output multiplexers of the correlation array are controlled together; for example, in a $1 \times 256$ correlation, the input data is loaded into DIN7 and the output appears on DOUT7. The configuration of the data bits, the length of the correlation (and in the two- dimensional data, the number of rows), is commonly called the correlation window.

## Correlator Array

The core of the HSP45256 is the correlation array, which consists of eight 32-tap stages. A single correlator cell consists of an XNOR gate for the individual bit comparison; i.e., if the data and reference bits are either both high or both low, the output of the correlator cell is high. In addition, two latches, one for the reference and one for the control data path are contained in this cell. These latches are loaded from the preload registers on the rising edge of CLK when TXFR\# is low so that the reference and mask values are updated without interrupting data processing.
The mask function is implemented with an AND gate. When a mask bit is a logic low, the corresponding correlator cell output is low.
The function performed by one correlation cell is:

$$
\begin{aligned}
& \left(D_{i, n} \text { XNOR } R_{i, n}\right) \text { AND } M_{i, n} \\
& \text { where: } \\
& D_{i, n}=\text { Bit } i \text { of data register } n \\
& R_{i, n}=\text { Bit } i \text { of reference register } n \\
& M_{i, n}=\text { Bit } i \text { of mask register } n
\end{aligned}
$$

The reference and mask bits are loaded sequentially, $N$ bits at a time, where N depends on the current configuration (See Table 3). New reference data is loaded on the rising edge of RLOAD\# and new mask data is loaded on the rising edge of CLOAD\#. The mask and reference bits are stored internally in shift registers, so that the mask and reference information that was loaded most recently will be used to process the newest data. When new information is loaded in, the previous contents of the mask and reference bits are shifted over by one sample, and the oldest information is lost. There are no registers in the multiplexer array (Figure 1), so the data on DOUTO-7 corresponds to the data in the last element of the correlation array. When monitoring DOUT0-7, AUXOUT0-8, and REFOUT0-7, only those bits listed in Table 3 are valid.

## Weight and Sum Logic

The Weight and Sum Logic provides the bit weighting and final correlator score from the eight stages of the correlation array. For a $1 \times 256$ 1-D configuration, the outputs of each of the stages are given a weight of 1 and then added together. In a $8 \times 32$ (8-bit data) configuration, the output of each stage will be shifted so that the output data represents an 8 -bit word, with stage seven being the MSB.
The 13-bit offset register is loaded from the control data bus. Its output is added to the correlation score obtained from the correlator array. This sum then goes to the programmable delay register data input.
When the chip is configured as dual correlators, the user has the capability of loading two different offset values for the two correlators.
The Programmable Delay Register sets the number of pipeline stages between the output of the weight and sum logic and the input of the Cascade Summer. This delay register is used to align the output of multiple correlators in cascaded configurations (See Applications). The number of delays is programmable from 1 to 16 , allowing for up to 16 correlators to be cascaded. When the HSP45256 is configured as dual correlators, the delay must be set to 0000, which specifies a delay of 1 .

## Cascade Summer

This is used for cascading several correlators together. This value on this bus represents the correlation score from the previous HSP45256 that will be summed with the current score to provide the final correlation score. When several correlators are cascaded, the CASOUTO-12 of each of the other correlators is connected to the CASINO-12 of the next correlator in the chain. The CASINO-12 of the first chip is tied low. The following function represents the correlation score seen on CASOUTO-12 of each correlator:

$$
\begin{aligned}
& \text { CASOUT(n) }=(\text { W7 } \times \text { CO7 })(n \text {-Delay })+(W 6 \times \text { CO6) }(n \text {-Delay })+ \\
& \text { (W5 x CO5)(n-Delay) + (W4 } \times \text { CO4)(n-Delay) }+ \\
& \text { (W3 } \times \text { CO3)(n-Delay) }+ \text { (W2 } \times \text { CO2)(n-Delay) }+ \\
& \text { (W1 } \times \text { CO1)(n-Delay) }+ \text { (W0 } \times \text { COO)(n-Delay) }+ \\
& \text { Offset ( } n \text {-Delay) + CASIN. }
\end{aligned}
$$

where:
COO-CO7 are the correlation score outputs out of the correlation stages; WO-W7 is the weight given to each stage; n -Delay represents the delay on the weighted and summed correlation score through the Programmable Delay Register; Offset is the value programmed into the Offset register; CASIN is the cascade input.


## Control Registers

The 3-bit address value, AO-2, is used to determine which internal register will be loaded with the data on DCONT0-7. The function is initiated when CLOAD\# is brought low, and the register is loaded on the rising edge of CLOAD\#. Table• 1 indicates the function associated with each address. Table 2 shows the function of the bits in each of the registers.

TABLE 1. ADDRESS MAPPING

| A2 | A1 | A0 | DESTINATION |
| :---: | :---: | :---: | :--- |
| 0 | 0 | 0 | Mask Register |
| 0 | 0 | 1 | Configuration Register |
| 0 | 1 | 0 | Offset Register A-Most Significant Bits |
| 0 | 1 | 1 | Offset Register A-Least Significant Bits |
| 1 | 0 | 0 | Programmable Delay Register |
| 1 | 0 | 1 | Offset Register B-Most Significant Bits |
| 1 | 1 | 0 | Offset Register B-Least Significant Bits |
| 1 | 1 | 1 | Reserved |

TABLE 2. CONTROL REGISTER BITS

## A0-2 $=000$ Mask Register

| MR7 | MR6 | MR5 | MR4 | MR3 | MR2 | MR1 | MR0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

MR0-7: Mask Register. When mask register bit $N=1$, the corresponding reference register bit is enabled. Mask register data is loaded from the DCONT0-7 bus into a holding register on the rising edge of CLOAD\# and is written to the mask register on the rising edge of TXFR\#.

A0-2 $=001$ Configuration Register

| - | - | TC | CONFIG4 | CONFIG3 | CONFIG2 | CONFIG1 | CONFIG0 |
| :---: | :---: | :--- | :--- | :--- | :--- | :--- | :--- |

TC: Configures correlator for two's complement input. Inverts the MSB of the input data, where the position of the MSB depends on the current configuration.
CONFIG4: The state of CONFIG4 sets up the HSP45256 as either one or two correlators. When CONFIG4 $=0$, the HSP45256 is configured as one correlator with the correlation score available on CASOUTO-12. When CONFIG4 $=1$, the HSP45256 is configured as dual correlators with the first correlator's score available on CASOUT0-8 and the second score available on AUXOUTO-8. When the chip is configured as dual correlators, the Programmable Delay must be set to 0000 for a delay of 1.
CONFIG2-3: Control the number of data bits to be correlated. See Table 3.
CONFIG0-1: CONFIG1 and CONFIGO represent the length of the correlation window as indicated in Table 3.
A0-2 $=010$ MS Offset Register A

| - | - | - | OFFA12 | OFFA11 | OFFA10 | OFFA9 | OFFA8 |
| :---: | :---: | :---: | :--- | :--- | :--- | :--- | :--- |

OFFA8-12: Most significant bits of Offset Register A. This is the register used in single correlator mode.
A0-2 = 011 LS Offset Register A

| OFFA7 | OFFA6 | OFFA5 | OFFA4 | OFFA3 | OFFA2 | OFFA1 | OFFA0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

OFFA0-7: Least significant bits of Offset Register A.
A0-2 $=100$ Programmable Delay

| - | - | - | - | PDELAY3 | PDELAY2 | PDELAY1 | PDELAYO |
| :---: | :---: | :---: | :---: | :--- | :--- | :--- | :--- |

PDELAYO-3: Controls amount of delay from the weight and sum logic to the cascade summer. The number of delays is 1-16, with PDELAY $=0000$ corresponding to a delay of 1 and PDELAY $=1111$ corresponding to a delay of 16.

A0-2 = 101 MS Offset Register B

|  | - | - | - | - | - | - | OFFSETB8 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| OFFB8: Most significant bit of Offset Register B. In dual correlator mode, this register is used for the correlator whose output appears on <br> the AUXOUT pins. |  |  |  |  |  |  |  |
| A0-2 $=\mathbf{1 1 0}$ LS Offset Register B | OFFB6 |  |  |  |  |  |  |
| OFFB7 | OFFB6 | OFFB5 | OFFB4 | OFFB3 | OFFB2 | OFFB1 | OFFB0 |
| OFFB0-7: Least significant bits of Offset Register B. |  |  |  |  |  |  |  |


| CONFIGURATION |  |  |  |  | NO. OF CORRELATORS | DATA BITS | ROWS | LENGTH | CORRELATOR | ACTIVE INPUTS |  | ACTIVE OUTPUTS |  |  | OUTPUT WEIGHTING |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 4 | 3 | 2 | 1 | 0 |  |  |  |  |  | DIN | DREF | DOUT | AUXOUT | CASOUT | CO7 | CO6 | CO5 | CO4 | CO3 | CO2 | CO1 | COO |
| 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 256 | - | 7 | 7 | 7 | 7 | 12-0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| 0 | 0 | 0 | 0 | 1 | 1 | 1 | 2 | 128 | - | 7, 3 | 7,3 | 7, 3 | 7, 3 | 12-0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| 0 | 0 | 0 | 1 | 0 | 1 | 1 | 4 | 64 | - | 7, 5, 3, 1 | 7, 5, 3, 1 | 7, 5, 3, 1 | 7, 5, 3, 1 | 12-0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| 0 | 0 | 0 | 1 | 1 | 1 | 1 | 8 | 32 | - | 7-0 | 7-0 | 7-0 | 7-0 | 12-0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| 0 | 0 | 1 | 0 | 1 | 1 | 2 | 1 | 128 | - | 7,3 | 7 | 7,3 | 7,3 | 12-0 | 2 | 2 | 2 | 2 | 1 | 1 | 1 | 1 |
| 0 | 0 | 1 | 1 | 0 | 1 | 2 | 2 | 64 | - | 7, 5, 3, 1 | 7,5 | 7, 5, 3, 1 | 7, 5, 3, 1 | 12-0 | 2 | 2 | 2 | 2 | 1 | 1 | 1 | 1 |
| 0 | 0 | 1 | 1 | 1 | 1 | 2 | 4 | 32 | - | 7-0 | 7,6, 5, 4 | 7-0 | 7-0 | 12-0 | 2 | 2 | 2 | 2 | 1 | 1 | 1 | 1 |
| 0 | 1 | 0 | 1 | 0 | 1 | 4 | 1 | 64 | - | 7, 5, 3, 1 | 7 | 7, 5, 3, 1 | 7, 5, 3, 1 | 12-0 | 8 | 8 | 2 | 2 | 4 | 4 | 1 | 1 |
| 0 | 1 | 0 | 1 | 1 | 1 | 4 | 2 | 32 | - | 7-0 | 7,6 | 7-0 | 7-0 | 12-0 | 8 | 8 | 2 | 2 | 4 | 4 | 1 | 1 |
| 0 | 1 | 1 | 1 | 1 | 1 | 8 | 1 | 32 | - | 7-0 | 7 | 7-0 | 7-0 | 12-0 | 128 | 8 | 32 | 4 | 64 | 2 | 16 | 1 |
| 1 | 0 | 0 | 0 | 1 | 2 | 1 | 1 | 128 | $\begin{aligned} & \text { A } \\ & \text { B } \end{aligned}$ | 7 3 | 7 3 | 7 3 | $8-0$ | 12-0 | 1 | 1 | 1 | 1 | $\stackrel{-}{1}$ | $\bar{i}$ | i | $1$ |
| 1 | 0 | 0 | 1 | 0 | 2 | 1 | 2 | 64 | $\begin{aligned} & \text { A } \\ & \text { B } \end{aligned}$ | $\begin{array}{r} 7,5 \\ 3,1 \end{array}$ | $\begin{aligned} & 7,5 \\ & 3,1 \end{aligned}$ | $\begin{array}{r} 7,5 \\ 3,1 \end{array}$ | 8-0 | $12-0$ - | 1 | 1. | 1 | 1. | 1 | $1$ | 1 | 1 |
| 1 | 0 | 0 | 1 | 1 | 2 | 1 | 4 | 32 | $\begin{aligned} & \text { A } \\ & \text { B } \end{aligned}$ | $\begin{aligned} & 7-4 \\ & 3-0 \end{aligned}$ | $\begin{aligned} & 7-4 \\ & 3-0 \end{aligned}$ | $\begin{aligned} & 7-4 \\ & 3-0 \end{aligned}$ | $8-0$ | 12-0 | 1 | 1. | 1 | 1. | $\bar{i}$ | 1 | $i$ | $i$ |
| 1 | 0 | 1 | 1 | 0 | 2 | 2 | 1 | 64 | $\begin{aligned} & \text { A } \\ & \text { B } \end{aligned}$ | $\begin{aligned} & 7,5 \\ & 3,1 \end{aligned}$ | 7 3 | $\begin{aligned} & 7,5 \\ & 3,1 \end{aligned}$ | $8-0$ | 12-0 | 2 | 2 | 1 | 1 | $2$ | $\overline{2}$ | 1 | $\dot{1}$ |
| 1 | 0 | 1 | 1 | 1 | 2 | 2 | 2 | 32 | $\begin{aligned} & A \\ & B \end{aligned}$ | $\begin{aligned} & 7-4 \\ & 3-0 \end{aligned}$ | $\begin{aligned} & 7,6 \\ & 3,2 \end{aligned}$ | $\begin{aligned} & 7-4 \\ & 3-0 \end{aligned}$ | 8-0 | 12-0 | 2 | 2 | 1 | 1. | $2$ | 2 | 1 | $\stackrel{\rightharpoonup}{1}$ |
| 1 | 1 | 0 | 1 | 1 | 2 | 4 | 1 | 32 | A | $\begin{aligned} & 7-4 \\ & 3-0 \end{aligned}$ | 7 3 | $\begin{aligned} & 7-4 \\ & 3-0 \end{aligned}$ | $8-0$ | 12-0 | 8 | 2 | 4 | 1 | 8 | 2 | 4 | 1 |

During reference register loading, the 8-bits, DREF0-7 are used as reference data inputs. The falling edge of RLOAD\# initiates reference data loading; when RLOAD\# returns high, the data on DREF0-7 is latched into the selected correlation stages. The active bits on DREF0-7 are controlled by the current configuration.

The window configuration is determined by the state of control signals upon programming the control register. Table 3 represents the programming information required for each window configuration. In Table 3, note that the data listed for Output Weighting refers to the weights given to each of the Correlation Sum Outputs (CO0-7 in Figure 1).
During initialization, the loading configuration for the reference data is set by the user. Table 3 shows the loading options. These load controls specify whether the reference data for a given stage comes from the shift register output of the previous stage or from an external data pin.

## Applications

## Single HSP45256 - 1-Bit Data, 256 Samples

A $1 \times 256$ (1-D configuration) correlation requires only 1 HSP45256. To initialize the correlator, all the reference bits, control bits, the delay value of the variable delay, and the window configuration must be specified.

TABLE 4. REGISTER CONTENTS FOR $1 \times 256$ CORRELATOR WITH EQUAL WEIGHTING

| AO-2 | DCONTO-7 | NOTES |
| :---: | :---: | :--- |
| 001 | 00000000 | 1256 -tap correlator: $1 \times 256$ window <br> configuration, reference loaded from <br> DREF7, eight stages weighted equally, <br> DIN 7 and DOUT7 are the data input <br> and output, respectively. |
| 010 | 00000000 | Offset Register $A=0$ |
| 011 | 00000000 |  |
| 100 | 00000000 | Programmable Delay $=0$ |
| 101 | 00000000 | Offset Register $B=0$ (Loading of this <br> register optional in this mode.) |
| 110 | 00000000 |  |

The loading of the reference and mask registers may be done simultaneously by setting $\mathrm{AO}-2=000$, setting the DREF and DCONT inputs to their proper values and pulsing RLOAD\# and CLOAD\# low. In this configuration, DREF7 loads the reference data and DCONT7 loads the mask information; both sets of data are loaded serially. It will take 256 load pulses (RLOAD\#) to load the reference array, and 256 CLOAD\# pulses to load the mask array. Upon completion of the mask and register loading, TXFR\# is pulsed low, which transfers the reference and control data from the preload registers to the reference and mask registers, updating the data that will be used in the correlation. Reference and mask data can be loaded more quickly by configuring the correlator as an 8 row by 32 sample array, loading the bits eight at a time, then changing the configuration back to $1 \times 256$ to perform the correlation.

## Single HSP45256-8-Bit Data, 32 Samples

An $8 \times 32$ correlation also requires only 1 HSP45256. To initialize the correlator, all the reference bits, control bits, the value of the programmable delay, and the window configuration must be specified.

Again, the loading of the reference and mask registers can be done simultaneously. Due to the programming initialization, DREF0-7 are used to load the reference data 8-bits at a time. It will take 32 load pulses each of RLOAD\# and CLOAD\# to load both arrays. Upon completion of the mask and register loading, TXFR\# is pulsed low, which transfers the reference and control data from the preload registers to the registers that store the active data.

TABLE 5. REGISTER LOADING FOR $8 \times 32$ CORRELATOR WITH BINARY WEIGHTING

| A0-2 | DCONTO-7 | NOTES |
| :---: | :--- | :--- |
| 001 | 00001111 | 1256 -tap correlator; $8 \times 32$ window configu- <br> ration, 8-bit data stream; reference register <br> is loaded from DREF7 for all stages. Corre- <br> lator score $=(128 \times$ CO7 $)+(64 \times$ CO3 $)+(32$ <br> $\times$ CO5 $)+(16 \times$ CO1 $)+(8 \times$ CO6 $)+(4 \times$ CO4 $)$ <br> $+(2 \times$ CO2 $)+$ COO |
| 010 | 00000000 | Offset Register $A=0000000010000$ |
| 011 | 00010000 |  |
| 100 | 00000000 | Programmable Delay $=0$ |
| 101 | 00000000 | Offset Register $B=0$ (Loading optional in <br> this mode.) |
| 110 | 00000000 |  |

This configuration performs correlation of an 8-bit number with a 1 -bit reference. Each byte out of the correlation array gives an 8-bit level of confidence that the data corresponds to the reference. The correlation score is the sum of these confidence levels.

## Single HSP45256 - Dual Correlators, 2-Bit Data, 64 Samples

Dual $2 \times 64$ correlators require only one HSP45256. To initialize the correlator, all the reference bits, control bits, the delay value of the variable delay, and the window configuration must be specified.

In this example, each of the dual correlators compares 2-bit data to a 1-bit reference. It will take 64 load pulses (RLOAD\#/CLOAD\#) to completely load the reference and mask registers in the array. The programmable delay must be set to 0 for the output of the two correlators to be aligned.

TABLE 6. REGISTER LOADING FOR DUAL $2 \times 64$ CORRELATORS WITH EQUAL WEIGHTING

| AO-2 | DCONT0-7 | NOTES |
| :---: | :---: | :---: |
| 001 | 00010010 | Dual correlators: each 2 bit data, 64 taps; reference register for correlation A is loaded from DREF7 and DREF5, the reference register for correlator $B$ is loaded from DREF3 and DREF1. Correlator \#1 $=2 \times \mathrm{C} 07+2 \times \mathrm{CO} 6+\mathrm{CO} 5+$ CO4, correlator \#2 $=2 \times \mathrm{CO} 3+2 \times \mathrm{CO} 2$ $+\mathrm{CO} 1+\mathrm{CO}$. |
| 010 | 00000000 | Offset Register $\mathrm{A}=0000000010000$ |
| 011 | 00010000 |  |
| 100 | 00000000 | Programmable Delay $=0$ |
| 101 | 00000000 | Offset Register B $=0$ |
| 110 | 00000000 |  |

## Cascading Correlators

Correlators can be cascaded in either a serial or parallel fashion. Longer correlations can be achieved by connecting several correlators together as shown in Figure 2. Each correlator is in a one data bit, one row, 256 tap configuration. The number of bits of significance at the CASOUT output of each correlator builds up from one correlation to the next,
that is, the maximum score out of the first correlator is 256, the maximum output of the second correlator is 512, etc. In this configuration, the maximum length of the correlation is 4096. This would be implemented with 16 HSP45256's. The programmable delay register in the first correlator would be set for one delay, the second would be set for two, and so on, with the final HSP45256 being set for a delay of 16.

Correlations of more bits can be calculated by connecting CASOUT of each chip to the CASIN of the following chip (Figure 3). The data on the CASOUT lines accumulates in a similar manner as in the $1 \times 256$ mode, except that the maximum output of the first correlator is decimal 960, (hexadecimal 3C0); in the general case, the maximum number of correlators that can be cascaded in this manner is eight, since the maximum output of the last one would be 1E00, which nearly uses up the 13 -bit range of the cascade summer. More parts could be cascaded together if some bits are to be masked out or if the user has a prior knowledge of the maximum value of the correlation score. As before, the delay in the first correlator would be set to one, the second correlator would be set for a delay of two, and so on.

Multiple HSP45256's can be cascaded for two dimensional one bit data (Figure 4). The maximum output for each chip is the same as in the $1 \times 256$ case; the only difference is in the manner in which the correlators are connected. The programmable delay registers would be set as before.


FIGURE 3. 4 BIT, 256 SAMPLE CONFIGURATION


## Reloading Data During Operation

RLOAD\# and CLOAD\# are asynchronous signals that are designed to be driven by the memory interface signals of a microprocessor. TXFR\# is synchronized to CLK so that the mask or reference data is updated on a specific clock cycle. In the normal mode of operation, the user loads the reference and mask memories, then pulses TXFR\# to use that data. The correlator uses the new mask or reference information immediately. Loading of the reference and mask data remains asynchronous as long as there is at least one cycle of CLK between the rising edge of RLOAD\# or CLOAD\# and the TXFR\# pulse.

If the system timing makes it necessary for TXFR\# and RLOAD\# and/or CLOAD\# to be active during the same clock cycle, then they must be treated as synchronous signals; the timing for this case is shown in Figure 5 and given in the AC Timing Specifications ( $T_{T H C L}$ and $T_{C L L H}$ ). In this example, data is loaded during clock cycle 1 and transferred on the rising edge of CLK that occurs in clock cycle two. Another set of data is loaded during clock cycle 2, which will be transferred by a later TXFR\# pulse. The sequence of events is as follows:

1. In clock cycle 1, TXFR\# becomes active at least $T_{T H}$ nanoseconds after the rising edge of CLK.
2. RLOAD and/or CLOAD\# pulses low; the timing is not critical as long as its rising edge occurs before the end of clock cycle 1. If this condition is not met, it is undetermined whether the data loaded by this pulse will be transferred by the current TXFR\# pulse.
3. The rising edge of TXFR\# occurs while CLK is high during clock cycle 2. The margin between the rising edge of TXFR\# and the falling edge of CLK is defined by TTHCL.
4. RLOAD\# and/or CLOAD\# pulses low. The rising edge of RLOAD\# and CLOAD\# must occur after the falling edge of CLK. The margin between the two is defined by $T_{\text {CLLH. }}$.

The time from the rising edge of TXFR\# to the falling edge of CLK must be greater than $T_{T H C L}$, and the time from the falling edge of CLK to the rising edge of RLOAD\# or CLOAD\# must be greater than $\mathrm{T}_{\mathrm{s}}$. If this timing is violated, the data being transferred by the TXFR\# pulse shown may or may not include the data loaded in clock cycle 2.


Figure 5. LOADING AND TRANSFERRING DATA DURING THE SAME CLOCK CYCLE

## Absolute Maximum Ratings

| Supply Voltage | 8.0V | Thermal Resistance | $\theta_{\text {ja }}$ | $\theta_{j}$ |
| :---: | :---: | :---: | :---: | :---: |
| Input, Output or I/O Voltage | . . . . GND-0.5V to $\mathrm{V}_{\mathrm{cc}}+0.5 \mathrm{~V}$ | PLCC Package | $34^{\circ} \mathrm{C} / \mathrm{N}$ | $11.3^{\circ} \mathrm{CN}$ |
| Storage Temperature Range | . . . . . . $65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ | PGA Package | $36^{\circ} \mathrm{C} / \mathrm{W}$ | $10^{\circ} \mathrm{CW}$ |
| Junction Temperature. . . . . . . | $+150^{\circ} \mathrm{C}$ (PLCC), $+175^{\circ} \mathrm{C}$ (PGA) | Maximum Package Power Dissipation at $+125^{\circ} \mathrm{C}$ |  |  |
| Lead Temperature (Soldering 10s). | $+300^{\circ} \mathrm{C}$ | PLCC Package |  | 2.2W |
| ESD Classification | . Class 1 | PGA Package |  | .2.9W |
|  |  | Gate Count |  | O Gates |

CAUTION: Stresses above those listed in "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.

## Operating Conditions

Operating Voltage Range . . . . . . . . . . . . . . . . . . +4.75 V to +5.25 V Operating Temperature Range . . . . . . . . . . . . . . . . . $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
DC Electrical Specifications

| PARAMETER | SYMBOL | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Logical One Input Voltage | $\mathrm{V}_{\mathrm{IH}}$ | 2.0 | - | V | $\mathrm{V}_{\mathrm{cc}}=5.25 \mathrm{~V}$ |
| Logical Zero Input Voltage | $V_{1 L}$ | - | 0.8 | V | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| High Level Clock Input | $\mathrm{V}_{\text {IHC }}$ | 3.0 | - | V | $\mathrm{V}_{\mathrm{cc}}=5.25 \mathrm{~V}$ |
| Low Level Clock Input | $V_{\text {ILC }}$ | - | 0.8 | V | $\mathrm{V}_{\mathrm{cc}}=4.75 \mathrm{~V}$ |
| Output High Voltage | $\mathrm{V}_{\mathrm{OH}}$ | 2.6 | - | V | $\mathrm{I}_{\mathrm{OH}}=400 \mu \mathrm{~A}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Output Low Voltage | $\mathrm{V}_{\mathrm{OL}}$ | - | 0.4 | V | $\mathrm{I}_{\mathrm{OL}}=+2.0 \mathrm{~mA}, \mathrm{~V}_{C C}=4.75 \mathrm{~V}$ |
| Input Leakage Current | 1 | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {CC }}$ or GND, $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| Output Leakage Current | 10 | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {OUT }}=\mathrm{V}_{\text {CC }}$ or GND, $\mathrm{V}_{\text {CC }}=5.25 \mathrm{~V}$ |
| Standby Power Supply Current | $l_{\text {ccse }}$ | - | 500 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\mathrm{CC}}$ or GND, $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$, Note 3 |
| Operating Power Supply Current | Iccop | - | 179 | mA | $\begin{aligned} & f=25.6 \mathrm{MHz}, \mathrm{~V}_{I N}=\mathrm{V}_{\mathrm{CC}} \text { or } \mathrm{GND}, \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V} \text {, } \\ & \text { Note } 1, \text { Note } 3 \end{aligned}$ |

Capacitance ( $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$, Note 2)

| PARAMETER | SYMBOL | MIN | MAX | UNITS | TEST CONDITIONS |
| :--- | :---: | :---: | :---: | :---: | :--- |
| Input Capacitance | $\mathrm{C}_{\mathrm{IN}}$ | - | 10 | pF | Frequency $=1 \mathrm{MHz}, \mathrm{V}_{\mathrm{CC}}=$ Open <br> All measurements are referenced to device ground. |
| Output Capacitance | $\mathrm{C}_{\mathrm{O}}$ | - | 10 | pF |  |

## NOTES:

1. Power supply current is proportional to operating frequency. Typical rating for ICCOP is 7 mAMMHz .
2. Not tested, but characterized at initial design and at major process/design changes.
3. Output load per test load circuit and $C_{L}=40 \mathrm{pF}$.

AC Electrical Specifications $\quad\left(V_{C C}=5.0 \mathrm{~V} \pm 5 \%, T_{A}=0^{\circ} \mathrm{C}\right.$ to $+70^{\circ} \mathrm{C}$, Note 1)

| PARAMETER | SYMBOL | 33 MHz |  | 25.6MHz |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |  |  |
| CLK Period | $\mathrm{T}_{\mathrm{CP}}$ | 30 | - | 39 | - | ns |  |
| CLK High | $\mathrm{T}_{\mathrm{CH}}$ | 12 | - | 15 | - | ns |  |
| CLK Low | $\mathrm{T}_{\mathrm{CL}}$ | 12 | - | 15 | - | ns |  |
| Set-Up Time DIN to CLK High | $\mathrm{T}_{\text {D }}$ | 12 | - | 13 | - | ns |  |
| Hold Time CLK High to DIN | $\mathrm{T}_{\mathrm{DH}}$ | 0 | - | 0 | - | ns |  |
| TXFR\# Set-Up Time | $T_{\text {TS }}$ | 12 | - | 13 | - | ns |  |
| TXFR\# Hold Time | $\mathrm{T}_{\text {TH }}$ | 0 | - | 0 | $\bullet$ | ns |  |
| Output Delay DOUT, AUXOUT, CASOUT | $\mathrm{T}_{\mathrm{DO}}$ | - | - | - | 20 | ns |  |
| CLOAD\# Cycle Time | $T_{\text {CLC }}$ | 30 | 15 | 39 | - | ns |  |
| CLOAD\# High | $\mathrm{T}_{\text {CLH }}$ | 12 | - | 15 | - | ns |  |
| CLOAD\# Low | $\mathrm{T}_{\text {CLL }}$ | 12 | - | 15 | - | ns |  |
| Set-Up Time, A to RLOAD\#, CLOAD\# | $\mathrm{T}_{\text {AS }}$ | 12 | - | 13 | - | ns |  |
| Hold Time, RLOAD\#, CLOAD\# to A | $\mathrm{T}_{\text {AH }}$ | 0 | - | 0 | - | ns |  |
| RLOAD\# Cycle Time | $\mathrm{T}_{\text {RLC }}$ | 30 | $\cdot$ | 39 | $\bullet$ | ns |  |
| RLOAD\# High | $\mathrm{T}_{\text {RLH }}$ | 12 | - | 15 | $\bullet$ | ns |  |
| RLOAD\# Low | T RLL | 12 | - | 15 | - | ns |  |
| Set-Up Time, DCONT to CLOAD\# | $\mathrm{T}_{\text {DCS }}$ | 12 | - | 13 | $\cdot$ | ns |  |
| Hold Time, CLOAD\# to DCONT | $\mathrm{T}_{\mathrm{DCH}}$ | 0 | - | 0 | - | ns |  |
| Set-Up Time, DREF to RLOAD\# | $\mathrm{T}_{\text {RS }}$ | 12 | - | 13 | $\bullet$ | ns |  |
| Hold Time, RLOAD\# to DREF | $\mathrm{T}_{\text {RH }}$ | 0 | $\bullet$ | 0 | $\bullet$ | ns |  |
| Output Enable Time | $\mathrm{T}_{\text {OE }}$ | - | 15 | $\bullet$ | 15 | ns |  |
| Output Disable Time | $\mathrm{T}_{\text {OD }}$ | - | 15 | $\bullet$ | 15 | ns | Note 2 |
| Output Rise, Fall Time | $\mathrm{T}_{\text {RF }}$ | $\bullet$ | 6 |  | 6 | ns | Note 2 |
| TXFR\# High to CLK Low | $\mathrm{T}_{\text {THCL }}$ | 3 | - | 3 | - | ns | Note 2 |
| CLK Low to RLOAD\#, CLOAD\# High | $\mathrm{T}_{\text {CLLH }}$ | 1 | $\bullet$ | 1 | $\cdot$ | ns | Note 2 |

NOTES:

1. AC testing is performed as follows: Input levels (CLK Input) 4.0 V and 0 V ; Input levels (all other inputs) 0 V and 3.0 V ; Timing reference levels (CLK) 2.0V; All others 1.5 V . Output load per test load circuit with $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$. Output transition is measured at $\mathrm{V}_{O H}>1.5 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{OL}}<1.5 \mathrm{~V}$.
2. Controlled via design or process parameters and not directly tested. Characterized upon initial design and after major process and/or design changes.

## Test Load Circuit



SWITCH S1 OPEN FOR IccsB AND Iccop TEST

## Timing Waveforms




TRANSFER, LOAD TIMING WHEN BOTH OCCUR ON A SINGLE CYCLE

## Features

- This Circuit is Processed in Accordance to Mil-Std883 and is Fully Conformant Under the Provisions of Paragraph 1.2.1.
- Reconfigurable 256 Stage Binary Correlator
- 1-Bit Reference $\times$ 1, 2, 4, or 8-Bit Data
- Separate Control and Reference Interfaces
- Configurable for 1-D and 2-D Operation
- Double Buffered Mask and Reference
- Programmable Output Delay
- Cascadable
- Standard Microprocessor Interface
- 85-pin PGA


## Applications

- Radar/Sonar
- Spread Spectrum Communications
- Pattern/Character Recognition
- Error Correction Coding


## Description

The Harris HSP45256 is a high-speed, 256 tap binary correlator. It can be configured to perform one- or twodimensional correlations of selectable data precision and length. Multiple HSP45256's can be cascaded for increased correlation length. Unused taps can be masked out for reduced correlation length.

The correlation array consists of eight 32-tap stages. These may be cascaded internally to compare 1, 2, 4 or 8 -bit input data with a 1-bit reference. Depending on the number of bits in the input data, the length of the correlation can be up to $256,128,64$, or 32 taps. The HSP45256 can also be configured as two separate correlators with window sizes from 4 by 32 to 1 by 128 each. The mask register can be used to prevent any subset of the 256 bits from contributing to the correlation score.

The output of the correlation array (correlation score) feeds the weight and sum logic, which gives added flexibility to the data format. In addition, an offset register is provided so that a preprogrammed value can be added to the correlation score. This result is then passed through a user programmable delay stage to the cascade summer. The delay stage simplifies the cascading of multiple correlators by compensating for the latency of previous correlators.

The Binary Correlator is configured by writing a set of control registers via a standard microprocessor interface. To simplify operation, both the control and reference registers are double buffered. This allows the user to load new mask and reference data while the current correlation is in progress.

## Block Diagram



## Pinouts



85 PIN PGA
BOTTOM VIEW


## Pin Description

| SYMBOL | PIN NUMBER | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{Cc}}$ | D2, G9, K2 |  | The +5 V power supply pin |
| GND | $\begin{aligned} & \text { A10, B1, D10, } \\ & \text { J10, L2 } \end{aligned}$ |  | Ground. |
| DINO-7 | $\begin{aligned} & \text { D1, E1-E3, F2, } \\ & \text { F3, G1, G3 } \end{aligned}$ | 1 | The DINO-7 bus consists of eight single data input pins. The assignment of the active pins is determined by the configuration. Data is loaded synchronous to the rising edge of CLK. DINO is the LSB. |
| DOUT0-7 | $\begin{aligned} & \text { E9-E11, F9-F11, } \\ & \text { G10, G11 } \end{aligned}$ | 0 | The DOUTO-7 bus is the data output of the correlation array. The format of the output is dependent on the window configuration and bit weighting. DOUT0 is the LSB. |
| CLK | C1 | 1 | System clock. Positive edge triggered. |
| CASINO-12 | $\begin{aligned} & \text { A1-A6, B2-B5, } \\ & C 2, C 5, C 6 \end{aligned}$ | 1 | CASINO-12 allows multiple correlators to be cascaded by connecting CASOUTO-12 of one correlator to CASINO-12 of another. The CASIN bus is added internally to the correlation score to form CASOUT. CASINO is the LSB. |
| CASOUT0-12 | $\begin{array}{\|l} \text { A7-A9, A11, } \\ \text { B6-B11, C10, } \\ \text { C11, D11 } \end{array}$ | 0 | CASOUT0-12 is the output correlation score. This value is the delayed sum of all the 256 taps of one chip and CASINO-12. When the part is configured to act as two independent correlators, CASOUT0-8 represents the correlation score for the first correlator while the second correlation score is available on the AUXOUT0-8 bus. In this configuration, the cascading feature is no longer an option. CASOUTO is the LSB. |
| OEC\# | C7 | 1 | OEC\# is the output enable for CASOUTO-12. When OEC\# is high, the output is threestated. Processing is not interrupted by this pin. (Active low.) |
| TXFR\# | L3 | 1 | TXFR\# is a synchronous clock enable signal that allows the loading of the reference and mask inputs from the preload register to the correlation array. Data is transferred on the rising edge of CLK while TXFR\# is low. (Active low.) |
| DREF0-7 | $\begin{aligned} & \text { F1, G2, H1, H2, } \\ & \mathrm{J} 1, \mathrm{~J} 2, \mathrm{~K} 1, \mathrm{~L} 1 \end{aligned}$ | 1 | DREF0-7 is an 8-bit wide data reference input. This is the input data bus used to load the reference data. RLOAD\# going active initiates the loading of the reference registers. This input bus is used to load the reference registers of the correlation array. The manner in which the reference data is loaded is determined by the window configuration. If the window configuration is $1 \times 256$, the reference bits are loaded one at a time over DREF7. When the HSP45256 is configured as an $8 \times 32$ array, the data is loaded into all stages in parallel. In this case, DREF7 is the reference data for the first stage and DREFO is the reference data for the eighth stage. The contents of the reference data registers are not affected by changing the window configuration. DREFO is the LSB. |
| RLOAD\# | K3 | 1 | RLOAD\# enables loading of the reference registers. Data on DREFO-7 is loaded into the preload registers on the rising edge of RLOAD\#. This data is transferred into the correlation array by TXFR\#. (Active low.) |
| DCONT0-7 | $\begin{aligned} & \mathrm{J} 6, \mathrm{~J} 7, \mathrm{~K} 6, \mathrm{K7}, \\ & \mathrm{~L}-\mathrm{LB} \end{aligned}$ | 1 | DCONT0-7 is the control data input, which is used to load the mask bit for each tap as well as the configuration registers. The mask data is sequentially loaded into the eight stages in the same manner as the reference data. DCONTO is the LSB. |
| CLOAD\# | K4 | 1 | CLOAD\# enables the loading of the data on DCONTO-7. The destination of this data is controlled by A0-2. (Active low.) |
| A0-2 | J5, K5, L4 | 1 | A0-2 is a 3-bit address that determines what function will be performed when CLOAD\# is active. This address bus is set up with respect to the rising edge of the load signal, CLOAD\#. AO is the LSB. |
| AUXOUTO-8 | $\begin{array}{\|l\|} \hline \text { H10, H11, J11, } \\ \text { K9-K11, L9-L11 } \end{array}$ | 0 | AUXOUT0-8 is a 9 -bit bus that provides either the data reference output or the 9 -bit correlation score of the second correlator, depending on the configuration. When the user programs the chip to be two separate correlators, the score of the second correlator is output on this bus. When the user has programmed the chip to be one correlator, AUXOUTO-7 represents the reference data out, with the state of AUXOUTO-8 undefined. AUXOUTO is the LSB. |
| OEA\# | K8 | I | The OEA\# signal is the output enable for the AUXOUTO-8 output. When OEA\# is high, the output is disabled. Processing is not interrupted by this pin. (Active low.) |
| Index Pin | C3 |  | Used for orienting pin in socket or printed cirecuit board. Must be left as a no connect in circuit. |



## Operating Conditions

Operating Voltage Range +4.5 V to +5.5 V Operating Temperature Range
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
TABLE 1. DC ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and 100\% Tested

| PARAMETER | SYMBOL | CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | LIMITS |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX |  |
| Logical One Input Voltage | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 2.2 | $\bullet$ | V |
| Logical Zero Input Voltage | $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 0.8 | V |
| Logical One Input Voltage Clock | $\mathrm{V}_{\text {IHC }}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | 3.0 | - | V |
| Logical Zero Input Voltage Clock | VILC | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ | 1,2,3 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | $\bullet$ | 0.8 | V |
| Output HIGH Voltage | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}(\text { Note } 1) \end{aligned}$ | 1,2,3 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 2.6 | - | V |
| Output LOW Voltage | $\mathrm{V}_{\mathrm{OL}}$ | $\begin{aligned} & \mathrm{IOL}_{\mathrm{OL}}=+2.0 \mathrm{~mA} \\ & \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}(\text { Note } 1) \end{aligned}$ | 1,2,3 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 0.4 | V |
| Input Leakage Current | 1 | $\begin{aligned} & V_{I N}=V_{C C} \text { or GND } \\ & V_{C C}=5.5 \mathrm{~V} \end{aligned}$ | 1,2,3 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Output Leakage Current | 10 | $\begin{aligned} & V_{I N}=V_{C C} \text { or GND } \\ & V_{C C}=5.5 \mathrm{~V} \end{aligned}$ | 1,2,3 | $-55^{\circ} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | -10 | +10 | $\mu \mathrm{A}$ |
| Standby Power Supply Current | ICcsB | $\begin{aligned} & V_{I N}=V_{C C} \text { or GND } \\ & V_{C C}=5.5 \mathrm{~V}, \\ & \text { Outputs Open } \end{aligned}$ | 1,2,3 | $-55^{\circ} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 500 | $\mu \mathrm{A}$ |
| Operating Power Supply Current | Iccop | $\begin{aligned} & \mathrm{f}=20 \mathrm{MHz}, \mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}} \\ & \text { or GND, } \mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V} \\ & \text { (Note 2) } \end{aligned}$ | 1,2,3 | $-55^{\circ} \leq \mathrm{T}_{\mathrm{A}} \leq+125^{\circ} \mathrm{C}$ | - | 140 | mA |
| Functional Test | FT | (Note 3) | 7,8 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | - | - |

## NOTES:

1. Interchanging of force and sense conditions is permitted.
2. Operating Supply Current is proportional to frequency, typical rating is 7 mANMHz .
3. Tested as follows: $f=1 \mathrm{MHz}, \mathrm{V}_{\mathrm{IH}}$ (clock inputs) $=3.4 \mathrm{~V}, \mathrm{~V}_{\mathrm{IH}}$ (all other inputs) $=2.6 \mathrm{~V}, \mathrm{~V}_{\mathrm{IL}}=0.4 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}} \geq 1.5 \mathrm{~V}$, and $\mathrm{V}_{\mathrm{OL}} \leq 1.5 \mathrm{~V}$.

TABLE 2. AC ELECTRICAL PERFORMANCE CHARACTERISTICS
Device Guaranteed and $100 \%$ Tested

| PARAMETER | SYMBOL | (NOTE 1) CONDITIONS | GROUP A SUBGROUPS | TEMPERATURE | -25 (25.6MHz) |  | -20 (20MHz) |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| CLK Period | $\mathrm{T}_{\mathrm{CP}}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 39 | - | 50 | - | ns |
| CLK High | $\mathrm{T}_{\mathrm{CH}}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 15 | - | 20 | - | ns |
| CLK Low | $\mathrm{T}_{\mathrm{CL}}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 15 | - | 20 | - | ns |
| CLOAD\# Cycle Time | TCLC |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 39 | - | 50 | - | ns |
| CLOAD\# High | $\mathrm{T}_{\text {CLH }}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 15 | - | 20 | - | ns |
| CLOAD\# Low | $\mathrm{T}_{\text {CLL }}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 15 | - | 20 | - | ns |
| RLOAD\# Cycle Time | $\mathrm{T}_{\mathrm{RLC}}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 39 | - | 50 | - | ns |
| RLOAD\# High | $\mathrm{T}_{\text {RLH }}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 15 | - | 20 | - | ns |
| RLOAD\# Low | TRLL |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 15 | - | 20 | - | ns |
| Set-up Time; DIN to CLK High | $\mathrm{T}_{\mathrm{DS}}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 13 | - | 15 | - | ns |
| Hold Time; DIN to CLK High | $\mathrm{T}_{\text {DH }}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 1 | - | 1 | - | ns |
| Set-up Time; DREF to RLOAD High | Trs |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 14 | - | 15 | - | ns |
| Hold Time; DREF to RLOAD High | $\mathrm{T}_{\text {RH }}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 1 | - | 1 | - | ns |
| DCONT Set up Time | T ${ }_{\text {ccs }}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 13 | - | 15 | - | ns |
| DCONT Hold Time | $\mathrm{T}_{\mathrm{DCH}}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 1 | - | 1 | - | ns |
| Address Set up Time | $\mathrm{T}_{\text {AS }}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 13 | - | 15 | - | ns |
| Address Hold Time | $\mathrm{T}_{\text {AH }}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 1 | - | 1 | - | ns |
| TXFR \# Set up Time | $T_{\text {TS }}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 13 | - | 15 | - | ns |
| TXFR\# Hold Time | $\mathrm{T}_{\text {TH }}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 1 | - | 1 | - | ns |
| CLK to Output Delay DOUT, AUXOUT, CASOUT | $T_{\infty}$ |  | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 20 | - | 25 | ns |
| Output Enable Time | ToE | Note 2 | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 20 | - | 20 | ns |
| TXFR\# High to CLK Low | $\mathrm{T}_{\text {THCL }}$ | Note 3 | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 3 | - | 4 | - | ns |
| CLK Low to RLOAD", CLOAD\# High | $\mathrm{T}_{\text {CLLH }}$ | Note 3 | 9, 10, 11 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | 1 | - | 1 | - | ns |

NOTES:

1. AC testing is performed as follows: $\mathrm{V}_{C C}=4.5 \mathrm{~V}$ and 5.5 V . Input levels (CLK Input) 4.0 V and 0 V ; Input levels (all other inputs) 3.0 V and 0 V ; Timing reference levels (CLK) 2.0V; All others 1.5 V . Output load per test load circuit with $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$. Output transistion is measured at $\mathrm{V}_{\mathrm{OH}} \geq 1.5 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{OL}} \leq 1.5 \mathrm{~V}$.
2. Transistion is measured at $\pm 200 \mathrm{mV}$ from steady state voltage, Output loading per test load circuit, $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$.
3. Applicable only when TXFR\# and RLOAD\# or CLOAD\# are active on the same cycle of CLK.

TABLE 3. ELECTRICAL PERFORMANCE CHARACTERISTICS

| PARAMETER | SYMBOL | CONDITIONS | NOTES | TEMPERATURE | -25 |  | -20 |  | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | MAX | MIN | MAX |  |
| Input Capacitance | $\mathrm{C}_{\text {IN }}$ | VCC = Open, $f=1$ MHz All measurements are referenced to device GND. | 1 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 10 | - | 10 | pF |
| Output Capacitance | Cout |  | 1 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 10 | - | 10 | pF |
| Output Disable Time | $\mathrm{T}_{\text {OD }}$ |  | 1, 2 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 20 | - | 20 | ns |
| Output Rise Time | $\mathrm{T}_{\mathrm{R}}$ | From 0.8 V to 2.0 V | 1,2 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 8 | - | 8 | ns |
| Output Fall Time | $\mathrm{T}_{\text {F }}$ | From 2.0 V to 0.8 V | 1,2 | $-55^{\circ} \leq T_{A} \leq+125^{\circ} \mathrm{C}$ | - | 8 | - | 8 | ns |

NOTES:

1. The parameters in Table 3 are controlled via design or process parameters and not directly tested. Characterized upon initial design and after major process and/or design changes.
2. Loading is as specified in the test load circuit with $C_{L}=40 \mathrm{pF}$.

TABLE 4. APPLICABLE SUBGROUPS

| CONFORMANCE GROUPS | METHOD | SUBGROUPS |
| :--- | :---: | :---: |
| Initial Test | $100 \% / 5004$ | - |
| Interim Test | $100 \% / 5004$ | - |
| PDA | $100 \%$ | 1 |
| Final Test | $100 \%$ | $2,3,8 \mathrm{~A}, 8 \mathrm{~B}, 10,11$ |
| Group A | - | $1,2,3,7,8 \mathrm{~A}, 8 \mathrm{~B}, 9,10,11$ |
| Groups C and D | Samples $/ 5005$ | $1,7,9$ |

## Test Load Circuit



SWITCH S1 OPEN FOR Iccse AND Iccop TEST

## Burn-In Circuits



| PGA <br> PIN | PIN <br> NAME | BURN-IN <br> SIGNAL |
| :--- | :--- | :--- |
| A1 | CASIN2 | F3 |
| A2 | CASIN4 | F5 |
| A3 | CASIN5 | F6 |
| A4 | CASIN7 | F1 |
| A5 | CASIN10 | F4 |
| A6 | CASIN11 | F5 |
| A7 | CASOUT0 | $V_{C d^{2}}$ |
| A8 | CASOUT3 | $V_{C d^{2}}$ |
| A9 | CASOUT5 | $V_{C d^{2}}$ |
| A10 | GND | GND |
| A11 | CASOUT8 | $V_{C d^{2}}$ |
| B1 | GND | GND |
| B2 | CASIN1 | F2 |
| B3 | CASIN3 | F4 |
| B4 | CASIN6 | F7 |
| B5 | CASIN9 | F3 |
| B6 | CASOUT2 | $V_{C d^{2}}$ |
| B7 | CASOUT1 | $V_{C d^{2}}$ |
| B8 | CASOUT4 | $V_{C d^{2}}$ |
| B9 | CASOUT6 | $V_{C d^{2}}$ |
| B10 | CASOUT7 | $V_{C d^{2}}$ |


| PGA PIN | $\begin{aligned} & \text { PIN } \\ & \text { NAME } \end{aligned}$ | BURN-IN SIGNAL |
| :---: | :---: | :---: |
| 811 | CASOUT10 | $\mathrm{V}_{\mathrm{C}}{ }^{2}$ |
| C1 | CLK | F0 |
| C2 | CASINO | F1 |
| C5 | CASIN8 | F2 |
| C6 | CASIN12 | F6 |
| C7 | OEC\# | F11 |
| C10 | CASOUT9 | $\mathrm{V}_{\mathrm{c}}{ }^{2}$ |
| C11 | CASOUT11 | $\mathrm{V}_{\mathrm{CC}}{ }^{\text {2 }}$ |
| D1 | DIN7 | F8 |
| D2 | $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ |
| D10 | GND | GND |
| D11 | CASOUT12 | $\mathrm{V}_{\mathrm{CC}}{ }^{2}$ |
| E1 | DIN4 | F5 |
| E2 | DIN5 | F6 |
| E3 | DIN6 | F7 |
| E9 | DOUTO | $\mathrm{V}_{\mathrm{c}} \mathrm{d}^{2}$ |
| E10 | DOUT1 | $\mathrm{V}_{\mathrm{c}} \mathrm{d}^{2}$ |
| E11 | DOUT2 | $\mathrm{V}_{\mathrm{c}}{ }^{\prime 2}$ |
| F1 | DREF6 | F7 |
| F2 | DIN3 | F4 |
| F3 | DIN2 | F3 |

NOTES:

1. $\mathrm{V}_{\mathrm{C}}{ }^{2}(2.7 \mathrm{~V} \pm 10 \%)$ used for outputs only.
2. $47 \mathrm{k} \Omega( \pm 20 \%)$ resistor connected to all pins except $\mathrm{V}_{\mathrm{CC}}$ and GND .
3. $\mathrm{V}_{\mathrm{CC}}=5.5 \pm 0.5 \mathrm{~V}$.

| PGA PIN | PIN NAME | BURN-IN SIGNAL |
| :---: | :---: | :---: |
| F9 | DOUT4 | $\mathrm{V}_{\mathrm{cc}}{ }^{12}$ |
| F10 | DOUT7 | $\mathrm{VCC}^{12}$ |
| F11 | DOUT3 | $\mathrm{Vcd}^{12}$ |
| G1 | DINO | F1 |
| G2 | DREF7 | F8 |
| G3 | DIN1 | F2 |
| G9 | $V_{\text {cc }}$ | $V_{C C}$ |
| G10 | DOUT6 | $\mathrm{VCC}{ }^{2}$ |
| G11 | DOUT5 | $\mathrm{Vcc}^{12}$ |
| H 1 | DREF5 | F6 |
| H2 | DREF4 | F8 |
| H10 | AUXOUT1 | $\mathrm{VCC}^{12}$ |
| H11 | AUXOUTO | $\mathrm{V}_{\mathrm{c}}{ }^{12}$ |
| J1 | DREF3 | F7 |
| J2 | DREF1 | F5 |
| J5 | A1 | F10 |
| J6 | DCONT5 | F6 |
| J7 | DCONT4 | F8 |
| J10 | GND | GND |
| J11 | AUXOUT2 | $\mathrm{V}_{\mathrm{cc}}{ }^{2}$ |
| K1 | DREF2 | F6 |


| PGA <br> PIN | $\begin{aligned} & \text { PIN } \\ & \text { NAME } \end{aligned}$ | BURN-IN SIGNAL |
| :---: | :---: | :---: |
| K2 | $V_{C C}$ | $V_{\text {cc }}$ |
| K3 | RLOAD\# | F3 |
| K4 | CLOAD\# | F3 |
| K5 | AO | F9 |
| K6 | DCONT6 | F7 |
| K7 | DCONT2 | F6 |
| K8 | OEA\# | F11 |
| K9 | AUXOUT6 | $\mathrm{V}_{\mathrm{cd}} / 2$ |
| K10 | AUXOUT4 | $\mathrm{VCO}^{12}$ |
| K11 | AUXOUT3 | $\mathrm{V}_{\mathrm{cc}}{ }^{12}$ |
| L1 | DREFO | F4 |
| L2 | GND | GND |
| L3 | TXFR\# | F2 |
| L4 | A2 | F11 |
| L5 | DCONT7 | F8 |
| L6 | DCONT1 | F5 |
| L7 | DCONT3 | F7 |
| L8 | DCONTO | F4 |
| L.9 | AUXOUT8 | $\mathrm{V}_{\mathrm{cc}}{ }^{\prime 2}$ |
| L10 | AUXOUT7 | $\mathrm{V}_{\mathrm{cc}}{ }^{2}$ |
| L11 | AUXOUT5 | $\mathrm{V}_{\mathrm{cd}}{ }^{2}$ |

4. $0.1 \mu \mathrm{~F}(\mathrm{~min})$ capacitor between $\mathrm{V}_{\mathrm{CC}}$ and GND per position.
5. $\mathrm{FO}=100 \mathrm{kHz} \pm 10 \%, F 1=F 0 / 2, F 2=F 1 / 2 \ldots \mathrm{~F} 11=F 10 / 2,40-60 \%$ Duty Cycle.
6. Input Voltage Limits: $\mathrm{V}_{\mathrm{IL}}=0.8 \mathrm{~V}$ max, $\mathrm{V}_{\mathrm{IH}}=4.5 \pm 10 \%$.

## Metal Topology

DIE DIMENSIONS:
$254 \times 214 \times 19 \pm 1$ mils
METALLIZATION:
Type: Si - Al or $\mathrm{Si}-\mathrm{Al}-\mathrm{Cu}$
Thickness: 8k $\AA$
GLASSIVATION:
Type: Nitrox
Thickness: $10 \mathrm{k} \AA$
DIE ATTACH:
Material: Gold Silicon Eutectic Alloy or Silver-Glass
WORST CASE CURRENT DENSITY:
$0.96 \times 10^{5} \mathrm{~A} / \mathrm{cm}^{2}$

Metallization Mask Layout
HSP45256/883

CASIN1 (74)
CASINO (73)
GND (72)
CLK (71)
VCC (70)
DIN7 (69)
DIN6 (68)
DIN5 (67)
DIN4 (66)
DIN3 (65)
DIN2 (64)
DIN1 (63)
DINO (62) DREF7 (61) DREF6 (60) DREF5 (59) DREF4 (58) DREF3 (57) DREF2 (56) DREF1 (55) DREFO (54)


HENRPRIS
HSP48410

## Features

- 10-Bit Pixel Data
- 4k x 4k Frame Sizes
- Asynchronous Flash Clear Pin
- Single Cycle Memory Clear
- Fully Asynchronous 16 or 24-Bit Host Interface
- Generates and Stores Cumulative Distribution Function
- Look Up Table Mode
- 1024 x 24 Bit Delay Memory
- 24-Bit Three State VO Bus
- TTL Compatible Inputs/Outputs
- Available in 84 Pin PGA and PLCC Packages
- DC to $\mathbf{4 0 M H z}$ Clock Rate


## Applications

- Histogramming
- Histogram Equalization
- Image and Signal Analysis
- Image Enhancement
- RGB Video Delay Line


## Description

The Harris HSP48410 is an 84 pin Histogrammer IC intended for use in image and signal analysis. The on-board memory is configured as $1024 \times 24$ array. This translates to a pixel resolution of 10 bits and an image size of $4 \mathrm{k} \times 4 \mathrm{k}$ with no possibility of overflow.

In addition to Histogramming, the HSP48410 can generate and store the Cumulative Distribution Function for use in Histogram Equalization applications. Other capabilities of the HSP48410 include: Bin Accumulation, Look Up Table, 24-bit Delay memory, and Delay \& Subtract mode.

A Flash Clear pin is available in all modes of operation and performs a single cycle reset on all locations of the internal memory array and all internal data paths.
The HSP48410 includes a fully asynchronous interface which provides a means for communications with a host, such as a microprocessor. The interface includes dedicated Read/Write pins and an address port which are asynchronous to the system clock. This allows random access of the Histogram Memory Array for analysis or conditioning of the stored data.

## Block Diagram



HSP48410

## Pinouts



## Pin Description

| NAME | PLCC PIN | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| CLK | 1 | 1 | Clock input. This input has no effect on the chips functionality when the chip is programmed to an asynchronous mode. All signals denoted as synchronous have their timing specified with reference to this signal. |
| PINO-9 | 3-11, 83 | 1 | Pixel Input. This input bus is sampled by the rising edge of clock. It provides the onchip RAM with address values in Histogram, Bin Accumulate and LUT(write) mode. During Asynchronous modes it is unused. |
| LD\# | 15 | 1 | The Load pin is used to load the FCTO-2 bits into the FCT registers. (See below). |
| FCTO-2 | 16-18 | 1 | These three pins are decoded to determine the mode of operation for the chip. The signals are sampled by the rising edge of LD\# and take effect after the rising edge of LD\#. Since the loading of this function is asynchronous to CLK, it is necessary to disable the START\# pin during loading and enable START\# at least 1 CLK cycle following the LD\# pulse. |
| START\# | 14 | 1 | This pin informs the on-chip circuitry which clock cycle will start and/or stop the current mode of operation. Thus, the modes are asynchronously selected (via LD\#) but are synchronously started and stopped. This input is sampled by the rising edge of CLK. The actual function of this input depends on the mode that is selected. START\# must always be held high (disabled) when changing modes. This will provide a smooth transition from one mode to the next by allowing the part to reconfigure itself before a new mode begins. When START\# is high, LUT(read) mode is enabled except for Delay and Delay \& Subtract modes. |
| FC\# | 12 | 1 | Flash Clear. This input provides a fully asynchronous signal which effectively resets all bits in the RAM Array and the input and output data paths to zero. |
| DINO-23 | $\begin{aligned} & 58-63, \\ & 65-82 \end{aligned}$ | 1 | Data input bus. Provides data to the Histogrammer during Bin Accumulate, LUT, Delay and Delay \& Subtract modes. Synchronous to CLK. |
| DIO0-23 | $\begin{aligned} & 33-40, \\ & 42-57 \end{aligned}$ | 1/0 | Asynchronous data bus. Provides RAM access for a microprocessor in preconditioning the memory array and reading the results of the previous operation. Configuarable as either a 24 or 16 -bit bus. |
| IOADD0-9 | 22-31 | 1 | RAM address in asynchronous modes. Sampled on the falling edge of WR\# or RD\#. |
| uws | 21 | 1 | Upper Word Select. In 16-bit Asynchronous mode, a one on this pin denotes the contents of DIO0-7 as being the upper eight bits of the data in or out of the Histogrammer. A zero means that DIOO-15 are the lower 16 bits. In all other modes, this pin has no effect. |
| WR\# | 19 | 1 | Write enable to the RAM for the data on DIO0-23 when the HSP48410 is configured in one of the asynchronous modes. Asynchronous to CLK. |
| RD\# | 13 | 1 | Read control for the data on DIO0-23 in asynchronous modes. Output enable for DIO0-23 in other modes. Asynchronous to CLK. |
| $\mathrm{V}_{\mathrm{cc}}$ | 2,32 |  | $+5 \mathrm{~V} .0 .1 \mu \mathrm{~F}$ capacitors between the $\mathrm{V}_{\mathrm{CC}}$ and GND pins are recommended. |
| GND | 20, 41, 64, 84 |  | Ground |

## NOTES:

1. A \# after a pin name denotes an active low signal.
2. Bit 0 is the LSB on all busses.

## Functional Description

The Histogrammer is intended for use in signal and image processing applications. The on-board RAM is 24 bits by 1024 locations. For histogramming, this translates to an image size of $4 \mathrm{k} \times 4 \mathrm{k}$ with 10 -bit data. A functional block diagram of the part is shown in Figure 1.

In addition to histogramming, the HSP48410 will also perform Histogram Accumulation while feeding the results back into the memory array. The on-board RAM will then contain the Cumulative Distribution Function and can be used for further operation such as histogram equalization.

Other modes are: Bin Accumulate, Look Up Table (LUT), Delay Memory, and Delay \& Subtract. The part can also be accessed as a 24-bit by 1024 word asynchronous RAM for preconditioning or reading the results of the histogram.

The Histogrammer can be accessed both synchronously and asynchronously to the system clock (CLK). It was designed to be configured asynchronously by a microprocessor, then switched to a synchronous mode to process data. The result of the processing can then be read out synchronously, or the part can be switched to one of the asynchronous modes so the data may be read out by a microprocessor. All modes are synchronous except for the Asynchronous 16 and 24 modes.
A Flash Clear operation allows the user to reset the entire RAM array and all input and output data paths in a single cycle.

## Histogram Memory Array

The Histogram Memory Array is a 24 -bit by 1024 deep RAM. Depending on the current mode, its input data comes from either the synchronous input DINO-23, from the asynchronous data bus DIO0-23, or from the output of the adder. The output data goes to the DIO bus in both synchronous and asynchronous modes.

## Address Generator

This section of the circuit determines the source of the RAM address. In the synchronous modes, the address is taken from either the output of the counter or PINO-9. The pixel input bus is used for Histogram, Bin Accumulate, and LUT(read) modes. All other synchronous modes, i.e. Histogram Accumulate, LUT(write), Delay, and Delay \& Subtract use the counter output. The counter is reset on the first rising edge of CLK after a falling edge on START\#.
During asynchronous modes, the read and write addresses to the RAM are taken from the IOADD bus on the falling edge of the RD\# and WR\# signals, respectively.

## Adder Input

The Adder Input Control section contains muxes, registers and other logic that provide the proper data to the adder. The configuration of this section is controlled by the output of the Function Decode section.

## DIO Interface

The DIO Interface Section transfers data between the Histogrammer and the outside world. In the synchronous modes, DIO acts as a synchronous output for the data currently being processed by the chip; RD\# acts as the output enable for the DIO bus; WR\# and IOADD0-9 have no effect. When either of the Asynchronous modes are selected (16 or 24-bit), the RAM output is passed directly to the DIO bus on read cycles, and on write cycles, data input on DIO goes to the RAM input port. In this case, data reads and writes are controlled by RD\#, WR\# and IOADD0-9.

## Function Decode

This section provides the signals needed to configure the part for the different modes. The eight modes are decoded from FCTO-2 on the rising edge of LD\# (see Table 1). The output of this section is a set of signals which control the path of data through the part.

The mode should only be changed while START\# is high. After changing from one mode to another, START\# must be clocked high by the rising edge of CLK at least once.

TABLE 1. FUNCTION DECODE

| FCT |  |  |  |
| :---: | :---: | :---: | :--- |
| 2 | 1 | 0 |  |
| 0 | 0 | 0 | Mistogram |
| 0 | 0 | 1 | Histogram Accumulate |
| 0 | 1 | 0 | Delay \& Subtract |
| 0 | 1 | 1 | Look Up Table |
| 1 | 0 | 0 | Bin Accumulate |
| 1 | 0 | 1 | Delay Memory |
| 1 | 1 | 0 | Asynchronous 24 |
| 1 | 1 | 1 | Asynchronous 16 |

## Flash Clear

Flash Clear allows the user to clear the entire RAM with a single pin. When the FC\# pin is low, all bits of the RAM and the data path from the RAM to DIOO-23 are set to zero. The FC\# pin is asynchronous with respect to CLK: the reset begins immediately following a low on this signal. For synchronous modes, in order to ensure consistent results, FC\# should only be active while START\# is high. For asynchronous modes, WR\# must remain inactive while FC\# is low.

Functional Block Diagram


FIGURE 1. FUNCTIONAL BLOCK DIAGRAM

## Histogram Mode

This is the fundamental operation for which this chip was intended. When this mode is selected, the chip configures itself as shown in the block diagram of Figure 2. The pixel data is sampled on the rising edge of clock and used as the read address to the RAM array. The data contained in that address (or bin) is then incremented by 1 and written back into the RAM at the same address.


FIGURE 2. HISTOGRAM MODE BLOCK DIAGRAM

At the same time, the new value is also displayed on the DIO bus. This procedure continues until the circuit is interrupted by START\# returning high. When START\# is high, the RAM write is disabled, the read address is taken from the Pixel Input bus, and the chip acts as if it is in LUT(read) mode. Figure 3 shows histogram mode timing. START\# is used to disregard the data on PIN0-9 at DATA2. START\# is sampled on the rising edge of clock, but is delayed internally by 3 cycles to match the latency of the Address Generator. Data is clocked onto the DIO bus on the rising edge of CLK. RD\# acts as output enable.


FIGURE 3. HISTOGRAM MODE TIMING

## Histogram Accumulate Mode

This function is very similar to the Histogram function. In this case, a counter is used to provide the address data to the RAM. The RAM is sequentially accessed, and the data from each bin is added to the data from the previous bins. This accumulation of data continues until the function is halted. The results of the accumulation are displayed on the DIO bus while simultaneously being written back to the RAM. When the operation is complete, the RAM will contain the Cumulative Distribution Function (CDF) of the image.

Figure 4 shows the configuration for this mode. Once this function is selected, the START\# pin is used to reset the counter and enable writing to the RAM. Write enable is delayed 3 cycles to match the delay in the Address Generator. The START\# pin determines when the accumulation will begin. Before this pin is activated, the counter will be in an unknown state and the DIO bus will contain unpredictable data. Once the START\# pin is sampled low, the data registers are reset in order to clear the accumulation. The output (DIO bus) will then be zero until a non-zero data value is read from the RAM. Timing for this operation is shown in Figure 5.


FIGURE 4. HISTOGRAM ACCUMULATE MODE BLOCK DIAGRAM


FIGURE 5. HISTOGRAM ACCUMULATE MODE TIMING

The START\# pin must remain low in order to allow the accumulated data to overwrite the original histogram data contained in the RAM. When the START\# pin returns to a high state, the configuration remains intact, but writing to the

RAM is disabled and the part is in LUT(read) mode. Note that the counter is not reset at this point. The counter will be reset on the first cycle of CLK that START\# is detected low. To prevent invalid data from being written to the RAM, when the counter reaches its maximum value (1023), further writing to the RAM is disabled and the counter remains at this value until the mode is changed.

At the end of the histogram accumulation, the DIO output bus will contain the last accumulated value. The chip will remain in this state until START\# becomes inactive. The results of the accumulation can then be read out synchronously by keeping START\# high, or asynchronously in either of the asynchronous modes.

## Bin Accumulate Mode

The functionality of this mode is also similar to the Histogram function. The only difference is that instead of incrementing the bin data by 1 , the bin data is added to the incoming DIN bus data. The DIN bus is delayed internally by 3 cycles to match the latency in the address generator. Figure 6 shows the block diagram of the internal configuration for this mode, while the timing is given in Figure 7. Note that in this figure, START\# is used to disregard the data on DINO-23 during DATA2.


FIGURE 6. BIN ACCUMULATE BLOCK DIAGRAM


FIGURE 7. BIN ACCUMULATE TIMING

## Look Up Table Mode

A Look Up Table (LUT) is used to perform a fixed transformation function on pixel values. This is particularly useful when the transformation is non-linear and cannot be realized directly with hardware. An example is the remapping of the original pixel values to a new set of values based on the CDF obtained through Histogram Accumulation.

The transformation function can be loaded into the LUT in one of three ways: in LUT mode, through DINO-23; in either asynchronous mode, over the DIO bus as described below under Asynchronous 16/24 Modes; in the Histogram Accumulate mode the transformation function is calculated internally (see description above). The transformation function can then be utilized by deactivating START\#, putting the part in LUT mode and clocking the data to be transformed onto the PIN bus. Note that it is necessary to wait one clock cycle after changing the mode before clocking data into the part.

The block diagram and timing for this mode are shown in Figures 8 and 9 . The left half of the timing diagram shows LUT(write) mode. On the first CLK that detects START\# low, the counter is reset and the write enable is activated for the RAM. As long as START\# remains low, the counter provides the write address to the RAM and data is sequentially loaded through the DIN bus. The DIN bus is delayed internally by 3 cycles to match the latency in the Address Generator. The DIO bus will contain the previous contents of the memory location being updated. When 1024 words have been written to the RAM, the counter stops and further writes to the RAM are disabled. The part stays in this state while START\# remains low.

When START\# returns high, the RAM write is disabled, the read address is taken from the PIN bus, and the chip acts as a synchronous LUT. (This is known as LUT(read) mode.) In order to ensure that the internal pipelines are clear, data should not be input to PINO-9 until the third clock after START\# goes high.


FIGURE 8. LOOK UP TABLE BLOCK DIAGRAM


- Previous contents of bin location.

FIGURE 9. LOOK UP TABLE MODE TIMING

## Delay Memory (Row Buffer) Mode

As seen by comparing Figures 8 and 10, the configuration for this mode is nearly identical to the LUT mode. In this mode, however, the counter is always providing the address and the write function is always enabled.

In order to force this configuration to act as a row delay register, the START\# signal must be used to reset the internal counter each time a new row of pixels is being sampled. Because of the inherent latency in the address and data paths, the counter must be reset every N-4 cycles, where N is the desired delay length. For example, if a delay from DIN to DIO of ten cycles is desired, the START\# signal must be set low every six cycles (see Figure 11). If the internal address counter reaches its maximum count (1023), it holds that value and further writes to the RAM are disabled.


FIGURE 10. DELAY MEMORY BLOCK DIAGRAM


FIGURE 11. DELAY MEMORY MODE TIMING FOR ROW LENGTH OF TEN

## Delay \& Subtract Mode

This mode is similar to the Delay Memory mode, except the input data is subtracted from the corresponding data stored in RAM (See Figures 12 and 13).


FIGURE 12. DELAY AND SUBTRACT BLOCK DIAGRAM


FIGURE 13. DELAY AND SUBTRACT MODE TIMING FOR ROW LENGTH OF TEN

## Asynchronous 16/24 Modes

In the Asynchronous modes, the chip acts like a single port RAM. In this mode, the user can read (access) any bin location on the fly by simply setting the 10-bit IO address to the desired bin location. The RAM is then read or written on the following RD\# or WR\# pulse. A block diagram for this mode is shown in Figure 14. Note that all registers and pipeline stages are bypassed; START\# and CLK have no effect in this mode.

Timing waveforms for this mode are also shown in Figure 15. During reading, the read address is latched (internally) on the falling edge of RD\#. During write operations, the address is latched on the falling edge of WR\# and data is latched on the rising edge of WR\#. Note that reading and writing occur on different ports, so that, in this mode, the write port always latches its address and data values from the WR\# signal, while the read port always uses RD\# for latching.

The difference between the Async 16 mode and the Async 24 mode is the number of data bits available to the user. In 16-bit mode, the user can connect the system data bus to the lower 16 bits of the Histogrammer's DIO bus. The UWS pin becomes the LSB of the IO address, which determines if the lower 16 bits or upper 8 bits of the 24-bit Histogrammer data is being used. When UWS is low, the data present at DIOO-15 is the lower 16 bits of the data in the IOADD0-9 location. When UWS is high, the upper 8 bits of the IOADD09 location are present on DIOO-7. (This is true for both reading and writing.) Thus it takes 2 cycles for an asynchronous 24-bit operation when in Async 16 mode. Unused outputs are zeros.


FIGURE 14. ASYNCHRONOUS 16/24 BLOCK DIAGRAM

WRITE CYCLE TIMING


READ CYCLE TIMING


FIGURE 15. ASYNCHRONOUS 16/24 MODE TIMING

## Specifications HSP48410

## Absolute Maximum Ratings



## Thermal Information

| Thermal Resistance PGA Package . | $\begin{gathered} \theta_{\mathrm{ja}} \\ 34.3^{\circ} \mathrm{C} M \end{gathered}$ | $\begin{gathered} \theta_{j \mathrm{jc}} \\ 8.0^{\circ} \mathrm{C} / \mathrm{W} \end{gathered}$ |
| :---: | :---: | :---: |
| PLCC Package | $33.7^{\circ} \mathrm{CN}$ | $11.1{ }^{\circ} \mathrm{CN}$ |
| Maximum Package Power Dissipation at $+70^{\circ} \mathrm{C}$ |  |  |
| PGA Package |  | 3.1W |
| PLCC Package |  | 2.4W |
| ate Count |  | 0 Gates |

CAUTION: Stresses above those listed in "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.

## Operating Conditions

Operating Voltage Range . . . . . . . . . . . . . . . . . . . . . . . . . . $+5 \mathrm{~V} \pm 5 \%$ Operating Temperature Range . . . . . . . . . . . . . . . . . . $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$

## DC Electrical Specifications

| PARAMETER | SYMBOL | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Logical One Input Voltage | $\mathrm{V}_{\mathrm{IH}}$ | 2.0 | - | V | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| Logical One Input Voltage | $\mathrm{V}_{\mathrm{IL}}$ | - | 0.8 | V | $\mathrm{V}_{C C}=4.75 \mathrm{~V}$ |
| High Level Clock Input | $\mathrm{V}_{\text {IHC }}$ | 3.0 | - | V | $\mathrm{V}_{C C}=5.25 \mathrm{~V}$ |
| Low Level Clock Input | $V_{\text {ILC }}$ | - | 0.8 | V | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Output High Voltage | $\mathrm{V}_{\mathrm{OH}}$ | 2.6 | - | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Output Low Voltage | $\mathrm{V}_{\mathrm{OL}}$ | - | 0.4 | V | $\mathrm{l}_{\mathrm{OL}}=+2.0 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Input Leakage Current | $I_{L}$ | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}$ or GND, $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| I/O Leakage Current | 10 | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {OUT }}=\mathrm{V}_{\text {CC }}$ or GND, $\mathrm{V}_{\text {cC }}=5.25 \mathrm{~V}$ |
| Standby Supply Current | Iccss | - | 500 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathbb{I}}=\mathrm{V}_{\mathrm{CC}} \text { or } \mathrm{GND}, \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V} \text {, } \\ & \text { Outputs Open } \end{aligned}$ |
| Operating Power Supply Current | ICCOP | - | 396 | mA | $\begin{aligned} & f=33 \mathrm{MHz}, V_{I N}=V_{C C} \text { or GND } \\ & V_{C C}=5.25 \mathrm{~V}(\text { Note } 1,2) \end{aligned}$ |

NOTES:

1. Power supply current is proportional to operating frequency. typical rating for $\mathrm{I}_{\text {ccop }}$ is 12 mAMMz .
2. Maximum junction temperature must be considered when operating part at high clock frequencies.

Capacitance $T_{A}=+25^{\circ} \mathrm{C}$, Not tested, but characterized at initial design and at major process or design changes.

| PARAMETER | SYMBOL | MIN | MAX | UNITS | TEST CONDITIONS |
| :--- | :---: | :---: | :---: | :---: | :--- |
| Input Capacitance | $\mathrm{C}_{\mathrm{IN}}$ | - | 12 | pF | FREQ $=1 \mathrm{MHz}, \mathrm{V}_{\text {CC }}=$ Open, all <br> measurements are referenced to <br> device ground. |
| Output Capacitance | $\mathrm{C}_{\text {OUT }}$ | - | 12 | pF |  |

AC Electrical Specifications $\quad V_{C C}=5 \mathrm{~V} \pm 5 \%, T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ (Note 1)

| PARAMETER | SYMBOL | -40 (40 MHz) |  | -33 (33 MHz) |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |  |  |
| Clock Period | $\mathrm{T}_{\text {CP }}$ | 25 | - | 30 | - | ns |  |
| Clock Low | $\mathrm{T}_{\mathrm{CH}}$ | 10 | - | 12 | - | ns |  |
| Clock High | $\mathrm{T}_{\mathrm{CL}}$ | 10 | - | 12 | $\bullet$ | ns |  |
| DIN Setup | $\mathrm{T}_{\mathrm{DS}}$ | 12 | - | 13 | $\bullet$ | ns |  |

Specifications HSP48410
AC Electrical Specifications $V_{C C}=5 \mathrm{~V} \pm 5 \%, T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ (Note 1) (Continued)

| PARAMETER | SYMBOL | -40 (40 MHz) |  | -33 (33 MHz) |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |  |  |
| DINO-23 Hold | $\mathrm{T}_{\mathrm{DH}}$ | 0 | - | 0 | - | ns |  |
| Clock to DIOO-23 Valid | $\mathrm{T}_{\mathrm{DO}}$ | - | 15 | - | 19 | ns |  |
| FC\# Pulse Width | $\mathrm{T}_{\mathrm{FL}}$ | 35 | - | 35 | - | ns |  |
| FCTO-2 Setup to LD\# | $\mathrm{T}_{\text {FS }}$ | 10 | - | 10 | - | ns |  |
| FCT0-2 Hold from LD\# | $\mathrm{T}_{\mathrm{FH}}$ | 0 | - | 0 | - | ns |  |
| START\# Setup to CLK | $\mathrm{T}_{\text {ss }}$ | 12 | - | 13 | - | ns |  |
| START\# Hold from CLK | $\mathrm{T}_{\text {SH }}$ | 0 | - | 0 | - | ns |  |
| PINO-9 Setup Time | $\mathrm{T}_{\text {PS }}$ | 12 | - | 13 | - | ns |  |
| PINO-9 Hold Time | $\mathrm{T}_{\text {PH }}$ | 0 | - | 0 | - | ns |  |
| LD\# Pulse Width | $\mathrm{T}_{\mathrm{L}}$ | 10 | - | 12 | - | ns |  |
| LD\# Setup to START\# | $T_{\text {L }}$ | $\mathrm{T}_{\mathrm{CP}}$ |  | $\mathrm{T}_{\mathrm{CP}}$ | - | ns | Note 2 |
| WR\# Low | $T_{W L}$ | 12 | - | 15 | - | ns |  |
| WR\# High | $\mathrm{T}_{\text {WH }}$ | 12 | - | 15 | - | ns |  |
| Address Setup | $\mathrm{T}_{\text {AS }}$ | 13 | - | 15 | - | ns |  |
| Address Hold | $\mathrm{T}_{\text {AH }}$ | 1 | - | 1 | - | ns |  |
| DIO Setup to WR\# | $\mathrm{T}_{\text {ws }}$ | 12 | - | 15 | - | ns |  |
| DIO Hold from WR\# | $\mathrm{T}_{\text {WH }}$ | 1 | - | 1 | - | ns |  |
| RD\# Low | $\mathrm{T}_{\mathrm{RL}}$ | 35 | - | 43 | - | ns |  |
| RD\# High | $\mathrm{T}_{\mathrm{RH}}$ | 15 | - | 17 | - | ns |  |
| RD\# Low to DIO Valid | $\mathrm{T}_{\text {RD }}$ | - | 35 | - | 43 | ns |  |
| Read/Write Cycle Time | $\mathrm{T}_{\mathrm{CY}}$ | 55 | - | 65 | - | ns |  |
| DIO Valid after RD\# High | $\mathrm{TOH}^{\text {H}}$ | - | 0 | - | 0 | ns | Note 3 |
| Output Enable Time | TOE | - | 18 | - | 19 | ns | Note 4 |
| Output Disable Time | $\mathrm{T}_{\mathrm{OD}}$ | - | 18 | $\bullet$ | 19 | ns | Note 3 |
| Output Rise Time | $\mathrm{T}_{\text {R }}$ | - | 6 | - | 6 | ns | From 0.8V to 2.0 V , Note 3 |
| Output Fall Time | $\mathrm{T}_{\mathrm{F}}$ | - | 6 | - | 6 | ns | From 2.0 V to 0.8 V , Note 3 |

## NOTES:

1. AC Testing is performed as follows: Input levels (CLK) 0.0 V and 4.0 V ; Input levels (All other inputs) 0 V and 3.0 V . Timing reference levels $(C L K)=2.0 \mathrm{~V}$, (All others) $=1.5 \mathrm{~V}$. Output load circuit with $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$. Output transition measured at $\mathrm{V}_{\mathrm{OH}} \geq 1.5 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{OL}} \leq 1.5 \mathrm{~V}$.
2. There must be at least one rising edge of CLK between the rising edge of LD\# and the falling edge of START\#.
3. Characterized upon initial design and after major changes to design and/or process.
4. Transition is measured at $\pm 200 \mathrm{mV}$ from steady state voitage with loading as specified in test load circuit with $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$.

## Test Load Circuit



SWITCH S1 OPEN FOR ICCSB AND I ${ }_{\text {CCOP }}$ TEST

## Waveforms



READ CYCLE TIMING


FLASH CLEAR TIMING

FC\#


OUTPUT RISE AND FALL TIMES


## Features

- DC to 32 MHz Operating Frequency
- Programmable Buffer Length from 2 to 1281 Words
- Supports Data Words to 10-Bits
- Clock Select Logic for Positive or Negative Edge System Clocks
- Data Recirculate or Delay Modes of Operation
- Expandable Data Word Width or Buffer Length
- Three-State Outputs
- TTL Compatible Inputs/Outputs
- Low Power CMOS
- Available in 44 Pin PLCC Package


## Applications

- Sample Rate Conversion
- Data Time Compression/Expansion
- Software Controlled Data Alignment
- Programmable Serial Data Shifting
- Audio/Speech Data Processing


## Video/Image Processing

- 1-H Delay Line of 910 NTSC, 1135 PAL or 1280 Samples:
- High Resolution Monitor Delay Line
- Comb Filter Designs
- Progressive Scanning Display
- TV Standards Conversion
- Image Processing


## Description

The HSP9501 is a 10 -Bit wide programmable data buffer designed for use in high speed digital systems. Two different modes of operation can be selected through the use of the MODSEL input. In the delay mode, a programmable data pipeline is created which can provide 2 to 1281 clock cycles of delay between the input and output data. In the data recirculate mode, the output data path is internally routed back to the input to provide a programmable circular buffer.

The length of the buffer or amount of delay is programmed through the use of the 11-bit length control input port (LCO-10) and the length control enable (LCEN\#). An 11 -bit value is applied to the LCO-10 inputs, LCEN\# is asserted, and the next selected clock edge loads the new count value into the length control register. The delay path of the HSP9501 consists of two registers with a programmable delay RAM between them, therefore, the value programmed into the length control register is the desired length -2 . The range of values which can be programmed into the length control register are from 0 to 1279, which in turn results in an overall range of programmable delays from 2 to 1281.

Clock select logic is provided to allow the use of a positive or negative edge system clock as the CLK input to the HSP9501. The active edge of the CLK input is controlled through the use of the CLKSEL input. All synchronous timing (i.e. data setup, hold and output delays) are relative to the clock edge selected by CLKSEL. An additional clock enable input (CLKEN\#) provides a means of disabling the internal clock and holding the existing contents temporarily. All outputs of the HSP9501 are three-state outputs to allow direct interfacing to system or multi-use busses.

The HSP9501 is recommended for digital video processing or any applications which require a programmable delay or circular data buffer.

## Pinout



Block Diagram


## Pin Descriptions

| NAME | PIN NUMBER | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| $\mathrm{v}_{\mathrm{CC}}$ | 12,34 |  | The +5 V power supply pin. A $0.1 \mu \mathrm{~F}$ capacitor between the $\mathrm{V}_{\mathrm{CC}}$ and GND pin is recommended. |
| GND | 13,33 |  | The device ground. |
| CLK | 1 | 1 | Input Clock. This clock signal is used to control the data movement through the programmable buffer. It is also the signal which latches the input data, length control word and mode select. Input setup and hold times with respect to the clock must be met for proper operation. |
| DIO-9 | $\begin{gathered} 27,29-32, \\ 35-39 \end{gathered}$ | 1 | Data Inputs. This 10-bit input port is used to provide the input data. When MODSEL is low, data on the DIO-9 inputs is latched on the clock edge selected by CLKSEL. |
| DOO-9 | $\begin{aligned} & 7-11, \\ & 14-18 \end{aligned}$ | 0 | Data Outputs. This 10-bit port provides the output data from the internal delay registers. Data latched into the DIO-9 inputs will appear at the DOO-9 outputs on the Nth clock cycle, where N is the total delay programmed. |
| LC0-10 | $\begin{aligned} & 20-26, \\ & 41-44 \end{aligned}$ | 1 | Length Control Inputs. These inputs are used to specify the number of clock cycles of delay between the DIO-9 inputs and the DOO-9 outputs. An integer value between 0 and 1279 is placed on the LCO-10 inputs, and the total delay length ( N ) programmed is the LCO-10 value plus 2 . In order to properly load an active length control word, the value must be presented to the LCO-10 inputs and LCEN\# must be asserted during an active clock edge selected by CLKSEL. |
| LCEN\# | 6 | I | Length Control Enable. LCEN\# is used in conjuction with LC0-10 and CLK to load a new length control word. An 11-bit value is loaded on the LC0-10 inputs, LCEN\# is asserted, and the next selected clock edge will load the new count value. Since this operation is synchronous, LCEN\# must meet the specified setup/hold times with respect to CLK for proper operation. |
| OE\# | 19 | 1 | Output Enable. This input controls the state of the DOO-9 output port. A low on this control line enables the port for output. When OE\# is high, the output drivers are in the high impedance state. Internal latching or transfer of data is not affected by this input. |
| MODSEL | 40 | 1 | Mode Select. This input is used to control the mode of operation of the HSP9501. A low on MODSEL causes the device to latch new data at the DIO-9 inputs on every clock cycle, and operate as a programmable pipeline register. When MODSEL is high, the HSP9501 is in the recirculate mode, and will operate as a programmable length circular buffer. This control signal may be used in a synchronous fashion during device operation, however, care must be taken to ensure the required setup/hold times with respect to CLK are met. |
| CLKSEL | 5 | 1 | Clock Select Control. This input is used to determine which edge of the CLK signal is used for controlling all internal events. A low on CLKSEL selects the negative going edge, therefore, all setup, hold, and output delay times are with respect to the negative edge of CLK. When CLKSEL is high, the positive going edge is selected and all synchronous timing is with respect to the positive edge of the CLK signal. |
| CLKEN\# | 2 | 1 | Clock Enable. This control signal can be used to enable or disable the CLK input. When low, the CLK input is enabled and will operate in a normal fashion. A high on CLKEN\# will disable the CLK input and will "hold" all internal operations and data. This control signal may also be used in a synchronous fashion, however, setup and hold requirements with respect to CLK must be met for proper device operation. |

## Functional Description

The HSP9501 is a 10 -bit wide programmable length data buffer. The length of delay is programmable from 2 to 1281 delays in single delay increments.

Data into the delay line may be selected from the data input bus ( $\mathrm{D} \mid 0-9$ ) or as recirculated output, depending on the state of the mode select (MODSEL) control input.

## Mode Select

The MODSEL control pin selects the source of the data moving into the delay line. When MODSEL is low, the data input bus (DIO-9) is the source of the data. When MODSEL is high, the output of the HSP9501 is routed back to the input to form a circular buffer.
The MODSEL control line is latched at the input by the CLK signal. The edge which latches this control signal is determined by the CLKSEL control line. In either case, the MODSEL line is latched on one edge of the CLK signal with the following edge moving data into and through the HSP9501. Refer to the functional timing waveforms for specific timing references.

## Clock Select Logic

The clock select logic is provided to allow the use of positive or negative edge system clocks. The active edge of the CLK input to the HSP9501 is controlled through the use of the CLKSEL input.

When CLKSEL is low, the negative going edge of CLK is used to control all internal operations. A high on CLKSEL selects the positive going edge of CLK.
All synchronous timing (i.e. setup, hold and output propagation delay times are relative to the CLK edge selected by CLKSEL. Functional timing waveforms for each state of CLKSEL are provided (refer to timing waveforms for details).

## Delay Path Control

The HSP9501 buffer length is programmable from 2 to 1281 data words in one word increments. The minimum number of delays which can be programmed is two, consisting of the input and output buffer registers only.

The Length control inputs (LCO-10) are used to set the length of the programmable delay ram which can vary in length from 0 to 1279. The total length of the HSP9501 data buffer will then be equal to the programmed value on LCO-10 plus 2. The programmed delay is established by the 11-bit integer value of the LCO-10 inputs with LC10 as the MSB and LCO as the LSB.

For example,

| LC10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | LCO |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 1 |

programs a length value of $2^{6}+2^{0}=65$. The total length of the delay will be $65+2$ or 67 delays.

Table 1 indicates several programming values. The decimal value placed on LCO-10 must not exceed 1279. Controlled operation with larger values is not guaranteed.

Values on LCO-10 are latched on the CLK edge selected by the CLKSEL control line, when LCEN\# is active. LCO-10 and LCEN\# must meet the specified setup and hold times relative to the selected CLK edge for proper device operation.

TABLE 1. LENGTH CONTROL PROGRAMMING EXAMPLES

| LC10 | LC9 |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $2^{10}$ | $\mathbf{2}^{9}$ | $\mathbf{2}^{8}$ | $2^{7}$ | $2^{6}$ | $\mathbf{2}^{5}$ | $\mathbf{2}^{4}$ | $\mathbf{2}^{3}$ | $\mathbf{2}^{2}$ | $\mathbf{2 1}^{1}$ | $2^{2}$ | PROGRAMMED <br> LENGTH | TOTAL <br> LENGTH <br> N |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 2 |
| 0 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 118 | 120 |
| 0 | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 808 | 810 |
| 1 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1049 | 1051 |
| 1 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1279 | 1281 |

## Absolute Maximum Ratings



## Operating Conditions



```
Operating Temperature Range
\(0^{\circ} \mathrm{C}\) to \(+70^{\circ} \mathrm{C}\)
```

D.C. Electrical Specifications $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}+5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$, Commercial)

| PARAMETER | SYMBOL | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Logical One Input Voltage | $\mathrm{V}_{\mathrm{IH}}$ | 2.0 | - | V | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| Logical Zero Input Voltage | $\mathrm{V}_{\text {IL }}$ | - | 0.8 | V | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Output HIGH Voltage | $\mathrm{V}_{\mathrm{OH}}$ | 2.4 | - | V | $\mathrm{I}^{\mathrm{OH}}=-4 \mathrm{~mA} \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Output LOW Voltage | $\mathrm{V}_{\mathrm{OL}}$ | - | 0.4 | V | $\mathrm{IOL}=+4.0 \mathrm{~mA} \mathrm{~V} \mathrm{VC}=4.75 \mathrm{~V}$ |
| Input Leakage Current | 1 | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=$ GND or $\mathrm{V}_{\text {CC }} \mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| Output Leakage Current | 10 | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {OUT }}=\mathrm{GND}$ or $\mathrm{V}_{\text {CC }} \mathrm{V}_{\text {CC }}=5.25 \mathrm{~V}$ |
| Standby Current | ${ }^{\text {I CcsB }}$ | - | 500 | $\mu \mathrm{A}$ | $V_{I N}=V_{C C} \text { or } G N D, V_{C C}=5.25 \mathrm{~V}$ $\text { Note } 2$ |
| Operating Power Supply Current | ICCOP | - | 125 | mA | $\begin{aligned} & f=25 \mathrm{MHz}, \mathrm{~V}_{\text {IN }}=\mathrm{V}_{\mathrm{CC}} \text { or GND } \\ & \mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V} \text {, Note } 1,2 \end{aligned}$ |
| Input Capacitance | $\mathrm{CIN}^{\text {IN }}$ | - | 10 | pF | FREQ $=1 \mathrm{MHz}, \mathrm{V}_{\text {CC }}=$ Open, |
| Output Capacitance | $\mathrm{Co}_{0}$ | - | 10 | pF |  |

A.C. Electrical Specifications $\left(V_{C C}=5.0 \mathrm{~V} \pm 5 \%, T_{A}=0^{\circ} \mathrm{C}\right.$ to $+70^{\circ} \mathrm{C}$, Commercial), (Note 4)

| PARAMETER | SYMBOL | -32 |  | -25 |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |  |  |
| Clock Period | $\mathrm{T}_{\mathrm{CP}}$ | 31 | - | 40 | - | ns |  |
| Clock Pulse Width High | TPWH | 12 | - | 15 | - | ns |  |
| Clock Pulse Width Low | TPWL | 12 | - | 15 | - | ns |  |
| Data Input Setup Time | TDS | 10 | - | 12 | - | ns |  |
| Data Input Hold Time | TDH | 2 | - | 2 | - | ns |  |
| Output Enable Time | TENA | - | 20 | - | 25 | ns |  |
| Output Disable Time | TDIS | - | 24 | - | 25 | ns | Note 3 |
| CLKEN\# to Clock Setup | TES | 10 | - | 12 | - | ns |  |
| CLKEN\# to Clock Hold | TEH | 2 | - | 2 | - | ns |  |
| LCO-10 Setup Time | TLS | 10 | - | 13 | - | ns |  |
| LCO-10 Hold Time | TLH | 2 | - | 2 | - | ns |  |
| LCEN\# to Clock Setup | TLES | 10 | - | 13 | - | ns |  |
| LCEN\# to Clock Hold | TLEH | 2 | - | 2 | - | ns |  |
| MODSELSetup Time | TMS | 10 | - | 13 | - | ns |  |
| MODSEL Hold Time | $T_{\text {MH }}$ | 2 | - | 2 | - | ns |  |
| Clock to Data Out | TOUT | - | 16 | - | 22 | ns |  |
| Output Hold from Clock | TOH | 4 | - | 4 | - | ns |  |
| Rise, Fall Time | TRF | - | 6 | - | 6 | ns | Note 3 |

## NOTES:

1. Power supply current is proportional to operating frequency. Typical rating for ${ }^{1} \mathrm{CCOP}$ is $5 \mathrm{~mA} / \mathrm{MHz}$.
2. Output load per test load circuit with switch open and $C_{L}=40 \mathrm{pF}$.
3. Controlled by design or process parameters and not directly tested. Characterized upon initial design and after major process and/or design changes.
4. A.C. Testing is performed as follows: Input levels: OV and 3.0 V , Timing reference levels $=1.5 \mathrm{~V}$, Input rise and fall times driven at $1 \mathrm{~ns} / \mathrm{N}$, Output load $C_{L}=40 \mathrm{pF}$.

Test Load Circuit


Switch S1 Open for ICCSB and ICCOP Tests

Timing Waveforms


FUNCTIONAL TIMING (CLKSEL = LOW)


INTERNAL
CLOCK


CLKEN\# TIMING (CLKSEL = LOW)


OUTPUT RISE AND FALL TIMES


LENGTH CONTROL TIMING (CLKSEL = LOW)

## Timing Waveforms (Continued)



FUNCTIONAL TIMING (CLKSEL $=$ HIGH)


CLKEN\# TIMING (CLKSEL $=$ HIGH)


LENGTH CONTROL TIMING (CLKSEL $=\mathrm{HIGH})$

## Features

- Four 8-Bit Registers
- Hold, Transfer and Load Instructions
- Single 4-Stage or Dual-2 Stage Pipelining
- All Register Contents Available at Output
- Fully TTL Compatible
- Three-State Outputs
- High Speed, Low Power CMOS
- Available in 24 Pin Dual-In-Line and SOIC Packages


## Applications

- Array Processor
- Digital Signal Processor
- A/D Buffer
- Telecommunication
- Byte Wide Shift Register
- Mainframe Computers


## Description

These devices are multilevel pipeline registers implemented using a low power CMOS process. They are pin for pin compatible replacements for industry standard multilevel pipeline registers such as the L29C520 and L29C521. The HSP9520 and HSP5921 are direct replacements for the AM29520/21 and WS59520/21.

They consist of four 8-bit registers which are dual ported. They can be configured as a single four level pipeline or a dual two level pipeline. A single 8-bit input is provided, and the pipelining configuration is determined by the instruction code input to the 10 and 11 inputs (see instruction control).

The contents of any of the four registers is selectable at the multiplexed outputs through the use of the S0 and S1 multiplexer control inputs (see register select). The output is 8 -bits wide and is three-stated through the use of the OE\# input.

The '9520 and '9521 differ only in the way data is loaded into and between the registers in dual two-level operation. In the '9520, when data is loaded into the first level the existing data in the first level is moved to the second level. In the '9521, loading the first level simply causes the current data to be overwritten. Transfer of data to the second level is achieved using the single four level mode ( $11,10=$ ' 0 '). This instruction also causes the first level to be loaded. The HOLD instruction ( $11,10=$ ' 1 ') provides a means of holding the countents of all registers.

## Pinout



## Block Diagram



## Pin Descriptions

| NAME | DIP PIN | TYPE | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| $\mathrm{v}_{\mathrm{CC}}$ | 24 |  | The +5 V power supply pin. A $0.1 \mu \mathrm{~F}$ capacitor between the $\mathrm{V}_{\mathrm{CC}}$ and GND pin is recommended. |
| GND | 12 |  | The device ground. |
| CLK | 11 | 1 | Input Clock. Data is latched on the low to high transition of this clock signal. Input setup and hold times with respect to the clock must be met for proper operation. |
| D0-7 | 3-10 | 1 | Data Input Port. These inputs are used to supply the 8 bits of data which will be latched into the selected register on the next rising clock edge. |
| YO-7 | 21-14 | 0 | Data Output Port. This 8-bit port provides the output data from the four internal registers. They are provided in a multiplexed fashion, and are controlled via the multiplexer control inputs ( SO and S 1 ). |
| 10,11 | 1,2 | 1 | Instruction Control Inputs. These inputs are used to provide the instruction code which determines the internal register pipeline configuration. Refer to the Instruction Control Table for the specific codes and their associated configurations. |
| so, S1 | 23, 22 | 1 | Multiplexer Control Inputs. These inputs select which of the four internal registers' contents will be available at the output port. Refer to the Register Select Table for the codes to select each register. |
| OE\# | 13 | 1 | Output Enable. This input controls the state of the output port (YO-Y7). A LOW on this control line enables the port for ouput. When OE\# is HIGH, the output drivers are in the high impedance state. Internal latching or transfer of data is not affected by this pin. |



## Operating Conditions

Operating Voltage Range ....................... +4.75 V to +5.25 V
Operating Temperature Range
$.0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Reliability Information
$\theta_{\mathrm{ja}} \ldots \ldots . . . . . . . . . . . . . . .$.
 Maximum Package Power Dissipation. ...1.5W (DIP), 1.0W (SOIC)
D.C. Electrical Specifications ( $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ )

| PARAMETER | SYMBOL | MIN | MAX | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Logical One Input Voltage | $\mathrm{V}_{\mathrm{IH}}$ | 2.0 | - | V | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| Logical Zero Input Voltage | $\mathrm{V}_{\text {IL }}$ | - | 0.8 | V | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Output HIGH Voltage | $\mathrm{V}_{\mathrm{OH}}$ | 2.4 | - | V | $\mathrm{I}^{\mathrm{OH}}=-6.5 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Output LOW Voltage | $\mathrm{V}_{\mathrm{OL}}$ | - | 0.5 | V | $\mathrm{I}_{\mathrm{OL}}=+20.0 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Input Leakage Current | 1 | -10 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{1 \mathrm{~N}}=\mathrm{V}_{\mathrm{CC}}$ or $\mathrm{GND}, \mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| Output Leakage Current | 10 | -10 | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{\text {OUT }}=V_{C C} \text { or } G N D \\ & V_{C C}=5.25 \mathrm{~V} \end{aligned}$ |
| Standby Power Supply Current | ${ }^{\text {I CcsB }}$ | - | 500 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{I N}=V_{C C} \text { or } G N D \\ & V_{C C}=5.25 V \text { Outputs Open } \end{aligned}$ |
| Operating Power Supply Current | ${ }^{\text {I CCOP }}$ | - | 12 | mA | $\begin{aligned} & f=5.0 \mathrm{MHz}, V_{I N}=V_{C C} \text { or GND } \\ & V_{C C}=5.25 \mathrm{~V} \text {, Ouputs Open, Note } 1 \end{aligned}$ |

Capacitance $\mathbf{~}^{( } \mathrm{A}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$, Note 3)

| PARAMETER | SYMBOL | MIN | MAX | UNITS | TEST CONDITIONS |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Input Capacitance | CIN | - | 12 | pF | FREQ $=1 \mathrm{MHz}, \mathrm{V}_{\mathrm{CC}}=$ Open, all measurements <br> are referenced to device ground. |
| Output Capacitance | CO | - | 12 | pF |  |

A.C. Electrical Specifications $\left(V_{C C}=5.0 \mathrm{~V} \pm 5 \%, T_{A}=0^{\circ} \mathrm{C}\right.$ to $+70^{\circ} \mathrm{C}$, Note 2)

| PARAMETER | SYMBOL | MIN | MAX | UNITS | TEST CONDITIONS (Note 2) |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Clock to Data Out | TPD | - | 21 | ns |  |
| Mux Select to Data Out | TSELD | - | 20 | ns |  |
| Input Setup Time (DO-7/10-7) | TS | 10 | - | ns |  |
| Input Hold Time (D0-7/10-7) | TH | 3 | - | ns |  |
| Output Enable Time | TENA | - | 20 | ns |  |
| Output Disable Time | TDIS | - | 13 | ns | Note 3 |
| Clock Pulse Width | TPW | 10 | - | ns |  |

NOTES:

1. Power supply current is proportional to frequency. Typical rating for $I_{C C O P}$ is $2.4 \mathrm{~mA} / \mathrm{MHz}$.
2. A.C. Testing is performed as follows: Input levels: OV and 3.0 V , Timing reference levels $=1.5 \mathrm{~V}$, Input rise and fall times driven at 1 ns $/ \mathrm{V}$, Output load $C_{L}=40 \mathrm{pF}$.
3. Controlled by design or process parameters and not directly tested. Characterized upon initial design and after major design and/or process changes.


Absolute Maximum Ratings
$+8.0 \mathrm{~V}$
Storage Temperature Range........ $.65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Junction Temperature . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $+150^{\circ} \mathrm{C}$
Lead Temperature (Soldering, Ten Seconds) . . . . . . . . . . . . $+300^{\circ} \mathrm{C}$

## Operating Conditions

Operating Voltage Range . . . . . . . . . . . . . . . . . . . . +4.75 V to +5.25 V
Operating Temperature Range $\ldots \ldots \ldots \ldots \ldots . . .0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Reliability Information

D.C. Electrical Specifications $\left(V_{C C}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $\left.+70^{\circ} \mathrm{C}\right)$

| PARAMETER | SYMBOL | MIN | MAX | UNITS | TEST CONDITIONS |
| :--- | :---: | :---: | :---: | :---: | :--- |
| Logical One Input Voltage | $\mathrm{V}_{\text {IH }}$ | 2.0 | - | V | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| Logical Zero Input Voltage | $\mathrm{V}_{\mathrm{IL}}$ | - | 0.8 | V | $\mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Output HIGH Voltage | $\mathrm{V}_{\mathrm{OH}}$ | 2.4 | - | V | $\mathrm{I}_{\mathrm{OH}}=-2.0 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Output LOW Voltage | $\mathrm{V}_{\mathrm{OL}}$ | - | 0.5 | V | $\mathrm{I}_{\mathrm{OL}}=+12.0 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Input Leakage Current | I | -10 | 10 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{IN}}=\mathrm{GND}$ or $\mathrm{V}_{\mathrm{CC}}, \mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| Output Leakage Current | IO | -10 | 10 | $\mu \mathrm{~A}$ | $\mathrm{V}_{\mathrm{OUT}}=\mathrm{V}_{\mathrm{CC}}$ or GND <br> $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| Standby Power Supply Current | $I_{\mathrm{CCSB}}$ | - | 500 | $\mu \mathrm{~A}$ | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\mathrm{CC}}$ or GND <br> $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ Outputs Open |
| Operating Power Supply Current | $\mathrm{I}_{\mathrm{CCOP}}$ | - | 12 | mA | $\mathrm{f}=5.0 \mathrm{MHz}, \mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}$ or GND <br> $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{Ouputs}$ Open, Note 1 |

Capacitance $\left(T_{A}=+25^{\circ} \mathrm{C}\right.$, Note 3)

| PARAMETER | SYMBOL | MIN | MAX | UNITS | TEST CONDITIONS |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Input Capacitance | CIN | - | 12 | pF | FREQ $=1 \mathrm{MHz}, \mathrm{V}_{\mathrm{CC}}=$ Open, all measure- <br> ments are referenced to device ground. |
| Output Capacitance | CO | - | 12 | pF |  |

A.C. Electrical Specifications ( $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ Note 2)

| PARAMETER | SYMBOL | MIN | MAX | UNITS | TEST CONDITIONS (Note 2) |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Clock to Data Out | TPD | - | 25 | ns |  |
| Mux Select to Data Out | TSELD | - | 25 | ns |  |
| Input Setup Time (D0-7, 10-1) | TS | 15 | - | ns |  |
| Input Hold Time (DO-7, 10-1) | $\mathrm{T}_{\mathrm{H}}$ | 3 | - | ns |  |
| Output Enable Time | TENA | - | 25 | ns |  |
| Output Disable Time | T DIS | - | 20 | ns | Note 3 |
| Clock Pulse Width | TPW | 13 | - | ns |  |

## NOTES:

1. Power supply current is proportional to frequency. Typical rating is $2.4 \mathrm{~mA} / \mathrm{MHz}$.
2. A.C. Testing is performed as follows: Input levels: $O V$ and 3.0 V , Timing reference levels $=1.5 \mathrm{~V}$, Input rise and fall times driven at $1 \mathrm{~ns} / \mathrm{V}$, Output load $C_{L}=40 \mathrm{pF}$.
3. Controlled by design or process parameters and not directly tested. Characterized upon initial design and after major design and/or process changes.

## Timing Waveform



TABLE 1. INSTRUCTION CONTROL


TABLE 2. REGISTER SELECT

| S1 | S0 | '9520 OR'9521 |
| :---: | :---: | :---: |
| 0 | 0 | $B 2$ |
| 0 | 1 | B1 |
| 1 | 0 | A2 |
| 1 | 1 | A1 |



## DEVELOPMENT TOOLS

PAGE

## DATA SHEETS

Deci•Mate Harris HSP43220 Decimating Digital Filter Development Software ..... 7-3
HSP-EVAL DSP Evaluation Platform ..... 7-7
HSP45116-DB HSP45116 Daughter Board ..... 7-8

May 1991

## Harris HSP43220 Decimating Digital Filter Development Software

Harris DECI•MATE Development Software assists the design engineer to prototype designs for the Harris HSP43220 Decimating Digital filter (DDF). Developed specifically for the DDF, this software consists of three integrated modules: DDF Design, DDF Simulator and DDF PROM. The Design module designs a filter from a set of user specifications for the DDF. The Simulator module models the DDF's internal operation. The PROM module uses the device configuration created by the Design module to build a PROM data file that can be used to store and download the DDF configuration.

## DDF System Design

The DDF consists of two stages: a High Decimation Filter (HDF) and a Finite Impulse Response (FIR) filter. Together these provide a unique narrow band, low pass filter. Because of this unique architecture, special software is required to configure the device for a given set of filter parameters. This software uses system level filter parameters (listed below) to perform the trade off analysis and calculate the values for the DDF's configuration registers and FIR coefficients.
Design specifications are supplied by the user in terms of:

1. Input sample frequency
2. Required output sample frequency
3. Passband signal bandwidth
4. Transition bandwidth
5. Amount of attenuation allowed in the passband
6. Amount of stopband attenuation required for signals outside of the band of interest.

This information is entered into a menu screen (See Figure 1), providing immediate feedback on the design validity. The design module calculates the order of the HDF, HDF decimation required, the FIR input data rate, minimum clock frequency for the FIR, FIR order and decimation required in the FIR.

The design module will then generate the FIR filter. Four different methods are provided for the FIR design:

1. A Standard FIR automatically designed by the module using the Parks-McClellan method to compute the coefficients of an equiripple (Chebyshev) filter.
2. Any FIR imported into the Design module from another FIR design program.
3. A precompensated FIR which is automatically designed by the module to compensate for the roll-off in the passband of the HDF frequency response.
4. The FIR may also be bypassed in which case the optimal HDF is designed from the user specifications.

Frequency response curves are then displayed showing the resulting responses in the HDF, FIR and for the entire chip using the given filter design. Figure 2 is a typical display. The user may save this frequency response data for further analysis. The design module also creates a report file documenting the filter design and providing the coefficients and setup register values for programming the device.

## DDF Simulator

The simulator provides an accurate simulation of the device before any hardware is built. It can be used to simulate any filter designed with DECI • MATE. The simulator takes into account the fixed point bus widths and pipeline delays for every element in the DDF.
The simulator provides the user with an input signal which can be used to stimulate the filter. This signal is created from the options shown in Table 1. The user can select a pure step, impulse, cosine, chirp, uniform or Gaussian noise as the input signal, or a more complex signal can be generated by combining that data with an option selected from the Signal \#2 column, with the combining operator chosen from the middle column. The user can also import a signal from an outside source.

SIGNAL \#1 Step Impulse cosine Chirp Uniform Noise Gaussian Noise

OPERATION

No Operation Add Concatenate Multiply

SIGNAL \#2
Step
Impulse
cosine
Chirp
Uniform Noise
Gaussian Noise

## Imported From Outside

Probes are provided to select specific areas to graphically display data values as well as save into data files for further processing. The DDF Simulator has two levels; the DDF Simulator Specification screen and the DDF Simulator Main Screen.

The specification screen (see Figure 3) is used to input the simulation parameters. The users selects display modes in either continuous or decimated format and data formats in either decimal or hexadecimal. The specification screen also provides for selection of the input signal.
The simulator main screen (see Figure 4) defines the simulator test probes and displays the data values per clock cycle. The interactive simulator screen consists of the HSP43220 block diagram, test probes and register contents. The user selects the step size of the input sample clock and also selects the probes to be monitored. The simulator will then clock through the specified number of clock cycles and display the resulting time domain response. Figure 5 shows a typical probe display.

## Monarch 2.0 DSP Design Software

$\mathrm{DECI} \bullet$ MATE is fully integrated with Monarch 2.0 professional DSP design software. Monarch is a fullfeatured DSP package with FIR IIR filter design and analysis, Two dimensional and Three dimensional viewing, a programmable signal/systems laboratory with $100+$ DSP/ Math functions, extensive fixed-point support and FFTs/ IFFTs. Monarch is available separately from The Athena Group, Inc.

When used with Monarch 2.0, DECI • MATE becomes a full feature design environment for a DSP system. Data can easily be transferred from $\mathrm{DECl} \bullet$ MATE modules to the Monarch modules for further analysis.

## System Requirements

IBM PC ${ }^{\text {m }}, \mathrm{XT}^{\mathrm{mm}}, \mathrm{AT}^{\mathrm{mw}}, \mathrm{PS} / 2^{\mathrm{mm}}$ computer or $100 \%$ compatible with 640k RAM running MS/PC-DOS 2.0 or higher. One MegaByte of fixed-disk space with $5.25^{\prime \prime}$ or $3.5^{\prime \prime}$ floppy drive. CGA, MCGA, EGA, VGA, 8514, or Hercules graphics adapter. A Math co-processor is strongly recommended.


FIGURE 1. FILTER SPECIFICATION MENU


FIGURE 2. FREQUENCY DISPLAY


```
Filter File : PRES.DAR
Probe Display : HEX
```

- Signal Origin : GENERATED

| Signal \#1 | : COSINE | Amplitude <br> 1.00 | Frequen |  |
| :--- | :---: | :---: | :---: | :---: |
| Operator | $:$ | + |  |  |
|  |  |  | Mean | StdDev |
| Signal \#2 | $:$ | GAUSS | 0.00 | 0.500000 |

FIGURE 3. SPECIFICATION MENU


FIGURE 4. SIMULATOR - MAIN MENU


FIGURE 5. SIMULATOR PROBE DISPLAY

HSP-EVAL

## Features

- Single HSP-EVAL May be Used to Evaluate a Variety of Parts within the HSPXXXXX Family
- May be Daisy Chained to Support Evaluation of Multi-chip Solutions
- Parallel Port Interface to IBM PC to Simplify Evaluation Board VO
- Three Clocking Modes for Flexibility in Performance Analysis and Prototyping
- C Based Software Template for Data VO Between IBM PC and Evaluation Board
- Dual 96-Pin DIN Connector for High Speed VO


## Applications

- PC Based Performance Analysis of HSPXXXXX Family of DSP
- Rapid Prototyping


## Description

The HSP-EVAL is the mother board for a set of daughter boards based on the HSPXXXXX family of Digital Signal Processing products. Each product specific daughter board is mated with the HSP-EVAL to provide a mechanism for rapid evaluation and prototyping. As shown in the block diagram, the HSP-EVAL consists of input, control, and output busses which provide I/O data paths to the target daughter board. These busses are brought out through dual 96 Pin connectors to support daisy chaining HSP-EVAL's for multichip prototyping. The input and control busses can be driven by registers which are down loaded with data via the parallel port of an IBM PC or compatible. Besides using the PC to drive the daughter board inputs, the PC can also read daughter board outputs which have been serialized by the shift register on the output bus. For high speed I/O, the VME compatible, $96-\mathrm{Pin}$ DIN, connectors are provided as an alternative data path for HSP-EVAL I/O and control.

Jumper selectable clock sources provide three different methods of clocking the part under evaluation. In mode one, the clock signal is generated under PC based software control. In mode two, the onboard oscillator may be selected as the clock source. In mode three, the user may provide an external clock throught a DIN connector.
A PC based software interface is available to simplify I/O to the HSPEVAL. In modes where the HSP-EVAL is configured to provide the daughter board with a high speed clock, the interface software can be used for real time control and configuration. For modes in which the HSP-EVAL is configured to provide a software generated clock, the interface software can drive the daughter board inputs with a user defined data set while collecting daughter board outputs to the PC's disk.

HARRIS
HSP45116-DB

## Features

- Designed for Use with HSP-EVAL
- Access to HSP45116's Input, Output, and Control Signals Through Three 50 Pin Headers
- Jumper Configuration Field as Alternative for Programming Control Inputs
- C Based Software to Support HSP45116 VO and Control When Used with HSP-EVAL
- High Speed IVO Supported


## Applications

- PC Based Performance Analysis of HSP45116 When Used with HSP-EVAL
- Rapid Prototyping


## Description

The HSP45116-DB is a daughter board designed to mate with the HSP-EVAL for rapid evaluation and prototyping of the HSP45116 Numerically Controlled Oscillator Modulator. Together this combination of boards provides a mechanism to evaluate HSP45116 operation using IBM PC based I/O and control. As shown in the block diagram, the HSP45116-DB maps the input, output, and control signals of the HSP45116 to three 50 pin connectors. These connectors mate the HSP45116's various I/O and control signals with the HSP-EVAL's data busses. Thus, a path is established for PC based I/O and control.

A IBM PC based software package is provided which controls HSP45116-DB operation through the HSP-EVAL. The software package provides the user with a DOS command line or menu driven interface for daughter board I/O and control. Since the software supports data acquisition from the HSP45116, software based signal analysis may be used to quantify part performance.
The degree of control exerted by the software varies depending upon the clock provided to the HSP45116-DB. If a high speed clock is provided via the HSP-EVAL's on board oscillator or external clock pin, the software can be used to exert real time control. If a software controlled clock is provided, the HSP45116-DB can be driven with a user defined data set while storing results back to the PC for later analysis.

The HSP45116-DB is a 6 layer printed circuit board which comes populated with one HSP45116GC-25. The PC based software required to control the daughter board via the HSP-EVAL is also provided.

## Block Diagram




The evaluation hardware for the HSP family of products consists of the motherboard, which forms the interface to the PC, and the daughterboard, which carries the part under evaluation.


The hardware to evaluate the HSP45116 consists of the HSP-EVAL motherboard and the HSP45116-DB daughterboard. Two software packages are provided for the data and control interface between the HSP45116-DB and the PC. One is menu driven and the other accepts DOS command lines.

## APPLICATION NOTES

PAGE

## APPLICATION NOTE NUMBER

AN116 Extended Digital Filter Configurations ..................................................... 8-3
AN9205 Timing Relationships for HSP45240...................................................... . 8-13
AN9206 Correlating on Extended Data Lengths ................................................. . . 8-15
AN9102 Noise Aspects of Applying Advanced CMOS Semiconductors . ....................... 8-17
AN9207 Temperature Considerations .......................................................................... 8-26


No. 116 May 1991

## Harris Signal Processing

## EXTENDED DIGITAL FILTER CONFIGURATIONS

## Introduction

Harris HSP43891/881/481 Digital Filters (DFs) perform high speed sum-of-products operations. These video speed devices operate at 30 MHz , offering substantial improvement in processing speed over other available technology. Throughputs in excess of 30 MHz are achieved using multiple devices.

The DF data sheet explains how multiple DFs can be easily cascaded to achieve long filters with 8 bit data and coefficients. This note presents extensions of the basic cascaded configuration for:

- Designing Extended Length Filters Using a Single Device (the Number of Taps Exceeds the Number of Cells).
- Implementing Higher Precision (Greater Than 8 or 9 Bits) Full Speed Designs Using Multiple Devices.
- Implementing Higher Precision Designs Using a Single Device.

It is assumed that the reader has a basic knowledge of filter design and some digital hardware experience. Readers who require more detailed information on the electrical characteristics of the DF family devices should refer to the Harris DF engineering data sheets. Harris also provides a comprehensive set of hardware and software development tools.

## The Finite Impulse Response Filter

The finite impulse response (FIR) filter is simply a finitelength sum-of-products digital filter. Each output sample is a weighted sum of the new input value and the L-1 previous
inputs, where $L$ is the order of the filter. With the tapped delay line architecture (Figure 1) the filter coefficients remain fixed while the input data shifts from cell to cell on each clock cycle.

The DF's architecture (Figure 2) is different from the traditional tapped delay line filter. In the DF the filter coefficients shift from cell to cell with each clock cycle. As each new data sample becomes available it is distributed to all of the cells at the same time. In addition, every DF cell contains its own multiplier and accumulator. This allows each cell to maintain an independent sum-of-products in its accumulator. A new output value becomes available on each clock cycle by properly sequencing the filter coefficients through the cells.


FIGURE 1. DIRECT FORM REPRESENTATION OF FIR FILTER


FIGURE 2. DF CELL DIAGRAM

Each cell's accumulator is cleared after its contents are output. This allows accumulation of the next sum-of-products to begin. Note that the filter coefficients enter from the left, shifting one cell to the right with each clock cycle.

A single device may be used to implement filters with a large number of coefficients. In this case the number of filter taps will exceed the number of DF cells. This requires manipulating the input data and filter coefficient sequences, maintaining the proper sum-of-products in each cell's accumulator. This implementation is described in greater detail in the following section.

## Eight Tap Filter With a Four Cell Device

A simple example is the best way to demonstrate how data and coefficients are properly sequenced. Table 1 illustrates the situation when an eight tap filter is computed in a single 4 cell HSP43481. The table lists information in six columns. The first column shows the initial 21 clock cycles, which is enough to evaluate the example. The next four columns represent the actions taking place in each of the four DF cells as a function of the clock. The final column shows the output results, also a function of the clock.
Within the filter cell are internal pipeline delays. The result is a startup delay of three CLKs before the data and coefficients present at the input of the DF are processed and stored in the accumulator of the first cell. This delay is not
relevant to the sequential operation of the DF and will be ignored in subsequent discussions (also ignored in Table 1).

The basic computational sequence is shown below:
CLK 0 - Initial data point $X_{0}$ is made available to all four cells. At the same time coefficient $C_{7}$ enters Cell 0.

- The First Product $\left(C_{7} \times X_{0}\right)$ is Computed and Stored in Accumulator of Cell 0 .
CLK $1-X_{1}$ is made available to all four cells. At the same time coefficient $C_{6}$ enters Cell 0 , shifting $C_{7}$ to Cell 1.
- The Accumulator of Cell 0 is Updated With the Additional Term $\mathrm{C}_{6} \times \mathrm{X}_{1}$.
- The Product $C_{7} \times X_{1}$ is Computed and Stored in Accumulator of Cell 1.

CLK $2-X_{2}$ is made available to all four cells. At the same time coefficient $\mathrm{C}_{5}$ enters Cell 0 , shifting $\mathrm{C}_{7}$ to Cell 2 and $\mathrm{C}_{6}$ to Cell 1.

- The Accumulator of Cell 0 is Updated With the Additional Term $\mathrm{C}_{5} \times \mathrm{X}_{2}$.
- The Accumulator of Cell 1 is Updated With the Additional Term $C_{6} \times X_{2}$.
- The Product $C_{7} \times X_{2}$ is Computed and Stored in Accumulator of Cell 2.


## $\stackrel{\bullet}{\bullet}$

etc.

TABLE 1. HSP434818 TAP FIR FILTER SEQUENCE USING SINGLE 4 CELL DEVICE


| CLK | CELL 0 | CELL 1 | CELL 2 | CELL 3 | SUM/CLR |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | $\mathrm{C}_{7} \times \mathrm{X}_{0}$ | 0 | 0 | 0 | - |
| 1 | $+\mathrm{C}_{6} \times \mathrm{X}_{1}$ | $C_{7} \times{ }_{1}$ | 0 | 0 | - |
| 2 | $+\mathrm{C}_{5} \times \mathrm{X}_{2}$ | $+\mathrm{C}_{6} \times \mathrm{X}_{2}$ | $\mathrm{C}_{7} \times \mathrm{X}_{2}$ | 0 | - |
| 3 | $+\mathrm{C}_{4} \times \mathrm{X}_{3}$ | $+\mathrm{C}_{5} \times{ }^{\text {P }}$ | $+\mathrm{C}_{6} \times \mathrm{X}_{3}$ | $\mathrm{C}_{7} \times \mathrm{X}_{3}$ | - |
| 4 | $+C_{3} \times X_{4}$ | $+C_{4} \times{ }^{4}$ | $+\mathrm{C}_{5} \times \mathrm{X}_{4}$ | $+\mathrm{C}_{6} \times \mathrm{X}_{4}$ | - |
| 5 | $+C_{2} \times{ }_{5}$ | $+C_{3} \times X_{5}$ | $+C_{4} \times{ }^{\prime}$ | $+C_{5} \times{ }^{\prime}$ | - |
| 6 | $+C_{1} \times \mathrm{X}_{6}$ | $+\mathrm{C}_{2} \times \mathrm{X}_{6}$ | $+\mathrm{c}_{3} \times \mathrm{X}_{6}$ | $+\mathrm{C}_{4} \times \mathrm{X}_{6}$ | - |
| 7 | $+C_{0} \times x_{7}$ | $+C_{1} \times{ }_{7}$ | $+\mathrm{C}_{2} \times \mathrm{X}_{7}$ | $+c_{3} \times{ }^{4}$ | Cell $0\left(Y_{7}\right)$ |
| 8 | 0 | $+C_{0} \times{ }_{8}$ | $+\mathrm{C}_{1} \times{ }_{8}$ | $+\mathrm{C}_{2} \times \mathrm{X}_{8}$ | Cell $1\left(Y_{8}\right)$ |
| 9 | 0 | 0 | $+\mathrm{Co}_{0} \times \mathrm{X}_{9}$ | $+C_{1} \times \times{ }_{9}$ | Cell $2\left(Y_{9}\right)$ |
| 10 | 0 | 0 | 0 | $+C_{0} \times{ }_{10}$ | Cell $3\left(Y_{10}\right)$ |
| 11 | $\mathrm{C}_{7} \times \mathrm{X}_{4}$ | 0 | 0 | 0 | - |
| 12 | $+C_{6} \times x_{5}$ | $\mathrm{C}_{7} \times \mathrm{X}_{5}$ | 0 | 0 | - |
| 13 | $+C_{5} \times \mathrm{X}_{6}$ | $+\mathrm{C}_{6} \times \mathrm{X}_{6}$ | $\mathrm{C}_{7} \times \mathrm{X}_{6}$ | 0 | - |
| 14 | $+C_{4} \times x_{7}$ | $+C_{5} \times{ }^{4}$ | $+C_{6} \times{ }^{4}$ | $\mathrm{C}_{7} \times \mathrm{X}_{7}$ | - |
| 15 | $+C_{3} \times{ }_{8}$ | $+\mathrm{C}_{4} \times \mathrm{X}_{8}$ | $+C_{5} \times{ }^{8}$ | $+\mathrm{C}_{6} \times \mathrm{X}_{8}$ | - |
| 16 | $+\mathrm{C}_{2} \times \mathrm{X}_{9}$ | $+\mathrm{C}_{3} \times \mathrm{X}_{9}$ | $+C_{4} \times{ }^{1}$ | $+\mathrm{C}_{5} \times \mathrm{X}_{9}$ | - |
| 17 | $+\mathrm{C}_{1} \times \mathrm{X}_{10}$ | $+\mathrm{C}_{2} \times \mathrm{X}_{10}$ | $+c_{3} \times{ }_{10}$ | $+C_{4} \times{ }^{10}$ | - |
| 18 | $+C_{0} \times{ }^{11}$ | $+\mathrm{C}_{1} \times \mathrm{X}_{11}$ | $+\mathrm{C}_{2} \times \mathrm{X}_{11}$ | $+\mathrm{C}_{3} \times \mathrm{X}_{11}$ | Cell $0\left(Y_{11}\right)$ |
| 19 | 0 | $+c_{0} \times{ }^{12}$ | $+\mathrm{C}_{1} \times \mathrm{X}_{12}$ | $+\mathrm{C}_{2} \times \mathrm{X}_{12}$ | Cell $1\left(Y_{12}\right)$ |
| 20 | 0 | 0 | $+\mathrm{C}_{0} \times \mathrm{X}_{13}$ | $+\mathrm{C}_{1} \times \mathrm{X}_{13}$ | Cell 2 ( $Y_{13}$ ) |
| 21 | 0 | 0 | 0 | $+\mathrm{C}_{0} \times \mathrm{X}_{14}$ | Cell 3 ( $Y_{14}$ ) |

This process continues until eight taps have been computed and accumulated in each cell. This happens first in Cell 0, followed one CLK later by Cell 1, two CLKs later by Cell 2, and three CLKs later by Cell 3. Output points become available after each cell accumulates the sum of eight taps in the order given above.

After Cell 3's output becomes available, we are ready to begin work on the next four output points. We can cycle the eight filter coefficients in the same fashion as before but the input data is out of sequence. Before computing the fifth output point the DF requires $X_{4}$ to be available at the data input. Since $X_{4}$ passed by seven CLKs ago (during CLK 4) some method of storing the previous seven data points is necessary.

In order to access the previous seven data values they must have been originally stored in some form of sequential memory. FIFOs work very well and will be discussed in the next section. Starting with CLK 11 the taps once more begin to accumulate in each of the four cells.

The result of re-accessing data after every four output points is to lower the effective throughput. The output rate drops about fifty percent to a rate of four output points for every eleven CLKs.

## L Tap Filter With an N Cell Device Where L>N

The example above leads to the more general case of implementing an $L$ tap filter with an $N$ cell device ( $L>N$ ). When an $L$ tap filter is implemented using an $N$ cell $D F$ (where $L>N$ ), the DF computes a block of $N$ filter output samples at a time. Between these output blocks there are L-1 CLK cycles during which no valid output points are available. Therefore, generating a block of $N$ output points requires $L+N-1$ CLKs. During these $L+N-1$ CLKs there are $L+N-1$ new input samples being clocked into the DIN (Data IN) port.

It can be seen from Table 1 that N outputs are read out of the DF during the last $N$ CLKs of each L+N-1 CLK sequence. After inputting the first $L$ data samples $N-1$ CLKs are required to flush the coefficients from the cells. The final $\mathrm{L}-1$ of the previous $\mathrm{L}+\mathrm{N}-1$ input samples must be re-submitted at the input port. After the outputs are read out an additional $L+N-1$ samples are fed in and the process repeats itself until no more data is available.

In this paper, throughput is defined as the average rate at which outputs are computed by the DF. When the number of taps exceeds the number of filter cells, the necessity to re-access the data stream determines the maximum throughput. The generalized performance of an $L$ tap, $8 \times 8$ FIR filter is shown below. Let:
$\mathrm{L}=$ Number of taps
$N=$ Number of filter cells in DF
$R=$ Maximum clock rate of $\operatorname{DF}(20,25.6$, or 30 MHz )
$F_{\mathbf{S}}=$ Desired throughput $(\mathrm{MHz})$ where $R>F_{S}$

If $L, N$, and $R$ are known then:
$F_{S}=N \times R /(L+N-1)$
If $L, R$, and $F_{S}$ are known then:
$N=F_{s}(L-1) /\left(R-F_{s}\right)$
Since there are either four (HSP43481) or eight (HSP43881) cells in each DF, the required number of DFs can be computed as:
\# of 4 cell DFs $=\mathrm{N} / 4$ (round up to next integer value)
\# of 8 cell DFs $=$ N/8 (round up to next integer value)
An example design with $L=128$ taps, $F_{S}=5 \mathrm{MHz}$, and $\mathrm{R}=20 \mathrm{MHz}$ would yield:
$N=5 \times 127 / 15=43$ cells
\# of 4 cell DFs $=43 / 4=11$
$\#$ of 8 cell DFs $=43 / 8=6$
Optimum arrangement $=40 / 8+3 / 4=$ Five 8 cell and one 4 cell DFs.
The sequencing of the input data can be realized in various ways, with the simplest design using FIFOs. Figure 3 shows the block diagram of a design using an eight cell DF. The input data buffered in two FIFOs (each must have threestate outputs).

An 8 bit counter is configured to count modulo $L+N-1$. To initialize the system, the first $L-1$ data samples are passed through FIFO \#1 and written into FIFO \#2. While this occurs N more samples are clocked into FIFO \#1. Following that a repetitive steady state sequence begins as shown below:

1. Clock the first L-1 samples from FIFO \#2 into the DF.
2. Clock $N$ samples from FIFO \#1 into the DF.
3. Clock the last L-1 samples of the sequence in steps 1 and 2 back into FIFO \#2.
4. Clock the next N samples into FIFO \#1 concurrently with steps 1-3.
This sequence of steps 1 through 4 can be repeated ad infinitum.

The output data is available in blocks of $N$ points separated by L-1 CLK cycles. FIFO \#3 acts as a rate buffer for the output and is optional. The coefficient memory contains the $L$ coefficients followed by the necessary $\mathrm{N}-1$ zeros.
A design example using the above technique might include a 57 tap filter with a sample rate of 2.5 MHz . This can be done with a single 8 cell device operating at 20 MHz .

## Higher Precision Filters and Correlators

Several digital filtering applications require wider wordwidth calculations to maintain precision. The DFs are designed to be flexible in creating filters with input precision levels of 8 , $16,24,32$ bits or greater.
The first step is to restructure the data and/or coefficients into 8 bit quantities which can be processed by the DF.


FIGURE 3. BLOCK DIAGRAM OF AN 8 CELL DF CONFIGURED TO IMPLEMENT EXTENDED FILTER LENGTHS (UP TO 249 TAPS)

These quantities are used to form the partial products of the larger multiplication involving the full precision data and coefficients. An example of segmenting the partial products of a $16 \times 8$ multiplication ( 16 bit coefficients and 8 bit data) would be:

$$
\begin{array}{ll}
C(16 \text { bit })=C_{H} \times 2^{8}+C_{L} \times 2^{0} & H
\end{array} \begin{array}{ll}
H \text { High Order Byte } \\
X(8 \text { bit })=X \times 2^{0} & L
\end{array}
$$

Consequently,

$$
\begin{aligned}
C \times X & =\left(C_{H} \times 2^{8}+C_{L} \times 2^{0}\right) \times \times 2^{0} \\
& =C_{H} \times \times 2^{8}+C_{L} \times 2^{0}
\end{aligned}
$$

The process of convolution or correlation requires repeated multiply and accumulate operations. The resulting partial output word widths are a function of the number of MAC operations and of the coefficient scaling. Although each partial product is only 16 bits wide, the sum of the partial products in the output stage is allowed to accumulate up to a maximum width of 26 bits.

Care must be taken when combining the upper and lower partial sums-of-products into each complete output result. Figure 5 illustrates how the upper and lower sums of partial products for each output point must be re-combined. Sign extension must be used if more than 26 bits are required from the output stage representing the least significant sum of partial products.

Two separate techniques can be used in determining higher precision results:

1. Use separate DFs, combining the two partial products using external adders.

- Throughput equals the clock rate of the DF.

2. Accumulate the two partial products in separate cells of a single DF.

- The SHADD (SHift and ADD) feature of the output adder allows the data to be properly aligned and combined.
- Throughput is determined by the number of taps, partial products, and DF cells, as well as the clock rate of the DF.

The equations describing the filtering operation are the same for either technique and can be given as:

$$
y(n)=\sum_{i=0}^{N-1} C(i) X(n-i)
$$

However: $\left(\mathrm{C}_{\mathrm{H}} \times \mathbf{2}^{8}+\mathrm{C}_{\mathrm{L}}\right) \mathrm{X}=\mathrm{C}_{\mathrm{H}} \times \times 2^{8}+\mathrm{C}_{\mathrm{L}} \mathrm{X}$
Therefore: $y(n)=\sum_{i=0}^{N-1} C_{H}(i) X(n-i) \times 2^{8}+\sum_{i=0}^{N-1} C_{L}(i) X(n-1)$
Assuming the coefficients are represented as two's complement numbers, the least significant byte has to be treated as a positive (unsigned) number. The TCCI input of the DF is used to take care of this.

## Word-Size Extension at Full Speed

Full performance filters with extended precision data and/or coefficients are easily designed. This is achieved by computing the partial products in separate DFs and combining their results with external adders. When external adders are used the system performance is limited only by the throughput of the DF itself.

The filter equations listed directly above can be expanded into their partial products and grouped for processing. An
expansion of the first four output points resulting from the convolution of 16 bit coefficient and 8 bit data is shown in Table 2.

In this case, for a 4 tap filter, each device accumulates four partial products at once, one in each cell. The output adder combines these partial products into the proper result. The sequence table (Table 2) shows the results of the multiply accumulate operations for one device (DFO).
Figure 4 is a block diagram that directly implements the grouping given above. DFO is generating the $C_{L} X$ partial products while DF1 is generating the partial products for $\mathrm{CH}_{\mathrm{H}} \mathrm{X}$. The two $8 \times 8$ partial products are generated in separate DFs and combined with an external adder. Notice that the lower and upper coefficients bytes are separated and used to supply different DFs. Using this design the throughput is limited only by the DF (up to 30 MHz ).
The adder stage of Figure 4 merits further discussion. Each 4 cell DF has 26 output lines (SUMO-25). Therefore, if all the available bits were preserved we would have a 34 bit sum as shown in Figure 5. However, many designs require only 16 output bits. Which 16 bits are selected depends on the coefficient scaling and the input signal level.

TABLE 2. HSP43481 4 TAP SINGLE PARTIAL PRODUCT FIR FILTER

$\bullet$
etc.

| CLK | CELLO | CELL 1 | CELL 2 | CELL 3 | OUTPUT |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | $\mathrm{C}_{\mathrm{L} 3} \times \mathrm{X}_{\text {LO }}$ | 0 | 0 | 0 |  |
| 1 | $+\mathrm{C}_{\mathrm{L} 2} \times \mathrm{X}_{\mathrm{L} 1}$ | $\mathrm{C}_{\mathrm{L} 3} \times \mathrm{X}_{\mathrm{L} 1}$ | 0 | 0 |  |
| 2 | $+\mathrm{C}_{\mathrm{L} 1} \times \mathrm{X}_{\mathrm{L} 2}$ | $+\mathrm{C}_{\mathrm{L} 2} \times \mathrm{X}_{\mathrm{L} 2}$ | $\mathrm{C}_{\mathrm{L} 3} \times \mathrm{X}_{\text {L3 }}$ | 0 |  |
| 3 | $+\mathrm{C}_{\text {LO }} \times \mathrm{X}_{\text {L3 }}$ | $+\mathrm{C}_{\mathrm{L} 1} \times \mathrm{X}_{\text {L3 }}$ | $+\mathrm{C}_{\mathrm{L} 2} \times \mathrm{X}_{\text {L }}$ | $\mathrm{C}_{\mathrm{L} 3} \times \mathrm{X}_{\mathrm{L} 3}$ | Cell $0\left(Y_{L} 3\right.$ ) |
| 4 | $\mathrm{C}_{\text {L }} \times \mathrm{X}_{\mathrm{L} 4}$ | +CLO ${ }_{\text {C }} \mathrm{K}_{\text {L } 4}$ | $+C_{L 1} \times{ }_{\text {L }}$ | $+\mathrm{C}_{\mathrm{L} 2} \times \mathrm{X}_{\mathrm{L} 4}$ | Cell 0 ( $\mathrm{Y}_{\mathrm{L}}$ ) |
| 5 | $+\mathrm{C}_{\mathrm{L} 2} \times \mathrm{X}_{\text {L5 }}$ | $C_{L 3} \times X_{L 5}$ | $+C_{L 0} \times{ }_{\text {L }}$ | $+C_{L 1} \times X_{L 5}$ | Cell $0\left(Y_{L} 5\right)$ |
| 6 | $+C_{L 1} \times X_{L 6}$ | $+\mathrm{C}_{\mathrm{L} 2} \times \mathrm{X}_{\text {L6 }}$ | $C_{L 3} \times X_{\text {L } 6}$ | $+\mathrm{CLO}_{\text {L }} \times \mathrm{X}_{\text {L6 }}$ | Cell $0\left(Y_{L} 6\right)$ |
| 7 | $+\mathrm{C}_{\mathrm{LO}} \times \mathrm{X}_{\mathrm{L7}}$ | $+C_{L 1} \times X_{L 7}$ | $+\mathrm{C}_{\mathrm{L} 2} \times \mathrm{X}_{\mathrm{L} 7}$ | $\mathrm{C}_{\mathrm{L} 3} \times \mathrm{X}_{\mathrm{L} 7}$ | Cell $0\left(Y_{L} 7\right)$ |



FIGURE 4. BLOCK DIAGRAM OF A $30 \mathrm{MHz}, 4$ TAP, $16 \times 8$ FIR FILTER


FIGURE 5. IDEAL OUTPUT STAGE ADDER

The results for the $16 \times 8$ example can be extended to the general case of more than four taps. Let:
$L=$ Number of taps
$N=$ Total number of filter cells required
$R=$ Maximum clock rate of $\operatorname{DF}(20,25.6$, or 30 MHz )
$\mathrm{F}_{\mathrm{S}}=$ Desired throughput ( MHz )
For a full speed ( $F_{S}=R$ ) $16 \times 8$ design: $N=2 L$
There are either four (HSP43481) or eight (HSP43881) cells in each DF. Therefore, the number of DFs can be computed as: \# of 4 cell DFs $=2 \times[L / 4$ (rounded up to next integer value)] \# of 8 cell DFs $=2 \times[L / 8$ (rounded up to next integer value)]
An example design with $L=15$ taps and $F_{S}=R=25 \mathrm{MHz}$ would yield:
\# of 4 cell DFs $=2 \times[15 / 4]=8$
\# of 8 cell DFs $=2 \times[15 / 8]=4$

## Word-Size Extension Using One Device

The second technique for extending the word width accumulates the partial products in separate cells of a

$$
\begin{aligned}
& y(0)= C_{H}(0) X(0) \times 2^{8}+C_{L}(0) X(0) \\
&+C_{H}(1) X(1) \times 2^{8}+C_{L}(1) X(1) \\
& C_{H}(2) X(2) \times 2^{8}+C_{L}(2) X(2) \\
&+ C_{H}(3) X(3) \times 2^{8}+ \\
& C_{L}(3) X(3)
\end{aligned}
$$

$$
\begin{aligned}
y(2) & =C_{H}(0) X(2) \times 2^{8}+C_{L}(0) X(2) \\
& +C_{H}(1) X(3) \times 2^{8}+C_{L}(1) X(3) \\
& +C_{H}(2) X(4) \times 2^{8}+C_{L}(2) X(4) \\
& +C_{H}(3) X(5) \times 2^{8}+C_{L}(3) X(5) \\
& +\underset{\text { Cell } 1}{ } \text { 0 }
\end{aligned}
$$

single device. An expansion of the first four output points resulting from the convolution of 16 bit coefficient and 8 bit data is shown below.

The groupings are the same as in the earlier case using multiple DFs. However, in this case individual cells within one DF are responsible for generating the partial products. This method of processing eliminates the need for an external adder in exchange for lower throughput.
The sequence table (Table 3) shows the results of the multiply accumulate operation for the separate cells of a 4 tap $16 \times 8$ FIR filter. Cells 1 and 3 accumulate the partial products $\mathrm{C}_{\mathrm{H}} \mathrm{X}$. Cells 0 and 2 accumulate the partial products $C_{L} X$.
After computing and outputting the first result Cell 0 is ready to accumulate the next partial products. At this point (CLK 11) Cell 0 needs to re-access $X_{2}$, which was last available during CLK 5. In order to accomplish this a temporary storage, sequential memory (such as a FIFO) is necessary. The design of Figure 6 shows such a FIFO based design.

$$
\begin{aligned}
y(1) & =C_{H}(0) X(1) \times 2^{8}+C_{L}(0) X(1) \\
& +C_{H}(1) X(2) \times 2^{8}+C_{L}(1) X(2) \\
& +C_{H}(2) X(3) \times 2^{8}+C_{L}(2) X(3) \\
& +C_{H}(3) X(4) \times 2^{8}+C_{L}(3) X(4) \\
& \text { Cell 3 2 }
\end{aligned}
$$

$$
\begin{aligned}
& y(3)=C_{H}(0) X(3) \times 2^{8}+C_{L}(0) X(3) \\
&+C_{H}(1) X(4) \times 2^{8}+C_{L}(1) X(4) \\
&+C_{H}(2) X(5) \times 2^{8}+C_{L}(2) X(5) \\
&+C_{H}(3) X(6) \times 2^{8}+C_{L}(3) X(6) \\
& \text { Cell 3 2 }
\end{aligned}
$$

TABLE 3. HSP43481 4 TAP, $16 \times 8$ FIR FILTER SEQUENCE
INPUT DATA
COEFFICIENT
SEQUENCE $\mathrm{C}_{\mathrm{L} 3}, \mathrm{C}_{\mathrm{H} 3}, 0,0, \mathrm{C}_{\mathrm{LO}}, \mathrm{C}_{\mathrm{HO}}, \mathrm{C}_{\mathrm{L} 1}, \mathrm{C}_{\mathrm{H} 1}, \mathrm{C}_{\mathrm{L} 2}, \mathrm{C}_{\mathrm{H} 2}, \mathrm{C}_{\mathrm{L} 3}, \mathrm{C}_{\mathrm{H} 3} \longrightarrow \mathrm{DF} \longrightarrow \mathrm{Y}(5) \ldots \mathrm{Y}(4) \ldots \mathrm{Y}(3)$

| CLK | CELLO | CELL 1 | CELL 2 | CELL 3 | OUTPUT |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | $\mathrm{C}_{\mathrm{H} 3} \times 0$ | - | - | - | - |
| 1 | $\mathrm{C}_{\mathrm{L} 3} \times \mathrm{X}_{0}$ | $\mathrm{CH}_{3} \times \mathrm{X}_{0}$ | - | - | - |
| 2 | $\mathrm{C}_{\mathrm{H} 2} \times \mathrm{O}$ | $\mathrm{C}_{\mathrm{L} 3} \times 0$ | $\mathrm{CH}_{\mathrm{H} 3} \times 0$ | - | - |
| 3 | $+\mathrm{C}_{\mathrm{L} 2} \times \mathrm{X}_{1}$ | $+\mathrm{C}_{\mathrm{H} 2} \times \mathrm{X}_{1}$ | $\mathrm{CL} \times 1 \times{ }_{1}$ | $\mathrm{CH}_{3} \times \mathrm{X}_{1}$ | - |
| 4 | $\mathrm{C}_{\mathrm{H} 1} \times 0$ | $\mathrm{C}_{\mathrm{L} 2} \times 0$ | $\mathrm{C}_{\mathrm{H} 2} \times 0$ | $\mathrm{C}_{\mathrm{L} 3} \times 0$ | - |
| 5 | $+\mathrm{C}_{\mathrm{L} 1} \times \mathrm{X}_{2}$ | $+\mathrm{C}_{\mathrm{H} 1} \times \mathrm{X}_{2}$ | $+\mathrm{C}_{\mathrm{L} 2} \times \mathrm{X}_{2}$ | $+^{+} \mathrm{CH}_{2} \times \mathrm{X}_{2}$ | - |
| 6 | $\mathrm{CHO}^{\text {O }}$ | $\mathrm{C}_{\mathrm{L} 1} \times 0$ | $\mathrm{C}_{\mathrm{H} 1} \times 0$ | $\mathrm{C}_{\mathrm{L} 2} \times 0$ | - |
| 7 | $+\mathrm{CLO}_{\text {O }} \times \mathrm{X}_{3}$ | $+\mathrm{CHO}_{\mathrm{HO}} \times 3$ | $+\mathrm{C}_{\mathrm{L} 1} \times \mathrm{X}_{3}$ | $+\mathrm{C}_{\mathrm{H} 1} \times \mathrm{X}_{3}$ | $Y_{L}(3)$ |
| 8 | $0 \times 0$ | $\mathrm{CLO}_{\mathrm{LO}} \mathrm{O}$ | $\mathrm{C}_{\mathrm{HO}} \times$ | $\mathrm{C}_{\mathrm{L} 1} \times 0$ | - |
| 9 | $0 \times 1$ | $0 \times 1$ | $+\mathrm{C}_{\text {LO }} \times \mathrm{X}_{4}$ | $+\mathrm{CHO} \times \mathrm{X}_{4}$ | $\mathrm{Y}_{\mathrm{H}}(3)$ |
| 10 | $\mathrm{CH}_{3} \times 0$ | $0 \times 0$ | $0 \times 0$ | $\mathrm{C}_{\mathrm{LO}} \times 0$ | - |
| 11 | $\mathrm{C}_{\mathrm{L} 3} \times \mathrm{X}_{2}$ | $\mathrm{C}_{\mathrm{H} 3} \times \mathrm{X}_{2}$ | $0 \times 12$ | $0 \times 12$ | $Y_{L}(4)$ |
| 12 | $\mathrm{C}_{\mathrm{H} 2} \times \mathrm{O}$ | $\mathrm{C}_{\mathrm{L} 3} \times 0$ | $\mathrm{CH}_{\mathrm{H} 3} \times 0$ | $0 \times 0$ | - |
| 13 | $+\mathrm{C}_{\mathrm{L} 2} \times \mathrm{X}_{3}$ | $+\mathrm{C}_{\mathrm{H} 2} \times \mathrm{X}_{3}$ | $\mathrm{C}_{\mathrm{L} 3} \times \mathrm{X}_{3}$ | $\mathrm{CH}_{3} \times \mathrm{X}_{3}$ | $Y_{H}(4)$ |
| 14 | $\mathrm{C}_{\mathrm{H} 1} \times 0$ | $\mathrm{C}_{\mathrm{L} 2} \times 0$ | $\mathrm{C}_{\mathrm{H} 2} \times 0$ | $\mathrm{C}_{\mathrm{L} 3} \times 0$ | - . |
| 15 | $+\mathrm{C}_{\mathrm{L} 1} \times \mathrm{X}_{4}$ | $+\mathrm{C}_{\mathrm{H} 1} \times \mathrm{X}_{4}$ | $+\mathrm{C}_{\mathrm{L} 2} \times \mathrm{X}_{4}$ | $+\mathrm{C}_{\mathrm{H} 2} \times \mathrm{X}_{4}$ | - |
| 16 | $\mathrm{C}_{\mathrm{HO}} \times 0$ | $\mathrm{C}_{\mathrm{L} 1} \times 0$ | $\mathrm{C}_{\mathrm{H} 1} \times 0$ | $\mathrm{C}_{\mathrm{L} 2} \times 0$ | - |
| 17. | $+\mathrm{CLO}_{\text {L }} \times \mathrm{X}_{5}$ | $+\mathrm{CHO} \times \mathrm{X}_{5}$ | $+\mathrm{C}_{\mathrm{L} 1} \times \mathrm{X}_{5}$ | $+\mathrm{C}_{\mathrm{H} 1} \times \mathrm{X}_{5}$ | $Y_{L}(5)$ |
| 18 | $0 \times 0$ | $\mathrm{C}_{\mathrm{LO}} \times 0$ | $\mathrm{C}_{\mathrm{HO}} \times \mathrm{O}$ | $\mathrm{C}_{\mathrm{L} 1} \times 0$ | - |
| 19 | $0 \times 16$ | $0 \times{ }_{6}$ | $+\mathrm{CLO}_{\text {LO }} \times 1$ | $+\mathrm{CHO} \times \mathrm{X}_{6}$ | $Y_{H}(5)$ |
| 20 | $\mathrm{C}_{\mathrm{H} 3} \times 0$ | $0 \times 0$ | $0 \times 0$ | $\mathrm{C}_{\mathrm{LO}} \times 0$ | - |
| 21 | $\mathrm{C}_{\mathrm{L} 3} \times \mathrm{X}_{4}$ | $\mathrm{C}_{\mathrm{H} 3} \times \mathrm{X}_{4}$ | $0 \times{ }_{4}$ | $0 \times{ }^{4}$ | $Y_{L}(6)$ |
| 22 | $\mathrm{C}_{\mathrm{H} 2} \times 0$ | $\mathrm{C}_{\mathrm{L} 3} \times 0$ | $\mathrm{C}_{\mathrm{H} 3} \times 0$ | $0 \times 0$ | - |
| 23 | $+\mathrm{C}_{\mathrm{L} 2} \times \mathrm{X}_{5}$ | $+\mathrm{CH}_{2} \times \mathrm{X}_{5}$ | $\mathrm{C}_{\mathrm{L} 3} \times \mathrm{X}_{5}$ | $\mathrm{CH}_{3} \times \mathrm{X}_{5}$ | $Y_{H}(6)$ |
| 24 | $\mathrm{C}_{\mathrm{H} 1 \times 0}$ | $\mathrm{C}_{\mathrm{L} 2} \times 0$ | $\mathrm{CH}_{\mathrm{H} 2} \times 0$ | $\mathrm{C}_{\mathrm{L} 3} \times 0$ | - |
| 25 | $+\mathrm{C}_{\mathrm{L} 1} \times \mathrm{X}_{6}$ | $+\mathrm{C}_{\mathrm{H} 1} \times \mathrm{X}_{6}$ | $+\mathrm{C}_{\mathrm{L} 2} \times \mathrm{X}_{6}$ | $+\mathrm{CH}_{\mathrm{H} 2} \times \mathrm{X}_{6}$ | - |



FIGURE 6. $16 \times 84$ TAP FIR FILTER BLOCK DIAGRAM

In order to interlace the necessary zeros between data samples we must toggle the DIENB control line. This line is driven low when passing a valid data sample to the X register and set high when loading the $X$ register with zero. The sequencing of the input data through the FIFOs is similar to the example given in Figure 3.
The output stage (Figure 7) plays a key role in determining the final results. In the output stage there are several control signals. The most important signals controlling the output stage are SHADD (SHift and ADD), ADRO-1 (cell AdDRess), SENBL (Sum0-15 ENaBled), and SENBH (Sum16-25 ENaBled). $\overline{\text { SENBL }}$ and $\overline{\text { SENBH }}$ are always asserted in this example, enabling the three-state output buffer and allowing the external register to clock in data at the proper time. SHADD and ADRO-1 are used to control the flow of data through the output stage.
The contents of a selected cell (ADRO-1) are routed to two separate locations within the output stage; the 26 bit adder and the output mux. From the output mux the 26 bit cell
contents are available to the outside world as either the 16 LSBs ( $\overline{\text { SENBL }}), 10 \mathrm{MSBs}$ ( $\overline{\mathrm{SENBH}}$ ), or all 26 bits (SENBL $+\overline{\text { SENBH }}$ ).
The 26 bit adder feeding the output buffer has two possible inputs. The first input represents the contents of the selected cell. The zero mux determines whether the other input to the adder is zero or the 18 MSBs of the output buffer. A high on the SHADD input selects the 18 MSBs of the output buffer and a low on the SHADD input selects zero. The results from the adder are immediately stored in the output buffer.

Data reaches the three-state buffer by one of two separate paths. The first path routes the data directly from the cell result multiplexer through the output multiplexer and onto the output bus. The second path is from the cell result multiplexer, through the adder, and finally onto the output bus. Both of these routes will be used in order to create the final result from the partial products.


FIGURE 7. DF OUTPUT STAGE

After the partial products are made available to the output bus they are stored in temporary registers. This allows the two sections of the final result to be combined properly. Following this the full result may be stored directly into some form of memory. Figure 6 shows a block diagram illustrating the complete concept.

The following summary describes the sequence of events listed in Table 3 (also refer to Figures 6 and 7).

CLK 0-5

- Each Cell Is Accumulating Partial Product Data
- SHADD Not Asserted

CLK 6

- Cell 0 Selected (ADRO-1 = 0)
- Erase Accumulator of Cell 0 ( $\overline{\text { ERASE }}=0$ )
- SHADD Not Asserted

CLK 7

- Cell 0 Contents Added to Zero and Available at Input to Output Buffer
- Cell 0 Contents Available at SUMO-15
- Cell 1 Selected (ADRO-1 = 1)
- Erase Accumulator of Cell 1 ( $\overline{\text { ERASE }}=0$ )
- SHADD Not Asserted

CLK 8

- External 8 Bit Register Clock Asserted. Lower 8 Bits of SUM0-15 (Least Significant Byte of $\mathrm{Y}(3)$ ) Entered Into External 8 Bit Register
- Cell 0 Contents Entered Into Output Buffer
- Cell 1 Contents Added to Zero and Available at Input to Output Buffer
- SHADD Asserted


## CLK 9

- Shift Cell 0 Contents Down 8 Bits and Add to Contents of Cell 1 (Output Buffer). This 16 Bit Value Becomes Available at SUMO-15
- SHADD Not Asserted

CLK 10

- External 16 Bit Register Clock Asserted. All 16 Bits of SUMO-15 (Most Significant Word of Y(3)) Entered Into External 16 Bit Register
- Cell 2 Selected (ADRO-1 =2)
- Erase Accumulator of Cell 2 ( $\overline{\text { ERASE }}=0$ )
- SHADD Not Asserted

CLK 11

- Cell 2 Contents Added to Zero and Available at Input to Output Buffer
- Cell 2 Contents Available at SUMO-15
- Cell 3 Selected (ADRO-1 = 3)
- Erase Accumulator of Cell $3(\overline{\text { ERASE }}=0)$
- Write Y(3) Into Output FIFO (Optional)
- SHADD Not Asserted


## CLK 12

- External 8 Bit Register Clock Asserted. Lower 8 Bits of SUMO-15 (Least Significant Byte of Y(4)) Entered Into External 8 Bit Register
- Cell 2 Contents Entered Into Output Buffer
- Cell 3 Contents Added to Zero and Available at Input to Output Buffer
- SHADD Asserted

CLK 13

- Shift Cell 2 Contents Down 8 Bits and Add to Contents of Cell 3 (Output Buffer). This 16 Bit Value Becomes Available at SUMO-15
- SHADD Not Asserted


## CLK 14

- External 16 Bit Register Clock Asserted. All 16 Bits of SUMO-15 (Most Significant Word of Y(4)) Entered Into External 16 Bit Register
- SHADD Not Asserted

This same pattern repeats until the input data is exhausted. Note that the value stored in the External Register must be stored elsewhere before the low byte of the next output value is sequenced.

The performance specifications for the $16 \times 8$ filter are listed below.

```
- 2 Outputs/10 CLKS = 1 Output/5.0 CLKS
    = 200ns/Output (25.6MHz Device)
    = 5MHz Throughput (25.6MHz Device)
```

The results for the $16 \times 8$ design used in this implementation can be extended to the general case. Let:
$\mathrm{L}=$ Number of taps
$\mathrm{F}_{\mathrm{S}}=$ Sample rate $(\mathrm{MHz})$
N2 = Number of 2 cell groups
$R=$ Maximum clock rate of $\operatorname{DF}(20,25.6$, or 30 MHz$)$
( $\mathrm{R}>\mathrm{F}_{\mathrm{S}}$ )
Then: $\quad F_{S}=(N 2 \times R) /(2 L+2(N 2-1))$
$\left.\mathrm{N} 2=2 \mathrm{~F}_{\mathrm{s}}(\mathrm{L}-1) / \mathrm{R}-2 \mathrm{~F}_{\mathrm{s}}\right)$

## Harris Semiconductor



## TIMING RELATIONSHIPS FOR HSP45240

Author: Mike Petrowski

The timing diagram in Figure 1 shows the timing relationship between the various output signals of the HSP45240 when the sequence generator is programmed for One-Shot Mode with Restart (see Sequence Generator Section of Datasheet). In this example, the HSP45240 is configured to generate a sequence consisting of two address blocks. Each block is 6 addresses long, and the end of a block is denoted by the assertion of BLOCKDONE\#. As the final address in the second block is generated, both DONE\# and BLOCKDONE\# are asserted to signal the end of the address sequence. On the next clock, a new address sequence is started (see assertion of ADDVAL\#) because the Sequencer was configured to restart. In this mode the STARTOUT\# signal is asserted prior to the end of the address sequence for the synchronization of multiple HSP45240's.


NOTE: Asserting STARTIN\# after an addressing sequence has been started will cause the sequencer to restart from the beginning of the sequence.
FIGURE 1. SIGNAL RELATIONSHIPS FOR ONE-SHOT MODE WITH RESTART

The timing diagram in Figure 2 shows the timing relationship between the various output signals of the HSP45240 when the sequence generator is programmed for One-Shot Mode without Restart (see Sequence Generator Section of Datasheet). As in the above example, the HSP45240 is configured to generate a sequence consisting of two address blocks. Each block is 6 addresses long, and the end of a block is denoted by the assertion of BLOCKDONE\#. As
the final address in the second block is generated, both DONE\# and BLOCKDONE\# are asserted and addressing is halted.


FIGURE 2. SIGNAL RELATIONSHIPS FOR ONE-SHOT MODE WITHOUT RESTART

The timing diagram in Figure 3 shows the timing relationship between the various output signals of the HSP45240 when the sequence generator is internally started by writing the Sequencer "START" address (see Table 1 of Datasheet). The output signals are shown with respect to the rising edge of WR\# responsible for the internal START. The address generation parameters are as above.


FIGURE 3. SIGNAL RELATIONSHIPS FOR INTERNALLY GENERATED START

## DLYBLK Operation

Address generation can be halted by assertion of DLYBLK prior to the completion of an address block (Figure $4 \& 5$ ). Addressing will resume once DLYBLK is de-asserted. Since there is a pipeline delay between the assertion of DLYBLK at the pin and when it is internally active, DLYBLK must be asserted prior to the end of an address block. The pipeline delay associated with DLYBLK differs for halting address generation in mid-sequence and halting address generation after the final address block of a sequence.

For halting address generation in mid-sequence, DLYBLK must be asserted 3 clocks prior to the end of the addressing block as shown in Figure 4. In this example, DLYBLK is asserted for one clock cycle which delays the generation of the next address block by one clock. If addressing has been halted in mid-sequence, addressing will resume 4 clocks after de-asserting DLYBLK. Note: BLOCKDONE\# will be asserted and OUTO-23 will be held until addressing resumes.


FIGURE 4. SIGNAL RELATIONSHIPS FOR A ONE CYCLE BLOCK DELAY IN MID-SEQUENCE

For halting address generation after the final block of addresses in a sequence, DLYBLK must be asserted 4 clocks prior to the end of the addressing block as shown in Figure 5. In this example, DLYBLK is asserted for one clock cycle which delays the start of a new address sequence by one clock. The part is assumed to be configured for One-Shot Mode with Restart. Addressing will resume 5 clocks after de-asserting DLYBLK. Note: BLOCKDONE\# and DONE\# will be asserted and OUTO-23 will be held until addressing resumes. Also, STARTOUT\# will be asserted one clock after the assertion of DLYBLK.


FIGURE 5. SIGNAL RELATIONSHIPS FOR A ONE CYCLE BLOCK DELAY AFTER FINAL BLOCK IN AN ADDRESSING SEQUENCE

## STARTIN\# Operation

The STARTIN\# pin has two functions: first, it downloads the configuration data in the processor interface into the register bank that controls the operation of the part; second, it starts the address sequence using the updated configuration. When STARTIN\# is deasserted, the part continues on with the new sequence. Note that there are four stages of pipeline delay between the sequence generator and the output of the part; all of the output signals will continue on using the original sequence for those four clock cycles.

After the assertion of STARTIN\#, the first value in the sequence appears on the output after four pipeline delays. The part will remain in this state for the remainder of the time that STARTIN\# is low, and for four clocks after STARTIN\# returns high. This is shown in Figure 6, note that the old sequence ends at clock 3; the first address of the new sequence goes from clock 4 to clock 12; the second address of the new sequence appears on clock 13.

Asserting STARTIN\# in the middle of a sequence demonstrates the sequence restart function as described above. The internal count of the HSP45240 returns to the starting point (the value in the Start Address Register - not the Current Block Start Address Register) on the first rising edge of CLK that STARTIN\# is low. The first address of the sequence is output four clocks after the assertion of STARTIN\#. The Sequencer goes to the second address in the sequence when STARTIN\# goes away; this address appears on the output pins four clocks later. Sequencing continues based on the updated configuration. In Figure 7, the new sequence is started on clock 1 ; the old sequence will continue unaffected until clock 4, and the first address of the new sequence becomes valid on the outputs during clock 5.


FIGURE 6. INPUT, OUTPUT SIGNALS WHEN STARTIN* IS LONGER THAN ONE CLOCK CYCLE.


FIGURE 7. USING STARTIN\# TO RESTART SEQUENCE DURING OPERATION


# Harris Signal Processing 

## CORRELATING ON EXTENDED DATA LENGTHS

Author: Clay Olmstead

Correlations of data sets longer than the maximum length of the HSP45256 are implemented in one of two ways. The first method is to use multiple correlator chips in the manner shown in the HSP45256 data sheet. This will perform a classical correlation on data sets up to 4096 samples of one bit data with no external logic. The limitation on the number of samples is the 16 stage programmable delay register. The advantage of this method is that the user will be guaranteed of finding the data set that best matches the reference no matter where that set lies in the data stream.

The second method involves using external logic to perform a piecewise correlation. The data and reference are each divided into blocks of $N$ samples, and the data is processed block by block. By reloading the reference memory while processing, the correlation can be carried out at the full data rate while using fewer correlators than would be necessary with the first method. This method will work for any length data sets, but the user must have an initial estimate of the offset between the data and the reference. The true correlation peak will only be found if the data and the corresponding reference fall within the same block. If this block is longer than 256 samples, then multiple correlators are used.

A block diagram of a circuit to perform correlation with a 512 sample reference is shown in Figure 1. The reference is divided into two blocks; the first block is loaded into the reference memory prior to data being sent into the part. The correlation of the data with the current block of the reference is calculated with the HSP45256; as each correlation score comes out, it is stored in the HSP9501, which is set for a delay of 256 clocks. The output of the HSP9501 is sent to the cascade input of the HSP45256 such that the correlation score for each sample in the current block is added to the score from the corresponding sample of the previous block. While the first block is being processed, the reference for the second block is being loaded into the shadow registers of the reference memory of the HSP45256. At the end of the first block, the TXFR\# line is pulsed to load the shadow registers into the operating reference memory, and correlation of the second block takes place. At the end of the second block, the HSP9501 will contain the correlation scores for the entire set of data. This method will work up to the highest correlation score that can be stored in the 10 bit data word of
the HSP9501: $2^{10}-1$, or 1023. See Figure 2 for an example of data that has been processed by the circuit shown. This method could be extended to 8191 samples by using two HSP9501's in parallel to store the full 13 bit output of the Correlator. For longer correlations, an external adder would be necessary. Figure 3 is a block diagram for a circuit with a maximum correlation score of $2^{20}-1$.


FIGURE 1. CORRELATION OF LENGTH UP TO 1023

## DATA



FIGURE 2. CORRELATION RESULTS


FIGURE 3. CORRELATION OF LENGTH GREATER THAN 8191

Figure 4 shows an implementation of a M tap correlation where the uncertainty in the data alignment is greater than 256 samples. The reference is divided into blocks and the correlation is performed one block at a time. The results of these partial correlations are then added to form a piecewise correlation. The amount of hardware required depends on
the length of the correlation desired and the initial misalignment of the data. The total delay in the HSP9501's is set for a delay of one block of data; the correlators compute the correlation score for one block of data at a time, where one correlator is needed for every 256 samples in the block.


FIGURE 4. LONG CORRELATION WITH LARGE DATA/REFERENCE MISALIGNMENT


# Harris Signal Processing 

# NOISE ASPECTS OF APPLYING ADVANCED CMOS SEMICONDUCTORS 

By: R. Kenneth Keenan, Ph.D. and David F. Bennett

## Introduction and Summary

This report is about noise aspects of high-speed logic, with a focus on Advanced CMOS semiconductor applications. The present report pertains to supression of ringing for both short and long traces, with experimental evidence provided for long traces.

Although termination and decoupling techniques cited here minimize ringing for all semiconductor technologies (AC/ ACT, LSTTL, HCMOS, AS, etc.), external resistive termination is usually not required for slower semiconductor technologies. Decoupling is an important aspect of design for all semiconductor technologies.

The preferred termination technique is a resistor, $\mathrm{R}_{\mathrm{T}}$, equal in value to the trace's characteristic impedance, $\mathrm{Z}_{\mathrm{O}}$, in series with a trace at the driving end of that trace. For AC/ ACT, series termination results in a modest (1ns to 3 ns ) increase in propagation and transition times. The increase in transition times incurred with series termination helps to minimize interference generation.
The length of traces with distributed loading to which series termination can be applied is limited by the increased transition times at intermediate points along those traces.

For long traces with distributed loading, AC shunt termination-a resistor in series with a small-value capacitor-is used from a trace to ground at the receiving end of a trace. The value of the capacitor depends on clock frequency, but it is typically 50 pF to 200 pF . Larger values result in improved pulse fidelity at the expense of increased power dissipation in the terminating resistor. At the expense of a capacitor, AC shunt termination consumes much less power than purely resistive shunt termination. AC shunt termination does not appear to materially effect propagation and transition times, except insofar as it removes the ringing contributing to shorter transition and propagation times.

## Series Termination with a Single Receiver

## Resistive Termination

Figure 1 illustrates the waveforms at the receiver for the case of no termination and for the case where the line is terminated at the driver end of the line. The termination resistor is $80 \Omega$, approximately equal to the $78 \Omega$ characteristic impedance of the line on the board. In this and all succeeding Figures, the line is 12 inches long.


FIGURE 1. UNTERMINATED AND TERMINATED ( $R_{T} \approx Z_{O}$ ) LINES

[^3][^4]
## Application Note 9102

Zero and five-volt reference lines are shown in each of the above oscillograms. It is clear from Figure 1 that termination assists in reducing both the undershoot for the low-to-high transition and the overshoot for the high-to-low transition. The noise immunity limits for CMOS are given in Table 1.
table 1. noise immunities and margins

| D.C. SPECIFICATION | VOLTAGE LEVEL <br> $(\mathrm{V})$ |
| :--- | :---: |
| Maximum Low-Level Input Voltage (Max $\left.\mathrm{V}_{\mathrm{IL}}\right)$ | 0.8 |
| Minimum High-Level Input Voltage (Min $\left.\mathrm{V}_{\mathrm{IH}}\right)$ | 2.0 |
| Maximum Low-Level Output <br> Voltage (Max $\left.\mathrm{V}_{\mathrm{OL}}\right)$ | 0.4 |
| Minimum High-Level Output <br> Voltage (Min $\left.\mathrm{V}_{\mathrm{OH}}\right)$ | 2.4 |
| Low-Level Noise Margin ( $\left.\mathrm{V}_{\mathrm{NML}}=\mathrm{V}_{\mathrm{IL}}-\mathrm{V}_{\mathrm{OL}}\right)$ | 0.4 |
| High-Level <br> $\left(\mathrm{V}_{\mathrm{NMH}}=\mathrm{V}_{\mathrm{OH}}-\mathrm{V}_{\mathrm{IH}}\right)$ | 0.4 |

For the unterminated line in Figure 1, the maximum $\mathrm{V}_{\mathrm{IL}} 0.8 \mathrm{~V}$ is breached. Therefore, CMOS gates driven with the unterminated-line (upper) waveform in Figure 1 can mistake the "bump" between $t=20 \mathrm{~ns}$ and $\mathrm{t}=30 \mathrm{~ns}$ for a "high". Thus, for the unterminated-line waveform, CMOS gates are subject to logic errors. The terminated line rings less and provides a signal which is well within the noise immunity limits for AC/ACT.

The relative sensitivity of the value of termination resistor was assesed. Figure 2 illustrates experimental results.
From Figure 2, the pulse waveform is marginally improved for termination resistance greater than the characteristic impedance, but it becomes more unterminated-like when a terminating resistance less than the characteristic impedance is used.

Table 1 summarizes the effects of terminating resistance on transition times and propagation delays. The propagation delay of the line, 1.8 ns , has been subtracted from the experimentally-measured propagation delay in the data in Table 1. The propagation delay was measured as illustrated in Figure 3.


FIGURE 2. SENSITIVITY OF PULSE TO TERMINATING RESISTANCE


FIGURE 3. MEASUREMENTS

TABLE 2. SUMMARY OF TRANSITION TIMES AND PROPAGATION DELAYS

| $*$ <br> $\mathbf{R}_{\mathbf{T}}$ <br> $(\Omega)$ | TRANSISTION <br> TIMES (ns) |  | PROPAGATION <br> DELAYS (ns) |  |
| :---: | :---: | :---: | :---: | :---: |
|  | $\mathbf{t}_{\mathbf{r}}$ | $\mathbf{t}_{\mathbf{f}}$ | $\mathbf{t}_{\text {pih }}$ | $\mathbf{t}_{\mathbf{p h i}}$ |
| 0 | 4.0 | 2.6 | 3.1 | 5.0 |
| 30 | 4.6 | 3.6 | 3.8 | 6.0 |
| $80\left(=\mathrm{Z}_{\mathrm{O}}\right)$ | 5.4 | 5.8 | 4.8 | 8.0 |
| 130 | 8.4 | 7.4 | 5.6 | 10.6 |

Transition times are measured in the conventions 10\%/90\% and $90 \% / 10 \%$, and, similarly, propagation delay is measured between the $50 \%$ points of the waveforms.
Termination with a resistor equal to the characteristic impedance of the line adds 1.7 ns to 3.0 ns to the propagation delays and increases the transition times. From the perspective of the emissions problems discussed in Section 9.0, an increase in transition times is good. However, increased propagation delays may be undesirable from a functional standpoint. With AC/ACT, some termination resistance must be used to prevent ringing which could exceed the noise immunity limits.

## Shunt Termination with a Single

## Receiver

AC shunt termination is a means of approximating a resistive termination without incurring the power dissipation of resistive termination. In laptop computers, power drain is a battery life issue. In computers and other powerlinepowered digital equipment, power drain causes heat dissipation and implies a diminution in reliability. CMOS, in spite of its speed, consumes relatively little power while operating and near zero power while in standby (or high-Z) states. Therefore, in a total power "budget", it is important to consider the power dissipation of termination resistors.

Figure 4 illustrates the effects of AC shunt termination for two different values of capacitors.
In designing an AC shunt termination, the value of the resistor is equal to the characteristic impedance of the line: $R_{T}=Z_{O}$. To allow for complete charging and discharging of the terminating capacitor $\left(C_{1}\right)$ during one-half the clock period: $\mathrm{C}_{1}<1 / 6 \mathrm{Z}_{\mathrm{O}} \mathrm{C}$. Then the power dissipated in $\mathrm{R}_{\mathrm{T}}$ is $\mathrm{V}_{\mathrm{CC}}{ }^{2}{ }^{f} \mathrm{C} \mathrm{C}_{1}$ (see Table 7). For the present case of $\mathrm{f}_{\mathrm{C}}=12 \mathrm{MHz}$, and $\mathrm{Z}_{\mathrm{O}}=80 \Omega, \mathrm{C}_{1}<1 / 6 \mathrm{Z}_{\mathrm{O}}{ }^{f} \mathrm{C}=$ 174 pF . At the extreme, where $\mathrm{C}_{1} \rightarrow \infty$, the power dissipation approaches that of a resistive terminator: $\mathrm{V}_{\mathrm{CC}}{ }^{2} / 2 \mathrm{Z}_{\mathrm{O}}$ for a $50 \%$ duty cycle clock.

For the case $\mathrm{C}_{1}=56 \mathrm{pF}$, the power dissipation in the terminating resistor is relatively small: 16.8 mW . For the case $\mathrm{C}_{1}=560 \mathrm{pF}$, the power dissipation approaches that of a resistive terminator: 156 mW (the power dissipation in the driver is approximately 30 mW ). However, the waveform with $\mathrm{C}_{1}=560 \mathrm{pF}$ is somewhat better than that with $\mathrm{C}_{1}=56 \mathrm{pF}$. In shunt termination, one is always trading power dissipation in the terminating resistor for pulse fidelity.
Table 3 summarizes propagation and transition times for AC shunt termination.

TABLE 3. PROPAGATION AND TRANSITION TIMES

| TERMINATION | TRANSISTION <br> TIMES (ns) |  | PROPAGATION <br> DELAYS (ns) |  |
| :---: | :---: | :---: | :---: | :---: |
|  | $\mathbf{t}_{\mathbf{r}}$ | $\mathbf{t}_{\mathbf{f}}$ | $\mathbf{t}_{\text {pih }}$ | $\mathbf{t}_{\text {phi }}$ |
| None | 4.0 | 2.6 | 3.1 | 5.0 |
| $80 \Omega / 56 \mathrm{pF}$ | 5.0 | 4.2 | 4.6 | 7.2 |
| $80 \Omega / 560 \mathrm{pF}$ | 5.8 | 4.6 | 4.2 | 7.0 |

AC shunt termination at the sending end (only) was not tried. However, in the context of distributed loads with both ends of the bus AC shunt terminated, the driving-end termination did not improve the waveform.
Ch. 1

- 2.000 volts/div Timebase - $10.0 \mathrm{~ns} / \mathrm{div}$

$$
\begin{aligned}
& \text { Offset }=2.500 \text { volts } \\
& \text { Offset }=2.500 \text { volts } \\
& \text { Delay }=0.00000 \mathrm{~s}
\end{aligned}
$$



FIGURE 4. AC SHUNT TERMINATION AT RECEIVER

Since computer bus lines may be in the active high state for relatively long periods of time, the DC blocking capacitor, $\mathrm{C}_{1}$ ( 56 pF and 560pF in Figure 4), can be of considerable benefit when driving CMOS logic. However, when driving bipolar logic, the current required by the inputs of driven gates can total much more than that required by a terminating resistor without a DC blocking capacitor. Then, AC termination offers insignificant advantages over conventional resistive termination.

## Terminations Applicable to Distributed Loads

## Description of Board with Simulated Load

The circuit shown in Figure 5 is the simulated load used along the bus-like structure on the test board. It is patterned after the equivalent input curcuitry. The inductor was formed by a small loop of wire.


## FIGURE 5. SIMULATED CMOS LOAD

The average value of the input capacitance of a CMOS gate is 7.5 pF . That value was not available, so 5 pF capacitors were used. The above load was distributed along one of the bus traces at points shown in Figure 6. The diodes are 1N914's, high-speed silicon types.


FIGURE 6. DISTRIBUTION OF SIMULATED LOADS ALONG bus trace

The measurements and waveforms cited below were made at the gate four inches from the driver and at the gate at the end of the line. The points designated by arrows in the figure are referred to as the "intermediate gate" and "end gate" in the measurements to follow. In all cases, the waveform at the end gate was the worst case with respect to ringing.
When a load is distributed along a trace, the characteristic impedance of that trace is modified in accordance with [2, p. 148]
$Z_{O}=Z_{\infty} /[1+$ distributed load capacitance on line/ capacitance of line] ${ }^{1 / 2}$
$Z_{\infty}=$ Characteristic impedance of line without distributed loading.

In the case of the test board, the capacitance along the unloaded line of $0.72 \mathrm{pF} / \mathrm{in} . \times 12 \mathrm{in} .=8.6 \mathrm{pF}$, and the distributed load, including that at the last gate, was ( $4 \times 5 \mathrm{pF}$ ) $+7.5 \mathrm{pF}=27.5 \mathrm{pF}$. Then, $\mathrm{Z}_{\mathrm{O}}=80 /[1+27.5 \mathrm{pF} / 8.6 \mathrm{pF}]^{1 / 2} \approx$ $40 \Omega$.

## Series Termination

Figure 7 illustrates waveforms along the line for unterminated lines, with and without distributed loading, and for the series-terminated line with $\mathrm{R}_{\mathrm{T}}=\mathrm{Z}_{\mathrm{O}}$. It is clear from a comparison of the top two oscillograms that the presence of distributed loading-even without terminationtends to smooth the waveforms. At least in part, this is probably due to the diodes in the simulated loads, which are also present in CMOS input gates.
Distributed loading increases line propagation delays by the same factor by which the characteristic impedance is decreased, which is a factor of approximately two in the present case. Propagation delay measurements were taken as indicated in Figure 2, with $2 \times 1.8=3.6 \mathrm{~ns}$ subtracted from the measured propagation delays to provide the "distributed load" propagation times in Tables 4 and 5.
The problem with using series termination with distributed loading is that the waveform along the line will tend to become a three-level waveform [2, p. 53]. This tendency is clear in the third oscillogram from the top in Figure 7. Thus, in Table 5 the transition times at the intermediate point on the line are greater than those at the end of the line given in Table 4. If the bus was longer, the "kink" at a line voltage of 2.5 volts would be more noticeable. However, in the present case, transition times are great enough to smooth the otherwise sharp three-level waveform. In some applications, an increase in transition times may be acceptable, and the extra component in the form of the capacitor necessary for AC shunt termination-which does not "three-level" the waveform along the bus-is not necessary. AC shunt termination is discussed in the next section.






FIGURE 7. WAVEFORMS FOR DISTRIBUTED LOADING

TABLE 4. TRANSITION AND PROPAGATION TIMES-END GATE

| $\mathbf{R}_{\mathbf{T}}$ <br> $(\Omega)$ | TRANSISTION <br> TIMES (ns) |  | PROPAGATION <br> DELAYS (ns) |  |
| :--- | :---: | :---: | :---: | :---: |
|  | $\mathbf{t}_{\mathbf{r}}$ | $\mathbf{t}_{\mathbf{f}}$ | $\mathbf{t}_{\text {pih }}$ | $\mathbf{t}_{\text {phi }}$ |
| 0 (No Dist. <br> load) | 4.0 | 2.6 | 3.1 | 5.0 |
| 0 (Dist. <br> load only) | 4.4 | 3.6 | 4.4 | 6.4 |
| $40\left(=Z_{\mathrm{O}}\right)+$ <br> Dist. load | 4.8 | 5.2 | 5.2 | 7.8 |

TABLE 5. TRANSITION TIMES-INTERMEDIATE GATE

| $\begin{aligned} & \mathbf{R}_{\mathbf{T}} \\ & (\Omega) \end{aligned}$ | TRANSISTION TIMES (ns) |  | PROPAGATION DELAYS (ns) |  |
| :---: | :---: | :---: | :---: | :---: |
|  | $\mathbf{t r}_{\boldsymbol{r}}$ | $t_{f}$ | ${ }^{\text {pih }}$ | ${ }^{\text {tphi }}$ |
| 0 (Dist. load only) | 6.6 | 5.6 | Not measured |  |
| $40\left(=Z_{0}\right)+$ <br> Dist. load | 8.0 | 7.8 | Not measured |  |

## AC Shunt Termination

This termination technique was previously explored in the context of a single load. For the case of loads distributed along a single line, the advantage of shunt termination is that the tendency toward a three-level waveform with series termination is absent. Figure 8 illustrates the waveforms obtained with AC shunt termination. As previously discussed, the corrected (for distributed loading) value of the characteristic impedance is $40 \Omega$.
The discussion of trading off waveform integrity for power dissipation also applies here. The power consumed by
the terminating resistor when $\mathrm{C}=560 \mathrm{pF}$ is substantially greater than when $\mathrm{C}=56 \mathrm{pF}$.

Table 6 summarizes propagation and transition time data. As in the preceding section, gate propagation delay $=$ measured delay -3.6 ns .

TABLE 6. SUMMARY OF TRANSITION TIMES AND PROPAGATION DELAYS

| $\begin{aligned} & R_{\mathbf{T}} \\ & (\Omega) \end{aligned}$ | TRANSISTION TIMES (ns) |  | PROPAGATION DELAYS (ns) |  |
| :---: | :---: | :---: | :---: | :---: |
|  | $T_{R}$ | $\mathrm{T}_{\mathbf{F}}$ | TPLH | TPHL |
| 40ת/56pF |  |  |  |  |
| End Gate | 6.0 | 6.0 | 3.3 | 4.4 |
| Int Gate | 9.0 | 8.3 | Not measured |  |
| 40ת/560pF |  |  |  |  |
| End Gate | 8.0 | 8.3 | 3.7 | 8.0 |
| Int Gate | 8.8 | 9.0 | Not measured |  |

As is evident from a comparison of Tables 5 and 6, shunt termination with a small capacitor ( 56 pF ) does not extract as much propagation delay "penalty" as does series termination-nor does a 56 pF shunt termination cause a tendency toward a three-level waveform on the bus. With a 560 pF capacitor, the waveform is better in the sense that there is less ringing, but, as indicated earlier, the power dissipation of the terminating resistor is substantially increased.

From a comparison of Figures 7 and 8, series termination appears to suppress ringing better than shunt terminationat least that shunt termination where, in order to reduce power consumed by termination resistors, the value of the capacitor is relatively small. Also, the increased transition times associated with series termination are very desirable from the standpoint of minimizing both ringing and ground bounce.

## Termination Techniques

Table 7 illustrates termination techniques which can be used at the receiving end of a trace; $C_{l}$ is the input capacitance of the driven semiconductor. The first three techniques require that the characteristic impedance of the trace structure be well-defined and constant along the trace run, which is complicated when a trace is to be run on both interior and exterior layers of a PCB.
Diode termination allows uncontrolled impedance-such as that obtained on a two-sided board where the trace-toground trace spacing is variable-but requires more expensive components than other techniques. In effect, CMOS input circuitry is a mixture of the series and diode termination techniques shown in Table 7.
In Table 7, the Termination Dissipation has been computed by assuming a (worst-case) $O \Omega$ source resistance. The power dissipation expressions apply to use of the terminating networks at either end of the line. For example, the expression given for the dissipation of a series termination applies whether the termination is used on the sending (proper) end of the line or the receiving (improper) end of the line.
Series termination has been analyzed in some detail. For use at either the receiving or sending end, maximum clock frequency is determined by assuming that, after a high-tolow transition, the input capacitor, $\mathrm{C}_{\mathrm{l}}$, must discharge to a voltage below $5 \%$ of $V_{C C}$ before the next clock low-to-high transition. This requires that three $Z_{O} C_{1}$ time constants occur during one-half of the clock period, which leads to the clock-frequency limitation shown for series termination in Table 7.
The relatively large power consumed in termination resistors can be a problem. AC shunt termination, as defined in Table 7 and used in Figures 4 and 8, provides a worthwhile low-power alternative, to be applied at the receiving end of a trace. In AC shunt termination, pulse fidelity is traded off for power dissipation: the larger the value of the DC blocking capacitor, C1, the better the pulse, but the higher the power consumption of the terminating resistor.
In the limit as the value of C1 is made very large, the power dissipation of the terminating network approaches that of purely resistive termination. The improved pulse fidelity with larger values of C 1 is apparent from Figure 8 . The maximum value of C1 which still permits adequate charging/ discharging of the shunt termination network over one-half of the clock cycle is $\mathrm{C}_{1}<1 / 6 \mathrm{f}_{\mathrm{C}} \mathrm{Z}_{\mathrm{O}}$; this inverse clock-frequency limitation is given in the "Max $\mathrm{f} C$ " column of Table 7. However, for $\mathrm{C}_{1} \gg 1 / 6 \mathrm{f}_{\mathrm{C}} \mathrm{Z}_{\mathrm{O}}$, the network is slow enough that full charging never occurs, the network begins to approach a purely resistive shunt terminator, and clock frequencies are limited only by the driver.
AC shunt termination should be used whenever the DC drive capability of the driving device is approached via heavy TTL loading.

## Decoupling CMOS

Clock-related noise on the $V_{C C}$ bus can arise if too few decoupling capacitors are used [5, p.3.11-1]. It
is recommended that all board layouts allow for one decoupling capacitor per semiconductor package. However, it is sometimes possible to remove some of the decoupling capacitors after a working prototype is developed. This is best done experimentally while carefully monitoring emissions, particularly at frequencies less than 200 MHz . At those frequencies, cable radiation dominates radiated emissions spectra. Assuming good grounding, cable radiation is an accurate indicator of $V_{C C}$ bus contamination.

On large (> 50-pin) devices with more than one $V_{C C}$ pin, use one decoupling capacitor at each VCC pin. In these cases, then, more than one decoupling capacitor per semiconductor package is recommended.

## Choosing the Value of a Decoupling Capacitor

A simplified diagram of the equivalent circuit for the output of a Harris CMOS device is shown in Figure 10. When the circuit shown transitions from low to high, switch S1 connects to terminal $A$ and current is drawn from the $V_{C C}$ bus to charge the capacitor. On a high to low transition, the switch connects to B ; current is sourced by the capacitor as it discharges into ground through S1. Note that the switch is, in the ideal case, a "break before make" circuit, so that no current is drawn from A to B as S1 changes state - a common source of current consumption in early CMOS logic.
Departures from ideality include the totem-pole effect: for time intervals which are smaller than the transition time, both the upper (PMOS) and lower (NMOS) transistors are partially "on". Then, during both the low-to-high and high-to-low transitions, there is a pulse of current drawn from the $V_{C C}$ bus. This is in addition to the current pulse required-and predicted by the model-for the charging of $\mathrm{C}_{\text {S }}$ when making the low-to-high transition. Also, the internal gates-those which precede the output gate-require both totem-pole and charging currents (charging currents for internal gates are much smaller than that required for the output gate, as the source capacitance associated with those gates is on the order of tens of femptofarads [1 femptofarad $=10^{-15}$ farad]).
A decoupling capacitor is the $V_{C C}$ bus for the purpose of supplying current during transitions. The inductance of a $V_{C C}$ trace or plane precludes those sources from supplying all of the rapidly-changing current required during a transition. Between clock pulse transitions, a trace or plane supplies recharge current to decoupling capacitors. Recharging can take place over the much longer time of one-half of the clock period.
A value of $0.1 \mu \mathrm{~F}$ will adequately decouple all known AC/ACT glue logic and VLSI circuits (even heavily loaded/fanned out), but the use of that relatively large value should be resisted in order to maintain the highest possible self-resonant frequency of the decoupling capacitor. Use $0.001 \mu \mathrm{~F}$ and $0.01 \mu \mathrm{~F}$, not so much for reduced cost as for the purpose of increasing the self-resonant frequency of the decoupling capacitor.


FIGURE 8. WAVEFORMS FOR AC SHUNT TERMINATION

TABLE 7. RECEIVING END TERMINATION TECHNIQUES

| TERMINATION | MAX fC | TERMINATION DISSIPATION | PULSE INTEGRITY | NOTES |
| :---: | :---: | :---: | :---: | :---: |
|  | $\frac{1}{6 Z_{0} \mathrm{C}_{1}}\left(667 \mathrm{MHz}^{\star}\right)$ | Very Low: $\begin{aligned} & p=V_{C C^{2}} f_{C} C_{1} \\ & (3.8 m W) \end{aligned}$ | Improves with small $\mathrm{Z}_{\mathrm{O}}, \mathrm{C}_{1}$ | Transition times increased. <br> Want Low $\mathrm{Z}_{0}$ |
|  | Driver-Limited | Very High: $\frac{V_{\mathrm{CC}^{2}}}{2 Z_{\mathrm{O}}}(250 \mathrm{~mW})$ | Good Reflected \% $=\frac{4.4 Z_{O C_{1}}}{r_{r}-4.4 Z_{O} C_{1}}$ | Drive current $=\frac{V_{C C}}{Z_{O}}=(100 \mathrm{~mA})$ |
| AC Shunt (Controlled $\mathrm{Z}_{\mathrm{O}}$ ) | $\frac{\frac{1}{6 Z_{O C}}}{\text { (33.3MHz, see text) }}$ | Low to Moderate, increasing with $\mathrm{C}_{1}$ $P=V_{C C^{2}} f_{C} C_{1}$ <br> ( 75 mW , about same as device) | Best with largest possible value of $C_{1}=1 / 6 Z_{o f}$ Intergrity improves with $\mathrm{C}_{1}$ | Must use low-ESL $\mathrm{C}_{1}$ with short leads <br> Want Low $\mathrm{Z}_{\mathrm{O}}$ |
| Diode (Uncontrolled $\mathrm{Z}_{\mathrm{O}}$ ) | Driver-Limited | Low | Good with highspeed Schotky diodes or built-in protection diodes of some semiconductors | External diodes costly |

[^5]

FIGURE 9. RESISTIVE TERMINATION IS USED IN MOST STANDARD BUSES


FIGURE 10. EQUIVALENT CIRCUIT FOR CMOS OUTPUT

## The Equivalent Series Inductance (ESL) of a Decoupling Capacitor

The equivalent series inductance (ESL) of a decoupling capacitor and the inductance of the leads/planes used to connect the decoupling capacitor to a semiconductor package should be as small as economics and manufacturing practicalities permit. This decreases both ringing and emissions. It is shown in [5, pp. 3.9-7 through 3.9-10] that maximum attenuation of noise on the power bus occurs at the self-resonant frequency of the decoupling capacitor. To have that attenuation occur at frequencies where ringing and emissions suppression is otherwise difficult (generally 35 MHz to 90 MHz ) using a capacitor value chosen according to the previous section requires ESL's less than 10 nH . Surface-mount ("chip") capacitors on a multilayer board with both $V_{C C}$ and ground planes are particularly desirable.

The ESL of a decoupling capacitor is at least as important as its capacitance. Above the self-resonant frequency of a decoupling capacitor which provides filtering; that inductance should be as small as manufacturing techniques and economy permit.

## Placement of Decoupling Capacitor on a Board

A decoupling capacitor should always be placed on that end of the semiconductor package which points toward the power entry point on a board. One of the purposes of decoupling is to minimize $V_{C C}$ noise at the power-entry point, and the filtration implied by a decoupling capacitor should be between the semiconductor package and the power entry point.

## Conclusions and Recommendations

## Use Multilayer Boards

The inductances associated with two-sided boards are often too large for successful application of high speed

CMOS circuits. Two-sidéd boards designed from an RF standpoint could be used, but the low component density associated with such boards is inconsistent with most contemporary system design requirements.

## The "Best" Termination Technique: Series Resistor at Driving End

When loads do not require much DC current, as with CMOS inputs, the preferred termination technique for a single load and large class of multiple distributed loads is a terminating resistor at the driving end of the trace. The value of the terminating resistor, $\mathrm{R}_{\mathrm{T}}$, is ideally equal to the characteristic impedance of the driven trace, $\mathrm{ZO}_{\mathrm{O}}$, as modified by any distributed loading. The correction for distributed loading is given in equation 1.

Reduction of the value of a series terminating resistor from $R_{T}=Z_{O}$ leads to decreased propagation and transition times. However, for even zero-length traces, reduction of RT eventually leads to ringing. Although the internal diodes in the input circuitry of Harris CMOS tend to limit ringing, noise immunity problems can still occur.

Increasing the value of the terminating resistor beyond $\mathrm{Z}_{\mathrm{O}}$ tends to further enhance the smoothness of the pulse but can lead to undesirable increases in propagation delays. The resulting increased transition times tend to suppress emissions.

For driving-end series termination with distributed loading on lines 12 inches long, transition times at intermediate loads are doubled relative to those at the end of the bus. Longer buses lead to even greater increases in transition times at intermediate bus points. Should this not be tolerable, the alternative AC shunt termination discussed below should be used.

## An Alternative Termination Technique

In the above case and/or when a resistively-terminated bus and/or heavy TTL loads are to be driven by CMOS gates, AC shunt termination should be considered as an alternative to putely resistive termination.

At least for the driven-end terminated case considered in this report, AC shunt termination does not appear quite as effictive as sending-end series termination in suppressing ringing.

When terminating high-speed traces, SIP resistors and capacitors should be avoided. The equivalent series inductance (ESL) is too large in many applications. Discrete SMD's are preferred to minimize ESL.

## Minimize Power Bus Ringing to Minimize Interference

To minimize ringing on the power bus, it is recommended that CMOS devices which handle high-frequency periodic signals be carefully decoupled from the power bus. Specific decoupling recommendations have been provided in this report.

## Bibliography

[1] R.K. Keenan, FCC Emissions and Power Bus Noise (Second Edition), Pinellas Park, Florida: TKC, February 1988.
[2] William R. Blood, Jr., MECL System Design Handbook (Fourth Edition, Rev. 1), Phoenix, Arizona: Motorola Inc., 1988.
[3] RCA/GE/Harris Semiconductor, GE Solid State Data Book (for) RCA Advanced CMOS Logic ICs, Somerville, N.J.: GE Corporation, 1987.
[4] J.D. Kraus, Electromagnetics (Third Edition), New York: McGraw Hill, 1984.
[5] R.K. Keenan, Decoupling and Layout of Digital Printed Circuits, Pinellas Park, Florida: TKC, 1987.
[6] R.K. Keenan, Digital Design for Interference Specifications, Pinellas Park, Florida: TKC, 1983.
[7] H.H. Skilling, Electrical Engineering Circuits, New York: Wiley, 1958.

# TEMPERATURE CONSIDERATIONS 

Author: Clay Olmstead

## Junction Temperature

The energy expended by an integrated circuit is dissipated as heat. In a CMOS system, current (and hence power) increase proportionally with switching frequency. With the advent of fast CMOS circuits, the attendant rise in temperature causes a variety of problems. In some cases, the current and/or temperature constraints placed on the device by its operating environment are the limiting factors on the clock rate. The increased die temperature due to the switching speed produces a number of secondary effects. The propagation delay time of a CMOS gate increases, causing a decline in the overall performance of the system. In addition, the effects of various failure mechanisms are accelerated (see Reliability Fundamentals). Depending on the failure mechanism, the lifetime of the product can be decreased by a factor of two for every $10^{\circ} \mathrm{C}$ rise in junction temperature.

The internal temperature of a semiconductor device is defined as junction temperature, $\mathrm{T}_{\mathrm{J}}$. Harris products are designed to operate with a 10 year lifetime under the stated operating conditions. For parts in ceramic packages, these include a maximum junction temperature of $175^{\circ} \mathrm{C}$. For plastic packages, the maximum $\mathrm{T}_{\mathrm{J}}$ is $150^{\circ} \mathrm{C}$ - this is to maintain the integrity of the package, not the device inside. Note that the $175^{\circ} \mathrm{C}$ limit is set according to military standards; many users in specific industries set this limit higher or lower, depending on their individual requirements.

## Determination Of Junction Temperature

Once the designer has selected an IC and calculated the clock frequency that meets the needs of the application, the operating temperature of the die (junction temperature) must be calculated to determine whether it exceeds reliability guidelines. This involves the concept of thermal resistance: the temperature differential across a body that is dissipating a given amount of energy. There are two common sets of reference points for thermal resistance: $\theta_{\mathrm{Jc}}$ is the temperature differential between the p -n junction of a semiconductor device and the outside surface of the package (case); $\theta_{\mathrm{JA}}$ is measured from the junction to ambient conditions. Other reference points for measuring thermal resistance are defined depending on specific requirements.

To calculate whether a device will exceed its maximum junction temperature, the first step is to multiply the clock rate by the frequency coefficient (given in mAMMz ) for that product. This is listed in the D.C. Electrical Specifications section of
the data sheet under $I_{\text {ccop }}$ The total package power dissipation is calculated by multiplying that current by the maximum $\mathrm{V}_{\mathrm{Cc}}$. If this figure is less than the Maximum Package Power Dissipation listed in the data sheet, then the operating conditions meet Harris specifications. In some applications, it is necessary to operate the part using a higher junction temperature (for applications that can absorb the penalty in expected lifetime) or lower temperature (for high reliability applications). Users with these requirements calculate their actual junction temperature using one of the following equations. Given the maximum ambient temperature, the proper equation is:
$T_{J}=\left(\theta_{J A} \times P\right)+T_{A} \quad$ Equation 1
Where:
$\mathrm{T}_{J}=$ Junction Temperature of the Part $\ln { }^{\circ} \mathrm{C}$
$\theta_{\mathrm{JA}}=$ Thermal Resistance from Junction to Ambient In ${ }^{\circ} \mathrm{C} / \mathbf{N}$
$\mathrm{P}=\mathrm{I}_{\mathrm{CcOP}} \times \mathrm{V}_{\mathrm{CC}}$
$T_{A}=$ Ambient Temperature
The junction temperature for a given case temperature is:
$T_{J}=\left(\theta_{J C} \times P\right)+T_{C} \quad$ Equation 2
Where:
$\mathrm{T}_{J}=$ Junction Temperature of the Part $\operatorname{In}{ }^{\circ} \mathrm{C}$
$\theta_{\mathrm{JC}}=$ Thermal Resistance from Junction to Case In ${ }^{\circ} \mathrm{C} / \mathrm{W}$
$\mathrm{P}=\mathrm{I}_{\mathrm{CcOP}} \times \mathrm{V}_{\mathrm{Cc}}$
$\mathrm{T}_{\mathrm{C}}=$ Case Temperature

## Reducing Junction Temperature

If, after going through the above equations, the junction temperature exceeds the allowable limit, there are several possible solutions. With some types of parts, such as digital filters, the user can replace a single part running at a high data rate with multiple parts, each operating at a reduced clock rate. Using this method, the junction temperature of each IC is reduced but the throughput of the entire circuit is unaffected. In most cases, the optimum solution is to improve the heat flow out of the package by adding a heat sink and/or forcing airflow across the package. Moving air lowers the effective $\theta_{\mathrm{JA}}$ of the part as shown in Figure 1. The required value for the effective thermal resistance is calculated by solving equation 1 for $\theta_{J A}$ :
$\theta_{J A}=\left(T_{J}-T_{A}\right) / P \quad$ Equation 3
Once the necessary value for $\theta_{\mathrm{JA}}$ is known, Figure 1 is used to locate the corresponding air flow for the package of
interest. Note that the improvement in thermal impedance is a function of the airflow measured in linear feet per minute ( lfm ), but fan manufacturers measure airflow in cubic feet per minute (cfm). Assuming $100 \%$ efficiency, lfm is converted to cfm by multiplying the required lfm by the cross sectional area of the path of moving air. In reality, obstructions in the airflow cause back pressure, which diminish the fan output to between $60 \%$ and $80 \%$ of its free air capacity; divide the lfm figure derived from Figure 1 by this compensation factor to obtain the required fan output.


FIGURE 1. TYPICAL RELATIONSHIP BETWEEN $\theta_{J A}$ AND AIR FLOW FOR VARIOUS PACKAGES
Another viable solution is to use a heat sink, either by itself (natural convection) or with moving air (forced convection). There is a wide range of heat sinks available for virtually any package type. Note, however, that a heat sink is much more effective when used in combination with a ceramic package. This is due to the greater thermal efficiency of the ceramic material: most of the flow of thermal energy is from the die directly into the package, where the entire surface of the part acts as a radiating surface to let the heat escape. Some energy flows from the die through the bond wires and pins and out through the copper traces in the board, but this effect is negligible due to the fact that the bond wires are only 1 mil in diameter and thus their thermal impedance is relatively high. In a plastic package, the main path for the heat flow is from the die through the paddle and the plastic molding compound and on to the outside world. Since plastic is a relatively poor thermal conductor, other paths, such as the bond wires, take on a greater proportion of the total heat transfer so that their contribution is no longer negligible. For this reason, a heat sink mounted to a plastic package dissipates less heat than Equation 2 would indicate. Harris recommends the use of a ceramic package for operating conditions that require a heat sink.
Addition of a heat sink puts two additional elements in path of thermal transfer: the heat sink and the thermal joint compound that attaches it to the package. The total value for $\theta_{\mathrm{JA}}$ is divided into its component parts: the thermal resistance from the junction to the surface of the package, from the package to the heat sink, and from the heat sink to ambient:
$\theta_{\mathrm{JA}}=\theta_{\mathrm{JC}}+\theta_{\mathrm{CS}}+\theta_{\mathrm{SA}} \quad$ Equation 4
Where CS is the thermal resistance from the IC package to the heat sink, which is controlled by the mounting technique and thermal joint compound used. OSA is the thermal resistance from the heat sink to ambient.
Under natural convection, heat sink dissipation is a function of the power dissipation of the chip. The heat sink manufac-
turer's catalog will specify the performance for their products using a chart similar to that shown in Figure 2. Starting with the power dissipated by the device on the x axis, find the corresponding temperature rise of the package on the $y$ axis. Add this value to the ambient temperature, $T_{A}$, to find the elevated case temperature. Use Equation 2 to find the new junction temperature.
If a fan is to be used, then the following procedure is recommended. Use Equation 3 to calculate the required total thermal resistance. Solving Equation 4 for $\theta_{\mathrm{SA}}$, calculate the maximum thermal resistance allowable for the heat sink. The literature from the maker of the heat sink will have a chart similar to Figure 3 ; find $\theta_{S A}$ on the right axis and find the air flow that corresponds to that value on the top axis. (The placement of the axes is to allow Figures 2 and 3 to be combined into one graph.) Convert lfm to cfm and divide that value by the compensation factor for back pressure mentioned above; use that figure to select a fan.


FIGURE2. PACKAGE TEMPERATURE INCREASE AS A FUNCtion of power for a typical heat sink UNDER NATURAL CONVECTION


FIGURE 3. THERMAL RESISTANCE VERSUS AIR VELOCITY FOR TYPICAL HEAT SINK UNDER FORCED CONVECTION

## For Further Reading

The discussion above outlines the overall method for calculating the thermal parameters of a circuit. the interested reader may refer to the following references for further information.

MIL STD 883 Method 1012.1; JEDEC ENG. Bulletin No. 20, January 1975; 1992 Semi Std. Vol. 4, Methods G30-86, G32-86, G42-88, G43-87

## DSP



## HARRIS QUALITY AND RELIABILITY

PAGEINTRODUCTION ..... 9-3
THE ROLE OF THE QUALITY ORGANIZATION ..... 9-3
THE IMPROVEMENT PROCESS ..... 9-3
HARRIS STANDARD FLOWS ..... 9-3
MEASUREMENT ..... 9-6
Analytical Services Laboratory ..... 9-6
Calibration Laboratory ..... 9-6
FIELD RETURN PRODUCT ANALYSIS SYSTEM ..... 9-6
Failure Analysis Laboratory ..... 9-7
PFAST Action Request Form ..... 9-8
RELIABILITY ..... 9-9
Reliability Assessment and Enhancement ..... 9-9
Qualifications ..... 9-9
In-Line Reliability Monitors ..... 9-9
PRODUCT/PACKAGE RELIABILITY MONITORS ..... 9-9
Matrix I, II, III ..... 9-9
RELIABILITY FUNDAMENTALS ..... 9-9
Failure Rate Calculations ..... 9-9
Accelleration Factors ..... 9-11
Activation Energy ..... 9-12
QUALIFICATION PROCEDURES ..... 9-12
Document Control ..... 9-13
/883 DATA SHEET HIGHLIGHTS ..... 9-13
GENERAL TEST PHILOSOPHY ..... 9-15
NON-STANDARD PRODUCT OFFERINGS ..... -15
IC HANDLING PROCEDURES ..... 9-16
Handling Rules ..... 9-16
ESD HANDLING PROCEDURES ..... 9-17
Measures of Protection and Prevention ..... 9-17
Technical Brief \#52 - Electrostatic Discharge Control ..... 9-18

## Harris Quality \& Reliability

## Introduction

Success in the integrated circuit industry means more than simply meeting or exceeding the demands of today's market. It also includes anticipating and accepting the challenges of the future. It results from a process of continuing improvement and evolution, with perfection as the constant goal.

Harris Semiconductor's commitment to supply only top value integrated circuits has made quality improvement a mandate for every person in our work force - from circuit designer to manufacturing operator, from hourly employee to corporate executive. Price is no longer the only determinant in marketplace competition. Quality, reliability, and performance enjoy significantly increased importance as measures of value in integrated circuits.

Quality in integrated circuits cannot be added on or considered after the fact. It begins with the development of capable process technology and product design. It continues in manufacturing, through effective controls at each process or step. It culminates in the delivery of products which meet or exceed the expectations of the customer.

## The Role of The Quality Organization

The emphasis on building quality into the design and manufacturing processes of a pruduct has resulted in a significant refocus of the role of the Quality organization. In addition to facilitating the development of SPC and DOX programs and working with manufacturing to establish control charts, Quality professionals are involved in the measurement of equipment capability, standardization of inspection equipment and processes, procedures for chemical controls, analysis of inspection data and feedback to the manufacturing areas, coordination of efforts for process and product improvement, optimization of environmental or raw materials quality, and the development of quality improvement programs with vendors.

At critical manufacturing operations, process and product quality is analyzed through random statistical sampling and product monitors. The Quality organization's role is changing from policing quality to leadership and coordination of quality programs or procedures through auditing, sampling, consulting, and managing Quality Improvement projects.

To support specific market requirements, or to ensure conformance to military or customer specifications, the Quality organization still performs many of the conventional quality functions (e.g., group testing for military products or wafer lot acceptance). But, true to the philosophy that quality is everyone's job, much of the traditional on-line measurement and control of quality characteristics is where it belongs - with the people who make the product. The

Quality organization is there to provide leadership and assistance in the deployment of quality techniques, and to monitor progress.

## The Improvement Process



FIGURE 1. STAGES OF STATISTICAL QUALITY TECHNOLOGY
Harris Semiconductor's quality methodology is evolving through the stages shown in Figure 1. In 1981 we embarked on a program to move beyond Stage I, and we are currently in the transition from Stage II to Stage III, as more and more of our people become involved in quality activities. The traditional "quality" tasks of screening, inspection, and testing are being replaced by more effective and efficient methods, putting new tools into the hands of all employees. Table 1 illustrates how our quality systems are changing to meet today's needs.

## Harris Standard Flows

Harris Semiconductor offers a variety of standard product flows which cover the myriad of application environments our customers experience. These flows run the gamut of low cost commercial parts to fully qualified JAN microcircuits. All of these grades have one thing in common. They result from meticulous attention to quality, starting with design decisions made during product development and ending with the labeling of shipping containers for delivery to our customers. The standard flows offered are:

## Commercial: Electrical performance guaranteed from $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ <br> /883: Mil-Std-883-compliant product: contact the factory or local Harris Sales Office for details on availability and specifications

Details of the individual process requirements are contained in the flow charts on the following pages.


Harris Semiconductor Standard Processing Flows (Continued)

(2) Burn-in test temperatures can be increased and time reduced per regression tables in Mil-Std-883, Method 1015

## Advantages of Standard Flows

Wherever feasible, and in accordance with good value engineering practice, the IC user should specify device grades based on one of the five standard Harris manufacturing flows. These are more than adequate for the overwhelming majority of applications and may be utilized quite effectively if the user engineer bases designs on the standard data sheet, military drawing or slash sheet (as applicable) electrical limits.
Some of the more important advantages gained by using standard as opposed to custom flows are as follows:

- Lower cost than the same or an equivalent flow executed on a custom basis. This results from the higher efficiency achieved with a constant product flow and the elimination of such extra cost items as special fixturing, test programs, additional handling and added documentation.
- Faster delivery. The manufacturer often can supply many items from inventory and, in any case, can establish and
maintain a better product flow when there is no need to restructure process and/or test procedures.
- Increased confidence in the devices. A continuing flow of a given product permits the manufacturer to mointor trends which may bear on end-product performance or reliability and to implement corrective action, if necessary.
- Reduction of risk. Since each product is processed independent of specific customer orders, the manufacturer absorbs production variability within its scheduling framework without major impact on deliveries. In a custom flow, a lot failure late in the production cycle can result in significant delays in delivery due to the required recycling time.
Despite the advantages of using standard flows, there are cases where a special or custom flow is mandatory to meet design or other requirements. In such cases, the Harris Marketing groups stand ready to discuss individual customer needs and, where indicated, to accomodate appropriate custom flows.


## Measurement

## Analytical Services Laboratory

Harris facilities, engineering, manufacturing, and product assurance are supported by the Analytical Services Laboratory. Organized into chemical or microbeam analysis methodology, staff and instrumentation from both labs cooperate in fully integrated approaches necessary to complete analytical studies. The capabilities of each area are shown below.

SPECTROSCOPIC METHODS: Colorimetry, Optical Emission, Ultraviolet Visible, Fourier Transform-Infrared, Flame Atomic Absorption, Furnace Organic Carbon Analyzer, Mass Spectrometer.

CHROMATOGRAPHIC METHODS: Gas Chromatography, Ion Chromatography.

THERMAL METHODS: Differential Scanning Colorimetry, Thermogravimetric Analysis, Thermomechanical Analysis.

PHYSICAL METHODS: Profilometry, Microhardness, Rheometry.

CHEMICAL METHODS: Volumetric, Gravimetric, Specific Ion Electrodes.

ELECTRON MICROSCOPE: Transmission Electron Microscopy, Scanning Electron Microscope.

X-RAY METHODS: Energy Dispersive X-ray Analysis (SEM), Wavelength Dispersive X-ray Analysis (SEM), X-ray Fluorescence Spectrometry, X-ray Diffraction Spectrometry.
SURFACE ANALYSIS METHODS: Scanning Auger Microprobe, Electron Spectroscope/Chemical Analysis, Secondary Ion Mass Spectrometry, Ion Scattering Spectrometry, Ion Microprobe.

The department also maintains ongoing working arrangements with commercial, university, and equipment manufacturers' technical service laboratories, and can obtain any materials analysis in cases where instrumental capabilities are not available in our own facility.

## Calibration Laboratory

Another important resource in the product assurance system is Harris Semiconductor's Calibration Lab. This area is responsible for calibrating the electronic, electrical, electro/mechanical, and optical equipment used in both the production and engineering areas. The accuracy of instruments used at Harris in calibration is traceable to the National Bureau of Standards. The lab maintains a system which conforms to the current revision of MIL-STD-45662, "Calibration System Requirements."

Each instrument requiring calibration is assigned a calibration interval based upon stability, purpose, and degree of use. The equipment is labeled with an identification tag on which is specified both the date of the last calibration and of the next required calibration. The Calibration Lab reports on a regular basis to each user department. Equipment out of calibration is taken out of
service until calibration is performed. The Quality organization performs periodic audits to assure proper control in the using areas. Statistical procedures are used where applicable in the calibration process.

## Field Return Product Analysis System

The purpose of this system is to enable Harris' Field Sales and Quality operations to properly route, track and respond to our customers' needs as they relate to product analysis.

The Product Failure Analysis Solution Team (PFAST) consists of the group of people who must act together to provide timely, accurate and meaningful results to customers on units returned for analysis. This team includes the salesman or applications engineer who gets the parts from the customer, the PFAST controller who coordinates the response, the Product or Test Engineering people who obtain characterization and/or test data, the analysts who failure analyze the units, and the people who provide the ultimate corrective action. It is the coordinated effort of this team, through the system described in this document that will drive the Customer responsiveness and continuous improvement that will keep Harris on the forefront of the semiconductor business.

The system and procedures define the processing of product being returned by the customer for analysis performed by Product Engineering, Reliability Failure Analysis and/or Quality Engineering. This system is designed for processing "sample" returns, not entire lot returns or lot replacements.

The philosophy is that each site analyzes its own product. This applies the local expertise to the solutions and helps toward the goal of quick turn time.

Goals: quick, accurate response, uniform deliverable (consistent quality) from each site, traceability.

The PFAST system is summarized in the following steps:

1) Customer calls the sales rep about the unit(s) to return.
2) Fill out PFAST Action Request - see the PFAST form in this section. This form is all that is required to process a Field Return of samples for failure analysis. This form contains essential information necessary to perform root cause analysis. (See Figure 2).
3) The units must be packaged in a manner that prevents physical damage and prevents ESD. Send the units and PFAST form to the appropriate PFAST controller. This location can be determined at the field sales office or rep using "look-up" tables in the PFAST document.
4) The PFAST controller will log the units and route them to ATE testing for data log.
5) Test results will be reviewed and compared to customer complaint and a decision will be made to route the failure to the appropriate analytical group.
6) The customer will be contacted with the ATE test results and interim findings on the analysis. This may relieve a line down situation or provide a rapid disposition of material. The customer contact is valuable in analytical process to insure root cause is found.
7) A report will be written and sent directly to the customer with copies to sales, rep, responsible individuals with corrective actions and to the PFAST controller so that the records will capture the closure of the cycle.
8) Each report will contain a feedback form (stamped and preaddressed) so that the PFAST team can assess their performance based on the customers assessment of quality and cycle time.
9) The PFAST team objectives are to have a report in the customers hands in 28 days, or 14 days based on agreements. Interim results are given realtime.

## Failure Analysis Laboratory

The Failure Analysis Laboratory's capabilities encompass the isolation and identification of all failure modes/failure mechanisms, preparing comprehensive technical reports, and assigning appropriate corrective actions. Research vital to understanding the basic physics of the failure is also undertaken.


FIGURE 3. NON-DESTRUCTIVE

Failure analysis is a method of enhancing product reliability and determining corrective action. It is the final and crucial step used to isolate potential reliability problems that may have occurred during reliability stressing. Accurate analysis results are imperative to assess effective corrective actions. To ensure the integrity of the analysis, correlation of the failure mechanism to the initial electrical failure is essential.

A general failure analysis procedure has been established in accordance with the current revision of MIL-STD-883, Section 5003. The analysis procedure was designed on the premise that each step should provide information on the failure without destroying information to be obtained from subsequent steps. The exact steps for an analysis are determined as the situation dictates. (See Figures 3 and 4). Records are maintained by laboratory personnel and contain data, the failure analyst's notes, and the formal Product Analysis Report.
$\qquad$

## PFAST ACTION REQUEST

## Date:

## Originator

LOCATION/Phone No.
Device Type/Part No.
No. Samples Returned


The completeness and timely response of the evaluation is directly related to the completeness of the data provided. Please provide all pertinent data. Attach additional sheets if necessary.

## TYPE OF PROBLEM

1. I Incoming Inspection
$\square 100 \%$ SCREEN $\square$ SAMPLE INSPECTION No. Tested $\qquad$ No. of Rejects $\qquad$ ARE RESULTS REPRESENTATIVE OF PREVIOUS LOTS?
```
- YES
\(\square\) NO
```

$\square$ Brief description of evaluation and results attached
2. In Process/Manufacturing Failure
$\square$ Board Checkout

- System Checkout
$\square$ Failed on Turn-on
$\square$ Failed after $\qquad$ HOURS OPERATION
WAS UNIT RETESTED UNDER INCOMING INSPECTION CONDITIONS? $\square$ YES $\square$ NO $\square$ Brief Description of how failure was isolated TO COMPONENT ATTACHED

3. $\square$ Field Failure

Failed after $\qquad$ HOURS OPERATION
Estimated failure rate $\qquad$ \% PER 1000 HOURS

End User $\qquad$ LOCATION $\qquad$ Ambient Temperature |  | $C$ |
| :--- | :--- |
| $M A X$ |  |

Min. $\qquad$ C MAX. $\qquad$ C

Rel. Humidity $\qquad$ \%
$\square$ END USER FAILURE CORRESPONDENCE ATTACHED
ACTION REQUESTED BY CUSTOMER

Specific Action Requested
Impact of Failed Units on Customer's Situation: $\qquad$

Customer Contacts with Specific Knowledge of Rejects Name Position $\qquad$ PHONE

DETAILS OF REJECT
(Where appropriate serialize units and specify for each)
Test Conditions Relating to Failure

- Tester Used (MFGR/MODEL) $\qquad$
- Test Temperature
- Test Time: $\square$ Continuous Test - One Shot ( $\mathrm{T}=$ $\qquad$ SEC)
- DESCRIPTION OF ANY OBSERVED CONDITION TO WHICH FAILURE APPEARS SENSITIVE: $\qquad$

1. DC FAILURES
$\square$ Opens $\square$ Shorts $\square$ Leakage $\square$ Stress $\square$ Power Drain $\square$ Input Level Output Level $\square$ LIST OF FORCING CONDITIONS AND MEASURED RESULTS FOR EACH PIN IS ATTACHED
$\square$ POWER SUPPLY SEQUENCING ATTACHED
2. ac Failures

List Failing Characteristics

Address of Failing Location (if applicable)

## Attached:

$\square$ List of Power Supply and Driver Levels (Include pictures of waveforms).
$\square$ LIST OF OUTPUT LEVELS AND LOADING CONDITIONS
$\square$ Input and Output Timing Diagrams
$\square$ Description of Patterns Used (If not standard patterns, give very complete description including address sequence).
3. $\square$ Prom Programming Failures

Address of Failures
Programmer Used (MFG/Model/Rev. No.)
4. $\square$ Physical/Assembly Related Failures

- See Comments Below $\square$ See Attached

Additional Comments:

FIGURE 2. PFAST ACTION REQUEST

## Reliability

## Reliability Assessment and Enhancement

At Harris Semiconductor, reliability is built into every product by emphasizing quality throughout manufacturing. This starts by ensuring the excellence of the design, layout, and manufacturing process. The quality of the raw materials and workmanship is monitored using statistical process control (SPC) to preserve the reliability of the product. The primary and ultimate goal of these efforts is to provide full performance to the product specification throughout its useful life. Product reliability is maintained through the following sources: Qualifications, In-Line Reliability Monitors, Failure Analysis.

## Qualifications

Qualifications at Harris de-emphasize the sole dependence on production product which is only available late in the development cycle. The focus is primarily on the use of test vehicles to establish design ground rules for the product and the process that will eliminate any wearout mechanisms during the useful life of the product. However, to comply with the military requirements concerning reliability, product qualifications are performed. (See Figure 5).

## In-line Reliability Monitors

In-line reliability monitors provide immediate feedback to manufacturing regarding the quality of workmanship, quality of raw materials, and the ultimate reliability implications. The rudimentary implementation of this monitoring is the "First Line of Defense," which is a pass/ fail acceptance procedure based on control charts and trend analysis. The second level of monitoring is referred to as the "Early Warning System" and incorporates wafer level reliability concepts for extensive diagnostic and characterization capabilities of various components that may impact the device reliability or stability. The quick feedback from these schemes allows more accurate correlation to process steps and corrective actions.

## Product/Package Reliability Monitors

Reliability of finished product is monitored extensively under a program called Matrix I, II, III monitor. All major technologies are monitored.
Matrix I - Has a higher sampling size and rate per week and uses short duration test, usually less than 48 hours to assess day to day, week to week reliability. High volume types are prevalent in this data. Stresses - Operating Life, Static Life and HAST. $\mathrm{T}_{\mathrm{A}}=+125^{\circ} \mathrm{C}$ to $+200^{\circ} \mathrm{C}$
Matrix II - Longer duration test, much like requalification. The sample sizes are reduced in number and frequency, yet meet or exceed the JEDEC Standard 29. Stresses Operating Life, Storage, THB, Autoclave, Temp Cycle, and Thermal Shock.

Matrix III - Package specific test. Tests Solderability, Lead Fatigue, Physical Dimensions, Brand Adhesion, Flammability, Bond Pull, Constant Acceleration, and Hermeticity.
Data from these Monitor Stress Test provides the following information:

- Routine reliability monitoring of products by die technology and package styles.
- Data base for determining FIT Rates and Failures Mode trends used drive Continuous Improvement.
- Major source of reliability data for customers.
- Customers have used this data to qualify Harris products.


## Reliability Fundamentals

Reliability, by its nature, is a mixture of engineering and probability statistics. This combination has derived a vocabulary of terms essential for describing the reliability of a device or system. Since reliability involves a measurement of time, it is necessary to accelerate the failures which may occur. This, then, introduces terms like "activation energy" and "acceleration factor," which are needed to relate results of stressing to normal operating conditions (see Table 1). Also, to assess product reliability requires failures. Therefore, only a statistical sample can be used to determine the model of the failure distribution for the entire population of product.

## Failure Rate Calculations

Reliability data for products may be composed of several different failure mechanisms and requires careful combining of diverse failure rates into one comprehensive failure rate. Calculating the failure rate is further complicated because failure mechanisms are thermally accelerated at varying rates and thereby have differing accelerating factors. Additionally, this data is usually obtained a variety of life tests at unique stress temperatures. The equation below accounts for these considerations and then inserts a statistical factor to obtain the confidence interval for the failure rate.

$$
\begin{aligned}
& F I T=\left(\begin{array}{cccc}
B & x_{i} & & \\
\sum_{i=1} & \sum_{j=1}^{K} & T D H_{j} & A F_{i j}
\end{array}\right) \times 10^{9} \quad x M \\
& B=\quad \# \text { of distinct possible failure mechanisms } \\
& K=\quad \# \text { of life tests being combined } \\
& X_{i}=\# \text { of failures for a given failure mechanism } \\
& i=1,2, \ldots \text { B } \\
& T D G_{j}=\text { Total device hours of test time (unaccelerated) for } \\
& \text { Life Test }{ }_{j} \\
& A F_{i j}=\quad \text { Acceleration factor for appropriate failure mecha- } \\
& \text { nism } \mathrm{i}=1,2, \ldots \mathrm{~K} \\
& M=\text { Statistical factor for calculating the upper confi- } \\
& \text { dence limit ( } M \text { is a function of the total number of } \\
& \text { failures and an estimate of the standard deviation } \\
& \text { of the failure rates) }
\end{aligned}
$$

In the failure rate calculation, Acceleration Factors $\left(\mathrm{AF}_{\mathrm{ij}}\right)$ are used to derate the failure rate from thermally accelerated Life Test conditions to a failure rate indicative of use temperatures. Though no standards exist, a temperature of $+55^{\circ} \mathrm{C}$ has been popular and allows some comparison of product failure rates. All Harris Semiconductor Reliability Reports will derate to $+55^{\circ} \mathrm{C}$ at both the $60 \%$ and $95 \%$ confidence intervals.

FLOW - PRODUCT DEVELOPMENT


## RELIABILITY FOCUS

- Assumes Process Development Required
- Evaluate Reliability Risks Factors
- Attain Commitment for Test Vehicle (T.V.) Development
- Review Test Vehicle Development and Stress Test Plan
- Review Package Requirements
- Review Latent Failure Mechanism History for Design Sensitivity and Elimination
- Review Ground Rules for Design and Elimination of Wearout Mechanisms
- Review Process Characterization, Statistical Control \& Capability which are Design Considerations
- Review Test Vehicle Stress Results
- Review Device Modeling \& Simulations
- Review Process Variability \& Producibility
- Define Wafer Reliability Monitor Vehicles, Application of Early Warning System
- Verify Wearout Mechanisms are Eliminated by Design \& Process Control (Test Vehicle + SPC)
- Evaluate Design of Chip to Package Risk Factors
- Review Ground Rule Checks (DRCs)
- Establish Reliability Test, Stress and Failure Analysis Capabilities. Project Failure Rate Based on T.V. Data.
- Review Burn-In Diagrams for Production and Qualification
- Review Overall Qualification Plan \& Begin Balance of Life Test
- Review Product Characterization to Data Sheet, ESD, Latch-up \& DPA Results \& Define Corrective Actions
- Review of Life Test Data \& Failure Mechanisms. Define Corrective Actions
- Utilize Statistical Design of Experiments (DOX) if Required to Adjust Process or Design
- Define Necessary Changes to Eliminate Any Systematic Failure Mechanism
- If Mature Process - Grant Generic Release
- Qualification Requirements Complete and Presented. Meet FIT Rate Requirements
- Review Infant Mortality (I.M.) Burn-in Results. If Greater Than $1 \%$ at $125^{\circ} \mathrm{C}$ Determine I.M. Burn-in Requirements
- Reliabiltiy Monitors:
- Real Time Early Warning Wafer Level Reliability control
- Real Time Reliability Control of Burn-in PDA with Control Charts
- Add-On Life Testing: - Mil Std Group C \& D
- Industrial/Commercial Life Testing
- Trend Analysis of Reliability Performance Used to Develop Product Improvements
- Special Studies
- High Quality and Reliability Products to Harris Customers
- Failure Analysis - Determine Assignable Cause of Failure
- Closed Loop Corrective Action Process
- Continuous Improvement Objectives in Product Reliability \& Quality

FIGURE 5. NEW PROCESS PRODUCT DEVELOPMENT AND LIFE CYCLE

## Acceleration Factors

The Acceleration Factors (AF) are determined from the Arrhenius Equation. This equation is used to describe physiochemical reaction rates and is an appropriate model for expressing the thermal acceleration of semiconductor failure mechanisms.


Both $T_{\text {use }}$ and $T_{\text {stress }}$ (in degrees Kelvin) include the internal temperature rise of the device and therefore represent the junction temperature. With the use of the Arrhenius Equation, the thermal Activation Energy ( $\mathrm{E}_{\mathrm{a}}$ ) term is a major influence on the result. This term is usually empirically derived and can vary widely.

## TABLE 1. FAILURE RATE PRIMER

## GLOSSARY OF TERMS

| TERMS/DEFINITION | UNITS/DESCRIPTION |
| :---: | :---: |
| FAILURE RATE $\lambda$ <br> For Semiconductors, usually expressed in FITs. <br> Represents useful life failure rate (which implies a constant failure rate). <br> FITs are not applicable for infant mortality or wearout failure rate expressions. | FIT - Failure in Time <br> 1 FIT - 1 failure in $10^{9}$ device hours. <br> Equivalent to $0.0001 \% / 1000$ hours <br> FITs = <br> \# Failures $\times 10^{9} \times \mathrm{m}$ <br> \# Devices x \# hours stress x AF <br> $m$ - Factor to establish Confidence Interval <br> $10^{9}$ - Establishes in terms of FITs <br> AF - Acceleration Factor at temperature for a given failure mechanism |
| MTTF - Mean Time To Failure <br> For semiconductors, MTTF is the average or mean life expectancy of a device. <br> If an exponential distribution is assumed then the mean time to fail of the population will be when $63 \%$ of the parts have failed. | Mean Time is measured usually in hours or years. <br> 1 Year $=8760$ hours <br> When working with a constant failure rate the MTTF can be calculated by taking the reciprocal of the failure rate. <br> MTTF $=1 / \lambda$ (exponential model) <br> Example: $=10$ FITs at $+55^{\circ} \mathrm{C}$ <br> The MTTF is: $M T T F=1 / \lambda=0.1 \times 10^{9}$ hours $=100 \mathrm{M}$ hours |
| CONFIDENCE INTERVAL (C. I.) <br> Establishes a Confidence Interval for failure rate predictions. Usually the upper limit is most significant in expressing failure rates. | Example: <br> "10 FITs @ a 95\% C.I. @ $55^{\circ}{ }^{\circ}$ " means only that you are 95\% certain the the FITs $<10$ at $+55^{\circ} \mathrm{C}$ use conditions. |

## Activation Energy

To determine the Activation Energy ( $\mathrm{E}_{\mathrm{a}}$ ) of a mechanism (see Table 2) you must run at least two (preferably more) tests at different stresses (temperature and/or voltage). The stresses will provide the time to failure (Tf) for the populations which will allow the simultaneous solution for the Activation Energy by putting the experimental results into the following equations.


Then, by subtracting the two equations, the Activation Energy becomes the only variable, as shown.
$\ln \left(\mathrm{t}_{\mathrm{f} 1}\right)-\ln \left(\mathrm{t}_{\mathrm{f} 2}\right)=\mathrm{E}_{\mathrm{a}} / \mathrm{k}(1 / \mathrm{T} 1-1 / \mathrm{T} 2)$
$E_{a}=K^{*}\left(\left(\ln \left(t_{f} 1\right)-\ln \left(t_{f}\right)\right) /(1 / T 1-1 / T 2)\right)$
The Activation Energy may be estimated by graphical analysis plots. Plotting In time and In temperature then provides a convenient nomogram that solves (estimates) the Activation Energy.
Table 3 is a summary for the L7 process.
All Harris Reliability Reports from qualifications and Group C1 (all high temperature operating life tests) will provide the
data on all factors necessary to calculate and verify the reported failure rate (in FITs) using the methods outlined in this primer.

## Qualification Procedures

New products are reliably introduced to market by the proper use of design techniques and strict adherence to process layout ground rules. Each design is reviewed from its conception through early production to ensure compliance to minimum failure rate standards. Ongoing monitoring of reliability performance is accomplished through compliance to 883C and standard Quality Conformance Inspection as defined in Method 5005.
New process/product qualifications have two major requirements imposed. First is a check to verify the proper use of process methodology, design techniques, and layout ground rules. Second is a series of stress tests designed to accelerate failure mechanisms and demonstrate the reliability of integrated circuits.
From the earliest stages of a new product's life, the design phase, through layout, and in every step of the manufacturing process, reliability is an integral part of every Harris Semiconductor product. This kind of attention to detail "from the ground up" is the reason why our customers can expect the highest quality for any application.

TABLE 2. FAILURE MECHANISM

| FAILURE MECHANISM | ACTIVATION ENERGY | SCREENING AND TESTING METHODOLOGY | CONTROL METHODOLOGY |
| :---: | :---: | :---: | :---: |
| Oxide Defects | $0.3-0.5 \mathrm{eV}$ | High temperature operating life (HTOL) and voltage stress. Defect density test vehicles. | Statistical Process Control of oxide parameters, defect density control, and voltage stress testing. |
| Silicon Defects (Bulk) | $0.3-0.5 \mathrm{eV}$ | HTOL \& voltage stress screens. | Vendor Statistical Quality Control programs, and Statistical Process Control on thermal processes. |
| Corrosion | 0.45 eV | Highly accelerated stress tesing (HAST) | Passivation dopant control, hermetic seal control, improved mold compounds, and product handling. |
| Assembly Defects | 0.5-0.7eV | Temperature cycling, temperature and mechanical shock, and environmental stressing. | Vendor Statistical Quality Control programs, Statistcal Process Control of assembly processes proper handling methods. |
| Electromigration <br> - Al Line <br> - Contact | $\begin{aligned} & 0.6 \mathrm{eV} \\ & 0.9 \mathrm{eV} \end{aligned}$ | Test vehicle characterizations at highly elevated temperatures. | Design ground rules, wafer process statistical process steps, photoresist, metals and passivation |
| Mask Defects/ Photoresist Defects | 0.7 eV | Mask FAB comparator, print checks, defect density monitor in FAB, voltage stress test and HTOL. | Clean room control, clean mask, pellicles Statistical Process Control or photoresist/etch processes. |
| Contamination | 1.0 eV | C-V stress at oxide/interconnect, wafer FAB device stress test (EWS) and HTOL. | Statistical Process Control of C-V data, oxide/ interconnect cleans, high integrity glassivation and clean assembly processes. |
| Charge Injection | 1.3 eV | HTOL \& oxide characterization. | Design ground rules, wafer level Statistical Process Control and critical dimensions for oxides. |

TABLE 3. HIGH TEMPERATURE OPERATING LIFE TEST SUMMARY

| GENERIC GROUP | GROUP NAME | PROCESS DESCRIPTION | QUANTITY | QUANTITY FAILURE | HOURS <br> @ $125^{\circ} \mathrm{C}$ | FAILURE RATEFITs @ $55^{\circ} \mathrm{C} 60 \% \mathrm{Cl}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| C-105-5 | Microprocessor and Peripherals | SAJI CMOS L7 | 1452 | 0 | $5.72 \mathrm{E}+06$ | 2 |

## Harris High Reliability Product Specification Highlights

Harris Semiconductor is a leading supplier of high reliability integrated circuits to the military and aerospace community and takes pride in offering products tailored to the most demanding applications requirements. Our Manufacturing facilities are JAN-Certified to MIL-M-38510 and provide JAN-qualified and MIL-STD-883 compliant products as standard data book items. This DSP Data Book contains detailed information on high-reliability integrated circuits presently available from Harris Semiconductor.

The intent of the /883 data sheet is to provide to our customers a clear understanding of the testing being performed in conformance with MIL-STD-883 requirements. Additionally, it is our intent to provide the most effective and comprehensive testing feasible.

## Document Control

Harris has established each of the /883 data sheets as an internally revised controlled document. Any product revision or modification must be approved and signed-off throughout the manufacturing and engineering sections. Harris has made every effort to ensure accuracy of the information in this data book through quality control methods. Harris reserves the right to make changes to the products contained in this data book to improve performance, reliability and producibility. Each data sheet will use the printed date as the revision control identification. Contact Harris for the latest available specifications and performance data.

## $/ 883$ Data Sheet Highlights

Each specific /883 data sheet documents the features, description, pinouts, tested electrical parameters, test circuits, burn-in circuits, die characteristics, packaging and design information. The following are notes and clarifications that will help in applying the information provided in the data sheet.

Absolute Maximum Ratings: These ratings are provided as maximum stress ratings and should be taken into consideration during system design to prevent conditions which may cause permanent damage to the device. Operation of the device at or above the "Absolute Maximum Ratings" is not intended, and extended exposure may affect the device reliability.

Reliability Information: Each /883 data sheet contains thermal information relating to the package and die. This information is intended to be used in system design for determining the expected device junction temperatures for overall system reliability calculations.

Packaging: Harris utilizes MIL-M-38510, Appendix C for packages used for $/ 883$ products. The mechanical dimensions and materials used are shown for each individual product to complete each data sheet as a self contained document.
D.C. and A.C. Electrical Parameters: Tables 1 and 2 define the D.C. and A.C. Electrical Parameters that are $100 \%$ tested in production to guarantee compliance to MIL-STD-883. The subgroups used are defined in MIL-STD-883, Method 5005 and designated under the provisions of Paragraph 1.2.1a. Test Conditions and Test Circuits are provided for specific parameter testing.

Table 3 provides additional device limits that are guaranteed by characterization of the device and are not directly tested in production. Characterization takes place at initial device design and after any major process or design changes. The characterization data is on file and available demonstrating the test limits established.

Table 4 provides a summary of the test requirements and the applicable MIL-STD-883 subgroups.

Burn-in Circuits: The Burn-in circuits defined in the individual data sheets are those used in the actual production process. Burn-in is conducted per MIL-STD883, Method 1015.
Design Information Sections: Harris provides an additional Design Information Section in many of the Jata sheets to assist in system application and design. This information may be in the form of applications circuits, typical device parameters, or additional device related user information such as programming information. While this information cannot be guaranteed, it is based on actual characterization of the product and is representative of the data sheet device.

## High Reliability Products Information

Harris' High Reliability Products are all produced in accordance with military specifications and standards, primarily MIL-M-38510 (General Specifications for Microcircuits) and MIL-STD-883 (Test Methods and Procedures for Microelectronics).
MIL-STD-883 contains test methods and procedures for various electrical, mechanical and environmental tests as well as requirements for screening, qualification and quality conformance inspection. Method 5004 of MIL-STD-883 lists the $100 \%$ screening tests which are required for each of the product assurance classes defined above.

Following the device screening, samples are removed from the production lot(s) for Quality Conformance Inspection testing. This testing is divided into four inspection groups: $\mathrm{A}, \mathrm{B}, \mathrm{C}$ and D , which are performed at prescribed intervals per MIL-M-38510 to assure the processes are in control and to ensure the continued quality level of the product being produced.

Group A electrical inspection involves dynamic, static, functional and switching tests at maximum, minimum and room operating temperatures. Sample sizes and specific tests performed depend upon the particular product assurance class chosen. Electrical test sampling is performed on all subgroups as defined in MIL-STD-883, Method 5005.

Group B inspection includes tests for marking permanency, internal visual and mechanical correctness, bond strength, and solderability. It is intended to provide assurance of the absence of lot-to-lot fabrication and manufacturing variances. Group B tests are again defined in test Method 5005.

Group C is oriented toward die integrity and consists of operating life testing as defined in MIL-STD-883, Method 5005.

Group $D$ environmental testing is provided to verify die and package reliability. Among the Group $D$ tests are lead integrity, hermeticity, temperature cycling, thermal and mechanical shock, and constant acceleration.

MIL-M-38510 requires that Group A and Group B inspection be performed on each lot, while Group C inspection must be done every 3 months and Group D every 6 months to be in compliance with MIL-M-38510 JAN requirements. To limit the amount of testing, MIL-M-38510 allows the multitude of micro- circuits to be grouped by technology, commonly known as "generic families". Thus, one group $C$ performed will cover all parts included in that generic family for three months. For Group D, which is package related, although there are some restrictions, one Group D performed on a 24-pin ceramic dual-in-line packaged part will cover all devices in the same package regardless of the technology group.

For MIL-STD-883 products, Groups A and B are required on each lot, Groups C and D are required every 52 weeks by generic die family and package fabricated and manufactured from the same plant as the die and package represented.

## General Test Philosophy

The general philosophy for test set development is to supply test software that guarantees the high performance and quality of the products being designed and manufactured by Harris. The general final test set includes a guardbanded initial test program and a QA test program for the quality test step. Characterization software is an additional test program that parametrically measures and records the performance of the device under test. This test set is used to evaluate the performance of a product and to determine the acceptability of non-standard Source Control Drawings. BSPEC and RSPEC test programs are custom final test programs written to conform to customer specifications.

The general test development strategy is to develop software using a "shell" programming technique which creates standard test program flows, and reduces test development and execution times. Statistically derived guardbands are utilized in the "shell" programs to null out test system variability. High performance hardware interface designs are incorporated for maximized test effectiveness, and efficient fault graded vector sets are utilized for functional and $A C$ testing.

The initial step in generating the test set is the test vector generation. The test vectors are the binary stimulus applied to the device under test to functionally test the operation of the product. The vectors are developed against a behavioral model that is a software representation of the device functionality. The output of the behavioral model can be translated directly to ATE test vectors or prepared for CAD simulation.

The philosophy in the generation of test vectors is to develop efficient fault graded patterns with a goal of greater than $90 \%$ fault coverage. There is no intent to generate a worst case or best case noise vector set. The intent is to maximize fault coverage through efficient vector use. Generally only one vector set will be required to enable complete test coverage within a given test program.

Exceptions to this would be vector generation to test certain identified critical AC speed paths or DC vectors for testing VIH/VIL parameters. These vector sets typically will not increase fault coverage and can not be substituted for fault graded vector sets.

The ultimate goal for testing all /883 products is data sheet compliancy, thoroughness, and quality of testing. By taking this approach to test set generation, Harris is capable of supplying high performance semiconductors of the highest quality to the marketplace.

## Non-Standard Product Offerings

Harris understands the need for customer generated Source Control Drawings with non-standard parameter and/or screening requirements. A Customer Engineering Department is responsible for efficiently expediting your SCDs through a comprehensive review process. The Customer Engineering Group compares your SCD to its closest equivalent grade device type and works closely with the Product Engineer, Manufacturing Engineer, Design Engineer, or applicable individual to compare Harris' screening ability against your non-standard requirement(s). For product processed to non-standard requirements, a unique part number suffix is assigned.

Harris shares the military's objective to utilize standards wherever possible. We recommend using our /883 data sheet as the guideline for your SCD's. In instances where an available military specification or Harris /883 datasheet is inappropriate, it is Harris' sincerest wish to work closely with the buyer in establishing an acceptable procurement document. For this reason, the customer is requested to contact the nearest Harris Sales Office or Representative before finalizing the Source Control Drawing. Harris looks forward to working with the customer prior to implementation of the formal drawing so that both parties may create a mutually acceptable procurement document.

## IC Handling Procedures

Harris IC processes are designed to produce the most rugged products on the market. However, no semiconductor is immune from damage resulting from the sudden application of many thousands of volts of static electricity. While the phenomenon of catastrophic failure of devices containing MOS transistors or capacitors is well known, even bipolar circuits can be damaged by static discharge, with altered electrical properties and diminished reliability. None of the common IC internal protection networks operate quickly enough to positively prevent damage.

It is suggested that all semiconductors be handled, tested, and installed using standard "MOS handling techniques" of proper grounding of personnel and equipment. Parts and subassemblies should not be in contact with untreated plastic bags or wrapping material. High impedance IC inputs wired to a P.C. connector should have a path to ground on the card.

## HANDLING RULES

Since the introduction of integrated circuits with MOS structures and tiigh quality junctions, a safe and effective means of handling these devices has been of primary importance. One method employed to protect gate oxide structures is to incorporate input protection diodes directly on the monolithic chip. However, there is no completely foolproof system of chip input protection in existence in the industry. In addition, most compensation networks in linear circuits are located at high impedance nodes, where protection networks would disturb normal circuit operation. If static discharge occurs at sufficient magnitude ( 2 kV or more), some damage or degradation will usually occur. It has been found that handling equipment and personnel can generate static potentials in excess of 10 kV in a low humidity environment. Thus it becomes necessary for additional measures to be implemented to eliminate or reduce static charge. It is evident, therefore, that proper handling procedures or rules should be adopted.

Elimination or reduction of static charge can be accomplished as follows:

- Use static-free work stations. Static-dissipative mats on work benches and floor, connected to common point ground through a $1 \mathrm{M} \Omega$ resistor, help eliminate static build-up and discharge. Do not use metallic surfaces.
- Ground all handling equipment.
- Ground all handling personnel with a conductive bracelet through $1 \mathrm{M} \Omega$ to ground (the $1 \mathrm{M} \Omega$ resistor will prevent electroshock injury to personnel). Transient product personnel should wear grounding heel straps when conductive flooring is present.
- Smocks and clothing of certain insulating materials (notably nylon) should not be worn in areas where devices are handled. These materials, highly dielectric in nature, will hold, or aid in the generation of a static charge. Where they cannot be eliminated, natural materials such as cotton should be used to minimize charge generation capacity. Conductive smocks are also available as an alternative.
- Control relative humidity to as high a level as practical. $50 \%$ is generally considered sufficient. (Operations should cease if R.H. falls below $25 \%$ ).
- Ionized air blowers reduce charge build-up in areas where grounding is not possible or practical.
- Devices should be in conductive static-shielded containers during all phases of transport. Leads may be shorted by tubular metallic carriers, conductive foam, or foil.
- In automated handling equipment, the belts, chutes, or other surfaces should be of conducting non-metal material. If this is not possible, ionized air blowers or ionizing bars may be a good alternative.


## ESD Handling Procedures

Harris has developed a static control program that enables employees to detect problems generated by static electricity whether on site, in transit, or in the field. Controlling the requirements, methods, materials, and training for static protection of our products is ongoing and updated with new developments in electrostatic prevention. Harris has responded with controls and procedures as part of daily operations to be followed in all areas.

The challenge is to insure all electrostatic control procedures are followed throughout the system - from manufacturing through end use. Unprotected integrated circuits can be destroyed or functionally altered by merely passing them through the electrostatic field of something as simple as Styrofoam ${ }^{\text {Tw }}$ or human contact.

## Measures of Protection and Prevention

When handling static sensitive devices, three standard procedures must be followed:

1. Prior to any handling of static-sensitive components, the individual must be properly grounded.
2. All static-sensitive components must be handled at static safeguarded work stations.
3. Containers and packing materials that are static-protective must be used when transporting all static-sensitive components.
Special handling equipment (static-safeguarded work stations, conductive wrist straps, static-protected packaging, ionized air blowers) should be used to reduce damaging effects of electrostatic fields and charges.
Static-safeguarded work station is an area that is free from all damaging electricity, including people. To accomplish this, static on conductors and nonconductors must be controlled.

Controlling electrically conductive items can be accomplished by bonding and grounding techniques. The human body is considered a conductor of electricity and is by far the greatest generator of static electricity. Personnel handling ICs must use con- ductive wrist straps to ground themselves. Simple body moves act like a variable capacitor, and can create static charges. In addition, conductive clothing is recommended for minimizing electrostatic build up.

Static protective packaging prevents electric field from influencing or damaging ICs. An effective static-protective package exhibits three types of features:

1. Antistatic protection that prevents triboelectric or frictional charging,
2. Dielectric protection that insulates discharging, and
3. Shielding or Faraday cage protection that prevents transient field penetration.

Harris uses only packaging that exhibits all three features. Employees are required to adhere to the same static-protective packaging techiques during handling and shipment to assure device integrity is maintained.
lonized air blowers aid in neutralizing charges on nonconductors such as synthetic clothing, plastics, and Styrofoam ${ }^{\mathrm{mm}}$. The blowers are placed at the work site and in close proximity to the IC handling area, since nonconductors do not lose or drain charges using normal grounding techniques.

By using wrist straps, static-protected work stations and static-protected containers, Harris product quality is maintained throughout the product cycle.


FIGURE 2. STATIC-SAFEGUARDED WORK STATION
NOTE 1. All electrical equipment on the conductive table top must be hard grounded and isolated from the table top.
2. Earth ground is not computer ground or RF ground or any other limited ground.

Styrofoam ${ }^{T w}$ is a trademark of Dow Chemical Corporation

# ELECTROSTATIC DISCHARGE CONTROL A GUIDE TO HANDLING INTEGRATED CIRCUITS 

This paper discusses methods and materials recommended for protection of ICs against ESD damage or degradation during manufacturing operations vulnerable to ESD exposure. Areas of concern include dice prep and handling, dice and package inspection, packing, shipping, receiving, testing, assembly and all operations where ICs are involved.
All integrated circuits are sensitive to electrostatic discharge (ESD) to some degree. Since the introduction of integrated circuits with MOS structures and high quality junctions, safe and effective means of handling these devices have been of primary importance.
If static discharge occurs at a sufficient magnitude, 2 kV or greater, some damage or degradation will usually occur. It has been found that handling equipment and personnel can generate static potentials in excess of 10kV in a low humidity environment; thus it becomes necessary for additional measures to be implemented to eliminate or reduce static charge. Avoiding any damage or degradation by ESD when handling devices during the manufacturing flow is therefore essential.

## ESD Protection and Prevention Measures

One method employed to protect gate oxide structures is to incorporate input protection diodes directly on the monolithic chip. However, there is no completely foolproof system of chip input protection in existence in the industry.
In areas where ICs are being handled, certain equipment should be utilized to reduce the damaging effects of ESD. Typically, equipment such as grounded work stations, conductive wrist straps, conductive floor mats, ionized air blowers and conductive packaging materials are included in the IC handling environment. Any time an individual intends to handle an IC, in any way, they must insure they have been grounded to eliminate circuit damage.
Grounding personnel can, practically, be performed by two methods. First, grounded wrist straps which are usually made of a conductive material, such as Velostat or metal. A resistor value of 1 megohm ( $1 / 2$ watt) in series with the strap to ground completes a discharge path for ESD when the operator wears the strap in contact with the skin. Another method is to insure direct physical contact with a grounded, conductive work surface.
This consists of a conductive surface like Velostat, covering the work area. The surface is connected to a 1 megohm (1/2 watt) resistor in series with ground.

In addition to personnel grounding, areas where work is being performed with ICs, should be equipped with an ionized air blower. Ionized air blowers force positive and negative ions simultaneously over the work area so that any nonconductors that are near the work surface would have their static charge neutralized before it would cause device damage or degradation.
Relative humidity in the work area should be maintained as high as practical. When the work environment is less than $40 \%$ RH, a static build-up condition can exist on nonconductors allowing stored charges to remain near the ICs causing possible static electricity discharge to ICs.
Integrated circuits that are being shipped or transported require special handling and packaging materials to eliminate ESD damage. Dice or packaged devices should be in conductive carriers during all phases of transport and handling. Leads of packaged devices can be shorted by tubular metalic carriers, conductive foam or foil.

## Do's and Don'ts for Integrated Circuit Handling

## Do's

Do keep paper, nonconductive plastic, plastic foams and films or cardboard off the static controlled conductive bench top. Placing devices, loaded sticks or loaded burn-in boards on top of any of these materials effectively insulates them from ground and defeats the purpose of the static controlled conductive surface.

Do keep hand creams and food away from static controlled conductive work surfaces. If spilled on the bench top, these materials will contaminate and increase the resistivity of the work area.

Do be especially careful when using soldering guns around conductive work surfaces. Solder spills and heat from the gun may melt and damage the conductive mat.
Do check the grounded wrist strap connections daily. Make certain they are snugly fitted before starting work with the product.
Do put on grounded wrist strap before touching any devices. This drains off any static build-up from the operator.
Do know the ESD caution symbols.
Do remove devices or loaded sticks from shielding bags only when grounded via wrist strap at grounded work station. This also applies when loading or removing devices from the antistatic sticks or the loading on or removing from the burn-in boards.

Do wear grounded wrist straps in direct contact with the bare skin never over clothing.
Do use the same ESD control with empty burn-in boards as with loaded boards if boards contain permanently mounted ICs as part of driver circuits.

Do insure electrical test equipment and solder irons at an ESD control station are grounded and only uninsulated metal hand tools be used. Ordinary plastic solder suckers and other plastic assembly aids shall not be used.

Do use ionizing air blowers in static controlled areas when the use of plastic (nonconductive) materials cannot be avoided.

## Don'ts

Don't allow anyone not grounded to touch devices, loaded sticks or loaded burn-in boards. To be grounded they must be standing on a conductive floor mat with conductive heel straps attached to footwear or must wear a grounded wrist strap.
Don't touch the devices by the pins or leads unless grounded since most ESD damage is done at these points.

Don't handle devices or loaded sticks during transport from work station to work station unless protected by shielding bags. These items must never be directly handled by anyone not grounded.

Don't use freon or chlorinated cleaners at a grounded work area.

Don't wax grounded static controlled conductive floor and bench top mats. This would allow build-up of an insulating layer and thus defeating the purpose of a conductive work surface.

Don't touch devices or loaded sticks or loaded burn-in boards with clothing or textiles even though grounded wrist strap is worn. This does not apply if conductive coats are worn.

Don't allow personnel to be attached to hard ground. There must always be 1 megohm series resistance ( $1 / 2$ watt between the person and the ground).

Don't touch edge connectors of loaded burn-in boards or empty burn-in boards containing permanently mounted
driver circuits when not grounded. This also applies to burnin programming cards containing ICs.
Don't unload stick on a metal bench top allowing rapid discharge of charged devices.

Don't touch leads. Handle devices by their package even though grounded.
Don't allow plastic "snow or peanut" polystyrene foam or other high dielectric materials to come in contact with devices or loaded sticks or loaded burn-in boards.

Don't allow rubber/plastic floor mats in front of static controlled work benches.

Don't solvent-clean devices when loaded in antistatic sticks since this will remove antistatic inner coating from sticks.
Don't use antistatic sticks for more than one throughput process. Used sticks should not be reused unless recoated.

## Recommended Maintenance Procedures

## Daily:

Perform visual inspection of ground wires and terminals on floor mats, bench tops, and grounding receptacles to ensure that proper electrical connections via 1 megohm resistor (1/2 watt) exist.

Clean bench top mats with a soft cloth o paper towel dampened with a mild solution of detergent and water.

## Weekly:

Damp mop conductive floor mats to remove any accumulated dirt layer which causes high resistivity.

## Annually:

Replace nuclear elements for ionized air blowers.
Review ESD protection procedures and equipment for updating and adequacy.

## Static Controlled Work Station

The figure below shows an example of a work bench properly equipped to control electro-static discharge. Note that the wrist strap is connected to a 1 megohm resistor. This resistor can be omitted in the setup if the wrist strap has a 1 megohm assembled on the cable attached.




## PACKAGING AND ORDERING INFORMATION

PAGE
PACKAGING AVAILABILITY . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10-3
PACKAGE OUTLINES................................................................................................. . . . 10-4
ORDERING INFORMATION . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10-9
AVAILABLE PRODUCT CODES . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10-10

## Package Availability

| PART NUMBER | PLCC | PGA | PLASTIC DIP | soic |
| :---: | :---: | :---: | :---: | :---: |
| MULTIPLIERS |  |  |  |  |
| HMU16/17 | N2 | T1 | - | - |
| HMU16/883 | - | T1 | - | - |
| HMU17/883 | - | T1 | - | - |
| HMA510 | N2 | T1 | - | - |
| HMA510/883 | - | T1 | - | - |
| ONE DIMENSIONAL FILTERS |  |  |  |  |
| HSP43168 | N3 | T2 | - | - |
| HSP43168/883 | - | T2 | - | - |
| HSP43220 | N3 | T2 | - | - |
| HSP43220/883 | - | T2 | - | - |
| HSP43481 | N2 | T1 | - | - |
| HSP43481/883 | - | T1 | - | - |
| HSP43881 | N3 | T3 | - | - |
| HSP43881/883 | - | T3 | - | - |
| HSP43891 | N3 | T3 | - | - |
| HSP43891/883 | - | T3 | - | - |
| TWO DIMENSIONAL FILTERS |  |  |  |  |
| HSP48901 | N2 | T1 | - | - |
| HSP48908 | N3 | T2 | - | - |
| HSP48908/883 | - | T2 | - | - |
| SIGNAL SYNTHESIZERS |  |  |  |  |
| HSP45102 | - | - | E2 | M1 |
| HSP45106 | N3 | T3 | - | - |
| HSP45106/883 | - | T3 | - | - |
| HSP45116 | - | T4 | - | - |
| HSP45116/883 | - | T4 | - | - |
| SPECIAL FUNCTION |  |  |  |  |
| HSP45240 | N2 | T1 | - | - |
| HSP45240/883 | - | T1 | - | - |
| HSP45256 | N3 | T3 | - | - |
| HSP45256/883 | - | T3 | - | - |
| HSP48410 | N3 | T2 | - | - |
| HSP9501 | N1 | - | - | - |
| HSP9520/21 | - | - | E1 | M2 |
| ISP9520/21 | - | - | E1 | - |



Package Outlines
M1 SOIC


NOTE: All Dimensions Are $\frac{\text { Min }}{\text { Max }}$, Dimensions Are In Inches.


## CERAMIC 68 PIN GRID ARRAY (PGA)



NOTE: All Dimensions Are $\frac{\text { Min }}{\text { Max }}$, Dimensions Are In Inches.

84 LEAD PIN GRID ARRAY (PGA)


DIP OR TIN PLATE LEAD FINISH APPLIES.

NOTE: All Dimensions Are $\frac{\text { Min }}{M a x}$, Dimensions Are In Inches.


## Product Code

Harris products are designated by a "Product Code". This code includes designators for the product family, device type, performance grade, temperature grade and package style. An example of the Product Code is shown below:

HARRIS PRODUCT CODE EXAMPLE


## Available Product Codes

| DEVICE TYPE | PACKAGE | TEMPERATURE | SPEED | SCREENING |
| :---: | :---: | :---: | :---: | :---: |
| HMA510 | J | C | -45, -55 |  |
|  | G | c | -55 |  |
|  | G | M | -55, -65, -75 | /883 |
| HMU16/17 | $J$ | C | -35, -45 |  |
|  | G | C | -35, -45 |  |
|  | G | M | -45, -60 | /883 |
| HSP43168 | $J$ | C | -33,-45 |  |
|  | G | c | -33,-45 |  |
|  | G | M | -25,-33 | /883 |
| HSP43220 | J | c | -15, -25,-33 |  |
|  | G | C | -15, -25, -33 |  |
|  | G | M | -15,-25 | 1883 |
| HSP43481 | $J$ | C | -20, -25, -30 |  |
|  | G | c | -20, -25, -30 |  |
|  | G | M | -20,-25 | /883 |
| HSP43881/891 | $J$ | C | -20, -25, -30 |  |
|  | G | C | -20, -25, -30 |  |
|  | G | M | -20, -25 | /883 |
| HSP45102 | P | C | -33, -40 |  |
|  | P | 1 | -33, -40 |  |
|  | S | C | -33,-40 |  |
|  | S | 1 | -33, -40 |  |
| HSP45106 | $J$ | C | -25, -33 |  |
|  | G | C | -25, -33 |  |
|  | G | M | -25 | 1883 |
| HSP45116 | G | C | -15, -25, -33 |  |
|  | G | M | -15,-25 | 1883 |
| HSP45240 | $J$ | C | -33, -40, -50 |  |
|  | G | C | -33, -40, -50 |  |
|  | G | M | -33,-40 | /883 |
| HSP45256 | $J$ | C | -25, -33 |  |
|  | G | c | -25, -33 |  |
|  | G | M | -20. -25 | 1883 |
| HSP48410 | $J$ | c | -33,-40 |  |
|  | G | c | -33,-40 |  |
| HSP48901 | $J$ | C | -20, -30 |  |
|  | G | C | -20, -30 |  |
| HSP48908 | $J$ | C | -20, -32 |  |
|  | G | C | -20,-32 |  |
|  | G | M | -20, -27 | 1883 |
| HSP9501 | $J$ | C | -25,-32 |  |


| DEVICE TYPE | TEMPERATURE | PACKAGE | SPEED | SCREENING |
| :--- | :---: | :---: | :---: | :---: |
| HSP9520/21 | C | P,S |  |  |
| ISP9520/21 | C | PX |  |  |

## SALES OFFICES

A complete and current listing of all Harris Sales, Representative and Distributor locations worldwide is on 11-2 through 11-8.
HARRIS HEADQUARTER LOCATIONS BY COUNTRY:
U.S. HEADQUARTERS

Harris Semiconductor 1301 Woody Burke Road
Melbourne, Florida 32902
TEL: (407) 724-3000

SOUTH ASIA
Harris Semiconductor H.K. Ltd
13/F Fourseas Building
208-212 Nathan Road
Tsimshatsui, Kowloon
Hong Kong
TEL: (852) 723-6339

EUROPEAN HEADQUARTERS
Harris Semiconductor
Mercure Centre
Rue de la Fusee, 100
1130 Brussels, Belgium
TEL: (32) 2-246-21.11
NORTH ASIA
Harris K.K.
Shinjuku NS Bldg. Box 6153
2-4-1 Nishi-Shinjuku
Shinjuku-Ku, Tokyo 163 Japan
TEL: (81) 3-3345-8911

TECHNICAL FIELD APPLICATION ASSISTANCE AVAILABILITY:

| UNITED STATES | CALIFORNIA | Costa Mesa . . . . . . . . . . . . . . . . 714-433-0600 San Jose ................ 408-985-7322 Woodland Hills. . . . . . . . . . . . 818-992-0686 |
| :---: | :---: | :---: |
|  | FLORIDA | Melbourne . . . . . . . . . . . . . . . . . 407-724-3576 |
|  | GEORGIA | Duluth. . . . . . . . . . . . . . . . . . . . 404-476-2035 |
|  | ILLINOIS | Schaumburg. . . . . . . . . . . . . . . . 708-240-3499 |
|  | MASSACHUSETTS | Burlington. . . . . . . . . . . . . . . . . 617-221-1850 |
|  | NEW JERSEY | Mt. Laurel. . . . . . . . . . . . . . . . . . 609-727-1909 |
|  | NEW YORK | Great Neck. . . . . . . . . . . . . . . . . 516-829-9441 Wappingers Falls . . . . . . . . . . . $914-298-0413$ |
|  | TEXAS | Dallas. . . . . . . . . . . . . . . . . . . . 214-733-0800 |
| INTERNATIONAL | FRANCE | Paris. . . . . . . . . . . . . . . . . . . . 33-1-346-54046 |
|  | GERMANY | Munich . . . . . . . . . . . . . . . . . . . . 49-8-963-8130 |
|  | HONG KONG | Kowloon . . . . . . . . . . . . . . . . . . 852-723-6339 |
|  | ttaly | Milano . . . . . . . . . . . . . . . . . . . 39-2-262-0761 |
|  | JAPAN | Tokyo . . . . . . . . . . . . . . . . . . . . 81-03-345-8911 |
|  | KOREA | Seoul . . . . . . . . . . . . . . . . . . . . 82-2-551-0931 |
|  | UNITED KINGDOM | Camberley . . . . . . . . . . . . . . . . . 44-2-766-86886 |


| ALABAMA | Harris Microwave |
| :---: | :---: |
| Harris Semiconductor | Semiconductor Products |
| Suite 103 | Harris Microwave |
| Office Park South | Semiconductor |
| 600 Boulevard South | 1530 McCarthy Blvd. |
| Huntsville, AL 35802 | Milpitas, CA 95035 |
| TEL: (205)-883-2791 | TEL: (408) 433-2222 |
| FAX: 2058832861 | TWX: 9103362247 |
| Giesting \& Associates | FAX: 4084323268 |
| Suite 15 | Gray \& Steward, Inc. |
| 4835 University Square | 1054 Whispering Pines Dr. |
| Huntsville, AL 35816 | Scotts Valley, CA 95066 |
| TEL: (205) 830-4554 | TEL: (408) 439-8905 |
| FAX: 2058304699 | FAX: 4084399001 |
| ARIZONA | CANADA |
| Compass Marketing \& Sales, | Blakewood Electronic |
| Inc. | Systems, Inc. |
| 11801 N. Tatum Blvd. \#101 | 1A-12880 Bathgate Way |
| Phoenix, AZ 85028 | Richmond, BC Canada |
| TEL: (602) 996-0635 | Canada V6V 1 Z4 |
| FAX: 6029960586 | TEL: (604) 273-9910 |
| P.O. Box 65447 | FAX: 6042731483 |
| Tucson, AZ 85728 | Clark Hurman Associates Unit 14 |
| TEL: (602) 557-0580 |  |
| FAX: 6025570581 | 20 Regan Road |
|  | Brampton, Ontario |
| CALIFORNIA | Canada L7A IC3 |
|  | TEL: (416) 840-6066 |
| Suite 320 | FAX: 416 840-6091 |
| 1503 So. Coast Drive | 66 Colonnade Rd. |
| Costa Mesa, CA 92626 | Suite 205 |
| TEL: (714) 433-0600 | Nepean, Ontario |
| FAX: 7144330682 | Canada K2E 7K7 |
| Harris Semiconductor Suite 308 | TEL.: (613) 727-5626 |
|  | FAX: 6137271707 |
| 5250 W. Century Blvd. | 4 Chester |
| Los Angeles, CA 90045 | Pointe Claire, Quebec |
| TEL: (310) 649-4752 | Canada H9R 4H7 |
| FAX: 3106494804 | TEL: (514) 426-0453 |
| Harris Semiconductor 3031 Tisch Way | FAX: 5144260455 |
|  |  |
| 1 Plaza South | COLORADO |
| San Jose, CA 95128 | Compass Marketing |
| TEL: (408) 985-7322 | Suite 350D |
| FAX: 4089857455 | 5600 So. Quebec St. |
| Harris Semiconductor <br> Suite 350 <br> 6400 Canoga Ave. <br> Woodland Hills, CA 91367 <br> TEL: (818) 992-0686 <br> FAX: 8188830136 | Greenwood Village, CO 80111 |
|  | TEL: (303) 721-9663 |
|  | FAX: 3037210195 |
|  |  |
|  | CONNECTICUT <br> Advanced Tech Sales, Inc. <br> Westview Office Park Bldg. 2, Suite 1C 850 N. Main Street Extension Wallingford, CT 06492 TEL: (203) 284-0838 FAX: 2032848232 |
|  |  |
| CK Associates |  |
| 8333 Clairemont Mesa Blvd. |  |
| Suite 102 |  |
| San Diego, CA 92111 |  |
| TEL: (619) 279-0420 |  |
| FAX: 6192797650 |  |
| Ewing Foley, Inc. 185 Linden Avenue Auburn, CA 95603 TEL: 916-885-6591 FAX: 9168856594 | FLORIDA <br> Harris Semiconductor <br> * 1301 Woody Burke Rd. Melbourne, FL 32902 <br> TEL: (407) 724-3576 <br> FAX 4077243130 |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |

## RIZONA

Compass Marketing \& Sales,
11801 N. Tatum Blvd. \#101
Phoenix, AZ 85028
TEL: (602) 996-0635
6029960586

Tucson, AZ 85728
TEL: (602) 557-0580

CALIFORNIA
Harris Semiconductor
1503 So. Coast Drive
Costa Mesa, CA 92626
EL: (714) 433-0600

Harris Semiconductor
uite 308

A 90045
TEL: (310) 649-4752
FAX: 3106494804

* 3031 Tisch Way

Plaza South
San Jose, CA 95128
408) 985-7322

Harris Semiconductor
6400 Canoga Ave.
赖

CK Assoclat
8333 Clairemont Mesa Blvd.
有

TEL: (619) 279-0420
FAX: 6192797650
Ewing Foley, Inc.
ablinde 15003
TEL: 916-885-6591
FAX: 9168856594

Harris Semiconductor
300 6th Avenue, North
Indian Rocks Beach, FL 34635
TEL: (813) 595-4030
FAX: 8135955780

## GEORGIA

Glesting \& Associates

* Suite 108

2434 Hwy. 120
Duluth, GA 30136
TEL: (404) 476-0025
FAX: 4044762405

## ILLINOIS

Harris Semiconductor

* Suite 600

1101 Perimeter Dr.
Schaumburg, IL 60173
TEL: (708) 240-3480
FAX: 7086191511

## Oasis Sales

1101 Tonne Road
Elk Grove Village, IL 60007
TEL: (708) 640-1850
FAX: 7086409432

## INDIANA

Harris Semiconductor

- Suite 100

11590 N. Meridian St. Carmel, IN 46032
TEL: (317) 843-5180
FAX: 3178435191
Giesting \& Associates
370 Ridgepoint Dr.
Carmel, IN 46032
TEL: (317) 844-5222
FAX: 3178445861

## IOWA

Advanced Technical Sales
Inc.
375 Collins Road, NE
Cedar Rapids, IA 52402
TEL: (319) 393-8280
FAX: 3193937258
Oasis Sales
Suite 203
4905 Lakeside Dr., NE
Cedar Rapids, IA 52402
TEL: (319) 377-8738
FAX: 3193778803

## KANSAS

Advanced Technical Sales, Inc.
Suite 8
601 North Mur-Len
Olathe, KS 66062
TEL: (913) 782-8702
FAX: 9137828641
KENTUCKY
Giesting \& Associates
212 Grayhawk Court
Versailles, KY 40383
TEL: (606) 873-2330
FAX: 6068736233

MARYLAND
New Era Sales, Inc. 678 Ritchie Highway Severna Park, MD 21146
TEL: (410) 544-4100
FAX: 410 544-6092

MASSACHUSETTS
Harris Semiconductor

* Suite 240

3 Burlington Woods
Burlington, MA 01803
TEL: (617) 221-1850
FAX: 6172211866
Advanced Tech Sales
Suite 102
348 Park Street
Park Place West
N. Reading, MA 01864

TEL: (508) 664-0888
FAX: 5086645503

## MICHIGAN

Harris Semiconductor

* Suite 460 27777 Franklin Rd. Southfield, MI 48034
TEL: (313) 746-0800
FAX: 3137460516
Giesting \& Associates
Suite 113
34441 Eight Mile Rd.
Livonia, MI 48152
TEL: (313) 478-8106
FAX: 3134776908
6898 Curtis Dr.
Coloma, MI 49038
TEL: 616-468-4200
FAX: 6164686511
1279 Skyhills N.E.
Comstock Park, MI 49321
TEL: (616) 784-9437
FAX: 6167849438


## MINNESOTA

Oasis Sales
Suite 210
7805 Telegraph Road
Bloomington, MN 55438
TEL: (612) 941-1917
FAX: 6129415701

## MISSOURI

Advanced Technical Sales 13755 St. Charles Rock Rd. Bridgeton, MO 63044
TEL: (314) 291-5003
FAX: 3142917958

## NEW JERSEY

Harris Semiconductor

* Suite 210 North 6000 Midlantic Drive
Mt. Laurel, NJ 08054
TEL: (609) 727-1909
FAX: 6097279099


| ALABAMA Arrow/Schweber Huntsville TEL: (205) 837-6955 | Hamilton/Avnet | COLORADO | ILLINOIS |
| :---: | :---: | :---: | :---: |
|  | Costa Mesa | Anthem | Anthem |
|  | TEL: (714) 641-6111 | Englewood | Schaumburg |
|  | Costa Mesa | TEL: (303) 790-4500 | TEL: (708) 884-0200 |
| Hall-Mark | TEL: (714) 641-4100 | Arrow/Schweber | Arrow/Schweber |
| Huntsville | Gardena | Englewood | Itasca |
| TEL: (205) 837-8700 | TEL: (310) 217-2046 | TEL: (303) 799-0258 | TEL: (708) 250-0500 |
| Hamilton/Avnet | Culver City | Hall-Mark | Hall-Mark |
| Huntsville | TEL: (310) 558-2000 | Englewood | Wood Dale |
| TEL: (205) 837-7210 | Roseville | TEL: (303) 790-1662 | TEL: (312) 860-3800 |
|  | TEL: (916) 781-6614 | Hamilton/Avnet | Hamilton/Avnet |
| ARIZONA <br> Anthem Tempe TEL: (602) 966-6600 | San Diego | Englewood | Benserville |
|  | TEL: (619) 571-7525 | TEL: (303) 799-7800 | TEL: (708) 860-8566 |
|  | Sunnyvale | Colorado Springs | Newark |
|  | TEL: (408) 743-3300 | TEL: (719) 637-0055 | Chicago |
| Arrow/Schweber <br> Tempe <br> TEL: (602) 431-0030 | Woodland Hills | Wyle Laboratories | TEL: (312) 784-5100 |
|  | TEL: (818) 700-6545 | TEL: (303) 457-9953 | INDIANA |
|  | Wyle Laboratories |  | Arrow/Schweber |
| Hall-Mark <br> Phoenix <br> TEL (602) 437-1200 | Calabasas ${ }^{\text {TEL: }}$ (818) $880-9000$ | CONNECTICUT | Indianapolis <br> TEL: (317) 299-2071 |
|  |  | Anthem ${ }^{\text {Waterbury }}$ | Hall-Mark |
| Hamilton/Avnet Chandler TEL: (602) 961-6411 | TEL.: (714) 863-9953 | TEL: (203) 575-1575 | Indianapolis |
|  | Rancho Cordova | Arrow/Schweber | TEL: (317) 872-8875 |
| Wyle Laboratories Phoenix <br> TEL: (602) 437-2088 | TEL: (916) 638-5282 | Wallingford <br> TEL (203) 265-7741 | Hamilton/Avnet Carmel |
|  | $\begin{aligned} & \text { San Diego } \\ & \text { TEL: (619) 565-9171 } \end{aligned}$ | Falcon | TEL: (317) 844-9333 |
|  | Santa Clara | TEL: (203) 878-5272 | IOWA |
| CALIFORNIA Anthem Chatsworth TEL: (818) 700-1000 | TEL: (408) 727-2500 | Hall-Mark | Arrow/Schweber |
|  |  | Cheshire | Cedar Rapids |
|  | CANADA | TEL: (203) 271-2844 | TEL: (319) 395-7230 |
|  | Arrow/Schweber | Hamilton/Avnet | Hamilton/Avnet |
| E. Irvine <br> TEL: (714) 768-444 | Burnaby, British Columbia <br> TEL: (604) 421-2333 | Danbury | Cedar Rapids TEL: (319) 362-4757 |
| Rocklin <br> TEL: (916) 624-9744 | Dorval, Quebec |  |  |
|  | TEL: (514) 421.7411 | FLORIDA | KANSAS |
| San Diego <br> TEL: (619) 453-9005 | Nepan, Ontario | Arrow/Schweber | Lenexia |
|  | TEL: (613) 226-6903 | Deerrield Beach | TEL: (913)541-9542 |
| San Jose <br> TEL: (408) 452-2287 | Mississagua, Ontario | Lake Mary | Hall-Mark |
|  | TEL: (416) 670-7769 | TEL: (407) 333-9300 | Lenexa |
| Arrow/Schweber <br> Calabasas <br> TEL:(818) 880-9686 | Hamilton/Avnet Burnaby, B.C. | Hall Mark | TEL: (913) 888-4747 |
|  | Burnaby, B.c. <br> TEL: (604) 420-4101 | Casselberry | Hamilton/Avnet |
|  | Mississaugua, Ontario | TEL: (407) 830-5855 | TEL: (913) 541-7924 |
| Irvine <br> TEL: (714) 454-4372 | TEL: (416) 564-6060 | Largo (813) $541-7440$ |  |
| San Diego TEL: (619) 565-4800 | Nepean, Ontario <br> TEL: (613) 727-7501 | Pompano Beach TEL: (305) 971-9280 | KENTUCKY <br> Hamilton/Avnet Lexington |
| San Jose <br> TEL: (408) 441-9700 <br> TEL: (408) 432-7171 | St. Laurent, Quebec TEL: (514) 335-1000 | Hamilton/Avnet Ft. Lauderdale | TEL: (606) 288-4911 |
|  | ITT Multicomponents | TEL: (305) 733-6300 | MARYLAND |
| Hall-Mark <br> Chatsworth <br> TEL: (818) 773-4500 | Vancouver <br> TEL: (604) 421-6222 | St. Petersburg TEL: (813) 573-3930 | Anthem Columbia |
|  | Calgary, Alberta | Winter Park | TEL: (410) 995-6640 |
| Rocklin <br> TEL: (916) 624-9781 | TEL: (403) 273-2780 | TEL: (407) 657-9018 | Arrow/Schweber |
|  | Concord, Ontario |  | Columbia |
| San Diego TEL: (619) 268-1201 | TEL: (416) 798-4884 | GEORGIA | TEL: (410) 596-7800 |
|  | Edmonton, Alberta | Arrow/Schweber | Falcon |
| San Jose <br> TEL: (408) 432-4000 | TEL: (800) 332-8387 | TEL: (404)497-1300 | TEL: (410) 247-5800 |
| Irvine <br> TEL: (714) 727-6000 | V. St. Laurent, Quebec <br> TEL: (514) 335-7697 | Hall-Mark Duluth | Hall-Mark Columbia |
|  | Nepean, Ontario | TEL: (404) 623-4400 | TEL: (410) 988-9800 |
|  | TEL: (613) 596-6980 | Hamilton/Avnet | Hamilton/Avnet |
|  | Winnipeg, Manitoba <br> TEL: (204) 786-8401 | Duluth <br> TEL: (404) 623-5475 | $\begin{aligned} & \text { Columbia } \\ & \text { TEL: (410) 995-3528 } \end{aligned}$ |


| MASSACHUSETTS Anthem Wilmington TEL：（508）657－5170 | Pinebrook | Highland Heights | Hamilton／Avnet |
| :---: | :---: | :---: | :---: |
|  | TEL：（201）227－7880 | TEL：（216）442－3441 | Austin TEL: (512) 832-4306 |
|  | Parsippany | Worthington | Dallas |
|  | TEL：（201）515－3000 | TEL：（614）888－3313 | TEL：（214）404－9906 |
| Arrow／Schweber Wilmington <br> TEL：（508）658－0900 | Moorestown <br> TEL．：（609）235－1900 | Solon <br> TEL：（216）349－4632 | Stafford TEL：（713）274－9336 |
| Gerber Norwood TEL：（617）769－6000 | Hamilton／Avnet Cherry Hill TEL：（609）424－0100 | Hamilton／Avnet <br> Dayton <br> TEL：（513）439－6700 | Wyle Laboratories Austin <br> TEL：（512）345－8853 |
|  |  | TEL：（513）439－6721 | Houston |
| Hall－Mark Billerica TEL：（508）667－0902 | TEL：（201）515－5300 | Columbus | TEL：（713）879－9953 |
|  |  | TEL：（614）882－7389 | Richardson |
| Hamilton／Avnet <br> Peabody <br> TEL：（508）531－7430 | Hamilton／Avnet | Solon | EL：（214） |
|  | Albuquerque |  | UTAH |
|  | TEL：（505）765－1500 | OKLAHOMA | Anthem |
| MICHIGAN <br> Arrow／Schweber Livonia TEL：（313）462－2290 | NEW YORK | Arrow／Schweber | Salt Lake City TEL: (801) 973-8555 |
|  | Anthem | TEL：（918）252－7537 | Arrow／Schweber |
|  | Commack | Hall－Mark | Salt Lake City |
|  | TEL：（516）864－6600 | Tulisa | TEL：（801）973－6913 |
| Hall－Mark <br> Livonia <br> TEL：（313）462－1205 | Falcon | TEL：（918）254－6110 | Hamilton／Avnet |
|  | Hauppauge | Hamilton／Avnet | Salt Lake City |
| Hamilton／Avnet <br> Novi <br> TEL：（313）347－4270 |  | Tulsa | TEL：（801）266－2022 |
|  | Hauppauge | TEL：（918）252－7297 | Wyle Laboratories West Valley |
|  | TEL：（516）231－1000 | OREGON | TEL：（801）974－9953 |
| Grandville <br> TEL：（616）531－0345 | Rochester | Almac／Arrow |  |
|  | TEL：（716）427－0300 | Beaverton | WASHINGTON |
| MINNESOTA <br> Anthem Eden Prairie TEL：（612）944－5454 | Hall－Mark | TEL：（503）629－8090 | Almac／Arrow |
|  | Fairport | Anthem | Bellevue |
|  | TEL：（716）425－3300 | Beaverton | TEL：（206）643－9992 |
|  | Ronkonkoma | TEL：（503）643－1114 | Spokane |
| Arrow／Schweber Eden Prarie TEL：（612）941－5280 | TEL：（516）737－0600 | Hamilton／Avnet | TEL：（509）924－9500 |
|  | Hamilton／Avnet | Beaverton | Anthem |
|  | Syracuse | （503）627－0201 | TEL：（206）483－1700 |
| Hall－Mark <br> Bloomington <br> TEL：（612）941－2600 | TEL：（315）434－2426 | Wyle Laboratories | Hall－Mark |
|  | Hauppauge ${ }^{\text {TEL：（516）434－7490 }}$ | TEL：（503）643－7900 | Seattle |
|  | TEL：（516）434－7490 |  | TEL：（206）547－0415 |
| Hamilton／Avnet Minnetonka <br> TEL：（612）932－0600 | Rochester | PENNSYLVANIA | TEL：1－800－548－3976 |
|  | TEL：（716）475－9130 | Anthem | FAX： 2066324814 |
|  | Westbury | Horsham | Hamilton／Avnet |
|  | TEL：（516）997－6868 | TEL：（215）443－5150 | Redmond |
| MISSOURI Arrow／Schweber St．Louis TEL：（314）567－6888 |  | Arrow／Schweber | TEL．（206）881－6697 |
|  | NORTH CAROLINA | Pittsburgh | Wyle Laboratories |
|  | Arrow／Schweber | TEL：（412）963－6807 | Redmond |
|  | Raleigh |  | TEL：（206）881－1150 |
| Hall－Mark <br> Earth City <br> TEL：（314）291－5350 | TEL：（919）876－3132 | Pittsburgh |  |
|  | EMC | TEL：（412）772－1881 | WISCONSIN |
|  | Charlotte |  | Arrow／Schweber |
| Hamilton／Avnet Chesterfield TEL：（314）537－1600 | （704）394－6195 | TEXAS | Brookfield |
|  | Hall－Mark | Arrow／Schweber | TEL：（414）792－0150 |
|  | Raleigh | Austin | Hall－Mark |
|  | TEL：（919）878－0712 | TEL：（512）835－4180 | New Berlin |
| NEW HAMPSHIRE <br> Hamilton／Avnet Manchester TEL：（603）624－9400 | Hamilton／Avnet | Dallas | TEL：（414）797－7844 |
|  | Raleigh | TEL：（214）380－6464 | Hamilton／Avnet |
|  | TEL：（919）878－0819 | Houston | Waukesha |
|  | OHIO | TEL：（713）530－4700 | TEL：（414）784－4518 |
| NEW JERSEY Anthem Pinebrook TEL：（201）277－7960 Arrow／Schweber Marlton TEL：（609）596－8000 | Arrow／Schweber |  | South American |
|  | Solon | TEL：（512）258－8848 | Authorized Distributor |
|  | Centerville | Dallas | Graftec Electronic Sales Inc． |
|  | TEL：（513）435－5563 | TEL：（214）343－5000 | One Boca Place，Suite 305 East |
|  | EMC | TEL：（214）553－4300 |  |
|  | Columbus <br> TEL：（614）299－4161 | $\begin{aligned} & \text { Houston } \\ & \text { TEL: (713) 781-6100 } \end{aligned}$ | TEL：（407）994－0933 |



|  |  |  |  |
| :---: | :---: | :---: | :---: |
|  |  |  |  |
| Harris Semiconductor Chip Distributors | Silverstar Ltd． <br> Viale Fulvio Testi 280 | SWITZERLAND | Thame Components Thame Park Rd． |
| Hybritech CM（HCM） | 1－20126 Milano | BASIX fur Elektronik AG | Thame，Oxfordshire OX9 3UQ |
| 7，Avenue Juliot Curie | TEL： 392661251 | Hardturmstrasse 181 | TEL： 44844261188 |
| F－17027 LA Rochelle Cedex | FAX： 39266101359 |  | FAX： 44844261681 |
| TEL： 3346451270 | TWX： 332189 |  | TWX： 837917 |
| FAX： 3346450444 TWX： 793034 | NETHERLANDS | FAX： 4112761234 TWX： 822966 | Harris Semiconductor Chlp Distributors |
| Edgetek | ＊Auriema Nederland BV |  | Die Technology Ltd． |
| Zai De Courtaboeuf | Doornakkersweg， 26 | TURKEY | Corbrook Rd． |
| Avenue Des Andes | NL－5642 MP Eindhoven | EMPA | Chadderton |
| 91952 Les Ulis Cedex | TEL： 3140816565 | Elektronik Mamulleri | Lancashire OL9 9SD |
| TEL： 33164460650 | FAX： 3140811815 | Pazarlama AS | TEL： 44616263827 |
| FAX： 33169284396 | TWX： 51992 | Besyol Londra Asfalti | FAX： 44616274321 |
| TWX： 600333 | Diode Components BV | 34630 Sefakoy／Istanbul | TLX： 668570 |
| Eltek Semiconducteurs | Coltbaan 17 | TEL： 9015993050 | Eltek Semiconductor Ltd． |
| Z．A．De La Tuilerie | NL－ 3439 NG Nieuwegein | FAX： 9015985353 | Nelson Rd．Industrial Estate |
| B．P． 1077 | TEL： 31340235924 | TWX： 21137 | Dartmouth |
| 78204 Mantes－La－Jolie | FAX： 31340291234 |  | Devon TQ6 9NA |
| TEI： 33134771616 |  | UNITED KINGDOM | TEL： 44803834455 |
| FAX： 33134779579 | NORWAY | Avnet Access Ltd | FAX： 44803833011 |
| TWX： 699737 | Hans H．Schive ASS | Jubilee House | Rood Technology |
|  | Undelstadia 27 | Jubilee Road | Test House Mill Lane |
| FINLAND | Postboks 185 | Letchworth | Alton |
| Yleiselektronilikka OY | N－1371 Asker | Hertfordshire SG6 1QH | Hampshire GU34 2QG |
| Telercas | TEL： 472900900 | TEL： 44462480888 | TEL： 4442088022 |
| P．O．Box 63 | FAX： 472904484 | FAX： 44462682467 | FAX： 4442087259 |
| Luomannotko， 6 | TWX： 19124 | TWX： 826505 | TLX： 858456 |
| SF－ 02201 Espoo |  | ESD Distribution Ltd |  |
| TEL： 35804521622 | PORTUGAL | Edinburgh Way | GERMANY |
| FAX： 35804523337 | Cristalonica | Harlow | Alfred Neye Enatechnik GmbH |
|  | Componentes De Radio E | Essex CM20 2DE | Schillerstrasse 14 |
| GREECE | Televisao，Lda | TEL： 44279626777 | D－ 2085 Quickborn |
| Semicon Co． | Rua Bernardim Ribeiro， 25 | FAX： 44279441687 | TEL： 4941066120 |
| 104 Aeolou Street | P－1100 Lisbon | TWX： 818801 | FAX： 494106612268 |
| GR－ 10564 Athens | TEL： 35113534631 | Farnell Electronic | TWX： 213590 |
| TEL： 3013253626 | FAX： 351135617 | Components Ltd． | Bit－Electronic AG |
| FAX： 3013216063 TWX： 216684 | TWX： 64119 | Marketing \＆Purchasing Div． | Dingolfinger Strasse 6 |
|  |  | Armley Road，Leeds | Postfach 800245 |
|  | SPAIN | West Yorkshire LS12 2QQ | D－ 8000 Muenchen 80 |
| ISRAEL | Amitron S．A． | TEL： 44532790101 | TEL： 49894180070 |
| Aviv Electronics Ltd | Avenida Valladolid 47D BAJO | FAX： 44532633404 | FAX： 498941800720 |
| P．O．Box 24190 | SP－ 28008 Madrid | TWX： 55147 | TWX： 5212931 |
| 5，Arad Street | TEL： 3415420906 |  |  |
| Ramat Hahayal | TEL： 3415479313 | Vestry Industrial Estate | Electronic Components |
| IS－Tel－Aviv 69710 | FAX： 3412487958 | Sevenoaks | Service |
| TEL： 97235447262 | TWX： 45550 | Kent TN14 5EU | Carl－Zeiss Strasse 3 |
| FAX： 97235447650 | EBV Elekronik S．A． | TEL： 44732743743 | D－2085 Quickborn |
| TWX： 33572 | Salvatierra 4 | FAX： 44732451251 | TEL： 49410670050 |
|  | SP－ 28034 Madrid | TWX： 95142 | FAX： 494106700537 |
| ITALY | TEL： 3413581835 | Macro Marketing Ltd | TWX： 213693 |
| Eurelettronica SpA | FAX： 3417293752 | Burnham Lane |  |
| Via Enrico Fermi， 8 | TWX： 23382 | Slough，Berkshire SL1 6LN | GmbH |
| I－20090 Assago（MI） |  | TEL： 44628604422 | Postfach 1563 |
| TEL： 3924880022 | SWEDEN | FAX： 44628666873 | Emil Kommerling Str． 5 |
| FAX： 3924880275 | Martinsson Elektronik AB | TWX： 847945 | E－6780 Pirmasens |
| EBV Elektronik SRL | Instrumentvaegen 15 | Micromark Electronics Ltd． | TEL： 49633194065 |
| Via Frova， 34 | Box 9060 | Boyn Valley Road | FAX： 49633194064 |
| F－20092 Cinisello Balsamo | S－ 12609 Hagersten | Maidenhead | TWX： 452269 |
| （MI） | TEL： 4687440300 | Berkshire SL6 4DT |  |
| TEL： 392660.17111 | FAX： 4687743403 | TEL： 4462876176 | Jermyn GmbH |
| FAX： 392660.17020 | TWX： 13077 | FAX： 44628783799 | D－ 6250 Limburg 4 |
| Lasi Elettronica SpA |  | TWX： 847397 | TEL： 4964315080 |
| Viale Fulvio Testi 280 |  |  | FAX： 496431508289 |
| 1－20126 Milano |  |  | TLX： 4152570 |
| TEL： 39266101370 |  |  |  |
| FAX： 39266101385 |  |  |  |
| TWX： 352040 |  |  | European Distributors <br> （Continued Next Page） |
|  | ＊Field Application | ssistance Available |  |

European Distributors
(Continued)
Sasco GmbH
Hermann-Oberth Strasse 16
D - 8011 Putzbrunn-Bei-Muenchen
TEL: 498946110
FAX: 49894611270
TWX: 529504
Spoerle Electronic KG Max-Planck Strasse 1-3
D-6072 Dreieich 1- Bei-Frankfurt TEL: 4961033048 FAX: 496103304201 TWX: 417972

NORTH ASIA<br>Sales Headquarters JAPAN<br>Harris K.K.<br>Shinjuku NS Bldg. Box 6153<br>2-4-1 Nishi-Shinjuku<br>Shinjuku-ku, Tokyo 163-08<br>Japan<br>TEL: 81-3-3345-8911<br>FAX: 81-3-3345-8910

## SOUTH ASIA

Sales Headquarters
HONG KONG
Harris Semiconductor H.K.
Ltd.
13/F Fourseas Building
208-212 Nathan Road
Tsimshatsui, Kowloon
TEL: 852-723-6339
FAX: 852-739-8946
TLX: 78043645

| AUSTRALIA <br> VSI Promark Electronics Pty Ltd 16 Dickson Avenue Artarmon NSW 2064 TEL.: (61) 2-439-4655 FAX: (61) 2-439-6435 | SINGAPORE |
| :---: | :---: |
|  | Harris Semiconductor |
|  | Pte Ltd. |
|  | 105 Boon Keng Road |
|  | \#01-01 Singapore 1233 |
|  | Att: Sales Office |
|  | TEL: 65-291-0203 |
|  | FAX: 65-293-4301 |
| KOREA TLX: RS36460 RCASIN |  |
|  |  |
| RM \#419-1 4TH FL. | TAIWAN |
| Korea Air Terminal Bldg. | Harris Semiconductor |
| 159-1, Sam Sung-Dong, | Room 1103 |
| Kang Nam-ku, Seoul | 600 Ming Chuan East Road |
| 135-728, Korea | Taipei |
| TEL: 82-2-551-0931/4 | TEL: 886-2-716-9310 |
| FAX: 82-2-551-0930 | FAX: 886-2-715-3029 |
| Inhwa Company, Ltd. 3 Flr., Suh Kang Bldg. |  |
|  |  |
| \#789-21, Yoksam-dong, |  |
| Kangnam-ku, Seoul |  |
| TEL: 822-554-7341 |  |
| FAX: 822-557-5043 |  |

## Asian Pacific Authorized Distributors

| AUSTRALIA | Electrocon Products, Ltd. | Takachiho Koheki Co., Ltd. |
| :---: | :---: | :---: |
| VSI Promark Electronics | 8F, Block B | 1-2-8, Yotsuya |
| Pty Ltd | Prosperity Centre | Shinjuku-ku, Tokyo 160 |
| 16 Dickson Avenue | 77 Container Port Road | TEL: 03-3355-6696 |
| Artarmon, NSW 2064 | Kwai Chung, N.T. | FAX: 03-3357-5034 |
| TEL: (61) 2-439-4655 | TEL: (852) 481-6022 |  |
| FAX: (61) 2-439-6435 | FAX: (852) 481-5804 | KOREA |
| HONG KONG | JAPAN | KumOh Electric Co., Lt 203-1, Jangsa-Dong, |
| Dodwell Engineering | Hakuto Co., Ltd. | Chongro-ku, Seoul |
| 7/F, Cavendish Centre | Toranomon Sangyo Bldg. | TEL: 822-279-3614 |
| 23 Yip Hing Street | 1-2-29, Toranomon | FAX: 822-272-6496 |
| Wong Chuk Hang <br> TEL: (852) 555-4633 | Minato-ku, Tokyo 105 <br> TEL: 03-3225-8910 | Inhwa Company, Ltd. 3 Flr., Suh Kang Bldg. |
| FAX: (852) 873-0625 | FAX: 03-3597-8975 | \#789-21, Yoksam-dong, |
| Karin Electronic Supplies Co., Ltd. | Macnica Inc. <br> Hakusan High Tech Park | Kangnam-ku, Seoul TEL: 822-554-7341 |
| 7F, Karin Bldg. | 1-22-2, Hakusan | FAX: 822-557-5043 |
| 166 Wai Yip Street | Midori-ku, Yokohama-shi, |  |
| Kwun Tong, Kowloon | Kanagawa 226 | NEW ZEALAND |
| TEL: (852) 389-8252 | TEL: 045-939-6116 | Components and Instru- |
| FAX: (852) 343-6479 | FAX: 045-939-6117 | mentation NZ, Ltd. |
| Means Come Ltd. | Jepico Corp. | Semple Street |
| Room 1007, Harbour Centre | Shinjuku Daiichi Seimei Bldg. | Porirua, Wellington |
| 8 Hok Cheung Street | 2-7-1, Nishi-Shinjuku | P.O. Box 50-548 |
| Hung Hom, Kowloon | Shinjuku-ku, Tokyo 163 | TEL: (64) 4-237-5632 |
| TEL: (852) 334-8188 | TEL: 03-3348-0611 | FAX: (64) 4-237-8392 |
| FAX: (852) 334-8649 | FAX: 03-3348-0623 |  |
| Sunnice Electronics Co., Ltd. | Micron, Inc. | PHILIPPINES |
| Flat F, 5/F, Everest Ind. Ctr. | Misuzu Bldg. | Crystalsem, Inc. |
| 396 Kwun Tong Road | 4-27-12, Sendagaya, | 216 Ortega Street |
| Kowloon, | Shibuya-Ku, Tokyo 151 | San Juan, Metro |
| TEL: (852) 790-8073 | TEL: 03-3796-1860 | Manila 3134 |
| FAX: (852) 763-5477 | FAX: 03-3796-1866 | TEL: (632) 79-05-29 |
| Willas Co., Ltd. | Okura Electronics Co., Ltd. | TLX: 722-22031 (IMCPH) |
| 8F, Wing Tai Centre | 2-3-6, Ginza Chuo-ku, |  |
| 12 Hing Yip Street | Tokyo 104 |  |
| Kwun Tong, Kowloon | TEL: 03-3564-6871 |  |
| TEL: (852) 3414281 | FAX: 03-3564-6870 |  |
| FAX: (852) 3431229 |  |  |

SINGAPORE
B.B.S Electronics PTE, Ltd. 1 Genting Link
\#06-03 Perfect Indust. Bldg.
Singapore 1334
TEL: (65) 7488400
FAX: (65) 7488466
Device Electronics PTE, Ltd. 605B MacPherson Road 04-12 Citimac Ind. Complex Singapore 1336
TEL: (65) 2886455
FAX: (65) 2879197
TAIWAN
Galaxy Far East Corporation
8F-6, No. 390, Sec. 1
Fu Hsing South Road
Taipei, Taiwan
TEL: 886-2-705-7266
FAX: 886-2-708-7901
Acer Sertek Inc.
3F, No. 135, Sec. 2
Chien Kuo N. Road
Taipei, Taiwan
TEL: (886) 2-501-0055
FAX: (886) 2-501-2521
TECO Enterprise Co., Ltd.
10FL., No. 292, Min-Sheng
W. Road, Taipei

Taiwan, ROC
TEL: (886) 2-521-9676
FAX: (886) 2-542-6006

## THAILAND

Grawinner Co., Ltd.
226/227 Phahonyothin Rd.
Phyathai, Bangkok 10400
TEL: (662) 271-8742
FAX: (662) 271-2494

## We're Backing You Up with Products, Support, and Solutions!

## Signal Processing

- Linear
- Custom Linear
- Data Conversion
- Interface
- Analog Switches
- Multiplexers
- Filters
- DSP
- Telecom


## Digital

- CMOS Microprocessors and Peripherals
- CMOS Microcontrollers
- CMOS Logic


## Microwave

- GaAs FETs
- GaAs MMICs
- Foundry Services


## Power Products

- Power MOSFETS
- IGBTS
- Bipolar Discretes
- Transient Voltage Suppressors
- Power Rectifiers


## Intelligent Power

- Power ICs
- Power ASICs
- Hybrid Programmable Switches
- Full-Custom High Voltage ICs


## ASICs

- Full-Custom
- Analog Semicustom
- Mixed-Signal
- ASIC Design Software

Military/Aerospace Products

- Microprocessors and Peripherals
- Memories
- Analog IC
- Digital ICs.
- Discrete Power
- Bipolar
- MOSFET
- Rad-Hard ICs

Military/Aerospace Programs

- COMSEC Programs
- Strategic and Space Programs
- Military ASIC Programs


[^0]:    2. Transition is measured at $\pm 200 \mathrm{mV}$ from steady state voltage, Output loading per test load circuit, with $V_{1}=1.5 \mathrm{~V}, \mathrm{R}_{1}=500 \Omega$ and $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$.
[^1]:    1. Controlled by design or process parameters and not directly tested. Characterized upon initial design and after major process and/or design changes.
    2. Transition is measured at $\pm 200 \mathrm{mV}$ from steady state voltage with loading as specified in test load circuit with and $C_{L}=40 \mathrm{pF}$.
    3. A.C. Testing is performed as follows: Input levels (CLK Input) 4.0 O and OV , Input levels (all other Inputs) OV and 3.0 V , Timing reference levels (CLK) $=2.0 \mathrm{~V}$, (Others) $=1.5 \mathrm{~V}$, Output load per test load circuit and $C_{L}=40 \mathrm{pF}$.
    4. Applies only when $\mathrm{H} \_$BYP $=1$ or H _DRATE $=0$.
[^2]:    1. Power supply current is proportional to operating frequency. Typical
    2. Output load per test load circuit with switch open and $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$. rating for $I_{C C O P}$ is $3 \mathrm{~mA} / \mathrm{MHz}$.
    3. Not tested, but characterized at initial design and at major process/design changes.
[^3]:    This work was supported by Harris Semiconductor (Harris ) and The Keenan Corporation (TKC). The authors thank the external reviewers, Mr. Richard E. Funk, Manager, Applications Engineering, Harris Semiconductor, and Dr. Leonard Rosi, EMC Engineer, of Hewlett-Packard's Corvallis Workstation Operation, for their helpful comments.

[^4]:    Copyright Notice: Copyright 1989, TKC. Reprinted by Harris Semiconductor, April 1989, with permission of TKC.

[^5]:    * Examples are for $\mathrm{Z}_{\mathrm{O}}=50, \mathrm{C}_{1}=5 \mathrm{pF}, \mathrm{V}_{\mathrm{CC}}=5, \mathrm{f}_{\mathrm{C}}=30 \mathrm{MHz}$, Duty Cycle $=50 \%$

