Isppac 10: Features Functional Block Diagram
Isppac 10: Features Functional Block Diagram
Isppac 10: Features Functional Block Diagram
1 2 3 4 5 6 7 8 9 IA IA IA IA
OA
OA
Description
The ispPAC10 is a member of the Lattice family of InSystem Programmable analog circuits, digitally configured via nonvolatile E2CMOS technology. Analog function modules, called PACblocks, replace traditional analog components such as op amps and active filters, eliminating the need for most external resistors and capacitors. With no requirement for external configuration components, ispPAC10 expedites the design process, simplifying prototype circuit implementation and change, while providing high performance and integrated functionality. Designers configure the ispPAC10 and verify its performance using PAC-Designer, an easy-to-use, Microsoft Windows compatible development tool. Device programming is supported using PC parallel port I/O operations. A library of configurations is included with basic solutions and examples of advanced circuit techniques. The ispPAC10 is configured through its IEEE Standard 1149.1 (JTAG) compliant serial port. The flexible InSystem Programming capability enables programming, verification and reconfiguration if desired, directly on the printed circuit board.
OA
OA
15 OUT3+
Ain+ Ain-
Ref+ RefispPAC10
Copyright 2000 Lattice Semiconductor Corp. All brand or product names are trademarks or registered trademarks of their respective holders. The specifications and information herein are subject to change without notice.
LATTICE SEMICONDUCTOR CORP., 5555 Northeast Moore Ct., Hillsboro, Oregon 97124, U.S.A. Tel. (503) 268-8000; 1-800-LATTICE; FAX (503) 268-8556; http://www.latticesemi.com
September 2000
pac10_04
Specifications ispPAC10
TA = 25C; VS = 5.0V; Signal path = VIN to VOUT of one PACblock (second input unused); 1V VOUT 4V; Gain = 1; Output load = 200pf, 1M. Feedback enabled; Feedback capacitor = minimum; Auto-Cal initiated immediately prior. (Unless otherwise specified). .
DC Electrical Characteristics
SYMBOL PARAMETER CONDITION
Applied Either to VIN+ or VIN 2| VIN+ VIN | G = 10 G=1 -40 to +85C
MIN.
1 6
TYP.
MAX. UNITS
4 V Vp-p V mV V/C pF pA nV/Hz V Vp-p mA V dB % % ppm/C dB dB % V ppm/C A A VRMS dB cycles 0.8 VS 10 +40/-70 0.5 V V A A V V V mA mW C C
Analog Input VIN (1) Input Voltage Range VIN-DIFF Differential Input Voltage Swing (2) VOS (2) Differential Offset Voltage (Input Referred) VOS/T Differential Offset Voltage Drift RIN Input Resistance CIN Input Capacitance IB Input Bias Current eN Input Noise Voltage Density Analog Output VOUT Output Voltage Range VOUT-DIFF Differential Output Voltage Swing (2) IOUT Output Current VCM Common Mode Output Voltage Static Performance G Programmable Gain Range Gain Error Gain Matching G/T Gain Drift PSR Power Supply Rejection Common Mode Reference Output (VREFOUT) VREFOUT Reference Output Voltage Range CMVIN (4) Common Mode Voltage Input Reference Output Voltage Drift IREFOUT Reference Output Current Reference Output Noise Voltage Reference Power Supply Rejection Programming Erase/Reprogram Cycles Digital I/O VIL VIH IIL, IIH Input Low Voltage Input High Voltage Input Leakage Current
at DC At 10kHz, Referred to Input, G = 10 Present at Either VOUT+ or VOUT 2| VOUT+ VOUT | Source/Sink (VOUT+ + VOUT-)/2 ; VIN+ = VIN Each Individual PACblock RL = 300 Differential Between Two Inputs of Same PACblock -40 to +85C Differential at 1kHz Single-ended at 1kHz Nominally 2.500V Optional External Common-Mode Voltage -40 to +85C (VREFOUT = 1%) Source (VREFOUT = 1%) Sink 10MHz Bandwidth; 1F Bypass Capacitor 1kHz 0.1 9.6 10 2.495 0
20 0.2 50 109 2 3 38
100 1.0
4.9
2.500
VOL Output Low Voltage (TDO) VOH Output High Voltage (TDO) Power Supplies VS Operating Supply Voltage IS Supply Current PD Power Dissipation Temperature Range Operation Storage
0V TCK Input VS 0V CAL, TDI, TMS, TRST Inputs VS IOL = 4.0mA IOH = -1.0mA
Specifications ispPAC10
AC Electrical Characteristics
SYMBOL PARAMETER CONDITION
FIN = 10kHz FIN = 100kHz 0.1Hz to 100kHz 10kHz 100kHz
MIN.
TYP.
-88 -72 -67 -63 103 69 55 550 330 330 7.5 4.0 -90
MAX.
-74 -62
UNITS
dB dB dB dB dB dB dB kHz kHz kHz V/s s dB kHz % % %/C
Differential Single-Ended Differential Single-Ended SNR Signal to Noise G = 1 to 10 CMR Common Mode Rejection (VIN = 1V to 4V) Note: VIN+ and VIN- connected together BW Small Signal Bandwidth G=1 G = 10 BWFP Full Power Bandwidth VIN = 6 SR Slew Rate tS Settling Time 0.1% Crosstalk Filter Characteristics Filter Pole Programming Range F0 Absolute Pole Frequency Accuracy F0 Pole Step Size (Between Calculated Poles) F0/T Pole Frequency Change vs. Temperature
VDIFF, VOUT = -3dB; G=1 5.0 6VDIFF Input Step Between Any Two Channels Number of Poles in Range > 120 Deviation From Calculated Value 10kHz to 100kHz -40 to +85C 10
1.0 0.02
Notes: (1) A wider input range of 0.7V to 4.3V is typical, but not guaranteed. Inputs larger than this will be clipped. Input signals are also subject to common-mode voltage limitations. Refer to the table of conditions in this datasheet. (2) Refer to theory of operation section later in this datasheet for explanation of differential voltage swing computation. (3) To insure full spec performance an additional auto-calibration should be performed after initial turn-on and the device reaches thermal stability. (4) The user-provided voltage on this pin (CMVIN) becomes an optional (selected via programming) alternative to the default 2.5V VREFOUT.
Package Options
1
1
ispPAC10
28-Pin PDIP
ispPAC10
28-Pin SOIC
Device Family Device Number Performance Grade 01 = Standard Package P = PDIP, S = SOIC Grade Blank = Commercial I = Industrial Temperature
Specifications ispPAC10
Timing Specifications
TA = 25C; VS = +5.0V (Unless otherwise specified). SYMBOL PARAMETER CONDITION MIN. TYP. MAX. UNITS
Dynamic Performance tckmin Minimum Clock Period tckh TCK High Time tckl TCK Low Time tmss TMS Setup Time tmsh TMS Hold Time tdis TDI Setup Time tdih TDI Hold Time tdozx TDO Float to Valid Delay tdov TDO Valid Delay tdoxz TDO Valid to Float Delay trstmin Minimum reset pulse width tpwp Time for a programming operation tpwe Time for an erase operation tpwcal1 Time for auto-cal operation on power-up tcalmin Minimum auto-cal pulse width tpwcal2 Time for user initiated auto-cal operation
200 50 50 15 10 15 10 60 60 60 Executed in Run-Test/Idle Executed in Run-Test/Idle Automatically executed at power-up Executed on rising edge of CAL 40 80 80 40 100 100 100 250
ns ns ns ns ns ns ns ns ns ns ns ms ms ms ns ms
tckl
tckmin
TMS
CAL tcalmin
*Note: During device JTAG programming, analog outputs will stop responding to normal input stimulus. This is because all configuration information is erased and then re-written as part of a normal programming cycle, momentarily disrupting the input to output signal path. Behavior is not predictable during either of these steps since the analog outputs are not clamped during a programming cycle. Usually, however, the outputs will slew to either 0V (Ground) or 5V (Vsupply) or 2.5V (VREFOUT). This behavior is partially determined by conditions existing immediately prior to device reprogramming and intermediate configurations that occur during the process.
Specifications ispPAC10
Pin Descriptions
Pin
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28
Symbol
OUT2+ OUT2IN2+ IN2TDI TRST VS TDO TCK TMS IN4IN4+ OUT4OUT4+ OUT3+ OUT3IN3+ IN3CMVIN
Name
Output 2(+) Output 2(-) Input 2(+) Input 2(-) Test Data In Test Reset Supply Voltage Test Data Out Test Clock Test Mode Select Input 4(-) Input 4(+) Output 4(-) Output 4(+) Output 3(+) Output 3(-) Input 3(+) Input 3(-) Input for VCM Reference
Description
Differential output pin, VOUT+. (Plus complement of VOUT with respect to VREFOUT, where differential VOUT = VOUT+ - VOUT-). Differential output pin, VOUT-. (Minus component, where differential VOUT = VOUT+ - VOUT-). Differential input pin, VIN+. (Plus VIN, where differential VIN = VIN+ - VIN-). Differential input pin, VIN-. (Minus component of differential VIN, where VIN = VIN+ - VIN-). Serial interface logic input pin. Input data valid on rising edge of TCK. Serial interface logic reset pin (input). Asynchronously resets logic controller. Active low. Reset is equivalent of power-on default. Analog supply voltage pin (5V nominal). Should be bypassed to GND with 1F and .01F capacitors. Serial interface logic output pin. Input data valid on falling edge of TCK. Serial interface logic clock pin (input). Best analog performance when TCK is idle. Serial interface logic mode select pin (input). Differential input pin, VINDifferential input pin, VIN+ Differential output pin, VOUTDifferential output pin, VOUT+ Differential output pin, VOUT+ Differential output pin, VOUTDifferential input pin, VIN+ Differential input pin, VINInput pin for optional (external) analog Common-Mode Voltage (VCM). Replaces VREFOUT (+2.5V) for any so programmed PACblock as its common-mode output voltage value. Digital input pin. Commands an auto-calibration sequence on a rising edge. Ground pin. Should normally be connected to analog ground plane. Common-mode voltage reference output pin (+2.5V nominal). Must be bypassed to GND with a 0.1F capacitor. Manufacturing test pin. Connect to GND for proper circuit operation. Manufacturing test pin. Connect to GND for proper circuit operation. Differential input pin, VINDifferential input pin, VIN+ Differential output pin, VOUTDifferential output pin, VOUT+
CAL Auto-Calibrate GND Ground VREFOUT Common-Mode Reference TEST TEST IN1IN1+ OUT1OUT1+ Test Pin Test Pin Input 1(-) Input 1(+) Output 1(-) Output 1(+)
Connection Notes
1. All inputs and outputs are labeled with plus (+) and minus (-) signs. Polarity is labeled for reference and can be selected externally by reversing pin connections or internally under user programmable control. 2. All analog output pins are hard-wired to internal output devices and should be left open if not used. Outputs of uncommitted PACblocks are forced to VREFOUT (2.5V) and can be used as low impedance reference output buffers. VOUT+ and VOUT- should not be tied together as unnecessary power will be dissipated. 3. When the signal input is single-ended, the other half of the unused differential input must be connected to a DC common-mode reference (usually VREFOUT, 2.5V).
Pin Configuration
OUT2+ OUT2 IN2+ IN2 TDI TRST VS (5V) TDO TCK TMS IN4 IN4+ OUT4 OUT4+
1
OUT1+ OUT1 IN1+ IN1 TEST (tie to GND) TEST (tie to GND) VREFout GND (0V) CAL CMVin IN3 IN3+ OUT3 OUT3+
ispPAC10
Specifications ispPAC10
Typical Performance Characteristics
Input Noise Spectrum
1000 Noise: Referred to Input G = 10
Noise Voltage (nV Hz)
70
100
60
50
40 30
10
10
20
10
100
1M
100
1k
1M
G=2 G=1
G=5
-50
-50
-60
-60
-70
-70
-80 -90
1k
1k
100k
VOS Tempco
30 25 3 Wafer Lots PDIP Pkg -40C to +85C
Percentage of Devices (%)
VREFOUT Tempco
30 25 3 Wafer Lots PDIP Pkg 0C to +85C
18
Overshoot (%)
15 12 9 6 3 0
20
20
15
15
10
10
5 0
5 0
10
10k
-160
-100
Specifications ispPAC10
Typical Performance Characteristics
10.34kHz Filter FC Accuracy
50 2000 Units PDIP Pkg
50 2000 Units PDIP Pkg
30
30
40
40
40
30
20
20
20
10
10
10
-4 -3
-4 -3
Large-Signal Response
Small-Signal Response
1.0V
Gain = 1 Load = No Load
1S
20mV
Gain = 1 Load = No Load
1S
1.0V
Gain = 1 Load = 600pF
1S
20mV
Gain = 1 Load = 600pF
1S
Specifications ispPAC10
Theory of Operation Introduction
The ispPAC10 consists of four programmable analog macrocells called PACblocks, each emulating a collection of operational amplifiers, resistors and capacitors. Requiring no external components, it flexibly implements basic analog functions such as precision filtering, summing/differencing, gain/attenuation and integration. Each PACblock contains a summing amplifier, two differential input instrument amplifiers, and an array of feedback capacitors. The capacitors, combined with a fixed value feedback element, provide more than 120 programmable poles between 10kHz to 100kHz with an absolute accuracy of 5.0 percent. Variable gain input instrument amplifiers make it possible to program any PACblock gain in integer steps between 1 and 10. More complex signal processing functions are performed by configuring additional PACblocks in combination with each other to achieve a variety of circuit functions. The ispPAC10 architecture is fully differential from input to output. This effectively doubles dynamic range versus single-ended I/O. It also affords improved performance with regard to specifications such as input common mode rejection (CMR) and total harmonic distortion (THD). Differential peak-peak voltage is determined by knowing the signal extremes on both differential input or output pins. For example, if V(+) equals 4V and V(-) equals 1V, the differential voltage is defined as V(+) - V(-) = Vdiff, or 4V - 1V = +3V. Since either polarity can exist on differential I/O pins, it is also possible for the opposite extreme to exist and would mean when V(+) equals 1V and V(-) equals 4V, the differential voltage is now 1V - 4V = -3V. To calculate the differential peak-peak voltage or full signal swing, the absolute difference between the two extreme Vdiffs is calculated. Using the previous examples would result in |(+3V) - (-3V)| = 6V. It can be immediately seen that true differential signals result in a doubling of usable dynamic range. For more explanation of this and other differential circuit benefits, please refer to application note AN6019. Input polarity is programmable without affecting input impedance or dynamic performance, since no internal change is made other than routing to the input amplifier. Single-ended operation is achieved by using either one input and/or one output pin, as required, and adjusting gain settings to achieve desired output levels. The ispPAC10 operates on a single 5V supply and includes an internal reference generating 2.5V. This reference is made available externally through the voltage common-mode reference or VREFOUT pin (Pin 22). The output common mode voltage is always referenced to 2.5V, regardless of the input common mode level. It is possible, when desired, to use an externally supplied voltage instead of VREFOUT, however. This optional common-mode output voltage (VCM) must be provided by the user via the CMVIN input pin (Pin 19). The only limitation is this reference voltage must be between 1.25V and 3.25V. When an external voltage is present, an ispPAC10 must be programmed, on a per-PACblock basis, to use the external reference instead of the internal 2.5V. Configuring an ispPAC10 is accomplished using PAC-Designer, a Windows-based design environment. PAC-Designer includes an AC simulator for design verification prior to programming. The user can download the design to the ispPAC10 at any time via the devices IEEE Standard 1149.1 (JTAG) compliant serial port directly from the parallel port of a PC using an ispDOWNLOAD cable. Once downloaded, the circuit topology and component values are stored in non-volatile digital E2CMOS cells on the ispPAC10 without any need for external programming voltages.
Architecture
In all ispPAC products, individual programmable circuit functions called PACells are carefully combined to form larger analog macrocells or PACblocks. The ispPAC10 has four such PACblocks that incorporate specially configured PACells to perform amplification, summation, integration and filtering. Each of the four filtering/summation or FilSum PACblocks within ispPAC10 is comprised of three separate PACells, two input instrument amplifiers and an output summing amplifier (see Figure 1). The input amplifier PACells act as front-end gain stages for the FilSum PACblock and allow multiple signals to be summed together. The PACblocks output amplifier is similar to the familiar operational amplifier except that it has true differential outputs. Also included with each output amplifier is a filter capacitor array and switchable DC feedback path element. These components in combination enable the filtering and integrating functions of the FilSum PACblock.
Specifications ispPAC10
Theory of Operation (Continued)
Figure 1. FilSum (Filtering/Summation) PACblock Diagram
IA1 gm1
VINVIN+
VIN+
CF
VIN
IAF gm3
VOUT+
functionality: Signals can be summed, the resistive amplifier feedback can be removed to create an integrator, the sign of PACblock transfer function can be changed without changing the input or output loading characteristics. The FilSum PACblock can precisely filter, amplify or attenuate signals, always maintaining the high impedance input qualities of instrumentation amplifiers.
IA2 gm2
VOUT
VOUT-
VIN
VIN-
CF
Each FilSum PACblock actually employs three instrument amplifier (IA) PACells: two at the input (IA1 and IA2) and one as a feedback element around the op amp (IAF). The instrument amplifier PACells all have differential I/O and convert an input voltage to an output current (refer to Figure 2). This type of amplifier is sometimes referred to as an operational transconductance amplifier or OTA. When a differential input voltage is applied to these IAs, it is converted to a current proportional to the input signal. Because an AC signal common to both of the high impedance inputs of the IA does not create a net difference in the input signal, it is rejected by the amplifier. This characterizes the function of what is commonly known as an instrument amplifier and is a very desirable property because it acts to preserve the integrity of small signals in the presence of otherwise overwhelming noise. Figure 2. Instrument Amplifier PACell
IM IP
IAF
VOUT
The two input instrument amplifiers have a programmable transconductance (gm) value in 10 steps between 2A/V and 20A/V with programmable input polarity, whereas the feedback amplifier is fixed at 2A/V. The IA PACells exhibit extremely high input impedance so they dont load circuitry driving them and their outputs can be enabled or disabled under E2CMOS control, effectively switching them in and out of the FilSum PACblock circuitry. These simple characteristics permit a great deal of
CF
VCMIN (2.5V)
Input Offset Auto-Calibration. A unique feature of the ispPAC10 is its ability to automatically calibrate itself to achieve very low offset error. This is done utilizing onchip circuitry to perform an auto-calibration (auto-cal)
Specifications ispPAC10
Theory of Operation (Continued)
sequence every time the device is turned on, or anytime it is commanded externally via the CAL pin or by a JTAG programming command. With this feature, the degradation of device offset performance that could occur over time and temperature is dramatically reduced. Specifically, this means one PACblock of an ispPAC10 in a gain configuration of one is guaranteed to never have an input offset error greater than 1mV, after being auto-calibrated. For higher gain settings when offset is especially important, the error is not multiplied by gain, but is instead divided by it, due to the unique architecture of the ispPAC10. When an individual PACblock is configured in a gain of ten, that results in an input referred offset error that never exceeds 100V. Internally, auto-calibration is accomplished by simultaneous successive approximation routines (SAR) to determine the amount of offset error referred to each of the four PACblock output amplifiers of the ispPAC10. That error is then nulled by a calibration DAC for each output amplifier. The calibration constant is not stored in E2CMOS memory, but is recomputed each time the device is powered up or auto-cal is otherwise initiated. Initiation of auto-cal occurs when an ispPAC10 is powered on as part of its normal power on routine, or by a positive going pulse to the CAL pin (Pin 20), or by issuing the appropriate JTAG command. During auto-cal, all ispPAC10 outputs are driven to 0V and remain there until calibration is complete. The timing for the calibration process is generated internally. At power on, the sequence takes a maximum of 250ms, and when auto-cal is initiated via the CAL pin or by JTAG programming, it takes a maximum of 100ms to complete. The longer time required at power on insures the device power supply reaches its final value before calibration begins. Additional attempts to initiate auto-cal once calibration is in progress are ignored. Finally, the only direct indication of auto-cal completion will be the devices outputs returning to operational values from the 0V clamped state. To insure maximum accuracy of the auto-cal procedure, all digital signals to the ispPAC10 should be suspended when calibration is in progress to avoid feed-through of noise to critical analog circuitry. This is especially true when auto-cal is initiated via JTAG command and the programming port is in use. There is sufficient time, however, to clock the JTAG controller back to its reset state without affecting the calibration process. feedback capacitance to optimize the step response. The trimmed step response resembles that of a critically damped system with minimum overshoot. The bandwidth trim ensures a nominal feedback capacitance is always present, limiting the small signal bandwidth of an OA PACell to about 600kHz when configured in a gain of 1 (G=1). This should not be confused with the gain-bandwidth product of the op amp within the output amplifier PACells which is approximately 5MHz. It is important to note that the individual output amplifiers are always in essentially the same fixed gain configuration and do not, therefore, contribute to a decrease in signal bandwidth at higher PACblock gain settings. Since the gain of an individual PACblock is determined by varying the gm of the input amplifier, bandwidth is not reduced in direct proportion to gain, as it would be in a traditional voltage feedback amplifier configuration. Specifically, small signal bandwidth is only reduced by a factor of 2, not the expected 10, with a PACblock gain setting change of G=1 to G=10. This is a significant advantage of the PACblock architecture.
Pole Accuracy Trim. Separate from the bandwidth trim capacitance, each FilSum PACblock contains a range of user selectable op amp feedback capacitance. This is made possible by a parallel arrangement of seven capacitors, each in series with an E2CMOS switch. The user controls the position of the switches when selecting from the available capacitor values. The resulting capacitance is in parallel with the op amp feedback element, IAF, making 128 possible pole locations available. The capacitor values are not binarily weighted, instead they are chosen to optimize and concentrate pole spacing below 100kHz. There are 122 poles between 10kHz and 96kHz, which guarantees a step of no greater than 3.2% anywhere in that frequency range (to the nearest computed pole location). In fact, step size in over 50% of that range is less than 1.0%. Finally, capacitors are trimmed to achieve 5.0% accuracy (absolute) with regard to their nominal value.
(1) (2)
Bandwidth Trim. The bandwidth of an OA PACell is trimmed during manufacturing by adjusting the amplifiers
Using KCL (Kirchoffs current law) at the op amp inputs and assuming the input is connected to IA1 only: 10
Specifications ispPAC10
Theory of Operation (Continued)
- VIN gm1 + VOUT gm3 + ( VOUT + ( V - ))sCF
VIN gm1 - VOUT gm3 + ( VOUT - ( V +))sC F
(3a) (3b)
k1 IA1
where V- and V+ are the voltages at the op amp inverting and non-inverting inputs respectively. Because of feedback they are equal, so
RF
- VIN gm1 + VOUT gm3 + ( VOUT + sCF ) = VIN gm1 VOUT gm3 + ( VOUT - sCF )
(4)
and the differential output voltage VOUT is the difference VOUT+ - VOUT- ,
The FilSum PACblock implements two primary functions: the lossy integrator (low pass filter) and the integrator, both with gain.
VOUT = VIN
(5a)
Lossy Integrator. The lossy integrators schematic within PAC-Designer is shown in Figure 5. Manipulating the PACblock transfer function of Equation 5 to better show the pole frequency yields:
VOUT = k1VIN1 + k 2 VIN2 sCF 1+ 2gm
Since the PACblock has two separate inputs (IA1 and IA2) summed at the output amplifier input:
VOUT =
(6)
The input amplifiers have a programmable gain of k2A/V (gm1 and gm2) where k is an integer from -10 to 10. The feedback amplifier transconductance gm3 is fixed at 2A/V, but may be disabled (gm3 = 0) to open-circuit the output amplifiers resistive feedback. The programmable feedback capacitance lies in the range 1pF to 62pF. The PACblock model from PAC-Designer is shown in Figure 4. The output amplifier is configured as an inverting mode op amp and illustrates the summing configuration. The input instrument amplifiers are shown to make it clear that unlike a typical inverting op amp, the PACblock input impedance is extremely high. The input amplifier (IA) transconductance (gain) is shown as the value (k) above or below each amplifier. The gain of IA1 and IA2 are independently programmable. Because the feedback transconductor IAF (designated here as RF) can be disabled by the user, a user configurable switch is shown in series.
k1 VIN1 IA1
The DC gain of each input is set by k1 or k2 respectively, the gain constant for the input amplifiers. Below the pole frequency, this circuit can be viewed as a gain block. Because of the bandwidth trim capacitance, there is a minimum value of CF causing the bandwidth to be approximately 550kHz when the DC gain is one. For larger gains, the input amplifier bandwidth begins to dominate the overall PACblock response, limiting the bandwidth to about 330kHz when the gain is 10. Examining this transfer function shows the pole frequency is (1/2)(2gm/C). Since gm = 2A/V and 1pF CF 62pF, then 600kHz fP 10kHz. Due to the selection options for feedback capacitance, there are at least 120 poles between 10kHz and 100kHz.
11
Specifications ispPAC10
Theory of Operation (Continued)
Integrator. Switching out RF (turning off IAF) removes the feedback element as shown in Figure 6. The integrators transfer function can be derived from Equation 5b by setting gm3 = 0 (open circuit IAF (RF)).
Figure 6. PAC-Designer PACblock Integrator (IAF Disabled; gm3 = 0)
k1 VIN1 IA1 RF VIN2 OA1 IA2 k2 2.5V VOUT CF
It can also be seen that the transfer function VFB(s)/VIN(s) implements a lowpass filter. This application is discussed further in a separate application note. Figure 7b. Biquad Bandpass Filter Schematic
OUT1
1 IA1
PACblock 1
8.19pF
IN1
IA2 -1 -1 PACblock 2
VOUT =
IN2
(7)
IA4 OUT2 1
The integrator slope is proportional to 1/f and, for the case of a single input, the transfer function magnitude equals |k| when the frequency is (1/2)(2gm/C). The integrator should not be used as a stand-alone circuit element. It needs to be used in configurations that provide DC feedback to ensure the output does not saturate, as illustrated by the biquad filter circuit below.
Application Examples
Biquad Filter. By simply combining the two structures, the integrator providing feedback around the lossy integrator, creates a useful circuit. The block diagram is shown in Figure 7a
Figure 7a. Biquad Bandpass Filter Block Diagram
Attenuator. The PACblock architecture makes variations possible on these two basic building blocks just described. An example uses summation to connect an input amplifier (IA2) in parallel with the feedback element (RF), as shown in Figure 8.
Figure 8. PACblock AV < 1
k1 VIN1 IA1 RF IA2 OA1 2.5V VOUT CF
VIN (IN1)
Error
B s 1+ p 1 VOUT1 (OUT1)
k2
VOUT2 (OUT2)
VFB
A s
(8)
and the schematic from PAC-Designer is shown in Figure 7b. The transfer function OUT1(s)/IN1(s) is a band pass filter with programmable gain, Q and center frequency. Note the presence of DC feedback around the integrator.
The gains k1 and k2 are independently set by the user; this circuit can either amplify or attenuate an input signal. The one in the denominator is due to RF; if RF is disabled,
12
Specifications ispPAC10
Theory of Operation (Continued)
this term is eliminated. The level of attainable attenuation is as low as 1/11 (-20.8dB) with R F enabled or 1/10 (-20dB) with RF disabled. When configuring a PACblock to attenuate, it is necessary to increase the value of feedback capacitance to maintain stability. Increasing feedback capacitance has the same beneficial effect as for a discrete op amp: It increases the networks phase margin which assists in maintaining stability.
Interfacing
When used in a single-supply system where the system common mode voltage is near VS/2, signals may be directly connected to the ispPAC10 input. If the input signal does not have such a DC bias, then one needs to be added to the signal in order to accommodate the input requirements for the ispPAC10. A DC coupled bias can be added to a signal by using a voltage divider circuit as shown for one-half of the differential input in Figure 10a. Normally the choice for the reference DC voltage is the supply voltage, but other values may be used if necessary (and available). Figure 10a. DC Biasing an Input Signal
Using VREFOUT
The VREFOUT output is high impedance and it should be buffered when used as a reference. A PACblock can be made into a VREFOUT buffer as shown in Figure 9. The PACblock inputs are left unconnected and the feedback closed. In this condition the input amplifiers are tied to VREFOUT and the output amplifiers outputs are thus forced to VREFOUT or 2.5V. Either output is now a VREFOUT voltage source. This reference has the same drive capabilities of any ispPAC10 output. However, do not short the two outputs together. There is a small potential difference between them which will cause a steady state current to flow, thus needlessly dissipating power. Figure 9. PACblock as VREFOUT Buffer
OUT1=2.5V Unconnected 1.07pF
VREFOUT R2 VSE
VIN+ VIN*
R1
*Single-Ended V SE: Connect to VREF OUT or other DC Reference. *Differential V SE: Duplicate Vin+ Network on Vin-.
OUT1
1 IA1
PACblock 1
V R VREFOUT R1 VIN+ = SE 2 + R1 + R 2 R1 + R 2
OA1 2.5V
IN1
IA2 -1
It is not always necessary to buffer the VREFOUT output. If it is used to reference a high impedance source, i.e., one that does not require more than 10A, then it can be directly connected. An example is shifting the DC level of a signal connected to the input of a PACblock. In this case, the signal is AC coupled and terminated in VREFOUT through a minimum total resistance of 100k. Referring to Figure 10b, if RIN is greater than 200k then the VREFOUT pin may be used without buffering.
Where DC coupling is not required, the input signal may be AC coupled as shown in Figure 10b. This circuit forms a high pass filter with a cutoff frequency of 1/(2RC) and adds the necessary DC bias to the signal to accommodate the ispPAC10 input requirements. The DC reference should equal VS/2, making VREFOUT the natural choice. The minimum resistance when using the VREFOUT buffer circuit of Figure 9 is 600; when using the VREFOUT output pin it is 200k (as discussed earlier).
13
Specifications ispPAC10
Theory of Operation (Continued)
Figure 10b. AC-coupled Input with DC Bias requires DC current, the amount available for voltage swing is reduced. The output is capable of 10mA, so any DC current raises the minimum allowable load impedance.
Noise gain is the gain of a circuit configuration to its combined input-referred circuit noise. The noise gain of an inverting op amp circuit is:
Noise Gain = 1+ Closed Loop Voltage Gain
(9)
In this case, the noise gain of the circuit increases proportionally to the circuit gain. A FilSum PACblock contains an input amplifier stage followed by an output amplifier. In this way it can be viewed as a system, with each of the components having its own contribution to the overall noise as shown in Figure 11. Both the output amplifier noise (N2) and input amplifier noise (N1) contribute to the overall noise performance, but the contribution due to the output amplifier dominates except at input gains near 10. The result is that the SNR of a FilSum PACblock is nearly constant versus gain. This is different than the behavior predicted by Equation 9. Figure 11. Multistage ispPAC Noise Diagram
VREFOUT
Single-ended Operation
Single-ended signals may be connected to the ispPAC10 input and one of the two differential ispPAC10 outputs can be used to drive single-ended circuitry. So, in addition to fully differential I/O, either the input, output or both may be used single-ended.
Single-ended Input. To connect the ispPAC10 differential input to a single-ended signal, one of the differential inputs needs to be connected to a DC bias, preferably VREFOUT. The input signal must either be AC coupled (as in Figure 10b) or have a DC bias equal to the DC level of the other input. Since the input voltage is defined as VIN+- VIN-, the common mode level is ignored. The signal information is only present on one input, the other being connected to a voltage reference. Single-ended Output. Connecting the output to a singleended circuit is simpler still. Simply connect one-half of the differential output, but not the other. Either output conveys the signal information, just at half the magnitude of the differential output. The DC level of the singleended output will be VREFOUT due to the re-referencing aspect of the FilSum PACblock. If the load is not AC coupled and is at a DC potential other than VREFOUT, the load draws a constant current. Using one of the differential outputs halves the available output voltage swing (3VPP versus 6VPP) and since the output current capacity is the same whether driving differentially or single-ended, a single output can drive twice the load as the differential output (150 vs. 300 or 2000pF vs. 1000pF). If the load
N1
G1
N2
G2
Stage One
2 N1 +
N2 G1
(10a)
(10b)
There is a few dB decrease in SNR as the gain approaches 10. This characteristic implies the input amplifier noise contribution is approaching that of the op amp. As the gain of the input amplifier nears 10, its noise contribution in Equation 10a (N1) approaches that of the op amp and becomes a factor in the overall output noise voltage, causing it to increase.
14
Specifications ispPAC10
Theory of Operation (Continued) Input Common-Mode Voltage Range
For the ispPAC10, both maximum input signal range and corresponding common-mode voltage range are a function of the input gain setting. The maximum input voltage times the gain of an individual PACblock cannot exceed the output range of that block or clipping will occur. The maximum guaranteed input range is 1V to 4V, with an extended typical range of 0.7V to 4.3V for a 5V supply voltage. The input common-mode voltage is VCM = (VCM+ + VCM-)/2. When the value of VCM is 2.5V, there are no further input restrictions other than the previously mentioned clipping consideration. This is easily achieved when the input signal is true differential and referenced to 2.5V. When VCM is not 2.5V and the gain setting is greater than one, distortion will occur when the maximum input limit is reached for a particular gain. The lowest VCM for a given gain setting is expressed by the formula, VCM = 0.675V + 0.584GVIN where G is the gain setting and VIN is the peak input voltage, expressed as |VIN+ - VIN| and the highest VCM is VCM+ = 5.0V - VCM where 5V is the nominal supply voltage. In Table 1, the maximum VIN for a given VCM to VCM+ range is given. If the maximum VIN is known, find the equivalent or greater value under the appropriate gain column and the widest range for VCM will be found horizontally across in the left-most two columns. Only a VCM range equal to or less than this will give distortionfree performance. Conversely, if the maximum VCM range is known, the largest acceptable peak value of VIN can be found in the corresponding gain column. All values of VIN less than this will give full rated performance.
15
Specifications ispPAC10
Software-Based Design Environment Design Entry Software
Designers configure the ispPAC10 and verify its performance using PAC-Designer, an easy to use, Microsoft Windows compatible program. Circuit designs are entered graphically and then verified, all within the PAC-Designer environment. Full device programming is supported using PC parallel port I/O operations and a download cable connected to the serial programming interface of the ispPAC10. A library of configurations is included with basic solutions and examples of advanced circuit techniques. In addition, comprehensive on-line and printed documentation is provided that covers all aspects of PAC-Designer operation. The PAC-Designer schematic window, shown in Figure 12, provides access to all configurable ispPAC10 elements via its graphical user interface. All analog input and output pins are represented. Static or non-configurable pins such as power, ground, VREFOUT, and the serial digital interface are omitted for clarity. Any element in the schematic window can be accessed via mouse operations as well as menu commands. When completed, configurations can be saved, simulated, and downloaded to devices. PAC-Designer operation can be automated and extended by using custom-designed Visual Basic programs that set the interconnections and the parameters of ispPAC products. These stand-alone programs are called circuit generator macros. An example of such a macro is the biquad filter generator supplied with PAC-Designer. With this macro, filter parameters such as gain, Q and corner frequency are input directly and then automatically converted to a schematic configuration. The application example shown in Figure 7b was generated using the biquad filter generator macro. More information on this and other topics is included in the on-line documentation as well as ispPAC application notes.
OUT1
OUT3
1.07 pF 1 IA1 OA1 IN1 IA2 2.5V 1 1.07 pF 1 IN2 IA3 OA2 IA4 OUT2 1 2.5V PAC Block 2 PAC Block 1
1.07 pF PAC Block 3 1 IA5 OA3 IA6 2.5V 1.07 pF PAC Block 4 1 IA7 OA4 IA8 2.5V 1 OUT4 IN4 1 IN3
UES = 00000000
Ready
16
Specifications ispPAC10
Software-Based Design Environment (Continued) Design Simulation Capability
A powerful feature of PAC-Designer is its simulation capability enabling quick and accurate verification of circuit operation and performance. Once a circuit is configured via the interactive design process, gain and phase response between any input and output can then be determined. This function is part of the simulator capability which derives a transfer equation between the two points and then sweeps it over the user-specified frequency range. Figure 13 shows a typical screen plot of the gain/phase simulator. In it are the input to output response curves of a 2nd order biquad filter similar to the implementation illustrated in Figure 7b. In this example, the lowpass and bandpass characteristics of the filter are seen. The simulator is capable of displaying up to four separate input to output responses. This allows multiple signal paths to be viewed as well as intermediate results of component changes so performance comparisons can be made. There is also a user positioned crosshair cursor that intersects the curves on the plot, and reads out the gain and frequency in the lower right hand corner of the plot window when activated.
In-System Programming
The ispPAC10 is an in-system programmable device. This is accomplished by integrating all high voltage programming circuitry on-chip. Programming is performed through a 5-wire, IEEE 1149.1 (JTAG) compliant serial port interface at normal logic levels. Once a device is programmed, all configuration information is stored in onchip, non-volatile E2CMOS memory cells. The specifics of the IEEE 1149.1 serial interface are described in the interface section of this data sheet.
Vo1/Vi1 Vo2/Vi1
100
1K
10K
100K
1M
10M
100
1K
10K
100K
1M
10M
Ready
Curve:1 Vout1/Vin1
17
Specifications ispPAC10
In-System Programmability Electronic Security
An electronic security fuse (ESF) bit is provided in every ispPAC10 device to prevent unauthorized readout of the E2CMOS user bit patterns. Once programmed, this cell prevents further access to the functional user bits in the device. This cell can only be erased by reprogramming the device, so the original configuration can not be examined once programmed. Usage of this feature is optional. ispPAC10 and can be used in real time to check circuit operation as part of the design process. Input and output connections as well as a breadboard circuit area are provided to speed debugging of the circuit.
Evaluation Fixture
Included in the basic ispPAC10 Design Kit is an engineering prototype board that is connected to the parallel port of a PC. It demonstrates proper layout techniques for the
PAC-Designer Software
Other System Circuitry
18
Specifications ispPAC10
IEEE Standard 1149.1 Interface Overview
An IEEE 1149.1 test access port (TAP) provides the control interface for serially accessing the digital I/O of the ispPAC10. The TAP controller is a state machine driven with mode and clock inputs. Under the correct protocol, instructions are shifted into an instruction register which then determines subsequent data input, data output, and related operations. Device programming is performed by addressing the user register, shifting data in, and then executing a program user instruction, after which the data is transferred to internal E2CMOS cells. It is these non-volatile cells that determine the configuration of the ispPAC10. By cycling the TAP controller through the necessary states, data can also be shifted out of the user register to verify the current ispPAC10 configuration. Instructions exist to access all data registers and perform internal control operations. Figure 15. ispPAC10 TAP Registers register. All instructions relating to boundary scan operations place the ispPAC10 in the BYPASS mode to maintain compliance with the specification. The optional identification register described in IEEE 1149.1 is also included in the ispPAC10. One additional data register included in the TAP of the ispPAC10 is the Lattice defined user register. Figure 15 shows how the instruction and various data registers are placed in an ispPAC10.
Output Latch
TDI
TCK
TMS
TRST
TDO
For compatibility between compliant devices, two data registers are mandated by the IEEE 1149.1 specification. Others are functionally specified, but inclusion is strictly optional. Finally, there are provisions for optional data registers defined by the manufacturer. The two required registers are the bypass and boundary-scan registers. For ispPAC10, the bypass register is a 1-bit shift register that provides a short path through the device when boundary testing or other operations are not being performed. The ispPAC10, as mentioned, has no boundary-scan logic and therefore no boundary scan
MUX
19
Specifications ispPAC10
IEEE Standard 1149.1 Interface (Continued)
tion. This, in conjunction with mandated bit codes, allows a blind interrogation of any device in a compliant IEEE 1149.1 serial chain. From the Capture state, the TAP transitions to either the Shift or Exit1 state. Normally the Shift state follows the Capture state so that test data or status information can be shifted out or new data shifted in. Following the Shift state, the TAP either returns to the Run-Test/Idle state via the Exit1 and Update states or enters the Pause state via Exit1. The Pause state is used to temporarily suspend the shifting of data through either the Data or Instruction Register while an external operation is performed. From the Pause state, shifting can resume by reentering the Shift state via the Exit2 state or be terminated by entering the Run-Test/Idle state via the Exit2 and Update states. If the proper instruction is shifted in during a Shift-IR operation, the next entry into Run-Test/Idle initiates the test mode (steady state = test). This is when the device is actually programmed, erased or verified. All other instructions are executed in the Update state. function of three required and six optional instructions. Any additional instructions are left exclusively for the manufacturer to determine. The instruction word length is not mandated other than to be a minimum of 2 bits, with only the BYPASS and EXTEST instruction code patterns being specifically called out (all ones and all zeroes respectively). The ispPAC10 contains the required minimum instruction set as well as one from the optional instruction set. In addition, there are several proprietary instructions that allow the device to be configured and verified. For ispPAC10, the instruction word length is 5 bits. All ispPAC10 instructions available to users are shown in Table 2.
BYPASS is one of the three required instructions. It selects the Bypass Register to be connected between TDI and TDO and allows serial data to be transferred through the device without affecting the operation of the ispPAC10. The bit code of this instruction is defined to be all ones by the IEEE 1149.1 standard.
The required SAMPLE/PRELOAD instruction dictates the Boundary-Scan Register be connected between TDI and TDO. The ispPAC10 has no boundary-scan register, so for compatibility it defaults to the BYPASS mode whenever this instruction is received. The bit code for this instruction is defined by Lattice as shown in Table 2.
Test Instructions
Like data registers, the IEEE 1149.1 standard also mandates the inclusion of certain instructions. It outlines the
Note: The value shown adjacent to each state transition in this figure represents the signal present at TMS at the time of a rising edge at TCK.
20
Specifications ispPAC10
IEEE Standard 1149.1 Interface (Continued)
The EXTEST (external test) instruction is required and would normally place the device into an external boundary test mode while also enabling the Boundary-Scan Register to be connected between TDI and TDO. Again, since the ispPAC10 has no boundary-scan logic, the device is put in the BYPASS mode to ensure specification compatibility. The bit code of this instruction is defined by the 1149.1 standard to be all zeros. Table 2. ispPAC10 TAP Instructions
Instruction EXTEST ADDUSR UBE VERUSR PRGUSR IDCODE ENCAL SAMPLE BYPASS Code 00000 00001 00010 00011 00100 01101 10000 11110 11111 Description External test. Default to BYPASS. Address User data register. User bulk erase. Verify User data register. Program User data register. Read Identification data register. Enable Calibration sequence. Sample/Preload. Default to BYPASS. Bypass (connect TDI to TDO).
ADDUSR (address user register) instruction is a Lattice defined instruction that selects the user register to be shifted during a Shift-DR operation. Normal operation of a device is not interrupted by this instruction. It precedes a PROGUSR (program user) instruction to shift in a new configuration and follows a VERUSR (verify user) instruction to shift out the current configuration. The bit code for this instruction is shown in Table 2.
The PRGUSR (program user) is a Lattice instruction that enables the data shifted into the user register to be programmed into the non-volatile E2CMOS memory of the ispPAC10 and thereby alter its configuration. The user register is a 109-bit shift register that contains all the user-controlled parametric and interconnect data pertaining to the configuration of the ispPAC10. Normal operation of the device is interrupted during the actual programming time. A programming operation does not begin until entry of the Run-Test/Idle state. The time required to insure data retention is given in the TAP signal specifications table. The user must ensure that the recommended programming times are observed. The bit code for this instruction is shown in Table 2.
The optional IDCODE (identification code) instruction is incorporated in the ispPAC10 and leaves it in its functional mode when executed. It selects the Device Identification Register to be connected between TDI and TDO. The Identification Register is a 32-bit shift register containing information regarding the IC manufacturer, device type and version code (see Figure 17). Access to the Identification Register is immediately available, via a TAP data scan operation, after power-up of the device, after a reset using the optional TRST pin, or by issuing a Test-Logic-Reset instruction. The bit code for this instruction is defined by Lattice as shown in Table 2. The Figure 17. Identification Code (IDCODE) 32-Bit Binary Word for Lattice ispPAC10
MSB LSB
VERUSR (verify user) is the next Lattice instruction and causes the current configuration of the ispPAC10 to be loaded into the user register. This operation doesnt interrupt operation of the device. The current configuration can then be shifted out of the user register immediately after an ADDUSR instruction is executed. The bit code for this instruction is shown in Table 2. ENCAL (enable calibration) is a Lattice instruction that enables the start of an auto-calibration sequence. This operation causes all outputs of the device to go to 0V until the calibration sequence is completed (see timing specifications). As with the programming instructions above, calibration does not begin until entry of the Run-Test/Idle state. The completion of the calibration is not dependent, however, on any further TAP control. This means the state of the TAP can be returned immediately to the TestLogic-Reset state. The only consideration would be to not clock the TAP during critical analog operations. The first several milliseconds of the calibration routine are consumed waiting for configurations to settle, though, leaving more than enough time to clock the TAP back to the Test-Logic-Reset state. The bit code for this instruction is shown in Table 2.
JEDEC Manfacturer Identity Code for Lattice Semiconductor (11 bits) Constant 1 (1 bit) per 1149.1-1990
21
Specifications ispPAC10
IEEE Standard 1149.1 Interface (Continued)
The last Lattice instruction is UBE (user bulk erase). Operation of the device is interrupted during UBE, after which all inputs are disconnected and all outputs driven to VREFOUT (2.5V). To economize internal circuitry, programming can only be selectively done in one direction (from zeroes to ones). The UBE is used to return all user bits to a zero state at the same time. A UBE usually proceeds a PRGUSR operation, otherwise one to zero changes would not be implemented. It can also be used to erase all configuration information from a device and is the default condition of parts shipped from the factory. The same programming constraints apply to UBE as for PRGUSR. The bit code for this instruction is shown in Table 2. The ADDUSR, BYPASS, EXTEST, IDCODE and SAMPLE/PRELOAD instructions are all executed in the Update-IR state. Other instructions: PRGUSR, VERUSR and UBE are executed upon entry of the Run-Test/Idle state. It is recommended that when all serial interface operations are completed, the TAP controller be reset and left in the Test-Logic-Reset state (the power-up default) and the TCK and TMS inputs idled. This will insure the best analog performance possible by minimizing the effects of digital logic feed-through.
22
Specifications ispPAC10
Package Diagrams
28-Pin Plastic DIP Dimensions in Inches MIN./MAX. (Dimensions in millimeters, shown in parenthesis, are for reference only)
.180 (4.57) MAX .125 / .135 (3.17 / 3.43) .045 /.055 (1.14 / 1.40) .015 /.021 (.38 / .53) .100 (2.54) BSC
0-15
28-Pin Plastic SOIC Dimensions in Inches MIN./MAX. (Dimensions in millimeters, shown in parenthesis, are for reference only)
Top View
.0091 (.23) .050 (1.27) BSC .697 (17.70) .712 (18.08) .097 (2.46) .104 (2.64) .0050 (.127) .0115 (.292) 0 8 .0125 (.32)
23