# $NuDAQ^{\hat{a}}$

# ACL-8316/8312

16/12-bit High Performance DAS Cards with 1K FIFO

# User's Guide



**Recycled Paper** 

©Copyright 1996~2000 ADLINK Technology Inc.

All Rights Reserved.

Manual Rev. 2.50: November 9, 2000

The information in this document is subject to change without prior notice in order to improve reliability, design and function and does not represent a commitment on the part of the manufacturer.

In no event will the manufacturer be liable for direct, indirect, special, incidental, or consequential damages arising out of the use or inability to use the product or documentation, even if advised of the possibility of such damages.

This document contains proprietary information protected by copyright. All rights are reserved. No part of this manual may be reproduced by any mechanical, electronic, or other means in any form without prior written permission of the manufacturer.

#### Trademarks

NuDAQ<sup>®</sup> is registered trademark of ADLINK Technology Inc..

Other product names mentioned herein are used for identification purposes only and may be trademarks and/or registered trademarks of their respective companies.

# Getting service from ADLINK

Customer Satisfaction is always the most important thing for ADLINK Tech Inc. If you need any help or service, please contact us and get it.

| nie. Il yeu neeu       | any noip              |                                 |                     | ana goria                 |  |
|------------------------|-----------------------|---------------------------------|---------------------|---------------------------|--|
|                        | -                     | ADLINK Techn                    | ology Inc.          |                           |  |
| Web Site               |                       | /w.adlink.com.tw                |                     |                           |  |
|                        |                       | http://www.adlinktechnology.com |                     |                           |  |
| Sales & Service        | service@adlink.com.tw |                                 |                     |                           |  |
| Technical              | NuDAQ                 |                                 | nudaq@adlink.com.tw |                           |  |
| Support                | NuDAM                 |                                 | nudam@adlink.com.tw |                           |  |
|                        | NuIPC                 |                                 | nuipc@adlink.com.tw |                           |  |
|                        | NuPRO                 |                                 | nupro@adlink.com.tw |                           |  |
|                        | Software              | Э                               | sw@adlink.c         | com.tw                    |  |
| TEL                    | +886-2-8              | 32265877                        | FAX                 | +886-2-82265717           |  |
| Address                |                       |                                 |                     | aipei, 235 Taiwan, R.O.C. |  |
| Please inform o        | r FAX us              | s of your detailed in           | nformation f        | or a prompt, satisfactory |  |
| and constant se        | ervice.               |                                 |                     | -<br>-                    |  |
|                        |                       | Detailed Company                | / Informatio        | n                         |  |
| Company/Organiz        | zation                |                                 |                     |                           |  |
| Contact Person         |                       |                                 |                     |                           |  |
| E-mail Address         |                       |                                 |                     |                           |  |
| Address                |                       |                                 |                     |                           |  |
| Country                |                       |                                 |                     |                           |  |
| TEL                    |                       |                                 | FAX                 |                           |  |
| Web Site               |                       |                                 |                     |                           |  |
|                        |                       | Questio                         | ns                  |                           |  |
| Product Model          |                       |                                 |                     |                           |  |
| Environment to U       | se                    | □ OS                            |                     |                           |  |
|                        |                       | Computer Brand                  |                     |                           |  |
|                        |                       | □ M/B :                         |                     |                           |  |
|                        |                       |                                 |                     | • ·                       |  |
|                        |                       | Chipset :                       |                     | 55:                       |  |
|                        |                       | □ Video Card :                  |                     |                           |  |
|                        |                       | Network Interface Card :        |                     |                           |  |
|                        |                       | □ Other :                       |                     |                           |  |
|                        |                       |                                 |                     |                           |  |
| Challenge Descrip      | otion                 |                                 |                     |                           |  |
|                        |                       |                                 |                     |                           |  |
| Suggestions for A      |                       |                                 |                     |                           |  |
| Suggestions for ADEINK |                       |                                 |                     |                           |  |

# Table of Contents

| Chapte | er 1 Introduction                  | 1  |
|--------|------------------------------------|----|
| 1.1    | Features                           | 3  |
| 1.2    | Applications                       | 3  |
| 1.3    | Specifications                     | 4  |
| 1.4    | Software Support                   | 6  |
|        | 1.4.1 Programming Library          | 6  |
|        | 1.4.2 LabView Driver               | 6  |
| Chapte | er 2 Installation                  | 7  |
| 2.1    | What You Have                      | 7  |
| 2.2    | Unpacking                          | 7  |
| 2.3    | ACL-8316/12's Layout               | 8  |
| 2.4    | Jumper and DIP Switch Description  | 9  |
| 2.5    | Base Address Setting               | 9  |
| 2.6    | Analog Input Channel Configuration | 11 |
| 2.7    | Analog Output Channel Setting      | 11 |
|        | 2.7.1 Channel Output Range Setting | 11 |
|        | 2.7.2 Output Mode Setting          |    |
| 2.8    | DMA Channel Setting                | 14 |
| 2.9    | IRQ Level Setting                  |    |
| 2.10   | Clock Source Setting               |    |
| 2.11   | Connectors Pin Assignment          |    |
| 2.12   | Daughter Board Connection          |    |
|        | 2.12.1 Connect with ACLD-8125      |    |
|        | 2.12.2 Connect with ACLD-9137      |    |
|        | 2.12.3 Connect with ACLD-9182      |    |
|        | 2.12.4 Connect with ACLD-9185      |    |
|        | 2.12.5 Connect with ACLD-9188/9138 | 19 |
| Chapte | er 3 Registers Format              | 20 |
| 3.1    | I/O Port Address                   | 20 |
| 3.2    | A/D Data Registers                 |    |
| 3.3    | FIFO Enable Register               | 22 |
| 3.4    | Gain Control Register              | 22 |
| 3.5    | A/D Channel Multiplexer Register   | 23 |
| 3.6    | Interrupt Source Control Register  | 24 |

| 3.7                                                                                                                         | AD Mode Control Register                                                                                                                                                                                                                                                                                                                   | 25                                                                         |
|-----------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|
| 3.8                                                                                                                         | A/D Status Register                                                                                                                                                                                                                                                                                                                        | 26                                                                         |
| 3.9                                                                                                                         | Clear Interrupt Register                                                                                                                                                                                                                                                                                                                   | 27                                                                         |
| 3.10                                                                                                                        | Software A/D Trigger Register                                                                                                                                                                                                                                                                                                              | 27                                                                         |
| 3.11                                                                                                                        | DA Data Registers                                                                                                                                                                                                                                                                                                                          | 27                                                                         |
| 3.12                                                                                                                        | DA Mode Control Register                                                                                                                                                                                                                                                                                                                   | 28                                                                         |
| 3.13                                                                                                                        | Digital I/O register                                                                                                                                                                                                                                                                                                                       | 30                                                                         |
| 3.14                                                                                                                        | Internal Timer/Counter Register                                                                                                                                                                                                                                                                                                            |                                                                            |
| Chapte                                                                                                                      | er 4 Operation Theorem                                                                                                                                                                                                                                                                                                                     | 31                                                                         |
| 4.1                                                                                                                         | A/D Conversion                                                                                                                                                                                                                                                                                                                             | 31                                                                         |
|                                                                                                                             | 4.1.1 A/D Conversion Procedure                                                                                                                                                                                                                                                                                                             |                                                                            |
|                                                                                                                             | 4.1.2 A/D Signal Source Control                                                                                                                                                                                                                                                                                                            | 32                                                                         |
|                                                                                                                             | 4.1.3 A/D Trigger Sources Control                                                                                                                                                                                                                                                                                                          |                                                                            |
|                                                                                                                             | 4.1.4 A/D Data Buffering                                                                                                                                                                                                                                                                                                                   |                                                                            |
|                                                                                                                             | 4.1.5 A/D Data Transfer Modes                                                                                                                                                                                                                                                                                                              |                                                                            |
|                                                                                                                             | 4.1.6 A/D Data Format                                                                                                                                                                                                                                                                                                                      | -                                                                          |
| 4.2                                                                                                                         | Interrupt System                                                                                                                                                                                                                                                                                                                           |                                                                            |
| 4.3                                                                                                                         | D/A Conversion                                                                                                                                                                                                                                                                                                                             |                                                                            |
| 4.4                                                                                                                         | Digital Input and Output                                                                                                                                                                                                                                                                                                                   |                                                                            |
|                                                                                                                             |                                                                                                                                                                                                                                                                                                                                            |                                                                            |
| 4.4<br>4.5                                                                                                                  | Timer/Counter Operation                                                                                                                                                                                                                                                                                                                    |                                                                            |
| 4.5                                                                                                                         |                                                                                                                                                                                                                                                                                                                                            | 46                                                                         |
| 4.5                                                                                                                         | Timer/Counter Operation                                                                                                                                                                                                                                                                                                                    | 46<br><b>49</b>                                                            |
| 4.5<br>Chapte                                                                                                               | Timer/Counter Operation                                                                                                                                                                                                                                                                                                                    | 46<br><b>49</b><br>49                                                      |
| 4.5<br><b>Chapte</b><br>5.1                                                                                                 | Timer/Counter Operation<br>er 5 C/C++ Library<br>Installation                                                                                                                                                                                                                                                                              | 46<br><b>49</b><br>50                                                      |
| 4.5<br><b>Chapte</b><br>5.1<br>5.2                                                                                          | Timer/Counter Operation<br>er 5 C/C++ Library<br>Installation<br>Software Utility                                                                                                                                                                                                                                                          | 46<br>49<br>50<br>50                                                       |
| 4.5<br><b>Chapte</b><br>5.1<br>5.2<br>5.3                                                                                   | Timer/Counter Operation<br>er 5 C/C++ Library<br>Installation<br>Software Utility<br>Programming Guide                                                                                                                                                                                                                                     | 46<br>49<br>50<br>50<br>51                                                 |
| 4.5<br><b>Chapte</b><br>5.1<br>5.2<br>5.3<br>5.4                                                                            | Timer/Counter Operation<br>er 5 C/C++ Library<br>Installation<br>Software Utility<br>Programming Guide<br>_8316_Initial                                                                                                                                                                                                                    | 46<br>49<br>50<br>51<br>51                                                 |
| 4.5<br><b>Chapte</b><br>5.1<br>5.2<br>5.3<br>5.4<br>5.5                                                                     | Timer/Counter Operation<br>er 5 C/C++ Library<br>Installation<br>Software Utility<br>Programming Guide<br>_8316_Initial<br>_8316_Switch_Card_No                                                                                                                                                                                            | 46<br>49<br>50<br>51<br>51<br>52                                           |
| 4.5<br><b>Chapte</b><br>5.1<br>5.2<br>5.3<br>5.4<br>5.5<br>5.6                                                              | Timer/Counter Operation<br>er 5 C/C++ Library<br>Installation<br>Software Utility<br>Programming Guide<br>_8316_Initial<br>_8316_Switch_Card_No<br>_8316_DI.<br>_8316_DI _Channel                                                                                                                                                          | 46<br>49<br>50<br>51<br>51<br>52<br>52                                     |
| 4.5<br><b>Chapte</b><br>5.1<br>5.2<br>5.3<br>5.4<br>5.5<br>5.6<br>5.7                                                       | Timer/Counter Operation<br>er 5 C/C++ Library<br>Installation<br>Software Utility<br>Programming Guide<br>8316_Initial<br>8316_Switch_Card_No8316_DI.                                                                                                                                                                                      |                                                                            |
| 4.5<br><b>Chapte</b><br>5.1<br>5.2<br>5.3<br>5.4<br>5.5<br>5.6<br>5.7<br>5.8                                                | Timer/Counter Operation<br>er 5 C/C++ Library<br>Installation<br>Software Utility<br>Programming Guide<br>_8316_Initial<br>_8316_Switch_Card_No<br>_8316_DI<br>_8316_DI<br>_8316_DO                                                                                                                                                        | 46<br>49<br>50<br>51<br>51<br>51<br>52<br>52<br>53<br>53                   |
| 4.5<br><b>Chapte</b><br>5.1<br>5.2<br>5.3<br>5.4<br>5.5<br>5.6<br>5.7<br>5.8<br>5.9                                         | Timer/Counter Operation<br>er 5 C/C++ Library<br>Installation<br>Software Utility<br>Programming Guide<br>_8316_Initial<br>_8316_Switch_Card_No<br>_8316_DI<br>_8316_DI<br>_8316_DO<br>_8316_DO<br>_8316_DO<br>_8316_DO                                                                                                                    | 46<br>49<br>50<br>51<br>51<br>51<br>52<br>52<br>53<br>53<br>54             |
| 4.5<br><b>Chapte</b><br>5.1<br>5.2<br>5.3<br>5.4<br>5.5<br>5.6<br>5.7<br>5.8<br>5.9<br>5.10                                 | Timer/Counter Operation er 5 C/C++ Library Installation Software Utility. Programming Guide8316_Initial8316_Switch_Card_No8316_DI8316_DI8316_DO8316_DO8316_DO.Channel8316_DA_Set_Mode                                                                                                                                                      |                                                                            |
| 4.5<br><b>Chapte</b><br>5.1<br>5.2<br>5.3<br>5.4<br>5.5<br>5.6<br>5.7<br>5.8<br>5.9<br>5.10<br>5.11                         | Timer/Counter Operation<br>er 5 C/C++ Library<br>Installation<br>Software Utility<br>Programming Guide<br>_8316_Initial<br>_8316_Switch_Card_No<br>_8316_DI<br>_8316_DI<br>_8316_DD<br>_8316_DO<br>_8316_DO.Channel<br>_8316_DA_Set_Mode<br>_8316_DA.                                                                                      |                                                                            |
| 4.5<br><b>Chapte</b><br>5.1<br>5.2<br>5.3<br>5.4<br>5.5<br>5.6<br>5.7<br>5.8<br>5.9<br>5.10<br>5.11<br>5.12                 | Timer/Counter Operation<br>er 5 C/C++ Library<br>Installation<br>Software Utility<br>Programming Guide<br>_8316_Initial<br>_8316_Switch_Card_No<br>_8316_DI _Channel<br>_8316_DO<br>_8316_DO Channel<br>_8316_DA_Set_Mode<br>_8316_DA<br>_8316_AD_Set_Channel                                                                              | 46<br>49<br>50<br>51<br>51<br>51<br>52<br>52<br>53<br>53<br>54<br>55<br>55 |
| 4.5<br><b>Chapte</b><br>5.1<br>5.2<br>5.3<br>5.4<br>5.5<br>5.6<br>5.7<br>5.8<br>5.9<br>5.10<br>5.11<br>5.12<br>5.13         | Timer/Counter Operation<br>er 5 C/C++ Library<br>Installation<br>Software Utility<br>Programming Guide<br>_8316_Initial<br>_8316_Switch_Card_No<br>_8316_DI<br>_8316_DI _Channel<br>_8316_DO<br>_8316_DO.Channel<br>_8316_DA_Set_Mode<br>_8316_DA<br>_8316_AD_Set_Channel<br>_8316_AD_Range                                                |                                                                            |
| 4.5<br><b>Chapte</b><br>5.1<br>5.2<br>5.3<br>5.4<br>5.5<br>5.6<br>5.7<br>5.8<br>5.9<br>5.10<br>5.11<br>5.12<br>5.13<br>5.14 | Timer/Counter Operation<br>er 5 C/C++ Library<br>Installation.<br>Software Utility<br>Programming Guide<br>_8316_Initial<br>_8316_Switch_Card_No.<br>_8316_DI<br>_8316_DI<br>_8316_DO<br>_8316_DO<br>_8316_DO<br>_8316_DO<br>_8316_DA_Set_Mode.<br>_8316_AD_Set_Channel.<br>_8316_AD_Set_Mode.<br>_8316_AD_Set_Mode.<br>_8316_AD_Set_Mode. |                                                                            |

| Produc | ct Warranty/Service            | 72 |
|--------|--------------------------------|----|
|        | 6.4.2 DA Channel 2 Calibration | 71 |
|        | 6.4.1 DA Channel 1 Calibration |    |
| 6.4    | D/A Adjustment                 |    |
| 6.3    | A/D Adjustment                 | 70 |
| 6.2    | VR Assignment                  | 70 |
| 6.1    | What do you need               |    |
| Chapte | er 6 Calibration & Utilities   | 69 |
| 5.31   | _8316_TIMER_Stop               | 68 |
| 5.30   | _8316_TIMER_Read               |    |
| 5.29   | _8316_TIMER_Start              |    |
| 5.28   | _8316_AD_Timer                 |    |
| 5.27   | _8316_AD_INT_Stop              | 65 |
| 5.26   | _8316_AD_INT_Status            | 65 |
| 5.25   | _8316_AD_INT_Start             | 63 |
| 5.24   | _8316_AD_DMA_Stop              | 63 |
| 5.23   | _8316_AD_DMA_Status            |    |
| 5.22   |                                |    |
| 5.21   | 8316_AD_Aquire                 |    |
| 5.20   | 8316_AD_Read_FIFO              |    |
| 5.19   | 8316_AD_Soft_Trig              |    |
| 5.18   | _8316_CLR_IRQ                  |    |

# How to Use This Guide

This manual is designed to help you use the ACL-8316/12. The manual describes how to modify various settings on the ACL-8316/12 card to meet your requirements. It is divided into six chapters:

- Chapter 1: "Introduction", gives an overview of the product features, applications, and specifications.
- Chapter 2: "Installation", describes how to install the ACL-8316/12. The layout of ACL-8316/12 is shown, the switch setting for base address, and jumper setting for analog input channel configuration, output channel configuration, clock source for timer/counter, interrupt level and DMA channel are specified. The connectors' pin assignment and daughter board connection are also described here.
- Chapter 3: "Registers format", describes the details of register format and structure of the ACL-8316/12, this information is very important for the programmers who want to control the hardware by low-level programming.
- Chapter 4: "Operation Theorem", describes how to operate the ACL-8316/12. The A/D, D/A, DIO and timer/counter functions are introduced. Also, some programming concepts are specified.
- Chapter 5: "C/C++ library", describes high-level programming interface in C/C++ language. It helps programmer to control ACL-8316/12 in high level language style.
- Chapter 6: "Calibration", describes how to calibrate the ACL-8316/12 for accurate measurement.

# 1

# Introduction

The ACL-8316/12 series DAS cards are high resolution and high performance data acquisition card based on the 16-bit PC/ISA Bus architecture. Both ACL-8316 and ACL-8312 share a common architecture and core features making each card is ideal for data logging and signal analysis applications.

The ACL-8316/12 series features continuous, high speed, gap-free data acquisition under Windows or DOS environments. An on-board FIFO buffer and 16-bit DMA data transfer allows the acquisition of large amounts of data without losing data. The channel auto-scanning lets a high speed acquisition in a sequential order to select channel.

An lite(L) version of ACL-8316/12 are offered for the customer who does not need any D/A analog output channels. It lets customers do not waste any extra money to buy unnecessary source. The system block diagram is shown on next page for further reference.



#### 1.1 Features

The ACL-8316/12 high performance and high resolution Data Acquisition Card provides the following advanced features:

- 16-bit PC/ISA Bus
- 16-bit or 12-bit analog input resolution
- On-board A/D FIFO memory for 1K
- Auto-scanning channel selection
- Up to 100 kHz A/D sampling rates
- 16 single-ended or 8 differential analog input channels
- Bipolar or Unipolar input signals
- Programmable gain of x1, x2, x4, x8
- On-chip sample & hold
- Two 12-bit monolithic multiplying analog output channels (optional)
- 16 digital input / output channels
- 3 independent programmable 16-bit down counter
- Three A/D trigger modes: software trigger, programmable pacer trigger, and external pulse trigger.
- Integral DC-to-DC converter for stable analog power source
- 37-pin D-type connector
- Compact size: half-size PCB

# 1.2 Applications

- Industrial and laboratory ON/OFF control
- Energy management
- Annunciation
- 16 TTL/DTL compatible digital input channels
- Security controller
- Product test
- Period and pulse width measurement

## 1.3 Specifications

#### Analog Input (A/D)

• Converter:

ADS7805 or equivalent for ACL-8316 ADS7804 or equivalent for ACL-8312

- Resolution: 16-bit (ACL-8316), 12-bit (ACL-8312)
- ADconverter type: successive approximation type
- Number of channels: 16 single-ended or 8 differential
- Conversion Time: 8 µ sec
- Maximum sampling rate: 100KHz multiplexing
- Input Range: (programmable)
   Bipolar: ± 10V, ± 5V, ±2.5V, ±1.25V
- Data format: Two's complement data output
- On-board Memory: 1K words FIFO, half and full ready interrupt
- Over-voltage protection: Continuous ± 35V maximum
- Accuracy:

| GAIN = 1    | 0.01% of FSR ±1 LSB |
|-------------|---------------------|
| GAIN = 2, 4 | 0.02% of FSR ±1 LSB |
| GAIN = 8    | 0.04% of FSR ±1 LSB |

- Input impedance: 10 MΩ
- AD trigger modes: Software, Pacer, and External trigger
- Data Transfer: Software polling, EOC Interrupt, FIFO polling, FIFO half-full interrupt, DMA transfer

#### Analog Output (D/A)

- Converter: DAC2813 or equivalent, monolithic multiplying
- Resolution: 12-bit
- Number of channels: 2
- Output Range: (jumper selectable)
  - Bipolar: -10V ~ +10V
  - Unipolar: 0V ~ +10V
- Control Mode: Double buffered mode or Transparency Mode
- Data Format: Binary format or Binary format
- Settling Time: 4.5µ sec(typical), 6µ sec (max.)
- Linearity: ±1/2 bit LSB(Max.) ±1/4 bit LSB(typical)
- Output driving: ±5mA (min.)
- Output Impedance: 0.2 Ω

#### Digital I/O (DIO)

- Channel: 16 TTL compatible inputs and outputs
- Input Voltage:
  - Low: Min. 0V ; Max. 0.8V High: Min. +2.0V
- Input Load:

Low: +0.5V @ -0.2mA max. High: +2.7V @ +20mA max. Output Voltage: Low: Min. 0V ; Max. 0.4V High: Min. +2.4V

 Driving Capacity: Low: Max. +0.5V at 8.0mA (Sink) High: Min. 2.7V at 0.4mA (Source)

#### Programmable Counter

- Device: 82C54
- A/D pacer: 32-bit timer( two 16-bit counter cascaded together) with a 2MHz time base
- Counter: One 16-bit counter with a 2MHz time base or external timer clock
- Pacer Output: 0.00046 Hz ~ 100K Hz

#### • General Specifications

- I/O Base Address: 16 consecutive address location
- Connector: 37-pin D-type connector, and two 20-pin ribbon connectors
- IRQ Level: 3, 5, 6, 7, 9, 11, 12, 15
- DMA Level: 5, 6, and 7
- Operating Temperature: 0° C ~ 55° C
- Storage Temperature: -20° C ~ 80° C
- Humidity: 5 ~ 95%, non-condensing
- Power Consumption: +5 V @ 400 mA typical +12V @ 260 mA typical
- PCB Dimension: Half-sized 163mm(L) X 123mm(H)

# 1.4 Software Support

#### 1.4.1 Programming Library

For the customers who are writing their own programs, we provide MS-DOS Borland C/C++ programming library.

ACLS-DLL2 is the Development Kit for NuDAQ ISA-Bus Cards with Analog I/O, windows 3.1/95(98)/NT. ACLS-DLL2 can be used for many programming environments, such as VC++, VB, Delphi. ACLS-DLL2 is included in the ADLINK CD. It need license.

#### 1.4.2 LabView Driver

The ACLS-LVIEW includes the ACL-8316/8312's Vis, which is used to interface with NI's LabView software package. The ACLS-LVIEW supports Windows-95(98)/NT. ACLS-LVIEW is included in the ADLINK CD. It need license.

# 2

# Installation

This chapter describes how to install the ACL-8316/12. At first, the contents in the package and unpacking information that you should care about are described. The jumpers and switches setting for the ACL-8316/12's base address, analog input channel configuration, interrupt IRQ level, analog output configuration are also specified.

### 2.1 What You Have

In addition to this User's Manual, the package includes the following items:

- ACL-8316/12 Enhanced Multi-function Data Acquisition Card
- ADLINK CD

If any of these items is missing or damaged, contact the dealer from whom you purchased the product. Save the shipping materials and carton in case you want to ship or store the product in the future.

# 2.2 Unpacking

Your ACL-8316/12 card contains sensitive electronic components that can be easily damaged by static electricity.

The card should be done on a grounded anti-static mat. The operator should be wearing an anti-static wristband, grounded at the same point as the anti-static mat.

Inspect the card module carton for obvious damage. Shipping and handling may cause damage to your module. Be sure there are no shipping and handing damages on the module before processing.

After opening the card module carton, extract the system module and place it only on a grounded anti-static surface component side up.

Again inspect the module for damage. Press down on all the socketed IC's to make sure that they are properly seated. Do this only with the module place on a firm flat surface.

#### Note: DO NOT APPLY POWER TO THE CARD IF IT HAS BEEN DAMAGED.



You are now ready to install your ACL-8316/12.

# 2.3 ACL-8316/12's Layout

Figure 2.1 PCB Layout of the ACL-8316/12

# 2.4 Jumper and DIP Switch Description

You can change the ACL-8316/12's channels and the base address by setting jumpers and DIP switches on the card. The card's jumpers and switches are preset at the factory. You can change the jumper settings for your own applications.

A jumper switch is closed (sometimes referred to as "shorted") with the plastic cap inserted over two pins of the jumper. A jumper is open with the plastic cap inserted over one or no pin(s) of the jumper.

## 2.5 Base Address Setting

The ACL-8316/12 requires 16 consecutive address locations in the I/O address space. The base address of the ACL-8316/12 is restricted by the following conditions.

- 1. The base address must within the range Hex 200 to Hex 3FF.
- The base address should not conflict with any PC reserved I/O address.
- 3. The base address must not conflict with any add-on card on your own PC. Please check your PC before installing the ACL-8316/12.

The base address of registers in ACL-8316/12 is selected by an 5 positions DIP switch **SW1**. The default setting of base address is set to be *HEX 220*. All possible base address combinations are listed as Table 2.1. You may modify the base address if the address *HEX 220* has been occupied by another add-on card.





Figure 2.2 Default Base Address Setting

| I/O port     |     | 1   | 2   | 3   | 4   | 5   |
|--------------|-----|-----|-----|-----|-----|-----|
| Address(Hex) | A9  | A8  | A7  | A6  | A5  | A4  |
| 200-20F      |     | ON  | ON  | ON  | ON  | ON  |
|              | (1) | (0) | (0) | (0) | (0) | (0) |
| 210-21F      |     | ON  | ON  | ON  | ON  | OFF |
|              | (1) | (0) | (0) | (0) | (0) | (1) |
| 220-22F      |     | ON  | ON  | ON  | OFF | ON  |
| (default)    | (1) | (0) | (0) | (0) | (1) | (0) |
| 230-23F      |     | ON  | ON  | ON  | OFF | OFF |
|              | (1) | (0) | (0) | (0) | (1) | (1) |
| :            |     |     |     |     |     |     |
| 300-30F      |     | OFF | ON  | ON  | ON  | ON  |
|              | (1) | (1) | (0) | (0) | (0) | (0) |
| :            |     |     |     |     |     |     |
| 3F0-3FF      |     | OFF | OFF | OFF | OFF | OFF |
|              | (1) | (1) | (1) | (1) | (1) | (1) |

Table 2.1 Possible Base Address Combinations

A0, ..., A9 is corresponding to PC Bus address lines

A9 is fixed as "1".

#### How to define the base address for the ACL-8112 ?

The DIP1 to DIP5 in the switch SW1 are one to one corresponding to the PC AT-bus address line A8 to A4. A9 is always 1 and A0~A3 are always 0. If you want to change the base address, you can only change the values of A8 to A4 (the shadow area of below table). The following table is an example, which shows you how to define the base address as *Hex 220* 

Base Address: Hex 220

| 2  | 2  | 2  |    |    | 0  |    |    |    |    |
|----|----|----|----|----|----|----|----|----|----|
| 1  | 0  | 0  | 0  | 1  | 0  | 0  | 0  | 0  | 0  |
| A9 | A8 | A7 | A6 | A5 | A4 | A3 | A2 | A1 | A0 |

# 2.6 Analog Input Channel Configuration

The ACL-8316/12 offer 16 single-ended or 8 differential analog input channels. The jumper JP7 controls the analog input channel configuration. The settings of JP7 is specified as following illustration.



Figure 2.3 Analog Input Channels Configuration

# 2.7 Analog Output Channel Setting

#### 2.7.1 Channel Output Range Setting

The ACL-8316/12's analog outputs are generated by a very powerful D/A converter B.B. DAC2813. It can be configured either bipolar ( $+10V \sim -10V$ ) or unipolar (0V  $\sim 10V$ ) output. The jumper JP5 and JP6 are used to set D/A CH1 and D/A CH2 individually.

| D/A CH1 Output<br>-10V~+10V<br>Bipolar<br>(Default) | JP5<br>BI1 0 0 UP1 |
|-----------------------------------------------------|--------------------|
| D/A CH1 Output<br>0V~10V<br>Unipolar                | JP5<br>BI1 • UP1   |

Figure 2.4 D/A CH1 Output Range setting



Figure 2.5 D/A CH2 Output Range setting

#### 2.7.2 Output Mode Setting

The ACL-8316/12 consists of two independently addressable latched in two ranks for each D/A converter. The first rank consists of one 12-bit input latch which can be loaded from the PC bus. The input latch holds data temporarily before it is load into the second latch, the D/A latch. This **double buffered** organization permits simultaneously update of all D/As.

On the other hands, if you do not need to latch D/A output by double buffered mode. The *transparency mode* can driver the D/A output immediately without waiting for the second latch. The configuration for either double buffered mode or transparent mode is set by jumper JP8 and is shown on Figure 2.6 below.

| Transprant<br>(default | JP1   |
|------------------------|-------|
| Double                 | JP1 D |
| mod                    | JP1 T |

Figure 2.6 D/A Output Mode Setting

# 2.8 DMA Channel Setting

The A/D data transfer of ACL-8316/12 is designed with DMA transfer capability. The setting of DMA channel 5, 6 or 7 is controlled by the jumpers JP1 and JP2. The possible settings are illustrated in the Figure 2.7 below.

| DMA 5<br>(Default) | DACK<br>JP1<br>•••••<br>7 6 5 | DRQ<br>JP2<br>7 6 5 |
|--------------------|-------------------------------|---------------------|
| DMA 6              | DACK<br>JP1<br>0 0 0<br>7 6 5 | DRQ<br>JP2<br>7 6 5 |
| DMA 7              | DACK<br>JP1<br>7 6 5          | DRQ<br>JP2          |

Figure 2.7 DMA Channel Setting

# 2.9 IRQ Level Setting

The ACL-8316/12 can connect to any one of the interrupt lines of the PC I/O channel. The interrupt line is selected by the jumper JP3. If you wish to use the interrupt capability of ACL-8316/12, you must select an interrupt level and place the jumper in the appropriate position to enable the particular interrupt line.

The default interrupt level is IRQ15, which is selected by placing the jumper on the pins in row number 10. Figure 2.8 shows the default interrupt jumper setting IRQ5. You only remove the jumper from IRQ15 to other new pins, if you want to change to another IRQ level.

Note: Be aware that there is no other add-on card shares the same interrupt level at the same system.



Figure 2.8 IRQ Level Setting

# 2.10 Clock Source Setting

The 8254 programmable interval timer is used in the ACL-8316/12. It provides 3 independent channels of 16-bit programmable down counters. The input of counter 2 is connected to a precision 2MHz oscillator for internal pacer. The input of counter 1 is cascaded from the output of counter 2. The channel 0 is free for user's applications. There are two selections for the clock source of channel 0: the internal 2MHz clock or the external clock signal from connector CN3 pin 37. The setting of clock is shown as Figure 2.9.

| Internal Clock    | JP4    |
|-------------------|--------|
| Source : 2MHz     | INTCLK |
| (default setting) | EXTCLK |
| External Clock    | JP4    |
| Source            | INTCLK |
| ( Pin-37 of CN3)  | EXTCLK |

Figure 2.9 Timer's Clock Source Setting

# 2.11 Connectors Pin Assignment

The ACL-8316/12 comes equipped with two 20-pin insulation displacement connectors - CN1 and CN2 and one 37-pin D-type connector - CN3. The CN1 and CN2 are located on board and CN3 located at the rear plate.

CN1 is used for digital signal output, CN2 for digital signal input, CN3 for analog input, analog output and timer/counter's signals. The pin assignment of each connector is illustrated in Figure 2.10~2.12.

• CN1: Digital Signal Output (DO 0 ~ 15)





• CN2: Digital Signal input (DI 0 ~ 15)





#### Legend:

DI n: Digital output signal channel nDO n: Digital input signal channel nGND: Digital ground • CN 3: Analog Input/Output & Counter/Timer



(for single-ended connection)



 CN 3: Analog Input/Output & Counter/Timer (for differential connection)





#### Legend:

- Ain : Analog Input Channel n ( single-ended)
- AlHn : Analog High Input Channel n (differential)
- AlLn : Analog Low Input Channel n (differential)
- ExtRef n : External Reference Voltage for D/A CH n
- Aon : Analog Output Channel n
- ExtCLK : External Clock Input
- ExtTrig : External Trigger Signal
- CLK : Clock input for 8254
- GATE : Gate input for 8254
- COUT n : Signal output of Counter n
- V.ERF : Voltage Reference
- A.GND : Analog Ground
- GND : Ground

# 2.12 Daughter Board Connection

The ACL-8316/12 can be connected with five different daughter boards, ACLD-8125, ACLD-9137, 9182, 9185, and 9188. The functionality and connections are specified as follows.

#### 2.12.1 Connect with ACLD-8125

The ACLD-8125 has a 37-pin D-sub connector, which can connect with ACL-8316/12HG through 37-pin assemble cable. The most outstanding feature of this daughter board is a CJC (cold junction compensation) circuit on board.

#### 2.12.2 Connect with ACLD-9137

The ACLD-9137 is a direct connector for the card which is equipped with 37-pin D-sub connector. This board provides a simple way for connection. It is very suitable for the simple applications that do not need complex signal condition before the A/D conversion is performed.

#### 2.12.3 Connect with ACLD-9182

The ACLD-9182 is a 16 channel isolated digital input board. This board is connected with CN1 of ACL-8316/12 via 20-pin flat cable. The advantage of board is an 500Vdc isolation voltage is provided, and it can protect your PC system from damage when an abnormal input signal is occurred.

#### 2.12.4 Connect with ACLD-9185

The ACLD-9185 is a 16 channel SPDT relay output board. This board is connected with CN2 of ACL-8316/12 via 20-pin flat cable. by using this board, you can control outside device through the digital output signals.

#### 2.12.5 Connect with ACLD-9188/9138

ACLD-9188 and ACLD-9138 are two general purpose terminal boards for all the card which comes equipped with 37-pin D-sub connector. ACLD-9188 is big size and uses Barrier-strip terminal block. The ACLD-9138 is compact size and uses screw-clamp terminal block.

# 3

# **Registers Format**

The detailed description of the ACL-8316/12's register format is specified in this chapter. This information is quite useful for the programmer who wish to handle the ACL-8316/12 card by low-level program.

# 3.1 I/O Port Address

The ACL-8316 requires 16 consecutive addresses in the PC I/O address space. Table 3.1 shows the I/O address of each register with respect to the base address. The function of each register will be introduced in the following sections.

| Location  | Read                      | Write                    |
|-----------|---------------------------|--------------------------|
| Base + 0  | Counter 0                 | Counter 0                |
| Base + 1  | Counter 1                 | Counter 1                |
| Base + 2  | Counter 2                 | Counter 2                |
| Base + 3  | Counter Status            | Counter Control          |
| Base + 4  | A/D Data                  | D/A Channel #1           |
| Base + 5  |                           |                          |
| Base + 6  | A/D Data (FIFO)           | D/A Channel #2           |
| Base + 7  |                           |                          |
| Base + 8  | A/D Channel and Status    | FIFO Enable              |
| Base + 9  | Clear Interrupt Request   | Gain Control             |
| Base + 10 | Software A/D trigger      | Channel MUX              |
| Base + 11 | Interrupt Source Setting  | Interrupt Source Control |
| Base + 12 | A/D Mode Setting          | A/D Mode Control         |
| Base + 13 | D/A Mode and FIFO setting | D/A Mode Control         |
| Base + 14 | DI (016)                  | DO (016)                 |
| Base + 15 |                           |                          |

Note: The ACL-8316/12 includes both 8 bits & 16 bits I/O ports. The AD Data, DA channels, and digital I/O ports are 16 bits port. All the others are 8 bits I/O port.

The 16-bit I/O data ( A/D, D/A and DIO) have to access via 16-bit I/O operation.

## 3.2 A/D Data Registers

The value of AD data register is directly read from AD converter which address is base address + 4. The A/D data is updated whenever AD is triggered. The AD FIFO data is read from FIFO chips which address is base address + 6, however, the AD data read from FIFO may be not in 'real time'. The FIFO data should be read with FIFO control. The AD FIFO port is enable only after the FF\_ENA bit in A/D mode control register is set.( refer to section 4.3)

#### Address : BASE + 4 and BASE + 6 Attribute : read only Data Format:

| 1.7.10 |      | (a.eg . = |     | - / |     |     |     |     |
|--------|------|-----------|-----|-----|-----|-----|-----|-----|
| Bit    | 15   | 14        | 13  | 12  | 11  | 10  | 9   | 8   |
|        | AD11 | AD10      | AD9 | AD8 | AD7 | AD6 | AD5 | AD4 |
| Bit    | 7    | 6         | 5   | 4   | 3   | 2   | 1   | 0   |
|        | AD3  | AD2       | AD1 | AD0 | 0   | 0   | 0   | 0   |

(1) ACL-8312 (using 12 bits ADC)

AD11 .. AD0: Analog to digital data. AD11 is Most Significant Bit of the 12 bits digits and AD0 is Least Significant Bit.

(2) ACL-8316 (using 16 bits ADC)

| 7-7- | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | 00100 | aonig io |      | 0)   |      |      |     |     |
|------|-----------------------------------------|-------|----------|------|------|------|------|-----|-----|
| E    | Bit                                     | 15    | 14       | 13   | 12   | 11   | 10   | 9   | 8   |
|      |                                         | AD15  | AD14     | AD13 | AD12 | AD11 | AD10 | AD9 | AD8 |
| E    | Bit                                     | 7     | 6        | 5    | 4    | 3    | 2    | 1   | 0   |
|      |                                         | AD7   | AD6      | AD5  | AD4  | AD3  | AD2  | AD1 | AD0 |

AD15 .. AD0: Analog to digital data. AD15 is Most Significant Bit of the 16 bits digits, and AD0 is Least Significant Bit.

**Note:** The 12 bits of A/D data of ACL-8312 are located on the 12 MSBs and the 4 LSB is zero alwayse. Users can consider the ACL-8312, which is of only 12 bit resolution, is the special case of the ACL-8316.

# 3.3 FIFO Enable Register

The FF\_ENA bit directly control FIFO memory. Clear FF\_ENA bit to '0' can always reset the FIFO and any read operation to the A/D FIFO port will get value '0'. Set FF\_ENA bit to '1' can enable the FIFO. Note that FF\_ENA status can be read back from Base+13.

#### Address : BASE + 8 Attribute : write only Data Format:

| Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0      |
|-----|---|---|---|---|---|---|---|--------|
|     | Х | Х | Х | Х | Х | Х | Х | FF_ENA |

FF\_ENA: FIFO Enable Control

0: FIFO Disable

1: FIFO Enable

# 3.4 Gain Control Register

The gain control register is used to adjust the analog input ranges for A/D channels. Table 4.2 shows the relationship between the register data, gain value and the A/D input range.

Address : BASE + 9 Attribute : write only Data Format:

| Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1  | 0  |
|-----|---|---|---|---|---|---|----|----|
|     | Х | Х | Х | Х | Х | Х | G1 | G0 |

| G1 | G0 | Gain | A/D input Range  |
|----|----|------|------------------|
| 0  | 0  | 1    | - 10V ~ +10V     |
| 0  | 1  | 2    | - 5V ~ +5V       |
| 1  | 0  | 4    | - 2.5V ~ +2.5V   |
| 1  | 1  | 8    | - 1.25V ~ +1.25V |

# 3.5 A/D Channel Multiplexer Register

The A/D channel multiplexer register is used to select the A/D channel under normal mode, or the stop channel number under the auto-scan mode. Refer to section 3.7 to find the definition of the auto-scan control bit 'ASCAN'. When auto scanning is disabled, the register values select the AD channel number.

When auto scanning is enabled, the register values set the stop channel number while the starting channel is from channel 0. After every A/D conversion, the A/D channel to be selected will be increased by one automatically until the channel number reach this register value, then channel 0 is selected again.

#### Address: BASE + 10 Attribute: write only Data Format:

| Bit | 7 | 6 | 5 | 4 | 3   | 2   | 1   | 0   |
|-----|---|---|---|---|-----|-----|-----|-----|
|     | Х | Х | Х | Х | CS3 | CS2 | CS1 | CS0 |

CS3 ... CS0: Stop multiplexer channel number.

Note that as the hardware jumpers set the ACL-8316/12 to differential input mode, only 8 channels are available. The CS3 value is useless. The initial value of the channel number is 0.

# 3.6 Interrupt Source Control Register

The interrupt source of ACL-8316 is controlled by both of this register and the A/D mode control register. The DMAEAN bit in A/D mode control register will decide the interrupt source, too. This register values can be read back on the same port.

#### Address : BASE + 11 Attribute : read and write Data Format:

| Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1   | 0   |
|-----|---|---|---|---|---|---|-----|-----|
|     | Х | Х | Х | Х | Х | Х | IS1 | IS0 |

When DMAENA is set (DMA enable), interrupt must come from TC (terminal count) signal to indicate DMA transfer ending. However, when the DMAENA is cleared (DMA disable), the interrupt source is set as following table.

| IS1 | IS0 | Interrupt Sources             |
|-----|-----|-------------------------------|
| 0   | 0   | A/D EOC                       |
| 0   | 1   | External interrupt source (1) |
| 1   | 0   | Internal Pacer Interrupt      |
| 1   | 1   | FIFO half full (2)            |

- **Note(1)** The external AD trigger signal can be used as external interrupt source under this mode.
- **Note(2)** The FIFO half full interrupt and DMA can not be run concurrently. But the FIFO can still be read even the DMA is enable.

# 3.7 AD Mode Control Register

The A/D mode control register is used to select A/D data transfer mode A/D trigger source, and A/D channel selection.

#### Address : BASE + 12 Attribute : read and write Data Format:

| Bit | 7 | 6 | 5 | 4 | 3      | 2      | 1      | 0     |
|-----|---|---|---|---|--------|--------|--------|-------|
|     | Х | Х | Х | Х | DMAENA | EXTINT | ITSSEL | ACSCN |

- ♦ A/D Data Transfer control
  - DMAENA:
  - 0: Software data polling (DMA is disabled)
  - 1: DMA data transfer
- ♦ A/D Trigger Source
  - EXTINT: External or Internal trigger source
    - 0: Internal A/D trigger Source (trigger source is from ITSSEL)
    - 1: External A/D trigger Source (trigger source is from Ext\_Trg of CN3)
  - ITSSEL: Internal Trigger source type
    - 0: Internal software A/D trigger
    - 1: Internal pacer A/D trigger
- A/D Channel Control
  - ASCAN
  - 0: Auto Channel Scan Disable
  - 1: Auto Channel Scan Enable

## 3.8 A/D Status Register

#### Address : BASE + 8 Attribute : read only Data Format:

| Bit | 7       | 6     | 5     | 4     | 3   | 2   | 1   | 0   |
|-----|---------|-------|-------|-------|-----|-----|-----|-----|
|     | AD_BUSY | FF-FF | FF_HF | FF_EF | CNH | CN2 | CN1 | CN0 |

CNH and CN2~CN0

These bits are used to feedback the *channel number* to be selected. When the ACL-8316/12 is set to be differential mode. CNH will be 1 always. When the A/D mode is in auto scan mode, the channel number will be increased by one automatically.

• FF\_EF

0: FIFO is empty

1: FIFO is not empty

• FF\_HF

0: FIFO is half full

- 1: FIFO is not half full
- FF\_FF
  - 0: FIFO is full
  - 1: FIFO is not full

Above 3 bits are FIFO relative flags which are used to indicate the FIFO status. These status can be used to read A/D FIFO data by software polling without the help of hardware.

#### • AD\_BUSY

- 0: A/D converter is busy, i.e. A/D conversion is not completed
- 1: A/D converter is not busy, i.e. A/D conversion is completed

# 3.9 Clear Interrupt Register

To **read** this port can generate clear interrupt signal. No matter which interrupt source is used, the clear interrupt register must be read to allow next interrupt.

Address : BASE + 9 Attribute : read only Data Format:

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

## 3.10 Software A/D Trigger Register

To *read* this port can generate A/D trigger signal if the AD mode control register is set to use internal software A/D trigger source.

Address: BASE + 10 Attribute: read only Data Format:

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

## 3.11 DA Data Registers

There are two DA channels in ACL-8316. The address Base + 4 is DA channel 1 and the address Base +6 is DA channel 2. DA11 is Most Significant Bit, and DA0 is Least Significant Bit. The lowest 4 bits of this register is don't cared. Users can consider the DA data values as 16-bits with the lowest 4 bits are truncated. Therefore, result in 12-bits resolution although the DA data value is in the range from 0 to 65535.

#### Address : BASE + 4 and BASE+6 Attribute : write only Data Format:

| Bit | 15   | 14   | 13  | 12  | 11  | 10  | 9   | 8   |
|-----|------|------|-----|-----|-----|-----|-----|-----|
|     | DA11 | DA10 | DA9 | DA8 | DA7 | DA6 | DA5 | DA4 |
| Bit | 7    | 6    | 5   | 4   | 3   | 2   | 1   | 0   |
|     | DA3  | DA2  | DA1 | DA0 | Х   | Х   | Х   | Х   |

DA11 ... DA0: Digital to analog data value.

## 3.12 DA Mode Control Register

Address: BASE + 13 Attribute: write Data Format:

| Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1      | 0      |
|-----|---|---|---|---|---|---|--------|--------|
|     | Х | Х | Х | Х | Х | Х | DA_FMT | DA_MD1 |

Address : BASE + 13 Attribute : read Data Format:

| Bit | 7 | 6 | 5 | 4 | 3      | 2    | 1      | 0      |
|-----|---|---|---|---|--------|------|--------|--------|
|     | Х | Х | Х | Х | FF_ENA | STYP | DA_FMT | DA_MD1 |

The D/A operation and D/A data format are controlled by this register and the jumper JP8. The lower two bits are programmable and can be read back too. Another two bits, the FIFO enable (FF\_ENA) bit and the A/D signal type (STYP) bit, are read only.

These two DA channels are set as transparency mode or double buffer mode by DA\_MD1 bit and jumper JP8 setting. The versatile operation functions are shown as following table. The default setting of the JP8 is TP and initial state of DA\_MD1 is 0 too. Therefore, the DA channels are default set as transparency mode. However, if user want to default set double buffered mode when system power on, he can set JP8 to 'DB' externally. Even if the power on state is double buffer mode, the users still can set DA\_MD1 to 1 to change the DA channels to transparency mode.

| JP8 Status<br>(hardware) | DA_MD1<br>(software) | DAs Control Mode   |
|--------------------------|----------------------|--------------------|
| 0                        | 0                    | Transparency mode  |
| 0                        | 1                    | Double buffer mode |
| 1                        | 0                    | Double buffer mode |
| 1                        | 1                    | Transparency mode  |

DA\_FMT:

0: DA data value is in two's complement mode which the same as AD.

1: DA data value is in binary mode.

FF\_ENA:

0: means FIFO is reset

1: means FIFO is enable.

STYP:

0: A/D signal sources are differential input.

1: A/D signal sources are signal ended.

## 3.13 Digital I/O register

There are 16 digital input channels and 16 digital output channels are provided by the ACL-8312/16. The address Base + 14 and Base + 15 are used for both digital input and digital output control.

## Address : BASE + 14 & BASE + 15

## Attribute: read only

Data Format:

| Bit | 15   | 14   | 13   | 12   | 11   | 10   | 9   | 8   |
|-----|------|------|------|------|------|------|-----|-----|
|     | DI15 | DI14 | DI13 | DI12 | DI11 | DI10 | DI9 | DI8 |
| Bit | 7    | 6    | 5    | 4    | 3    | 2    | 1   | 0   |
|     | DI7  | DI6  | DI5  | DI4  | DI3  | DI2  | DI1 | DIO |

## Address : BASE + 14 & BASE + 15

Attribute: write only

Data Format:

| Bit | 15   | 14   | 13   | 12   | 11   | 10   | 9   | 8   |
|-----|------|------|------|------|------|------|-----|-----|
|     | DO15 | DO14 | DO13 | DO12 | DO11 | DO10 | DO9 | DO8 |
| Bit | 7    | 6    | 5    | 4    | 3    | 2    | 1   | 0   |
|     | DO7  | DO6  | DO5  | DO4  | DO3  | DO2  | DO1 | DO0 |

## 3.14 Internal Timer/Counter Register

Two counters of 8254 are used for periodically triggering the A/D conversion, the remainder is free for user's applications. The 8254 occupies 4 I/O address locations in the ACL-8316/12 as shown blow. Users can refer to Tundra's or Intel's data sheet ("http://www.tundra.com" or

"http://support.intel.com/support/controllers/peripheral/231164.htm") for a fully description of the &54 features. Condensed information is specified in section 4.5 Timer/Counter Operation.

## Address : BASE + 0 ~ BASE + 3 Attribute: read / write Data Format:

| Base + 0 | Counter 0 Register (R/W) |
|----------|--------------------------|
| Base + 1 | Counter 1 Register (R/W) |
| Base + 2 | Counter 2 Register (R/W) |
| Base + 3 | 8254 CONTROL BYTE( W)    |

# 4

## **Operation Theorem**

The operation theorem of the functions on ACL-8316/12 card is described in this chapter. The functions include the A/D conversion, D/A conversion, digital I/O and counter/timer. The operation theorem can help you to understand how to manipulate and to program the ACL-8316/12.

## 4.1 A/D Conversion

Before programming the ACL-8316/12 to perform the A/D conversion, you should understand the following issues:

- A/D conversion procedure
- A/D signal source control
- A/D trigger source control
- A/D data buffering
- A/D data transfer mode
- Interrupt System (refer to section 4.2)
- A/D data format

## 4.1.1 A/D Conversion Procedure

For using the A/D converter, users must know about the property of the signal to be measured at first. The users can decide which channels to be used and connect the signals to the ACL-8316. Refer to the 'Signal Connection' (Section 2.11). In addition, users should define and control the A/D signal sources, including the A/D channel, A/D gain, and A/D signal types. Please refer to section 4.1.2. for A/D signal source control.

After deciding the A/D signal source, the user must decides how to trigger the A/D conversion and define / control the trigger source. The A/D converter will start to convert the signal to a digital value when a trigger signal is rising. The ACL-8316 provides three trigger modes, refer to section 4.1.3 for details.

At the ending of A/D conversion, the A/D data is stored in A/D data register and in the FIFO if FIFO is enable. This issue stands as A/D data buffering. Please refer to section 4.1.4.

The A/D data should be transferred into PC's memory for further using or processing. The data can be either read by I/O instruction which is handled directly by software or transferred to memory by the DMA controller. Please refer to section 4.1.5 to obtain ideas about the multi-configurations for A/D data transferring.

To process A/D data, programmer should know about the A/D data format. Refer to section 4.1.6 for details.

## 4.1.2 A/D Signal Source Control

To control the A/D signal source, three concepts should be understood. That is signal type, signal channel and signal range.

## Signal Type

The A/D signal sources of ACL-8316 could be single ended (SE) or differential input (DI) type. The signal type is selected by external jumper (JP7). The setting can be read back through the D/A format register.

ACL-8316/12 provides 16 single-ended or 8 differential analog input channels. The analog signal can be converted to digital value by the A/D converter. To avoid ground loops and get more accuracy measurement of A/D conversion, it is quite important to understand the signal source type and how to choose the analog input modes: signal-ended and differential. The ACL-8316/12 offers jumpers to select 16 single-ended or 8 different analog inputs.

## Single-ended Mode:

The single-ended mode has only one input relative to ground and it suitable for connecting with the *floating signal source*. The floating source means it does not have any connection to ground. The following figure shows the single-ended connection. Note that when more than two floating sources are connected, the sources must be with common ground.



Figure 4.1.1 Floating source and single-ended

## Differential input mode

The differential input mode provides two inputs that respond to the difference signal between them. If the signal source has one side connected to local ground, the differential mode can be used for reducing ground loop. Figure 4.1.2 shows the connection of the differential input mode. However, even if the signal source is local grounded, the single-ended still can be used when the Vcm (Common Mode Voltage) is very small and the effect of ground loop can be negated.



Figure 4.1.2 Ground source and differential input

A differential mode must be used when the signal source is differential. A differential source means the ends of the signal are not grounded. To avoid the danger of high voltage between the local ground of signal and the ground of the PC system, a shorted ground path must be connected. Figure 4.1.3 shows the connection of differential source.



Figure 4.1.3 Differential source and differential input

If your signal source is both floating and local ground, you should use the differential mode, and the floating signal source should be connected as the Figure 4.1.4.



Figure 4.1.4 Floating source and differential input

## Signal Channel

There are 16 channels in SE mode and 8 channels in DI mode. There are two ways to control the channel number. The first is the software programming and the second is the auto channel scanning, which is controlled by the ASCAN bit in AD mode control register. As ASCAN is cleared (0), the value of AD channel MUX register defines the channel to be selected. Only one channel can be selected in one moment.

As ASCAN is set (1), the value in AD channel MUX register define the ending channel number of auto-scanning operation. Under auto scan mode, the channel is scanning from channel 0 to the ending channel. Whenever a trigger signal is rising, the channel number to be selected will increase automatically. For example, if the ending channel number is 3, the auto channel scanning sequence is 0,1,2,3,0,1,2..., until the ASCAN bit to be cleared.

The current A/D channel number could be read back from the A/D status register. Refer to section 4.8 for the register format of the A/D status register.

## Signal Range

The proper signal range is important for data acquisition. The input signal may be saturated if the A/D gain is too large. The resolution of data may be not enough if the signal is small and gain is not enough. The maximum A/D signal range of ACL-8316 is +/- 10 volts when the A/D gain value is 1. The A/D gain control register controls the maximum signal input range. The signal gain is programmable with 4 levels (1,2,4,8). The signal range of the 16 channels will be identity all the time even if the channel number is scanning.

The available signal polarity on ACL-8316 is only bipolar but no unipolar configuration. However, the bipolar input range still covers the unipolar applications. Therefore, ACL-8316 is suitable for full range of applications.

## 4.1.3 A/D Trigger Sources Control

The A/D conversion is started by trigger signal. There are total three trigger sources in the ACL-8316. One is *External* trigger source and two are *Internal* trigger sources.

The trigger source is programmable by the AD mode control register. Please refer to section 3.7 for details of the register. The different trigger conditions are specified as following:

## Software trigger (EXTINT=0, ITSSEL=0)

The trigger source is generated and fully controlled by software under this mode. That is, the A/D conversion is started by reading the software trigger register (BASE+12). Software trigger mode is suitable for low speed applications. However, it is difficult to control the fixed A/D conversion rate except generating trigger in a timer interrupt service routine with a fixed trigger rate.

## Timer Pacer Trigger (EXTINT=0, ITSSEL=1)

An on-board timer / counter chip 8254 is used to provide an internal trigger source for A/D conversion at a fixed rate. Two counters of the 8254 chip are cascaded together to generate trigger pulse with precise period. Please refer to section 3.4 for 8254 architecture. This mode is ideal for high speed A/D conversion. It's recommend to use this mode if your applications need a fixed and precise A/D sampling rate.

## External Trigger (EXTINT=1)

Through the pin-17 of CN3 (*ExtTrig*), the A/D conversion is triggered when a rising edge of external signal is occurred. The conversion rate under this mode is more flexible than the previous two modes, because the users can handle the external signal by outside devices. The external trigger can combine with the DMA transfer, interrupt data transfer, or even program polling data transfer. Generally, the interrupt data transfer is more often used when external trigger mode is used.

## 4.1.4 A/D Data Buffering

On the ACL-8316, the AD data will store in the A/D data register. While A/D conversion, the register keeps the previous conversion result. The data will be updated when the end of the conversion. The A/D data register can keep the newest conversion data until the ending of the next conversion. The A/D data register can store only one data and the data can be real time operated.

The A/D data can also be buffered in the FIFO memory when the FIFO is enable. But it is not suitable to use FIFO if the application needs real-time A/D data operation. The FIFO size on ACL-8316 is 1K samples. If the sampling rate is 100 kHz, the FIFO can buffer 10 ms analog signal. After the FIFO is full, the lasting coming data will be lost. The software must read out the FIFO data before it becomes full.

## 4.1.5 A/D Data Transfer Modes

The A/D data must be transferred to CPU for processing. On the ACL-8316, many AD data transfer modes can be used. Note that there are only two kinds of operation can transfer AD data from port into PC's memory. The data can be either read by I/O instruction ('inport' in terms of C language), which is handled directly by software, or transferred to memory by the DMA controller. Combing with programming the AD mode control register and the interrupt source control register, the ACL-8316 provides the following transfer modes:

## Software Data Read

It is very simple to read A/D data through the A/D data register. Usually, this mode is used combining with software trigger mode. Because of the A/D conversion time will not excess 10µs on ACL-8316, after software triggering, the software can just wait for 10µs then A/D data will be available in the A/D data register. The software can read the data simply by using the inport instruction.

## Software Data Polling

In this mode, A/D data is also read through the A/D data register but check the  $AD_BUSY$  bit. After the A/D conversion triggering, the software can poll the  $AD_BUSY$  bit in the A/D status register until  $AD_BUSY$  becomes to high level. The newest A/D data is stored in the A/D data register now, then the software can read data simply by using the inport instruction.

## Software Data Polling from FIFO

The A/D data can also be read from FIFO buffer if FIFO is enable. In this mode, the A/D data is read from FIFO after check the FF\_EF bit of the A/D status register. As the FF\_EF is set (1), the FIFO is not empty and to read A/D value through the FIFO register is available.

## EOC Interrupt Transfer

By properly programming the interrupt control register, the ACL-8316 provides end of conversion (EOC) interrupt. It is useful to combine the EOC interrupt transfer with the timer pacer trigger. The data transfer is essentially asynchronous with the control software under this mode. Users must set the IRQ level by hardware jumper as installing. Please refer section 2.x for IRQ jumper setting. After the A/D conversion completing, a hardware interrupt will be inserted and its corresponding ISR (Interrupt Service Routine) will be invoked and executed. The converted data can be transferred by the ISR program.

## FIFO Half-Full Interrupt Transfer

By properly programming the interrupt control register, the ACL-8316 provides FIFO half-full interrupt. As the FIFO is enable and be half-full, an interrupt is inserted and the corresponding ISR will be invoked. The ISR can read at least 512 sampling data because of the FIFO size is 1K sample. This mode can tolerate more time delay and it is interrupt driven, therefore, it is very suitable for Windows applications. The maximum 100 kHz sampling rate can be also applied under this mode for high speed applications.

## DMA Transfer

As the *DMAENA* bit of the A/D mode control register is set, the DMA (Direct Memory Access) mode is enable and the interrupt resource will be occupied by the terminal counting (TC) signal of the DMA controller. The DMA allows data to be transferred directly from A/D data register to the PC memory at the fastest possible rate without using any CPU time. The A/D data is automatically transferred to PC's memory after conversion is complete.

The DMA transfer mode is very complex to program. It is recommended to use the high level program library to operate this card. If you wish to program the software which can handle the DMA data transfer, please refer to more information about 8237 DMA controller.

## 4.1.6 A/D Data Format

The A/D data read either from A/D data port or the FIFO port is in the two's complement format. As the A/D gain is 1, the A/D signal range is roughly +10V ~ -10V bipolar. In ACL-8316, 16 bits A/D data is available. The relationship between the voltage and the value is shown in the following table:

| A/D Data (Hex) | Decimal Value | Voltage (Volts) |
|----------------|---------------|-----------------|
| 7FFF           | +32767        | +10.00000       |
| 4000           | +16384        | +5.00015        |
| 0001           | 1             | +0.00031        |
| 0000           | 0             | 0.00000         |
| FFFF           | -1            | -0.00031        |
| C000           | -16384        | -5.00015        |
| 8001           | -32767        | -10.00000       |
| 8000           | -32768        | -10.00031       |

**Note:** The decimal value of the A/D data is in the same sign with the bipolar voltage. Therefore, the sign extension conversion is not necessary.

The A/D data format of 12 bits ACL-8312 is compatible with the 16 bits ACL-8316. Only the 4 LSB of the 16 bits A/D data are truncated to zero. Therefore the software is compatible for the two cards. The relationship between the voltage and the value is shown in the following table:

| A/D Data (Hex) | Decimal Value | Voltage (Volts) |
|----------------|---------------|-----------------|
| 7FF 0          | +32752        | +10.0000        |
| 400 0          | +16384        | +5.0024         |
| 001 0          | +16           | +0.0049         |
| 000 0          | 0             | 0.0000          |
| FFF 0          | -16           | -0.0049         |
| C00 0          | -16384        | -5.0024         |
| 801 0          | -32752        | -10.0000        |
| 800 0          | -32768        | -10.0049        |

The formula between the A/D data and the analog value is

$$Voltage = AD\_data \times \frac{1}{K} \times \frac{10}{gain}$$

where the *gain* is the value of the A/D gain control register. The K is a coefficient. For ACL-8316, K=32767; for ACL-8312, K=32752=2047x16.

## 4.2 Interrupt System

The interrupt system of the ACL-8316/12 is very flexible for many applications. There are four plus one (4+1) programmable interrupt sources. The interrupt signal can be routed one of the 10 IRQ channels by jumper setting. The following diagram shows interrupt system.



Figure 4.2 The illustration of Interrupt System

The 4 programmable interrupt source is the external interrupt, end of conversion (EOC) interrupt, 8254 timer interrupt and the FIFO half-full interrupt. The additional one is the DMA terminal counter (TC) interrupt. As the DMA is enable, the only one possible interrupt source is the DMA TC interrupt because the DMA programming must use this interrupt to set the DMA controller. However, if the DMA is disable, the other 4 signal can be selectable by program,

Sometimes the interrupt signal may be used by combining with the data transfer. For example, the EOC interrupt and the FIFO half-full interrupt can startup an ISR to read data, please refer to section 4.1.5 for data transferring. However, as the A/D data is read by software FIFO polling, the interrupt can be reserved to be used as emergency interrupt, which comes from external, or timer interrupt, which comes directly from the 8254 timer interrupt.

The interrupt signal is routed to one of the ten IRQ levels: 3, 4, 5, 6, 7, 9, 10, 11, 12, 15. The jumper (JP3) sets the IRQ channels. To disable the interrupt, just remove the jumper and put the jumper to the 'NC' position.

## 4.3 D/A Conversion

The ACL-8316/12 has two unipolar analog output channels. To make the D/A output connections from the appropriate D/A output, please refer Figure 4.3.



Figure 4.3 Connection of Analog Output Connection

The operation of D/A conversion is much more simple than A/D operation. You only need to write digital values into the D/A data registers and the corresponding voltage will be output from the AO1 or AO2. Refer to section 4.11 for information about the D/A data register and section 4.12 for control the D/A data format. The mathematical relationship between the digital number DAn and the output voltage is formulated as following:

$$Vout = -Vref \times \frac{DAn}{4096}$$

where the *Vref* is the reference voltage, the *Vout* is the output voltage, and the *DAn* is the digital value in D/A data registers. Because of the D/A channels use the 16 bits data bus, the digits can write to DAC by only one outport instruction.

| Digital Input<br>Binary Format | Analog Output |             |  |
|--------------------------------|---------------|-------------|--|
|                                | Unipolar      | Bipolar     |  |
|                                | 0 to 10V      | -10V to 10V |  |
| FFF hex                        | +9.9976V      | +9.9951V    |  |
| 800 hex                        | +5.0000V      | 0.0000V     |  |
| 7FF hex                        | +4.9976V      | -0.0049V    |  |
| 000 hex                        | 0.0000V       | -10.0000V   |  |
| 1LSB                           | 2.44mV        | 4.88mV      |  |

Note that the two D/A channels could be in **double buffered** mode or in the **transparency** mode. In the transparency mode, the operation of the two D/A channels are independent. The analog out signal will real-time response the digital value written into the DACs. However, in the double buffered, the digital value of each channels is double buffered. That means the analog out signal of both the two channels will response the digital value only when channel #2 is written and the analog signal update in the same time. The benefit the double buffered mode is that the power on voltage of the analog output is controllable. It will be 0 volts. However, the power on voltage of the analog output can not be guaranteed in transparency mode.

The default setting of the DA channels is the double buffered mode. However, the user can change it to transparency mode after power on. Please refer the section 3.12 for the DA output mode control.

## 4.4 Digital Input and Output

The ACL-8316/12 provides 16 digital input and 16 digital output channels through the connector CN1 and CN2 on board. The digital I/O signal are fully TTL/DTL compatible. The detailed digital I/O signal specification can be referred in section 1.3.



Figure 4.4 Digital I/O Connection

The D/A of ACL-8316 is an optional module, users can purchase it according to the requirement of the applications. The D/A output range of the ACL-8316 is fixed bipolar -10V ~ +10V. It can cover both unipolar and bipolar applications.

To program digital I/O operation is fairly straight forward. The digital input operation is just to read data from the corresponding registers, and the digital output operation is to write data to the corresponding registers. The digital I/O registers' format are shown in section 3.9. Note that the DIO data channel can only be read or written in form of 8 bits together. It is impossible to access individual bit channel.

## 4.5 Timer/Counter Operation

The ACL-8316/12 has an 8254 programmable interval timer/counter on board. It offers 3 independent 16-bit programmable down counters; counter 1 and counter 2 are cascaded together for A/D timer pacer trigger of A/D conversion, counter 0 is free for your applications. Figure 4.5 shows the 8254 timer/counter connection.



Figure 4.5 Block Diagram of 8254 Timer/Counter

The clock source of counter 0 can be internal or external, while it's gate can be controlled externally and the output is send to the connector CN3. As to counter 1 and counter 2, the gates are internally pulled high and still can be controlled externally. All clock sources and outputs of counter 1 and counter 2 are internally fixed and can't be accessed via any connector. All the timer/counter signals are TTL compatible.

## The 8254 Timer / Counter Chip

The Intel (NEC) 8254 contains three independent, programmable, multimode 16 bit counter/timers. The three independent 16 bit counters can be clocked at rates from DC to 5 MHz. Each counter can be individually programmed with 6 different operating modes by appropriately formatted control words. The most commonly uses for the 8254 in microprocessor based system are:

- programmable baud rate generator
- event counter
- binary rate multiplier
- real-time clock
- digital one-shot
- motor control

For more information about the 8254, please refer to the Intel's website (http://support.intel.com/support/controllers/peripheral/231164.htm).

## Pacer Trigger Source

The counter 1 and counter 2 are cascaded together to generate the timer pacer trigger of A/D conversion. The frequency of the pacer trigger is software controllable. The maximum pacer signal rate is 2MHz/4=500K which excess the maximum A/D conversion rate of the ACL-8316/12. The minimum signal rate is 2MHz/65535/65535, which is a very slow frequency that user may never use it.

## General Purpose Timer/ Counter

The counter 0 is free for users' applications. The clock source, gate control signal and the output signal are sent to the connector CN3. This general purpose timer/counter can be used as event counter, frequency generator or used for measuring frequency and others functions.

## I/O Address

The 8254 in the ACL-8316/12 occupies 4 I/O address as shown below.

| BASE + 0 | LSB OR MSB OF COUNTER 0 |
|----------|-------------------------|
| BASE + 1 | LSB OR MSB OF COUNTER 1 |
| BASE + 2 | LSB OR MSB OF COUNTER 2 |
| BASE + 3 | CONTROL BYTE            |

The programming of 8254 is controlled by the registers BASE+0 to BASE+3. For more detailed information, please refer to Intel's data sheet (see "http://support.intel.com/support/controllers/peripheral/231164.htm").

## Control Byte

Before loading or reading any of these individual counters, the control byte (BASE+3) must be loaded first. The format of the control byte is:

| Bit | 7   | 6   | 5   | 4   | 3  | 2  | 1  | 0   |
|-----|-----|-----|-----|-----|----|----|----|-----|
|     | SC1 | SC0 | RL1 | RL0 | M2 | M1 | MO | BCD |

• SC1 & SC0 - Select Counter (Bit7 & Bit 6)

| SC1 | SC0 | COUNTER          |
|-----|-----|------------------|
| 0   | 0   | Select Counter 0 |
| 0   | 1   | Select Counter 1 |
| 1   | 0   | Select Counter 2 |
| 1   | 1   | ILLEGAL          |

| RL1 | RL0 | OPERATION                     |
|-----|-----|-------------------------------|
| 0   | 0   | COUNTER LATCH FOR STABLE READ |
| 0   | 1   | READ/LOAD LSB ONLY            |
| 1   | 0   | READ/LOAD MSB ONLY            |
| 1   | 1   | READ/LOAD LSB FIRST. THEN MSB |

• RL1 & RL0 - Select Read/Load operation (Bit 5 & Bit 4)

• M2, M1 & M0 - Select Operating Mode (Bit 3, Bit 2, & Bit 1)

| M2 | M1 | MO | MODE |
|----|----|----|------|
| 0  | 0  | 0  | 0    |
| 0  | 0  | 1  | 1    |
| х  | 1  | 0  | 2    |
| х  | 1  | 1  | 3    |
| 1  | 0  | 0  | 4    |
| 1  | 0  | 1  | 5    |

• BCD - Select Binary/BCD Counting (Bit 0)

| 0    | 16-BITS BINARY COUNTER                                                                                        |
|------|---------------------------------------------------------------------------------------------------------------|
| 1    | BINARY CODED DECIMAL (BCD) COUNTER (4<br>DIGITAL)                                                             |
| Note | The count of the binary counter is from 0 up to 65,535 and the count of the BCD counter is from 0 up to 9,999 |

## Mode Definitions

In 8254, six operating modes can be selected. They are:

- Mode 0: Interrupt on Terminal Count
- Mode 1: Programmable One-Shot.
- Mode 2: Rate Generator.
- Mode 3: Square Wave Rate Generator.
- Mode 4: Software Triggered Strobe.
- Mode 5: Hardware Triggered Strobe.

All detailed descriptions of these modes are written in Intel's data sheet ("http://support.intel.com/support/controllers/peripheral/231164.htm").

# 5

## C/C++ Library

This chapter describes the DOS software library, which is free supplied. The DOS library software includes a utility program, C language library, and some demonstration programs, which can help you reduce the programming work.

To program in Windows environment, please use ACLS-DLL2. The function reference manual of ACLS-DLL2 is included in the ADLINK CD. It needs license.

## 5.1 Installation

To install the DOS library software and utilities, please follow the following installation procedures:

- 1. Put ADLINK CD into the appropriate CD-ROM drive.
- 2. Type the following commands to change to the card's directory (*X* indicates the CD-ROM drive):

## X:\>CD \NuDAQISA\7120

- 3. Execute the setup batch program to install the software:
- 4. X:\NuDAQISA\7120>**SETUP**

## 5.2 Software Utility

The ACL-8316/12's Utility includes *System Configuration*, *Calibration*, and *Functional Testing*. This utility software is designed by menu-driven based on windowing environment. Not only the text messages are shown for operating guidance, but also has the graphic to indicate you how to set right hardware configuration

## Running the 8316UTIL.EXE

After finishing the installation, you can execute the utility by typing as follows:

C> CD \ADLINK\8316\DOS\UTIL

C> 8316UTIL

the following diagram will be displayed on you screen.

## 5.3 Programming Guide

There are 28 function calls are provided by the C Language Library, all the functions of ACL-8316/12 are covered by this library, its capabilities include A/D conversion, D/A conversion, Digital Input and Output, etc.

## Data Types

We defined some data types in 8316.H. These data types are used by ACL-8316 library. We suggest you to use these data types in your application programs. The following table shows the data type names and their ranges.

| Type Name | Description             | Range                     |
|-----------|-------------------------|---------------------------|
| U8        | 8-bit ASCII character   | 0 to 255                  |
| l16       | 16-bit signed integer   | -32768 to 32767           |
| U16       | 16-bit unsigned integer | 0 to 65535                |
| 132       | 32-bit signed integer   | -2147483648 to            |
|           |                         | 2147483647                |
| U32       | 32-bit unsigned integer | 0 to 4294967295           |
| F32       | 32-bit single-precision | -3.402823E38 to           |
|           | floating-point          | 3.402823E38               |
| F64       | 64-bit double-precision | -1.797683134862315E308 to |
|           | floating-point          | 1.797683134862315E309     |
| Boolean   | Boolean logic value     | TRUE, FALSE               |

## 5.4 \_8316\_Initial

## @ Description

An ACL-8316/12 card is initialized according to the card number and the corresponding base address. Every ACL-8316/12 Multi-Function Data Acquisition Card have to be initialized by this function before calling other functions.

## @ Syntax

I16 \_8316\_Initial( U8 card\_number,U16 base\_addresss )

## @ Argument

card\_number: the card number to be initialized, up to three cards can be initialized, the card number must be CARD\_1, CARD\_2 or CARD\_3.

base\_address: the I/O port base address of the card, the default address on the hardware setting is Hex 220.

## @ Return Code

ERR\_NoError, ERR\_InvalidBoardNumber, ERR\_BaseAddressError

## 5.5 \_8316\_Switch\_Card\_No

## @ Description

This function is used when more than one ACL-8316/12 cards on your system. After initialized more than one ACL-8316/12 card, this function is used to select which card is active currently.

**Note:** In this library, only three ACL-8316/12 can be initialized. The reason is only three DMA channels are supported in the card.

## @ Syntax

int \_8316\_Switch\_Card\_No( U8 card\_number )

## @ Argument

card\_number: the card number to be initialized, only three cards can be initialized, the card number must be CARD\_1, CARD\_2 or CARD\_3.

## @ Return Code

ERR\_NoError, ERR\_InvalidBoardNumber, ERR\_BoardNoIni

## 5.6 \_8316\_DI

## @ Description

This function is used to read data from digital input port. There are 16bit digital inputs on the ACL-8316/12. The digital input status can be accessed by this function directly.

## @ Syntax

I16 \_8316\_DI( U16 \*data )

## @ Argument

data: return value from digital port.

## @ Return Code

ERR\_NoError, ERR\_BoardNoInit

## @ Example

See Demo Program 'DI\_DEMO.C'

## 5.7 \_8316\_DI \_Channel

## @ Description

This function is used to read data from digital input channels (bit). There are 16 digital input channels on the ACL-8316/12. When performs this function, the digital input port is read and the value of the corresponding channel is returned.

\* channel means each bit of digital input ports.

## @ Syntax

I16 \_8316\_DI( U8 di\_ch\_no, Boolean \*data )

## @ Argument

di\_ch\_no: the DI channel number, the value has to be set from 0 to 15.

data: return value, either 0 or 1.

## @ Return Code

ERR\_NoError, ERR\_BoardNoInit, ERR\_InvalidDIChannel

## 5.8 \_8316\_DO

## @ Description

This function is used to write data to digital output port. There are 16 digital outputs on the ACL-8316/12. You can control the digital outputs by this function directly.

## @ Syntax

I16 \_8316\_DO( U16 data )

#### @ Argument

data: value will be written to digital output port

## @ Return Code

ERR\_NoError, ERR\_BoardNoInit

## 5.9 \_8316\_DO\_Channel

## @ Description

This function is used to write data to digital channel. There are 16 digital outputs on the ACL-8316/12. You can control each digital output channel by this function directly. After performing this function, the output status of the special digital output channel will be changed to the do\_data you specified.

\* channel means each bit of digital input ports.

## @ Syntax

I16 \_8316\_DO\_Channel( U8 do\_ch\_no, Boolean do\_data )

## @ Argument

do\_ch\_no: the DO channel number, the value has to be set

from 0 to 15.

do\_data: value will be written to digital output port

## @ Return Code

ERR\_NoError, ERR\_BoardNoInit, ERR\_InvalidDOChannel

## 5.10 \_8316\_DA\_Set\_Mode

## @ Description

This function is used to configure the D/A output mode . There are four modes can be set when the D/A output is used.

- 1. DA\_MODE\_0: Transparency and Binary data format
- 2. DA\_MODE\_1: Transparency and Two's complement format
- 3. DA\_MODE\_2: double buffered and Binary data format
- 4. DA\_MODE\_3: double buffered and Two's complement format

| Digital Input | Digital Input  | Analog Output        |                        |  |
|---------------|----------------|----------------------|------------------------|--|
| Binary Format | 2's complement | Unipolar<br>0 to 10V | Bipolar<br>-10V to 10V |  |
| FFF hex       | 7FFhex         | +9.9976V             | +9.9951V               |  |
| 800 hex       | 000 hex        | +5.0000V             | 0.0000V                |  |
| 7FF hex       | FFF hex        | +4.9976V             | -0.0049V               |  |
| 000 hex       | 800 hex        | 0.0000V              | -10.0000V              |  |
| 1LSB          | 1 LSB          | 2.44mV               | 4.88mV                 |  |

## @ Syntax

I16 \_8316\_DA\_Set\_Mode( U8 da\_mode )

## @ Argument

da\_mode: D/A mode

DA\_MODE\_0: Transparency and Binary data format DA\_MODE\_1: Transparency and Two's complement format DA\_MODE\_2: double buffered and Binary data format DA\_MODE\_3: double buffered and Two's complement format

## @ Return Code

ERR\_NoError, ERR\_BoardNoInit, ERR\_InvalidDAChannel

## 5.11 \_8316\_DA

## @ Description

This function is used to write data to D/A converters. There are two Digital-to-Analog conversion channels on the ACL-8316/12. The resolution of each channel is 12-bit; its data format can be binary or two's complement format. Which data format is used for this function, depends on the setting of function \_8316\_DA\_Set\_Mode().

## @ Syntax

I16 \_8316\_DA( U8 da\_ch\_no, I16 da\_data )

## @ Argument

da\_ch\_no: D/A channel number, DA\_CH\_1 or DA\_CH\_2.

| da_data: | D/A | converted  | value, | the  | data   | format   | of  | binary | and | 2's |
|----------|-----|------------|--------|------|--------|----------|-----|--------|-----|-----|
|          | com | plement ar | e show | n as | the ta | ble belo | ow: |        |     |     |

| Digital Input Digital Inpu |                | Analog Output    |             |  |
|----------------------------|----------------|------------------|-------------|--|
| Binary Format              | 2's complement | Unipolar Bipolar |             |  |
|                            |                | 0 to 10V         | -10V to 10V |  |
| FFF hex                    | 7FFhex         | +9.9976V         | +9.9951V    |  |
| 800 hex                    | 000 hex        | +5.0000V         | 0.0000V     |  |
| 7FF hex                    | FFF hex        | +4.9976V         | -0.0049V    |  |
| 000 hex                    | 800 hex        | 0.0000V          | -10.0000V   |  |
| 1LSB                       | 1 LSB          | 2.44mV           | 4.88mV      |  |

## @ Return Code

ERR\_NoError, ERR\_BoardNoInit, ERR\_InvalidDAChannel

## 5.12 \_8316\_AD\_Set\_Channel

## @ Description

This function is used to set AD channel by means of writing data to the multiplexer scan channel register. There are 16 single-ended or 8 differential A/D channels in ACL-8316/12, so the channel number should be set either 0~15 or 0~7. The initial state is channel 0 which is a default setting by the ACL-8316/12 hardware configuration.

## @ Syntax

I16 \_8316\_AD\_Set\_Channel( U8 ad\_ch\_no )

## @ Argument

ad\_ch\_no: channel number to perform AD conversion

for single-ended mode: channel no. is from 0-15

for differential mode: channel no. is from 0-7

## @ Return Code

ERR\_NoError, ERR\_BoardNoInit, ERR\_InvalidADChannel

## 5.13 \_8316\_AD\_Range

## @ Description

This function is used to set the A/D analog input range by means of writing data to the A/D range control register. For ACL-8316/12 card, the gain values only support 1, 2, 4, 8 four levels. The relationship between analog input voltage ranges and gains are specified by table below:

| AD_INPUT    | GAIN | Input Range |
|-------------|------|-------------|
| AD_B_10_V   | 1    | ±10V        |
| AD_B_5_V    | 2    | ±5V         |
| AD_B_2_5_V  | 4    | ±2.5V       |
| AD_B_1_25_V | 8    | ±1.25V      |

## @ Syntax

I16 \_8316\_AD\_Set\_Range(U8 ad\_range )

## @ Argument

U8 ad\_range: the programmable range of A/D conversion, the possible value are:

AD\_B\_10\_V, AD\_B\_5\_V, AD\_B\_2\_5\_V, and AD\_B\_1\_25\_V

## @ Return Code

ERR\_NoError, ERR\_BoardNoInit, ERR\_AD\_InvalidGain

## 5.14 \_8316\_AD\_Set\_Mode

## @ Description

This function is used to set the A/D trigger source, A/D channel selection and A/D data transfer mode by means of writing data to the *AD Mode Control Register* (refer to section 4.7). The hardware initial state of the ACL-8316/12 is set as internal software trigger with program polling data transfer.

For more detailed A/D mode description, please refer to section 4.1 A/D conversion.

## @ Syntax

I16 \_8316\_AD\_Set\_Mode(U8 ad\_mode )

## @ Argument

ad\_mode: AD Mode control value

## @ Return Code

ERR\_NoError

## 5.15 \_8316\_AD\_Set\_Autoscan

## @ Description

This function is used to set automatic hardware channel scan to be enable or disable. If the ACL-8316/12 is set as enable mode, then the A/D channel can be converted automatically, that is, the hardware will automatically decrement until channel 0. And then, it will go back to channel which is set by \_8316\_AD\_Set\_Channle and wrap back to zero again. For example, the channel is set as 4, the A/D conversion sequence will be 4,3,2,1,0,4,3,2,1,0,4,3,2,1,0.....

If the auto\_scan is set as disable, the channel will be kept as single channel only, such as channel 4.

## @ Syntax

I16 \_8316\_AD\_Autoscan( Boolean flag )

## @ Argument

flag: '1' Enable the autoscan

'0' Disable the autoscan

## @ Return Code

ERR\_NoError, ERR\_BoardNoInit

## 5.16 \_8316\_AD\_Set\_FIFO

## @ Description

This function is used to enable the FIFO on the ACL-8312/15. As the FIFO is enabled, all A/D converted data are stored into the FIFO. The size of A/D FIFO is 1 K words on-board.

#### @ Syntax

I16 \_8316\_AD\_Set\_FIFO( Boolean flag )

#### @ Argument

None

## @ Return Code

ERR\_NoError, ERR\_BoardNoInit

## 5.17 \_8316\_AD\_Set\_INT\_Source

## @ Description

Four interrupt sources can be used to trigger the interrupt:

INTSRC\_EXTERNAL: the interrupt is trigger by external source through pin-17 of CN3 (ExtTrg signal)

INTSRC\_EOC: interrupt is triggered when an EOC ( A/D converter's end of conversion) is asserted.

INTSRC\_INTERNAL: interrupt is triggered by internal timer pacer INTSRC\_FIFO\_HF: interrupt is triggered by FIFO half ready signal.

The details of interrupt source selection can be referred form section 4.2 Interrupt system.

## @ Syntax

I16 \_8316\_AD\_Set\_INT\_Source( U8 int\_src )

## @ Argument

int\_src: interrupt trigger source,

INTSRC\_EXTERNAL, INTSRC\_EOC, INTSRC\_INTERNAL, INTSRC\_FIFO\_HF

## @ Return Code

ERR\_NoError, ERR\_BoardNoInit

## 5.18 \_8316\_CLR\_IRQ

## @ Description

This function is used to clear interrupt request which requested by the ACL-8316/12. If you use interrupt to transfer A/D converted data, you should use this function to clear interrupt request status, otherwise no new coming interrupt will be generated.

## @ Syntax

I16 \_8316\_CLR\_IRQ( void )

## @ Argument

None

## @ Return Code

ERR\_NoError

## 5.19 \_8316\_AD\_Soft\_Trig

## @ Description

This function is used to trigger the A/D conversion by software. When the function is called, a trigger pulse will be generated and the converted data will be stored in the base address Base +4 and Base +5, and can be retrieved by function \_8316\_AD\_Aquire(). Please refer to section 4.11.

## @ Syntax

I16 \_8316\_AD\_Soft\_Trig( void )

## @ Argument

None

## @ Return Code

ERR\_NoError, ERR\_BoardNoInit

## 5.20 \_8316\_AD\_Read\_FIFO

## @ Description

This function is used to get the AD conversion data which are stored in the FIFO. This function is useful when the FIFO is enabled and converted A/D data already saved in it.

## @ Syntax

I16 \_8316\_AD\_Read\_FIFO( I16 \*ad\_data )

## @ Argument

ad\_data: 16 or 12 bits A/D converted value.

The data format can be referred from section 4.1.5 for details

## @ Return Code

ERR\_NoError, ERR\_BoardNoInit

## 5.21 \_8316\_AD\_Aquire

## @ Description

This function is used to poll the AD conversion data. It will trigger the AD conversion, and read the 16-bit or 12-bit A/D data until the data is ready ('data ready' bit becomes low).

## @ Syntax

I16 \_8316\_AD\_Aquire( I16 \*ad\_data )

## @ Argument

ad\_data: The data format can be referred from section 4.1.6.

for details

## @ Return Code

ERR\_NoError, ERR\_BoardNoInit, ERR\_AD\_AquireTimeOut

## 5.22 \_8316\_AD\_DMA\_Start

## @ Description

The function will perform A/D conversion N times with DMA data transfer by using the pacer trigger (internal timer trigger). It will take place in the background which will not stop until the Nth conversion has completed or your program executes \_8316\_AD\_DMA\_Stop() function to stop the process. After executing this function, it is necessary to check the status of the operation by using the function \_8316\_AD\_DMA\_Status().

## @ Syntax

I16 \_8316\_DMA\_Start( U8 trig\_src, Boolean auto\_scan, U8 ad\_ch\_no, U8 ad\_range, U8 dma\_ch\_no, U8 irq\_no, U16 dma\_count, I16 \*ad\_buf)

## @ Argument

trig\_src: Trigger source for DMA data transfer

DMA\_MODE\_0: Internal timer pacer trigger

DMA\_MODE\_1: External Trigger (Ext\_Trg)

auto\_scan:0: auto-scan is disabled

1: auto-scan is enabled

ad\_ch\_no: A/D channel number

\* If the auto\_scan is enabled, the A/D channel selection sequence is: 0, 1, 2, 3, ...[ad\_ch\_no], 0, 1, 2, 3, ...[ad\_ch\_no], ......

\* If the auto\_ch\_no is disabled, only the [ad\_ch\_no] will be converted.

ad\_range: A/D analog input range, the possible values are:

| ad_range    | GAIN | Input Range |
|-------------|------|-------------|
| AD_B_10_V   | 1    | ±10V        |
| AD_B_5_V    | 2    | ±5V         |
| AD_B_2_5_V  | 4    | ±2.5V       |
| AD_B_1_25_V | 8    | ±1.25V      |

dma\_ch\_no: DMA channel number, DMA\_CH\_5, DMA\_CH\_6 or DMA\_CH\_7

**Note:** Make sure your hardware configuration is set to right DMA channel.

irq\_ch\_no: IRQ channel number, used to stop DMA

Note: Make sure your hardware configuration is set to right IRQ interrupt level.

dma\_count: the number of A/D conversion

ad\_buf: the start address of the memory buffer to store the AD data, the buffer size must be larger than the number of AD conversion.

## @ Return Code

ERR\_NoError, ERR\_BoardNoInit, ERR\_InvalidADChannel,

ERR\_AD\_InvalidGain, ERR\_InvalidDMAChannel,

ERR\_InvalidIRQChannel, ERR\_InvalidTrigSrc

## @ Example

See Demo Program 'AD\_DEMO3.C'

## 5.23 \_8316\_AD\_DMA\_Status

## @ Description

Since the \_8316\_AD\_DMA\_Start function is executed in background, you can issue the function \_8316\_AD\_DMA\_Status to check its operation status.

## @ Syntax

I16 \_8316\_AD\_DMA\_Status( U8 \*status , U16 \*count )

## @ Argument

status: status of the DMA data transfer

0: AD DMA is not completed 1: AD DMA is completed

count: the number of A/D data which has been transferred.

## @ Return Code

ERR\_NoError, ERR\_BoardNoInit, ERR\_AD\_DMANotSet

## @ Example

See Demo Program 'AD\_DEMO3.C'

## 5.24 \_8316\_AD\_DMA\_Stop

## @ Description

This function is used to stop the DMA data transferring. After executing this function, the internal A/D trigger is disable and the A/D timer (timer #1 and #2) is stopped. The function returns the number of the data which has been transferred, no matter if the A/D DMA data transfer is stopped by this function or by the DMA terminal count ISR.

## @ Syntax

I16 \_8316\_AD\_DMA\_Stop( U16 \*count )

## @ Argument

count: the number of A/D converted data which has been transferred.

## @ Return Code

ERR\_NoError, ERR\_BoardNoInit, ERR\_AD\_DMANotSet

## @ Example

See Demo Program 'AD\_DEMO3.C'

## 5.25 \_8316\_AD\_INT\_Start

## @ Description

The function will perform A/D conversion N times with interrupt data transfer by using pacer trigger. It takes place in the background which will not stop until the Nth conversion has completed or your program executes \_8316\_AD\_INT\_Stop() function to stop the process. After executing this function, it is necessary to check the status of the operation by using the function \_8316\_AD\_INT\_Status().

## @ Syntax

```
I16 _8316_INT_Start( U8 int_mode, Boolean auto_scan,
U8 ad_ch_no, U8 ad_range, U8 irq_no, U16 int_count,
I16 *ad_buf)
```

## @ Argument

int\_mode: A/D conversion by interrupt data transfer

| INT_MODE_0: | Internal timer pacer trigger A/D conversion, |
|-------------|----------------------------------------------|
|             | EOC( end of conversion ) trigger interrupt,  |
|             | and get A/D converted data through I/O port. |
|             |                                              |

INT\_MODE\_1: Internal timer pacer trigger A/D conversion, FIFO\_HF( FIFO half full ready ) trigger interrupt, and get 512 A/D converted data through I/O port.

- INT\_MODE\_2: External Trigger A/D conversion , and EOC( end of conversion ) trigger interrupt, and get A/D converted data through I/O port.
- INT\_MODE\_3: External trigger A/D conversion, FIFO\_HF( FIFO half full ready ) trigger interrupt, and get 512 A/D converted data through I/O port.

auto\_scan: 0: auto-scan is disabled

1: auto-scan is enabled

ad\_ch\_no: A/D channel number

ad\_range: A/D analog input range, the possible values are:

| ad_range    | GAIN | Input Range |
|-------------|------|-------------|
| AD_B_10_V   | 1    | ±10V        |
| AD_B_5_V    | 2    | ±5V         |
| AD_B_2_5_V  | 4    | ±2.5V       |
| AD_B_1_25_V | 8    | ±1.25V      |

irq\_ch\_no: IRQ channel number, used to stop DMA

Note: Make sure your hardware configuration is set to right IRQ interrupt level.

int\_count: the number of A/D conversion

ad\_buf: the start address of the memory buffer to store the AD data, the buffer size must large than the number of AD conversion.

## @ Return Code

ERR\_NoError, ERR\_BoardNoInit, ERR\_InvalidADChannel ERR\_AD\_InvalidGain, ERR\_InvalidIRQChannel, ERR\_InvalidTimerValue

## @ Example

See Demo Program 'AD\_DEMO2.C'

## 5.26 \_8316\_AD\_INT\_Status

## @ Description

Since the \_8316\_AD\_INT\_Start() function is executed in background, you can issue the function \_8316\_AD\_INT\_Status to check the status of interrupt operation.

#### @ Syntax

I16 \_8316\_AD\_INT\_Status( U8 \*status, U16 \*count )

#### @ Argument

status: status of the INT data transfer

0: A/D INT is completed 1: A/D INT is not completed

count: current conversion count number.

#### @ Return Code

ERR\_NoError, ERR\_BoardNoInit

#### @ Example

See Demo Program 'AD\_DEMO2.C'

## 5.27 \_8316\_AD\_INT\_Stop

## @ Description

This function is used to stop the interrupt data transfer function. After executing this function, the internal AD trigger is disabled and the AD timer is stopped. The function returns the number of data which has been transferred, no matter whether the AD interrupt data transfer is stopped by this function.

## @ Syntax

I16 \_8316\_AD\_INT\_Stop( U16 \*count )

## @ Argument

count: the number of A/D data which has been transferred.

## @ Return Code

ERR\_NoError, ERR\_BoardNoInit

## @ Example

See Demo Program 'AD\_DEMO2.C'

## 5.28 \_8316\_AD\_Timer

## @ Description

This function is used to setup the Timer #1 and Timer #2. Timer #1 & #2 are used as frequency divider for generating constant A/D sampling rate dedicatedly. It is possible to stop the pacer trigger by setting any one of the dividers as 0. Because the AD conversion rate is limited due to the conversion time of the AD converter, the highest sampling rate of the ACL-8316/12 can not exceed 100 kHz. The multiplication of the dividers must be larger than 20.

## @ Syntax

I16 \_8316\_AD\_Timer( U16 c1 , U16 c2 )

## @ Argument

c1: frequency divider of timer #1 c2: frequency divider of timer #2,

**Note**: the A/D sampling rate is equal to:

2MHz/(c1 \* c2),

when c1 = 0 or c2 = 0, the pacer trigger will be stopped.

## @ Return Code

ERR\_NoError, ERR\_BoardNoInit, ERR\_InvalidTimerValue

## 5.29 \_8316\_TIMER\_Start

## @ Description

The Timer #0 on the ACL-8316/12 can be freely programmed by the users. This function is used to program the Timer #0. This timer can be used as frequency generator if internal clock is used. It also can be used as event counter if external clock is used. All the 8253 mode is available.

## @ Syntax

I16 \_8316\_TIMER\_Start( U8 timer\_mode, U16 c0 )

## @Argument

timer\_mode: the 8253 timer mode, the possible values are: TIMER\_MODE0, TIMER\_MODE1, TIMER\_MODE2, TIMER\_MODE3, TIMER\_MODE4, TIMER\_MODE5. c0: the counter value of timer

## @ Return Code

ERR\_NoError, ERR\_BoardNoInit, ERR\_InvalidTimerMode ERR\_InvalidTimerValue

## 5.30 \_8316\_TIMER\_Read

## @ Description

This function is used to read the counter value of the Timer #0.

## @ Syntax

I16 \_8316\_TIMER\_Read( U16 \*counter\_value )

## @ Argument

counter\_value: the counter value of the Timer #0

## @ Return Code

ERR\_NoError, ERR\_BoardNoInit

## @ Example

See Demo Program 'TMR\_DEMO.C'

## 5.31 \_8316\_TIMER\_Stop

## @ Description

This function is used to stop the timer operation. The timer is set to the 'One-shot' mode with counter value '0'. That is, the clock output signal will be set to high after executing this function.

## @ Syntax

I16 \_8316\_TIMER\_Stop( U16 \*counter\_value )

## @ Argument

counter\_value: the current counter value of the Timer #0

## @ Return Code

ERR\_NoError, ERR\_BoardNoInit

## @ Example

See Demo Program 'TMR\_DEMO.C'

# 6

# **Calibration & Utilities**

In data acquisition process, how to calibrate your measurement devices to maintain its accuracy is very important. Users can calibrate the analog input and analog output channels under the users' operating environment for optimizing the accuracy. This chapter will guide you to calibrate your ACL-8316/12 to an accuracy condition.

## 6.1 What do you need

Before calibrating your ACL-8316/12 card, you should prepare some equipment's for the calibration:

- Calibration program: Once the program is executed, it will guide you to complete the calibration. This program is included in the delivered package.
- A 5 1/2 digit multimeter ( 6 1/2 is recommended)
- A voltage calibrator or a very stable and noise free DC voltage generator.

## 6.2 VR Assignment

There are five variable resistors (VR) on the ACL-8316/12 board to allow you making accurate adjustment on A/D and D/A channels. The function of each VR is specified as Table 6.1.

| VR1 | A/D bipolar offset adjustment                |
|-----|----------------------------------------------|
| VR2 | A/D full scale adjustment                    |
| VR3 | D/A channel 1 full scale adjustment          |
| VR4 | D/A channel 1 offset adjustment              |
| VR5 | D/A channel 2 full scale adjustment          |
| VR6 | D/A channel 2 offset adjustment              |
| VR7 | A/D programmable amplifier offset adjustment |

## Table 6.1 Function of VRs

## 6.3 A/D Adjustment

- 1. Set the analog input range as: +/- 10V, i.e. the gain = 1
- Short the A/D channel 0 (pin 1 of CN3) to ground(GND), and connect the TP1(+) and TP2(-) with your DVM. Trim the variable resister VR7 to obtain a value as close as possible to 0V.
- 3. Applied a +0V input signal to A/D channel 0, and trim the VR1 to obtain reading between 0 to 1.
- 4. Applied a +10V input signal to A/D channel 1, and trim the VR2 to obtain reading between 2046~2047 (8312) or 32766~32767 (8316).
- 5. Repeat step 3 and step 4, adjust VR2 and VR1.

## 6.4 D/A Adjustment

## 6.4.1 DA Channel 1 Calibration

- 1. Set JP5 to BI1 (Bipolar for DA Channel 1).
- 2. Connect VDM (+) to CN3.AO1 pin-30 and VDM(-) to CN3.GND pin-29.
- 3. Set DA1 output to 0x8000
- 4. Trim the variable resister VR4 to obtain -10.005V reading in the DVM.
- 5. Set DA1 output to 0x7FF0
- 6. Trim the variable resister VR3 to obtain +10V reading in the DVM.

## 6.4.2 DA Channel 2 Calibration

- 1. Set JP6 to BI1 (Bipolar for DA Channel 2).
- 2. Connect VDM (+) to CN3.AO2 pin-32 and VDM(-) to CN3.GND pin-29.
- 3. Set DA2 output to 0x8000
- 4. Trim the variable resister VR6 to obtain -10.005V reading in the DVM.
- 5. Set DA2 output to 0x7FF0
- 6. Trim the variable resister VR5 to obtain +10V reading in the DVM.

A calibration utility is supported in the software diskette which is included in the product package. The detailed calibration procedures and description can be found in the utility. Users only need to run the software calibration utility and follow the procedures. You will get the accurate measure data.

## Product Warranty/Service

Seller warrants that equipment furnished will be free form defects in material and workmanship for a period of one year from the confirmed date of purchase of the original buyer and that upon written notice of any such defect, Seller will, at its option, repair or replace the defective item under the terms of this warranty, subject to the provisions and specific exclusions listed herein.

This warranty shall not apply to equipment that has been previously repaired or altered outside our plant in any way as to, in the judgment of the manufacturer, affect its reliability. Nor will it apply if the equipment has been used in a manner exceeding its specifications or if the serial number has been removed.

Seller does not assume any liability for consequential damages as a result from our products uses, and in any event our liability shall not exceed the original selling price of the equipment.

The equipment warranty shall constitute the sole and exclusive remedy of any Buyer of Seller equipment and the sole and exclusive liability of the Seller, its successors or assigns, in connection with equipment purchased and in lieu of all other warranties expressed implied or statutory, including, but not limited to, any implied warranty of merchant ability or fitness and all other obligations or liabilities of seller, its successors or assigns.

The equipment must be returned postage-prepaid. Package it securely and insure it. You will be charged for parts and labor if you lack proof of date of purchase, or if the warranty period is expired.