

## **COUNTER TIMER CARD**

# **CTR-05**

# **USER MANUAL**

file: MCTR-05.B3c

## NOTICES

The information in this document is provided for reference only. ACCES I/O PRODUCTS INC does not assume any liability arising out of the application or use of the information or products described herein. This document may contain or reference information and products protected by copyrights or patents and does not convey any license under the patent rights of ACCES, nor the rights of others.

IBM PC, PC/XT, and PC/AT are registered trademarks of the International Business Machines Corporation.

Printed in USA. Copyright 1993 by ACCES I/O PRODUCTS INC, 16023 Roselle Street, San Diego, CA 92121. All rights reserved.

## TABLE OF CONTENTS

| INSTALLATION<br>CD INSTALLATION<br>3.5-INCH DISKETTE INSTALLATION<br>DIRECTORIES CREATED ON THE HARD DISK<br>INSTALLING THE CARD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 1-1<br>1-1<br>1-2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FUNCTIONAL DESCRIPTION<br>COUNTERS<br>CRYSTAL TIMEBASE<br>DIGITAL I/O<br>INTERRUPTS<br>SOFTWARE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 2-1<br>2-1<br>2-2<br>2-2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| BLOCK DIAGRAM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| OPTION SELECTION<br>CRYSTAL TIMEBASE<br>SYNCHRONIZATION<br>READ/WRITE PULSE WIDTH<br>INTERRUPTS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 4-1<br>4-1<br>4-1<br>4-1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| OPTION SELECTION MAP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 4-2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| SOFTWARE<br>INTRODUCTION<br>LOADING THE CALL ROUTINE<br>CALL STATEMENT FORMAT<br>TASK SUMMARY<br>TASK 0 INITIALIZE & SET MASTER MODE REGISTER<br>TASK 1 SET A COUNTER MODE REGISTER<br>TASK 2 MULTIPLE COUNTER CONTROL COMMANDS<br>TASK 3 LOAD COUNTER LOAD REGISTER<br>TASK 4 READ SELECTED COUNTER HOLD REGISTER<br>TASK 5 READ THE DIGITAL INPUT PORT<br>TASK 6 WRITE TO DIGITAL OUTPUT PORT<br>TASK 6 WRITE TO DIGITAL OUTPUT PORT<br>TASK 7 LATCH COUNTERS AND SAVE ON INTERRUPT<br>TASK 8 RETURN STATUS OF INTERRUPTS<br>TASK 9 TRANSFER DATA DURING/AFTER INTERRUPT<br>TASK 10 MEASURE FREQUENCY<br>SUMMARY OF ERROR CODES | 5-1<br>5-2<br>5-3<br>5-5<br>5-5<br>5-5<br>5-6<br>5-5<br>5-5<br>5-6<br>5-9<br>5-102<br>5-123<br>5-102<br>5-123<br>5-102<br>5-123<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102<br>5-102 |
| PROGRAMMING<br>I/O ADDRESSES<br>BYTE-ORIENTED OPERATION<br>9513 REGISTER FUNCTIONS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 6-1<br>6-1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

| COMMAND REGISTER              |
|-------------------------------|
| CALIBRATION                   |
| CONNECTOR PIN ASSIGNMENTS 8-1 |
| SPECIFICATION                 |
|                               |
| WARRANTY 10-1                 |
| LSI TYPE 9513 DATA SHEET A-1  |

#### INSTALLING THE CARD

Before installing the card, carefully read the Address Selection section of this manual and configure the card according to your requirements. Use the special software program called SETUP provided with the card. It supplies visual aids to configure all areas of the card.

Be especially careful with address selection. If the addresses of two installed functions overlap, you'll experience unpredictable computer behavior. If unsure what locations are available, you can use the FINDBASE program provided on our CD to locate blocks of available addresses.

To install the card:

- 1. Remove power from the computer.
- 2. Remove the computer cover.
- 3. Remove the blank I/O backplate.

4. Install jumpers and set switches for the selected options. See Option Selection section of this manual.

5. Select the base address on the card. See Address Selection section of this manual.

6. Install the card in the selected I/O expansion slot.

7. Inspect for proper fit of the card and cables and tighten screws. *Make sure that the card mounting bracket is properly screwed into place and that there is a positive chassis ground.* 

8. Replace the computer cover.

## FUNCTIONAL DESCRIPTION

CTR-05 is a half-size card that contains five general-purpose 16-bit counters, a crystal-controlled timebase with dividers, and two 8-bit parallel digital I/O ports. CTR-05 plugs into IBM PC/XT/AT and compatible computers.

#### COUNTERS

The counters can be programmed to count up or count down in either binary or BCD. A selection of various internal frequency sources and outputs may be chosen as inputs for individual counters with software selectable active-high or active-low polarities. Each counter may be gated by either software or hardware. The CTR-05 card includes flip-flops to synchronize gate and clock inputs and improve timing and counting accuracy. As described in the Option Selection section of this manual, you can place jumpers to select either the synchronized mode or the non-synchronized mode for each counter. Moreover, a second jumper associated with each counter selects either leading edge or falling edge synchronization.

Also, CTR-05 contains a means to assure that Read and Write pulses from the computer are at least 400 nanoseconds in duration. This feature is activated when a jumper is placed across two programming pins labeled WAIT. While normally not required, this feature is useful for computers with bus speeds above 6-8 MHz.

Each counter has associated with it a Load Register and a Hold Register. Load Registers are used to automatically reload the counter to any predefined value, thus controlling the effective count period. Hold Registers are used to save count values without disturbing the count process. This permits the processor to read intermediate counts. The Hold Register may also be used as a second Load Register.

Counters 1 and 2 have additional alarm registers and comparators associated with them plus logic for operations in a 24-hour time-of-day mode. The time-of-day logic will accept 50 Hz, 60 Hz, and 100 Hz input frequencies.

Each counter has a single dedicated output pin. It may be configured in such a way as to be turned off when the output is not of interest. Considerable versatility for configuring both the input and the gating of individual counters is provided. This not only permits dynamic re-assignment of inputs under software control but also allows multiple counters to use a single input and allows a single gate input to control more than one counter.

#### CRYSTAL TIMEBASE

An 8-MHz crystal oscillator is provided on the card. Also, a three-stage divider provides means for jumper selection of 4, 2, and 1 MHz clock inputs for the counters.

#### DIGITAL I/O

The CTR-05 also contains an 8-bit, latched, parallel digital, TTL input port and an 8-bit, latched, parallel digital, TTL output port. The input port is comprised of transparent D-type latches meaning that when an Enable control input is high, outputs will follow the inputs. When the Enable input is taken low, outputs will be latched at the data levels that were set up. The output port features three-state outputs designed specifically for driving capacitive or low-impedance loads. Outputs can sink up to 24 mA and can drive 15 standard TTL loads or 60 low-power schottky TTL loads.

#### INTERRUPTS

Interrupts from counter outputs or external sources are supported. An output from a PAL is connected to any one of interrupt levels IRQ2 through IRQ7 are user-selected by jumper installation on the card. If an Interrupt Enable input at I/O connector pin 2 is held high, the interrupt function is disabled. Conversely, if the Interrupt Enable input is held low, a positive edge on the Interrupt Input, pin 1, will generate an interrupt on the selected level. It is the user's responsibility to set up and enable the 8259 controller in the computer, the interrupt vectors, and an interrupt service routine.

Typically, counter outputs can be jumpered to the Interrupt Input and the Interrupt Enable can be controlled by one of the digital output bits. This would allow periodic interrupts. Alternatively, the Interrupt Input can be used for other purposes such as transferring data into and out of the computer, etc.

#### SOFTWARE

Utility software provided with the CTR-05 card includes an illustrated setup program, drivers, and sample programs. The driver is provided in three forms; a BASIC loadable file, a C language linkable file, and a QuickBASIC and Pascal linkable file.

In addition, two sample programs are included in C, Pascal, and QuickBASIC. One of these programs sets up all five counters to count down from different levels, then latches and reads their contents at a given interval using interrupts. The other program measures frequency.

Finally, a VisualBASIC utility driver is included. That driver includes PEEK and POKE statements for reading and writing RAM as well as INPORT and OUTPORT for reading and writing port I/O. The driver is in the form of a DLL and allows you to access hardware as if the language was designed for it when you use VisualBASIC for Windows.

## **BLOCK DIAGRAM**

## ADDRESS SELECTION

The CTR-05 card requires four consecutive address locations in I/O space. The base address can be selected anywhere within the I/O range 100-3FF hex (except 1F0 through 1F8) for AT's and 200 through 3FF for XT's provided that it does not overlap with other functions. If in doubt refer to the following tables and the FINDBASE program to find an available address.

#### STANDARD ADDRESS ASSIGNMENTS FOR 286/386/486 COMPUTERS

| Hex Range | Usage                               |  |  |  |  |
|-----------|-------------------------------------|--|--|--|--|
| 000-01F   | DMA Controller 1                    |  |  |  |  |
| 020-03F   | INT Controller 1, Master            |  |  |  |  |
| 040-05F   | Timer                               |  |  |  |  |
| 060-06F   | 8042 (Keyboard)                     |  |  |  |  |
| 070-07F   | Real Time Clock, NMI Mask           |  |  |  |  |
| 080-09F   | DMA Page Register                   |  |  |  |  |
| 0A0-0BF   | INT Controller 2                    |  |  |  |  |
| 0C0-0DF   | DMA Controller 2                    |  |  |  |  |
| 0F0       | Clear Math Coprocessor Busy         |  |  |  |  |
| 0F1       | Reset Coprocessor                   |  |  |  |  |
| 0F8-0FF   | Arithmetic Processor                |  |  |  |  |
| 1F0-1F8   | Fixed Disk                          |  |  |  |  |
| 200-207   | Game I/O                            |  |  |  |  |
| 278-27F   | Parallel Printer Port 2             |  |  |  |  |
| 2F8-2FF   | Asynchronous Comm'n (Secondary)     |  |  |  |  |
| 300-31F   | Prototype Card                      |  |  |  |  |
| 360-36F   | Reserved                            |  |  |  |  |
| 378-37F   | Parallel Printer Port 1             |  |  |  |  |
| 380-38F   | SDLC or Binary Synchronous Comm'n 2 |  |  |  |  |
| 3A0-3AF   | Binary Synchronous Comm'n 1         |  |  |  |  |
| 3B0-3BF   | Monochrome Display/Printer          |  |  |  |  |
| 3C0-3CE   | Local Area Network                  |  |  |  |  |
| 3D0-3DF   | Color/Graphic Monitor               |  |  |  |  |
| 3F0-3F7   | Floppy Diskette Controller          |  |  |  |  |
| 3F8-3FF   | Asynchronous Comm'n (Primary)       |  |  |  |  |

The illustrated setup program provided with CTR-05 provides an easy method to set Base Address. The following discussion is presented to help you understand how that program operates.

The CTR-05 base address is set by a DIP switch. The DIP switch controls address bits A2 through A9. (Lines A1, and A0 are used on the card to select individual registers.)

To determine how to set the DIP switches for a desired hex-code address, first convert the hex address number to binary form. Then, *for each "0", set the corresponding switch to ON and for each "1", set the corresponding switch to OFF.* 

The following example illustrates switch selection corresponding to hex 300 (or binary 11 0000 00xx). The "xx" represents address lines A1, and A0 used on the card to select individual registers. See Programming section of this manual.

| Base Address in Hex Code |     | 3   | 0  |    |    |    | 0  |    |
|--------------------------|-----|-----|----|----|----|----|----|----|
| Conversion Factors       | 2   | 1   | 8  | 4  | 2  | 1  | 8  | 4  |
| Binary Representation    | 1   | 1   | 0  | 0  | 0  | 0  | 0  | 0  |
| Switch Legend            | A9  | A8  | A7 | A6 | A5 | A4 | A3 | A2 |
| Address Line Controlled  | A9  | A8  | A7 | A6 | A5 | A4 | A3 | A2 |
| Address Switch Setup     | OFF | OFF | ON | ON | ON | ON | ON | ON |

Carefully review the address selection reference table on the preceding page before selecting the card address. If the addresses of two installed functions overlap, you will experience unpredictable computer behavior.

## **OPTION SELECTION**

There are four selectable options on CTR-05; (a) crystal controlled time base frequency, (b) synchronized or non-synchronized gate and clock inputs, (c) activation of circuitry which assures that Read and Write pulses are at least 400 nanoseconds long, and (d) interrupt level to assert. Options are selected by placing jumpers on the card. In the text that follows, jumper identification is given in capitol letters and is identical to what is silkscreened on the board.

#### CRYSTAL TIMEBASE

You can select 1, 2, or 4 MHz output by placing a jumper at one of the three CLK SEL jumper positions 1, 2, or 4 located in the upper left quadrant of the card. Note that a jumper <u>must</u> be placed in one of those three positions for the on-board clock to operate.

#### SYNCHRONIZATION

If the gate inputs are synchronized with the counter inputs, improved timing and counting accuracy is achieved; particularly at higher frequencies. Flip-Flops on CTR-05 provide synchronization when jumper selected. Five jumper locations labeled GATE-1 through GATE-5 control each of the five counters and pins at those locations are labeleled S (Synchronized) and N (Non-Synchronized. Moreover, a second jumper associated with each counter selects either leading-edge or falling-edge synchronization. These jumper locations are labeled SYNC-1 through SYNC-5 and pins at each of these locations are labeled + (Leading edge) and - (Falling edge).

#### **READ/WRITE PULSE WIDTH**

In computers that have I/O bus speeds above 6-8 MHz, Read and Write pulse width can be very narrow. A means to insure that Read and Write pulses from the host computer are at least 400 nanoseconds is provided when a jumper is installed between the pins labeled WAIT.

#### INTERRUPTS

Interrupt commands are supported if the Interrupt Enable input at I/O connector pin 2 is held high. Interrupt levels 2 through 7 are available. You can select the desired level by installing a jumper in one of the locations marked IRQ2 through IRQ7.

## **OPTION SELECTION MAP**

## SOFTWARE

#### INTRODUCTION

Software provided with CTR-05, in addition to the FINDBASE and SETUP programs previously mentioned, includes a C-linkable driver and samples, a Pascal-linkable driver and samples, a BASIC driver in binary form, a QuickBASIC-linkable driver and samples, and a VisualBASIC utility driver.

When using Assembly and most high level languages, the CTR-05 card can be programmed using INPUT and OUTPUT functions. However using these functions; (a) normally requires formatting data and dealing with absolute I/O addresses, (b) can require many lines of code, and (c) necessitates a detailed understanding of the type 9513 LSI chip used on CTR-05. Further, there are a number of mode registers and counter control combinations possible using that chip. To write initializing and control routines in BASIC can be time consuming and is error prone. To simplify application program generation a special I/O driver routine, CTR5DRV, is included on the CD provided with the CTR-05 card. This driver can be accessed in BASIC by a single line CALL statement:

#### 100 CALL CTR5DRV (TASK%, PARAM%(0), STATUS%)

This CALL routine provides ten tasks (TASK%) to select functions of the CTR-05, transfer data to and from BASIC variables (PARAM%(0)), check for errors (STATUS%), and perform complex operations such as measuring frequency or transferring counter contents to memory using periodic interrupts.

#### NOTE

# BASIC has no interrupt-processing functions and data acquisition using interrupts is only available by using the CALL routine

Due to the very large number of operating modes of the 9513, the CTR5DRV driver is a compromise between flexibility and simplicity. It performs the more common operations that the CTR-05 can be used for, but you may wish to resort to programming with INP and OUT statements for some of the less common applications.

#### LOADING THE CALL ROUTINE

When loading the CALL routine into memory, avoid loading it over any part of memory that is being used by another program; e.g. BASIC, print spoolers, RAM disk, etc. If another program's use of memory is interfered with, the CALL routine will not work and your computer may hang up.

#### CALL STATEMENT FORMAT

If you are new to using CALL statements, the following will assist you to understand how the CALL transfers execution to the machine language (binary) driver routine.

Prior to entering the CALL, the DEF SEG = SG statement sets the segment address at which the CALL subroutine is located. The CALL statement for CTR5DRV must be in the form:

xxxxx CALL CTR5DRV (TASK%, PARAM%(0), STATUS%)

CTR5DRV is the address offset from the current memory segment as defined in the last DEF SEG statement. In all of the examples here, we have chosen to define the current segment to correspond with the starting address of the CALL routine. Therefore, the offset is zero and CTR5DRV = 0.

The three variables within the brackets are known as the CALL parameters. When the CALL is executed, the addresses of the variables (pointers) are passed in the sequence written to BASIC's stack. The CALL routine starts off by unloading these pointers from the stack and uses them to locate the variables in BASIC's data space so that data can be exchanged with them. Several important format requirements must be met:

1. CALL parameters are positional. The subroutine knows nothing about the names of the variables, it only knows their location from the order of their pointers on the stack. you write:

xxxxx CALL CTR5DRV (PARAM%(0), TASK%, STATUS%)

you will mix up the CALL routine because it will interpret PARAM%(0) as the Task number, the TASK% as the data, etc. The parameters must always be written in the order (task, data, errors).

2. The CALL routine expects parameters to be integer type variables and reads and writes accordingly. If you slip up and use a non-integer variable (real single or double precision) in the CALL parameters, the routine will not function correctly. Also, the data variable PARAM% should always be declared as a ten-element array; i.e., (DIM PARAM%(9).

3. You cannot perform any arithmetic functions within the parameter list brackets of the following CALL statement is illegal and will produce a syntax error:

CALL CTR5DRV (TASK% + 2, PARAM%(0) + 8, STATUS%)

4. You cannot use constants for any of the parameters in the CALL statement. For example, the following is illegal:

#### CALL CTR5DRV (7, 2, STATUS%)

That must be programmed as:

xxx10 TASK% = 7 xxx20 PARAM%(0) = 2 xxx30 CALL CTR5DRV (TASK%, PARAM%(0), STATUS%)

Apart from these restrictions, you can name the variables whatever you want, the names are just convenient mnemonics. However, you should declare the variables before executing the call. If you do not, the simple variables will be declared by default on execution. But, an array variable cannot be dimensioned by default and must be dimensioned before the CALL to pass data correctly if used as a CALL parameter.

Most tasks of the CALL routine require that data be passed in an array. In this case PARAM%(0) should be specified as the data variable so that the CALL routine can correctly locate the position of the array. It is OK to dimension arrays with more elements than will be used by the CALL, unused elements will be unchanged and, for example, could be used to tag data with time, date, or other information.

#### TASK SUMMARY

- TASK 0 .... Initialize, set master mode register and base I/O address
- TASK 1 .... Set a counter mode register
- TASK 2 .... Multiple counter control commands, arm, load, latch, etc
- TASK 3 .... Load a selected counter load register
- TASK 4 .... Read a selected counter hold register
- TASK 5 .... Read digital input port IP0-7
- TASK 6 .... Write digital output port OP0-7
- TASK 7 .... Latch counter(s) & store data on interrupt
- TASK 8 .... Return status of interrupts
- TASK 9 .... Unload interrupt data from memory and transfer to BASIC array variable
- TASK 10.... Measure frequency from any of nine inputs

The following paragraphs contain detailed information and examples of use of the CALL routine for all 11 tasks. The tasks are selected by the TASK% parameter in the CALL as follows:

#### TASK 0 INITIALIZE & SET MASTER MODE REGISTER

Task 0 checks that the base I/O address is in the legal range of 256-1020 (Hex 100-3FC) for the IBM PC. If not, an error exit will occur. If OK, the base I/O address is stored for use by other tasks on re-entry to the CALL.

Task 0 must be executed as an initializing step before any of the other tasks are selected. Selecting any other task before task 0 is entered will cause error code 1 because the driver will not be aware of the I/O location of the CTR-05.

After storing the base I/O address, the 9513 master mode register is loaded according to the content of PARAM% parameter in the CALL statement. Four default conditions are assumed:

1.) MM15=1: scaler set to BCD. Because a 1 MHz crystal is used, BCD scaling gives round-number sub-multiples:

F1 = 1 MHz F2 = 100 KHz F3 = 10 KHz F4 = 1 KHz F5 = 100 Hz

- 2.) MM14=1: data pointer automatic increment disabled. Automatic increment is not used by the CTR5DRV driver.
- 3.) MM13=0: eight bit data bus is required by the hardware.
- 4.) MM12=0: F<sub>out</sub> is permanently ON.

The remaining master mode register bits are controlled by the input variables.

Entrance data are as follows:

```
PARAM%(0) = Base I/O address (100H-3FCH)
PARAM\%(1) = F_{out} divider ratio (0-15)
              0 = /16
               n = /n
PARAM\%(2) = F_{out} source (0-15)
                     0 = F1
                     1 = Source 1
                     2 = Source 2
                     3 = Source 3
                     4 = Source 4
                     5 = Source 5
                     6 = \text{Gate 1}
                     7 = \text{Gate } 2
                     8 = \text{Gate } 3
                     9 = \text{Gate } 4
                    10 = \text{Gate } 5
                    11 = F1
                    12 = F2
                    13 = F3
                    14 = F4
                    15 = F5
```

PARAM%(3) = Compare 2 disable/enable (0/1) PARAM%(4) = Compare 1 disable/enable (0/1) PARAM%(5) = Time of day mode control (0-3)

Exit data:

PARAM%(0-9) - Unchanged

The following error codes apply to task 0:

```
STATUS% = 0(no error, OK)STATUS% = 2(task number out of range, <0 or >10)STATUS% = 3(base address out of range, <256 or >1020)STATUS% = 11 thru 19(PARAM%(1) thru PARAM%(9) out of range;<br/>e.g. if PARAM%(2) wrong, yields error #12)
```

Note that error #3 will occur if you have specified an I/O address is less than 256 (hex 100) or greater than 1020 (hex 3FC). I/O addresses below hex 100 are all used internally by PC computer resources and would always cause an address conflict with the CTR-05. Addresses above hex 3FF are not exclusively decoded by other peripherals on the computer.

#### TASK 1 SET A COUNTER MODE REGISTER

Task 1 is used to configure each individual counter by setting the associated mode register. Task 1 is usually used right after task 0. Entrance data are as follows:

> PARAM%(0) = Counter number (1-5) PARAM%(1) = Gating control (0-7)0 = No gating1 =Active high level TCN-1 2 = Active high level Gate N+1 3 = Active high level Gate N-1 4 = Active high level Gate N 5 =Active low level Gate N 6 = Active high edge Gate N 7 = Active low edge Gate N PARAM%(2) = Count edge positive/negative (0/1)PARAM%(3) = Count source selection 0 = TCN-11 =Source 12 =Source 23 =Source 34 =Source 4

6 = Gate 17 = Gate 28 = Gate 39 = Gate 410 = Gate 511 = F112 = F213 = F314 = F415 = F5PARAM%(4) = Disable/enable special gate (0/1)PARAM%(5) = Reload from load/reload from load or hold register (0/1) PARAM%(6) = Count once/count repetitively (0/1)PARAM%(7) = Binary count/BCD count (0/1)PARAM%(8) = Count down/count up (0/1)PARAM%(9) = Output control (0-5 except 3) 0 = inactive, output low 1 = active high terminal count pulse 2 = terminal count toggled 3 = illegal4 = Inactive, output high impedance 5 = active low terminal count pulse

Exit data:

PARAM%(0-9) - Unchanged

The following error codes apply to task 1:

STATUS% = 0(no error, OK)STATUS% = 1(base address unknown)STATUS% = 2(task number out of range, <0 or >10)STATUS% = 10 thru 19(PARAM%(0) thru PARAM%(9) out of range;<br/>e.g. if PARAM%(2) is wrong, gives error #12)

#### TASK 2 MULTIPLE COUNTER CONTROL COMMANDS

Task 2 allows you to perform operations such as loading, latching and saving, enabling, and disabling on individual or multiple counters simultaneously. Addressing of counters is performed by a linear select using PARAM%(1) through PARAM%(5) for counters 1-5. This is a powerful feature of the 9513. If you wish to operate on a counter, the corresponding PARAM% variable should be set to 1, otherwise it should be set to 0. The chosen command (1-6) is set by the value of PARAM%(n). Note the following:

1.) The terms ARM and DISARM are synonymous with enable and disable. A disarmed counter will not count or respond to clock and gate inputs.

2.)Each counter has a load and a hold register associated with it. To load a counter, use task 3 to load the load register for each counter. Data in the load register(s) can then be transferred into the counter(s) using commands 2 or 3 of this task. Likewise, the counter(s) contents can be transferred into the hold register(s) using commands 4 or 5 of this task. Note that this is a simultaneous transfer for all selected counters and, in the case of command 5, the counting process is not disturbed. Thus you can read any of the counters simultaneously "on the fly" and the contents of the hold register(s) can be read at leisure using task 4.

3.)Operations of unselected counters is not disturbed in any way by operations on selected counters.

Entrance data are as follows:

PARAM%(0) = Command (1-6) as follows:

- 1 = Arm selected counter
- 2 = Load source to counter
- 3 = Load and arm counter
- 4 = Disarm and save counter
- 5 = Latch counter to hold register
- 6 = Disarm counter
- PARAM%(1) = Select counter 1 (0/1)
- PARAM%(2) = Select counter 2 (0/1)
- PARAM%(3) = Select counter 3 (0/1)
- PARAM%(4) = Select counter 4 (0/1)
- PARAM%(5) = Select counter 5 (0/1)
- PARAM%(6-9) = Not used

Exit data:

PARAM%(0-9) - Unchanged

The following error codes apply to task 2:

| STATUS% = 0  | (no error, OK)                          |
|--------------|-----------------------------------------|
| STATUS% = 1  | (base address unknown)                  |
| STATUS% = 2  | (task number out of range, <0 or >10    |
| STATUS% = 10 | (command number out of range, <1 or >6) |
| STATUS% = 11 | (counter 1 select not 0 or 1)           |
| STATUS% = 12 | (counter 2 select not 0 or 1)           |
| STATUS% = 13 | (counter 3 select not 0 or 1)           |
| STATUS% = 14 | (counter 4 select not 0 or 1)           |
| STATUS% = 15 | (counter 5 select not 0 or 1)           |

#### TASK 3 LOAD COUNTER LOAD REGISTER

Task 3 is used to place data in any selected counter's load register. (Note that this does not physically load the counter until task 2 is used to perform a load and arm (enable) or load command. This transfers data from the load register into the counter. In this way, counters can be simultaneously loaded and started even though data are entered sequentially into each load register.)

Entrance data are as follows:

PARAM%(0) = Counter number (1-5) PARAM%(1) = Load data (-32768 to +32767)PARAM%(2-9) = Not used

Exit data:

PARAM%(0-9) - Unchanged

The following error codes apply to task 3:

| STATUS% = 0  | (no error, OK)                          |
|--------------|-----------------------------------------|
| STATUS% = 1  | (base address unknown)                  |
| STATUS% = 2  | (task number out of range, <0 or >10)   |
| STATUS% = 10 | (counter number out of range, <1 or >5) |

#### TASK 4 READ SELECTED COUNTER HOLD REGISTER

Task 4 is used to read a selected counter's hold register. Note that this task does not read the counter's content directly. Counter contents must be transferred to its associated hold register using task 2 before entering task 4 to read the counter contents indirectly. There is no direct method of reading a counter.

Entrance data are as follows:

PARAM%(0) = Counter number (1-5) PARAM%(1) = Data read variable, value does not matter PARAM%(2-9) = Not used

Exit data:

PARAM%(0) = Counter number (1-5) PARAM%(1) = Counter data (-32,768 to +32,767) PARAM%(2-9) = Unchanged

The following error codes apply to task 4:

STATUS% = 0(no error, OK)STATUS% = 1(base address unknown)STATUS% = 2(task number out of range, <0 or >10)

#### TASK 5 READ THE DIGITAL INPUT PORT

Task 5 allows you to read the state of the digital input port IP0-IP7. This port consists of a transparent latch and has a hardware strobe input on pin 21 at the rear connector. When the STROBE INPUT is high, data at the inputs may be read directly. When the STROBE INPUT is taken low, the data at IP0-IP7 are latched and reading the port yields the latched data regardless of the inputs. Eight-bit data (range 0-255) are returned in PARAM%(0).

The digital input port is entirely independent of the 9513 LSI counter. Task 5 is equivalent to a BASIC INP(BASE +2) instruction.

Entrance data are as follows:

PARAM%(0) = Data read variable, value does not matter PARAM%(1-9) = Not used

Exit data:

PARAM%(0) = Input port data (0-255)PARAM%(1-9) = Not used

The following error codes apply to task 5:

STATUS% = 0 (no error, OK) STATUS% = 1 (base address unknown) STATUS% = 2 (task number out of range, <0 or >10)

#### TASK 6 WRITE TO DIGITAL OUTPUT PORT

Task 6 allows you to write data to the 8-bit digital output port OP0-OP7. Data should be in the range 0 to 255 decimal which corresponds to eight binary bits. Task 6 performs an equivalent function to BASIC's OUT BASE+3. The output port is entirely independent of the 9513 LSI counter.

Entrance data are as follows:

PARAM%(0) = Output data, range 0-255 PARAM%(1-9) = Not used

Exit data:

PARAM%(0-9) - Unchanged

The following error codes apply to task 6:

| STATUS% = 0  | (no error, OK)                         |
|--------------|----------------------------------------|
| STATUS% = 1  | (base address unknown)                 |
| STATUS% = 2  | (task number out of range, <0 or >10)  |
| STATUS% = 10 | (output data out of range, <0 or >255) |

#### TASK 7 LATCH COUNTERS AND SAVE ON INTERRUPT

Task 7 is a complex task that transfers selected counter contents "on the fly" to buffer memory each time an interrupt occurs.

A typical application might drive the interrupt input from the F<sub>out</sub> pin or a counter in divide-by-N mode, so that interrupts are generated at a constant rate. Any combination of the remaining counters can be set up to transfer their contents on each interrupt to individual buffer areas outside BASIC's workspace. This is especially useful when you need to measure the change in frequency versus time and also accumulate the total count. On each interrupt the counters are simultaneously latched and data transferred to a selected segment. The next interrupt transfers the data to (memory address+2) so that a series of words are built up in memory that are a log of the counter contents versus time. Each counter is allocated an individual segment of memory that may be up to 64K bytes in length, sufficient for 32,767 interrupts. (A 16-bit counter uses two bytes to store its data.) The PARAM%(1) - PARAM%(5) variables control allocation of the buffer segment for each counter. The segments should be chosen outside BASIC's workspace to avoid writing over the program/stack area.

Before selecting task 7, you should decide which interrupt level you wish to assign to the CTR-05 and move the interrupt jumper to that level. The IBM PC and PC/XT provide eight levels of interrupt which operate through the 8259 Interrupt Controller. Level 0 has the highest priority and level 7 has the lowest priority. However, levels 0 and 1 are not available on the I/O bus connectors because level 0 is used internally by the timer for the TIME & DATE functions and level 1 is used to service the keyboard. Levels 2-7 are accessible on the bus and have been pre-assigned for use by expansion boards as follows:

- Level 2... Reserved (but not used) by the Color Graphics Adapter
- Level 3... Serial I/O (used if COM2 is installed)
- Level 4... Serial I/O (used if COM1 is installed)
- Level 5... Printer (may be used by LPT2 if installed)
- Level 6... Always in use by disk drives
- Level 7... Printer (may be used by LPT1 if installed)

In most systems, at least one or more of levels 2-5 will be available making these the best choices.

Task 7 initiates the following sequence of actions:

1. Loads interrupt vectors into memory for the level selected and stores any old vectors for subsequent automatic restitution at the end of interrupts.

2. Enables the interrupt handler routine.

3. Initializes the 8259 Interrupt Controller and enables the 8259 interrupt mask register for the level selected. Interrupts are generated by a low-to-high transition on the IN-TERRUPT INPUT (pin 1). This interrupt is enabled when the INTERRUPT ENABLE (pin 2) is held low.

4. Selects which counter(s) will be dumped on interrupt according to PARAM%(1) thru PARAM%(5) which control the dump segments in memory for each counter. If any of these variables is zero, dumping for that counter will be disabled.

5. Performs the number of interrupts (up to 32,767) set by PARAM%(0) and then disables further interrupts and restores old vectors.

Notes on the hardware operation under task 7:

i.)After setting interrupts running, exit takes place from task 7 as follows. Data collection continues as a background operation and can be monitored using task 8. Meanwhile, the foreground program can be analyzing/manipulating data as it is collected.

ii.) Due to the finite time that the interrupt handler takes to execute, it's not recommended that the interrupt rate exceed 4000 per second. As the rate increases, more and more processor time is used servicing interrupts and less is available for foreground tasks.

iii.) Latency, or the uncertainty of exactly when the interrupt is serviced, may cause small variations or jitter in the sampling intervals. Major contributors to this jitter are any other interrupts in the computer; especially the timer interrupt which occurs on level 0 eighteen times/second. If necessary, this interrupt can be suppressed by reading the 8259 mask register and disabling the timer interrupt. You can do this with the following BASIC code before entering task 7:

xxx00 IMR% = INP(&H21) xxx10 OUT &H21, (IMR% OR &H01)

Since the disk drives use the timer for run up, the timer should be re-enabled after interrupts by:

xxx20 OUT &H21,IMR%

Other interrupts can be avoided by not using the keyboard or COM ports during data collection. Suppressing interrupts will reduce latency to the variation of a few clock cycles.

Entrance data are as follows:

PARAM%(0) = Number of interrupts (1-32767) PARAM%(1) = Memory segment to dump data from counter 1 (0-65535) PARAM%(2) = Memory segment to dump data from counter 2 (0-65535) PARAM%(3) = Memory segment to dump data from counter 3 (0-65535) PARAM%(4) = Memory segment to dump data from counter 4 (0-65535) PARAM%(5) = Memory segment to dump data from counter 5 (0-65535) PARAM%(5) = Start on IPO disabled/enabled (0/1) PARAM%(7) = Interrupt level (2-7) PARAM%(8-9) = Not used, value does not matter

#### NOTE

If any of the dump segments is set to zero, then dumping of that counter's data is disabled. This provides means to select which counter(s) data will be stored on interrupt.

Exit data:

PARAM%(0-9) - Unchanged

The following error codes apply to task 7:

| STATUS% = 0  | (no error, OK)                        |
|--------------|---------------------------------------|
| STATUS% = 1  | (base address unknown)                |
| STATUS% = 2  | (task number out of range, <0 or >10) |
| STATUS% = 10 | (interrupt count out of range, <=0)   |

#### TASK 8 RETURN STATUS OF INTERRUPTS

Task 8 provides a means of determining the progress of an interrupt operation initiated by task 7. PARAM%(0) returns the status in terms of whether the interrupts are still active or finished and PARAM%(1) returns the current word count (number of interrupts).

Entrance data are as follows:

PARAM%(0-9) = Value irrelevant

Exit data:

PARAM%(0) = Interrupt active/finished (1/0)

PARAM%(1) = Current word count PARAM%(2-9) = Unchanged

The following error codes apply to task 8:

STATUS% = 0 (no error, OK) STATUS% = 1 (base address unknown) STATUS% = 2 (task number out of range, <0 or >10)

#### TASK 9 TRANSFER DATA DURING/AFTER INTERRUPT

Task 9 is a general purpose block transfer routine that will transfer any number of words from any position in any memory segment to a suitably dimensioned integer array in BASIC. Data may be transferred in small blocks, piece by piece, when it is not possible to dimension a large integer array (e.g. to hold 32767 words because of limitations in BASIC's workspace. Task 9 is a faster method than using BASIC's PEEK which could perform the same function. Task 9 is usually used to retrieve data after the interrupt task7 has placed data in memory.

Entrance data are as follows:

PARAM%(0) = Number of words to transfer (1-32767) PARAM%(1) = Starting word number (0-PARAM%(0) PARAM%(2) = Memory segment to transfer from PARAM%(3) = Starting integer array element address (offset) to transfer data to. PARAM%(4-9) = Not used, value does not matter

NOTE

The pointer to the starting element in each array is provided by BASIC's VARPTR function; e.g. PARAM%(3) = VARPTR(ARRAY%(N))

It is the programmer's responsibility to assure that integer data arrays are adequately dimensioned to receive the data. Overrunning the array may have strange effects and cause system crashes.

Exit data:

PARAM%(0-9) - Unchanged Data transferred to selected array

The following error codes apply to task 9:

STATUS% = 0 (no error, OK)

STATUS% = 1 (base address unknown) STATUS% = 2 (task number out of range, <0 or >10) STATUS% = 10 (number of words <=0) STATUS% = 11 (starting word number <0)

#### TASK 10 MEASURE FREQUENCY

Task 10 uses features of the 9513 LSI chip to measure frequency from any of nine external frequency inputs. The TTL compatible input signals are applied to any or all of Sources 1-5 or Gates 1-4.

The measurement method uses a pair of counters. Counter 4 is used in the toggled mode and establishes a timebase. Counter 5 is used to accumulate pulses. The input to counter 4 is internally gated to the F4 crystal-divider source. In the BCD mode (default), this is a 1 KHz signal. Counter 4 is loaded in the countdown mode with the gating interval such that the toggled output is alternately high for the gating interval and then low for the gating interval. The output of counter 4 (connector pin 32) is connected to the gate input of counter 5 (pin 12). The clock input of counter 5 can be any of the nine source or gate inputs. While the gate input is high, counter 5 accumulates input pulses. The state of counter 4's output and, hence, counter 5's gate is sensed in the routine by reading the 9513 status register through the control port.

A measurement is performed as follows:

- 1. Set the mode registers of counters 4 and 5.
- 2. Load and continuously run the timebase counter 4.

3. Wait for the timebase counter output to go from high to low by reading the status register.

4. Load counter 5 with zeroes. Counter 5 is in the count up mode and is now disabled because it's gate is low.

5. Wait for counter 5's gate to go high and then low again by reading the status register for counter 4's output. Counter 5 will now contain the count accumulated during the gating interval.

6. Read counter 5 and transfer the data to PARAM%(2).

7. Return.

Note the following features and limitations:

a.) The gate interval can be from 1mS to 32,767 Sec. as set by PARAM%(0).

b.) The accumulating counter has 16 bits resolution (65,535 counts). Select a gate interval appropriate for the input frequency range. For example, you wouldn't use a 1 mS gate with a 10KHz signal because that would only provide capability to accumulate ten counts. Similarly, you wouldn't use a 1 second gate with a 5 MHz signal (5,000,000 counts). In the event of an overflow, the counter will continue to count but there is no way to ascertain the number of times it overflows.

c.)Due to the measurement algorithm used, it can take up to three gate intervals to return a result. If you select a long gate interval (e.g., 10 seconds) your computer may appear to have hung up when it is simply waiting for the result.

d.)Nine separate frequency sources can be connected to the Gate and Source inputs of the CTR-05 at the same time. However, measurements are performed on one source at a time. In effect, the 9513 LSI chip is used to multiplex the input signals as well as to count them. The selected source is controlled by PARAM%(1). Counters 1 through 3 are unaffected by task 10 and can be used for other purposes.

e.)Counter 5's Gate input must be externally jumpered to counter 4's output. This is most easily accomplished by installing an external jumper between pins 12 and 32 of the I/O connector.

f.)Crystal oscillator precision is better than 0.01% after adjustment of the trimmer capacitor. (See Calibration section of this manual.) Without that adjustment, it will be within 0.1%. Also, the maximum frequency input with optimum 50% duty cycle is 7MHz.

g.)Note that the method described here is not the only way to measure frequency with this card. For example, to provide greater count capacity, you can modify this task to concatenate another counter for a total of 32 bits.

Entrance data are as follows:

PARAM%(0) = Gate interval in mSec (1-32767) PARAM%(1) = Selects input source (1-9) 1 = Source 1 2 = Source 2 3 = Source 2 3 = Source 3 4 = Source 4 5 = Source 5 6 = Gate 1 7 = Gate 2 8 = Gate 3 9 = Gate 4 PARAM%(2-9) = Not used, value does not matter

Exit data:

PARAM%(0-1) = Unchanged PARAM%(2) = Counts accumulated in gating interval PARAM%(3-9) = Unchanged

The following error codes apply to task 10:

STATUS% = 0 (no error, OK) STATUS% = 1 (base address unknown) STATUS% = 2 (task number out of range, <0 or >10) STATUS% = 10 (gate interval out of range, <1 or >32767) STATUS% = 11 (source input out of range, <0 or >9)

#### SUMMARY OF ERROR CODES

If, for any reason, the STATUS% variable is returned non-zero, then an error has occurred in input of data to the CALL routine. Checking for valid data occurs first in the routine and no action will be taken if an error condition exists. An immediate return will take place with the error specified in the STATUS% variable. The following is a list of error codes:

| <u>ERROR</u> | FAULT                                                                                                                                                                                                                                                                                                                |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1            | Base address unknown. Failure to initialize base address using task 0.                                                                                                                                                                                                                                               |
| 2            | Task number out of range. TASK% is specified as less than 0 or greater than 10.                                                                                                                                                                                                                                      |
| 3            | Base address out of range. Invalid base I/O address. Valid addresses must be in the range hex 100 to hex 3FC.                                                                                                                                                                                                        |
| 10-19        | These error codes apply to data parameters that are out of range for the particular mode selected. If, for example, PARAM%(4) was incorrect, then error code 14 would be generated. In general, error code (10+n) is generated when PARAM%(n) is wrong. See each task description for the specific error conditions. |

Error detection <u>after</u> the CALL routine is easily implemented as follows:

xxx10 CALL CTR5DRV(TASK%, PARAM%(0),STATUS%) xxx20 IF FLAG% <> 0 then gosub YYYY

YYYYY REM: Error handling subroutine zzzz RETURN

.

This is useful while debugging a new program or, with a suitable error handling subroutine, can be left permanently in place in the program.

#### PROGRAMMING IN OTHER LANGUAGES

The Driver is provided in three forms; (a) a BASIC loadable form called CTR5DRV.BIN, (b) a C language linkable file called CTR5DRVC.OBJ and (c) a QuickBASIC and Pascal linkable form called CTR5DRV.OBJ.

Either of the object drivers may be linked to an Assembly language program provided that the proper calling convention is used. If using the C driver, before each driver call, the parameters must be PUSH'ed on to the stack in reverse order; i.e., first STATUS, then PARAM, and then TASK. Upon return from the driver call, the stack must be POP'ed to remove the parameters. Three POP's must be done to clear the stack.

If using the Pascal driver, the parameters are PUSH'ed in normal order; i.e., first TASK, then PARAM, and then STATUS. No cleanup of the stack is required upon return from the driver call because the driver will POP the stack upon return.

## PROGRAMMING

#### **I/O ADDRESSES**

The CTR5 uses four consecutive addresses in I/O address space and available addresses are from hex 100 to hex 3FC. The base or starting address is selected by DIP switch as described in the Address Selection section of this manual and automatically falls on a 4-bit boundary. Each device of the CTR-05 has its own I/O location as follows:

| I/O ADDRESS | I                 | <u>FUNCTION</u>  |
|-------------|-------------------|------------------|
|             | Write             | Read             |
| Base +0     | 9513 data in      | 9513 data out    |
| +1          | 9513 command reg. | 9513 status reg. |
| +2          | -                 | IP0-7 dig. input |
| +3          | OP0-7 dig. out    | -                |

#### BYTE-ORIENTED OPERATION

If you are using an AT class computer, note that all ports are eight bits wide (one byte) and you should perform byte-oriented read/write operations rather than word (16 bits) operations. When performing consecutive byte transfers to the same I/O port on an AT, be sure to allow sufficient recovery time for the I/O circuits. The AT Technical Reference Manual recommends the following Assembly language code:

|       | OUT IO_ADDR,AL | 'write low byte  |
|-------|----------------|------------------|
|       | JMP NEXT       | 'delay           |
| NEXT: | MOV AL,AH      | 'fetch high byte |
|       | OUT IO_ADDR,AL | 'write high byte |

#### 9513 REGISTER FUNCTIONS

All data transfers to the 9513 LSI counter timer chip are performed through two I/O ports. The Data port at the base address is used for data transfer; i.e., loading and reading counters and counter mode registers. The port at (base address+1) is used for addressing, command, control, and status purposes. Since there are a number of internal registers in the 9513 LSI chip, an indirect system of accessing those registers is used via an internal data pointer register which, in turn, is reached through the command register. The command register also performs other functions such as loading and enabling the counters, latching counter contents, etc. (Appendix A of this manual contains a data sheet with detailed information on the 9513 LSI chip.) The various command register codes are as follows:

#### COMMAND REGISTER

| COMMAND CODE |           |           |           |           |           | FUNCTION  |           |                                     |
|--------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-------------------------------------|
| <u>C7</u>    | <u>C6</u> | <u>C5</u> | <u>C4</u> | <u>C3</u> | <u>C2</u> | <u>C1</u> | <u>C0</u> |                                     |
| 0            | 0         | 0         | E2        | E1        | G4        | G2        | G1        | Load Data Pointer Reg w/ E & G      |
| 0            | 0         | 1         | S5        | S4        | S3        | S2        | S1        | Arm Counting for Selected Ctrs      |
| 0            | 1         | 0         | S5        | S4        | S3        | S2        | S1        | Load Source into Spec'd Ctr         |
| 0            | 1         | 1         | S5        | S4        | S3        | S2        | S1        | Load and Arm Spec'd Ctrs            |
| 1            | 0         | 0         | S5        | S4        | S3        | S2        | S1        | Disarm & Save all Selected Ctrs     |
| 1            | 0         | 1         | S5        | S4        | S3        | S2        | S1        | Save Selected Ctrs in Hold Reg's    |
| 1            | 1         | 0         | S5        | S4        | S3        | S2        | S1        | Disarm all Selected Ctrs            |
| 1            | 1         | 1         | 0         | 0         | N4        | N2        | N1        | Clear Output Bit N (001<= N <= 101) |
| 1            | 1         | 1         | 0         | 1         | N4        | N2        | N1        | Set Output Bit N (001<= N <= 101    |
| 1            | 1         | 1         | 1         | 0         | N4        | N2        | N1        | Step Ctr N (001<= N <= 101)         |
| 1            | 1         | 1         | 0         | 0         | 0         | 0         | 0         | Enable Data Pnt'r Seq'g (clrMM14)   |
| 1            | 1         | 1         | 0         | 0         | 1         | 1         | 0         | Gate Fout (clr MM12)                |
| 1            | 1         | 1         | 0         | 0         | 1         | 1         | 1         | Enter 8-Bit Bus Mode (clr MM13)     |
| 1            | 1         | 1         | 0         | 1         | 0         | 0         | 0         | Disable Data Pnt'r Seq'g (set MM14) |
| 1            | 1         | 1         | 0         | 1         | 1         | 1         | 0         | Gate Fout Off (ste MM12)            |
| 1            | 1         | 1         | 0         | 1         | 1         | 1         | 1         | Enter 16-Bit Bus Mode (set MM13)    |
| 1            | 1         | 1         | 1         | 1         | 1         | 1         | 1         | Master Reset                        |

Note that there is the following logical structure to command codes:

- a. Codes beginning with 000 reference the data pointer register.
- b. Codes from 001 to 110 reference counter operations.
- c. Codes beginning with 111 and ending in 001 thru 101 perform single-bit counter functions.
- d. Codes beginning with 111 and ending in 000 or 110 thru 111 perform master control functions. (These functions can also be activated by writing to the master mode register.)

Those codes that reference counter operations use a linear select S5 thru S1. All counter(s) with the appropriate"S" bit are affected. This feature allows simultaneous loading, latching, enabling, etc of <u>any combination of counters.</u>

Command codes that commence with 000 select internal registers according to the "E" and "G" fields which set the internal data pointer register. The 9513 LSI chip has one master mode register that controls operation of all counters and the scaler. This register must be set in the initialization sequence of your program.

Also, each counter has its own mode, load, and hold registers. These registers are accessed through the data port at the CTR-05 base address after setting the internal data pointer register to the desired register. The data pointer register format is as follows:

#### DATA POINTER REGISTER

| <u>E2 E1</u><br>T                                 | G4 G2 G1<br>T<br>* | <u>BP</u><br>.)))Q | Byte Pointer          |
|---------------------------------------------------|--------------------|--------------------|-----------------------|
| *                                                 | *                  | 1 = l ea           | ast significant       |
| *                                                 | *                  | 0.                 | byte transferred next |
| *                                                 | *                  |                    |                       |
| *                                                 | *                  | 0 = Mo             | st significant        |
| *                                                 | *                  |                    | byte transferred next |
| *                                                 | *                  |                    |                       |
| R                                                 | .))))))))          | <b>ý</b>           | Group Pointer         |
| Element                                           | Pointer            |                    | 000 = Illegal         |
|                                                   |                    | 001 = 0            | Counter group 1       |
| Counter (                                         | •                  |                    | 010 = Counter group 2 |
| (at base a                                        | ,                  |                    | 011 = Counter group 3 |
|                                                   | ode register       |                    | 100 = Counter group 4 |
|                                                   | oad register       |                    | 101 = Counter group 5 |
|                                                   | old register       |                    | 110 = Illegal         |
|                                                   | old register       |                    | 111 = Control group   |
| (hold                                             | d cycle increment) |                    |                       |
| Control                                           |                    |                    |                       |
| Control C                                         | •                  |                    |                       |
| •                                                 | address+1)         |                    |                       |
| 00 = Alarm register 1<br>01 = Alarm register 2    |                    |                    |                       |
|                                                   |                    |                    |                       |
| 10 = Master mode register<br>11 = Status register |                    |                    |                       |
|                                                   | increment)         |                    |                       |
| UII)                                              | norementy          |                    |                       |

The data pointer consists of: (a) a 2-bit element pointer (E2 and E1), (b) a 3-bit group pointer (G4, G2, and G1), and (c) a 1-bit byte pointer. The element and group pointers select which internal register is to be accessible through the data port. The byte pointer bit indicates which byte of a 16-bit register is to be transferred on the next access through the data port. Whenever the data pointer is loaded, the byte pointer is set to 1 indicating that a least significant byte is expected next. With an 8-bit data bus as used on the CTR-05, the byte pointer toggles following each 8-bit data transfer (Master mode MM13=0). The byte pointer can be read as a bit in the status register but the element and group pointers cannot be read.

Random access to any internal location can be accomplished by loading the data pointer (through base address+1) and then reading or writing to the location through the data port (at base address) as appropriate. The counter registers are all 16 bit and after loading the pointer the data are transferred in low-byte/high-byte sequence. The following is an example of loading counter 3's load register using C:

OUTPORTB(BASE+1, 0x13) //write 000 10 011 to command register OUTPORTB(BASE,0) //low byte = 0 OUTPORTB(BASE, 0x80) //high byte = 128 //register loaded with 32,768

In many applications you will find a pattern of loading the counter mode register, load register and hold register in sequence or setting alarm register 1, alarm register 2, and the master mode register. The element pointers auto-increment on each two-byte data transfer if master mode bit 14 (MM14) = 0. This saves writing to the command register between items of data and, depending on your preference, is a feature that can reduce the amount of code that you write.

In general, most programs will consist of an initialization section to set the overall operation through the master mode register, then proceed to set each counter's operating configuration through their individual mode registers, and then load initial data into the counters through the load and hold registers. Following this initialization, the counters are usually enabled using the command register, possibly latched and read using the command and hold registers, etc or disabled, re-loaded and re-enabled, etc. Most of the programming work is in initialization. Subsequent reading and writing operations are much simpler.

(Continued on Next Page)

#### MASTER MODE REGISTER

The master mode register controls overall operation of the 9513 LSI chip and should be the first register initialized by your program. It is a 16-bit register and, in the following description, bit locations are listed as MM15 through MM0 corresponding to the most significant bit through the least significant bit. Bit functions in the master mode register are as follows:

| BIT POSIT               | ION FUNCTION                       | CODE                                                                                                                                                                                                                                                                                                                                         |
|-------------------------|------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MM15                    | Scaler control                     | 0 = Binary division<br>1 = BCD division                                                                                                                                                                                                                                                                                                      |
| MM14                    | Data pointer contro<br>1 = Disable |                                                                                                                                                                                                                                                                                                                                              |
| MM13                    | Data bus width                     | 0 = 8-bit data bus<br>1 = 16-bit data bus                                                                                                                                                                                                                                                                                                    |
| MM12                    | F <sub>out</sub> gate              | $0 = F_{out} ON$<br>1 = F <sub>out</sub> OFF                                                                                                                                                                                                                                                                                                 |
| MM11<br>through<br>MM8  | F <sub>out</sub> divider           | 0000 = Divide by 16<br>0001 = Divide by 1<br>0010 = Divide by 2<br>0011 = Divide by 3<br>0100 = Divide by 4<br>0101 = Divide by 5<br>0110 = Divide by 6<br>0111 = Divide by 7<br>1000 = Divide by 8<br>1001 = Divide by 9<br>1010 = Divide by 10<br>1011 = Divide by 11<br>1100 = Divide by 12<br>1101 = Divide by 13<br>1110 = Divide by 15 |
| MM7 I<br>through<br>MM4 | F <sub>out</sub> source            | 0000 = E1<br>0001 = Source 1<br>0010 = Source 2<br>0011 = Source 3<br>0100 = Source 4<br>0101 = Source 5<br>0110 = Gate 1<br>0111 = Gate 2<br>1000 = Gate 3                                                                                                                                                                                  |

(Continued on Next Page)

#### Master Mode Register (Continued)

|     |                  | 1001 = Gate 4<br>1010 = Gate 5<br>1011 = F1<br>1100 = F2<br>1101 = F3<br>1110 = F4 |
|-----|------------------|------------------------------------------------------------------------------------|
|     |                  | 1111 = F5:                                                                         |
| MM3 | Compare 2 enable | 0 = disabled                                                                       |
|     | -                | 1 = enabled                                                                        |
| MM2 | Compare 1 enable | 0 = disabled                                                                       |
|     |                  | 1 = enabled                                                                        |
| MM1 | Time of day mode | 00 = TOD disabled                                                                  |
| and | -                | 01 = TOD enabled/5 input                                                           |
| MMO |                  | 10 = TOD enabled/6 input                                                           |
|     |                  | 11 = TOD enabled/10 input                                                          |
|     |                  | T = TOD enabled/TO input                                                           |

**MM15** selects the counting configuration of four 4-bit frequency scaler counters. The scaler stages divide by either 10 or 16 according to whether MM15 is a "1" or a "0". The fundamental crystal frequency F1 (1 MHz) and each of the scaler outputs F2, F3, F4, and F5 can be routed to any of the counters and the  $F_{out}$  divider under software control. Thus, frequency scaler outputs are as follows:

| Frequency | BCD       | <u>Binary</u> |
|-----------|-----------|---------------|
| F1        | OSC       | OSC           |
| F2        | F1/10     | F1/16         |
| F3        | F1/100    | F1/256        |
| F4        | F1/1000   | F1/4096       |
| F5        | F1/10,000 | F1/65536      |

**MM14** controls the data pointer register to enable/disable automatic sequencing functions. When MM14 is a "1", contents of the data pointer register can only be changed via the command register. When MM14 is a "0", several types of automatic sequencing of the data pointer are available as described in the data sheet in Appendix A of this manual.

**MM13** controls a multiplexer at the 9513's data bus interface to configure for either 8-bit or 16-bit data bus. In the CTR-05, an 8-bit bus is used.

**MM12** provides software-controlled gating capability for the F<sub>out</sub> signal (I/O connector pin 30). MM12 can also be individually controlled via the command register.

**MM11 through MM8** specify how to divide the  $F_{out}$  source signal. This is a four-bit divider ahead of the  $F_{out}$  output and divides the  $F_{out}$  source by an integer value between 1 and 16. (Note: Don't confuse this with the oscillator scaler described previously.)

**MM7 through MM4** specify the source input for the  $F_{out}$  divider. Fifteen inputs are available for selection including the oscillator scaler outputs F1 through F5, any of the counter gate inputs G1 through G5, and any of the external source inputs S1 through S5. The sixteenth combination (all zeroes) assures that an active frequency is available at the  $F_{out}$  divider input following reset.

**MM3 and MM2** control comparators associated with counters 1 and 2. When a comparator is enabled, its output is substituted for the normal counter outputs on I/O connector pins 35 and 34 for counters 1 and 2 respectively. When a comparison occurs, the output will be true and will remain true until the count changes at which time it will go false.

The comparator will be active-high if the output control field (CM2 through CM0) of the counter mode register is 001 or 010 and will be active-low if that control field is 101.

A special case occurs when the time-of day option is revoked and both comparators are enabled. In this case, operation of comparator 2 will be conditioned by comparator 1. This provides means for 32-bit comparison.

**MM1 and MM0** set the optional time-of-day mode for counters 1 and 2. When both these bits are set to zero, the mode is disabled and these counters operate identically to the other counter. When either MM0 or MM1 are are set to "1", additional decoding and control logic is enabled on these counters such that the most significant byte of counter 2 represents hours, the less significant byte of counter 2 represents minutes, and the most significant byte of counter 1 represents seconds. The least significant byte of counter 1 becomes a scaler in this mode and can divide by 50, 60, or 100 for 50 Hz, 60 Hz, or 100 Hz input frequencies.

#### COUNTER MODE REGISTER

A counter mode register associated with each counter controls each counter's operation. The counter mode registers should be initialized after the master mode register. It is a 16-bit register and, in the following description, bit locations are designated CM15 through CM0 corresponding to the most significant bit through the least significant bit respectively. Bit functions are as follows:

| <b>BIT POSITION</b> | <b>FUNCTION</b> | <u>CODE</u>                    |
|---------------------|-----------------|--------------------------------|
| CM15                | Gating control  | 000 = No gating                |
| through             | -               | 001 = Active high IvI TCN-1    |
| CM13                |                 | 010 = Active high IvI Gate N+1 |
|                     |                 | 011 = Active high Ivl Gate N-1 |
|                     |                 | 100 = Active high IvI Gate N   |
|                     |                 | 101 = Active low IvI Gate N    |
|                     |                 | 110 = Active high edge Gate N  |
|                     |                 | 111 = Active low edge Gate N   |

| Counter Mode Register | (Continued) |
|-----------------------|-------------|
|-----------------------|-------------|

| CM12<br>through<br>CM8 | Count source<br>selection 1xxxx = 0 | 0xxxx = Count on rising edge $x0000 = Output of cntr (n-1)$ $x0001 = Source 1$ $x0010 = Source 2$ $x0011 = Source 3$ $x0100 = Source 4$ $x0101 = Source 5$ $x0110 = Gate 1$ $x0111 = Gate 2$ $x1000 = Gate 3$ $x1001 = Gate 4$ $x1010 = Gate 5$ $x1011 = F1$ $x1100 = F2$ $x1101 = F3$ $x1110 = F4$ $x1111 = F5$ |
|------------------------|-------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CM7<br>through<br>CM3  | Count control                       | 0xxxx = Disable special gate<br>1xxxx = Enable special gate<br>x0xxx = Reload from load<br>x1xxx = Reload from load/hold<br>xx0xx = Count once<br>xx1xx = Count repetitively<br>xxx0x = Binary count<br>xxx1x = BCD count<br>xxxx0 = Count down<br>xxxx1 = Count up                                              |
| CM2<br>through<br>CM0  | Output control                      | 000 = Inactive, output low<br>001 = Active high TC pulse<br>010 = TC toggled<br>011 = Illegal<br>100 = Inactive high impedance<br>101 = Active low TC pulse<br>110 = Illegal<br>111 = Illegal                                                                                                                    |

**CM15 through CM13** control how the Gate inputs affect the selected counter. The gate input can either be disabled or it can be enabled in a variety of ways. The counter can be gated to count from the output of the previous counter (TCN-1 = terminal count of counter)

-1). Alternatively a counter can be gated from it's own gate input (Gate N) or from adjacent gate inputs (Gate N+1 or Gate N-1). That latter configuration allows two or three counters to share the same gate control input provided the gate is level triggered. If only the counter's own gate input is used, it may be level triggered (active high or low) or edge triggered (positive or negative).

**CM12 through CM8** specify the clock input source for the counter. You can select whether to count on the positive or negative input edge and you can select any of the source inputs, gate inputs, or crystal scaler outputs or from the output of the next lower counter. Thus, you can connect several counters to the same source or a standard frequency input or, to provide greater resolution, you can cascade counters for 32, 48, 64, or 80 bits.. all under software control.

**CM7 through CM3** control counter operations. Note that each bit performs a specific function.

**CM2 through CM0** establish terminal-count output characteristics. (TC = terminal count)

#### DIGITAL INPUT/OUTPUT

The CTR-05 card also contains two independent eight-bit parallel digital I/O ports; one for inputs and one for outputs. These are independent of the 9513 LSI chip and may be used for any purpose.

The port at (base address+2) is the input port and uses an eight-bit transparent latch. While the Strobe line is high data passes through the latch. Data present when the strobe line is taken low is latched and held as long as the Strobe line is held low.

The port at (base address+3) is the output port. Each output can sink up to 24 mA and can drive 15 standard TTL loads or 60 low-power schottky TTL loads.

#### INTERRUPT INPUT

An output from a PAL is provided which can be connected to any of the bus interrupt levels 2 through 7 via an IRQ jumper. When the Interrupt Enable input at I/O connector pin 2 is held low, a positive edge at the Interrupt Input pin 1 will generate an interrupt on the selected level. It is your responsibility to set up and enable the 8259 interrupt controller in the computer, the interrupt vectors, and an interrupt service routine.

## CALIBRATION

A trimmer capacitor on the CTR-05 card can change the crystal oscillator frequency by +/-0.01%. If you are not using the internal frequency source in your application or if 0.1% accuracy is satisfactory for your application, then there is no need to adjust this frequency.

The internal crystal source can be readily adjusted to 0.001% but remember that it has a temperature coefficient of 1 PPM/°C and an aging characteristic of under 3 PPM/year.

To calibrate the crystal, connect an accurate frequency counter to  $F_{out}$  (pin 30) and digital common (pin 11). An extender card will be helpful in providing access to the CTR-05 card. After the computer is re-booted and performed a reset of the CTR-05, the output frequency will default to 62.500 KHz (1 MHz/16). Adjust the trimmer capacitor for a reading of 62.5000 KHz using a 10-second gate interval on the frequency counter.

That's a rather long gate interval so, if you prefer you can use a 1 second gate interval with an  $F_{out}$  of 1 MHz using the following procedure in C:

OUTPORTB(BASE + 1,23); (Note: BASE is the base address selected for the CTR-05) OUTPORTB(BASE,0); OUTPORTB(BASE,1);

After the third OUT, the frequency will change to 1 MHz and the adjustment can be performed to 1.000000 MHz.

## **CONNECTOR PIN ASSIGNMENTS**

Counter and digital I/O signals are connected to the CTR-05 card via a 37-pin D type connector that extends through the back of the computer case. The mating connector is an AMP 747304-1 or equivalent. Pin assignments are as follows:

| PIN                                                                                                                                              | NAME                                                                                                                                         | FUNCTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|--------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| $\begin{array}{c}1\\2\\3\\4\\5\\6\\7\\8\\9\\10\\11\\12\\13\\14\\15\\16\\17\\18\\9\\20\\21\\22\\23\\24\\25\\26\\27\\28\\9\\30\\31\\32\end{array}$ | NAME<br>OP7<br>OP6<br>OP5<br>OP4<br>OP3<br>OP2<br>OP1<br>OP0<br>GND<br>+5VDC<br>IP7<br>IP6<br>IP5<br>IP4<br>IP3<br>IP2<br>IP1<br>IP0<br>Fout | Interrupt Input<br>(Not) Interrupt Enable<br>Digital Output Bit 8<br>Digital Output Bit 7<br>Digital Output Bit 6<br>Digital Output Bit 5<br>Digital Output Bit 3<br>Digital Output Bit 2<br>Digital Output Bit 1<br>Digital Output Bit 1<br>Digital common<br>Counter 5 Gate<br>Counter 5 Input<br>Counter 4 Gate<br>Counter 4 Gate<br>Counter 3 Gate<br>Counter 3 Input<br>Counter 2 Gate<br>Counter 2 Input<br>+5 VDC Power from Computer<br>(Not) IP Strobe<br>Digital Input Bit 8<br>Digital Input Bit 7<br>Digital Input Bit 7<br>Digital Input Bit 5<br>Digital Input Bit 5<br>Digital Input Bit 3<br>Digital Input Bit 3<br>Digital Input Bit 1<br>Oscillator Output<br>Counter 4 Output |
| 32<br>33<br>34<br>35<br>36<br>37                                                                                                                 |                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

## SPECIFICATION

#### MODES

Software-Triggered Strobe w/No Hardware Gating Software-Triggered Strobe w/Level Gating Hardware-Triggered Strobe Rate Generator w/No Hardware Gating Rate Generator w/Level Gating Non-Retriggerable One-Shot Software-Triggered Delayed-Pulse One-Shot Software-Triggered Delayed-Pulse One-Shot w/ Hardware Gating Hardware-Triggered Delayed Pulse Strobe Variable Duty Cycle Rate Generator w/No Hardware Gating Variable Duty Cycle Rate Generator w/Level Gating Hardware-Triggered Delayed-Pulse One-Shot Software-Triggered Strobe w/Level Gating and Hardware Retriggering Software-Triggered Strobe w/Edge gating and Hardware Retriggering Rate Generator w/Synchronization (Event Counter with Auto-Read/Reset) Retriggerable One-Shot Frequency Shift Keying

#### INPUTS

| Voltage:        | One LSTTL I   | bad                     |
|-----------------|---------------|-------------------------|
| Logic High:     | 2.2 to 5.0 VD | С                       |
| Logic Low:      | -0.5 to 0.8 V | DC                      |
| Hysteresis (Sou | rce & Gate):  | 0.2V min., 0.3V typical |
| Switching Chara | acteristics:  | See Appendix A          |
| Maximum Input   | Frequency:    | 7 MHz                   |

#### OUTPUTS

| Counter Outputs:     | Can sink 3.2 mA and source 200 uA                           |
|----------------------|-------------------------------------------------------------|
| F <sub>out</sub> :   | Can sink 3.2 mA and source 200 uA.                          |
| Digital Output Port: | Can drive up to 15 standard TTL loads or 60 low-power LSTTL |
|                      | loads.                                                      |

#### ENVIRONMENTAL

| Operating Temperature Range: | 0 <sup>°</sup> to 50 <sup>°</sup> C. |
|------------------------------|--------------------------------------|
| Storage Temperature Range:   | -25° to +85° C.                      |
| Humidity:                    | 0 to 90% RH, non-condensing          |
| Power Required:              | +5 VDC at 400 mA typical             |

## WARRANTY

Prior to shipment, ACCES equipment is thoroughly inspected and tested to applicable specifications. However, should equipment failure occur, ACCES assures its customers that prompt service and support will be available. All equipment originally manufactured by ACCES which is found to be defective will be repaired or replaced subject to the following considerations.

#### TERMS AND CONDITIONS

If a unit is suspected of failure, contact ACCES' Customer Service department. Be prepared to give the unit model number, serial number, and a description of the failure symptom(s). We may suggest some simple tests to confirm the failure. We will assign a Return Material Authorization (RMA) number which must appear on the outer label of the return package. All units/components should be properly packed for handling and returned with freight prepaid to the ACCES designated Service Center, and will be returned to the customer's/user's site freight prepaid and invoiced.

#### COVERAGE

First Three Years: Returned unit/part will be repaired and/or replaced at ACCES option with no charge for labor or parts not excluded by warranty. Warranty commences with equipment shipment.

Following Years: Throughout your equipment's lifetime, ACCES stands ready to provide on-site or in-plant service at reasonable rates similar to those of other manufacturers in the industry.

#### EQUIPMENT NOT MANUFACTURED BY ACCES

Equipment provided but not manufactured by ACCES is warranted and will be repaired according to the terms and conditions of the respective equipment manufacturer's warranty.

#### GENERAL

Under this Warranty, liability of ACCES is limited to replacing, repairing or issuing credit (at ACCES discretion) for any products which are proved to be defective during the warranty period. In no case is ACCES liable for consequential or special damage arriving from use or misuse of our product. The customer is responsible for all charges caused by modifications or additions to ACCES equipment not approved in writing by ACCES or, if in ACCES opinion the equipment has been subjected to abnormal use. "Abnormal use" for purposes of this warranty is defined as any use to which the equipment is exposed other than that use specified or intended as evidenced by purchase or sales representation. Other than the above, no other warranty, expressed or implied, shall apply to any and all such equipment furnished or sold by ACCES.

## APPENDIX A LSI TYPE 9513 DATA SHEET

The following pages are a data sheet for the LSI counter used on the CTR05 counter card.