



electronic payment exchange

---

# PayTrans\_POS Terminal Communications Specification

Public - Security Level 0

---

March 2022

**REVISION HISTORY**

| Date   | Version | Author(s) | Comments                                        |
|--------|---------|-----------|-------------------------------------------------|
| 5/5/16 | 2.0     | C. Meaney | Corrections to typos, formatted to new template |
|        |         |           |                                                 |

**CONFIDENTIALITY STATEMENT**

This document contains confidential and proprietary information that belongs exclusively to Electronic Payment Exchange (EPX). Receipt of this document imposes the obligation on the recipient to protect the information from loss or disclosure to other parties.

This publication may not be reproduced or distributed for any purpose without the written permission of EPX.

© 2022 Electronic Payment Exchange. All rights reserved.

# Contents

---

|                                                                     |    |
|---------------------------------------------------------------------|----|
| Introduction .....                                                  | 1  |
| Access Options .....                                                | 2  |
| Dial Access .....                                                   | 2  |
| Message Format Structure .....                                      | 3  |
| General Format Structure .....                                      | 3  |
| Longitudinal Redundancy Check (LRC) .....                           | 3  |
| Character Sets .....                                                | 4  |
| Data link character set .....                                       | 4  |
| Modes of Normal Operation (Flowcharts) .....                        | 6  |
| Credit Card, Debit Card, EBT Single-transaction mode .....          | 6  |
| ATM Single-Transaction mode .....                                   | 7  |
| Single-batch mode .....                                             | 8  |
| Error Flow Diagrams .....                                           | 9  |
| No response to host ENQ .....                                       | 9  |
| Recoverable LRC or parity error in batch-settlement process .....   | 10 |
| Unrecoverable LRC or parity error in batch-settlement process ..... | 11 |

---

# List of Figures

---

|                                                         |    |
|---------------------------------------------------------|----|
| Figure 1: Dial Access .....                             | 2  |
| Figure 2: General Message Format .....                  | 3  |
| Figure 3: Longitudinal Redundancy Check (LRC) .....     | 3  |
| Figure 4: ASCII Character Set.....                      | 5  |
| Figure 5: Credit Card Single-Transaction.....           | 6  |
| Figure 6: Debit Card Single-Transaction .....           | 7  |
| Figure 7: Single-Batch Mode .....                       | 8  |
| Figure 8: No Response .....                             | 9  |
| Figure 9: Recoverable LRC Error in Batch Response ..... | 10 |
| Figure 10: Unrecoverable LRC Error in Batch .....       | 11 |

# Introduction

This specification document provides details for the VISA 2nd Generation Terminal Communications Protocol. The following flow charts depict the protocol level for messages sent between the terminal and the processor.

The purpose of this document is to help provide information necessary to develop a communications interface for transmitting transaction information to and from a POS terminal and an acquirer/processor. The flow charts include the modes of normal operation as well as conditions that may be recoverable or result in cancelled transactions.

This document was created under the assumption that the reader already possesses current knowledge of POS processing and data communications.

# Access Options

## Dial Access

Figure 1 depicts the initial communication between the Terminal device and the EPX host.

Figure 1: Dial Access



# Message Format Structure

## General Format Structure

*Figure 2* depicts a general message format and flow used for Visa 2nd generation messaging. A “message” refers to a data frame starting with a start-of-text (STX), followed by information characters and ending with an end-of-text (ETX) and an LRC (or Longitudinal Redundancy Check).

Figure 2: General Message Format

|     |            |     |     |
|-----|------------|-----|-----|
| STX | Data Frame | ETX | LRC |
|-----|------------|-----|-----|

## Longitudinal Redundancy Check (LRC)

A Longitudinal Redundancy Check or LRC is depicted in *Figure 3*. An LRC helps ensure the data integrity of information messages. An LRC character is generated and added to all data messages in order to detect and recover from any resulting errors during transmission. An LRC is calculated by doing an exclusive OR of each byte in the message, starting with the first byte after the STX and including the ETX.

Figure 3: Longitudinal Redundancy Check (LRC)



For more detailed description of the LRC algorithm see:

[https://en.wikipedia.org/wiki/Longitudinal\\_redundancy\\_check](https://en.wikipedia.org/wiki/Longitudinal_redundancy_check)

# Character Sets

## Data link character set

The VISA 2nd Generation protocol uses characters defined within the ASCII character set. [Table 1](#) provides a partial listing of the special-use characters used by this protocol.

Table 1: Control-character summary

| Character | DEC | HEX | Name                              |
|-----------|-----|-----|-----------------------------------|
| STX       | 2   | 02  | Start of Text                     |
| ETX       | 3   | 03  | End of Text                       |
| EOT       | 4   | 04  | End of Transmission               |
| ENQ       | 5   | 05  | Enquiry                           |
| ACK       | 6   | 06  | Acknowledgement                   |
| BEL       | 7   | 07  | Bell, Affirmative Acknowledgement |
| DLE       | 16  | 10  | Data Link Escape                  |
| NAK       | 21  | 15  | Negative Acknowledgement          |
| ETB       | 23  | 17  | End of Transmission Block         |

Figure 4: ASCII Character Set

| Bits           |                |                |                |                | 0              | 0              | 0        | 1     | 0 | 1 | 1 | 0   | 1 | 0 | 1 | 1 | 1 |
|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------|-------|---|---|---|-----|---|---|---|---|---|
| b <sub>7</sub> | b <sub>6</sub> | b <sub>5</sub> | b <sub>4</sub> | b <sub>3</sub> | b <sub>2</sub> | b <sub>1</sub> | Column ↓ | Row ↓ | 0 | 1 | 2 | 3   | 4 | 5 | 6 | 7 |   |
| 0              | 0              | 0              | 0              | 0              | NUL            | DLE            | SP       | 0     | @ | P | ' | p   |   |   |   |   |   |
| 0              | 0              | 0              | 1              | 1              | SOH            | DC1            | !        | 1     | A | Q | a | q   |   |   |   |   |   |
| 0              | 0              | 1              | 0              | 2              | STX            | DC2            | "        | 2     | B | R | b | r   |   |   |   |   |   |
| 0              | 0              | 1              | 1              | 3              | ETX            | DC3            | #        | 3     | C | S | c | s   |   |   |   |   |   |
| 0              | 1              | 0              | 0              | 4              | EOT            | DC4            | \$       | 4     | D | T | d | t   |   |   |   |   |   |
| 0              | 1              | 0              | 1              | 5              | ENQ            | NAK            | %        | 5     | E | U | e | u   |   |   |   |   |   |
| 0              | 1              | 1              | 0              | 6              | ACK            | SYN            | &        | 6     | F | V | f | v   |   |   |   |   |   |
| 0              | 1              | 1              | 1              | 7              | BEL            | ETB            | '        | 7     | G | W | g | w   |   |   |   |   |   |
| 1              | 0              | 0              | 0              | 8              | BS             | CAN            | (        | 8     | H | X | h | x   |   |   |   |   |   |
| 1              | 0              | 0              | 1              | 9              | HT             | EM             | )        | 9     | I | Y | i | y   |   |   |   |   |   |
| 1              | 0              | 1              | 0              | 10             | LF             | SUB            | *        | :     | J | Z | j | z   |   |   |   |   |   |
| 1              | 0              | 1              | 1              | 11             | VT             | ESC            | +        | ;     | K | [ | k | {   |   |   |   |   |   |
| 1              | 1              | 0              | 0              | 12             | FF             | FC             | ,        | <     | L | \ | l |     |   |   |   |   |   |
| 1              | 1              | 0              | 1              | 13             | CR             | GS             | -        | =     | M | ] | m | }   |   |   |   |   |   |
| 1              | 1              | 1              | 0              | 14             | SO             | RS             | .        | >     | N | ^ | n | ~   |   |   |   |   |   |
| 1              | 1              | 1              | 1              | 15             | SI             | US             | /        | ?     | O | _ | o | DEL |   |   |   |   |   |

# Modes of Normal Operation (Flowcharts)

## Credit Card, Debit Card, EBT Single-transaction mode

Figure 5 depicts a normal single-transaction cycle between a terminal and the host processor during a credit card authorization request.

Figure 5: Credit Card Single-Transaction



# ATM Single-Transaction mode

Figure 6 depicts a normal single-transaction cycle between a terminal and the host processor during a debit card authorization request.

Figure 6: Debit Card Single-Transaction



# Single-batch mode

Figure 7 depicts a single-batch cycle between a terminal and the host processor during settlement.

Figure 7: Single-Batch Mode



# Error Flow Diagrams

## No response to host ENQ

Figure 8 depicts protocol for when the terminal does not respond to the Host's enquiry. The host will send at least 4 ENQ before disconnecting.

Figure 8: No Response



# Recoverable LRC or parity error in batch-settlement process

Figure 9 depicts a scenario in which the terminal receives an error in a batch response message and sends a NAK and request for retransmission, eventually receiving a response without error.

Figure 9: Recoverable LRC Error in Batch Response



# Unrecoverable LRC or parity error in batch-settlement process

Figure 10 depicts a scenario in which the terminal receives an error in a batch response message. The host will make three attempts before disconnection.

Figure 10: Unrecoverable LRC Error in Batch

