



# QF4A512

## 4-Channel Programmable Signal Converter (PSC)

### APPLICATIONS

- Industrial Control
- Wireless Sensor Networks
- Machine Monitoring
- Smart Sensors
- Medical Monitoring and Diagnostics
- Homeland Security

### DESCRIPTION

The QF4A512 Programmable Signal Converter is a 4-channel, signal conditioner and signal converter. Each channel can be individually programmed for the gain, anti-aliasing filter cutoff frequency, A-to-D sampling frequency, and unique filter requirements. This is accomplished with 4 separate high-precision 512-tap FIR filters.

Quickfilter Pro software has been created for rapid device configuration and filter design at performance levels unattainable with analog components.

### **ORDERING INFORMATION**

| Device                       | Package                                              |
|------------------------------|------------------------------------------------------|
| QF4A512A-LQT<br>QF4A512A-LQB | 32-Pin LQFP - Tape & Reel (Reel qty 1000)<br>- Trays |
| QF4A512-DK                   | Development Kit                                      |



Functional Block Diagram

### FEATURES

- 4 Channel Analog 16-bit Programmable A/D Converter
- Differential or Single Ended Inputs
- 4 Programmable (1x, 2x, 4x, 8x) Gain Amplifiers
- Anti-Aliasing Filter Per Channel, 3rd Order Bessel
- Analog DC 900kHz, up to 2Msps Sampling rate
- Internal Precision Voltage Reference
- 4 Individual Programmable 512-tap Digital FIR Filters
- SPI Port Interface
- 3.3V Digital I/O, 5 Volt Tolerant
- 32-Pin LQFP Package
- Industrial Temp -40C to +85C
- 4K Byte EEPROM for filter coefficient, chip configuration and calibration.
  - 128 bytes of EEPROM User Data Space
  - 384 Bit Masks for IEEE 1451.4 TEDS on 4 Channels

### QUICKFILTER DEVELOPMENT KIT

#### (QF4A512-DK)

- Quickfilter Pro Windows<sup>®</sup>-based Software for Rapid Filter Design and IC Configuration
- In-System Programmability (ISP) trough SPI Port
- Evaluation board for verification of device performance



Filter Design Screen



## TABLE OF CONTENTS

| 1. SPECIFICATIONS                                        | 4  |
|----------------------------------------------------------|----|
| 1.1 Absolute Maximum Ratings                             | 4  |
| 1.2 PACKAGE ASSEMBLY                                     |    |
| 1.3 RECOMMENDED OPERATING CONDITIONS                     | 4  |
| 1.4 ELECTRICAL CHARACTERISTICS                           |    |
| 1.5 TIMING REQUIREMENTS                                  |    |
| 1.6 TYPICAL PERFORMANCE CHARACTERISTICS                  | 8  |
| 2. PINOUT AND PIN DESCRIPTIONS                           | ٥  |
|                                                          | -  |
| 2.1 PINOUT                                               |    |
| 2.2 PIN DESCRIPTIONS                                     | 9  |
| 3. GENERAL DESCRIPTION                                   | 11 |
| 3.1 ANALOG FRONT END (AFE)                               |    |
| 3.2 ANALOG TO DIGITAL CONVERTER (ADC)                    |    |
| 3.3 FINITE IMPULSE RESPONSE FILTER (FIR)                 |    |
| 3.4 SERIAL INTERFACE - SERIAL PERIPHERÁL INTERFACE (SPI) |    |
| 3.5 STARTUP MODES                                        |    |
| 3.6 MEMORY                                               |    |
| 4. SOFTWARE                                              | 13 |
|                                                          |    |
| 4.1 DEVICE CONFIGURATION                                 |    |
| 4.2 QUICKFILTER DEVELOPMENT KIT (QF4A512DK)              |    |
| 4.3 IN-CIRCUIT (RE)CONFIGURATION                         |    |
| 5. STARTUP                                               | 14 |
| 5.1 Power up / Reset Sequence                            |    |
| 5.2 EXTENDED INITIALIZATION                              |    |
| 5.3 CALIBRATION                                          |    |
| 6. ANALOG FRONT END (AFE)                                |    |
| 6.1 CONFIGURABLE PARAMETERS                              | 17 |
| 6.2 CHOPPER-STABILIZED AMPLIFIER                         |    |
| 6.3 PROGRAMMABLE GAIN AMPLIFIER (PGA)                    |    |
| 6.4 INPUT VOLTAGE LEVELS.                                |    |
| 6.5 ANTI-ALIASING FILTER (AAF)                           |    |
| 6.6 ENABLING CHANNELS                                    |    |
| 7. ANALOG TO DIGITAL CONVERTER                           |    |
| 7.1 Overview                                             | 10 |
| 7.1 OVERVIEW<br>7.2 SAMPLING RATES / ENOB                |    |
| 7.2 SAMPLING RATES / LINOB                               |    |
| 7.4 Serial Interface                                     |    |
| 7.5 DATA FORMAT                                          |    |
| 7.6 ANALOG MUX                                           | -  |
| 7.7 GAIN AND OFFSET CALIBRATION                          |    |
| 7.8 FACTORY CALIBRATION                                  |    |
| 7.9 USER (SYSTEM LEVEL) CALIBRATION                      |    |
| 8. FIR FILTERS                                           |    |
| 0. FIK FILIEKO                                           |    |
| 8.1 FIR OVERVIEW                                         |    |
| 8.2 FIR MEMORY LOCATIONS                                 |    |
| 8.3 FIR LATENCY                                          |    |
| 8.4 MAXIMUM NUMBER OF TAPS                               |    |



| 9. SYSTEM CLOCKS                          | 23 |
|-------------------------------------------|----|
| 9.1 PLL CLOCK                             |    |
| 9.2 System Clock                          |    |
| 9.3 ADC CLOCK                             |    |
| 9.4 EE CLOCK                              |    |
| 10. SERIAL INTERFACE                      | 24 |
| 10.1 Modes of Operation                   |    |
| 10.2 Configure Mode                       |    |
| 10.3 Run Mode                             |    |
| 10.4 Sending Commands in Run Mode         |    |
| 11. EEPROM                                | 31 |
|                                           |    |
|                                           |    |
| 11.2 EEPROM TRANSFER PROCEDURES           |    |
| 11.3 CALIBRATION DATA<br>11.4 USER MEMORY |    |
|                                           |    |
| 12. CONTROL REGISTERS                     |    |
| 12.1 OVERVIEW                             |    |
| 12.2 HIGH-LEVEL REGISTERS                 |    |
| 12.3 EEPROM STARTUP REGISTERS             |    |
| 12.4 Run and Status Registers             |    |
| 12.5 GLOBAL CONFIGURATION REGISTERS.      |    |
| 12.6 GLOBAL MAINTENANCE REGISTERS.        |    |
| 12.7 CHANNEL-SPECIFIC REGISTERS           |    |
| 12.8 GLOBAL MAINTENANCE 2 REGISTERS       |    |
| 12.9 FIR COEFFICIENT AND RAM REGISTERS    |    |
| 12.10 REGISTER LISTING                    |    |
| 13. APPLICATION CIRCUITS                  | 61 |
| 13.1 AC COUPLED, SINGLE-ENDED             | 61 |
| 13.2 DC COUPLED, SINGLE-ENDED             |    |
| 13.3 AC COUPLED, DIFFERENTIAL             |    |
| 13.4 DC COUPLED, DIFFERENTIAL             | 64 |
| 14. PACKAGING INFORMATION                 | 65 |
| LIST OF FIGURES                           |    |
| LIST OF TABLES                            |    |
|                                           |    |



### 1. SPECIFICATIONS

#### **1.1 Absolute Maximum Ratings**

Stresses above those listed under Absolute Maximum Ratings can cause permanent device failure. Functionality at or above these limits is not implied. Exposure to absolute maximum ratings for extended periods may affect device reliability.

| Parameter                                          | Min   | Мах                     | Units |
|----------------------------------------------------|-------|-------------------------|-------|
| Storage Temperature                                | -60   | 125                     | °C    |
| Supply Voltage, V <sub>DD18</sub> to DGND          | -0.2V | 2.2V                    | V     |
| Supply Voltage, $V_{DD33}$ with respect to DGND    | -0.2V | 4.0V                    | V     |
| Digital Input Voltage with respect to DGND         | -0.3  | 7                       | V     |
| Analog Input Voltage with respect to AGND          | -0.3  | V <sub>DD33</sub> + 0.3 | V     |
| ESD Immunity (Human Body Model, JESD222 Class 1C)) | 1000  |                         | V     |



This integrated circuit can be damaged by ESD. Quickfilter Technologies recommends that all integrated circuits be handled with appropriate precautions. Failure to observe proper handling and installation procedures can cause damage.

#### 1.2 Package Assembly

The QF4A512 is offered in a "green" package (RoHS & no Sb/Br), assembled with enhanced environmentally compatible Pb-free and halide-free materials. The leads possess a matte-tin plating which is compatible with conventional board assembly processes or newer lead-free board assembly processes. The peak soldering temperature should not exceed 260°C during printed circuit board assembly.

| Parameter             | Symbol            | Min | Тур | Мах | Units |
|-----------------------|-------------------|-----|-----|-----|-------|
| Supply Voltage 1.8    | V <sub>DD18</sub> | 1.6 | 1.8 | 2.0 | V     |
| Supply Voltage 3.3    | V <sub>DD33</sub> | 3.0 | 3.3 | 3.6 | V     |
| Digital Input Voltage |                   | 0   |     | 5.5 | V     |
| Analog Input Voltage  | A <sub>IN</sub>   | 0.2 |     | 2.5 | V     |
| Clock Frequency       | f <sub>0</sub>    | 5   | 20  | 200 | MHz   |
| Ambient Temperature   | T <sub>A</sub>    | -40 | 25  | 85  | °C    |
| ADC Clock Rate        | f <sub>ADC</sub>  | 10  |     | 100 | MHz   |

#### **1.3 Recommended Operating Conditions**

Note: Quickfilter guarantees the performance of this device over specified ranges by conducting electrical characterization over each range and by conducting a production test with single insertion coupled to periodic sampling.



#### **1.4 Electrical Characteristics**

| Symbol           | Parameter                         | (Condition)                                                                                            | Min | Тур                          | Max    | Units            | Note     |
|------------------|-----------------------------------|--------------------------------------------------------------------------------------------------------|-----|------------------------------|--------|------------------|----------|
| Resoluti         | on                                |                                                                                                        | 1   |                              |        |                  |          |
| Ν                | Resolution, Nominal               |                                                                                                        | 16  |                              |        | Bits             |          |
| NMC              | No Missing Codes Guaranteed       |                                                                                                        | 16  |                              |        | Bits             |          |
| DC Accu          | iracy                             |                                                                                                        |     | 1                            | 1      | 1                |          |
| PSRR             | Power-supply rejection ratio      |                                                                                                        |     | 54                           |        | dB               |          |
| G <sub>ERR</sub> | Gain Error (Uncalibrated)         |                                                                                                        |     |                              | 1      | %FSR             | 1        |
| Vos              | DC Offset Error (Uncalibrated)    | - Chopper Off<br>- Chopper On                                                                          |     | ±10                          | ± 0.01 | mV               | 1        |
| $V_{REF}$        | Internal Voltage Reference        |                                                                                                        |     | 1.2                          |        | V                |          |
| $TCV_{REF}$      | Internal Voltage Reference Drift  | over temp                                                                                              |     | 100                          |        | ppm/°C           | 2        |
| INL              | Integral Non-linearity (PGA = x1) | 1                                                                                                      |     |                              | 0.02   | %FS              |          |
| DNL              | Differential Non-linearity (PGA = | x1)                                                                                                    |     |                              | 1      | LSB              |          |
| AC Accu          | iracy                             |                                                                                                        |     |                              | 1      |                  | <u> </u> |
| SNR              | Signal To Noise Ratio,            | $f_{S} = 2kHz$<br>$f_{S} = 20kHz$<br>$f_{S} = 200kHz$<br>$f_{S} = 2MHz$                                |     | 82<br>81<br>77<br>69         |        | dBFS             | 3        |
| SINAD            | Signal To Noise and Distortion,   | $\label{eq:states} \begin{split} f_S &= 2kHz\\ f_S &= 20kHz\\ f_S &= 200kHz\\ f_S &= 2MHz \end{split}$ |     | 81<br>80<br>76<br>69         |        | dBFS             | 3        |
| SFDR             | Spurious Free Dynamic Range,      | $\label{eq:states} \begin{split} f_S &= 2kHz\\ f_S &= 20kHz\\ f_S &= 200kHz\\ f_S &= 2MHz \end{split}$ |     | 89<br>88<br>88<br>87         |        | dBc              | 3        |
| THD              | Total Harmonic Distortion,        | $\label{eq:states} \begin{split} f_S &= 2kHz\\ f_S &= 20kHz\\ f_S &= 200kHz\\ f_S &= 2MHz \end{split}$ |     | -89<br>-88<br>-85<br>-83     |        | dBc              | 3        |
| ENOB             | Effective number of bits          | $f_{S} = 2kHz$<br>$f_{S} = 20kHz$<br>$f_{S} = 200kHz$<br>$f_{S} = 20MHz$                               |     | 13.2<br>13.0<br>12.4<br>11.2 |        | Bits             | 3        |
|                  |                                   |                                                                                                        |     |                              |        |                  |          |
| Analog I         | nputs                             |                                                                                                        | 1   | 1                            | 1      | 1                | L        |
| $V_{\text{FSR}}$ | Input Differential Voltage Range  |                                                                                                        |     | 1.6                          | 2.0    | V <sub>P-P</sub> |          |
| V <sub>CM</sub>  | Input Common Mode Voltage Ra      | ange                                                                                                   | 0.2 | 1.2                          | 2.5    | V                |          |
| CMRR             | Common Mode Rejection Ratio       |                                                                                                        |     | 55                           |        | dB               |          |
| C <sub>IN</sub>  | Input Capacitance (Single Endec   | (لا                                                                                                    |     | 5                            |        | pF               |          |
| R <sub>IN</sub>  | Input Resistance (Single Ended)   |                                                                                                        | 9.2 | 10.0                         | 10.8   | kΩ               | 4        |



pF kΩ

dB %

dBc

dB kHz MHz

mΑ

mΑ

mW

V V nA

kΩ

рF

V V

nA

pF

V

V

pF

pF

1.9

2.8

10

0.2

10

30

5

5

5

4

| Technolog         | lies                                                          |                                                                                                                                                                                                                                                             |      |                                |          |
|-------------------|---------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------------------------------|----------|
|                   | Differential Input Capacitance                                |                                                                                                                                                                                                                                                             |      | 10                             |          |
|                   | Differential Input Resistance                                 |                                                                                                                                                                                                                                                             | 4.6  | 5                              | 5.4      |
| AV_PB             | Passband Attenuation (DC to 500                               | ) kHz)                                                                                                                                                                                                                                                      |      |                                | 0.2      |
| GD                | Group Delay Variation (DC to 50                               | 0 kHz)                                                                                                                                                                                                                                                      |      |                                | 5        |
| CI                |                                                               |                                                                                                                                                                                                                                                             |      | 75<br>35                       |          |
| AN                | Alias Noise Attenuation                                       |                                                                                                                                                                                                                                                             | 45   |                                |          |
|                   | Anti-aliasing Filter Cutoff Frequer                           | ncy, aaf_freq=0<br>aaf_freq=1                                                                                                                                                                                                                               |      |                                | 500<br>3 |
| Supply            | Current & Power Dissipation                                   |                                                                                                                                                                                                                                                             |      |                                |          |
| I <sub>DD18</sub> | 1.8V Supply Operating Current                                 | $\begin{array}{l} - \ f_{S} = 1 \mbox{ Hz} \ (\mbox{four channels}) \\ - \ f_{S} = 100 \mbox{ Hz} \ (\mbox{four channels}) \\ - \ f_{S} = 2 \mbox{ MHz} \ (\mbox{single channel}) \\ - \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \$                                 |      | 98<br>129<br>147<br>1.1<br>0.5 |          |
| I <sub>DD33</sub> | 3.3V Supply Operating Current                                 | $\label{eq:started} \begin{array}{l} - f_{\rm S} = 1 \text{kHz} \mbox{(four channels)} \\ - f_{\rm S} = 100 \text{kHz} \mbox{(four channels)} \\ - f_{\rm S} = 2 \text{MHz} \mbox{(single channel)} \\ - \mbox{Standby} \\ - \mbox{Power Down} \end{array}$ |      | 17<br>17<br>4.3<br>0.6<br>0.2  |          |
| P <sub>DD</sub>   | Power Dissipation, Active - Sing<br>- Star<br>- Pow           |                                                                                                                                                                                                                                                             |      | 87<br>4<br>1.6                 |          |
| Digital I         | nputs (SCLK, SDI, /CS, /RST) †                                |                                                                                                                                                                                                                                                             |      |                                |          |
| V <sub>IH</sub>   | High-level Input Voltage, DV <sub>DD33</sub>                  | = 3.6V                                                                                                                                                                                                                                                      | 2    |                                | 5.5      |
| VIL               | Low-level Input Voltage, DV <sub>DD33</sub> =                 | = 3.0V                                                                                                                                                                                                                                                      | -0.3 |                                | 0.8      |
| I <sub>IN</sub>   | Input (leakage) current (SCLK, S                              | DI)                                                                                                                                                                                                                                                         |      | 2.1                            |          |
| R <sub>IN</sub>   | Pull-up Resistance (/CS, /RST)<br>Pull-down Resistance (DRDY) |                                                                                                                                                                                                                                                             | 31   |                                |          |
| C <sub>IN</sub>   | Input Capacitance                                             |                                                                                                                                                                                                                                                             |      |                                | 10       |
| Digital I         | nput (XIN) <sup>†</sup>                                       |                                                                                                                                                                                                                                                             |      | 1                              | 1        |
| VIH               | High-level Input Voltage, DV <sub>DD18</sub>                  | = 2.0V                                                                                                                                                                                                                                                      | 1.4  |                                | 5.5      |
| VIL               | Low-level Input Voltage, DV <sub>DD18</sub> =                 | = 1.6V                                                                                                                                                                                                                                                      | 0    |                                | 0.4      |
|                   | I                                                             |                                                                                                                                                                                                                                                             |      | 1                              | I        |

Digital Output (XOUT)<sup>†</sup>

 $I_{IN}$ 

 $C_{\text{IN}}$ 

 $V_{\text{OH}}$ 

 $V_{\text{OL}}$ 

 $C_{\text{O}}$ 

 $C_{L}$ 

Input (leakage) current

High-level Output Voltage,  $DV_{DD33} = 3.0V$ ,  $I_{OH} = -100uA$ 

Low-level Output Voltage,  $DV_{DD33} = 3.0V$ ,  $I_{OL} = 100uA$ 

Input Capacitance Digital Outputs (SDO, DRDY/SEL)<sup>†</sup>

**Output Capacitance** 

Load Capacitance



| V <sub>OH</sub> | High-level Output Voltage, DV <sub>DD18</sub> = 1.6V, I <sub>OH</sub> = -100uA | 1.4 |     | V  |  |
|-----------------|--------------------------------------------------------------------------------|-----|-----|----|--|
| V <sub>OL</sub> | Low-level Output Voltage, $DV_{DD18} = 3.0V$ , $I_{OL} = 100uA$                |     | 0.2 | V  |  |
| Co              | Output Capacitance                                                             |     | 10  | pF |  |
| CL              | Load Capacitance                                                               |     | 20  | pF |  |

1. System calibration will reduce these errors to below the noise level.

2. System calibration at any temperature will eliminate this error.

3. Programmable Gain Amplifier set at a gain of x1,  $f_{IN} = f_s / 25$ 

4. Input resistance may vary as much as +/-26% without calibration. See gain and offset calibration.

5. Standby is with all channels inactive, and analog front end turned off. Power down is when the oscillator/PLL is turned off.

<sup>†</sup> The digital input and output pins are 5V-tolerant. Inputs may be driven with 5V signals, outputs can be connected via pull-ups to 5V levels.

#### **1.5 Timing Requirements**

| Parameter                                                               | Min                                            | Мах     | Units | Note |
|-------------------------------------------------------------------------|------------------------------------------------|---------|-------|------|
| Input Clock Frequency, f <sub>0</sub>                                   | 5                                              | 200     | MHz   |      |
| Serial Port Clock Frequency, $f_{SCLK}$ (Run and Configure Modes)       |                                                | 40      | MHz   |      |
| Serial Port Clock Frequency, f <sub>EE</sub> (EEPROM Mode)              |                                                | 5       | MHz   |      |
| PLL Clock Frequency, PLL_CLK                                            | 20                                             | 200     | MHz   |      |
| Chip select low pulse width                                             | 2/SYS_CLK                                      |         | ns    |      |
| SYS_CLK frequency (User filters, sampling rates)                        | (((N <sub>TAPS</sub> + 1)/2)+1)*f <sub>S</sub> | PLL_CLK |       | 6, 9 |
| SYS_CLK frequency (Fixed G and H filters)                               | 103* f <sub>s</sub>                            | PLL_CLK |       | 7, 9 |
| SYS_CLK frequency (relative to SCLK) - 16-bit output<br>- 24-bit output | 3*SCLK/16<br>SCLK/(8*N)                        | PLL_CLK |       | 8, 9 |
| Setup time, Chip Select (/CS) low to SCLK↑                              | 5                                              |         | ns    |      |
| Setup time, SDI before SCLK↑                                            | 5                                              |         | ns    |      |
| Hold time, SDI after SCLK↑                                              | 5                                              |         | ns    |      |

6.  $f_S$  is the sampling rate for any given channel and  $N_{TAPS}$  is the number of taps used in the associated FIR. The highest value of the expression for any active channel defines the minimum frequency for SYS\_CLK.

7. This parameter is derived in similar fashion to the previous one and is determined by the fixed number of taps used in the G and H filters.

8. This limit is caused by the requirement for DRDY to be cleared before /CS returns to a high level after a data transfer. Two SYS\_CLKS are required to clear DRDY this must occur before the data transfer is completed. N is the number of channels active in the output data.

9. All three of the minimum conditions must be satisfied for correct device operation.



#### **1.6 Typical Performance Characteristics**

Default Conditions:  $T_A = 25 \text{ C}$ ,  $V_{DD18} = 1.8 \text{ V}$ ,  $V_{DD33} = 3.3 \text{ V}$ , unless otherwise noted.









### 2. PINOUT and PIN DESCRIPTIONS

2.1 Pinout



#### 2.2 Pin Descriptions

| Pin<br># | Pin Name          | Туре  | Description                                                             |
|----------|-------------------|-------|-------------------------------------------------------------------------|
| 1        | A <sub>IN1-</sub> | Input | Analog Input Channel 1 Differential-, or DC bias input (SE)             |
| 2        | A <sub>IN1+</sub> | Input | Analog Input Channel 1, Single-Ended or Differential+ (No phase shift)  |
| 3        | A <sub>IN2-</sub> | Input | Analog Input Channel 2 Differential-, or DC bias input (SE)             |
| 4        | A <sub>IN2+</sub> | Input | Analog Input Channel 2 , Single-Ended or Differential+ (No phase shift) |
| 5        | A <sub>IN3-</sub> | Input | Analog Input Channel 3 Differential-, or DC bias input (SE)             |
| 6        | A <sub>IN3+</sub> | Input | Analog Input Channel 3, Single-Ended or Differential+ (No phase shift)  |
| 7        | A <sub>IN4-</sub> | Input | Analog Input Channel 4 Differential-, or DC bias input (SE)             |
| 8        | A <sub>IN4+</sub> | Input | Analog Input Channel 4, Single-Ended or Differential+ (No phase shift)  |



| 9  | $DV_{DD18}$        | Power        | +1.8V DC Power (Digital)                                                                   |
|----|--------------------|--------------|--------------------------------------------------------------------------------------------|
| 10 | DGND               | Ground       | Digital Ground                                                                             |
| 11 | DGND               | Ground       | Digital Ground                                                                             |
| 12 | /CS                | Input        | Chip Select from SPI Bus (Low logic selects chip). Internal pull-up.                       |
| 13 | DRDY/SEL           | Input/Output | High when new data is ready, if pulled high accesses EEPROM direct.<br>Internal pull-down. |
| 14 | SDO                | Output       | SPI Serial Data Output                                                                     |
| 15 | SDI                | Input        | SPI Serial Data Input                                                                      |
| 16 | SCLK               | Input        | SPI Clock (Maximum 40 MHz)                                                                 |
| 17 | /RST               | Input        | Chip RESET (Low logic resets chip). Internal pull-up.                                      |
| 18 | DGND               | Ground       | Digital Ground                                                                             |
| 19 | $DV_{DD18}$        | Power        | +1.8V DC Power (Digital)                                                                   |
| 20 | $DV_{DD33}$        | Power        | +3.3V DC Power (Digital)                                                                   |
| 21 | $XV_{DD18}$        | Power        | Filtered +1.8V DC Power for Internal Oscillator                                            |
| 22 | XIN                | Input        | Crystal connection or external clock input (5-200 MHz)                                     |
| 23 | XOUT               | Output       | Crystal connection                                                                         |
| 24 | XGND               | Ground       | Ground for Internal Oscillator                                                             |
| 25 | PGND               | Ground       | Ground for Phase Lock Loop                                                                 |
| 26 | $PV_{DD18}$        | Power        | +1.8V DC Filtered Power for Phase Lock Loop                                                |
| 27 | AGND               | Ground       | Analog Ground                                                                              |
| 28 | $AV_{DD18}$        | Power        | +1.8V DC Power (Analog)                                                                    |
| 29 | AV <sub>DD18</sub> | Power        | +1.8V DC Power (Analog)                                                                    |
| 30 | AGND               | Ground       | Analog Ground                                                                              |
| 31 | AGND               | Ground       | Analog Ground                                                                              |
| 32 | $AV_{DD33}$        | Power        | +3.3V DC Power (Analog)                                                                    |



### **3. GENERAL DESCRIPTION**



Figure 1. Functional Block Diagram

#### 3.1 Analog Front End (AFE)

The AFE consists of a Programmable Gain Amplifier (PGA), a chopper-stabilized amplifier and an Anti-Aliasing Filter.

#### Programmable Gain Amplifier (PGA)

The PGA can be set at gains of 1X, 2X, 4X, and 8X. The input impedance of the PGA is  $10k\Omega$  on both the positive and negative inputs. The PGA can be configured as either single ended or differential and can receive inputs of up to 2.0V p-p directly. With a single scaling resistor in each channel, two if configured differentially, the PGA can receive signals of up to +/- 10Vp-p or higher.

#### Chopper-stabilized Amplifier (not shown in diagram)

This circuit minimizes correlated (1/f) noise and dc offset within the chip. For sampling rates less than 200kHz this circuit will maximize signal-to-noise performance, and hence SINAD and ENOB. (see Section 6.2)

#### Anti-Aliasing Filter (AAF)

The Anti-Aliasing Filter is designed to reject frequencies that are higher than the band of interest. If those frequencies are sent to the ADC, they can alias back into the band of interest and can cause erroneous readings to result. The AAF is a 3rd order Bessel function (linear phase) and is set to the appropriate cut-off frequency based on the filter design that is implemented. The AAF has two available cut off frequencies, 500kHz and 3MHz.

#### 3.2 Analog to Digital Converter (ADC)

The ADC has a pipeline architecture that is 12 bits in hardware and runs at up to 100Msps. Resolutions of up to 16 bits are achieved by oversampling the input and averaging the resultant conversions. During Chip Configuration and Filter Design, the exact sampling speed of the ADC is determined (based on the highest sampling rate required for any one of the four channels).

Not shown in the block diagram are the following sub-blocks which handle decimation/down-conversion of the oversampled data:

#### CIC (Cascaded Integrator Comb Filters)

The purpose of the CIC filter is the integration of 16 bits, and adjustment of the proper sample rate through decimation. The digitized signal is then processed in the CIH (Cascaded Integrator Halfband Filters)

#### CIH (Cascaded Integrator Halfband Filters)



The purpose of the CIH stage is droop recovery to compensate for the frequency response of the CIC filter. After moving through the CIH, the signals are sent into the FIR (Finite Impulse Response Filter) for user filtering.

#### 3.3 Finite Impulse Response filter (FIR)

The four FIR filters consist of 512 taps each and are individually programmable. A different filter design may be implemented in each of the 4 filters and may include lowpass, notched lowpass, highpass, bandpass, dual bandpass, bandstop, and dual bandstop. Currently available filter algorithms include Parks-McClellan and Windowed Sinc.

#### 3.4 Serial Interface - Serial Peripheral Interface (SPI)

The serial interface is fully compatible with a standard SPI bus. The serial bus on the QF4A512 is capable of running at up to 40 MHz, although it may be run at much lower speeds. The QF4A512 operates in a SLAVE mode.

Two main modes of operation are used by the bus:

"Configure" mode is used to setup and program the QF4A512 Coefficient RAMs and control registers. Read access to the data RAMs is also available.

"Run" mode provides up to 4 channels of 16-bit multiplexed data out the SPI port. The format is 24-bit (New Data Flag + Over Flow Info + Channel ID + 16-bits of data) multiplexed data. The chip will arbitrate between the incoming channels from the FIRs by monitoring each channel's internal data ready signal. If new data for a given channel is ready in time, it will be inserted on the serial output stream at the appropriate place for that channel and the new data flag will be set in the header. Otherwise the old data will remain in the time slot and the new data flag will not be set. The highest channel sample rate is used as the data rate output for a Data Ready signal, which can be used to maximize bus throughput.

#### 3.5 Startup Modes

The behavior of the QF4A512 during power up or after a reset can be determined by the configuration of 2 bits in the **STARTUP\_1** register (07h). The **auto\_config** bit, if set, will initiate transfer of EEPROM contents to the control registers and FIR filter coefficient RAMs.

The **auto\_start** bit will determine whether the chip starts in Run mode, filtering and sending data out on the SPI bus (**auto\_start=1**), or the chip will wait in configure mode until manually started (**auto\_start=**0).

If the **auto\_config** bit is not set, the chip will wait in configure mode until externally programmed.

An Extended Initialization mode is also available to perform sequences of data transfers from EEPROM to chip control registers (See Chapter 5).

#### 3.6 Memory

The QF4A512 features on-chip Control Registers, RAM and EEPROM. Important device configuration data and filter coefficients can be copied to EEPROM to provide non-volatility. These data can be copied back from EEPROM when the chip is powered up making it unnecessary to reprogram the device at each power up or reset.



#### **RAM / REGISTERS**

Figure 2. Memory Map



QF4A512



Within EEPROM, 128 bytes of user space are provided for storing application-specific information. This data could include, for example, Transducer Electronic Data Sheets (TEDS, IEEE P1451.4).

The full 14-bit address space can be accessed via the SPI interface in the "Configure" mode. In the "Run" mode only 8-bits of address space can be accessed, which include the command registers and other general configuration registers.

### 4. SOFTWARE

#### 4.1 Device Configuration

Before useful data can be output from the QF4A512 it must first be correctly configured. Configuration parameters include the following:

- 1. Startup mode. Options include copying configuration parameters and filter coefficients from EEPROM and then immediately running or waiting for an external command.
- 2. Number of channels to be active.
- 3. Gain of the PGA for each input channel.
- 4. Cutoff frequency of the anti-aliasing filter for each channel.
- 5. Analog to digital converter sampling rate and decimation/down conversion rate for each channel.
- 6. FIR filter coefficients.
- 7. Output data format.

#### 4.2 Quickfilter Development Kit (QF4A512-DK)

The Development Kit is a complete hardware and software combination which allows for rapid development of the QF4A512 configuration parameters for a specific application.

The Quickfilter Pro Design Software tool allows all the necessary parameters to be generated in a quick and user-friendly manner. The user enters the desired characteristics (e.g. sampling rates, type of filter, cut-off frequencies etc.) for each channel and the software generates a configuration file for the device. The configuration file can be immediately downloaded into the QF4A512 on the development board, and the *actual hardware device performance* can be monitored - either in response to a PC-generated noise source or to a user-applied signal. Device configuration parameters can be further adjusted, if necessary, until the optimum system performance is reached.

Once satisfied with the performance the configuration file can be saved for future use, for example to program devices in bulk prior to volume board manufacturing.

#### 4.3 In-circuit (Re)configuration

The Quickfilter Pro Design Software is the recommended method to derive the configuration data for the device. However, it may sometimes be desired to verify the configuration written to the device. Or, in certain applications, it may be desired to re-configure the device in circuit from a host MCU, for example to switch channels on/off, change gain values etc. Therefore, more detailed descriptions of device operation and descriptions of various register settings etc. can be found in sections 5 - 12. For most applications the software alone will be sufficient to provide optimum device performance and reference to these sections will be unnecessary.





### 5. STARTUP

The behavior of the QF4A512 during power up or after a reset can be determined by the configuration of 2 bits in the **STARTUP\_1** register. The **auto\_config** bit, if set, will initiate transfer of EEPROM contents to the control registers and FIR filter coefficient RAMs.

The **auto\_start** bit will determine whether the chip starts in Run mode, filtering and sending data out on the SPI bus (**auto\_start=1**), or the chip will wait in configure mode until manually started (**auto\_start=0**).

If the **auto\_config** bit is not set, the chip will wait in configure mode until externally programmed.

#### 5.1 Power up / Reset Sequence









The sequence of events that occurs after a hardware reset is detailed in the preceding diagram. The hardware reset will be applied at power-up or when the external /RST pin is toggled low. If the DRDY pin is held high (for example to write directly to EEPROM) the startup sequence is bypassed.

#### 5.2 Extended Initialization

There is an option to perform an Extended Initialization regardless of the setting for **auto\_config**. The Extended Initialization comprises a series of programmable block transfers from the EEPROM to the on-chip registers. To invoke Extended Initialization the **alt\_startup1** bit must be set in the **STARTUP\_1** register (07h). This will cause the chip to read the **xtnd\_init** bit in the **STARTUP\_2** Register (Bit 2, register 08h) to determine if an Extended Initialization will occur. If **xtnd\_init** is set the chip will then read the starting address for the sequence(s) in EEPROM, **initseq\_addr**, from registers **IGC\_SEQADDR** (EBh, ECh).







Note: The value in the **IGC\_SEQADDR** registers can set in two ways. By default, if **auto\_config** is not set it will take a value of F00h – corresponding to the start of User Memory. If **auto\_config** is set it will be written to the value stored in the corresponding EEPROM address.

The format for the sequences stored in EEPROM is shown in figure 4. The sequences must be in consecutive memory locations and consist of a series of addresses, each having a 16-bit (i.e 2 byte) value.

The first address, **seqstop\_addr**, is simply the ending address for the sequence and points to the byte immediately following the final sequence address. This is then followed by a series of sequences, each comprising three addresses. The first address, **seq\_eestartaddr**, points to the starting address in EEPROM for the block read. The second address, **seq\_sifstartaddr**, points to the destination starting address for where the block data will be written. The third address, **seq\_sifendaddr**, is the destination ending address for the data to be written. This will cause the chip to copy a number of bytes, N, starting at address **seq\_eestartaddr** to a block of registers starting at **seq\_sifstart\_addr** and ending at **seq\_sifendaddr**, where **seq\_sifendaddr** = **seq\_sifstartaddr** + N - 1.

Once this transfer is complete the chip will move to the next sequence and perform a similar operation for its specified addresses, until it reaches **seqstop\_addr**. At this point the chip will return to the corresponding point in the Power Up / Reset flow as shown in figure 3.

#### 5.3 Calibration

One possible use for an Extended Initialization sequence is to transfer calibration values stored in EEPROM to the corresponding gain and offset calibration registers for each channel. For more information see Section 7.7.

Quickfilter"

### 6. ANALOG FRONT END (AFE)

#### 6.1 Configurable parameters

The following items are configurable for the AFE:

- 1. Chopper on or off
- 2. PGA Gain
- 3. AAF Cutoff Frequency
- 4. Channel on or off

These settings can all be configured via the Quickfilter Pro software.

#### 6.2 Chopper-stabilized Amplifier

Low frequency flicker noise, which is inherent to CMOS devices, limits maximum dynamic range that can be attained solely by oversampling and averaging data from the analog front end (AFE). This flicker noise has a 1/f^n characteristic, which dominates other noise sources at low frequencies of interest. This is in contrast to white noise, with a flat frequency spectrum, which proportionally decreases with oversampling and averaging.

Chopper stabilization is a technique that applies modulation to transpose the signal of interest to a higher frequency where there is no flicker noise, and then demodulate it back to the baseband after amplification. Details can be found in the following paper: 'Circuit Techniques for Reducing the Effects of Op-Amp Imperfections: Autozeroing, Correlated Double Sampling, and Chopper Stabilisation' By Enz and Temes, Proceedings of the IEEE, November 1996.

In the QF4A512, the circuit is chopped at the input (prior to the PGA) and is remodulated back to the baseband after the analog to digital conversion has occurred. Harmonic components of the chopper frequency are subsequently filtered out in the CIC and CIH blocks. The chopper circuit improves the SNR for configurations with data rates 200 kHz and below. Two important settings in the QF4A512 are the chopper frequency and the phase offset between the modulator and demodulator.

The chopper frequency is set with a divider whose setting is closely related to the CIC R decimation value. The chopper frequency is derived from the ADC clock and the divider value is stored in the **CHPC\_DIV***n* register for each channel. The best setting for the chopper divider is 2 x R x (# of active channels) in most cases. This setting puts the chopper 2nd harmonic frequency in the first null of the CIC filter to most effectively remove it from the final digital signal. While the chopper circuit is effective at signal data rates of 200 kHz and below (down to Hz), the chopper signal itself is most effective at 10 kHz and above, which means the chopper divider should track the CIC R value down only to the point where the chopper frequency would be 10 kHz. For example, for a 4 channel configuration, with the ADC clock running at 50 MHz, and output data rates of 10 kHz and below, the chopper divider should be set no higher than 4E2h (decimal 1250) to ensure the chopper frequency is 10 kHz or above.

The chopper phase accounts for the group delay of the AAF and the pipeline delay of the ADC to ensure the modulated signal is demodulated in the correct phase. The value, which ranges from 680-810 ns, is factory calibrated.

#### 6.3 Programmable Gain Amplifier (PGA)

The PGA buffers and amplifies analog input signals prior to conversion and filtering. The input impedance of the PGA is around 10K on both the positive and negative inputs. The PGA incorporates a chopper stabilized amplifier design to minimize dc offset and noise.

The PGA can be configured as either single-ended or differential and can receive input signals of up to 2.0V p-p directly. With the addition of a single scaling resistor in each channel, two if configured differentially, the PGA can receive signals of up to +/- 10Vp-p or higher. (see Section 14, Applications Circuits)

The PGA gain for each channel can be set to a value of 1, 2, 4 or 8, allowing for the optimum signal level to be passed on for further processing. Usually this will be configured automatically by the Quickfilter Pro software, the resultant value can be verified in the **CHn\_PGA** register (n = channel number). The gain should be set as high as possible for best SNR, but not too high to cause clipping of the input signal.



#### 6.4 Input Voltage Levels

Ideally the maximum input voltage to the QF4A512 should correspond to a full-scale reading from the ADC. If the input signal level is too low to achieve this, then PGA gain can be introduced to provide a larger signal to the ADC. If the input signal is too high then it should be attenuated to prevent clipping (see section 13 for suggested input circuit configurations). Positive full-scale output from the ADC (7FFFh) will occur when the positive input,  $A_{IN+}$ , is 1V more positive than the negative input,  $A_{IN-}$ . Negative full scale output (8000h) will occur when  $A_{IN+}$  is 1V more negative than  $A_{IN-}$ .



Figure 5. QF4A412 Input schematic

Internally, each input is biased to 1.2V, with a recommended input voltage range from 0.5V to 2.5V. This limits the negative swing on the input to -0.7V so to achieve full scale output from the ADC the input swing would be limited to +/-0.5V (with respect to the 1.2V bias) and a PGA gain of x2 would be selected.

This subject is covered in more detail in Application Note QFAN004, Interfacing Analog Signals to the QF4A512 programmable Signal Converter.

#### 6.5 Anti-Aliasing Filter (AAF)

The Anti-Aliasing Filter is designed to reject frequencies that are higher than the band of interest. If those frequencies are sent to the ADC, they can alias back into the band of interest and can cause erroneous readings to result. The AAF is a 3rd order Bessel function (linear phase) and is set to the appropriate cut-off frequency based on the filter design that is implemented. The AAF has two available cut off frequencies, 500kHz and 3MHz.

The anti-aliasing filter has two frequency cutoff settings which are also configured by the Quickfilter Pro software. If desired the value can be verified in register **CH**n**\_CFG** (where n is the channel of interest). Either 0.5MHz or 3MHz can be selected according to the frequency of interest for each particular channel.

#### 6.6 Enabling Channels

For a given channel to be active and produce digital output data the following conditions must be met:

- a) ADC and system clock enabled (Register ENABLE\_0, control bits pcg\_ch\_enb).
- b) AAF enabled (Register **ENABLE\_1**, control bits **afe\_opmfec**).
- c) Sampling of the designated channel enabled and demuxing to the selected output data stream (Register ENABLE\_2, control bits arec\_ch\_enab).
- d) Channel designated to be present in the output data stream (Register ENABLE\_2, control bits sif\_ch\_enab)
- e) Channel enabled in the global channel control register (Register GLBL\_CH\_CTRL, control bit ch*n*\_pwrd, where *n* is the channel number)

To disable a channel it is only necessary to set the corresponding disable bit in the **GLBL\_CH\_CTRL** register, this setting will override the ENABLE register bit settings described above.



### 7. ANALOG TO DIGITAL CONVERTER

#### 7.1 Overview

The ADC has a pipeline architecture that is 12 bits in hardware and runs at up to 100Msps. Resolutions of up to 16 bits are achieved by oversampling the input and averaging the resultant conversions. With INL and DNL of +/- 1LSB, 16 bit linearity is achieved. During Chip Configuration and Filter Design, the exact sampling speed of the ADC is determined (based on the highest sampling rate required for any one of the four channels).

Not shown in the block diagram are the following sub-blocks which handle decimation/down-conversion of the oversampled data:

**CIC** (Cascaded Integrator Comb Filters)

The purpose of the CIC stage is the integration of 16 bits, and adjustment of the proper sample rate through decimation. The digitized signal is then processed in the CIH (Cascaded Integrator Halfband Filters)

**CIH** (Cascaded Integrator Halfband Filters)

The purpose of the CIH stage (not shown in block diagram) is droop recovery to compensate for the frequency response of the CIC filter. After moving through the CIH, the signals are sent into the FIR (Finite Impulse Response Filter) for user filtering.

#### 7.2 Sampling Rates / ENOB

The QF4A512 features a very flexible architecture allowing tradeoffs between resolution, sampling rate and accuracy. The combination of the ADC sampling rate, subsequent down-conversion in the CIC/CIH blocks and number of active input channels will determine the *effective sampling rate,* (f<sub>S</sub>), or each input channel. The effective sampling rate is the parameter which limits the overall input bandwidth, according to Nyquist. The table illustrates several different configurations and performance levels for various ADC clock rates.

| Table 1. Example sampling rates and ADC clock frequency | Table 1. | Example | sampling | rates and | ADC | clock frequency |  |
|---------------------------------------------------------|----------|---------|----------|-----------|-----|-----------------|--|
|---------------------------------------------------------|----------|---------|----------|-----------|-----|-----------------|--|

| ADC clock<br>(f <sub>ADC,</sub> MHz) | Oversampling<br>Rate | Effective<br>Sampling Rate<br>(f <sub>S</sub> ) | Aggregate.<br>BW * | Data<br>Output<br>(bits) |
|--------------------------------------|----------------------|-------------------------------------------------|--------------------|--------------------------|
| 12.5                                 | 6248                 | 2 kHz                                           | 909 Hz             | 16                       |
| 12.5                                 | 624                  | 20 kHz                                          | 9.09 kHz           | 16                       |
| 25                                   | 128                  | 201.6 kHz                                       | 91.6 kHz           | 16                       |
| 50                                   | 24                   | 2.08 MHz                                        | 945 kHz            | 16                       |
| 100                                  | 48                   | 2.08 MHz                                        | 945 kHz            | 16                       |

\* The aggregate bandwidth is equal to the effective sampling rate divided by 2.2.

Although the ADC is 12-bits in hardware, the effective resolution can be increased by oversampling. Theoretically, a 4x increase in the oversampling rate increases the effective resolution by 1 bit. Decimation within the converter always results in 16-bit output data words, regardless of oversampling rate. Beyond a certain limit, determined by the noise and distortion performance of the device, the effective number of bits (ENOB) does not increase any further. For the QF4A512, oversampling rates above 100 have been coded into the Quickfilter Pro Software ("Optimize Precision") to provide optimum performance.

Depending on the application and frequencies of interest it may be more meaningful to refer to the SNR, SFDR or THD in Electrical Characteristics, for a more accurate reflection of overall system performance.

The ADC clock rate (Register ADC\_CLK\_RATE) is always the same for all four channels. However, the oversampling rate can be varied on a per-channel basis. Oversampling by a factor of 4 always occurs in the CIH block, additional oversampling occurs according to the value of "R" in the CIC block. The effective sampling rate ( $f_S$ ) for each channel is given by the following formula:

Equation 1: effective sampling rate

 $f_S = f_{ADC} / (4 \times R \times N)$ 

R = CIC "R" value (register **CIC** $_n$ R , **n** = channel number) N = Number of active channels

There are many more combinations of ADC clock rate and CIC R values than shown in the table. The Quickfilter Pro software will chose optimum values for each depending on the filter characteristics specified for each of the configured channels. The resulting parameters can be reviewed in the software, and also reviewed by examining the QF4A512's register contents.



#### 7.3 Aggregate Bandwidth

The aggregate bandwidth is the total bandwidth available to all active channels. If only one channel is active then it can use the entire bandwidth, but as further channels are activated the bandwidth available to each will be reduced. Since the oversampling rate can be adjusted for each channel the bandwidth for that channel should be calculated based on its own effective sampling rate. Although Nyquist suggests the sampling rate should be twice the highest frequency of interest it is recommended that a factor of 2.2 be used for optimum performance.

#### 7.4 Serial Interface

For higher frequencies of interest the data rate across the SPI bus must also be considered. The maximum clock rate for the bus is 40MHz which results in a maximum 1.66MHz word rate for 24-bit transfers (multi-channel mode), or 2MHz word rate for 16-bit transfers (single channel mode). The SPI transaction requires typically 3 additional SPI clocks cycles per sample. Allowing for further bandwidth reductions when multiple channels are active, and by applying the 2.2 oversampling factor the maximum analog bandwidth can be determined as shown in the table under "Maximum sampling rate SPI Bus". The last row of the table shows the actual maximum sampling rates for the QF4A512 when **Equation 1: effective sampling rate** (see section 7.2) is used. The actual sampling rate is limited by the available 'R' values.

| Table 2. Maximum Analog Input Frequency @40M | /Hz SPI bus clock |
|----------------------------------------------|-------------------|
|----------------------------------------------|-------------------|

|                                   | Single Channel | el Multi-channel Mode |             |             |             |  |  |  |  |  |  |
|-----------------------------------|----------------|-----------------------|-------------|-------------|-------------|--|--|--|--|--|--|
|                                   | Mode           | 1 channel             | 2 channels  | 3 channels  | 4 channels  |  |  |  |  |  |  |
| Maximum analog input<br>frequency | 0.909MHz       | 672kHz                | 356kHz      | 242kHz      | 183kHz      |  |  |  |  |  |  |
| Maximum sampling rate<br>SPI Bus  | 2.11Msps       | 1.48Msps              | 784ksps     | 533ksps     | 404ksps     |  |  |  |  |  |  |
| Maximum sampling rate<br>QF4A512  | 2.083Msps      | 1.47Msps              | 781.250ksps | 520.833ksps | 390.625ksps |  |  |  |  |  |  |

#### 7.5 Data Format

The filtered ADC output words are always 16 bits in length. (The 24-bit words output in multi-channel mode comprise a 16-bit data word plus channel ID and status info, see section 10, Serial Interface). The output format is 2's complement so the msb can be regarded as a sign bit. The maximum positive value is 7FFFh, corresponding to an input differential voltage of +1V. The most negative value is 8000h, corresponding to an input differential voltage of -1V (assuming 1x gain).

Each lsb will correspond to  $30.5\mu$ V at the input with a PGA gain of 1,  $15.25\mu$ V with a gain of 2,  $7.63\mu$ V with a gain of 4 and  $3.81\mu$ V with a gain of 8.

#### 7.6 Analog Mux

The ADC samples each input channel in turn at the output of the analog multiplexer. It takes 9 clock cycles to complete each sample so there is a latency of 9N clock cycles before a complete sample is passed on to the next stage (where N is the number of active channels). Thereafter the pipeline architecture of the ADC will output data on every cycle for subsequent samples. The data samples from the ADC are accumulated and decimated in the CIC/CIH blocks for each respective channel.

#### 7.7 Gain and Offset Calibration

Provision is provided on chip to calibrate both gain and offset to compensate for deviations from nominal performance in the Analog Front End and ADC. The calibration registers can also be user configured to compensate for variations in external components in the user's application circuit.

Offset calibration, on a per channel basis, is achieved by use of the **CAL\_n\_OFF** register (addresses 56h, 57h for channel 1). This 16bit value has a default setting of 0h. By appropriately setting this register, offset error can be reduced to less than 1 lsb, well below the noise floor of the device. Typically this register is set to produce a zero output with the differential inputs are shorted together.

Note: If the chopper circuit is used the offset error is effectively removed with no need for offset calibration.

Gain calibration can be used to fine tune the gain of the chip over a 2:1 range. Register **CAL**\_*n*\_**GAIN** (addresses 58h, 59h for channel 1) is used to set the gain on a per channel basis. The nominal / default value for this 16-bit value is 8000h, increasing or decreasing the value will adjust the gain in either direction. User gain calibration can be performed by applying a specific voltage to the analog input and adjusting the value of the **CAL**\_*n*\_**GAIN** registers until the appropriate output value is achieved. When used in conjunction with the PGA gain setting it is equivalent to having the ability to scale the input voltage over approximately a 0.5x to 16x range in fine increments. See application notes for calibration details.



#### 7.8 Factory Calibration

Device level calibration can be performed during product test. However such calibration will not be as useful as system-level calibration performed by the user. Therefore, by default, factory calibration is NOT performed. Please contact Quickfilter to discuss any requirements you have for factory calibration.

#### 7.9 User (System-level) Calibration

Overall system level performance can be improved if a system level calibration is performed. Using this technique gain and offset errors introduced by variation in external components as well components internal to the QF4A512 itself can be minimized. To achieve this improvement, provision must be made in the user's application circuit to short the input to the channel of interest (for offset calibration) and to apply a known fixed voltage (for gain calibration). The calculated gain and offset calibration values are written to the appropriate CAL\_n\_GAIN and CAL\_n\_OFF registers.

To perform a user calibration the CAL\_CTRL (EDh) and CAL\_DTGT (EEh) registers are used:

- 1. The cal\_chan\_set bits are written to select the channel, *n*, to be calibrated. (00 = channel 1, 01 = channel 2 ...11= channel 4)
- 2. The cal\_gain\_mode bit selects whether offset (0) or gain (1) calibration is being performed.
- 3. The **CAL\_DTGT** register holds the desired target value (ADC output value) for the voltage applied to the input. It should be set to zero for offset calibration.
- 4. The cal\_enab bit is then written to start the calibration measurement.
- 5. The resultant calibration value is written to the CAL\_n\_GAIN (if doing a gain calibration) or CAL\_n\_OFF (if doing offset calibration) register.
- 6. Completion of the test is indicated by **DRDY** going high (and the **cal\_enab** bit will auto clear).

Typically this sequence would be performed first for the offset calibration and then repeated (after adjusting **cal\_gain\_mode** and **CAL\_DTGT** accordingly) for gain calibration.

7. To make this calibration data non-volatile the CAL\_n\_GAIN and CAL\_n\_OFF register values should be copied to EEPROM ((see Section 11.2)) after the calibration measurement is complete.

For gain calibration the target value (**CAL\_DTGT**) will depend on the input voltage applied and the PGA gain setting for the channel. For example, a full scale (positive) reading of the ADC would be 7FFFh for a 1V input (to the ADC). If the PGA gain is set to x2 this would correspond to a +0.5V differential voltage at the device input pins. In practice a fixed input voltage in the range of 75-80% of full scale and the corresponding ADC output value would typically be used – allowing for some headroom for offset calibration and to prevent "clipping" of the ADC output for slightly over-range input voltages.

Note: The method described above is ideal if the QF4A512 configuration is static in the user's application. If the application calls for dynamically altering the configuration (for example PGA gain), or if a single design is used for multiple applications with differing configurations, it may be beneficial to take multiple calibration readings, one for each configuration. In this case the multiple calibration values could be stored in User EEPROM and transferred to the calibration registers at power up (or reset) by means of an extended initialization sequence tailored for the desired configuration. This is the same technique that is used to transfer the factory calibration data to the appropriate calibration registers. Indeed, if user calibration is performed it may be convenient to replace the default factory calibration values with the user measured values.



### 8. FIR FILTERS

#### 8.1 FIR Overview

Each channel features a 512-tap FIR which is used to define the precise filtering characteristics desired. The filtering characteristics of each channel may be set independently may include any combination of the following types: lowpass, notched lowpass, highpass, bandpass, dual bandpass, bandstop, and dual bandstop. Currently available filter algorithms include Parks-McClellan and Windowed Sinc.

The Quickfilter Pro software allows the user to enter the filter characteristics required and see the predicted performance in terms of frequency and impulse response. Once the desired performance has been attained, the configuration can be downloaded to the QF4A512, and the actual hardware performance verified, by using the development kit. The device can be fed with a white noise source (or other source as desired by the user) and the software can display an FFT of the QF4A512's filter response.

The FIR coefficients are downloaded from EEPROM into RAM at power up (depending on the contents of the STARTUP register). The output data from the FIRs is stored in data RAM, this data in turn is output from the SPI port when the device is run mode (see Section 9).

ain

#### 8.2 FIR Memory Locations

The memory locations for the control registers, coefficient and data RAM's for each channel are shown in the following tables:

| Address       | Register Name    | Description                                        |
|---------------|------------------|----------------------------------------------------|
| 0030h         | CH1_PGA          | Control Register. Enable FIR operation, set PGA ga |
| 0100h – 017Fh | FIR_0_0_COEF_RAM | G & H coefficients                                 |
| 0300h – 05FFh | FIR_0_1_COEF_RAM | FIR Coefficients                                   |
| 1000h – 10FFh | FIR_0_0_DATA_RAM | G & H Data memory                                  |
| 1400h – 17FFh | FIR_0_1_DATA_RAM | FIR filter Data Memory                             |

Table 3. Channel 1 - FIR Filter Address Information

#### Table 4. Channel 2 - FIR Filter Address Information

| Address       | Register Name    | Description                                           |
|---------------|------------------|-------------------------------------------------------|
| 0060h         | CH2_PGA          | Control Register. Enable FIR operation, set PGA gain. |
| 0180h – 01FFh | FIR_1_0_COEF_RAM | G & H coefficients                                    |
| 0600h – 08FFh | FIR_1_1_COEF_RAM | FIR Coefficients                                      |
| 1100h – 11FFh | FIR_1_0_DATA_RAM | G & H Data memory                                     |
| 1800h – 1BFFh | FIR_1_1_DATA_RAM | FIR filter Data Memory                                |

Table 5. Channel 3 - FIR Filter Address Information

| Address       | Register Name    | Description                                           |
|---------------|------------------|-------------------------------------------------------|
| 0090h         | CH3_PGA          | Control Register. Enable FIR operation, set PGA gain. |
| 0200h – 027Fh | FIR_2_0_COEF_RAM | G & H coefficients                                    |
| 0900h – 0BFFh | FIR_2_1_COEF_RAM | FIR Coefficients                                      |
| 1200h – 12FFh | FIR_2_0_DATA_RAM | G & H Data memory                                     |
| 1C00h – 1FFFh | FIR_2_1_DATA_RAM | FIR filter Data Memory                                |

Table 6. Channel 4 - FIR Filter Address Information

| Address       | Register Name    | Description                                           |
|---------------|------------------|-------------------------------------------------------|
| 00C0h         | CH4_PGA          | Control Register. Enable FIR operation, set PGA gain. |
| 0280h – 02FFh | FIR_3_0_COEF_RAM | G & H coefficients                                    |
| 0C00h - 0DFFh | FIR_3_1_COEF_RAM | FIR Coefficients                                      |
| 1300h – 13FFh | FIR_3_0_DATA_RAM | G & H Data memory                                     |
| 2000h – 23FFh | FIR_3_1_DATA_RAM | FIR filter Data Memory                                |

Note: Address space from 0F00h - 0FFFh and 2400h - 3FFFh is not used.



#### 8.3 FIR Latency

There will be a delay introduced to the signal as it passes through the QF4A512. There are several components to this latency:

- 1. PGA and AAF = If sample frequency  $F_S$  is greater than 800kHz add 0.122uS, else add 0.667uS
- 2. ADC = 12/ADC Clock rate
- 3. CIC = (Number of Channels\*4/ADC Clock rate)+(5/(4\*F<sub>S</sub>))
- 4.  $G = (G \text{ number of taps} 1) / (2^*G_F_S) = 7 / (4^*F_S)$
- 5.  $H = (H number of taps 1) / (2^*H_F_S) = 44/(2^*F_S)$
- 6. FIR filters = (Number of taps -1) / (2\*F<sub>S</sub>)

The dominant influence on the overall latency will be number of taps in FIR filter.

Download Quickfilters QF4A512 Latency Calculator from our website at <u>www.quickfiltertech.com</u> this excel spreadsheet based calculator will give you immediate accurate results. QFPro Software also shows the latency during configuration.

#### 8.4 Maximum number of taps

There may be situations where it is not possible to implement a filter using all 512 taps. Quickfiters QFPro software limits the number of taps you can use if the design approaches the maximum limits. At high sampling rates it may not be possible to implement all 512 taps within the maximum available sys\_clk rate. The FIR processes two taps per sys\_clk and requires 4 additional clocks to fill the processor pipeline. The equation which determines the max taps is as follows:

#### Max Taps = $2 * Sys_clk/f_s - 4$

Example: sys\_clk = 200MHz (max allowed value), fs =  $2MHz \rightarrow Maximum$  number of taps = 196.



Figure 6. Maximum Taps vs. Sample Rate vs. Sys Clk

### 9. SYSTEM CLOCKS

The master clock for the QF4A512 is produced by a crystal oscillator with a nominal frequency of 20MHz. Alternatively, the device can be fed with an external clock signal derived elsewhere. The master clock is used as a reference for a phase-locked loop (PLL), from



which clocks are derived to drive the FIR filters, the ADC and the analog front end. The master clock is also divided down to provide a clock to be used for transfers to the on-chip EEPROM.



Figure 7. System Clocks Block Diagram (Default settings shown)

#### 9.1 PLL Clock

The PLL clock frequency is determined by the input clock frequency, f<sub>0</sub>, the pre-divider value (M) and the divider value (N):

 $PLL\_CLK = f_0 * N / M$ 

The default frequency for PLL\_CLOCK is 200MHz. ( $f_0 = 20MHz$ , M = 1, N= 10)

Operation of the PLL is possible in two frequency ranges: 20-100MHz and 100-300MHz.

Control registers: PLL\_CTRL0 and PLL\_CTRL1

#### 9.2 System Clock

The System Clock (SYS CLK) is divided down from PLL CLK by a number in the range 1 - 64, default = 1. SYS CLK is used as the reference for the FIRs.

The default frequency for SYS CLK is 200MHz.

Control register: SYS\_CLK\_CTRL

#### 9.3 ADC Clock

The ADC Clock (ADC CLK) is also divided down from PLL CLK. The range of divisor values is 2 -16, default = 2. ADC CLK is used to drive the ADC (including CIC and CIH blocks) and other analog front end blocks.

The default frequency for ADC\_CLK is 100MHz.

Control register: ADC\_CLK\_RATE

#### 9.4 EE Clock

The EE Clock (EE CLK) is used for transfers to/from EEPROM. This clock is divided down directly from the master clock with divisors in the range 1 - 32, default value = 16.

The default frequency for EE\_CLK is 1.25MHz.

Control register: STARTUP

### **10. SERIAL INTERFACE**

#### 10.1 Modes of Operation



The QF4A512 is designed to interface directly with the serial peripheral interface (SPI) of microcontrollers and Digital Signal Processors. The QF4A512 always operates in SPI slave mode where SDI is the input serial data, and SDO is the output serial data. SCLK is the input serial clock maximum 40 MHz.

In order to address and write to the QF4A512, /CS is asserted low. When the device is not selected, data will not be accepted via the serial input pin (SDI) and the serial output pin (SDO) will remain in a high impedance state.

There are two primary modes of bus operation for the QF4A512, "configure" mode, and "run" mode. The required mode is selected by writing the **run\_mode** bit in the **RUN\_MODE** register (04h).

"Configure" mode is used to set up or change options in the QF4A512. In this mode it is possible to read/write the control registers and the coefficient RAMs. It is also possible to initiate transfers of data between the registers/RAM and the EEPROM. DRDY will be held low by an internal pulldown in this mode.

"Run" Mode is used to send the filtered data out of the QF4A512 via the SDO pin. In "Run" mode the Data Ready, DRDY, pin is used as a data rate output derived from the highest channel sampling rate.

A third, "EEPROM" mode is available for transfers directly from the SPI bus to/from the EEPROM. This mode is intended for bulk programming of devices. "EEPROM" mode is entered by first setting the device into "Configure" mode, then by pulling high the DRDY/SEL pin. Further information on the use of this mode is documented in Application Note QFAN007, "Bulk Programming EEPROM".

#### 10.2 Configure Mode

By setting the **run\_mode** bit to 0 the QF4A512 is in Configure mode, ready for setup and programming. General parameters include things such as auto start, auto configure, and unique channel setup. In this mode the bus has access to the full 14-bit on-chip address space which includes all the internal registers, coefficient and data RAMs.

Once the QF4A512 has been programmed, the register and coefficient RAM data can be transferred to EEPROM for non-volatile storage. A single command is provided to transfer the data from all of the internal registers and filter coefficients. A complementary command is also available to copy back all the data from EEPROM to the registers and RAM. This command may be invoked automatically at device power on and rest by configuring the Startup register.

Partial, block, transfers can be performed by specifying the desired starting and ending memory locations. This method is particularly useful for accessing the user data from EEPROM – 128bytes in total are available in EEPROM but they must be accessed in 8 byte blocks from the SPI bus.

#### Configure Mode Format : Single Access



#### Figure 8. Configure Mode Format

Table 7. Configure Mode, Register Address Decoding SDI (0000h-3FFF)

| A15   |      |      |      |      |      |      |      |      |      |      |      |      |      |      |   |
|-------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|---|
| R/W   | Addr | v |
| N/ VV | 13   | 12   | 11   | 10   | 9    | 8    | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    | ^ |

R/W = Write is 0, Read is 1

X = Don't Care

(Addr13 - Addr0) = Command Address

#### Table 8. Configure Mode, Register Data (00h-FFh)

| D7    | D6    | D5    | D4    | D3    | D2    | D1    | D0    |
|-------|-------|-------|-------|-------|-------|-------|-------|
| Data7 | Data6 | Data5 | Data4 | Data3 | Data2 | Data1 | Data0 |

(Data7 - Data0) = Unique data per command.









#### Figure 9. Configure Mode Timing, Read and Write

#### Configure Mode : Multiple Read Access (Address Auto Increment On)

| Bit #      | 23 22  | 21 20 | 19 1 | 8 17     | 16 15  | 5 14   | 13 1 | 2 1 | 1 10 | 9             | 8   | 7 6 | 6 5   | 4    | 3 2  | 2 1   | 0   | 7 6 | 5     | 4    | 3    | 2 1  | 0    | ( 7 | 6   | 5 4     | 3               | 2              | 1 0  |      |   |
|------------|--------|-------|------|----------|--------|--------|------|-----|------|---------------|-----|-----|-------|------|------|-------|-----|-----|-------|------|------|------|------|-----|-----|---------|-----------------|----------------|------|------|---|
| DRDY(i/p). |        |       |      |          |        |        |      |     |      |               |     |     |       |      |      |       |     |     |       |      |      |      |      |     |     |         |                 |                |      |      | _ |
| CSN (i/p)  | -      |       |      |          |        |        |      |     |      |               |     |     |       |      |      |       |     |     |       |      |      |      |      |     |     |         |                 |                |      |      | - |
| SCLK (i/p) |        | цт    | ĽΓ   | Π'n      |        | ηh     | Ĺ.   | ΓĽ  | Ť    | ц'n           |     |     | ΓĽΓ   | ப்ப  | 'n.  |       |     | Ł   | Ϋ́    | ι'n  | Lh.  |      | ц'n  |     | ι'n |         | Ţ               | ĽΓ             | 'nл  | -    | - |
| SDI (i/p)  | ZZZXIX |       | _    | 14-bit a | addres | ss (A0 | )    |     |      | $\Rightarrow$ | ά77 | 777 | 777   | ĽΖ   | 777  | 777   | 777 | 777 | 777   | 777  | ŻΖ.  | ŻΖŻ  |      | ZZ  | T/Z | 777     | $\overline{TT}$ | $\overline{D}$ | 7777 | 7777 | - |
| SDO (o/p)  | 77     |       |      |          |        |        |      |     |      |               |     |     | 8-bit | read | data | (D-A0 | фx  |     | 8-bit | read | data | (D-A | 1) 🔿 |     | 8-  | bit rea | ad dat          | a (D-/         | N)   | ÓZZZ | - |
|            | 1 1 1  |       | 1    |          | 1      | 1      | 1    |     | 1    |               | 1   | 1   |       | 1    | 1    |       | 1   |     | 1     | 1    | 1    | 1 1  | 1    | ) : |     | 1       | 1               | 1              |      | 1    |   |
|            |        |       |      |          |        |        |      |     |      |               |     |     |       |      |      |       |     |     |       |      |      |      |      |     |     |         |                 |                |      |      |   |

#### Configure Mode : Multiple Write Access (Address Auto Increment On)

| Bit #       | 23 22 21 20 19 | 9 18 17 16 15 14 13 12 11 10 | 8 7 6 5 4 3 2 1 0 7 6 5 4 3 2 1 0                     | 7 6 5 4 3 2 1 0         |
|-------------|----------------|------------------------------|-------------------------------------------------------|-------------------------|
| DRDY (i/p)  |                |                              |                                                       |                         |
| CSN (i/p)   |                |                              |                                                       |                         |
| SCLK (i/p)  |                |                              |                                                       |                         |
| SDI (i/p) 🗍 | 77X0X          | 14-bit address (A0)          | X/X 8-bit write data (D-A0) X 8-bit write data (D-A1) | 8-bit write data (D-AN) |
| SDO (o/p) 🛛 | 7              |                              |                                                       |                         |



#### Figure 10. Configure Mode Timing – Multiple Read / Write

Note that Configure mode registers wider than 8 bits must be written completely starting at the low address.



#### 10.3 Run Mode

By setting the **run\_mode** bit to 1 the QF4A512 is in Run mode, and will output converted and filtered data. A 24-bit format is used including information and data (New Data Flag + Channel ID + 16 bits of data). The Serial Interface (SIF) will arbitrate between the incoming channels from the FIRs by monitoring each channels internal data ready signal. If new data for a given channel is ready in time, it will be inserted on the serial output stream at the appropriate spot for that channel and the new data flag will be set in the header. Otherwise the old data will be output and the new data flag will not be set. The highest channel's sample rate will be used as the data rate output for the DRDY signal, which can be used for handshaking to maximize bus throughput. Over and under range of the ADC per channel can be monitored. See Section 10.4 for available commands in Run Mode.

The parity bit can be activated to verify proper data transfer. When turned on the parity bit will either add a 0 or 1 to force the remaining 23 bits to equal an odd number of 1's.

Note: For single-channel applications it is possible to use a "high-speed" 16-bit format, without the channel IDs and New Data Flag. This would be used if bus throughput was the limiting item on overall performance. Use of this format is detailed in Application Note <u>QFAN002, "High-Speed Single Channel Operation"</u>.

Note: If the device is configured such that a low system clock is used in conjunction with the maximum SPI clock it may be possible for /CS to return to a high level before DRDY has been cleared. To prevent this from occurring be sure to conform to the timing requirements in Electrical Characteristics.







Table 9. Run Mode, Control Address for Command Writes, SDI (00h-FFh)

| A7    | A6    | A5    | A4    | A3    | A2    | A1    | A0    |
|-------|-------|-------|-------|-------|-------|-------|-------|
| Addr7 | Addr6 | Addr5 | Addr4 | Addr3 | Addr2 | Addr1 | Addr0 |

Addr7-Addr0 = Command Address

Description: See Section 10.4.

#### Table 10. Run Mode, Control Register Data Format (00h-FFh)

| D7    | D6    | D5    | D4    | D3    | D2    | D1    | D0    |
|-------|-------|-------|-------|-------|-------|-------|-------|
| Data7 | Data6 | Data5 | Data4 | Data3 | Data2 | Data1 | Data0 |

(Data7 - Data0) = Unique data per command.

Description: See Section 10.4.

Table 11. Run Mode, Output Data Structure, LSB, SD0 (0000h-FFFFh)

| D7    | D6    | D5    | D4    | D3    | D2    | D1    | D0    |
|-------|-------|-------|-------|-------|-------|-------|-------|
| Data7 | Data6 | Data5 | Data4 | Data3 | Data2 | Data1 | Data0 |

Data7- Data0 = Least Significant Byte (LSB)

Description: This is the Least Significant Byte of the 16-Bit filtered data output.

#### Table 12. Output Data, Second LSB, SD0 (0000h-FFFFh)

| D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 |
|-----|-----|-----|-----|-----|-----|----|----|
|-----|-----|-----|-----|-----|-----|----|----|

Data15 Data14 Data13 Data12 Data11 Data10 Data9 Data8

Data15- Data8 = Most Significant Byte (MSB)

Description: This is the Most Significant Byte of the 16-Bit filtered data output.

Table 13. Output Data, MSB, SD0 (00h-FFh)

| D23    | D22   | D21   | D20 | D19      | D18    | D17      | D16    |
|--------|-------|-------|-----|----------|--------|----------|--------|
| PARITY | CH_ID | CH_ID | NEW | adc_ov_L | adc_ov | adc_un_L | adc_un |

Data23- Data16 = MSB of the 24 bit serial data.

Description: This is the information byte showing which channel the data corresponds to, along with the new data flag and parity bit for valid data check.

Bits D16-D19 – ADC Overflow/Underflow

Description: These bits, if enabled by the **adc\_stat** bit in the **SPI\_CTRL** register (15h), indicate over- or under-range conditions in the ADC output. The unlatched bits reflect the contents of the **ADC\_STATUS\_1** register (11h), the latched bits reflect the contents of the **CHn\_STAT** registers (31h, 61h, 91h, C1h). The latched bits will retain their state until reset by writing a zero to the appropriate **CHn\_STAT** register.

adc\_ov\_L 1 = ADC Over-range, latched output

adc\_ov 1 = ADC Over-range, not latched

adc\_un\_L 1 = ADC Under-range, latched output

adc\_un 1 = ADC Under-range, not latched

Note: If these bits are enabled the parity option should not also be enabled.

NEW (Sets new data flag)

\* 0 = No new data has been put on the SIF serial bus for that specific channel

1 = The data has been updated on the SIF bus

CH\_ID (Identifies which channel the data corresponds to)

\* 00 = Channel 1

01 = Channel 2

10 = Channel 3

11 = Channel 4

PARITY (Parity bit)

If Parity is enabled this bit will assume a state such that the total number of ones in the data word is odd.

Note: Parity should not be enabled if ADC out-of-range status reporting is turned on (bit 6 of register 15h – **SPI\_CTRL**). If both features are enabled the state of the parity bit will not be reliable.

### **DATA SHEET**



#### Figure 12. Run Mode Timing, Read and Write

Note: Once set by the chip DRDY will remain high until /CS is pulled low.

#### 10.4 Sending Commands in Run Mode

Although Run mode exists primarily to output filtered data from the ADC it is also possible to issue commands to the QF4A512 in this mode. Of fundamental importance is the ability to write the command to exit run mode and return to Configure mode!

In fact, it is possible to write to any register (that allows writes) within the first 8 bits of address space (Registers 00h – FFh). The format and timing can be seen in Figures 10 and 11. In the register descriptions (Chapter 12) all registers are writeable (R/W) except those specifically designated as Read Only or Auto Set. Obviously since the output data is dedicated to filtered conversion results from the ADC it is not possible to read any of the control registers while in Run mode (except of course for data which is included in the header of the MSB, for example, the new data flags).

The most likely registers to be used for dynamic adjustment during Run mode are as follows:

#### **GLBL\_SW** (00h)

Quickfilter

Actually being used as a dummy register, it is useful to set the control address to 00h when no commands are being issued to prevent inadvertent writes to other command registers.

#### RUN\_MODE (04h)

Writing a 0 to bit 0 will take the QF4A512 out of Run mode and back to Configure mode.

#### ENABLE\_2 (0Bh)

The 4 lsb's can be used to turn on/off data in the output data stream (**arec\_ch\_en** bits). This can be useful to regulate SPI bandwidth when using multiple channels with varying sample rates.

**CHn\_PGA** (30h, 60h, 90h, C0h) The **pga\_gain** bits can be used to vary the PGA gain on a per channel basis.

CAL\_*n*\_OFF (56h,57h, 86h, 87h, B6h, B7h, E6h, E7h) Offset calibration value for channel *n*.

**CAL\_***n***\_GAIN** (58h,59h, 88h, 89h, B8h, B9h, E8h, E9h) Gain calibration value for channel *n*.

#### Note: There are differences in the way the address and data is formatted between Run Mode and Configure mode.





In Configure mode 14-bit address words are used. In Run mode 8-bit addressing is used. These differences are shown graphically in the following diagram. Consequently the host controller must use the appropriate timing depending on which mode of operation is active. (At power up the mode of operation is determined by the value of the **auto\_start** bit (register **STARTUP\_1**).



Figure 13. Comparison of Configure and Run Mode Timing

If it is unknown which mode is active there are several ways to determine this. If in Run mode there should be a continuous stream of conversions occurring which should be reflected by changes in level of the DRDY pin, furthermore if SCLK is active and CSN is held low there should be transitions occurring on the SDO pin. These pins can me monitored for activity within a pre-determined timeout interval. These methods are summarized below.

- 1. If the QF4A512 is in Run mode, DRDY will be driven high when the fastest sample is available. If in Configure mode, DRDY is an input (internal pull-down in the chip). So, by monitoring DRDY you can determine the mode of operation.
- 2. Holding SDI low (to prevent inadvertently writing any bad info to the chip), toggle SCLK and look for data on SDO. If in Configure mode, SDO will be low the whole time. If in Run mode, SDO will eventually toggle.

#### 10.5 Multiple QF4A512s and Synchronous Sampling

A single QF4A512 can sample 4 analog signals simultaneously. However, some applications sample more than 4 channels using multiple QF4A512 chips. Multi-chip configurations of QF4A512 are described in App Note QFAN005 "Multiple Chip Configuration". Some systems additionally require that the samples across multiple chips be tightly synchronized. App Note QFAN020 "Synchronized Sampling Using Multiple QF4A512 Programmable Signal Converters" describes a simple additional procedure to synchronize multiple QF4A512 devices so that all analog signals are sampled at the same moment and all DRDY signals assert synchronously.



### 11. EEPROM

### 11.1 Overview

Table 14. EEPROM Memory Map



The internal EEPROM is used to store the QF4A512's FIR coefficients, general parameters and startup mode as well as have user space for application specific use, for example Transducer Electronic Data Sheets (TEDS).

Address space 0007 through 0EFF can be automatically transferred at startup to the corresponding Register and RAM addresses. Full transfers can also be initiated, in either direction, by writing to the **EETRANS** (EEPROM Transfer) register. Manual single-byte and block transfers can be performed as described below.

#### **11.2 EEPROM Transfer Procedures**

Usually the SPI port connects directly to the chip's internal serial interface (SIF) control block. The SIF allows the user to read or write to on-chip control registers and RAMs. In turn the SIF controls data transfers internally between the registers/RAM and EEPROM.

The following describes procedures to transfer data to/from the EEPROM.

#### Manual Single Byte and Multi-Byte Transfers

Manual transfers between the register map & coefficient RAM, and the EEPROM occur as follows:

Set the clock rate divider for the transfer based on the crystal frequency as the source: **eeclk\_rate** = 000 to 101 (Register **STARTUP\_1**, 07h). 000 = XTAL rate, 001 = divby2 ... 101 = divby32.

Set the source address:

EE start address for block transfers: **EE\_STADDR (17h,18h)**. Chip start address for block transfers: **CHIP\_STADDR (19h,1Ah)**.

Set the destination starting address (can be different from source address): Ending address for block transfers : **END\_ADDR (1Bh,1Ch)**.

For single byte transfers:

Set the destination ending address to the same value as the destination starting address: END\_ADDR (1Bh).

For multi-byte transfers:

Set the destination address to the desired ending address of the *destination* block. See the following paragraph for applicable restrictions.

Start the transfer:

For EEPROM reads: Set the rd\_start bit in the EE\_TRANS register (05h).

For EEPROM writes: Set the wr\_start bit in the EE\_TRANS register (05h).

Wait for the transfer to complete. One way to accomplish this is to continually try reading the **GLBL\_ID** register (01h) until you get the correct ID value.



#### **Multi-Byte Transfer Restrictions**

#### Reading from EEPROM

A contiguous transfer will not proceed across the register map – coefficient memory boundary. In other words, you can't cross 00FFh – 0100h within the block you are transferring. An easy solution is to break up the block into 2 block transfers, one up to 00FFh and the other starting with 0100h.

#### Writing to EEPROM

Starting with address 0000h, all block transfers must be on 32-byte boundaries (EEPROM limitation). As an example, if you want to transfer into EEPROM addresses 0000h to 0030h (48 dec), you would break this into 2 blocks, one from 0000 to 001Fh (31 dec), and one from 0020h to 0030h.

#### **EEPROM Status**

By setting the **rd\_status** bit (**EE\_TRANS** register) the chip will read the status register of the EEPROM and put its contents into the **EE\_VAL** register. Again, to check if the transfer is done, you can continually access the **GLBL\_ID** register (01h) until you get the correct ID value.

#### Full Transfers

Full EEPROM transfers cover the address range **0006h – 0EFFh**. A one-to-one image is copied for this entire range. Addresses that are undefined in the memory map will fill the EEPROM with a default value. Addresses prior to this range (< 0006h) do not contain information which needs to stored in non-volatile memory and also control the manual transfers described above. Thus we don't want these to go into the EEPROM or they may cause unusual behavior when the chip powers-up (resets). Full transfers are performed as follows:

As above in Manual Transfers, eeclk\_rate (07h) should be set appropriately.

Start the transfer:

For reading from the EEPROM: Set the **rd\_full** bit in the **EE\_COPY** register (06h).

For writing to the EEPROM: Set the **wr\_full** bit in the **EE\_COPY** register (06h).

Wait for the transfer to complete. One way to accomplish this is to continually try reading the ID register (0001h) until the correct ID value is returned.

WARNING - When writing to the first 8 registers of EEProm, if the values are incorrect or if there is a conflict with the other values, the chip may be put into an infinite loop at startup. For example, if Auto Start is set, but Auto Config is not set and there is no configuration loaded on EEPROM; or the EEPROM Status registers are set to busy then the chip continuously loops.

#### 11.3 Calibration Data

128 bytes of memory are nominally reserved for calibration data. This data can be transferred to the CAL\_OFFSET\_*n* and CAL\_GAIN\_*n* registers (see Section 7.7) at startup by using the Extended Initialization feature of the QF4A512 (see Section 5.2).

By default the QF4A512 is shipped with factory calibration data in this area of memory. At the User's option he may elect to replace this data with his own system-level calibration data, or if no calibration data is required this memory may be used as an additional 128 bytes of User Memory.

Note: Once overwritten the factory calibration data cannot be restored.

#### 11.4 User Memory

128 bytes of EEPROM (starting address 0F80h) have been set aside for user data. This can contain any type of application specific data, for example TEDS data as defined in IEEE P1451.4.

Table 15. T.E.D.S. (Transducer Electronic Data Sheet, Basic Template)

|                 | Bit Length | Allowable Range |
|-----------------|------------|-----------------|
| Manufacturer ID | 14         | 17 - 16381      |
| Model Number    | 15         | 0 – 32767       |



| Version Letter | 5  | A – Z (data type Chr5) |
|----------------|----|------------------------|
| Version Number | 6  | 0 - 63                 |
| Serial Number  | 24 | 0 - 16777215           |

Refer to IEEE-P1451.3 for further information on TEDS.

Alternatively other user-specific information and/or formats can be stored in this area.

The user data is not copied into chip RAM at power up. Since direct reads from EEPROM are not usually possible there are two methods to read/write the user data:

- a) Using the **SCRATCH** registers. The 8 registers starting at address 001Dh can be used to transfer data 8 bytes at a time, using the multi-byte transfer method described above.
- b) Using the data RAM at startup. If the device is powered up in Configure mode all 128 bytes of user data can be block transferred into the filter data RAM starting at address 1000h. Once the device enters Run mode this data will be overwritten with the data output from the FIRs so this technique can only be used at startup.

### 12. CONTROL REGISTERS

#### 12.1 Overview

Table 16. Control Register Map

|      | 0            | •                  |
|------|--------------|--------------------|
|      | Channel      | Maintenance (9)    |
|      | 4            | Configuration (31) |
| 00C0 | -            | Run & Status (2)   |
|      | Channel      | Maintenance (9)    |
|      | 3            | Configuration (31) |
| 0090 | Ū            | Run & Status (2)   |
|      | Channel      | Maintenance (9)    |
|      | 2            | Configuration (31) |
| 0060 | -            | Run & Status (2)   |
| 0051 | Channel      | Maintenance (9)    |
| 0032 | 1            | Configuration (31) |
| 0030 | •            | Run & Status (2)   |
| 001D | Global Main  | tenance (19)       |
| 0011 | Global Conf  | iguration (12)     |
| 0009 | Run & Statu  | s (8)              |
| 0005 | EEPROM S     | tartup (4)         |
| 0000 | High Level ( | 5)                 |
|      |              |                    |

Note: Numbers in parentheses are the number of bytes allocated to each function.

The Control Registers are located in the first 256 bytes of address space as shown in the table. The QF4A512 can be configured to automatically load these registers from EEPROM, with the exception of the first 7 bytes, at power up or after a reset.

It is strongly recommended that the configuration and filter coefficient data is set up using the Quickfilter Pro software. For applications requiring reconfiguration on the fly it is suggested that complete configuration files, generated by the software, are stored in external memory and loaded in full to the device. However, it may often be necessary to write individual commands to the device, for example to



switch between run and configure mode, or to turn on/off specific channels. To accomplish this, more detailed descriptions of register functions can be found in the following paragraphs.

Several registers are designated as "Reserved". The user may write to these registers without any effect on chip operation, i.e. it is possible to write to the entire register map as a single contiguous block. However, when they are read these registers will return all ones or zeroes, not necessarily reflecting the value written to them during the write operation.

The corresponding EEPROM locations can also be written, and these values can also be read back. Since these locations may be used for future functionality they should not be used for user data (the user area is available for this purpose).

Other registers are denoted for Factory Use Only. These registers should be written with the default values shown to ensure correct device operation.

| Hex*  | Register Name | Description                                      |
|-------|---------------|--------------------------------------------------|
| 0000h | GLBL_SW       | Software Register, Test Reads and Writes         |
| 0001h | GLBL_ID       | Chip ID Including Revision Number.               |
| 0002h | FULL_SRST     | Activates all soft resets                        |
| 0003h | GLBL_CH_CTRL  | Reset, Enable or Power Down each channel         |
| 0004h | RUN_MODE      | Set chip in Run or Configure Mode                |
| 0005h | EE_TRANS      | Control data transfers to/from EEPROM            |
| 0006h | EE_COPY       | Control full transfers to/from EEPROM            |
| 0007h | STARTUP_1     | Set startup configuration, rate for EEPROM clock |
| 0008h | STARTUP_2     | Initialization delay counter                     |
| 0009h | ENABLE_0      | Enable ADC and system clock per channel          |
| 000Ah | ENABLE_1      | Enable AAF per channel, ADC operation mode       |
| 000Bh | ENABLE_2      | Designate active channels                        |
| 000Ch | PLL_SIF_STAT  | PLL lock, SIF address out of range               |
| 000Dh | EE_VAL        | EEPROM status register value                     |
| 000Eh | EE_STATUS     | EEPROM transfer status flags                     |
| 000Fh | ADC_STATUS_0  | ADC out of range, per channel                    |
| 0010h | ADC_STATUS_1  | ADC out of range, high or low, per channel       |

Table 17. Control Register listing (High-Level, EEPROM Startup, Run & Status)

Several registers are designated as "Reserved". The user may write to these registers without any effect on chip operation, i.e. it is possible to write to the entire register map as a single contiguous block. However, when they are read these registers will not necessarily reflect the value written to them during the write operation.

#### 12.2 High-level Registers

Note: \* denotes default values

#### **00h GLBL\_SW** (User Register)

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Address 00h | D7    | D6    | D5    | D4    | D3    | D2    | D1    | D0    |

Description: Global Software is provided as a blank user byte for the programmer to read and write to as a test. This byte defaults to 0 at power up and is not loaded from EEPROM.

01h GLBL\_ID (Chip ID) - READ ONLY

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Address 01h | ID7   | ID6   | ID5   | ID4   | ID3   | ID2   | ID1   | ID0   |

[ID7:ID0] = Identification number of the QF4A512, default = A0h (was B1h on pre-production devices).



Description: This read-only byte contains a number describing the identification of the QF4A512 device. This data is hard-wired and is not transferred from EEPROM. It can be read at any time.

Note: Revision information can be found in the **DIE\_REV** register (EAh)

#### 02h FULL\_SRST (Global Soft Reset)

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0     |
|-------------|-------|-------|-------|-------|-------|-------|-------|-----------|
| Address 02h | Х     | Х     | Х     | Х     | Х     | Х     | Х     | glbl_srst |

glbl\_srst

\* 0 = Does nothing.

1 = Reset

Description: Activates all soft resets. The reset value of this register is zero, regardless of the data in the corresponding EEPROM address.

03h GLBL\_CH\_CTRL (Global Channel Control)

|             | Bit 7    | Bit 6    | Bit 5    | Bit 4    | Bit 3    | Bit 2    | Bit 1    | Bit 0    |
|-------------|----------|----------|----------|----------|----------|----------|----------|----------|
| Address 03h | ch4_pwrd | ch3_pwrd | ch2_pwrd | ch1_pwrd | ch4_srst | ch3_srst | ch2_srst | ch1_srst |

chN\_srst

\* 0 = Does nothing.

1 = Reset

Description: Activates all soft resets on a per channel basis.

chN\_pwrd

\* 0 = Does nothing.

1 = Disable/power down

Description: Turns on or off each channel.

Note: The reset value of this register is zero, regardless of the data in the corresponding EEPROM address.

04h RUN\_MODE (Serial Interface Run mode)

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0    |
|-------------|-------|-------|-------|-------|-------|-------|-------|----------|
| Address 04h | Х     | Х     | Х     | Х     | Х     | Х     | Х     | run_mode |

run\_mode

\* 0 = Configure mode.

1 = Run mode.

Description: Sets the serial interface (SPI) to either configure or run mode. The reset value of this register is zero, regardless of the data in the corresponding EEPROM address. However, if **auto\_run** and **auto\_config** bits are set the chip will write this register to 1 after a reset (see **STARTUP\_1** Register, 07h).

#### 12.3 EEPROM Startup Registers

#### 05h EE\_TRANS (EEPROM Transfer) – AUTO CLEAR

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2     | Bit 1   | Bit 0   |
|-------------|-------|-------|-------|-------|-------|-----------|---------|---------|
| Address 05h | Х     | Х     | Х     | Х     | Х     | rd_status | wr_strt | rd_strt |



#### rd\_strt

- \* 0 = default
- 1 = start transfer

Description: Command to start transfer from EEPROM to registers/RAM.

#### wr\_strt

- \* 0 = default
- 1 = start transfer

Description: Command to start transfer from registers/RAM to EEPROM.

#### rd\_status

- \* 0 = default
- 1 = start read of status register

Description: Command to start read of EEPROM status register.

Note: These command bits are automatically cleared by the chip after use. The reset value of this register is zero, regardless of the data in the corresponding EEPROM address.

#### 06h EE\_COPY (Full EEPROM Transfer) – AUTO CLEAR

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1   | Bit 0   |
|-------------|-------|-------|-------|-------|-------|-------|---------|---------|
| Address 06h | Х     | Х     | Х     | Х     | Х     | Х     | wr_full | rd_full |

rd\_full

\* 0 = default

1 = start transfer

Description: Command to start full transfer from EEPROM to registers/RAM.

wr\_full

\* 0 = default

1 = start transfer

Description: Command to start full transfer from registers/RAM to EEPROM.

Note: These command bits are automatically cleared by the chip after use. The reset value of this register is zero, regardless of the data in the corresponding EEPROM address.

For all the following registers the default values (shown with an \*) will be overwritten with the values in the corresponding EEPROM address if the **auto\_config** bit in the STARTUP register is set in EEPROM memory.

#### 07h STARTUP\_1 (SPI Setup)

|             | Bit 7        | Bit 6       | Bit 5       | Bit 4       | Bit 3 | Bit 2 | Bit 1      | Bit 0       |
|-------------|--------------|-------------|-------------|-------------|-------|-------|------------|-------------|
| Address 07h | alt_startup2 | eeclk_rate2 | eeclk_rate1 | eeclk_rate0 | 0     | 0     | auto_start | auto_config |

auto\_config

\* 0 = Does nothing.

1 = Data copied from EEPROM

Description: Automatically loads chip configuration registers and FIR coefficients into RAM.

auto\_start



#### \* 0 = Configure mode.

1 = Run mode

Description: In Run mode automatically starts filtering and sending out filtered data on the SIF interface.

Note: Bits 2 and 3 must be left at their default value of 0.

eeclk\_rate 000 (110, 111) = XTAL frequency

001 = XTAL frequency/2

010 = XTAL frequency/4

011 = XTAL frequency/8

\*100 = XTAL frequency/16

101 = XTAL frequency/32

Description: Clock Rate for EEPROM data transfer. Frequency is divided down as shown above. Maximum value is 5, higher values if written will default back to 000.

alt\_startup2

Description: Selects alternate values for STARTUP\_2 register. Default value is 0.

**08h STARTUP\_2** (Initialization delay counter)

|             | Bit 7     | Bit 6     | Bit 5     | Bit 4     | Bit 3     | Bit 2                | Bit 1          | Bit 0          |
|-------------|-----------|-----------|-----------|-----------|-----------|----------------------|----------------|----------------|
| Address 08h | init_dly7 | init_dly6 | init_dly5 | init_dly4 | init_dly3 | init_dly2/ xtnd_init | init_dly1 / P1 | init_dly0 / P0 |

init\_dly

\* 10h = Delay count

Description: Delay counter for the initialization and general control

xtnd\_init

Description: If alt\_startup2 AND xtnd\_init bits are set, calls for extended initialization (e.g. load calibration settings)

P0, P1

Description: Reserved for future use.

### 12.4 Run and Status Registers

#### 09h ENABLE\_0 (ADC Enable)

|             | Bit 7      | Bit 6      | Bit 5      | Bit 4      | Bit 3 | Bit 2 | Bit 1   | Bit 0      |
|-------------|------------|------------|------------|------------|-------|-------|---------|------------|
| Address 09h | pcg_ch4_en | pcg_ch3_en | pcg_ch2_en | pcg_ch1_en | Х     | Х     | pll_pdn | osc_enable |

osc\_enable

0 = Powered Down

\*1 = Oscillator enabled

Description: Enables the crystal oscillator (or external clock if configured).

PLL\_enable

0 = Powered Down

\*1 = PLL enabled

Description: Enables the phase locked loop.



# pcg\_chN\_en

\*0 = Disabled

1 = Enabled

Description: Enables the ADC clock and system clock for channel N.

#### **0Ah ENABLE\_1** (AAF Enable, ADC Mode)

|             | Bit 7 | Bit 6 | Bit 5       | Bit 4       | Bit 3       | Bit 2       | Bit 1       | Bit 0       |
|-------------|-------|-------|-------------|-------------|-------------|-------------|-------------|-------------|
| Address 0Ah | Х     | Х     | afe_opmadc1 | afe_opmadc0 | afe_opmfec4 | afe_opmfec3 | afe_opmfec2 | afe_opmfec1 |

afe\_opmfecN

\* 0 = Powered Down

1 = Enabled

Description: Enables the anti-aliasing filter for channel *N*. Must be enabled for the channel to be used, this bit is for power savings on disabled channels.

afe\_opmadc

\* 00 = Powered Down (10uW, 5us)

01 = Sleep (2mW, 0.5us)

10 = Standby (22mW, 12 clock cycles)

11 = Active (80mW)

Description: Sets the operating mode of the ADC. These bits can be used to conserve power in duty cycle applications. The mode can be chosen to trade off power savings versus time to return to an active state (approximate values as shown).

|             | Bit 7      | Bit 6      | Bit 5      | Bit 4      | Bit 3       | Bit 2       | Bit 1       | Bit 0       |
|-------------|------------|------------|------------|------------|-------------|-------------|-------------|-------------|
| Address 0Bh | sif_ch_en4 | sif_ch_en3 | sif_ch_en2 | sif_ch_en1 | arec_ch_en4 | arec_ch_en3 | arec_ch_en2 | arec_ch_en1 |

arec\_ch\_enN

0 = Disabled

\*1 = Enabled

Description: Controls the input mux and enables sampling for channel *N*. This bit should be disabled only for power savings on unused channels. Disabling a channel will alter the effective sampling rate for the remaining active channels.

Sif\_ch\_enN

\*0 = Disabled

1 = Enabled

Description: Controls the output mux. In multi-channel mode enables channel N in the serial output data stream. In single-channel mode identifies which channel is enabled in the serial output data stream. If two or more bits are set the lowest channel set will be output.

| 0Ch PI I | SIF    | STAT | PII | status  | serial | interface status) |
|----------|--------|------|-----|---------|--------|-------------------|
|          | _011 _ |      |     | siaius, | Senai  | intenace status)  |

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1        | Bit 0    |
|-------------|-------|-------|-------|-------|-------|-------|--------------|----------|
| Address 0Ch | Х     | Х     | Х     | Х     | Х     | Х     | ism_pll_lock | pll_lock |

pll\_lock - READ ONLY

\* 0 = Not locked.

1 = Locked.

Description: Indicates PLL lock status.



Quickfilter"

ism\_pll\_lock - AUTO SET, may be reset by user

\* 0 = Not locked.

1 = Locked.

Description: Indicates initialization lock status.

#### 0Dh EE\_VAL (EEPROM Status Register Value) - READ ONLY

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Address 0Dh | D7    | D6    | D5    | D4    | D3    | D2    | D1    | D0    |

Description: Value of the EEPROM Status register. Default value = 0 at powerup.

#### 0Eh EE\_STATUS (EEPROM Status Flags) - Bits are autoset by the chip, can only be reset by the user

|             | Bit 7            | Bit 6        | Bit 5        | Bit 4        | Bit 3       | Bit 2       | Bit 1        | Bit 0        |
|-------------|------------------|--------------|--------------|--------------|-------------|-------------|--------------|--------------|
| Address 0Eh | igc_done_xtdinit | igc_done_ism | wr_full_done | rd_full_done | spim_eebusy | spim_eestat | spim_wr_done | spim_rd_done |

Default value= 00h.

These flags can only be set by the chip. They can only be cleared by writing a zero to the desired location.

spim\_rd\_done = Read from EEPROM complete.

spim\_wr\_done = Write to EEPROM complete.

spim\_eestat = EEPROM status read complete.

spim\_eebusy = EEPROM busy caused abort of attempted read/write.

rd\_full\_done = Full read from EEPROM complete.

wr\_full\_done = Full write to EEPROM complete.

igc\_done\_ism = Initialization sequence complete.

igc\_done\_xtdinit = Extended initialization sequence complete.

Description: Status flags for data transfers to/from EEPROM.

#### 0Fh ADC\_STATUS0 (ADC out of range, high or low) - READ ONLY

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3   | Bit 2   | Bit 1   | Bit 0   |
|-------------|-------|-------|-------|-------|---------|---------|---------|---------|
| Address 0Fh | Х     | Х     | Х     | Х     | adc_oo4 | adc_oo3 | adc_oo2 | adc_oo1 |

adc\_00*N* 

\* 0 = Within range.

1 = Out of range, high or low.

Description: Indicates an out of range condition for the ADC on channel N.

#### 10h ADC\_STATUS1 (ADC out of range, specific) - READ ONLY

|             | Bit 7   | Bit 6   | Bit 5   | Bit 4   | Bit 3   | Bit 2   | Bit 1   | Bit 0   |
|-------------|---------|---------|---------|---------|---------|---------|---------|---------|
| Address 10h | adc_un4 | adc_un3 | adc_un2 | adc_un1 | adc_ov4 | adc_ov3 | adc_ov2 | adc_ov1 |

adc\_ovN

\* 0 = No overflow.

1 = ADC overflow, out of range, high.

Description: Indicates an overflow condition for the ADC on channel N.

adc\_unN

\* 0 = No underflow.

1 = ADC underflow, out of range, low.

Description: Indicates an underflow condition for the ADC on channel N.

# **12.5 Global Configuration Registers**

Table 17. Control Register listing (Global Configuration)

| Hex*  | Register Name | Description                                    |
|-------|---------------|------------------------------------------------|
| 0011h | PLL_CTRL_0    | PLL Pre-divider, frequency range.              |
| 0012h | PLL_CTRL_1    | PLL loop divider.                              |
| 0013h | ADC_CLK_RATE  | Clock rate for ADC, CRC and AREC.              |
| 0014h | SYS_CLK_CTRL  | System Clock control.                          |
| 0015h | SPI_CTRL      | Set single-, multi-channel mode                |
| 0016h | SPI_MON       | Monitor internal data transfers                |
| 0017h | EE_STADDR     | EE start address for block transfers (byte0)   |
| 0018h | EE_STADDR     | EE start address for block transfers (byte1)   |
| 0019h | CHIP_STADDR   | Chip start address for block transfers (byte0) |
| 001Ah | CHIP_STADDR   | Chip start address for block transfers (byte1) |
| 001Bh | END_ADDR      | Ending address for block transfers (byte0)     |
| 001Ch | END_ADDR      | Ending address for block transfers (byte1)     |

11h PLL\_CTRL\_0 (PLL pre-divider and range)

|             | Bit 7 | Bit 6     | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  |
|-------------|-------|-----------|--------|--------|--------|--------|--------|--------|
| Address 11h | Х     | pll_range | pll_m5 | pll_m4 | pll_m3 | pll_m2 | pll_m1 | pll_m0 |

pll\_m

Description: A 6-bit number designating the value of the PLL pre-divider (M). Default value is 1.

pll\_range

0 = 20 - 100 MHz

\*1 = 100 – 200 MHz

Description: Set the range of the PLL clock which supplies the ADC and system clocks.

#### 12h PLL\_CTRL\_1 (PLL loop divider)

|             | Bit 7 | Bit 6 | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  |
|-------------|-------|-------|--------|--------|--------|--------|--------|--------|
| Address 12h | Х     | Х     | pll_n5 | pll_n4 | pll_n3 | pll_n2 | pll_n1 | pll_n0 |

PII\_n

Description: A 6-bit number designating the value of the PLL loop divider (N). Default value is 10.

#### 13h ADC\_CLK\_RATE (ADC Clock Rate)

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2       | Bit 1        | Bit 0        |
|-------------|-------|-------|-------|-------|-------|-------------|--------------|--------------|
| Address 13h | Х     | Х     | Х     | Х     | Х     | afe_clk_inv | adcclk_rate1 | adcclk_rate0 |

adcclk\_rate



\*00 = PLL clock/2 01 = PLLCLK/4 10 = PLLCLK/8 11 = PLLCLK/16 Description: Clock for the analog front end and ADC blocks.

Afe\_clk\_inv \*0 = No inversion

1 = Inverted

Description: Inverts the clock input to the ADC. This setting should not be altered.

#### 14h SYS\_CLK\_CTRL (System Clock Control)

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4     | Bit 3 | Bit 2        | Bit 1        | Bit 0        |
|-------------|-------|-------|-------|-----------|-------|--------------|--------------|--------------|
| Address 14h | Х     | Х     | Х     | csifee_en | Х     | Sysclk_rate2 | sysclk_rate1 | sysclk_rate0 |

sysclk\_rate

\*000 = PLL clock rate

Description: System clock. Frequency is PLLCLK/2<sup>N</sup>, where N is the 3-bit value. Maximum value for N is 6 (divide by 64).

csifee\_en

0 = Disabled

\*1 = Inverted

Description: Enables clk\_sifee, the clock for EEPROM transfers.

#### 15h SPI\_CTRL (Serial Interface Control)

|             | Bit 7 | Bit 6    | Bit 5    | Bit 4    | Bit 3       | Bit 2   | Bit 1        | Bit 0        |
|-------------|-------|----------|----------|----------|-------------|---------|--------------|--------------|
| Address 15h | Х     | reserved | fast_ch1 | fast_ch0 | sif_autoinc | sif_par | sif_singlech | ram_run_mode |

ram\_run\_mode

\*0 = Disabled

1 = Enabled

Description: Keeps RAM contents updated. Disable only during access to internal RAM from the SPI bus in configure mode. Usually will be enabled with run mode once the coefficient RAMs have been configured.

sif\_singlech

\*0 = multi-channel mode

1 = Single channel mode

Description: Sets configuration of output data in run mode.

sif\_par

\*0 = No parity

1 = Parity enabled

Description: If set and in multi-channel mode, each channel's MSB will toggle so the total number of "ones" is always odd.

sif\_autoinc

\*0 = Disable

1 = Enable



Description: Enable address autoincrement. If set, on the next read/write cycle the address data can be followed by multiple data bytes.

fast\_ch

\*00 = Channel 1

01 = Channel 2

10 = Channel 3

11 = Channel 4

Description: Identifies the channel with the fastest sample rate. This channel is used to provide the DRDY signal. The user must ensure this channel is correctly identified and that the corresponding channel is enabled, otherwise missed data samples will result. The value will be correctly set by the Quickfilter Pro Software, but if the chip configuration is dynamically altered the user must ensure this value is correctly maintained.

16h SPI\_MON (SPI Monitor) - For factory use only

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1       | Bit 0        |
|-------------|-------|-------|-------|-------|-------|-------|-------------|--------------|
| Address 16h | Х     | Х     | Х     | Х     | Х     | Х     | mon_ee_sifn | en_sifee_mon |

en\_sifee\_mon

\*0 = Disable

1 = Enable

Description: Allows monitoring of internal bus during transfers.

Mon\_ee\_sifn

\*0 = Monitor SIF

1 = Monitor EEPROM

Description: Selects which bus is monitored.

#### 17h EE\_STADDR (EEPROM Starting address - LSB)

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Address 17h | addr7 | addr6 | addr5 | addr4 | addr3 | addr2 | addr1 | addr0 |

#### 18h EE\_STADDR (EEPROM Starting address - MSB)

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3  | Bit 2  | Bit 1 | Bit 0 |
|-------------|-------|-------|-------|-------|--------|--------|-------|-------|
| Address 18h | Х     | Х     | Х     | Х     | addr11 | addr10 | addr9 | addr8 |

Description: Starting address in EEPROM for block transfers.

#### 19h CHIP\_STADDR (Chip Starting address - LSB)

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Address 19h | addr7 | addr6 | addr5 | addr4 | addr3 | addr2 | addr1 | addr0 |

#### 1Ah CHIP\_STADDR (Chip starting address - MSB)

|             | Bit 7 | Bit 6 | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1 | Bit 0 |
|-------------|-------|-------|--------|--------|--------|--------|-------|-------|
| Address 1Ah | Х     | Х     | addr13 | addr12 | addr11 | addr10 | addr9 | addr8 |

Description: Chip starting address for block transfers.

#### 1Bh END\_ADDR (Destination ending address - LSB)



Address 1Bh addr7 addr6 addr5 addr4 addr3 addr2 addr1 addr0

#### 1Ch END\_ADDR (Destination ending address - MSB)

|             | Bit 7 | Bit 6 | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1 | Bit 0 |
|-------------|-------|-------|--------|--------|--------|--------|-------|-------|
| Address 1Ch | Х     | Х     | addr13 | addr12 | addr11 | addr10 | addr9 | addr8 |

Description: Destination ending address for block transfers.

# 12.6 Global Maintenance 1 Registers

Table 18. Control Register listing (Global Maintenance 1)

| Hex*         | Register Name | Description                                      |
|--------------|---------------|--------------------------------------------------|
| 001D – 0024h | SCRATCH       | User scratch pad.                                |
| 0025h        | SU_UNLOCK     | Lock bit for test/maintenance (factory use only) |
| 0026h        | GLBL_SRST     | Global soft resets                               |
| 0027h        | ADC_CTRL      | ADC control.                                     |
| 0028h        | AREC_CTRL     | AREC control.                                    |
| 0029h        | PMUX          | Test mux (factory use only)                      |
| 002Ah        | DEBUG         | Debug (factory use only)                         |
| 002Bh        | PCG_MNTNC     | Clock test (factory use only)                    |
| 002Ch        | CAL_AFE       | Calibration (reserved for future use)            |
| 002Dh        | BIST_CTRL     | BIST control register (factory use only)         |
| 002Eh        | BIST_STATUS_0 | BIST status register (factory use only)          |
| 002Fh        | BIST_STATUS_1 | BIST Status register (factory use only)          |

#### 1D - 24h SCRATCH (User scratchpad)

|                   |    |    |    |    |    |    |    | Bit 0 |
|-------------------|----|----|----|----|----|----|----|-------|
| Addresses 1D -24h | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0    |

Description: 8 bytes of space reserved for user functions. Since the 128 bytes of user data in EEPROM are not copied over to RAM/registers these 8 bytes can be used to access the data (or any other data as required). See Chapter 11 for further information.

#### 25h SU\_UNLOCK (Test/Maintenance unlock) - Factory use only

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0     |
|-------------|-------|-------|-------|-------|-------|-------|-------|-----------|
| Address 25h | Х     | Х     | Х     | Х     | Х     | Х     | Х     | su_unlock |

su\_unlock

\*0 = Locked

1 = Unlocked

Description: This bit can be read. Writing to this bit will lock the device. Locks the registers designated as "Locked".

#### 26h GLBL\_SRST (Global soft resets) - Factory use only

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4     | Bit 3     | Bit 2    | Bit 1     | Bit 0    |
|-------------|-------|-------|-------|-----------|-----------|----------|-----------|----------|
| Address 26h | Х     | Х     | Х     | pmux_srst | arec_srst | spim_rst | ilgc_srst | pcg_srst |



#### \*0 = Default

1 = Reset

Description: Soft reset of internal blocks. User resets can be performed in register FULL\_SRST (02h).

#### 27h ADC\_CTRL (ADC control) - LOCKED

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3      | Bit 2        | Bit 1         | Bit 0         |
|-------------|-------|-------|-------|-------|------------|--------------|---------------|---------------|
| Address 27h | Х     | Х     | Х     | Х     | afe_dcr_en | afe_adc_shin | afe_sub_samp1 | afe_sub_samp0 |

### 28h AREC\_CTRL (ADC Pipeline latency) - LOCKED

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Address 28h | Х     | Х     | Х     | Х     | D3    | D2    | D1    | D0    |

Description: Programmable ADC pipeline latency. Default value is 9, allowable range is 6 – 10.

**29h PMUX** (Test Mux) – Factory use only (Default value = 0)

**2Ah DEBUG** (Debug mode) – *Factory use only* (Default value = 0)

**2Bh PCG\_MNTNC** (PCG maintenance) – *Factory use only* (Default value = 0)

**2Ch CAL\_AFE** (AFE Calibration) – *Factory use only* (Default value = 1)

**2Dh BIST\_CTRL** (BIST control) – *Factory use only* (Default value = 0)

2Eh BIST\_STATUS\_0 (BIST status) - Factory use only (Default value = 0)

**2Fh BIST\_STATUS\_1** (BIST status) – *Factory use only* (Default value = 0)

### 12.7 Channel-specific Registers

Table 19. Channel-specific Register Map

| Channel | Channel | Channel | Channel | Function      |
|---------|---------|---------|---------|---------------|
| 1       | 2       | 3       | 4       |               |
| 0030h - | 0060h - | 0090h - | 00C0h – | Run & Status  |
| 0031h   | 0061h   | 0091h   | 00C1h   |               |
| 0032h – | 0062h – | 0092h – | 00C2h – | Configuration |
| 0050h   | 0080h   | 00B0h   | 00E0h   |               |
| 0051h – | 0081h – | 00B1h – | 00E1h – | Maintenance   |
| 0059h   | 0089h   | 00B9h   | 00E9h   |               |
| 005Ah – | 008Ah – | 00Bah – | 00EAh – | Reserved      |
| 005Fh   | 008Fh   | 00BFh   | 00EFh   |               |

The following descriptions show the address for Channel 1. The maps for the other three channels are identical with address offsets of 30h for Channel 2, 60h for Channel 3 and 90h for Channel 4, as shown in the table above.



Run and Status Registers

#### **30h CH1\_PGA** (Programmable Gain Amplifier Setting, FIR bypass)

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4          | Bit 3 | Bit 2 | Bit 1     | Bit 0     |
|-------------|-------|-------|-------|----------------|-------|-------|-----------|-----------|
| Address 30h | Х     | Х     | Х     | fir_0_1_bypass | Х     | Х     | pga_gain1 | pga_gain0 |

pga\_gain

\* 00 = 1 01 = 2

10 = 4

11 = 8

Description: Sets the individual gain of the programmable gain amplifiers. The four settings are 1x 2x 4x or 8x the incoming signal.

fir\_0\_1\_bypass

0 = In-circuit

\*1 = Bypassed

Description: Bypasses the main FIR filter (filter 1).

31h CH1\_STAT (Channel status) - AUTOSET

|             | Bit 7       | Bit 6       | Bit 5           | Bit 4           | Bit 3 | Bit 2  | Bit 1  | Bit 0  |
|-------------|-------------|-------------|-----------------|-----------------|-------|--------|--------|--------|
| Address 31h | fir_outsat1 | fir_outsat0 | fir_inbuf_over1 | fir_inbuf_over0 | Х     | adc_un | adc_ov | adc_oo |

Once set these bits retain their value until reset by the user.

adc\_oo

\*0 = In range

1 = Out of range

Description: ADC out of range, high or low.

adc\_ov

\*0 = No overflow

1 = Overflow

Description: ADC out of range, high.

adc\_un

\*0 = No underflow

1 = Underflow

Description: ADC out of range, low.

fir\_inbuf\_over0 \*0 = No overflow 1 = Overflow Description: FIR, filter 0, input buffer overflow flag.

fir\_inbuf\_over1 \*0 = No overflow



#### 1 = Overflow

Description: FIR, filter 1, input buffer overflow flag.

fir\_outsat0

\*0 = Not saturated

1 = Saturated

Description: FIR output saturation flag, filter 0.

fir\_outsat1

\*0 = Not saturated

1 = Saturated

Description: FIR output saturation flag, filter 1.

#### **Configuration Registers**

#### 32h CH1\_CFG (Channel configuration)

|            | Bit 7            | Bit 6          | Bit 5          | Bit 4        | Bit 3 | Bit 2       | Bit 1     | Bit 0     |
|------------|------------------|----------------|----------------|--------------|-------|-------------|-----------|-----------|
| Address 32 | h fir_0_0_bypass | fir_0_1_enable | fir_0_0_enable | cic_0_bypass | Х     | chpc_calph0 | chpc_inv0 | aaf_freq0 |

aaf\_freq

\*0 = 0.5MHz

1 = 3MHz

Description: Anti-aliasing filter cutoff frequency select.

chpc\_inv0

\*0 = No invert

1 = Invert

Description: Inverts the input signal using the chopper circuit. Do not alter. - for factory use only

chpc\_calph0

\*0 = Default

1 = Use calibrated chopper phase

Description: Use calibrated chopper phase. Do not alter. – for factory use only

cic\_0\_bypass

0 = No bypass

\*1 = Bypass

Description: Bypasses the CIC module. Do not alter. - for factory use only

fir\_0\_0\_enable

0 = Disable

\*1 = Enable

Description: Enable FIR operation, filter 0.

fir\_0\_1\_enable

0 = Disable

\*1 = Enable

Description: Enable FIR operation, filter 1.



fir\_0\_0\_bypass

0 = In-circuit

\*1 = Bypassed

Description: Bypasses the FIR filter (filter 0).

#### 33h AREC\_1\_GAIN (AREC gain control)

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Address 33h | D7    | D6    | D5    | D4    | D3    | D2    | D1    | D0    |

#### 34h AREC\_1\_GAIN (AREC gain control)

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Address 34h | D15   | D14   | D13   | D12   | D11   | D10   | D9    | D8    |

Description: AREC gain control, default value = 4000. This is a function of the CIC "R" value and along with CIC\_SHIFT (3Ah) is calculated automatically by the Quickfilter Pro software.

35h CHPC\_1\_DIV (Chopper divider setting)

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Address 35h | D7    | D6    | D5    | D4    | D3    | D2    | D1    | D0    |

#### 36h CHPC\_1\_DIV (Chopper divider setting)

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Address 36h | D15   | D14   | D13   | D12   | D11   | D10   | D9    | D8    |

Description: Sets the frequency for the chopper circuit. Default value = 0, which turns off the chopper circuit. When a value is written here the chopper frequency is equal to the ADC\_CLK divided by this value.

37h CIC\_1\_R (CIC decimation, R value)

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Address 37h | D7    | D6    | D5    | D4    | D3    | D2    | D1    | D0    |

**38h CIC\_1\_R** (CIC decimation, R value)

|             |     |     |     |     |     |     | Bit 1 |    |
|-------------|-----|-----|-----|-----|-----|-----|-------|----|
| Address 38h | D15 | D14 | D13 | D12 | D11 | D10 | D9    | D8 |

39h CIC\_1\_R (CIC decimation, R value)

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Address 39h | Х     | Х     | Х     | Х     | Х     | Х     | Х     | D16   |

Description: CIC decimation rate factor minus 1 (R-1), default value = 8. Effective sampling rate for the channel is the ADC\_CLK divided by (Number of channels \* 4). See Section 7.2)

3Ah CIC\_1\_SHIFT (CIC shift)

|             |   |    |    |    |    | Bit 2 |    |    |
|-------------|---|----|----|----|----|-------|----|----|
| Address 3Ah | Х | D6 | D5 | D4 | D3 | D2    | D1 | D0 |



Description: CIC shift value, default; value = 0. This is a function of the CIC "R" value and along with AREC\_GAIN (33h, 34h) is calculated automatically by the Quickfilter Pro software.

# Note: The following registers (3Bh – 50h) have values generated by the Quickfilter Pro Design Software. Manual alteration of these registers is not recommended, the descriptions are for reference only.

#### **3Bh FIR\_0\_0\_CTRL** (FIR Control, filter 0)

|             | Bit 7           | Bit 6           | Bit 5           | Bit 4           | Bit 3 | Bit 2         | Bit 1         | Bit 0             |
|-------------|-----------------|-----------------|-----------------|-----------------|-------|---------------|---------------|-------------------|
| Address 3Bh | fir_0_0_decimf2 | fir_0_0_decimf2 | fir_0_0_decimf1 | fir_0_0_decimf1 | Х     | fir_0_0_oddf2 | fir_0_0_oddf1 | fir_0_0_f2_enable |

fir\_0\_0\_f2\_enable

\*0 = Disable

1 = Enable

Description: Enable the second filter block, f2.

fir\_0\_0\_oddf1

\*0 = Disable

1 = Enable

Description: Set an odd number of taps for f1.

fir\_0\_0\_oddf2

\*0 = Disable

1 = Enable

Description: Set an odd number of taps for f2.

fir\_0\_0\_decimf1 Description: Decimation value for f1. Default value = 0, values in range 0 - 3.

fir\_0\_0\_decimf2 Description: Decimation value for f2. Default value = 0, values in range 0 - 3.

#### 3Ch FIR\_0\_0\_NMIN\_F1 (Minimum storage address for f1)

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Address 3Ch | Х     | addr6 | addr5 | addr4 | addr3 | addr2 | addr1 | addr0 |

Default value = 0

**3Dh FIR\_0\_0\_NMAX\_F1** (Maximum storage address for f1)

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Address 3Dh | Х     | addr6 | addr5 | addr4 | addr3 | addr2 | addr1 | addr0 |

Default value = 7F

Description: Minimum and maximum data storage (tap) address values for f1.

| 3Eh FIR_0_0_CMIN_F1 | (Minimum coefficient st | torage address for f1) |
|---------------------|-------------------------|------------------------|
|---------------------|-------------------------|------------------------|

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Address 3Eh | Х     | Х     | addr5 | addr4 | addr3 | addr2 | addr1 | addr0 |

Default value = 0

3Fh FIR\_0\_0\_CMAX\_F1 (Maximum coefficient storage address for f1)

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Address 3Fh | Х     | Х     | addr5 | addr4 | addr3 | addr2 | addr1 | addr0 |

Default value = 3F

Description: Minimum and maximum coefficient storage address values for f1.

#### 40h FIR\_0\_0\_NMIN\_F2 (Minimum storage address for f2)

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Address 40h | Х     | addr6 | addr5 | addr4 | addr3 | addr2 | addr1 | addr0 |

Default value = 0

#### 41h FIR\_0\_0\_NMAX\_F2 (Maximum storage address for f2)

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Address 41h | Х     | addr6 | addr5 | addr4 | addr3 | addr2 | addr1 | addr0 |

Default value = 7F

Description: Minimum and maximum data storage (tap) address values for f2.

#### 42h FIR\_0\_0\_CMIN\_F2 (Minimum coefficient storage address for f2)

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Address 42h | Х     | Х     | addr5 | addr4 | addr3 | addr2 | addr1 | addr0 |

#### Default value = 0

43h FIR\_0\_0\_CMAX\_F2 (Maximum coefficient storage address for f2)

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Address 43h | Х     | Х     | addr5 | addr4 | addr3 | addr2 | addr1 | addr0 |

Default value = 3F

Description: Minimum and maximum coefficient storage address values for f2.

#### 44h FIR\_0\_1\_CTRL (FIR Control, filter 1)

|             | Bit 7           | Bit 6           | Bit 5           | Bit 4           | Bit 3 | Bit 2         | Bit 1         | Bit 0             |
|-------------|-----------------|-----------------|-----------------|-----------------|-------|---------------|---------------|-------------------|
| Address 44h | fir_0_1_decimf2 | fir_0_1_decimf2 | fir_0_1_decimf1 | fir_0_1_decimf1 | Х     | fir_0_1_oddf2 | fir_0_1_oddf1 | fir_0_1_f2_enable |

fir\_0\_1\_f2\_enable

\*0 = Disable

1 = Enable

Description: Enable the second filter block, f2.

fir\_0\_1\_oddf1

\*0 = Disable

1 = Enable

Description: Set an odd number of taps for f1.

fir\_0\_1\_oddf2

\*0 = Disable

1 = Enable

Description: Set an odd number of taps for f2.

fir\_0\_1\_decimf1

Quickfilter"

Description: Decimation value for f1. Default value = 0, values in range 0 - 3.

fir\_0\_1\_decimf2

Description: Decimation value for f2. Default value = 0, values in range 0 - 3.

#### 45h FIR\_0\_1\_NMIN\_F1 (Minimum storage address for f1)

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Address 45h | addr7 | addr6 | addr5 | addr4 | addr3 | addr2 | addr1 | addr0 |

#### **46h FIR\_0\_1\_NMIN\_F1** (Minimum storage address for f1)

|                 | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-----------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Address 46h     | Х     | Х     | Х     | Х     | Х     | Х     | Х     | Addr8 |
| Default value 0 |       |       |       |       |       |       |       |       |

Default value = 0

#### 47h FIR\_0\_1\_NMAX\_F1 (Maximum storage address for f1)

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Address 47h | addr7 | addr6 | addr5 | addr4 | addr3 | addr2 | addr1 | addr0 |

#### 48h FIR\_0\_1\_ NMAX\_F1 (Maximum storage address for f1)

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Address 46h | Х     | Х     | Х     | Х     | Х     | Х     | Х     | Addr8 |

Default value =1FF

Description: Minimum and maximum data storage (tap) address values for f1.

#### 49h FIR\_0\_1\_CMIN\_F1 (Minimum coefficient storage address for f1)

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Address 49h | addr7 | addr6 | addr5 | addr4 | addr3 | addr2 | addr1 | addr0 |

Default value = 0

4Ah FIR\_0\_1\_CMAX\_F1 (Maximum coefficient storage address for f1)

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Address 4Ah | addr7 | addr6 | addr5 | addr4 | addr3 | addr2 | addr1 | addr0 |

Default value =FF

Description: Minimum and maximum coefficient storage address values for f1.

#### 4Bh FIR\_0\_1\_NMIN\_F2 (Minimum storage address for f2)

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Address 4Bh | addr7 | addr6 | addr5 | addr4 | addr3 | addr2 | addr1 | addr0 |

#### 4Ch FIR\_0\_1\_NMIN\_F2 (Minimum storage address for f2)

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Address 4Ch | Х     | Х     | Х     | Х     | Х     | Х     | Х     | addr8 |

Default value = 0

Description: Minimum data storage (tap) address value for f2.

4Dh FIR\_0\_1\_NMAX\_F2 (Maximum storage address for f2)



|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Address 4Dh | addr7 | addr6 | addr5 | addr4 | addr3 | addr2 | addr1 | addr0 |

#### 4Eh FIR\_0\_1\_ NMAX\_F2 (Maximum storage address for f2)

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Address 4Eh | Х     | Х     | Х     | Х     | Х     | Х     | Х     | addr8 |

Default value =1FF

Description: Maximum data storage (tap) address value for f2.

#### 4Fh FIR\_0\_1\_CMIN\_F2 (Minimum coefficient storage address for f2)

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Address 4Fh | addr7 | addr6 | addr5 | addr4 | addr3 | addr2 | addr1 | addr0 |
|             | •     |       |       |       |       |       |       |       |

Default value = 0

Description: Minimum coefficient storage address value for f2.

| 50h FIR_0_1_CMA | K F2 (Maximum | coefficient storad | e address for f2)                       |
|-----------------|---------------|--------------------|-----------------------------------------|
| ••••••          |               |                    | , • • • • • • • • • • • • • • • • • • • |

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Address 50h | addr7 | addr6 | addr5 | addr4 | addr3 | addr2 | addr1 | addr0 |

Default value = FF

Description: Maximum coefficient storage address value for f2.

#### **Maintenance Registers**

51h CH1\_SRST (Channel soft reset) - For factory use. User should use FULL\_SRST (02H) to reset the chip

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4        | Bit 3        | Bit 2       | Bit 1      | Bit 0       |
|-------------|-------|-------|-------|--------------|--------------|-------------|------------|-------------|
| Address 51h | Х     | Х     | Х     | fir_0_1_srst | fir_0_0_srst | txrx_0_srst | cic_0_srst | chpc_0_srst |

chpc\_0\_srst

\*0 = No action

1 = Reset

Description: Soft reset the chopper clock generator.

cic\_0\_srst

\*0 = No action

1 = Reset

Description: Soft reset the CIC module. Clears all internal CIC registers.

txrx\_0\_srst

\*0 = No action

1 = Reset

Description: Soft reset the tx/rx.

fir\_0\_0\_srst

\*0 = No action

1 = Reset

Quickfilter"

Description: Soft reset the FIR block, filter 0.

fir\_0\_1\_srst

\*0 = No action

1 = Reset

Description: Soft reset the FIR block, filter 1.

#### 52h CHP\_OFFSET\_1 (Chopper clock phase offset) - Factory use only

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Address 52h | D7    | D6    | D5    | D4    | D3    | D2    | D1    | D0    |

#### 53h CHP\_OFFSET\_1 (Chopper clock phase offset) – Factory use only

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Address 53h | Х     | Х     | Х     | Х     | D11   | D10   | D9    | D8    |

Default value = 95

Description: Chopper clock phase offset value.

#### 54h AREC\_OFFSET\_1 (Digital offset) – Factory use only

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Address 37h | D7    | D6    | D5    | D4    | D3    | D2    | D1    | D0    |

#### 55h AREC\_OFFSET\_1 (Digital offset) - Factory use only

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Address 55h | D15   | D14   | D13   | D12   | D11   | D10   | D9    | D8    |

Default value = C000

Description: Digital offset for the channel.

#### 56h CAL\_1\_OFF (Calibration offset)

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Address 56h | D7    | D6    | D5    | D4    | D3    | D2    | D1    | D0    |

#### 57h CAL\_1\_OFF (Calibration offset)

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Address 57h | D15   | D14   | D13   | D12   | D11   | D10   | D9    | D8    |

Default value = 0

Description: Offset calibration value is written here.

#### 58h CAL\_1\_GAIN (Calibration gain)

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Address 58h | D7    | D6    | D5    | D4    | D3    | D2    | D1    | D0    |

#### 59h CAL\_1\_GAIN (Calibration gain)

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Address 59h | D15   | D14   | D13   | D12   | D11   | D10   | D9    | D8    |



#### Default value = 8000

Description: Gain calibration value is written here.

#### 5Ah – 5Fh – Reserved

The following registers implement similar functionality for the three remaining channels. Please refer to the descriptions above.

60h – 8Fh Channel 2 Registers (see 30h – 5Fh for functionality)

90h – BFh Channel 3 Registers (see 30h – 5Fh for functionality)

C0h - E9h Channel 4 Registers (see 30h - 5Fh for functionality)

#### 12.8 Global Maintenance 2 Registers

Table 21. Control Register listing (Global Maintenance 2)

| Hex*      | Register Name | Description                                    |
|-----------|---------------|------------------------------------------------|
| EAh       | DIE_REV       | Metal Revision ID                              |
| EBh, ECh  | IGC_SEQADDR   | Extended Initialization Sequence Start Address |
| EDh       | CAL_CTRL      | Calibration Control                            |
| EEh, EFh  | CAL_DTGT      | Target Calibration Value                       |
| F0h       | DBG_TEST      | Factory Use Only                               |
| F1h - FFh |               | Reserved                                       |

### EAh DIE\_REV – Read Only

Default value = C1

Description: Die revision.

#### EBh IGC\_SEQADDR (Extended Initialization Sequence Start Address)

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Address EBh | D7    | D6    | D5    | D4    | D3    | D2    | D1    | D0    |

ECh IGC\_SEQADDR (Extended Initialization Sequence Start Address)

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Address ECh | Х     | Х     | Х     | Х     | D11   | D10   | D9    | D8    |

Default value = F00h

Description: Starting address for an Extended Initialization Sequence (See Section 5.2).

#### EDh CAL\_CTRL (Calibration Control)

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4    | Bit 3    | Bit 2         | Bit 1        | Bit 0        |
|-------------|-------|-------|-------|----------|----------|---------------|--------------|--------------|
| Address EDh | Х     | Х     | Х     | cal_srst | cal_enab | cal_gain_mode | cal_chan_sel | cal_chan_sel |

cal\_chan\_sel

Description: Selects the channel to be calibrated.

cal\_gain\_mode

\*0 = Offset calibration



#### 1 = Gain calibration

Description: Select whether to perform gain or offset calibration.

cal\_enab

\*0

1 = Start

Description: Write to 1 to begin calibration.

cal\_srst

\*0

1 = Reset

Description: Soft reset the calibration block.

EEh CAL\_DTGT (Target Calibration Value)

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Address EEh | D7    | D6    | D5    | D4    | D3    | D2    | D1    | D0    |

EFh CAL\_DTGT (Target Calibration Value)

|             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Address EFh | D15   | D14   | D13   | D12   | D11   | D10   | D9    | D8    |

Default value = 0

Description: Target calibration value for applied input voltage (gain calibration). Write to 0 for offset calibration.

**F0h DBG\_TEST** – Reserved (Factory use only) (Default = 0)

F1h – FFh – Reserved

# 12.9 FIR coefficient and Data RAM addresses

**G&H Filter Values** 

G Filter: 15 taps 00A5 0206 FEF5 F843 FA02 0C6B 2661 32C3

 H Filter: 111 taps

 0000
 0001
 FFFF
 FFFE
 0000

 0003
 0001
 FFFF
 FFFE
 0007

 0007
 FFF9
 FFF3
 0005
 0015

 0000
 FFE3
 FFF6
 0023
 0018

 FFDB
 FFCF
 001F
 0048
 FFF2

 FF9B
 FFEE
 007A
 0041
 FF7D

 FF81
 0076
 00C8
 FFB3
 FEEE

 0000
 0151
 0075
 FE89
 FEEE

 016F
 01D3
 FEDB
 FD52
 007F

 0395
 00A3
 FB8A
 FD85
 053F

 0594
 FA22
 F40A
 0644
 2831

 3999



# 100h FIR\_0\_0\_COEF\_RAM (Coefficients for G Filter Channel 1, LSB)

|               | Bit 7   | Bit 6   | Bit 5   | Bit 4   | Bit 3   | Bit 2   | Bit 1   | Bit 0   |
|---------------|---------|---------|---------|---------|---------|---------|---------|---------|
| Channel1 100h | C1TG1_7 | C1TG1_6 | C1TG1_5 | C1TG1_4 | C1TG1_3 | C1TG1_2 | C1TG1_1 | C1TG1_0 |
| Channel2 180h | C2TG1_7 | C2TG1_6 | C2TG1_5 | C2TG1_4 | C2TG1_3 | C2TG1_2 | C2TG1_1 | C2TG1_0 |
| Channel3 200h | C3TG1_7 | C3TG1_6 | C3TG1_5 | C3TG1_4 | C3TG1_3 | C3TG1_2 | C3TG1_1 | C3TG1_0 |
| Channel4 280h | C4TG1_7 | C4TG1_6 | C4TG1_5 | C4TG1_4 | C4TG1_3 | C4TG1_2 | C4TG1_1 | C4TG1_0 |

\*Note, Failure to write both addresses 100h and 101h will result in nothing being written to either of the addresses. (C1TG1\_0 - C1TG1\_7): Represents the LSB in half of TAP1 Coefficient Data for Channel 1.

Description: This is the LSB of the 16 bit Coefficient Data for the first unique TAP value. The G filter has a fixed set of 15 taps. Because the Taps are mirrored, only 8 unique 16 bit coefficients are stored. Since this is an odd number of taps, you have to add 1 to 15 = 16 / 2 = 8 coefficients. The starting address for the H filter would then be (8 Unique taps x 2 bytes each) = 16 bytes. So, the H filter for Channel 1 would start at 100h + 16 = 110h.

The next unique Tap value would start at 102h, Tap3 would start at 104h and so on until all 8 values were entered.

Channel 2: FIR\_1\_0\_COEF\_RAM Address 180h

Channel 3: FIR\_2\_0\_COEF\_RAM Address 200h

Channel 4: FIR\_3\_0\_COEF\_RAM Address 280h

|               | Bit 7    | Bit 6    | Bit 5    | Bit 4    | Bit 3    | Bit 2    | Bit 1   | Bit 0   |
|---------------|----------|----------|----------|----------|----------|----------|---------|---------|
| Channel1 101h | C1TG1_15 | C1TG1_14 | C1TG1_13 | C1TG1_12 | C1TG1_11 | C1TG1_10 | C1TG1_9 | C1TG1_8 |
| Channel2 181h | C2TG1_15 | C2TG1_14 | C2TG1_13 | C2TG1_12 | C2TG1_11 | C2TG1_10 | C2TG1_9 | C2TG1_8 |
| Channel3 201h | C3TG1_15 | C3TG1_14 | C3TG1_13 | C3TG1_12 | C3TG1_11 | C3TG1_10 | C3TG1_9 | C3TG1_8 |
| Channel4 281h | C4TG1_15 | C4TG1_14 | C4TG1_13 | C4TG1_12 | C4TG1_11 | C4TG1_10 | C4TG1_9 | C4TG1_8 |

# 101h FIR\_0\_0\_COEF\_RAM (Coefficients for G Filter per Channel, MSB)

\*Note, Failure to write both addresses 100h and 101h will result in nothing being written to either of the addresses. (C1TG1\_8 - C1TG1\_15): Represents the MSB in half of TAP1 Coefficient Data for Channel 1.

Description: This is the MSB of the 16 bit Coefficient Data for the first unique TAP value. The G filter has a fixed set of 15 taps. Because the Taps are mirrored, only 8 unique 16 bit coefficients are stored.

The H filter for Channel 1 would start at 101h + 16 = 111h.

The next unique Tap value would start at 103h, Tap3 would start at 105h and so on until all 8 values were entered.

Channel 2: FIR\_1\_0\_COEF\_RAM Address 181h

Channel 3: FIR\_2\_0\_COEF\_RAM Address 201h

Channel 4: FIR\_3\_0\_COEF\_RAM Address 281h

### 110h FIR\_0\_0\_COEF\_RAM (Coefficients for H Filter Channel 1, LSB)

|               | Bit 7   | Bit 6   | Bit 5   | Bit 4   | Bit 3   | Bit 2   | Bit 1   | Bit 0   |
|---------------|---------|---------|---------|---------|---------|---------|---------|---------|
| Channel1 11Dh | C1TH1_7 | C1TH1_6 | C1TH1_5 | C1TH1_4 | C1TH1_3 | C1TH1_2 | C1TH1_1 | C1TH1_0 |
| Channel2 19Dh | C2TH1_7 | C2TH1_6 | C2TH1_5 | C2TH1_4 | C2TH1_3 | C2TH1_2 | C2TH1_1 | C2TH1_0 |
| Channel3 21Dh | C3TH1_7 | C3TH1_6 | C3TH1_5 | C3TH1_4 | C3TH1_3 | C3TH1_2 | C3TH1_1 | C3TH1_0 |
| Channel4 29Dh | C4TH1_7 | C4TH1_6 | C4TH1_5 | C4TH1_4 | C4TH1_3 | C4TH1_2 | C4TH1_1 | C4TH1_0 |

\*Note, Failure to write both addresses 110h and 111h will result in nothing being written to either of the addresses.



(C1TH1\_0 - C1TH1\_7): Represents the LSB in half of TAP1 Coefficient Data for Channel 1.

Description: This is the LSB of the 16 bit Coefficient Data for the first unique TAP value. The H filter has a fixed set of 89 taps. Because the Taps are mirrored, only 45 unique 16 bit coefficients are stored. Since this is an odd number of taps, you have to add 1 to 89=90/2=45. The starting address for the H filter is after the G filter coefficients end. This would then be (8 Unique taps x 2 bytes each) = 16 bytes. So, the H filter for Channel 1 would start at 100h + 16 = 110h.

The next unique Tap value would start at 112h, Tap3 would start at 114h and so on until all 45 values were entered.

Channel 2: FIR\_1\_0\_COEF\_RAM Address 190h

Channel 3: FIR\_2\_0\_COEF\_RAM Address 210h

Channel 4: FIR\_3\_0\_COEF\_RAM Address 290h

# 111h FIR\_0\_0\_COEF\_RAM (Coefficients for H Filter per Channel, MSB)

|               | Bit 7    | Bit 6    | Bit 5    | Bit 4    | Bit 3    | Bit 2    | Bit 1   | Bit 0   |
|---------------|----------|----------|----------|----------|----------|----------|---------|---------|
| Channel1 11Dh | C1TH1_15 | C1TH1_14 | C1TH1_13 | C1TH1_12 | C1TH1_11 | C1TH1_10 | C1TH1_9 | C1TH1_8 |
| Channel2 19Dh | C2TH1_15 | C2TH1_14 | C2TH1_13 | C2TH1_12 | C2TH1_11 | C2TH1_10 | C2TH1_9 | C2TH1_8 |
| Channel3 21Dh | C3TH1_15 | C3TH1_14 | C3TH1_13 | C3TH1_12 | C3TH1_11 | C3TH1_10 | C3TH1_9 | C3TH1_8 |
| Channel4 29Dh | C4TH1_15 | C4TH1_14 | C4TH1_13 | C4TH1_12 | C4TH1_11 | C4TH1_10 | C4TH1_9 | C4TH1_8 |

\*Note, Failure to write both addresses 110h and 111h will result in nothing being written to either of the addresses. (C1TH1\_8 - C1TH1\_15): Represents the MSB in half of TAP1 Coefficient Data for Channel 1.

Description: This is the MSB of the 16 bit Coefficient Data for the first unique TAP value. The H filter has a fixed set of 89 taps. Because the Taps are mirrored, only 45 unique 16 bit coefficients are stored. Since this is an odd number of taps, you have to add 1 to 89 = 90/2 = 45 coefficients. The starting address for the H filter would then be (8 Unique taps x 2 bytes each) = 16 bytes. So, the H filter for Channel 1 would start at 101h + 16 = 111h.

The next unique Tap value would start at 113h, Tap3 would start at 115h and so on until all 45 values were entered.

Channel 2: FIR\_1\_0\_COEF\_RAM Address 191h

Channel 3: FIR\_2\_0\_COEF\_RAM Address 211h

Channel 4: FIR\_3\_0\_COEF\_RAM Address 291h

# **300h FIR\_0\_1\_COEF\_RAM** (Coefficients for **FIR** Filter per Channel, LSB, Byte 1)

|               | Bit 7  | Bit 6  | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  |
|---------------|--------|--------|--------|--------|--------|--------|--------|--------|
| Channel1 300h | C1T1_7 | C1T1_6 | C1T1_5 | C1T1_4 | C1T1_3 | C1T1_2 | C1T1_1 | C1T1_0 |
| Channel2 600h | C2T1_7 | C2T1_6 | C2T1_5 | C2T1_4 | C2T1_3 | C2T1_2 | C2T1_1 | C2T1_0 |
| Channel3 900h | C3T1_7 | C3T1_6 | C3T1_5 | C3T1_4 | C3T1_3 | C3T1_2 | C3T1_1 | C3T1_0 |
| Channel4 C00h | C4T1_7 | C4T1_6 | C4T1_5 | C4T1_4 | C4T1_3 | C4T1_2 | C4T1_1 | C4T1_0 |

\*Note, Failure to write addresses 300h, 301, and 302h will result in nothing being written to any of the addresses. (C1T1\_0 - C1T1\_7): Represents the LSB in three bytes storing 20 bits of data for a unique tap coefficient.

Description: This is the LSB of the 20 bit Coefficient Data for the first unique TAP value for the FIR filter. The FIR filter can have up to 512 taps depending on the filter design. Because the Taps are mirrored, only half of the actual taps are stored in coefficient RAM. Since most likely it will be an odd number of taps design, the extra "non-mirrored" tap is added to the number of unique tap coefficients. Example, if a low pass filter design required 137 taps, the number of unique taps would be 137+1 = 138 /2 = 69 unique tap coefficients. Each coefficient is 20 bits, requiring 3 bytes of space for each coefficient. The data is shifted to the least significant bit.

The next unique Tap value would start at 303h, Unique Tap3 value would start at 306h and so on until all 69 values were entered. Channel 2: FIR\_1\_1\_COEF\_RAM Address 600h

Channel 3: FIR\_2\_1\_COEF\_RAM Address 900h

Channel 4: FIR\_3\_1\_COEF\_RAM Address C00h



|               | Bit 7   | Bit 6   | Bit 5   | Bit 4   | Bit 3   | Bit 2   | Bit 1  | Bit 0  |
|---------------|---------|---------|---------|---------|---------|---------|--------|--------|
| Channel1 301h | C1T1_15 | C1T1_14 | C1T1_13 | C1T1_12 | C1T1_11 | C1T1_10 | C1T1_9 | C1T1_8 |
| Channel2 601h | C2T1_15 | C2T1_14 | C2T1_13 | C2T1_12 | C2T1_11 | C2T1_10 | C2T1_9 | C2T1_8 |
| Channel3 901h | C3T1_15 | C3T1_14 | C3T1_13 | C3T1_12 | C3T1_11 | C3T1_10 | C3T1_9 | C3T1_8 |
| Channel4 C01h | C4T1_15 | C4T1_14 | C4T1_13 | C4T1_12 | C4T1_11 | C4T1_10 | C4T1_9 | C4T1_8 |

# 301h FIR\_0\_1\_COEF\_RAM (Coefficients for FIR Filter per Channel, Byte 2)

\*Note, Failure to write addresses 300h, 301, and 302h will result in nothing being written to any of the addresses.

(C1T1\_8 - C1T1\_15): Represents the middle byte in three bytes storing 20 bits of data.

See Quickfilter software for unique filter design.

Description: This is the LSB of the 20 bit Coefficient Data for the first unique TAP value for the FIR filter. The FIR filter can have up to 512 taps depending on the filter design. Because the Taps are mirrored, only half of the actual taps are stored in coefficient RAM. Since most likely it will be an odd number of taps design, the extra "non-mirrored" tap is added to the number of unique tap coefficients. Example, if a low pass filter design required 137 taps, the number of unique taps would be 137+1 = 138 /2 = 69 unique tap coefficients. Each coefficient is 20 bits, requiring 3 bytes of space for each coefficient. The data is shifted to the least significant bit.

The next unique Tap value would start at 304h, Unique Tap3 value would start at 307h and so on until all 69 values were entered. Channel 2: FIR\_1\_1\_COEF\_RAM Address 600h

Channel 3: FIR\_2\_1\_COEF\_RAM Address 900h

Channel 4: FIR\_3\_1\_COEF\_RAM Address C00h

# 302h FIR\_0\_1\_COEF\_RAM (Coefficients for FIR Filter per Channel, MSB, Byte 3)

|               | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3   | Bit 2   | Bit 1   | Bit 0   |
|---------------|-------|-------|-------|-------|---------|---------|---------|---------|
| Channel1 302h | Х     | Х     | Х     | Х     | C1T1_19 | C1T1_18 | C1T1_17 | C1T1_16 |
| Channel2 602h | Х     | Х     | Х     | Х     | C2T1_19 | C2T1_18 | C2T1_17 | C2T1_16 |
| Channel3 902h | Х     | Х     | Х     | Х     | C3T1_19 | C3T1_18 | C3P1_17 | C3T1_16 |
| Channel4 C02h | Х     | Х     | Х     | Х     | C4T1_19 | C4T1_18 | C4T1_17 | C4T1_16 |

\*Note, Failure to write addresses 300h, 301, and 302h will result in nothing being written to any of the addresses.

(C1T1\_16 - C1TP1\_19): Represents the MSB in three bytes storing 20 bits of data.

Description: This is the LSB of the 20 bit Coefficient Data for the first unique TAP value for the FIR filter. The FIR filter can have up to 512 taps depending on the filter design. Because the Taps are mirrored, only half of the actual taps are stored in coefficient RAM. Since most likely it will be an odd number of taps design, the extra "non-mirrored" tap is added to the number of unique tap coefficients. Example, if a low pass filter design required 137 taps, the number of unique taps would be 137+1 = 138/2 = 69 unique tap coefficients. Each coefficient is 20 bits, requiring 3 bytes of space for each coefficient. The data is shifted to the least significant bit.

The next unique Tap value would start at 305h, Unique Tap3 value would start at 308h and so on until all 69 values were entered. Channel 2: FIR\_1\_1\_COEF\_RAM Address 600h

Channel 3: FIR\_2\_1\_COEF\_RAM Address 900h

Channel 4: FIR\_3\_1\_COEF\_RAM Address C00h



# 1400h FIR\_0\_1\_DATA\_RAM (FIR Data Memory, LSB)

|                | Bit 7  | Bit 6  | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  |
|----------------|--------|--------|--------|--------|--------|--------|--------|--------|
| Channel1 1400h | C1D1_7 | C1D1_6 | C1D1_5 | C1D1_4 | C1D1_3 | C1D1_2 | C1D1_1 | C1D1_0 |
| Channel2 1800h | C2D1_7 | C2D1_6 | C2D1_5 | C2D1_4 | C2D1_3 | C2D1_2 | C2D1_1 | C2D1_0 |
| Channel3 1C00h | C3D1_7 | C3D1_6 | C3D1_5 | C3D1_4 | C3D1_3 | C3D1_2 | C3D1_1 | C3D1_0 |
| Channel4 2000h | C4D1_7 | C4D1_6 | C4D1_5 | C4D1_4 | C4D1_3 | C4D1_2 | C4D1_1 | C4D1_0 |

(C1D1\_0 - C1D1\_7): Represents the LSB of a 16 bit value of in this case TAP1, Channel 1 of the computed FIR filter data.

Description: These are the memory locations of the temporary stored data of each tap as the signal is multiplied and accumulated.

The next unique Tap value would start at 1402h, Tap3 would start at 1404h and so on for all of the computed Taps.

Channel 2: FIR\_1\_1\_DATA\_RAM Address 1800h

Channel 3: FIR\_2\_1\_DATA\_RAM Address 1C00h

Channel 4: FIR\_3\_1\_DATA\_RAM Address 2000h

# 1401h FIR\_0\_1\_DATA\_RAM (FIR Data Memory, MSB)

|                | Bit 7   | Bit 6   | Bit 5   | Bit 4   | Bit 3   | Bit 2   | Bit 1  | Bit 0  |
|----------------|---------|---------|---------|---------|---------|---------|--------|--------|
| Channel1 1401h | C1D1_15 | C1D1_14 | C1D1_13 | C1D1_12 | C1D1_11 | C1D1_10 | C1D1_9 | C1D1_8 |
| Channel2 1801h | C2D1_15 | C2D1_14 | C2D1_13 | C2D1_12 | C2D1_11 | C2D1_10 | C2D1_9 | C2D1_8 |
| Channel 1C01h  | C3D1_15 | C3D1_14 | C3D1_13 | C3D1_12 | C3D1_11 | C3D1_10 | C3D1_9 | C3D1_8 |
| Channel4 2001h | C4D1_15 | C4D1_14 | C4D1_13 | C4D1_12 | C4D1_11 | C4D1_10 | C4D1_9 | C4D1_8 |

(C1D1\_8 - C1D1\_15): Represents the MSB of a 16 bit value of in this case TAP1, Channel 1 of the computed FIR filter data. Description: These are the memory locations of the temporary stored data of each tap as the signal is multiplied and accumulated. For internal use only.

The next unique Tap value would start at 1403h, Tap3 would start at 1405h and so on for all the computed Taps. Channel 2: FIR\_1\_0\_DATA\_RAM Address 1801h

Channel 3: FIR\_2\_0\_DATA\_RAM Address 1C01h

Channel 4: FIR\_3\_0\_DATA\_RAM Address 2001h



| 12.10 Register Listing                                                  |      |
|-------------------------------------------------------------------------|------|
| 00H GLBL_SW (User Register)                                             | 24   |
| 01H GLBL_ID (CHIP ID) - READ ONLY                                       |      |
| 02H FULL_SRST (GLOBAL SOFT RESET)                                       |      |
| 03H GLBL CH CTRL (GLOBAL CHANNEL CONTROL)                               |      |
| 04H RUN_MODE (SERIAL INTERFACE RUN MODE)                                |      |
| 05H EE_TRANS (EEPROM TRANSFER)                                          |      |
| 06H EE_COPY (Full EEPROM TRANSFER)                                      |      |
| 07H STARTUP (SPI SETUP)                                                 |      |
| 09H ENABLE 0 (ADC ENABLE)                                               |      |
| <b>0AH ENABLE 1</b> (AAF ENABLE, ADC MODE)                              |      |
| <b>0BH ENABLE_2</b> (SAMPLING ENABLE, SERIAL OUTPUT ENABLE)             |      |
| ODH EE VAL (EEPROM STATUS REGISTER VALUE)                               |      |
| OEH EE_STATUS (EEPROM STATUS FLAGS)                                     |      |
| 0FH ADC_STATUSO (ADC OUT OF RANGE, HIGH OR LOW) - READ ONLY             |      |
| 10H ADC_STATUS1 (ADC OUT OF RANGE, SPECIFIC) – READ ONLY                |      |
| 11H PLL_CTRL_0 (PLL pre-divider and range)                              |      |
| 12H PLL_CTRL_1 (PLL LOOP DIVIDER)                                       |      |
| 13H ADC_CLK_RATE (ADC CLOCK RATE)                                       |      |
| 14H SYS CLK CTRL (SYSTEM CLOCK CONTROL)                                 |      |
| 15H SPI_CTRL (Serial Interface Control)                                 |      |
| 16H SPI_MON (SPI MONITOR) - FOR FACTORY USE ONLY                        | .42  |
| 17H EE_STADDR (EEPROM STARTING ADDRESS - LSB)                           | .42  |
| 18H EE_STADDR (EEPROM STARTING ADDRESS - MSB)                           | . 42 |
| 19H SIF_STADDR (SIF STARTING ADDRESS - LSB)                             | . 42 |
| 1AH SIF_STADDR (SIF STARTING ADDRESS - MSB)                             | .42  |
| 1BH END_ADDR (DESTINATION ENDING ADDRESS - LSB)                         |      |
| 1CH END_ADDR (DESTINATION ENDING ADDRESS - MSB)                         | .43  |
| 1D - 24H SCRATCH (USER SCRATCHPAD)                                      |      |
| 25H SU_UNLOCK (Test/Maintenance Unlock) - Factory use only              | .43  |
| 26H GLBL_SRST (GLOBAL SOFT RESETS)                                      | . 43 |
| 27H ADC_CTRL (ADC CONTROL)                                              | .44  |
| 28H AREC_CTRL (ADC PIPELINE LATENCY)                                    |      |
| 29H PMUX (TEST MUX) – FACTORY USE ONLY                                  |      |
| 2AH DEBUG (DEBUG MODE) – FACTORY USE ONLY                               |      |
| 2BH PCG_MNTNC (PCG MAINTENANCE) – FACTORY USE ONLY                      |      |
| 2CH CAL_AFE (AFE CALIBRATION) – RESERVED FOR FUTURE USE                 |      |
| 2DH BIST_CTRL (BIST CONTROL) – FACTORY USE ONLY                         | .44  |
| 2EH BIST_STATUS (BIST STATUS) – FACTORY USE ONLY                        | .44  |
| 2EH BIST_STATUS (BIST STATUS) – FACTORY USE ONLY                        |      |
| 30H CH1_PGA (PROGRAMMABLE GAIN AMPLIFIER SETTING, FIR BYPASS)           |      |
| 31H CH1_STAT (CHANNEL STATUS)                                           |      |
| 32H CH1_CFG (CHANNEL CONFIGURATION)                                     |      |
| 33H AREC_1_GAIN (AREC GAIN CONTROL)                                     |      |
| 34H AREC_1_GAIN (AREC GAIN CONTROL)                                     |      |
| 35H CHPC_1_DIV (CHOPPER PERIOD SETTING)                                 |      |
| 36H CHPC_1_DIV (CHOPPER PERIOD SETTING)                                 |      |
| 37H CIC_1_R (CIC DECIMATION, R VALUE)                                   |      |
| 38H CIC_1_R (CIC DECIMATION, R VALUE)                                   |      |
| 39H CIC_1_R (CIC DECIMATION, R VALUE)                                   |      |
|                                                                         |      |
| 3BH FIR_0_0_CTRL (FIR CONTROL, FILTER 0)                                |      |
| 3CH FIR_0_0_NMIN_F1 (MINIMUM STORAGE ADDRESS FOR F1)                    |      |
| 3DH FIR_0_0_NMAX_F1 (MAXIMUM STORAGE ADDRESS FOR F1)                    |      |
| <b>3EH FIR_0_0_CMIN_F1</b> (MINIMUM COEFFICIENT STORAGE ADDRESS FOR F1) |      |
| <b>3FH FIR_0_0_CMAX_F1</b> (MAXIMUM COEFFICIENT STORAGE ADDRESS FOR F1) |      |
| 40H FIR_0_0_NMIN_F2 (MINIMUM STORAGE ADDRESS FOR F2)                    | .49  |



| red managed                                                      |    |
|------------------------------------------------------------------|----|
| 41H FIR_0_0_NMAX_F2 (MAXIMUM STORAGE ADDRESS FOR F2)             |    |
| 42H FIR_0_0_CMIN_F2 (MINIMUM COEFFICIENT STORAGE ADDRESS FOR F2) |    |
| 43H FIR_0_0_CMAX_F2 (MAXIMUM COEFFICIENT STORAGE ADDRESS FOR F2) |    |
| 44H FIR_0_1_CTRL (FIR CONTROL, FILTER 1)                         |    |
| 45H FIR_0_1_NMIN_F1 (MINIMUM STORAGE ADDRESS FOR F1)             |    |
| 46H FIR_0_1_NMIN_F1 (MINIMUM STORAGE ADDRESS FOR F1)             |    |
| 47H FIR_0_1_NMAX_F1 (MAXIMUM STORAGE ADDRESS FOR F1)             |    |
| 48H FIR_0_1_ NMAX_F1 (MAXIMUM STORAGE ADDRESS FOR F1)            |    |
| 49H FIR_0_1_CMIN_F1 (MINIMUM COEFFICIENT STORAGE ADDRESS FOR F1) |    |
| 4AH FIR_0_1_CMAX_F1 (MAXIMUM COEFFICIENT STORAGE ADDRESS FOR F1) |    |
| 4Bh FIR_0_1_NMIN_F2 (MINIMUM STORAGE ADDRESS FOR F2)             |    |
| 4CH FIR_0_1_NMIN_F2 (MINIMUM STORAGE ADDRESS FOR F2)             |    |
| 4DH FIR_0_1_NMAX_F2 (MAXIMUM STORAGE ADDRESS FOR F2)             | 50 |
| 4EH FIR_0_1_ NMAX_F2 (MAXIMUM STORAGE ADDRESS FOR F2)            |    |
| 4FH FIR_0_1_CMIN_F2 (MINIMUM COEFFICIENT STORAGE ADDRESS FOR F2) | 51 |
| 50H FIR_0_1_CMAX_F2 (MAXIMUM COEFFICIENT STORAGE ADDRESS FOR F2) |    |
| 51H CH1_SRST (CHANNEL SOFT RESET)                                |    |
| 52H CHP_OFFSET_1 (CHOPPER CLOCK PHASE OFFSET) – FACTORY USE ONLY |    |
| 53H CHP_OFFSET_1 (CHOPPER CLOCK PHASE OFFSET) – FACTORY USE ONLY |    |
| 54H AREC OFFSET 1 (DIGITAL OFFSET) – FACTORY USE ONLY            |    |
| 55H AREC OFFSET 1 (DIGITAL OFFSET) – FACTORY USE ONLY            |    |
| 56H CAL 1 OFF (CALIBRATION OFFSET)                               |    |
| 57H CAL 1 OFF (CALIBRATION OFFSET)                               |    |
| 58H CAL 1 GAIN (CALIBRATION GAIN)                                |    |
| 59H CAL 1 GAIN (CALIBRATION GAIN)                                |    |
| 5AH – 5FH - Reserved                                             |    |
| 60H – 8FH CHANNEL 2 REGISTERS (SEE 30H – 5FH FOR FUNCTIONALITY)  |    |
| 90H – BFH CHANNEL 3 REGISTERS (SEE 30H – 5FH FOR FUNCTIONALITY)  |    |
| C0H – E9H CHANNEL 4 REGISTERS (SEE 30H – 5FH FOR FUNCTIONALITY)  |    |
|                                                                  |    |
| EBHIGC SEQADDR (EXTENDED INITIALIZATION SEQUENCE START ADDRESS)  |    |
| ECHIGC SEQADDR (EXTENDED INITIALIZATION SEQUENCE START ADDRESS)  |    |
| EDH CAL_CTRL (CALIBRATION CONTROL).                              |    |
| EEH CAL_DTGT (TARGET CALIBRATION VALUE)                          |    |
| EFH CAL DTGT (TARGET CALIBRATION VALUE)                          |    |
| FOH DBG_TEST – FACTORY USE ONLY                                  |    |
| F1H – FFH – Reserved                                             |    |
|                                                                  |    |



# **13. APPLICATION CIRCUITS**

For more information please see Application note QFAN004 at http://www.quickfiltertech.com/html/app\_notes.php

### 13.1 AC Coupled, Single-ended





| AC-coupled, singled-ended |               |             |  |  |  |
|---------------------------|---------------|-------------|--|--|--|
| Input level               | R1 - R8 value | PGA setting |  |  |  |
| 1V ptp                    | 0k            | x2          |  |  |  |
| 3.3V ptp                  | 6.5k          | x1          |  |  |  |
| 5V ptp                    | 15k           | x1          |  |  |  |
| 10V ptp                   | 40k           | x1          |  |  |  |







Figure 15. Application Circuit – Single-ended, dc coupled

| Table 21. | Example resistor values for dc-coupled, sin | gle-ended |
|-----------|---------------------------------------------|-----------|
|           | DC-coupled singled-ended                    |           |

| DC-coupled, singled-ended |             |             |  |  |  |  |
|---------------------------|-------------|-------------|--|--|--|--|
| Input level               | R1-R8 value | PGA setting |  |  |  |  |
| 0 – 1V                    | 0 – 1V 18k  |             |  |  |  |  |
| 0 - 3.3V                  | 23k         | x1          |  |  |  |  |
| 0-5V                      | 40k         | x1          |  |  |  |  |
| 0 – 10V 90k               |             | x1          |  |  |  |  |



#### 13.3 AC coupled, Differential





| AC-coupled, differential |             |             |  |  |
|--------------------------|-------------|-------------|--|--|
| Input level              | R1-R8 value | PGA setting |  |  |
| 1V ptp                   | 0k          | x2          |  |  |
| 3.3V ptp                 | 23k         | x2          |  |  |
| 5V ptp                   | 40k         | x2          |  |  |
| 10V ptp                  | 90k         | x2          |  |  |

Table 22. Example resistor values for ac-coupled, differential





# 13.4 DC coupled, Differential



### Figure 17. Application Circuit – Differential, dc coupled

| DC-coupled, differential |             |             |  |  |
|--------------------------|-------------|-------------|--|--|
| Input Level              | R1-R8 Value | PGA setting |  |  |
| -0.25V +0.25V            | 10K         | x8          |  |  |
| -0.5 to +0.5V            | 10K         | x4          |  |  |
| -1V to 1V                | 10K         | x2          |  |  |
| -2V to 2V                | 10K         | x1          |  |  |
| -3V to 3V                | 20K         | x1          |  |  |
| -3.3V to 3.3V            | 23K         | x1          |  |  |
| -5V to 5V                | 40K         | x1          |  |  |
| -10V to 10V              | 90K         | x1          |  |  |
| -12V to 12V              | 110K        | x1          |  |  |
| -15V to 15V              | 140K        | x1          |  |  |
| -20V to 20V              | 190K        | x1          |  |  |
| -24V to 24V              | 230K        | x1          |  |  |
| -28V to 28V              | 270K        | x1          |  |  |

Table 23. Example resistor values for dc-coupled, differential



# **14. PACKAGING INFORMATION**

7x7x1.4mm, LQFP 32, 0.8 mm Pitch POD (JEDEC)



| Dimension | Minimum<br>(mm) | mm      | Maximum<br>(mm) |
|-----------|-----------------|---------|-----------------|
| А         | 1.4             |         | 1.6             |
| A1        | 0.05            |         | 0.15            |
| A2        | 1.35            |         | 1.45            |
| b         | 0.3             |         | 0.45            |
| b1        | 0.3             |         | 0.4             |
| С         | 0.09            |         | 0.2             |
| c1        | 0.09            |         | 0.178           |
| D         |                 | 9 BSC   |                 |
| D1        |                 | 7 BSC   |                 |
| е         |                 | 0.8 BSC |                 |
| Е         |                 | 9 BSC   |                 |
| E1        |                 | 7BSC    |                 |
| L         | 0.5             |         | 0.7             |
| L1        |                 | 1 REF   |                 |
| R         | 0.15            |         | 0.25            |
| S         |                 | 0.2 REF |                 |
| θ         | 1°              |         | 5°              |
| θ1        |                 | 12° REF |                 |





#### Notes:

- 1. Dimensions are in millimeters.
- 2. Interpret dimensions and tolerance per ASME Y14.5M-1994
- 3. Datum Plane H is located at bottom of lead and is coincident with the lead where the lead exits the plastic body at the bottom of the parting line.
- 4. Datum T, U, and Z to be determined at Datum Plane H.
- 5. Dimensions D and E to be determined at seating Plane Y.
- Dimensions D1 and E1 do not include mold protrusion. Allowable protrusion is 0.25 mm per side. Dimensions D1 and E1 do include mold mismatch and are determined at datum plane H.
- Dimension b does not include Dam Bar protrusion. Dam Bar protrusion shall not cause the b dimension to exceed 0.533 mm.
- 8. Minimum solder plate thickness shall be 0.0076 mm.
- 9. Exact shape of each corner may vary from depiction.



# **List of Figures**

| FIGURE 1. FUNCTIONAL BLOCK DIAGRAM                        |    |
|-----------------------------------------------------------|----|
| FIGURE 2. MEMORY MAP                                      | 12 |
| FIGURE 3. POWER UP / RESET SEQUENCE                       | 14 |
| FIGURE 4. EXTENDED INITIALIZATION                         | 15 |
| FIGURE 5. QF4A412 INPUT SCHEMATIC                         | 18 |
| FIGURE 6. MAXIMUM TAPS VS SAMPLE RATE                     | 23 |
| FIGURE 7. SYSTEM CLOCKS BLOCK DIAGRAM                     |    |
| FIGURE 8. CONFIGURE MODE FORMAT                           | 25 |
| Figure 9. Configure Mode Timing, Read and Write           | 26 |
| FIGURE 10. CONFIGURE MODE TIMING – MULTIPLE READ/WRITE    | 26 |
| FIGURE 11. RUN MODE FORMAT                                | 27 |
| FIGURE 12. RUN MODE TIMING, READ AND WRITE                | 29 |
| FIGURE 13. COMPARISON OF CONFIGURE AND RUN MODE TIMING    | 30 |
| FIGURE 14. APPLICATION CIRCUIT – SINGLE-ENDED, AC COUPLED |    |
| FIGURE 15. APPLICATION CIRCUIT – SINGLE-ENDED, DC COUPLED | 62 |
| FIGURE 16. APPLICATION CIRCUIT – DIFFERENTIAL, AC COUPLED | 63 |
| FIGURE 17. APPLICATION CIRCUIT – DIFFERENTIAL, DC COUPLED | 64 |

# List of Tables

| TABLE 1. EXAMPLE SAMPLING RATES AND ENOB                                      | 19 |
|-------------------------------------------------------------------------------|----|
| TABLE 2. MAXIMUM ANALOG INPUT FREQUENCY @40MHz SPI BUS CLOCK                  | 20 |
| TABLE 3. CHANNEL 1 - FIR FILTER ADDRESS INFORMATION                           |    |
| TABLE 4. CHANNEL 2 - FIR FILTER ADDRESS INFORMATION                           |    |
| TABLE 5. CHANNEL 3 - FIR FILTER ADDRESS INFORMATION                           |    |
| TABLE 6. CHANNEL 4 - FIR FILTER ADDRESS INFORMATION                           |    |
| TABLE 7. CONFIGURE MODE, REGISTER ADDRESS DECODING                            |    |
| TABLE 8. CONFIGURE MODE, REGISTER DATA                                        | 25 |
| TABLE 9. RUN MODE, CONTROL ADDRESS FOR COMMAND WRITES,                        |    |
| TABLE 10. RUN MODE, CONTROL REGISTER DATA FORMAT                              | 27 |
| TABLE 11. RUN MODE, OUTPUT DATA STRUCTURE                                     | 27 |
| TABLE 12. OUTPUT DATA, SECOND LSB                                             |    |
| TABLE 13. OUTPUT DATA, MSB                                                    |    |
| TABLE 14. EEPROM MEMORY MAP                                                   |    |
| TABLE 15. T.E.D.S. (TRANSDUCER ELECTRONIC DATA SHEET, BASIC TEMPLATE)         |    |
| TABLE 16. CONTROL REGISTER MAP                                                |    |
| TABLE 17. CONTROL REGISTER LISTING (HIGH-LEVEL, EEPROM STARTUP, RUN & STATUS) |    |
| TABLE 17. CONTROL REGISTER LISTING (GLOBAL CONFIGURATION)                     |    |
| TABLE 18. CONTROL REGISTER LISTING (GLOBAL MAINTENANCE 1)                     |    |
| TABLE 19. CHANNEL-SPECIFIC REGISTER MAP                                       | 44 |
| TABLE 21. CONTROL REGISTER LISTING (GLOBAL MAINTENANCE 2)                     | 53 |
| TABLE 20. EXAMPLE RESISTOR VALUES FOR AC-COUPLED, SINGLE-ENDED                | 61 |
| TABLE 21. EXAMPLE RESISTOR VALUES FOR DC-COUPLED, SINGLE-ENDED                |    |
| TABLE 22. EXAMPLE RESISTOR VALUES FOR AC-COUPLED, DIFFERENTIAL                |    |
| TABLE 23. EXAMPLE RESISTOR VALUES FOR DC-COUPLED, DIFFERENTIAL                | 64 |



The contents of this document are provided in connection with Quickfilter Technologies, Inc. products. Quickfilter makes no representations or warranties with respect to the accuracy or completeness of the contents of this publication and reserves the right to make changes to specifications and product descriptions at any time without notice. No license, whether express, implied, arising by estoppel or otherwise, to any intellectual property rights is granted by this publication. Except as set forth in Quickfilter's Standard Terms and Conditions of Sale, Quickfilter assumes no liability whatsoever, and disclaims any express or implied warranty, relating to its products including, but not limited to, the implied warranty of merchantability, fitness for a particular purpose, or infringement of any intellectual property right. Quickfilter's products are not designed, intended, authorized or warranted for use as components in systems intended for surgical implant into the body, or in other

Quickfilter's products are not designed, intended, authorized or warranted for use as components in systems intended for surgical implant into the body, or in other applications intended to support or sustain life, or in any other application in which the failure of Quickfilter's product could create a situation where personal injury, death, or severe property or environmental damage may occur. Quickfilter reserves the right to discontinue or make changes to its products at any time without notice.

© 2008 Quickfilter Technologies, Inc. All rights reserved.

1024 S. Greenville Ave Suite 100 Allen, TX 75002-3344

Telephone: (214) 547-0460 Fax: (214) 547-0481

For inquiries, please contact Quickfilter at the above address,

Or visit our website: <u>http://www.quickfiltertech.com</u>

Quickfilter, the Quickfilter logo and "Programmable Signal Converter", and combinations thereof, are trademarks of Quickfilter Technologies, Inc. Other product names used in this publication are for identification purposes only and may be trademarks of their respective companies.