DAS-1800HC Series Register-Level Programming

USER'S GUIDE

# DAS-1800HC Series Register-Level Programming User's Guide

Revision A - November 1993 Part Number: 86260

### **New Contact Information**

Keithley Instruments, Inc. 28775 Aurora Road Cleveland, OH 44139

Technical Support: 1-888-KEITHLEY Monday – Friday 8:00 a.m. to 5:00 p.m (EST) Fax: (440) 248-6168

Visit our website at http://www.keithley.com

The information contained in this manual is believed to be accurate and reliable. However, Keithley Instruments, Inc., assumes no responsibility for its use; nor for any infringements or patents or other rights of third parties that may result from its use. No license is granted by implication or otherwise under any patent rights of Keithley Instruments, Inc.

KEITHLEY INSTRUMENTS, INC., SHALL NOT BE LIABLE FOR ANY SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES RELATED TO THE USE OF THIS PRODUCT. THIS PRODUCT IS NOT DESIGNED WITH COMPONENTS OF A LEVEL OF RELIABILITY THAT IS SUITED FOR USE IN LIFE SUPPORT OR CRITICAL APPLICATIONS.

Refer to your Keithley Instruments license agreement and Conditions of Sale document for specific warranty and liability information.

All brand and product names are trademarks or registered trademarks of their respective companies.

© Copyright Keithley Instruments, Inc., 1993.

All rights reserved. Reproduction or adaptation of any part of this documentation beyond that permitted by Section 117 of the 1976 United States Copyright Act without permission of the Copyright owner is unlawful.

**Keithley Instruments, Data Acquisition Division** 

440 Myles Standish Blvd. Taunton, MA 02780

Telephone: (508) 880-3000 • FAX: (508) 880-0179

### **Preface**

This guide describes the register-level functions of DAS-1800HC Series boards and is offered as a supplement to the *DAS-1800HC Series User's Guide*.

The DAS-1800HC Series Register-Level Programming User's Guide is for users whose applications require a degree of operational control beyond what is provided by the software packages currently available for DAS-1800HC Series boards. To use the information in this manual, you must be familiar with data acquisition principles and with the functions of the DAS-1800HC Series boards. You must also be familiar with the configuration and installation requirements for DAS-1800HC Series boards, and you must be experienced at programming register-level functions.

**Note:** The information in this guide is not intended for use with any of the software packages currently available for DAS-1800HC Series boards. If you want information on a particular software package, refer to the manual for that package.

This guide is organized as follows:

- Chapter 1 describes the functions for each I/O address of the DAS-1800HC Series boards.
- Chapter 2 outlines a procedure for programming DAS-1800HC Series boards to perform software A/D conversions.
- Appendix A summarizes functions of the bits at each I/O address of the DAS-1800HC Series boards.

## **Table of Contents**

#### Preface

| 1 | I/O Addres  | sses                                            |
|---|-------------|-------------------------------------------------|
|   | Base Addres | ss +0h                                          |
|   | A/D FIF     | O Data (Read)                                   |
|   |             | Data (Read/Write)                               |
|   |             | nd DAC 1 Data (Write)                           |
|   |             | version (Write)                                 |
|   | Base Addres | ss +2h (Data Select Register, Read/Write)1-6    |
|   |             | ss +3h (Digital I/O)                            |
|   | Base Addres | ss +4h (Control Register A, Read/Write)1-7      |
|   |             | ss +5h (Control Register B, Read/Write)1-11     |
|   |             | ss +6h (Control Register C, Read/Write)1-14     |
|   |             | ss +7h (Status Register, Read/Write)1-16        |
|   |             | ss +8h (Burst Length Register, Read/Write) 1-20 |
|   |             | ss +9h (Burst Mode Conversion Rate Register,    |
|   |             | rite)                                           |
|   |             | ss +Ah (QRAM Address Start Register,            |
|   |             | rite)1-21                                       |
|   |             | ss +Ch, +Dh, +Eh, and +Fh (82C54                |
|   |             | mable Interval Counter/Timer)                   |
|   |             |                                                 |
| 2 | Programm    | ning Guidelines                                 |
|   | Programmir  | ng the QRAM with Channel-gain Data              |
|   |             | ng the Board Setup2-2                           |
|   |             |                                                 |
| Α | Summary     | of I/O Address Bits                             |
|   | •           |                                                 |
|   | List of Tab | les                                             |
|   | Table 1-1.  | I/O Address Map                                 |
|   | Table 1-2.  | Gain-Code-Select Bits GN1 and GN01-4            |
|   | Table 1-3.  | Data Source Select Bits DSL1 and DSL0 1-6       |
|   | Table 1-4.  | Trigger Modes Using an Internal A/D Pacer       |
|   |             | Clock                                           |
|   | Table 1-5.  | Trigger Modes Using an External Pacer Clock1-11 |
|   |             |                                                 |

| Table 1-6.  | Interrupt Level Select Bits IL2 to IL0 1-13     |
|-------------|-------------------------------------------------|
| Table 1-7.  | DMA Level Select Bits DL2 to DL01-13            |
| Table 1-8.  | Pacer Clock Select Bits S1 and S01-15           |
| Table 1-9.  | Status Register Bit Manipulation Operations1-16 |
| Table 1-10. | Read/Write Capabilities of Counter/Timer        |
|             | Registers1-23                                   |
| Table A-1.  | Summary of I/O Address Bits A-1                 |

## 1

## I/O Addresses

DAS-1800HC Series boards use 16 addresses in the computer I/O space. The addresses start at the base address and extend as shown in the I/O map of Table 1-1.

Table 1-1. I/O Address Map

| Location                      | Function                                    | Туре       |
|-------------------------------|---------------------------------------------|------------|
| Base Address +0h <sup>1</sup> | A/D FIFO <sup>2</sup> and QRAM Data         | Read       |
|                               | QRAM, DAC 0, and DAC 1 Data; A/D Conversion | Write      |
| Base Address +2h              | Data Select Register                        | Read/Write |
| Base Address +3h              | Digital I/O In Byte                         | Read       |
|                               | Digital I/O Out Byte                        | Write      |
| Base Address +4h              | Control Register A                          | Read/Write |
| Base Address +5h              | Control Register B                          | Read/Write |
| Base Address +6h              | Control Register C                          | Read/Write |
| Base Address +7h              | Status Register                             | Read/Write |
| Base Address +8h              | Burst Length Register                       | Read/Write |
| Base Address +9h              | Burst Mode Conversion Rate Register         | Read/Write |
| Base Address +Ah              | QRAM Address Start                          | Read/Write |
| Base Address +Bh              | N/A                                         |            |
| Base Address +Ch              | Counter 0                                   | Read/Write |
| Base Address +Dh              | Counter 1                                   | Read/Write |

Table 1-1. I/O Address Map (cont.)

| Location         | Function        | Туре       |
|------------------|-----------------|------------|
| Base Address +Eh | Counter 2       | Read/Write |
| Base Address +Fh | Counter Control | Write      |

#### **Notes**

**Note:** Note that all register bits of fixed value, except the identification value in the upper nibble of the Digital Input register (Base Address +3h), are reserved for internal use and subject to change without notification; do not use these bits.

The following sections describe the I/O map in more detail.

#### Base Address +0h

Base Address +0h is used for the following functions:

- Data from the A/D FIFO
- Data from the QRAM
- Data from DAC 0
- Data from DAC 1
- A/D Conversion

Access to one of the four data sources at Base Address +0h requires indirect addressing, using the Data Select register. Refer to "Base Address +2h (Data Select Register, Read/Write)" on page 1-6 for more information. The use of Base Address +0h for each of these data sources and for A/D conversion is discussed in the following subsections.

1-2 I/O Addresses

 $<sup>^1</sup>$  Access to the data sources at Base Address +0h requires indirect addressing.  $^2$  FIFO stands for *First In First Out*.

#### A/D FIFO Data (Read)

The 16-bit A/D FIFO data is read only and uses 16-bit data transfers on the computer bus. Data is in twos complement format for bipolar mode and positive magnitude for unipolar mode.

While this address uses 16-bit data transfers on the PC bus, data words are actually 12-bits long and right-justified. In bipolar mode, D11 is the sign bit and bits D12 to D15 are sign-extender bits that are always equal to D11. In unipolar mode, all data is positive; bits 12 to 15 are always 0 to indicate positive polarity.

Bit assignments for the A/D FIFO data in bipolar mode are as follows:



Bit assignments for the A/D FIFO data in unipolar mode are as follows:



**Note:** The Data Select register (Base Address +2h) must be set to 00h prior to reading the A/D FIFO data.

#### **QRAM Data (Read/Write)**

The channel-gain QRAM is read/write when used in conjunction with the QRAM Address Start register (Base Address +Ah). The QRAM uses 16-bit data transfers on the computer bus.

Bit assignments for QRAM data are as follows:

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7   | 6   | 5    | 4    | 3    | 2    | 1    | 0    |
|----|----|----|----|----|----|---|---|-----|-----|------|------|------|------|------|------|
| X  | X  | X  | X  | X  | X  | X | X | GN1 | GN0 | MUX5 | MUX4 | MUX3 | MUX2 | MUX1 | MUX0 |

The bit names are defined and used as follows:

- $\mathbf{X} = \mathbf{Don't}$  care.
- **GN1** and **GN0** are the gain-code-select bits, as shown in Table 1-2.

Table 1-2. Gain-Code-Select Bits GN1 and GN0

| Gain | Code | Gain Value |            |  |  |  |  |
|------|------|------------|------------|--|--|--|--|
| GN1  | GN0  | DAS-1801HC | DAS-1802HC |  |  |  |  |
| 0    | 0    | 1          | 1          |  |  |  |  |
| 0    | 1    | 10         | 2          |  |  |  |  |
| 1    | 0    | 50         | 4          |  |  |  |  |
| 1    | 1    | 250        | 8          |  |  |  |  |

• MUX5 to MUX0 are the analog-input multiplexer-control bits to select 1 of 64 channels in single-ended mode or 1 of 32 channels in differential mode.

Before you can read or write to the QRAM, you must complete the following tasks:

- 1. Write the QRAM address to the QRAM Address Start register (Base Address +Ah)
- 2. Set the Data Select register (Base Address +2h) to a value of 01h

You must also disable A/D conversions while communicating with QRAM (see description for CVEN on page 116).

For more details on programming the QRAM, refer to "Base Address +Ah (QRAM Address Start Register, Read/Write)" on page 1-21.

#### DAC 0 and DAC 1 Data (Write)

Data from DAC 0 and DAC 1 is written to the 12-bit, right-justified, offset binary D/A registers. These registers are write only and use 16-bit data

1-4 I/O Addresses

transfers on the computer bus. The MSB (most significant bit) of each register is D11, at position 11. The LSB (least significant bit) is D0, at position 0.

Bit assignments for DAC 0 data in D/A Register #0 are as follows:



**Note:** The Data Select register (Base Address +2h) must be set to a value of 02h prior to a write of DAC 0 data.

Bit assignments for DAC 1 data in D/A Register #1 are as follows:



**Note:** The Data Select register (Base Address +2h) must be set to a value of 03h prior to a write of DAC 1 data.

DAC 0 is updated when DAC 1 is updated. The Xs indicate *don't care* positions.

### A/D Conversion (Write)

A write to Base Address +0h starts an A/D conversion only if the following conditions exist:

- The software pacer clock is selected (S1 and S0 of Control Register C at Base Address +6h)
- Conversions are enabled (CVEN of the Status register at Base Address +7h)

• A/D conversion is selected by the Data Select register, at Base Address +2h (the value of the Data Select Register must be 00h)

Any data written to Base Address +0h while A/D conversion is selected is lost.

### Base Address +2h (Data Select Register, Read/Write)

The Data Select register is read/write and selects the 16-bit data source to connect with the computer's data bus. The four possible data sources are the A/D FIFO, the channel-gain QRAM, DAC 0, and DAC 1. This register is set to 00h during power-up reset.

Bit assignments of the Data Select register are as follows:

| 7 | 6 | 5 | 4 | 3 | 2 | 1    | 0    |
|---|---|---|---|---|---|------|------|
| 0 | 0 | 0 | 0 | 0 | 0 | DSL1 | DSL0 |

Bits **DSL1** and **DSL0** select a data source to connect to the computer bus, as shown in Table 1-3.

Table 1-3. Data Source Select Bits DSL1 and DSL0

| DSL1 | DSL0 | Data Source |  |  |  |  |
|------|------|-------------|--|--|--|--|
| 0    | 0    | A/D FIFO    |  |  |  |  |
| 0    | 1    | QRAM        |  |  |  |  |
| 1    | 0    | DAC 0       |  |  |  |  |
| 1    | 1    | DAC 1       |  |  |  |  |

1-6 I/O Addresses

### Base Address +3h (Digital I/O)

Digital I/O consists of two hardware-configured ports: an 8-bit output port (DO0 to DO7) and a 4-bit input port (DI0 to DI3). These ports share the same I/O address but are independent (that is, data written to the output port is not readable by the input port unless the DO0 to DO3 lines are externally connected to the DI0 to DI3 lines). In addition, some of the input port lines do double duty. DI0 is also an input for an external A/D pacer clock, and DI1 is a input for a hardware trigger/gate. Depending on the application, these secondary functions may or may not be used. You can always determine the state of the inputs by reading Base Address +3h.

The DAS-1800HC Series boards provide a strobe signal (DOSTB) for the purpose of strobing data through the digital outputs and latching the data into a register in other equipment. Bit assignments for the output port (DO0 to DO7) are as follows:

| _ | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|---|-----|-----|-----|-----|-----|-----|-----|-----|
|   | DO7 | DO6 | DO5 | DO4 | DO3 | DO2 | DO1 | DO0 |

Bit assignments for the input port (DI0 to DI3) are as follows:

| <br>7 | 6 | 5 | 4 | 3   | 2   | 1   | 0   |
|-------|---|---|---|-----|-----|-----|-----|
| 1     | 0 | 0 | 0 | DI3 | DI2 | DI1 | DI0 |

**Note:** The value of the upper nibble of the input register is fixed at 8h and is used for board identification.

#### Base Address +4h (Control Register A, Read/Write)

Control Register A is a read/write register that controls the trigger/gate and FIFO Enable functions. This register is set to 00h during power-up reset.

Bit assignments for Control Register A are as follows:

| 7    | 6    | 6 5 4 |      | 3    | 2    | 1    | 0    |
|------|------|-------|------|------|------|------|------|
| ATEN | TGPL | TGSL  | TGEN | CGSL | CGEN | SHEN | FFEN |

The bit names are defined as follows:

• ATEN - About Trigger Mode Enable/Disable. This mode uses counter 0 programmed for Interrupt On Terminal Count (82C54 Mode 0) as a post-trigger counter. Conversions can be started by software (TGEN = 0) or by a hardware external trigger (TGEN = 1). After a hardware trigger (DI1/TGIN) is detected (or second hardware trigger in the case TGEN = 1), counter 0 begins to count down until it reaches zero (Counter 0 Terminal Count). Counter 0 reaches zero N conversions later, where N is the value loaded into counter 0 (zero < N). When counter 0 reaches zero, A/D conversions stop and an interrupt is issued.

ATEN functions are as follows:

- ATEN = 0 disables About-trigger mode
- ATEN = 1 enables About-trigger mode

**Note:** Counter 0 must be programmed for 82C54 Mode 0 if the About-trigger mode is to function.

See also "Base Address +7h (Status Register, Read/Write)" on page 1-16 for information on the Counter 0 Terminal Count (COTC) bit.

- TGPL External Trigger/Gate Input Polarity Select (for I/O connector signal DI1/TGIN) determines the polarity that will initiate a triggering or gating of A/D conversions or initiate a trigger to start the About-trigger counter, counter 0. TGPL functions are as follows:
  - TGPL = 0 selects negative edge/level for external trigger/gate
  - TGPL = 1 selects positive edge/level for external trigger/gate

1-8 I/O Addresses

- TGSL Trigger/Gate Select selects I/O connector signal DI1/TGIN as either a trigger input or a gate input. TGSL functions are as follows:
  - TGSL = 0 selects external trigger (edge)
  - TGSL = 1 selects external gate (level)

In About-trigger mode, set TGSL to 0 (Trigger selected).

- TGEN Hardware Trigger/Gate Enable enables/disables I/O connector signal DI1/TGIN as a trigger or gate source for A/D conversions. TGEN does not enable/disable DI1/TGIN as a trigger or gate for About-trigger mode. TGEN functions are as follows:
  - TGEN = 0 disables external trigger/gate
  - TGEN = 1 enables external trigger/gate

When About-trigger mode is enabled (ATEN = 1) and hardware triggers are enabled (TGEN = 1), the first hardware trigger starts conversions and the second hardware trigger begins counting down conversions (counter 0) to ultimately stop conversions.

- CGSL Counter 1/Counter 2 Gate Source Select selects either control bit CGEN or I/O connector signal DI1/TGIN as the counter 1/counter 2 gate source (see "Base Address +Ch, +Dh, +Eh, and +Fh (82C54 Programmable Interval Counter/Timer)" on page 1-23 for more information on counter 1/counter 2). CGSL functions are as follows:
  - CGSL = 0 selects control bit CGEN as the counter 1/counter 2 gate source
  - CGSL = 1 selects external pin DI1 (trigger/gate) as the counter 1/counter 2 gate source
- **CGEN** Counter 1 and Counter 2 Gate Enable/Disable is a software gate for counter 1/counter 2. This bit functions only if bit CGSL = 0. CGEN functions are as follows:
  - CGEN = 0 disables the counter 1/counter 2 gate

- CGEN = 1 enables the counter 1/counter 2 gate
- SHEN Sample and Hold Enable/Disable enables/disables the capability of DAS-1800HC Series boards to work with an external sample-and-hold source. SHEN functions as follows:
  - SHEN = 0 disables the sample-and-hold capability
  - SHEN = 1 enables the sample-and-hold capability
- **FFEN** *FIFO Enable* enables/disables the FIFO's read and write address pointers. The FIFO should be reset before A/D conversions are enabled to ensure proper FIFO operation. FFEN functions are as follows:
  - FFEN = 0 disables FIFO (FIFO reset)
  - FFEN = 1 enables FIFO

Table 1-4 shows trigger modes using an internal A/D pacer clock (82C54 counter 1/counter 2).

Table 1-4. Trigger Modes Using an Internal A/D Pacer Clock

| Function                                   | ATEN | TGSL  | TGEN | CGSL | CGEN  | T/G Source |
|--------------------------------------------|------|-------|------|------|-------|------------|
| Internal Gate                              | 0    | $X^1$ | 0    | 0    | $G^2$ | CGEN       |
| External Gate                              | 0    | 1     | 1    | 1    | X     | TGIN       |
| External Post Trigger                      | 0    | 0     | 1    | 1    | X     | TGIN       |
| External Pre-about<br>Trigger <sup>3</sup> | 1    | 0     | 0    | 0    | 1     | TGIN       |
| External Pre-about<br>Trigger <sup>4</sup> | 1    | 0     | 1    | 0    | 1     | TGIN       |

#### Notes

1-10 I/O Addresses

 $<sup>^{1}</sup>$  X = Don't care.

 $<sup>^2</sup>$  G = Gate.

<sup>&</sup>lt;sup>3</sup> With TGEN = 0, the first external trigger begins the countdown of counter 0 for Pre- and About-trigger mode.

<sup>&</sup>lt;sup>4</sup> With TGEN = 1, the first trigger starts A/D conversions, and the second trigger begins the countdown of counter 0 for Pre- and About-trigger mode.

Table 1-5 shows trigger modes using an external A/D pacer clock (Input Signal DIO/XPCLK).

Table 1-5. Trigger Modes Using an External Pacer Clock

| Function                                   | ATEN | TGSL  | TGEN | CGSL | CGEN           | T/G Source |
|--------------------------------------------|------|-------|------|------|----------------|------------|
| Internal Gate                              | 0    | $X^1$ | 0    | 0    | A <sup>2</sup> | CVEN       |
| External Gate                              | 0    | 1     | 1    | 0    | A              | TGIN       |
| External Post Trigger                      | 0    | 0     | 1    | 0    | A              | TGIN       |
| External Pre-about<br>Trigger <sup>3</sup> | 1    | 0     | 0    | 0    | A              | TGIN       |
| External Pre-about<br>Trigger <sup>4</sup> | 1    | 0     | 1    | 0    | A              | TGIN       |

#### **Notes**

Note: In About-trigger and Pre-trigger modes, the Convert Enable bit (CVEN) is automatically reset to 0 when counter 0 reaches Terminal Count.

### Base Address +5h (Control Register B, Read/Write)

Control Register B is a read/write register that controls the enabling/disabling and the level settings of interrupts and DMA. This

 $<sup>^{1}</sup>$  X = Don't care.

 $<sup>^{2}</sup>$  A = Available. (When an external clock is used for A/D pacing, counter 1/counter 2 is available

for interrupt generation for Digital I/O and DAC Outputs.)

With TGEN = 0, the first external trigger begins the countdown of counter 0 for Pre- and About-trigger mode.

<sup>&</sup>lt;sup>4</sup> With TGEN = 1, the first trigger starts the A/D conversions, and the second trigger begins the countdown of counter 0 for Pre- and About-trigger mode.

register is set to 00h during power-up reset, thereby disabling DMA and interrupts. Bit assignments for this register are as follows:

| _ | 7    | 6    | 5   | 4   | 3   | 2   | 1   | 0   |
|---|------|------|-----|-----|-----|-----|-----|-----|
|   | CIEN | FIMD | IL2 | IL1 | IL0 | DL2 | DL1 | DL0 |

The bit names are defined as follows:

- **CIEN** *Enable/Disable Interrupt on Counter 2 Terminal Count.* CIEN functions as follows:
  - CIEN = 0 disables the interrupt on counter 1/counter 2
  - CIEN = 1 enables the interrupt on counter 1/counter 2
- **FIMD** *FIFO Interrupt Mode*. FIFO Not Empty or Half Full interrupts are disabled when DMA is enabled. FIMD functions are as follows:
  - FIMD = 0 enables interrupt on FIFO Not Empty only if interrupts are enabled
  - FIMD = 1 enables interrupt on FIFO Half Full only if interrupts are enabled
- **IL2** to **IL0** *Interrupt Level Select / Enable* selects and enables the desired interrupt level for processing interrupts.

If interrupts are enabled and DMA is disabled, an interrupt is generated as determined by the FIFO Interrupt mode (FIMD) bit. If interrupts are enabled and DMA is enabled, an interrupt is generated when a terminal count (T/C) is received from the computer's DMA controller to signify completion of the DMA transfer.

1-12 I/O Addresses

Table 1-6. Interrupt Level Select Bits IL2 to IL0

| IL2 | IL1 | IL0 | Interrupt Level        |
|-----|-----|-----|------------------------|
| 0   | 0   | 0   | Interrupts not enabled |
| 0   | 0   | 1   | Level 3                |
| 0   | 1   | 0   | Level 5                |
| 0   | 1   | 1   | Level 7                |
| 1   | 0   | 0   | Interrupts not enabled |
| 1   | 0   | 1   | Level 10               |
| 1   | 1   | 0   | Level 11               |
| 1   | 1   | 1   | Level 15               |

**Note:** The DAS-1800HC Series boards use pulsed interrupts, allowing one board to share an interrupt level with another. Sharing a level already assigned to another I/O device (other than a DAS-1800HC Series board) may cause a bus conflict.

• **DL2** to **DL0** - *DMA Level Select*. These bits serve dual functions: they enable/disable DMA operation and, when enabling DMA operation, they determine the DMA level (or levels) for DAS-1800HC Series boards. A DMA request is issued when the FIFO is not empty.

DL2 to DL0 function as shown in Table 1-7.

Table 1-7. DMA Level Select Bits DL2 to DL0

| DL2 | DL1 | DL0 | Function             |
|-----|-----|-----|----------------------|
| 0   | 0   | 0   | DMA disabled         |
| 0   | 0   | 1   | DMA level 5 selected |
| 0   | 1   | 0   | DMA level 6 selected |

Table 1-7. DMA Level Select Bits DL2 to DL0 (cont.)

| DL2 | DL1 | DL0 | Function                         |
|-----|-----|-----|----------------------------------|
| 0   | 1   | 1   | DMA level 7 selected             |
| 1   | 0   | 0   | DMA disabled                     |
| 1   | 0   | 1   | Dual DMA level 5 and 6 selected  |
| 1   | 1   | 0   | Dual DMA levels 6 and 7 selected |
| 1   | 1   | 1   | Dual DMA levels 7 and 5 selected |

As Table 1-7 shows, the DAS-1800HC Series boards support single or dual DMA. In dual DMA mode, the first level used for data transfer is the first level indicated in the sequences shown under *Function* in Table 1-7. For example, when bits DL0 = 1, DL1 = 0, and DL2 = 1, they select dual DMA operation at levels 5 and 6. From Table 1-7, level 5 is the first DMA level used for data transfer; level 6 follows.

### Base Address +6h (Control Register C, Read/Write)

Control Register C is a read/write register that controls the following board-level functions: selection of unipolar/bipolar input mode, selection of single-ended/differential input mode, selection of the ADC pacer clock source, and enabling/disabling of the burst mode. Control Register C is set to 00h during power-up reset.

Bit assignments for Control Register C are as follows:

| 7   | 6   | 5 | 4 | 3 | 2    | 1  | 0  |
|-----|-----|---|---|---|------|----|----|
| U/B | S/D | 0 | 0 | 0 | BMDE | S1 | S0 |

1-14 I/O Addresses

The bit names for Control Register C are defined as follows:

- U/B Unipolar/Bipolar Analog Input Select. U/B functions are as follows:
  - U/B = 0 sets the analog input for bipolar mode
  - U/B = 1 sets the analog input for unipolar mode
- S/D Single-ended/Differential Select. S/D functions as follows:
  - S/D = 0 sets the analog input for 32-channel differential mode
  - S/D = 1 sets the analog input for 64-channel single-ended mode
- Bits 3, 4, and 5 of Control Register C are unused.
- BMDE Burst Mode Enable/Disable determines whether burst A/D conversions are enabled. Burst mode must be enabled when a sample-and-hold board is used with a DAS-1800HC Series board. BMDE functions as follows:
  - BMDE = 0 disables burst mode
  - BMDE = 1 enables burst mode
- **S1** and **S0** *Pacer Clock Source Select* selects the pacer-clock source for A/D conversions. S1 and S0 function as shown in Table 1-8.

Table 1-8. Pacer Clock Select Bits S1 and S0

| S1 | S0 | Function                                                                   |  |
|----|----|----------------------------------------------------------------------------|--|
| 0  | 0  | Software convert only                                                      |  |
| 0  | 1  | Internal pacer clock source<br>82C54 (counter 1/counter 2<br>falling edge) |  |
| 1  | 0  | External pacer clock source (rising edge) DI0/XPCLK                        |  |
| 1  | 1  | External pacer clock source (falling edge) DI0/XPCLK                       |  |

#### Base Address +7h (Status Register, Read/Write)

The Status register is set to a value of 00h during power-up reset. Bit assignments are as follows:



You can read all bits of the Status register by issuing an I/O read at Base Address +7h. You can also clear, set, and mask many of the Status register bits by manipulating them as shown in Table 1-9.

**Table 1-9. Status Register Bit Manipulation Operations** 

| Bit No. | Flag                                             | Bit Manipulation Operation                   |
|---------|--------------------------------------------------|----------------------------------------------|
| 0       | INT - event-driven interrupt                     | Read, Clear <sup>1</sup> , Mask <sup>2</sup> |
| 1       | DMATC - DMA Terminal Count                       | Read, Clear, Mask                            |
| 2       | C2TC - counter 2 Terminal Count                  | Read, Clear, Mask                            |
| 3       | COTC - counter 0 Terminal Count                  | Read, Clear, Mask                            |
| 4       | OVF - conversion overflow                        | Read, Clear, Mask                            |
| 5       | FHF - FIFO Half Empty                            | Read                                         |
| 6       | FNE - FIFO Not Empty                             | Read                                         |
| 7       | CVEN - Convert Enable/Disable<br>A/D Conversions | Read, Clear, Mask, Set <sup>3</sup>          |

#### **Notes**

The bit names are defined as follows:

**CVEN** - Convert Enable/Disable A/D Conversions. This bit has ultimate control over A/D conversions, depending on the states of triggers, gates, and pacer clocks. CVEN functions as follows:

1-16 I/O Addresses

Clear indicates that writing a 0 to this location clears the bit.

<sup>&</sup>lt;sup>2</sup> Mask indicates that writing a 1 to this location protects the value of the bit against an overwrite. The exception is CVEN, which is masked against an overwrite by bit 6 of the Status register.

3 Set indicates that writing a 1 to this location sets the bit to a 1.

- CVEN = 0 disables conversions
- CVEN = 1 enables conversions

**Note:** CVEN is automatically reset by hardware in the event of a FIFO overflow condition or when, in About-trigger mode, a Counter 0 Terminal Count occurs.

FNE - FIFO Not Empty flag. This bit comes directly from the FIFO
to indicate whether the FIFO contains data; it can not be reset by
writing to the status register.

FNE functions are as follows:

- FNE = 0 for FIFO empty
- FNE = 1 for FIFO not empty

**Note:** When FIMD (bit 6) of Control Register B is 0 and interrupts are enabled (and DMA disabled), a FIFO Not Empty event causes an interrupt and sets INT (bit 0) of the Status register to 1.

- **FHF** *FIFO Half Full* flag. This bit comes directly from the FIFO to indicate whether the FIFO is half full (512 words); FHF can not be reset by writing to the Status register. This interrupt is useful in conjunction with the Intel INSW instruction to move large blocks of data. FHF functions as follows:
  - FHF = 0 for FIFO not half full
  - FHF = 1 for FIFO is half full

**Note:** When FIMD (bit 6) of Control Register B is 1 and interrupts are enabled (and DMA Disabled), the FIFO Half Full event causes an interrupt and sets INT (bit 0) of the Status register to 1.

• **OVF** - Event-driven *FIFO Overflow* condition. This bit indicates that the FIFO contains the maximum amount of data it can hold (1024 words) and is about to overflow. To prevent data loss, this condition always terminates conversions (CVEN = 0). If interrupts are enabled, FIFO Overflow always causes an interrupt and sets the INT bit of the Status register to 1. OVF can be cleared by writing a 0 to Status register bit 4.

#### OVF functions as follows:

- OVF = 0 for data has not overflowed in FIFO
- OVF = 1 for data has overflowed in FIFO

**Note:** OVF is enabled only when the FIFO is enabled (FFEN = 1).

• **COTC** - Event-driven *Counter 0 Terminal Count*. This bit indicates that counter 0 has reached its Terminal Count and is to be used in conjunction with the About-trigger mode. Counter 0 must be programmed for 82C54 Mode 0 and ATEN (bit 7) of Control Register A set to 1 for About-trigger mode to operate. If interrupts are enabled, this event causes an interrupt and sets the INT bit of this register to 1. COTC can be cleared by writing a 0 to Status register bit 3.

#### COTC functions are as follows:

- C0TC = 0 indicates that a Counter 0 Terminal Count has not occurred
- COTC = 1 indicates that a Counter 0 Terminal Count has occurred

**Note:** COTC is enabled only when the About-trigger mode is enabled (ATEN = 1).

• **C2TC** - Event-driven *Counter 1/Counter 2 Terminal Count*. This bit indicates that counter 2 of the cascaded counters 1 and 2 has reached its Terminal Count. This bit detects a low-going Terminal Count pulse

1-18 I/O Addresses

(82C54 mode 2) when CIEN (bit 7) of Control Register B is set to a 1. If interrupts are enabled, this event will cause an interrupt and set the INT bit of this register to 1. C2TC can be cleared by writing a 0 to Status register bit 2.

#### C2TC functions are as follows:

- C2TC = 0 indicates that a counter 1/counter 2 Terminal Count has not occurred
- C2TC = 1 indicates that a counter 1/counter 2 Terminal Count has occurred

**Note:** C2TC is enabled only if an interrupt is enabled on Counters 1 and 2 (CIEN = 1).

• **DMATC** - Event-driven *DMA Terminal Count*. When DMA is enabled, this bit indicates that a DMA Terminal Count has been reached. If interrupts are also enabled, this event causes an interrupt and sets the INT bit of this register. DMATC can be cleared by writing a 0 to Status register bit 1.

#### DMATC functions are as follows:

- DMATC = 0 indicates that a DMA Terminal Count has not occurred
- DMATC = 1 indicates that a DMA Terminal Count has occurred

**Note:** DMATC is enabled only if DMA is enabled.

- **INT** Event-driven *Interrupt* flag. The events that can cause this bit to be set are as follows:
  - DMA Terminal Count
  - Counter 1/Counter 2 Terminal Count

- Counter 0 Terminal Count
- FIFO Overflow
- FIFO Half Full
- FIFO Not Empty

Interrupts must be enabled for this bit to function. INT can be cleared by writing a 0 to Status register bit 0.

INT functions are as follows:

- INT = 0 indicates that no interrupt has occurred
- INT = 1 indicates that an interrupt has occurred

### Base Address +8h (Burst Length Register, Read/Write)

The Burst Length register is an 8-bit read/write register that controls the operation of the Burst Length counter when in burst mode. The Burst Length register is set to 00h during power-up reset.

Bit assignments of the Burst Length register are as follows:

| 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|------|------|------|------|------|------|------|------|
| BLV7 | BLV6 | BLV5 | BLV4 | BLV3 | BLV2 | BLV1 | BLV0 |

**BLV7** to **BLV0** represent the *Burst Length Value*. These bits determine the number of conversions to perform for each pacer clock tick during a burst mode acquisition. These bits have no function if burst mode is not enabled. Burst Length Values have the following characteristics: Burst Length = BLV + 1; BLV < 256

1-20 I/O Addresses

**Note:** The burst length must be set to the number of conversions plus one when used with SSH mode. Refer to the *DAS-1800HC Series User's Guide* for information on using SSH hardware.

## Base Address +9h (Burst Mode Conversion Rate Register, Read/Write)

The Burst Mode Conversion Rate register is an 8-bit read/write register whose lower six bits program the burst mode conversion rate (A/D conversion rate) during burst mode acquisition. This register is set to 00h during power-up reset.

Bit assignments of the Burst Mode Conversion Rate register are as follows:

| 7 | 6 | 5    | 4    | 3    | 2    | 1    | 0    |
|---|---|------|------|------|------|------|------|
| 0 | 0 | BRV5 | BRV4 | BRV3 | BRV2 | BRV1 | BRV0 |

The bit names are defined as follows:

- Bits 7 and 6 are unused.
- **BRV5** to **BRV0** *Burst Rate Value*. These bits determine the rate of conversions during a burst mode acquisition. These six bits have no function if burst mode is not enabled. The Burst Rate Value has the following characteristics: Burst Rate = 1 MHz / (BRV + 1); BRV > 1

## Base Address +Ah (QRAM Address Start Register, Read/Write)

The QRAM Address Start register is a read/write register that determines the starting address of the channel-gain QRAM for A/D multiplexing.

This register, when used in conjunction with the QRAM Data location (Base Address 0h, write), sets the address for loading the QRAM.

**Note:** The QRAM Address counter is a down counter. Thus, the QRAM is loaded with the first channel-gain data at Address N-1, the next at N-2, and so on down to Address 00h (where N is the scan length).

When a data word has been loaded into the QRAM, the QRAM address automatically decrements. Thus, a QRAM address need not be loaded prior to every QRAM data write. An address write need only occur at the beginning and end of loading the entire scan data into the QRAM.

After all of the channel-gain data is loaded into the QRAM, the QRAM address must be set to the *starting* address by writing the starting address to the QRAM Address Start register.

Bit assignments of the QRAM Address Start register are as follows:

| 7 | 6 | 5    | 4    | 3    | 2    | 1    | 0    |
|---|---|------|------|------|------|------|------|
| 0 | 0 | QAS5 | QAS4 | QAS3 | QAS2 | QAS1 | QAS0 |

- Bits 7 and 6 are unused.
- QAS5 to QAS0 *QRAM Address Start* bits. These bits determine the starting address of the channel-gain QRAM for A/D multiplexing.

About 400 ns after the ADC starts a conversion, while the sample/hold is holding the previous channel, the QRAM address decrements for the next conversion. At the end of a conversion scan, the cycle repeats, starting with the QRAM start address. On writing to the QRAM Address Start register, the QRAM Address counter always automatically initializes to the QRAM start address. To perform conversions on a single channel, set the QRAM start address to 00h and load the QRAM with the appropriate channel number and gain data. The QRAM Address register is set to 00h during power-up reset.

1-22 I/O Addresses

## Base Address +Ch, +Dh, +Eh, and +Fh (82C54 Programmable Interval Counter/Timer)

The registers from Base Address +Ch to +Fh correspond to the four registers of the 82C54 Programmable Counter/Timer. Refer to the Intel 82C54 data sheet for a full description of features (you can obtain the data sheet from Intel by telephoning 800/548-4725).

On DAS-1800HC Series boards, counter 0 of the 82C54 is dedicated to serving as an A/D conversion counter for the About-trigger mode. In the About-trigger mode, **counter 0 MUST be programmed in 82C54 Mode 0.** 

Counters 1 and 2 of the 82C54 are used as the onboard A/D Pacer Clock or as a programmable interrupt generator. These counters are cascaded as counter 1 then counter 2, with the counter 2 output as the source of A/D pacing or programmed interrupts. **These counters must be programmed in 82C54 Mode 2.** The read/write capabilities of Counter/Timer registers are shown in Table 1-10.

Table 1-10. Read/Write Capabilities of Counter/Timer Registers

| Base Address | Register      | Mode       |
|--------------|---------------|------------|
| +Ch          | Counter 0     | Read/Write |
| +Dh          | Counter 1     | Read/Write |
| +Eh          | Counter 2     | Read/Write |
| +Fh          | 82C54 control | Write only |

**Note:** Counter 1 Rate =  $5 \text{ MHz} \div \text{N}$ ; 1 < N < 65,536. Counter 2 Rate = Counter 1 Rate  $\div \text{M}$ ; 1 < M < 65,536

## **Programming Guidelines**

This chapter provides basic steps for programming a software conversion with a DAS-1800HC Series board. In these steps, you are programming the board for unipolar mode, single-ended analog inputs, software conversions, and internal trigger. You are sampling four analog input channels in ascending order (0 to 3), and each channel has a gain of 5 if the board is a DAS-1801HC or 2 if the board is a DAS-1802HC. To perform the A/D conversion, program the QRAM first, then program the board setup. The following sections describe these procedures.

### Programming the QRAM with Channel-gain Data

Perform the following procedure to program the QRAM:

- 1. Set the Data Select register to point to the QRAM by writing the value 01h to Base Address +2h.
- 2. Initialize the QRAM starting address to the number of channels in the scan minus one by writing the value 03h to Base Address Ah.
- 3. Load the QRAM with the channel-gain data, as follows:
  - a. Write the value 0040h (for channel 0, gain of 2) to Base Address +0h.
  - b. Write the value 0041h (for channel 1, gain of 2) to Base Address +0h.
  - c. Write the value 0042h (for channel 2, gain of 2) to Base Address 0h.

- d. Write the value 0043h (for channel 3, gain of 2) to Base Address 0h.
- 4. Re-initialize the QRAM to its starting address by writing the value 03h to Base Address Ah.

#### **Programming the Board Setup**

Program the board for its modes, input configuration, triggering, and other functions as follows:

- 1. Set the A/D operating modes (unipolar, single-ended, software conversions) by writing the value C0h to Base Address +6h (Control Register C).
- 2. Enable the A/D FIFO by writing the value 01h to Base Address +4h (Control Register A).
- 3. Set the Data Select register to point to the A/D FIFO by writing the value 00h to Base Address +2h.
- 4. Enable A/D conversions by writing the value 80h to Base Address 7h (Status register).
- 5. Initiate an A/D conversion by writing any word value to Base Address +0h.
- 6. Poll for the condition of A/D FIFO Not Empty by continuously reading Base Address 7h (Status register) for the condition of bit 6 = 1.
- 7. Read the A/D FIFO by reading a word of ADC data from Base Address +0h.
- 8. Repeat steps 5, 6, and 7 until inputs from all four channels have been converted.
- 9. Disable A/D conversions by writing the value 00h to Base Address 7h (Status register).

10. Disable the A/D FIFO by writing the value 00h to Base Address +4h (Control Register A).



## **Summary of I/O Address Bits**

Table A-1 summarizes the functions of all bits at the I/O addresses used by DAS-1800HC Series boards. The table also lists the pages of Chapter 1 containing information on these bits.

Table A-1. Summary of I/O Address Bits

| Bit Name     | Description                                                                                     | Page Reference    |
|--------------|-------------------------------------------------------------------------------------------------|-------------------|
| ATEN         | Enable/disable bit for About-trigger mode                                                       | page 1-8          |
| BLV0 to BLV7 | Determine the number of conversions during each burst mode scan                                 | page 1-20         |
| BMDE         | Enables/disables burst mode                                                                     | page 1-15         |
| BRV0 to BRV5 | Determine the burst mode conversion rate                                                        | page 1-21         |
| СОТС         | Indicates whether a Counter 0 Terminal Count has occurred                                       | page 1-18         |
| C2TC         | Indicates whether a Counter 1/Counter 2 Terminal Count has occurred                             | page 1-18         |
| CGEN         | Enables/disables the counter 1/counter 2 gate                                                   | page 1-9          |
| CGSL         | Selects either bit CGEN or I/O connector signal DI1/TGIN as the counter 1/counter 2 gate source | page 1-9          |
| CIEN         | Enables/disables the interrupt on counter 1/counter 2                                           | page 1-12         |
| CVEN         | Enables/disables A/D conversions                                                                | page 1-16         |
| D1 to D10    | Data bits for A/D FIFO data and DAC 0/1 data                                                    | pages 1-3 and 1-5 |
| DI0 to DI3   | Bits of the digital input port                                                                  | page 1-7          |
| DL0 to DL2   | Enable/disable DMA operation and set DMA level                                                  | page 1-13         |

Table A-1. Summary of I/O Address Bits (cont.)

| Bit Name      | Description                                                                                                        | Page Reference |
|---------------|--------------------------------------------------------------------------------------------------------------------|----------------|
| DMATC         | Indicates whether a DMA Terminal Count has occurred                                                                | page 1-19      |
| DO0 to DO7    | Bits of the digital output port                                                                                    | page 1-7       |
| DSL0 and DSL1 | Select the data source for Base Address +0h                                                                        | page 1-6       |
| FFEN          | Enables/disables the FIFO read/write address pointers                                                              | page 1-10      |
| FHF           | Indicates whether or not the FIFO is half full                                                                     | page 1-17      |
| FIMD          | Enables interrupt on FIFO Not Empty or FIFO Half Full - only when interrupts are enabled                           | page 1-12      |
| FNE           | Indicates whether the FIFO is empty                                                                                | page 1-17      |
| GN0 and GN1   | Select the gain code                                                                                               | page 1-4       |
| IL0 to IL2    | Selects and enables the interrupt level                                                                            | page 1-12      |
| INT           | Indicates whether an interrupt has occurred                                                                        | page 1-19      |
| MUX0 to MUX5  | Analog-input multiplexer-control bits; these bits select 1 of 64 single-ended or 1 of 32 differential channels     | page 1-4       |
| OVF           | Indicates whether data has overflowed in the FIFO                                                                  | page 1-18      |
| QAS0 to QAS5  | Determine starting address of the channel-gain QRAM                                                                | page 1-22      |
| S0 and S1     | Selects the pacer clock source for A/D conversions                                                                 | page 1-15      |
| S/D           | Selects single-ended or differential input configuration                                                           | page 1-15      |
| SHEN          | Enables/disables the sample-and-hold capability                                                                    | page 1-10      |
| TGEN          | Enables/disables I/O connector signal DI1/TGIN as a trigger or gate source for A/D conversions                     | page 1-9       |
| TGPL          | Sets the polarity for initiating a trigger/gate of A/D conversions or a trigger to start the about-trigger counter | page 1-8       |
| TGSL          | Selects I/O connector signal DI1/TGIN as either a trigger or a gate                                                | page 1-9       |
| U/B           | Selects unipolar or bipolar input mode                                                                             | page 1-15      |