# NuDAQ<sup>®</sup> PCI-9114(A) DG/HG

Enhanced Multi-Functions
Data Acquisiton Card
User's Guide



### ã Copyright 1999~2001 ADLINK Technology Inc.

All Rights Reserved.

Manual Rev. 1.30: March 29, 2001

Part No. 50-11114-201

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®, NuIPC®, DAQBench® are registered trademarks 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.

| ADLINK Technology Inc.          |                                     |                         |                           |  |  |  |
|---------------------------------|-------------------------------------|-------------------------|---------------------------|--|--|--|
| Web Site                        | http://www.adlink.com.tw            |                         |                           |  |  |  |
| http://www.adlinktechnology.com |                                     |                         |                           |  |  |  |
| Sales & Service                 | service@adlink.com.tw               |                         |                           |  |  |  |
|                                 | NuDAQ                               | nudaq@adlir             | nk.com.tw                 |  |  |  |
|                                 | NuDAM                               | nudam@adlink.com.tw     |                           |  |  |  |
| Technical                       | NulPC nuipc@adlink.com.tw           |                         |                           |  |  |  |
| Support                         | NuPRO                               | PRO nupro@adlink.com.tw |                           |  |  |  |
|                                 | Software                            | sw@adlink.com.tw        |                           |  |  |  |
|                                 | AMB amb@adlink.com.tw               |                         |                           |  |  |  |
| TEL                             | +886-2-82265877 FAX +886-2-82265717 |                         |                           |  |  |  |
| Address                         | 9F, No. 166, Jian Yi Road, Ch       | ungho City, T           | aipei, 235 Taiwan, R.O.C. |  |  |  |

♦ Please inform or FAX us of your detailed information for a prompt, satisfactory and constant service.

| D                     | Detailed Company I                                                              | nformation                    |   |
|-----------------------|---------------------------------------------------------------------------------|-------------------------------|---|
| Company/Organization  |                                                                                 |                               |   |
| Contact Person        |                                                                                 |                               |   |
| E-mail Address        |                                                                                 |                               |   |
| Address               |                                                                                 |                               |   |
| Country               |                                                                                 |                               |   |
| TEL                   |                                                                                 | FAX                           |   |
| Web Site              |                                                                                 |                               |   |
|                       | Questions                                                                       | 5                             |   |
| Product Model         |                                                                                 |                               |   |
| Environment to Use    | □OS: □Computer Brand: □M/B: □Chipset: □Video Card: □Network Interface ( □Other: | —<br>□CPU:<br>□Bios:<br>Card: | - |
| Challenge Description |                                                                                 |                               |   |
| Suggestions to ADLINK |                                                                                 |                               |   |

# **Table of Contents**

| Chapter 1 Introduction                | 1                                  |
|---------------------------------------|------------------------------------|
| 1.1 Features                          | 2                                  |
|                                       | 2                                  |
| 1.3 Specifications                    | 3                                  |
| 1.4 Software Support                  | 4                                  |
|                                       | /4                                 |
|                                       | <i>IEW</i> <sup>®</sup> Driver5    |
|                                       | Driver5                            |
| 1.4.4 DAQBench <sup>TM</sup> : Active | eX Controls6                       |
| 1.4.5 DASYLab™ PRO                    | erver and InTouch <sup>™</sup> 6   |
| 1.4.6 PCIS-DDE: DDE Se                | erver and InTouch $^{\!	op M}$ $6$ |
|                                       | $=^{\text{TM}}$ driver6            |
|                                       | <sup>TM</sup> Driver6              |
| 1.4.9 PCIS-OPC: OPC Se                | rver6                              |
| Chapter 2 Installation                | 7                                  |
| 2.1 What You Have                     | 7                                  |
| 2.2 Unpacking                         | 8                                  |
| 2.3 PCB Layout of PCI-9114            | (A)9                               |
|                                       | 9114 Rev. B19                      |
| 2.3.2 PCB Layout of PCI-91            | 114 Rev. C2 and PCI-9114A<br>      |
|                                       | 10                                 |
|                                       | indows Systems10                   |
|                                       | ents11                             |
| 2.6.1 Pin Assignment of C             | N111                               |
|                                       | CN2 & CN312                        |
| 2.6.3 Pin Assignment of CN            | l4 (Only available in PCI-9114A    |
|                                       | 2 or later)13                      |
|                                       | 14                                 |
|                                       | Input Type Selection14             |
|                                       | Sensor Selection14                 |
|                                       | ction Selection (Only available in |
|                                       | 114 Rev. C2 or later)15            |
| 2.8 Termination Board Conne           | ection 16                          |

| Cnapt | er 3 Registers Format                                  | .17  |
|-------|--------------------------------------------------------|------|
| 3.1   | PCI PnP Registers                                      | . 17 |
| 3.2   | I/O Address Map                                        |      |
|       | A/D Data Registers                                     |      |
|       | A/D Channel Control Register                           |      |
| 3.5   | A/D Input Signal Range Control Register                | . 20 |
| 3.6   | A/D Status Read-back Register                          |      |
| 3.7   | Trigger Mode Control and Read-back Register            |      |
| 3.8   | Interrupt Control and Read-back Register               |      |
| 3.9   | Software Trigger Register                              |      |
| 3.10  | Hardware Interrupt Clear Registers                     |      |
|       | Timer/Counter Register                                 |      |
| 3.12  | High Level Programming                                 | . 25 |
| Chapt | er 4 Operation Theorem                                 | 26   |
| 4.1   | A/D Conversion                                         | .26  |
| 4.1.  |                                                        |      |
| 4.1.  |                                                        |      |
| 4.1.  |                                                        |      |
| 4.1.  |                                                        |      |
| 4.1.  | 5 Pre-Trigger Control (Only available in PCI-9114A and |      |
|       | PCI-9114 Rev.C2 or later)                              | . 34 |
| 4.1.  | 6 A/D Data Format                                      | . 36 |
| 4.2   | Interrupt Control                                      | .37  |
| 4.2.  |                                                        |      |
| 4.2.  |                                                        |      |
| 4.2.  |                                                        |      |
| 4.2.  |                                                        |      |
|       | Isolated Digital Input                                 |      |
|       | Isolated Digital Output                                |      |
|       | Timer/Counter Operation                                |      |
| 4.5.  |                                                        |      |
| 4.5.  | 2 Pacer Trigger Source                                 | . 43 |
| Chapt | er 5 C/C++ Library                                     | 44   |
| 5.1   | Libraries Installation                                 | .44  |
|       | Programming Guide                                      |      |
| 5.2.  | •                                                      |      |
| 5.2.  | 2 Data Types                                           | . 45 |

| 5.3  | _9114_Initial                                        | 46 |
|------|------------------------------------------------------|----|
| 5.4  | _9114_Software_Reset                                 | 46 |
| 5.5  | _9114_DO                                             | 47 |
| 5.6  | _9114_DI                                             |    |
| 5.7  | _9114_AD_Read_Data                                   |    |
| 5.8  | _9114_AD_Read_Data_Repeat                            |    |
| 5.9  | _9114_AD_Read_Data_MUX                               | 50 |
| 5.10 | _9114_AD_Read_Data_Repeat_MUX                        | 51 |
| 5.11 | _9114_AD_Set_Channel                                 | 52 |
| 5.12 | _9114_AD_Set_Range                                   | 53 |
| 5.13 | _9114_AD_Get_Range                                   | 54 |
| 5.14 | _9114_AD_Get_Status                                  | 55 |
| 5.15 | _9114_AD_Set_Mode                                    | 56 |
| 5.16 | _9114_AD_Get_Mode                                    | 57 |
| 5.17 | _9114_INT_Set_Reg                                    | 58 |
| 5.18 | _9114_AD_Get_Reg                                     | 59 |
| 5.19 | _9114_Reset_FIFO                                     | 60 |
| 5.20 | _9114_AD_Soft_Trigger                                | 61 |
| 5.21 | _9114_Set_8254                                       | 62 |
| 5.22 | _9114_Get_8254                                       | 63 |
| 5.23 | _9114_AD_Timer                                       | 64 |
| 5.24 | _9114_Counter_Start (Only available in PCI-9114A and |    |
|      | PCI-9114 Rev.C2 or later)                            | 65 |
| 5.25 | _9114_Counter_Read (Only available in PCI-9114A and  |    |
|      | PCI-9114 Rev.C2 or later)                            | 66 |
| 5.26 | _9114_Counter_Stop (Only available in PCI-9114A and  |    |
|      | PCI-9114 Rev.C2 or later)                            |    |
| 5.27 | _9114_INT_Source_Control                             |    |
| 5.28 | _9114_CLR_IRQ1                                       |    |
| 5.29 | _9114_CLR_IRQ2                                       |    |
| 5.30 | _9114_Get_IRQ_Channel                                |    |
| 5.31 | _9114_Get_IRQ_Status                                 |    |
| 5.32 | _9114_AD_FFHF_Polling                                |    |
| 5.33 | _9114_AD_FFHF_Polling_MUX                            |    |
| 5.34 | _9114_AD_Aquire                                      |    |
| 5.35 | _9114_AD_Aquire_MUX                                  |    |
| 5.36 | _9114_AD_INT_Start                                   |    |
| 5.37 | _9114_AD_FFHF_INT_Start                              |    |
| 5.38 | _9114_AD_INT_Status                                  |    |
| 5.39 | _9114_AD_FFHF_INT_Status                             | 80 |
|      |                                                      |    |

| 5.40 _9 <sup>-</sup> | 114_AD_FFHF_INT_Restart                         | 81     |
|----------------------|-------------------------------------------------|--------|
|                      | 114_AD_INT_Stop                                 |        |
| Chapter              | 6 Calibration & Utilities                       | 83     |
| 6.1 Ca               | libration                                       | 83     |
|                      | What do you need                                |        |
|                      | VR Assignment                                   |        |
| 6.1.3                | A/D Adjustment                                  | 84     |
|                      | Software A/D Offset Calibration                 |        |
| 6.2 Uti              | lity                                            | 87     |
| 6.2.1                | 9114util (For PCI-9114 Rev. B2 Only)            | 87     |
| 6.2.2                | 9114AUtl (For PCI-9114A and PCI-9114 Rev. C2 or | later) |
|                      |                                                 | 90     |
| 6.2.3                | I_EEPROM                                        | 93     |
| Appendi              | x A. 8254 Programmable Interval Timer           | 94     |
| A.1 The              | e 8254 Timer / Counter Chip                     | 94     |
|                      | e Control Byte                                  |        |
| Appendi              | x B.Signal Wiring Diagram                       | 97     |
| Product              | Warranty/Service                                | 100    |

# How to Use This Guide

This manual is designed to help you to use the PCI-9114(A) DG/HG. It is divided into six chapters:

- **Chapter 1**, "Introduction," gives an overview of product features, applications, and specifications.
- Chapter 2, "Installation," describes how to install the PCI-9114(A).
   The layout of PCI-9114(A) is shown, and the jumper settings for analog input channel configuration are specified. The connectors pin assignments and termination boards connection are described.
- Chapter 3, "Registers Format," describes the details of registers format and structure of the PCI-9114(A), this information is very important for the programmers who want to control the hardware by low-level programming language.
- Chapter 4, "Operation Theorem" describes how the PCI-9114(A) operates. The A/D and timer/counter functions are introduced. Also, some programming concepts are specified in this chapter.
- Chapter 5, "C/C++ Library" describes high-level programming interface. It helps programmer to control PCI-9114(A) in high-level language style.
- Chapter 6, "Calibration & Utilities," describes how to calibrate the accuracy of PCI-9114(A), and how to use the utility programs included in the software CD.

# Introduction

The PCI-9114(A) is an advanced data acquisition card based on the 32-bit PCI Bus architecture. High performance designs and the state-of-the-art technology make this card ideal for data logging and signal analysis applications in medical, process control, and etc. The following block diagram shows the brief functions of the PCI-9114(A).



### 1.1 Features

The PCI-9114(A) PCI-Bus Advanced Data Acquisition Card provides the following advanced features:

- 32-bit PCI-Bus, Plug and Play
- 32 single-ended or 16 differential analog inputs channels
- 16-bits high resolution AD conversion
- High amplification gain of 1, 10, 100, 1000 for PCI-9114(A) HG
- Normal gain of 1, 2, 4, 8 for PCI-9114(A) DG
- Single channel sampling rate up to 100 KHz for PCI-9114
- Single channel sampling rate up to 250 KHz for PCI-9114A
- Multi-AD trigger mode: software trigger, timer pacer trigger
- On-board A/D 1K WORDS FIFO memory
- Auto-scanning channel selection
- One user configurable general purpose Timer/Counter (Only available in PCI-9114A and PCI-9114 Rev. C2 or later)
- 16 Isolated Digital Input Channels
- 16 Isolated Digital Output Channels with high driving capability
- 5000 V rms high voltage isolation for DIO channels

# 1.2 Applications

- Industrial process control
- Transducer, thermocouple, RTD
- Power monitor
- Medical instrument
- Biomedical measurement

#### 1.3 **Specifications**

### Analog Input (A/D)

- Converter: LTC1605 (LTC1606 for PCI-9114A) or equivalent, successive approximation type
- Resolution: 16 bits
- Input channels: 32 single-ended or 16 differential input channels
- **Input Range:** (Programmable)

Bipolar:  $\pm 10V$ ,  $\pm 1V$ ,  $\pm 100$  mV,  $\pm 10$  mV (PCI-9114(A) HG) Bipolar:  $\pm 10V$ ,  $\pm 5V$ ,  $\pm 2.5$ ,  $\pm 1.25V$  (PCI-9114(A) DG)

- Throughput: single channel 100 KHz max for PCI-9114 single channel 250 KHz max for PCI-9114A
- Over Voltage Protection for Analog inputs: Continuous ±35V maximum
- Input Impedance: 10 MΩ
- A/D Trigger Modes: Software and Timer pacer trigger
- Data Transfer Mode: Pooling, EOC Interrupt, FIFO Half-full Interrupt
- FIFO Buffer Size: 1024 samples

### Isolated Digital Input (IDI)

- Number of input channels: 16
- Input voltage: 0~ 24 VDC

Logic L: 0~1.5V Logic H: 3~24V

- Input resistance: 4.7 KΩ @ 0.5W • Isolation voltage: 5000 V rms
- Throughput: 10 KHz

# Isolated Digital Output (IDO)

- Number of output channels: 16 channels current source
- Output type: open emitter 0.5 to 50 V<sub>DC</sub>
- Source Current:

Single channel sources 500 mA maximum 8 channels source 60mA maximum simultaneously

• Isolation voltage: 5000 V rms

• Throughput: 10 KHz

### General Specifications

• Connector: 37-pin D-type connector

• Operating Temperature: 0° C ~ 60° Cs

• Storage Temperature: -20° C ~ 80° C

• **Humidity**: 5 ~ 95%, non-condensing

Power Consumption:

+5 V @ 600 mA (typical)

+12 V @ 100 mA (typical)

Dimension:

Length: 7.88" (200 mm) for PCI-9114 Rev. B1

6.89" (175 mm) for PCI-9114 Rev. C2 and PCI-9114A

Width: 4.18" (106 mm)(W)

### 1.4 Software Support

ADLINK provides versatile software drivers and packages for users' different approach to built-up a system. We not only provide programming library such as DLL for many Windows systems, but also provide drivers for many software package such as LabVIEW<sup>®</sup>, HP VEE<sup>TM</sup>, DASYLab<sup>TM</sup>, InTouch<sup>TM</sup>, InControl<sup>TM</sup>, ISaGRAF<sup>TM</sup>, and so on.

All the software options are included in the ADLink CD. The non-free software drivers are protected with serial licensed code. Without the software serial number, you can still install them and run the demo version for two hours for demonstration purpose. Please contact with your dealer to purchase the formal license serial code.

# 1.4.1 Programming Library

For customers who are writing their own programs, we provide function libraries for many different operating systems, including:

- ♦ DOS Library: Borland C/C++ and Microsoft C++, the functions descriptions are included in this user's guide.
- ♦ Windows 95 DLL: For VB, VC++, Delphi, BC5, the functions descriptions are included in this user's guide.

- ◆ PCIS-DASK: Include device drivers and DLL for Windows 98, Windows NT and Windows 2000. DLL is binary compatible across Windows 98, Windows NT and Windows 2000. That means all applications developed with PCIS-DASK are compatible across Windows 98, Windows NT and Windows 2000. The developing environment can be VB, VC++, Delphi, BC5, or any Windows programming language that allows calls to a DLL. The user's guide and function reference manual of PCIS-DASK are in the CD. (\\Manual\_PDF\Software\PCIS-DASK)
- ◆ PCIS-DASK/X: Include device drivers and shared library for Linux. The developing environment can be Gnu C/C++ or any programming language that allows linking to a shared library. The user's guide and function reference manual of PCIS-DASK/X are in the CD. (\Manual\_PDF\Software\PCIS-DASK-X.)

The above software drivers are shipped with the board. Please refer to the "Software Installation Guide" to install these drivers.

### 1.4.2 PCIS-LVIEW: LabVIEW® Driver

PCIS-LVIEW contains the VIs, which are used to interface with NI's LabVIEW software package. The PCIS-LVIEW supports Windows 95/98/NT/2000. The LabVIEW drivers are free shipped with the board. You can install and use them without license. For detail information about PCIS-LVIEW, please refer to the user's guide in the CD.

(\Manual\_PDF\Software\PCIS-LVIEW)

### 1.4.3 PCIS-VEE: HP-VEE Driver

The PCIS-VEE includes the user objects, which are used to interface with HP VEE software package. PCIS-VEE supports Windows 95/98/NT. The HP-VEE drivers are free shipped with the board. You can install and use them without license. For detail information about PCIS-VEE, please refer to the user's guide in the CD.

(\Manual\_PDF\Software\PCIS-VEE)

### 1.4.4 DAQBench™: ActiveX Controls

We suggest the customers who are familiar with ActiveX controls and VB/VC++ programming use the DAQBench<sup>TM</sup> ActiveX Control components library for developing applications. The DAQBench<sup>TM</sup> is designed under Windows NT/98. For more detailed information about DAQBench, please refer to the user's guide in the CD.

(\Manual\_PDF\Software\DAQBench\DAQBench Manual.PDF)

### 1.4.5 DASYLab<sup>™</sup> PRO

DASYLab is an easy-to-use software package, which provides easy-setup instrument functions such as FFT analysis. Please contact us to get DASYLab PRO, which include DASYLab and ADLINK hardware drivers.

### 1.4.6 PCIS-DDE: DDE Server and InTouch™

DDE stands for Dynamic Data Exchange specifications. The PCIS-DDE includes the PCI cards' DDE server. The PCIS-DDE server is included in the ADLINK CD. It needs license. The DDE server can be used conjunction with any DDE client under Windows NT.

### 1.4.7 PCIS-ISG: ISaGRAF™ driver

The ISaGRAF WorkBench is an IEC1131-3 SoftPLC control program development environment. The PCIS-ISG includes ADLINK products' target drivers for ISaGRAF under Windows NT environment. The PCIS-ISG is included in the ADLINK CD. It needs license.

### 1.4.8 PCIS-ICL: InControl<sup>™</sup> Driver

PCIS-ICL is the InControl driver which support the Windows NT. The PCIS-ICL is included in the ADLINK CD. It needs license.

### 1.4.9 PCIS-OPC: OPC Server

PCIS-OPC is an OPC Server, which can link with the OPC clients. There are many software packages on the market can provide the OPC clients now. The PCIS-OPC supports the Windows NT. It needs license.

# Installation

This chapter describes how to install the PCI-9114(A). Please follow the following steps to install the cards.

- ◆ Check what you have (section 2.1)
- ♦ Unpacking (section 2.2)
- ◆ Check the PCB and jumper location (section 2.3)
- ◆ Install the hardware and setup and jumpers (section 2.4, 2.7)
- Install the software drivers and run utility to test (section 2.5)
- ◆ Cabling with external devices (section 2.6, 2.8)

### 2.1 What You Have

In addition to this user's guide, the package includes the following items:

- PCI-9114(A) Enhanced Multi-function Data Acquisition Card
- ADLINK CD
- Software Installation Guide

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 PCI-9114(A) card contains sensitive electronic components that can be easily damaged by static electricity.

The card should be put 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 handling 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 possible damage.

**Note:** Do not apply power to the card if it has been damaged.

You are now ready to install your PCI-9114(A).

# 2.3 PCB Layout of PCI-9114(A)

# 2.3.1 PCB Layout of PCI-9114 Rev. B1



# 2.3.2 PCB Layout of PCI-9114 Rev. C2 and PCI-9114A Rev.A2



### 2.4 Hardware Installation

### Hardware configuration

The PCI cards (or CompactPCI cards) are equipped with plug and play PCI controller, it can request base addresses and interrupt according to PCI standard. The system BIOS will install the system resource based on the PCI cards' configuration registers and system parameters (which are set by system BIOS). Interrupt assignment and memory usage (I/O port locations) of the PCI cards can be assigned by system BIOS only. These system resource assignments are done on a board-by-board basis. It is not suggested to assign the system resource by any other methods.

### PCI slot selection

The PCI card can be inserted to any PCI slot without any configuration for system resource.

### Installation Procedures

- 1. Turn off your computer
- Turn off all accessories (printer, modem, monitor, etc.) connected to your computer.
- 3. Remove the cover from your computer.
- 4. Setup jumpers on the PCI or CompactPCI card.
- 5. Select a 32-bit PCI slot. PCI slot are shorter than ISA or EISA slots, and are usually white or ivory.
- 6. Before handling the PCI cards, discharge any static buildup on your body by touching the metal case of the computer. Hold the edge and do not touch the components.
- 7. Position the board into the PCI slot you selected.
- 8. Secure the card in place at the rear panel of the system.

# 2.5 Device Installation for Windows Systems

Once Windows 95/98/2000 has started, the Rug and Play function of Windows system will find the new NuDAQ/NuIPC cards. If this is the first time to install NuDAQ/NuIPC cards in your Windows system, you will be informed to input the device information source. Please refer to the 'Software Installation Guide" for the steps of installing the device.

# 2.6 Connector Pin Assignments

### 2.6.1 Pin Assignment of CN1

The PCI-9114(A) comes equipped one 37-pin D-type connector - CN1. The pin assignment of CN1 is illustrated in the Figure 2.1.



Figure 2.1 Pin Assignment of CN1

### Legend:

Aln : Analog Input Channel #n (for single-ended mode, n=0~15)

AlxH : Analog Input Channel #x (for differential positive input, x=0-31)

AixL : Analog Input Channel #x (for differential negative input, x=0-31)

AGND : Ground plane for analog signals

+12V : +12V power supply output (with fuse protection)

-12V : -12V power supply output (with fuse protection)

GND : Ground Plane

### 2.6.2 Pin Assignments of CN2 & CN3

The CN2 and CN3 are used for Isolated Digital input and output signals respectively. The pin assignment of CN2 and CN3 is illustrated in the Figure 2.2.

| CN3 (for Isolation Digital Output) |          | CN2 (for Isola  | tion Digital Input) |
|------------------------------------|----------|-----------------|---------------------|
| Vpower20                           | 19Vpower | EICOM4 20       | 19 EICOM2           |
| EOGND 18 O                         | 17 FOCND | EICOM3 18       | 17 EICOM1           |
| DO_15_16_0                         | 15       | DI_1516         | 0 0 15 DI_7         |
| DO 14 14 0                         |          | DI_14 <u>14</u> | 0 0 13 DI_6         |
| DO 13 12 0                         | -        | DI_13 <u>12</u> | 0 0 11 DI_5         |
| DO_1210_                           | 9DO_4    | DI_12 <u>10</u> | 0 0 9 DI_4          |
| DO_118                             | 7DO_3    | DI_118          | 0 0 7 DI_3          |
| DO_106                             | 1 5 00 2 | DI_10 <u>6</u>  | 0 0 <u>5</u> DI_2   |
| DO_94                              | 3DO_1    | DI_94           | 0 0 3 DI_1          |
| DO_82                              | 1 000    | DI_8 <u>2</u>   | 0 0 1 DI_0          |
|                                    |          |                 |                     |

Figure 2.2 Pin Assignments of CN2 & CN3

### Legend:

Dln : Isolated Digital Input Channel # n (n=0~15)

EICOMx : Common plane for Isolated Input group #x (x=1-4)

DOn : Isolated Digital Output Channel #n

EOGND: Isolated Output Signal Ground

Vpower : Isolated Output Driver's Power Supply

# 2.6.3 Pin Assignment of CN4 (Only available in PCI-9114A and PCI-9114 Rev. C2 or later)

The CN4 is used for external signals connection. The pin assignment of CN4 is illustrated in the Figure 2.3.



Figure 2.3 Pin Assignment of CN4

### Legend:

Ext Clk: External Clock for Counter #0

N.C.: No Connection

Cnt\_Out : Output of Counter #0
Clk\_2M : Internal 2MHz Clock

Cnt\_Gate: External Gate Control Signal for Counter #0

+5V : +5V power supply

GND : Ground Plane

Ext\_Trg : External A/D Trigger Signal

PreTrg : External Pre-trigger Signal

# 2.7 Jumper Descriptions

### 2.7.1 JP1: Analog Signal Input Type Selection

JP1 is the selection jumper of analog signal input type. The following diagram shows the possible configurations.



### 2.7.2 JP2: Cold Junction Sensor Selection

JP2 is used toset the usage of cold junction sensor. Note that this jumper is used with JP1 together. The following diagram shows the possible configurations.

• Do not use the C.J. Sensor (Default)



 Connect the C.J. sensor to AD Channel #0 under Differential Input mode. Note that if the JP1 is wrongly set as SE mode, the C.J sensor is connected to CH#0 and the CH#16 is connected to ground plane.



• Connect the C.J. Sensor to AD Channel #0 under Single-Ended Input mode. CH#16 is used as normal single-ended input.



# 2.7.3 JP4: Counter #0 Function Selection (Only available in PCI-9114A and PCI-9114 Rev. C2 or later)

JP4 is used to set the usage of Counter #0. Counter #0 can be set as a Pre-trigger controller or a user configurable Timer/Counter. When Counter #0 was set as a user configurable Timer/Counter, the Clock input, Gate control signal and the Counter Output of Counter #0 can be connected by user via CN4.



### 2.8 Termination Board Connection

The PCI-9114(A) is equipped with the DB-37 connector. The available termination boards include:

### Connect with ACLD-9137

The ACLD-9137 is a direct connector for the add-on card that 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 in front of the A/D conversion.

### Connect with ACLD-9188

ACLD-9188 is a general purposed terminal board for all the cards which come equipped with 37-pin D-sub connector.

### Connect with ACLD-9178

ACLD-9178 is a general purposed terminal board for all the cards, which come, equipped with two 20-pin header connectors.

### Connect with DIN-37D

DIN-37D is a general purposed 37-pin screw terminal with DIN-socket, which provide the easily installation socket. DIN-37D is shipped with a 37-pin cable

# Registers Format

The detailed descriptions of the registers format are specified in this chapter. This information is quite useful for the programmers who wish to handle the card by low-level programming. However, we suggest user have **b** understand more about the PCI interface then start any low-level programming. In addition, the contents of this chapter can help users understand how to use software driver to manipulate this card.

# 3.1 PCI PnP Registers

This PCI card functions as a 32-bit PCI target device to any master on the PCI bus. There are three types of registers: PCI Configuration Registers (PCR), Local Configuration Registers (LCR) and PCI-9114(A) registers.

The PCR, which is compliant to the PCI-bus specifications, is initialized and controlled by the plug & play (PnP) PCI BIOS. User's can study the PCI BIOS specification to understand the operation of the PCR. Please contact with PCISIG to acquire the specifications of the PCI interface.

The PCI bus controller PCI-9050 is provided by PLX technology Inc. (www.plxtech.com). For more detailed information of LCR, please visit PLX technology's web site to download relative information. It is not necessary for users to understand the details of the LCR if you use the software library. The PCI PnP BIOS assigns the base address of the LCR. The assigned address is located at offset 14h of PCR.

The PCI-9114(A) registers are shown in the next section. The base address of the PCI-9114(A) registers is also assigned by the PCI PnP BIOS. The assigned base address is located at offset 18h of PCR.

Please do not try to modify the base address and interrupt which assigned by the PCI PnP BIOS, it may cause resource confliction in your system.

# 3.2 I/O Address Map

Most of the PCI-9114(A) registers are 16 bits. The users can access these registers by 16 bits I/O instructions. There is one 32 bits register on PCI-9114(A). The 32 bits register occupied another LCR address space, that is, base address #2. The base address is allocated by PCI BIOS and is stored at offset 1Ch of PCR. Users can read the PCR to get the LCR base address and the two PCI-9114(A) base addresses by using the PCI BIOS function call.

| I/O Base<br>Address #1 | Write                  | Read                                         |
|------------------------|------------------------|----------------------------------------------|
| Base + 00h             | Isolated DO port       | Isolated DI port                             |
| Base + 02h             | AD MUX channel no.     | AD MUX channel no setting                    |
| Base + 04h             | AD range control       | AD range control read back                   |
| Base + 06h             | AD trigger mode        | AD trigger mode read back                    |
| Base + 08h             | Interrupt control      | Interrupt control read back                  |
| Base + 0Ah             | Software AD trigger    | FIFO status read back                        |
| Base + 0Ch             | Clear H/W IRQ1         |                                              |
| Base + 0Eh             | Clear H/W IRQ2         |                                              |
| Base + 20h             | 8254 Counter #0        | 8254 Counter #0                              |
| Base + 22h             | 8254 Counter #1        | 8254 Counter #1                              |
| Base + 24h             | 8254 Counter #2        | 8254 Counter #2                              |
| Base + 26h             | 8254 Control Registers | 8254 Status Registers                        |
| I/O Base<br>Address #2 | Write                  | Read                                         |
| Base 2 + 00h           |                        | 32 bits AD FIFO data and channel number read |

Table 3.1 I/O Address

# 3.3 A/D Data Registers

The PCI-9114(A) A/D data is stored in the FIFO after conversion. The data can be transferred to host memory by software only. 16-bit input port instruction can read the AD value. The A/D data can also be read back with the channel number together. User will know exactly the channel number of the A/D data. However, it must use 32 bits reading port instruction.

Address: BASE2 + 00h
Attribute: read only

### **Data Format:**

| Bit       | 7    | 6    | 5    | 4    | 3    | 2    | 1   | 0   |
|-----------|------|------|------|------|------|------|-----|-----|
| BASE2+00h | AD7  | AD6  | AD5  | AD4  | AD3  | AD2  | AD1 | AD0 |
| BASE2+01h | AD15 | AD14 | AD13 | AD12 | AD11 | AD10 | AD9 | AD8 |
| BASE2+02h | Χ    | Χ    | Χ    | CH4  | CH3  | CH2  | CH1 | CH0 |
| BASE2+03h | Χ    | Χ    | Χ    | Χ    | Χ    | Χ    | Χ   | Χ   |

AD15~AD0: Analog to digital data. AD15 is the Most Significant Bit (MSB). AD0 is the Least Significant Bit (LSB).CH4~CH0: Channel number of the A/D data.

# 3.4 A/D Channel Control Register

The PCI-9114(A) provides 32 SE or 16 DI channels. The channel control register is used to set the A/D channels to be converted. The 5 LSBs of this register control the channel number. Under non-auto scanning mode, the register sets the channel number for conversion. Under auto-scanning mode, the register set the ending channel number. Note that the read back value is the setting value but not the current selected AD channel number.

Address: BASE + 02h
Attribute: write and read

#### Data Format:

| Bit      | 7 | 6 | 5 | 4   | 3   | 2   | 1   | 0   |
|----------|---|---|---|-----|-----|-----|-----|-----|
| BASE+02h | Χ | Χ | Χ | CN4 | CN3 | CN2 | CN1 | CN0 |
| BASE+03h | Х | Х | Х | Х   | Х   | Х   | Х   | Х   |

CNn: channel number of multiplexer.

CN4 is MSB, and CN0 is LSB.

# 3.5 A/D Input Signal Range Control Register

The A/D range register is used to adjust the analog input ranges. This register directly controls the PGA (programmable gain amplifier). When a different gain value is set, the analog input range will be changed to its corresponding value.

Address: BASE + 04h
Attribute: write and read

Data Format:

| Bit      | 7 | 6 | 5 | 4 | 3 | 2 | 1  | 0  |
|----------|---|---|---|---|---|---|----|----|
| BASE+04h | Χ | Χ | Χ | Χ | Χ | Χ | G1 | G0 |
| BASE+05h | Χ | Χ | Χ | Χ | Χ | Χ | Χ  | Χ  |

The relationship between gain setting and its corresponding A/D range is listed in the table below.

| G1 | G0 | Gain<br>HG/DG | Analog Input Range of PCI-9114(A)HG | Analog Input Range of PCI-9114(A)DG |
|----|----|---------------|-------------------------------------|-------------------------------------|
| 0  | 0  | 1/1           | ±10V                                | ±10V                                |
| 0  | 1  | 10 / 2        | ±1V                                 | ±5V                                 |
| 1  | 0  | 100 / 4       | ±100 mV                             | ±2.5V                               |
| 1  | 1  | 1000 / 8      | <u>+</u> 10 mV                      | ±1.25V                              |

# 3.6 A/D Status Read-back Register

The A/D FIFO status can be read back from this register.

Address: BASE + 0Ah

Attribute: read only

Data Format:

| Bit      | 7 | 6 | 5 | 4 | 3       | 2     | 1     | 0     |
|----------|---|---|---|---|---------|-------|-------|-------|
| BASE+0Ah | Χ | Χ | Χ | Χ | AD_BUSY | FF_FF | FF_HF | FF_EF |
| BASE+0Bh | Χ | Χ | Χ | Χ | Χ       | Χ     | Χ     | Χ     |

FF\_EF: '0' means FIFO is empty
FF HF: '0' means FIFO is half-full

FF\_FF: '0' means FIFO is full, A/D data may have been loss



# 3.7 Trigger Mode Control and Read-back Register

This register is used to control or read back the A/D trigger control setting and the AD range setting.

Address: BASE + 06h

Attribute: write and read

### **Data Format:**

| Bit      | 7 | 6 | 5 | 4 | 3    | 2    | 1     | 0     |
|----------|---|---|---|---|------|------|-------|-------|
| BASE+06h | Χ | Χ | Χ | Χ | PTRG | EITS | TSSEL | ASCAN |
| BASE+07h | Χ | Χ | Χ | Χ | Χ    | Χ    | Χ     | Χ     |

PTRG: Pre-trigger ON/OFF control (Only available in PCI-9114A and PCI-9114 Rev. C2 or later)

1: Pre-Trigger ON

0: Pre-Trigger OFF

EITS: External / Internal Trigger Source (Only available in PCI-9114A and PCI-9114 Rev. C2 or later)

1: External Trigger Source

0: Internal Trigger Source

TSSEL: Timer Pacer / Software Trigger

1: Timer Pacer Trigger

0: Software Trigger

ASCAN: Auto Scan Control

1: Auto Scan ON

0: Auto Scan OFF

Only the modes listed below can be applied on the PCI-9114(A) card:

| Bit 3<br>PTRG | Bit 2<br>EITS | Bit 1<br>TPST | Bit 0<br>ASCAN | Mode Description    |
|---------------|---------------|---------------|----------------|---------------------|
| 0/1           | 0             | 0             | 0/1            | Software Trigger    |
| 0/1           | 0             | 1             | 0/1            | Timer Pacer Trigger |
| 0/1           | 1             | Χ             | 0/1            | External Trigger    |

# 3.8 Interrupt Control and Read-back Register

The PCI-9114(A) has a dual interrupt system, thus two interrupt sources can be generated and be checked by the software. This register is used to select the interrupt sources.

Address: BASE + 08h

Attribute: write and read

### **Data Format:**

| Bit      | 7 | 6 | 5 | 4 | 3   | 2    | 1    | 0    |
|----------|---|---|---|---|-----|------|------|------|
| BASE+08h | Χ | Χ | Χ | Χ | MUX | FFEN | ISC1 | ISC0 |

ISC0: IRQ0 signal select

0: IRQ on the ending of the AD conversion (EOC)

1: IRQ when FIFO is half full

ISC1: IRQ1 signal select (Timer Interrupt only)

FFEN: FIFO enable pin

0: FIFO Enable (Power On default value)

1: FIFO Disable

(To reset FIFO, set FFEN sequence as 0 -> 1 -> 0)

MUX: This is read-only bit to indicate the JP1 is set to single-ended (1) or differential-input (0).

# 3.9 Software Trigger Register

To generate a trigger pulse to the PCI-9114(A) for A/D conversion, you just write any data to this register, then the A/D converter will be triggered.

Address: BASE + 0Ah
Attribute: write only

### Data Format:

| Bit      | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----------|---|---|---|---|---|---|---|---|
| BASE+0Ah | Χ | Χ | Χ | Χ | Χ | Χ | Χ | Χ |
| BASE+0Bh | Χ | Χ | Χ | Χ | Χ | Χ | Χ | Χ |

# 3.10 Hardware Interrupt Clear Registers

Because the PCI interrupt signal is level trigger, the interrupt clear register must be written to clear the flag after processing the interrupt request event; otherwise, that another interrupt request is inserted will cause the software to hang on processing the interrupt event.

There are two interrupt clear registers. The two registers are used to clear the IRQ1 and IRQ2 respectively.

Address: BASE + 0Ch

Attribute: write only

### **Data Format:**

| Bit      | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----------|---|---|---|---|---|---|---|---|
| BASE+0Ch | Χ | Χ | Χ | Χ | Χ | Χ | Χ | Χ |

Address: BASE + 0Eh

Attribute: write only

### **Data Format:**

| Bit      | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----------|---|---|---|---|---|---|---|---|
| BASE+0Eh | Χ | Χ | Χ | Χ | Χ | Χ | Χ | Х |

# 3.11 Timer/Counter Register

The 8254 chip occupies 4 I/O address locations in the PCI-9114(A) as shown blow. Users can refer to NEC's or Intel's data sheet for the full description of the 8254 features. You can download the data sheet for a full description of the 82C54 features on the following web site:

(1) http://support.intel.com/support/controllers/peripheral/231164.htm

(2)http://www.tundra.com (for Tundra's 82C54 datasheet.)

Address: BASE + 20h ~ BASE + 26h

Attribute: read / write

#### Data Format:

| Base + 20h | Counter 0 Register (R/W) |
|------------|--------------------------|
| Base + 22h | Counter 1 Register (R/W) |
| Base + 24h | Counter 2 Register (R/W) |
| Base + 26h | 8254 CONTROL BYTE (W)    |

# 3.12 High Level Programming

To operate the PCI-9114(A), you can bypass the detailed register structures and use the high-level application programming interface (API) to control your PCI-9114(A) card directly. The software library, DOS library for Borland C/C++ is included in the All-in-one CD. Please refer to chapter 5 for more detailed information.



# Operation Theorem

The operation theorem of the functions on PCI-9114(A) card is described in this chapter. The operation theorem can help you to understand how to manipulate or to program the PCI-9114(A).

### 4.1 A/D Conversion

Before programming the PCI-9114(A) 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 transfer mode
- Interrupt System (refer to section 4.2)
- A/D data format

**Note:** Because some of the A/D data transfer modes will use the system interrupt resource. Users have to understand the interrupt system (section 4.2) for understanding AD operation.

#### 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 PCI-9114(A). Refer to the chapter 2. 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 decide 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. Refer to the section 4.1.3 for the two trigger sources.

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

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

## 4.1.2 A/D Signal Source Control

To control the A/D signal source, the signal type, signal channel and signal range should be considered.

## Signal Type

The A/D signal sources of PCI-9114(A) could be single ended (SE) or differential input (DI). There are 32 SE or 16 DI A/D channels on board. To avoid ground loops and get more accurate measurement of A/D conversion, it is quite important to understand the signal source type.

The single-ended (SE) mode means the voltage signal to be measured is relative to the isolated ground (IGND) and is suitable for connecting with the floating signal source. The floating source means the signal source have no connection to real ground or to PC's ground. Figure 4.1 shows the single-ended AI signal connection. Note that when more than two floating sources are connected, the sources must have common ground.

The differential input (DI) mode means the voltage signal to be measured is by a pair of signals, for example, AI3L and AI3H is a differential pair. The AD circuits measure the voltage difference between the differential pair. The common mode noise can be reduced under this mode. Note that the differential signal pair should be still common ground. Figure 4.2 shows the

differential analog signal input connection. By differential input mode, the common mode noise on AIHn and AILn will be deducted.



Figure 4.1 Signal sources and single-ended connection



Figure 4.2 Grounded source and differential input

#### Signal Channel Control

There are two ways to control the channel number. The first one is the software programming and the second one is the auto channel scanning which is controlled by the ASCAN bit in AD trigger mode control register. As ASCAN is cleared (0), the value of AD Channel Control register defines the channel to be selected.

As ASCAN is set 1, the value in AD channel control register defines 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 hannel scanning sequence is 0,1,2,3,0,1,2,3, ..., until the ASCAN bit is cleared.

### 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. Sometimes, the resolution may be not enough if the signal is small. The maximum A/D signal range of PCI-9114(A) is +/- 10 volts when the programmable 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,10,100,1000) or (1,2,4,8). The signal range of the 32 channels will be identical all the time even if the channel number is scanning. The available signal polarity on PCI-9114(A) is bi-polar only, however, the 16-bit high resolution of PCI-9114(A) can cover all the 12-bits uni-polar applications.

### 4.1.3 A/D Trigger Source Control

The A/D conversion is started by a trigger source, and then the A/D converter will start to convert the signal to a digital value. In PCI-9114(A), two internal sources can be selected: the software trigger or the timer pacer trigger. The A/D operation mode is controlled by A/D trigger mode register. Total two trigger sources are provided in the PCI-9114(A). The different trigger conditions are specified as follows:

#### Software trigger (TSSEL=0)

The trigger source is software controllable in this mode. That is, the A/D conversion is starting when any value is written into the software trigger register. This trigger mode is suitable for low speed A/D conversion. Under this mode, the timing of the A/D conversion is fully controlled by software. However, it is difficult to control the fixed A/D conversion rate unless another timer interrupt service routine is used to generate a fixed rate trigger. Refer to interrupt control section (section 4.2) for fixed rate timer interrupt operation.

### Timer Pacer Trigger (TSSEL=1)

An on-board timer/counter chip 8254 is used to provide a 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 4.3 for 8254 architecture. This mode is ideal for high speed A/D conversion. It can be combined with the FIFO half-full interrupt or EOC interrupt to transfer data. It is also possible to use software FIFO polling to transfer data. The A/D trigger, A/D data transfer and Interrupt can be set independently, most of the complex applications can thus be covered. It's recommended using this mode if your applications need a fixed and precise A/D sampling rate.

### External Trigger (EITS=1, TPST=don't care)

Through the pin-4 of CN4 (*ExtTrig*), the A/D conversion also can be triggered by an external signal. The A/D conversion starts as ExtTrig changes from high to low. The conversion rate of this mode is more flexible than the previous two modes, because the users can handle the external signal by the outside device. The external trigger can be also combined with the FIFO half interrupt, EOC interrupt or program FIFO polling to transfer data.

#### 4.1.4 A/D Data Transfer Modes

The A/D data are buffered in the FIFO memory. The FIFO size on PCI-9114(A) is 1024 (1K) words. If the sampling rate is 100 KHz, the FIFO can buffer 10.24 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.

The data must be transferred to host memory after the date is ready and before the FIFO is full. On the PCI-9114(A), many data transfer modes can be used. The different transfer modes are specified as follows:

#### Software Data Polling

The software data polling is the easiest way to transfer A/D data. This mode can be used with software A/D trigger mode. After the A/D conversion is triggered by software, the software should poll the FF\_EF bit of the A/D status register until it becomes low level.

If the FIFO is empty before the A/D start, the FF\_EF bit will be low. After the A/D conversion is completed, the A/D data is written to FIFO immediately, thus the FF\_EF becomes high. You can consider the FF\_EF bit as a flag to indicate the converted data ready status. That is, FF\_EF is high means the data is ready. Note that, while A/D is converted, the ADBUSY bit is low. After A/D conversion, the ADBUSY becomes high to indicate not busy. Please do NOT use this bit to poll the AD data.

It is possible to read A/D converted data without polling. The A/D conversion time will not exceed 10 $\mu s$  on PCI-9114 card, and 4 $\mu s$  on PCI-9114A card. Hence, after software trigger, the software can wait for at least 10 $\mu s$  of 4 $\mu s$  and then read the A/D register without polling.

The data polling transfer is very suitable for the application that needs to process AD data in real time. Especially, when combining with the timer interrupt generation, the timer interrupt service routine can use the data polling method to get multi-channel A/D data in real time and with the fixed data sampling rate.

### FIFO Half-Full Polling

The FIFO half-full polling mode is the most powerful AD data transfer mode. The 1 K words FIFO can be stored up to 10.24 ms analog data under 100 KHz sampling rate (10.24ms = 1024/100KHz), and 4.096 ms analog data under 250 KHz sampling rate (4.096ms = 1024/250KHz). Theoretically, the software can poll the FIFO every 10 or 4 ms without taking care how to trigger A/D or transfer A/D data.

It's recommend that users check your system to find out the user software's priority in the special application. If the application software is at the highest priority, polling the FIFO every 10 ms is suitable. However, the user's program must check the FIFO is full or empty every time reading data.

To avoid this problem, the half-full polling method is used. If the A/D trigger rate is 100KHz, the FIFO will be half-full (512 words) in 5.12 ms. If the user's software checks the FIFO half full signal every 5 ms and the FIFO is not half-full, the software does not read data. When the FIFO is full, the AD FIFO is overrun. That means the sampling rate is higher than users' expect or the polling rate is too slow. It is also possible due to your system occupy the CPU resource thus reducing the polling rate. When the FIFO is half-full and not full, the software can read one "block" (512 words) A/D data without checking the FIFO status. This method is very convenient to read A/D in size of a "block" and it is benefit to software programming.

Usually, the timer trigger is used under this mode, therefore the sampling rate is fixed. The method also utilizes the minimum CPU resources because it is not necessary to be the highest priority. The other benefit is this method will not use hardware interrupt resource. Therefore, the interrupt is reserved for system clock or emergency external interrupt request. The FIFO half-full polling method is the most powerful A/D data transfer mode.

## EOC Interrupt Transfer

The PCI-9114(A) provides traditional hardware end-of-conversion (EOC) interrupt capability. Under this mode, an interrupt signal is generated when the A/D conversion is ended and the data is ready to be read in the FIFO. It is useful to combine the EOC interrupt transfer with the timer pacer trigger mode. After A/D conversion is completed, the hardware interrupt will be inserted and its corresponding ISR (Interrupt Service Routine) will be invoked and executed. The ISR program can read the converted data. This method is most suitable for data processing applications under real-time and fixed sampling rate

#### FIFO Half-Full Interrupt Transfer

Sometimes, the applications do not need real-time processing, but the foreground program is too busy to poll the FIFO data. The FIFO half-full interrupt transfer mode is useful for the situation mentioned above. In addition, as the external A/D trigger source is used, the sampling rate may be not easy to predict, and then the method could be applied. Because the CPU is only interrupted when the FIFO is half-full, thus reserved the CPU load.

Under this mode, an interrupt signal is generated when FIFO becomes half-full. It means there are 512 words data in the FIFO already. The ISR can read a block of data every interrupt occurring. This method is very convenient to read A/D in size of a "block" (512 words) and it is benefit for software programming.

# 4.1.5 Pre-Trigger Control (Only available in PCI-9114A and PCI-9114 Rev.C2 or later)

In certain applications, the data acquisition is applied and stops under special hardware signal. Without Pre-Trigger function, the software can start the A/D at any time, but it is very difficult to stop the A/D in real-time by software. Under "Pre-Trigger" mode, the pre-trigger (PTRG) signal (from pin-9 of CN4) and the 8254 counter 0 are used to "STOP" the A/D sampling.

After setting up the Pre-Trigger mode, the hardware is continuously acquiring A/D data and waiting for the pre-trigger signal. Before the pre-trigger signal is inserted, the software must read the FIFO data to prevent FIFO full. Besides, if these data are usable, the software should store these data as many as possible to the host PC's memory.

When the pre-trigger signal is inserted, the counter is starting to count down from the initial counter value N to count the number of the A/D conversion trigger signal. The A/D trigger will be disabled automatically when the counter value reach zero. The value of N could be 1 to 65535 and the last N A/D data is sampled after the pre-trigger signal. The software must continuously read data out from the FIFO to prevent FIFO full. The software also should poll the counter value to check if the A/D sampling is stopped.

To set up the Pre-Trigger mode, the following steps should be followed:

- 1. Set Pre-Trigger Mode Off: PTRG = OFF.
- 2. Set 8254 Counter #0 value N (N=1~65535). Note that the larger the counter value, the more host memory buffer is needed.
- 3. Set up A/D data acquire, including, A/D range, channel scan, data transfer mode and so on.
- 4. Set Pre-Trigger Mode On: PTRG = ON.
- Read A/D data into host PC memory buffer by certain data transfer method, otherwise the FIFO will full. At the same time, wait the pre-trigger signal and check if the 8254 Counter # 0 value is down to zero.
- 6. If A/D is stopped, set the Pre-Trigger Mode off and process the data which stored in the host memory.
- 7. Go to Step 1 to set the Pre-Trigger mode and wait the next pre-trigger event.

The Pre-Trigger timing is shown as following:



If the application acquires data after the pre-trigger signal, only the last N data need to be stored. The maximum value of N is 65535. If the application only needs to acquire data before the pre-trigger signal, set N=1 then just one more data will be sampled after pre-trigger signal and infinite data before pre-trigger signal can be stored.

#### 4.1.6 A/D Data Format

The range of A/D data read from the FIFO port is from -32768 to 32767. As the A/D gain is 1, the A/D signal range is -10V  $\sim$  +10V. The relationship between the voltage and the value is shown in the following table:

| A/D Data (Hex) | Decimal Value | Voltage (Volts) |
|----------------|---------------|-----------------|
| AND Data (Hex) | Decimal value | ± 10V (Bipolar) |
| 7FFF           | 32767         | +9.9997         |
| 4000           | 16384         | +5.0000         |
| 0001           | 1             | +0.0003         |
| 0000           | 0             | +0.0000         |
| FFFF           | -1            | -0.0003         |
| C000           | -16385        | -5.0000         |
| 8001           | -32767        | -9.9997         |
| 8000           | -32768        | -10.0000        |

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

where the gain is 1,10,100, 1000 for HG version or 1,2,4,8 for DG version.

## 4.2 Interrupt Control

## 4.2.1 System Architecture

The PCI-9114(A)'s interrupt system is a powerful and flexible system that is suitable for A/D data acquisition and many applications. The system is a **Dual Interrupt System**. The dual interrupt means the hardware can generate two interrupt request signals in the same time and the software can service these two request signals by ISR. Note that the dual interrupt does not mean the card occupies two IRQ levels.

The two interrupt request signals (INT1 and INT2) come from digital signals or the timer / counter output. An interrupt source multiplexer (MUX) is used to select the IRQ sources. Fig 4.2.1 shows the interrupt system.



Figure 4.2.1 Dual Interrupt System of PCI-9114(A)

## 4.2.2 IRQ Level Setting

There is only one IRQ level used by this card, although it is a dual interrupt system. This card uses INT #A interrupt request signal to PCI bus. The motherboard circuits will transfer INT #A to one of the AT bus IRQ levels. The IRQ level is set by the PCI plug and play BIOS. This value is saved in the PCI controller. It is not necessary for users to set the IRQ level.

## 4.2.3 Dual Interrupt System

The PCI controller of PCI-9114(A) can receive two hardware IRQ sources. However, a PCI controller can generate only one IRQ to PCI bus, the two IRQ sources should be distinguished by ISR of the application software if the two IRQ are all used.

The application software can use the "\_9114\_Get\_Irq\_Status" function to distinguish which interrupt is inserted. After servicing an IRQ signal, users

should check if another IRQ is also asserted and then clear current IRQ to allow the next IRQ occurring.

The two IRQs are named as INT1 and INT2. INT1 comes from AD EOC or the FIFO half-full flag. INT2 comes from timer's pacer output only. The sources of INT1 and INT2 are selective by the Interrupt Control (ISC) Register.

Because of dual interrupt system, for example, you can use FIFO half-full and external interrupt at the same time if your software ISR can distinguish these two events.

## 4.2.4 Interrupt Source Control

There are two bits to control the IRQ sources of INT1 and INT2. Refer to section 4.9 for the details of the two bits. In addition, the PCI controller itself can also control the use of the interrupt. For manipulating the interrupt system more easily, we recommend you to use the function \_9114\_INT\_Source\_Control to control the IRQ source so that you can disable one or two of the IRQ sources.

Note that even you disable all the two IRQ sources without changing the initial condition of the PCI controller, the PCI BIOS still assigns an IRQ level to the PCI card and it will occupy the PC resource. It is not suggested to re-design the initial condition of the PCI card by users' own application software. If users want to disable the IRQ level, please use the software utility to change the power on interrupt setting.

## 4.3 Isolated Digital Input

There are 16 Isolated Digital input signals. Every digital input signal is connect to one photo isolator such that the signal is isolated from the ground or the power plane of the host PC. The Figure 4.3 illustrates the single digital input circuits.



Figure 4.3 Isolated Input Circuits

The Isolated Digital input could be AC input. The isolation voltage is 5000 V rms. The input resistance is 1.2K Ohm.

Note that the 16 DI signals are partitioned into 4 groups. Each group is based on common plane. Every two groups are mutual isolated. Please refer the Figure 4.3 and the Table 4.3 for the four groups.

| Signal Names | Common Signal |
|--------------|---------------|
| ID_0~ID_3    | EICOM1        |
| ID_4~ID_7    | EICOM2        |
| ID_8~ID_11   | EICOM3        |
| ID_12~ID_15  | EICOM4        |

Table 4.3 Digital input signals and ground plane

The common plane could be either common power or common ground. The following diagram shows the EICOM as common ground. The external devices or circuits provide the power source or current source.



The following diagram shows the EICOM as common power. The external devices or circuits provide the power source and current sink. Most of the open collector output device can connect to PCI-9114(A) by this configuration.



## 4.4 Isolated Digital Output

There are 16 Isolated Digital output signals. Darlington transistors drive the digital output signals. Figure 3.7 shows the output circuits.

Note that the 16 DO signals are using common ground and common external power supply.



Figure 4.4 Digital output circuits

The EOGND pin is used as (fly-wheel) diode, which can protect the driver if the loading is inductance loading such as relay, motor or solenoid. If the loading is resistance loading such as resistor or LED, the connection to fly-wheel diode is not necessary.

Therefore, the first step for connecting the output with external device is to distinguish the type of loading. For example, if the loading is LED or resistor, you can use the following wiring diagram.



Figure 4.5 opto-isolated output circuit for resistance loading

If the loading is an inductance loading such as relay, you can use the following wiring diagram. The POWER must connect to the external power to form a fly-wheel current loop.



Figure 4.6 opto-isolated output circuit for inductance loading

#### 4.5 Timer/Counter Operation

#### 4.5.1 Introduction

One 8254 programmable timer/counter chip is installed in PCI-9114(A). There are three counters in one 8254 chip and 6 possible operation modes for each counter. The block diagram of the timer/counter system is shown in following diagram.



Note: Counter #0 only available in PCI-9114A and PCI-9114 Rev. C2 or later

Figure 4.5.1 Timer/Counter system of PCI-9114(A).

#### 4.5.2 **Pacer Trigger Source**

The timer #1 and timer #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 PCI-9114(A) (80KHz). The minimum signal rate is 2MHz/65535/65535, which is a very slow frequency that user may never use it. The output of the programmable timer can be used as the pacer interrupt source or the timer pacer trigger source of A/D conversion. In software library, the timer #1 and #2 are always set as mode 2 (rate generator) or mode 3.

# C/C++ Library

This chapter describes the software library for operating this card. Only the functions in DOS library and Windows 95 DLL are described. Please refer to the PCIS-DASK function reference manual, which included in ADLINK CD, for the descriptions of the Windows 98/NT/2000 DLL functions.

The function prototypes and some useful constants are defined in the header files LIB directory (DOS) and INCLUDE directory (Windows 95). For Windows 95 DLL, the developing environment can be Visual Basic 4.0 or above, Visual C/C++ 4.0 or above, Borland C++ 5.0 or above, Borland Delphi 2.x (32-bit) or above, or any Windows programming language that allows calls to a DLL. It provides the C/C++, VB, and Delphi include files.

### 5.1 Libraries Installation

Please refer to the "**Software Installation Guide**" for the detail information about how to install the software libraries for DOS, or Windows 95 DLL, or PCIS-DASK for Windows 98/NT/2000.

The device drivers and DLL functions of Windows 98/NT/2000 are included in the PCIS-DASK. Please refer the PCIS-DASK user's guide and function reference, which included in the ADLINK CD, for detailed programming information.

## 5.2 Programming Guide

## 5.2.1 Naming Convention

The functions of the NuDAQ PCI cards or NuIPC CompactPCI cards' software driver are using full-names to represent the functions' real meaning. The naming convention rules are:

In DOS Environment:

\_{hardware\_model}\_{action\_name}. e.g. \_9114\_Initial().

All functions in PCI-9114(A) driver are with 9114 as {hardware\_model}. But they can be used by PCI-9114(A)DG, PCI-9114(A)HG.

In order to recognize the difference between DOS library and Windows 95 library, a capital "W" is put on the head of each function name of the Windows 95 DLL driver. e.g. W\_9114\_Initial().

## 5.2.2 Data Types

We defined some data type in Pci\_9114.h (DOS) and Acl\_pci.h (Windows 95). These data types are used by NuDAQ Cards' library. We suggest you to use these data types in your application programs. The following table shows the data type names and their range.

| Type Name | Description                            | Range                                           |
|-----------|----------------------------------------|-------------------------------------------------|
| U8        | 8-bit ASCII character                  | 0 to 255                                        |
| I16       | 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 floating-point | -3.402823E38 to 3.402823E38                     |
| F64       | 64-bit double-precision floating-point | -1.797683134862315E308 to 1.797683134862315E309 |
| Boolean   | Boolean logic value                    | TRUE, FALSE                                     |

## 5.3 \_9114\_Initial

### @ Description

This function is used to initialize PCI-9114(A). Every f has to be initialized by this function before calling other functions.

#### @ Syntax

```
C/C++ (DOS)
   U16 _9114_Initial (U16 *existCards, PCI_INFO *info)
C/C++ (Windows 95)
   U16 W_9114_Initial (U16 *existCards, PCI_INFO *info)
Visual Basic (Windows 95)
   W_9114_Initial (existCards As Integer, info As PCI_INFO)
   As Integer
```

### @ Argument

```
existCards: numbers of existing PCI-9114(A) cards
info: relative information of the PCI-9114(A) cards
```

#### @ Return Code

```
ERR_NoError
ERR_BoardNoInit
ERR PCIBiosNotExist
```

## 5.4 \_9114\_Software\_Reset

### @ Description

This function is used to reset the I/O port configuration. Note that this function can not re-start the PCI bus and all the hardware setting won't be changed neither.

## @ Syntax

```
C/C++ (DOS)
  void _9114_Software_Reset (U16 cardNo)
C/C++ (Windows 95)
  void W_9114_Software_Reset (U16 cardNo)
Visual Basic (Windows 95)
  W_9114_Software_Reset (ByVal cardNo As Integer)
```

### @ Argument

cardNo: The card number of initialized PCI-9114(A) card

#### @ Return Code

None

## 5.5 \_9114\_DO

#### @ Description

This function is used to write data to digital output port. There are 16 digital output channels on PCI-9114(A).

#### @ Syntax

```
C/C++ (DOS)
   U16   _9114_DO (U16 cardNo, U16 DOData);

C/C++ (Windows 95)
   U16 W_9114_DO (U16 cardNo, U16 DOData)

Visual Basic (Windows 95)
   W_9114_DO (ByVal cardNo As Integer, ByVal DOData As Integer) As Integer
```

### @ Argument

cardNo: The card number of initialized PCI-9114(A) card
DOData: The value will be written to digital output port

#### @ Return Code

ERR\_NoError

## 5.6 \_9114\_DI

### @ Description

This function is used to read data from digital input port. There are 16 digital input channels on PCI-9114(A). The digital input status can be accessed by this function directly.

## @ Syntax

```
C/C++ (DOS)
   U16 _9114_DI (U16 cardNo, U16 far *DIData )
C/C++ (Windows 95)
   U16 W_9114_DI (U16 cardNo, U16 *DIData)
Visual Basic (Windows 95)
   W_9114_DI (ByVal cardNo As Integer, DIData As Integer)
   As Integer
```

## @ Argument

cardNo: The card number of initialized PCI-9114(A) card
DIData: The value accessed from digital input port

#### @ Return Code

## 5.7 \_9114\_AD\_Read\_Data

## @ Description

This function is used to read the AD conversion data from AD Data register. The resolution of A/D conversion data is 16-bit.

### @ Syntax

```
C/C++ (DOS)
   U16 _9114_AD_Read_Data (U16 cardNo, U16 far *ADData)
C/C++ (Windows 95)
   U16 W_9114_AD_Read_Data (U16 cardNo, U16 *ADData)
Visual Basic (Windows 95)
   W_9114_AD_Read_Data (ByVal cardNo As Integer, ADData As Integer) As Integer
```

## @ Argument

cardNo: The card number of initialized PCI-9114(A) card
ADData: A/D converted value. Bit 0 is the LSB of A/D
converted data and bit 15 is the MSB of A/D converted
data.

#### @ Return Code

## 5.8 \_9114\_AD\_Read\_Data\_Repeat

### @ Description

This function is used to read the AD conversion data from the data register n times continuously.

#### @ Syntax

#### C/C++ (DOS)

U16 \_9114\_AD\_Read\_Data\_Repeat (U16 cardNo, I16 far
\*ADData, U16 n)

#### C/C++ (Windows 95)

U16 W\_9114\_AD\_Read\_Data\_Repeat (U16 cardNo, I16 \*ADData,
U16 n)

#### Visual Basic (Windows 95)

W\_9114\_AD\_Read\_Data\_Repeat (ByVal cardNo As Integer, ADData As Integer, ByVal n As Integer) As Integer

### @ Argument

cardNo: The card number of PCI-9114(A) card initialized
ADData: A/D converted value. Bit 0 is the LSB of A/D
converted data and bit 15 is the MSB of A/D converted
data.

n: The number of times to read the AD conversion data

#### @ Return Code

## 5.9 \_9114\_AD\_Read\_Data\_MUX

## @ Description

This function is used to read data from A/D Data Registers. The A/D Data and Channel Number Register is a 32-bit register. Please refer to section 4.2 for the description of A/D Data and Channel Number Register.

### @ Syntax

```
C/C++ (DOS)
   U16 _9114_AD_Read_Data_MUX (U16 cardNo, U32 far
   *ADData)
C/C++ (Windows 95)
   U16 W_9114_AD_Read_Data_MUX (U16 cardNo, U32 *ADData)
Visual Basic (Windows 95)
   W_9114_AD_Read_Data_MUX (ByVal cardNo As Integer,
   ADData As Long) As Integer
```

#### @ Argument

<code>cardNo:</code> The card number of PCI-9114(A) card initialized <code>ADData:</code> A/D converted value. The resolution of A/D conversion data is 16-bit. The unsigned integer data format of ADData is as follows:

bit 0~15: A/D converted data bit 16~20: converted channel no.

#### @ Return Code

## 5.10 \_9114\_AD\_Read\_Data\_Repeat\_MUX

#### @ Description

This function is used to read data from A/D Data and Channel Number Register n times continuously. The A/D Data and Channel Number Register is a 32-bit register. Please refer to section 4.2 for the description of A/D Data and Channel Number Register.

### @ Syntax

#### C/C++ (DOS)

U16 \_9114\_AD\_Read\_Data\_Repeat\_MUX (U16 cardNo, U32 far
\*ADData, U16 n)

#### C/C++ (Windows 95)

U16 W\_9114\_AD\_Read\_Data\_Repeat\_MUX (U16 cardNo, U32
\*ADData, U16 n)

#### C/C++ (Windows 95)

W\_9114\_AD\_Read\_Data\_Repeat\_MUX (ByVal cardNo As Integer, ADData As Long, ByVal n As Integer) As Integer

#### @ Argument

cardNo: The card number of PCI-9114(A) card initialized
ADData: A/D converted value. The resolution of the AD
conversion data is 16-bit. The unsigned integer data
format of ADData is as follows:

bit 0~15: A/D converted data bit 16~20: converted channel no.

n: The timer of times to read the AD conversion data.

#### @ Return Code

## 5.11 \_9114\_AD\_Set\_Channel

### @ Description

This function is used to set AD channel by means of writing data to the channel control register. There are 32 single-ended A/D channels in PCI-9114(A), therefore the channel number could be set between 0 to 31. Under non-auto scan mode, the ADChannelNo stores the channel number setting. Under auto-scan mode, the ADChannelNo records the channel number of ending channel.

#### @ Syntax

```
C/C++ (DOS)
   U16 _9114_AD_Set_Channel (U16 cardNo, U16
   ADChannelNo)
C/C++ (Windows 95)
   U16 W_9114_AD_Set_Channel (U16 cardNo, U16
   ADChannelNo)
```

#### Visual Basic (Windows 95)

W\_9114\_AD\_Set\_Channel (ByVal cardNo As Integer, ByVal ADChannelNo As Integer) As Integer

#### @ Argument

cardNo: The card number of PCI-9114(A) card initialized.
ADChannelNo: The selected channel number or the ending
channel number to perform A/D conversion.

#### @ Return Code

## 5.12 \_9114\_AD\_Set\_Range

### @ Description

This function is used to set the A/D range by means of writing data to the AD range control register. The initial value of gain is '1' which is the default setting by PCI-9114(A) hardware. The following tables specify the relationship between gain and input voltage ranges:

#### For PCI9114HG:

| Input Range (V) | Gain   | Gain Code   |
|-----------------|--------|-------------|
| ±10 V           | X 1    | AD_B_10_V   |
| ±1 V            | X 10   | AD_B_1_V    |
| ±100m V         | X 100  | AD_B_0_1_V  |
| ±10m V          | X 1000 | AD_B_0_01_V |

#### For PCI9114DG:

| Input Range (V) | Gain | Gain Code   |
|-----------------|------|-------------|
| ±10 V           | X 1  | AD_B_10_V   |
| ±5 V            | X 2  | AD_B_5_V    |
| ±2.5 V          | X 4  | AD_B_2_5_V  |
| ±1.25 V         | X 8  | AD_B_1_25_V |

### @ Syntax

#### C/C++ (DOS)

U16 \_9114\_AD\_Set\_Range (U16 cardNo, U16 ADRange)

#### C/C++ (Windows 95)

U16 W\_9114\_AD\_Set\_Range (U16 cardNo, U16 ADRange)

#### Visual Basic (Windows 95)

W\_9114\_AD\_Set\_Range (ByVal cardNo As Integer, ByVal ADRange As Integer) As Integer

#### @ Argument

cardNo: The card number of PCI-9114(A) card initialized
ADRange: The programmable gain of A/D conversion, the
possible values are: AD\_B\_10\_V, AD\_B\_1\_V, AD\_B\_0\_1\_V,
AD\_B\_0\_01\_V, AD\_B\_5\_V, AD\_B\_2\_5\_V, AD\_B\_1\_25\_V,

#### @ Return Code

## 5.13 \_9114\_AD\_Get\_Range

### @ Description

This function is used to get the A/D range from the AD range control register. The following table specifies the relationship between the gain and input voltage ranges, please refer to the previous section for the possible range.

### @ Syntax

```
C/C++ (DOS)
   U16 _9114_AD_Get_Range (U16 cardNo, U16 *ADRange)
C/C++ (Windows 95)
   U16 W_9114_AD_Get_Range (U16 cardNo, U16 *ADRange)
Visual Basic (Windows 95)
   W_9114_AD_Get_Range (ByVal cardNo As Integer, ADRange As Integer) As Integer
```

## @ Argument

cardNo: The card number of PCI-9114(A) card initialized
ADRange: The programmable gain of A/D conversion, the
possible values are: AD\_B\_10\_V, AD\_B\_1\_V, AD\_B\_0\_1\_V,
AD\_B\_0\_01\_V, AD\_B\_5\_V, AD\_B\_2\_5\_V, AD\_B\_1\_25\_V

#### @ Return Code

## 5.14 \_9114\_AD\_Get\_Status

## @ Description

This function is used to get AD FIFO status from the status read back register.

### @ Syntax

```
C/C++ (DOS)
   U16 _9114_AD_Get_Status (U16 cardNo, U16 *ADStatus)
C/C++ (Windows 95)
   U16 W_9114_AD_Get_Status (U16 cardNo, U16 *ADStatus)
Visual Basic (Windows 95)
   W_9114_AD_Get_Status (ByVal cardNo As Integer, ADStatus As Integer) As Integer
```

### @ Argument

```
cardNo: The card number of PCI-9114(A) card initialized
ADStatus: The status of AD FIFO. The AD FIFO status could
be one of the following:
   ADSTS_FF_EF: FIFO is not empty
   ADSTS_FF_HF: FIFO is not half-full
   ADSTS_FF_FF: FIFO is not full
   ADSTS_BUSY: AD is not busy
```

#### @ Return Code

## 5.15 \_9114\_AD\_Set\_Mode

## @ Description

This function is used to set AD trigger mode. Please refer to section 5.1.3 for the detailed description of AD trigger modes.

### @ Syntax

```
C/C++ (DOS)
   U16 _9114_AD_Set_Mode (U16 cardNo, U16 ADMode)
C/C++ (Windows 95)
   U16 W_9114_AD_Set_Mode (U16 cardNo, U16 ADMode)
Visual Basic (Windows 95)
   W_9114_AD_Set_Mode (ByVal cardNo As Integer, ByVal ADMode As Integer) As Integer
```

#### @ Argument

```
cardNo: The card number of PCI-9114(A) card initialized
ADMode: The value of AD mode.
The returned value could be one or a combination of the
following modes:
    A_9114_AD_TimerTrig, A_9114_AD_SoftTrig
    A_9114_AD_AutoScan
```

#### @ Return Code

## 5.16 \_9114\_AD\_Get\_Mode

## @ Description

This function is used to get AD mode from AD trigger mode control register. Please refer to section 5.1.3 for the detailed description of AD trigger modes.

### @ Syntax

```
C/C++ (DOS)
   U16 _9114_AD_Get_Mode (U16 cardNo, U16 *ADMode)
C/C++ (Windows 95)
   U16 W_9114_AD_Get_Mode (U16 cardNo, U16 *ADMode)
Visual Basic (Windows 95)
   W_9114_AD_Get_Mode (ByVal cardNo As Integer, ADMode As Integer) As Integer
```

### @ Argument

```
cardNo: The card number of PCI-9114(A) card initialized
ADMode: The value of AD mode
The returned value could be one or a combination of the
following modes:
    A_9114_AD_TimerTrig, A_9114_AD_SoftTrig
    A_9114_AD_AutoScan
```

#### @ Return Code

## 5.17 \_9114\_INT\_Set\_Reg

## @ Description

This function is used to select the interrupt sources by writing data to interrupt control register. Please refer to section 4.9 to learn how to set the interrupt control register.

## @ Syntax

### C/C++ (DOS)

U16 \_9114\_INT\_Set\_Reg (U16 cardNo, U16 INTC)

### C/C++ (Windows 95)

U16 W\_9114\_INT\_Set\_Reg (U16 cardNo, U16 INTC)

#### **Visual Basic (Windows 95)**

 $W_9114\_INT\_Set\_Reg$  (ByVal cardNo As Integer, ByVal INTC As Integer) As Integer

#### @Argument

cardNo: The card number of PCI-9114(A) card initialized
INTC: The value written to the interrupt control
register

#### @Return Code

## 5.18 \_9114\_AD\_Get\_Reg

### @ Description

This function is used to get the AD mode setting and interrupt control setting by reading data from the Interrupt control read back register. The settings returned are stored in INTC. Please refer to section 4.7 and section 4.9 for the detailed definition of each bit of the returned data.

### @ Syntax

```
C/C++ (DOS)
   U16 _9114_INT_Get_Reg (U16 cardNo, U16 *INTC)
C/C++ (Windows 95)
   U16 W_9114_INT_Get_Reg (U16 cardNo, U16 *INTC)
Visual Basic (Windows 95)
   W_9114_INT_Get_Reg (ByVal cardNo As Integer, INTC As Integer) As Integer
```

### @ Argument

cardNo: The card number of PCI-9114(A) card initialized.
INTC: The value returned from the interrupt control
register.

#### @ Return Code

## 5.19 \_9114\_Reset\_FIFO

## @ Description

The PCI-9114(A) A/D data are stored in the FIFO after conversion. This function is used to reset A/D FIFO. This function should be called before performing A/D conversion to clear the old data stored in the FIFO.

## @ Syntax

```
C/C++ (DOS)
   U16 _9114_Reset_FIFO (U16 cardNo)

C/C++ (Windows 95)
   U16 W_9114_Reset_FIFO (U16 cardNo)

Visual Basic (Windows 95)
   W_9114_Reset_FIFO (ByVal cardNo As Integer) As Integer
```

## @ Argument

cardNo: The card number of PCI-9114(A) card initialized.

#### @ Return Code

## 5.20 \_9114\_AD\_Soft\_Trigger

## @ Description

This function is used to trigger the A/D conversion by software. When this function is called, a trigger pulse will be generated and the converted data will be stored in data register.

## @ Syntax

```
C/C++ (DOS)
   U16 _9114_AD_Soft_Trigger (U16 cardNo)

C/C++ (Windows 95)
   U16 W_9114_AD_Soft_Trigger (U16 cardNo)

Visual Basic (Windows 95)
   W_9114_AD_Soft_Trigger (ByVal cardNo As Integer) As Integer
```

### @ Argument

cardNo: The card number of PCI-9114(A) card initialized.

#### @ Return Code

## 5.21 \_9114\_Set\_8254

#### @ Description

This function is used to write PCI-9114(A) 8254 Programmable Timer.

### @ Syntax

```
C/C++ (DOS)
```

U16 \_9114\_Set\_8254 (U16 cardNo, U16 tmr\_ch, U8 count)

#### C/C++ (Windows 95)

U16 W\_9114\_Set\_8254 (U16 cardNo, U16 tmr\_ch, U8 count)

#### Visual Basic (Windows 95)

W\_9114\_Set\_8254 (ByVal cardNo As Integer, ByVal tmr\_ch As Integer, ByVal count As Byte) As Integer

### @ Argument

cardNo: The card number of PCI-9114(A) card initialized.
tmr\_ch: Port of 8254 Timer, the value is within 0 to 2.
count: The counter value.

#### @ Return Code

## 5.22 \_9114\_Get\_8254

#### @ Description

This function is used to read PCI-9114(A) 8254 Programmable Timer. The read value is stored in count.

#### @ Syntax

```
C/C++ (DOS)
   U16 _9114_Get_8254 (U16 cardNo, U16 tmr_ch, U8 *count)
C/C++ (Windows 95)
   U16 W_9114_Get_8254 (U16 cardNo, U16 tmr_ch, U8 *count)
Visual Basic (Windows 95)
   W_9114_Get_8254 (ByVal cardNo As Integer, ByVal tmr_ch
   As Integer, count As Byte) As Integer
```

#### @ Argument

cardNo: The card number of PCI-9114(A) card initialized.
tmr\_ch: Port of 8254 Timer, the value is within 0 to 2.
count: value read from 8254 programmable timer, only 8
LSBs are effective

#### @ Return Code

ERR NoError

## 5.23 \_9114\_AD\_Timer

#### @ Description

This function is used to set the Timer #1 and Timer#2. These timers are used as frequency dividers 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. Since the AD conversion rate is limited due to the conversion time of the AD converter, the highest sampling rate of the PCI-9114(A) can not be exceeded 100 KHz. Thus the multiplication of the dividers must be larger than 20.

#### @ Syntax

```
C/C++ (DOS)

U16 _9114_AD_Timer (U16 cardNo, U16 c1, U16 c2)

C/C++ (Windows 95)

U16 W_9114_AD_Timer (U16 cardNo, U16 c1, U16 c2)

Visual Basic (Windows 95)

W_9114_AD_Timer (ByVal cardNo As Integer, ByVal c1 As Integer, ByVal c2 As Integer) As Integer

@ Argument

cardNo: The card number of PCI-9114(A) card initialized.
c1: frequency divider of timer #1

c2: frequency divider of timer #2
```

#### @ Return Code

ERR NoError

# 5.24 \_9114\_Counter\_Start (Only available in PCI-9114A and PCI-9114 Rev.C2 or later)

#### @ Description

The counter #0 of the PCI-9114(A) Timer/Counter chip can be freely programmed by the users. This function is used to program the counter #0. This counter 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 8254 modes (six operating modes) are available.

#### @ Syntax

```
C/C++ (DOS)
    U16 _9114_Counter_Start (U16 cardNo, U16 mode, U16 c0)
C/C++ (Windows 95)
    U16 W_9114_Counter_Start (U16 cardNo, U16 mode, U16 c0)
Visual Basic (Windows 95)
    W_9114_Counter_Start (ByVal cardNo As Integer, ByVal mode As Integer, ByVal c0 As Integer) As Integer
```

#### @ Argument

```
cardNo: The card number of PCI-9114(A) card initialized.
mode: the 8254 timer mode, the possible values are :
   TIMER_MODE0, TIMER_MODE1,
   TIMER_MODE2, TIMER_MODE3,
   TIMER_MODE4, TIMER_MODE5.
   Please refer to Counter/Timer 8254's reference
   manual for more detailed information of timer mode.
c0: counter value of counter#0
```

#### @ Return Code

ERR\_NoError

## 5.25 \_9114\_Counter\_Read (Only available in PCI-9114A and PCI-9114 Rev.C2 or later)

#### @ Description

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

#### @ Syntax

```
C/C++ (DOS)
  U16 _9114_Counter_Read (U16 cardNo, U16 *c0)
C/C++ (Windows 95)
  U16 W_9114_Counter_Read (U16 cardNo, U16 *c0)
Visual Basic (Windows 95)
```

W\_9114\_Counter\_Read (ByVal cardNo As Integer, c0 As Integer) As Integer

#### @ Araument

cardNo: The card number of PCI-9114(A) card initialized. c0: count value of counter#0

#### @ Return Code

ERR NoError

## 5.26 \_9114\_Counter\_Stop (Only available in PCI-9114A and PCI-9114 Rev.C2 or later)

#### @ Description

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

#### @ Syntax

```
C/C++ (DOS)
  U16 _9114_Counter_Stop (U16 cardNo, U16 *c0)
C/C++ (Windows 95)
  U16 W_9114_Counter_Stop (U16 cardNo, U16 *c0)
Visual Basic (Windows 95)
```

U16 W\_9114\_Counter\_Stop (ByVal cardNo As Integer, c0 As Integer) As Integer

#### @ Argument

cardNo: The card number of PCI-9114(A) card initialized. c0: the current counter value of the Counter#0

#### @ Return Code

ERR NoError

## 5.27 \_9114\_INT\_Source\_Control

#### @ Description

PCI-9114(A) has a dual-interrupt system, therefore, two interrupt sources can be generated and be checked by the software. This function is used to select and control PCI-9114(A) interrupt sources by writing data to interrupt control register. Please refer to section 5.1.4 for detailed description of A/D data transfer modes.

#### @ Syntax

```
C/C++ (DOS)
```

void \_9114\_INT\_Source\_Control (U16 cardNo, U16 int1Ctrl, U16 int2Ctrl)

#### C/C++ (Windows 95)

void W\_9114\_INT\_Source\_Control (U16 cardNo, U16 intlCtrl, U16 int2Ctrl)

#### Visual Basic (Windows 95)

W\_9114\_INT\_Source\_Control (ByVal cardNo As Integer, ByVal int1Ctrl As Integer, ByVal int2Ctrl As Integer)

#### @ Argument

cardNo: the card number of PCI-9114(A) card initialized.
intlCtrl: the value to control INT1, the value can be
set and the corresponding definition is the following:

0 : INT1 disable

1 : INT1 AD end of conversion (EOC) interrupt

2 : INT1 FIFO half full

int2Ctrl: the value to control INT2, the value can be set and the corresponding definition is the following:

0 : INT2 disable

1 : INT2 timer pacer interrupt

#### @ Return Code

## 5.28 \_9114\_CLR\_IRQ1

#### @ Description

This function is used to clear interrupt request that is requested by PCI-9114INT1. If you use interrupt to transfer A/D converted data, you should use this function to clear interrupt request status, otherwise the new coming interrupt will not be generated.

#### @ Syntax

```
C/C++ (DOS)
  void _9114_CLR_IRQ1 (U16 cardNo)
C/C++ (Windows 95)
  void W_9114_CLR_IRQ1 (U16 cardNo)
Visual (Windows 95)
  W_9114_CLR_IRQ1 (ByVal cardNo As Integer)
```

#### @ Argument

None

#### @ Return Code

None

## 5.29 \_9114\_CLR\_IRQ2

## @ Description

This function is used b clear interrupt request that is requested by PCI-9114INT2. If you use interrupt to transfer A/D converted data, you should use this function to clear interrupt request status, otherwise the new coming interrupt will not be generated.

## @ Syntax

```
C/C++ (DOS)
  void _9114_CLR_IRQ2 (U16 cardNo)
C/C++ (Windows 95)
  void W_9114_CLR_IRQ2 (U16 cardNo)
Visual (Windows 95)
  W_9114_CLR_IRQ2 (ByVal cardNo As Integer)
```

#### @ Argument

None

#### @ Return Code

## 5.30 \_9114\_Get\_IRQ\_Channel

## @ Description

This function is used to get the IRQ level of the PCI-9114(A) card currently used.

#### @ Syntax

```
C/C++ (DOS)
  void _9114_Get_IRQ_Channel (U16 cardNo, U16 *irq_no)
C/C++ (Windows 95)
  void W_9114_Get_IRQ_Channel (U16 cardNo, U16 *irq_no)
Visual Basic (Windows 95)
  W_9114_Get_IRQ_Channel (ByVal cardNo As Integer, irq_no As Integer)
```

#### @ Argument

cardNo: The card number of PCI-9114(A) card initialized.
Irq\_no: The IRQ level used to transfer A/D data for this
card

#### @ Return Code

## 5.31 \_9114\_Get\_IRQ\_Status

#### @ Description

This function is used to get the status of the two IRQs (INT1 and INT2) in PCI-9114(A) card.

#### @ Syntax

```
C/C++ (DOS)
```

void \_9114\_Get\_IRQ\_Status (U16 cardNo, U16 \*ch1, U16
\*ch2)

#### C/C++ (Windows 95)

void W\_9114\_Get\_IRQ\_Status (U16 cardNo, U16 \*ch1, U16
\*ch2)

#### Visual Basic (Windows 95)

W\_9114\_Get\_IRQ\_Status (ByVal cardNo As Integer, ch1 As Integer, ch2 As Integer)

### @ Argument

cardNo: the card number of PCI-9114(A) card initialized.

ch1: the IRQ status of INT1
ch2: the IRQ status of INT2

#### @ Return Code

## 5.32 \_9114\_AD\_FFHF\_Polling

#### @ Description

This function is used to perform the powerful AD data transfer by applying half-full polling mode. This method checks the FIFO half-full signal every time calling this function. If the FIFO is not half-full, the software does not read data. When the FIFO is full, the AD FIFO is overrun. When the FIFO is half-full but not full, software reads the A/D data, which is stored in FIFO, in size of one "block" (512 words). The FIFO half-full polling method is the most powerful A/D data transfer mode. Please refer to section 5.1.4 for the detailed description of half-full polling mode.

#### @ Syntax

```
C/C++ (DOS)
    U16 _9114_AD_FFHF_Polling (U16 cardNo, I16 far *ad_buf)
C/C++ (Windows 95)
    U16 W_9114_AD_FFHF_Polling (U16 cardNo, I16 *ad_buf)
Visual Basic (Windows 95)
    W_9114_AD_FFHF_Polling (ByVal cardNo As Integer, ad_buf As Integer) As Integer
```

#### @ Argument

cardNo: the card number of PCI-9114(A) card initialized.
ad\_buf: the buffer stores the A/D converted value. The
size of ad\_buf can not be smaller than 512 words. The
data format can be referred to section 5.1.5 for the
details

```
ERR_NoError
ERR_FIFO_Half_NotReady
```

## 5.33 \_9114\_AD\_FFHF\_Polling\_MUX

#### @ Description

This function is used to perform powerful AD data transfer by applying half-full polling mode. This method checks the FIFO half full signal every time calling this function. If the FIFO is not half-full, the software does not read data. When the FIFO is full, the AD FIFO is overrun. When the FIFO is half-full and not full, software reads the A/D data, which is stored in FIFO, in size of one "block" (512 words). The difference between this function and 9114\_AD\_FFHF\_Polling is in that the former reads data from the 16 bits register and the latter reads data from 32 bits data register. Please refer to section 5.1.4 for the detailed description of half-full polling mode.

#### @ Syntax

```
C/C++ (DOS)
     U16 _9114_AD_FFHF_Polling_MUX (U16 cardNo, U32 far
     *ad buf)
  C/C++ (Windows 95)
     U16 W_9114_AD_FFHF_Polling_MUX (U16 cardNo, U32
     *ad_buf)
  Visual Basic (Windows 95)
     U16 W 9114_AD_FFHF_Polling_MUX(ByVal cardNo As Integer,
     ad_buf As Long) As Integer
@ Argument
```

cardNo: The card number of PCI-9114(A) card initialized. ad\_buf: The 32bits A/D converted value. The data format can be referred to section 5.1.5 for details.

```
ERR_NoError
ERR_FIFO_Half_NotReady
```

## 5.34 \_9114\_AD\_Aquire

#### @ Description

This function is used to poll the A/D converted data for PCI-9114(A) by software trigger. It reads the A/D data when the data is ready.

#### @ Syntax

```
C/C++ (DOS)
   U16 _9114_AD_Aquire (U16 cardNo, I16 far *ad_data)
C/C++ (Windows 95)
   U16 W_9114_AD_Aquire (U16 cardNo, I16 *ad_data)
Visual Basic (Windows 95)
   W_9114_AD_Aquire (ByVal cardNo As Integer, ad_data As Integer) As Integer
```

#### @ Argument

cardNo: the card number of PCI-9114(A) card initialized. ad\_data: the 16bits A/D converted value. The bit 0 of ADData is the LSB of A/D converted data and the bit 15 of ADData is the MSB of A/D converted data. Please refer to section 5.1.5 for the relationship between the voltage and the value.

```
ERR_NoError
ERR_AD_AquireTimeOut
```

## 5.35 \_9114\_AD\_Aquire\_MUX

#### @ Description

This function is used to poll the A/D conversion data for PCI-9114(A). It reads the A/D data when the data is ready.

#### @ Syntax

```
C/C++ (DOS)
   U16_9114_AD_Aquire_MUX ( U16 cardNo, U32 far *ad_data )
C/C++ (Windows 95)
   U16 W_9114_AD_Aquire_MUX ( U16 cardNo, U32 far *ad_data )
Visual Basic (Windows 95)
   W_9114_AD_Aquire_MUX (ByVal cardNo As Integer, ad_data As Long) As Integer
```

#### @ Argument

```
ERR_NoError
ERR_FIFO_Half_NotReady
```

## 5.36 \_9114\_AD\_INT\_Start

#### @ Description

This function is used to initial and startup the AD EOC (end-of-conversion) interrupt. This function could perform A/D conversion N times with interrupt data transfer by using pacer trigger. It takes place in the background and will not stop until the Nth conversion has been completed or your program execute \_9114\_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 \_9114\_AD\_INT\_Status(). The function can perform on single A/D channel (autoscan is disabled) or multiple A/D channels (autoscan is enabled) with a fixed analog input range.

**Note:** The interrupt mode provided in this function is internal timer source, therefore you must specify c1 & c2 as calling this function. In addition, this function in DOS library supports just one PCI-9114(A) card and provides only one ISR (interrupt service routine) for processing the interrupt events.

#### @ Syntax

#### C/C++ (DOS)

U16 \_9114\_AD\_INT\_Start (U16 cardNo, U16 auto\_scan, U16
ad\_ch\_no, U16 ad\_gain, U16 count, U32 \*ad\_buffer, U16
c1, U16 c2)

#### C/C++ (Windows 95)

U16 W\_9114\_AD\_INT\_Start ( U16 cardNo, U16 auto\_scan, U16 ad\_ch\_no, U16 ad\_gain, U16 count, U32 \*ad\_buffer, U16 c1, U16 c2)

#### Visual Basic (Windows 95)

W\_9114\_AD\_INT\_Start (ByVal cardNo As Integer, ByVal auto\_scan As Integer, ByVal ad\_ch\_no As Integer, ByVal ad\_gain As Integer, ByVal count As Integer, ad\_buffer As Long, ByVal cl As Integer, ByVal c2 As Integer) As Integer

#### @ Argument

cardNo: the card number of PCI-9114(A) card initialized.
auto scan: 0: autoscan is disabled.

1: autoscan is enabled.

ad\_ch\_no: A/D channel number.

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

If the auto\_scan is set as disabled, only the data input from [ad\_ch\_no] is converted.

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

count: the number of A/D conversion

ad\_buffer: the start address of the memory buffer to store the AD data. The buffer size must large than the number of AD conversion. The unsigned integer data format in ad\_buffer is as follows:

bit 0...15: A/D converted data

bit 16...20: converted channel no.

c1: the frequency divider of Timer#1.

c2: the frequency divider of Timer#2.

#### @ Return Code

ERR\_InvalidADChannel
ERR\_AD\_InvalidGain
ERR\_InvalidTimerValue
ERR\_NoError

## 5.37 \_9114\_AD\_FFHF\_INT\_Start

#### @ Description

This function is used to initial and start up the AD EOC (end-of-conversion) interrupt by using AD FIFO Half-Full Interrupt Transfer Mode. This function could perform A/D conversion N times with interrupt data transfer by using pacer trigger. It takes place in the background and will not stop until the Nth conversion has been completed or your program execute \_9114\_AD\_INT\_Stop() function to stop the process. After executing this function, it is necessary to check the status of the operation bν usina the \_9114\_AD\_FFHF\_INT\_Status(). The function can perform on single A/D channel (autoscan is disabled) or multiple A/D channels (autoscan is enabled) with fixed analog input range.

Note: The interrupt mode provided in his function is internal timer source, therefore you must specify c1 & c2 as calling this function. In addition, this function in this library supports just one PCI-9114(A) card and provides only one ISR (interrupt service routine) for processing the interrupt events.

#### @ Syntax

#### C/C++ (DOS)

U16\_9114\_AD\_FFHF\_INT\_Start ( U16 cardNo, U16 auto\_scan, U16 ad\_ch\_no, U16 ad\_gain, U16 blockNo, U32 \*ad\_buffer, U16 c1, U16 c2)

#### C/C++ (Windows 95)

U16 W\_9114\_AD\_FFHF\_INT\_Start ( U16 cardNo, U16 auto\_scan, U16 ad\_ch\_no, U16 ad\_gain, U16 blockNo, U32 \*ad\_buffer, U16 c1, U16 c2)

#### Visual Basic (Windows 95)

W\_9114\_AD\_FFHF\_INT\_Start (ByVal cardNo As Integer, ByVal auto\_scan As Integer, ByVal ad\_ch\_no As Integer, ByVal ad\_gain As Integer, ByVal blockNo As Integer, ad\_buffer As Long, ByVal c1 As Integer, ByVal c2 As Integer) As Integer

#### @ Argument

cardNo: the card number of PCI-9114(A) card initialized. 0: autoscan is disabled. auto scan:

1: autoscan is enabled.

ad\_ch\_no: A/D channel number.

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

If the auto\_scan is set as disable, only the data input from [ad\_ch\_no] is converted.

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

> AD\_B\_10\_V, AD\_B\_1\_V, AD\_B\_0\_1\_V, AD\_B\_0\_01\_V, AD\_B\_5\_V, AD\_B\_2\_5\_V, AD\_B\_1\_25\_V.

blockNo: the number of blocks for performing A/D conversion, one block of A/D conversion is 512 words. ad\_buffer: the start address of the memory buffer to store the AD data. The buffer size must large than the number of AD conversion. The unsigned integer data format in ad\_buffer is as follows:

> bit 0...15: A/D converted data bit 16...20: converted channel no.

c1: the frequency divider of Timer#1. c2: the frequency divider of Timer#2.

#### @ Return Code

ERR InvalidADChannel ERR\_AD\_InvalidGain ERR\_InvalidTimerValue ERR\_NoError

## 5.38 \_9114\_AD\_INT\_Status

#### @ Description

This function is used to check the status of interrupt operation. The \_9114\_AD\_INT\_Start() is executed on background, therefore you can issue this function to check the status of interrupt operation.

#### @ Syntax

```
C/C++ (DOS)
```

U16 \_9114\_AD\_INT\_Status (U16 cardNo, U16 \*status, U16
\*count)

#### C/C++ (Windows 95)

U16 W\_9114\_AD\_INT\_Status (U16 cardNo, U16 \*status, U16 \*count)

#### Visual Basic (Windows 95)

W\_9114\_AD\_INT\_Status (ByVal cardNo As Integer, status
As Integer, count As Integer) As Integer

#### @ Argument

cardNo: the card number of PCI-9114(A) card initialized.
status: the status of the INT data transfer, the possible
 values are:

AD\_INT\_RUN, AD\_INT\_STOP

count: the A/D conversion count number performed
currently

#### @ Return Code

ERR\_NoError

## 5.39 \_9114\_AD\_FFHF\_INT\_Status

#### @ Description

This function is used to check the status of interrupt operation. The \_9114\_AD\_FFHF\_INT\_Start() is executed on background, therefore you can issue this function to check the status of interrupt operation.

#### @ Syntax

```
C/C++ (DOS)
```

U16 \_9114\_AD\_FFHF\_INT\_Status (U16 cardNo, U16 \*status, U16 \*blockNo)

#### C/C++ (Windows 95)

U16 W\_9114\_AD\_FFHF\_INT\_Status (U16 cardNo, U16 \*status, U16 \*blockNo)

#### Visual Basic (Windows 95)

W\_9114\_AD\_FFHF\_INT\_Status (ByVal cardNo As Integer, status As Integer, blockNo As Integer) As Integer

#### @ Argument

cardNo: the card number of PCI-9114(A) card initialized.
status: the status of the INT data transfer, the possible

values are:

AD\_FFHF\_INT\_RUN, AD\_FFHF\_BLOCK\_FULL

#### @ Return Code

ERR\_NoError

## 5.40 \_9114\_AD\_FFHF\_INT\_Restart

#### @ Description

After calling \_9114\_AD\_FFHF\_INT\_Start(), the AD conversion and transfer won't stop until the N blocks of the AD data is acquired, calling this function can restart the FIFO half full interrupt transfer without re-initial all the relative registers. However, if the interrupt operation was stopped by calling \_9114\_AD\_FFHF\_INT\_Stop(), the program should use \_9114\_AD\_FFHF\_INT\_Start() to restart the interrupt transfer function.

#### @ Syntax

```
C/C++ (DOS)
     U16 _9114_AD_FFHF_INT_Restart (U16 cardNo)
  C/C++ (Windows 95)
     U16 W_9114_AD_FFHF_INT_Restart (U16 cardNo)
  Visual Basic (Windows 95)
     W_9114_AD_FFHF_INT_Restart (ByVal cardNo As Integer) As
     Integer
@ Argument
```

cardNo: the card number of PCI-9114(A) card initialized.

#### @ Return Code

ERR NoError

## 5.41 \_9114\_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. This function returns the number of data has been transferred, no matter whether the AD interrupt data transfer is stopped by this function.

#### @ Syntax

```
C/C++ (DOS)
   U16 _9114_AD_INT_Stop (U16 cardNo, U16 *count)
C/C++ (Windows 95)
   U16 W_9114_AD_INT_Stop (U16 cardNo, U16 *count)
Visual Basic (Windows 95)
   W_9114_AD_INT_Stop (ByVal cardNo As Integer, count As Integer) As Integer
```

#### @ Argument

CardNo: the card number of PCI-9114(A) card initialized. count: the number of A/D data which has been transferred.

```
ERR_AD_INTNotSet
ERR_NoError
```

## 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.

The software CD provides two utility programs. They are 9114util.exe which provides three functions, System Configuration, Calibration, and Functional Testing, and I\_eeprom which is used to enable or disable interrupt of PCI-9114(A) board. The utility programs are described in the following sections.

#### 6.1 Calibration

## 6.1.1 What do you need

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

#### 6.1.2 VR Assignment

There are three variable resistors (VR) on the PCI-9114(A) board to allow you making accurate adjustment on A/D channels. The function of each VR is specified in Table 6.1.

| VR1 | A/D offset adjustment                                       |
|-----|-------------------------------------------------------------|
| VR2 | A/D full scale adjustment                                   |
| VR3 | Programmable Gain Amplifier input offset adjustment         |
| VR4 | Cold junction sensor offset adjustment                      |
| VR5 | Programmable Gain Amplifier output offset adjustment        |
|     | (Only available in PCI-9114A and PCI-9114 Rev. C2 or later) |

Table 6.1. Function of the VRs

#### 6.1.3 A/D Adjustment

- · Analog input offset calibration (For PCI-9114 Rev. B2 Only)
  - 1. Set AD input signal type to single-ended (default) input.
  - 2. Short AD Channel 0 (CN1 pin 19) to ground (CN1 pin 11 or 29).
  - 3. Trim VR1 (post-gain offset) until the reading approach to zero.
  - 4. Trim **VR3** (pre-gain offset) until the reading approach to zero.
  - 5. Repeat step 3 and 4 until both post-gain offset and pre-gain offset are steadily zero.
  - 6. Connect +5V to AD channel 1 (pin 18).
  - 7. Adjust VR2 to obtain reading between 16383~16384.
- · PGA offset calibration (For PCI-9114A and PCI-9114 Rev. C2 or later)
  - 1. Set AD input signal type to single-ended (default) input.
  - 2. Adjust JP2 to set AD channel #16 to be grounded (D.I. mode, Refer to section 2.7.2.) and program the card to use AD ch#16.
  - 3. Use multi-meter to measure the voltage between TP1 and TP2.
  - 4. Set Gain (AD range) register to maximum gain (gain = 8 for PCI-9114(A) DG; gain = 1000 for PCI-9114(A) HG).
  - 5. Adjust **VR3** until the multi-meter value approach to zero.
  - 6. Set Gain (AD range) register to minimum gain (gain = 1).

- 7. Adjust **VR5** until the multi-meter value approach to zero.
- Repeat Step 4~7 until the multi-meter value approach to zero even after the Gain changed.

#### · A/D offset calibration (For PCI-9114A and PCI-9114 Rev. C2 or later)

- 1. Set AD input signal type to single-ended (default) input.
- 2. Adjust JP2 to set AD channel #16 to be grounded (D.I. mode, Refer to section 2.7.2.) and program the card to use AD ch#16.
- 3. Set Gain (AD range) register to minimum gain (gain = 1).
- 4. Adjust **VR1** to obtain reading between -1~+1.

#### · A/D full range calibration

- 1. Set AD input signal type to single-ended (default) input.
- 2. Use multi-meter to calibrate the reference voltage on user's external voltage to +10V.
- 3. Connect the reference voltage to AD channel #0, and program the card to use AD ch#0.
- 4. Set Gain (AD range) register to minimum gain (gain = 1).
- 5. Adjust VR2 to obtain reading between 32766~32767.

#### · Cold junction sensor calibration

- Set to use the C.J. sensor under S.E. input mode. (Refer to section 2.7.2), and program the card to use AD ch#0.
- 2. Set Gain (AD range) register to minimum gain (gain = 1).
- 3. Measure the current temperature.
- 4. Adjust the *VR4* until the read-out value equal to the temperature value.
- 5. The relation between temperature and the read-out value is as followed:

$$V (mV) = T (^{\circ}K) \times 10 (mV / ^{\circ}K)$$
  
 $T (^{\circ}K) = V (mV) / 10 (mV / ^{\circ}K)$   
 $T (^{\circ}C) = T (^{\circ}K) - 273 (^{\circ}K)$ 

#### For example:

If the temperature is  $25^{\circ}$ C, user should calibrate the C.J. voltage to (25+273) x 10 = 2980 mV = 2.98 V

#### 6.1.4 Software A/D Offset Calibration

For more accuracy calibrates the input offset signal, using software to calibrate the offset of the analog input signal is a good approach. Another benefit is this method can calibrate offset online and thus eliminate any temperature drift. For example, user can adjust JP2 to set AD channel #16 to be grounded (D.I. mode, Refer to section 2.7.2.). Measuring the digital value of channel #16 can obtain the offset voltage of the AD channels. If the digital offset value is  $V_{\rm off}$ , user can modify any AD data by subtracting  $V_{\rm off}$  from the AD data to obtain the offset calibrated value. Note that the  $V_{\rm off}$  may be different for each gain level. Users should calibrate the offset value for every gain value.

## 6.2 Utility

#### 6.2.1 9114util (For PCI-9114 Rev. B2 Only)

There are three functions provided by 9114util. They are System Configuration, Calibration, and Functional Testing. This utility software is designed as menu-driven based windowing style. 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 9114util.exe

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

C> cd \ADLINK\9114\DOS\Util

C> 9114UTIL

The following diagram will be displayed on you screen. The message at the bottom of each window guidesyou how to select item, go to the next step and change the default settings.

```
***** PCI-9114 Utility Rev. 2.1 *****
```

Copyright © 2000-2004, ADLINK Technology Inc. All rights reserved.

```
<F1> : Configuration.
```

<F2> : Calibration.

<F3> : Function testing.

<Esc>: Quit.

>>> Select function key F1,F2,F3, or press <Esc> to quit. <<<

#### · System Configuration

This function guides you to configure the PCI-9114 card, and set the right hardware configuration. The configuration window shows the setting items that you have to set before using the PCI-9114 card.

The following diagram will be displayed on the screen as you choose the Configuration function from main menu.

```
***** Configuration of PCI-9114 *****
```

```
<1> Card Type PCI9114HG
```

<2> AD Polarity setting Bipolar

```
>>> <Up/Down>: Select Item, <PgUp/PgDn>: Change Setting <<<
```

#### · Calibration

This function guides you to calibrate the PCI-9114. The calibration program serves as a useful test of the PCI-9114's A/D functions and can aid in troubleshooting if problems arise.

**Note:** For an environment with frequently large changes of temperature and vibration, a 3 months re-calibration interval is recommended. For laboratory conditions, 6 months to 1 year is acceptable

When you choose the calibration function from the main menu list, a calibration items menu is displayed on the screen. After you select one of the calibration items from the calibration items menu, a calibration window shows. The upper window shows the detailed procedures which have to be followed when you proceed the calibration. The instructions will guide you to calibrate each item step by step. In addition, the proper Variable Resister (VR) will blink to indicate the related VR which needs to be adjusted for the current calibration step.

```
***** PCI-9114 Calibration *****
```

```
<1> PGA Offset adjustment

<2> A/D Bipolar adjustment

<3> Cold junction sensor calibration

<Esc> Quit
```

Select 1 to 3 or <Esc> to quit calibration.

#### · Functional Testing

This function is used to test the functions of PCI-9114. It includes Digital I/O testing, D/A testing, A/D polling testing, A/D Interrupt Testing, and A/D FIFO Half-Full Interrupt testing.

When you choose one of the testing functions from the function menu, a diagram is displayed on the screen. The figures below are the function testing menu window.

```
***** PCI-9114 Function Testing *****
```

```
<1> : A/D with Polling Test

<2> : A/D with Interrupt Test

<3> : A/D with FIFO Half-Full Interrupt

<4> : DI/DO Test

<Esc>: Quit
```

Select 1 to 4 or (Esc) to quit function testing

#### 6.2.2 9114AUtl (For PCI-9114A and PCI-9114 Rev. C2 or later)

There are three functions provided by 9114AUtl. They are System Configuration, Calibration, and Functional Testing. This utility software is designed as menu-driven based windowing style. 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 9114util.exe

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

C> cd \ADLINK\9114\DOS\Util

C> 9114AUTL

The following diagram will be displayed on you screen. The message at the bottom of each window guides you how to select item, go to the next step and change the default settings.

```
***** PCI-9114(A) Utility Rev. 2.0 *****
```

Copyright © 2001-2003, ADLink Technology Inc. All rights reserved.

```
<F1> : Configuration.
<F2> : Calibration.
<F3> : Function testing.
<Esc>: Quit.
```

>>> Select function key F1,F2,F3, or press <Esc> to quit. <<<

### · System Configuration

This function guides you to configure the PCI-9114(A) card, and set the right hardware configuration. The configuration window shows the setting items that you have to set before using the PCI-9114(A) card.

The following diagram will be displayed on the screen as you choose the Configuration function from main menu.

```
***** Configuration of PCI-9114(A) *****
```

```
<1> Card Type PCI9114(A) HG
```

<2> AD Polarity setting Bipolar

```
>>> <Up/Down>: Select Item, <PqUp/PqDn>: Change Setting <<<
```

#### · Calibration

This function guides you to calibrate the PCI-9114(A). The calibration program serves as a useful test of the PCI-9114(A)'s A/D functions and can aid in troubleshooting if problems arise.

**Note:** For an environment with frequently large changes of temperature and vibration, a 3 months re-calibration interval is recommended. For laboratory conditions, 6 months to 1 year is acceptable

When you choose the calibration function from the main menu list, a calibration items menu is displayed on the screen. After you select one of the calibration items from the calibration items menu, a calibration window shows. The upper window shows the detailed procedures which have to be followed when you proceed the calibration. The instructions will guide you to calibrate each item step by step. In addition, the proper Variable Resister (VR) will blink to indicate the related VR which needs to be adjusted for the current calibration step.

```
***** PCI-9114(A) Calibration *****
```

```
<1> PGA Offset adjustment
<2> A/D Bipolar adjustment
<3> Cold junction sensor calibration
<Esc> Quit
```

Select 1 to 3 or <Esc> to quit calibration.

#### · Functional Testing

This function is used to test the functions of PCI-9114(A). It includes Digital I/O testing, D/A testing, A/D polling testing, A/D Interrupt Testing, and A/D FIFO Half-Full Interrupt testing.

When you choose one of the testing functions from the function menu, a diagram is displayed on the screen. The figures below are the function testing menu window.

```
***** PCI-9114(A) Function Testing *****
```

```
<1> : A/D with Polling Test

<2> : A/D with Interrupt Test

<3> : A/D with FIFO Half-Full Interrupt

<4> : DI/DO Test

<Esc>: Quit
```

Select 1 to 4 or (Esc) to quit function testing

#### 6.2.3 | EEPROM

This file is used to enable or disable the interrupt of PCI-9114(A) board. This software is a text-driven program. Because the default interrupt on PCI-9114(A) board is "on", users who don't want to use interrupt function can use this utility to turn off the interrupt of their PCI-9114(A) board. If the interrupt is disabled, then BIOS will not assign any IRQ resource to PCI-9114(A). This may solve some compatibility problem due to the ISA cards' IRQ is not sharing.

#### · Running I\_eeprom.exe

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

C> cd \ADLINK\ 9114\DOS\UTIL

C> I\_eeprom

At first, this program prompts you to input the card type—9114. After specifying the card type, this program shows the instructions to guide you to enable or disable the interrupt of your PCI-9114(A) board.

# Appendix A. 8254 Programmable Interval Timer

## A.1 The 8254 Timer / Counter Chip

The Intel (NEC) 8254 contains three independent, programmable, multi-mode 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 common 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

## A.2 The Control Byte

The 8254 occupies 4 I/O address locations in the PCI-9113A I/O map. As shown in the following table:

| Base + 20 | LSB OR MSB OF COUNTER 0 |
|-----------|-------------------------|
| Base + 22 | LSB OR MSB OF COUNTER 1 |
| Base + 24 | LSB OR MSB OF COUNTER 2 |
| Base + 26 | CONTROL BYTE            |

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

## **Control Byte:**

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

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

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

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

| TET a res coloct read potation (Bit o a Bit 1) |     |                               |  |
|------------------------------------------------|-----|-------------------------------|--|
| RL1                                            | RL0 | OPERATION                     |  |
| 0                                              | 0   | COUNTER LATCH                 |  |
| 0                                              | 1   | READ/LOAD LSB                 |  |
| 1                                              | 0   | READ/LOAD MSB                 |  |
| 1                                              | 1   | READ/LOAD LSB FIRST, THEN MSB |  |

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

| IVIZ, IVIT CETVICE C | cicci Operating | Wode (Dit 5, Dit | 2, a Dit 1) |
|----------------------|-----------------|------------------|-------------|
| M2                   | M1              | M0               | 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                          |
|      | 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").

# Appendix B.Signal Wiring Diagram

## **Analog Input**



## (Channel 0 for CJC)

## **Digital Input**



## **Digital Output**





## 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.