

Series PMC521 Octal EIA/TIA-422B Communication Module

**USER'S MANUAL** 

ACROMAG INCORPORATED 30765 South Wixom Road Wixom, MI 48393-2417 U.S.A. Tel: (248) 295-0310 Fax: (248) 624-9234

Copyright 2007, Acromag, Inc., Printed in the USA. Data and specifications are subject to change without notice.

8500756E

### TABLE OF CONTENTS

The information of this manual may change without notice. Acromag makes no warranty of any kind with regard to this material, including, but not limited to, the implied warranties of merchantability and fitness for a particular purpose. Further, Acromag assumes no responsibility for any errors that may appear in this manual and makes no commitment to update, or keep current, the information contained in this manual. No part of this manual may be copied or reproduced in any form without the prior written consent of Acromag, Inc.

### IMPORTANT SAFETY CONSIDERATIONS

You must consider the possible negative effects of power, wiring, component, sensor, or software failure in the design of any type of control or monitoring system. This is very important where property loss or human life is involved. It is important that you perform satisfactory overall system design and it is agreed between you and Acromag, that this is your responsibility.

### **1.0 General Information**

| KEY 521 FEATURES           | 4 |
|----------------------------|---|
| PCI INTERFACE FEATURES     | 5 |
| SIGNAL INTERFACE PRODUCTS  | 5 |
| Board DLL Control Software | 6 |
| Board VxWORKS Software     | 6 |
| Board QNX Software         | 6 |

### 2.0 PREPARATION FOR USE

| UNPACKING AND INSPECTION     | 7 |
|------------------------------|---|
| CARD CAGE CONSIDERATIONS     | 7 |
| BOARD CONFIGURATION          | 7 |
| Default Configuration        | 7 |
| Front Panel I/O              | 8 |
| Rear J4 Field I/O Connector  | 9 |
| Non-Isolation Considerations | 9 |

### 3.0 PROGRAMMING INFORMATION

| PCI CONFIGURATION ADDRESS SPACE       | 10 |
|---------------------------------------|----|
| PCI configuration address space       | 10 |
| Configuration registers               | 10 |
| MEMORY MAP                            | 11 |
| Global Interrupt Status Register      | 14 |
| 8XMODE                                | 14 |
| RESET                                 | 14 |
| Global Interrupt Enable               | 14 |
| RHR – Receive Holding Register        | 15 |
| THR – Receive Holding Register        | 15 |
| DLL and DLM – Divisor Latch Registers | 15 |
| IER - Interrupt Enable Register       | 16 |
| ISR - Interrupt Status Register       | 17 |
| FCR – FIFO Control Register           | 19 |
| LCR – Line Control Register           | 20 |
| MCR – Modem Control Register          | 21 |
| LSR – Line Status Register            | 22 |
| MSR – Modem Status Register           | 23 |
| SCR – Scratch Pad Register            | 24 |
| FCTR – Feature Control Register       | 24 |
| EFR – Enhanced Feature Register       | 25 |
| TXCNT – Transmit FIFO Level Counter   | 26 |
| TXTRG – Transmit FIFO Trigger Level   | 26 |
| RXCNT – Receive FIFO Level Counter    | 27 |
| RXTRG – Receive FIFO Trigger Level    | 27 |
| XCHAR Register                        | 27 |
| XON/XOFF – 1,2 Registers              | 27 |
| =                                     |    |

|     | Read RX FIFO Register             | 27       |
|-----|-----------------------------------|----------|
|     | Write TX FIFO Register            | 27       |
|     | Read RX FIFO with Errors Register | 28       |
|     | THE EFFECT OF RESET               | 28       |
|     | PMC521 PROGRAMMING CONSIDERATIONS | 29       |
|     | FIFO Polled Mode                  | 29       |
|     | FIFO Interrupt Mode               | 29       |
|     | Loopback Mode Operation           | 30       |
|     | Software Flow Control             | 30       |
|     | Hardware Flow Control             | 31       |
|     | Programming Example               | 32       |
| 4.0 | THEORY OF OPERATION               |          |
|     | EIA/TIA-422B SERIAL INTERFACE     | 33       |
|     | PMC521 OPERATION                  | 34       |
|     | LOGIC/POWER INTERFACE             | 35       |
|     |                                   | 55       |
| 5.0 | SERVICE AND REPAIR                |          |
| ••• | SERVICE AND REPAIR ASSISTANCE     | 36       |
|     | PRELIMINARY SERVICE PROCEDURE     | 36       |
|     | WHERE TO GET HELP                 | 36       |
| 60  | SPECIFICATIONS                    |          |
| 0.0 |                                   | 27       |
|     | PHYSICAL                          | 37       |
|     |                                   | 37       |
|     |                                   | 38       |
|     | RS-422/485 CHANNELS               | 38       |
|     | RS-422/485 TRANSMITTER OUTPUTS    | 38       |
|     | RS-422/485 RECEIVER INPUTS        | 38       |
|     | PCI LOCAL BUS INTERFACE           | 38       |
| AP  | PENDIX                            |          |
|     | CABLE: MODEL 5028-432             | 40       |
|     | TERMINATION PANEL: MODEL 5025-288 | 40       |
| DR  | AWINGS                            |          |
|     | 4502-021 PMC521 BLOCK DIAGRAM     | 41       |
|     |                                   |          |
|     | 4502-020 PMC521 INTERFACE DIAGRAM | 42       |
|     | 4502-020 PMC521 INTERFACE DIAGRAM | 42<br>43 |
|     |                                   |          |

Trademarks are the property of their respective owners.

### **RELATED PUBLICATIONS**

The following datasheet provides additional information for in depth understanding of the PMC521.

XR17D158 Datasheet

http://www.exar.com

### TABLE OF CONTENTS

# 1.0 GENERAL INFORMATION

**Table 1.1:** The PMC521 boards are available in standard and extended temperature ranges

### KEY PMC521 FEATURES

The PMC521 board provides eight EIA/TIA-422B serial communication channels from a single PMC socket. The EIA/TIA-485 standard is also supported.

The transmit and receive paths of each channel include generous 64byte FIFO buffers to minimize CPU interaction. Character size, stop bits, parity, and baud rate are software configurable. Prioritized interrupt generation is also supported for transmit, receive, line status, and data set conditions. The PMC521 utilizes state of the art Surface-Mounted Technology (SMT) to achieve its wide functionality and is an ideal choice for a wide range of industrial communication interface applications that require a highly reliable, high-performance interface at a low cost.

| MODEL    | Board Form<br>Factor             | Description                    | OPERATING<br>TEMPERATURE<br>RANGE |
|----------|----------------------------------|--------------------------------|-----------------------------------|
| PMC521   | PCI Mezzanine<br>Card            | Eight EIA/TIA-422B<br>Channels | 0°C to +70°C                      |
| PMC521R  | PCI Mezzanine<br>Card (Rear I/O) | Eight EIA/TIA-422B<br>Channels | 0°C to +70°C                      |
| PMC521E  | PCI Mezzanine<br>Card            | Eight EIA/TIA-422B<br>Channels | -40°C to +85°C                    |
| PMC521RE | PCI Mezzanine<br>Card (Rear I/O) | Eight EIA/TIA-422B<br>Channels | -40°C to +85°C                    |

- **High density –** Provides programmable control of eight EIA/TIA-422B serial channels.
- **64-Character FIFO Buffers -** Both the transmit and receive channels of each serial port provide 64-byte data buffering to reduce CPU interactions and interrupts. This allows the external processor to handle more tasks within a given time.
- **Programmable Character Size** Each serial port is software programmable for 5, 6, 7, or 8 bit character sizes.
- **Programmable Stop Bits** Each serial port allows 1, 1-1/2, or 2 stopbits to be added to, or deleted from, the serial data stream.
- **Programmable Parity Generation & Detection** Even, Odd, or No Parity generation and detection is supported.
- Line-Break Generation & Detection provision for sending and detecting the line break character is provided.
- False Start Bit Detection Prevents the receiver from assembling false data characters due to low-going noise spikes on the RX input line.
- **Programmable Baud Rate** The internal baud rate generator allows a 921.6K baud rate to be divided by any divisor between 1 and (2<sup>16</sup> 1), providing support for all standard baud rates. Note an additional multiplication factor of two is available resulting in a 1.8432M maximum baud rate using the standard crystal. Baud rates up to 3.000Mbps are available with a user-specified crystal.
- Interrupt Support Individually controlled transmit empty, receive ready, line status, data set, & flow control interrupts may be generated.

- Internal Diagnostic Capabilities Loopback controls for communication link fault isolation are included. Break, parity, overrun, and framing error simulation are also possible.
- **Compatible with Industry Standard UARTs** Each UART of this PMC module has its own 16550 UART compatible configuration register set.
- **Software Flow Control** One or two sequential receive data characters are compared to a programmed Xon or Xoff character value. Data transmission can be suspended or resumed via software flow control.
- Hardware (CTS) Flow Control The CTS signal is monitored for remote buffer overflow indication and will suspend transmissions if it becomes active.
- **High density –** Single-width PMC Target module.
- Field Connections All eight EIA/TIA-422B serial channels connections are made through a single 68-pin SCSI front panel I/O connector. Models PMC521R and PMC521RE, only use J4 64 pin rear I/O connector.
- **32, 16, 8-bit I/O** Register Read/Write is performed through data transfer cycles in the PCI memory space. All registers can be accessed via 32, 16, or 8-bit data transfers.
- Compatibility Complies to PCI Local Bus Specification Revision 2.3. Provides one multifunction interrupt. Universal PCI Bus buffers – Auto sense 3.3V or 5V operation.

Cables and a termination panel are also available to interface with this board, via the 68 pin SCSI front panel connector.

### Cable:

Model 5028-432: A 2-meter, round 68 conductor shielded cable with a male SCSI-3 connector at both ends and 34 twisted pairs. The cable is used for connecting the board to Model 5025-288 termination panels. For optimum performance, use the shortest possible length of shielded input cable.

### **Termination Panel:**

Model 5025-288: DIN-rail mountable panel provides 68 screw terminals for universal field I/O termination. Connects to Acromag board, via SCSI-3 to twisted pair cable described above.

### KEY PMC521 FEATURES

### PCI INTERFACE FEATURES

### SIGNAL INTERFACE PRODUCTS

See the Appendix for further information on these products.

h

| BOARD DLL CONTROL<br>SOFTWARE | Acromag provides a software product (sold separately) to facilitate the development of Windows (98/Me/2000/XP®) applications accessing Acromag PMC I/O board products, PCI I/O Cards, and CompactPCI I/O Cards. This software (Model PCISW-API-WIN) consists of low-level drivers and Windows 32 Dynamic Link Libraries (DLLs) that are compatible with a number of programming environments including Visual C++ <sup>™</sup> , Visual Basic®, Borland C++ Builder® and others. The DLL functions provide a high-level interface to boards eliminating the need to perform low-level reads/writes of registers, and the writing of interrupt handlers. |
|-------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BOARD VxWORKS<br>SOFTWARE     | Acromag provides a software product (sold separately) consisting of<br>board VxWorks® software. This software (Model PMCSW-API-VXW) is<br>composed of VxWorks® (real time operating system) libraries for all<br>Acromag PMC I/O board products, PCI I/O Cards, and CompactPCI I/O<br>Cards. The software is implemented as a library of "C" functions which link<br>with existing user code to make possible simple control of all Acromag PMC<br>boards.                                                                                                                                                                                              |
| BOARD QNX<br>SOFTWARE         | Acromag provides a software product (sold separately) consisting of board QNX® software. This software (Model PCISW-API-QNX) is composed of QNX® (real time operating system) libraries for all Acromag PMC I/O board products, PCI I/O Cards, and CompactPCI I/O Cards. The software is implemented as a library of "C" functions which link with existing user code to make possible simple control of all Acromag PMC boards.                                                                                                                                                                                                                        |

Upon receipt of this product, inspect the shipping carton for evidence of mishandling during transit. If the shipping carton is badly damaged or water stained, request that the carrier's agent be present when the carton is opened. If the carrier's agent is absent when the carton is opened and the contents of the carton are damaged, keep the carton and packing material for the agent's inspection.

For repairs to a product damaged in shipment, refer to the Acromag Service Policy to obtain return instructions. It is suggested that salvageable shipping cartons and packing material be saved for future use in the event the product must be shipped.

This board is physically protected with packing material and electrically protected with an anti-static bag during shipment. However, it is recommended that the board be visually inspected for evidence of mishandling prior to applying power.

Refer to the specifications for loading and power requirements. Be sure that the system power supplies are able to accommodate the power requirements of the carrier/CPU board, plus the installed boards, within the voltage tolerances specified.

Adequate air circulation must be provided to prevent a temperature rise above the maximum operating temperature and to prolong the life of the electronics. If the installation is in an industrial environment and the board is exposed to environmental air, careful consideration should be given to airfiltering.

Remove power from the system before installing board, cables, termination panels, and field wiring.

The board may be configured differently, depending on the application. When the board is shipped from the factory, it is configured as follows:

- The default configuration of the programmable software control register bits at power-up are described in section 3.
- The control registers must be programmed to the desired configuration before starting data input or output operation.

### 2.0 PREPARATION FOR USE

### UNPACKING AND INSPECTION



WARNING: This board utilizes static sensitive components and should only be handled at a staticsafe workstation.

### CARD CAGE CONSIDERATIONS

*IMPORTANT:* Adequate air circulation must be provided to prevent a temperature rise above the maximum operating temperature.

### BOARD CONFIGURATION

**Default Configuration** 

# Front Panel Field I/O Connector

The front panel connector provides the field I/O interface connections. It is a SCSI-3 68-pin female connector (AMP 787082-7 or equivalent) employing latch blocks and 30 micron gold in the mating area (per MIL-G-45214, Type II, Grade C). Connects to Acromag termination panel 5025-288 from the front panel via round shielded cable (Model 5028-432).

All eight EIA/TIA-422B serial communication channels for interfacing are shown in table 2.1. Each channel has eight signals and are designated by channels 0 through channel 7.

| Pin Description | Pin | Pin Description | Pin |
|-----------------|-----|-----------------|-----|
| TX0+            | 1   | TX4+            | 35  |
| TX0-            | 2   | TX4-            | 36  |
| RX0+            | 3   | RX4+            | 37  |
| RX0-            | 4   | RX4-            | 38  |
| RTS0+           | 5   | RTS4+           | 39  |
| RTS0-           | 6   | RTS4-           | 40  |
| CTS0+           | 7   | CTS4+           | 41  |
| CTS0-           | 8   | CTS4-           | 42  |
| TX1+            | 9   | TX5+            | 43  |
| TX1-            | 10  | TX5-            | 44  |
| RX1+            | 11  | RX5+            | 45  |
| RX1-            | 12  | RX5-            | 46  |
| RTS1+           | 13  | RTS5+           | 47  |
| RTS1-           | 14  | RTS5-           | 48  |
| CTS1+           | 15  | CTS5+           | 49  |
| CTS1-           | 16  | CTS5-           | 50  |
| TX2+            | 17  | TX6+            | 51  |
| TX2-            | 18  | TX6-            | 52  |
| RX2+            | 19  | RX6+            | 53  |
| RX2-            | 20  | RX6-            | 54  |
| RTS2+           | 21  | RTS6+           | 55  |
| RTS2-           | 22  | RTS6-           | 56  |
| CTS2+           | 23  | CTS6+           | 57  |
| CTS2-           | 24  | CTS6-           | 58  |
| TX3+            | 25  | TX7+            | 59  |
| TX3-            | 26  | TX7-            | 60  |
| RX3+            | 27  | RX7+            | 61  |
| RX3-            | 28  | RX7-            | 62  |
| RTS3+           | 29  | RTS7+           | 63  |
| RTS3-           | 30  | RTS7-           | 64  |
| CTS3+           | 31  | CTS7+           | 65  |
| CTS3-           | 32  | CTS7-           | 66  |
| COMMON          | 33  | COMMON          | 67  |
| COMMON          | 34  | COMMON          | 68  |

# **Table 2.1:** Board Field I/O Pin Connections

The board has eight EIA/TIA-422B serial communication channels. On models with rear I/O, the J4 PMC connector provides the field I/O interface connections. This connector is a 64-pin female receptacle header (AMP 120527-1 or equivalent) which mates to the male connector on the carrier/CPU board (AMP 120521-1 or equivalent).

All eight EIA/TIA-422B serial communication channels for interfacing are shown in table 2.2. Each channel has eight signals and are designated by channels 0 through channel 7.

| Pin Description | Pin | Pin Description | Pin |
|-----------------|-----|-----------------|-----|
| TX0+            | 1   | TX4+            | 33  |
| TX0-            | 2   | TX4-            | 34  |
| RX0+            | 3   | RX4+            | 35  |
| RX0-            | 4   | RX4-            | 36  |
| RTS0+           | 5   | RTS4+           | 37  |
| RTS0-           | 6   | RTS4-           | 38  |
| CTS0+           | 7   | CTS4+           | 39  |
| CTS0-           | 8   | CTS4-           | 40  |
| TX1+            | 9   | TX5+            | 41  |
| TX1-            | 10  | TX5-            | 42  |
| RX1+            | 11  | RX5+            | 43  |
| RX1-            | 12  | RX5-            | 44  |
| RTS1+           | 13  | RTS5+           | 45  |
| RTS1-           | 14  | RTS5-           | 46  |
| CTS1+           | 15  | CTS5+           | 47  |
| CTS1-           | 16  | CTS5-           | 48  |
| TX2+            | 17  | TX6+            | 49  |
| TX2-            | 18  | TX6-            | 50  |
| RX2+            | 19  | RX6+            | 51  |
| RX2-            | 20  | RX6-            | 52  |
| RTS2+           | 21  | RTS6+           | 53  |
| RTS2-           | 22  | RTS6-           | 54  |
| CTS2+           | 23  | CTS6+           | 55  |
| CTS2-           | 24  | CTS6-           | 56  |
| TX3+            | 25  | TX7+ *          | 57  |
| TX3-            | 26  | TX7-            | 58  |
| RX3+            | 27  | RX7+            | 59  |
| RX3-            | 28  | RX7-            | 60  |
| RTS3+           | 29  | CTS7+           | 61  |
| RTS3-           | 30  | CTS7 -          | 62  |
| CTS3+           | 31  | COMMON          | 63  |
| CTS3-           | 32  | COMMON          | 64  |

Rear J4 Field I/O Connector

**Table 2.2:** Board Rear FieldI/O Pin Connections

The board has eight EIA/TIA-422B serial communication channels.

\* Note: Channel 7 does not use RTS7+ or RTS7- signals due to not enough I/O pins on Rear I/O connector. These signals are used on Front I/O models only.

The board is non-isolated, since there is electrical continuity between the logic and field I/O grounds. As such, the field I/O connections are not isolated from the system. Care should be taken in designing installations without isolation to avoid noise pickup and ground loops caused by multiple ground connections. This is particularly important for analog inputs and outputs when a high level of accuracy/resolution is needed.

### Non-Isolation Considerations

1

| 3.0 PROGRAMMING                    | This Section provides the specific information necessary to program and                                                                                                                                                                                                                                                                                                                                                                                        |
|------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| INFORMATION                        | operate the board.                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                                    | This board is a PCI Specification version 2.3 compliant PCI bus target only board.                                                                                                                                                                                                                                                                                                                                                                             |
|                                    | The PCI bus is defined to address three distinct address spaces: I/O, memory, and configuration space. This board can be accessed via the PCI bus memory space and configuration spaces, only.                                                                                                                                                                                                                                                                 |
|                                    | The card's configuration registers are initialized by system software at<br>power-up to configure the card. The board is a Plug-and-Play PCI card. As<br>a Plug-and-Play card the board's base address and system interrupt request<br>line are not selected via jumpers but are assigned by system software upon<br>power-up via the configuration registers. A PCI bus configuration access is<br>used to read/write the PCI card's configuration registers. |
| PCI Configuration<br>Address Space | When the computer is first powered-up, the computer's system configuration software scans the PCI bus to determine what PCI devices are present. The software also determines the configuration requirements of the PCI card.                                                                                                                                                                                                                                  |
|                                    | The system software accesses the configuration registers to determine<br>how many blocks of memory space the carrier requires. It then programs<br>the board's configuration registers with the unique memory base address.                                                                                                                                                                                                                                    |
|                                    | The configuration registers are also used to indicate that the board requires an interrupt request line. The system software then programs the configuration registers with the interrupt request line assigned to the board.                                                                                                                                                                                                                                  |
|                                    | Since this board is relocatable and not fixed in address space, its device<br>driver must use the mapping information stored in the board's Configuration<br>Space registers to determine where the board is mapped in memory space<br>and which interrupt line will be used.                                                                                                                                                                                  |
| PCI CONFIGURATION<br>REGISTERS     | The PCI specification requires software driven initialization and configuration via the Configuration Address space. This board provides 256 bytes of configuration registers for this purpose. It contains the configuration registers, shown in Table 3.1, to facilitate Plug-and-Play compatibility.                                                                                                                                                        |
|                                    | The Configuration Registers are accessed via the Configuration Address<br>and Data Channels. The most important Configuration Registers are the<br>Base Address Registers and the Interrupt Line Register which must be read<br>to determine the base address assigned to the board and the interrupt<br>request line that goes active on a board interrupt request.                                                                                           |

| Reg.<br>Num. | D31                                            | D24                                        | D23      | D16      | D15           | D8        | D7      | D0     |
|--------------|------------------------------------------------|--------------------------------------------|----------|----------|---------------|-----------|---------|--------|
| 0            |                                                | Device I                                   | D=052    | 1        |               | Vendor ID | )= 16D5 |        |
| 1            |                                                | Sta                                        | itus     |          |               | Comm      | nand    |        |
| 2            |                                                | C                                          | Class Co | ode=0700 | 002           |           | Rev I   | D=02   |
| 3            | BI                                             | BIST Header                                |          | Lat      | Latency Cache |           |         |        |
| 4            | 4 32-bit Memory Base Address for 4K-Byte Block |                                            |          |          |               |           |         |        |
| 5:10         | Not Used                                       |                                            |          |          |               |           |         |        |
| 11           | S                                              | Subsystem ID=0521 Subsystem Vendor ID=16D5 |          |          |               |           |         |        |
| 12           | Not Used                                       |                                            |          |          |               |           |         |        |
| 13,14        | Reserved                                       |                                            |          |          |               |           |         |        |
| 15           | Max                                            | _Lat                                       | Min      | _Gnt     | Inte          | er. Pin   | Inter   | . Line |

**Table 3.1**ConfigurationRegisters

The memory space address map for the board is shown in Table 3.2. Note that the base address for the board in memory space must be added to the addresses shown to properly access the board registers. Register accesses as 32, 24, 16, and 8-bit in memory space are permitted unless otherwise specified.

The memory space consists of two types of registers. The first type is the Device Configuration Registers (Table 3.3). These registers occupy 4K of memory space at Base Address + 80H and are used for general device configuration and monitoring. The second register type consists of each channel's UART configuration registers. These are used to control and monitor the status of the individual channels.

| D07 D00                                                   | LCR       | Base<br>Addr+ |
|-----------------------------------------------------------|-----------|---------------|
| UART Channe                                               | 10        |               |
| READ – RHR<br>Channel 0 - Receive Holding Register        | Bit 7= 0  | 00            |
| WRITE – THR<br>Channel 0 - Transmit Holding Register      | Bit 7 = 0 | 00            |
| READ/WRITE – DLL<br>Channel 0 - Divisor Latch Low         | Bit 7 = 1 | 00            |
| READ/WRITE – DLM<br>Channel 0 - Divisor Latch High        | Bit 7 = 1 | 01            |
| READ/WRITE – IER<br>Channel 0 - Interrupt Enable Register |           | 01            |
| READ – ISR<br>Channel 0 - Interrupt Status Register       |           | 02            |
| WRITE – FCR<br>Channel 0 - FIFO Control Register          |           | 02            |
| READ/WRITE – LCR<br>Channel 0 - Line Control Register     |           | 03            |
| READ/WRITE – MCR<br>Channel 0 - Modem Control Register    |           | 04            |
| READ – LSR<br>Channel 0 - Line Status Register            |           | 05            |

### MEMORY MAP

### **MEMORY MAP**

| D07 D00                                                    | Comments                 | Base<br>Addr+ |
|------------------------------------------------------------|--------------------------|---------------|
| READ – MSR<br>Channel 0 - Modem Status Register            |                          | 06            |
| WRITE – RS485<br>Channel 0 - Turn-Around Delay Register    | Not Supported            | 06            |
| READ/WRITE – SPR<br>Channel 0 - Scratch Pad Register       |                          | 07            |
| READ/WRITE – FCTR<br>Channel 0 – Feature Control Register  |                          | 08            |
| READ/WRITE – EFR<br>Channel 0 – Enhanced Function Register |                          | 09            |
| READ – TXCNT<br>Channel 0 – Transmit FIFO Level Counter    |                          | 0A            |
| WRITE – TXTRG<br>Channel 0 – Transmit FIFO Trigger Level   |                          | 0A            |
| READ – RXCNT<br>Channel 0 – Receive FIFO Level Counter     |                          | 0B            |
| WRITE – RXTRG<br>Channel 0 – Receive FIFO Trigger Level    |                          | 0B            |
| WRITE<br>Channel 0 – Xoff-1 – Xoff Character 1             |                          | 0C            |
| READ<br>Channel 0 – Xchar                                  | Xon, Xoff<br>Rcvd. Flags | 0C            |
| WRITE<br>Channel 0 – Xoff-2 – Xoff Character 2             |                          | 0D            |
| WRITE<br>Channel 0 – Xon-1 – Xon Character 1               |                          | 0E            |
| WRITE<br>Channel 0 – Xon-2 – Xon Character 2               |                          | 0F            |
| Reserved                                                   |                          | 10-7F         |
| DEVICE CONFIGURATION REGISTERS                             | See Table 3.3            | 80-93         |
| Reserved                                                   |                          | 94-FF         |
| READ<br>Channel 0 – Read FIFO                              | Data Width<br>8/16/24/32 | 100-13F       |
| WRITE<br>Channel 0 – Write FIFO                            | Data Width<br>8/16/24/32 | 100-13F       |
| Reserved                                                   |                          | 140-17F       |
| READ<br>Channel 0 – Read FIFO with errors                  | Data Width<br>16/32      | 180-1FF       |
| UART Channel                                               | 1                        |               |
| Channel 1 – Registers                                      |                          | 200-20F       |
| Reserved                                                   |                          | 210-2FF       |
| READ<br>Channel 1 – Read FIFO                              | Data Width<br>8/16/24/32 | 300-33F       |

MEMORY MAP

| D07 D00                                   | Comments                 | Base<br>Addr+ |
|-------------------------------------------|--------------------------|---------------|
| WRITE<br>Channel 1 – Write FIFO           | Data Width<br>8/16/24/32 | 300-33F       |
| Reserved                                  |                          | 340-37F       |
| READ<br>Channel 1 – Read FIFO with errors | Data Width<br>16/32      | 380-3FF       |
| UART Channel 2                            |                          | 400-5FF       |
| UART Channel 3                            |                          | 600-7FF       |
| UART Channel 4                            |                          | 800-9FF       |
| UART Channel 5                            |                          | A00-BFF       |
| UART Channel 6                            |                          | C00-DFF       |
| UART Channel 7                            |                          | E00-FFF       |

Notes (Table 3.2):

 To save user manual space the registers corresponding to channels 1 to 7 have not been individually shown. The registers of channels 1 to 7 are in the address space shown above. To access a register in channel 7, for example, the offset of E00 hex is added to the address of the corresponding register given in table 3.2. All channels require a 512 byte memory block.

| REGISTER                                     | Byte 3<br>[31:24] | Byte 2<br>[23:16] | Byte 1<br>[15:8]    | Byte 0<br>[7:0] | Base<br>Addr+ |
|----------------------------------------------|-------------------|-------------------|---------------------|-----------------|---------------|
| Global<br>Interrupt<br>Status<br>(Read-only) | INT3              | INT2              | INT1                | INT0            | 80-83         |
| Timer<br>(Read/Write)                        | TIMER<br>MSB      | TIMER<br>LSB      | TIMER<br>(reserved) | TIMER<br>CNTL   | 84-87         |
| Ancillary1<br>(Read/Write)                   | SLEEP             | RESET             | REGA<br>(reserved)  | 8XMODE          | 88-8B         |
| Ancillary2<br>(Read-only)                    | MPIOINT           | REGB              | DVID                | DREV            | 8C-8F         |
| MPIO<br>(Read/Write)                         | MPIOSEL           | MPIOINV           | MPIO3T              | MPIOLVL         | 90-93         |

**Table 3.3:** Device ConfigurationRegisters shown in DWORDalignment.

This memory map reflects byte accesses using the "Little Endian" byte ordering format. Little Endian uses even-byte addresses to store the low-order byte. The Intel x86 family of microprocessors uses "Little Endian" byte ordering. Big Endian is the convention used in the Motorola 68000 microprocessor family and is the VMEbus convention. In Big Endian, the lower-order byte is stored at odd-byte addresses.

This board operates in two different modes. In one mode, this device remains software compatible with the industry standard 16C550 family of UART's and provides double-buffering of data registers. In the FIFO Mode (enabled via bit 0 of the FCR register), data registers are FIFO-buffered so that read and write operations can be performed while the UART is performing serial-to-parallel and parallel-to-serial conversions. Two FIFO modes are possible: FIFO Interrupt Mode and FIFO Polled Mode. Some registers operate differently between the available modes and this is noted in the following paragraphs.

### DEVICE CONFIGURATION REGISTERS

**Note:** Only device configuration registers that are supported by the PMC521 are described in this section.

### Global Interrupt Status Register (READ Only)

This 32-bit wide register [INT0, INT1, INT2 and INT3] provides interrupt source and type information. Each of the first 8 bits (INT0) represents a channel and indicates if that channel has requested service. For example INT0 bit-0 represents the interrupt status for channel 0 and INT0 bit-7 represents the interrupt status for channel 7. An interrupt service routine can inspect INT0 to determine that a channel requires service and then read the channel's Interrupt Status Register (ISR) to determine the source of the interrupt.

INT3, INT2 and INT1 [31:8] provide a twenty-four bit encoded interrupt indicator. Each channel's interrupt is encoded into 3 bits for receive, transmit and status. Bits [10:8] represent channel 0, bits [13:11] represent channel 1 and so forth. The table below shows the 3 bit encoding and priority order. This interrupt source encoding provides much of the same interrupt source data that would be obtained by reading each channel's ISR. Interrupt clearing is covered in the description of the Interrupt Status Register

| Priority | Bit[N + 2] | Bit[N + 1] | Bit[N + 0] | Source of the Interrupt                                                                |
|----------|------------|------------|------------|----------------------------------------------------------------------------------------|
| Х        | 0          | 0          | 0          | None                                                                                   |
| 1        | 0          | 0          | 1          | RXRDY and RX Line Status                                                               |
| 2        | 0          | 1          | 0          | RXRDY Timeout                                                                          |
| 3        | 0          | 1          | 1          | TXRDY or THR empty                                                                     |
| 4        | 1          | 1          | 0          | MSR, RTS/CTS or DTR/DSR<br>delta or Xoff/Xon detected or<br>special character detected |

#### UART Channel [7:0] Interrupt Source Encoding

### 8XMODE (Read/Write)

Each bit of this 8-bit register selects an 8X or 16X sampling rate for the corresponding UART channel. Channels 7 to 0 are configured using bits 7 to 0 respectively. Logic 0 (default) selects normal 16X sampling while logic 1 selects 8X sampling rate. Transmit and receive data rates will double by selecting 8X.

### **RESET (Read/Write)**

UART channels 7 to 0 can be reset using bits 7 to 0 respectively. After setting a bit to logic 1, all registers in the corresponding channel will be reset to the default condition. Each bit is self-resetting after it is written.

#### Global Interrupt Enable (Read/Write)

On the PMC521 the UART's multi-purpose input/output 0 (MPIO0) is used internally as a Global Interrupt Enable switch. In order for any UART channel interrupts to be seen by the system, the multi-purpose input/output registers must be configured as follows:

- 1. The MPIOINT, MPIO3T, and MPI03T registers should be left in their default states (all bits low).
- 2. The MPIOSEL register should be set to FEH (FFH is the default). This configures MPIO pin 0 as an output.
- 3. MPIOLVL bits 7 to 1 should be left in their default state (low).
- 4. MPIOLVL bit 0 now acts as the Global Interrupt Enable bit.
  - 0 = Disable Interrupt
  - 1 = Enable Interrupt

### RHR - Receive Holding Register, Channels 0-7 (READ Only)

The Receive Holding Register (RHR) is a serial channel input data register that receives the input data from the receiver shift register. Note that the RHR will only receive data if the transceiver is first enabled to receive data. The transceiver is enabled to receive data by setting bit-0 of the MCR (Modem Control Register) to logic 1.

The RHR holds from 5 to 8 bits of data, as specified by the character size programmed in the Line Control Register (LCR bits 0 and 1). If less than 8 bits are transmitted, then data is right-justified to the LSB. If parity is used, then LCR bit 3 (parity enable) and LCR bit 4 (type of parity) are required. Status for the receiver is provided via the Line-Status Register (LSR). When a full character is received (including parity and stop bits), the data-received indication bit (bit 0) of the LSR is set to 1. The host CPU then reads the Receiver Buffer Register, which resets LSR bit 0 low. If the character is not read prior to a new character transfer between the receiver shift register and the receive holding register, the overrun-error status indication is set in LSR bit 1. If there is a parity error, the error is indicated in LSR bit 2. If a stop bit is not detected, a framing error indication is set in bit 3 of the LSR.

Serial asynchronous data is input to the receiver shift register via the receive data line. From the idle state, this line is monitored for a high-to-low transition (start bit). When the start bit is detected, an internal receiver counter starts counting at the 16x or 8x clock rate. After 8 or 4 clocks the start bit period should be at its center. The start bit is judged valid if it is still low at this point. This is known as false start-bit detection. By verifying the start bit in this manner, it helps to prevent the receiver from assembling an invalid data character due to a low-going noise spike on the receive data line.

### THR - Transmit Holding Register, Channels 0-7 (WRITE Only)

The Transmitter Holding Register (THR) is a serial channel output data register that shifts the data to the transmit data line (TX). However, the THR data will not pass to the TX line unless the transceiver is first enabled. The transceiver must be enabled to transmit data by setting bit-1 of the MCR (Modem Control Register) to logic 1.

The THR holds from 5 to 8 bits of data, as specified by the character size programmed in the Line Control Register. If less than 8 bits are transmitted, then data is entered right-justified to the LSB. This data is framed as required, then shifted to the transmit data line. The THR is also the input register to the transmit FIFO when FIFO operation is enabled by FCR bit-0.

The status of the THR is provided in the Line Status Register (LSR). The THR empty flag in the LSR register is set to a logic 1 when the last data byte is transferred from the THR to the transmit shift register.

### DLL & DLM - Divisor Latch Registers, Channels 0-7 (R/W)

Each channel has its own Baud Rate Generator (BRG) with a prescaler for the transmitter and receiver. A software bit in the Modem Control Register (MCR) controls the prescaler. The MCR register bit-7 sets the prescaler to divide the 14.7456MHz crystal by 1 or 4. The output of the prescaler clocks to the BRG. The BRG further divides this clock by a programmable divisor between 1 and  $2^{(16-1)}$  to obtain a 16x or 8x sampling clock of the serial data rate. Two 8-bit divisor latch registers per channel are used to store the divisors in 16-bit binary format. The DLL register stores the low-order byte of the divisor and DLM stores the high-order byte. These registers default to random values during upon power up and must be loaded during initialization.

# UART CONFIGURATION REGISTERS

### **UART CONFIGURATION** REGISTERS

Table 3.4: Baud Rate Divisors (14.74MHz Clock).

Note: Setting 8XMODE=1 will multiply all baud rates in this table by a factor of two.

Note that bit 7 of the LCR register must first be set high to access the divisor latch registers (DLL and DLM) during a read/write operation.

The relationship between the baud rate, prescaler, divisor, and the 14.7456MHz clock can be summarized in the following equations:

Divisor =  $\frac{14.7456 \text{MHz}}{16 \times \text{Baud Rate} \times \text{Prescaler}}$ with  $8 \times MODE = 0$ 

Divisor =  $\frac{14.7456 \text{MHz}}{8 \times \text{Baud Rate} \times \text{Prescaler}}$ 

with  $8 \times MODE = 1$ 

The Prescaler term represents the state of MCR bit-7 as follows: Prescaler = 1 If MCR bit-7=0 Prescaler = 4If MCR bit-7=1

The following table shows the correct divisor to use for generation of some standard baud rates (based on the 14.7456MHz clock at 16X clock rate). A different external crystal can replace the 14.7456MHz crystal on the circuit board to obtain unique clock rates. You may contact Acromag Applications Engineering to explore options in this area.

| BAUD           | RATE           |         | DIVISOR (    | N)           |
|----------------|----------------|---------|--------------|--------------|
| MCR<br>Bit-7=1 | MCR<br>Bit-7=0 | Decimal | DLM<br>(HEX) | DLL<br>(HEX) |
| 50             | 200            | 4608    | 12           | 00           |
| 300            | 1200           | 768     | 03           | 00           |
| 600            | 2400           | 384     | 01           | 80           |
| 1200           | 4800           | 192     | 00           | C0           |
| 2400           | 9600           | 96      | 00           | 60           |
| 3600           | 14,400         | 64      | 00           | 40           |
| 4800           | 19,200         | 48      | 00           | 30           |
| 7200           | 28,800         | 32      | 00           | 20           |
| 9600           | 38,400         | 24      | 00           | 18           |
| 19,200         | 76,800         | 12      | 00           | 0C           |
| 28,800         | 115,200        | 8       | 00           | 08           |
| 38,400         | 153,600        | 6       | 00           | 06           |
| 57,600         | 230,400        | 4       | 00           | 04           |
| 115,200        | 460,800        | 2       | 00           | 02           |
| 230,400        | 921,600        | 1       | 00           | 01           |

The following table shows the correct divisor to use for generation of some standard baud rates (based on the 14.7456MHz clock at 16X clock rate). A different external crystal can replace the 14.7456MHz crystal on the circuit board to obtain unique clock rates. You may contact Acromag Applications Engineering to explore options in this area.

### IER - Interrupt Enable Register, Channels 0-7 (R/W)

The Interrupt Enable Register is used to independently enable/ disable the serial channel interrupt sources. Each of the eight channels have seven unique interrupt sources which are all mapped to INTA# of the PMC module.

An interrupt source is disabled by setting the corresponding IER bit to logic 0, and enabled by setting the IER bit to logic 1. Note that in order for channel interrupts to be seen by the system, the multi-purpose input/output registers must be configured properly (see the Global Interrupt Enable section).

### Interrupt Enable Register

| IER BIT     | INTERRUPT ACTION                                                                                                      |
|-------------|-----------------------------------------------------------------------------------------------------------------------|
|             | RHR Interrupt Enable                                                                                                  |
| 0           | 0 = Disable Interrupt (default)                                                                                       |
|             | 1 = Enable Interrupt                                                                                                  |
|             | The receive data ready interrupt will be issued when RHR                                                              |
|             | has a data character in the non-FIFO mode or when the                                                                 |
|             |                                                                                                                       |
|             | receive FIFO has reached the programmed trigger level in the FIFO mode. A receive data timeout interrupt will be      |
|             | issued in the FIFO mode when the receive FIFO has not                                                                 |
|             | reached the programmed trigger level and the RX input has                                                             |
|             | been idle for 4 character + 12 bit times.                                                                             |
| 1           |                                                                                                                       |
| 1           | THR Interrupt Enable                                                                                                  |
|             | 0 = Disable Interrupt (default)                                                                                       |
|             | 1 = Enable Interrupt                                                                                                  |
|             | This interrupt is associated with bit-5 in the LSR register. An interrupt is issued whenever the THR becomes empty or |
|             | when data in the FIFO falls below programmed trigger level.                                                           |
| 2           | Receive Line Status Interrupt Enable                                                                                  |
| 2           | 0 = Disable Interrupt (default)                                                                                       |
|             | 1 = Enable Interrupt                                                                                                  |
|             | Any LSR register bits 1, 2, 3 or 4 will generate an LSR                                                               |
|             | immediately when a character received in the RX FIFO has                                                              |
|             | an error.                                                                                                             |
| 3           | Modem Status Interrupt Enable                                                                                         |
| 5           | 0 = Disable Interrupt (default)                                                                                       |
|             | 1 = Enable Interrupt                                                                                                  |
| 4           | Reserved                                                                                                              |
| 5           | Xoff Interrupt Enable (requires EFR bit-4=1)                                                                          |
| Ū.          | 0 = Disable the software flow control (default)                                                                       |
|             | 1 = Enable the software flow control                                                                                  |
| 6           | RTS#/DTR# Output Interrupt Enable (requires EFR bit-4=1)                                                              |
| -           | 0 = Disable Interrupt (default)                                                                                       |
|             | 1 = Enable Interrupt.                                                                                                 |
|             | The UART issues an interrupt when the RTS#/DTR# pin                                                                   |
|             | makes a transition. The RTS# or DTR# output is selected                                                               |
|             | via MCR bit-2.                                                                                                        |
|             | A DTR signal path is NOT SUPPORTED by this model. The                                                                 |
|             | DTR# output is used to enable the receiver of the channel                                                             |
|             | RX. Although a RTS signal path is present, the RTS#                                                                   |
|             | output's primary purpose is to enable the transmitter of the                                                          |
|             | channel TX. Note that using RTS# for flow control may                                                                 |
|             | interfere with the ability of the channel to transmit data.                                                           |
| 7           | CTS# Input Interrupt Enable (requires EFR bit-4=1)                                                                    |
|             | 0 = Disable Interrupt (default)                                                                                       |
|             | 1 = Enable Interrupt.                                                                                                 |
|             | The UART issues an interrupt when the CTS# pin makes a                                                                |
|             | transition.                                                                                                           |
| A nound oid | in (#) is used to indicate an active-low signal on the LIART nin                                                      |

A pound sign (#) is used to indicate an active-low signal on the UART pin.

### ISR - Interrupt Status Register, Channels 0-7 (READ Only)

The Interrupt Status Register is used to indicate that a prioritized interrupt is pending and the type of interrupt that is pending. The eight individual channels share the PMC module INTA# signal. Six levels of prioritized interrupts are provided to minimize software interaction. Performing a read cycle on the ISR will provide the user with the highest pending interrupt level to be serviced. No other interrupts are acknowledged until the pending interrupt is serviced. Whenever the interrupt status register is read, the interrupt status is cleared. Note, only the current pending interrupt is cleared by the read. A lower level interrupt may be seen after re-reading the interrupt status bits.

# UART CONFIGURATION REGISTERS

### **UART CONFIGURATION** REGISTERS

The following interrupt source table shows the data values (bit 0-5) for the seven prioritized interrupt levels and the interrupt sources associated with each of these interrupt levels.

### Interrupt Status Register

| PRIORITY<br>LEVEL | ISR BITS<br>Bit5 to Bit0 | Source of the Interrupt                                  |
|-------------------|--------------------------|----------------------------------------------------------|
| 1                 | 000110                   | LSR (Receiver Line Status Register, see<br>LSR bits 1-4) |
| 2                 | 000100                   | RXRDY (Received Data Ready)                              |
| 3                 | 001100                   | RXRDY (Receive Data Time-out)                            |
| 4                 | 000010                   | TXRDY (Transmitter Holding Register<br>Empty)            |
| 5                 | 000000                   | MSR (Modem Status Register)                              |
| 6                 | 010000                   | RXRDY (Received Xon/Xoff or Special<br>character)        |
| 7                 | 100000                   | CTS#, RTS#/DTR# change of state                          |
| Х                 | 000001                   | None (default)                                           |

<u>Notes</u> (Interrupt Status Register): 1. Bit 4 of the EFR (Enhanced Feature Register) must be set to a logic 1 to unlock access to bits 4 and 5 of the ISR register.

Note that ISR bit 0 can be used to indicate whether an interrupt is pending (bit 0 is low when interrupt is pending). ISR bits 1, 2, and 3 are used to indicate the source for a pending interrupt at interrupt priority levels 1, 2, 3, and 4. Bit 4 set indicates a Xoff/Xon or special character detected interrupt pending. Reading the XCHAR register will indicate which character (Xoff or Xon) was received last. Bit 5 indicates a pending interrupt due to a change of state on the CTS#/ or RTS#/DTR# signals.

Bits 6 and 7 are set to a logic 0 when the FIFOs are disabled. They are set to a logic 1 when the FIFOs are enabled.

### Interrupt Clearing:

- LSR interrupt is cleared by a read of the LSR register
- RXRDY is cleared by reading data until FIFO falls below the trigger level.
- RXRDY Time-out is cleared by reading data until the RX FIFO is empty.
- TXRDY interrupt is cleared by a read of the ISR register.
- MSR interrupt is cleared by a read of the MSR register
- Xon or Xoff character interrupt is cleared by a read of the ISR register.
- Special character interrupt is cleared by a read of the ISR register or after the next character is received.
- RTS#/DTR# and CTS# status change interrupts are cleared by a read to the MSR register.

This write-only register is used to enable and clear the FIFO buffers, and set the transmit/receive FIFO trigger levels.

### FIFO Control Register

| FCR BIT | FUNCTION                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                        |                  |                     |
|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|---------------------|
| 0       | TX and RX FIFO Enable<br>0 = Disable the transmit and receive FIFO (default).<br>1 = Enables both the Tx and Rx FIFO's. <u>This bit must be a</u><br><u>"1" when other FCR bits are written to or they will not be</u><br><u>programmed.</u>                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                        |                  | This bit must be a  |
| 1       | RX FIFO Reset<br>This bit is only active when FCR bit-0 is active.<br>0 = No receive FIFO reset (default).<br>1 = Reset the receive FIFO pointers and FIFO level counter<br>logic (the receive shift register is not cleared or altered).<br>This bit will return to logic 0 after resetting the FIFO.                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                        |                  |                     |
| 2       | TX FIFO Res<br>This bit is on<br>0 = No transr<br>1 = Reset the<br>logic (the tran<br>This bit will re                                                                                                                                                                                                                                                                                                                             | This bit will return to logic 0 after resetting the FIFO.<br>TX FIFO Reset<br>This bit is only active when FCR bit-0 is active.<br>0 = No transmit FIFO reset (default).<br>1 = Reset the transmit FIFO pointers and FIFO level counter<br>logic (the transmit shift register is not cleared or altered).<br>This bit will return to logic 0 after resetting the FIFO. |                  |                     |
| 3       | DMA Mode S                                                                                                                                                                                                                                                                                                                                                                                                                         | Select (DMA N                                                                                                                                                                                                                                                                                                                                                          | ot Supported)    |                     |
| 5,41    | Transmit FIFO Trigger Select<br>These bits are used to set the trigger level for the transmit<br>FIFO interrupt. An interrupt will be issued when the number<br>of characters in the FIFO drops below the selected trigger<br>level, or when the FIFO becomes empty in the case that it<br>did not get filled over the trigger level on last reload. FCTR<br>bits 6-7 are used to select one of four trigger tables <sup>2</sup> . |                                                                                                                                                                                                                                                                                                                                                                        |                  |                     |
|         | Table                                                                                                                                                                                                                                                                                                                                                                                                                              | Bit 5                                                                                                                                                                                                                                                                                                                                                                  | Bit 4            | Trigger Level       |
|         | A                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0                                                                                                                                                                                                                                                                                                                                                                      | 0                | 1 (default)         |
|         | В                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0<br>0<br>1<br>1                                                                                                                                                                                                                                                                                                                                                       | 0<br>1<br>0<br>1 | 16<br>8<br>24<br>30 |
|         | С                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0<br>0<br>1<br>1                                                                                                                                                                                                                                                                                                                                                       | 0<br>1<br>0<br>1 | 8<br>16<br>32<br>56 |
|         | D                                                                                                                                                                                                                                                                                                                                                                                                                                  | Х                                                                                                                                                                                                                                                                                                                                                                      | Х                | Programmable        |

### UART CONFIGURATION REGISTERS

| UART CONFIGURATION |
|--------------------|
| REGISTERS          |

| FCR BIT | FUNCTION                                       |                                                    |                                                      |               |
|---------|------------------------------------------------|----------------------------------------------------|------------------------------------------------------|---------------|
| 7,6     | These bits ar<br>FIFO interrup<br>when the nur | ot. In FIFO mo<br>nber of charac<br>trigger level. | he trigger leve<br>de an interrup<br>ters in the FIF |               |
|         | Table                                          | Bit 7                                              | Bit 6                                                | Trigger Level |
|         | A                                              | 0                                                  | 0                                                    | 1 (default)   |
|         |                                                | 0                                                  | 1                                                    | 4             |
|         |                                                | 1                                                  | 0                                                    | 8             |
|         |                                                | 1                                                  | 1                                                    | 14            |
|         | В                                              | 0                                                  | 0                                                    | 8             |
|         |                                                | 0                                                  | 1                                                    | 16            |
|         |                                                | 1                                                  | 0                                                    | 24            |
|         |                                                | 1                                                  | 1                                                    | 28            |
|         | С                                              | 0                                                  | 0                                                    | 8             |
|         |                                                | 0                                                  | 1                                                    | 16            |
|         |                                                | 1                                                  | 0                                                    | 56            |
|         |                                                | 1                                                  | 1                                                    | 60            |
|         | D                                              | Х                                                  | Х                                                    | Programmable  |

- Notes (FIFO Control Register): 1. Bits 4 and 5 are only programmable when the EFR bit 4 is set to 1. 2. The receiver and transmitter constants with the effective of the set to 1.
  - 2. The receiver and transmitter cannot use different trigger tables. The table selected last applies to both the RX and TX side.

### LCR - Line Control Register, Channels 0-7 (Read/Write)

The Line Control Register is used to specify the asynchronous data communication format. The word length, the number of stop bits, and the parity are selected by writing the appropriate bits in this register.

### Line Control Register

| LCR Bit | FUNCTION    | PROGRAMMING                                    |
|---------|-------------|------------------------------------------------|
| 1,0     | Word        | 0.0 = 5 Data Bits (default)                    |
|         | Length Sel. | 0 1 = 6 Data Bits                              |
|         |             | 1 0 = 7 Data Bits                              |
|         |             | 1 1 = 8 Data Bits                              |
| 2       | Stop Bit    | 0 = 1 Stop Bit (default)                       |
|         | Select      | 1 = 1.5 Stop Bits if 5 data bits;              |
|         |             | 2 Stop Bits if 6, 7, or 8 data bits selected.  |
| 3       | Parity      | 0 = No Parity                                  |
|         | Enable      | 1 = A parity bit is generated during the       |
|         |             | transmission while the receiver checks for     |
|         |             | parity error of the data character received.   |
| 4       | Parity      | 0 = ODD Parity                                 |
|         | Select      | 1 = EVEN Parity                                |
| 5       | Forced      | 0 = parity is not forced (default)             |
|         | Parity      | 1 and LCR BIT-4 = 0, parity bit is forced to a |
|         | Select      | logic 1 (MARK) for the transmit and received   |
|         |             | data.                                          |
|         |             | 1 and LCR BIT-4 = 1, parity bit is forced to a |
|         |             | logic 0 (SPACE) for the transmit and received  |
|         |             | data.                                          |
| 6       | Transmit    | 0 = No TX break condition (default)            |
|         | Break       | 1 = Forces the transmitter output (TX) to a    |
|         | Enable      | "space", LOW, for alerting the remote receiver |
|         |             | of a line break condition. This condition      |
|         |             | remains until disabled by setting LCR bit-6 to |
|         |             | a logic 0.                                     |
| 1       |             | a logic v.                                     |

**UART CONFIGURATION** 

REGISTERS

| LCR Bit | FUNCTION                                    | PROGRAMMING                                                                                                       |
|---------|---------------------------------------------|-------------------------------------------------------------------------------------------------------------------|
| 7       | Baud Rate<br>Divisor<br>(DLL/DLM)<br>Enable | <ul> <li>0 = Data registers are selected (default).</li> <li>1 = Divisor latch registers are selected.</li> </ul> |

A detailed discussion of word length, stop bits, parity, and the break signal is included in Section 4.0 (Theory of Operation).

### MCR - Modem Control Register, Channels 0-7 (R/W)

The Modem Control register is used for controlling the modem interface signals or general purpose inputs/outputs.

| Modem Control Register |                                             |                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
|------------------------|---------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| MCR Bit                | FUNCTION                                    | PROGRAMMING                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
| 0                      | DTR# Pins                                   | <ul> <li>0 = Channel receiver disabled</li> <li>1 = Channel receiver enabled</li> <li>A DTR signal path is NOT SUPPORTED</li> <li>by this model. Instead, the output is used</li> <li>to enable the receiver of the channel RX.</li> </ul>                                                                                                                                                                         |  |  |
| 1                      | RTS# Pins                                   | 0 = Channel transmitter disabled<br>1 = Channel transmitter enabled<br>Although a RTS signal path is present,<br>the RTS# output's primary purpose is to<br>enable the transmitter of the channel TX.<br>Note that using RTS# for flow control may<br>interfere with the ability of the channel to<br>transmit data.                                                                                               |  |  |
| 2                      | Auto Flow<br>Control Select                 | The UART uses this bit to select between<br>RTS/CTS (bit-2 = 0) or DTR/DSR (bit-2 =<br>1) for auto hardware flow control. Since<br>this DTR and DSR signal paths are not<br>supported this bit should be left at logic 0<br>(default). This bit is only in effect when<br>auto RTS/DTR is enabled by EFR bit-6                                                                                                     |  |  |
| 3                      | (OP2)                                       | OP2 is not available                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| 4                      | Internal<br>Loopback <sup>1</sup><br>Enable | 0 = Disabled internal loopback mode<br>(default)<br>1 = Enabled internal loopback mode                                                                                                                                                                                                                                                                                                                             |  |  |
| 5 <sup>2</sup>         | Xon-Any<br>Enable                           | 0 = Disable Xon-Any function (default)<br>1 = Enable any Xon-any function. In this<br>mode any RX character received will<br>enable Xon, resume data transmission.                                                                                                                                                                                                                                                 |  |  |
| 6                      | Infrared<br>Encoder/<br>Decoder<br>Enable   | Infrared mode is not supported                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
| 72                     | Clock Prescaler<br>Select                   | <ul> <li>0 = Divide by one. The input clock from<br/>the crystal is fed directly to the<br/>Programmable Baud Rate Generator<br/>without further modifications, i.e., divide<br/>by one (default)</li> <li>1 = Divide by four. The prescaler divides<br/>the input clock from the crystal by four<br/>and feeds it to the Programmable Baud<br/>Rate Generator, hence, data rates<br/>become one-forth.</li> </ul> |  |  |

| UART CONFIGURATION |  |
|--------------------|--|
| REGISTERS          |  |

### Notes (Modem Control Register):

- MCR Bit 4 provides a local loopback feature for diagnostic testing of the UART channel. All UART functions operate normally. Transmit data from the transmit shift register is internally routed to the receive shift register input allowing the system to receive the same data that it was sending. The TX, RTS# and DTR# pins are held de-asserted, and the CTS# input is ignored.
- 2. Bits 5-7 are only programmable when the EFR bit 4 is set to "1". The programmed values for these bits are latched when EFR bit 4 is cleared, preventing existing software from inadvertently overwriting the extended functions

### LSR - Line Status Register, Channels 0-7 (Read/Write-Restricted)

The Line Status Register (LSR) provides the status of data transfers between the UART and the host. If IER bit-2 is set to a logic 1, an LSR interrupt will be generated immediately when any character in the RX FIFO has an error (parity, framing, overrun, break). Reading LSR will clear LSR bits 1-4.

### Line Status Register

| LSR Bit | FUNCTION                                | PROGRAMMING                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|---------|-----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0       | Receive<br>Data<br>Ready<br>Indicator   | 0 = No data in the receive holding register or<br>FIFO (default).<br>1 = Data has been received and is saved in<br>the receive holding register or FIFO.                                                                                                                                                                                                                                                                                                                                                                 |
| 1       | Receiver<br>Overrun<br>Flag             | 0 = No overrun error (default).<br>1 = Overrun error. A data overrun error<br>condition occurred in the receive shift register.<br>This happens when additional data arrives<br>while the FIFO is full. In this case the<br>previous data in the receive shift register is<br>overwritten. Note that under this condition the<br>data byte in the receive shift register is not<br>transferred into the FIFO, therefore the data in<br>the FIFO is not corrupted by the error. This<br>bit is cleared after LSR is read. |
| 2       | Receive<br>Data Parity<br>Error Flag    | 0 = No parity error (default).<br>1 = Parity error. The received character in the<br>RHR does not have the correct parity<br>information and is suspect. This error is<br>associated with the character available for<br>reading in RHR. This bit is cleared after LSR<br>is read.                                                                                                                                                                                                                                       |
| 3       | Receive<br>Data<br>Framing<br>Error Tag | 0 = No framing error (default).<br>1 = Framing error. The receive character did<br>not have a valid stop bit(s). This error is<br>associated with the character available for<br>reading in RHR. This bit is cleared after LSR<br>is read.                                                                                                                                                                                                                                                                               |
| 4       | Receive<br>Break Tag                    | 0 = No break condition (default).<br>1 = The receiver received a break signal (RX<br>was a logic 0 for one character frame time).<br>In FIFO mode, only one break character is<br>loaded into the FIFO. This bit is cleared after<br>LSR is read.                                                                                                                                                                                                                                                                        |

| 5 | Transmit<br>Holding                         | This bit is the Transmit Holding Register Empty indicator. This bit indicates that the transmitter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|---|---------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   | Register<br>Empty<br>Flag                   | is ready to accept a new character for<br>transmission. In addition, this bit causes the<br>UART to issue an interrupt to the host when the<br>THR interrupt enable is set. The THR bit is set<br>to a logic 1 when the last data byte is<br>transferred from the transmit holding register to<br>the transmit shift register. The bit is reset to<br>logic 0 concurrently with the data loading to the<br>transmit holding register by the host. In FIFO<br>mode this bit is set when the transmit FIFO is<br>empty; it is cleared when at least 1 byte is<br>written to the transmit FIFO. |
| 6 | Transmit<br>Shift<br>Register<br>Empty Flag | This bit is the Transmit Shift Register Empty<br>indicator. This bit is set to a logic 1 whenever<br>the transmitter goes idle. It is set to logic 0<br>whenever the THR or TSR contains the data<br>character. In FIFO mode this bit is set to 1<br>whenever the transmit FIFO and transmit shift<br>register are both empty.                                                                                                                                                                                                                                                               |
| 7 | Receiver<br>FIFO Data<br>Error Flag         | 0 = No FIFO error (default).<br>1 = An indicator for the sum of all error bits in<br>the RX FIFO. At least one parity error, framing<br>error or break indication is in the FIFO data.<br>This bit clears when there is no more error(s) in<br>the FIFO.                                                                                                                                                                                                                                                                                                                                     |

### MSR - Modem Status Register, Channels 0-7 (Read- Only)

The Modem Status Register (MSR) provides the host CPU with an indication on the status of the modem input lines from a modem or other peripheral device. This register allows the current state of CTS and DSR to be read and provides indication of whether the state of these lines has changed since the last read of the MSR.

#### Modem Status Register

| MSR Bit | Bit FUNCTION PROGRAMMING |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |
|---------|--------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|         |                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |
| 0       | Delta CTS#<br>Input Flag | <ul> <li>0 = No Change on CTS# input (default)</li> <li>1 = The CTS# input has changed state since<br/>the last time it was monitored. A modem<br/>status interrupt will be generated if MSR<br/>interrupt is enabled (IER bit-3)</li> </ul>                                                                                                                                                                                                                                                                                                                                             |  |  |
| 1       | Delta DSR#<br>Input Flag | △DSR – Not Supported.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| 2       | Delta RI#<br>Input Flag  | $\Delta RI - Not Supported.$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
| 3       | Delta CD#<br>Input Flag  | ∆CD - Not Supported                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
| 4       | CTS Input<br>Status      | CTS# pin may function as automatic hardware<br>flow control signal input if it is enabled and<br>selected by Auto CTS (EFR bit-7) and<br>RTS/CTS flow control select (MCR bit-2).<br>Auto CTS flow control allows starting and<br>stopping of local data transmissions based on<br>the modem CTS# signal. A logic 1 on the<br>CTS# pin will stop UART transmitter as soon<br>as the current character has finished<br>transmission, and a logic 0 will resume data<br>transmission. If automatic hardware flow<br>control is not used, MSR bit-4 is the<br>compliment of the CTS# input. |  |  |

### UART CONFIGURATION REGISTERS

### UART CONFIGURATION REGISTERS

## MSR Bit FUNCTION PROGRAMMING 5 DSR Input Sta DSR - Not Supported 6 RI Input Status RI - Not Supported 7 CD Input Status CD - Not Supported

Note that not all UART signal paths are used by this model and their corresponding UART pins are tied high (+5V). This includes DSR (Data Set Ready), RI (Ring Indicator) and CD (Carrier Detect).

### SCR - Scratch Pad Register, Channels 0-7 (Read/Write)

This 8-bit read/write register has no effect on the operation of either serial channel. It is provided as an aide to the programmer to temporarily hold data.

### FCTR – Feature Control Register, Channels 0-7 (Read/Write)

#### Feature Control Register

| FCTR<br>Bit | FUNCTION                                          | PROGRAMMING                                                                                                                                                                                                                                                                                                                                                                                                       |      |  |
|-------------|---------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--|
| 3:0         | Auto RTS Flow<br>Control<br>Hysteresis<br>Select. | Although a RTS signal path is present,<br>the RTS# output's primary purpose is to<br>enable the transmitter of the channel TX.<br>Note that using RTS# for flow control may<br>interfere with the ability of the channel to<br>transmit data.<br>When Trigger Table-D is selected, these<br>bits select the auto RTS flow control<br>hysteresis. The RTS hysteresis is<br>referenced to the RX FIFO trigger level |      |  |
|             |                                                   | FCTR [3:0] RTS/DTR Hysteresis<br>(characters)                                                                                                                                                                                                                                                                                                                                                                     |      |  |
|             |                                                   | 0000 0                                                                                                                                                                                                                                                                                                                                                                                                            |      |  |
|             |                                                   | 0001 ± 4                                                                                                                                                                                                                                                                                                                                                                                                          |      |  |
|             |                                                   | 0010 ± 6                                                                                                                                                                                                                                                                                                                                                                                                          |      |  |
|             |                                                   | 0011                                                                                                                                                                                                                                                                                                                                                                                                              | ± 8  |  |
|             |                                                   | 0100                                                                                                                                                                                                                                                                                                                                                                                                              | ± 8  |  |
|             |                                                   | 0101                                                                                                                                                                                                                                                                                                                                                                                                              | ± 16 |  |
|             |                                                   | 0110                                                                                                                                                                                                                                                                                                                                                                                                              | ± 24 |  |
|             |                                                   | 0111                                                                                                                                                                                                                                                                                                                                                                                                              | ± 32 |  |
|             |                                                   | 1100                                                                                                                                                                                                                                                                                                                                                                                                              | ± 12 |  |
|             |                                                   | 1101                                                                                                                                                                                                                                                                                                                                                                                                              | ± 20 |  |
|             |                                                   | 1110                                                                                                                                                                                                                                                                                                                                                                                                              | ± 28 |  |
|             |                                                   | 1111                                                                                                                                                                                                                                                                                                                                                                                                              | ± 36 |  |
|             |                                                   | 1000                                                                                                                                                                                                                                                                                                                                                                                                              | ± 40 |  |
|             |                                                   | 1001                                                                                                                                                                                                                                                                                                                                                                                                              | ± 44 |  |
|             |                                                   | 1010                                                                                                                                                                                                                                                                                                                                                                                                              | ± 48 |  |
|             |                                                   | 1011                                                                                                                                                                                                                                                                                                                                                                                                              | ± 52 |  |
| 4           | Infrared RX<br>Input Logic<br>Select              | Not supported                                                                                                                                                                                                                                                                                                                                                                                                     |      |  |
| 5           | Auto RS485<br>Enable                              | Not supported                                                                                                                                                                                                                                                                                                                                                                                                     |      |  |

| FCTR<br>Bit | FUNCTION                                  | PROGRAMMING                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------------|-------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:6         | TX and RX<br>FIFO Trigger<br>Table Select | 00 = Table A<br>01 = Table B<br>10 = Table C<br>11 = Table D<br>When table A, B, or C is selected the auto<br>RTS flow control trigger is set to "next<br>FIFO trigger level" for compatibility to<br>ST16C550 and ST16C650 series. RTS#<br>triggers on the next level of the RX FIFO<br>trigger level (one FIFO level above and<br>one FIFO level below). For example, if<br>Table C is used on the receiver with RX<br>FIFO trigger level set to 56 bytes, RTS#<br>output will de-assert at 60 and re-assert<br>when the level drops below 16. |

### EFR - Enhanced Feature Register, Channels 0-7 (Read/Write)

The Enhanced Feature register is used to enable or disable the enhanced features (software flow control, and hardware flow control). This register is also used to unlock access to programming the extended register functionality of IER bits 4-7, ISR bits 4-5, FCR bits 4-5, and MCR bits 5-7.

### **Enhanced Feature Register**

| EFR Bit | FUNCTION                        | PROGRAMMING                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------|---------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0     | Software<br>Flow<br>Control     | <ul> <li>00XX = No Transmit Flow Control</li> <li>10XX = Transmit Xon1/Xoff1</li> <li>01XX = Transmit Xon2/Xoff2</li> <li>11XX = Transmit Xon1 and Xon2, Xoff1 and Xoff2</li> <li>XX00 = No receive Flow Control</li> <li>XX10 = Receiver Compares Xon1/Xoff1</li> <li>XX01 = Receiver Compares Xon2/Xoff2</li> <li>1011 = Transmit Xon1/Xoff1, Receiver compares Xon1 and Xon2, Xoff1 and Xoff2.</li> <li>0111 = Transmit Xon2/Xoff2. Receiver compares Xon1 and Xon2, Xoff1 and Xoff2.</li> <li>1111 = Transmit Xon1 and Xon2, Xoff1 and Xoff2.</li> <li>1111 = Transmit Xon1 and Xon2, Xoff1 and Xoff2.</li> <li>0011 = No transmit flow control. Receiver compares Xon1 and Xoff2.</li> <li>0011 = No transmit flow control. Receiver compares Xon1 and Xon2, Xoff1 and Xoff2.</li> </ul> |
| 4       | Enhanced<br>Function<br>Control | <ul> <li>0 = Disable and latch the Enhanced<br/>Functions: the IER bits 4-7, ISR bits 4-5,<br/>FCR bits 4-5, MCR bits 5-7 (default). This<br/>feature prevents existing software from<br/>altering or overwriting the enhanced<br/>functions.</li> <li>1 = Enables the enhanced functions. Allows<br/>the IER bits 4-7, ISR bits 4-5, FCR bits 4-<br/>5, and MCR bits 5-7 to be modified.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                          |

| UART CONFIGURATION |
|--------------------|
| REGISTERS          |

| EFR Bit | FUNCTION                                  | PROGRAMMING                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|---------|-------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5       | Special<br>Character<br>Detect<br>Control | <ul> <li>0 = Disable special character detect (default).</li> <li>1 = Enable special character detect.<br/>Incoming receive characters are compared<br/>with Xoff-2 data. If a match exists, the<br/>receive data will be transferred to the FIFO<br/>and ISR bit-4 will be set to indicate<br/>detection of special character. Bit-0 of the<br/>Xoff/Xon registers corresponds with the<br/>LSB bit for the receive character. If flow<br/>control is set for comparing Xon1, Xoff1<br/>then flow control and special character<br/>detect work normally. However, if flow<br/>control is set for comparing Xon2, Xoff2<br/>then flow control works normally but Xoff2<br/>will not go to the FIFO, and both an Xoff<br/>interrupt and special character interrupt will<br/>be generated.</li> </ul>                                                                                                     |
| 6       | RTS<br>Hardware<br>Flow<br>Control        | <ul> <li>0 = Disable Auto RTS (default).</li> <li>1= Enable Automatic RTS flow control.<br/>Although a RTS signal path is present, the<br/>RTS# output's primary purpose is to<br/>enable the transmitter of the channel TX.<br/>Note that using RTS# for flow control may<br/>interfere with the ability of the channel to<br/>transmit data.<br/>The RTS pin can be automatically<br/>controlled to indicate local buffer overflows to<br/>remote units. When Auto RTS is enabled, an<br/>interrupt will be generated when the receive<br/>FIFO is filled to the programmed trigger level<br/>and RTS# will de-assert HIGH at the next<br/>upper trigger or selected hysteresis level.<br/>RTS# will return LOW when data is unloaded<br/>below the next lower trigger or selected<br/>hysteresis level. The RTS# output must be<br/>asserted (LOW) before the auto RTS can take<br/>effect.</li> </ul> |
| 7       | CTS<br>Hardware<br>Flow<br>Control        | <ul> <li>0 = Disable Auto CTS (default).</li> <li>1 = Enable Automatic CTS flow control. The CTS pin can be monitored for remote buffer overflow indication. When automatic CTS hardware flow control is enabled, Transmission stops when CTS# pin de-asserts HIGH. Transmission resumes after CTS# returns LOW.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

### TXCNT – Transmit FIFO Level Counter, Channels 0-7 (Read- Only)

This 8-bit register gives an indication of the transmit FIFO level byte count (0 to 64). Due to the dynamic nature of the FIFO counters, this register should be read until the same value is returned twice.

### TXTRG – Transmit FIFO Trigger Level, Channels 0-7 (Write- Only)

When trigger table D is selected, an 8-bit value written to this register sets the TX FIFO trigger level (0 to 64). If enabled, an interrupt will be generated whenever the data level in the transmit FIFO falls below this preset trigger level.

### RXCNT - Receive FIFO Level Counter, Channels 0-7 (Read- Only)

This 8-bit register gives an indication of the receive FIFO level byte count (0 to 64). Due to the dynamic nature of the FIFO counters, this register should be read until the same value is returned twice.

#### RXTRG – Transmit FIFO Trigger Level, Channels 0-7 (Write- Only)

When trigger table D is selected, an 8-bit value written to this register sets the RX FIFO trigger level (0 to 64). If enabled, an interrupt will be generated whenever the data level in the receive FIFO falls below this preset trigger level.

### XCHAR - Register, Channels 0-7 (Read- Only)

When an Xoff/Xon interrupt occurs (ISR bit-4 is logic 1), reading the XCHAR register will indicate which character (Xoff or Xon) was received last.

### XCHAR Register

| EFR Bit | FUNCTION                      | PROGRAMMING                                                                                        |
|---------|-------------------------------|----------------------------------------------------------------------------------------------------|
| 0       | Xoff<br>Detected<br>Indicator | 0 = Xoff not detected<br>1 = Xoff detected. This bit is automatically<br>cleared after being read. |
| 1       | Xon<br>Detected<br>Indicator  | 0 = Xon not detected<br>1 = Xon detected. This bit is automatically<br>cleared after being read.   |
| 7:2     | Not used                      |                                                                                                    |

### XON/XOFF-1,2 Registers, Channel 0-7 (R/W)

These registers hold the programmed Xon and Xoff characters for software flow control. Xon or Xoff characters may be 1 or 2 bytes long. The UART compares incoming data to these values and restarts (Xon) or suspends (Xoff) data transmission when a match is detected.

### READ RX FIFO, Channel 0-7 (Read-Only)

This register provides a faster alternative to reading data in 8-bit format from the receive holding register (RHR). Using this register, RX FIFO data can be read out using 32-bit read operations (maximum 16 DWORD reads). The data is formatted as follows:

| READ RX<br>FIFO | Byte 3    | Byte 2    | Byte 1    | Byte 0    |
|-----------------|-----------|-----------|-----------|-----------|
| Read n+0 to     | n+3       | FIFO Data | FIFO Data | FIFO Data |
| n+3             |           | n+2       | n+1       | n+0       |
| Read n+4 to     | FIFO Data | FIFO Data | FIFO Data | FIFO Data |
| n+7             | n+7       | n+6       | n+5       | n+4       |
| Etc.            |           |           |           |           |

### WRITE TX FIFO, Channel 0-7 (Write-Only)

This register provides a faster alternative to writing data in 8-bit format to the transmit holding register (THR). Using this register, TX FIFO data can be written using 32-bit write operations (maximum 16 DWORD writes). The data is formatted as follows:

### UART CONFIGURATION REGISTERS

### UART CONFIGURATION REGISTERS

| n+3 n+3 n+2 n+1 n- |                  |
|--------------------|------------------|
|                    | FIFO Data<br>n+0 |
|                    | FIFO Data<br>n+4 |

### **READ RX FIFO with Errors, Channel 0-7 (Read-Only)**

This register provides a faster alternative to reading data in 8-bit format from the receive holding register (RHR) and line status register (LSR). Using this register, RX FIFO data and LSR status information is read out side-by-side. The status and data bytes must be read in 16 or 32 bits format to maintain data integrity. The status and data is formatted as follows:

| READ RX<br>FIFO with<br>LSR Errors | Byte 3           | Byte 2  | Byte 1           | Byte 0  |
|------------------------------------|------------------|---------|------------------|---------|
| Read n+0 to<br>n+1                 | FIFO Data<br>n+1 | LSR n+1 | FIFO Data<br>n+0 | LSR n+0 |
| Read n+2 to<br>n+3                 | FIFO Data<br>n+3 | LSR n+3 | FIFO Data<br>n+2 | LSR n+2 |
| Etc.                               |                  |         |                  |         |

### THE EFFECT OF RESET

The following table summarizes the effect of a reset on the various registers and internal and external signals:

### **UART Reset Conditions**

| REGISTERS | RESET STATE                           |
|-----------|---------------------------------------|
| DLL       | Bits $7:0 = 0xXX$                     |
| DLM       | Bits $7:0 = 0xXX$                     |
| RHR       | Bits $7:0 = 0xXX$                     |
| THR       | Bits $7:0 = 0xXX$                     |
| IER       | Bits $7:0 = 0x00$                     |
| FCR       | Bits $7:0 = 0x00$                     |
| ISR       | Bits 7:0 = 0x01                       |
| LCR       | Bits $7:0 = 0x00$                     |
| MCR       | Bits $7:0 = 0x00$                     |
| LSR       | Bits $7:0 = 0x60$                     |
| MSR       | Bits $7,6,3:0 = \log c 0,$            |
|           | Bits 5:4 = logic levels of the inputs |
| SPR       | Bits 7:0 = 0xFF                       |
| FCTR      | Bits 7:0 = 0x00                       |
| EFR       | Bits 7:0 = 0x00                       |
| TXCNT     | Bits 7:0 = 0x00                       |
| TXTRG     | Bits $7:0 = 0x00$                     |
| RXCNT     | Bits 7:0 = 0x00                       |
| RXTRG     | Bits 7:0 = 0x00                       |
| XCHAR     | Bits 7:0 = 0x00                       |
| XON1      | Bits $7:0 = 0x00$                     |
| XON2      | Bits 7:0 = 0x00                       |
| XOFF1     | Bits $7:0 = 0x00$                     |
| XOFF2     | Bits 7:0 = 0x00                       |

### UART CONFIGURATION REGISTERS

| I/O SIGNALS  | RESET STATE |
|--------------|-------------|
| TX[CH 7:0]   | HIGH        |
| RTS#[CH 7:0] | HIGH        |
| DTR#[CH 7:0] | HIGH        |

### PMC521 PROGRAMMING CONSIDERATIONS

Each serial channel of this module is programmed by the control registers: LCR, IER, DLL, DLM, MCR, and FCR. These control words define the character length, number of stop bits, parity, baud rate, and modem interface. The control registers can be written in any order, but the IER register should be written last since it controls the interrupt enables. The contents of these registers can be updated any time the serial channel is not transmitting or receiving data.

The complete status of each channel can be read by the host CPU at any time during operation. Two registers are used to report the status of a particular channel: the Line Status Register (LSR) and the Modem Status Register (MSR).

Serial channel data is read from the Receive Holding Register (RHR), and written to the Transmitter Holding Register (THR). Writing data to the THR initiates the parallel-to-serial transmitter shift register to the TX line. Likewise, input data is shifted from the RX pin to the Receive Holding Register as it is received.

This board operates in two different modes. In one mode, this device remains software compatible with the industry standard 16C550 family of UART's, and provides double-buffering of data registers. In the FIFO Mode (enabled via bit-0 of the FCR register), data registers are FIFO-buffered so that read and write operations can be performed while the UART is performing serial-to-parallel and parallel-to-serial conversions.

Two FIFO modes of operation are possible: FIFO Interrupt Mode and FIFO Polled Mode. In FIFO Interrupt Mode, data transfer is initiated by reaching a pre-determined trigger-level or generating time-out conditions. In FIFO-Polled Mode, there is no time-out condition indicated or trigger-level reached. The transmit and the receive FIFO's simply hold characters and the Line Status Register must be read to determine the channel status.

#### **FIFO Polled-Mode**

Resetting all Interrupt Enable Register (IER) bits to 0, with FIFO Control Register (FCR) Bit 0 =1, puts the channel into the polled-mode of operation. The receiver and transmitter are controlled separately and either one or both may be in the polled mode. In FIFO-Polled Mode, there is no time-out condition indicated or trigger-level reached, the transmit and the receive FIFO's simply hold characters and the Line Status Register must be read to determine the channel status.

### **FIFO-Interrupt Mode**

In FIFO Interrupt Mode, data transfer is initiated by reaching a predetermined trigger-level or generating a time-out condition. Please note the following with respect to this mode of operation.

When the receiver FIFO and receiver interrupts are enabled, the following receiver status conditions apply:

- 1. LSR Bit 0 is set to 1 when a character is transferred from the shift register to the receiver FIFO. It is reset to 0 when the FIFO is empty.
- 2. The receiver line-status interrupt (ISR=06) has a higher priority than the received data-available interrupt (ISR=04).

3. The receive data-available interrupt is issued to the CPU when the PMC521 PROGRAMMING programmed trigger level is reached by the FIFO. It is cleared when the CONSIDERATIONS FIFO drops below its programmed trigger level. The receive dataavailable interrupt indication (ISR=04) also occurs when the FIFO reaches its trigger level, and is cleared when the FIFO drops below its trigger level. When the receiver FIFO and receiver interrupts are enabled, the following receiver FIFO character time-out status conditions apply: 1. A FIFO character time-out interrupt occurs if the receive FIFO has not reached the programmed trigger level and the RX input has been idle for 4 character + 12 bit times. 2. From the clock signal input, the character times can be calculated. The delay is proportional to the baud rate. The time-out timer is reset after the CPU reads the receiver FIFO or 3 after a new character is received when there has been no time-out interrupt. 4. A time-out interrupt is cleared by reading data until the RX FIFO is empty. When the transmit FIFO and transmit interrupts are enabled (FCR Bit 0 =1 and IER Bit 1 = 1), a transmitter interrupt will occur as follows: Whenever the THR becomes empty or the amount of data in the FIFO falls below the programmed trigger level, the transmitter holding register interrupt (ISR = 02) occurs. The interrupt is cleared when the Interrupt Status Register (ISR) is read. The Transmit FIFO Level Counter (TXCNT) may be used to help determine the number of characters that can be written to the transmit FIFO when servicing this interrupt.

### **Loopback Mode Operation**

This device can be operated in a "loopback mode", useful for troubleshooting a serial channel without physically wiring to the channel. Bit 4 of the Modem Control Register (MCR) is used to enable the local loopback feature for the UART channel. All regular UART functions operate normally. Transmit data from the transmit shift register output is internally routed to the receive shift register. The TX, RTS# and DTR# pins are held HIGH (idle or de-asserted), and the CTS# input is ignored. The CTS and DSR input status bits (MSR [5:4]) reflect the states of the RTS# and DTR# bits (MCR[1:0]) respectively.

#### Software Flow Control

Model PMC521 modules include support for software flow control. Software flow control utilizes special XON and XOFF characters to control the flow of data, for more efficient data transfer and to minimize overrun errors.

Software flow control (sometimes called XON/XOFF pacing) sends a signal from one node to another by adding flow control characters to the data stream. The receiving node will detect the XON or XOFF character and respond by suspending transmission of data (XOFF turns the data flow off), or resuming transmission of data (XON turns the data flow on). Flow control is used frequently in data communications to prevent overrun errors or the loss of excess data. For example, a node might transmit the XOFF character to the host computer if the host is sending data too quickly to be processed or buffered, thus preventing the loss of excess data.

The flow control characters are stored in the XON1, XON2, XOFF1 and XOFF2 registers. Two XON and XOFF registers are provided because the flow control character may be 1 or 2 bytes long. The contents of the XON and XOFF registers are reset to "0" upon power-up or system reset, and

may be programmed to any value for software flow control. Different conditions may be set to detect the XON/XOFF characters or start/stop the transmission.

When software flow control is enabled, the UART of this model will compare single or dual consectutive received data bytes with preprogrammed XOFF1/XOFF2 characters. When an XOFF match is detected, the UART will halt transmission after completing the transmission of the current character. The Xoff Interrupt Status flag of the Interrupt Status register will be set (ISR bit 4 is set to 1 when the XOFF character has been detected), only if enabled via bit 5 of the Interrupt Enable register (IER bit 5 is used to enable the received XOFF interrupt). An interrupt will then be generated. After recognition of the XOFF character(s), the UART will compare incoming characters with the preprogrammed XON1/XON2 characters. If a match is detected, the UART will resume transmission. When receiving data, the UART will automatically send XOFF1/XOFF2 character(s) approximately 2 character times after the programmed RX FIFO trigger level is reached, causing the host to suspend transmission. The UART will then transmit the programmed XON1/XON2 character(s) when the RX FIFO level falls below the next lowest trigger level, thus causing the host to resume transmission.

When single XON/XOFF characters are selected, the UART compares the received data to these values and controls the transmission accordingly (XON=restart transmission, XOFF=suspend transmission). These characters are not stacked in the data buffer or FIFO. It is also possible to configure Special Character Detect which allows the Xoff2 value to be transferred to the FIFO. This is configured using bit 5 of the Enhanced Feature Register. When the XonAny function is enabled (MCR bit 5 is set), the UART will automatically resume transmission after receiving *ANY* character after having recognized XOFF and suspended transmission.

### Hardware Flow Control

Model PMC521 modules include support for hardware flow control via the CTS signal and limited support for flow control using the RTS signal. The CTS# input pin can be monitored to suspend/resume a local transmitter. The RTS# output pin can be used to request a remote unit to suspend/resume data transmission. Note, however, that the RTS# output's primary purpose is to enable the transmitter of the channel TX. Using the RTS# output pin for flow control may interfere with the ability of the channel to transmit data.

Hardware flow control can be enabled by setting bits 6 and/or 7 of the EFR register to logic 1. Bit 6 enables Auto RTS; Bit 7 enables Auto CTS. Modem Control Register bit 2 must be set to logic 0.

Auto RTS flow control must be started by asserting the RTS# output pin low (MCR bit-1 = 1). When Auto RTS is selected, the RTS# signal will be forced to the de-asserted state when the receiver FIFO reaches a programmed trigger level. RTS# will re-assert when the receiver holding register contents drops below the next-lower trigger level. The UART will accept additional data when the transmission is suspended during hardware flow control until all FIFO locations are filled.

When Auto CTS is selected, the UART will automatically suspend data transmission as soon as a complete character is transmitted and the CTS# input level changes from low to high (de-asserted). Transmission will resume as soon as the CTS# signal changes to the low level (asserted).

Two interrupts are associated with auto RTS/CTS flow control and may be used to give indication when the RTS# pin or CTS# pin are de-asserted during operation. Setting IER bit-6 will enable the RTS# interrupt when

### PMC521 PROGRAMMING CONSIDERATIONS

PMC521 PROGRAMMING CONSIDERATIONS

these pins are de-asserted. Setting IER bit-7 will enable the CTS# interrupt when these pins are de-asserted. Note that EFR bit 4 must be set to 1 to access IER bits 6 and 7.

Both hardware and software flow controls can be enabled for automatic operation.

### **Programming Example**

The following example will demonstrate transfer between channel 0 of the host PMC521 and another node. The PMC521 will use the FIFO mode of operation. The baud will be set to 9600. The data format will use 8-bit characters, odd-parity and 1 stop bit. The example assumes registers not mentioned are in their default states. Please refer to Table 3.1 for address locations. The "H" following data below refers to the Hexadecimal format.

1. Write 80H to the Line Control Register (LCR).

This sets the Divisor Latch Access bit to permit access to the two divisor latch bytes used to set the baud rate. These bytes share addresses with the Receive and Transmit buffers, and the Interrupt Enable Register (IER).

2. Write 00H to the Divisor Latch MSB (DLM). Write 60H to Divisor Latch LSB (DLL).

This sets the divisor to 96 for 9600 baud (i.e. 9600 = 14.7456MHz / [16 x 96]).

3. Write 0BH to the Line Control Register (LCR).

This first turns off the Divisor Latch Access bit to permit accesses to the Receiver and Transmit buffers and the Interrupt Enable Register. It also sets the word length to 8 bits, the number of stop bits to one and enables odd-parity.

4. Write 10H to the Enhanced Feature Register (EFR).

This enables the enhanced function bits in the IER, ISR, FCR, and MCR.

5. Write 80H to the Feature Control Register (FCTR).

This selects Trigger Table C.

6. Write 25H to the FIFO Control Register (FCR)

This enables and resets the TX FIFO. It also sets the Transmit Trigger Level to 32.

7. Write 02H to the Modem Control Register (MCR)

This enables the channel's transmitter

8. Write FEH to the Multipurpose Input/Output Pin Select Register (MPIOSEL) and write 01H to the Multipurpose Input/Output Level Control Register (MPIOLVL).

This enables interrupts from any channel to reach the PCI bus.

9. Write 02H to the Interrupt Enable Register (IER).

After setting this bit, an interrupt is issued whenever the data in the TX FIFO falls below the programmed trigger level.

10. The interrupt service routine reads the Interrupt Status Register (ISR) to clear the TXRDY interrupt.

Data is added to the FIFO by repeatedly writing 8-bit values to the Transmit Holding Register (THR). Alternatively, 16 or 32 bit values can be written to the channel's Write FIFO Register.

Transmission of serial data will take place on the TX0 line.

11. When there is no more data to transmit, write 00H to the Interrupt Enable Register (IER).

This prevents further TXRDY interrupts.

This section contains information regarding theTIA/EIA-422B serial data interface. A description of the basic functionality of the circuitry used on the board is also provided. Refer to the Block Diagram shown in Drawing 4502-021 as you review this material.

### EIA/TIA-422B SERIAL INTERFACE

The Electronic Industries Association (EIA) in conjunction with the Telecommunication Industries Association (TIA) introduced TIA/EIA-422B as a balanced (differential) serial data transmission interface standard between Data Terminal Equipment (DTE) and Data Communication Equipment (DCE). By definition, DTE is commonly used to represent the data source, data sink, or both. DCE is used to represent the devices used to establish, maintain, and terminate a connection, and to code/decode the signals between the DTE and the transmission channel. Most computers are considered DTE devices, while modems are DCE devices.

The EIA/TIA-422B interface is the second revision of this standard and specifies a balanced driver with balanced receivers. Balanced data transmission refers to the fact that only two conductors are switched per signal and the logical state of the data is referenced by the difference in potential between the two conductors, not with respect to signal ground. The differential method of data transmission makes EIA-422B ideal for noisy environments since it minimizes the effects of coupled noise and ground potential differences. That is, since these effects are seen as common-mode voltages (common to both lines), not differential, they are rejected by the receivers. Additionally, balanced drivers have generally faster transition times and allow operation at higher data rates over longer distances.

The EIA/TIA-422B standard defines a unidirectional, terminated, single driver and multiple receiver configuration. By providing a separate data path for transmit and receive, full-duplex operation is accomplished. The maximum data transmission cable length is generally limited to 4000 feet without a signal repeater installed.

### PMC521 PROGRAMMING CONSIDERATIONS

# 4.0 THEORY OF OPERATION

EIA/TIA-422B SERIAL INTERFACE EIA/TIA-422B is electrically similar to EIA-485, except that EIA-485 supports multiple driver operation. Consequently, this board may be used to implement a full-duplex EIA-485 interface (see Drawing 4502-020).

With respect to EIA/TIA-422B, logic states are represented by differential voltages from 2V to 10V. The polarity of the differential voltage determines the logical state. A logic 0 (the 'space' or OFF state) is represented by a positive differential voltage between the terminals (measured A to B, or + to -). A logic 1 (the 'mark' or ON state) is represented by a negative differential voltage between the terminals (measured A to B, or + to -). Note that at the interface, a logic '0' is represented by a positive voltage, and a logic '1' by a negative voltage. The line receivers convert these signals to the conventional TTL level associations.

| EIA/TIA-<br>422B | BINARY 0<br>(SPACE/OFF) | BINARY 1<br>(MARK/ON) |  |  |  |  |  |
|------------------|-------------------------|-----------------------|--|--|--|--|--|
| SIGNAL           | Positive                | Negative              |  |  |  |  |  |
| A to B           | Differential            | Differential          |  |  |  |  |  |
| (+) to (-)       | Voltage                 | Voltage               |  |  |  |  |  |

Start and stop bits are used to synchronize the DCE to the asynchronous serial data of the DTE. The transmit data line is normally held in the mark state (logical 1). The transmission of a data byte requires that a start bit (a logical 0 or a transition from mark to space) be sent first. This tells the receiver that the next bit is a data bit. The data bits are followed by a stop bit (a logical 1 or a return to the mark state). The stop bit tells the receiver that a complete byte has been received. Thus, 10 bits make up a data byte if the data character is 8 bits long (and no parity is assumed). Nine bits are required if only standard ASCII data is being transmitted (1 start bit + 7 data bits + 1 stop bit). The character size for this module is programmable between 5 and 8 bits.

Parity is a method of judging the integrity of the data. Odd, even, or no parity may be configured for this module. If parity is selected, then the parity bit precedes transmission of the stop bit. The parity bit is a 0 or 1 bit appended to the data to make the total number of 1 bits in a byte even or odd. Parity is not normally used with 8-bit data. Even parity specifies that an even number of logical 1's be transmitted. Thus, if the data byte has an odd number of 1's, then the parity bit is set to 1 to make the parity of the entire character even. Likewise, if the transmitted data has an even number of 1's, then the parity bit is set to 0 to maintain even parity. Odd parity works the same way using an odd number of logical 1's.

Thus, both the DTE & DCE must have the same parity. If a byte is received that has the wrong parity, an error is assumed and the sending system is typically requested to retransmit the byte. Two other parity formats supported by this module are mark and space parity. Mark parity specifies that the parity bit will always be a logical 1, space parity requires that the parity bit will always be 0.

The most common asynchronous serial data format is 1 start bit, 8 data bits, and 1 stop bit, with no parity. The following table summarizes the available data formats:

| START BIT | Binary 0 (a shift from "Mark" to<br>"Space") |
|-----------|----------------------------------------------|
| DATA BITS | 5,6,7, or 8 Bits                             |
| PARITY    | Odd, Even, Stick, or None                    |
| STOP BIT  | Binary 1 (1, 1-1/2, or 2 Bit times)          |

With start, stop, and parity in mind, for an asynchronous data byte, note that at least one bit will be a 1 (the stop bit). This defines the break signal

(all 0 bits with a 1 stop bit lasting longer than one character). A break signal is a transfer from "mark" to "space" that lasts longer than the time it takes to transfer one character. Because the break signal doesn't contain any logical 1's, it cannot be mistaken for data. Typically, whenever a break signal is detected, the receiver will interpret whatever follows as a command rather than data. The break signal is used whenever normal signal processing must be interrupted. In the case of a modem, it will usually precede a modem control command. Do not confuse the break signal with the ASCII Null character, since a break signal is longer than one character time. That is, it is any "space" condition on the line that lasts longer than a single character (including its framing bits) and is usually 1-1/2 to 2 character times long.

The baud rate is a unit of transmission speed equal to the number of electrical signals (signal level changes) sent on a line in one second. It is thus, the electrical signaling rate or frequency at which electrical impulses are transmitted on a communication line. The baud rate is commonly confused with the bit transfer rate (bits-per-second), but baud rate does not equate to the number of bits transmitted per second unless one bit is sent per electrical signal. However, one electrical signal (change in signal level) may contain more than one bit (as is the case with most phone modems). While bits-per-second (bps) refers to the actual number of bits transmitted in one second, the baud rate refers to the number of signal level changes that may occur in one second. Thus, 2400 baud does not equal 2400 bits per second unless 1 bit is sent per electrical signal. Likewise, a 1200bps or 2400bps modem operates at a signaling rate of only 600 baud since they encode 2 and 4 bits, respectively, in one electrical impulse (through amplitude, phase, and frequency modulation techniques). However, for this device, the baud rate is considered equivalent to the bit rate.

### **PMC521 OPERATION**

Connection to each serial channel is provided through connector P1 or J4 (refer to Table 2.1 or 2.2). These pins are tied to the inputs and outputs of EIA/TIA-422B line receivers and drivers. The function of the line receivers is to convert the required EIA/TIA-422B signals to the TTL levels required by the UART (Universal Asynchronous Receiver/Transmitter). The line drivers convert the UART TTL levels to the EIA/TIA-422B voltage levels. The UART provides the necessary conversion from serial-to-parallel (receive) and parallel-to-serial (transmit) for interfacing to the data bus. Additionally, it provides data buffering and data formatting capabilities.

Note that the field serial interface to the carrier board provided through connector P1 or J4 (refer to Table 2.1 or 2.2) is <u>NON-ISOLATED</u>. This means that the field signal return and logic common have a direct electrical connection to each other. As such, care must be taken to avoid ground loops (see Section 2 for connection recommendations). Ignoring this effect may cause errors in operation, and with extreme abuse, possible circuit damage. Refer to Drawing 4502-020 for example communication wiring connections.

### LOGIC/POWER INTERFACE

The logic interface to the carrier board is made through PMC connectors J1/J2. Not all of the PMC logic J1/J2 pin functions is used. J1/J2 also provides +5V to power the module.

A programmable UART device installed on the PMC Module provides the control signals required to operate the board. It decodes the selected addresses and produces the chip selects, control signals, and timing required by the communication registers.

### EIA/TIA-422B SERIAL INTERFACE

# 5.0 SERVICE AND REPAIR

PMC521 User's Manual

### SERVICE AND REPAIR ASSISTANCE

Surface-Mounted Technology (SMT) boards are generally difficult to repair. It is highly recommended that a non-functioning board be returned to Acromag for repair. The board can be easily damaged unless special SMT repair and service tools are used. Further, Acromag has automated test equipment that thoroughly checks the performance of each board. When a board is first produced and when any repair is made, it is tested, placed in a burn-in room at elevated temperature, and retested before shipment.

Please refer to Acromag's Service Policy Bulletin or contact Acromag for complete details on how to obtain parts and repair.

### PRELIMINARY SERVICE PROCEDURE

**CAUTION:** POWER MUST BE TURNED OFF BEFORE REMOVING OR INSERTING BOARDS

### WHERE TO GET HELP www.acromag.com

Before beginning repair, be sure that all of the procedures in Section 2, Preparation For Use, have been followed. Also, refer to the documentation of your carrier/CPU board to verify that it is correctly configured. Replacement of the board with one that is known to work correctly is a good technique to isolate a faulty board.

If you continue to have problems, your next step should be to visit the Acromag worldwide web site at <u>http://www.acromag.com</u>. Our web site contains the most up-to-date product and software information.

### Go to the "Support" tab to access:

- Application Notes
- Frequently Asked Questions (FAQ's)
- Product Knowledge Base
- Tutorials
- Software Updates/Drivers

An email question can also be submitted from within the Knowledge Base or directly from the "Contact Us" tab.

Acromag's application engineers can also be contacted directly for technical assistance via telephone or FAX through the numbers listed at the bottom of this page. When needed, complete repair services are also available.

### Single PMC Board

| Height          | 13.5 mm (0.531 in)   |
|-----------------|----------------------|
| Stacking Height | 10.0 mm (0.394 in)   |
| Depth           | 149.0 mm (5.866 in)  |
| Width           | 74.0 mm (2.913 in) ´ |
| Board Thickness | 1.59 mm (0.062 in)   |
|                 |                      |

PCI Local Bus Interface: Two 64-pin female receptacle header (AMP 120527-1 or equivalent). Universally keyed for 3.3V or 5V signaling.

Front Field I/O: 68-pin, SCSI-3, female receptacle header (AMP 787082-7 or equivalent) for all front I/O models

Rear Field I/O: 64-pin female receptacle header (AMP 120527-1 or equivalent) for PMC rear I/O models only.

| Power Requirements |         |          |
|--------------------|---------|----------|
| 5V (±5%)           | Typical | 750mA    |
| 01 (±070)          | Max.    | 950mA    |
| +/-12V (±5%)       |         | Not used |

**Operating Temperature:** 0 to +70°C. –40°C to +85°C (E Version) **Relative Humidity:** 5-95% Non-Condensing.

**Storage Temperature:** -55°C to 125°C. (-55°C to 105°C for PMC Models) **Non-Isolated:** Logic and field commons have a direct electrical connection.

- Radiated Field Immunity (RFI): Complies with EN61000-4-3 (3V/m, 80 to 1000MHz AM & 900MHz. keyed) and European Norm 61000-6-1 with no register upsets.
- **Conducted R F Immunity (CRFI):** Complies with EN61000-4-6 (3V/rms, 150KHz to 80MHz) and European Norm EN61000-6-1 with no register upsets.
- **Electromagnetic Interference Immunity (EMI):** No register upsets occur under the influence of EMI from switching solenoids, commutator motors, and drill motors.
- **Surge Immunity:** Not required for signal I/O per European Norm EN61000-6-1.

**Radiated Emissions:** Meets or exceeds European Norm EN50081-1 for class B equipment. Shielded cable with I/O connections in shielded enclosure are required to meet compliance.

**Mean Time Between Failure:** 2,321,047 hours at 25°C by MIL-HDBK-217F, notice 2.

### 6.0 SPECIFICATIONS PHYSICAL

### Connectors

*Table 6.1:* Power Requirements

5V Maximum rise time of 100m seconds

### ENVIRONMENTAL

| SPECIFICATIONS<br>UART | Exar XR17D158: Obtain data sheet at http://www.exar.com                                                                                                                                                                                                                                                                                                                                                                                  |
|------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RS-422/485 Channels    | Channel Configuration: Eight independent, non-isolated EIA/TIA-422B serial channels with a common signal return connection.                                                                                                                                                                                                                                                                                                              |
|                        | Data Rate: 3.000M bits/sec, Maximum. (Limited by XR17D158B UART).<br>1.8432Mbps Maximum with standard (14.7456MHz) crystal.                                                                                                                                                                                                                                                                                                              |
|                        | Interface: Asynchronous serial only.                                                                                                                                                                                                                                                                                                                                                                                                     |
|                        | Cable Length: 4000 feet (1200m), typical @ 250Kbps.                                                                                                                                                                                                                                                                                                                                                                                      |
|                        | Character Size: Software Programmable 5 to 8 bits.                                                                                                                                                                                                                                                                                                                                                                                       |
|                        | Parity: Software Programmable odd, even, or no parity.                                                                                                                                                                                                                                                                                                                                                                                   |
|                        | Stop Bits: Software Programmable 1, 1-1/2, or 2 bits.                                                                                                                                                                                                                                                                                                                                                                                    |
|                        | Data Register Buffers: The data registers are double buffered (16C450 mode), or 64-byte FIFO buffered (FIFO mode).                                                                                                                                                                                                                                                                                                                       |
|                        | Interrupts: Receiver Line Status Interrupt (i.e. Overrun, Parity, or Framing error, or Break Interrupt); Received/Transmit FIFO level reached or Character Time-Out; or Modem Status; Xon/Xoff/Special Character Detect.                                                                                                                                                                                                                 |
|                        | Termination Resistors: $120\Omega$ Termination Resistors are installed in sockets<br>on the module and may be removed if required (see Drawing 4502-019 for<br>location). For an RS422 network install a terminating resistor at the end of<br>the network only. For an RS422/RS485 network, transmitting and receiving<br>channels may have terminating resistors (RT) at both ends of the network<br>(see interface Drawing 4502-020). |
|                        | Bias Resistor: $560\Omega$ pullup to +5V on (+) output lines, $560\Omega$ pull-down to GND on (-) lines, installed in sockets on board and may be removed if required (see Drawing 4502-019 for location).                                                                                                                                                                                                                               |
| RS-422/485 Transmitter | Differential Output: 2.0V Minimum (Loaded 50 $\Omega$ ).                                                                                                                                                                                                                                                                                                                                                                                 |
| Outputs                | Common-Mode Output Voltage: 3V Max.                                                                                                                                                                                                                                                                                                                                                                                                      |
|                        | Propagation Delay: 60ns Max, $R_{DIFF} = 54\Omega$ , $C_L = 100pF$                                                                                                                                                                                                                                                                                                                                                                       |
|                        | Driver Rise and Fall Time: 40ns Max, $R_{DIFF}$ = 54 $\Omega$ , $C_L$ = 100pF                                                                                                                                                                                                                                                                                                                                                            |
| RS-422/485 Receiver    | Data Rate: Up to 3.000Mbps (Limited to by XR17D158B UART).                                                                                                                                                                                                                                                                                                                                                                               |
| Inputs                 | Input Voltage Range: -8V to +12.5V DC Maximum.                                                                                                                                                                                                                                                                                                                                                                                           |
|                        | Input High Threshold: 2.0V Minimum.                                                                                                                                                                                                                                                                                                                                                                                                      |
|                        | Input Low Threshold: 0.8V Maximum.                                                                                                                                                                                                                                                                                                                                                                                                       |
|                        | Input Resistance: 12K $\Omega$ Minimum, 25K $\Omega$ Typical.                                                                                                                                                                                                                                                                                                                                                                            |

### SPECIFICATIONS

**PCI Local Bus Interface** 

PMC521 Compatibility: Conforms to PCI Bus Specification, Revision 2.3 and PMC Specification, P1386.1

4K Memory Space Required: One Base Address Register

PCI commands Supported: Configuration Read/Write memory Read/Write, 32,16, and 8-bit data transfer types supported.

Signaling: Universal PCI Bus buffers – Auto sense 3.3V or 5V operation. INTA#: Interrupt A is used to request an interrupt. Source of interrupt can be from the Digital I/O, or Counter/Timer Functions.

Access Times: 8 PCI Clock Cycles for all register accesses.

## **APPENDIX**

| CABLE: MODEL 5028-<br>432 (SCSI-3 to Round,<br>Shielded) | <ul> <li>Type: Round shielded cable, 34 twisted pairs (SCSI-3 male connector at both ends). The cable length is 2 meters (6.56 feet). This shielded cable is recommended for all I/O applications (both digital I/O and precision analog I/O).</li> <li>Application: Used to connect Model 5025-288 termination panel to the front panel of the Board.</li> <li>Length: Standard length is 2 meters (6.56 feet). Consult factory for other lengths. It is recommended that this length be kept to a minimum to reduce noise and power loss.</li> <li>Cable: 68 conductors, 28 AWG on 0.050 inch centers (permits mass termination for IDC connectors), foil/braided shield inside a PVC jacket.</li> <li>Connectors: SCSI-3, 68-pin male connector with backshell.</li> <li>Keying: The SCSI-3 connector has a "D Shell".</li> <li>Schematic and Physical Attributes: See Drawing 4501-919.</li> <li>Electrical Specifications: 30 VAC per UL and CSA (SCSI-3 connector spec.'s).</li> <li>Operating Temperature: -30°C to +80°C.</li> <li>Storage Temperature: -40°C to +85°C.</li> <li>Shipping Weight: 1.0 pound (0.5Kg), packed.</li> </ul>                                                                                              |
|----------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TERMINATION PANEL:<br>MODEL 5025-288                     | <ul> <li>Type: Termination Panel For 68 Pin SCSI-3 Cable Connection</li> <li>Application: To connect field I/O signals to the board. <i>Termination</i><br/><i>Panel:</i> Acromag Part 4001-066. The 5025-288 termination panel<br/>facilitates the connection of up to 68 field I/O signals and connects to the<br/>board (connectors only) via a round shielded cable (Model 5028-<br/>432). Field signals are accessed via screw terminal strips. The terminal<br/>strip markings on the termination panel (1-68) correspond to field I/O<br/>(pins 1-68) on the board. Each board has its own unique<br/>pin assignments. Refer to the board manual for correct wiring<br/>connections to the termination panel.</li> <li>Schematic and Physical Attributes: See Drawing 4501-920.</li> <li>Field Wiring: 68-position terminal blocks with screw clamps. Wire range<br/>12 to 26 AWG.</li> <li>Mounting: Termination panel is snapped on the DIN mounting rail.</li> <li>Printed Circuit Board: Military grade FR-4 epoxy glass circuit board, 0.063<br/>inches thick.</li> <li>Operating Temperature: -40°C to +100°C.</li> <li>Storage Temperature: -40°C to +100°C.</li> <li>Shipping Weight: 1.0 pounds (0.5kg) packaged.</li> </ul> |

Acromag, Inc. Tel:248-295-0310 Fax:248-624-9234 Email:solutions@acromag.com http://www.acromag.com





|                        | CHANNEL | 0                             | 0                                      | 0       | 0       | -                            | -                            | -     | 1     | 2                              | 2                              | 2                         | 2     | 3         | e                             | e     | е                             | 4                            | 4       | 4                             | 4                             | 5                            | 5                             | 5                             | 5                             | 9       | 9                            | 9                             | 9                                               | 7                            | 7                             | 7                                                                | 7                                                       |                                                                                                                                                                                            |                                                                                                                             | -019A                                                                                                                                             |  |
|------------------------|---------|-------------------------------|----------------------------------------|---------|---------|------------------------------|------------------------------|-------|-------|--------------------------------|--------------------------------|---------------------------|-------|-----------|-------------------------------|-------|-------------------------------|------------------------------|---------|-------------------------------|-------------------------------|------------------------------|-------------------------------|-------------------------------|-------------------------------|---------|------------------------------|-------------------------------|-------------------------------------------------|------------------------------|-------------------------------|------------------------------------------------------------------|---------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|--|
| T FRMINATION RESISTORS |         | :A 120 OHM TX0+/- TERMINATION | B 120 OHM RX0+/- TERMINATION           | 120 OHM | 120 OHM | A 120 OHM TX1+/- TERMINATION | B 120 OHM RX1+/- TERMINATION |       |       | ::A 120 OHM TX2+/- TERMINATION | ::B 120 OHM RX2+/- TERMINATION | 120 OHM                   |       |           | B 120 OHM RX3+/- TERM INATION |       | D 120 OHM RTS3+/- TERMINATION | A 120 OHM TX4+/- TERMINATION | 120 OHM | C 120 OHM CTS4+/- TERMINATION | D 120 OHM RTS4+/- TERMINATION | A 120 OHM TX5+/- TERMINATION | B 120 OHM RX5+/- TERM INATION | C 120 OHM CTS5+/- TERMINATION | D 120 OHM RTS5+/- TERMINATION | 120 OHM | B 120 OHM RX6+/- TERMINATION | C 120 OHM CTS6+/- TERMINATION | D 120 OHM RTS6+/- TERMINATION                   | A 120 OHM TX7+/- TERMINATION | :B 120 OHM RX7+/- TERMINATION | C 120 OHM CTS7+/- TERMINATION                                    | R37:D 120 OHM RTS7+/- TERMINATION                       |                                                                                                                                                                                            |                                                                                                                             | 4502-0194                                                                                                                                         |  |
|                        | SIP     | R30:A                         | R30:B                                  | R30:C   | R30:D   | R31:A                        | R31:B                        | R31:C | R31:D | R32:A                          | R32:B                          | R32:C                     | R32:D | R33:A     | R33:B                         | R33:C | R33:D                         | R34:A                        | R34:B   | R34:C                         | R34:D                         | R35:A                        | R35:B                         | R35:C                         | R35:D                         | R36:A   | R36:B                        | R36:C                         | R36:D                                           | R37:A                        | R37:B                         | R37:C                                                            | R37                                                     |                                                                                                                                                                                            |                                                                                                                             |                                                                                                                                                   |  |
|                        |         |                               | PIN 1 POSITION IS IDENTIFIED BY A DOT. |         | ▶       | 7<br>२3                      | R3<br>6<br>8                 | 3     |       |                                |                                | R41 560 OHM TX#- BIAS GND |       |           |                               |       |                               |                              |         | <b>•</b> ]<br>31              |                               | R4 R2 R4                     | 32                            |                               |                               |         |                              |                               | NOTES CONCERNING RESISTOR PLACEMENT AND REMOVAL | -                            |                               | RESISTORS(RT) AT BOTH ENDS OF THE NETWORK. THE PMC 521 HAS USER- | REMOVEABLE PLUG-IN SIP TERMINATION RESISTORS (120 OHM). | THERE MUST BE AT MOST, ONE SET OF BIAS RESISTORS ASSOCIATED<br>WITH EACH PAIR OF SIGNAL WIRES TO KEEP THE NETWORK FROM<br>FLOATING WHEN NO UNITS ARE TRANSMITTING. (SEE DR AWING 4502-020) | THE TXD AND RTSLINES SOURCED FROM A PORT CAN BE ENABLED VIA<br>SOFTWARE. IF SO, THE NETWORK BIAS RESISTOR'S ASSOCIATED WITH | EACH PAIR OF SIGNAL WIRESWILL NOT BE NEEDED. THESE RESISTORS<br>ARE INSTALLED IN SOCKETSAND CAN BE REMOVED IF THESE DRIVERSARE<br>ALWAYS ENABLED. |  |
|                        |         |                               |                                        |         |         |                              |                              |       |       |                                |                                | FIELD                     | 0/1   | INTERFACE |                               |       |                               |                              |         |                               |                               |                              |                               |                               |                               |         |                              |                               | C<br>Z                                          |                              | 1. A                          | Υ.                                                               | R                                                       | 2.<br>1                                                                                                                                                                                    | ⊢ŭı<br>rö                                                                                                                   | ı₹₹                                                                                                                                               |  |

PMC521 RESISTOR LOCATIONS

PMC521 User's Manual



Acromag, Inc. Tel:248-295-0310 Fax:248-624-9234 Email:solutions@acromag.com http://www.acromag.com



## **Revision History**

The following table shows the revision history for this document:

| Release Date | Version | EGR/DOC | Description of Revision                 |
|--------------|---------|---------|-----------------------------------------|
| 24 APR 2018  | E       | CAB/ARP | Correction of Maximum Data Rate (Mbps). |
|              |         |         |                                         |
|              |         |         |                                         |
|              |         |         |                                         |
|              |         |         |                                         |
|              |         |         |                                         |