The Embedded I/O Company



# **TPMC851**

# Multifunction I/O (16 bit ADC/DAC, TTL I/O, Counter)

Version 2.0

## **User Manual**

Issue 2.0.0 December 2022

 TEWS TECHNOLOGIES GmbH

 Am Bahnhof 7
 25469 Halstenbek, Germany

 Phone: +49 (0) 4101 4058 0
 Fax: +49 (0) 4101 4058 19

 e-mail: info@tews.com
 www.tews.com



#### **TPMC851-10R** This document contains information, which is proprietary Multifunction I/O to TEWS TECHNOLOGIES GmbH. Any reproduction without written permission is forbidden. (16 bit ADC/DAC, TTL I/O, Counter) TEWS TECHNOLOGIES GmbH has made any effort to ensure that this manual is accurate and complete. However TEWS TECHNOLOGIES GmbH reserves the right to change the product described in this document at any time without notice. TEWS TECHNOLOGIES GmbH is not liable for any damage arising out of the application or use of the device described herein. **Style Conventions** Hexadecimal characters are specified with prefix 0x, i.e. 0x029E (that means hexadecimal value 029E). For signals on hardware products, an ,Active Low' is represented by the signal name with # following, i.e. IP\_RESET#. Access terms are described as: W Write Only R Read Only R/W Read/Write R/C Read/Clear R/S Read/Set ©2014-2022 by TEWS TECHNOLOGIES GmbH All trademarks mentioned are property of their respective owners.



| Issue | Description                                                                                         | Date           |
|-------|-----------------------------------------------------------------------------------------------------|----------------|
| 1.0   | Initial Issue                                                                                       | May 2004       |
| 1.1   | Added ADC power-up note                                                                             | January 2005   |
| 1.2   | Correction Interrupt Control Register ICR, Summarization of Important<br>Notes                      | February 2006  |
| 1.3   | New address TEWS LLC                                                                                | September 2006 |
| 1.4   | Changed PCI9030 Local Configuration<br>Clarified Sequencer Start / Stop Control in ADCSEQCONT       | September 2006 |
| 1.5   | Added note to ADC Control Register                                                                  | October 2006   |
| 1.0.6 | New notation for HW Engineering Documentation Releases                                              | March 2009     |
| 1.0.7 | Corrected DAC Data Register Reset Value to 0x0000                                                   | January 2010   |
| 1.0.8 | General Revision                                                                                    | August 2014    |
| 1.0.9 | "PCI Base Address 2 for Local Address Space 0" initial value<br>corrected in Table "PCI9030 Header" | September 2014 |
| 2.0.0 | User Manual Update for TPMC851 V2.0.                                                                | September 2022 |



## **Table of Contents**

| 1 | PR  | ODUCT DESCRIPTION                                                                                                                                             | . 8 |
|---|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| 2 | ΤE  | CHNICAL SPECIFICATION                                                                                                                                         | 10  |
| 3 | НΔ  | NDLING AND OPERATION INSTRUCTIONS                                                                                                                             | 12  |
| • |     | ESD Protection                                                                                                                                                |     |
| 4 | -   | DRESSING                                                                                                                                                      |     |
| 4 |     |                                                                                                                                                               | -   |
|   | 4.1 | PCI Configuration Space                                                                                                                                       |     |
|   |     | <ul><li>4.1.1 PCI Address Space Overview</li><li>4.1.2 Serial EEPROM Memory</li></ul>                                                                         |     |
|   | 4.2 | PCI Controller Register Space                                                                                                                                 |     |
|   |     | 4.2.1 PCI Controller Configuration Register Map                                                                                                               |     |
|   | 4.3 | Local Register Address Space                                                                                                                                  |     |
|   |     | 4.3.1 Analog Input Registers                                                                                                                                  |     |
|   |     | 4.3.1.1 ADC Control Register ADCCONT (Offset 0x0000)                                                                                                          |     |
|   |     | 4.3.1.2 ADC Data Register ADCDATA (Offset 0x0004)                                                                                                             | 19  |
|   |     | <ul> <li>4.3.1.3 ADC Status Register ADCSTAT (Offset 0x0008)</li> <li>4.3.1.4 ADC Conversion Start Register ADCCONV (Offset 0x000C)</li> </ul>                | 20  |
|   |     | 4.3.1.5 ADC Sequencer Control Register ADCSEQCONT (Offset 0x000C)                                                                                             | 21  |
|   |     | 4.3.1.6 ADC Sequencer Status Register ADCSEQSTAT (Offset 0x0014)                                                                                              |     |
|   |     | 4.3.1.7 ADC Sequencer Timer Register ADCSEQTIME (Offset 0x0018)                                                                                               |     |
|   |     | 4.3.1.8 ADC Sequencer Instruction RAM (Offset 0x0020 - Offset 0x009C)                                                                                         |     |
|   |     | 4.3.2 Analog Output Registers                                                                                                                                 |     |
|   |     | 4.3.2.1 DAC Control Register DACCONT (Offset 0x00C0)                                                                                                          |     |
|   |     | <ul> <li>4.3.2.2 DAC Sequencer Status Register DACSEQSTAT (Offset 0x00C4)</li> <li>4.3.2.3 DAC Sequencer Timer Register DACSEQTIME (Offset 0x00C8)</li> </ul> |     |
|   |     | 4.3.2.4 DAC Data Register DACDATA 1-8 (Offset 0x00D0 - Offset 0x00EC)                                                                                         |     |
|   |     | 4.3.3 Digital I/O Registers                                                                                                                                   |     |
|   |     | 4.3.3.1 Line Direction Register LINEDIR (Offset 0x0100)                                                                                                       |     |
|   |     | 4.3.3.2 Line Debounce Enable Register LINEDEB (Offset 0x0104)                                                                                                 | 31  |
|   |     | 4.3.3.3 Line Debounce Time Register LINEDBT (Offset 0x0108)                                                                                                   |     |
|   |     | <ul><li>4.3.3.4 Line Input Register LINEIN (Offset 0x010C)</li><li>4.3.3.5 Line Output Register LINEOUT (Offset 0x0110)</li></ul>                             |     |
|   |     | 4.3.3.6 Line Interrupt Enable Register LINEIEN (Offset 0x0110)                                                                                                |     |
|   |     | 4.3.3.7 Line Interrupt Status Register LINEIST (Offset 0x0118)                                                                                                |     |
|   |     | 4.3.4 Counter Registers                                                                                                                                       |     |
|   |     | 4.3.4.1 Counter Preload Register CNTPRL (Offset 0x0120)                                                                                                       |     |
|   |     | 4.3.4.2 Counter Compare Register CNTCMP (Offset 0x0124)                                                                                                       |     |
|   |     | <ul> <li>4.3.4.3 Counter Data Register CNTDATA (Offset 0x0128)</li> <li>4.3.4.4 Counter Control Register CNTCONT (Offset 0x012C)</li> </ul>                   |     |
|   |     | <ul> <li>4.3.4.4 Counter Control Register CNTCONT (Offset 0x012C)</li> <li>4.3.4.5 Counter Status Register CNTSTAT (Offset 0x0130)</li> </ul>                 |     |
|   |     | 4.3.4.6 Counter Command Register CNTCOM (Offset 0x0134)                                                                                                       |     |
|   |     | 4.3.5 Interrupt Control Register ICR (Offset 0x0140)                                                                                                          | 41  |
|   | 4.4 | ADC Sequencer Data RAM                                                                                                                                        |     |
|   | 4.5 | ADC/DAC Calibration Data ROM                                                                                                                                  | 42  |
| 5 | CC  | ONFIGURATION HINTS                                                                                                                                            | 44  |
|   | 5.1 | Local Software Reset                                                                                                                                          | 44  |
| 6 | PR  | OGRAMMING HINTS                                                                                                                                               | 45  |
|   | 6.1 | Data Correction                                                                                                                                               | 45  |
|   |     | 6.1.1 ADC Correction Formula                                                                                                                                  |     |
|   |     | 6.1.2 DAC Correction Formula                                                                                                                                  |     |
|   | 6.2 | ADC Operating Modes                                                                                                                                           | 46  |



|     | 6.2.1 Man          | ual Mode                                          |    |
|-----|--------------------|---------------------------------------------------|----|
|     | 6.2.2 Seq          | uencer Mode                                       | 47 |
|     | 6.2.2.1            | Sequencer Errors                                  |    |
|     |                    | lication Examples                                 |    |
|     |                    | Fastest Conversion of an arbitrary Single Channel |    |
|     | 6.2.3.2            | Fastest Conversion of a specific Single Channel   |    |
|     | 6.2.3.3            | Periodic Conversion of multiple Channels          | 51 |
|     | 6.2.3.4            |                                                   |    |
| 6.3 | DAC Opera          | ting Modes                                        | 53 |
|     | 6.3.1 Imm          | ediate Update                                     |    |
|     | 6.3.2 Sim          | ultaneous Update                                  | 53 |
| 6.4 | <b>Digital TTL</b> | I/O                                               | 54 |
| 6.5 | Counter Op         | perating Modes                                    | 55 |
|     | 6.5.1 Inpu         | It Modes                                          |    |
|     | 6.5.1.1            | Timer Mode                                        |    |
|     | 6.5.1.2            | Direction Count                                   |    |
|     | 6.5.1.3            | Up/Down Count                                     |    |
|     | 6.5.1.4            | Quadrature Count                                  |    |
|     | 6.5.2 Cou          | nt Modes                                          |    |
|     | 6.5.2.1            | Divide-by-N                                       |    |
|     | 6.5.2.2            | Single Cycle                                      | 56 |
|     | 6.5.3 Con          | trol Modes                                        |    |
|     | 6.5.3.1            | No Control Mode                                   | 57 |
|     | 6.5.3.2            | Load Mode                                         |    |
|     | 6.5.3.3            | Latch Mode                                        |    |
|     | 6.5.3.4            | Gate Mode                                         | 57 |
|     | 6.5.3.5            | Reset Mode                                        |    |
|     | 6.5.4 Con          | figuration Examples                               | 57 |
|     |                    | Watchdog Timer                                    | 57 |
|     | 6.5.4.2            | Event Counting                                    |    |
|     | 6.5.4.3            | Input Pulse Width Measurement                     |    |
|     | 6.5.4.4            | Mechanical System Positioning                     |    |
| 6.6 |                    |                                                   |    |
|     | 6.6.1 Inter        | rrupt Sources                                     | 59 |
| INS | STALLATI           | ON                                                | 60 |
| 7.1 | ADC Input          | Wiring                                            | 60 |
|     |                    | It Wiring                                         |    |
|     | •                  | erface                                            |    |
|     |                    | MENT – I/O CONNECTOR                              |    |
|     |                    | NOTES                                             |    |
|     |                    |                                                   |    |
|     | -                  | nversions after Power-up                          |    |
| 9.Z | Open Multi         | plexer Inputs                                     |    |

7

8 9



# List of Figures

| FIGURE 1-1 : BLOCK DIAGRAM                                           | 9  |
|----------------------------------------------------------------------|----|
| FIGURE 6-1 : FLOW: FASTEST CONVERSION OF AN ARBITRARY SINGLE CHANNEL | 49 |
| FIGURE 6-2 : FLOW: FASTEST CONVERSION OF A SPECIFIC SINGLE CHANNEL   | 50 |
| FIGURE 6-3 : FLOW: PERIODIC CONVERSION OF MULTIPLE CHANNELS          | 51 |
| FIGURE 6-4 : FLOW: CONTINUOUS CONVERSION OF MULTIPLE CHANNELS        | 52 |
| FIGURE 6-5: QUADRATURE SIGNALS                                       | 56 |
| FIGURE 7-1 : ADC INPUT WIRING                                        | 60 |
| FIGURE 7-2 : DAC OUTPUT WIRING                                       | 61 |
| FIGURE 7-3 : TTL I/O INTERFACE                                       | 61 |

## List of Tables

| TABLE 2-1 : TECHNICAL SPECIFICATION                          | 11 |
|--------------------------------------------------------------|----|
| TABLE 4-1 : PCI CONTROLLER HEADER                            | 13 |
| TABLE 4-2: PCI ADDRESS SPACE OVERVIEW                        | 13 |
| TABLE 4-3 : CONFIGURATION EEPROM TPMC851-10R                 | 14 |
| TABLE 4-4 : PCI CONTROLLER CONFIGURATION REGISTER MAP        | 15 |
| TABLE 4-5 : REGISTER ADDRESS SPACE                           | 16 |
| TABLE 4-6 : ADC CONTROL REGISTER                             | 18 |
| TABLE 4-7 : ADC DATA REGISTER                                |    |
| TABLE 4-8 : ADC DATA CODING                                  |    |
| TABLE 4-9 : ADC STATUS REGISTER                              | 20 |
| TABLE 4-10 : ADC SEQUENCER CONTROL REGISTER                  | 22 |
| TABLE 4-11 : ADC SEQUENCER STATUS REGISTER                   | 23 |
| TABLE 4-12: ERROR FLAG IRQ GENERATION                        |    |
| TABLE 4-13: ADC SEQUENCER TIMER REGISTER                     | 24 |
| TABLE 4-14: ADC SEQUENCER INSTRUCTION RAM REGISTER           | 25 |
| TABLE 4-15: ADC SEQUENCER INSTRUCTION RAM REGISTER POSITIONS | 26 |
| TABLE 4-16: DAC CONTROL REGISTER                             | 27 |
| TABLE 4-17: DAC SEQUENCER STATUS REGISTER                    | 28 |
| TABLE 4-18: DAC SEQUENCER TIMER REGISTER                     | 29 |
| TABLE 4-19: DAC DATA REGISTER                                |    |
| TABLE 4-20: DAC DATA CODING                                  |    |
| TABLE 4-21: LINE DIRECTION REGISTER                          | 30 |
| TABLE 4-22: LINE DEBOUNCE ENABLE REGISTER                    | 31 |
| TABLE 4-23: LINE DEBOUNCE TIME REGISTER                      |    |
| TABLE 4-24: LINE INPUT REGISTER                              | -  |
| TABLE 4-25: LINE OUTPUT REGISTER                             | 33 |
| TABLE 4-26: LINE INTERRUPT ENABLE REGISTER                   | -  |
| TABLE 4-27: LINE INTERRUPT STATUS REGISTER                   | 35 |
| TABLE 4-28: COUNTER PRELOAD REGISTER                         | 36 |



| TABLE 4-29: COUNTER COMPARE REGISTER                       |    |
|------------------------------------------------------------|----|
| TABLE 4-30: COUNTER DATA REGISTER                          |    |
| TABLE 4-31: COUNTER CONTROL REGISTER                       |    |
| TABLE 4-32: COUNTER STATUS REGISTER                        |    |
| TABLE 4-33: COUNTER COMMAND REGISTER                       | 40 |
| TABLE 4-34: INTERRUPT CONTROL REGISTER                     | 41 |
| TABLE 4-35: ADC SEQUENCER DATA RAM SPACE ADDRESS MAP       |    |
| TABLE 4-36: ADC/DAC CALIBRATION ROM DATA SPACE ADDRESS MAP | 43 |
| TABLE 6-1 : SEQUENCER ERRORS                               | 48 |
| TABLE 6-2 : DAC LOAD MODES                                 | 53 |
| TABLE 6-3 : INPUT MODES                                    | 55 |
| TABLE 6-4 : CLOCK PRESCALER                                |    |
| TABLE 6-5 : COUNT DIRECTIONS                               | 55 |
| TABLE 6-6 : INPUT CONTROL MODE EVENTS                      | 57 |
| TABLE 6-7: GATE MODE                                       | 57 |
| TABLE 6-8 : INTERRUPT SOURCES                              | 59 |
| TABLE 8-1 : PIN ASSIGNMENT I/O CONNECTOR                   | 62 |



# 1 **Product Description**

The TPMC851 combines 32 single ended / 16 differential channels of 16 bit multiplexed analog input, 8 channels of 16 bit analog output, 16 digital I/O lines and a 32 bit multi-purpose counter on a standard single-width PMC module.

A 16 bit ADC converts 32 single-ended or 16 differential multiplexed ADC input channels. The data acquisition and conversion time is up to  $1.25\mu$ s without channel/gain change and up to  $17.25\mu$ s with channel/gain change (ADC throughput rate up to 250ksps). The input multiplexer of the A/D circuit offers analog overvoltage protection of up to 70Vpp. A programmable gain amplifier allows gains of 1, 2, 4 or 8 resulting in input voltage ranges of  $\pm 10V$ ,  $\pm 5V$ ,  $\pm 2.5V$  or  $\pm 1.25V$ .

The ADC part of the TPMC851 can operate in Manual Mode or Sequencer Mode:

Manual Mode

In Manual Mode the multiplexer, programmable gain amplifier and the converter are fully controlled by the user. A conversion for a selected channel / gain can be started automatically after the settling time has elapsed, or manually by the user.

• Sequencer Mode

In Sequencer Mode each of the A/D channels can be independently enabled and configured for the sequencer. The sequencer can run continuously, at specific time intervals, or it may be triggered by an external event. Conversion data is stored in a data RAM.

The 8 analog output channels are realized by eight 16 bit digital to analog converters (DACs). The conversion time is 10  $\mu$ s. An operational amplifier drives the full-scale range of ±10V and is capable to drive high capacitive loads. Similar to the analog inputs a sequencer can control the analog outputs. Following operation modes are available:

- Immediate Update: Updates the DAC output immediately when new data is written to the DAC channel.
- Simultaneous Update: DAC data is buffered and all DAC outputs are updated simultaneously on a trigger event:
  - o Manual Update: Updates all DAC outputs on a manual event (register write)
  - Trigger Update: Updates all DAC outputs on a external event
  - Sequencer Update: Updates all DAC outputs after the sequencer timer has elapsed

Each TPMC851 is factory calibrated. The calibration data is stored in an EEPROM unique to each TPMC851.

The 16 digital TTL tri-state I/O lines with  $4.7k\Omega$  pull up resistors are ESD protected. All 16 lines can be individually programmed as input or output, and can generate an interrupt on negative and positive transitions. Each input has an electronic debounce circuit to prevent short spikes on the input lines to cause an interrupt. The digital inputs can supply the external signals for the ADC and DAC sequencer and the 32 bit counter.



Additionally the TPMC851 offers a 32 bit multi-purpose counter. The counter includes a 32 bit preload register and a 32 bit compare register. The 32 bit counter can be fed with an internal clock or with an external signal supplied by the digital inputs. The 4 counter input modes determine the interpretation of the input signals. Additionally 3 count modes, which describe the behavior of the counter, and 4 control modes are available.

- Counter input modes:
  - o Internal clock with prescaler
  - o Up/Down count: first counter input counts up, second input counts down
  - o Direction count: first counter input counts, second input sets count direction
  - Quadrature count with 1x, 2x or 4x resolution multiplier
- Count modes:
  - o Cycling Counter: normal wrap-around count mode
  - Divide-by-N: counter is reloaded from the preload register upon a borrow or carry
  - Single Cycle: counter stops upon a borrow or carry
- Control Modes:
  - o Load on Control: counter is reloaded from the preload register
  - o Latch on Control: counter value is latched
  - Gate on Control: counter input is gated
  - Reset on Control: counter is reset



Figure 1-1 : Block Diagram



# 2 **Technical Specification**

| Mechanical InterfacePCI Mezzanine Card (PMC) Interface<br>Single SizeElectrical InterfacePCI Rev. 3.0 compatible<br>3.3V and 5V PCI Signaling VoltageOn Board DevicesPCI Target ChipTEWS PCI Interface FPGAADCAD7663DACDA7643Analog Input32 single-ended or 16 differential channelsInput Gain AmplifierProgrammable for gain 1, 2, 4 and 8Input Gain AmplifierProgrammable for gain 1, 2, 4 and 8Input Voltage Range±10V for gain = 1<br>±2.5V for gain = 2<br>±2.5V for gain = 8Input Voltage Protection70VppCalibration DataCalibration data for gain and offset correction in ID PROMResolution16 bit with no missing codesConversion Time1.25V soft are radibrationLinearity±2 LSB @ 25°C after calibrationAnalog Output8 analog output channelsMumber of Analog Outputs8 analog output channelsConversion Time1.125V or gain = 4<br>±1.25V or gain = 4<br>±1.25V for gain = 8Input Voltage Protection70VppCalibration DataCalibration data for gain and offset correction in ID PROMResolution16 bit with no missing codesConversion Time1.25V soft after calibrationLinearity±2 LSB @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibrationCalibration DataCalibration data for gain and offset correction in ID PROMResolution16 bitConversion Time10µs max.Accuracy±1 LSB @ 25°C after calibrationLinearity                                                                                                                                                                                                                                                                                            | PMC Interface                |                                                            |  |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|------------------------------------------------------------|--|--|--|
| Electrical InterfacePCI Rev. 3.0 compatible<br>33 MHz / 32 bit PCI<br>3.3V and 5V PCI Signaling VoltageOn Board DevicesPCI Target ChipTEWS PCI Interface FPGAADCAD7663DACDAC7644Analog Input32 single-ended or 16 differential channelsInput Gain AmplifierProgrammable for gain 1, 2, 4 and 8Input Voltage Range±10V for gain = 1<br>±5V for gain = 2<br>±2.5V for gain = 2<br>±2.5V for gain = 8Input Voltage Protection70VppCalibration DataCalibration data for gain and offset correction in ID PROMResolution16 bit with no missing codesConversion Time1.25µs without channel/gain change (ADC throughput rate up to 250ksps)<br>17.25µs with channel/gain change<br>16µs / channel in sequencer modeAccuracy±2 LSB @ 25°C after calibrationLinearity±3 LSBAnalog Output8 analog output channelsOutput Voltage Range<br>10µ × 01438£10VCalibration DataCalibration data for gain and offset correction in ID PROMResolution16 bit with no missing codesConversion Time1.25µs without channel/gain change<br>16µs / channel in sequencer modeAccuracy±1 LSB (25°C after calibrationLinearity4.1 LSB (25°C after calibrationAnalog Output8 analog output channelsOutput Voltage Range<br>Resolution100VCalibration DataCalibration data for gain and offset correction in ID PROMCalibration DataCalibration data for gain and offset correction in ID PROMCancersy±1 LSB @ 25°C after calib                                                                                                                                                                                                                        | Mechanical Interface         | PCI Mezzanine Card (PMC) Interface                         |  |  |  |
| 33 MHz / 32 bit PCI<br>3.3V and 5V PCI Signaling VoltageOn Board DevicesPCI Target ChipTEWS PCI Interface FPGAADCAD7663DACDAC7644Analog Input32 single-ended or 16 differential channelsInput Gain AmplifierProgrammable for gain 1, 2, 4 and 8Input Voltage Range±10V for gain = 1<br>±2.5V for gain = 2<br>±2.5V for gain = 4<br>±1.25V for gain = 4<br>±1.25V for gain = 8Input Voltage Protection70VppCalibration DataCalibration data for gain and offset correction in ID PROMResolution16 bit with no missing codesConversion Time1.25µs with channel/gain change (ADC throughput rate up to 250ksps)<br>17.25µs with channel/gain change<br>16µs / channel in sequencer modeAccuracy±2 LSB @ 25°C after calibrationLinearitya Lago output channelsOutput Voltage Range110VCalibration DataCalibration data for gain and offset correction in ID PROMResolution1.25µs without channel/gain change (ADC throughput rate up to 250ksps)<br>17.25µs with channel/gain change<br>16µs / channel in sequencer modeAccuracy±2 LSB @ 25°C after calibrationLinearitya LSBAnalog OutputB analog output channelsOutput Voltage Range<br>esolution10VCalibration DataCalibration data for gain and offset correction in ID PROMResolutionLase @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibration<                                                                                                                                                                                                                             |                              | Single Size                                                |  |  |  |
| Sava and SV PCI Signaling VoltageOn Board DevicesPCI Target ChipTEWS PCI Interface FPGAADCAD7663DACBO7664Analog InputSavard SV PCI Signaling VoltageNumber of Analog Inputs32 single-ended or 16 differential channelsInput Gain AmplifierProgrammable for gain 1, 2, 4 and 8Input Voltage Range±10V for gain = 1<br>±5V for gain = 2<br>±2.5V for gain = 2<br>±2.5V for gain = 8Input Overvoltage Protection70VppCalibration DataCalibration data for gain and offset correction in ID PROMResolution16 bit with no missing codesConversion Time1.25µs without channel/gain change (ADC throughput rate up to 250ksps)<br>17.25µs withotu channel/gain change<br>16µs / channel in sequencer modeAccuracy± 2LSB @ 25°C after calibrationLinearity± 2LSB @ 25°C after calibrationAnalog Output8 analog output channelsOutput Voltage Range± 10VCalibration Data6 analog output channelsAccuracy± 1.SB @ 25°C after calibrationLinearity± 1.SB @ 25°C after calibrationChips / channel10 PROMGaination Data6 analog output channelsConversion Time10 VOttigate Range± 10 VCalibration Data6 analog output channelsAccuracy± 1.SB @ 25°C after calibrationAccuracy± 1.SB @ 25°C after calibrationChange Calibration Data6 bitConversion Time10 µs max.Accuracy± 1.SB @ 25°C after calibration <th>Electrical Interface</th> <th>PCI Rev. 3.0 compatible</th>                                                                                                                                                                                                                                                               | Electrical Interface         | PCI Rev. 3.0 compatible                                    |  |  |  |
| On Board Devices         PCI Target Chip       TEWS PCI Interface FPGA         ADC       AD7663         DAC       DAC7644         Analog Input       32 single-ended or 16 differential channels         Number of Analog Inputs       32 single-ended or 16 differential channels         Input Gain Amplifier       Programmable for gain 1, 2, 4 and 8         Input Voltage Range       ±10V for gain = 1         ±5V for gain = 2       ±2.5V for gain = 4         ±1.25V for gain = 8       1         Input Overvoltage Protection       70Vpp         Calibration Data       Calibration data for gain and offset correction in ID PROM         Resolution       16 bit with no missing codes         Conversion Time       1.25µs without channel/gain change (ADC throughput rate up to 250ksps) 17.25µs with channel/gain change (ADC throughput rate up to 250ksps) 17.25µs with channel/gain change (ADC throughput rate up to 250ksps) 17.25µs with channel/gain change (ADC throughput rate up to 250ksps) 17.25µs with channel/gain change (ADC throughput rate up to 250ksps) 17.25µs with channel/gain change (ADC throughput rate up to 250ksps) 17.25µs with channel/gain change (ADC throughput rate up to 250ksps) 17.25µs with channel/gain change (ADC throughput rate up to 250ksps) 17.25µs with channel/gain change (ADC throughput rate up to 250ksps) 17.25µs with channel/gain change (ADC throughput rate up to 250ksps) 17.25µs with channel/gain change (ADC throughput rate up to 250ksps) 17.25µs with channel/gain change (ADC throughput rate up to 250ksps) 17.25µs with channel/ga |                              |                                                            |  |  |  |
| PCI Target ChipTEWS PCI Interface FPGAADCAD7663DACDAC7644Analog Input32 single-ended or 16 differential channelsInput Gain AmplifierProgrammable for gain 1, 2, 4 and 8Input Gain AmplifierProgrammable for gain 1, 2, 4 and 8Input Voltage Range±10V for gain = 1<br>±5V for gain = 2<br>±2.5V for gain = 4<br>±1.25V for gain = 8Input Overvoltage Protection70VppCalibration DataCalibration data for gain and offset correction in ID PROMResolution16 bit with no missing codesConversion Time1.25g with channel/gain change (ADC throughput rate up to 250ksps)<br>17.25g with channel/gain change<br>16µs / channel in sequencer modeAccuracy±2 LSB @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibrationAnalog Output8 analog output channelsOutput Voltage Range±10VCalibration DataCalibration data for gain and offset correction in ID PROMResolution16 bit with no missing codesConversion Time1.25g with channel/gain change<br>16µs / channel in sequencer modeAccuracy±2 LSB @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibrationAnalog Output8 analog output channelsOutput Voltage Range±10VCalibration DataCalibration data for gain and offset correction in ID PROMResolution16 bitConversion Time10µs max.Accuracy±1LSB @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibrationLinearity<                                                                                                                                                                                                                                                                          |                              | 3.3V and 5V PCI Signaling Voltage                          |  |  |  |
| ADCAD7663DACDAC7644Analog Input32 single-ended or 16 differential channelsNumber of Analog Inputs32 single-ended or 16 differential channelsInput Gain AmplifierProgrammable for gain 1, 2, 4 and 8Input Voltage Range±10V for gain = 1<br>±5V for gain = 2<br>±2.5V for gain = 4<br>±1.25V for gain = 8Input Overvoltage Protection70VppCalibration DataCalibration data for gain and offset correction in ID PROMResolution16 bit with no missing codesConversion Time1.25µs without channel/gain change (ADC throughput rate up to 250ksps)<br>17.25µs with channel/gain change<br>16µs / channel in sequencer modeAccuracy±2 LSB @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibrationADC INL/DNL Error±3 LSBAnalog Outputs8 analog output channelsOutput Voltage Range±10VCalibration DataCalibration data for gain and offset correction in ID PROMResolution±1 LSB @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibrationAnalog Output8 analog output channelsOutput Voltage Range±10VCalibration DataCalibration data for gain and offset correction in ID PROMResolution16 bitConversion Time10µs max.Accuracy±1 LSB @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibr                                                                                                                                                                                                                                                                                   |                              |                                                            |  |  |  |
| DACDAC7644Analog Input32 single-ended or 16 differential channelsNumber of Analog Inputs32 single-ended or 16 differential channelsInput Gain AmplifierProgrammable for gain 1, 2, 4 and 8Input Voltage Range±10V for gain = 1<br>±5V for gain = 2<br>±2.5V for gain = 4<br>±1.25V for gain = 8Input Overvoltage Protection70VppCalibration DataCalibration data for gain and offset correction in ID PROMResolution16 bit with no missing codesConversion Time1.25µs without channel/gain change<br>16µs / channel in sequencer modeAccuracy±2 LSB @ 25°C after calibrationAbe go utput8 analog output channelsOutput Voltage Range±10VCalibration Data8 analog output channelsConversion Time8 analog output channelsOutput Voltage Range±10VAccuracy±2 LSB @ 25°C after calibrationLinearity8 analog output channelsOutput Voltage Range±10VCalibration Data6 alibration data for gain and offset correction in ID PROMResolution16 bitConversion Time8 analog output channelsOutput Voltage Range±10VCalibration DataCalibration data for gain and offset correction in ID PROMAccuracy±1 LSB @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibrationAccuracy±1 LSB @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibrationLinearity±2 LSB @ 25                                                                                                                                                                                                                                                                                                            | PCI Target Chip              | TEWS PCI Interface FPGA                                    |  |  |  |
| Analog InputNumber of Analog Inputs32 single-ended or 16 differential channelsInput Gain AmplifierProgrammable for gain 1, 2, 4 and 8Input Voltage Range±10V for gain = 1<br>±5V for gain = 2<br>±2.5V for gain = 4<br>±1.25V for gain = 4<br>±1.25V for gain = 8Input Overvoltage Protection70VppCalibration DataCalibration data for gain and offset correction in ID PROMResolution16 bit with no missing codesConversion Time1.25µ without channel/gain change (ADC throughput rate up to 250ksps)<br>17.25µs with channel/gain change<br>16µs / channel in sequencer modeAccuracy±2 LSB @ 25°C after calibrationLinearity±3 LSBAnalog Output8 analog output channelsNumber of Analog Outputs8 analog output channelsOutput Voltage Range<br>±10V±10VCalibration DataCalibration data for gain and offset correction in ID PROMAccuracy±2 LSB @ 25°C after calibrationLinearity±1 LSBAnalog Output6 bitNumber of Analog Outputs8 analog output channelsOutput Voltage Range<br>esolution±10VCalibration DataCalibration data for gain and offset correction in ID PROMResolution16 bitConversion Time10µs max.Accuracy±1 LSB @ 25°C after calibrationLinearity±2 LSB @ 25                                                                                                                                                                                                                                                                            | ADC                          | AD7663                                                     |  |  |  |
| Number of Analog Inputs32 single-ended or 16 differential channelsInput Gain AmplifierProgrammable for gain 1, 2, 4 and 8Input Voltage Range±10V for gain = 1<br>±5V for gain = 2<br>±2.5V for gain = 4<br>±1.25V for gain = 8Input Overvoltage Protection70VppCalibration DataCalibration data for gain and offset correction in ID PROMResolution16 bit with no missing codesConversion Time1.25µs without channel/gain change (ADC throughput rate up to 250ksps)<br>17.25µs with channel/gain change<br>16µs / channel in sequencer modeAccuracy±2 LSB @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibrationAnalog Output8 analog output channelsOutput Voltage Range±10VCalibration data for gain and offset correction in ID PROMAccuracy±2 LSB @ 25°C after calibrationLinearity±1 LSB @ 25°C after calibrationAnalog Output8 analog output channelsOutput Voltage Range±10VCalibration DataCalibration data for gain and offset correction in ID PROMResolution16 bitConversion Time10µs max.Accuracy±1 LSB @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibrationLinearity<                                                                                                                                                                                                                                                                | DAC                          | DAC7644                                                    |  |  |  |
| Input Gain AmplifierProgrammable for gain 1, 2, 4 and 8Input Voltage Range±10V for gain = 1<br>±5V for gain = 2<br>±2.5V for gain = 4<br>±1.25V for gain = 4<br>±1.25V for gain = 8Input Overvoltage Protection70VppCalibration DataCalibration data for gain and offset correction in ID PROMResolution16 bit with no missing codesConversion Time1.25µs without channel/gain change<br>16µs / channel in sequencer modeAccuracy±2 LSB @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibrationAnalog Output8 analog output channelsOutput Voltage Range±10VCalibration DataCalibration data for gain and offset correction in ID PROMResolution16 bit with no missing codesConversion Time1.25µs with channel/gain change<br>16µs / channel in sequencer modeAccuracy±2 LSB @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibrationAnalog Output8 analog output channelsOutput Voltage Range±10VCalibration DataCalibration data for gain and offset correction in ID PROMResolution16 bitConversion Time10µs max.Accuracy±1 LSB @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibrationDAC INL/DNL Error±1 LSB @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibrationLinearity </th <th>Analog Input</th> <th></th>                                                                                                                                                                                                                                       | Analog Input                 |                                                            |  |  |  |
| Input Voltage Range±10V for gain = 1<br>±5V for gain = 2<br>±2.5V for gain = 4<br>±1.25V for gain = 8Input Overvoltage Protection70VppCalibration DataCalibration data for gain and offset correction in ID PROMResolution16 bit with no missing codesConversion Time1.25µs without channel/gain change (ADC throughput rate up to 250ksps)<br>17.25µs with channel/gain change<br>16µs / channel in sequencer modeAccuracy±2 LSB @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibrationAnalog Output8 analog output channelsOutput Voltage Range±10VCalibration DataCalibration data for gain and offset correction in ID PROMResolution16 bitLinearity±2 LSB @ 25°C after calibrationAccuracy±10VCalibration DataCalibration data for gain and offset correction in ID PROMResolution16 bitOutput Voltage Range±10VCalibration DataCalibration data for gain and offset correction in ID PROMResolution16 bitConversion Time10µs max.Accuracy±1 LSB @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibrationDAC INL/DNL Error±1 LSB @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibrationDAC INL/DNL Error±1/±3 LSB                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Number of Analog Inputs      | 32 single-ended or 16 differential channels                |  |  |  |
| ±5V for gain = 2<br>±2.5V for gain = 4<br>±1.25V for gain = 8Input Overvoltage Protection70VppCalibration DataCalibration data for gain and offset correction in ID PROMResolution16 bit with no missing codesConversion Time1.25µs without channel/gain change (ADC throughput rate up to 250ksps)<br>17.25µs with channel/gain change<br>16µs / channel in sequencer modeAccuracy±2 LSB @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibrationAnalog Output8 analog output channelsOutput Voltage Range±10VCalibration DataCalibration data for gain and offset correction in ID PROMResolution16 bitCarcacy±10VCalibration DataCalibration data for gain and offset correction in ID PROMResolution16 bitCurversion Time±10VCalibration DataCalibration data for gain and offset correction in ID PROMResolution16 bitConversion Time10µs max.Accuracy±1 LSB @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibrationAccuracy±1 LSB @ 25°C after calibrationData10µs max.Accuracy±1 LSB @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibrationLinearity<                                                                                                                                                                                                                                                                                                                          | Input Gain Amplifier         | Programmable for gain 1, 2, 4 and 8                        |  |  |  |
| ±2.5V for gain = 4<br>±1.25V for gain = 8Input Overvoltage Protection70VppCalibration DataCalibration data for gain and offset correction in ID PROMResolution16 bit with no missing codesConversion Time1.25µs without channel/gain change (ADC throughput rate up to 250ksps)<br>17.25µs with channel/gain change<br>16µs / channel in sequencer modeAccuracy±2 LSB @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibrationAnalog Output8 analog output channelsOutput Voltage Range±10VCalibration DataCalibration data for gain and offset correction in ID PROMResolution16 bitOutput Voltage Range±10VCalibration DataCalibration data for gain and offset correction in ID PROMResolution16 bitOutput Voltage Range±10VCalibration DataCalibration data for gain and offset correction in ID PROMResolution16 bitConversion Time10µs max.Accuracy±1 LSB @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibrationDAC INL/DNL Error±4/±3 LSB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Input Voltage Range          | -                                                          |  |  |  |
| ±1.25V for gain = 8Input Overvoltage Protection70VppCalibration DataCalibration data for gain and offset correction in ID PROMResolution16 bit with no missing codesConversion Time1.25µs without channel/gain change (ADC throughput rate up to 250ksps)<br>17.25µs with channel/gain change (ADC throughput rate up to 250ksps)<br>17.25µs with channel/gain change<br>16µs / channel in sequencer modeAccuracy±2 LSB @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibrationAnalog Output8 analog output channelsOutput Voltage Range±10VCalibration DataCalibration data for gain and offset correction in ID PROMResolution16 bitOutput Voltage Range±10VCalibration DataCalibration data for gain and offset correction in ID PROMResolution16 bitDupt Notage Range±10VCalibration DataCalibration data for gain and offset correction in ID PROMResolution16 bitConversion Time10µs max.Accuracy±1 LSB @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibrationDAC INL/DNL Error±4/±3 LSB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                              | •                                                          |  |  |  |
| Input Overvoltage Protection70VppCalibration DataCalibration data for gain and offset correction in ID PROMResolution16 bit with no missing codesConversion Time1.25µs without channel/gain change (ADC throughput rate up to 250ksps)<br>17.25µs with channel/gain change<br>16µs / channel in sequencer modeAccuracy±2 LSB @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibrationADC INL/DNL Error±3 LSBAnalog Output8 analog output channelsOutput Voltage Range±10VCalibration DataCalibration data for gain and offset correction in ID PROMResolution16 bitConversion Time1.9µs max.Accuracy±1 LSB @ 25°C after calibrationDupt16 bitDataCalibration data for gain and offset correction in ID PROMResolution16 bitDataCalibration data for gain and offset correction in ID PROMResolution16 bitConversion Time10µs max.Accuracy±1 LSB @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibrationDAC INL/DNL Error±4/±3 LSB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                              | -                                                          |  |  |  |
| Calibration DataCalibration data for gain and offset correction in ID PROMResolution16 bit with no missing codesConversion Time1.25µs without channel/gain change (ADC throughput rate up to 250ksps)<br>17.25µs with channel/gain change<br>16µs / channel in sequencer modeAccuracy±2 LSB @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibrationADC INL/DNL Error±3 LSBAnalog Output8 analog output channelsOutput Voltage Range±10VCalibration DataCalibration data for gain and offset correction in ID PROMResolution16 bitConversion Time10µs max.Accuracy±1 LSB @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibrationDutput Voltage Range±10VCalibration DataCalibration data for gain and offset correction in ID PROMResolution16 bitConversion Time10µs max.Accuracy±1 LSB @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibrationDAC INL/DNL Error±4/±3 LSB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                              |                                                            |  |  |  |
| Resolution16 bit with no missing codesConversion Time1.25μs without channel/gain change (ADC throughput rate up to 250ksps)<br>17.25μs with channel/gain change<br>16μs / channel in sequencer modeAccuracy±2 LSB @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibrationADC INL/DNL Error±3 LSBAnalog Output8 analog output channelsOutput Voltage Range±10VCalibration DataCalibration data for gain and offset correction in ID PROMResolution16 bitConversion Time10μs max.Accuracy±1 LSB @ 25°C after calibrationLinearity±1 LSB @ 25°C after calibrationDutton DataCalibration data for gain and offset correction in ID PROMResolution16 bitConversion Time10μs max.Accuracy±1 LSB @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibrationDAC INL/DNL Error±4/±3 LSB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Input Overvoltage Protection | 70Vpp                                                      |  |  |  |
| Conversion Time1.25µs without channel/gain change (ADC throughput rate up to 250ksps)<br>17.25µs with channel/gain change<br>16µs / channel in sequencer modeAccuracy±2 LSB @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibrationADC INL/DNL Error±3 LSBAnalog Output8 analog output channelsNumber of Analog Outputs8 analog output channelsOutput Voltage Range±10VCalibration DataCalibration data for gain and offset correction in ID PROMResolution10µs max.Accuracy±1 LSB @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Calibration Data             | Calibration data for gain and offset correction in ID PROM |  |  |  |
| 17.25μs with channel/gain change<br>16μs / channel in sequencer modeAccuracy±2 LSB @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibrationADC INL/DNL Error±3 LSBAnalog Output8 analog output channelsNumber of Analog Outputs8 analog output channelsOutput Voltage Range±10VCalibration DataCalibration data for gain and offset correction in ID PROMResolution16 bitConversion Time10μs max.Accuracy±1 LSB @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibrationDAC INL/DNL Error±4/±3 LSB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Resolution                   | · · · · · · · · · · · · · · · · · · ·                      |  |  |  |
| Accuracy±2 LSB @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibrationADC INL/DNL Error±3 LSBAnalog Output8 analog output channelsNumber of Analog Outputs8 analog output channelsOutput Voltage Range±10VCalibration DataCalibration data for gain and offset correction in ID PROMResolution16 bitConversion Time10µs max.Accuracy±1 LSB @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibrationDAC INL/DNL Error±4/±3 LSB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Conversion Time              |                                                            |  |  |  |
| Accuracy±2 LSB @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibrationADC INL/DNL Error±3 LSBAnalog Output8 analog output channelsNumber of Analog Outputs8 analog output channelsOutput Voltage Range±10VCalibration DataCalibration data for gain and offset correction in ID PROMResolution16 bitConversion Time10µs max.Accuracy±1 LSB @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibrationDAC INL/DNL Error±4/±3 LSB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                              |                                                            |  |  |  |
| Linearity±2 LSB @ 25°C after calibrationADC INL/DNL Error±3 LSBAnalog Output#3 LSBNumber of Analog Outputs8 analog output channelsOutput Voltage Range±10VCalibration DataCalibration data for gain and offset correction in ID PROMResolution16 bitConversion Time10µs max.Accuracy±1 LSB @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibrationDAC INL/DNL Error±4/±3 LSB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                              |                                                            |  |  |  |
| ADC INL/DNL Error±3 LSBAnalog OutputNumber of Analog Outputs8 analog output channelsOutput Voltage Range±10VCalibration DataCalibration data for gain and offset correction in ID PROMResolution16 bitConversion Time10µs max.Accuracy±1 LSB @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibrationDAC INL/DNL Error±4/±3 LSB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | -                            |                                                            |  |  |  |
| Analog OutputNumber of Analog Outputs8 analog output channelsOutput Voltage Range±10VCalibration DataCalibration data for gain and offset correction in ID PROMResolution16 bitConversion Time10µs max.Accuracy±1 LSB @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibrationDAC INL/DNL Error±4/±3 LSB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | -                            | ±2 LSB @ 25°C after calibration                            |  |  |  |
| Number of Analog Outputs8 analog output channelsOutput Voltage Range±10VCalibration DataCalibration data for gain and offset correction in ID PROMResolution16 bitConversion Time10µs max.Accuracy±1 LSB @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibrationDAC INL/DNL Error±4/±3 LSB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ADC INL/DNL Error            | ±3 LSB                                                     |  |  |  |
| Output Voltage Range±10VCalibration DataCalibration data for gain and offset correction in ID PROMResolution16 bitConversion Time10μs max.Accuracy±1 LSB @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibrationDAC INL/DNL Error±4/±3 LSB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Analog Output                |                                                            |  |  |  |
| Calibration DataCalibration data for gain and offset correction in ID PROMResolution16 bitConversion Time10µs max.Accuracy±1 LSB @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibrationDAC INL/DNL Error±4/±3 LSB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Number of Analog Outputs     | 8 analog output channels                                   |  |  |  |
| Resolution16 bitConversion Time10µs max.Accuracy±1 LSB @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibrationDAC INL/DNL Error±4/±3 LSB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Output Voltage Range         | ±10V                                                       |  |  |  |
| Conversion Time10µs max.Accuracy±1 LSB @ 25°C after calibrationLinearity±2 LSB @ 25°C after calibrationDAC INL/DNL Error±4/±3 LSB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Calibration Data             | Calibration data for gain and offset correction in ID PROM |  |  |  |
| Accuracy       ±1 LSB @ 25°C after calibration         Linearity       ±2 LSB @ 25°C after calibration         DAC INL/DNL Error       ±4/±3 LSB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Resolution                   | 16 bit                                                     |  |  |  |
| Linearity     ±2 LSB @ 25°C after calibration       DAC INL/DNL Error     ±4/±3 LSB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Conversion Time              | 10µs max.                                                  |  |  |  |
| DAC INL/DNL Error ±4/±3 LSB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Accuracy                     | ±1 LSB @ 25°C after calibration                            |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Linearity                    | ±2 LSB @ 25°C after calibration                            |  |  |  |
| Capacitive Load Up to 10 000pF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | DAC INL/DNL Error            | ±4/±3 LSB                                                  |  |  |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Capacitive Load              | Up to 10 000pF                                             |  |  |  |



| Digital I/O           | Digital I/O                                                                                                                                                                                                                                                                                                                                                               |                                                     |  |  |  |  |  |  |
|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------|--|--|--|--|--|--|
| Number of Digital I/O | 16 digital I/O c                                                                                                                                                                                                                                                                                                                                                          | 16 digital I/O channels                             |  |  |  |  |  |  |
| Minimum Pulse Width   | Programmable                                                                                                                                                                                                                                                                                                                                                              | e, 100ns – 6.55ms                                   |  |  |  |  |  |  |
| I/O Interface         |                                                                                                                                                                                                                                                                                                                                                                           |                                                     |  |  |  |  |  |  |
| I/O Connector         | Front I/O: HD6<br>No PMC P14 I                                                                                                                                                                                                                                                                                                                                            | 8 SCSI-3 type female connector (AMP 787082-7)<br>/O |  |  |  |  |  |  |
| Physical Data         |                                                                                                                                                                                                                                                                                                                                                                           |                                                     |  |  |  |  |  |  |
| Power Requirements    | 385 mA typical @ +5V DC                                                                                                                                                                                                                                                                                                                                                   |                                                     |  |  |  |  |  |  |
| Temperature Range     | Operating-40°C to +85 °CStorage-40°C to +85°C                                                                                                                                                                                                                                                                                                                             |                                                     |  |  |  |  |  |  |
| MTBF                  | 239930 h<br>MTBF values shown are based on calculation according to MIL-HDBK-217F and<br>MIL-HDBK-217F Notice 2; Environment: $G_B 20^{\circ}$ C.<br>The MTBF calculation is based on component FIT rates provided by the<br>component suppliers. If FIT rates are not available, MIL-HDBK-217F and<br>MIL-HDBK-217F Notice 2 formulas are used for FIT rate calculation. |                                                     |  |  |  |  |  |  |
| Humidity              | 5 – 95 % non-condensing                                                                                                                                                                                                                                                                                                                                                   |                                                     |  |  |  |  |  |  |
| Weight                | 75.5 g                                                                                                                                                                                                                                                                                                                                                                    |                                                     |  |  |  |  |  |  |

Table 2-1 : Technical Specification



# 3 Handling and operation Instructions

# 3.1 ESD Protection



This PMC module is sensitive to static electricity. Packing, unpacking and all other module handling has to be done with appropriate care.



# 4 Addressing

# 4.1 PCI Configuration Space

| PCI CFG<br>Register | w                                            | rite '0' to all unus | sed (Reserved) b | its           | PCI<br>writeable | Initial Values<br>(Hex Values) |  |
|---------------------|----------------------------------------------|----------------------|------------------|---------------|------------------|--------------------------------|--|
| Address             | 31 24                                        | 23 16                | 15 8             | 7 0           |                  | (                              |  |
| 0x00                | Devi                                         | ce ID                | Vend             | lor ID        | Ν                | 0353 1498                      |  |
| 0x04                | Sta                                          | itus                 | Com              | mand          | Y                | 0280 0000                      |  |
| 0x08                |                                              | Class Code           |                  | Revision ID   | N                | 118000 00                      |  |
| 0x0C                | not supported                                | Header Type          | not supported    | not supported | Y[7:0]           | 00 00 00 00                    |  |
| 0x10                | PCI Base                                     | Address 0 for MEI    | M Mapped Config. | Registers     | Y                | FFFFFF80                       |  |
| 0x14                | PCI Base                                     | e Address 1 for I/C  | Mapped Config.   | Registers     | Y                | FFFFFF81                       |  |
| 0x18                | PCI E                                        | Base Address 2 for   | Local Address Sp | ace 0         | Y                | FFFFFE00                       |  |
| 0x1C                | PCI E                                        | Base Address 3 for   | Local Address Sp | ace 1         | Y                | FFFFFFC0                       |  |
| 0x20                | PCI E                                        | Base Address 4 for   | Local Address Sp | ace 2         | Y                | FFFFFFC0                       |  |
| 0x24                |                                              | not sup              | oported          |               | Y                | 00000000                       |  |
| 0x28                |                                              | not sup              | oported          |               | N                | 00000000                       |  |
| 0x2C                | Subsys                                       | stem ID              | Subsystem        | NVendor ID    | Ν                | 000A 1498                      |  |
| 0x30                |                                              | not sup              | oported          |               | Y                | 00000000                       |  |
| 0x34                |                                              | Reserved Cap. Ptr. N |                  |               |                  |                                |  |
| 0x38                | Reserved                                     |                      |                  |               |                  | 00000000                       |  |
| 0x3C                | Max_Lat Min_Gnt Interrupt Pin Interrupt Line |                      |                  |               |                  | 00 00 01 00                    |  |
| 0x40-<br>0xFF       |                                              |                      | 0000000          |               |                  |                                |  |

## 4.1.1 PCI Address Space Overview

| PCI<br>BAR | PCI Base Address<br>(Offset in PCI<br>Configuration Space) | PCI<br>Space<br>Mapping | Size<br>(Byte) | Port<br>Width<br>(Bit) | Endian<br>Mode | Description                     |
|------------|------------------------------------------------------------|-------------------------|----------------|------------------------|----------------|---------------------------------|
| 0          | 0x10                                                       | MEM                     | 128            | 32                     | Little         | PCI Controller Register         |
| 1          | 0x14                                                       | I/O                     | 128            | 32                     | Little         | Space                           |
| 2          | 2 (0x18)                                                   | MEM                     | 512            | 32                     | BIG            | Local Register Address<br>Space |
| 3          | 3 (0x1C)                                                   | MEM                     | 64             | 16                     | BIG            | Sequencer Data RAM              |
| 4          | 4 (0x20)                                                   | MEM                     | 64             | 16                     | BIG            | ADC/DAC Calibration<br>ROM Data |
| 5          | 5 (0x24)                                                   | -                       | -              | -                      | -              | Not Used                        |

Table 4-2: PCI Address Space Overview



## 4.1.2 Serial EEPROM Memory

The serial EEPROM memory contains by default the TEWS PCI Interface FPGA configuration data for compatibility reasons. However, the entire configuration data are stored within and loaded from the internal flash of the PCI target chip.

| Address | Offset |        |        |        |        |        |        |        |
|---------|--------|--------|--------|--------|--------|--------|--------|--------|
|         | 0x00   | 0x02   | 0x04   | 0x06   | 0x08   | 0x0A   | 0x0C   | 0x0E   |
| 0x00    | 0x0353 | 0x1498 | 0x0280 | 0x0000 | 0x1180 | 0x0000 | s.b.   | 0x1498 |
| 0x10    | 0x0000 | 0x0040 | 0x0000 | 0x0100 | 0x4801 | 0x4801 | 0x0000 | 0x0000 |
| 0x20    | 0x0000 | 0x4C06 | 0x0000 | 0x0003 | 0xFFFF | 0xFE00 | 0xFFFF | 0xFFC0 |
| 0x30    | 0xFFFF | 0xFFC0 | 0x0000 | 0x0000 | 0x0000 | 0x0000 | 0x0000 | 0x0001 |
| 0x40    | 0x0000 | 0x0201 | 0x0000 | 0x0301 | 0x0000 | 0x0000 | 0x0000 | 0x0000 |
| 0x50    | 0x0180 | 0x6022 | 0x0140 | 0x0022 | 0x0140 | 0x0022 | 0x0000 | 0x0000 |
| 0x60    | 0x0000 | 0x0000 | 0x0000 | 0x0101 | 0x0000 | 0x0221 | 0x0000 | 0x0321 |
| 0x70    | 0x0000 | 0x0000 | 0x0030 | 0x0041 | 0x0078 | 0x4000 | 0x026D | 0xB6D2 |
| 0x80    | 0x0000 | 0x0000 | 0x0000 | 0x0000 | 0xFFFF | 0xFFFF | 0xFFFF | 0xFFFF |
| 0x90    | 0xFFFF |
| 0xA0    | 0xFFFF |
| 0xB0    | 0xFFFF |
| 0xC0    | 0xFFFF |
| 0xD0    | 0xFFFF |
| 0xE0    | 0xFFFF |
| 0xF0    | 0xFFFF |

Table 4-3 : Configuration EEPROM TPMC851-10R

Subsystem-ID Value (Offset 0x0C): TPMC851-10R 0x000A



# 4.2 PCI Controller Register Space

### 4.2.1 PCI Controller Configuration Register Map

The PCI base address for the PCI Controller Configuration Registers is PCI Base Address 0 (PCI Memory Space, Offset 0x10 in the PCI Configuration Space) or PCI Base Address 1 (PCI I/O Space, Offset 0x14 in the PCI Configuration Space).

Do not change hardware dependent bit settings in the PCI Controller Configuration Registers.

| Offset from<br>PCI Base<br>Address | Register                                                                  | Value       |
|------------------------------------|---------------------------------------------------------------------------|-------------|
| 0x00                               | Local Address Space 0 Range                                               | 0xFFFF_FE00 |
| 0x04                               | Local Address Space 1 Range                                               | 0xFFFF_FFC0 |
| 0x08                               | Local Address Space 2 Range                                               | 0xFFFF_FFC0 |
| 0x0C                               | Local Address Space 3 Range                                               | 0x0000_0000 |
| 0x10                               | Expansion ROM Range                                                       | 0x0000_0000 |
| 0x14                               | Local Address Space 0 Local Base Address (Remap)                          | 0x0000_0001 |
| 0x18                               | Local Address Space 1 Local Base Address (Remap)                          | 0x0000_0201 |
| 0x1C                               | Local Address Space 2 Local Base Address (Remap)                          | 0x0000_0301 |
| 0x20                               | Local Address Space 3 Local Base Address (Remap)                          | 0x0000_0000 |
| 0x24                               | Expansion ROM Local Base Address (Remap)                                  | 0x0000_0000 |
| 0x28                               | Local Address Space 0 Bus Region Descriptor                               | 0x0180_6022 |
| 0x2C                               | Local Address Space 1 Bus Region Descriptor                               | 0x0140_0022 |
| 0x30                               | Local Address Space 2 Bus Region Descriptor                               | 0x0140_0022 |
| 0x34                               | Local Address Space 3 Bus Region Descriptor                               | 0x0000_0000 |
| 0x38                               | Expansion ROM Bus Region Descriptor                                       | 0x0000_0000 |
| 0x3C                               | Chip Select 0 Base Address                                                | 0x0000_0101 |
| 0x40                               | Chip Select 1 Base Address                                                | 0x0000_0221 |
| 0x44                               | Chip Select 2 Base Address                                                | 0x0000_0321 |
| 0x48                               | Chip Select 3 Base Address                                                | 0x0000_0000 |
| 0x4C                               | Interrupt Control/Status                                                  | 0x0041      |
| 0x4E                               | Serial EEPROM Write-Protected Address Boundary                            | 0x0030      |
| 0x50                               | PCI Target Response, Serial EEPROM Control, and<br>Initialization Control | 0x0078_4000 |
| 0x54                               | General Purpose I/O Control                                               | 0x026D_B6D2 |
| 0x70                               | Hidden1 Register for Power Management Data Select                         | 0x0000_0000 |
| 0x74                               | Hidden 2 Register for Power Management Data Scale                         | 0x0000_0000 |

Table 4-4 : PCI Controller Configuration Register Map



## 4.3 Local Register Address Space

The PCI base address for the Local Registers is PCI Base Address 2 (PCI Memory Space, Offset 0x18 in the PCI Configuration Space).

The register offsets stated below refer to 32 bit accesses. The registers shorter than 32 bit are filled with zeros on long word read-accesses. The not used addresses will return 0 when read.

| Offset to PCI Base<br>Address 2 | Symbol Register Nam |                                    |
|---------------------------------|---------------------|------------------------------------|
| 0x0000                          | ADCCONT             | ADC Control Register               |
| 0x0004                          | ADCDATA             | ADC Data Register                  |
| 0x0008                          | ADCSTAT             | ADC Status Register                |
| 0x000C                          | ADCCONV             | ADC Conversion Start Register      |
| 0x0010                          | ADCSEQCONT          | ADC Sequencer Control Register     |
| 0x0014                          | ADCSEQSTAT          | ADC Sequencer Status Register      |
| 0x0018                          | ADCSEQTIME          | ADC Sequencer Timer Register       |
| 0x001C                          | -                   | Not used                           |
| 0x0020 - 0x009C                 | ADCSEQIRAM          | ADC Sequencer Instruction RAM 1-32 |
| 0x00A0 – 0x00BF                 | -                   | Not used                           |
| 0x00C0                          | DACCONT             | DAC Control Register               |
| 0x00C4                          | DACSEQSTAT          | DAC Sequencer Status Register      |
| 0x00C8                          | DACSEQTIME          | DAC Sequencer Timer Register       |
| 0x00CC                          | -                   | Not used                           |
| 0x00D0 - 0x00EC                 | DACDATA             | DAC Data Register 1-8              |
| 0x00F0 – 0x00FF                 | -                   | Not used                           |
| 0x0100                          | LINEDIR             | Line Direction Register            |
| 0x0104                          | LINEDEB             | Line Debounce Enable Register      |
| 0x0108                          | LINEDBT             | Line Debounce Time Register        |
| 0x010C                          | LINEIN              | Line Input Register                |
| 0x0110                          | LINEOUT             | Line Output Register               |
| 0x0114                          | LINEIEN             | Line Interrupt Enable Register     |
| 0x0118                          | LINEIST             | Line Interrupt Status Register     |
| 0x011C                          | -                   | Not used                           |
| 0x0120                          | CNTPRL              | Counter Preload Register           |
| 0x0124                          | CNTCMP              | Counter Compare Register           |
| 0x0128                          | CNTDATA             | Counter Data Register              |
| 0x012C                          | CNTCONT             | Counter Control Register           |
| 0x0130                          | CNTSTAT             | Counter Status Register            |
| 0x0134                          | CNTCOM              | Counter Command Register           |
| 0x0138 – 0x013F                 | -                   | Not used                           |
| 0x0140                          | ICR                 | Interrupt Control Register         |
| 0x0144 – 0x014F                 | -                   | Factory use only. Do not Write.    |
| 0x0150 – 0x01FF                 | -                   | Not used                           |

| Table 4-5 : | Register Addr | ess Space |
|-------------|---------------|-----------|
|-------------|---------------|-----------|



## 4.3.1 Analog Input Registers

| Bit   | Symbol     |                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                     | Description                                 |                             | Access | Reset<br>Value |  |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------|-----------------------------|--------|----------------|--|
| 31:12 | -          | Reserved<br>Write: don't<br>Read: alway                                                                                                                                                                                                                                                                    | R                                                                                                                                                                                                                                                                                                                   | 0                                           |                             |        |                |  |
| 11    | RST        |                                                                                                                                                                                                                                                                                                            | ,                                                                                                                                                                                                                                                                                                                   | DC is reset. Curre<br>diately after a write | nt conversions are aborted. | R/W    | 0              |  |
| 10    | IRQC       | 0 = IRQ afte<br>1 = IRQ afte<br>An interrupt<br>(ADC_BUS)<br>For pending                                                                                                                                                                                                                                   | IRQ after Conversion Enable<br>0 = IRQ after Conversion disabled<br>1 = IRQ after Conversion enabled<br>An interrupt will be generated after a conversion is finished<br>(ADC_BUSY changes from 1 to 0).<br>For pending interrupts and interrupt acknowledge see the ADC Status<br>Register ADCSTAT.                |                                             |                             |        |                |  |
| 9     | IRQST      | 0 = IRQ afte<br>1 = IRQ afte<br>An interrupt<br>(SETTL_BU<br>For pending                                                                                                                                                                                                                                   | IRQ after Settling Time Enable<br>0 = IRQ after Settling Time disabled<br>1 = IRQ after Settling Time enabled<br>An interrupt will be generated after the settling time has elapsed<br>(SETTL_BUSY changes from 1 to 0)<br>For pending interrupts and interrupt acknowledge see the ADC Status<br>Register ADCSTAT. |                                             |                             |        |                |  |
| 8     | ASTC       | Automatic Settling Time Control<br>0 = OFF (Normal Mode)<br>A conversion must be initiated manually in the ADC Conversion Start<br>Register ADCCONV.<br>1 = ON (Automatic Mode)<br>A conversion is automatically initiated after the settling time has<br>elapsed.<br>The ADC settling time is appr. 16µs. |                                                                                                                                                                                                                                                                                                                     |                                             |                             |        | 0              |  |
|       |            | Gain Selecti                                                                                                                                                                                                                                                                                               | on (Analog                                                                                                                                                                                                                                                                                                          | Input Amplifier)                            |                             |        |                |  |
|       |            | GAIN1                                                                                                                                                                                                                                                                                                      | GAIN0                                                                                                                                                                                                                                                                                                               | Gain Factor                                 | Input Voltage Range         |        |                |  |
|       |            | 0                                                                                                                                                                                                                                                                                                          | 0                                                                                                                                                                                                                                                                                                                   | 1                                           | ±10V                        |        |                |  |
| 7:6   | GAIN [1:0] | 0                                                                                                                                                                                                                                                                                                          | 1                                                                                                                                                                                                                                                                                                                   | 2                                           | ±5V                         | R/W    | 00             |  |
|       |            | 1                                                                                                                                                                                                                                                                                                          | 0                                                                                                                                                                                                                                                                                                                   | 4                                           | ±2.5V                       |        |                |  |
|       |            | 1                                                                                                                                                                                                                                                                                                          | 1                                                                                                                                                                                                                                                                                                                   | 8                                           | ±1.25V                      |        |                |  |
| 5     | SE/DIFF    | Single/Differential Mode Control<br>0 = Single-ended mode<br>32 single-ended input channels available<br>1 = Differential mode<br>16 differential input channels available                                                                                                                                 |                                                                                                                                                                                                                                                                                                                     |                                             |                             |        | 0              |  |

### 4.3.1.1 ADC Control Register ADCCONT (Offset 0x0000)



| Bit | Symbol  |                        | Access                                 | Reset<br>Value                         |     |       |
|-----|---------|------------------------|----------------------------------------|----------------------------------------|-----|-------|
|     |         | Channel Select (Analog | g Input Channel)                       |                                        |     |       |
|     |         | CS[4:0]                | Single-ended<br>Channel<br>SE/DIFF = 0 | Differential<br>Channel<br>SE/DIFF = 1 |     |       |
|     |         | 00000                  | CH1                                    | CH1                                    |     |       |
|     |         |                        |                                        |                                        |     |       |
| 4:0 | CS[4:0] | 01111                  | CH16                                   | CH16                                   | R/W | 00000 |
|     |         | 10000                  | CH17                                   | N/A                                    |     |       |
|     |         |                        |                                        |                                        |     |       |
|     |         | 11111                  | CH32                                   | N/A                                    |     |       |
|     |         | 'N/A' = ADC Input conn | ected to GND                           |                                        |     |       |

A write to this register sets the new channel and gain. Subsequent write accesses are ignored until the settling time has elapsed. This register is developed for a word (16 bit) or long word (32 bit) read/write access. Byte accesses on this register are not supported and will fail.

Do NOT write to this register while the sequencer is running! A write to this register while the sequencer is running can lead to unpredictable results!

Interrupts are generated only if the Master Interrupt Enable (MIE) is enabled in the Interrupt Control Register ICR.



#### 4.3.1.2 ADC Data Register ADCDATA (Offset 0x0004)

The ADC Data Register contains the converted data value. The output format is two's complement.

This register is updated if the conversion was initiated with the ADC Conversion Start Register ADCCONV or by the Automatic Settling Time Control ASTC on the falling edge of ADC\_BUSY in the ADC Status Register (ADCSTAT). Conversions initiated by the sequencer will have no effect to this register.

| Bit   | Symbol | Description                                                | Access | Reset<br>Value |
|-------|--------|------------------------------------------------------------|--------|----------------|
| 31:16 | -      | Reserved<br>Write: don't care<br>Read: always reads as '0' | R      | 0              |
| 15:0  |        | Stores the converted 16 bit data value.                    | R      | 0              |

Table 4-7 : ADC Data Register

| Description              | ±10V<br>(Gain 1) | ±5V (Gain 2) | ±2.5V<br>(Gain 4) | ±1.25V<br>(Gain 8) | Two's<br>Complement |
|--------------------------|------------------|--------------|-------------------|--------------------|---------------------|
| Full Scale Range         | ±10V             | ±5V          | ±2.5              | ±1.25              |                     |
| Least Significant<br>Bit | 305.2µV          | 152.6µV      | 76.2µV            | 38.15µV            |                     |
| FSR - 1LSB               | 9.999695V        | 4.999847V    | 2.499924V         | 1.249962V          | 0x7FFF <sup>1</sup> |
| Midscale + 1LSB          | 305.2µV          | 152.6µV      | 76.2µV            | 38.15µV            | 0x0001              |
| Midscale                 | 0V               | 0V           | 0V                | 0V                 | 0x0000              |
| Midscale – 1LSB          | -305.2µV         | -152.6µV     | -76.2µV           | -38.15µV           | 0xFFFF              |
| -FSR + 1LSB              | -9.999695V       | -4.999847V   | -2.499924V        | -1.249962V         |                     |
| Full Scale (neg.)        | -10V             | -5V          | -2.5V             | 1.25V              | 0x8000 <sup>2</sup> |

<sup>1</sup>This is also the code for an overrange analog input. <sup>2</sup>This is also the code for an underrange analog input.

#### Table 4-8 : ADC Data Coding

After power up the on board ADC device is in a random state and requires two dummy conversions before operating correctly. This is based on the chip design of the ADC device.

Software should ignore the data of the first two ADC conversions after power-up.

The software drivers from TEWS TECHNOLOGIES already include these two dummy conversions.



#### 4.3.1.3 ADC Status Register ADCSTAT (Offset 0x0008)

| Bit  | Symbol        | Description                                                                                                                                                                                                                                                                                                                                                                                                    | Access | Reset<br>Value |
|------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------|
| 31:4 | -             | Reserved<br>Write: don't care<br>Read: always read as '0'                                                                                                                                                                                                                                                                                                                                                      | R      | 0              |
| 3    | SETTL<br>IRQ  | Pending Settling Time Interrupts (Read),<br>Interrupt acknowledge (Write)<br>On a read-access this bit shows a pending Settling Time interrupt.<br>Pending interrupts are marked with a '1'.<br>An interrupt is acknowledged by writing a '1' to this bit after the error<br>flags are cleared.                                                                                                                |        | 0              |
| 2    | ADC IRQ       | Pending Conversion Interrupts (Read),<br>Interrupt acknowledge (Write)<br>On a read-access this bit shows a pending Conversion interrupt.<br>Pending interrupts are marked with a '1'.<br>An interrupt is acknowledged by writing a '1' to this bit after the error<br>flags are cleared.                                                                                                                      | R/C    | 0              |
| 1    | SETTL<br>BUSY | SETTL_BUSY<br>Indicates that the required settling time after a write to the CONTREG<br>register is not yet done.<br>This bit is set by writing to the CONTREG register. The bit is cleared<br>when the required settling time has elapsed.<br>This bit must be read as '0' before a conversion is started by a write to<br>the ADC Conversion Start Register ADCCONV.<br>The ADC settling time is appr. 16µs. | R      | 0              |
| 0    | ADC<br>BUSY   | ADC_BUSY<br>Indicates if an actual data conversion is in progress.<br>If "Automatic Settling Time Mode" is OFF, this bit is set by writing to<br>the ADC Conversion Start Register ADCCONV.<br>If "Automatic Settling Time Mode" is ON, this bit is set automatically<br>after the settling time has elapsed.<br>This bit must be read as '0' before the conversion data is read from the<br>DATAREG register. | R      | 0              |

Table 4-9 : ADC Status Register

Interrupts are generated only if the Master Interrupt Enable (MIE) is enabled in the Interrupt Control Register ICR.



#### 4.3.1.4 ADC Conversion Start Register ADCCONV (Offset 0x000C)

The ADC Conversion Start Register is used to start an ADC conversion when "Automatic Settling Time Mode" is OFF. Any write access starts the conversion. The user must read the SETTL\_BUSY bit in the ADC Status Register as '0' or wait for a Settling Time Interrupt before the conversion is started. The ADC\_BUSY bit in the ADC Status Register indicates if the conversion data in the ADC Data Register is valid (ADC\_BUSY bit = '0').

It is allowed to set up a new channel/gain by writing to the ADC Control Register CONTREG immediately after starting an ADC conversion.

If "Sequencer Mode" is selected (SEQCONT register bit 0 is set to '1') all write accesses to the ADC Conversion Start Register ADCCONV are ignored.

Please pay attention to the chapter "Important Notes".



#### 4.3.1.5 ADC Sequencer Control Register ADCSEQCONT (Offset 0x0010)

| Bit  | Symbol      | Description                                                                                                                            | Access | Reset<br>Value |
|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------|--------|----------------|
|      |             | Reserved                                                                                                                               |        |                |
| 31:3 | -           | Write: don't care                                                                                                                      | R      | 0              |
|      |             | Read: always reads as '0'                                                                                                              |        |                |
|      |             | Sequencer Interrupt Enable Control                                                                                                     |        |                |
|      |             | 0 = Sequencer Interrupt Disabled                                                                                                       |        |                |
|      | SEQ INT     | 1 = Sequencer Interrupt Enabled                                                                                                        | R/W    |                |
| 2    | ENA         | An interrupt request will be generated if any error flag is set in the ADCSEQSTAT Register (Sequencer Data Valid or Sequencer Error).  |        | 0              |
|      |             | For pending interrupts and interrupt acknowledge see ADC Sequencer<br>Status Register ADCSEQSTAT.                                      |        |                |
|      | 050         | Sequencer Trigger Source                                                                                                               |        |                |
| 1    | SEQ<br>TRIG | 0 = Sequencer Timer                                                                                                                    | R/W    | 0              |
|      | TRIO        | 1 = External Signal (Dig I/O Line 0)                                                                                                   |        |                |
|      |             | Sequencer Start / Stop Control                                                                                                         |        |                |
| 0    | SEQ ON      | 0 = Stops the Sequencer after last Instruction (Sequencer Continuous Mode:<br>Sequencer stops immediately). No DATA AV will be issued. | R/W    | 0              |
|      |             | 1 = Starts the Sequencer immediately                                                                                                   |        |                |

Table 4-10 : ADC Sequencer Control Register

If an error flag (DATA\_OVERFLOW\_ERROR, TIMER\_ERROR, I-RAM\_ERROR) is set in the Sequencer Status Register SEQSTAT, the sequencer will be stopped after the last instruction (SEQ\_ON will be set to '0'). The user must clear the status bits and start the sequencer again.

Interrupts are generated only if the Master Interrupt Enable (MIE) is enabled in the Interrupt Control Register ICR.

Please pay attention to the chapter "Important Notes" before using the sequencer.

If ADC\_OUT in the Line Direction Register LINEDIR is set to '1', the trigger signal for the sequencer is available for external use on Dig I/O Line 0.

Do not use the External Signal as Sequencer Trigger Source if ADC\_OUT is enabled. This will cause the sequencer to lock.



#### 4.3.1.6 ADC Sequencer Status Register ADCSEQSTAT (Offset 0x0014)

| Bit  | Symbol                    | Description                                                                                                                                                                                                                                                                                                                                                                          | Access | Reset<br>Value |
|------|---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------|
| 31:5 | -                         | Reserved<br>Write: don't care<br>Read: always reads as '0'                                                                                                                                                                                                                                                                                                                           | R      | 0              |
| 4    | SEQ IRQ                   | Pending Sequencer Interrupts (Read),<br>On a read-access this bit shows a pending Sequencer interrupt. Pending<br>interrupts are marked with a '1'.<br>An interrupt is acknowledged when the error flags are cleared.                                                                                                                                                                | R      | 0              |
| 3    | I-RAM<br>ERROR            | Instruction RAM Error Flag<br>Set by the sequencer if the sequencer has been started and there is no<br>instruction in the Sequencer Instruction RAM.<br>To clear this flag the user must write '1' to this bit.                                                                                                                                                                     | R/C    | 0              |
| 2    | TIMER<br>ERROR            | Timer Error Flag<br>Set by the sequencer if the sequencer timer has elapsed but the actual<br>sequence is still in progress.<br>To clear the Timer Error Flag the user must write '1' to this bit.<br>If the Sequencer Timer Register is 0 (Sequencer Continuous Mode) the<br>Timer Error Flag always reads as '0'.                                                                  | R/C    | 0              |
| 1    | DATA<br>OVERFLOW<br>ERROR | Data Overflow Error Flag<br>Set by the sequencer if the last sequencer instruction is done and the<br>Data Available Flag of the previous sequence has not yet been cleared by<br>the user.<br>To clear the error flag the user must write '1' to this bit.<br>If the Sequencer Timer Register is 0 (Sequencer Continuous Mode) the<br>Data Overflow Error Flag always reads as '0'. | R/C    | 0              |
| 0    | DATA AV                   | Data Available Flag<br>Set if a sequence is done and new ADC Data is available in the ADC Data<br>RAM.<br>After reading the ADC Data RAM the user must clear the Data Available<br>Flag by writing '1' to this bit.                                                                                                                                                                  | R/C    | 0              |

Table 4-11 : ADC Sequencer Status Register

| Description                | Sequencer<br>Timer | Continuous<br>Mode | External<br>Trigger |
|----------------------------|--------------------|--------------------|---------------------|
| Data Available Flag        | Active, IRQ        | Active, no IRQ     | Active, IRQ         |
| Data Overflow Error Flag   | Active, IRQ        | Disabled           | Active, IRQ         |
| Timer Error Flag           | Active, IRQ        | Disabled           | Active, IRQ         |
| Instruction RAM Error Flag | Active, IRQ        | Active, IRQ        | Active, IRQ         |

Table 4-12: Error Flag IRQ generation

Also see chapter 'Sequencer Errors' for details.



#### 4.3.1.7 ADC Sequencer Timer Register ADCSEQTIME (Offset 0x0018)

| Bit   | Symbol | Description                                                | Access | Reset<br>Value |
|-------|--------|------------------------------------------------------------|--------|----------------|
| 31:16 | -      | Reserved<br>Write: don't care<br>Read: always reads as '0' | R      | 0              |
| 15:0  |        | Sequencer Timer Preload Value                              | R/W    | 0              |

Table 4-13: ADC Sequencer Timer Register

The Sequencer Timer is programmable from 100µs to 6.5535s in 100µs steps. The time base for the sequencer timer is derived from an on board 40 MHz oscillator.

Whenever the timer reaches the programmed value the sequencer starts a new sequence with the first instruction found in the instruction RAM.

Assure that the time needed to complete a sequence is suitable to the chosen sequence timer value. If the sequence timer elapses while a sequence is still in progress, a timer error will be asserted.

If the Sequencer Timer Register is set to '0', the "Sequencer Continuous Mode" is selected. The sequencer will start again with the first instruction of the sequence immediately after the last instruction of the previous sequence has been completed. In this mode the Timer Error Flag (TIMER\_ERROR) and the Data Overflow Error Flag (DATA\_OVERFLOW\_ERROR) are not active and will read as '0'. The Data Available Flag (DATA\_AV) will be active, but will not produce an interrupt.



#### 4.3.1.8 ADC Sequencer Instruction RAM (Offset 0x0020 - Offset 0x009C)

| Bit  | Symbol     |                                         |                                                                                                                                                                                                                | Descriptio                 | on                                  |      | Access | Reset<br>Value |
|------|------------|-----------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|-------------------------------------|------|--------|----------------|
| 31:4 | -          | Reserved<br>Write: don't<br>Read: alway |                                                                                                                                                                                                                | 0'                         |                                     |      | R      | 0              |
|      |            | Gain Selecti                            | ain Selection (Analog Input Amplifier)                                                                                                                                                                         |                            |                                     |      |        |                |
|      |            | GAIN1                                   | GAIN0                                                                                                                                                                                                          | Gain Factor                | Input Voltage Range                 |      |        |                |
|      |            | 0                                       | 0                                                                                                                                                                                                              | 1                          | ±10V                                |      | R/W    |                |
| 3:2  | GAIN [1:0] | 0                                       | 1                                                                                                                                                                                                              | 2                          | ±5V                                 |      |        | 00             |
|      |            | 1                                       | 0                                                                                                                                                                                                              | 4                          | ±2.5V                               |      |        |                |
|      |            | 1                                       | 1                                                                                                                                                                                                              | 8                          | ±1.25V                              |      |        |                |
|      |            |                                         |                                                                                                                                                                                                                |                            |                                     | -    |        |                |
| 1    | ENA        | 0 = Sequend<br>1 = Sequend              | able this ADC Channel for the Sequencer<br>= Sequencer will pass over the ADC Channel<br>= Sequencer converts this ADC Channel and updates the ADC Data in the<br>quencer Data RAM at the end of the sequence. |                            |                                     |      | R/W    | 0              |
| 0    | SE/DIFF    |                                         | nded mode<br>ded channe<br>tial mode<br>al channels<br>els 1-16 can                                                                                                                                            | ls available<br>available. | differential channel. Channel<br>6. | s 17 | R/W    | 0              |

Table 4-14: ADC Sequencer Instruction RAM Register

If a channel is configured as differential channel, the instruction of the associated channel is ignored (see following chart or chapter 'Pin Assignment – I/O Connector' for the associated channels).

Within a sequence mixed single-ended and differential modes are possible.

Example: Channel 1 to channel 8 (with channels 17 to channel 24) are selected as differential inputs, channel 9 to channel 16 and channel 25 to channel 32 as single-ended input channels.

Only the Sequencer Data RAM locations of channels enabled for the sequence are updated at the end of a sequence. All other RAM locations are empty or contain old data.

Example: If only channel 1, channel 2, and channel 8 are enabled, only the three ADC RAM locations for channel 1, channel 2, and channel 8 are updated at the end of the sequence. The user must only read these three ADC RAM locations then.

If a sequence is started with an empty instruction RAM, an I-RAM error is issued.

#### The Sequencer Instruction RAM is accessible only while the sequencer is not running (SEQ\_ON = 0).



The following table shows the position of the Sequencer Instruction RAM bytes in the local memory space.

| Offset | Single Ended | Differential               |  |  |
|--------|--------------|----------------------------|--|--|
| 0x20   | Channel 1    | Channel 1                  |  |  |
| 0x24   | Channel 2    | Channel 2                  |  |  |
| 0x28   | Channel 3    | Channel 3                  |  |  |
| 0x2C   | Channel 4    | Channel 4                  |  |  |
| 0x30   | Channel 5    | Channel 5                  |  |  |
| 0x34   | Channel 6    | Channel 6                  |  |  |
| 0x38   | Channel 7    | Channel 7                  |  |  |
| 0x3C   | Channel 8    | Channel 8                  |  |  |
| 0x40   | Channel 9    | Channel 9                  |  |  |
| 0x44   | Channel 10   | Channel 10                 |  |  |
| 0x48   | Channel 11   | Channel 11                 |  |  |
| 0x4C   | Channel 12   | Channel 12                 |  |  |
| 0x50   | Channel 13   | Channel 13                 |  |  |
| 0x54   | Channel 14   | Channel 14                 |  |  |
| 0x58   | Channel 15   | Channel 15                 |  |  |
| 0x5C   | Channel 16   | Channel 16                 |  |  |
| 0x60   | Channel 17   | N/A (Input for Channel 1)  |  |  |
| 0x64   | Channel 18   | N/A (Input for Channel 2)  |  |  |
| 0x68   | Channel 19   | N/A (Input for Channel 3)  |  |  |
| 0x6C   | Channel 20   | N/A (Input for Channel 4)  |  |  |
| 0x70   | Channel 21   | N/A (Input for Channel 5)  |  |  |
| 0x74   | Channel 22   | N/A (Input for Channel 6)  |  |  |
| 0x78   | Channel 23   | N/A (Input for Channel 7)  |  |  |
| 0x7C   | Channel 24   | N/A (Input for Channel 8)  |  |  |
| 0x80   | Channel 25   | N/A (Input for Channel 9)  |  |  |
| 0x84   | Channel 26   | N/A (Input for Channel 10) |  |  |
| 0x88   | Channel 27   | N/A (Input for Channel 11) |  |  |
| 0x8C   | Channel 28   | N/A (Input for Channel 12) |  |  |
| 0x90   | Channel 29   | N/A (Input for Channel 13) |  |  |
| 0x94   | Channel 30   | N/A (Input for Channel 14) |  |  |
| 0x98   | Channel 31   | N/A (Input for Channel 15) |  |  |
| 0x9C   | Channel 32   | N/A (Input for Channel 16) |  |  |

Table 4-15: ADC Sequencer Instruction RAM Register positions



## 4.3.2 Analog Output Registers

#### 4.3.2.1 DAC Control Register DACCONT (Offset 0x00C0)

| Bit  | Symbol         |                                                                                                                        | Description                                                                                                                                                                                                                                                                                   | Access | Reset<br>Value |                                             |                                                                                                                                                                                                                              |   |   |   |   |                                                                                                           |   |    |                                                                                                                                         |     |   |
|------|----------------|------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------|---------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|-----------------------------------------------------------------------------------------------------------|---|----|-----------------------------------------------------------------------------------------------------------------------------------------|-----|---|
| 31:6 | -              | Reserved<br>Write: don't care<br>Read: always reads as '0'                                                             |                                                                                                                                                                                                                                                                                               | R      | 0              |                                             |                                                                                                                                                                                                                              |   |   |   |   |                                                                                                           |   |    |                                                                                                                                         |     |   |
| 5    | DAC IRQ<br>ENA | 0 = DAC Interrupt Di<br>1 = DAC Interrupt Er<br>An interrupt is issued<br>Update or Trigger Up<br>For pending interrup | DAC Interrupt Enable<br>0 = DAC Interrupt Disabled<br>1 = DAC Interrupt Enabled<br>An interrupt is issued on a Sequencer Data Request in the Sequencer<br>Update or Trigger Update mode.<br>For pending interrupts and interrupt acknowledge see DAC Sequencer<br>Status Register DACSEQSTAT. |        |                |                                             |                                                                                                                                                                                                                              |   |   |   |   |                                                                                                           |   |    |                                                                                                                                         |     |   |
|      |                | Load Mode Select<br>The Load Mode deter<br>LOADSEL[1:0]<br>Immediate Update                                            | Immediate Update:                                                                                                                                                                                                                                                                             |        |                |                                             |                                                                                                                                                                                                                              |   |   |   |   |                                                                                                           |   |    |                                                                                                                                         |     |   |
|      | LOAD<br>SEL    | -                                                                                                                      | _                                                                                                                                                                                                                                                                                             | -      | -              | Simultaneous Up                             | Manual Update:<br>All DAC outputs are updated simultaneously when                                                                                                                                                            |   |   |   |   |                                                                                                           |   |    |                                                                                                                                         |     |   |
| 4:3  |                |                                                                                                                        |                                                                                                                                                                                                                                                                                               |        |                | -                                           | -                                                                                                                                                                                                                            | - | - | 3 | - | -                                                                                                         | - | 10 | LOADDAC is set to '1'.<br>Sequencer Update:<br>All DAC outputs are updated simultaneously when<br>the DAC Sequencer Timer reaches zero. | R/W | 0 |
|      |                |                                                                                                                        |                                                                                                                                                                                                                                                                                               |        |                |                                             |                                                                                                                                                                                                                              |   |   |   |   | Trigger Update:<br>All DAC outputs are updated simultaneously by an<br>external trigger (Dig I/O Line 1). |   |    |                                                                                                                                         |     |   |
|      |                |                                                                                                                        |                                                                                                                                                                                                                                                                                               |        |                | via the DAC Data Re<br>which all DACs are u | Update modes it is required to load the DACs with data egisters. This data is buffered until the trigger event on updated simultaneously with the buffered data. If a ded with new data, it will use the old data previously |   |   |   |   |                                                                                                           |   |    |                                                                                                                                         |     |   |
| 2    | LOAD<br>DAC    |                                                                                                                        | ode writing a '1' loads all DACs simultaneously. This bit ely after a write access.                                                                                                                                                                                                           | W      | 0              |                                             |                                                                                                                                                                                                                              |   |   |   |   |                                                                                                           |   |    |                                                                                                                                         |     |   |
| 1    | RSTSEL         |                                                                                                                        | ndicates the action of RSTDAC. A RSTDAC command will set the DAC registers and outputs to midscale.                                                                                                                                                                                           |        |                |                                             |                                                                                                                                                                                                                              |   |   |   |   |                                                                                                           |   |    |                                                                                                                                         |     |   |
| 0    | RSTDAC         | Reset DACs<br>Writing '1' resets the<br>cleared immediately                                                            | DACs. The DACs are set to midscale. This bit is after a write access.                                                                                                                                                                                                                         | w      | 0              |                                             |                                                                                                                                                                                                                              |   |   |   |   |                                                                                                           |   |    |                                                                                                                                         |     |   |

Table 4-16: DAC Control Register

DAC analog outputs of all channels are held in a reset state for the time of a PCI or local reset.

Interrupts are generated only if the Master Interrupt Enable (MIE) is enabled in the Interrupt Control Register ICR.

If DAC\_OUT in the Line Direction Register LINEDIR is set to '1', the trigger signal for the sequencer is available for external use on Dig I/O Line 1.



Do not use the Trigger Update mode if DAC\_OUT is enabled. This will cause the sequencer to lock.

#### 4.3.2.2 DAC Sequencer Status Register DACSEQSTAT (Offset 0x00C4)

| Bit  | Symbol  | Description                                                                                                                                                                                                                                                                                                                                                                                                                   | Access | Reset<br>Value |
|------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------|
| 31:3 | -       | Reserved<br>Write: don't care<br>Read: always reads as '0'                                                                                                                                                                                                                                                                                                                                                                    | R      | 0              |
| 2    | DAC IRQ | Pending DAC Interrupts (Read),<br>On a read-access this bit shows a pending DAC interrupt. Pending interrupts<br>are marked with a '1'.<br>An interrupt is acknowledged when the SDR bit is cleared.                                                                                                                                                                                                                          | R      | 0              |
| 1    | SDU     | Sequencer Data Underflow (bit is used to signalize a data underflow condition for the sequencer data RAM)<br>1 = Sequencer Data Underflow (sequencer is ready for the next sequence but the user has not yet confirmed new data in sequencer data RAM).<br>0 = All DAC Data Registers have been updated with new data.                                                                                                        | R      | 1              |
| 0    | SDR     | Sequencer Data Request/Acknowledge (bit is used to signalize data request<br>for the sequencer data RAM)<br>1 = Sequencer Data Request (sequencer is requesting new data in the<br>sequencer data RAM)<br>During the Simultaneous/Sequencer/Trigger Update modes this status bit<br>must be cleared after the sequencer data RAM has been updated with data<br>for the next sequence.<br>The bit is cleared by writing a '1'. | R/C    | 0              |

Table 4-17: DAC Sequencer Status Register



#### 4.3.2.3 DAC Sequencer Timer Register DACSEQTIME (Offset 0x00C8)

| Bit   | Symbol | Description                                                | Access | Reset<br>Value |
|-------|--------|------------------------------------------------------------|--------|----------------|
| 31:16 | -      | Reserved<br>Write: don't care<br>Read: always reads as '0' | R      | 0              |
| 15:0  |        | Sequencer Timer Preload Value                              | R/W    | 0              |

Table 4-18: DAC Sequencer Timer Register

Setting LOADSEL in the DAC Control Register (DACCONT) to 'Sequencer Update' starts the timer. The minimum for the Sequencer Timer Preload Value is 1; the timer will not start if the Sequencer Timer Preload Value is 0.

The sequencer timer is programmable from 100µs to 6.5535s in 100µs steps. The sequencer timer is loaded with the value in the Sequencer Timer Register when a sequence is started. In sequencer timer mode the start of the next sequence is delayed for: Register Value \* 100µs.

The time base for the sequencer timer is derived from an on board 40 MHz oscillator.

#### 4.3.2.4 DAC Data Register DACDATA 1-8 (Offset 0x00D0 - Offset 0x00EC)

| Bit   | Symbol             | Description                                                                                                          | Access | Reset<br>Value |
|-------|--------------------|----------------------------------------------------------------------------------------------------------------------|--------|----------------|
| 31:16 | -                  | Reserved<br>Write: don't care<br>Read: always reads as '0'                                                           | R      | 0              |
| 15:0  | DAC<br>DATA<br>1-8 | DAC Data Value<br>When LOADSEL in the DAC Control Register is set to "00", the DAC output<br>is updated immediately. | R/W    | 0x0000         |

#### Table 4-19: DAC Data Register

After power-on or reset the value of all DAC Data registers are set to 0x8000. The analog output voltage is set to Midscale 0V DC.

The settling time for a full range voltage step is typically 8µs and maximum 10µs.

| Description           | Output Voltage | DAC Data<br>Value (in two's<br>complement) |
|-----------------------|----------------|--------------------------------------------|
| Full Scale Range      | ±10V           |                                            |
| Least Significant Bit | 305.2µV        |                                            |
| FSR - 1LSB            | 9.999695V      | 0x7FFF                                     |
| Midscale + 1LSB       | 305.2µV        | 0x0001                                     |
| Midscale              | 0V             | 0x0000                                     |
| Midscale – 1LSB       | -305.2µV       | 0xFFFF                                     |
| -FSR + 1LSB           | -9.999695V     | 0x8001                                     |
| Full Scale (neg.)     | -10V           | 0x8000                                     |

Table 4-20: DAC Data Coding



## 4.3.3 Digital I/O Registers

| Bit   | Symbol    |                                | Description                                                                                            | Access | Reset<br>Value |
|-------|-----------|--------------------------------|--------------------------------------------------------------------------------------------------------|--------|----------------|
| 31:18 | -         | Reserved                       | Reserved<br>Write: don't care                                                                          |        | 0              |
|       |           | Read: always                   |                                                                                                        |        |                |
| 17    | DAC OUT   | Enable DAC S<br>1 = Override L | sequencer trigger output<br>INEDIR1 and output DAC Sequencer trigger on I/O Line 1<br>NEDIR1 operation | R/W    | 0              |
| 16    | ADC OUT   | 1 = Override L                 | equencer trigger output<br>INEDIR0 and output ADC Sequencer trigger on I/O Line 0<br>NEDIR0 operation  | R/W    | 0              |
| 15    | LINEDIR15 | I/O Line 15                    |                                                                                                        |        | 0              |
| 14    | LINEDIR14 | I/O Line 14                    |                                                                                                        |        | 0              |
| 13    | LINEDIR13 | I/O Line 13                    |                                                                                                        |        | 0              |
| 12    | LINEDIR12 | I/O Line 12                    |                                                                                                        |        | 0              |
| 11    | LINEDIR11 | I/O Line 11                    |                                                                                                        |        | 0              |
| 10    | LINEDIR10 | I/O Line 10                    |                                                                                                        |        | 0              |
| 9     | LINEDIR9  | I/O Line 9                     |                                                                                                        |        | 0              |
| 8     | LINEDIR8  | I/O Line 8                     | 0 = TTL I/O line as Input                                                                              | R/W    | 0              |
| 7     | LINEDIR7  | I/O Line 7                     | 1 = TTL I/O line as Output                                                                             | r/ vv  | 0              |
| 6     | LINEDIR6  | I/O Line 6                     |                                                                                                        |        | 0              |
| 5     | LINEDIR5  | I/O Line 5                     |                                                                                                        |        | 0              |
| 4     | LINEDIR4  | I/O Line 4                     |                                                                                                        |        | 0              |
| 3     | LINEDIR3  | I/O Line 3                     |                                                                                                        |        | 0              |
| 2     | LINEDIR2  | I/O Line 2                     |                                                                                                        |        | 0              |
| 1     | LINEDIR1  | I/O Line 1                     |                                                                                                        |        | 0              |
| 0     | LINEDIR0  | I/O Line 0                     |                                                                                                        |        | 0              |

Table 4-21: Line Direction Register

The reset value of the Line Direction Register is 0x0000. That means all TTL I/O lines are inputs.



| Bit   | Symbol    |                   | Description                                 | Access | Reset<br>Value |
|-------|-----------|-------------------|---------------------------------------------|--------|----------------|
| 31:16 | -         | Reserved          |                                             | R      | 0              |
|       |           | Write: don't care | 9                                           |        |                |
|       |           | Read: always re   | eads as '0'                                 |        |                |
| 15    | LINEDEB15 | I/O Line 15       |                                             |        | 0              |
| 14    | LINEDEB14 | I/O Line 14       |                                             |        | 0              |
| 13    | LINEDEB13 | I/O Line 13       |                                             |        | 0              |
| 12    | LINEDEB12 | I/O Line 12       |                                             | R/W    | 0              |
| 11    | LINEDEB11 | I/O Line 11       |                                             |        | 0              |
| 10    | LINEDEB10 | I/O Line 10       |                                             |        | 0              |
| 9     | LINEDEB9  | I/O Line 9        |                                             |        | 0              |
| 8     | LINEDEB8  | I/O Line 8        | 0 = Debounce disabled for this TTL I/O line |        | 0              |
| 7     | LINEDEB7  | I/O Line 7        | 1 = Debounce enabled for this TTL I/O line  |        | 0              |
| 6     | LINEDEB6  | I/O Line 6        |                                             |        | 0              |
| 5     | LINEDEB5  | I/O Line 5        |                                             |        | 0              |
| 4     | LINEDEB4  | I/O Line 4        |                                             |        | 0              |
| 3     | LINEDEB3  | I/O Line 3        |                                             |        | 0              |
| 2     | LINEDEB2  | I/O Line 2        |                                             |        | 0              |
| 1     | LINEDEB1  | I/O Line 1        |                                             |        | 0              |
| 0     | LINEDEB0  | I/O Line 0        |                                             |        | 0              |

#### 4.3.3.2 Line Debounce Enable Register LINEDEB (Offset 0x0104)

Table 4-22: Line Debounce Enable Register

For the enabled I/O lines a digital debounce filter will be applied. The debounce duration can be programmed in the Line Debounce Time Register LINEDBT. The digital input signal must have duration greater than the programmed debounce duration in order to be recognized as a valid input signal.

The disabled I/O lines will not be filtered.

#### 4.3.3.3 Line Debounce Time Register LINEDBT (Offset 0x0108)

| Bit   | Symbol | Description                                                | Access | Reset<br>Value |
|-------|--------|------------------------------------------------------------|--------|----------------|
| 31:16 | -      | Reserved<br>Write: don't care<br>Read: always reads as '0' | R      | 0              |
| 15:0  |        | Line Debounce Time Value                                   | R/W    | 0              |

Table 4-23: Line Debounce Time Register

The Line Debounce Time Register allows to program the debounce duration from 100ns to 6.55ms. Use following formula to calculate the debounce duration:

Debounce duration = (Line Debounce Time Value \* 100ns) + 100ns

The debounce time is common for all 16 inputs.



### 4.3.3.4 Line Input Register LINEIN (Offset 0x010C)

| Bit   | Symbol   | Description       |                                                                                                                                                                                                              | Access | Reset<br>Value |
|-------|----------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------|
| 31:16 | -        | Reserved          |                                                                                                                                                                                                              |        |                |
|       |          | Write: don't care |                                                                                                                                                                                                              | R      | 0              |
|       |          | Read: always read | ls as '0'                                                                                                                                                                                                    |        |                |
| 15    | LINEIN15 | I/O Line 15       |                                                                                                                                                                                                              |        | 0              |
| 14    | LINEIN14 | I/O Line 14       |                                                                                                                                                                                                              |        | 0              |
| 13    | LINEIN13 | I/O Line 13       |                                                                                                                                                                                                              |        | 0              |
| 12    | LINEIN12 | I/O Line 12       |                                                                                                                                                                                                              |        | 0              |
| 11    | LINEIN11 | I/O Line 11       |                                                                                                                                                                                                              |        | 0              |
| 10    | LINEIN10 | I/O Line 10       | Reflects the actual input state of the debounced TTL I/O<br>lines at all times, including I/O lines configured as output<br>in the LINEDIR (to provide readback functionality)<br>0 = TTL I/O line logic low |        | 0              |
| 9     | LINEIN9  | I/O Line 9        |                                                                                                                                                                                                              |        | 0              |
| 8     | LINEIN8  | I/O Line 8        |                                                                                                                                                                                                              | R      | 0              |
| 7     | LINEIN7  | I/O Line 7        |                                                                                                                                                                                                              | ĸ      | 0              |
| 6     | LINEIN6  | I/O Line 6        | 1 = TTL I/O line logic high                                                                                                                                                                                  |        | 0              |
| 5     | LINEIN5  | I/O Line 5        |                                                                                                                                                                                                              |        | 0              |
| 4     | LINEIN4  | I/O Line 4        |                                                                                                                                                                                                              |        | 0              |
| 3     | LINEIN3  | I/O Line 3        |                                                                                                                                                                                                              |        | 0              |
| 2     | LINEIN2  | I/O Line 2        |                                                                                                                                                                                                              |        | 0              |
| 1     | LINEIN1  | I/O Line 1        |                                                                                                                                                                                                              |        | 0              |
| 0     | LINEIN0  | I/O Line 0        |                                                                                                                                                                                                              |        | 0              |

Table 4-24: Line Input Register



#### 4.3.3.5 Line Output Register LINEOUT (Offset 0x0110)

| Bit   | Symbol    | Description                   |                                                                         | Access | Reset<br>Value |
|-------|-----------|-------------------------------|-------------------------------------------------------------------------|--------|----------------|
| 31:16 | -         | Reserved<br>Write: don't care |                                                                         | R      | 0              |
|       |           | Read: always reads as '0'     |                                                                         |        | Ū              |
| 15    | LINEOUT15 | I/O Line 15                   |                                                                         |        | 0              |
| 14    | LINEOUT14 | I/O Line 14                   |                                                                         |        | 0              |
| 13    | LINEOUT13 | I/O Line 13                   |                                                                         |        | 0              |
| 12    | LINEOUT12 | I/O Line 12                   |                                                                         |        | 0              |
| 11    | LINEOUT11 | I/O Line 11                   |                                                                         |        | 0              |
| 10    | LINEOUT10 | I/O Line 10                   |                                                                         |        | 0              |
| 9     | LINEOUT9  | I/O Line 9                    | Sets output state of the TTL I/O lines. Writes on I/O lines             |        | 0              |
| 8     | LINEOUT8  | I/O Line 8                    | configured as input in the LINEDIR are allowed but will take no effect. | R/W    | 0              |
| 7     | LINEOUT7  | I/O Line 7                    | 0 = TTL I/O line logic low                                              | r(/v/  | 0              |
| 6     | LINEOUT6  | I/O Line 6                    | 1 = TTL I/O line logic high                                             |        | 0              |
| 5     | LINEOUT5  | I/O Line 5                    |                                                                         |        | 0              |
| 4     | LINEOUT4  | I/O Line 4                    |                                                                         |        | 0              |
| 3     | LINEOUT3  | I/O Line 3                    |                                                                         |        | 0              |
| 2     | LINEOUT2  | I/O Line 2                    |                                                                         |        | 0              |
| 1     | LINEOUT1  | I/O Line 1                    |                                                                         |        | 0              |
| 0     | LINEOUT0  | I/O Line 0                    |                                                                         |        | 0              |

Table 4-25: Line Output Register



#### 4.3.3.6 Line Interrupt Enable Register LINEIEN (Offset 0x0114)

| Bit | Symbol     | Description |                                                                                                                           | Access | Reset<br>Value |
|-----|------------|-------------|---------------------------------------------------------------------------------------------------------------------------|--------|----------------|
| 31  | LINEIENN15 | I/O Line 15 | 0 = Disable Interrupt for negative transitions for I/O line<br>1 = Enable Interrupt for negative transitions for I/O line |        | 0              |
| 30  | LINEIENN14 | I/O Line 14 |                                                                                                                           |        | 0              |
| 29  | LINEIENN13 | I/O Line 13 |                                                                                                                           |        | 0              |
| 28  | LINEIENN12 | I/O Line 12 |                                                                                                                           |        | 0              |
| 27  | LINEIENN11 | I/O Line 11 |                                                                                                                           |        | 0              |
| 26  | LINEIENN10 | I/O Line 10 |                                                                                                                           |        | 0              |
| 25  | LINEIENN9  | I/O Line 9  |                                                                                                                           |        | 0              |
| 24  | LINEIENN8  | I/O Line 8  | An interrupt will be generated when the input line                                                                        | R/W    | 0              |
| 23  | LINEIENN7  | I/O Line 7  | changes from 1 to 0.                                                                                                      | K/W    | 0              |
| 22  | LINEIENN6  | I/O Line 6  | For pending interrupts and interrupt acknowledge see the Line Interrupt Status Register LINEIST.                          |        | 0              |
| 21  | LINEIENN5  | I/O Line 5  |                                                                                                                           |        | 0              |
| 20  | LINEIENN4  | I/O Line 4  |                                                                                                                           |        | 0              |
| 19  | LINEIENN3  | I/O Line 3  |                                                                                                                           |        | 0              |
| 18  | LINEIENN2  | I/O Line 2  |                                                                                                                           |        | 0              |
| 17  | LINEIENN1  | I/O Line 1  |                                                                                                                           |        | 0              |
| 16  | LINEIENN0  | I/O Line 0  |                                                                                                                           |        | 0              |
| 15  | LINEIENP15 | I/O Line 15 |                                                                                                                           |        | 0              |
| 14  | LINEIENP14 | I/O Line 14 |                                                                                                                           |        | 0              |
| 13  | LINEIENP13 | I/O Line 13 |                                                                                                                           |        | 0              |
| 12  | LINEIENP12 | I/O Line 12 |                                                                                                                           |        | 0              |
| 11  | LINEIENP11 | I/O Line 11 |                                                                                                                           |        | 0              |
| 10  | LINEIENP10 | I/O Line 10 | 0 = Disable interrupt for positive transitions for I/O line                                                               |        | 0              |
| 9   | LINEIENP9  | I/O Line 9  | 1 = Enable interrupt for positive transitions for I/O line                                                                |        | 0              |
| 8   | LINEIENP8  | I/O Line 8  | An interrupt will be generated when the input line                                                                        | R/W    | 0              |
| 7   | LINEIENP7  | I/O Line 7  | changes from 0 to 1.                                                                                                      |        | 0              |
| 6   | LINEIENP6  | I/O Line 6  | For pending interrupts and interrupt acknowledge see the Line Interrupt Status Register LINEIST.                          |        | 0              |
| 5   | LINEIENP5  | I/O Line 5  |                                                                                                                           |        | 0              |
| 4   | LINEIENP4  | I/O Line 4  |                                                                                                                           |        | 0              |
| 3   | LINEIENP3  | I/O Line 3  |                                                                                                                           |        | 0              |
| 2   | LINEIENP2  | I/O Line 2  |                                                                                                                           |        | 0              |
| 1   | LINEIENP1  | I/O Line 1  |                                                                                                                           |        | 0              |
| 0   | LINEIENP0  | I/O Line 0  |                                                                                                                           |        | 0              |

Table 4-26: Line Interrupt Enable Register

Interrupts are generated only if the Master Interrupt Enable (MIE) is enabled in the Interrupt Control Register ICR.



#### 4.3.3.7 Line Interrupt Status Register LINEIST (Offset 0x0118)

| Bit | Symbol     | Description |                                           | Access | Reset<br>Value |
|-----|------------|-------------|-------------------------------------------|--------|----------------|
| 31  | LINEISTN15 | I/O Line 15 | Interrupt status for negative transitions |        | 0              |
| 30  | LINEISTN14 | I/O Line 14 |                                           |        | 0              |
| 29  | LINEISTN13 | I/O Line 13 |                                           |        | 0              |
| 28  | LINEISTN12 | I/O Line 12 |                                           |        | 0              |
| 27  | LINEISTN11 | I/O Line 11 |                                           |        | 0              |
| 26  | LINEISTN10 | I/O Line 10 |                                           | -      | 0              |
| 25  | LINEISTN9  | I/O Line 9  | Read access:                              |        | 0              |
| 24  | LINEISTN8  | I/O Line 8  | 0 : no interrupt request pending          | R/C    | 0              |
| 23  | LINEISTN7  | I/O Line 7  | 1 : interrupt request pending             | K/C    | 0              |
| 22  | LINEISTN6  | I/O Line 6  | Write access:                             |        | 0              |
| 21  | LINEISTN5  | I/O Line 5  | 1 : clear pending interrupt request       |        | 0              |
| 20  | LINEISTN4  | I/O Line 4  |                                           |        | 0              |
| 19  | LINEISTN3  | I/O Line 3  |                                           |        | 0              |
| 18  | LINEISTN2  | I/O Line 2  |                                           |        | 0              |
| 17  | LINEISTN1  | I/O Line 1  |                                           |        | 0              |
| 16  | LINEISTN0  | I/O Line 0  |                                           |        | 0              |
| 15  | LINEISTP15 | I/O Line 15 |                                           |        | 0              |
| 14  | LINEISTP14 | I/O Line 14 |                                           |        | 0              |
| 13  | LINEISTP13 | I/O Line 13 |                                           |        | 0              |
| 12  | LINEISTP12 | I/O Line 12 |                                           |        | 0              |
| 11  | LINEISTP11 | I/O Line 11 |                                           |        | 0              |
| 10  | LINEISTP10 | I/O Line 10 | Interrupt status for positive transitions |        | 0              |
| 9   | LINEISTP9  | I/O Line 9  | Read access:                              |        | 0              |
| 8   | LINEISTP8  | I/O Line 8  | 0 : no interrupt request pending          | R/C    | 0              |
| 7   | LINEISTP7  | I/O Line 7  | 1 : interrupt request pending             | R/C    | 0              |
| 6   | LINEISTP6  | I/O Line 6  | Write access:                             |        | 0              |
| 5   | LINEISTP5  | I/O Line 5  | 1 : clear pending interrupt request       |        | 0              |
| 4   | LINEISTP4  | I/O Line 4  |                                           |        | 0              |
| 3   | LINEISTP3  | I/O Line 3  |                                           |        | 0              |
| 2   | LINEISTP2  | I/O Line 2  |                                           |        | 0              |
| 1   | LINEISTP1  | I/O Line 1  |                                           |        | 0              |
| 0   | LINEISTP0  | I/O Line 0  |                                           |        | 0              |

Table 4-27: Line Interrupt Status Register



## 4.3.4 Counter Registers

#### 4.3.4.1 Counter Preload Register CNTPRL (Offset 0x0120)

| Bit  | Symbol | Description                                                                                                                                                                                                                                                                                                                           | Access | Reset<br>Value |
|------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------|
| 31:0 | CNTPRL | Counter Preload Register<br>The value of this register can be loaded into the counter by:<br>- Setting bit 4 (LCNT) of the Channel Command Register<br>- An impulse on the Control-Input when the 'Load on Control'-mode is active<br>- Automatically in the 'Divide-by-N'-mode every time the counter creates a<br>borrow or a carry | R/W    | 0              |

Table 4-28: Counter Preload Register

#### 4.3.4.2 Counter Compare Register CNTCMP (Offset 0x0124)

| Bit  | Symbol | Description                                                                                                                                                                                                    | Access | Reset<br>Value |
|------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------|
| 31:0 | CNTCMP | Counter Compare Register<br>Every time the counter matches the Counter Compare Register value, bit 2<br>(MAT) of the Channel Status Register is set to '1' and, if enabled, a Match<br>Interrupt is generated. |        | -1             |

Table 4-29: Counter Compare Register

#### 4.3.4.3 Counter Data Register CNTDATA (Offset 0x0128)

| Bit  | Symbol  | Description                                                                                                                                                                                                                                                                                                        | Access | Reset<br>Value |
|------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------|
| 31:0 | CNTDATA | Counter Data Register<br>This Register contains the actual Counter Data Value.<br>A Latch Mode event loads the current counter value into the Counter Data<br>Register. The counter value is latched until the Counter Data Register is<br>read or when bit 5 (CDLT) of the Channel Status Register is set to '1'. | R      | 0              |

#### Table 4-30: Counter Data Register

The Counter Data Register will not load again while the latch is active. If a Latch Mode event occurs while the Counter Data Register Latch is active, the OVFL bit in the Counter Status Register will be set to indicate that data was lost.

To avoid data inconsistencies this register is developed for a long word (32 bit) read/write access. Byte or word accesses on this register are not supported and will fail.



### 4.3.4.4 Counter Control Register CNTCONT (Offset 0x012C)

| Bit   | Symbol | Description                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                  |                                                                                                    |                                |           | Reset<br>Value |
|-------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------|--------------------------------|-----------|----------------|
| 31:15 | -      | Reserved<br>Write: don't care<br>Read: always reads as '0'                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                  |                                                                                                    |                                | -         | 0              |
|       |        | Input Polarity                                                                                                                                                                                                                                                                                                                                         | rity Control                                                                                                                                                                                                                                     | can be used to a                                                                                   | dapt the counter inputs to the |           |                |
|       |        | POL                                                                                                                                                                                                                                                                                                                                                    | Input                                                                                                                                                                                                                                            | Polarity                                                                                           |                                |           |                |
| 14:12 | POL    | 14                                                                                                                                                                                                                                                                                                                                                     | TTL I/O line                                                                                                                                                                                                                                     | e 4 0 = high a                                                                                     | active, 1 = low active         | R/W       | 000            |
|       |        | 13                                                                                                                                                                                                                                                                                                                                                     | TTL I/O line                                                                                                                                                                                                                                     | e 3 0 = high a                                                                                     | active, 1 = low active         |           |                |
|       |        | 12                                                                                                                                                                                                                                                                                                                                                     | TTL I/O line                                                                                                                                                                                                                                     | e 2 0 = high a                                                                                     | active, 1 = low active         |           |                |
| 11    | CIEN   | 0 = Control Mo<br>1 = Control Mo<br>An interrupt wil<br>For pending int                                                                                                                                                                                                                                                                                | Enable Control Mode Interrupt<br>0 = Control Mode Interrupt disabled<br>1 = Control Mode Interrupt enabled<br>An interrupt will be generated on a control mode event.<br>For pending interrupts and interrupt acknowledge see the Counter Status |                                                                                                    |                                |           |                |
| 10    | MIEN   | Register CNTSTAT.         Enable Match Interrupt         0 = Match Interrupt disabled         1 = Match Interrupt enabled         An interrupt will be generated when the counter value matches the Counter         Compare Register CNTCMP.         For pending interrupts and interrupt acknowledge see the Counter Status         Register CNTSTAT. |                                                                                                                                                                                                                                                  |                                                                                                    |                                |           | 0              |
| 9:7   | ZCM    | Control Mode<br>The Control Mod<br>(I/O line 4).                                                                                                                                                                                                                                                                                                       | <b>ZCM</b><br>000<br>001<br>010<br>011<br>100                                                                                                                                                                                                    | Control Mode<br>No Control Mode<br>Load Mode<br>Latch Mode<br>Gate Mode<br>Reset Mode              |                                | ut<br>R/W | 000            |
| 6:5   | SCM    | Count Mode<br>The Count Mod<br>See chapter 'C                                                                                                                                                                                                                                                                                                          | <b>SCM</b><br>00<br>01<br>10                                                                                                                                                                                                                     | es the behavior of<br>Count Mode<br>Cycling Count<br>Divide-by-N<br>Single Cycle<br>' for details. |                                | R/W       | 00             |
|       |        | Internal Clock                                                                                                                                                                                                                                                                                                                                         | Prescaler<br>DIV                                                                                                                                                                                                                                 | Prescaler                                                                                          | Clock frequency                |           |                |
| 1.0   | CLKDIV | 00                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                  | 1x<br>2x                                                                                           | 40 MHz                         | R/W       | 00             |
| 4:3   | GLKDIV | 01                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                  | 2x<br>4x                                                                                           | 20 MHz<br>10 MHz               | K/W       | 00             |
|       |        | 11                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                  | 4x<br>8x                                                                                           | 5 MHz                          |           |                |
|       |        |                                                                                                                                                                                                                                                                                                                                                        | I                                                                                                                                                                                                                                                | -                                                                                                  |                                |           |                |
| 2:0   | INPUT  | Input Mode                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                  |                                                                                                    |                                | R/W       | 000            |



| Bit | Symbol |      | Description                            |                                |                          |  | Reset<br>Value |
|-----|--------|------|----------------------------------------|--------------------------------|--------------------------|--|----------------|
|     |        | coun | Input M<br>iter inte<br>a 1x, 2>       |                                |                          |  |                |
|     |        | IN   | IPUT                                   | Input Mode                     | Input Source             |  |                |
|     |        | (    | 000 Counter disabled -                 |                                |                          |  |                |
|     |        | (    | 001                                    | Timer Mode Up                  | Internal Clock Prescaler |  |                |
|     |        | (    | 010                                    | Timer Mode Down                | Internal Clock Prescaler |  |                |
|     |        | (    | 011                                    | Direction Count I/O line 2 & 3 |                          |  |                |
|     |        | 1    | 100                                    | Up/Down Count                  | I/O line 2 & 3           |  |                |
|     |        | 1    | 101                                    | Quadrature Count 1x            | I/O line 2 & 3           |  |                |
|     |        | 1    | 110                                    | Quadrature Count 2x            | I/O line 2 & 3           |  |                |
|     |        | 1    | 111 Quadrature Count 4x I/O line 2 & 3 |                                |                          |  |                |
|     |        | See  | chapter                                | · 'Input Modes' for details.   |                          |  |                |

Table 4-31: Counter Control Register

Interrupts are generated only if the Master Interrupt Enable (MIE) is enabled in the Interrupt Control Register ICR.



### 4.3.4.5 Counter Status Register CNTSTAT (Offset 0x0130)

| Bit   | Symbol | Description                                                                                                                                                                                                                                                                         |     | Reset<br>Value |
|-------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|----------------|
| 31:10 | -      | Reserved<br>Read: always reads as '0'                                                                                                                                                                                                                                               | R   | 0              |
| 9     | CIRQ   | Pending Control Mode Interrupts (Read),<br>Interrupt acknowledge (Write)<br>On a read-access this bit shows a pending Control Mode Interrupt. Pending<br>interrupts are marked with a '1'.<br>An interrupt is acknowledged by writing a '1' to this bit.                            | R/C | 0              |
| 8     | MIRQ   | Pending Match Interrupts (Read),<br>Interrupt acknowledge (Write)<br>On a read-access this bit shows a pending Match Interrupt. Pending<br>interrupts are marked with a '1'.<br>An interrupt is acknowledged when the MAT bit is cleared.                                           | R   | 0              |
| 7     | SGL    | Single Cycle active<br>In Single Cycle counting mode this bit is set to '1' if the counter is enabled.                                                                                                                                                                              | R   | 0              |
| 6     | OVFL   | Counter Data Register Latch Overflow<br>If a Latch Mode event occurs while the Counter Data Register Latch is<br>active, this bit will be set to indicate that data was lost. This bit must be reset<br>by writing a '1' to this bit.                                               | R/C | 0              |
| 5     | CDLT   | Counter Data Register Latch<br>This bit is set to '1', when the Counter Data Register is latched due to a<br>'Latch on Control. This bit is cleared after a read access to the Output<br>Register or by writing a '1' to this bit.                                                  |     | 0              |
| 4     | DIR    | Count Direction<br>This bit indicates the direction, the counter is counting to. '1' indicates up, '0'<br>indicates down. In the 'Up/Down Count' mode this bit indicates the direction<br>at the last count. In the 'Direction Count' mode this bit corresponds to the Y-<br>input. |     | 0              |
| 3     | SGN    | Sign<br>The Sign bit is set to '1' when the counter overflows, and set to '0' when the<br>counter underflows.<br>After reset or power-up this bit should be considered as "don't care" until the<br>first Carry or Borrow occurred.                                                 |     | 0              |
| 2     | MAT    | Match<br>This bit is set to '1' when the counter value matches the value of the Counter<br>Compare Register. This bit must be reset by writing a '1' to this bit.                                                                                                                   |     | 0              |
| 1     | CRY    | Carry<br>This bit is set to '1' when the counter changes from 0xFFFFFFFF to<br>0x00000000. This bit must be reset by writing a '1' to this bit.                                                                                                                                     | R/C | 0              |
| 0     | BOR    | Borrow<br>This bit is set to '1' when the counter changes from 0x00000000 to<br>0xFFFFFFF. This bit must be reset by writing a '1' to this bit.                                                                                                                                     | R/C | 0              |

Table 4-32: Counter Status Register



## 4.3.4.6 Counter Command Register CNTCOM (Offset 0x0134)

| Bit  | Symbol | Description                                                                                                                                                   | Access | Reset<br>Value |
|------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------|
| 31:2 | -      | Reserved<br>Write: don't care                                                                                                                                 | -      | -              |
| 1    | LCNT   | Load Counter<br>Write '1' to load the counter with the value of the Counter Preload Register<br>CNTPRL. This bit is cleared immediately after a write access. | W      | 0              |
| 0    | RCNT   | Reset Counter<br>Write '1' to reset the counter. This bit is cleared immediately after a write<br>access.                                                     | W      | 0              |

Table 4-33: Counter Command Register



### 4.3.5 Interrupt Control Register ICR (Offset 0x0140)

| Bit  | Symbol  | Description                                                                                                               |     | Reset<br>Value |
|------|---------|---------------------------------------------------------------------------------------------------------------------------|-----|----------------|
| 31:8 | -       | Reserved<br>Write: don't care<br>Read: always reads as '0'                                                                | R   | 0              |
| 7    | CIRQ    | Pending Control Mode Interrupt<br>This interrupt must be acknowledged in the Counter Status Register<br>CNTSTAT           | R   | 0              |
| 6    | MIRQ    | Pending Match Interrupt<br>This interrupt must be acknowledged in the Counter Status Register<br>CNTSTAT                  |     | 0              |
| 5    | LINEIST | Pending Digital I/O Line IRQ<br>This interrupt must be acknowledged in the Line Interrupt Status Register<br>LINEIST      |     | 0              |
| 4    | DAC IRQ | Pending DAC Sequencer Interrupt<br>This interrupt must be acknowledged in the DAC Sequencer Status Register<br>DACSEQSTAT |     | 0              |
| 3    | SEQ IRQ | Pending ADC Sequencer Interrupt<br>This interrupt must be acknowledged in the ADC Sequencer Status Register<br>ADCSEQSTAT |     | 0              |
| 2    | IRQST   | Pending IRQ after Settling Time<br>This interrupt must be acknowledged in the ADC Status Register ADCSTAT                 |     | 0              |
| 1    | IRQC    | Pending IRQ after Conversion<br>This interrupt must be acknowledged in the ADC Status Register ADCSTAT                    |     | 0              |
| 0    | MIE     | Master Interrupt Enable<br>0 = All interrupts requests are disabled<br>1 = Interrupts requests are enabled                | R/W | 0              |

Table 4-34: Interrupt Control Register

The interrupt flags in this register are informational only. All interrupts must be acknowledged in their associated registers.

Interrupts are generated only if the Master Interrupt Enable (MIE) is enabled in the Interrupt Control Register ICR.



## 4.4 ADC Sequencer Data RAM

#### PCI Base Address: PCI Base Address 3 (Offset 0x1C in PCI Configuration Space).

The ADC Sequencer Data RAM is a 32 x 16 bit wide RAM storing the converted data values.

Each channel has its own ADC Data location.

The ADC Sequencer Data RAM is updated after every full sequencer cycle. Only the channels enabled in the ADC Sequencer Instruction RAM are updated.

| Offset to PCI Base<br>Address 3 | Description                   | Size<br>(Bit) |
|---------------------------------|-------------------------------|---------------|
| 0x00                            | Channel 1 ADC Sequencer Data  | 16            |
| 0x02                            | Channel 2 ADC Sequencer Data  | 16            |
|                                 |                               |               |
| 0x3C                            | Channel 31 ADC Sequencer Data | 16            |
| 0x3E                            | Channel 32 ADC Sequencer Data | 16            |

 Table 4-35:
 ADC Sequencer Data RAM Space Address Map

## 4.5 ADC/DAC Calibration Data ROM

PCI Base Address: PCI Base Address 4 (Offset 0x20 in PCI Configuration Space).

The calibration data values are determined at factory and stored in this ROM space.

There is one Offset Error value and one Gain Error value for each ADC gain which are valid for all 32 channels. For the DACs again there is an Offset Error value and a Gain Error value for each DAC channel.

See the Programming Hints chapter for data correction formulas.

The calibration data is read only.

The calibration data is available 500 µs after reset.

| Offset to PCI Base<br>Address 4 | Description                        | Size<br>(Bit) |
|---------------------------------|------------------------------------|---------------|
| 0x00                            | ADC Offset <sub>ERROR</sub> Gain 1 | 16            |
| 0x02                            | ADC Gainerror Gain 1               | 16            |
| 0x04                            | ADC Offseterror Gain 2             | 16            |
| 0x06                            | ADC Gain <sub>ERROR</sub> Gain 2   | 16            |
| 0x08                            | ADC Offset <sub>ERROR</sub> Gain 4 | 16            |
| 0x0A                            | ADC Gain <sub>ERROR</sub> Gain 4   | 16            |
| 0x0C                            | ADC Offseterror Gain 8             | 16            |
| 0x0E                            | ADC Gainerror Gain 8               | 16            |
| 0x10                            | DAC Channel 1 Offseterror          | 16            |
| 0x12                            | DAC Channel 1 Gainerror            | 16            |
| 0x14                            | DAC Channel 2 Offseterror          | 16            |
| 0x16                            | DAC Channel 2 Gainerror            | 16            |



| 0x18 | DAC Channel 3 Offset <sub>ERROR</sub>    | 16 |  |  |
|------|------------------------------------------|----|--|--|
| 0x1A | DAC Channel 3 Gainerror                  | 16 |  |  |
| 0x1C | DAC Channel 4 Offseterror                | 16 |  |  |
| 0x1E | DAC Channel 4 Gainerror                  | 16 |  |  |
| 0x20 | DAC Channel 5 Offseterror                | 16 |  |  |
| 0x22 | DAC Channel 5 Gainerror                  | 16 |  |  |
| 0x24 | DAC Channel 6 Offset <sub>ERROR</sub>    | 16 |  |  |
| 0x26 | DAC Channel 6 Gainerror                  | 16 |  |  |
| 0x28 | DAC Channel 7 Offset <sub>ERROR</sub>    | 16 |  |  |
| 0x2A | DAC Channel 7 Gainerror                  | 16 |  |  |
| 0x2C | DAC Channel 8 Offset <sub>ERROR</sub> 16 |    |  |  |
| 0x2E | DAC Channel 8 Gain <sub>ERROR</sub>      | 16 |  |  |

Table 4-36: ADC/DAC Calibration ROM Data Space Address Map



# 5 **Configuration Hints**

## 5.1 Local Software Reset

A Local Software Reset signal may be used to reset the on board local logic.

The local reset is active during PCI reset or if the PCI Adapter Software Reset bit is set in the Miscellaneous Control Register CNTRL (offset 0x50) in the PCI Controller Register Space.

#### CNTRL[30] PCI Adapter Software Reset:

Value of 1 issues a reset to the local logic. The local logic remains in this reset condition until the PCI Host clears the bit. The contents of the PCI Controller Configuration Registers are not reset.



# 6 Programming Hints

## 6.1 Data Correction

There are two errors which affect the DC accuracy of the ADC and the DACs.

• Offset Error:

ADC: The data value when converting with the input connected to its own ground in single-ended mode, or with shorted inputs in differential mode. This error is corrected by subtracting the known error from the readings.

DAC: The data value that is required to get a zero voltage output signal. This error is corrected by subtracting the known error from the data value.

• Gain Error:

ADC: The difference between the ideal gain and the actual gain of the programmable gain amplifier and the ADC. It is corrected by multiplying the reading with a correction factor.

DAC: The difference between the ideal gain and the actual gain of the DAC. It is corrected by multiplying the data value with a correction factor.

The data correction values are obtained during factory calibration and are stored in the Calibration Data ROM.

### 6.1.1 ADC Correction Formula

Please use the total 16 bit data register value for the ADC correction formula.

The basic formula for correcting any ADC reading for the TPMC851 (bipolar input voltage range) is:

Value = Reading 
$$\cdot \left(1 - \frac{Gain_{corr}}{131072}\right) - \frac{Offset_{corr}}{4}$$

Value is the corrected result.

Reading is the data read from the ADC Data Register.

*Gaincorr* and *Offsetcorr* are the ADC correction factors from the Calibration Data ROM stored for each gain factor and are the same for all channel 1-32.

The correction values are stored as two's complement 16 bit values in the range -32768 to 32767. For higher accuracy they are scaled to ¼ LSB.

Floating point arithmetic or scaled integer arithmetic is necessary to avoid rounding error while computing above formula.



### 6.1.2 DAC Correction Formula

The basic formula for correcting any DAC value is:

$$Data = Value \cdot \left(1 - \frac{Gain_{corr}}{131072}\right) - \frac{Offset_{corr}}{4}$$

Value is the desired DAC value.

Data is the corrected DAC value that must be sending to the DAC.

*Gaincorr* and *Offsetcorr* are the DAC correction values from the Calibration Data ROM. They are stored separately for each of the 8 DAC channels.

The correction values are stored as two's complement byte wide values in the range from -32768 to +32767. For higher accuracy they are scaled to 1/4 LSB.

Floating point arithmetic or scaled integer arithmetic must be used to avoid rounding errors in computing above formula.

## 6.2 ADC Operating Modes

The ADC part of the TPMC851 can operate in two modes: the Manual Mode, with little or none support through automation, and the Sequencer Mode, with large support through automation.

Manual Mode

In this mode, the converter operation relies on the user. The channel and gain are set by the user, and the user has large influence on the converter operation.

Use this mode to convert specific channels and to control conversion timing or to read a channel repeatedly without the need to await the settling time.

Sequencer Mode

In this mode almost everything is automated and the converter operation is transparent to the user.

Use this mode to convert all channels at specific time intervals, or to always have current data available.

### 6.2.1 Manual Mode

The Manual Mode is useful if direct control of converter operation is needed. Setup the desired channel and gain in the ADCCONT register. If the "Automatic Settling Time Control" is deactivated, the user has to wait until the ADC\_SETTL flag reads '0'. Then the conversion can be started with a write access to the ADC Conversion Start Register ADCCONV. If the Automatic Settling Time Control is activated, the conversion starts automatically after the settling time has elapsed.

It is possible to select the next channel and/or gain in the ADCCONT register immediately after the write to the ADC Conversion Start Register ADCCONV. The conversion and the settling time will then proceed simultaneously.

The conversion data is available in the ADCDATA register when the ADC\_BUSY flag in the ADCSTAT register reads as '0'.

If interrupts are enabled, two interrupts will be generated: the first interrupt is generated when the settling time has elapsed (and the Automatic Settling Time Control is deactivated); the second interrupt is generated when the conversion has finished. Using the interrupts exempts from polling the ADC\_SETTL and ADC\_BUSY flags.



Without Automatic Settling Time Control:

- → Setup the conversion in the ADC Control Register ADCCONT
- → Poll for SETTL\_BUSY flag
- → After settling time has elapsed, write to the ADC Conversion Start Register ADCCONV to start conversion
- → Poll for ADC\_BUSY flag
- → After conversion time has elapsed, read conversion data in the ADC Data Register ADCDATA

With Automatic Settling Time Control:

- → Setup the conversion in the ADC Control Register ADCCONT
- → Poll for SETTL\_BUSY flag
- → Poll for ADC\_BUSY flag
- $\rightarrow$  After conversion time has elapsed, read conversion data in the ADC Data Register ADCDATA

### 6.2.2 Sequencer Mode

The Sequencer Mode is very useful for periodic measurements or to always provide actual conversion data. The sequencer converts all enabled ADC channels and stores the results in the Sequencer Data RAM. After a programmable time the sequencer repeats the sequence.

To use the sequencer, all channels must be configured for the sequence in the Sequencer Instruction RAM. In the Sequencer Instruction RAM the channels are enabled for the sequence, and the gain and the mode (single-ended or differential) are selected.

Once the sequencer is started, all enabled channels are converted and the results are stored in the Sequencer Data RAM. When the last sequencer instruction has been completed, the Data Available Flag DATA\_AV in the Sequencer Status Register (ADCSEQSTAT) is set to '1' and, if enabled, an interrupt request will be asserted. The user can now read the ADC data from the Sequencer Data RAM (note: only the enabled channels are updated; Channels not enabled in the Sequencer Instruction RAM are not updated and may contain invalid data from former conversions). After that, the DATA\_AV flag must be cleared by writing a '1' to the Sequencer Status Register ADCSEQSTAT bit 0.

The repeat frequency of the sequencer can be programmed in the Sequencer Timer Register. The Sequencer Timer is programmable from 100µs to 6.5535s in steps of 100µs. Whenever the timer reaches the programmed value, the sequencer starts a new sequence.

A special function is the Sequencer Continuous Mode. It is activated if the Sequencer Timer Register is set to 0x0000. In this mode the sequencer immediately starts a new sequence when the actual sequence has been completed. If the sequencer is in Sequencer Continuous Mode, the user can read valid data from the Sequencer Data RAM at any time. The Sequencer Data RAM locations of the enabled ADC channels are updated with every sequence.

If the Sequencer Continuous Mode is active, the Timer Error Flag (TIMER\_ERROR) and the Data Overflow Error Flag (DATA\_OVERFLOW\_ERROR) are not active and will read as '0'. Clearing the Data Available Flag DATA\_AV is not necessary in the Sequencer Continuous Mode (it will not produce an interrupt), but it may be useful in order to monitor the completion of the sequences.

The sequencer may also be triggered by an external signal instead of the timer. In this case the Timer Error Flag (TIMER\_ERROR) is not active. A new external trigger is accepted only after a sequence has completed. An external trigger while the sequencer runs is ignored.

The update rate depends on the number of enabled channels:

Update Rate =  $16\mu s \cdot number of enabled channels$ 



#### 6.2.2.1 Sequencer Errors

If the sequencer detects an error, it will stop after the last instruction and sets the corresponding error flag in the Sequencer Status Register SEQSTAT.

| Error                    | Description                                                                                                                                                                                                   | Sequencer Action                                                                                                                                            | User Action                                                                                                                                                                          |
|--------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Data Overflow<br>Error   | Error occurs if the sequencer<br>has new data to store but the<br>user has not yet<br>acknowledged that the data<br>from the previous sequence<br>has been read out.<br>(not in Sequencer Continuous<br>Mode) | Sequencer stops after the last<br>instruction is done.<br>Data Overflow Error Flag is set.<br>If enabled, an interrupt request will<br>be asserted.         | Write a '1' to the Sequencer Status<br>Register bit 1.<br>Make sure the Sequencer Data is<br>read and acknowledged within the<br>programmed Sequence Time.<br>Start Sequencer again. |
| Timer Error              | Error occurs if the<br>programmed Sequencer Time<br>is shorter than the sequence<br>itself.<br>(not in Sequencer Continuous<br>Mode)                                                                          | Sequencer stops after the last<br>instruction is done.<br>Timer Error Flag is set.<br>If enabled, an interrupt request will<br>be asserted.                 | Write a '1' to the Sequencer Status<br>Register bit 2.<br>Program a larger Sequence Time.<br>Start Sequencer again.                                                                  |
| Instruction RAM<br>Error | Error occurs if the no channel<br>is enabled for the sequence<br>(bit 1 of Sequencer Instruction<br>RAM byte) and the Sequencer<br>is started.                                                                | Sequencer stops after the last<br>instruction is done.<br>Instruction RAM Error Flag is set.<br>If it is enabled, an interrupt request<br>will be asserted. | Write a '1' to the Sequencer Status<br>Register bit 3.<br>Correct the Sequencer Instruction<br>RAM setting.<br>Start Sequencer again.                                                |

Table 6-1 : Sequencer Errors

If the Sequence Timer Register is set to 0x0000 (Sequencer Continuous Mode) the sequencer ignores the data overflow. The Data Overflow Error Flag is always read as '0' in this mode.



### 6.2.3 Application Examples

The following examples all use interrupts. The use of interrupts can be replaced by polling the according status flags in the ADC Status Register or the Sequencer Status Register.

#### 6.2.3.1 Fastest Conversion of an arbitrary Single Channel

- → Program the desired channel and gain in the ADC Control Register ADCCONT. Activate the Automatic Settling Time Control (ASTC = '1') and the IRQ after Conversion (IRQC = '1')
- → The channel is now converted without any further user action. After completion of the conversion an interrupt is issued which signals that the conversion data is available in the ADCDATA Register
- → Acknowledge the Interrupt in the ADC Status Register ADCSTAT (ADC\_READY = '1') and read ADCDATA



Figure 6-1 : Flow: Fastest conversion of an arbitrary single channel

Conversion time is approx. 17.25µs.

#### 6.2.3.2 Fastest Conversion of a specific Single Channel

- → Program the ADC Control Register with desired channel and gain and activate the IRQ after Settling Time (IRQS = '1') and the IRQ after Conversion (IRQC = '1')
- → When the IRQ after Settling Time is issued, the channel is ready for conversion. Write to the ADC Conversion Start Register ADCCONV and acknowledge the Interrupt in the ADC Status Register ADCSTAT (SETTL\_IRQ = '1')



- → After completion of the conversion an IRQ after Conversion is issued which signals that the conversion data is available in the ADCDATA Register
- → Write again to the ADC Conversion Start Register ADCCONV to start the next conversion of this channel, acknowledge the Interrupt in the ADC Status Register ADCSTAT (ADC\_IRQ = '1') and read ADCDATA.





Conversion time is approx 1.25µs, as long as neither the channel nor the gain is changed (ADC throughput rate up to 250ksps).



#### 6.2.3.3 Periodic Conversion of multiple Channels

- → Activate the channels to be converted and program the gain in the Sequencer Instruction RAM
- $\rightarrow$  Set the sequencer period in the ADC Sequencer Timer Register ADCSEQTIMER
- → Enable the Sequencer Interrupt SEQ\_INT\_ENA and start the Sequencer in the Sequencer Control Register ADCSEQCONT
- → After completion of the sequence a Sequencer Interrupt is issued which signals that the conversion data is available in the Sequencer Data RAM
- → Acknowledge the Interrupt and clear the DATA\_AV flag in the ADC Sequencer Status Register ADCSEQSTAT (SEQ\_IRQ = '1') and read the Sequencer Data RAM







#### 6.2.3.4 Continuous Conversion of multiple Channels

- → Activate the channels to be converted and program the gain and mode of these channels in the Sequencer Instruction RAM
- → Set the Sequencer Timer Register ADCSEQTIMER to 0x0000
- → Start the Sequencer in the Sequencer Control Register ADCSEQCONT
- $\rightarrow$  Read the data from the Sequencer Data RAM as needed.



Figure 6-4 : Flow: Continuous conversion of multiple channels



## 6.3 DAC Operating Modes

The DAC part of the TPMC851 can operate in two modes – Immediate Update or Simultaneous Update. These modes are configured with the Load Mode Select (LOADSEL) bits in the DAC Control Register DACCONT.

| LOADSEL[1:0]     | Load Mode                                                                                                    |  |  |  |  |  |
|------------------|--------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Immediate Update | Immediate Update                                                                                             |  |  |  |  |  |
| 00               | Immediate Update:<br>The DAC outputs are updated immediately on a<br>write access to a DAC Data Register     |  |  |  |  |  |
| Simultaneous Up  | date                                                                                                         |  |  |  |  |  |
| 01               | Simultaneous Update:<br>All DAC outputs are updated simultaneously when<br>LOADDAC is set to '1'             |  |  |  |  |  |
| 10               | Sequencer Update:<br>All DAC outputs are updated simultaneously when<br>the DAC Sequencer Timer reaches zero |  |  |  |  |  |
| 11               | Trigger Update:<br>All DAC outputs are updated simultaneously by an<br>external trigger (Dig I/O Line 1)     |  |  |  |  |  |

Table 6-2 : DAC Load Modes

### 6.3.1 Immediate Update

The DACs are updated immediately on a write access to a DAC Data Register. Use this mode if single channels need to be updated on an irregular base.

### 6.3.2 Simultaneous Update

Write accesses to the DAC Data Registers don't immediately update the DACs. Instead this data is buffered until a trigger event. This trigger event simultaneously updates all DACs with the buffered data. The Simultaneous Update Mode divides into three sub modes. These modes vary in the source for the trigger event:

- Simultaneous Update: The DACs are updated simultaneously when LOADDAC in the DAC Control Register DACCONT is set to '1'. Use this mode if all channels need to be updated on an irregular base.
- Sequencer Update: All DAC outputs are updated simultaneously when the DAC Sequencer Timer reaches zero. Use this mode if all channels need to be updated on a regular base.
- Trigger Update: All DAC outputs are updated simultaneously by an external trigger (Dig I/O Line 1). Use this mode if all channels need to be updated on an external event.

Before a simultaneous update all DACs should be loaded with new data via the DAC Data Registers. If a channel was not loaded with new data, it will use the old data previously buffered.

Allow the DAC outputs to settle for approx. 10µs before performing a new DAC update.



## 6.4 Digital TTL I/O

Note that some digital inputs are internally used in the other parts of the TPMC851:

TTL I/O line 0 as ADC sequencer trigger

TTL I/O line 1 as DAC sequencer trigger

TTL I/O line 2 and TTL I/O line 3 as counter inputs

TTL I/O line 4 as counter control input

Normally the usage of these digital I/O lines is not subject to any restrictions, as long as they are used as inputs (i.e. as trigger for a sequencer). Exceptions are I/O lines 0 and 1, these can also be used as sequencer trigger output.

If ADC\_OUT in the Line Direction Register LINEDIR is set to '1', the trigger signal for the ADC sequencer is available for external use on Dig I/O Line 0.

If DAC\_OUT in the Line Direction Register LINEDIR is set to '1', the trigger signal for the DAC sequencer is available for external use on Dig I/O Line 1.

In this case the settings in the Line Direction Register for these I/O lines (LINEDIR0 resp. LINEDIR1) are overridden and they are always used as output. Writes in the Line Output Register to these I/O lines (LINEOUT0 resp. LINEOUT1) have no effect.

Avoid to use this configuration while the sequencer is set to wait for an external trigger (ADC: SEQ\_TRIG = 1; DAC: LOAD\_SEL = 11). This will cause the sequencer to lock.

If it is required to use the I/O line as sequencer trigger input and output at the same time, this can be achieved with following solution:

- $\rightarrow$  Configure the sequencer to wait for an external trigger (ADC: SEQ\_TRIG = 1; DAC: LOAD\_SEL = 11)
- $\rightarrow$  Configure the I/O Line as output (ADC: LINEDIR0 = 1; DAC: LINEDIR1 = 1)
- $\rightarrow$  Trigger the sequencer with a write to the Line Output Register (ADC: LINEOUT0 = 1; DAC: LINEOUT1 = 1)



## 6.5 Counter Operating Modes

The general purpose counter of the TPMC851 offers 3 Input Modes, 2 Count Modes and 4 Control Modes.

### 6.5.1 Input Modes

The Input Mode determines the input source for the counter and how the counter interprets these input signals:

| Input Mode       | I/O Line 2   | I/O Line 3                | I/O Line 4            |
|------------------|--------------|---------------------------|-----------------------|
| Timer Mode       | -            | -                         |                       |
| Direction Count  | Count        | Count direction (up/down) | Available for Control |
| Up/Down Count    | Count UP     | Count DOWN                | Modes                 |
| Quadrature Count | Quadrature X | Quadrature Y              |                       |

Changing the input mode does not affect the counter reading. If no input mode is selected, the counter is disabled.

#### 6.5.1.1 Timer Mode

In Timer mode the counter uses an internal clock prescaler as input:

| Bits | Prescaler | Clock frequency |
|------|-----------|-----------------|
| 00   | 1x        | 40 MHz          |
| 01   | 2x        | 20 MHz          |
| 10   | 4x        | 10 MHz          |
| 11   | 8x        | 5 MHz           |

Table 6-4 : Clock Prescaler

#### 6.5.1.2 Direction Count

The counter acts as up/down counter. Counting pulses are generated when a transition from low to high of the I/O Line 2 is detected. The I/O Line 3 determines the count direction. I/O Line 3 = 11 is up, I/O Line 3 = 0 is down.

| I/O Line 3 | Count Direction |
|------------|-----------------|
| 0          | Down            |
| 1          | Up              |

Table 6-5 : Count Directions

#### 6.5.1.3 Up/Down Count

The counter acts as up/down counter. Counting pulses are generated when a transition from low to high of either the I/O Line 2 or the I/O Line 3 is detected. The I/O Line 2 counts up, the I/O Line 3 counts down. Simultaneous transitions on both I/O lines do not generate a counting pulse.



#### 6.5.1.4 Quadrature Count

The counter acts as quadrature counter. The quadrature inputs can be interpreted as 1x, 2x or 4x counting. 1x lets the counter count once for each full cycle of the quadrature inputs, 2x lets the counter count once for each half cycle of the quadrature inputs and 4x lets the counter count once for each quarter cycle of the quadrature inputs. The count direction (increase or decrease) is determined by the relative phase of the Quadrature X- and Quadrature Y-signals.



Figure 6-5: Quadrature Signals

### 6.5.2 Count Modes

In normal operation, the counter is a cycling counter. Additional two Count Modes are available. The Count Modes are available for every Input Mode.

#### 6.5.2.1 Divide-by-N

The counter is enabled in the Channel Control Register and will run until disabled. The counter is loaded with the content of the preload register every time the counter creates a borrow or a carry. This mode assumes that the counter counts to one direction only.

#### 6.5.2.2 Single Cycle

The counter is enabled in the Channel Control Register and will start on a manual preload or reset in the Channel Command Register or on a control mode event in load or reset mode.

The counter stops when it creates a borrow or a carry.

### 6.5.3 Control Modes

The Control Mode determines how I/O Line 4 is interpreted. A control mode event generates interrupts, if the Control Mode Interrupt is enabled in the Counter Control Register.

With the exception of the Gate Mode, all modes react on a level change on the I/O Line 4. Note that if the digital debounce filter is applied, a change in the input level is only detected when the input line is stable for duration greater than the programmed debounce duration.



The following table gives an overview of the control mode events.

|                    | Polarity                         |                                 |  |
|--------------------|----------------------------------|---------------------------------|--|
| Input Control Mode | high active<br>(CNTCONT[14] = 0) | low active<br>(CNTCONT[14] = 1) |  |
| No Control Mode    | -                                | -                               |  |
| Load Mode          | Rising edge                      | Falling edge                    |  |
| Latch Mode         | Rising edge                      | Falling edge                    |  |
| Gate Mode          | High level                       | Low Level                       |  |
| Reset Mode         | Rising edge                      | Falling edge                    |  |

Table 6-6 : Input Control Mode events

#### 6.5.3.1 No Control Mode

In this mode I/O Line 4 is ignored.

#### 6.5.3.2 Load Mode

An event on I/O Line 4 loads the counter with the content of the Counter Preload Register.

If the 'Single Cycle' mode is active, the event on I/O Line 4 starts the counter.

The counter can also be preloaded by writing '1' to the 'Load Counter' (LCNT) bit in the Channel Command Register.

#### 6.5.3.3 Latch Mode

An event on I/O Line 4 latches the actual counter value in the Counter Data Register. It will remain latched until the Counter Data Register is read or the latch is released with the CDLT bit in the Counter Status Register.

#### 6.5.3.4 Gate Mode

The I/O Line 4 enables or disables counting.

| I/O Line 4 | Counter  |
|------------|----------|
| 0          | Disabled |
| 1          | Enabled  |

In this mode an interrupt is generated (if enabled) if the gate is closed.

#### 6.5.3.5 Reset Mode

An event on I/O Line 4 resets the counter.

If the 'Single Cycle' mode is active, the event on I/O Line 4 starts the counter.

The counter can also be reset by writing '1' to the Reset Counter (RCNT) bit in the Channel Command Register.

### 6.5.4 Configuration Examples

#### 6.5.4.1 Watchdog Timer

The watchdog timer counts down from a programmed value until it reaches 0. The counter must be reloaded on a regular base either internal via the Counter Command Register or external via I/O Line 4. Failure to cause a reload would generate a timeout and an interrupt.



| Input Mode     |   | Count Mode   | Control Mode | Additional Configuration                                                    |
|----------------|---|--------------|--------------|-----------------------------------------------------------------------------|
| Timer Mode Dow | n | Single Cycle | Load Mode    | Set CNTPRL to watchdog time,<br>CNTCMP to zero, enable<br>counter match IRQ |

#### 6.5.4.2 Event Counting

In this configuration, input pulses or events occurring at the input pin of the counter are counted up to a programmed count limit. Upon reaching the count limit, the counter output will generate an interrupt. To arm the counter for the next measurement, reset the counter in the Counter Command Register.

| Input Mode | Count Mode Control Mode |      | put Mode         Count Mode         Control Mode         Additional Configuration |  | Additional Configuration |
|------------|-------------------------|------|-----------------------------------------------------------------------------------|--|--------------------------|
| U/D Count  | Single Cycle            | none | Set CNTCMP to limit, enable<br>counter match IRQ                                  |  |                          |

#### 6.5.4.3 Input Pulse Width Measurement

For pulse-width measurement, the pulse-width being measured serves as a clock gate for an up-counter. To arm the counter for a measurement, reset the counter in the Counter Command Register. The measurement starts with the next rising edge and ends with the falling edge of the gate signal. An interrupt is generated upon completion of the pulse-width measurement. The up-counter uses the internal clock prescaler at the counter's clock pin. Use following formula to calculate the pulse-width:

Pulse Width = Counter Value / Clock Frequency

| Input Mode    | Count Mode   | Control Mode | Additional Configuration |
|---------------|--------------|--------------|--------------------------|
| Timer Mode Up | Single Cycle | Gate Mode    | Enable control mode IRQ  |

#### 6.5.4.4 Mechanical System Positioning

If a mechanical system provides position switches, these can be used for various purposes:

#### Establish a known home

|    | Input Mode                          | Count Mode    | nt Mode Control Mode | Additional Configuration |  |
|----|-------------------------------------|---------------|----------------------|--------------------------|--|
|    | U/D Count                           | Cycle Counter | Reset Mode           | Enable control mode IRQ  |  |
| ct | stablish a known reference position |               |                      |                          |  |

#### Establish a known reference position

| Input Mode          | Count Mode    | Control Mode | Additional Configuration |
|---------------------|---------------|--------------|--------------------------|
| U/D Count           | Cycle Counter | Load Mode    | Enable control mode IRQ  |
| <br>tuna a naaltian |               |              |                          |

#### Capture a position

| Input Mode | Count Mode    | Control Mode | Additional Configuration |
|------------|---------------|--------------|--------------------------|
| U/D Count  | Cycle Counter | Latch Mode   | Enable control mode IRQ  |



## 6.6 Interrupts

All Interrupts are requested at the LINT1 input of the PCI Target Chip.

Interrupts are generated only if the Master Interrupt Enable (MIE) is enabled in the Interrupt Control Register ICR.

## 6.6.1 Interrupt Sources

| IRQ     | IRQ Description                   | Enable IRQ                                   | Acknowledge IRQ                             |
|---------|-----------------------------------|----------------------------------------------|---------------------------------------------|
| IRQST   | ADC settling time elapsed         | ADC Control Register<br>ADCCONT              | ADC Status Register<br>ADCSTAT              |
| IRQC    | ADC conversion finished           | ADC Control Register<br>ADCCONT              | ADC Status Register<br>ADCSTAT              |
| SEQ IRQ | ADC sequencer interrupt           | ADC Sequencer Control<br>Register ADCSEQCONT | ADC Sequencer Status<br>Register ADCSEQSTAT |
| DAC IRQ | DAC sequencer interrupt           | DAC Control Register<br>DACCONT              | DAC Sequencer Status<br>Register DACSEQSTAT |
| LINEIST | Digital I/O line IRQ              | Line Interrupt Enable<br>Register LINEIEN    | Line Interrupt Status<br>Register LINEIST   |
| CIRQ    | Counter control mode<br>interrupt | Counter Control Register<br>CNTCONT          | Counter Status Register<br>CNTSTAT          |
| MIRQ    | Counter match interrupt           | Counter Control Register<br>CNTCONT          | Counter Status Register<br>CNTSTAT          |

Table 6-8 : Interrupt sources

The Interrupt Control Register can give a quick overview which interrupt source caused an interrupt.



# 7 Installation

## 7.1 ADC Input Wiring

The TPMC851 provides 32 single-ended or 16 differential multiplexed analog inputs. The desired input channel and the mode (single-ended or differential) are selected by programming the input multiplexer.

A software programmable gain amplifier with gain settings of 1, 2, 4 and 8 allows a direct connection of a wide range of sensors and instrumentation. The maximum analog input voltage range is  $\pm 10V$  at a gain of 1.





Make sure that all unused analog input pins are tied to the GND signal level (or any other valid signal level within the analog input voltage range). This is required even if the unused channels are turned off by software.

If unused analog inputs are left floating, they could badly degrade the performance of the active channels.



## 7.2 DAC Output Wiring

The DAC is used to generate the  $\pm 10V$  analog output voltage. The operational amplifier is able to drive high capacitance loads and protects the DAC.



Figure 7-2 : DAC Output Wiring

## 7.3 TTL I/O Interface

The 16 TTL I/O lines are realized with an input and output buffer with a  $4.7k\Omega$  pull up resistor for the tri-state output function and an array for ESD protection. See the following figure for more information of electrical circuitry.



Figure 7-3 : TTL I/O Interface

While power-up and after reset all digital I/O lines are configured as inputs. Because of the pull-up resistor an unused (open) digital I/O line will be read as '1'. A digital I/O line configured as input will appear as a high state to the outside, as long it is not driven from the outside.



# 8 Pin Assignment – I/O Connector

Connector: HD68 SCSI-3 type female connector (AMP 787082-7)

| Pin | Signal                    |              | Pin | Signal       | Signal       |  |
|-----|---------------------------|--------------|-----|--------------|--------------|--|
| 1   | ADC SE 1                  | ADC Diff 1+  | 35  | ADC SE 17    | ADC Diff 1-  |  |
| 2   | ADC SE 2                  | ADC Diff 2+  | 36  | ADC SE 18    | ADC Diff 2-  |  |
| 3   | ADC SE 3                  | ADC Diff 3+  | 37  | ADC SE 19    | ADC Diff 3-  |  |
| 4   | ADC SE 4                  | ADC Diff 4+  | 38  | ADC SE 20    | ADC Diff 4-  |  |
| 5   | ADC SE 5                  | ADC Diff 5+  | 39  | ADC SE 21    | ADC Diff 5-  |  |
| 6   | ADC SE 6                  | ADC Diff 6+  | 40  | ADC SE 22    | ADC Diff 6-  |  |
| 7   | ADC SE 7                  | ADC Diff 7+  | 41  | ADC SE 23    | ADC Diff 7-  |  |
| 8   | ADC SE 8                  | ADC Diff 8+  | 42  | ADC SE 24    | ADC Diff 8-  |  |
| 9   | GND                       |              | 43  | GND          |              |  |
| 10  | ADC SE 9                  | ADC Diff 9+  | 44  | ADC SE 25    | ADC Diff 9-  |  |
| 11  | ADC SE 10                 | ADC Diff 10+ | 45  | ADC SE 26    | ADC Diff 10- |  |
| 12  | ADC SE 11                 | ADC Diff 11+ | 46  | ADC SE 27    | ADC Diff 11- |  |
| 13  | ADC SE 12                 | ADC Diff 12+ | 47  | ADC SE 28    | ADC Diff 12- |  |
| 14  | ADC SE 13                 | ADC Diff 13+ | 48  | ADC SE 29    | ADC Diff 13- |  |
| 15  | ADC SE 14                 | ADC Diff 14+ | 49  | ADC SE 30    | ADC Diff 14- |  |
| 16  | ADC SE 15                 | ADC Diff 15+ | 50  | ADC SE 31    | ADC Diff 15- |  |
| 17  | ADC SE 16                 | ADC Diff 16+ | 51  | ADC SE 32    | ADC Diff 16- |  |
| 18  | GND                       |              | 52  | GND          |              |  |
| 19  | DAC 1 Output              |              | 53  | DAC 5 Output |              |  |
| 20  | DAC 2 Output              |              | 54  | DAC 6 Output |              |  |
| 21  | GND                       |              | 55  | GND          |              |  |
| 22  | DAC 3 Output              |              | 56  | DAC 7 Output |              |  |
| 23  | DAC 4 Output              |              | 57  | DAC 8 Output |              |  |
| 24  | GND                       |              | 58  | GND          |              |  |
| 25  | TTL I/O 0 (ADC Seq. Trg.) |              | 59  | TTL I/O 8    |              |  |
| 26  | TTL I/O 1 (DAC Seq. Trg.) |              | 60  | TTL I/O 9    |              |  |
| 27  | TTL I/O 2 (Counter input) |              | 61  | TTL I/O 10   |              |  |
| 28  | TTL I/O 3 (Counter input) |              | 62  | TTL I/O 11   |              |  |
| 29  | GND                       |              | 63  | GND          |              |  |
| 30  | TTL I/O 4 (Counter input) |              | 64  | TTL I/O 12   | TTL I/O 12   |  |
| 31  | TTL I/O 5                 |              | 65  | TTL I/O 13   |              |  |
| 32  | TTL I/O 6                 |              | 66  | TTL I/O 14   |              |  |
| 33  | TTL I/O 7                 |              | 67  | TTL I/O 15   |              |  |
| 34  | GND                       |              | 68  | GND          |              |  |

Table 8-1 : Pin Assignment I/O Connector



# 9 Important Notes

## 9.1 Dummy Conversions after Power-up

After power-up the ADC's logic will be in a random state and may not perform correctly. This has two consequences:

- 1. The first conversion results are not valid and should be ignored.
- 2. The ADC starts in a mode that prevents a correct start of the sequencer.

Therefore, two dummy conversions are required after each power-up, whose results should be ignored.

Use the ADC Conversion Start Register (ADCCONV) Register to perform the dummy conversions.

If the sequencer is to be used, these two dummy conversions are absolutely necessary.

If one of TEWS TECHNOLOGIES software drivers is used, these two dummy conversions are already included.

## 9.2 Open Multiplexer Inputs

Unused Multiplexer inputs can pick up stray signals which are injected into the device's substrate. This turns on spurious substrate devices which badly degrade the performance of the whole multiplexer device.

Make sure that all unused analog input pins are tied to the analog ground signal level (or any other valid signal level within the analog input voltage range). This is required even if the unused channels are turned off by software.