

#### LIMITED USE LICENSE AGREEMENT

Sangoma Technologies Inc. provides the computer software program contained on the medium in this package (hereinafter called the Program) and licenses its use.

THE LICENSEE SHOULD CAREFULLY READ THE FOLLOWING TERMS AND CONDITIONS BEFORE ATTEMPTING TO USE THIS PRODUCT. INSERTION OF ANY OF THE DISKETTES IN THIS PACKAGE INTO ANY MACHINE INDICATES THE LICENSEE'S ACCEPTANCE OF THESE TERMS AND CONDITIONS. IF THE LICENSEE DOES NOT AGREE WITH THE TERMS AND CONDITIONS. THE LICENSEE SHOULD PROMPTLY RETURN THE PACKAGE WITHIN 15 DAYS UNUSED AND UNCOPIED IN ANY WAY SHAPE OR FORM, AND MONIES WILL BE REFUNDED.

#### LICENSE:

- a. The purchaser of this license (hereinafter called the Licensee) is granted a personal, non-exclusive license to use the Program in accordance with the terms and conditions set out in this agreement.
- b. The Program may be used only on a single computer per license granted.
- The Licensee and the Licensee's agents and employees shall protect the confidentiality of the Program and shall not C. distribute or make available the Program or documentation to any third party.
- The Licensee may copy the programs into machine readable or printed form for backup or modification purposes only d. in support of the Licensee's use on a single machine. The Licensee must reproduce and include the copyright notice on any copy, modification or portion merged into another program.
- Any portion of the Program merged into or used in conjunction with another program will continue to be subject to e. the terms and conditions of this agreement.
- £ The Licensee may not assign or transfer the license or the program to any third party without the express prior consent of Sangoma Technologies Inc.
- The licensee acknowledges that this license is only a limited license to use the Program and documentation, and that g. Sangoma Technologies Inc. retains full title to the program and documentation.
- h. The Licensee shall not use, copy, modify or transfer the Program or documentation or any copy, modification or merged portion, in whole or in part, except as expressly provided for in this license. If the Licensee transfers possession of any copy, modification or merged portion of the program to a third party, the license is automatically terminated under this agreement.

#### TERM:

The license is effective until terminated. The licensee may terminate the license at any time by destroying the Program together with all copies, modifications and merged portion in any form. The Licensee agrees upon such termination to destroy the Program together with all copies, modifications and merged portion in any form.

#### LIMITED WARRANTY:

The Program is provided "as is" without warranty of any kind, either expressed or implied, including, but not limited to, the implied warranties of merchantability and fitness for a particular purpose. The entire risk as to the performance of the Program is with the Licensee. Should the Program prove defective, the Licensee (and not Sangoma Technologies Inc. or an authorized dealer) shall assume the entire cost of all necessary servicing, or correction. However, Sangoma Technologies Inc. warrants the diskettes on which the Program is furnished will be free of defects in materials or workmanship under normal use for a period of 90 days from the date of delivery to the Licensee. In no event will Sangoma Technologies Inc. be liable for any damages, including incidental or consequential damages arising out of the use or inability to use the Program, even if Sangoma Technologies Inc. or an authorized dealer have been advised of the possibility of such damages, or for any claim by any other party.

The Licensee acknowledges that the Licensee has read this agreement, understands it, and agrees to be bound by its terms and conditions. The Licensee further agrees that it is the complete and exclusive statement of the agreement between the parties and supersedes any proposal or prior agreement, oral or written, and any other communications between the parties relating to the subject matter of this agreement.

# **Table of Contents**

| 1. | Introduction       1 - 1         Conventions used in this manual       1 - 1 |
|----|------------------------------------------------------------------------------|
| 2. | Hardware                                                                     |
|    | General                                                                      |
|    | S502 v 3.0 2 - 1                                                             |
|    | S502E card 2 - 2                                                             |
| 3. | Software modules                                                             |
|    |                                                                              |
|    | XI OAD FXF 3-2                                                               |
|    | HDLC.502                                                                     |
|    | HDLC.SDL                                                                     |
|    | XIP.COM                                                                      |
|    | X25_TEST.EXE                                                                 |
| 4. | The programmer's interface 4 - 1                                             |
|    | Using the HDLC Shared Memory Interface 4 - 1                                 |
|    | Using the XIP TSR Interface 4 - 2                                            |
| 5. | COMMAND Codes                                                                |
|    | CONFIGURE_LINK (0x01) 5 - 2                                                  |
|    | HDLC_OPEN (0x02)                                                             |
|    | HDI C CLOSE $(0 \times 03)$ 5.4                                              |
|    | $IIDEC\_CEOSE(0x03) \dots 5-4$ $I INK SETUP(0x04) 5-5$                       |
|    | LINK DISCONNECT $(0x05)$ 5 - 6                                               |
|    | LINK STATUS $(0x06)$ 5 - 7                                                   |
|    | READ HDLC STATISTICS (0x07)                                                  |
|    | FLUSH_HDLC_STATISTICS (0x08)                                                 |
|    | READ_COMMS_ERR_STATS (0x09) 5 - 13                                           |
|    | FLUSH_COMMS_ERR_STATS (0x0A) 5 - 15                                          |
|    | SET_GLOBAL_VARIABLES (0x0B) 5 - 16                                           |
|    | READ_MODEM_STATUS (0x0C) 5 - 17                                              |
|    | FLUSH_HDLC_DATA_BUFFERS (0x0D) 5 - 18                                        |
|    | SEND_UNNUMBERED_INFORMATION_FRAME (0x10)                                     |
|    |                                                                              |
|    | HDLC_WRITE (0x11) 5 - 21                                                     |

|     | READ_HDLC_CONFIGURATION (0x12) 5 - 23                      |
|-----|------------------------------------------------------------|
|     | SET_HDLC_CONFIGURATION (0x13) 5 - 24                       |
|     | READ_CODE_VERSION (0x15) 5 - 26                            |
|     | OPERATE_DATALINE_MONITOR (0x14) 5 - 27                     |
|     | READ_TRACE_DATA (0x16) 5 - 29                              |
|     | HDLC_READ (0x21) 5 - 32                                    |
|     |                                                            |
| 6.  | Notes on Return Codes                                      |
|     |                                                            |
|     |                                                            |
| 7.  | PC/SDLA Interface Bytes                                    |
| 0   |                                                            |
| 8.  | General Programming Notes                                  |
| 0   | Example Code 0, 1                                          |
| ).  | Example code for interfacing with the XIP TSR 9 - 1        |
|     | Example code for interface to the shared memory area $9-5$ |
|     | Example showing interface to the shared memory area        |
| 10. | HDLC Implementation 10 - 1                                 |
|     | HDLC Protocol Specifics                                    |
|     |                                                            |
| 11. | Error messages 11 - 1                                      |
|     | XLOAD.EXE 11 - 1                                           |
|     | XIP.COM 11 - 2                                             |
|     | X25_TST.EXE                                                |
|     | —                                                          |

# 2. Introduction

The Sangoma S502 SDLA card is a general co-processor communication adapter capable of supporting any RS232 based communication protocol autonomously, and providing information transfer into PC work space. V.35 and X.21 interfaces are available.

This document describes the support of the HDLC protocol on the card, together with special enhancements implemented in the Sangoma HDLC code. It should be noted that this version of HDLC code provides the frame level support for the Sangoma X.25 code and the code referred to in this manual is actually X.25 code with the X.25 level disabled.

The hardware/software solution handles the link level autonomously, without

PC intervention. The PC accesses the system as required to send or receive Information frames and to recover status and statistical data..

The implementation of HDLC on the S502 adapter corresponds to the specifications of the ISO document ISO 7776: "Information processing systems - Data Communication - High-level data link control procedures- Description of HDLC LAPB-compatible DTE data link procedures", (first edition 1986-12-15).

# Conventions used in this manual

Programming conventions used are as follows:

Variables described with an 0x prefix are hexadecimal values. All other variables are decimal.

For bit mapping, the **least significant** (**low**) bit is denoted as bit **0**.

# 3. Hardware

# General

Sangoma supports HDLC on both the S502 v 3.0 and the S502E short card.

# S502 v 3.0

The Sangoma S502 v 3.0 SDLA adapter is compatible with an ISA or Microchannel bus. The hardware configuration is as follows:

# POST setup for MCA version:

Copy the .ADF file provided with your software onto the setup disk for your MCA machine. Use the automatic setup. Use the address 360 (default) unless it clashes with one of the other cards in the machine.

# **Clock speed:**

This is factory set by Jumper **JP3** on the ISA card and **JP1** on the MCA card. Do not change without consulting your Sangoma dealer.

# I/O port address:

This is set by Jumpers JP1 and JP2 on the ISA card.

| JP1          | JP2          | Selection                                |
|--------------|--------------|------------------------------------------|
| Jumpered     | Jumpered     | IO Address 250-252 (Hex)                 |
| Not Jumpered | Jumpered     | IO Address 300-302 (Hex)                 |
| Jumpered     | Not Jumpered | IO Address 350-352 (Hex)                 |
| Not Jumpered | Not Jumpered | IO Address 360-362<br>(Hex) <sup>®</sup> |

<sup>The Factory default.</sup>

#### Memory sharing:

This is set by software writing to the appropriate ports.

#### Cable pinout

#### <u>RS232</u>

| Function     | Pin # |                         |
|--------------|-------|-------------------------|
| TxD          | 2     |                         |
| RxD          | 3     |                         |
| GND          | 7     |                         |
| RTS          | 4     |                         |
| CTS          | 5     |                         |
| DTR          | 20    |                         |
| DSR          | 6     |                         |
| DCD          | 8     |                         |
| TxC          | 15    |                         |
| RxC          | 17    |                         |
| BxC          | 24    | (On board clock source) |
| Power (+12v) | 10    |                         |

# PLEASE NOTE:

The S502A card provides a +12V source on Pin 10 of the DB25 plug to power interface converters. Some modems or other DCE devices may ground or put voltage on Pin 10. In this case, the PC may not boot, the card may get hot or the DCE device may get hot. The solution is to disconnect the Pin 10 cable connection.

# S502E card

This is a short 4 layer card, compatible with the ISA bus. Unlike the S502 v 3.0, it supports hardware interrupts as well as operating in a passive polled mode. The S502E is available with either RS232 or V.35/X.21 interfaces.

# Clock speed:

This is factory set by Jumpers **JP1** and **JP2**. Do not change without consulting your Sangoma dealer.

# I/O port address:

This is set by Jumper **JP3**.

| Pins 1-2     | Pins 3-4     | Selection                                |
|--------------|--------------|------------------------------------------|
| Jumpered     | Jumpered     | IO Address 250-252 (Hex)                 |
| Not Jumpered | Jumpered     | IO Address 300-302 (Hex)                 |
| Jumpered     | Not Jumpered | IO Address 350-352 (Hex)                 |
| Not Jumpered | Not Jumpered | IO Address 360-362<br>(Hex) <sup>®</sup> |

Factory default.

## **IRQ** Selection

The optional IRQ is set using **JP4**.

| Pins 1-2 | Pins 3-4 | Pins 5-6 | Pins 7-8 | Selection          |
|----------|----------|----------|----------|--------------------|
| IN       | OUT      | OUT      | OUT      | IRQ 2              |
| OUT      | IN       | OUT      | OUT      | IRQ 3              |
| OUT      | OUT      | IN       | OUT      | IRQ 5              |
| OUT      | OUT      | OUT      | IN       | IRQ 7 <sup>∞</sup> |

<sup>™</sup>Factory default.

# Memory sharing:

This is set by software writing to the appropriate ports.

#### **Cable pinouts**

#### <u>RS232</u>

| <b>Function</b> | <u>Pin #</u> |                         |
|-----------------|--------------|-------------------------|
| TxD             | 2            |                         |
| RxD             | 3            |                         |
| GND             | 7            |                         |
| RTS             | 4            |                         |
| CTS             | 5            |                         |
| DTR             | 20           |                         |
| DSR             | 6            |                         |
| DCD             | 8            |                         |
| TxC             | 15           |                         |
| RxC             | 17           |                         |
| BxC             | 24           | (On board clock source) |
|                 |              |                         |

#### V.35/X.21

| Pin # | Function                             |
|-------|--------------------------------------|
| 4     | RTS                                  |
| 5     | CTS                                  |
| 6     | DSR                                  |
| 7     | GND                                  |
| 8     | DCD                                  |
| 10    | TxA                                  |
| 9     | TxB                                  |
| 12    | RxA                                  |
| 11    | RxB                                  |
| 19    | Tx Clock A                           |
| 20    | DTR (V10 signal)                     |
| 14    | DTRA (V11 signal)                    |
| 13    | DTRB (V11 signal)                    |
| 21    | Tx Clock B                           |
| 22    | RI                                   |
| 23    | Rx Clock A                           |
| 25    | Rx Clock B                           |
| 18    | Aux. Clock A (On board clock source) |
| 16    | Aux. Clock B (On board clock source) |

DLC FOR MS-DOS

# 4. Software modules

## General

This manual describes two interfaces which may be used to interface with the HDLC code running on the SDLA hardware:

- 1. The shared memory interface where the SDLA card is operated by reading and writing structures to positions in the shared memory window. Usage of this interface is described in a later section.
- 2. Under PC-DOS, XIP.COM may be used to provide a simple interface to avoid the complexities of direct memory accesses. The application interfaces with the XIP by means of a Software Interrupt and the XIP, in turn, reads and writes to the shared memory areas. Usage of this interface is described later.

Software support for HDLC consists of the following modules:

**XLOAD.EXE** loads the HDLC microcode onto the SDLA adapter, configures it, runs through a self test and starts the program.

**HDLC.502** is the run time HDLC downloadable module loaded by XLOAD.EXE.

**SDLA\_TST.502** is a module used for testing the SDLA hardware before loading HDLC.502.

**HDLC.SDL** is a file defining the HDLC configuration parameters.

**XIP.COM** is a PC-DOS TSR program which provides a simple method of interfacing with the adapter by means of a Software Interrupt.

**X25\_TEST.EXE** is a high-level interface to the HDLC code which allows the user to perform individual interface

HDLC FOR MS-DOS

# **XLOAD.EXE**

XLOAD.EXE is a PC-DOS program and has the following command line syntax:

XLOAD -c<CODE> -f<CONFIG>

where:

| CODE   | is the name of the file containing the SDLA<br>executable code for the HDLC<br>implementation, e.g. HDLC.502. |
|--------|---------------------------------------------------------------------------------------------------------------|
| CONFIG | is the name of the file containing the HDLC configuration information, e.g. HDLC.SDL                          |

#### Example:

XLOAD -c\HDLC\HDLC.502 -f\HDLC\HDLC.SDL

XLOAD will perform a system test, read the CODE and CONFIG files and load and configure the adapter. If XLOAD does not execute successfully, an error message will be displayed and an exit code will be returned. XLOAD may also display configuration warning messages. A description of these messages and corresponding exit codes are described in Section "Error Messages".

## HDLC.502

This is the HDLC support code which is loaded onto the card and establishes the link level communications.

HDLC.502 is **NOT** a PC-DOS program and is not executable under DOS.

# HDLC.SDL

This file contains the HDLC code configuration data. HDLC.SDL is an ASCII text file and may be edited using any standard editor.

The default parameters are as follows:

| io_port              |     | = 0x360                           |
|----------------------|-----|-----------------------------------|
| mem_segment          |     | $= 0 \mathbf{x} \mathbf{C} 0 0 0$ |
| mem_window           |     | = 8                               |
| line_speed           |     | = 9600                            |
| DTE                  |     | = 1                               |
| T1                   |     | = 1                               |
| T2                   |     | = 0                               |
| T4                   |     | = 10                              |
| N2                   |     | = 10                              |
| k                    | = 7 |                                   |
| auto_modem_err_fixup |     | = 1                               |
| auto_HDLC            |     | = 1                               |
| HDLC_config_options  |     | = 0 x 0 0                         |
| max_I_field_length   |     | = 1027                            |

#### io\_port

This corresponds to the base port address as set by the jumpers on the SDLA adapter. Valid values are 0x250, 0x300, 0x350 and 0x360.

#### mem\_segment

This is the 64K PC memory segment in which the shared memory window will reside. Valid values are 0xA000, 0xC000, 0xD000 and 0xE000.

#### mem\_window

This defines the 8k window of the PC memory segment which the PC sees as being occupied by the SDLA card. Valid values and their meanings are as follows:

| Value | PC memory window |
|-------|------------------|
| 0     | 0000H to 1FFFH   |
| 2     | 2000H to 3FFFH   |
| 4     | 4000H to 5FFFH   |
| 6     | 6000H to 7FFFH   |
| 8     | 8000H to 9FFFH   |
| А     | A000H to BFFFH   |
| С     | C000H to DFFFH   |

#### line\_speed

The HDLC link normally takes the line clocking from the modem. However, the S502 adapter will provide a clocking signal on pin 24. This means that in a local attach or test situation, there is no need for the expense or complexity of a modem eliminator. Valid values are (7.2 MHz adapter):

| Value (bj | <u>Speed (bps)</u> | Comments                    |
|-----------|--------------------|-----------------------------|
| 0         |                    | No clocking signal provided |
| 1200      | 1202               |                             |
| 2400      | 2405               |                             |
| 4800      | 4760               |                             |
| 9600      | 9727               |                             |
| 19200     | 18643              |                             |
| 38400     | 37286              |                             |
| 45000     | 44744              |                             |
| 56000     | 55930              |                             |
| 64000     | 55930              |                             |
| 74447     | 74573              |                             |
| 112000    | 111860             |                             |
| 128000    | 111860             |                             |
|           |                    |                             |

#### DTE

Defines the station's link level and packet level configuration and should be set to **1** for a **DTE** and **0** for a **DCE**.

3 - 4

**T1** 

The period timer T1 which is used for various link level retransmission and recovery procedures.

Valid values are 1 to 30 seconds and a typical value is 3 seconds.

## T2

T2 is the amount of time available at the station before an acknowledging frame must be initiated in order to ensure its receipt by the remote station, prior to timer T1 running out at that station.

Valid values are **0** to **29** seconds and is generally set to **0**. This value must always be less than T1.

#### **T4**

Once the HDLC link is in the asynchronous balanced mode (ABM) information transfer phase, there is no need for any HDLC Supervisory frame traffic to occur between the two devices on the link if no Information frames are being transmitted.

The **T4** parameter is used to allow the Sangoma HDLC code to issue a link level Supervisory frame (and to elicit a response from the remote device) periodically during this 'quiescent' ABM link phase.

If this parameter is set to  $\mathbf{0}$ , no unnecessary Supervisory frames will be generated. Otherwise a Supervisory frame will be issued at a period of

T4 x T1 (seconds)

For example, if the T1 timer is 3 seconds and T4 is 10, a Supervisory frame will be sent every 30 seconds.

N2

This is the maximum number of transmissions and retransmissions of an HDLC frame at T1 intervals before a state change occurs.

Valid values are 1 to 30 and a typical value is 10.

Valid values for this parameter are 0 to 240.

k

This parameter defines the size of the frame level window, i.e. the maximum number of sequentially numbered Information frames that may be unacknowledged at any given time.

Valid values are 1 to 7 and a typical value is 7.

#### auto\_modem\_err\_fixup

This parameter controls the reporting of modem failures to the application. If this function is enabled, then a particular modem error will only be reported once to the application. Otherwise, this error must be manually cleared by using the **SET\_GLOBAL\_VARIABLES** command.

Valid entries are 0 and 1, 1 enables the automatic error correction.

Note that if **auto\_HDLC** is enabled, then this parameter is also automatically enabled.

#### auto\_HDLC

If this parameter is enabled (set to **1**), then the link-level is automatically established on loading and the application need only deal with the transfer of Information frames. The CONFIGURE\_LINK and HDLC\_OPEN commands are not used. The **auto\_HDLC** value should only be set to **0** when the user wishes to fully control the set-up and disconnection of the HDLC link.

In general, this parameter should be set to **1** for HDLC code usage.

#### HDLC\_config\_options

This value describes the configuration options for the Sangoma HDLC code and the bit settings are as follows:

- bit 0 used for link setup control.
  If this bit is set to 0, then this station will issue SABM frames when link setup occurs. If set to 1, then this station will not issues SABMs, but will react appropriately to SABMs issued by the remote station.
- bit 1 If this bit is reset, then all Information frames aborted during transmission will be immediately retransmitted. If this bit is set, then no automatic recovery on aborts will occur and the link level protocol will be used to trigger Information frame retransmissions.

bits 2-7 reserved.

# max\_I\_field\_length

This parameter defines the maximum number of octets in the data field of an Information frame.

Incoming frames with a data field exceeding this maximum value will instigate a Frame Reject (FRMR) response. In addition, the XIP will prevent the application from transmitting Information frames of excessive length.

# XIP.COM

A PC-DOS interface is provided so as to avoid the complexities of direct memory access. The application interfaces with the **XIP** by means of a Software Interrupt and the **XIP**, in turn, reads and writes to shared memory area.

XIP.COM is loaded with the following command line:

XIP -f<CONFIG> -i<CALLING INTERRUPT> -r

where:

- CONFIG is the name of the file containing configuration information for the HDLC code, e.g. HDLC.SDL. The configuration file named here must be the same as that listed in the command line arguments for XLOAD.
- CALLING INTERRUPT is the software interrupt used by the application program to communicate with XIP. The default interrupt is **6F hex**.

The "-r" parameter is included when removing a resident XIP from memory.

e.g.

# XIP -fHDLC.SDL -i7A

Load the XIP with configuration file HDLC.SDL and use the software interrupt 7A (hex) to access the XIP.

The selected software interrupt is used to activate the XIP. When executing this call, the application must set the DX and BX registers to point to a control block.

If XIP does not execute successfully, an error message will be displayed and an exit code will be returned. A description of the error messages and corresponding exit codes are described in Section "Error Messages".

# X25\_TEST.EXE

X25\_TEST is a high-level interface to the HDLC code which allows the user to perform individual interface commands.

If X25\_TEST does not execute successfully, an error message will be displayed and an exit code returned.

DLC FOR MS-DOS

# 5. The programmer's interface

# Using the HDLC Shared Memory Interface

The SDLA card is operated by reading and writing structures to positions in the shared memory window. For details of moving the structures to/from the board, see the code example later in this document.

The application program accesses the HDLC software by completing the required parameters within the control block defined below and then setting the OPP\_FLAG. The SDLA processor will carry out the defined command and then update this control block with the required return code and, if applicable, the associated data buffer, data length etc. When the command has been completed, the OPP\_FLAG will once again be reset.

There are two control block areas within this shared memory window:

- ! the SEND control block is at offset **0x16B0** from the base address of the memory window and is used for all commands except the HDLC\_READ command.
- ! the RECEIVE control block is at offset **0x1AD0** from the base address of the memory window and is only used for the HDLC\_READ command.

Both these control blocks are of the same format.

The shared memory control block structure is as follows:

| Parameter         | Off-<br>set | Lth      | Remarks                                                                                                                                                                               |
|-------------------|-------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| OPP-FLAG          | 00H         | 1        | A flag set by the application to<br>inform the SDLA processor that a<br>COMMAND is pending. This flag is<br>in turn reset by the processor when<br>the COMMAND has been<br>completed. |
| COMMAND           | 01H         | 1        | Command code.                                                                                                                                                                         |
| BUFFER_<br>LENGTH | 02H         | 2        | Length of the data buffer associated with this call.                                                                                                                                  |
| RETURN_<br>CODE   | 04H         | 1        | Result of the previous command.                                                                                                                                                       |
| PF_BIT            | 05H         | 1        | The P/F bit setting.                                                                                                                                                                  |
| RESERVED          | 06H         | 10       | Reserved for later use.                                                                                                                                                               |
| DATA              | 10H         | 104<br>0 | This is the transfer area for passing data to and from the application level.                                                                                                         |

# Using the XIP TSR Interface

The application interfaces with the XIP by means of a Software Interrupt and the XIP, in turn, reads and writes to the shared memory areas. For details of using the XIP, see the code example later in this document.

The application program will access the XIP software by means of the following commands:

MOV BX, <data segment of control block> MOV DX, <offset of control block>

DLC FOR MS-DOS

4 - 1

HDLC FOR MS-DOS

#### INT <CALLING INTERRUPT>

The XIP software will transfer the control block (and associated data buffer, if applicable) from the application software and carry out the defined command. It will then update this control block at the application level with the required return code and, if applicable, the associated data buffer, data length etc.

The XIP Control Block Structure is as follows:

| Parameter         | Off-<br>set | Lth      | Remarks                                                                       |
|-------------------|-------------|----------|-------------------------------------------------------------------------------|
| COMMAND           | 00H         | 1        | Command code.                                                                 |
| BUFFER_<br>LENGTH | 01H         | 2        | Length of the data buffer associated with this call.                          |
| RETURN_<br>CODE   | 03H         | 1        | Result of the previous command.                                               |
| PF_BIT            | 04H         | 1        | The P/F bit setting.                                                          |
| RESERVED          | 05H         | 11       | Reserved for later use.                                                       |
| DATA              | 10H         | 104<br>0 | This is the transfer area for passing data to and from the application level. |

# 6. COMMAND Codes

The valid commands are:

| 0x01 | CONFIGURE_LINK               |
|------|------------------------------|
| 0x02 | HDLC_OPEN                    |
| 0x03 | HDLC_CLOSE                   |
| 0x04 | LINK_SETUP                   |
| 0x05 | LINK_DISCONNECT              |
| 0x06 | LINK_STATUS                  |
| 0x07 | READ_HDLC_STATISTICS         |
| 0x08 | FLUSH_HDLC_STATISTICS        |
| 0x09 | READ_COMMS_ERR_STATS         |
| 0x0A | FLUSH_COMMS_ERR_STATS        |
| 0x0B | SET_GLOBAL_VARIABLES         |
| 0x0C | READ_MODEM_STATUS            |
| 0x0D | FLUSH_HDLC_DATA_BUFFERS      |
| 0x10 | SEND_UNNUMBERED_INFORMATION_ |
|      | FRAME                        |
| 0x11 | HDLC_WRITE                   |
| 0x12 | READ_HDLC_CONFIGURATION      |
| 0x13 | SET_HDLC_CONFIGURATION       |
| 0x14 | OPERATE_DATALINE_MONITOR     |
| 0x15 | READ_CODE_VERSION            |
| 0x14 | OPERATE_DATALINE_MONITOR     |
| 0x16 | READ_TRACE_DATA              |
| 0x17 | SET_INTERRUPT_TRIGGERS       |
| 0x18 | READ_INTERRUPT_TRIGGERS      |

0x21 HDLC\_READ

# CONFIGURE\_LINK (0x01)

This command configures the Sangoma HDLC code to use the frame level addressing corresponding to a network DTE or DCE. The link is **CLOSED** and will not transmit frames or respond to any incoming frames until an **HDLC\_OPEN** has been performed. All queued Information frames are flushed, the statistic variables for the link are reset and the link is disconnected.

If 'auto\_HDLC' has been enabled (set to 1) in the configuration file, then this command should not be executed, as the station will already have been configured as defined in this configuration file.

#### Control Block values to be set on entry:

BUFFER\_ LENGTH: Set to **0x01**.

DATA: offset 0x00 is used to define the frame level addressing as follows:

**0x01** - use **DTE** addressing.

0x02 - use DCE addressing

#### **Control Block values set on return:**

## RETURN\_

- CODE: 0x00 The action has been performed successfully.
  - 0x01 The selected operational addressing mode is invalid.

0x06, 0x07, 0x08, 0x09, 0x0A See Section "Notes on Return Codes" for further details.

# HDLC\_OPEN (0x02)

This command allows the HDLC code to transmit frames and to respond to any incoming frames.

DTR will be automatically raised once the HDLC\_OPEN has been issued.

If 'auto\_HDLC' has been enabled in the configuration file, then this command is not neccessary, as the link would have been automatically 'opened' on loading.

Control Block values to be set on entry:

BUFFER\_ LENGTH: Set to 0x00.

Control Block values set on return:

## **RETURN**\_

CODE:

0x00 The action has been performed successfully.

0x06, 0x07, 0x08, 0x09, 0x0A See Section "Notes on Return Codes" for further details.

# HDLC\_CLOSE (0x03)

This command causes the HDLC code to no longer send frames or to respond to incoming frames.

The HDLC link state is unchanged, but no transmissions will occur until an HDLC\_OPEN command is executed.

Control block values to be set on entry:

BUFFER\_

LENGTH: Set to 0x00.

Control block values set on return:

## **RETURN\_**

CODE: 0x00 The action has been performed successfully.

0x06, 0x07, 0x08, 0x09, 0x0A See Section "Notes on Return Codes" for further details. LINK\_SETUP (0x04)

This command causes link initialization.

The HDLC code will attempt to enter the Asynchronous Balanced Mode (ABM) by positively responding to incoming SABM frames or issuing SABM frames of its own.

If 'auto\_HDLC' has been enabled in the configuration file, then this command is not neccessary, as the station will automatically attempt to enter the ABM on loading.

Control block values to be set on entry:

BUFFER\_ LENGTH: Set to 0x00.

**Control block values on return:** 

## **RETURN\_**

CODE: 0x00 The action has been performed successfully.

0x03 The device is CLOSED and so no frames may be transmitted. Perform an HDLC\_OPEN command.

0x06, 0x07, 0x08, 0x09, 0x0A See Section "Notes on Return Codes" for further details.

## LINK\_DISCONNECT (0x05)

This command causes link disconnection by the issuing of a DISC frame. The user has the option of entering different HDLC states once this disconnection has been completed.

Control block values to be set on entry:

#### **BUFFER**\_

LENGTH: Set to 0x01.

DATA: Offset 0x00 is used to define the HDLC state entered after the DISC frame has been issued, as follows:

> 0x00 - the link will not reenter the ABM and incomming SABM frames will be responded to with a DM frame. The LINK\_SETUP command must be issued to re-enter the ABM.

> **0x01** - the link will re-enter the ABM on receipt of a SABM from the remote station.

#### Control block values set on return:

# **RETURN\_** CODE:

- 0x00 The action has been performed successfully.
  - 0x02 The link is not currently in the ABM and so may not be disconnected.

0x03 The device is CLOSED and so no frames may be transmitted.

0x06, 0x07, 0x08, 0x09, 0x0A See Section "Notes on Return Codes" for further details.

# LINK\_STATUS (0x06)

# 7 frames).

| This com<br>the link,<br>queued for<br>rotating<br>and the s | mand returns the HDLC status of<br>the number of Information frames<br>or transmission and reception, the<br>g Supervisory frame reception count<br>station configuration. | Offset 0x01: | the number of<br>incoming<br>Information<br>frames queued for<br>reception by the<br>application (0 to 7<br>frames). |
|--------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|----------------------------------------------------------------------------------------------------------------------|
| Control                                                      | Block values to be set on entry:                                                                                                                                           | Affect Avas  | the station                                                                                                          |
| <b>BUFFER</b> -                                              |                                                                                                                                                                            | OTISEE VAUM  | configuration as                                                                                                     |
| LENGTH:                                                      | Set to 0x00.                                                                                                                                                               |              | defined in the<br>configuration<br>file (or as set in                                                                |
| Control                                                      | Block values set on return:                                                                                                                                                |              | the<br>CONFIGURE_LINK                                                                                                |
| <b>RETURN</b> _                                              |                                                                                                                                                                            |              | command).                                                                                                            |
| CODE:                                                        | 0x00 The link is in the                                                                                                                                                    |              | 0x01 configured                                                                                                      |
|                                                              | Disconnected mode.                                                                                                                                                         |              | as a DIE.                                                                                                            |
|                                                              |                                                                                                                                                                            |              | uxuz configured                                                                                                      |
|                                                              | 0x01 The link is in the                                                                                                                                                    |              | as a DCE.                                                                                                            |
|                                                              | Asynchronous Balanced                                                                                                                                                      | Offeet Avag  | nasanwad                                                                                                             |
|                                                              | Mode (ABM), permitting data                                                                                                                                                | Offset 0x03. | i esei veu.                                                                                                          |
|                                                              | transfer.                                                                                                                                                                  | Offsat Av04. | therotating                                                                                                          |
|                                                              | 000 007 008 004                                                                                                                                                            | Oliset vavi. | Supervisory frame                                                                                                    |
|                                                              |                                                                                                                                                                            |              | recention count.                                                                                                     |
|                                                              | See Section "Notes on Keturn<br>Codes" for further details                                                                                                                 |              | This count is                                                                                                        |
|                                                              | Codes" for further details.                                                                                                                                                |              | incremented on                                                                                                       |
| DITEEED                                                      |                                                                                                                                                                            |              | the recention of                                                                                                     |
| DUFFER-<br>IENICTU.                                          | Sat to AvA5 (fo DETUDN CODE of AvAA                                                                                                                                        |              | every Supervisory                                                                                                    |
| LEINGIN:                                                     | Set to vaus II a REFURIN_CODE OF Vaus                                                                                                                                      |              | frame and is                                                                                                         |
|                                                              | or uxul is received.                                                                                                                                                       |              | useful in                                                                                                            |
| DATA (walk                                                   | id if a DETUDN CODE of AvAA on AvA1 is                                                                                                                                     |              | monitoring link                                                                                                      |
| DATA (VALID IT A KETUKIN_CODE OF UXUU OF UXUI IS             |                                                                                                                                                                            |              | activity. This value                                                                                                 |
|                                                              |                                                                                                                                                                            |              | rotates between 0                                                                                                    |
|                                                              | Offset 0x00: the number of                                                                                                                                                 |              | and 255.                                                                                                             |
|                                                              | Information                                                                                                                                                                |              |                                                                                                                      |
|                                                              | frames queued for                                                                                                                                                          |              |                                                                                                                      |
|                                                              | transmission (0 to                                                                                                                                                         |              |                                                                                                                      |
|                                                              |                                                                                                                                                                            |              |                                                                                                                      |

# READ\_HDLC\_STATISTICS (0x07)

# Retrieve HDLC level statistics on the operation of this station.

**Control Block values to be set on entry:** 

BUFFER-LENGTH: Set to 0x00.

**Control Block values set on return:** 

#### **RETURN**\_

CODE: 0x00 The action was performed successfully.

0x06, 0x07, 0x08, 0x0A See Section "Notes on Return Codes" for further details.

#### **BUFFER**-

LENGTH: Set to 0x22 if a RETURN\_CODE of 0x00 is received.

DATA (valid if a RETURN\_CODE of 0x00 is received):

Note that each value listed below is a two byte unsigned short value and is set with the low byte first.

#### Offset

0x00,0x01: number of Information frames received and made available for reception by the application.

Offset

0x02,0x03: number of Information

frames received out of sequence.

Offset 0x04, 0x05: number of Information frames received with no data field present.

Offset

0x06, 0x07: number of incoming frames discarded due to one of the following reasons:

The frame type was unsupported.

The frame was shorter than four bytes in length.

The frame was of an S or U format but had an illegal Information field attached.

## Offset

0x08, 0x09: number of incoming frames whose data field exceeded the maximum configured data length.

#### Offset

**0x0A, 0x0B:** number of frames received with an invalid HDLC address.

#### Offset

0x0C, 0x0D: number of Information frames transmitted and acknowledged.

Offset 0x0E, 0x0F: number of Information

5 - 10

#### frames re-transmitted.

Offset 0x10, 0x11: number of T1 timeouts.

#### Offset

0x12, 0x13: number of SABM frames received.

#### Offset

0x14, 0x15: number of DISC frames received.

#### Offset

0x16, 0x17: number of DM frames received.

#### Offset

0x18, 0x19: number of FRMR frames received.

#### Offset

0x1A, 0x1B: number of SABM frames transmitted.

#### Offset

0x1C, 0x1D: number of DISC frames transmitted.

#### Offset

0x1E, 0x1F: number of DM frames transmitted.

#### Offset

0x20, 0x21: number of FRMR frames transmitted.

# FLUSH\_HDLC\_STATISTICS (0x08)

The current values of the variables accessed by the READ\_HDLC\_STATISTICS command are reset to zero.

Control Block values to be set on entry:

BUFFER-LENGTH: Set to 0x00.

**Control Block values set on return:** 

#### **RETURN\_**

CODE: 0x00 The action was performed successfully.

0x06, 0x07, 0x08, 0x0A See Section "Notes on Return Codes" for further details.

## READ\_COMMS\_ERR\_STATS (0x09)

**Retrieve the communications error statistics for the link.** 

Control Block values to be set on entry:

BUFFER-LENGTH: Set to 0x00.

**Control Block values set on return:** 

#### **RETURN\_**

CODE: 0x00 The action was performed successfully.

> 0x06, 0x07, 0x08, 0x0A See Section "Notes on Return Codes" for further details.

#### **BUFFER**-

LENGTH: Set to 0x0A if a RETURN\_CODE of 0x00 is received.

# DATA (valid if a RETURN\_CODE of 0x00 is received):

| Offset 0x00:              | number of receiver<br>overrun errors. |
|---------------------------|---------------------------------------|
| Offset 0x01:<br>errors.   | number of receiver CRC                |
| Offset 0x02:<br>received. | number of abort frames                |
| Offset 0x03:              | number of frames                      |

offset 0x03: number of frames discarded at the interrupt level due to

| Offset 0x04:<br>tra        | number of abort frames<br>nsmitted.                                      |
|----------------------------|--------------------------------------------------------------------------|
| Offset 0x05:<br>underruns. | number of transmit                                                       |
| Offset 0x06:               | number of missed<br>transmit underrun<br>interrupts.                     |
| Offset 0x07:               | reserved for later use.                                                  |
| Offset 0x08:               | number of times DCD<br>was found to be<br>unexpectedly inactive.         |
| Offset 0x                  | x09: number of times<br>CTS was found to<br>be unexpectedly<br>inactive. |

## FLUSH\_COMMS\_ERR\_STATS (0x0A)

The current values of the variables accessed by the READ\_COMMS\_ERR\_STATS command are reset to zero.

**Control Block values to be set on entry:** 

#### **BUFFER**-

LENGTH: Set to 0x00.

Control Block values set by XIP on return:

#### **RETURN\_**

CODE: 0x00 The action has been performed successfully.

> 0x06, 0x07, 0x08, 0x0A See Section "Notes on Return Codes" for further details

# SET\_GLOBAL\_VARIABLES (0x0B)

Set the status of DTR.

Control Block values to be set on entry:

BUFFER\_ LENGTH: Set to 0x03.

DATA:

Offset 0x00

reserved - set to 0x00.

Offset 0x01 DTR control as follows: set to 0x01 to lower DTR. set to 0x02 to raise DTR.

Offset 0x02 reserved - set to 0x00.

**Control Block values set on return:** 

#### **RETURN\_**

CODE: 0x00 The action has been performed successfully.

> 0x06, 0x07, 0x08, 0x0A See Section "Notes on Return Codes" for further details.

# READ\_MODEM\_STATUS (0x0C)

Read the current CTS and DCD status.

Control Block values to be set on entry:

BUFFER-LENGTH: Set to

LENGTH: Set to 0x00.

#### **Control Block values set on return:**

## **RETURN\_**

CODE: 0x00 The action has been performed successfully.

0x06, 0x07, 0x08, 0x0A See Section "Notes on Return Codes" for further details

### **BUFFER**-

LENGTH: Set to 0x01 if a RETURN\_CODE of 0x00 is received.

DATA (valid if a RETURN\_CODE of 0x00 is received):

Offset 0x00: The current CTS and DCD status as follows:

> If bit 5 is set, then CTS is high.

If bit 3 is set, then DCD is high.

# FLUSH\_HDLC\_DATA\_BUFFERS (0x0D)

Flush the queued transmit and receive Information frame buffers.

Control Block values to be set on entry:

BUFFER\_ LENGTH: Set to 0x00.

Control block values set on return:

**RETURN\_** 

CODE:

0x00 The action has been performed successfully.

0x06, 0x07, 0x08, 0x0A See Section "Notes on Return Codes" for further details Send an Unnumbered Information frame to the card for onward transmission to the network.

Control Block values to be set on entry:

## **BUFFER\_**

- LENGTH: The length of the actual Unnumbered Information data field, plus two bytes. The maximum BUFFER\_LENGTH is 1029 bytes.
- PF\_BIT: The status of the Poll/Final bit to be set in the UI frame. If the P-bit is to be set, then this parameter should be set to 0x01, otherwise it should be set to 0x00.
- DATA: The DATA area is formatted as follows:

Offset 0x00: the HDLC address to be used in this UI frame. This parameter is usually set to 0xFF.

Offset 0x01: reserved.

Offset 0x02 to 0xNN: the actual UI data field.

Control Block values set on return:

# **RETURN\_** CODE:

- **0x00** The UI frame has been queued for transmission.
  - 0x01 The buffer used for UI frame formatting is already in use.

Attempt to transmit the UI frame again after a short delay.

0x03 The link is currently CLOSED and an HDLC\_OPEN command must be executed before attempting to transmit Information frames.

0x04 The length of the UI data field is longer than the maximum of 1027 bytes.

0x06, 0x07, 0x08, 0x0A See Section "Notes on Return Codes" for further details

# HDLC\_WRITE (0x11)

Send a data message (Information frame) to the card for onward transmission to the network.

Control Block values to be set on entry:

## **BUFFER**\_

- LENGTH: The length of the data message to be transmitted. The maximum data length is 1027 bytes and is dependant on the max\_I\_field\_length defined in the configuration file.
- **PF\_BIT:** The status of the Poll/Final bit to be set in the HDLC header. In general, this parameter should be set to 0x00, but may be set to 0x01 if immediate confirmation of frame reception is required from the remote device.
- DATA: The data to be transmitted.

Control Block values set on return:

## **RETURN\_**

- CODE: 0x00 The data has been queued for transmission.
  - 0x01 The data was not queued due to the fact that the transmit window is closed.

The application is attempting to send data to the HDLC network at a rate faster than the network is able to receive the data. No data was sent to the S502 card and this same data should be resent in its entirety after a short delay.

- **0x02** The link is not currently in the ABM and data transfer is not possible.
- 0x03 The link is currently CLOSED and an HDLC\_OPEN command must be executed before attempting to transmit Information frames.
- 0x04 The length of the data message to be transmitted exceeded the maximum data length max\_I\_field\_length defined in the configuration file. The data was not transmitted.

0x06, 0x07, 0x08, 0x0A See Section "Notes on Return Codes" for further details.

# **READ HDLC CONFIGURATION (0x12)**

**Read the current HDLC configuration** parameters.

**Control Block values to be set on entry:** 

BUFFER LENGTH:

Set to 0x00.

**Control Block values set on return:** 

#### RETURN

CODE: **0x00** The action was performed successfully.

> 0x06, 0x07, 0x08, 0x0A See Section "Notes on Return Codes" for further details..

## BUFFER

LENGTH: Set to 0x0C if a RETURN\_CODE of 0x00 is received.

DATA (valid if a RETURN CODE of 0x00 is received): The data is in the same format as that for the SET\_HDLC\_CONFIGURATION command.

SET HDLC CONFIGURATION (0x13)

Set the HDLC configuration parameters.

Note that no checking of the validity of the passed configuration data is performed by the HDLC code and the user must therefore ensure that this data is correct. Before using this command, it is recommended that the **READ HDLC CONFIGURATION command be** performed to check the accuracy of the configuration structure defined in the application code.

**Control Block values to be set on entry:** 

BUFFER LENGTH: Set to 0x0C.

DATA: This area contains the configuration parameters. A detailed description of these parameters may be found in Section 3.

| <u>Size Par</u><br>(bytes)                                                                        | <u>rameter</u>                                                                                                                           |  |  |
|---------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| A number corresponding to<br>the baud rate generated by<br>the SDLA card on pin 24 as<br>follows: |                                                                                                                                          |  |  |
| <u>Val ue</u><br>(bps)                                                                            | <u>Baud Rate</u>                                                                                                                         |  |  |
| 0x00<br>0x01<br>0x02<br>0x03<br>0x04                                                              | External Clocking<br>1200<br>2400<br>4800<br>9600                                                                                        |  |  |
|                                                                                                   | <u>Size Par</u><br>(bytes)<br>A numbe<br>the baue<br>the SDL<br>follows<br><u>Value</u><br>(bps)<br>0x00<br>0x01<br>0x02<br>0x03<br>0x04 |  |  |

|               | 0x05 19200                           |                 |                                      |
|---------------|--------------------------------------|-----------------|--------------------------------------|
|               | 0x06 38400                           |                 |                                      |
|               | 0x07 45000                           | Control         | Block values set on return:          |
|               | 0x08 56000                           |                 |                                      |
|               | 0x09 64000                           | <b>RETURN</b> _ |                                      |
|               | 0x0A 74000                           | CODE:           | <b>0x00</b> The action was performed |
|               | 0x0B 112000                          |                 | successfully.                        |
|               | 0x0C 128000                          |                 | ·                                    |
|               |                                      |                 | 0x06, 0x07, 0x08, 0x0A               |
| 0x01 1        | The period timer T1.                 |                 | See Section "Notes on Return         |
|               |                                      |                 | Codes" for further details.          |
| Offsat        | Siza Paramatar                       |                 |                                      |
| <u>onsec</u>  | (bytas)                              |                 |                                      |
|               | (by ces)                             |                 |                                      |
| 0x02 1        | The timer T2.                        |                 |                                      |
| 0x03 1        | The N2 counter.                      |                 |                                      |
| 004 9         | The maximum length of the            |                 |                                      |
| UXU4 &        | Ine maximum length of the            |                 |                                      |
|               | HDLC INFORMATION FRAME               |                 |                                      |
|               | data field.                          |                 |                                      |
|               | Valid values are between 1           |                 |                                      |
|               | and 1027 length.                     |                 |                                      |
| 0x06 1        | The size of the frame level          |                 |                                      |
|               | window (k).                          |                 |                                      |
| 0x07 1        | The T4 parameter.                    |                 |                                      |
| 009 1         | The last a madem and Group!          |                 |                                      |
| UXU8 1        | narameter.                           |                 |                                      |
|               |                                      |                 |                                      |
| 0x09 1        | The 'auto_HDLC' parameter.           |                 |                                      |
|               |                                      |                 |                                      |
| 0x0A 1        | The 'HDLC_config_options'.           |                 |                                      |
| <b>0x0B</b> 1 | Defines the station's link           |                 |                                      |
|               | level and packet level               |                 |                                      |
|               | configuration and is set to          |                 |                                      |
|               | <b>0x01 for a DTE and 0x00 for a</b> |                 |                                      |
|               | DCE.                                 |                 |                                      |

٠

# READ\_CODE\_VERSION (0x15)

# **Return the code versions for both the HDLC code and the XIP (if resident).**

Control Block values to be set on entry:

#### **BUFFER**-

LENGTH: Set to 0x00.

**Control Block values set on return:** 

#### **RETURN\_**

CODE: 0x00 The action has been performed successfully.

0x06, 0x07, 0x08, 0x0A See Section "Notes on Return Codes" for further details..

#### **BUFFER**-

LENGTH: Set to 0x09 if a RETURN\_CODE of 0x00 is received.

DATA (valid if a RETURN\_CODE of 0x00 is received):

The code versions are of the format:

main-version.sub-version

For example, XIP code version 2.01.

Offset 0x00 - 0x03: the version of the HDLC code running on the SDLA adapter.

## Offset 0x04 - 0x07: the XIP code

version (if resident).

Offset 0x08: reserved.

|                                                                        | on the adapter to keep                                                                                                                                                                                                                                      |
|------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                        | pace with the rate at<br>which the application<br>is reading trace frames<br>from the board.                                                                                                                                                                |
| bit 3 if s                                                             | et, then HDLC I-frames will                                                                                                                                                                                                                                 |
| be t                                                                   | traced.                                                                                                                                                                                                                                                     |
| bit 4                                                                  | if set, then HDLC                                                                                                                                                                                                                                           |
|                                                                        | Supervisory frames will be traced.                                                                                                                                                                                                                          |
| bit 5                                                                  | if set, then Unnumbered<br>frames will be traced.                                                                                                                                                                                                           |
| bit 6                                                                  | if set. then all HDLC                                                                                                                                                                                                                                       |
|                                                                        | level frames will be                                                                                                                                                                                                                                        |
|                                                                        | traced.                                                                                                                                                                                                                                                     |
|                                                                        |                                                                                                                                                                                                                                                             |
| bit 7                                                                  | if set, then the current<br>trace configuration                                                                                                                                                                                                             |
|                                                                        | will be returned to the                                                                                                                                                                                                                                     |
|                                                                        | application. Note that                                                                                                                                                                                                                                      |
|                                                                        | the trace                                                                                                                                                                                                                                                   |
|                                                                        | configuration will                                                                                                                                                                                                                                          |
|                                                                        | not be set if this bit is<br>anabled                                                                                                                                                                                                                        |
|                                                                        |                                                                                                                                                                                                                                                             |
| et 0x01<br>tim<br>con<br>del<br>aut<br>the<br>the<br>rea<br>boa<br>def | the trace deactivation<br>er. This timer is used in<br>njunction with the trace<br>ay mode and<br>comatically deactivates<br>e trace in the case where<br>e application does not<br>d trace frames from the<br>ard at least once per<br>fined deacitivation |
|                                                                        | bit 3 if s<br>be t<br>bit 4<br>bit 5<br>bit 6<br>bit 7<br>bit 7                                                                                                                                                                                             |

period.

This value of this timer may be set from 1 to 8 seconds.

Control Block values set on return:

# **RETURN**\_

| CODE: | <b>0x00</b> | The action has been     |
|-------|-------------|-------------------------|
|       |             | performed successfully. |

0x06, 0x07, 0x08, 0x0A See Section "Notes on Return Codes" for further details..

# **BUFFER**-

LENGTH: Set to 0x01 if is the current trace configuration was requested.

DATA (valid if the current trace configuration was requested): Offset 0x00 miscel

x00 miscellaneous monitor configuration bits as defined above.

# READ\_TRACE\_DATA (0x16)

# Read a trace frame from the SDLA adapter.

Control Block values to be set on entry:

BUFFER-LENGTH: Set to 0x00.

Control Block values set on return:

**RETURN**\_

- CODE: 0x00 The action has been performed successfully and trace data for pick up in the DATA area of this interface structure.
  - 0x01 No trace frames are currently available for the application.
  - 0x02 The trace has not been activated.
  - 0x06, 0x07, 0x08, 0x0A See Section "Notes on Return Codes" for further details..

# **BUFFER**-

LENGTH: Set to the length of the received trace structure if a RETURN\_CODE of 0x00 is received.

DATA (valid if a RETURN\_CODE of 0x00 is received):

The received trace structure in the following format:

| Offset      |       |                           |                    |     | aborted<br>frame (mi | transmitted<br>issed transmit |
|-------------|-------|---------------------------|--------------------|-----|----------------------|-------------------------------|
| 0x00-0x01:  | the l | ength of the actual       |                    |     | underru              | n interrunt).                 |
|             | trac  | e data.                   |                    |     |                      |                               |
|             |       |                           | Offset 0x0         | 3:  | the num              | ber of trace                  |
| Offset 0x0  | 2:    | the type of trace is      |                    |     | packets o            | discarded since               |
|             |       | indicated in the low 2    |                    |     | the last             | trace frame                   |
|             |       | bits as follows:          |                    |     | was passe            | ed to the                     |
|             |       |                           |                    |     | applicati            | on.                           |
| <b>0x00</b> | the t | trace is of a received    |                    |     |                      |                               |
|             | fram  | le.                       | Offset             |     |                      |                               |
|             |       |                           | <b>0x04-0x08</b> : | val | id only if t         | he XIP                        |
| <b>0x01</b> | the t | trace is of a transmitted |                    | int | erface is be         | ing used, and is              |
|             | fram  | le.                       |                    | the | e time at wł         | nich this                     |
|             |       |                           |                    | tra | nsaction o           | occurred (in                  |
| <b>0x02</b> | the t | trace is of an HDLC error |                    | bin | ary coded            | decimal). The                 |
|             | fram  | e, in which case the      |                    | for | mat of thi           | s four-byte                   |
|             | trac  | e type byte is decoded as |                    | tim | e stamp is a         | s follows:                    |
|             | folle | ows:                      |                    |     |                      |                               |
|             |       |                           |                    |     | <u>Offset</u>        | <u>Parameter</u>              |
|             | 0x12  | the trace is of a         |                    |     | <b>0x04</b>          | Month                         |
|             |       | received abort frame.     |                    |     | <b>0x05</b>          | Day                           |
|             |       |                           |                    |     | <b>0x06</b>          | Hours                         |
|             | 0x22  | the trace is of a         |                    |     | <b>0x07</b>          | Minutes                       |
|             |       | received frame with a     |                    |     | <b>0x08</b>          | Seconds                       |
|             |       | CRC error.                |                    |     |                      |                               |
|             | 0x32  | the trace is of a         |                    |     |                      |                               |
|             |       | received frame with an    |                    |     |                      |                               |
|             |       | overrun error.            |                    |     |                      |                               |
|             | 0x42  | the trace is of a frame   |                    |     |                      |                               |
|             |       | received of excessive     |                    |     |                      |                               |
|             |       | length.                   |                    |     |                      |                               |
|             | 0x72  | the trace is of an        |                    |     |                      |                               |
|             |       | aborted transmitted       |                    |     |                      |                               |
|             |       | frame (missed transmit    |                    |     |                      |                               |
|             |       | interrupt).               |                    |     |                      |                               |
|             | 0x82  | the trace is of an        |                    |     |                      |                               |

Offset

0x09-0x0A: the millisecond time stamp for the frame (valid only if time stamping has been activated). This time stamp rotates between 0 and 65535 milliseconds.

### Offset

0x0B-0xNN: the actual contents of the frame. This includes all bytes in the frame, but excludes the opening and closing flags. For outgoing frames, the two CRC bytes are represented by the value 0xFFFF.

# HDLC\_READ (0x21)

**Receive a data message (Information frame)** from the network.

Control Block values to be set on entry:

#### **BUFFER**\_

LENGTH: Set to 0x00.

Control block values set on return:

#### RETURN\_ CODE:

0x00 Data has been received and is available for pick up in the DATA area of this control block.

**0x01** No data is available at the station.

- 0x02 The link is not currently in the ABM and data transfer is not possible.
- **0x03** The link is currently CLOSED and an HDLC\_OPEN command must be executed before attempting to receive Information frames.
- 0x06, 0x07, 0x08, 0x0A See Section "Notes on Return Codes" for

#### **BUFFER**\_

# LENGTH: The length of the data message received.

DLC FOR MS-DOS

5 - 36

(valid if a **RETURN\_CODE** of **0x00** is received).

**PF\_BIT:** The status of the HDLC Poll/Final bit in the received Information frame (valid if a RETURN\_CODE of 0x00 is received). If this value is set to 0x00, the the P/F-bit was reset in the frame, otherwise the P/F-bit was set.

DATA (valid if a RETURN\_CODE of 0x00 is received):

The actual I-frame data that has been received at thestation.

# 7. Notes on Return Codes

There are return codes common to specific commands which require additional discussion. These return codes (hexadecimal values) are:

**0x05** The command used is invalid.

0x06 An Unnumbered frame (SABM, DISC, DM, UA) was

unexpectedly received while the link was in the Asynchronous Balanced Mode, or a UI frame has been received.

The BUFFER\_LENGTH will be set to 0x01 (plus the length of the UI Data field if applicable) and the byte at offset 0x00 of the XIP structure DATA area indicates the type of Unnumbered frame received as follows:

0x01 - a SABM command frame was received.

**0x02** - a DISC command frame was received.

0x03 - a DM response frame was received.

0x04 - a UI frame was received.

0x05 - a UA response frame was received.

# If the received frame is a UI, then the DATA area is formatted as follows:

Offset 0x01: the HDLC address in the received UI frame.

Offset 0x02: reserved.

Offset 0x03 to 0xNN: The actual UI data field (of length BUFFER\_LENGTH - 3).

If the received frame is a DISC or a DM, the Sangoma HDLC code will automatically attempt to re-enter the ABM by issuing SABMs.

Note: the command executed when this return code was passed to the application was not performed (i.e. any returned data is invalid) and this call should be repeated.

0x07 The link is in the Frame Reject mode.

The BUFFER\_LENGTH will be set to 0x04 and the interface structure DATA area may be decoded as follows:

> Offset 0x00: the source of the FRMR frame 0x01 - local 0x02 - remote

Offset

0x01-0x03: the actual FRMR Information field. The byte at offset 0x03 provides the reason for the FRMR as follows:

**0x01** control field invalid or not

## implemented.

0x03 an S or U frame received with an illegal Ifield attached.

0x04 an I-frame received whose data length exceeded the defined maximum.

0x08 an invalid Nr count.

The Sangoma HDLC level code will automatically attempt to reset the link when FRMR responses are received.

Note: the command executed when this return code was passed to the application was not performed (i.e. any returned data is invalid) and this call should be repeated. **0x08** A modem failure occurred - DCD and/or CTS were found to be unexpectedly low.

The cause of this failure is returned at offset 0x00 of the XIP data buffer and may be one of the following:

> 0x01 - DCD was found to be unexpectedly low. 0x02 - CTS was found to be unexpectedly low.

Executing a READ\_COMMS\_ERR\_STATS will indicate the count of the various modem error types and the READ\_MODEM\_STATUS command will return the current status of DCD and CTS.

Note: the command executed when this return code was passed to the application was not performed (i.e. any returned data is invalid) and this call should be repeated.

0x09 The N2 retry limit has been exceeded, i.e. an unnumbered frame has been issued N2 times, but the remote device has still not responded.

> The BUFFER\_LENGTH will be set to 0x01 and the byte at offset 0x00 of the XIP structure DATA area indicates the type of Unnumbered frame concerned with this retry limit:

> > **0x01 - a SABM command retry limit occurred.**

0x02 - a DISC command retry limit

occurred.

0x0A A SDLA card timeout occurred (valid if the XIP is resident).

The XIP call to the board was not processed in the specified time, indicating a hardware failure.

If this error code is returned, run XLOAD.EXE again, ensuring successful execution. On reoccurrence of this error, contact your Sangoma dealer.

# 8. PC/SDLA Interface Bytes

There are a number of bytes within the shared PC/SDLA memory area which may be useful for programmers using the shared memory interface. These bytes are:

> The HDLC\_RX\_TX\_STATUS\_BYTE (offset 0x1EFF from the defined memory window base address). This byte is set as follows:

> > bits 0-3 set to the number of Information frames currently available for reception by the application.

bits 4-6 reserved.

bit 7 if this bit is set to 1, then there is space available for the queueing of at least one outgoing Information frame, i.e. an HDLC\_WRITE command will not return an error code of 0x01 on completion.

The MISCELLANEOUS\_HDLC\_BITS (offset 0x1FF0 from the defined memory window base address). This byte is set as follows:

> bit 0 set to 0 if the HDLC link is disconnected. set to 1 if the HDLC link is in the asynchronous balanced mode (ABM).

bits 1-2 reserved.

bit 3 if this bit is set to 1, then there is trace data available for the application (valid if the line trace has been enabled).

bits 4-7 reserved.

# 9. General Programming Notes

Once completion of an interface command has occurred (the XIP returns to the calling application or the 'opp\_flag' has been reset in the shared memory area), the application should examine the RETURN\_CODE and other parameters relevant to the particular command. Note that the RETURN\_CODE is most important, as it may indicate that the interface command was not successful. For example, if the command is an HDLC\_WRITE and the RETURN\_CODE is 0x01, then the Information frame was not sent to the adapter and this same HDLC\_WRITE should be re-issued.

# 10. Example Code

### Example code for interfacing with the XIP TSR (WRITTEN FOR BORLAND C++, Version 4.0)

/\*

To execute an XIP command, the following steps should be performed:

Set all the parameters in the XIP control block structure parameters required for the particular command. For example, if the command is an HDLC\_WRITE, then the BUFFER\_LENGTH, the PF\_BIT and DATA areas must be completed.

Set the BX register to the data segment and the DX register to the offset of the XIP control block structure.

Call the XIP software interrupt.

The XIP will carry out the defined command. It will then update the XIP control block at the application level with the required return code and, if applicable, the associated data buffer, data length etc.

Once control is returned to your application, examine the RETURN\_CODE and other parameters relevant to the particular XIP command.

```
*/
```

#include <stdio.h> #include <stdlib.h> #include <conio.h> #include <ctype.h> #include <mem.h> #include <dos.h> /\* XIP commands \*/ #define LINK\_STATUS 0x06 /\* read the link status \*/ /\* transmit data \*/ #define HDLC WRITE 0x11 #define HDLC READ /\* receive data \*/ 0x21 #define XIP\_INTERRUPT 0x6F /\* the XIP software interrupt \*/ /\* the XIP calling structure \*/ typedef struct { char command; /\* XIP command \*/ unsigned short buffer\_length;/\* buffer length \*/

DLC FOR MS-DOS

```
char return code;
                               /* return code */
  char PF bit;
                               /* the setting of the
                              poll/final-bit */
                               /* reserved for later use */
  char reserved[11];
  char data[1040];
                               /* data area */
} XIP CALL STRUCT;
XIP CALL STRUCT XIP struct;
int i;
void check link status(void);
void send HDLC I frame(void);
void receive_HDLC_I_frame(void);
void execute_interface_command(void);
void exit_from_example(char, char);
void main()
   /*
   Assume that the 'auto_HDLC' configuration parameter is set
  to '1' in the HDLC configuration file, and so the
CONFIGURE_LINK and HDLC_OPEN commands are not required.
   */
   /* check to see that the link is in the ABM (asynchronous
   balanced mode) */
   check link status();
   /* transmit an HDLC I-frame */
   send HDLC I frame();
   /* receive an HDLC I-frame */
   receive HDLC I frame();
}
/*** check to see that the link is in the ABM (asynchronous
balanced mode) ***/
void check link status()
   /* loop until the link is in the ABM and Information frames
     may be transferred */
   do {
      /* set the command */
      XIP struct.command = LINK STATUS;
      /* set the length of the data buffer */
      XIP_struct.buffer_length = 0x00;
```

```
execute interface command();
   /* loop until the command is successful */
   } while(XIP struct.return code != LINK IN ABM);
   printf("\n\nThe link is in the ABM");
/*** send an HDLC Information frame ***/
void send_HDLC_I_frame()
   /* set the command */
   XIP struct.command = HDLC WRITE;
   /* reset the P-bit in the frame */
   XIP struct.PF bit = 0 \times 00i
   /* set the actual data to be sent */
   sprintf(XIP struct.data, "%s", "HDLC TEST FRAME");
   /* set the length of the data */
   XIP_struct.buffer_length = 15;
   /* perform the interface command */
   execute_interface_command();
   if(XIP struct.return code)
      printf("\n\nHDLC I-frame not sent (return code = %x)",
      XIP struct.return code);
   else
      printf("\n\nI-frame successfully sent");
/*** receive an HDLC Information frame ***/
void receive HDLC I frame()
```

/\* perform the interface command \*/

```
{
    /* set the command */
    XIP_struct.command = HDLC_READ;
```

/\* set the length of the data buffer \*/
XIP\_struct.buffer\_length = 0x00;

```
/* perform the interface command */
execute_interface_command();
```

```
/* if there is an I-frame available, then dispay the
received data */
   if(!XIP struct.return code) {
      /* display the received data */
      printf("\n\ bytes of data received (P-bit = \x)",
      XIP_struct.buffer_length, XIP_struct.PF_bit);
      printf("\nData: ");
      for(i = 0; i < XIP struct.buffer length; i ++)</pre>
         printf("%x ", XIP_struct.data[i]);
   else
      printf("\n\nNo I-frame received");
/*** perform an interface command ***/
void execute_interface_command()
union REGS inregs;
   /* set the BX register to our Data Segment */
   inregs.x.bx = _DS;
   /* set the DX register to point to the XIP structure */
   inregs.x.dx = (unsigned short)&XIP struct.command;
   /* call the XIP with a software interrupt */
   int86(XIP_INTERRUPT, &inregs, &inregs);
/*** exit to the operating system ***/
void exit from example(char command, char exit code)
{
   printf("\n\nEXITING DUE TO RETURN CODE %x FOR COMMAND %x",
 exit code, command);
   exit((int)0x00);
```

# Example showing interface to the shared memory area

(WRITTEN FOR BORLAND C++, Version 4.0)

#include <stdio.h>
#include <stdlib.h>
#include <conio.h>
#include <ctype.h>
#include <mem.h>
#include <dos.h>

/\* XIP commands \*/ #define LINK\_STATUS 0x06 /\* read the link status \*/ #define HDLC\_WRITE 0x11 /\* transmit data \*/ #define HDLC\_READ 0x21 /\* receive data \*/

#### /\*

Assume that the HDLC code was loaded with the configuration file defining the memory address as 0xD000 and the memory window as 0. The physical address of the SEND interface mailbox is 0xD000:0x16B0 and the address of the RECEIVE interface mailbox 0xD000:0x1AD0.

#define SEND\_MAILBOX\_ADDRESS #define RECEIVE\_MAILBOX\_ADDRESS 0xD00016B0 0xD0001AD0

/\* for opp\_flag use \*/
#define RESET 0x00
#define SET 0x01
#define ZERO 0x00

```
/* the mailbox structure */
typedef struct {
 char opp_flag;
                                /* the opp flag */
                                /* XIP command */
 char command;
 unsigned short buffer_length; /* buffer length */
 char return code;
                                /* return code */
 char PF_bit;
                                /* the setting of the
                              poll/final-bit */
 char reserved[10];
                                /* reserved for later use */
                                /* data area */
  char data[1040];
MAILBOX_INTERFACE_STRUCT;
```

/\* define far pointers to the SEND and RECEIVE interface structures \*/ MAILBOX\_INTERFACE\_STRUCT \_far \*SEND\_mailbox\_ptr; MAILBOX\_INTERFACE\_STRUCT \_far \*RECEIVE\_mailbox\_ptr;

```
int i;
char test_data[] = "HDLC TEST FRAME";
char utility_buffer[1040];
```

```
void check_link_status(void);
void send_HDLC_I_frame(void);
void receive_HDLC_I_frame(void);
void execute_interface_command(MAILBOX_INTERFACE_STRUCT
_far *);
void exit_from_example(char, char);
```

```
void main()
```

```
/* set the SEND mailbox pointer to the physical address on
the adapter */
SEND_mailbox_ptr = (MAILBOX_INTERFACE_STRUCT
_far*)SEND_MAILBOX_ADDRESS;
```

/\* set the RECEIVE mailbox pointer to the physical address
 on the adapter \*/
RECEIVE\_mailbox\_ptr = (MAILBOX\_INTERFACE\_STRUCT
\_far\*)RECEIVE\_MAILBOX\_ADDRESS;

#### /\*

Assume that the 'auto\_HDLC' configuration parameter is set to '1' in the HDLC configuration file, and so the CONFIGURE\_LINK and HDLC\_OPEN commands are not required.

```
*/
```

```
/* check to see that the link is in the ABM (asynchronous
balanced mode) */
check_link_status();
```

```
/* transmit an HDLC I-frame */
send_HDLC_I_frame();
```

```
/* receive an HDLC I-frame */
receive_HDLC_I_frame();
```

```
}
```

```
/*** check to see that the link is in the ABM (asynchronous
balanced mode) ***/
void check link status()
   /* loop until the link is in the ABM and Information frames
     may be transferred */
   do {
      /* set the command */
      SEND mailbox ptr->command = LINK STATUS;
      /* set the length of the data buffer */
      SEND mailbox ptr->buffer length = 0x00;
      /* perform the interface command */
      execute interface_command(SEND_mailbox_ptr);
   /* loop until the command is successful */
   } while(SEND_mailbox_ptr->return_code != LINK_IN_ABM);
   printf("\n\nThe link is in the ABM");
/*** send an HDLC Information frame ***/
void send HDLC I frame()
   /* set the command */
   SEND_mailbox_ptr->command = HDLC_WRITE;
   /* reset the P-bit in the frame */
   SEND_mailbox_ptr->PF_bit = RESET;
   /* set the actual data to be sent */
   fmemcpy(SEND mailbox ptr->data, test data, 15);
   /* set the length of the data */
   SEND mailbox ptr->buffer length = 15;
   /* perform the interface command */
   execute interface command(SEND mailbox ptr);
   if(SEND_mailbox_ptr->return_code)
      printf("\n\nHDLC I-frame not sent (return code = %x)",
      SEND mailbox ptr->return code);
```

else

printf("\n\nI-frame successfully sent");

```
/*** receive an HDLC Information frame ***/
void receive HDLC I frame()
   /* set the command */
   RECEIVE mailbox ptr->command = HDLC READ;
   /* set the length of the data buffer */
   RECEIVE mailbox ptr->buffer length = 0 \times 00;
   /* perform the interface command */
   execute_interface_command(RECEIVE_mailbox_ptr);
   /* if there is an I-frame available, then dispay the
received data */
   if(!RECEIVE_mailbox_ptr->return_code) {
      /* display the received data */
      printf("\n\n%d bytes of data received (P-bit = %x)",
      RECEIVE_mailbox_ptr->buffer_length,
RECEIVE_mailbox_ptr->PF_bit);
      printf("\nData: ");
      _fmemcpy(utility_buffer, RECEIVE_mailbox_ptr->data,
      RECEIVE mailbox ptr->buffer length);
      for(i = 0; i < RECEIVE_mailbox_ptr->buffer_length; i ++)
         printf("%x ", utility_buffer[i]);
   }
   else
      printf("\n\nNo I-frame received");
/*** perform an interface command ***/
void execute_interface_command(mailbox_ptr)
MAILBOX INTERFACE STRUCT far *mailbox ptr;
long opp_flag_loops = 0x00;
   /* set the 'opp flag' to initiate the processing of the
 command */
   mailbox_ptr->opp_flag = SET;
   /* Read the 'opp_flag' from the shared memory area and, when
      it has been reset, then the command has been completed.
    Note that the application should check to see that the
 'opp flag' is reset within a defined time period after
being set. A suitable time out would be approximately one
      second (most commands would be completed with 1/100th of
     a second).
   * /
   do
      if((++ opp_flag_loops) == 200000) {
```

printf("\nAdapter dead. Contact your Sangoma

representative.");

# 11. HDLC Implementation

# **HDLC Protocol Specifics**

The implementation of the HDLC protocol on the \$502 adapter corresponds as closely as possible to the specifications of the ISO 7776 document "Information processing systems -Data communication - High-level data link control procedures - Description of HDLC LAPB-compatible DTE data link procedures", 15 December 1986, with the following specifics:

# **Link Initialization**

After issuing a CONFIGURE\_LINK command and a subsequent HDLC\_OPEN, the station issues DM responses at a period of T1 seconds. Also, all incoming frames with the P-bit set will be responded to with a DM frame.

Once the LINK\_SETUP command is issued, the station will issue the DM frame N2 times and then send SABM commands. Incoming SABMs will be responded to with a UA, setting the link in the ABM.

Note that if auto\_HDLC is enabled in the configuration file (as is usually done for an HDLC implementation), then the CONFIGURE\_LINK, HDLC\_OPEN and LINK\_SETUP commands are automatically issued on code startup.

## **Link Disconnection**

## When the LINK\_DISCONNECT command is used,

DLC FOR MS-DOS

a DISC command is issued on the link at a period of T1 until a UA response is received. The station then issues DM responses at a period of T1 seconds.

#### Frame Reject Mode

The HDLC station will begin Frame Reject transmission under the following circumstances:

> The Control field in the received frame does not allow an information field to be included with the frame, but an information field is present.

The function specified by the Control field has not been implemented.

An Information frame is received with an I-field which exceeds the maximum defined length.

When receiving a FRMR during the ABM, this station will attempt link re-initialization by issuing a SABM command.

# 12. Error messages

# **XLOAD.EXE**

If XLOAD does not execute successfully, an error message will be displayed and an exit code will be returned. The error messages and corresponding exit codes (DOS ERRORLEVEL) are as follows:

"A command line error was found when executing XLOAD" An invalid command line argument was used or the CODEFILE or CONFIG arguments were omitted (exit code of 1).

"The file FILENAME was not found" A filename listed in the command line arguments was not found in the defined directory (exit code of 2).

"The parameter PARAMETER was not found in the configuration file"

There is an error in the HDLC configuration file and the listed PARAMETER could not be located (exit code of 3).

"The parameter PARAMETER read from the configuration file is invalid" There is an error in the HDLC configuration file as the listed PARAMETER is invalid (exit code of 3).

"The code running on the adapter is not the same as the original downloaded code" There is a memory or I/O port address conflict in your PC. Change the I/O port address and/or the memory segment and memory window parameters (exit code of 4).

"The downloaded code is not running on the adapter"

The SDLA CPU has halted. Contact your Sangoma representative (exit code of 5).

#### "The \$502 adapter is configured with the incorrect serial communications cXIP" Contact your Sangoma representative (exit code of 6).

## XIP.COM

If XIP does not execute successfully (exit code of 0x00), an error message will be displayed and a non-zero exit code will be returned. The error messages and corresponding exit codes are as follows:

#### "THE XIP TSR IS ALREADY RESIDENT"

Multiple copies of this TSR may not be run at the same software interrupt address (exit code of 0x01).

#### "A COMMAND LINE ERROR WAS FOUND"

An invalid command line argument was used and the valid arguments are displayed (exit code of 0x02).

#### "THE DEFINED HDLC/HDLC CONFIGURATION FILE HAS NOT BEEN FOUND"

The configuration filename listed in the command line arguments (or the default configuration file) was not found in the defined directory (exit code of 0x03).

#### **"ERROR IN READING THE HDLC/HDLC** CONFIGURATION FILE"

The configuration file could not be opened for reading (exit code of 0x04).

# "THE HDLC CONFIGURATION FILE IS OF EXCESSIVE LENGTH"

The configuration file could not be read into the allocated buffer space (exit code of 0x05).

# "THE I/O PORT ADDRESS OR THE MEMORY CONFIGURATION PARAMETERS WERE NOT FOUND IN THE CONFIGURATION FILE"

Check the defined configuration file

11 - 2

HDLC FOR MS-DOS

# X25\_TST.EXE

## "A COMMAND LINE ERROR WAS FOUND"

An invalid command line argument was used (exit code of 1).

# Index

| <b>ABM</b>            | 5 - 5, 5 - 6, 7 - 1, 10 - 1   |
|-----------------------|-------------------------------|
| <b>ABM mode</b>       |                               |
| Abort                 |                               |
| ADF                   |                               |
| Asynchronous          |                               |
| Baud rate             |                               |
| Buffer                |                               |
| Buffering             |                               |
| Cable pinout          |                               |
| Code version          |                               |
| Control block         |                               |
| <b>CRC</b>            |                               |
| стя                   |                               |
| Data                  |                               |
| Data field            |                               |
| DCD                   |                               |
| DCE                   | 5 - 2, 5 - 6, 5 - 7, 5 - 25   |
| Default parameters    |                               |
| DISC                  | 5 - 10, 6 - 1, 7 - 1, 10 - 1  |
| Disconnected mode     |                               |
| DM                    |                               |
| DTE                   | 5 - 2, 5 - 6, 5 - 7, 5 - 25   |
| DTR                   |                               |
| ERRORLEVEL            | 11 - 1                        |
| Frame Reject          |                               |
| FRMR                  | 5 - 10, 5 - 11, 6 - 2, 10 - 2 |
| HDLC                  | 5 - 25, 5 - 27, 5 - 30        |
| I/O port address      | 2 - 1                         |
| Information frames    |                               |
| Errors                |                               |
| Interface converter   |                               |
| Interrupt             |                               |
| IRQ                   |                               |
| ISO                   |                               |
| Jumper                | 2 - 1, 2 - 3                  |
| Factory default       |                               |
| N2                    |                               |
| On board clock source |                               |
| OPP_FLAG              |                               |

| Overrun                       | 5 - 30                    |
|-------------------------------|---------------------------|
| P bit                         | 10 - 1                    |
| <b>PC-DOS</b>                 | 3 - 1                     |
| Poll/Final                    | 5 - 19, 5 - 21            |
| <b>POST setup</b>             | ····· 2 - 1               |
| Programming conventions       | 1 - 1                     |
| Registers                     | 3 - 8                     |
| <b>RS232</b>                  |                           |
| <b>\$502E</b> card            | 2 - 2                     |
| <b>SABM</b> 5 - 5, 5 - 3      | 10, 6 - 1, 10 - 1, 10 - 2 |
| SDLA_TST.502                  | 3 - 1                     |
| Shared memory                 | 3 - 1, 3 - 3, 4 - 1       |
| Software interrupt            | 3 - 8                     |
| Supervisory                   | 5 - 27                    |
| Supervisory frame             | 5 - 7, 5 - 8              |
| <b>T1</b>                     | . 5 - 10, 5 - 25, 10 - 1  |
| <b>T2</b>                     | 5 - 25                    |
| Time stamp                    | 5 - 27, 5 - 30            |
| Trace                         | 5 - 29                    |
| Transmit underruns            | 5 - 13                    |
| UA                            | 6 - 1, 10 - 1             |
| <b>UI</b>                     |                           |
| V.35                          | 2 - 4                     |
| <b>X.21</b>                   | 2 - 4                     |
| <b>X25.502</b>                | 3 - 1, 3 - 2              |
| X25.SDL                       | 3 - 1, 3 - 3              |
| X25_TEST.EXE                  | 3 - 1, 3 - 9              |
| XIP Control Block Structure . |                           |
| XIP.COM                       | 3-1                       |
| Kemoving                      | 3 - 8                     |
|                               |                           |
| XLUAD.EXE                     | ····· 3 - 1, 3 - 2        |