# HSP9501 January 1994 ## **Programmable Data Buffer** #### Features - DC to 32MHz 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 #### **Applications** - · Sample Rate Conversion - · Data Time Compression/Expansion - · Software Controlled Data Alignment - · Programmable Serial Data Shifting - · Audio/Speech Data Processing Video/Image 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 ## Ordering Information | PART NUMBER | TEMPERATURE<br>RANGE | PACKAGE | |--------------|----------------------|--------------| | HSP9501JC-25 | 0°C to +70°C | 44 Lead PLCC | | HSP9501JC-32 | 0°C to +70°C | 44 Lead PLCC | #### 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 (LC0-10) and the length control enable (LCEN#). An 11-bit value is applied to the LC0-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. ## HSP9501 # Pin Descriptions | NAME | PIN<br>NUMBER | TYPE | DESCRIPTION | |--------|---------------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Vcc | 12, 34 | | The +5V power supply pin. A 0.1 μF capacitor between the V <sub>CC</sub> and GND pin is recommended. | | GND | 13,33 | | The device ground. | | CLK | 1 | I | 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. | | DI0-9 | 27, 29-32,<br>35-39 | _ | Data Inputs. This 10-bit input port is used to provide the input data. When MODSEL is low, data on the DI0-9 inputs is latched on the clock edge selected by CLKSEL. | | DO0-9 | 7-11,<br>14-18 | 0 | Data Outputs. This 10-bit port provides the output data from the internal delay registers. Data latched into the DI0-9 inputs will appear at the DO0-9 outputs on the Nth clock cycle, where N is the total delay programmed. | | LC0-10 | 20-26,<br>41-44 | - | Length Control Inputs. These inputs are used to specify the number of clock cycles of delay between the DI0-9 inputs and the DO0-9 outputs. An integer value between 0 and 1279 is placed on the LC0-10 inputs, and the total delay length (N) programmed is the LC0-10 value plus 2. In order to properly load an active length control word, the value must be presented to the LC0-10 inputs and LCEN# must be asserted during an active clock edge selected by CLKSEL. | | LCEN# | 6 | ı | Length Control Enable. LCEN# is used in conjuction with LCO-10 and CLK to load a new length control word. An 11-bit value is loaded on the LCO-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 | I | 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 | ı | 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 DI0-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 | ı | 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 | I | 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. This signal takes effect on the clock following the one that latches it in. | ## 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 (DIO-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 (DI0-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 (LC0-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 LC0-10 plus 2. The programmed delay is established by the 11-bit integer value of the LC0-10 inputs with LC10 as the MSB and LC0 as the LSB. #### For example, | LC10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | LC0 | |------|---|---|---|---|---|---|---|---|---|-----| | 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 LC0-10 must not exceed 1279. Controlled operation with larger values is not guaranteed. Values on LC0-10 are latched on the CLK edge selected by the CLKSEL control line, when LCEN# is active. LC0-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<br>210 | LC9<br>29 | LS8<br>2 <sup>8</sup> | LC7<br>2 <sup>7</sup> | LC6<br>26 | LC5<br>25 | LC4<br>24 | LC3<br>2 <sup>3</sup> | LC2<br>2 <sup>2</sup> | LC1<br>21 | LC0<br>20 | 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 | ## Specifications HSP9501 #### **Absolute Maximum Ratings** | Supply Voltage | +8.0V | |--------------------------------------------------------------------------------------------|----------| | Input or Output Voltage Applied | | | Storage Temperature Range | | | Junction Temperature | +150°C | | Maximum Package Power Dissipation | 1.7W | | θJC | 16.4°C/W | | θ.;Δ | | | Lead Temperature (Soldering, Ten Seconds) | +300°C | | CAUTION: Stresses above those listed in the "Absolute Maximum Ratings" may cause permanent | | ## **Operating Conditions** | Operating Voltage Range | . +4.75V to +5.25V | |-----------------------------|--------------------| | Operating Temperature Range | 0°C to +70°C | ## **D.C. Electrical Specifications** ( $V_{CC} = 5.0V + 5\%$ , $T_A = 0^{\circ}C$ to +70°C, Commercial) | PARAMETER | SYMBOL | MIN | MAX | UNITS | TEST CONDITIONS | | |--------------------------------|------------------|-----|-----|-------|-------------------------------------------------------------------------------------------|--| | Logical One Input Voltage | V <sub>1H</sub> | 2.0 | _ | V | V <sub>CC</sub> = 5.25V | | | Logical Zero Input Voltage | V <sub>I</sub> L | - | 0.8 | ٧ | V <sub>CC</sub> = 4.75V | | | Output HIGH Voltage | V <sub>OH</sub> | 2.4 | - | ٧ | I <sub>OH</sub> = -4mA V <sub>CC</sub> = 4.75V | | | Output LOW Voltage | VOL | | 0.4 | V _ | I <sub>OL</sub> = +4.0mA V <sub>CC</sub> = 4.75V | | | Input Leakage Current | II | -10 | 10 | μА | V <sub>IN</sub> = GND or V <sub>CC</sub> V <sub>CC</sub> = 5.25V | | | Output Leakage Current | Ю | -10 | 10 | μA | VOUT = GND or VCC VCC = 5.25V | | | Standby Current | ICCSB | - | 500 | μА | $V_{IN} = V_{CC}$ or GND, $V_{CC} = 5.25V$ ,<br>Note 2 | | | Operating Power Supply Current | ICCOP | - | 125 | mA | t = 25MHz, V <sub>IN</sub> = V <sub>CC</sub> or GND<br>V <sub>CC</sub> = 5.25V, Note 1, 2 | | | Input Capacitance | CIN | - | 10 | pF | FREQ = 1MHz, V <sub>CC</sub> = Open, | | | Output Capacitance | co | - | 10 | pF | All measurements are referenced to device GND | | ## A.C. Electrical Specifications ( $V_{CC}$ = 5.0V $\pm$ 5%, $T_A$ = 0°C to +70°C, Commercial), (Note 4) | | | : | 32 | -25 | | | | |------------------------|------------------|-----|-----|-----|-----|-------|------------| | PARAMETER | SYMBOL | MIN | MAX | MIN | MAX | UNITS | CONDITIONS | | Clock Period | T <sub>CP</sub> | 31 | - | 40 | - | ns | | | Clock Pulse Width High | T <sub>PWH</sub> | 12 | - | 15 | - | ns | | | Clock Pulse Width Low | ↑ <sub>PWL</sub> | 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 | T <sub>DIS</sub> | | 24 | - | 25 | ns | Note 3 | | CLKEN# to Clock Setup | TES | 10 | - | 12 | - | ns | | | CLKEN# to Clock Hold | <sup>™</sup> EH | 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 | | | MODSEL Setup Time | T <sub>MS</sub> | 10 | _ | 13 | - | ns | | | MODSEL Hold Time | Тмн | 2 | - | 2 | | ns | | | Clock to Data Out | Тоит | _ | 16 | - | 22 | ns | | | Output Hold from Clock | ТОН | 4 | - | 4 | - | ns | | | Rise, Fall Time | TRF | - | 6 | - | 6 | ns | Note 3 | #### NOTES: - Power supply current is proportional to operating frequency. Typical rating for I<sub>CCOP</sub> is 5mA/MHz. - 2. Output load per test load circuit with switch open and $C_L$ = 40pF. - Controlled by design or process parameters and not directly tested. Characterized upon initial design and after major process and/or design - A.C. Testing is performed as follows: Input levels: 0V and 3.0V, Timing reference levels = 1.5V, Input rise and fall times driven at 1ns/V, Output load C<sub>L</sub> ≈ 40pF.