# Reference Manual

**VL-7614** 

64-Line TTL Interface Card for the STD Bus





VL-7614 VL-76CT14

64-Line TTL Interface Card for the STD Bus

## Model VL-7614 64-Line TTL Interface Card for the STD Bus REFERENCE MANUAL

VL-7614 Rev. 2.00 Doc. Rev. 01/04/94

VersaLogic Corporation 3888 Stewart Rd. • Eugene, OR 97402

> (503) 485-8575 Fax (503) 485-5712

Contents Copyright 1994 All Rights Reserved

## NOTICE:

Although every effort has been made to ensure this documentation is error-free, VersaLogic makes no representations or warranties with respect to this product and specifically disclaims any implied warranties of merchantability or fitness for any particular purpose.

VersaLogic reserves the right to revise this product and associated documentation at any time without obligation to notify anyone of such changes.



M7614

# Model VL-7614 64-Line TTL Interface Card

## REFERENCE MANUAL

## CONTENTS

| 1. (                         | )vervi                                              | L <b>ew</b>   |              |            |           |         |     |        |   |   |   |   |   |   |   |   |   |   |   |   |                          |
|------------------------------|-----------------------------------------------------|---------------|--------------|------------|-----------|---------|-----|--------|---|---|---|---|---|---|---|---|---|---|---|---|--------------------------|
| Inti<br>Ovei<br>Feat<br>Spec | roduct<br>rview<br>cures<br>cifica                  | ion<br>       | .s           | •          | •         | •       | •   | •      | • | • | • | • | • | • | • | • | • | • | • | • | 1-1<br>1-1<br>1-2<br>1-2 |
| 2. (                         | Config                                              | jurat         | io           | n.         |           |         |     |        |   |   |   |   |   |   |   |   |   |   |   |   |                          |
|                              | per Surd Add<br>8-Bit<br>10-Bi<br>IOEXE             | Add<br>t Add  | lre:<br>ldre | SS:<br>9S: | ing<br>si | ng<br>3 |     |        |   |   |   |   |   |   |   |   |   |   |   |   |                          |
| Mapp                         | ping M<br>8-Por<br>4-Por                            | iode<br>rt Ma | pp:          | ing        | g         | •       | •   | •      | • | • | • | • | ٠ | ٠ | • | • | ٠ | • | • | • | 2-7                      |
| 1/0                          | Ports                                               |               |              |            |           | •       | •   | •      | • | • | • | • | • | • | • | ٠ | ٠ | • | • | • | 2-8                      |
| 3.                           | Insta]                                              | llati         | on           |            |           |         |     |        |   |   |   |   |   |   |   |   |   |   |   |   |                          |
| Hand<br>Inst<br>Exte         | dling<br>tallat<br>ernal                            | ion<br>Conn   | nect         | tio        | on:       | •       | •   | •      | • | • | • | • | • | • | • | • | • | • | • | • | 3-1<br>3-1<br>3-2        |
|                              | Operat                                              |               |              |            |           |         |     |        |   |   |   |   |   |   |   |   |   |   |   |   |                          |
| Int:<br>I/O<br>Read<br>Soft  | roduct<br>Port<br>ding a<br>tware<br>Assem<br>BASIO | JDTA .        | Lai          | ngı        | ua        | gе      | ata | •<br>• | • | • | • | • | • | • | • | • | • | • | • | • | 4-1<br>4-1<br>4-2<br>4-3 |

## 5. Reference

VL-7614 Parts Placement Diagram VL-7614 Schematic VL-7614 Parts List VL-76CT14 Parts List

STD Bus Pinout ASCII Table

> Contents Copyright 1991 All Rights Reserved

VersaLogic Corporation 3888 Stewart Rd. Eugene, OR 97402

(503) 485-8575

Overview

## Section 1 OVERVIEW

#### INTRODUCTION

This manual details the installation and operation of VersaLogic's VL-7614 interface card. This card provides 64 TTL type I/O lines for general purpose interfacing requirements.

The VL-7614 is available in standard (VL-7614) and extended temperature (VL-76CT14) versions. Throughout this manual "VL-7614" will be used to refer to both versions of these boards, unless specifically noted otherwise

#### **OVERVIEW**

The VL-7614 card provides 64 TTL type input/output lines. Grouped as 8 ports of 8 lines, each port can be configured as 8 inputs, 8 outputs, or 8 outputs with readback.

I/O configuration is accomplished by physically removing or inserting selected chips from the board (one input and output chip per 8-bit port). This allows the board to be configured in any combination of input and output ports desired.

Each 8-bit port of non-inverting input lines can be read at any time by the system processor. Pull-up resistors are included to assure that unconnected lines do not have an undetermined state. Input ports can also be used in conjunction with output ports to "read back" the output data. LS244 type chips with .4V hysteresis (ACT244 in the extended temperature version) are used for the data input buffers.

The output lines are non-inverting and can drive 17 LS TTL loads (6.8 ma sink, 3.5 ma CT version). When a port is used for output, it can optionally be configured with the corresponding input buffer left in place. This allows the state of the output lines for that port to be read by the processor. This function, usually called port readback, can be used to simplify programming and assure correct program operation in many applications. LS273 type chips (HCT273 in the extended temperature version) are used for the data output latches.

External connections are made through four 34-pin latching connectors. Each connector interfaces sixteen I/O lines (two 8-bit ports) to external devices. Alternating ground lines, paired with each signal line, improve noise immunity and reduce cross talk.

The VL-7614 features 8 and 10-bit addressing, and is compatible with all common STD Bus processor types. The IOEXP line is also supported.

The VL-7614 normally occupies eight consecutive I/O addresses. It can alternately be mapped into only four I/O addresses when it is configured as four input ports and four output ports.

The board is fully compatible with the Pro-Log 7614 card.

Overview Section 1

## **FEATURES**

- Eight 8-bit I/O Ports.
- 6.8 ma output drive (3.5 ma CT version).
- 8 or 10-bit I/O addressing.
- IOEXP supported.
- Latching I/O connectors.
- Extended temperature version available.
- Universal STD Bus processor compatible.
- Plug-in replacement for Pro-Log 7614.

## SPECIFICATIONS

Size: Meets all STD Bus mechanical specifications

## Storage Temperature:

- VL-7614: -40 to +75 C
- VL-76CT14: -40 to +85 C

## Free Air Operating Temperature:

- VL-7614: 0 to +65 C
- VL-76CT14: -40 to +85 C

## Power Requirements:

- VL-7614: 5V  $\pm$ 5% @ 450 ma typ. (all outputs high)  $5V \pm 5\%$  @ 540 ma typ. (all outputs low)
- VL-76CT14: 5V  $\pm$ 10% @ 5.5 ma typ. (all outputs high)  $5V \pm 10\%$  @ 38.5 ma typ. (all outputs low)

## I/O Port Interface:

- VL-7614: Low level output drive: 6.8 ma @ .35V High level output drive: .9 ma @ 2.7V Input load: 1.2 ma @ .35V (4.7K ohm pull-up)
- VL-76CT14: Low level output drive: 3.5 ma @ .1V High level output drive: 4.0 ma @ 4.9V Input load .5 ma @ .1V (10K ohm pull-up)

Configuration

## Section 2 CONFIGURATION

## JUMPER SUMMARY

Various options available on the VL-7614 card are selected using removable jumper plugs (shorting plugs). Features are selected or deselected by installing or removing the jumper plugs as noted. The terms "IN" or "JUMPED" are used to indicate an installed plug. "OUT" or "OPEN" indicates the absence of a jumper plug.

The function of each jumper block is detailed in Figure 2-1. Figure 2-2 shows the jumper block locations on the VL-7614 board. It indicates the position of the jumper plugs as shipped from the factory.

| Jumper<br>Block | Description                                                                                            | As<br>Shipped                    |
|-----------------|--------------------------------------------------------------------------------------------------------|----------------------------------|
| V1              | 10-bit address control. See Board Address - A9 control. b - A8 control.                                | ess. a - ignore A9 b - ignore A8 |
| V2              | Board address. See Board Address.                                                                      | Hex 00                           |
| V3              | Addressing control. See <u>Board Address</u> .  a - A2 control (4-port mode only).  b - IOEXP control. | Ignore A2<br>Ignore IOEXP        |
| V4              | 4 or 8-port mapping. See Mapping Mode.                                                                 | 8-port mode                      |

Figure 2-1. Jumper Functions



Figure 2-2. Jumper Block Locations

P. 03

Section 2

Configuration

## BOARD ADDRESS

The VL-7614 supports both 8 and 10-bit I/O addressing. 8-bit addressing is used with most 8-bit processors (Z80, 8085, 6809, etc.) which provide 256 I/O addresses. 10-bit addressing can be used with 16-bit processors (i.e. 8088) to decode up to 1024 I/O port addresses.

Both 8 and 10-bit addressing can be extended (capacity doubled) using the IOEXP signal which is decoded by the VL-7614.

As shipped the board is configured for 8-bit addressing with a board address of hex 00. The VL-7614 normally occupies eight consecutive I/O addresses (i.e. 00-07). If it is configured as four input ports and four output ports it can optionally be mapped into only four I/O ports.

Configuration

## 8-Bit Addressing

To configure the board for an 8-bit I/O address refer to the figure below. Use the table to select the jumpering for the appropriate upper and lower halves of the desired starting address (i.e. "3" and "0" = hex address 30).



| <u>-</u> | V | 72<br>C | <br>d | Upper<br>Digit |  | V2<br>e | V3<br>a* | Lower<br>Digit |
|----------|---|---------|-------|----------------|--|---------|----------|----------------|
| х        | х | х       | х     | 0              |  | Х       | Х        | 0              |
| X        | X | X       | -     | ĭ              |  | X       | _        | 4              |
| X        | X | _       | Х     | 2              |  |         | X        | 8              |
| X        | X | _       |       | 3              |  |         | -        | С              |
| X        | _ | Х       | Х     | 4              |  |         |          |                |
| X        |   | X       | _     | 5              |  |         |          |                |
| X        | _ | _       | Х     | 6              |  |         |          |                |
| X        | _ | _       | _     | 7              |  |         |          |                |
| _        | Х | Х       | Х     | 8              |  |         |          |                |
| ***      | X | X       | _     | 9              |  |         |          |                |
| -        | X | -       | Х     | Ā              |  |         |          |                |
| _        | X |         |       | В              |  |         |          |                |
| _        | - | Х       | X     | C              |  |         |          |                |
| _        | _ | X       |       | Ď              |  |         |          |                |
|          | _ | _       | Х     | Ē              |  |         |          |                |
| _        |   |         | _     | F              |  |         |          |                |

X = Jumper installed.

Figure 2-3. 8-Bit Address Jumpers

 <sup>- =</sup> Jumper removed.
 \* Jumper V3a is used only with optional 4-port mapping. Otherwise the lower hex digit will be 0 or 8 (per the position of V2e).

Configuration

## 10-Bit Addressing

To configure the board for a 10-bit I/O address refer to the figure below. Use the table to select the jumpering for the appropriate upper, middle, and lower hex digits of the desired address (i.e. "1" and "3" and "0" = hex address 130).

| V1 |        | 0 0              | ← a<br>← b |
|----|--------|------------------|------------|
| ٠  | (d.ld. | <b>«</b>         | а          |
|    |        | <b>←</b>         | b          |
| V2 |        | <del>&lt;-</del> | C          |
|    | EIE.   | +                | ď          |
|    | (D D)  | <b>←</b>         | e          |
|    | 0.0    | ۵                | - a        |
| V3 | 0 0    | 0                |            |
|    |        |                  |            |

| V1<br>a          | <b>V</b> 1       | Upper<br>Digit   | а<br>а                              | — V                                                 | 72<br>C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | <br>d                                   | Middle<br>Digit                                                              | <b>V</b> 2<br>e  | V3<br>a*         | Lower<br>Digit   |
|------------------|------------------|------------------|-------------------------------------|-----------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|------------------------------------------------------------------------------|------------------|------------------|------------------|
| x<br>x<br>-<br>- | X<br>-<br>X<br>- | 0<br>1<br>2<br>3 | x<br>x<br>x<br>x<br>x<br>x<br>x<br> | x<br>x<br>x<br>x<br>-<br>-<br>-<br>x<br>x<br>x<br>x | x x - x x x - x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x x | x - x - x - x - x - x - x - x - x - x - | 0<br>1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>A<br>B<br>C<br>D<br>E<br>F | x<br>x<br>-<br>- | x<br>-<br>x<br>- | 0<br>4<br>8<br>C |

X = Jumper installed.

Figure 2-4. 10-Bit Address Jumpers

<sup>- =</sup> Jumper removed.

<sup>\*</sup> Jumper V3a is used only with optional 4-port mapping. Otherwise the lower hex digit will be 0 or 8 (per the position of V2e).

Configuration

As

## IOEXP Signal

The IOEXP (I/O expansion) signal on the STD Bus is normally used to select between two different I/O banks or maps. It can be used to double the number of available I/O addresses in the system (by selecting between two banks of I/O boards). The IOEXP signal is usually controlled by (or jumpered to ground on) the system CPU card.

A low IOEXP signal usually selects the standard or normal I/O map. A high IOEXP signal usually selects the secondary or alternate I/O map. Boards that ignore (or do not decode) IOEXP will appear in both I/O maps.

As shipped the IOEXP jumper is configured to ignore the IOEXP signal. The board will be addressed whether the IOEXP signal is high or low. It can be jumpered for two other modes as shown in Figure 2-5.



| Jumper<br>Block | Description                                                                                                                                     | As<br>Shipped     |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|
| V3              | <ul> <li>a - Ignore IOEXP (enable high or low).</li> <li>b - Enable on IOEXP low.</li> <li>None - Enable on IOEXP high (no jumpers).</li> </ul> | a - IN<br>b - out |

Figure 2-5. IOEXP Options

Configuration

## MAPPING MODE

The VL-7614 normally occupies eight I/O port addresses. In this mode the I/O ports can be configured in any way desired (all inputs, all outputs or any mix).

Optionally the board can be configured to occupy only four I/O port addresses. In this mode the I/O ports <u>must</u> be configured as four input channels and four output channels. This mode is advantageous only when there are many I/O boards in the system and the I/O map is becoming full.

Unless system I/O addresses are very scarce (all 256 or more being used), the board should be used in the 8-port mode.

## 8-Port Mapping

To configure the board for 8-port mapping, jumper the board as shown below. In this mode jumper V3a is ignored when selecting the starting address for the board and should be located as shown below.



Figure 2-6. 8-Port Mapping

## 4-Port Mapping

To configure the board for 4-port mapping, jumper the board as shown below. In this mode jumper V3a is used for addressing the board and should be inserted or removed from the position shown according to the addressing tables in the preceding sections.



Figure 2-7. 4-Port Mapping

Configuration

## I/O PORTS

The I/O ports are configured for input or output by removing selected chips from the board. The board is arranged as 8 channels of 8 lines each (64 lines total). Each group of 8 lines can be configured as either input or output lines.

As shipped, with all the chips on the board, the VL-7614 is configured as 8 output channels. To configure any of the channels for input the output chip (for that channel) is removed from the board.

Normally it is desirable to leave the input chip installed on channels used for output. This allows the current state of the output lines to be read if desired. If this feature is not needed, the input chips can be removed to save a small amount of power.

In the standard 8-port mode, any of the eight channels (0-7) can be configured as inputs or outputs as desired. The figure below shows an example of a typical configuration. It shows the location of the input and output chips for each channel, and how the channels would appear on the I/O connectors.



Figure 2-8. Typical I/O Configuration

Configuration

Alternately the board can be configured as four ports (I/O addresses) with an input and an output channel at each location. This configuration is not recommended for most applications.

When this mode is used the the board must be configured only as shown below. Writing to channels 0-3 will output data on connectors J1 and J2. Reading channels 0-3 will input data from connectors J3 and J4.

This configuration does not allow for readback of output channel data.



Figure 2-9. Special 4-Port Mode Configuration

Installation

Section 3
INSTALLATION

#### HANDLING

\*\* CAUTION \*\* The VL-7614 card uses chips which are sensitive to static electricity discharges. Normal precautions, such as discharging yourself, work stations, and tools to ground before touching the board should be taken whenever the board is handled.

The board should also be protected during shipment or storage by placing it in a conductive bag (such as the one it was received in) or by wrapping it in metal foil.

#### INSTALLATION

The VL-7614 card can be installed in any slot of an STD Bus card cage.

The VL-7614 does not use the STD Bus priority interrupt chain. However, the priority IN and OUT pins on this board are connected together so that the priority chain will not be broken. This board may be inserted between other boards that are using the priority chain.

- \*\* CAUTION \*\* When cards are installed in an STD Bus card cage they must be oriented correctly (usually with the card ejector toward the top of the cage). Refer to the card cage documentation for the correct way to insert the STD Bus cards.
- \*\* CAUTION \*\* Cards should be inserted or removed from the STD Bus card cage only when the system power is off.

P. 02

Section 3

Installation

## EXTERNAL CONNECTIONS

Connection to the VL-7614 can be made as noted below. Pinout listings for these connectors appear on the following pages. A pinout of the STD Bus connector appears in Section 5.

## Connectors J1 - J4

Connectors J1 - J4 are 34-pin latching header type connectors (on .1" centers). They may each be connected to external equipment using mating connectors such as Ansley #609-3441, AMP #499506-0, and 3M #3414-6034. The mating connectors should include a strain relief in order to use the built-in latch bars.

Installation

| Connector J1                              | Connector J2                                                                                 |
|-------------------------------------------|----------------------------------------------------------------------------------------------|
| Pin Channel - Bit                         | Pin Channel - Bit                                                                            |
| 1 0 - 0                                   | 1 2 - 0                                                                                      |
| 3 0 - 1                                   | 3 2 - 1                                                                                      |
| 5 0 - 2                                   | 5 2 - 2                                                                                      |
| 7 0 - 3                                   | 7 2 - 3                                                                                      |
| 9 0 - 4                                   | 9 2 - 4                                                                                      |
| 11 0 - 5                                  | 11 2 - 5                                                                                     |
| 13 0 - 6                                  | 13 2 - 6                                                                                     |
| 15 0 - 7                                  | 15 2 - 7                                                                                     |
| 17                                        | 17 3 - 0<br>19 3 - 1<br>21 3 - 2<br>23 3 - 3<br>25 3 - 4<br>27 3 - 5<br>29 3 - 6<br>31 3 - 7 |
| 33 Ground 2-34 even numbered pins ground. | 33 Ground<br>2-34 even numbered pins ground.                                                 |

Figure 3-1. Connectors J1 and J2 Pinouts

Installation

| Connector J3                              | Connector J4                                                                                 |
|-------------------------------------------|----------------------------------------------------------------------------------------------|
| Pin Channel - Bit                         | Pin Channel - Bit                                                                            |
| 1 4 - 0                                   | 1 6 - 0                                                                                      |
| 3 4 - 1                                   | 3 6 - 1                                                                                      |
| 5 4 - 2                                   | 5 6 - 2                                                                                      |
| 7 4 - 3                                   | 7 6 - 3                                                                                      |
| 9 4 - 4                                   | 9 6 - 4                                                                                      |
| 11 4 - 5                                  | 11 6 - 5                                                                                     |
| 13 4 - 6                                  | 13 6 - 6                                                                                     |
| 15 4 - 7                                  | 15 6 - 7                                                                                     |
| 17                                        | 17 7 - 0<br>19 7 - 1<br>21 7 - 2<br>23 7 - 3<br>25 7 - 4<br>27 7 - 5<br>29 7 - 6<br>31 7 - 7 |
| 33 Ground 2-34 even numbered pins ground. | 33 Ground<br>2-34 even numbered pins ground.                                                 |

Figure 3-2. Connectors J3 and J4 Pinouts

Operation

Section 4
OPERATION

#### INTRODUCTION

This section includes general information about the use and operation of the VL-7614 card. It focuses primarily on the software commands necessary to operate the card and includes examples to assist you in constructing your own software routines.

## I/O PORT MAPPING

The VL-7614 normally occupies eight I/O port addresses. Each I/O address corresponds to one 8-bit channel of inputs or outputs.

An alternate mapping may also be used which provides four ports that each access one input and one output channel. This mapping is not recommended for most applications and will not be covered in this section.

The locations of the eight ports is determined by the board address, which is jumper selectable. As shipped, the board is jumpered for hex address 00.

Once the board's I/O address has been determined, the addresses of the eight I/O ports can be determined as shown in Figure 4-1. Each I/O module port can be both read (for inputting data or reading the current output data) and written (for outputting data) depending on the physical configuration of the channel.

For applications that use byte-oriented data, each port can be read/written directly as needed. For applications that use bit-oriented data (i.e. many single status/control lines) the board is much easier to use with subroutines that treat it as 64 single addressable lines. Subroutines with this purpose are included later in this section.

Figure 4-2 details the way in which the bit numbering corresponds to each connector and port number (shown as shipped addressed at hex 00).

Operation

| Chan.# | Bit<br>Number                          | Connector                                                                         |
|--------|----------------------------------------|-----------------------------------------------------------------------------------|
| 0 0    | 0-7                                    | J1                                                                                |
| 1 1    | 8-15                                   | J1                                                                                |
| 2 2    | 16-23                                  | J2                                                                                |
| 3 3    | 24-31                                  | J2                                                                                |
| 4 4    | 32-39                                  | J3                                                                                |
| 5 5    | 40-47                                  | J3                                                                                |
| 6 6    | 48-56                                  | J4                                                                                |
| 7 7    | 57-63                                  | J4                                                                                |
|        | 0 0<br>1 1<br>2 2<br>3 3<br>4 4<br>5 5 | Chan.# Number  0 0 0-7 1 1 8-15 2 2 16-23 3 3 24-31 4 4 32-39 5 5 40-47 6 6 48-56 |

Figure 4-1. I/O Port Locations

| Conn. | Addr. | <b>D</b> 7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
|-------|-------|------------|----|----|----|----|----|----|----|
| J1    | 00    | 7          | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| J1    | 01    | 15         | 14 | 13 | 12 | 11 | 10 | 9  | 8  |
| J2    | 02    | 23         | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| J2    | 03    | 31         | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| J3    | 04    | 39         | 38 | 37 | 36 | 35 | 34 | 33 | 32 |
| J3    | 05    | 47         | 46 | 45 | 44 | 43 | 42 | 41 | 40 |
| J4    | 06    | 55         | 54 | 53 | 52 | 51 | 50 | 49 | 48 |
| J4    | 07    | 63         | 62 | 61 | 60 | 59 | 58 | 57 | 56 |

Figure 4-2. Bit Numbering

## READING AND WRITING DATA

All of the I/O buffers on the VL-7614 board are non-inverting (to set an output pin low, write a zero, etc.).

Note that the data read always reflects the actual state of the I/O pin, even for output channels. If an I/O pin is shorted to ground it will always read as a zero. Writing a high or low bit to the pin (assuming it's an output channel) will have no effect on the data read.

All output channels are cleared (set low) at power-up and whenever a system reset occurs.

Section 4 Operation

#### SOFTWARE EXAMPLES

Reading a VL-7614 port (data byte) is straightforward and requires no special considerations. If bit- oriented data is read, care must be taken to select the proper port and data bit which corresponds to the desired I/O line.

When writing to an I/O line, care must be taken not to change the current state of the seven other bits which appear at the same I/O port. This is easily done by reading the state of the output port before anding/oring in the bit that is being changed.

In systems where more than a few I/O lines are used, these operations can be made much easier with generalized subroutines that read or write to a specified I/O line. These subroutines calculate the port address and data bit involved and allow the programmer to concentrate on reading or writing to the desired line.

The routines allow reading of a single input line, writing to a single output line, and reading of a single output line to determine its current state.

The VL-7614 can be used with any language that allows direct access to system I/O ports. The examples below are shown in several programming languages. These examples have not necessarily been tested or verified for proper operation. They are supplied for general information only and may not be appropriate for any specific application.

Note: These routines use "readback" of the output channels. They assume (and require) that all the input buffer chips have been left in the board.

## Assembly Language Examples

The following Z80 program fragments illustrate how the VL-7614 board can be used in an assembly language environment.

The first example illustrates direct access to each desired I/O line. This method is appropriate when byte-oriented data is read/written, or only a small number of I/O lines are connected to the interface. It requires that the programmer determine the related port and bit of the desired I/O line.

The second example illustrates access by I/O line number. It uses sub-routines to read or write to a specified line, freeing the programmer from unnecessary calculations during program construction.

VL-7614 4-3

Operation

```
;Example 1. Direct access to the VL-7614.
                  ;Define all port locations.
       0000
                            EQU
                                  00H
                  DIOBASE
                                                  ;Board address = hex 00.
       0000
                  CHAN0
                            EQU
                                  DIOBASE + 0
                                                  ;Channel 0 (lines 0-7).
       0001
                  CHAN1
                            EQU
                                  DIOBASE + 1
                                                  ;Channel 1
       0002
                  CHAN2
                                  DIOBASE + 2
                                                  ;Channel 2
                            EQU
       0003
                  CHAN3
                            EQU
                                  DIOBASE + 3
                                                  ;Channel 3
       0004
                  CHAN4
                            EQU
                                  DIOBASE + 4
                                                  ;Channel 4
                                  DIOBASE + 5
       0005
                  CHAN5
                            EQU
                                                  ;Channel 5
       0006
                  CHAN6
                            EQU
                                  DIOBASE + 6
                                                  ;Channel 6
       0007
                                  DIOBASE + 7
                                                  ;Channel 7
                  CHAN7
                            EQU
       8000
                  CHAN8
                            EQU
                                  DIOBASE + 8
                                                  :Channel 8
0100
                       ORG
                                 100H
                                         :Start of code.
                  ; Reading a single line (state of input or output line).
0100
      DB 00
                      IN A, (CHANO)
                                    ;Read the I/O port.
0102
      E6 02
                      AND 00000010B
                                      ; Mask out all channels except #1.
0104
      C2 08 01
                      JP NZ, DOIT ; Jump to somewhere if channel is ON.
0107
       00
                          NOP
                                      ; Else do something here.
0108
       00
                  DOIT
                          NOP
                                      ;Dummy routine for jump above.
                  ;
                  ;Setting a line ON (output pin high).
0109
                      IN A, (CHAN1) ; Read the current state of the outputs.
      DB 01
010B
                      OR 01000000B ; Set the line #14 bit ON.
      F6 40
010D
      D3 01
                      OUT (CHAN1), A ; Write it to the board.
                  ;Setting a line OFF (output pin low).
010F
      DB 02
                      IN A, (CHAN2)
                                    ; Read the current state of the outputs.
0111
      E6 FB
                      AND 11111011B ;Set the channel #18 bit OFF.
                     OUT (CHAN2), A ; Write it to the port.
0113
      D3 02
```

Operation

```
;Example 2 - Accessing the VL-7614 by channel #.
       0000
                  ADDR7614 EQU 00H
                                             ;Board address = hex 00.
                          ORG 100H
0100
                                             :Start of code.
                  ;reading an I/O line (state of input or output).
0100
       3E 0C
                               A, 12
                                             ;Specify line #12
                          LD
0102
       CD 14 01
                          CALL READ
                                             ;Read it (result in A)
0105
       C2 09 01
                          JΡ
                               NZ, DUMMY
                                             ;Jump somewhere if it is ON.
0108
       00
                          NOP
                                             ; (do something else if it isn't)
0109
       00
                  DUMMY
                          NOP
                                             : (user routine)
                  ;Setting a line ON (output pin high).
                          LD A,9 ;Specify line #9
010A
       3E 09
       CD 1E 01
010C
                          CALL ON
                                            ;Turn it ON
                  ;Setting a line OFF (output pin low).
       3E 28
010F
                          LD A, 40
                                             ;Specify line #40
       CD 27 01
                          CALL OFF
                                              ;Turn it OFF
0111
                  ;** SUBROUTINES **
                  ;Reads a line (input or output). Chan.# (0-63) is in A.
                  ;Returns the state of the line (0 or 1) in reg. A.
0114
       CD 33 01
                  READ
                          CALL FIND
                                            ;Convert the line #.
0117
       ED 78
                          IN
                               A, (C)
                                             ; Read the port.
0119
                          AND A, B
                                            ; Mask for desired bit.
       A0
                                            ;Return if 0.
011A
       C8
                          RET Z
                                             ;Or else plug with a 1
011B
       3E 01
                          LD
                               A, 1
                          RET
                                             ; and return.
011D
       C9
                  ;Sets an output line ON. Chan.# (0-63) is in reg. A.
011E
       CD 33 01
                          CALL FIND
                                             ;Convert the line #.
                  ON
0121
       ED 78
                               A, (C)
                                            ; Read current output states.
                          IN
0123
                                            ;Set line on.
       В0
                          OR
                               В
       ED 79
                                             ;Write it to the port.
0124
                          OUT
                               (C),A
0126
       C9
                          RET
                                             ;Return.
                  ;Sets an output line off. Chan.# (0-63) is in reg. A.
                                             ;Convert the line #.
0127
       CD 33 01
                          CALL FIND
                  OFF
012A
       78
                          LD
                                             ;Complement B (bit mask).
                               A,B
012B
       2F
                          CPL
012C
       47
                          ID
                               B,A
012D
       ED 78
                          IN
                               A, (C)
                                             ;Read current output states.
012F
       A0
                          AND B
                                             ;Set line off.
0130
       ED 79
                          OUT
                               (C),A
                                            ;Write it to the port.
0132
       C9
                          RET
                                            ;Return
```

Operation

|      |       | reques | ; ;Computes the port address and bit mask for the ;requested line # (in register A). ;Returns A=0, B=bit mask, C=port address |             |                             |  |  |  |  |
|------|-------|--------|-------------------------------------------------------------------------------------------------------------------------------|-------------|-----------------------------|--|--|--|--|
| 0133 | 3C    | FIND   | INC                                                                                                                           | A           | ;Offset line # by 1.        |  |  |  |  |
| 0134 | 06 01 |        | LD                                                                                                                            | B, 1        | ;Initialize B, for line #0. |  |  |  |  |
| 0136 | 0E 00 |        | ${ m LD}$                                                                                                                     | C, ADDR7614 | ;Initialize C, for line #0. |  |  |  |  |
| 0138 | 3D    | L1     | DEC                                                                                                                           | A           | ;Decrement line #.          |  |  |  |  |
| 0139 | C8    |        | RET                                                                                                                           | Z           | ;Done when A=0.             |  |  |  |  |
| 013A | CB 00 |        | RLC                                                                                                                           | В           | ;Rotate bit mask.           |  |  |  |  |
| 013C | 30 FA |        | JR                                                                                                                            | NC, L1      | ;Loop if no carry.          |  |  |  |  |
| 013E | 0C    |        | INC                                                                                                                           | C           | ;Adjust port address.       |  |  |  |  |
| 013F | 18 F7 |        | JR                                                                                                                            | L1          | ;Continue.                  |  |  |  |  |

Operation

## BASIC Language Examples

The subroutines and program fragments in the first listing below illustrate how the VL-7614 board can be used with standard BASICs (or other high level languages) that include logical AND, OR, and XOR functions. Microsoft's BASIC-80 is used in this example.

Users of VersaLogic's C4 BASIC language should refer to the second listing which shows these same functions written in C4 BASIC.

Note: These routines may not operate correctly with some BASICs or be suitable for your application.

VL-7614 4-7

Section 4 Operation

```
10 REM Microsoft BASIC-80 language example for the VL-7614 board.
20 REM To read or write to single I/O lines (#0-63).
50 REM Set address of Digital Interface (DI) board (00 hex = 00 decimal)
51 DI = 0
100 REM Read line 0 and do something if it's ON.
110 LINE=0: GOSUB 510
120 IF STATE = 1 THEN GOTO 1000
150 REM Turn ON line 11
155 LINE=11: GOSUB 570
170 REM Turn line 8 OFF
171 LINE=8: GOSUB 540
500 REM SUBROUTINES FOR VL-7614 BOARD.
501 REM These routines are called with the line # (0-63) in "LINE".
502 REM Input data is returned in "STATE" (1=ON, 0=OFF).
510 REM Read the line in "LINE" (0-63)
520 GOSUB 600 : STATE=INP(ADDR) AND MASK : IF STATE > 0 THEN STATE=1
530 RETURN
540 REM Turn OFF line "LINE" (0-63)
550 GOSUB 600 : OUT ADDR, (INP (ADDR) AND (255 XOR MASK)
560 RETURN
570 REM Turn ON line "LINE" (0-63)
580 GOSUB 600 : OUT ADDR, (INP(ADDR) OR MASK))
590 RETURN
600 REM Computes port address and bit mast for routines above.
```

610 X=INT(LINE/8) : ADDR=DI+X : MASK=2^(LINE-8\*X) : RETURN

Section 4 Operation

```
10 REM VersaLogic C4 BASIC language example for the VL-7614 board.
50 REM Set address of Digital Interface (D1) board (00 hex)
51 D1 = \&00
100 REM Read line 0 and do something if it's ON.
110 N=0: GOSUB 510
120 IF S = 1 GOTO 1000
150 REM Turn ON line 11
155 N=11: GOSUB 570
170 REM Turn line 31 OFF.
171 N=31: GOSUB 540
500 REM SUBROUTINES FOR VL-7614 BOARD.
501 REM These routines are called with the line # in "N" (0-63).
502 REM Input data is returned in "S" (1=ON, 0=OFF).
510 REM Read the line in "N"
520 GOSUB 595 : S=IN(X) AND X1 : If S>0 S=1
530 RETURN
540 REM Turn OFF line "N"
550 GOSUB 595 : OUT X, (IN(X) AND NOT (X1))
560 RETURN
570 REM Turn ON line "N"
580 GOSUB 595 : OUT X, (IN(X) OR X1)
590 RETURN
594 REM Computes port addr (X) and bit mask (X1) for routines above
595 \times (N/8) + D1 : X1=1: X2=MOD(N,8): IF X2=0 RETURN
596 FOR X3 = 1 TO X2 : X1=X1*2 : NEXT X3 : RETURN
```

4 - 9

VL-7614 REV 2 Parts Placement Diagram

09/04/91



VL-7614 REV 2

PAGE 1/3 09/04/91



PAGE 2/3 VL-7614 REV 2 09/04/91 ⇔BD0-BD7 33 RP7 VV BRST\* BD7, BD7 P1-7 U11 UЗ XX244 XX273 17. RP4\_AAA P1-2 P1-0 BDO <u>√BD0</u> P1-1 <u>719</u> WR1\* RD1\* P1-0 RP3 VVV BRST\* P0-7 P0-7 P0-7 BD7 P0-5 RP4 AAA P0-4 U1 U9 XX273 P0-2 BDO P0-0 BDO P0-0 RP4 VVV RDO\* WR<u>0</u>\* P0--0 BRST\* P3-7 BD7 U15 U7 RP1\_\ XX273 XX244 P3-2 P3-0 P3-0 BDO BDO P3-1 WR3\* RD3\* BRST\* RP1 P2-7 U13 U5 XX244 9 RP1\_VVV XX273 BDO P2-0 P2-0 BDO R1 - VV WR2\* RD2\*

P6-0

PAGE 3/3VL-7614 REV 2 09/04/91 ⇔BD0-BD7 34 33 BRST\* 32 P5-7 31 30 P5-7 P5-6 BD7 BD7 29 15 14 15 28 27 6 14 26 18 19 8 P5-4 U4 U12 25 RP6 VV 11 XX273 XX244 24 17 13 16 23 RP6 AVV 16 7 6 4 22 P5-2 P5-0 21 BDO, 8 9 18 BDO 20 P5-1 19 RP6 VV WR5\* RD5\* 18 P5-0 17 RP6 /// 8 BRST\* 16 P4-7 15 14 P4-7 13 RP5 VVV 14 15 15 5 12 P4-5 6 4 11 RP5 VVV 10 18 8 19 U2 P4-4 U10 9 9 11 XX244 XX273 8 13 17 16 P4-3 7 7 16 6 P4-2 BD0/ P4-0 18 √BD0 8 P4-0 5 RP5 VV 4 <u>71</u>9 P4-1 11 . 3 RP5 \_\_\_\_\_8 RD4\* WR4\* 2 P4-0 34 33 RP9 VVV BRST\* 32 P7-7 31 RP9 A 30 P7-6 P7-7 BD7 BD7 13 17 29 14 15 15 5 28 P7-5 4. 27 6 14 RP9 VVV 26 18 8 19 P7-4 U8 U16 25 11 3 2 RP9 VVV 9 XX244 XX273 24 17 P7-3 16 13 23 7 6 4 16 22 P7-2 21 P7-0 P7-0 18 BDO/ <u>BD0</u> 8 9 RP9 AAA 20 P7-1 19 19 RD<u>7</u>+ WR<u>7</u>∗ 18 P7-0 17 RP8\_VVV BRST\* 16 P6-7 15 RP8 AAA 14 13 P6-7 BD7, BD7 P6-7 17 13 15 14 15 12 P6-5 4 11 6 RP8 VVV 10 19 8 18 12 U6 P6-4 U14 9 XX273 2 11 9 RP8 VVV XX244 8 16 17 P6-3 13 7 RP8 AAA 7 16 6 P<u>6-0</u> BD0/ BDO 8 9 P6-0 18 5 RP7 VV 4 3 P6-1 RP7 VV RD<u>6∗</u> WR6\* 2

VL-7614 (Rev 2) Parts List

09/04/91

Page 1 of 1

## VL-7614 PARTS LIST 64 Line TTL Interface

## Capacitors

C1-C12

.01 uf ceramic

C13

22 uf electrolytic, radial

## Integrated Circuits

U1-U8

74LS273

U9-U16, U20

74LS244

U17

74LS85

U18

74LS245

U19

74HCT688

U21, U22

74LS138

## Resistors

R1

4K7 ohm, 5%, 1/4 W

RP1-RP9

4K7 ohm, 7 resistor SIP

RP10, RP11

10K ohm, 7 resistor SIP

## Miscellaneous

J1, J2, J3, J4

34 pin R/A latching header

VL-76CT14 (Rev 2) Parts List

09/04/91 Page 1 of 1

## VL-76CT14 PARTS LIST

64 Line TTL Interface (Extended Temperature Version)

## Capacitors

C1-C12

.01 uf ceramic

C13

22 uf electrolytic, radial

## Integrated Circuits

U1-U8

74HCT273

U9-U16, U20

74ACT244

U17

74HCT85

U18

74ACT245

U19

74HCT688

U21, U22

74HCT138

## Resistors

R1

10K ohm, 5%, 1/4 W

RP1-RP9

10K ohm, 7 resistor SIP

RP10, RP11

100K ohm, 7 resistor SIP

## Miscellaneous

J1, J2, J3, J4

34 pin R/A latching header

## STD BUS PINOUT

Connections from the VL-7614 board to the STD BUS are shown below. Pins 1 and 2 are at the top (card ejector) edge of the board. As noted below the odd numbered pins are on the component side of the board while the even numbered pins are on the solder side. Direction of signal flow is referenced to the VL-7614.

|                                              | ONENT SII<br>SIGNAL E                                                     | ELOW                                   | DESCRIPTION                                                                                                                                                     |                                                          | DER SIDE<br>SIGNAL                                                          | FLOW                              | DESCRIPTION                                                                                                                                                                         |
|----------------------------------------------|---------------------------------------------------------------------------|----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------|-----------------------------------------------------------------------------|-----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3                                            | +5V<br>GND<br>VBB/VBAT                                                    | In<br>In                               | +5 volt power<br>Digital ground<br>-5V or bat. backup                                                                                                           | 2<br>4<br>6                                              | +5V<br>GND<br>-5V                                                           | In<br>In<br>-                     | +5 volt power<br>Digital ground<br>-5V power                                                                                                                                        |
| 9<br>11                                      | D3/A19<br>D2/A18<br>D1/A17<br>D0/A16                                      | I/O<br>I/O<br>I/O                      | Data bus<br>Data bus<br>Data bus<br>Data bus                                                                                                                    | 8<br>10<br>12<br>14                                      | D7<br>D6<br>D5/A21<br>D4/A20                                                | I/O<br>I/O<br>I/O                 | Data bus                                                                                                                                                                            |
| 17<br>19<br>21<br>23<br>25<br>27             | A7<br>A6<br>A5<br>A4<br>A3<br>A2<br>A1<br>A0                              | In<br>In<br>In<br>In<br>In<br>In<br>In | Address bus                                                     | 16<br>18<br>20<br>22<br>24<br>26<br>28<br>30             | A15<br>A14<br>A13<br>A12<br>A11<br>A10<br>A9<br>A8                          | -<br>-<br>-<br>-<br>-<br>In<br>In | Address bus                                                                         |
| 33<br>35<br>37<br>39<br>41<br>43<br>45<br>47 | WR* IORQ* IOEXP* REFRESH* STATUS1* BUSAK* INTAK* WAITRQ* SYSRESET* CLOCK* | -<br>-<br>-                            | Write strobe I/O addr. select I/O expansion Refresh timing CPU status Bus acknowledge Interrupt acknowl. Wait request System reset CPU clock Priority chain out | 32<br>34<br>36<br>38<br>40<br>42<br>44<br>46<br>48<br>50 | RD* MEMRQ* MEMEX* MCSYNC* STATUSO* BUSRQ* INTRQ* NMIRQ* PBRESET* CNTRL* PCI | In In                             | Read strobe Memory addr. select Memory expansion Machine cycle sync. CPU status Bus request Interrupt request Non-maskable interrupt Push button reset AUX timing Priority chain in |
|                                              | AUXGND<br>AUX+V                                                           | <u>-</u>                               | ±12 volt ground<br>+12 volt input                                                                                                                               | 54<br>56                                                 | AUXGND<br>AUX-V                                                             | <del>-</del>                      | ±12 volt ground<br>-12 volt input                                                                                                                                                   |

<sup>\*</sup> Denotes an active low signal.

## DECIMAL / HEX / ASCII CONVERSION CHART

The chart below is useful for both ASCII and decimal/hex conversion. The "^" symbol denotes control characters. "^A" represents control A, etc.

| Dec.     | Нех      | ASCII    | Dec.     | Hex      | ASCII  | Dec.     | Hex      | ASCII  | Dec.       | Нех      | ASCII |
|----------|----------|----------|----------|----------|--------|----------|----------|--------|------------|----------|-------|
| 0        | 00       | NUL      | 32       | 20       |        | 64       | 40       | @      | 96         | 60       | •     |
| 1        | 01       | ^A SOH   | 33       | 21       | !      | 65       | 41       | Ă      | 97         | 61       | a     |
| 2        | 02       | ^B STX   | 34       | 22       | 11     | 66       | 42       | В      | 98         | 62       | b     |
| 3        | 03       | ^C ETX   | 35       | 23       | #      | 67       | 43       | Ċ      | 99         | 63       | С     |
| 4        | 04       | ^D EOT   | 36       | 24       | ;      | 68       | 44       | Ď      | 100        | 64       | d     |
| 5        | 05       | ^E ENQ   | 37       | 25       | ģ      | 69       | 45       | Ē      | 101        | 65       | e     |
| 6        | 06       | ^F ACK   | 38       | 26       | &      | 70       | 46       | F      | 102        | 66       | f     |
| 7        | 07       | ^G BEL   | 39       | 27       | ,      | 71       | 47       | G      | 103        | 67       | g     |
| 8        | 08       | ^H BS    | 40       | 28       | (      | 72       | 48       | H      | 104        | 68       | h     |
| 9        | 09       | ^I HT    | 41       | 29       | )      | 73       | 49       | I      | 105        | 69       | i     |
| 10       | 0A       | ^J LF    | 42       | 2A       | *      | 74       | 4A       | J      | 106        | 6A       | j     |
| 11       | 0B       | ^K VT    | 43       | 2B       | +      | 75       | 4B       | K      | 107        | 6B       | k     |
| 12       | 0C       | ^L FF    | 44       | 2C       | ,      | 76       | 4C       | L      | 108        | 6C       | 1     |
| 13       | 0D       | ^M CR    | 45       | 2D       |        | 77       | 4D       | M      | 109        | 6D       | m     |
| 14       | 0E       | ^N SO    | 46       | 2E       | •      | 78       | 4E       | N      | 110        | 6E       | n     |
| 15       | 0F       | ^0 SI    | 47       | 2F       | /      | 79       | 4F       | 0      | 111        | 6F       | 0     |
| 16       | 10       | ^P DLE   | 48       | 30       | 0      | 80       | 50       | P      | 112        | 70       | p     |
| 17       | 11       | ^Q DC1   | 49       | 31       | 1      | 81       | 51       | Q      | 113        | 71       | q     |
| 18       | 12       | ^R DC2   | 50       | 32       | 2      | 82       | 52       | R      | 114        | 72       | r     |
| 19       | 13       | ^S DC3   | 51       | 33       | 3      | 83       | 53       | S      | 115        | 73       | S     |
| 20       | 14       | ^T DC4   | 52       | 34       | 4      | 84       | 54       | T      | 116        | 74       | t     |
| 21       | 15       | ^U NAK   | 53       | 35       | 5      | 85       | 55       | Ū      | 117        | 75       | u     |
| 22       | 16       | ^V SYN   | 54       | 36       | 6      | 86       | 56       | V      | 118        | 76       | v     |
| 23       | 17       | ^W ETB   | 55       | 37       | 7      | 87       | 57       | W      | 119        | 77       | W     |
| 24       | 18       | ^X CAN   | 56       | 38       | 8      | 88       | 58       | X<br>Y | 120<br>121 | 78<br>79 | X     |
| 25       | 19       | ^Y EM    | 57<br>50 | 39       | 9      | 89       | 59       |        | 121        | 79<br>7A | Ϋ́    |
| 26<br>27 | 1A       | ^Z SUB   | 58<br>59 | 3A<br>3B | :      | 90<br>91 | 5A<br>5B | Z      | 123        | 7B       | Z     |
| 28       | 1B<br>1C | ESC      | 60       | 3C       | ;<br>< | 91<br>92 | 5C       | [      | 123        | 7E<br>7C | 1     |
| 26<br>29 | 1D       | FS<br>GS | 61       | 3D       | =      | 92<br>93 | 5D       | ]      | 124        | 7D       | 1     |
| 30       | 1E       | RS       | 62       | 3E       | >      | 93<br>94 | 5E       | 7      | 126        | 7E       | ~     |
| 31       | 1E<br>1F | US       | 62<br>63 | 3F       | ?      | 95       | 5F       |        | 127        | 7E<br>7E | DEL   |
| ĴΙ       | TT       | OD       | 05       | JΓ       | -      | 90       | OL.      |        | 12/        | 12       | لدندي |