

## The Embedded I/O Company

# **TPMC553**

### 32 / 16 Channels of 16 bit D/A

Version 1.0

### **User Manual**

Issue 1.0.2 March 2009

Phone: +1 (775) 850 5830 Fax: +1 (775) 201 0347 e-mail: usasales@tews.com



#### TPMC553-10

32 Channels of 16 bit D/A

#### TPMC553-11

16 Channels of 16 bit D/A

This document contains information, which is proprietary to TEWS TECHNOLOGIES GmbH. Any reproduction without written permission is forbidden.

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

©2008-2009 by TEWS TECHNOLOGIES GmbH

All trademarks mentioned are property of their respective owners.



| Issue | Description                                                | Date           |
|-------|------------------------------------------------------------|----------------|
| 1.0   | Initial Issue                                              | September 2008 |
| 1.1   | Revised DAC correction section                             | October 2008   |
| 1.0.2 | New Notation for User Manual and Engineering Documentation | March 2009     |



# **Table of Contents**

| 1 | PRODUCT DESCRIPTION                                    | 6    |
|---|--------------------------------------------------------|------|
| 2 | 2 TECHNICAL SPECIFICATION                              | 7    |
| 3 | GENERAL NOTES ON THE TPMC553 QUAD-DA                   | \CS8 |
| 4 | PCI9030 TARGET CHIP                                    | 10   |
|   | 4.1 PCI Configuration Registers (PCR)                  | 10   |
|   | 4.1.1 PCI9030 Header                                   |      |
|   | 4.2 Local Configuration Register (LCR)                 |      |
|   | 4.3 Configuration EEPROM                               | 12   |
|   | 4.4 Local Software Reset                               | 13   |
| 5 | 5 LOCAL SPACE ADDRESSING                               | 14   |
|   | 5.1 PCI9030 Local Space Configuration                  |      |
|   | 5.2 Register Space                                     | 14   |
|   | 5.2.1 Q-DAC X Configuration Register (X = 1-8) (Offset |      |
|   | 5.2.2 Q-DAC X Control Register (X = 1-8) (Offset 0x20  |      |
|   | 5.2.3 Q-DAC X Status Register (X = 1-8) (Offset 0x40   |      |
|   | 5.2.4 Q-DAC X Sequencer Timer Register (X = 1-8) (C    |      |
|   | 5.2.5 Clear Register (Offset 0x80)                     |      |
|   | 5.2.7 Global Control Register (Offset 0x88)            |      |
|   | 5.2.8 Global Status Register (Offset 0x8C)             |      |
|   | 5.2.9 Interrupt Status Register (Offset 0x90)          |      |
|   | 5.2.10 Auto Status Timer Register (Offset 0x94)        |      |
|   | 5.3 DAC Data Space                                     | 28   |
|   | 5.4 DAC Calibration Data Space                         | 30   |
| 6 | FUNCTIONAL DESCRIPTION                                 | 32   |
|   | 6.1 Q-DAC Configuration                                | 32   |
|   | 6.2 Q-DAC Modes                                        | 32   |
|   | 6.2.1 I-Mode (Instant Mode)                            | 32   |
|   | 6.2.2 M-Mode (Manual Mode)                             | 33   |
|   | 6.2.3 T-Mode (Timer / Sequencer Mode)                  |      |
|   | 6.3 Q-DAC Status                                       |      |
|   | 6.3.1 Manual Status Read                               |      |
|   | 6.3.2 Automatic Status Read                            |      |
| 7 | PROGRAMMING HINTS                                      | 38   |
|   | 7.1 DAC Output Coding                                  |      |
|   | 7.2 DAC Data Correction                                |      |
|   | 7.2.1 DAC Correction Values                            |      |
|   | 7.2.2 DAC Correction Formula                           |      |
| 8 | PIN ASSIGNMENT – I/O CONNECTOR                         | 41   |
|   | 8.1 Front I/O Connector                                | 41   |
|   | 8.2 Pin Assignment                                     | Δ1   |



# **List of Figures**

| FIGURE 1-1: BLOCK DIAGRAM                               | 6  |
|---------------------------------------------------------|----|
| FIGURE 7-3: PRINCIPLE OF DAC D/A CORRECTION             | 39 |
| FIGURE 8-1: I/O FRONT CONNECTOR VIEW                    | 41 |
| List of Tables                                          |    |
| TABLE 2-1 : TECHNICAL SPECIFICATION                     | 7  |
| TABLE 3-1 : D/A CHANNEL TO Q-DAC MAPPING                | 9  |
| TABLE 4-1 : PCI9030 HEADER                              | 10 |
| TABLE 4-2 : PCI9030 LOCAL CONFIGURATION REGISTERS       | 11 |
| TABLE 4-3: CONFIGURATION EEPROM TPMC553-1X              | 12 |
| TABLE 5-1 : PCI9030 LOCAL SPACE CONFIGURATION           | 14 |
| TABLE 5-2 : REGISTER SPACE ADDRESS MAP                  | 15 |
| TABLE 5-3 : Q-DAC CONFIGURATION REGISTER (OFFSET 0X00)  | 17 |
| TABLE 5-4 : Q-DAC CONTROL REGISTER (OFFSET 0X20)        | 19 |
| TABLE 5-5 : Q-DAC STATUS REGISTER (OFFSET 0X40)         | 20 |
| TABLE 5-6: Q-DAC SEQUENCER TIMER REGISTER (OFFSET 0X60) | 21 |
| TABLE 5-7 : CLEAR REGISTER (OFFSET 0X80)                | 21 |
| TABLE 5-8: LOAD REGISTER (M-MODE) (OFFSET 0X84)         | 22 |
| TABLE 5-9 : GLOBAL CONTROL REGISTER (OFFSET 0X88)       | 23 |
| TABLE 5-10: GLOBAL STATUS REGISTER (OFFSET 0X8C)        | 25 |
| TABLE 5-11: INTERRUPT STATUS REGISTER (OFFSET 0X90)     | 26 |
| TABLE 5-12: AUTO STATUS TIMER REGISTER (OFFSET 0X94)    | 27 |
| TABLE 5-13: DAC DATA SPACE ADDRESS MAP                  | 29 |
| TABLE 5-14: DAC CALIBRATION DATA SPACE ADDRESS MAP      | 31 |
| TABLE 7-1 : DAC OUTPUT CODING, BIPOLAR OUTPUT RANGE     | 38 |
| TABLE 7-2 : DAC OUTPUT CODING, UNIPOLAR OUTPUT RANGE    |    |
| TABLE 8-1 : I/O FRONT CONNECTOR TYPE                    | 41 |
| TABLE 8-2: I/O PIN ASSIGNMENT                           | 42 |



# 1 **Product Description**

The TPMC553 is a standard single-wide 32 bit PMC module and provides 32/16 channels of 16 bit analog outputs. All signals are accessible through a HD68 SCSI-3 type front I/O connector.

The software selectable output voltage ranges are 0-5V, 0-10V, 0-10.8V,  $\pm$ 5V,  $\pm$ 10V or  $\pm$ 10.8V. The output voltage range can be individually set per channel. The conversion time is typ. 10  $\mu$ s and the DAC outputs are capable to drive a load of  $2k\Omega$ , with a capacitance up to 4000pF.

Beside of an individual channel update, the double buffered DACs allow simultaneous update of all channels. Additionally a sequencer on the TPMC553 allows to periodically updating enabled channels with a sequence timer range that extends from  $10\mu s$  to 167s.

Each TPMC553 is factory calibrated. The calibration information is stored in an on board serial EEPROM unique to each PMC module.



Figure 1-1: Block Diagram



# 2 Technical Specification

| PMC Interface             |                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
|---------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Mechanical Interface      | PCI Mezzanine Card (PMC) Interface confirming to IEEE P1386/P1386.1 Single Size                                                                                                                                                                                                                                                                                                              |  |  |  |  |
| Electrical Interface      | PCI Rev. 2.2 compliant                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |
|                           | 3 MHz / 32 bit PCI                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |
|                           | 3.3V and 5V PCI Signaling Voltage                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |
| On Board Devices          |                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
| PCI Target Chip           | PCI9030 (PLX Technology)                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |
| Quad-DAC                  | AD5754R (Analog Devices)                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |
| I/O Interface             |                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
| Number of D/A Channels    | TPMC553-10: 32 D/A channels TPMC553-11: 16 D/A channels                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |
| D/A Resolution            | 16 bit                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |
| D/A Output Voltage Range  | Selectable: 0V - +5V, 0V - +10V, 0V - +10.8V, ±5V, ±10V, ±10.8V                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
| D/A Channel Load          | Max 2kΩ   4000pF per D/A channel                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |
| D/A Channel Settling Time | Max 10us                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |
| D/A Protection            | 20mA current limit option, thermal shutdown option                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |
| D/A Calibration           | Calibration data for gain and offset correction                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
| DAC INL/DNL Error         | ±16/±1 LSB                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
| I/O Connector             | Front I/O HD68 / SCSI-3 (AMP 5-787082-7 or compatible)                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |
| Physical Data             |                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
| Power Requirements        | 200mA typical @ 3.3V<br>600mA typical @ 5V (±10V output, 2kΩ load)                                                                                                                                                                                                                                                                                                                           |  |  |  |  |
| Temperature Range         | Operating -40°C - +85°C<br>Storage -40°C - +85°C                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |
| MTBF                      | TPMC553-10: 683000 h TPMC553-11: 689000 h MTBF values shown are based on calculation according to MIL-HDBK-217F and MIL-HDBK-217F Notice 2; Environment: G <sub>B</sub> 20°C. The MTBF calculation is based on component FIT rates provided by the component suppliers. If FIT rates are not available, MIL-HDBK-217F and MIL-HDBK-217F Notice 2 formulas are used for FIT rate calculation. |  |  |  |  |
| Humidity                  | 5 – 95 % non-condensing                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |
| Weight                    | 79 g                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |

Table 2-1: Technical Specification



## 3 General Notes on the TPMC553 Quad-DACs

The TPMC553 is using Quad-DAC (Q-DAC) devices. Each Q-DAC device provides four D/A channels, internally called A, B, C and D.

The TPMC553-10 provides 32 D/A channels (1 to 32), thus eight Q-DAC devices (1 to 8). The TPMC553-11 provides 16 D/A channels (1 to 16), thus four Q-DAC devices (1 to 4).

The Q-DAC device provides an internal data register for each of the four D/A channels.

To set a certain analog output voltage, the D/A channel data is written to a DAC Data Space, from where it is transferred to the appropriate Q-DAC internal D/A channel data register automatically as soon as possible. The Q-DAC analog outputs are then updated, depending on the Q-DAC operating mode used.

Each Q-DAC devices provides a single serial interface, so all transfers to the Q-DACs are in fact serial data transfers. A data transfer to a Q-DAC takes approx. 1.4us per D/A channel, data transfer for all four Q-DAC D/A channels takes approx. 5.6us. A Q-DAC status read takes approx. 3.4us.

The Q-DAC data transfer engines (parallel/serial) are independent of each other (e.g. data for D/A channels 1, 2, 3 & 4 is transferred one channel after the other since these channels are located in the same Q-DAC, while data for D/A channels 1, 5, 9, 13 could be transferred all at the same time since these channels are located in different Q-DACs.

| TPMC553 D/A Channel | Q-DAC | Q-DAC internal<br>D/A Channel |
|---------------------|-------|-------------------------------|
| 1                   |       | A                             |
| 2                   | 1     | В                             |
| 3                   | ľ     | С                             |
| 4                   |       | D                             |
| 5                   |       | Α                             |
| 6                   | 2     | В                             |
| 7                   | 2     | С                             |
| 8                   |       | D                             |
| 9                   |       | Α                             |
| 10                  | 3     | В                             |
| 11                  | 3     | С                             |
| 12                  |       | D                             |
| 13                  |       | Α                             |
| 14                  | 4     | В                             |
| 15                  | 4     | С                             |
| 16                  |       | D                             |
| 17                  |       | Α                             |
| 18                  | 3     | В                             |
| 19                  | 3     | С                             |
| 20                  |       | D                             |
| 21                  |       | А                             |
| 22                  | 6     | В                             |
| 23                  | U     | С                             |
| 24                  |       | D                             |



| TPMC553 D/A Channel | Q-DAC | Q-DAC internal<br>D/A Channel |
|---------------------|-------|-------------------------------|
| 25                  |       | А                             |
| 26                  | 7     | В                             |
| 27                  | ,     | С                             |
| 28                  |       | D                             |
| 29                  |       | А                             |
| 30                  | 8     | В                             |
| 31                  | O     | С                             |
| 32                  |       | D                             |

Table 3-1 : D/A Channel to Q-DAC mapping



# 4 PCI9030 Target Chip

# 4.1 PCI Configuration Registers (PCR)

### 4.1.1 PCI9030 Header

| PCI CFG<br>Register | Write '0' to all u                     | PCI<br>writeable    | Initial Values<br>(Hex Values) |                    |             |             |
|---------------------|----------------------------------------|---------------------|--------------------------------|--------------------|-------------|-------------|
| Address             | 31 24                                  | 23 16               | 15 8                           | 7 0                |             |             |
| 0x00                | Devi                                   | ce ID               | Vend                           | dor ID             | N           | 0229 1498   |
| 0x04                | Sta                                    | itus                | Com                            | mand               | Υ           | 0280 0000   |
| 0x08                |                                        | Class Code          |                                | Revision ID        | N           | 118000 00   |
| 0x0C                | BIST                                   | Header Type         | PCI Latency<br>Timer           | Cache Line<br>Size | Y[7:0]      | 00 00 00 00 |
| 0x10                | PCI Base                               | Address 0 for ME    | M Mapped Config                | Registers          | Υ           | 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              | Υ           | FFFFE00     |
| 0x1C                | PCI E                                  | Base Address 3 for  | Local Address Sp               | ace 1              | Υ           | FFFFFC0     |
| 0x20                | PCI E                                  | Base Address 4 for  | Local Address Sp               | ace 2              | Υ           | FFFFFC00    |
| 0x24                | PCI E                                  | Base Address 5 for  | Local Address Sp               | ace 3              | Y           | 00000000    |
| 0x28                | PC                                     | l CardBus Informa   | ation Structure Poi            | nter               | N           | 00000000    |
| 0x2C                | Subsys                                 | stem ID             | Subsysten                      | Nendor ID          | N           | s.b. 1498   |
| 0x30                | PCI                                    | Base Address for    | Local Expansion I              | ROM                | Υ           | 00000000    |
| 0x34                |                                        | Reserved            |                                | New Cap. Ptr.      | N           | 000000 40   |
| 0x38                |                                        | Rese                | erved                          |                    | N           | 00000000    |
| 0x3C                | Max_Lat                                | Min_Gnt             | Interrupt Pin                  | Interrupt Line     | Y[7:0]      | 00 00 01 00 |
| 0x40                | PM Cap. PM Nxt Cap. PM Cap. ID         |                     | N                              | 4801 48 01         |             |             |
| 0x44                | PM Data PM CSR EXT PM                  |                     | PM                             | CSR                | Υ           | 00 00 0000  |
| 0x48                | Reserved HS CSR HS Nxt Cap. HS Cap. ID |                     | HS Cap. ID                     | Y[23:16]           | 00 00 4C 06 |             |
| 0x4C                | VPD Address VPD Nxt Cap. VF            |                     |                                | VPD Cap. ID        | Y[31:16]    | 0000 00 03  |
| 0x50                |                                        | VPD                 | Data                           |                    | Υ           | 00000000    |

Table 4-1: PCI9030 Header

Subsystem-ID: TPMC553-10 (32 Channels of 16 bit D/A) = 0x000A

TPMC553-11 (16 Channels of 16 bit D/A) = 0x000B



# 4.2 Local Configuration Register (LCR)

After reset, the PCI9030 Local Configuration Registers are loaded from an on board serial configuration EEPROM.

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

Do not change hardware dependent bit settings in the PCI9030 Local Configuration Registers.

| Offset from PCI<br>Base Address | Register                                                               | Value      |
|---------------------------------|------------------------------------------------------------------------|------------|
| 0x00                            | Local Address Space 0 Range                                            | 0xFFFFE00  |
| 0x04                            | Local Address Space 1 Range                                            | 0xFFFFFC0  |
| 0x08                            | Local Address Space 2 Range                                            | 0xFFFFFC00 |
| 0x0C                            | Local Address Space 3 Range                                            | 0x00000000 |
| 0x10                            | Expansion ROM Range                                                    | 0x00000000 |
| 0x14                            | Local Address Space 0 Local Base Address (Remap)                       | 0x00000001 |
| 0x18                            | Local Address Space 1 Local Base Address (Remap)                       | 0x00010001 |
| 0x1C                            | Local Address Space 2 Local Base Address (Remap)                       | 0x00020001 |
| 0x20                            | Local Address Space 3 Local Base Address (Remap)                       | 0x00000000 |
| 0x24                            | Expansion ROM Local Base Address (Remap)                               | 0x00000000 |
| 0x28                            | Local Address Space 0 Bus Region Descriptor                            | 0xD180A0E0 |
| 0x2C                            | Local Address Space 1 Bus Region Descriptor                            | 0xD180A0E0 |
| 0x30                            | Local Address Space 2 Bus Region Descriptor                            | 0xD180A0E0 |
| 0x34                            | Local Address Space 3 Bus Region Descriptor                            | 0x00000000 |
| 0x38                            | Expansion ROM Bus Region Descriptor                                    | 0x00000000 |
| 0x3C                            | Chip Select 0 Base Address                                             | 0x00000101 |
| 0x40                            | Chip Select 1 Base Address                                             | 0x00010041 |
| 0x44                            | Chip Select 2 Base Address                                             | 0x00020401 |
| 0x48                            | Chip Select 3 Base Address                                             | 0x00000000 |
| 0x4C                            | Interrupt Control/Status                                               | 0x0041     |
| 0x4E                            | Serial EEPROM Write-Protected Address Boundary                         | 0x0030     |
| 0x50                            | PCI Target Response, Serial EEPROM Control, and Initialization Control | 0x00780000 |
| 0x54                            | General Purpose I/O Control                                            | 0x00392270 |
| 0x70                            | Hidden1 Register for Power Management Data Select                      | 0x00000000 |
| 0x74                            | Hidden 2 Register for Power Management Data Scale                      | 0x00000000 |

Table 4-2: PCI9030 Local Configuration Registers



## 4.3 Configuration EEPROM

After power-on or PCI reset, the PCI9030 loads initial configuration register data from an on board configuration EEPROM.

The configuration EEPROM contains the following configuration data:

• Address 0x00 to 0x27 : PCI9030 PCI Configuration Register Values

• Address 0x28 to 0x87 : PCI9030 Local Configuration Register Values

• Address 0x88 to 0xFF: Reserved

See the PCI9030 Manual for more information.

| Address | Offset |        |        |        |        |        |        |        |
|---------|--------|--------|--------|--------|--------|--------|--------|--------|
|         | 0x00   | 0x02   | 0x04   | 0x06   | 80x0   | 0x0A   | 0x0C   | 0x0E   |
| 0x00    | 0x0229 | 0x1498 | 0x0280 | 0x0000 | 0x1180 | 0x0000 | s.b.   | 0x1498 |
| 0x10    | 0x0000 | 0x0040 | 0x0000 | 0x0100 | 0x4801 | 0x4801 | 0x0000 | 0x0000 |
| 0x20    | 0x0000 | 0x0006 | 0x0000 | 0x0003 | 0x0FFF | 0xFE00 | 0x0FFF | 0xFFC0 |
| 0x30    | 0x0FFF | 0xFC00 | 0x0000 | 0x0000 | 0x0000 | 0x0000 | 0x0000 | 0x0001 |
| 0x40    | 0x0001 | 0x0001 | 0x0002 | 0x0001 | 0x0000 | 0x0000 | 0x0000 | 0x0000 |
| 0x50    | 0xD180 | 0xA0E0 | 0xD180 | 0xA0E0 | 0xD180 | 0xA0E0 | 0x0000 | 0x0000 |
| 0x60    | 0x0000 | 0x0000 | 0x0000 | 0x0101 | 0x0001 | 0x0041 | 0x0002 | 0x0401 |
| 0x70    | 0x0000 | 0x0000 | 0x0030 | 0x0041 | 0x0078 | 0x0000 | 0x0039 | 0x2270 |
| 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 TPMC553-1x

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

TPMC553-11 0x000B



### **4.4 Local Software Reset**

The PCI9030 Local Reset Output LRESETo# is used to reset the on board local logic.

The PCI9030 local reset is active during PCI reset or if the PCI Adapter Software Reset bit is set in the PCI9030 local configuration register CNTRL (offset 0x50).

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

Value of '1' resets the PCI9030 and issues a reset to the Local Bus (LRESETo# asserted). The PCI9030 remains in this reset condition until the PCI Host clears this bit. The contents of the PCI9030 PCI and Local Configuration Registers are not reset. The PCI9030 PCI Interface is not reset.



# 5 Local Space Addressing

# 5.1 PCI9030 Local Space Configuration

The local on board addressable regions are accessed from the PCI side by using the PCI9030 local spaces.

| PCI9030<br>Local<br>Space | PCI9030 PCI Base Address (Offset in PCI Configuration Space) | PCI<br>Space<br>Mapping | Size<br>(Byte) | Port<br>Width<br>(Bit) | Endian<br>Mode | Description               |
|---------------------------|--------------------------------------------------------------|-------------------------|----------------|------------------------|----------------|---------------------------|
| 0                         | 2 (0x18)                                                     | MEM                     | 512            | 32                     | BIG            | Register Space            |
| 1                         | 3 (0x1C)                                                     | MEM                     | 64             | 32                     | BIG            | DAC Data Space            |
| 2                         | 4 (0x20)                                                     | MEM                     | 1K             | 32                     | BIG            | Calibration Data<br>Space |
| 3                         | 5 (0x24)                                                     | -                       | -              | -                      | -              | Not Used                  |

Table 5-1: PCI9030 Local Space Configuration

# **5.2 Register Space**

PCI Base Address: PCI9030 PCI Base Address 2 (Offset 0x18 in PCI Configuration Space).

| Offset to PCI<br>Base Address 2 | Description                    | Size<br>(Bit) |
|---------------------------------|--------------------------------|---------------|
| 0x000                           | Q-DAC 1 Configuration Register | 32            |
| 0x004                           | Q-DAC 2 Configuration Register | 32            |
| 0x008                           | Q-DAC 3 Configuration Register | 32            |
| 0x00C                           | Q-DAC 4 Configuration Register | 32            |
| 0x010                           | Q-DAC 5 Configuration Register | 32            |
| 0x014                           | Q-DAC 6 Configuration Register | 32            |
| 0x018                           | Q-DAC 7 Configuration Register | 32            |
| 0x01C                           | Q-DAC 8 Configuration Register | 32            |
| 0x020                           | Q-DAC 1 Control Register       | 32            |
| 0x024                           | Q-DAC 2 Control Register       | 32            |
| 0x028                           | Q-DAC 3 Control Register       | 32            |
| 0x02C                           | Q-DAC 4 Control Register       | 32            |
| 0x030                           | Q-DAC 5 Control Register       | 32            |
| 0x034                           | Q-DAC 6 Control Register       | 32            |
| 0x038                           | Q-DAC 7 Control Register       | 32            |
| 0x03C                           | Q-DAC 8 Control Register       | 32            |
| 0x040                           | Q-DAC 1 Status Register        | 32            |
| 0x044                           | Q-DAC 2 Status Register        | 32            |



| Offset to PCI<br>Base Address 2 | Description                      | Size<br>(Bit) |
|---------------------------------|----------------------------------|---------------|
| 0x048                           | Q-DAC 3 Status Register          | 32            |
| 0x04C                           | Q-DAC 4 Status Register          | 32            |
| 0x050                           | Q-DAC 5 Status Register          | 32            |
| 0x054                           | Q-DAC 6 Status Register          | 32            |
| 0x058                           | Q-DAC 7 Status Register          | 32            |
| 0x05C                           | Q-DAC 8 Status Register          | 32            |
| 0x060                           | Q-DAC 1 Sequencer Timer Register | 32            |
| 0x064                           | Q-DAC 2 Sequencer Timer Register | 32            |
| 0x068                           | Q-DAC 3 Sequencer Timer Register | 32            |
| 0x06C                           | Q-DAC 4 Sequencer Timer Register | 32            |
| 0x070                           | Q-DAC 5 Sequencer Timer Register | 32            |
| 0x074                           | Q-DAC 6 Sequencer Timer Register | 32            |
| 0x078                           | Q-DAC 7 Sequencer Timer Register | 32            |
| 0x07C                           | Q-DAC 8 Sequencer Timer Register | 32            |
| 0x080                           | Clear Register                   | 32            |
| 0x084                           | Load Register                    | 32            |
| 0x088                           | Global Control Register          | 32            |
| 0x08C                           | Global Status Register           | 32            |
| 0x090                           | Interrupt Status Register        | 32            |
| 0x094                           | Auto Status Timer Register       | 32            |

Table 5-2: Register Space Address Map

The Register Space requires using 32 bit transfer size.

Registers / Register bits for Q-DACs 5 - 8 are supported for 32 D/A channel TPMC553 options only.



### 5.2.1 Q-DAC X Configuration Register (X = 1-8) (Offset 0x00 ...)

There is a dedicated Q-DAC Configuration Register for each Q-DAC.

Each Q-DAC provides four D/A Channels, internally called A - D. Each Q-DAC also provides internal registers for device configuration.

If the Q-DAC busy bit in the Global Status Register is clear, a write to a Q-DAC Configuration Register starts the Q-DAC configuration (i.e. the Q-DAC configuration register setting is transferred to the Q-DAC internal configuration registers). Each Q-DAC configuration sequence does also include a read of the Q-DAC status (see Q-DAC Status Register).

Check the Q-DAC busy bit in the Global Status Register to determine when the Q-DAC configuration is done.

Each Q-DAC that is used must be configured first. A D/A Channel can only be used if it's PUA-bit is set.

Writes to a Q-DAC Configuration Register are ignored, when the Q-DAC busy bit is set in the Global Status Register.

| Bit   | Symbol     | Description                                                                                                                                                                                                                                                   | Access | Reset<br>Value |
|-------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------|
| 31:20 | -          | Reserved Set '0' for writes, undefined for reads.                                                                                                                                                                                                             | -      | -              |
| 19    | PUD        | D/A Channel D Power-Up See PUA description.                                                                                                                                                                                                                   | R/W    | 0              |
| 18    | PUC        | D/A Channel C Power-Up<br>See PUA description.                                                                                                                                                                                                                | R/W    | 0              |
| 17    | PUB        | D/A Channel B Power-Up<br>See PUA description.                                                                                                                                                                                                                | R/W    | 0              |
| 16    | PUA        | D/A Channel A Power-Up. When set, this bit places DAC A in normal operating mode. When cleared, this bit places DAC A in power-down mode (default).                                                                                                           | R/W    | 0              |
| 15    | TSD<br>ENA | TSD Enable Set to enable the Q-DAC thermal shutdown feature. Cleared to disable the thermal shutdown feature (default). The Q-DAC incorporates a thermal shutdown feature that automatically shuts down the device if the max device temperature is exceeded. | R/W    | 0              |
| 14    | CL<br>ENA  | Clamp Enable Set to enable the current limit clamp (default). The channel current is clamped at 20mA in case of over-current. Clear to disable the current-limit clamp. The channel powers down in case of over-current.                                      | R/W    | 1              |



| Bit  | Symbol     |                           | [                                                  | Description | 1                       |     | Access | Reset<br>Value |
|------|------------|---------------------------|----------------------------------------------------|-------------|-------------------------|-----|--------|----------------|
|      |            |                           |                                                    |             | ues in case the Q-D/    | AC  |        |                |
| 13   | CLR<br>SEL | CLR<br>SEL                | Unipo<br>Output R                                  |             | Bipolar<br>Output Range |     | R/W    | 0              |
|      |            | 0                         | 0V                                                 |             | 0V                      |     |        |                |
|      |            | 1                         | Mid-so                                             | ale         | Negative Full-sca       | le  |        |                |
| 12   | -          | Reserved<br>Set '0' for v | Reserved Set '0' for writes, undefined for reads.  |             |                         | -   | -      |                |
| 11:9 | ORD        |                           | D/A Channel D Output Range<br>See ORA description. |             |                         | R/W | 000    |                |
| 8:6  | ORC        |                           | D/A Channel C Output Range<br>See ORA description. |             |                         | R/W | 000    |                |
| 5:3  | ORB        |                           | D/A Channel B Output Range<br>See ORA description. |             |                         | R/W | 000    |                |
|      |            | D/A Chann                 | el A Output R                                      | ange        |                         |     |        |                |
|      |            |                           | ORA                                                | Output '    | Voltage Range           |     |        |                |
|      |            |                           | 000                                                |             | +5V                     |     |        |                |
|      |            |                           | 001                                                |             | +10V                    |     |        |                |
| 2:0  | ORA        |                           | 010                                                |             | +10.8V                  |     | R/W    | 000            |
|      |            |                           | 011                                                |             | ±5V                     |     |        |                |
|      |            |                           | 100                                                |             | ±10V                    |     |        |                |
|      |            | 101 ±10.8V                |                                                    |             |                         |     |        |                |
|      |            |                           | others                                             | r           | eserved                 |     |        |                |
|      |            |                           |                                                    |             |                         |     |        |                |

Table 5-3 : Q-DAC Configuration Register (Offset 0x00 ...)



# 5.2.2 Q-DAC X Control Register (X = 1-8) (Offset 0x20 ...)

| Bit   | Symbol | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Access | Reset<br>Value |
|-------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------|
| 31:10 | -      | Reserved Set '0' for writes, undefined for reads.                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | -      | -              |
| 9     | RDSTA  | Read Q-DAC Status Register Only valid for I-Mode and M-Mode (ignored for other QDAC modes). When set, a request for reading the Q-DAC status is logged and the status valid bit in the Q-DAC Status Register is cleared. When the Q-DAC status read is done, the Q-DAC status register is updated and the status valid bit is set again. The actual Q-DAC status read may be delayed by ongoing processes. Bit clears immediately.                                                                                        | W      | 0              |
| 8     | GLM    | Used in M-Mode only.  When set, this QDAC operates in global load mode. In global load mode, all four analog outputs of the Q-DAC are updated simultaneously along with the analog outputs of other Q-DACs set to global load mode when all available D/A channel data has been transferred to the Q-DACs.  When clear, this QDAC operates in standalone mode. In standalone mode, all four analog outputs of the Q-DAC are updated simultaneously when all available D/A channel data has been transferred to the Q-DAC. | R/W    | 0              |
| 7     | ASR    | Automatic Status Read Could be used for I-Mode, M-Mode and T-Mode. Set to enable automatic status reads of the Q-DAC internal status register. Clear to disable automatic status reads. See Auto Status Timer Register for I-Mode and M-Mode. In T-Mode (if enabled) there is one automatic Q-DAC status read per sequence (approx. 10us after the previous Q-DAC update).                                                                                                                                                | R/W    | 0              |
| 6     | -      | Reserved Set '0' for writes, undefined for reads.                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | -      | -              |
| 5     | IRQSE  | Q-DAC Sequencer IRQ enable. Enables Q-DAC Sequencer interrupts when set. Disables Q-DAC Sequencer interrupts when clear. See Interrupt Status Register for details.                                                                                                                                                                                                                                                                                                                                                       | R/W    | 0              |
| 4     | IRQAL  | Q-DAC Alert IRQ enable. Enables Q-DAC Alert interrupts when set. Disables Q-DAC Alert interrupts when clear. See Interrupt Status Register for details.                                                                                                                                                                                                                                                                                                                                                                   | R/W    | 0              |
| 3     | IRQLD  | Q-DAC Load IRQ enable Enables Q-DAC Load interrupt when set. Disables Q-DAC Load interrupts when clear. Should be disabled for I-Mode and T-Mode. See Interrupt Status Register for details.                                                                                                                                                                                                                                                                                                                              | R/W    | 0              |



| Bit | Symbol | Description                                                                                    |                                                                                                                                         |             | Access                                                                                         | Reset<br>Value |     |        |                                                                                                                                              |
|-----|--------|------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|-------------|------------------------------------------------------------------------------------------------|----------------|-----|--------|----------------------------------------------------------------------------------------------------------------------------------------------|
|     |        | Q-DAC Mo                                                                                       | de                                                                                                                                      |             |                                                                                                |                |     |        |                                                                                                                                              |
|     |        | MODE                                                                                           | Q-DAC<br>Mode                                                                                                                           | Description |                                                                                                |                |     |        |                                                                                                                                              |
| 2:0 | MODE   | MODE                                                                                           | 000                                                                                                                                     | I-Mode      | Instant Mode Q-DAC analog outputs are updated immediately after each D/A Channel data transfer |                |     |        |                                                                                                                                              |
|     |        |                                                                                                | MODE                                                                                                                                    | MODE        | MODE                                                                                           | MODE           | 001 | M-Mode | Manual Mode Q-DAC analog outputs are updated simultaneously per software command. D/A Channel data has been transferred to the Q-DAC before. |
|     |        | 010                                                                                            | -                                                                                                                                       | Reserved    |                                                                                                |                |     |        |                                                                                                                                              |
|     |        | 011 T-Mode triggers the data transfer to Q-DAC and the simultaneoupdate of the Q-DAC analogoup | Timer Mode An internal sequencer timer triggers the data transfer to the Q-DAC and the simultaneous update of the Q-DAC analog outputs. |             |                                                                                                |                |     |        |                                                                                                                                              |
|     |        | 1xx                                                                                            | -                                                                                                                                       | Reserved    |                                                                                                |                |     |        |                                                                                                                                              |
|     |        |                                                                                                |                                                                                                                                         |             |                                                                                                |                |     |        |                                                                                                                                              |

Table 5-4 : Q-DAC Control Register (Offset 0x20 ...)



### 5.2.3 Q-DAC X Status Register (X = 1-8) (Offset 0x40 ...)

The Q-DACs device used provides an internal status register, which is reflected in the Q-DAC X Status Registers. The Q-DAC X Status Registers are only updated when a status register read is ordered by writing a '1' to the RDSTA bit or the when ASR option is active.

| Bit   | Symbol | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Access | Reset<br>Value |
|-------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------|
| 31:11 | -      | Reserved Set '0' for writes, undefined for reads.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | -      | -              |
| 10    | SVAL   | Status is valid  This bit indicates that the other register bits are showing the result of a Q-DAC status read (no random data). It does not necessarily indicate that the other register bits are showing the most current Q-DAC status.  This bit is automatically set after the first Q-DAC status read (e.g. during Q-DAC configuration). The bit is cleared upon a Q-DAC status read request via the Q-DAC control register in I-Mode or M-Mode. The bit is then automatically set again, when the requested Q-DAC status read is done. | R      | 0              |
| 9     | TSD    | Thermal Shutdown Alert In the event of an over-temperature situation, this bit is set.                                                                                                                                                                                                                                                                                                                                                                                                                                                       | R      | 0              |
| 8     | PUREF  | Reference Power-Up When set, this bit indicates that the Quad-DAC internal reference is powered-up. Since the TPMC553 Quad-DACs are operating with internal reference, this bit should always be set for any status read from the Quad-DAC.                                                                                                                                                                                                                                                                                                  | R      | 0              |
| 7     | PUD    | DAC D Power-Up<br>See PUA description.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | R      | 0              |
| 6     | PUC    | DAC C Power-Up See PUA description.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | R      | 0              |
| 5     | PUB    | DAC B Power-Up See PUA description.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | R      | 0              |
| 4     | PUA    | DAC A Power-Up '0' when powered down, '1' when powered up. If the Q-DAC is configured with CL ENA bit clear, DAC A will power down automatically on detection of an over-current, PUA will be cleared to reflect this.                                                                                                                                                                                                                                                                                                                       | R      | 0              |
| 3     | OCD    | DAC D Over-current Alert See OCA description.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | R      | 0              |
| 2     | OCC    | DAC C Over-current Alert<br>See OCA description.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | R      | 0              |
| 1     | OCB    | DAC B Over-current Alert See OCA description.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | R      | 0              |
| 0     | OCA    | DAC A Over-current Alert In the event of an over-current situation on DAC A, this bit is set.                                                                                                                                                                                                                                                                                                                                                                                                                                                | R      | 0              |

Table 5-5 : Q-DAC Status Register (Offset 0x40 ...)



### 5.2.4 Q-DAC X Sequencer Timer Register (X = 1-8) (Offset 0x60 ...)

| Bit   | Symbol | Description                                                                                                                                                                                  | Access | Reset<br>Value |
|-------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------|
| 31:24 | -      | Reserved Set '0' for writes, undefined for reads.                                                                                                                                            | -      | -              |
| 23:0  | STPV   | Sequencer Timer Preload Value Controls the time between consecutive Q-DAC analog output updates in T-Mode. Actual time between consecutive Q-DAC analog output updates is (STPV + 1) x 10us. | R/W    | 0              |

Table 5-6: Q-DAC Sequencer Timer Register (Offset 0x60 ...)

### 5.2.5 Clear Register (Offset 0x80)

The Clear Register can be used to clear the 4 channels of a specific Q-DAC or to perform a global clear.

| Bit  | Symbol | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Access | Reset<br>Value |
|------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------|
| 31:8 | ı      | Reserved Set '0' for writes, undefined for reads.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | -      | ı              |
| 7    | CLR8   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | R/W    | 0              |
| 6    | CLR7   | The section of the se | R/W    | 0              |
| 5    | CLR6   | There is one clear control bit for each Q-DAC.  When set, the Q-DAC clear signal is asserted.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | R/W    | 0              |
| 4    | CLR5   | Could be used to set all four Q-DAC channels (internal D/A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | R/W    | 0              |
| 3    | CLR4   | Channel registers and analog outputs) to a value specified                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | R/W    | 0              |
| 2    | CLR3   | by the Q-DACs CLR SEL setting (see Q-DAC Configuration Register).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | R/W    | 0              |
| 1    | CLR2   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | R/W    | 0              |
| 0    | CLR1   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | R/W    | 0              |

Table 5-7 : Clear Register (Offset 0x80)

Do not change the output voltage range while the Q-DAC clear signal is active, as this might put the analog outputs to a value other than 0V.



### 5.2.6 Load Register (M-Mode) (Offset 0x84)

The Load Register is used to load (=update) the four analog outputs of a specific Q-DAC in M-Mode.

| Bit  | Symbol | Description                                                                                                                                                                                                             | Access | Reset<br>Value |
|------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------|
| 31:8 | -      | Reserved Set '0' for writes, undefined for reads.                                                                                                                                                                       | -      | 1              |
| 7    | LOAD8  | Q-DAC Analog Output Update Request.                                                                                                                                                                                     | R/W    | 0              |
| 6    | LOAD7  | There is one load control/status bit for each Q-DAC.                                                                                                                                                                    | R/W    | 0              |
| 5    | LOAD6  | Only valid for M-Mode (ignored for other Q-DAC modes).                                                                                                                                                                  | R/W    | 0              |
| 4    | LOAD5  | When set, a request is logged to update the Q-DAC analog outputs. When the request has been logged, the Q-DAC                                                                                                           | R/W    | 0              |
| 3    | LOAD4  | analog outputs are updated when all available D/A Channel                                                                                                                                                               | R/W    | 0              |
| 2    | LOAD3  | data for this Q-DAC has been transferred to the Q-DAC internal data registers.                                                                                                                                          | R/W    | 0              |
| 1    | LOAD2  | If the Q-DAC is configured for Global-M-Mode, the update of                                                                                                                                                             | R/W    | 0              |
| 0    | LOAD1  | the Q-DAC analog outputs is delayed until all Q-DACs in Global-M-Mode are ready for updating their analog outputs simultaneously.  The bit is automatically cleared when the Q-DAC analog outputs are actually updated. | R/W    | 0              |

Table 5-8 : Load Register (M-Mode) (Offset 0x84)

In M-Mode, after setting a LOAD-bit, software shall check that this bit is clear, before new DAC data for this Q-DAC is written to the DAC data space (since, once written to the DAC data space, the data is transferred to the Q-DAC as soon as possible and may interfere with an ongoing update of the analog outputs).



## 5.2.7 Global Control Register (Offset 0x88)

| Bit  | Symbol | Description                                                                                                                                                                                                         | Access | Reset<br>Value |
|------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------|
| 31:9 | -      | Reserved Set '0' for writes, undefined for reads.                                                                                                                                                                   | ı      | -              |
| 8    | MIE    | Master Interrupt Enable '0': Interrupts are disabled '1': Interrupts are enabled There are also dedicated enable/disable bits for the various interrupt sources. See Q-DAC Control Register.                        | R/W    | 0              |
| 7    | SEQST8 | Q-DAC Sequencer Start/Stop                                                                                                                                                                                          | R/W    | 0              |
| 6    | SEQST7 | There is one Sequencer Start/Stop bit for each Q-DAC.                                                                                                                                                               | R/W    | 0              |
| 5    | SEQST6 | 0 : Stop Sequencer                                                                                                                                                                                                  | R/W    | 0              |
| 4    | SEQST5 | 1 : Start Sequencer When the sequencer is running, the Q-DAC busy bit in the                                                                                                                                        | R/W    | 0              |
| 3    | SEQST4 | global status register is permanently set.                                                                                                                                                                          | R/W    | 0              |
| 2    | SEQST3 | When the sequencer is stopped, any Q-DAC data transfer in                                                                                                                                                           | R/W    | 0              |
| 1    | SEQST2 | progress will terminate normally. Check the Q-DAC busy bit in the Global Status Register to determine when the                                                                                                      | R/W    | 0              |
| 0    | SEQST1 | sequencer is actually stopped.  For a simultaneous update of the analog outputs of multiple Q-DACs in T-Mode, set the Q-DAC timer registers to the same value and start the sequencers using a single write access. | R/W    | 0              |

Table 5-9: Global Control Register (Offset 0x88)

Prior a sequencer start, the following steps are required:

- 1. Setup the Q-DAC Timer
- 2. Set the Q-DAC Mode to T-Mode
- 3. Write the Q-DAC data for the first sequence to the DAC data space.



# 5.2.8 Global Status Register (Offset 0x8C)

| Bit | Symbol | Description                                                                                                                                                                                                                                                                                                                                                                               | Access | Reset<br>Value |
|-----|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------|
| 31  | SDU8   |                                                                                                                                                                                                                                                                                                                                                                                           | R/C    | 0              |
| 30  | SDR8   | Q-DAC 8 status bits.                                                                                                                                                                                                                                                                                                                                                                      | R/C    | 0              |
| 29  | SET8   | (Refer to the Q-DAC 1 status bits for description).                                                                                                                                                                                                                                                                                                                                       | R      | 0              |
| 28  | BUSY8  |                                                                                                                                                                                                                                                                                                                                                                                           | R      | 0              |
| 27  | SDU7   |                                                                                                                                                                                                                                                                                                                                                                                           | R/C    | 0              |
| 26  | SDR7   | Q-DAC 7 status bits.                                                                                                                                                                                                                                                                                                                                                                      | R/C    | 0              |
| 25  | SET7   | (Refer to the Q-DAC 1 status bits for description).                                                                                                                                                                                                                                                                                                                                       | R      | 0              |
| 24  | BUS7   |                                                                                                                                                                                                                                                                                                                                                                                           | R      | 0              |
| 23  | SDU6   |                                                                                                                                                                                                                                                                                                                                                                                           | R/C    | 0              |
| 22  | SDR6   | Q-DAC 6 status bits.                                                                                                                                                                                                                                                                                                                                                                      | R/C    | 0              |
| 21  | SET6   | (Refer to the Q-DAC 1 status bits for description).                                                                                                                                                                                                                                                                                                                                       | R      | 0              |
| 20  | BUSY6  |                                                                                                                                                                                                                                                                                                                                                                                           | R      | 0              |
| 19  | SDU5   |                                                                                                                                                                                                                                                                                                                                                                                           | R/C    | 0              |
| 18  | SDR5   | Q-DAC 5 status bits.                                                                                                                                                                                                                                                                                                                                                                      | R/C    | 0              |
| 17  | SET5   | (Refer to the Q-DAC 1 status bits for description).                                                                                                                                                                                                                                                                                                                                       | R      | 0              |
| 16  | BUSY5  |                                                                                                                                                                                                                                                                                                                                                                                           | R      | 0              |
| 15  | SDU4   |                                                                                                                                                                                                                                                                                                                                                                                           | R/C    | 0              |
| 14  | SDR4   | Q-DAC 4 status bits.                                                                                                                                                                                                                                                                                                                                                                      | R/C    | 0              |
| 13  | SET4   | (Refer to the Q-DAC 1 status bits for description).                                                                                                                                                                                                                                                                                                                                       | R      | 0              |
| 12  | BUSY4  |                                                                                                                                                                                                                                                                                                                                                                                           | R      | 0              |
| 11  | SDU3   |                                                                                                                                                                                                                                                                                                                                                                                           | R/C    | 0              |
| 10  | SDR3   | Q-DAC 3 status bits.                                                                                                                                                                                                                                                                                                                                                                      | R/C    | 0              |
| 9   | SET3   | (Refer to the Q-DAC 1 status bits for description).                                                                                                                                                                                                                                                                                                                                       | R      | 0              |
| 8   | BUSY3  |                                                                                                                                                                                                                                                                                                                                                                                           | R      | 0              |
| 7   | SDU2   |                                                                                                                                                                                                                                                                                                                                                                                           | R/C    | 0              |
| 6   | SDR2   | Q-DAC 2 status bits.                                                                                                                                                                                                                                                                                                                                                                      | R/C    | 0              |
| 5   | SET2   | (Refer to the Q-DAC 1 status bits for description).                                                                                                                                                                                                                                                                                                                                       | R      | 0              |
| 4   | BUSY2  |                                                                                                                                                                                                                                                                                                                                                                                           | R      | 0              |
| 3   | SDU1   | Q-DAC 1 Sequencer Data Underflow Bit is set when the sequencer reads the D/A Channel data for the next sequence in T-Mode, but the software has not yet confirmed new D/A Channel data by clearing the Sequencer Data Request/Acknowledge bit. The sequencer continues normally and takes the D/A channel data actually found in the DAC Data Space. The bit is cleared by writing a '1'. | R/C    | 1              |
| 2   | SDR1   | Q-DAC 1 Sequencer Data Request/Acknowledge Bit is set when the sequencer is requesting new D/A Channel data for the next sequence in T-Mode. The bit is cleared by writing a '1'.                                                                                                                                                                                                         | R/C    | 0              |



| Bit | Symbol | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Access | Reset<br>Value |
|-----|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------|
| 1   | SET1   | Q-DAC 1 Settle Indicates Q-DAC analog output settling time. '1' when Q-DAC analog outputs are settling, '0' when Q-DAC analog outputs are stable. This is no physical representation of any kind, just an internal timer that expires 10µs after an update of the Q-DAC analog outputs.                                                                                                                                                                                                                                                                                                                          | R      | 0              |
| 0   | BUSY1  | Q-DAC 1 Busy Set in the following cases: (a) Transfer to the Q-DAC is in progress (configuration data transfer or D/A channel data transfer or status read transfer).  Note for I-Mode and M-Mode: Data may be written to the DAC data space while a Q-DAC transfer is in progress. E.g. data for D/A channels 3 & 4 may be written to the DAC data space while the data for D/A channel 1 is actually being transferred to the Q-DAC and thus the busy bit is set. (b) Waiting for actual Q-DAC load in M-Mode (after a load request) (c) Sequencer is running Clear when Q-DAC control logic is in Idle state. | R      | 0              |

Table 5-10: Global Status Register (Offset 0x8C)

When the SDR-bit is set, software should write new data for this Q-DAC to the DAC Data Space. When the D/A Channel data for this Q-DAC has been written, software shall clear this bit to acknowledge the request.



### 5.2.9 Interrupt Status Register (Offset 0x90)

| Bit   | Symbol | Description                                                                                                                 | Access | Reset<br>Value |
|-------|--------|-----------------------------------------------------------------------------------------------------------------------------|--------|----------------|
| 31:24 | -      | Reserved Set '0' for writes, undefined for reads.                                                                           | -      | -              |
| 23    | IRQSE8 | Q-DAC Sequencer Interrupt                                                                                                   | R/C    | 0              |
| 22    | IRQSE7 |                                                                                                                             | R/C    | 0              |
| 21    | IRQSE6 | There is one Sequencer Interrupt bit for each Q-DAC.                                                                        | R/C    | 0              |
| 20    | IRQSE5 | Set when the sequencer logic requests a new D/A Channel                                                                     | R/C    | 0              |
| 19    | IRQSE4 | data set for the next sequence and the interrupt is enabled.  Write '1' to clear the interrupt status bit.                  | R/C    | 0              |
| 18    | IRQSE3 | See Q-DAC Control Register for interrupt enable/disable                                                                     | R/C    | 0              |
| 17    | IRQSE2 | control.                                                                                                                    | R/C    | 0              |
| 16    | IRQSE1 |                                                                                                                             | R/C    | 0              |
| 15    | IQRLD8 | Q-DAC Load Interrupt                                                                                                        | R/C    | 0              |
| 14    | IQRLD7 | There is one Load Interrupt bit for each Q-DAC.                                                                             | R/C    | 0              |
| 13    | IQRLD6 | Set when Q-DAC has actually been loaded in M-Mode (Q-DAC analog outputs just have been updated) and the                     | R/C    | 0              |
| 12    | IQRLD5 | interrupt is enabled.                                                                                                       | R/C    | 0              |
| 11    | IQRLD4 | Write '1' to clear the interrupt status bit.                                                                                | R/C    | 0              |
| 10    | IQRLD3 | This interrupt should be disabled for other modes than M-Mode.                                                              | R/C    | 0              |
| 9     | IQRLD2 | See Q-DAC Control Register for interrupt enable/disable                                                                     | R/C    | 0              |
| 8     | IQRLD1 | control.                                                                                                                    | R/C    | 0              |
| 7     | IRQAL8 |                                                                                                                             | R/C    | 0              |
| 6     | IRQAL7 | Q-DAC Alert Interrupt                                                                                                       | R/C    | 0              |
| 5     | IRQAL6 | There is one Alert Interrupt bit for each Q-DAC.                                                                            | R/C    | 0              |
| 4     | IRQAL5 | Set when the Q-DAC status is read and any of the over-<br>current bits or the thermal alert bit is set and the interrupt is | R/C    | 0              |
| 3     | IRQAL4 | enabled.  Write '1' to clear the interrupt status bit.                                                                      | R/C    | 0              |
| 2     | IRQAL3 |                                                                                                                             | R/C    | 0              |
| 1     | IRQAL2 | See Q-DAC Control Register for interrupt enable/disable control.                                                            | R/C    | 0              |
| 0     | IRQAL1 |                                                                                                                             | R/C    | 0              |

Table 5-11: Interrupt Status Register (Offset 0x90)

For an interrupt status bit to be set, the interrupt must be enabled prior to the interrupt event.

An interrupt is asserted if the Master Interrupt Enable bit is set in the Global Control Register and there is at least one bit set in the Interrupt Status Register.



# 5.2.10 Auto Status Timer Register (Offset 0x94)

| Bit   | Symbol | Description                                                                                                                                                                                                  | Access | Reset<br>Value |
|-------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------|
| 31:28 | ASRT8  | Q-DAC Automatic Status Read Timer                                                                                                                                                                            | R/W    | 1000           |
| 27:24 | ASRT7  | There is one Automatic Status Read Timer bit for each Q-DAC.                                                                                                                                                 | R/W    | 1000           |
| 23:20 | ASRT6  | Only valid if the ASR bit is set for Q-DAC 1 (Q-DAC 1                                                                                                                                                        | R/W    | 1000           |
| 19:16 | ASRT5  | Control Register) and only valid for I-Mode and M-Mode.                                                                                                                                                      | R/W    | 1000           |
| 15:12 | ASRT4  | In Auto Status Read Mode a request for reading the Q-DAC                                                                                                                                                     | R/W    | 1000           |
| 11:8  | ASRT3  | status is logged every ASRTx time. Any ongoing transfer of D/A channel data will be terminated normally before the Q-                                                                                        | R/W    | 1000           |
| 7:4   | ASRT2  | DAC status read transfer is started.                                                                                                                                                                         | R/W    | 1000           |
| 3:0   | ASRT1  | ASRT1 Time 0000 10us 0001 20us 0001 20us 0010 40us 0011 80us 0100 160us 0101 320us 0110 640us 0111 1.280ms 1000 2.560ms 1001 5.120ms 1010 10.240ms 1011 20.480ms 1100 40.960ms 1110 81.920ms 1111 1327.680ms | R/W    | 1000           |

Table 5-12: Auto Status Timer Register (Offset 0x94)



### 5.3 DAC Data Space

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

The DAC Data Space provides a 16 bit address location for each of the D/A channels and is used for passing D/A Channel data in I-Mode, M-Mode and T-Mode. 16 bit or 32 bit transfer sizes may be used.

D/A Channels 1 to 4 belong to Q-DAC 1, D/A Channels 5 to 8 belong to Q-DAC 2, and so on.

For I-Mode or M-Mode: If data is written to the DAC data space, the data is transferred to the appropriate Q-DAC (via the Q-DAC serial interface) as soon as possible. Data may be written to the DAC data space while a Q-DAC data transfer is in progress. E.g. data for D/A channels 3 & 4 may be written to the DAC data space while the data for D/A channel 1 is actually being transferred to the Q-DAC and thus the Q-DAC Busy Bit is set in the Global Status Register.

16 bit or 32 bit transfer size must be used for accessing the DAC Data Space.

To optimize data throughput, this space allows 32 bit accesses, which target two subsequent 16 bit words (D/A Channels) (note that the TPMC553 local spaces are set to Big Endian mode).

The DAC data space is readable, but the read values are just showing the value of the previous write to the DAC data space location (they are not read-back from the Q-DAC internal data registers).

| Offset to PCI<br>Base Address 3 | Description         | Q-DAC   | Q-DAC<br>internal<br>Channel | Size<br>(Bit) |
|---------------------------------|---------------------|---------|------------------------------|---------------|
| 0x00                            | D/A Channel 1 Data  |         | Α                            | 16            |
| 0x02                            | D/A Channel 2 Data  | Q-DAC 1 | В                            | 16            |
| 0x04                            | D/A Channel 3 Data  | Q-DAC I | С                            | 16            |
| 0x06                            | D/A Channel 4 Data  |         | D                            | 16            |
| 0x08                            | D/A Channel 5 Data  |         | Α                            | 16            |
| 0x0A                            | D/A Channel 6 Data  | Q-DAC 2 | В                            | 16            |
| 0x0C                            | D/A Channel 7 Data  | Q-DAC 2 | С                            | 16            |
| 0x0E                            | D/A Channel 8 Data  |         | D                            | 16            |
| 0x10                            | D/A Channel 9 Data  |         | Α                            | 16            |
| 0x12                            | D/A Channel 10 Data | Q-DAC 3 | В                            | 16            |
| 0x14                            | D/A Channel 11 Data | Q-DAC 3 | С                            | 16            |
| 0x16                            | D/A Channel 12 Data |         | D                            | 16            |
| 0x18                            | D/A Channel 13 Data |         | Α                            | 16            |
| 0x1A                            | D/A Channel 14 Data | Q-DAC 4 | В                            | 16            |
| 0x1C                            | D/A Channel 15 Data | Q-DAC 4 | С                            | 16            |
| 0x1E                            | D/A Channel 16 Data |         | D                            | 16            |



| Offset to PCI<br>Base Address 3 | Description         | Q-DAC   | Q-DAC<br>internal<br>Channel | Size<br>(Bit) |
|---------------------------------|---------------------|---------|------------------------------|---------------|
| 0x20                            | D/A Channel 17 Data |         | Α                            | 16            |
| 0x22                            | D/A Channel 18 Data | Q-DAC 5 | В                            | 16            |
| 0x24                            | D/A Channel 19 Data | Q-DAC 3 | С                            | 16            |
| 0x26                            | D/A Channel 20 Data |         | D                            | 16            |
| 0x28                            | D/A Channel 21 Data |         | Α                            | 16            |
| 0x2A                            | D/A Channel 22 Data | Q-DAC 6 | В                            | 16            |
| 0x2C                            | D/A Channel 23 Data | Q-DAC 0 | С                            | 16            |
| 0x2E                            | D/A Channel 24 Data |         | D                            | 16            |
| 0x30                            | D/A Channel 25 Data |         | Α                            | 16            |
| 0x32                            | D/A Channel 26 Data | Q-DAC 7 | В                            | 16            |
| 0x34                            | D/A Channel 27 Data | Q-DAC / | С                            | 16            |
| 0x36                            | D/A Channel 28 Data |         | D                            | 16            |
| 0x38                            | D/A Channel 29 Data |         | Α                            | 16            |
| 0x3A                            | D/A Channel 30 Data | Q-DAC 8 | В                            | 16            |
| 0x3C                            | D/A Channel 31 Data | Q-DAC 6 | С                            | 16            |
| 0x3E                            | D/A Channel 32 Data |         | D                            | 16            |

Table 5-13: DAC Data Space Address Map



# 5.4 DAC Calibration Data Space

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

The calibration data values are determined at factory and are stored in this read-only space.

There is an Offset Correction value and a Gain Correction value for each D/A Channel at each voltage range.

16 bit or 32 bit transfer size must be used for accessing the Calibration Data Space.

See the Programming Hints chapter for data correction formulas.

The calibration data is loaded from a serial EEPROM after power-up or PCI reset and is available approx. 8 ms after PCI reset.

The correction factors are stored consecutive in 16 bit values, in order of the D/A Channels 1-32, starting with D/A Channel 1.

| Offset to PCI Base<br>Address 5 | Description            | D/A Channel | Voltage Range |
|---------------------------------|------------------------|-------------|---------------|
| 0x000                           | Offset <sub>corr</sub> | 1           | 0V +5V        |
| 0x002                           | Offset <sub>corr</sub> | 2           | 0V +5V        |
|                                 |                        |             |               |
| 0x03E                           | Offset <sub>corr</sub> | 32          | 0V +5V        |
| 0x040                           | Gain <sub>corr</sub>   | 1           | 0V +5V        |
| 0x042                           | Gain <sub>corr</sub>   | 2           | 0V +5V        |
|                                 |                        |             |               |
| 0x07E                           | Gain <sub>corr</sub>   | 32          | 0V +5V        |
| 0x080                           | Offset <sub>corr</sub> | 1           | 0V +10V       |
| 0x082                           | Offset <sub>corr</sub> | 2           | 0V +10V       |
|                                 |                        |             |               |
| 0x0BE                           | Offset <sub>corr</sub> | 32          | 0V +10V       |
| 0x0C0                           | Gain <sub>corr</sub>   | 1           | 0V +10V       |
| 0x0C2                           | Gain <sub>corr</sub>   | 2           | 0V +10V       |
|                                 |                        |             |               |
| 0x0FE                           | Gain <sub>corr</sub>   | 32          | 0V +10V       |
| 0x100                           | Offset <sub>corr</sub> | 1           | 0V +10.8V     |
| 0x102                           | Offset <sub>corr</sub> | 2           | 0V +10.8V     |
|                                 |                        |             |               |
| 0x13E                           | Offset <sub>corr</sub> | 32          | 0V +10.8V     |
| 0x140                           | Gain <sub>corr</sub>   | 1           | 0V +10.8V     |
| 0x142                           | Gain <sub>corr</sub>   | 2           | 0V +10.8V     |
|                                 |                        |             |               |



| Offset to PCI Base<br>Address 5 | Description            | D/A Channel | Voltage Range |
|---------------------------------|------------------------|-------------|---------------|
| 0x17E                           | Gain <sub>corr</sub>   | 32          | 0V +10.8V     |
| 0x180                           | Offset <sub>corr</sub> | 1           | ±5V           |
| 0x182                           | Offset <sub>corr</sub> | 2           | ±5V           |
|                                 |                        |             |               |
| 0x1BE                           | Offset <sub>corr</sub> | 32          | ±5V           |
| 0x1C0                           | Gain <sub>corr</sub>   | 1           | ±5V           |
| 0x1C2                           | Gain <sub>corr</sub>   | 2           | ±5V           |
|                                 |                        |             |               |
| 0x1FE                           | Gain <sub>corr</sub>   | 32          | ±5V           |
| 0x200                           | Offset <sub>corr</sub> | 1           | ±10V          |
| 0x202                           | Offset <sub>corr</sub> | 2           | ±10V          |
|                                 |                        |             |               |
| 0x23E                           | Offset <sub>corr</sub> | 32          | ±10V          |
| 0x240                           | Gain <sub>corr</sub>   | 1           | ±10V          |
| 0x242                           | Gain <sub>corr</sub>   | 2           | ±10V          |
|                                 |                        |             |               |
| 0x27E                           | Gain <sub>corr</sub>   | 32          | ±10V          |
| 0x280                           | Offset <sub>corr</sub> | 1           | ±10.8V        |
| 0x282                           | Offset <sub>corr</sub> | 2           | ±10.8V        |
|                                 | •••                    |             |               |
| 0x2BE                           | Offset <sub>corr</sub> | 32          | ±10.8V        |
| 0x2C0                           | Gain <sub>corr</sub>   | 1           | ±10.8V        |
| 0x2C2                           | Gain <sub>corr</sub>   | 2           | ±10.8V        |
|                                 |                        |             |               |
| 0x2FE                           | Gain <sub>corr</sub>   | 32          | ±10.8V        |

Table 5-14: DAC Calibration Data Space Address Map



# **6 Functional Description**

## **6.1 Q-DAC Configuration**

Each Q-DAC must be configured before usage, right after power-up or reset. See the Q-DAC Configuration Register for Q-DAC configuration options.

A Q-DAC is being configured by a write to the appropriate Q-DAC Configuration Register (there is a Q-DAC Configuration Register for each Q-DAC) while the Q-DAC Busy bit in the Global Status Register is clear. Writes to a Q-DAC Configuration Registers are ignored when the Q-DAC Busy bit is set for this Q-DAC.

When the Q-DAC configuration is started, the Q-DAC Busy bit in the Global Status Register is set and the Q-DAC configuration is transferred to the Q-DAC internal configuration registers via the Q-DAC serial interface.

Check the Q-DAC Busy bits in the Global Status Register to determine when a certain Q-DAC configuration is done.

Steps for Q-DAC configuration:

- Check the Q-DAC Busy bit(s) is (are) clear in the Global Status Register
- Write the Q-DAC configuration setup to the Q-DAC Configuration Register(s)
- Wait until the Q-DAC Busy bit(s) is (are) clear in the Global Status Register
- Check the Q-DAC Status Register(s) (e.g. check that all Q-DAC internal DACs are powered-up, etc.)

### 6.2 Q-DAC Modes

Each Q-DAC (i.e. a group of four D/A channels) can be set to I-Mode, M-Mode or T-Mode operation. The Q-DAC mode is set in the Q-DAC Control Register.

The Q-DAC mode should be setup soon after Q-DAC configuration and before any other Q-DAC action than Q-DAC configuration.

The Q-DAC Busy bit in the Global Status Register shall be checked to be clear before the Q-DAC mode is altered from the default I-Mode.

### 6.2.1 I-Mode (Instant Mode)

#### 6.2.1.1 Setting I-Mode

(it is assumed that the Q-DACs are already configured)

Instant Mode is the default Q-DAC mode after power-up or reset.

The following steps may be used if it is desired to set a Q-DAC back to I-Mode:

- Check the Q-DAC Busy bit is clear in the Global Status Register
- Set the Q-DAC Mode to I-Mode in the Q-DAC Control Register



#### 6.2.1.2 Using I-Mode

Data written to the DAC data space is transferred to the appropriate Q-DAC as soon as possible. The D/A channel analog output is automatically updated when the data has actually been transferred to the Q-DAC.

Each Q-DAC covers four D/A channels and provides a single serial interface.

If any D/A channel data is updated at a rate higher than 100kHz, data may get lost (depends on what and how many D/A channels are used and whether the Q-DAC status is read; less than four D/A channels per Q-DAC without Q-DAC status read may be updated at a higher rate). The settling of an analog output takes up to 10us (100kHz).

Max D/A channel data update rate without data loss (without Q-DAC status read):

```
1 / (number_of_qdac_dacs_used x 1.4us) number_of_qdac_dacs_used = 1 to 4
```

Max. D/A channel data update rate without data loss (with Q-DAC status read):

```
1 / ((number_of_qdac_dacs_used x 1.4us) + 3.4us) number_of_qdac_dacs_used = 1 to 4
```

Note, that for fastest D/A channel analog output update rate the used D/A channels should be spread over the various Q-DACs. E.g. when using D/A channels 1, 2, 3 & 4 the D/A channel data must be transferred to Q-DAC 1 one after the other and so the max D/A channel data update rate is 178kHz. When using D/A channels 1, 5, 9 & 13, the data is transferred to the Q-DACs 1, 2, 3 & 4 at the same time and so the max D/A channel data update rate is 714 kHz. Note also that the analog output settling time for each D/A channel is 10us max (100 kHz).

Software may wait to see the Q-DAC busy bit clear in the Global Status Register before new data is written for a Q-DAC. Up to four D/A channels per Q-DAC could be updated then, using two 32 bit or four 16 bit writes to the appropriate DAC data space locations.

There are no options for a simultaneous load (analog output update) between D/A channels or Q-DACs in this mode. Each D/A channel analog output is updated individually if the D/A channel data has been transferred to the Q-DAC.

### 6.2.2 M-Mode (Manual Mode)

#### 6.2.2.1 Setting M-Mode

(it is assumed that the Q-DACs are already configured)

The following steps should be used to set a Q-DAC to M-Mode:

- Check the Q-DAC Busy bit is clear in the Global Status Register
- Set the Q-DAC Mode to M-Mode in the Q-DAC Control Register (along with the Global Mode bit if desired)

#### 6.2.2.2 Using M-Mode

Data written to the DAC data space is transferred to the appropriate Q-DAC as soon as possible, but the Q-DAC analog outputs are not automatically updated when the data transfer is done.

Setting the Load bit in the Load Register logs a request for updating the Q-DAC analog outputs.

In **Standalone M-Mode**, the update of the Q-DAC analog outputs is delayed until all available D/A channel data has been transferred to the Q-DAC. The four D/A channel analog outputs of the Q-DAC are updated simultaneously.



In **Global M-Mode**, the update of the Q-DAC analog outputs is delayed until all available D/A channel data has been transferred to all the Q-DACs that are set to Global M-Mode. The D/A channel analog outputs of all Q-DACs in Global M-Mode are updated simultaneously.

See the Global Load Mode bit in the Q-DAC Control Register description.



#### **Method A** (the load command is set during the data transfer):

- Check the Q-DAC Load bit is clear in the Load Register
- Write new D/A channel data to the DAC data space (i.e. transfer new data to the Q-DAC)
- Set the Q-DAC Load bit in the Load Register (the Q-DAC load is delayed until all available data has been transferred to the Q-DAC)
- Wait until the Q-DAC Load bit is clear in the Load Register (i.e. wait until the Q-DAC analog outputs have been updated)
- Write new D/A channel data to the DAC data space (i.e. transfer new data to the Q-DAC)
- · and so on

#### Method B (data is transferred completely before the load command is set):

- Check the Q-DAC Busy bit is clear in the Global Status Register
- Write Q-DAC data to the DAC data space (i.e. transfer new data to the Q-DAC)
- Wait until the Q-DAC Busy bit is clear in the Global Status Register (i.e. wait until all data has been transferred to the Q-DAC)
- Set the Q-DAC Load bit in the Load Register (quick Q-DAC load response, since the data has already been transferred to the Q-DAC before)
- Wait until the Q-DAC Busy bit is clear in the Global Status Register (i.e. wait until the Q-DAC analog outputs have been updated)
- Write Q-DAC data to the DAC data space (i.e. transfer new data to the Q-DAC)
- and so on

### 6.2.3 T-Mode (Timer / Sequencer Mode)

#### 6.2.3.1 Preparing for T-Mode

(it is assumed that the Q-DACs are already configured)

- Set the Q-DAC Sequencer Timer Register
- Check the Q-DAC Busy bit is clear in the Global Status Register
- Set the Q-DAC Mode to T-Mode in the Q-DAC Control Register
- For interrupt controlled sequencer serving only: enable Q-DAC sequencer interrupt in the Q-DAC Control Register
- Write the Q-DAC data for the first sequence to the DAC Data Space

#### 6.2.3.2 Starting the Sequencer

If preparing for Timer / Sequencer Mode is completed, the Sequencer for a Q-DAC is started by setting the Sequencer Start/Stop bit in the Global Control Register.

For a simultaneous D/A channel update between Q-DACs, the Q-DAC timers must be set to the same value and the Q-DAC sequencers must be started simultaneously with the same write access to the Global Control Register.



#### 6.2.3.3 Serving the Sequencer

#### 6.2.3.3.1 Polling Mode

- Poll the Q-DAC Sequencer Data Request bit in the Global Status Register until the bit is set
- The Q-DAC Sequencer Underflow bit in the Global Status Register may be checked then
- Write new Q-DAC data to the DAC data space
- Clear the Q-DAC Sequencer Data Request bit in the Global Status Register
- Poll the Q-DAC Sequencer Data Request bit in the Global Status Register until the bit is set
- and so on

#### 6.2.3.3.2 Interrupt Mode

Upon Interrupt: Check the Interrupt Status Register for Q-DAC sequencer interrupt.

Upon Sequencer Interrupt:

- Check the Q-DAC Sequencer Data Request bit and the Q-DAC Sequencer Underflow bit in the Global Status Register
- Write the Q-DAC data for the next sequence to the appropriate location in the DAC data space (if the data for a D/A channel has not changed, it does not need to be written again).
- Clear the Q-DAC Sequencer Data Request bit in the Global Status Register
- Clear the Q-DAC Sequencer Interrupt Status bit in the Interrupt Status Register

#### 6.2.3.4 Stopping the Sequencer

The Sequencer is stopped by clearing the Sequencer Start / Stop bit in the Global Control Register.

Any ongoing data transfer to the Q-DAC will continue and terminate normally. Check the Q-DAC Busy bit in the Global Status Register to determine when the Sequencer is actually stopped.

### 6.3 Q-DAC Status

The Q-DAC device used provides an internal status register that could be read from the Q-DAC. See the Q-DAC Status Register for details.

#### 6.3.1 Manual Status Read

Manual Q-DAC status read is supported for I-Mode and M-Mode (not supported for T-Mode).

In I-Mode and M-Mode, setting the Read Status Register bit in the Q-DAC Control Register logs a request for reading the status of the Q-DAC device.

When the status read request is logged, the Status Valid bit in the Q-DAC Status Register is cleared. The Status Valid bit in the Q-DAC Status Register is automatically set again when the Q-DAC status read is done and the Q-DAC Status Register has been updated.

If there is any Q-DAC data transfer in progress, the Q-DAC status read is delayed until the current Q-DAC data transfer is done. If the Q-DAC is actually waiting for a global simultaneous load in Global M-Mode, the Q-DAC status read is delayed until the global simultaneous load is done.



#### 6.3.2 Automatic Status Read

Automatic Q-DAC status read is supported for I-Mode, M-Mode and T-Mode.

Automatic Q-DAC status read is enabled in the Q-DAC Control Register.

In I-Mode and M-Mode, a request for reading the Q-DAC status is logged every time the Q-DAC Auto Status Timer expires (cyclic timer). See the Auto Status Timer Register for details.

If there is any Q-DAC data transfer in progress, the Q-DAC status read is delayed until the current Q-DAC data transfer is done. If the Q-DAC is actually waiting for a global simultaneous load in Global M-Mode, the Q-DAC status read is delayed until the global simultaneous load is done.

In T-Mode, there is one Q-DAC status update per sequence.



# 7 **Programming Hints**

## 7.1 DAC Output Coding

| Analog Output         | Bipolar Output, Twos Complement Coding |            |            | Digital Input |
|-----------------------|----------------------------------------|------------|------------|---------------|
| Output Range          | ±5V                                    | ±10V       | ±10.8V     |               |
| Least Significant Bit | 152.59µV                               | 305.18μV   | 329.59µV   |               |
| +FSR                  | 4.999847V                              | 9.999695V  | 10.79967V  | 0x7FFF        |
| +FSR - 1LSB           | 4.999695V                              | 9.99939V   | 10.79934V  | 0x7FFE        |
| Midscale + 1LSB       | 152.59µV                               | 305.18μV   | 329.59µV   | 0x0001        |
| Midscale              | 0V                                     | 0V         | 0V         | 0x0000        |
| Midscale - 1LSB       | -152.59µV                              | -305.18µV  | -329.59µV  | 0xFFFF        |
| -FSR + 1LSB           | -4.999847V                             | -9.999695V | -10.79967V | 0x8001        |
| -FSR                  | -5                                     | -10V       | -10.8V     | 0x8000        |

Table 7-1: DAC Output Coding, Bipolar Output Range

| Analog Output         | Unipolar Out | put, Straight B | inary Coding | Digital Input |
|-----------------------|--------------|-----------------|--------------|---------------|
| Output Range          | +5V          | +10V            | +10.8V       |               |
| Least Significant Bit | 76.29µV      | 152.59µV        | 164.79µV     |               |
| FSR                   | 4.999924V    | 9.999847V       | 10.799835V   | 0xFFFF        |
| FSR - 1LSB            | 4.999847V    | 9.999695V       | 10.79967V    | 0xFFFE        |
| Midscale + 1LSB       | 2.500076V    | 5.000153V       | 5.400165V    | 0x8001        |
| Midscale              | 2.5V         | 5V              | 5.4V         | 0x8000        |
| Midscale - 1LSB       | 2.499924V    | 4.999847V       | 5.399835V    | 0x7FFF        |
| 0V + 1LSB             | 76.29µV      | 152.59µV        | 164.79µV     | 0x0001        |
| 0V                    | 0V           | 0V              | 0V           | 0x0000        |

Table 7-2: DAC Output Coding, Unipolar Output Range

## 7.2 DAC Data Correction

There are two errors which affect the DC accuracy the DACs.

- Offset Error: 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: 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 Space.



#### 7.2.1 DAC Correction Values

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

The corrections values are obtained the following way:

- First the DAC D/A function is determined by measuring the analog output voltage at several bit values at a given operating temperature.
- Then a regression line is calculated that fits best into the determined DAC D/A function (which in general is a curve with offset and gain errors).
- Both Offset\_Error and Gain\_Error are taken from the calculated regression line of the D/A function (Offset\_Error is the A value at D = 0, Gain\_Error is the deviation of the A value from the ideal A value at D = Full Scale).
- The Offset\_Corr (= Offset\_Error x 4) and Gain\_Corr (= Gain\_Error x 4) values are stored in a serial EEPROM. These values could be read in the Calibration Data Space.
- Offset\_Corr and Gain\_Corr values are available for every DAC channel and every output voltage range.



Figure 7-1: Principle of DAC D/A correction



### 7.2.2 DAC Correction Formula

#### 7.2.2.1 Unipolar Output Voltage Ranges

The basic formula for correcting the DAC value is:

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

Value is the desired DAC value.

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

*Gain<sub>corr</sub>* and *Offset<sub>corr</sub>* are the DAC correction values from the Calibration Data Space. They are stored separately for each of the 32 DAC channels and each output voltage range mode.

The correction values are stored as two's complement 16 bit wide values in the range from -32768 to +32767. For higher accuracy they are scaled to  $\frac{1}{4}$  LSB.

### 7.2.2.2 Bipolar Output Voltage Ranges

The basic formula for correcting the 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 sent to the DAC.

*Gain<sub>corr</sub>* and *Offset<sub>corr</sub>* are the DAC correction values from the Calibration Data Space. They are stored separately for each of the 32 DAC channels and each output voltage range mode.

The correction values are stored as two's complement 16 bit wide values in the range from -32768 to +32767. For higher accuracy they are scaled to  $\frac{1}{4}$  LSB.

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

Due to inherent DAC device deviation, the extremes of the full scale range may not be fully reachable, even after calibration.



# 8 Pin Assignment – I/O Connector

### 8.1 Front I/O Connector

| Pin-Count           | 68                           |
|---------------------|------------------------------|
| Connector Type      | HD68 / SCSI-3                |
| Source & Order Info | AMP 5-787082-7 or compatible |

Table 8-1: I/O Front Connector Type



Figure 8-1: I/O Front Connector View

# 8.2 Pin Assignment

Each D/A channel should share a twisted cable pair with GND.

| Pin | Signal         |
|-----|----------------|
| 1   | D/A Channel 1  |
| 2   | D/A Channel 2  |
| 3   | D/A Channel 3  |
| 4   | D/A Channel 4  |
| 5   | D/A Channel 5  |
| 6   | D/A Channel 6  |
| 7   | D/A Channel 7  |
| 8   | D/A Channel 8  |
| 9   | D/A Channel 9  |
| 10  | D/A Channel 10 |
| 11  | D/A Channel 11 |
| 12  | D/A Channel 12 |
| 13  | D/A Channel 13 |
| 14  | D/A Channel 14 |
| 15  | D/A Channel 15 |
| 16  | D/A Channel 16 |
| 17  | D/A Channel 17 |
| 18  | D/A Channel 18 |

| Pin | Signal |
|-----|--------|
| 35  | GND    |
| 36  | GND    |
| 37  | GND    |
| 38  | GND    |
| 39  | GND    |
| 40  | GND    |
| 41  | GND    |
| 42  | GND    |
| 43  | GND    |
| 44  | GND    |
| 45  | GND    |
| 46  | GND    |
| 47  | GND    |
| 48  | GND    |
| 49  | GND    |
| 50  | GND    |
| 51  | GND    |
| 52  | GND    |



| Pin | Signal         |
|-----|----------------|
| 19  | D/A Channel 19 |
| 20  | D/A Channel 20 |
| 21  | D/A Channel 21 |
| 22  | D/A Channel 22 |
| 23  | D/A Channel 23 |
| 24  | D/A Channel 24 |
| 25  | D/A Channel 25 |
| 26  | D/A Channel 26 |
| 27  | D/A Channel 27 |
| 28  | D/A Channel 28 |
| 29  | D/A Channel 29 |
| 30  | D/A Channel 30 |
| 31  | D/A Channel 31 |
| 32  | D/A Channel 32 |
| 33  | NC             |
| 34  | NC             |

| Pin | Signal |
|-----|--------|
| 53  | GND    |
| 54  | GND    |
| 55  | GND    |
| 56  | GND    |
| 57  | GND    |
| 58  | GND    |
| 59  | GND    |
| 60  | GND    |
| 61  | GND    |
| 62  | GND    |
| 63  | GND    |
| 64  | GND    |
| 65  | GND    |
| 66  | GND    |
| 67  | GND    |
| 68  | GND    |

Table 8-2 : I/O Pin Assignment