# Model PCL-724

24 Bit Digital I/O Card

# PCL-724 24 BIT DIGITAL I/O CARD

# **USER'S MANUAL**

This documentation is copyrighted 1993 by Advantech Co., Ltd. All rights are reserved. Advantech Co., Ltd. reserves the right to make improvements in the products described in this manual at any time without notice.

No part of this manual may be reproduced, copied, translated or transmitted, in any form or by any means without the prior written permission of Advantech Co., Ltd. Information provided in this manual is intended to be accurate and reliable. However, Advantech Co., Ltd. assumes no responsibility for its use, nor for any infringements of rights of third parties which may result from its use.

PC-LabCard is a trademark of Advantech Co., Ltd. IBM, PC, PC/XT and PC/AT are *trademarks* of International Business Machines Corporation. OPTO-22 is a trademark of OPTO-22 Corporation.

> Part No. 2003724010 Rev.A2 Printed in Taiwan Aug. 1993

# TABLE OF CONTENTS

| CHAPTER 1 GENERAL INFORMATION | 1  |
|-------------------------------|----|
| 1.1. Introduction             | 1  |
| 1.2. Features                 | 2  |
| 1.3. Applications             | 2  |
| 1.4. Specifications           | 2  |
| CHAPTER 2 INSTALLATION        | 5  |
| 2.1. Initial Inspection       | 5  |
| 2.2. Base Address Setting     | 6  |
| 2.3. Interrupt Settings       | 7  |
| CHAPTER 3 OPERATION           | 9  |
| 3.1. Configuration            | 9  |
| 3.2. Interrupt Handling       | 12 |
| CHAPTER 4 PROGRAMMING         | 13 |
| 4.1. Programming Notes        | 13 |
| 4.2. Programming Examples     | 14 |

# **CHAPTER 1 GENERAL INFORMATION**

### **1.1. Introduction**

The PCL-724 24 bit DIO card is a generalized 24 line parallel digital I/O capability, and emulates mode 0 of an 8255 programmable peripheral interface chip. With its 50-pin, OPTO-22 compatible connector, the PCL-724 is especially suitable for SSR I/O module control. Additionally, one line of the PCL-724 can be used to generate a hardware interrupt to your PC.



Figure 1-1 PCL-724 BLOCK DIAGRAM

- \* 24 TTL digital I/O lines, (6 connectors, each with 24 I/O lines).
- \* Emulates mode O of 8255 PPI
- \* Programmable interrupt handling
- " OPTO-22 compatible 50-pin connector

### **1.3. Applications**

- \* Industrial AC/DC I/O module monitoring and control
- \* Relay and switch monitoring and control
- \* Parallel data transfer
- \* Sensing the signals of TTL, DTL, CMOS logic
- \* Driving indicator LED's

### **1.4. Electrical Specifications**

### Input signal

Input logic high voltage : 2.0 V -- 5.25 V Input logic low voltage : 0.0 V -- 0.80 V High level input current : 20.0 uA Low level input current : - 0.2 mA

### **Output signal**

output logic high voltage : 2.4 V (min) output logic low voltage : 0.4 V (max) High level output current : -15.0 mA Low level output current : 24.0 mA

# Transfer rate

Typical : 300 K bytes/sec Maximum : 500 K bytes/sec

### **Power consumption**

Typical power : 0.5 A @ 5V DC(+ 5%)

Maximum power : 0.8 A @ 5V DC(+ 5%)

### Connector

One 50-pin connector (CN1) OPTO-22 compatible

| PC 7 | 1  | 2  | GND |
|------|----|----|-----|
| PC 6 | 3  | 4  | GND |
| PC 5 | 5  | 6  | GND |
| PC 4 | 7  | 8  | GND |
| PC 3 | 9  | 10 | GND |
| PC 2 | 11 | 12 | GND |
| PC 1 | 13 | 14 | GND |
| PC 0 | 15 | 16 | GND |
| PB 7 | 17 | 18 | GND |
| PB 6 | 19 | 20 | GND |
| PB 5 | 21 | 22 | GND |
| рв 4 | 23 | 24 | GND |
| РВ 3 | 25 | 26 | GND |
| PB 2 | 27 | 28 | GND |
| PB 1 | 29 | 30 | GND |
| рв 0 | 31 | 32 | GND |
| PA 7 | 33 | 34 | GND |
| PA 6 | 35 | 36 | GND |
| PA 5 | 37 | 38 | GND |
| PA 4 | 39 | 40 | GND |
| PA 3 | 41 | 42 | GND |
| PA 2 | 43 | 44 | GND |
| PA 1 | 45 | 46 | GND |
| PA O | 47 | 48 | GND |
| +5V  | 49 | 50 | GND |
|      | L  |    | ł   |

#### CONNECTOR PIN ASSIGNMENT

.....

If you like, you can also access the signals on CN1 by attaching connectors to the holes in the PCB at CN2 and CN3 by yourself. The pin assignments are as follows.

|                                                             | C                                                   | N2                                                   |                                                              |                                        | C                            | N3                           |                                         |
|-------------------------------------------------------------|-----------------------------------------------------|------------------------------------------------------|--------------------------------------------------------------|----------------------------------------|------------------------------|------------------------------|-----------------------------------------|
| PA0<br>PA2<br>PA4<br>PB0<br>PB2<br>PB4<br>PB6<br>GND<br>+5V | 1<br>3<br>5<br>7<br>9<br>11<br>13<br>15<br>17<br>19 | 2<br>4<br>6<br>8<br>10<br>12<br>14<br>16<br>18<br>20 | PA1<br>PA3<br>PA5<br>PB1<br>PB3<br>PB5<br>PB7<br>GND<br>+12V | PC0<br>PC2<br>PC4<br>PC6<br>GND<br>+5V | 1<br>3<br>5<br>7<br>17<br>19 | 2<br>4<br>6<br>8<br>18<br>20 | PC1<br>PC3<br>PC5<br>PC7<br>GND<br>+12V |

# **Operating environment**

| Temperature       | : | 0 °C to 70 °C            |
|-------------------|---|--------------------------|
| Relative humidity | : | 5% to 90%, noncondensing |

# Storage environment

| Temperature       | : | -55 °C to 150 °C         |
|-------------------|---|--------------------------|
| Relative humidity | : | 5% to 90%, noncondensing |

### Dimensions

| Dimensions    | : | 125.0 mm by 99.5 mm                |
|---------------|---|------------------------------------|
| I/O connector | : | 50 pin male ribbon cable connector |

# **CHAPPER 2 INSTALLATION**

# 2.1. Initial Inspection

Before installing the PCL-724 into your PC, first check to make sure that the contents of this package include the following:

1 PCL-724 24-bit Digital I/O Card 1 User's Manual

If anything is damaged due to shipping or appears to be defective, please contact your local dealer.

### **CAUTION !**

Do not install or remove the PCL-724 I/O board while the power is ON, as this may damage the plug-in board, computer, or both. Always ensure that the power has been turned OFF before proceeding with installation or removal.

The following diagram shows PCL-724' s switch and jumpers location



### 2.2. Base Address Setting

The PCL-724 requires four consecutive address locations within your PC s I/O space. Some I/O address locations will be occupied by internal I/O and peripherals devices. In order to avoid conflicts with these devices, the PCL-724 address can be set by a 8-position DIP switch, and placed anywhere in the IBM PC decoded external UO space. Address can range from 200 to 3FF (in hexdecimal), though you should check with the IBM Standard Technical Reference Manual for possible conflicts with commonly installed peripherals.

The required SWITCH settings for the BASE addresses are specified below:

| I/O PORT                   |         |         | SWIT    | CH POS  | SITION  | r (SW1  | )       |        | · <b>_</b> |
|----------------------------|---------|---------|---------|---------|---------|---------|---------|--------|------------|
| ADDRESSES<br>(HEXADECIMAL) | 1<br>A8 | 2<br>A7 | 3<br>A6 | 4<br>A5 | 5<br>A4 | 6<br>A3 | 7<br>A2 | 8<br>- |            |
| 200 - 203                  | 0       | 0       | 0       | 0       | 0       | 0       | 0       | Х      |            |
| 2C0 - 2C3*                 | 0       | 1       | 1       | 0       | 0       | 0       | 0       | Х      |            |
| <br>3FC - 3FF              | 1       | 1       | 1       | 1       | 1       | 1       | 1       | x      |            |

- **NOTE:** 1. 0 = ON, 1 = OFF
  - 2. "X" means "don't care"
  - 3. 1..8 are switch positions
  - 4. A2 through A9 correspond to address lines of the PC bus
  - 5. \* means factory setting

### 2.4. Interrupt Settings

The PCL-724 provides one I/O line (PCO) that generates a hardware interrupt to your PC. The IRQ level is determined by setting jumper, J1.

$$\begin{array}{c|ccccc}
 & J1 \\
IRQ & 2 & 0 & 0 \\
 & 3 & 0 & 0 \\
 & 4 & 0 & 0 \\
 & 5 & 0 & 0 \\
 & 5 & 0 & 0 \\
 & 6 & 0 & 0 \\
 & 7 & 0 & 0 \\
\end{array}$$
(Default Setting)

The interrupt capability of PC0 is controlled by setting jumper, J2. If J2 is set to DIS, then the interrupt capability is always disabled. Alternatively, if J2 is set to EN, then the card's interrupt capability is always enabled. In order to use the PCL-724's programmable interrupt feature, set J2 to PGM.

If J2 is set to PGM, I/O line, PC4, will enable the interrupt if it goes TTL LOW. If PC4 goes TTL HIGH, then the interrupt will be disabled.



(Default Setting)

Set J3 to select the interrupt's trigger edge: rising or falling. See the illustration below:



(Default Setting)

If you set the PCL-724 to trap on a rising edge change, then an interrupt will generate if PC0 changes from TTL LOW to TTL HIGH. Conversely, if you set the card to trap on a falling edge change, then it will generate an interrupt when PC0 changes from TTL HIGH to LOW HIGH.

# **CHAPTER 3 OPERATION**

The PCL-724 card emulates MODE 0 of 8255 PPI, and is pin compatible with most industrial solid state I/O racks and modules such as those manufactured by OPTO-22, Potter Brumfield, Gordos, etc.

The PCL-724 uses a 50-pin male IDC connectors to interface with OPTO-22 racks.

One of the PCL-724's I/O lines (PC-0) can be used to generate a hardware interrupt.

Note: The PCL-724 emulates MODE 0 of 8255 PPI, it is in effect the same as an 8255 controller card, and all packages or programs that support the 8255 in MODE 0 can be used on PCL-724 without reconfiguring software.

### 3.1. Configuration

Mode 0 of 8255 provides simple input/output functions. No handshaking is required since data is written directly to or read from a specified port (see 8255 MODE 0 Function Definitions).

PCL-724's read-back function is another useful function that allows you to monitor each output port.

### **8255 MODE 0 FUNCTION DEFINITIONS**

- Two 8-bit ports (Port A, Port B)
- Two 4-bit ports (Port C upper, Port C lower)
- Any port can be used for input or output
- Outputs are latched whereas inputs are not latched
- 16 different input/output configurations are available in this mode.

| Register | Address          | Function   |
|----------|------------------|------------|
| Port A   | BASE ADDRESS + 0 | Read/Write |
| Port B   | BASE ADDRESS + 1 | Read/Write |
| Port C   | BASE ADDRESS + 2 | Read/Write |
| CFG REG. | BASE ADDRESS + 3 | Write Only |

Fig. 3.1 8255 address map

**EXAMPLE** : Base address set at 2A0

|          | Address |
|----------|---------|
| Port A   | 2A0     |
| Port B   | 2A1     |
| Port C   | 2A2     |
| CFG Port | 2A3     |



Fig. 3.2 CFG register format (mode 0)

The following table lists all possible configured "commands" to configure 8255 in mode 0.

|         | D4        | D3        | D1        | D0        |
|---------|-----------|-----------|-----------|-----------|
| Config. | PA0 - PA7 | PC4 - PC7 | PB0 - PB7 | PC0 - PC3 |
| 80H     | output    | output    | output    | output    |
| 81H     | output    | output    | output    | input     |
| 82H     | output    | output    | input     | output    |
| 83H     | output    | output    | input     | input     |
| 88H     | output    | input     | output    | output    |
| 89H     | output    | input     | output    | input     |
| 8AH     | output    | input     | input     | output    |
| 8BH     | output    | input     | input     | input     |
| 90н     | input     | output    | output    | output    |
| 91H     | input     | output    | output    | input     |
| 92н     | input     | output    | input     | output    |
| 93н     | input     | output    | input     | input     |
| 98H     | input     | input     | output    | output    |
| 99н     | input     | input     | output    | input     |
| 9АН     | input     | input     | input     | output    |
| 9вн     | input     | input     | input     | input     |

8255 Mode O Configuration Table

### **3.2. Interrupt Handling**

The PCL-724's I/O line, PC0, can generate a hardware interrupt to your PC. Interrupts are edge-triggered (Please refer to Chapter 2 for the appropriate jumper setting and description).

To use the interrupt capability via PC0 you must determine the IRQ level to be used. Do this by simply closing the appropriate pins on J1 to select the desired interrupt level (IRQ 2 through 7). Then close J2 to select the desired interrupt enable mode (EN or PGM). Now, determine whether or not you want to trap either a rising edge signal or falling edge signal change.

**Note :** Since the PCL-724's digital input data are not latched, no "first event" trapping is provided to determine which input was active first.

Although interrupts are normally triggered by external signals, the PCL-724 can send output data to emulate an interrupt singal.

See the example in the next chapter.

# **CHAPTER 4 PROGRAMMING**

### 4.1. Programming Notes

The PCL-724's signal direction can be INPUT or OUTPUT from a software program . However, after you turn on or hardware reset your PC, all of the PCL-724's ports will automatically be configured as INPUT.

When the PCL-724 is programmed as an output port for the first time, it will not output until you execute the first output instruction. This action safeguards your external device from being damaged before it is initialized,



Figure 4.1 Signal Direction of PCL-724

- 1. The output driver is disabled (high impedance) when the port is set to INPUT or after RESET.
- 2. The output data written to the port is latched in the OUTPUT DATA LATCH no matter the port is set as INPUT or OUTPUT.
- 3. When the port is set as OUTPUT, the input circuit is used as output status read-back.
- 4. The data in the OUTPUT DATA LATCH is in a random status after power on. It must be initialized before setting the port to output direction.

#### 4.2. Programming Examples

The PCL-724 is easily programmed and the following section lists some program examples. All the program examples below have been fully tested on PC-XT/AT or compatible computers.

Note : The following programs should be run under Turbo C version 1.5 or 2.0.

#### EXAMPLE 1 :

```
This demo program demonstrates how to use the read back
                                                     *
* function of the PCL-724 to monitor the output status.
                                                     *
* HARDWARE SETTING :
                                                     *
        1. Base address set at 0x2CO
#include <stdio.h>
#include <conio.h>
#include <process.h>
#include <dos.h>
main()
      base = 0x2c0; /* set base address at 2CO (in hex) */
int
                                                  */
int
      portA;
                  /" save read back value of port A
                  /* save read back value of port B
int
     portB;
                                                  */
                   /* save read back value of port C
                                                  */
int
      portC;
int
      i,j;
/* screen handle x/
clrscr();
gotoxy(30,3);
textattr(0x70);
cputs("PCL-724 DEMO PROGRAME");
gotoxy(11,6);
printf("Port A output value --> ");
gotoxy(11,8);
printf("Port B output value --> ");
gotoxy(11,10);
printf("Port C output value --> ");
gotoxy(50,6);
printf("ReadBack -->");
gotoxy(50,8);
printf("ReadBack -->");
gotoxy(50,10);
printf("ReadBack -->");
```

```
/* Initialization */
   outportb (0x2c3, 0x80); /* all as output */
/************************* main program **********************/
for(j=0;j<0x100;j++)</pre>
  {
    outportb ( base, j); /* out j to port A */
    gotoxy(34,6);
    printf("%2x",j);
    portA = inportb (base); /" read back */
    gotoxy(63,6);
    printf("%2x",portA);
     if ( portA != j)
     {
       printf("\7");
                      /* beep */
       gotoxy(30,13);
       textattr(0x09);
       cprintf("Port A readback error!");
       getch();
                      /* quit to dos */
       exit(1);
     }
    outportb ( base+1, j); /* out j to port B */
    gotoxy(34,8);
    printf("%2x",j);
    portB = inportb (base+1); /" read back */
    gotoxy(63,8);
    printf("%2x",portB);
     if ( portB != j)
     {
       printf("\7"); /* beep */
       gotoxy(30,13);
       textattr(0x09);
       cprintf("Port B readback error!");
       getch();
       exit(1);
                      /* quit to dos */
     }
    outportb ( base+2, j); /* out j to port C */
    gotoxy(34,10);
    printf("%2x",j);
    portC = inportb (base+2); /" read back */
    gotoxy(63,10);
    printf("%2x",portC);
     if ( portC != j)
     ł
       printf("\7"); /* beep */
       gotoxy(30,13);
       textattr(0x09);
       cprintf("Port C readback error!");
       getch();
       exit(1); /* quit to dos */
     }
  }
}
```

### EXAMPLE 2 :

```
* This demo program demonstrates how to use the PCL-724's
* interrupt function (trapping a rising edge).
                                                       *
                                                       *
* HARDWARE SETTING :
                                                       *
        1. Base address set at 0X2C0
                                                       *
*
        2. J1 set at IRQ 2
*
        3. J2 set at EN or PGM
                                                       *
                                                       *
*
        4. J3 set at RISING trigger
#include <dos.h>
#include <stdio.h>
#include <conio.h>
/* new INT OAH ISR */
void interrupt alarm (void)
char Port61_0ld_Status;
char Port61_New_Status;
int DelayTime = 0x300;
int Count = 0;
int i;
/** get original port 61H status, and save it **/
Port61_New_Status = Port61_Old_Status = inportb(0x61);
/** set port 61h bitl = '0' **/
Port61_New_Status &= Oxfd; /* 1111 1101 in binary */
for ( Count=0 ; Count<0x300 ; Count++ , DelayTime--)</pre>
      ł
       Port61_New_Status ^= 0x02; /* On/Off bitl */
      outportb (0x61 , Port61_New_Status);
      for (i=0 ; i<DelayTime ; i++);</pre>
      }
outportb (0x61 , Port61_Old_Status);
outportb (0x20, 0x20);
                                 /* send EOI to 8259 */
}
void main()
int IMR;
void interrupt (*Int_A_Old_Vector)();
Int_A_Old_Vector = getvect(0x0a); /* get old int Oah ISR */
setvet (OxOa , alarm);
                              /* set new int Oah ISR */
```

Programming PCL-724 IMR = inportb(0x21); /\* get 8259 interrupt mask register \*/ /\* initialization \*/ outportb (0x2c3 , 0x80); /\* set Port A, Port B and Port C \*/ /\* all as output ports \*/ outportb (0x2c0, 0x0); /\* Port A \*/ outportb (0x2c1, 0x0); outportb (0x2c2, 0x0); /\* Port B \*/ /\* PC-4=0-->interrupt enable \*/ /\* PCO=0 \* / clrscr(); printf("Press any key to generate a rising edge interrupt"); getch(); outportb(0x21,0xfb & IMR); /\* set IRQ2 nonmasked \*/ printf("\n\nPort C = %x",inportb(0x2c2)); /\* generate a rising edge signal at PCO \*/ outportb (0x2c2 , 0x1); printf("\n\nPort C = %x",inportb(0x2c2)); printf("\n\npress any key to quit..."); getch(); /" restore old INT OAH ISR \*/ setvect (OxOa , Int\_A\_Old\_Vector); outportb(Ox21,IMR); /\* restore 8259 interrupt mask \*/ /\* set as INPUT to release IRQ2 line \*/ outportb(0x2c3,0x9b); }